*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--violet: #7c3aed;--violet-soft: #a78bfa;--violet-dark: #4c1d95;--magenta: #ec4899;--ink: #0f172a;--emerald: #10b981;--emerald-soft: #34d399;--bg-gradient: linear-gradient(135deg, #a78bfa 0%, #7c3aed 35%, #ec4899 70%, #f43f5e 100%);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased}html,body{min-height:100vh;background:var(--bg-gradient);background-attachment:fixed;color:#fff}body{line-height:1.5}#root{min-height:100vh;display:flex;flex-direction:column}button,input{font-family:inherit}code{font-family:ui-monospace,SF Mono,Consolas,monospace;background:#0000002e;padding:0 .3rem;border-radius:.25rem}kbd{font-family:ui-monospace,SF Mono,Consolas,monospace;font-size:.82em;font-weight:700;background:#ffffff2e;border:1px solid rgba(255,255,255,.35);border-radius:.35rem;padding:0 .35rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.4rem;border-radius:1rem;border:none;cursor:pointer;font-size:1rem;font-weight:800;color:#fff;transition:transform .12s,background-color .15s,box-shadow .15s;white-space:nowrap;border-bottom:4px solid transparent;text-decoration:none}.btn:disabled{opacity:.4;cursor:not-allowed}.btn:not(:disabled):active{transform:scale(.96)}.btn-large{padding:1rem 1.8rem;font-size:1.05rem}.btn-primary{background:linear-gradient(135deg,var(--emerald-soft),var(--emerald));border-bottom-color:#047857;box-shadow:0 8px 18px #10b98166}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#6ee7b7,#34d399)}.btn-secondary{background:#0f172a40;border-bottom-color:#0f172a73}.btn-ghost{background:#ffffff29;border:1.5px solid rgba(255,255,255,.4);border-bottom:4px solid rgba(255,255,255,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.loading-screen{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.loading-screen__spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.intro-view{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:2rem;text-align:center}.brand{display:flex;align-items:center;gap:.5rem;font-weight:900;font-size:1.4rem;background:#ffffff29;padding:.55rem 1.1rem;border-radius:999px;border:1px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.brand__icon{font-size:1.4rem}.intro-hero h1{font-size:clamp(2rem,5vw,3rem);font-weight:900;letter-spacing:-.02em;text-shadow:0 4px 24px rgba(0,0,0,.3);margin-bottom:.6rem}.intro-hero p{font-size:1.1rem;color:#ffffffe0;max-width:560px}.intro-actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.intro-back{color:#ffffffbf;text-decoration:none;font-size:.9rem;font-weight:600}.intro-back:hover{color:#fff}.view{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.view-header{display:flex;align-items:center;gap:.85rem;padding:.85rem 1.25rem;background:#0f172a73;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.15)}.view-header__title{flex:1;font-weight:800;font-size:1.05rem}.back-btn{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.35rem .8rem;border-radius:.55rem;cursor:pointer;font-family:inherit;font-weight:600}.back-btn:hover{background:#ffffff47}.error-banner{margin:.8rem 1.25rem;background:#f43f5ed9;color:#fff;border-radius:.85rem;padding:.65rem 1rem;font-weight:600}.view--auth{align-items:center;justify-content:center;padding-bottom:4rem}.auth-card{background:#fffffff2;color:var(--ink);border-radius:1.5rem;padding:2rem;max-width:420px;width:92%;box-shadow:0 30px 60px #0000004d;margin:2rem auto}.auth-card__head{text-align:center;margin-bottom:1rem}.auth-card__icon{font-size:2.5rem}.auth-card__title{font-size:1.4rem;font-weight:900;margin:.35rem 0 .15rem}.auth-card__sub{color:#0f172a99;font-size:.92rem}.auth-form{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.auth-input{font-family:inherit;font-size:1.4rem;font-weight:800;padding:1rem;border-radius:.85rem;border:2px solid rgba(15,23,42,.12);background:#fff;color:var(--ink);outline:none;text-align:center}.auth-input--code{letter-spacing:.35em;text-transform:uppercase}.auth-input:focus{border-color:var(--violet);box-shadow:0 0 0 3px #7c3aed33}.upload-area{padding:1.5rem;flex:1;display:flex;align-items:center;justify-content:center}.drop-zone{background:#ffffff1f;border:2px dashed rgba(255,255,255,.5);border-radius:1.5rem;padding:2rem 1.5rem;text-align:center;max-width:640px;width:100%;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.drop-zone.drag-over{background:#fff3;border-color:#fff}.drop-icon{font-size:3rem;margin-bottom:.5rem}.drop-text{font-weight:800;font-size:1.15rem;margin-bottom:.35rem}.drop-hint{font-size:.88rem;opacity:.85;margin-bottom:1rem;line-height:1.5}.drop-actions{display:flex;gap:.65rem;justify-content:center;flex-wrap:wrap}.setup-layout{display:flex;gap:1.25rem;padding:1.25rem;flex:1;min-height:0}.setup-main{flex:1;overflow-y:auto}.setup-sidebar{flex:0 0 320px;display:flex;flex-direction:column;gap:1rem}.setup-list{display:flex;flex-direction:column;gap:.75rem}.setup-empty{background:#ffffff1a;padding:1.5rem;border-radius:1rem;text-align:center;opacity:.85}.measure-card{display:flex;gap:1rem;align-items:center;background:#fff;color:var(--ink);border-radius:1rem;padding:.85rem 1rem}.measure-card__num{font-weight:900;background:var(--violet);color:#fff;width:2rem;height:2rem;border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0}.card{background:#fffffff2;color:var(--ink);border-radius:1.25rem;padding:1.1rem}.card__title{font-size:.82rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#0f172a99;margin-bottom:.65rem}.form-group{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.85rem}.form-group label{font-size:.78rem;font-weight:700;color:#0f172ab3}.form-group input{font-family:inherit;font-size:1rem;padding:.55rem .75rem;border-radius:.55rem;border:2px solid rgba(15,23,42,.15);background:#fff;color:var(--ink);outline:none}.form-group input:focus{border-color:var(--violet);box-shadow:0 0 0 3px #7c3aed26}.form-group input.input--error{border-color:#e11d48;box-shadow:0 0 0 3px #f43f5e2e}.form-preview{background:#10b9811f;border:1px solid rgba(16,185,129,.35);border-radius:.55rem;padding:.45rem .65rem;font-size:.85rem;color:#0f172abf;margin-bottom:.65rem}.help-list{list-style:none;display:flex;flex-direction:column;gap:.35rem;font-size:.88rem;color:#0f172abf}.help-list li:before{content:"• ";color:var(--violet);font-weight:900}.staff-svg{display:block}.staff-gap-highlight{animation:gapPulse 1.1s ease-in-out infinite}@keyframes gapPulse{0%,to{stroke-width:2.5;opacity:1}50%{stroke-width:4;opacity:.7}}.room-view{background:#00000026}.room-actions{display:flex;gap:.5rem}.room-layout{display:flex;gap:1rem;flex:1;padding:1rem;min-height:0}.room-main{flex:1;overflow-y:auto}.room-sidebar{flex:0 0 280px;display:flex;flex-direction:column;gap:1rem}.room-preview h2{font-size:1.1rem;margin-bottom:.75rem;opacity:.9}.room-preview__list{display:flex;flex-direction:column;gap:.75rem}.measure-preview-card{background:#fff;color:var(--ink);border-radius:1rem;padding:.65rem .85rem;display:flex;align-items:center;gap:.85rem}.measure-preview-card__num{font-weight:900;background:var(--violet);color:#fff;width:1.8rem;height:1.8rem;border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:.82rem;flex-shrink:0}.room-code{background:linear-gradient(135deg,var(--violet),var(--magenta));color:#fff;border:none;padding:1rem;border-radius:1.1rem;text-align:center;cursor:pointer;font-family:inherit;box-shadow:0 10px 22px #7c3aed66}.room-code__label{font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;opacity:.85}.room-code__value{font-family:ui-monospace,monospace;font-size:2rem;font-weight:900;letter-spacing:.25em;margin:.25rem 0}.room-code__hint{font-size:.75rem;opacity:.85}.student-list{background:#fffffff2;color:var(--ink);border-radius:1rem;padding:.85rem}.student-list__head{display:flex;justify-content:space-between;font-weight:800;margin-bottom:.65rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:#0f172a99}.student-list__count{background:var(--violet);color:#fff;padding:.15rem .55rem;border-radius:999px;font-size:.78rem}.student-list__empty{font-size:.85rem;opacity:.6;padding:.5rem;text-align:center}.student-list__rows{list-style:none;display:flex;flex-direction:column;gap:.35rem}.student-row{display:flex;align-items:center;gap:.5rem;padding:.35rem .55rem;background:#0f172a0a;border-radius:.55rem;font-size:.92rem}.student-row__rank{font-size:1rem}.student-row__name{flex:1;font-weight:700}.student-row__score{font-family:ui-monospace,monospace;font-weight:800;font-size:.85rem}.student-row--off{opacity:.5}.play-view{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.play-header{display:flex;align-items:center;gap:1rem;padding:.65rem 1rem;background:#0f172a99;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.play-name{font-weight:800;font-size:1rem}.play-room{font-size:.85rem;opacity:.85;flex:1}.play-actions{display:flex;gap:.5rem}.export-btn,.submit-btn{font-family:inherit;font-size:.85rem;font-weight:800;padding:.5rem .85rem;border:none;border-radius:.6rem;cursor:pointer}.export-btn{background:#ffffff2e;color:#fff}.submit-btn{background:var(--emerald);color:#fff}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.waiting-lobby{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;text-align:center;padding:1.5rem}.waiting-lobby__icon{font-size:4rem;animation:spin 5s linear infinite}.waiting-lobby h2{font-size:1.7rem;font-weight:900}.waiting-lobby__pulse{width:100px;height:6px;border-radius:3px;margin-top:1rem;background:#ffffff4d;overflow:hidden;position:relative}.waiting-lobby__pulse:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,#fff,transparent);animation:slide 1.4s ease-in-out infinite}@keyframes slide{0%{transform:translate(-100%)}to{transform:translate(100%)}}.noten-field{flex:1 1 auto;position:relative;width:100%;background:linear-gradient(180deg,#a78bfa,#7c3aed 60%,#4c1d95);overflow:hidden;color:#fff;-webkit-user-select:none;user-select:none}.noten-field--touch{touch-action:none;cursor:grab}.noten-field--touch:active{cursor:grabbing}.noten-hud{position:absolute;top:0;left:0;right:0;z-index:10;display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.65rem 1.1rem;background:linear-gradient(180deg,#0f172a8c,#0f172a00);pointer-events:none}.noten-hud>*{pointer-events:auto}.noten-hud__lives{font-size:1.3rem;letter-spacing:.12em;text-shadow:0 2px 6px rgba(0,0,0,.4)}.noten-hud__score,.noten-hud__level{display:flex;flex-direction:column;align-items:center;line-height:1}.noten-hud__label{font-size:.65rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;opacity:.85}.noten-hud__score strong,.noten-hud__level strong{font-size:1.2rem;font-weight:900}.noten-hud__audio{background:#fff3;border:1px solid rgba(255,255,255,.35);width:40px;height:40px;border-radius:50%;color:#fff;cursor:pointer;font-size:1.1rem}.noten-hud__audio:hover{background:#ffffff4d}.noten-measure{position:absolute;transform:translate(-50%);background:#fffffff7;border-radius:.8rem;padding:.35rem .5rem;box-shadow:0 8px 22px #0000004d;z-index:4;color:var(--ink);pointer-events:none}.noten-flash{position:absolute;top:60px;left:50%;transform:translate(-50%);font-size:1.5rem;font-weight:900;z-index:12;text-shadow:0 2px 12px rgba(0,0,0,.5);pointer-events:none;animation:flashOut .7s ease-out forwards}@keyframes flashOut{0%{opacity:0;transform:translate(-50%,-10px)}20%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-30px)}}.noten-aim-line{position:absolute;width:2px;transform:translate(-50%);background:linear-gradient(to bottom,#f59e0b1a,#f59e0b99);pointer-events:none;z-index:3}.noten-aim-marker{position:absolute;transform:translate(-50%);background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#422006;padding:.15rem .55rem;border-radius:.45rem;font-weight:900;font-size:.9rem;box-shadow:0 4px 12px #f59e0b80;pointer-events:none}.noten-projectile{position:absolute;transform:translate(-50%);background:linear-gradient(135deg,#34d399,#10b981);color:#fff;padding:.25rem .65rem;border-radius:.45rem;font-weight:900;font-size:.92rem;box-shadow:0 0 14px #34d399b3;z-index:7;pointer-events:none}.noten-projectile--wrong{background:linear-gradient(135deg,#fb7185,#f43f5e);box-shadow:0 0 14px #f43f5eb3}.noten-plane{position:absolute;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:2px;z-index:5;pointer-events:none;transition:transform .08s ease-out}.noten-plane__ammo{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#422006;border-radius:.4rem;padding:.1rem .55rem;font-weight:900;font-size:.9rem;box-shadow:0 2px 6px #00000040}.noten-plane__icon{font-size:2.5rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.4))}.noten-ammo-bar{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(180deg,#0f172a8c,#0f172ad9);border-top:2px solid rgba(255,255,255,.18);padding:.55rem .75rem;z-index:8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;flex-direction:column;align-items:center;gap:.35rem;height:96px}.noten-ammo-bar__label{font-size:.68rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase;opacity:.85}.noten-ammo-bar__slots{display:flex;gap:.55rem;flex-wrap:wrap;justify-content:center}.noten-ammo-bar__hint{font-style:italic;opacity:.7}.noten-ammo-slot{display:inline-flex;align-items:center;gap:.45rem;padding:.35rem .75rem;border-radius:.65rem;background:#ffffff2e;border:2px solid rgba(255,255,255,.3);color:#fff;font-family:inherit;cursor:pointer;min-width:3.4rem;transition:background .12s,transform .1s}.noten-ammo-slot:hover:not(:disabled){background:#ffffff4d}.noten-ammo-slot--active{background:linear-gradient(135deg,#fbbf24,#f59e0b);border-color:#fbbf24;color:#422006;box-shadow:0 4px 12px #f59e0b80}.noten-ammo-slot__num{display:inline-flex;align-items:center;justify-content:center;width:1.3rem;height:1.3rem;border-radius:999px;background:#0003;font-size:.7rem;font-weight:800}.noten-ammo-slot--active .noten-ammo-slot__num{background:#fff6;color:#422006}.noten-ammo-slot__text{font-weight:800;font-size:.95rem}.noten-touch{position:absolute;bottom:108px;left:0;right:0;padding:0 1rem;display:none;justify-content:space-between;pointer-events:none;z-index:9}.noten-touch>*{pointer-events:auto}.noten-touch__btn{width:60px;height:60px;border-radius:50%;background:#0f172a80;color:#fff;border:2px solid rgba(255,255,255,.5);font-size:1.6rem;font-weight:900;cursor:pointer;font-family:inherit;touch-action:none;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.noten-touch__btn--fire{width:72px;height:72px;background:linear-gradient(135deg,#f43f5ecc,#d946efcc)}@media (pointer: coarse){.noten-touch{display:flex}.noten-help,.noten-touch__btn--left,.noten-touch__btn--right{display:none}.noten-touch{justify-content:flex-end;padding-right:1rem}}.noten-help{position:absolute;bottom:100px;left:50%;transform:translate(-50%);font-size:.78rem;opacity:.65;pointer-events:none;z-index:6;background:#0000002e;padding:.25rem .65rem;border-radius:999px;white-space:nowrap}.noten-gameover{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:20;display:flex;align-items:center;justify-content:center;padding:1.5rem}.noten-gameover__card{background:#fff;color:var(--ink);border-radius:1.5rem;padding:2rem;text-align:center;max-width:420px;width:100%}.noten-gameover__icon{font-size:3rem}.noten-gameover__title{font-size:1.6rem;font-weight:900;margin:.25rem 0}.noten-gameover__score{font-size:2.4rem;font-weight:900;color:var(--violet);margin:.35rem 0}.noten-gameover__stats{display:flex;gap:.65rem;justify-content:center;flex-wrap:wrap;margin-bottom:1rem}.noten-gameover__stats span{background:#0f172a0f;padding:.35rem .75rem;border-radius:999px;font-size:.85rem;font-weight:700}.noten-gameover__hint{font-size:.82rem;opacity:.65;margin-top:.75rem}.results-view{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1.5rem}.results-card{background:#fffffff2;color:var(--ink);border-radius:1.5rem;padding:2.5rem 2rem;max-width:460px;width:100%;text-align:center;box-shadow:0 30px 60px #00000059}.results-trophy{font-size:3.5rem}.results-title{font-size:1.6rem;font-weight:900;margin:.25rem 0 .5rem}.results-score{font-size:3rem;font-weight:900;color:var(--violet);margin:.35rem 0}.results-score__sub{font-size:1rem;font-weight:700;opacity:.6}.results-sub{font-size:1rem;opacity:.75;margin-bottom:1.25rem}.results-chips{display:flex;gap:.55rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.5rem}.chip{background:#0f172a12;padding:.35rem .8rem;border-radius:999px;font-weight:700;font-size:.85rem}.chip--ok{background:#10b9812e;color:#047857}.chip--bad{background:#f43f5e2e;color:#be123c}@media (max-width: 900px){.setup-layout{flex-direction:column}.setup-sidebar{flex:0 0 auto}.room-layout{flex-direction:column}.room-sidebar{flex:0 0 auto}}
