:root{--bg:#05060c;--fg:#eaf0ff;--accent:#5ad7ff;--accent-2:#ffd23f;--danger:#ef4d5a;--panel:#0c101ed1;--panel-border:#78a0ff2e}*{box-sizing:border-box}html,body{background:var(--bg);height:100%;color:var(--fg);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;overscroll-behavior:none;margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;overflow:hidden}#app{position:fixed;top:0;bottom:0;left:0;right:0}#input-video{opacity:0;pointer-events:none;width:2px;height:2px;position:absolute;top:0;left:0}#game-canvas{touch-action:none;width:100%;height:100%;display:block;position:absolute;top:0;bottom:0;left:0;right:0}#cam-mini{z-index:6;border:1px solid #ffffff38;border-radius:10px;width:168px;height:126px;position:absolute;bottom:10px;right:10px;box-shadow:0 4px 18px #00000080}.hidden{display:none!important}#hud{z-index:4;pointer-events:none;padding:max(10px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) 10px max(14px, env(safe-area-inset-left));flex-direction:column;justify-content:space-between;display:flex;position:absolute;top:0;bottom:0;left:0;right:0}.hud-top{justify-content:space-between;align-items:flex-start;display:flex}.hud-score{text-shadow:0 2px 10px #000000b3;letter-spacing:1px;font-size:30px;font-weight:800}.hud-combo{color:var(--accent-2);min-height:16px;font-size:14px;font-weight:700}.hud-wave{opacity:.8;font-size:12px}.hud-right{text-align:right}.hud-gesture{background:var(--panel);border:1px solid var(--panel-border);border-radius:999px;padding:4px 10px;font-size:14px;font-weight:700;display:inline-block}.g-lost{color:var(--danger)}.g-neutral{color:#aab6d6}.g-attack{color:#9ff0ff}.g-defense{color:#7fb0ff}.g-super{color:var(--accent-2)}.hud-debug{opacity:.7;margin-top:6px;font-size:11px}.hud-bars{flex-direction:column;gap:6px;max-width:340px;display:flex}.bar{align-items:center;gap:8px;display:flex}.bar-icon{text-align:center;width:16px;font-size:13px}.bar-track{background:#ffffff1f;border-radius:999px;flex:1;height:10px;overflow:hidden}.bar-fill{border-radius:999px;width:100%;height:100%;transition:width .12s linear,background .2s}.fill-health{background:#46d17f}.fill-conc{background:linear-gradient(90deg,#6a8bff,#b06bff)}.bar-conc.ready .fill-conc{background:linear-gradient(90deg,#ffd23f,#ff7eb0);box-shadow:0 0 12px #ffd23fcc}.bar-conc.ready .bar-icon{color:var(--accent-2);animation:.7s infinite pulse}@keyframes pulse{50%{opacity:.4}}#screens{z-index:10;background:radial-gradient(circle at 50% 30%,#141a30d9,#05060cf0);justify-content:center;align-items:center;padding:20px;display:flex;position:absolute;top:0;bottom:0;left:0;right:0;overflow:auto}.screen{text-align:center;width:100%;max-width:720px;animation:.25s fade}@keyframes fade{0%{opacity:0;transform:translateY(8px)}}.logo{letter-spacing:4px;margin-bottom:4px;font-size:clamp(38px,9vw,68px);font-weight:900}.logo span{color:var(--accent)}.tagline{opacity:.85;margin:0 0 16px}.privacy{text-align:left;background:var(--panel);border:1px solid var(--panel-border);border-radius:12px;max-width:560px;margin:0 auto 16px;padding:12px 16px}.privacy h3{margin:4px 0 8px;font-size:15px}.privacy ul{opacity:.92;margin:0;padding-left:18px;font-size:13.5px;line-height:1.5}.options{gap:10px;max-width:560px;margin:0 auto 18px;display:grid}.options label{justify-content:space-between;align-items:center;gap:12px;font-size:13.5px;font-weight:600;display:flex}.seg{background:#ffffff12;border-radius:999px;gap:2px;padding:3px;display:inline-flex}.seg-btn{color:var(--fg);font:inherit;cursor:pointer;opacity:.7;background:0 0;border:0;border-radius:999px;padding:6px 12px;font-size:12.5px}.seg-btn.seg-active{background:var(--accent);color:#04121a;opacity:1;font-weight:700}.btn{font:inherit;cursor:pointer;border:0;border-radius:12px;padding:14px 26px;font-size:16px;font-weight:800}.btn-primary{background:linear-gradient(135deg, var(--accent), #6a8bff);color:#04121a;box-shadow:0 6px 22px #5ad7ff59}.btn-primary:disabled{filter:grayscale(.6)brightness(.7);cursor:default;box-shadow:none}.btn:active{transform:translateY(1px)}.hint{opacity:.7;margin-top:14px;font-size:12.5px}.screen-error .err-icon{font-size:42px}.screen-error h2{color:var(--danger)}.err-steps{text-align:left;max-width:520px;margin:12px auto 18px;font-size:14px;line-height:1.6}.screen-calib h2{margin-bottom:6px;font-size:26px}.gestures{flex-wrap:wrap;justify-content:center;gap:12px;margin:16px 0;display:flex}.gesture-card{background:var(--panel);border:1px solid var(--panel-border);border-radius:12px;min-width:96px;padding:14px 18px;transition:all .2s}.gesture-card .gi{font-size:28px}.gesture-card b{margin-top:4px;display:block}.gesture-card span{opacity:.7;font-size:12px}.gesture-card.done{border-color:#46d17f;box-shadow:0 0 16px #46d17f59}.gesture-card.done .gi:after{content:" ✓";color:#46d17f}.calib-live{margin:8px 0 16px;font-size:15px}.screen-pause .pause-icon,.screen-over h2{font-size:40px}.screen-pause h2{margin:6px 0;font-size:28px}.final-score{color:var(--accent-2);margin:6px 0;font-size:56px;font-weight:900}.final-meta{opacity:.85;margin-bottom:20px}.rank-badge{color:#090914;background:radial-gradient(circle at 35% 25%,#fff6bd,#ffd23f 45%,#ff7a3d);border-radius:50%;place-items:center;width:92px;height:92px;margin:0 auto 8px;font-size:34px;font-weight:950;display:grid;box-shadow:0 0 34px #ffd23f8c,inset 0 0 18px #ffffff59}.rank-ss,.rank-s{animation:.75s infinite pulse}.rank-label{color:var(--accent-2);margin-bottom:6px;font-weight:800}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;max-width:560px;margin:12px auto;display:grid}.stats-grid span{border:1px solid var(--panel-border);background:#ffffff14;border-radius:10px;padding:8px}.missions{text-align:left;gap:6px;max-width:620px;margin:10px auto 18px;padding:0;list-style:none;display:grid}.missions li{color:#eaf0ffb8;background:#ffffff0f;border-radius:10px;padding:8px 10px}.missions li.done{color:#eafff1;background:#46d17f21;border:1px solid #46d17f47}.screen-loading{flex-direction:column;align-items:center;gap:16px;display:flex}.spinner{border:4px solid #ffffff26;border-top-color:var(--accent);border-radius:50%;width:46px;height:46px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (orientation:portrait) and (max-width:820px){.tagline:after{content:" — 🔄 préférez le mode paysage.";color:var(--accent-2)}}
