:root{--brand: #008cdd;--brand-2: #30a2e4;--brand-light: #7dc5ee;--brand-dark: #015e94;--navy: #091747;--grad: linear-gradient(120deg, #30a2e4, #008cdd);--green: #69c765;--coral: #ff8585;--gold: #fab515;--bg: #eef5fb;--bg-grad: radial-gradient(1100px 520px at 12% -8%, #dcecfb 0%, transparent 60%), radial-gradient(900px 480px at 100% 0%, #e6f4fb 0%, transparent 55%), var(--bg);--surface: #ffffff;--surface-2: #f3f7fb;--surface-3: #e7eef6;--border: #d7e3ef;--text: #16263a;--muted: #5f7286;--faint: #94a3b4;--danger: #e5484d;--ok: var(--green);--radius: 16px;--radius-sm: 10px;--shadow: 0 12px 30px -16px rgba(9, 23, 71, .28);--shadow-sm: 0 4px 14px -8px rgba(9, 23, 71, .25);--map-empty: #dde9f4;--map-stroke: #ffffff;--font: "Open Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, system-ui, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font);color:var(--text);background:var(--bg-grad);background-attachment:fixed;-webkit-font-smoothing:antialiased;line-height:1.5}.container{width:100%;max-width:880px;margin:0 auto;padding:24px 20px 64px}.container.wide{max-width:1100px}.brand{display:flex;align-items:center;gap:12px;margin-bottom:28px}.brand-home{display:flex;align-items:center;gap:12px;flex:1;min-width:0;text-decoration:none;color:inherit;border-radius:12px}.brand-home:hover .logo{filter:brightness(1.07)}.brand .logo{width:42px;height:42px;border-radius:12px;background:var(--grad);display:grid;place-items:center;font-size:21px;box-shadow:var(--shadow-sm)}.brand h1{font-size:20px;margin:0;letter-spacing:-.02em;color:var(--navy);font-weight:800}.brand .tag{color:var(--muted);font-size:13px;margin:0}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}.card+.card{margin-top:18px}.card h2{margin:0 0 4px;font-size:17px;letter-spacing:-.01em;color:var(--navy)}.card .sub{color:var(--muted);font-size:13px;margin:0 0 18px}.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.spread{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.grow{flex:1;min-width:0}.muted{color:var(--muted)}.faint{color:var(--faint)}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);background:var(--surface);color:var(--text);font:inherit;font-weight:600;font-size:14px;padding:11px 18px;border-radius:var(--radius-sm);cursor:pointer;transition:transform .06s ease,background .15s ease,border-color .15s ease,box-shadow .15s,opacity .15s;display:inline-flex;align-items:center;gap:8px;white-space:nowrap}.btn:hover{background:var(--surface-2);border-color:var(--brand-light)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--grad);border-color:transparent;color:#fff;box-shadow:var(--shadow-sm)}.btn.primary:hover{filter:brightness(1.06);background:var(--grad);border-color:transparent}.btn.spotify{background:#1db954;border-color:transparent;color:#fff}.btn.spotify:hover{filter:brightness(1.06);background:#1db954;border-color:transparent}.btn.ghost{background:transparent}.btn.danger{color:var(--danger);border-color:#f3c9cb;background:#fdeced}.btn.danger:hover{background:#fbdcde;border-color:var(--danger)}.btn.lg{padding:14px 24px;font-size:16px}.btn.sm{padding:7px 12px;font-size:13px}.btn.block{width:100%;justify-content:center}.input{width:100%;font:inherit;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;outline:none;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #008cdd29}.input::placeholder{color:var(--faint)}.input.code-input{text-transform:uppercase;letter-spacing:.35em;font-weight:800;text-align:center;font-size:22px;padding:16px;color:var(--navy)}.field-label{font-size:12px;color:var(--muted);margin-bottom:6px;display:block;font-weight:600}.roles{display:grid;gap:16px;grid-template-columns:1fr 1fr}.role{display:block;text-align:left;padding:26px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);cursor:pointer;text-decoration:none;color:inherit;transition:transform .1s,border-color .15s,box-shadow .15s}.role:hover{transform:translateY(-3px);border-color:var(--brand);box-shadow:var(--shadow)}.role .ico{font-size:30px}.role h3{margin:12px 0 4px;font-size:18px;color:var(--navy)}.role p{margin:0;color:var(--muted);font-size:13px}.code-big{font-size:clamp(40px,9vw,76px);font-weight:800;letter-spacing:.12em;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1;margin:0}.join-url{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:13px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;word-break:break-all;color:var(--muted)}.qr{background:#fff;padding:12px;border-radius:14px;line-height:0;border:1px solid var(--border)}.qr img,.qr canvas{display:block;width:168px;height:168px}.count-num{font-size:44px;font-weight:800;line-height:1;color:var(--navy)}.count-num .of{font-size:20px;color:var(--muted);font-weight:600}.meter{height:10px;border-radius:999px;background:var(--surface-3);overflow:hidden;margin-top:12px}.meter>span{display:block;height:100%;background:var(--grad);transition:width .4s ease}.meter>span.indet{width:35%;animation:indet 1.1s ease-in-out infinite}@keyframes indet{0%{margin-left:-35%}to{margin-left:100%}}.analyze-progress{margin:16px 0 4px}.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;padding:4px 10px;border-radius:999px;background:var(--surface-3);color:var(--muted)}.pill.live{color:#1f8f3a;background:#e4f7e6}.pill.live .dot{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulse 1.8s infinite}.pill.closed{color:var(--danger);background:#fdeced}@keyframes pulse{0%{box-shadow:0 0 #69c76580}70%{box-shadow:0 0 0 7px #69c76500}to{box-shadow:0 0 #69c76500}}.tracks{display:flex;flex-direction:column;gap:8px}.track{display:flex;align-items:center;gap:12px;padding:8px;border-radius:12px;background:var(--surface-2);border:1px solid transparent}.track:hover{border-color:var(--border)}.track .art{width:46px;height:46px;border-radius:8px;object-fit:cover;background:var(--surface-3);flex:none}.track .art.ph{display:grid;place-items:center;font-size:18px;color:var(--faint)}.track .t-name{font-weight:600;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track .t-sub{color:var(--muted);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.track .t-by{color:var(--faint);font-size:11px;flex:none}.exp-badge{display:inline-grid;place-items:center;width:15px;height:15px;margin-left:7px;border-radius:3px;background:var(--surface-3);color:var(--muted);font-size:9px;font-weight:800;vertical-align:middle}.track .idx{width:22px;text-align:center;color:var(--faint);font-size:13px;font-variant-numeric:tabular-nums;flex:none}.track-svc{flex:none;display:inline-flex;align-items:center;padding:2px 4px;text-decoration:none;border-radius:8px}.track-svc img{height:20px;width:auto;display:block;opacity:.85;transition:opacity .15s,transform .06s}.track-svc:hover img{opacity:1;transform:scale(1.08)}.track-del{flex:none;width:28px;height:28px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--faint);font-size:18px;line-height:1;cursor:pointer;display:grid;place-items:center;padding:0;transition:color .15s,border-color .15s,background .15s}.track-del:hover{color:var(--danger);border-color:#f3c9cb;background:#fdeced}.track.fogged{opacity:.8}.art.fog-art{background:var(--surface-3)}.fog-dots{color:var(--faint);letter-spacing:4px;font-size:14px;line-height:1.5;-webkit-user-select:none;user-select:none}.fog-dots.short{font-size:12px;opacity:.6}.empty{text-align:center;color:var(--faint);padding:28px 12px;font-size:14px}.stat-grid{display:grid;gap:14px;grid-template-columns:repeat(3,1fr);margin-bottom:8px}.stat{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:14px;text-align:center}.stat .v{font-size:26px;font-weight:800;color:var(--brand-dark)}.stat .l{color:var(--muted);font-size:12px}.bars{display:flex;flex-direction:column;gap:9px}.bar-row{display:grid;grid-template-columns:130px 1fr;gap:10px;align-items:center}.bar-row .bl{font-size:13px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-track{background:var(--surface-3);border-radius:999px;height:22px;position:relative;overflow:hidden}.bar-fill{height:100%;background:var(--grad);border-radius:999px;min-width:3px;transition:width .5s ease}.bar-val{position:absolute;right:9px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--navy);font-weight:700}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:7px 13px;font-size:13px;display:inline-flex;gap:7px;align-items:center}.chip .c{color:var(--muted);font-size:12px}.section-title{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--faint);margin:18px 0 10px;font-weight:700}.map-wrap{background:var(--surface-2);border:1px solid var(--border);border-radius:12px;padding:10px 10px 4px}.map-hover{font-size:13px;color:var(--text);padding:4px 6px 8px;min-height:24px}.switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.switch input{display:none}.switch .track-sw{width:42px;height:24px;background:var(--surface-3);border-radius:999px;position:relative;transition:background .2s}.switch .track-sw:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:transform .2s}.switch input:checked+.track-sw{background:var(--green)}.switch input:checked+.track-sw:after{transform:translate(18px)}.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px;gap:3px}.seg button{border:none;background:transparent;color:var(--muted);font:inherit;font-weight:600;font-size:13px;padding:7px 14px;border-radius:7px;cursor:pointer}.seg button.active{background:var(--surface);color:var(--brand-dark);box-shadow:var(--shadow-sm)}.lang-switch{flex:none}.lang-switch button{display:inline-flex;align-items:center;gap:5px;padding:6px 10px}.lang-switch .lang-code{font-size:12px;font-weight:700}.toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%);background:var(--navy);border:1px solid var(--navy);color:#fff;padding:12px 18px;border-radius:999px;box-shadow:var(--shadow);font-size:14px;z-index:50}.spinner{width:16px;height:16px;border:2px solid rgba(0,0,0,.18);border-top-color:currentColor;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.btn.primary .spinner,.btn.spotify .spinner{border-color:#fff6;border-top-color:#fff}@keyframes spin{to{transform:rotate(360deg)}}.link{color:var(--brand);cursor:pointer;background:none;border:none;font:inherit;padding:0}.link:hover{text-decoration:underline}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#09174766;display:grid;place-items:center;z-index:60;padding:20px}.modal{background:var(--surface);border-radius:var(--radius);padding:24px;max-width:400px;width:100%;box-shadow:var(--shadow)}.modal h3{margin:0 0 8px;color:var(--navy)}.modal p{margin:0 0 20px;color:var(--muted);font-size:14px}.modal-wide{max-width:560px}.modal-wide p.sub{margin:6px 0 16px}.div-score{text-align:center;padding:18px 0 10px}.div-score .v{font-size:56px;font-weight:800;line-height:1;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.div-score .l{color:var(--muted);font-size:13px;margin-top:4px}.div-weight-line{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-top:8px;font-size:13px}.sessions-list{display:flex;flex-direction:column;gap:6px}.session-row{display:flex;align-items:center;gap:8px}.session-open{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:2px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:9px 12px;cursor:pointer;text-align:left;font:inherit}.session-open:hover{border-color:var(--brand-light);background:var(--surface-3)}.session-open .s-code{font-weight:800;letter-spacing:.12em;color:var(--brand-dark);font-size:18px}.session-open .s-title{font-weight:700;color:var(--navy);font-size:15px}.students{display:flex;flex-direction:column;gap:8px;max-height:60vh;overflow-y:auto}.student-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:12px;background:var(--surface-2);border:1px solid var(--border)}.student-row .s-name{font-weight:600;font-size:14px}.wrow{display:grid;grid-template-columns:110px 1fr 32px;gap:10px;align-items:center;margin-bottom:8px}.wrow input[type=range]{width:100%;accent-color:var(--brand)}@media (max-width: 640px){.roles{grid-template-columns:1fr}.stat-grid{grid-template-columns:1fr 1fr 1fr}.bar-row{grid-template-columns:96px 1fr}.qr img,.qr canvas{width:140px;height:140px}}
