:root{--bg:#0f1117;--surface:#1a1d27;--surface2:#22263a;--border:#2a2e42;--text:#e2e4f0;--muted:#6b7097;--accent:#6366f1}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6}.main-content{max-width:1100px;margin:0 auto;padding:2rem 1.5rem}.page{animation:.2s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.navbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:100;flex-wrap:wrap;justify-content:space-between;align-items:center;height:60px;padding:0 2rem;display:flex;position:sticky;top:0}.navbar-brand{color:var(--accent);letter-spacing:-.01em;font-size:1.15rem;font-weight:700}.navbar-links{gap:.25rem;display:flex}.nav-link{color:var(--muted);border-radius:6px;padding:.4rem .9rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .15s,background .15s}.nav-link:hover{color:var(--text);background:var(--surface2)}.nav-link.active{color:var(--accent);background:#6366f11f}.navbar-user{align-items:center;gap:.6rem;display:flex}.navbar-avatar{object-fit:cover;border:2px solid var(--accent);border-radius:50%;width:32px;height:32px}.navbar-username{color:var(--text);font-size:.88rem;font-weight:600}.navbar-logout{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;padding:.3rem .7rem;font-family:inherit;font-size:.82rem;transition:border-color .15s,color .15s}.navbar-logout:hover{color:#f87171;border-color:#f87171}.hamburger{cursor:pointer;background:0 0;border:none;border-radius:6px;flex-direction:column;justify-content:center;gap:5px;padding:.4rem;display:none}.hamburger span{background:var(--text);transform-origin:50%;border-radius:2px;width:22px;height:2px;transition:transform .25s,opacity .25s;display:block}.hamburger.open span:first-child{transform:translateY(7px)rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-menu{background:var(--surface);border-top:1px solid var(--border);flex-direction:column;gap:.25rem;width:100%;padding:.75rem 1.25rem 1rem;display:none}.mobile-user{border-bottom:1px solid var(--border);align-items:center;gap:.6rem;margin-bottom:.5rem;padding:.5rem 0 .75rem;display:flex}.mobile-link{color:var(--muted);border-radius:7px;padding:.65rem .75rem;font-size:.95rem;font-weight:500;text-decoration:none;transition:color .15s,background .15s}.mobile-link:hover{color:var(--text);background:var(--surface2)}.mobile-link.active{color:var(--accent);background:#6366f11f}.mobile-logout{border:1px solid var(--border);color:var(--muted);cursor:pointer;text-align:left;background:0 0;border-radius:7px;margin-top:.5rem;padding:.6rem .75rem;font-family:inherit;font-size:.88rem;transition:border-color .15s,color .15s}.mobile-logout:hover{color:#f87171;border-color:#f87171}@media (width<=640px){.navbar{padding:0 1.25rem}.navbar-links,.navbar-user{display:none}.hamburger,.mobile-menu{display:flex}}.landing{background:var(--bg);flex-direction:column;align-items:center;min-height:100vh;padding:0 1.5rem 4rem;display:flex}.landing-hero{text-align:center;flex-direction:column;align-items:center;max-width:560px;padding:5rem 1rem 3.5rem;display:flex}.landing-logo{filter:drop-shadow(0 0 24px #6366f180);margin-bottom:.5rem;font-size:4rem}.landing-title{color:var(--text);letter-spacing:-.02em;background:linear-gradient(135deg, #e2e4f0 0%, var(--accent) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 .75rem;font-size:clamp(2.2rem,6vw,3.5rem);font-weight:800}.landing-rules{color:var(--muted);text-align:center;flex-direction:column;gap:.6rem;max-width:460px;margin-bottom:2rem;font-size:.95rem;line-height:1.7;display:flex}.landing-cta{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:.85rem 2.5rem;font-family:inherit;font-size:1rem;font-weight:700;transition:opacity .15s,transform .1s,box-shadow .15s;box-shadow:0 4px 20px #6366f166}.landing-cta:hover{opacity:.88;transform:translateY(-2px)}.landing-cta:active{transform:scale(.97)}.landing-features{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;width:100%;max-width:780px;display:grid}.landing-feature-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:.5rem;padding:1.5rem 1.25rem;transition:border-color .15s,transform .15s;display:flex}.landing-feature-card:hover{border-color:var(--accent);transform:translateY(-3px)}.landing-feature-icon{font-size:1.8rem}.landing-feature-label{color:var(--text);margin:0;font-size:1rem;font-weight:700}.landing-feature-desc{color:var(--muted);margin:0;font-size:.85rem;line-height:1.5}.signin-bg{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.signin-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:1rem;width:100%;max-width:380px;padding:2.5rem 2rem;display:flex;box-shadow:0 8px 40px #0006}.signin-logo{text-align:center;font-size:2.5rem}.signin-title{text-align:center;color:var(--accent);margin:0;font-size:1.5rem;font-weight:700}.signin-sub{text-align:center;color:var(--muted);margin-top:-.5rem;font-size:.88rem}.signin-error{color:#f87171;text-align:center;background:#ef44441f;border:1px solid #ef444459;border-radius:7px;padding:.6rem .85rem;font-size:.85rem}.signin-label{color:var(--muted);flex-direction:column;gap:.4rem;font-size:.85rem;font-weight:600;display:flex}.signin-input{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:7px;outline:none;padding:.65rem .85rem;font-family:inherit;font-size:.95rem;transition:border-color .15s}.signin-input:focus{border-color:var(--accent)}.signin-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:7px;margin-top:.25rem;padding:.75rem;font-family:inherit;font-size:.95rem;font-weight:700;transition:opacity .15s,transform .1s}.signin-btn:hover{opacity:.88}.signin-btn:active{transform:scale(.98)}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}.signin-card.shake{animation:.45s shake}.leaderboard-page h1{margin-bottom:.25rem;font-size:2rem}.subtitle{color:var(--muted);margin-bottom:1.5rem;font-size:.95rem}.table-wrapper{border:1px solid var(--border);border-radius:10px;overflow-x:auto}.leaderboard-table{border-collapse:collapse;width:100%;font-size:.95rem}.leaderboard-table thead{background:var(--surface2)}.leaderboard-table th{text-align:left;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;padding:.75rem 1rem;font-size:.75rem;font-weight:600}.leaderboard-table td{border-top:1px solid var(--border);padding:.75rem 1rem}.leaderboard-table tbody tr:hover{background:var(--surface2)}.leaderboard-table .top-three td{background:#6366f10f}.rank-cell{width:60px;font-size:1.15rem;font-weight:700}.player-cell{align-items:center;gap:.75rem;display:flex}.player-avatar{object-fit:cover;border:2px solid var(--border);border-radius:50%;flex-shrink:0;width:56px;height:56px}.top-three .player-avatar{border-color:var(--accent)}.player-info{flex-direction:column;gap:.1rem;display:flex}.player-name{font-weight:600;line-height:1.2}.player-country{font-size:1rem;line-height:1}.score-cell{color:var(--accent);font-weight:700}.challenges-page h1{margin-bottom:.25rem;font-size:2rem}.challenges-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;display:grid}.challenge-card{background:var(--surface);border:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:10px;outline:none;flex-direction:column;gap:.4rem;padding:1.25rem;transition:transform .15s,box-shadow .15s,border-color .15s;display:flex}.challenge-card:hover:not(.uploading){border-color:var(--accent);transform:translateY(-3px);box-shadow:0 6px 20px #00000059}.challenge-card:focus-visible{border-color:var(--accent);box-shadow:0 0 0 3px #6366f14d}.challenge-card.done{border-color:#4ade80}.challenge-card.error{border-color:#f87171}.challenge-card.uploading{cursor:not-allowed;opacity:.8}.card-header{justify-content:space-between;align-items:center;margin-bottom:.25rem;display:flex}.card-id{color:var(--muted);font-size:.75rem;font-weight:600}.badge{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;padding:.2rem .55rem;font-size:.7rem;font-weight:700}.badge-easy{color:#4ade80;background:#22c55e26}.badge-medium{color:#facc15;background:#eab30826}.badge-hard{color:#f87171;background:#ef444426}.card-title{margin:0;font-size:1.05rem;font-weight:600}.card-category{color:var(--muted);margin:0;font-size:.82rem}.card-footer{justify-content:space-between;align-items:center;margin-top:auto;padding-top:.75rem;font-size:.82rem;display:flex}.points{color:var(--accent);font-weight:700}.solves{color:var(--muted)}.upload-area{border-top:1px solid var(--border);flex-direction:column;gap:.35rem;min-height:28px;margin-top:.75rem;padding-top:.75rem;display:flex}.upload-hint{color:var(--muted);font-size:.8rem}.upload-bar-track{background:var(--surface2);border-radius:999px;height:5px;overflow:hidden}.upload-bar-fill{background:var(--accent);border-radius:999px;height:100%;transition:width .2s}.upload-pct{color:var(--muted);font-size:.75rem}.upload-done{color:#4ade80;font-size:.82rem;font-weight:600}.upload-error{color:#f87171;font-size:.78rem}.upload-preview{object-fit:cover;border:1px solid var(--border);border-radius:7px;width:100%;max-height:140px;margin-top:.5rem}.vote-page h1{margin-bottom:.25rem;font-size:2rem}.vote-empty{color:var(--muted);margin-top:1rem;font-size:.95rem}.vote-challenge{margin-bottom:2.5rem}.vote-challenge-title{color:var(--text);align-items:center;gap:.6rem;margin-bottom:1rem;font-size:1.1rem;font-weight:700;display:flex}.vote-challenge-id{color:var(--muted);background:var(--surface2);border:1px solid var(--border);border-radius:5px;flex-shrink:0;padding:.15rem .45rem;font-size:.75rem;font-weight:700}.vote-photos-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.85rem;display:grid}.vote-photo-card{background:var(--surface);border:2px solid var(--border);cursor:pointer;text-align:left;color:var(--text);border-radius:10px;padding:0;font-family:inherit;transition:border-color .15s,transform .15s,box-shadow .15s;position:relative;overflow:hidden}.vote-photo-card:hover:not(:disabled){border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 18px #6366f133}.vote-photo-card.chosen{border-color:var(--accent);box-shadow:0 0 0 3px #6366f140}.vote-photo-card:disabled{cursor:not-allowed}.vote-photo{aspect-ratio:4/3;object-fit:cover;width:100%;display:block}.vote-photo-footer{justify-content:space-between;align-items:center;padding:.55rem .75rem;font-size:.82rem;display:flex}.vote-photo-player{color:var(--text);font-weight:600}.vote-photo-count{color:var(--muted);font-size:.75rem}.vote-chosen-badge{background:var(--accent);color:#fff;text-transform:uppercase;letter-spacing:.04em;border-radius:999px;padding:.2rem .5rem;font-size:.68rem;font-weight:700;position:absolute;top:.5rem;right:.5rem}.teams-page h1{margin-bottom:.25rem;font-size:2rem}.teams-list{flex-direction:column;gap:1.25rem;max-width:780px;display:flex}.team-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}.team-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.team-rank-name{align-items:center;gap:.65rem;display:flex}.team-rank{color:var(--muted);background:var(--surface2);border:1px solid var(--border);border-radius:5px;padding:.15rem .45rem;font-size:.75rem;font-weight:700}.team-name{color:var(--text);font-size:1.1rem;font-weight:700}.team-total{color:var(--accent);font-size:1.2rem;font-weight:800}.team-members{flex-wrap:wrap;gap:.75rem;padding:1rem 1.25rem;display:flex}.team-member{flex-direction:column;flex:1;align-items:center;gap:.35rem;min-width:80px;display:flex}.team-member-avatar{object-fit:cover;border:2px solid var(--border);border-radius:50%;width:52px;height:52px}.team-member-name{color:var(--text);font-size:.82rem;font-weight:600}.team-member-score{color:var(--muted);font-size:.75rem}.admin-page h1{margin-bottom:.25rem;font-size:2rem}.admin-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.admin-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-direction:column;display:flex;overflow:hidden}.admin-card-meta{flex-direction:column;gap:.2rem;padding:.9rem 1rem .75rem;display:flex}.admin-player{color:var(--text);font-size:.95rem;font-weight:700}.admin-challenge-title{color:var(--muted);font-size:.8rem}.admin-photo{aspect-ratio:4/3;object-fit:cover;border-top:1px solid var(--border);border-bottom:1px solid var(--border);width:100%}.admin-actions{gap:.5rem;margin:.85rem 1rem;display:flex}.admin-approve-btn,.admin-decline-btn{cursor:pointer;border-radius:7px;flex:1;padding:.55rem .75rem;font-size:.88rem;font-weight:600;transition:background .15s,opacity .15s}.admin-approve-btn{color:#4ade80;background:#4ade801f;border:1px solid #4ade804d}.admin-approve-btn:hover:not(:disabled){background:#4ade8038}.admin-decline-btn{color:#f87171;background:#f871711f;border:1px solid #f871714d}.admin-decline-btn:hover:not(:disabled){background:#f8717138}.admin-approve-btn:disabled,.admin-decline-btn:disabled{opacity:.5;cursor:not-allowed}.admin-card--suspicious{border-color:#facc15}.admin-flag{color:#facc15;margin-top:.25rem;font-size:.75rem;display:block}
