@import url('https://fonts.googleapis.com/css2?family=Archivo+Black&family=Work+Sans:wght@400;500;600;700;800&display=swap');

/* ===== Tokens ===== */
:root{
  --bg:#f5f1e8;          /* paper */
  --surface:#fffdf8;     /* card white */
  --surface-2:#faf5ea;   /* secondary surface */
  --border:#1a1a1a;      /* ink */
  --text:#1a1a1a;        /* ink */
  --muted:#7a7568;       /* warm gray */
  --flag:#ff5a1f;        /* marker orange — primary accent */
  --amber:#2c4cff;       /* marker blue — secondary accent */
  --danger:#d62828;      /* red */
  --ink-on-dark:#f3efe4; /* text for chrome floating over the live video feed */
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;height:100%;overscroll-behavior:none;}
body{
  background:#1a1a1a;
  color:var(--text);
  font-family:'Work Sans',sans-serif;
}
h1,h2,h3,.dock-btn .lab,.tally-label,.brand,.coaching-head h2{
  font-family:'Archivo Black',sans-serif;
}
.app{height:100dvh;width:100%;position:relative;overflow:hidden;}

/* ===== Camera stage (sits over live video — needs its own light-on-dark chrome) ===== */
.stage{position:absolute;inset:0;background:#000;}
video{width:100%;height:100%;object-fit:cover;display:block;}
canvas.overlay{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;}

.rotate-overlay{
  display:none;position:absolute;inset:0;z-index:50;background:rgba(13,12,10,.96);
  flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;color:#fff;padding:24px;
}
.rotate-overlay.show{display:flex;}
.rotate-icon{font-size:48px;animation:rotate-hint 1.6s ease-in-out infinite;}
.rotate-overlay p{font-size:14px;color:rgba(255,255,255,.85);margin:0;max-width:260px;}
@keyframes rotate-hint{0%,100%{transform:rotate(0deg);}50%{transform:rotate(90deg);}}

.stage-msg{
  position:absolute;inset:0;z-index:5;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:12px;text-align:center;padding:24px;
  background:var(--bg);
}
.stage-msg p{color:var(--muted);font-size:13px;max-width:280px;margin:0;}
.camera-code-line{font-size:13px;color:var(--text);margin-top:-4px;margin-bottom:4px;text-align:center;}
.camera-code-line b{color:var(--flag);letter-spacing:.08em;font-family:"SF Mono",Menlo,Consolas,monospace;}
.camera-code-line canvas{display:block;margin:8px auto;border-radius:14px;background:#fff;padding:6px;}
.remote-connect-label{font-size:12px;font-weight:700;color:var(--muted);}

.brand{
  position:absolute;top:calc(env(safe-area-inset-top,0px) + 10px);left:50%;transform:translateX(-50%);
  font-size:11px;letter-spacing:.04em;color:rgba(255,255,255,.65);z-index:3;pointer-events:none;
}
.brand span{color:#ffb38a;}
.mode-chooser .brand,.remote-ui .brand{position:static;transform:none;margin-bottom:6px;font-size:15px;color:var(--text);}
.mode-chooser .brand span,.remote-ui .brand span{color:var(--flag);}

.cam-menu-btn{
  position:absolute;top:calc(env(safe-area-inset-top,0px) + 12px);left:12px;z-index:8;
  width:38px;height:38px;border-radius:50%;
  background:rgba(9,13,11,.7);border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(4px);
  color:var(--ink-on-dark);display:flex;align-items:center;justify-content:center;font-size:15px;cursor:pointer;
}
.icon-btn{
  appearance:none;width:42px;height:42px;border-radius:50%;
  border:1px solid rgba(255,255,255,.2);background:rgba(9,13,11,.65);backdrop-filter:blur(4px);
  color:var(--ink-on-dark);display:flex;align-items:center;justify-content:center;font-size:17px;cursor:pointer;
}
.icon-btn.lens-btn{font-family:"SF Mono",Menlo,Consolas,monospace;font-size:13px;font-weight:700;}
.icon-btn.auto-mode-btn{font-size:9px;font-weight:800;letter-spacing:.04em;}
.icon-btn:active{transform:scale(.94);}
.icon-btn:disabled{opacity:.35;}
.icon-btn:focus-visible{outline:2px solid var(--flag);outline-offset:2px;}
.icon-btn.active{background:var(--flag);border-color:var(--flag);color:#fff;}

.top-right-stack{
  position:absolute;top:calc(env(safe-area-inset-top,0px) + 12px);right:12px;z-index:3;
  display:flex;flex-direction:column;align-items:flex-end;gap:8px;
}
.timer{
  background:rgba(9,13,11,.7);padding:6px 10px;border-radius:14px;
  font-family:"SF Mono",Menlo,Consolas,monospace;font-size:13px;backdrop-filter:blur(4px);
  text-align:center;color:var(--ink-on-dark);
}

.tally{
  position:absolute;top:calc(env(safe-area-inset-top,0px) + 12px);left:58px;z-index:3;
  display:flex;align-items:center;gap:8px;
  background:rgba(9,13,11,.7);padding:6px 12px 6px 8px;border-radius:100px;backdrop-filter:blur(4px);
}
.tally-dot{width:10px;height:10px;border-radius:50%;background:var(--muted);}
.tally.recording .tally-dot{background:var(--danger);animation:blink 1s steps(2,end) infinite;}
.tally.arming .tally-dot{background:var(--amber);}
@media (prefers-reduced-motion: reduce){.tally.recording .tally-dot{animation:none;}}
@keyframes blink{50%{opacity:.25;}}
.tally-label{font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-on-dark);}
.zone-indicator{display:none;margin-left:6px;color:#9db4ff;font-size:10px;font-weight:800;letter-spacing:.08em;}

.live-pill{
  position:absolute;top:calc(env(safe-area-inset-top,0px) + 56px);left:12px;z-index:3;
  display:flex;gap:10px;background:rgba(9,13,11,.7);padding:6px 12px;border-radius:100px;
  backdrop-filter:blur(4px);font-size:12px;font-weight:700;color:var(--ink-on-dark);
}
.live-pill .item{display:flex;align-items:center;gap:5px;}
.live-pill .muted-label{color:#b9b3a4;font-weight:600;}

.zone-boxes,.draw-preview{position:absolute;inset:0;pointer-events:none;}
.zone-box{
  position:absolute;border:2px dashed var(--flag);background:rgba(255,90,31,.12);
  pointer-events:none;z-index:4;border-radius:4px;
}
.zone-box .zone-del{
  position:absolute;top:-11px;right:-11px;width:22px;height:22px;border-radius:50%;
  background:var(--danger);color:#fff;border:none;font-size:13px;font-weight:800;
  display:flex;align-items:center;justify-content:center;cursor:pointer;pointer-events:auto;
}
.draw-preview{display:none;border:2px dashed var(--flag);background:rgba(255,90,31,.12);z-index:22;border-radius:4px;}
.draw-layer{position:absolute;inset:0;display:none;z-index:20;cursor:crosshair;touch-action:none;}
.draw-hint{
  position:absolute;top:calc(env(safe-area-inset-top,0px) + 12px);left:50%;transform:translateX(-50%);
  z-index:21;display:none;align-items:center;gap:10px;
  background:rgba(9,13,11,.88);backdrop-filter:blur(4px);color:var(--ink-on-dark);
  padding:8px 10px 8px 14px;border-radius:100px;font-size:12px;white-space:nowrap;
}

.toast{
  position:absolute;bottom:96px;left:50%;transform:translateX(-50%) translateY(10px);z-index:25;
  background:rgba(18,16,12,.94);border:1px solid rgba(255,255,255,.15);backdrop-filter:blur(4px);
  padding:10px 16px;border-radius:16px;font-size:12px;font-weight:600;max-width:88vw;text-align:center;
  opacity:0;pointer-events:none;color:var(--ink-on-dark);transition:opacity .2s ease, transform .2s ease;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.toast.flash{border-color:var(--flag);color:#ffb38a;}

/* Décompte de fin de capture AfterShot — on attend la fin du segment en cours.
   Volontairement gros et explicite pour que ça ne ressemble pas à un bug. */
.capture-countdown{
  display:none;position:absolute;inset:0;z-index:30;
  flex-direction:column;align-items:center;justify-content:center;gap:6px;text-align:center;
  padding:24px;background:rgba(13,12,10,.82);backdrop-filter:blur(3px);color:#fff;
}
.capture-countdown.show{display:flex;}
.capture-countdown .cc-rec{
  display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:800;
  letter-spacing:.08em;color:#ffb3b3;background:rgba(214,69,69,.18);
  border:1px solid var(--danger);padding:6px 14px;border-radius:100px;
}
.capture-countdown .cc-dot{width:10px;height:10px;border-radius:50%;background:var(--danger);animation:blink 1s steps(2,end) infinite;}
.capture-countdown .cc-title{font-size:18px;font-weight:800;margin-top:12px;}
.capture-countdown .cc-num{
  font-size:76px;font-weight:800;line-height:1;color:var(--flag);
  font-family:"SF Mono",Menlo,Consolas,monospace;margin:4px 0;
}
.capture-countdown .cc-sub{font-size:13px;color:rgba(255,255,255,.8);max-width:300px;line-height:1.4;}
@media (prefers-reduced-motion: reduce){.capture-countdown .cc-dot{animation:none;}}

.replay-capture-row{
  position:absolute;left:0;right:96px;bottom:calc(env(safe-area-inset-bottom,0px) + 20px);z-index:3;
  display:flex;justify-content:center;gap:10px;padding:0 16px;
}
.capture-pill{
  flex:1;max-width:120px;appearance:none;border:1px solid rgba(255,255,255,.2);
  background:rgba(18,16,12,.85);backdrop-filter:blur(4px);color:var(--ink-on-dark);
  border-radius:18px;padding:8px 6px;font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.03em;line-height:1.5;cursor:pointer;
}
.capture-pill b{
  display:block;font-size:14px;font-family:"SF Mono",Menlo,Consolas,monospace;
  letter-spacing:0;text-transform:none;color:#ffb38a;
}
.capture-pill:active{transform:scale(.95);background:rgba(255,90,31,.25);}
.capture-pill-plus{border-style:dashed;}
.capture-pill-plus b{color:#fff;font-size:18px;}

.bottom-bar{
  position:absolute;left:0;right:0;bottom:0;z-index:3;
  padding:14px 16px calc(env(safe-area-inset-bottom,0px) + 14px);
  display:flex;align-items:center;justify-content:center;gap:18px;
  background:linear-gradient(to top, rgba(0,0,0,.78), rgba(0,0,0,0));
}
.dock-btn{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  background:none;border:none;color:var(--ink-on-dark);
  font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  cursor:pointer;max-width:84px;text-align:center;
}
.dock-btn .circle{
  width:46px;height:46px;border-radius:50%;
  border:1px solid rgba(255,255,255,.2);background:rgba(18,16,12,.8);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;font-size:18px;position:relative;
}
.dock-btn.rec-btn .circle{width:62px;height:62px;background:var(--flag);border-color:var(--flag);color:#fff;}
.dock-btn.rec-btn.recording .circle{background:var(--danger);border-color:var(--danger);color:#fff;}
.dock-btn:active .circle{transform:scale(.94);}
.dock-btn:disabled,.dock-btn[disabled]{opacity:.4;}
.badge{
  position:absolute;top:-2px;right:-2px;min-width:16px;height:16px;padding:0 4px;
  background:var(--flag);color:#fff;border-radius:100px;font-size:10px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
}
.badge:empty{display:none;}

/* Colonne verticale de boutons à droite de l'écran caméra */
.side-bar{
  position:absolute;top:50%;right:10px;transform:translateY(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:14px;
}
.side-bar .dock-btn{max-width:72px;text-shadow:0 1px 3px rgba(0,0,0,.6);}
/* Groupe caméra : un bouton 📷 qui déploie Zoom + Av/Ar vers la gauche.
   Sous-groupe en position absolue → s'ouvre sans décaler le reste de la colonne. */
.cam-group{position:relative;}
.cam-sub{
  position:absolute;right:100%;top:50%;margin-right:10px;
  display:flex;flex-direction:row;align-items:center;gap:10px;
  opacity:0;pointer-events:none;transform:translateY(-50%) translateX(14px);
  transition:opacity .2s ease, transform .28s ease;
}
.cam-group.open .cam-sub{opacity:1;pointer-events:auto;transform:translateY(-50%) translateX(0);}
.cam-group.open #camToggleBtn .circle{background:var(--flag);border-color:var(--flag);color:#fff;}
.dock-btn .circle.lens-circle{font-family:"SF Mono",Menlo,Consolas,monospace;font-size:15px;font-weight:700;}

/* ===== Buttons (paper-themed, used everywhere off-video) ===== */
.btn{
  appearance:none;border:1px solid rgba(26,26,26,.08);background:var(--surface);color:var(--text);
  border-radius:16px;padding:10px 16px;font-size:13px;font-weight:600;cursor:pointer;
  box-shadow:0 4px 14px rgba(26,26,26,.10);transition:transform .08s ease, box-shadow .08s ease;
}
.btn:hover{background:var(--surface-2);}
.btn:active{transform:scale(.97);box-shadow:0 1px 4px rgba(26,26,26,.10);}
.btn:focus-visible{outline:2px solid var(--amber);outline-offset:2px;}
.btn.primary{background:var(--flag);color:#fff;border-color:var(--border);}
.btn.danger{background:var(--danger);color:#fff;border-color:var(--border);}
.btn.toggled{background:var(--amber);color:#fff;border-color:var(--border);}
.btn:disabled{opacity:.4;cursor:not-allowed;}
.btn.block{width:100%;}

.nav-back-btn{
  appearance:none;border:1px solid rgba(26,26,26,.08);background:var(--surface);color:var(--text);
  border-radius:100px;padding:8px 16px;font-size:12px;font-weight:700;cursor:pointer;
  box-shadow:0 3px 10px rgba(26,26,26,.10);
}
.remote-ui .nav-back-btn{position:absolute;top:calc(env(safe-area-inset-top,0px) + 16px);left:16px;z-index:5;}

/* ===== Backdrop + Drawers (Réglages / Clips) ===== */
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:40;}
.backdrop.show{opacity:1;pointer-events:auto;}
.drawer{
  position:fixed;top:0;bottom:0;right:0;width:min(420px, 92vw);
  background:var(--surface);border-left:1px solid rgba(26,26,26,.08);
  box-shadow:-8px 0 0 rgba(0,0,0,.08);
  transform:translateX(100%);transition:transform .25s ease;z-index:50;overflow-y:auto;
  padding:calc(env(safe-area-inset-top,0px) + 16px) 18px calc(env(safe-area-inset-bottom,0px) + 24px);
}
.drawer.open{transform:translateX(0);}
.drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.drawer-head h2{font-size:14px;margin:0;color:var(--text);}
.drawer-close{background:none;border:none;color:var(--muted);font-size:22px;line-height:1;cursor:pointer;padding:4px;}
.drawer-close:focus-visible{outline:2px solid var(--amber);}

.section{margin-bottom:22px;}
.section h3{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:0 0 10px;font-weight:700;}
.field{margin-bottom:14px;}
.field label{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-bottom:6px;}
.field label b{color:var(--text);font-weight:700;}
input[type="range"]{width:100%;accent-color:var(--flag);}

.switch-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:12px;}
.switch-row span{font-size:13px;font-weight:600;}
.switch-row .hint{display:block;font-size:11px;color:var(--muted);font-weight:400;margin-top:2px;}
.switch{
  position:relative;width:44px;height:24px;flex-shrink:0;
  background:var(--surface-2);border:1px solid rgba(26,26,26,.08);border-radius:100px;cursor:pointer;
}
.switch.on{background:var(--flag);border-color:var(--border);}
.switch::after{
  content:"";position:absolute;top:1px;left:1px;width:16px;height:16px;border-radius:50%;
  background:#fffdf8;border:1.5px solid var(--border);transition:left .15s ease;
}
.switch.on::after{left:23px;}
.switch:focus-visible{outline:2px solid var(--amber);outline-offset:2px;}

.select{
  width:100%;border:1px solid rgba(26,26,26,.08);background:var(--surface-2);color:var(--text);
  border-radius:9px;padding:10px 12px;font-size:13px;font-weight:600;
}
.select:focus-visible{outline:2px solid var(--amber);outline-offset:2px;}
.select:disabled{opacity:.4;}

details.diagnostic{border:1px solid rgba(26,26,26,.08);border-radius:16px;padding:10px 12px;background:var(--surface-2);}
details.diagnostic summary{cursor:pointer;font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;}
details.diagnostic[open] summary{margin-bottom:10px;}

.meter-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.meter{flex:1;height:10px;border-radius:6px;background:var(--bg);position:relative;overflow:hidden;border:1px solid var(--border);}
.meter-fill{position:absolute;left:0;top:0;bottom:0;width:0%;background:var(--flag);transition:width .12s linear;}
.meter-threshold{position:absolute;top:-2px;bottom:-2px;width:2px;background:var(--amber);}
.meter-label{font-size:11px;color:var(--muted);min-width:70px;}
.stat-row{display:flex;justify-content:space-between;align-items:baseline;padding:7px 0;border-bottom:1px solid var(--border);}
.stat-row:last-child{border-bottom:none;}
.stat-row .label{font-size:11px;color:var(--muted);}
.stat-row .value{font-family:"SF Mono",Menlo,Consolas,monospace;font-size:12px;font-weight:700;}

.controls-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:6px;}

.clips{list-style:none;margin:0;padding:0;}
.clip{border:1px solid rgba(26,26,26,.08);border-radius:16px;padding:10px;margin-bottom:10px;background:var(--surface-2);box-shadow:0 4px 14px rgba(26,26,26,.10);}
.clip-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px;}
.clip-head .t{font-size:12px;color:var(--muted);}
.clip-head .d{font-family:"SF Mono",Menlo,Consolas,monospace;font-size:13px;font-weight:700;}
.clip video{border-radius:6px;width:100%;display:block;margin-bottom:6px;background:#000;}
.clip a{font-size:12px;color:var(--flag);text-decoration:none;font-weight:700;}
.moment-li{margin-bottom:10px;}
.moment-folder{border:1px solid rgba(26,26,26,.08);border-radius:16px;background:var(--surface-2);overflow:hidden;box-shadow:0 4px 14px rgba(26,26,26,.10);}
.moment-folder summary{list-style:none;cursor:pointer;display:flex;align-items:baseline;gap:8px;padding:10px;}
.moment-folder summary::-webkit-details-marker{display:none;}
.moment-folder summary .chevron{color:var(--muted);font-size:11px;transition:transform .15s ease;flex-shrink:0;}
.moment-folder[open] summary .chevron{transform:rotate(90deg);}
.moment-folder summary .t{font-size:12px;color:var(--muted);flex:1;}
.moment-folder summary .d{font-family:"SF Mono",Menlo,Consolas,monospace;font-size:12px;font-weight:700;}
.moment-folder-body{padding:0 10px 10px;}
.moment-folder-body a{font-size:12px;color:var(--flag);text-decoration:none;font-weight:700;}
.empty{font-size:12px;color:var(--muted);text-align:center;padding:18px 0;}
.drawer-footnote{font-size:11px;color:var(--muted);text-align:center;margin-top:18px;}

/* ===== Mode chooser (home screen) ===== */
.mode-chooser{
  position:fixed;inset:0;z-index:60;background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;padding:24px;text-align:center;
}
.mode-chooser p{color:var(--muted);font-size:13px;max-width:280px;margin:0 0 18px;}

.mode-card-list{display:flex;flex-direction:column;gap:10px;width:100%;max-width:320px;}
.mode-card{
  appearance:none;border:none;background:var(--surface);color:var(--text);
  display:flex;align-items:center;gap:14px;text-align:left;
  border-radius:18px;padding:14px 16px;cursor:pointer;
  box-shadow:0 4px 14px rgba(26,26,26,.08);transition:transform .08s ease, box-shadow .08s ease;
}
.mode-card:active{transform:scale(.98);box-shadow:0 2px 8px rgba(26,26,26,.08);}
.mode-card-icon{
  width:44px;height:44px;border-radius:14px;background:var(--surface-2);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:20px;
}
.mode-card-text{display:flex;flex-direction:column;gap:2px;}
.mode-card-title{font-weight:800;font-size:14px;}
.mode-card-sub{font-size:11px;color:var(--muted);}
.mode-card.coming-soon{opacity:.6;}
.mode-card.coming-soon .mode-card-icon{filter:grayscale(.45);}
.soon-badge{display:inline-block;margin-left:6px;font-size:9px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:#fff;background:var(--muted);border-radius:100px;padding:2px 7px;vertical-align:middle;}
#chooseCameraBtn .mode-card-icon{background:var(--flag);}

/* ===== Télécommande ===== */
.remote-ui{
  display:none;position:absolute;inset:0;z-index:10;
  flex-direction:column;align-items:center;height:100dvh;overflow-y:auto;background:var(--bg);
  padding:calc(env(safe-area-inset-top,0px) + 24px) 20px calc(env(safe-area-inset-bottom,0px) + 24px);
  gap:16px;
}
.remote-connect,.remote-controls{width:100%;max-width:340px;display:flex;flex-direction:column;gap:12px;}
.remote-capture-row{display:flex;gap:8px;}
.remote-capture-row .btn b{display:block;font-size:14px;font-family:"SF Mono",Menlo,Consolas,monospace;}
.remote-connect label{font-size:12px;color:var(--muted);}
#remoteCodeInput{
  width:100%;padding:14px;font-size:20px;text-align:center;letter-spacing:.1em;
  border-radius:16px;border:1px solid rgba(26,26,26,.08);background:var(--surface);color:var(--text);
  box-shadow:0 4px 14px rgba(26,26,26,.10);
}
#remoteCodeInput:focus-visible{outline:2px solid var(--amber);}
.remote-status-badge{
  align-self:center;background:var(--surface);border:1px solid rgba(26,26,26,.08);
  border-radius:100px;padding:8px 18px;font-size:13px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;box-shadow:0 4px 14px rgba(26,26,26,.10);
}
.remote-controls .btn{padding:16px;font-size:15px;}
.remote-stats{display:flex;justify-content:center;gap:6px;font-size:12px;color:var(--muted);}
.remote-stats b{color:var(--text);}

.remote-clips-list{max-height:340px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;}

/* ===== Tutoriel ===== */
.tutorial-ui{
  display:none;position:absolute;inset:0;z-index:10;
  flex-direction:column;height:100dvh;overflow:hidden;background:var(--bg);
  padding:calc(env(safe-area-inset-top,0px) + 16px) 16px calc(env(safe-area-inset-bottom,0px) + 16px);
}
.tutorial-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;}
.tuto-step{
  border:1px solid rgba(26,26,26,.08);border-radius:18px;background:var(--surface);
  padding:14px;margin-bottom:14px;box-shadow:0 6px 18px rgba(26,26,26,.12);
}
.tuto-step h3{margin:0 0 8px;font-size:14px;}
.tuto-step p{margin:0 0 8px;font-size:13px;line-height:1.5;color:var(--text);}
.tuto-step p:last-child{margin-bottom:0;}
.tuto-step b{color:var(--flag);}

/* ===== Après entraînement (Coaching) ===== */
.coaching-ui{
  display:none;position:absolute;inset:0;z-index:10;
  flex-direction:column;height:100dvh;overflow:hidden;background:var(--bg);
  padding:calc(env(safe-area-inset-top,0px) + 16px) 16px calc(env(safe-area-inset-bottom,0px) + 16px);
}
.coaching-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;position:relative;}
.coaching-head h2{font-size:16px;margin:0;flex:1;}
.coaching-head .icon-btn{
  width:36px;height:36px;background:var(--surface);border:1px solid rgba(26,26,26,.08);
  color:var(--text);backdrop-filter:none;font-size:18px;
}
.coaching-controls{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap;}
.coaching-controls .btn{padding:7px 14px;font-size:12px;border-radius:100px;}
.filter-chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px;}
.filter-chip{
  border:1px solid rgba(26,26,26,.08);background:var(--surface);color:var(--text);
  border-radius:100px;padding:5px 12px;font-size:11px;font-weight:700;cursor:pointer;
}
.filter-chip.active{background:var(--flag);color:#fff;border-color:var(--border);}

.coaching-more-menu{
  display:none;position:absolute;top:48px;right:0;z-index:30;background:var(--surface);
  border-radius:16px;box-shadow:0 8px 24px rgba(26,26,26,.16);padding:10px;gap:8px;flex-direction:column;min-width:220px;
}
.coaching-more-menu.open{display:flex;}
.coaching-more-menu .btn{font-size:12px;padding:9px 12px;}

/* ---- Flux par date + grille de miniatures ---- */
.coaching-feed{flex:1;overflow-y:auto;min-height:0;}
.date-group-header{display:flex;align-items:baseline;gap:8px;margin:18px 0 10px;}
.date-group-header:first-child{margin-top:0;}
.date-group-title{font-weight:800;font-size:14px;text-transform:capitalize;flex:1;min-width:0;}
.date-group-rename{background:none;border:none;color:var(--muted);font-size:13px;cursor:pointer;padding:2px 4px;}
.date-group-count{font-size:11px;color:var(--muted);}

.thumb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.thumb-tile{
  position:relative;aspect-ratio:4/3;border-radius:14px;overflow:hidden;background:#000;
  cursor:pointer;border:none;padding:0;box-shadow:0 4px 14px rgba(26,26,26,.10);
}
.thumb-tile video{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;}
.thumb-tile-time{
  position:absolute;left:6px;bottom:6px;color:#fff;font-size:10px;font-weight:700;
  text-shadow:0 1px 3px rgba(0,0,0,.6);
}
.thumb-tile-badge{
  position:absolute;top:6px;right:6px;background:rgba(26,26,26,.65);color:#fff;
  font-size:10px;font-weight:800;border-radius:100px;padding:2px 7px;
}
.thumb-tile-fav{position:absolute;top:6px;left:6px;color:var(--flag);font-size:14px;text-shadow:0 1px 3px rgba(0,0,0,.5);}

/* ---- Écran détail (plein écran) ---- */
.clip-detail-overlay{
  display:none;position:fixed;inset:0;z-index:80;background:var(--bg);
  flex-direction:column;overflow-y:auto;
  padding:calc(env(safe-area-inset-top,0px) + 16px) 16px calc(env(safe-area-inset-bottom,0px) + 16px);
}
.clip-detail-overlay.open{display:flex;}
.clip-detail-head{margin-bottom:14px;}
.clip-detail-box{max-width:560px;width:100%;margin:0 auto;}
.clip-detail-box video{border-radius:16px;width:100%;display:block;margin-bottom:14px;background:#000;}

/* ---- Favori : plus visible ---- */
.fav-btn{
  display:flex;align-items:center;justify-content:center;float:right;border:1px solid rgba(26,26,26,.08);background:var(--surface-2);
  color:var(--muted);font-size:18px;line-height:1;width:36px;height:36px;border-radius:50%;cursor:pointer;
}
.fav-btn.active{background:var(--flag);color:#fff;border-color:var(--border);}

/* ---- Chips éditables (joueurs / tags) ---- */
.chip-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:10px;}
.chip-row label{width:100%;font-size:11px;color:var(--muted);margin-bottom:2px;}
.editable-chip{display:inline-flex;align-items:center;gap:4px;border:1px solid rgba(26,26,26,.08);background:var(--surface-2);color:var(--flag);border-radius:100px;padding:4px 6px 4px 12px;font-size:12px;font-weight:700;}
.editable-chip.action{color:var(--text);}
.editable-chip button{background:none;border:none;color:var(--muted);font-size:14px;cursor:pointer;padding:0 6px;line-height:1;}
.add-chip-btn{border:2px dashed var(--border);background:none;color:var(--muted);border-radius:100px;padding:5px 12px;font-size:11px;font-weight:700;cursor:pointer;}

/* ---- Pavé numérique (numpad) ---- */
.numpad-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:200;align-items:center;justify-content:center;padding:20px;}
.numpad-overlay.open{display:flex;}
.numpad-box{background:var(--surface);border:1px solid rgba(26,26,26,.08);border-radius:16px;padding:20px;width:100%;max-width:280px;box-shadow:0 8px 24px rgba(26,26,26,.14);}
.numpad-display{font-family:"SF Mono",Menlo,Consolas,monospace;font-size:32px;font-weight:800;text-align:center;color:var(--flag);border:1px solid rgba(26,26,26,.08);border-radius:16px;padding:10px;margin:8px 0 14px;background:var(--bg);}
.numpad-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.numpad-grid button{border:1px solid rgba(26,26,26,.08);background:var(--surface-2);color:var(--text);border-radius:16px;padding:14px 0;font-size:18px;font-weight:700;cursor:pointer;}
.numpad-grid button.ok{background:var(--flag);color:#fff;}

/* ---- Popup ajout de tag ---- */
.tag-popup-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:200;align-items:center;justify-content:center;padding:20px;}
.tag-popup-overlay.open{display:flex;}
.tag-popup-box{background:var(--surface);border:1px solid rgba(26,26,26,.08);border-radius:16px;padding:20px;width:100%;max-width:320px;box-shadow:0 8px 24px rgba(26,26,26,.14);}
.tag-popup-box input{width:100%;border:1px solid rgba(26,26,26,.08);border-radius:14px;padding:9px 10px;font-size:14px;font-family:inherit;background:var(--bg);color:var(--text);margin:6px 0 12px;}
.tag-popup-box input[type=range]{border:none;padding:0;background:transparent;margin:8px 0 4px;accent-color:var(--flag);}
.custom-dur-value{font-size:34px;font-weight:800;color:var(--flag);font-family:"SF Mono",Menlo,Consolas,monospace;margin:8px 0 2px;}
.tag-popup-suggestions{display:flex;flex-wrap:wrap;gap:6px;}

.numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;}
.numpad-key{padding:14px 0;font-size:18px;font-weight:700;border:1px solid rgba(26,26,26,.08);background:var(--surface-2);border-radius:14px;}
.numpad-key.ok{background:var(--flag);color:#fff;}
.session-summary-stats{display:flex;flex-direction:column;gap:8px;text-align:left;}
.session-summary-row{display:flex;align-items:center;gap:10px;border:1px solid rgba(26,26,26,.08);border-radius:14px;padding:10px 14px;font-size:13px;}
.session-summary-row span:first-child{font-size:16px;}
.session-summary-row b{font-size:15px;}
.session-summary-row span:last-child{color:var(--muted);}

/* ===== Video Room — desktop ===== */
@media(min-width:900px){
  .coaching-ui{padding:32px 40px;}
  .coaching-head h2{font-size:20px;}
  .coaching-head, .coaching-controls, .filter-chips, .coaching-feed{max-width:1100px;margin-left:auto;margin-right:auto;width:100%;}
  .thumb-grid{grid-template-columns:repeat(5,1fr);gap:14px;}
  .clip-detail-box{max-width:640px;}
}
@media(min-width:1300px){
  .thumb-grid{grid-template-columns:repeat(6,1fr);}
}
