:root{--color-bg: #f0f2f5;--color-surface: #ffffff;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-danger: #dc2626;--color-danger-hover: #b91c1c;--color-success: #16a34a;--color-text: #1f2937;--color-text-muted: #6b7280;--color-border: #e5e7eb;--color-gold: #fbbf24;--color-gold-bg: #fef3c7;--color-silver: #9ca3af;--color-silver-bg: #f3f4f6;--color-bronze: #d97706;--color-bronze-bg: #fef3c7;--display-bg: #0f172a;--display-surface: #1e293b;--display-text: #f1f5f9;--display-accent: #38bdf8;--touch-min: 48px;--radius: 8px;--radius-lg: 12px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased}.layout{min-height:100vh;display:flex;flex-direction:column}.layout-display{min-height:100vh;background:var(--display-bg);color:var(--display-text)}.main{flex:1;padding:24px;max-width:1200px;margin:0 auto;width:100%}.main-display{padding:24px;min-height:100vh}.nav{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:0 16px;display:flex;align-items:center;justify-content:space-between;height:56px}.nav-brand{display:flex;align-items:center;text-decoration:none}.nav-logo{height:34px;width:auto;display:block}.nav-burger-wrap{position:relative}.nav-burger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:10px;background:none;border:none;cursor:pointer;border-radius:var(--radius);transition:background .15s}.nav-burger:hover{background:var(--color-bg)}.nav-burger span{display:block;height:2px;width:100%;background:var(--color-text);border-radius:1px;transition:transform .25s,opacity .2s;transform-origin:center}.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.nav-burger.open span:nth-child(2){opacity:0}.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.nav-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 8px 24px #0000001f;padding:6px;min-width:160px;display:flex;flex-direction:column;gap:2px;z-index:100;opacity:0;transform:translateY(-8px) scale(.95);pointer-events:none;transition:opacity .18s,transform .18s}.nav-menu-open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.nav-link{padding:10px 16px;text-decoration:none;color:var(--color-text-muted);border-radius:var(--radius);font-weight:500;min-height:var(--touch-min);display:flex;align-items:center;transition:background .15s,color .15s}.nav-link:hover{background:var(--color-bg);color:var(--color-text)}.nav-link.active{background:var(--color-primary);color:#fff}.nav-dark{background:var(--display-surface);border-bottom-color:#ffffff14}.nav-dark .nav-burger span{background:var(--display-text)}.nav-dark .nav-burger:hover{background:#ffffff14}.nav-dark .nav-menu{background:var(--display-surface);border-color:#ffffff1f;box-shadow:0 8px 24px #0006}.nav-dark .nav-link{color:#f1f5f999}.nav-dark .nav-link:hover{background:#ffffff14;color:var(--display-text)}.nav-dark .nav-link.active{background:var(--display-accent);color:var(--display-bg)}.card{background:var(--color-surface);border-radius:var(--radius-lg);padding:24px;border:1px solid var(--color-border)}.card h2{margin-bottom:16px;font-size:18px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border:none;border-radius:var(--radius);font-size:15px;font-weight:500;cursor:pointer;min-height:var(--touch-min);transition:background .15s,opacity .15s;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-border)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--color-danger-hover)}.btn-small{padding:6px 12px;font-size:13px;min-height:36px}.btn-large{padding:16px 32px;font-size:18px;min-height:56px}.input{padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:15px;min-height:var(--touch-min);outline:none;transition:border-color .15s;background:var(--color-surface);color:var(--color-text)}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.input-large{font-size:20px;padding:14px 18px;min-height:56px}.input-small{width:80px}.input-score{font-size:32px;padding:16px 20px;min-height:72px;text-align:center;width:100%}.form-inline{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:16px}.input-hint{color:var(--color-text-muted);font-size:14px;margin-top:8px;margin-bottom:8px}.form-error{color:var(--color-danger);font-size:14px;width:100%}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--color-border)}.table th{font-weight:600;font-size:13px;text-transform:uppercase;color:var(--color-text-muted)}.table td.actions{display:flex;gap:6px}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px;color:var(--color-text-muted)}.spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:32px;color:var(--color-text-muted);font-size:15px}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius);padding:16px;color:var(--color-danger);display:flex;align-items:center;gap:12px}.text-muted{color:var(--color-text-muted);font-size:14px}.admin-page h1{margin-bottom:24px}.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}@media(max-width:768px){.admin-grid{grid-template-columns:1fr}}.export-buttons{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.import-section{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin:16px 0;padding-top:16px;border-top:1px solid var(--color-border)}.import-buttons{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.import-info-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;border:1.5px solid var(--color-primary);background:transparent;color:var(--color-primary);font-size:14px;font-weight:700;font-style:italic;font-family:Georgia,Times New Roman,serif;cursor:pointer;padding:0;line-height:1;flex-shrink:0}.import-info-btn:hover{background:var(--color-primary);color:#fff}.import-format-hint{width:100%;font-size:13px;color:var(--color-text-secondary);background:#f0f4ff;padding:6px 12px;border-radius:6px;border:1px solid var(--color-border)}.btn-danger{background:var(--color-danger);color:#fff;border:none}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.import-summary{width:100%;display:flex;align-items:center;gap:10px;font-size:15px;margin-bottom:4px}.import-badge-invalid{font-size:12px;padding:2px 8px;background:#fef2f2;color:var(--color-danger);border:1px solid #fecaca;border-radius:99px;font-weight:600}.import-badge-duplicate{font-size:12px;padding:2px 8px;background:#fffbeb;color:#92400e;border:1px solid #fde68a;border-radius:99px;font-weight:600}.import-preview{width:100%;max-height:300px;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--radius)}.import-preview .table{margin:0;font-size:14px}.import-row-invalid{background:#fef2f2}.import-row-duplicate{background:#fffbeb}.import-status-error{color:var(--color-danger);font-size:13px;font-weight:500}.import-status-dup{color:#92400e;font-size:13px;font-weight:500}.import-status-ok{color:var(--color-success);font-size:13px;font-weight:500}.import-actions{width:100%;display:flex;gap:10px;margin-top:4px}.import-result{width:100%;padding:12px 16px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius);color:var(--color-success);font-weight:500}.entry-page h1{margin-bottom:8px}.entry-header{display:flex;align-items:center;gap:16px;margin-bottom:8px}.breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:20px;font-size:14px;color:var(--color-text-muted)}.breadcrumb-active{font-weight:600;color:var(--color-primary)}.breadcrumb-done{color:var(--color-text)}.breadcrumb-back{background:none;border:none;font:inherit;font-weight:600;color:var(--color-primary);cursor:pointer;padding:2px 6px;margin:-2px -6px;border-radius:var(--radius);transition:background .15s;text-decoration:underline;text-underline-offset:2px}.breadcrumb-back:hover{background:#2563eb14}.breadcrumb-sep{font-size:18px}.selector-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.selector-search{width:120px;padding:6px 10px;font-size:13px;min-height:36px}.selector-sort-bar{display:flex;gap:6px}.selector-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;max-height:60vh;overflow-y:auto;margin-top:12px}.selector-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 4px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;min-height:56px;font-size:14px;text-align:center;transition:background .1s,border-color .1s;gap:1px;overflow:hidden;word-break:break-word}.selector-card:hover{background:#f0f7ff;border-color:var(--color-primary)}.selector-firstname{font-weight:600;font-size:15px}.selector-lastname{color:var(--color-text-muted);font-size:13px}.game-selector h2{margin-bottom:12px}.game-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media(min-width:900px){.game-grid{grid-template-columns:repeat(3,1fr)}}.game-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px;background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;min-height:120px;transition:border-color .15s,transform .1s}.game-card:hover{border-color:var(--color-primary);transform:translateY(-2px)}.game-card-full{opacity:.6}.game-station{font-size:13px;text-transform:uppercase;font-weight:600;color:var(--color-primary)}.game-icon{font-size:36px;line-height:1}.game-heading{display:flex;align-items:center;gap:12px;margin:0 0 16px;font-size:24px;font-weight:700}.game-heading-icon{font-size:36px;line-height:1}.game-name{font-size:18px;font-weight:600}.game-type{font-size:13px;color:var(--color-text-muted)}.game-attempts{font-size:13px;color:var(--color-text-muted);margin-top:4px}.attempt-overview h3{margin-bottom:12px}.attempt-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@media(max-width:600px){.attempt-cards{grid-template-columns:1fr}}.attempt-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px;border-radius:var(--radius-lg);border:2px solid var(--color-border);background:var(--color-surface)}.attempt-filled{background:#f0fdf4;border-color:#bbf7d0}.attempt-best{border-color:var(--color-success);box-shadow:0 0 0 2px #16a34a26}.attempt-empty{border-style:dashed}.attempt-number{font-size:13px;font-weight:600;text-transform:uppercase;color:var(--color-text-muted)}.attempt-score{font-size:28px;font-weight:700}.attempt-badge{font-size:12px;padding:2px 8px;background:var(--color-success);color:#fff;border-radius:99px;font-weight:600}.score-entry-form{max-width:400px;margin:0 auto;text-align:center}.score-entry-form h3{margin-bottom:16px}.score-entry-actions{display:flex;gap:12px;margin-top:24px}.score-entry-actions .btn{flex:1}.score-success{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px;font-size:20px;font-weight:600;color:var(--color-success)}.success-check{font-size:48px}.score-celebration{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px;animation:celebrate-fade .4s ease-out}.celebration-medal{font-size:80px;line-height:1;animation:celebrate-pop .6s cubic-bezier(.175,.885,.32,1.275)}.celebration-text{font-size:28px;font-weight:700;color:var(--color-primary);animation:celebrate-fade .5s ease-out .3s both}@keyframes celebrate-pop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.3);opacity:1}to{transform:scale(1)}}@keyframes celebrate-fade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.display-page{min-height:100vh}.display-back-link{position:absolute;top:12px;left:16px;color:var(--display-text);opacity:.3;text-decoration:none;font-size:14px;padding:8px 12px;border-radius:var(--radius);transition:opacity .2s;z-index:10}.display-back-link:hover{opacity:.8;background:var(--display-surface)}.display-brand{text-align:center;font-size:20px;font-weight:700;color:var(--display-accent);padding:12px;opacity:.7}.display-selector{display:flex;justify-content:center;margin-bottom:24px}.display-dropdown{background:var(--display-surface);color:var(--display-text);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius);padding:10px 20px;font-size:16px;font-weight:500;cursor:pointer;min-width:280px;text-align:center;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.display-dropdown:focus{outline:none;border-color:var(--display-accent);box-shadow:0 0 0 2px #38bdf833}.display-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--display-bg);color:var(--display-text)}.leaderboard{max-width:900px;margin:0 auto}.lb-header{text-align:center;margin-bottom:24px}.lb-station{font-size:14px;text-transform:uppercase;letter-spacing:2px;color:var(--display-accent);font-weight:600}.lb-title{font-size:40px;font-weight:700;margin:4px 0}.lb-type{font-size:16px;opacity:.6}.lb-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;margin-top:8px;-webkit-user-select:none;user-select:none;justify-content:center}.lb-toggle input{display:none}.lb-toggle-slider{position:relative;width:44px;height:24px;background:#ffffff26;border-radius:12px;transition:background .2s;flex-shrink:0}.lb-toggle-slider:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s}.lb-toggle input:checked+.lb-toggle-slider{background:var(--display-accent)}.lb-toggle input:checked+.lb-toggle-slider:after{transform:translate(20px)}.lb-toggle-label{font-size:14px;opacity:.7;color:var(--display-text)}.lb-toggle input:checked~.lb-toggle-label{opacity:1}.lb-list{display:flex;flex-direction:column;gap:6px}.lb-empty{text-align:center;padding:60px;font-size:20px;opacity:.5}.lb-card{display:flex;align-items:center;gap:16px;padding:14px 20px;background:var(--display-surface);border-radius:var(--radius);min-height:60px;transition:background .3s}.lb-card.medal-gold{background:linear-gradient(135deg,#92400e,#78350f);box-shadow:0 0 20px #fbbf2433}.lb-card.medal-silver{background:linear-gradient(135deg,#374151,#1f2937);box-shadow:0 0 12px #9ca3af26}.lb-card.medal-bronze{background:linear-gradient(135deg,#78350f,#451a03);box-shadow:0 0 12px #d9770626}.lb-card-new{animation:pulse 1.5s ease-in-out}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02);box-shadow:0 0 20px #38bdf84d}}.lb-rank{font-size:28px;font-weight:700;min-width:50px;text-align:center}.lb-info{flex:1;display:flex;flex-direction:column}.lb-name{font-size:22px;font-weight:600}.lb-age{font-size:14px;opacity:.6}.lb-score{font-size:24px;font-weight:700;color:var(--display-accent);text-align:right}.auto-rotate{transition:opacity .4s ease}.fade-out{opacity:0}.fade-in{opacity:1}.rotate-dots{display:flex;justify-content:center;gap:8px;margin-top:24px}.rotate-dot{width:10px;height:10px;border-radius:50%;background:var(--display-surface);transition:background .3s}.rotate-dot-active{background:var(--display-accent)}.layout .leaderboard{color:var(--color-text)}.layout .lb-card{background:var(--color-surface);border:1px solid var(--color-border)}.layout .lb-card.medal-gold{background:var(--color-gold-bg);border-color:var(--color-gold)}.layout .lb-card.medal-silver{background:var(--color-silver-bg);border-color:var(--color-silver)}.layout .lb-card.medal-bronze{background:var(--color-bronze-bg);border-color:var(--color-bronze)}.layout .lb-score{color:var(--color-primary)}@media(max-width:767px){.nav-link-admin{display:none!important}}.nav-divider{border:none;border-top:1px solid var(--color-border);margin:4px 0}.nav-theme-toggle{cursor:pointer;border:none;background:none;font:inherit;width:100%;text-align:left}html.dark-mode{--color-bg: #0f172a;--color-surface: #1e293b;--color-primary: #60a5fa;--color-primary-hover: #3b82f6;--color-danger: #f87171;--color-danger-hover: #ef4444;--color-success: #4ade80;--color-text: #f1f5f9;--color-text-muted: #94a3b8;--color-border: #334155;--color-gold-bg: rgba(251, 191, 36, .12);--color-silver-bg: rgba(156, 163, 175, .1);--color-bronze-bg: rgba(217, 119, 6, .12)}html.dark-mode .nav{border-bottom-color:#ffffff0f;box-shadow:0 1px #ffffff08}html.dark-mode .nav-burger:hover{background:#ffffff14}html.dark-mode .nav-menu{box-shadow:0 8px 24px #00000080;border-color:#ffffff14}html.dark-mode .nav-link:hover{background:#ffffff14}html.dark-mode .nav-link.active{background:var(--color-primary);color:#0f172a}html.dark-mode .nav-divider{border-top-color:#ffffff14}html.dark-mode .card{border:1px solid transparent;background:linear-gradient(var(--color-surface),var(--color-surface)) padding-box,linear-gradient(135deg,#6366f1,#8b5cf6,#a855f7,#ec4899) border-box}html.dark-mode .game-card{border:2px solid transparent;background:linear-gradient(var(--color-surface),var(--color-surface)) padding-box,linear-gradient(135deg,#22d3ee,#3b82f6,#6366f1) border-box}html.dark-mode .game-card:hover{border-color:transparent;background:linear-gradient(#1e3a5f,#1e3a5f) padding-box,linear-gradient(135deg,#22d3ee,#60a5fa,#818cf8) border-box;box-shadow:0 4px 20px #22d3ee26}html.dark-mode .game-card-full{opacity:.5}html.dark-mode .attempt-card{border:2px solid transparent;background:linear-gradient(var(--color-surface),var(--color-surface)) padding-box,linear-gradient(135deg,#2dd4bf,#14b8a6,#22d3ee) border-box}html.dark-mode .attempt-filled{background:linear-gradient(#0f2a1f,#0f2a1f) padding-box,linear-gradient(135deg,#4ade80,#22c55e,#10b981) border-box}html.dark-mode .attempt-best{box-shadow:0 0 12px #4ade8033}html.dark-mode .attempt-empty{border-style:dashed}html.dark-mode .selector-card{border:1px solid transparent;background:linear-gradient(var(--color-surface),var(--color-surface)) padding-box,linear-gradient(135deg,#475569,#64748b,#475569) border-box}html.dark-mode .selector-firstname,html.dark-mode .game-name{color:#fff}html.dark-mode .selector-card:hover{background:linear-gradient(#1e3a5f,#1e3a5f) padding-box,linear-gradient(135deg,#60a5fa,#818cf8,#a78bfa) border-box;box-shadow:0 2px 12px #60a5fa26}html.dark-mode .input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #60a5fa33}html.dark-mode .breadcrumb-back:hover{background:#60a5fa1f}html.dark-mode .error-message{background:#f871711a;border-color:#f871714d}html.dark-mode .import-format-hint{background:#60a5fa14;border-color:var(--color-border);color:var(--color-text-muted)}html.dark-mode .import-badge-invalid{background:#f8717126;border-color:#f871714d;color:#fca5a5}html.dark-mode .import-badge-duplicate{background:#fbbf241f;border-color:#fbbf244d;color:#fcd34d}html.dark-mode .import-row-invalid{background:#f8717114}html.dark-mode .import-row-duplicate{background:#fbbf240f}html.dark-mode .import-result{background:#4ade801a;border-color:#4ade804d;color:var(--color-success)}html.dark-mode .input-score{background:var(--color-surface);color:var(--color-text)}html.dark-mode .table th{color:var(--color-text-muted)}html.dark-mode .table td,html.dark-mode .table th{border-bottom-color:var(--color-border)}html.dark-mode .import-preview{border-color:var(--color-border)}html.dark-mode .celebration-text{color:var(--color-primary)}html.dark-mode .spinner{border-color:var(--color-border);border-top-color:var(--color-primary)}
