.header{background-color:#fff;border-bottom:1px solid #e0e0e0;position:sticky;top:0;z-index:1000;box-shadow:0 2px 4px #0000001a}.header-container{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;align-items:center;justify-content:space-between;height:64px}.header-left{display:flex;align-items:center;gap:2rem}.header-logo{display:flex;align-items:center;cursor:pointer;text-decoration:none;color:#333;font-size:1.5rem;font-weight:700;transition:opacity .2s ease}.header-logo:hover{opacity:.8}.logo-image{height:32px;width:auto;margin-right:.5rem}.logo-text{color:#2196f3}.header-nav{display:flex;align-items:center;gap:1.5rem}.nav-item-container{position:relative;display:inline-block}.nav-item{color:#666;font-size:1rem;font-weight:400;padding:.5rem 0;cursor:pointer;text-decoration:none;border-bottom:2px solid transparent;transition:all .2s ease;font-family:inherit;display:inline-block}.nav-item:hover{border-bottom-color:#2196f3}.nav-item.active{color:#2196f3;font-weight:600;border-bottom-color:#2196f3}.nav-dropdown{position:absolute;top:100%;left:0;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;box-shadow:0 4px 6px #0000001a;min-width:120px;z-index:1000;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s ease}.nav-item-container:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.nav-dropdown-item{display:block;padding:.75rem 1rem;color:#666;text-decoration:none;font-size:.9rem;transition:all .2s ease;border-bottom:1px solid #f0f0f0}.nav-dropdown-item:last-child{border-bottom:none}.nav-dropdown-item:hover{background-color:#f5f5f5;color:#2196f3}.header-auth{display:flex;align-items:center;gap:.5rem}.auth-button{padding:.5rem 1rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;cursor:pointer;transition:all .2s ease;text-decoration:none;font-family:inherit}.signin-button{background-color:transparent;color:#666}.signin-button:hover{background-color:#f5f5f5}.signup-button{background-color:#2196f3;color:#fff;border-color:#2196f3}.signup-button:hover{background-color:#1976d2;border-color:#1976d2}.logout-button{background-color:#f44336;color:#fff;border-color:#f44336}.logout-button:hover{background-color:#d32f2f;border-color:#d32f2f}.user-menu{display:flex;align-items:center;gap:1rem}.user-welcome{color:#666;font-size:.9rem;font-weight:500}.admin-badge{color:#ff9800;font-size:.8rem;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.1)}.mobile-menu-button{display:none;background:none;border:none;cursor:pointer;padding:.5rem;z-index:1001}.hamburger{display:flex;flex-direction:column;justify-content:space-between;width:24px;height:18px}.hamburger span{display:block;height:2px;width:100%;background-color:#333;border-radius:1px;transition:all .3s ease}.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.mobile-menu{position:fixed;top:64px;left:0;right:0;background-color:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 4px 6px #0000001a;z-index:999;transform:translateY(-100%);opacity:0;transition:all .3s ease;pointer-events:none}.mobile-menu.open{transform:translateY(0);opacity:1;pointer-events:auto}.mobile-nav{padding:1rem;display:flex;flex-direction:column}.mobile-nav-item-container{border-bottom:1px solid #f0f0f0}.mobile-nav-item-container:last-child{border-bottom:none}.mobile-nav-item{color:#333;font-size:1.1rem;font-weight:400;padding:.75rem 0;cursor:pointer;text-align:left;transition:color .2s ease;font-family:inherit;text-decoration:none;display:block}.mobile-nav-item:hover{color:#2196f3}.mobile-nav-subitems{padding-left:1rem;background-color:#f9f9f9}.mobile-nav-subitem{color:#666;font-size:1rem;font-weight:400;padding:.5rem 0;cursor:pointer;text-align:left;transition:color .2s ease;font-family:inherit;text-decoration:none;display:block;border-bottom:1px solid #f0f0f0}.mobile-nav-subitem:last-child{border-bottom:none}.mobile-nav-subitem:hover{color:#2196f3}.mobile-auth{display:flex;flex-direction:column;gap:.5rem;padding-top:1rem;border-top:1px solid #f0f0f0;margin-top:1rem}.mobile-auth-button{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;cursor:pointer;transition:all .2s ease;text-align:center;font-family:inherit}.mobile-auth-button.signin-button{background-color:transparent;color:#666}.mobile-auth-button.signin-button:hover{background-color:#f5f5f5}.mobile-auth-button.signup-button{background-color:#2196f3;color:#fff;border-color:#2196f3}.mobile-auth-button.signup-button:hover{background-color:#1976d2;border-color:#1976d2}.mobile-auth-button.logout-button{background-color:#f44336;color:#fff;border-color:#f44336}.mobile-auth-button.logout-button:hover{background-color:#d32f2f;border-color:#d32f2f}.mobile-user-menu{display:flex;flex-direction:column;gap:.5rem}.mobile-user-welcome{color:#666;font-size:1rem;font-weight:500;padding:.5rem 0;text-align:center}.mobile-user-welcome .admin-badge{display:block;margin-top:.25rem}.mobile-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:998;opacity:0;animation:fadeIn .3s ease forwards}@keyframes fadeIn{to{opacity:1}}@media (max-width: 768px){.desktop-nav,.desktop-auth{display:none}.mobile-menu-button{display:block}.header-container{padding:0 1rem}.logo-text{font-size:1.25rem}.logo-image{height:28px}}@media (min-width: 769px){.mobile-menu,.mobile-menu-overlay{display:none}}.nav-item:focus,.auth-button:focus,.mobile-nav-item:focus,.mobile-auth-button:focus,.mobile-menu-button:focus{outline:2px solid #2196f3;outline-offset:2px}body.mobile-menu-open{overflow:hidden}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fafafa;color:#333;line-height:1.6}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}button{font-family:inherit;font-size:inherit;transition:all .2s ease}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 8px #00000026}button:active:not(:disabled){transform:translateY(0)}button:disabled{opacity:.6;cursor:not-allowed}input,textarea,select{font-family:inherit;font-size:inherit;transition:border-color .2s ease,box-shadow .2s ease}input:focus,textarea:focus,select:focus{outline:none;border-color:#2196f3!important;box-shadow:0 0 0 2px #2196f333}.card{background:white;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 1px 3px #0000001a;transition:box-shadow .2s ease,transform .2s ease}.card:hover{box-shadow:0 2px 8px #00000026;transform:translateY(-1px)}.card-clickable{cursor:pointer}.card-selected{border-color:#2196f3;box-shadow:0 2px 8px #2196f34d}.badge{display:inline-flex;align-items:center;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.badge-public{background-color:#e8f5e8;color:#2e7d32}.badge-private{background-color:#fff3e0;color:#f57c00}.badge-game{background-color:#f3e5f5;color:#7b1fa2}.badge-format{background-color:#e3f2fd;color:#1976d2}.badge-tag{background-color:#fff3e0;color:#f57c00}.badge-version{background-color:#e8f5e8;color:#2e7d32}.badge-cards{background-color:#fff3e0;color:#f57c00}.badge-type{background-color:#f3e5f5;color:#7b1fa2}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-out}@media (max-width: 768px){.hide-mobile{display:none!important}.flex-mobile-column{flex-direction:column!important}.gap-mobile-small{gap:.5rem!important}}.error-container{padding:.75rem;background-color:#ffebee;border:1px solid #ffcdd2;border-radius:4px;color:#c62828}.success-container{padding:.75rem;background-color:#e8f5e8;border:1px solid #c8e6c9;border-radius:4px;color:#2e7d32}.warning-container{padding:.75rem;background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;color:#856404}.info-container{padding:.75rem;background-color:#e3f2fd;border:1px solid #bbdefb;border-radius:4px;color:#1976d2}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-content{background:white;border-radius:8px;box-shadow:0 4px 20px #00000026;max-height:90vh;overflow-y:auto;animation:fadeIn .3s ease-out}.code{font-family:Monaco,Menlo,Ubuntu Mono,monospace;background-color:#f5f5f5;padding:.25rem .5rem;border-radius:4px;font-size:.9em}.code-block{font-family:Monaco,Menlo,Ubuntu Mono,monospace;background-color:#f5f5f5;padding:1rem;border-radius:4px;border:1px solid #e0e0e0;overflow-x:auto;white-space:pre-wrap;font-size:.85em;line-height:1.5}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-bold{font-weight:700}.font-normal{font-weight:400}.text-sm{font-size:.875rem}.text-base{font-size:1rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-gray-500{color:#666}.text-gray-600{color:#555}.text-gray-700{color:#444}.text-gray-800{color:#333}.bg-gray-50{background-color:#fafafa}.bg-gray-100{background-color:#f5f5f5}.bg-white{background-color:#fff}.border{border:1px solid #e0e0e0}.border-t{border-top:1px solid #e0e0e0}.border-b{border-bottom:1px solid #e0e0e0}.border-l{border-left:1px solid #e0e0e0}.border-r{border-right:1px solid #e0e0e0}.rounded{border-radius:4px}.rounded-lg{border-radius:8px}.shadow{box-shadow:0 1px 3px #0000001a}.shadow-lg{box-shadow:0 4px 20px #00000026}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.m-1{margin:.25rem}.m-2{margin:.5rem}.m-3{margin:.75rem}.m-4{margin:1rem}.m-6{margin:1.5rem}.m-8{margin:2rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.w-full{width:100%}.h-full{height:100%}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-y-auto{overflow-y:auto}.overflow-x-auto{overflow-x:auto}*:focus-visible{outline:2px solid #2196f3;outline-offset:2px}@media (prefers-color-scheme: dark){body{background-color:#121212;color:#e0e0e0}.card{background-color:#1e1e1e;border-color:#333}.modal-content{background-color:#1e1e1e}.code,.code-block{background-color:#2a2a2a;border-color:#444}.bg-gray-50{background-color:#1a1a1a}.bg-gray-100{background-color:#2a2a2a}.bg-white{background-color:#1e1e1e}.border{border-color:#333}.border-t{border-top-color:#333}.border-b{border-bottom-color:#333}.border-l{border-left-color:#333}.border-r{border-right-color:#333}}
