/* ─────────────────────────────────────────────────────────────
   iaxion Meet — v2 UI
   Charte iaxion : indigo profond + accent corail
   Toutes les classes et IDs JS existants sont préservés
   ───────────────────────────────────────────────────────────── */

:root{
  --bg:#0b0b14;
  --bg-grad:radial-gradient(ellipse 80% 60% at 50% -10%, rgba(99,102,241,.18) 0%, transparent 60%),
            radial-gradient(ellipse 60% 50% at 90% 110%, rgba(244,114,182,.10) 0%, transparent 65%);
  --surface:#13131f;
  --surface2:#1a1a2a;
  --surface3:#212135;
  --border:#2a2a40;
  --border-soft:#1f1f30;
  --accent:#6366f1;       /* indigo iaxion */
  --accent-2:#8b8cf2;
  --accent-glow:rgba(99,102,241,.35);
  --accent-warm:#f472b6;  /* corail/rose secondaire */
  --accent-ok:#34d399;
  --accent-err:#f87171;
  --text:#ececf5;
  --text-soft:#c9c9da;
  --muted:#7a7a9c;
  --muted-2:#9696b8;
  --font:'Syne',system-ui,sans-serif;
  --mono:'DM Mono',ui-monospace,monospace;
  --r-sm:8px; --r-md:12px; --r-lg:18px; --r-xl:24px;
  --shadow-card:0 1px 0 rgba(255,255,255,.04) inset, 0 30px 80px -40px rgba(0,0,0,.6);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{min-height:100vh}

/* ── Thème Light (Kraft chaud) ───────────────────────────── */
[data-theme="light"]{
  --bg:#EDE0C8;
  --bg-grad:radial-gradient(ellipse 80% 60% at 50% -10%, rgba(196,112,58,.12) 0%, transparent 60%),
            linear-gradient(180deg,#EDE0C8 0%,#E4D4B8 100%);
  --surface:#F5ECD7;
  --surface2:#EAD9C0;
  --surface3:#DFC9A8;
  --border:#D4B896;
  --border-soft:#DEC9A8;
  --accent:#C4703A;
  --accent-2:#D4845A;
  --accent-glow:rgba(196,112,58,.3);
  --accent-warm:#A84830;
  --accent-ok:#4A8C4A;
  --accent-err:#C0392B;
  --text:#3D2005;
  --text-soft:#6B3A10;
  --muted:#8C5C30;
  --muted-2:#A07040;
  color-scheme:light;
}
[data-theme="light"] body{
  background:var(--bg);
  background-image:var(--bg-grad);
  color:var(--text);
}
[data-theme="light"] .card{background:var(--surface);border-color:var(--border);}
[data-theme="light"] header{background:var(--surface);border-color:var(--border);}
[data-theme="light"] .logo-text{color:var(--text);}
[data-theme="light"] .logo-text span{color:var(--accent);}
[data-theme="light"] textarea,
[data-theme="light"] input[type="text"],
[data-theme="light"] input[type="password"],
[data-theme="light"] select{background:#fff;border-color:var(--border);color:var(--text);}
[data-theme="light"] input::placeholder,[data-theme="light"] textarea::placeholder{color:var(--muted);}
[data-theme="light"] .tab-btn{color:var(--muted);background:transparent;}
[data-theme="light"] .tab-btn:hover{color:var(--text);}
[data-theme="light"] .tab-btn.active{color:#fff;background:var(--accent);border-bottom-color:var(--accent);}
[data-theme="light"] .step-pill{background:#fff;border-color:var(--border);color:var(--muted);}
[data-theme="light"] .step-pill.active{border-color:var(--accent);color:var(--text);background:#fff;box-shadow:0 0 0 2px var(--accent);}
[data-theme="light"] .step-pill.active .step-n{background:var(--accent);color:#fff;}
[data-theme="light"] .step-pill.done .step-n{background:var(--accent-ok);color:#fff;}
[data-theme="light"] .step-pill.done{opacity:1;border-color:var(--accent-ok);}
[data-theme="light"] .step-pill.done span:last-child{color:var(--muted);}
[data-theme="light"] .step-pill:not(.active):not(.done) span:last-child{color:var(--muted);}
[data-theme="light"] .step-arrow{color:var(--muted);}
[data-theme="light"] .sec{color:var(--muted-2);}
[data-theme="light"] .rec-timer{color:var(--text);}
[data-theme="light"] .rec-btn{background:var(--accent);}
[data-theme="light"] .login-card{background:var(--surface);border-color:var(--border);}
[data-theme="light"] .login-card input{background:var(--surface2);}
[data-theme="light"] .hist-card{background:var(--surface);border-color:var(--border);}
[data-theme="light"] .hist-card:hover{border-color:var(--accent);}
[data-theme="light"] audio{filter:invert(0) sepia(.2);}
[data-theme="light"] .prog-bar{background:var(--surface2);}
[data-theme="light"] .prog-fill{background:var(--accent);}
[data-theme="light"] .cbtn{background:var(--surface2);border-color:var(--border);color:var(--muted);}
[data-theme="light"] .cbtn:hover{border-color:var(--accent);color:var(--accent);}
[data-theme="light"] .btn-p{background:linear-gradient(135deg,var(--accent),var(--accent-warm));}
[data-theme="light"] .btn-g{background:var(--surface2);border-color:var(--border);color:var(--muted);}
[data-theme="light"] .btn-g:hover{border-color:var(--accent);color:var(--accent);}
[data-theme="light"] .step-panel{background:var(--surface);}
[data-theme="light"] .drop-zone{background:var(--surface2);border-color:var(--border);}
[data-theme="light"] .toast{background:var(--accent);color:#fff;}
[data-theme="light"] .lang-btn,[data-theme="light"] #themeBtn{
  border-color:var(--border);color:var(--muted);background:var(--surface2);}
body{
  background:var(--bg);
  background-image:var(--bg-grad);
  color:var(--text);font-family:var(--font);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ── Header ───────────────────────────────────────────────── */
header{
  position:relative;z-index:10;
  padding:18px 32px;
  display:flex;align-items:center;justify-content:flex-start;gap:18px;
  border-bottom:1px solid var(--border-soft);
  background:rgba(11,11,20,.6);
  backdrop-filter:blur(10px);
}
.logo{
  display:flex;align-items:center;gap:10px;
  font-size:1.05rem;font-weight:800;letter-spacing:-.02em;
}
.logo-mark{
  width:30px;height:30px;border-radius:8px;
  background:linear-gradient(135deg,var(--accent) 0%, var(--accent-warm) 100%);
  display:grid;place-items:center;color:#fff;font-weight:900;font-size:.85rem;
  box-shadow:0 8px 24px -8px var(--accent-glow);
}
.logo-text{font-family:var(--font)}
.logo-text span{color:var(--accent-2)}
.logo-sub{
  font-family:var(--mono);font-size:.7rem;color:var(--muted);
  border-left:1px solid var(--border);padding-left:14px;margin-left:4px;
}
.lang-btn,.admin-btn{
  background:none;border:1px solid var(--border);
  color:var(--muted);font-family:var(--mono);font-size:.68rem;
  padding:6px 11px;border-radius:6px;cursor:pointer;transition:all .2s;
}
.lang-btn{margin-left:auto}
.lang-btn:hover,.admin-btn:hover{border-color:var(--accent);color:var(--text)}
.admin-btn{border-color:transparent;text-decoration:underline;text-underline-offset:3px}

/* ── Tabs ─────────────────────────────────────────────────── */
.tabs{
  position:relative;z-index:10;
  display:flex;gap:6px;padding:22px 32px 0;flex-wrap:wrap;
}
.tab-btn{
  background:none;border:1px solid transparent;
  color:var(--muted);font-family:var(--font);
  font-size:.78rem;font-weight:600;letter-spacing:.04em;
  padding:9px 16px;border-radius:10px 10px 0 0;
  cursor:pointer;transition:all .2s;
}
.tab-btn:hover{color:var(--text)}
.tab-btn.active{
  background:var(--surface);border-color:var(--border);border-bottom-color:var(--surface);
  color:var(--text);
}

/* ── Container ────────────────────────────────────────────── */
.container{
  position:relative;z-index:10;
  margin:0 32px 40px;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:0 var(--r-lg) var(--r-lg) var(--r-lg);
  padding:30px 32px 36px;
  min-height:70vh;
  box-shadow:var(--shadow-card);
}
.panel{display:none}.panel.active{display:block;animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ── Stepper (Réunion uniquement) ─────────────────────────── */
.stepper{
  display:flex;align-items:center;justify-content:center;
  gap:8px;margin:6px 0 30px;flex-wrap:wrap;
}
.step-pill{
  display:flex;align-items:center;gap:10px;
  padding:9px 16px;
  background:var(--surface2);border:1px solid var(--border);
  border-radius:999px;cursor:pointer;
  font-family:var(--mono);font-size:.74rem;color:var(--muted);
  transition:all .25s;
}
.step-pill .step-n{
  width:22px;height:22px;border-radius:50%;
  background:var(--surface3);color:var(--muted);
  display:grid;place-items:center;font-weight:700;font-size:.72rem;
  transition:all .25s;
}
.step-pill.done{border-color:rgba(52,211,153,.4);color:var(--text-soft)}
.step-pill.done .step-n{background:var(--accent-ok);color:#0b0b14}
.step-pill.active{
  background:linear-gradient(135deg, rgba(99,102,241,.18), rgba(244,114,182,.10));
  border-color:var(--accent);color:var(--text);
  box-shadow:0 0 0 4px rgba(99,102,241,.08);
}
.step-pill.active .step-n{background:var(--accent);color:#fff}
.step-arrow{color:var(--muted);font-family:var(--mono);font-size:.7rem;opacity:.5}

.step-panel{display:none;animation:fadeIn .3s ease}
.step-panel.active{display:block}
.step-head{margin-bottom:22px}
.step-eyebrow{
  font-family:var(--mono);font-size:.68rem;color:var(--accent-2);
  letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px;
}
.step-title{font-size:1.4rem;font-weight:700;letter-spacing:-.01em;margin-bottom:6px}
.step-desc{font-family:var(--mono);font-size:.82rem;color:var(--muted-2);max-width:560px;line-height:1.6}

.step-nav{
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  margin-top:28px;padding-top:22px;border-top:1px solid var(--border-soft);
  flex-wrap:wrap;
}
@media(max-width:520px){
  .step-nav{flex-direction:column;align-items:stretch;}
  .step-nav .btn{width:100%;text-align:center;justify-content:center;}
  .step-nav span{text-align:center;}
}

/* ── Sections génériques ──────────────────────────────────── */
.sec{
  font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted);margin-bottom:14px;display:flex;align-items:center;gap:8px;
}
.sec::before{content:'';display:inline-block;width:18px;height:2px;background:currentColor;border-radius:2px}

/* ── Source audio (étape 1) ──────────────────────────────── */
.source-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.src-card{
  background:var(--surface2);border:1.5px solid var(--border);
  border-radius:var(--r-lg);padding:22px;
  transition:all .25s;display:flex;flex-direction:column;gap:14px;
}
.src-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.src-card-title{font-size:1rem;font-weight:700;display:flex;align-items:center;gap:10px}
.src-card-icon{
  width:36px;height:36px;border-radius:10px;
  background:linear-gradient(135deg,var(--accent),var(--accent-warm));
  display:grid;place-items:center;font-size:1.1rem;
}
.src-row{display:flex;gap:14px;flex-wrap:wrap}
.src-lbl{
  display:flex;align-items:center;gap:7px;
  font-family:var(--mono);font-size:.74rem;color:var(--muted-2);
  cursor:pointer;user-select:none;
}
.src-lbl input[type=radio]{accent-color:var(--accent);width:14px;height:14px;cursor:pointer}
.src-lbl:hover{color:var(--text)}
.src-note{font-family:var(--mono);font-size:.7rem;color:var(--accent-warm);min-height:1rem}

.recorder-box{
  display:flex;flex-direction:column;align-items:center;gap:14px;
  padding:18px 8px 14px;
}
.rec-timer{font-family:var(--mono);font-size:1.8rem;font-weight:500;letter-spacing:.05em}
.rec-btn{
  width:72px;height:72px;border-radius:50%;
  border:3px solid var(--accent);background:none;cursor:pointer;
  position:relative;transition:all .3s;outline:none;
}
.rec-btn::before{
  content:'';position:absolute;inset:9px;border-radius:50%;
  background:var(--accent);transition:all .3s;
}
.rec-btn:hover{box-shadow:0 0 0 6px rgba(99,102,241,.15)}
.rec-btn.recording{border-color:var(--accent-err);animation:pulse 1.2s ease-out infinite}
.rec-btn.recording::before{background:var(--accent-err);border-radius:6px;inset:20px}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(248,113,113,.5)}
  70%{box-shadow:0 0 0 18px rgba(248,113,113,0)}
  100%{box-shadow:0 0 0 0 rgba(248,113,113,0)}
}
.rec-status{font-family:var(--mono);font-size:.78rem;color:var(--muted);text-align:center}
.rec-status.on{color:var(--accent-err)}
.viz{width:100%;height:40px}.viz canvas{width:100%;height:100%;display:block}

.upload-lbl{
  border:1.5px dashed var(--border);border-radius:var(--r-md);
  padding:20px 14px;text-align:center;cursor:pointer;
  transition:all .2s;font-size:.82rem;color:var(--muted-2);display:block;width:100%;
}
.upload-lbl:hover{border-color:var(--accent);color:var(--text);background:rgba(99,102,241,.04)}
.upload-lbl input{display:none}
.fi{font-family:var(--mono);font-size:.76rem;color:var(--muted-2);margin-top:10px;min-height:1.2em;text-align:center}

/* ── Étape 2 / Transcription ─────────────────────────────── */
.trans-stage{
  background:var(--surface2);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:24px;
}
.prog{display:none;margin:14px 0}
.prog-lbl{font-family:var(--mono);font-size:.76rem;color:var(--muted);margin-bottom:7px}
.prog-bar{background:var(--surface3);border:1px solid var(--border);border-radius:6px;height:9px;overflow:hidden}
.prog-fill{
  height:100%;width:0%;
  background:linear-gradient(90deg,var(--accent),var(--accent-warm));
  transition:width .3s;border-radius:6px;
}
.res-ta{
  width:100%;min-height:220px;padding:18px;
  background:var(--surface3);border:1px solid var(--border);border-radius:var(--r-md);
  resize:vertical;outline:none;
  font-family:var(--mono);font-size:.86rem;line-height:1.75;color:var(--text);
  transition:border-color .2s;
}
.res-ta:focus{border-color:var(--accent)}

/* ── Étape 3 / CR ────────────────────────────────────────── */
.cr-types{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:10px;margin-bottom:18px;
}
.cr-chip{
  background:var(--surface2);border:1.5px solid var(--border);color:var(--text-soft);
  font-family:var(--font);font-size:.82rem;font-weight:600;
  padding:14px 14px;border-radius:var(--r-md);cursor:pointer;
  text-align:left;transition:all .2s;display:flex;flex-direction:column;gap:4px;
}
.cr-chip small{font-family:var(--mono);font-size:.66rem;color:var(--muted);font-weight:400}
.cr-chip:hover{border-color:var(--accent-2)}
.cr-chip.sel{
  background:linear-gradient(135deg, rgba(99,102,241,.16), rgba(244,114,182,.08));
  border-color:var(--accent);color:var(--text);
  box-shadow:0 0 0 4px rgba(99,102,241,.08);
}
.cr-chip.sel small{color:var(--accent-2)}

/* ── Boutons & rangées ───────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font);font-size:.78rem;font-weight:700;
  letter-spacing:.04em;
  padding:11px 18px;border-radius:10px;border:none;cursor:pointer;
  transition:all .2s;outline:none;white-space:nowrap;
}
.btn-p{
  background:linear-gradient(135deg,var(--accent),#7c7ef4);
  color:#fff;box-shadow:0 8px 24px -10px var(--accent-glow);
}
.btn-p:hover{transform:translateY(-1px);box-shadow:0 12px 30px -10px var(--accent-glow)}
.btn-p:disabled{opacity:.4;cursor:default;transform:none;box-shadow:none}
.btn-g{background:none;border:1px solid var(--border);color:var(--muted-2)}
.btn-g:hover{border-color:var(--accent);color:var(--text)}
.btn-g:disabled{opacity:.4;cursor:default}
.btn-gr{background:none;border:1px solid var(--accent-ok);color:var(--accent-ok)}
.btn-gr:hover{background:var(--accent-ok);color:#0b0b14}
.btn-gr:disabled{opacity:.4;cursor:default}
.btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}

.cbtn{
  background:none;border:1px solid var(--border);color:var(--muted);
  font-family:var(--mono);font-size:.72rem;padding:6px 12px;border-radius:6px;
  cursor:pointer;transition:all .2s;
}
.cbtn:hover{border-color:var(--accent);color:var(--text)}

/* ── Loader ──────────────────────────────────────────────── */
.ld{display:none;align-items:center;gap:8px;font-family:var(--mono);font-size:.8rem;color:var(--muted);margin-top:12px}
.ld.on{display:flex}
.sp{
  width:15px;height:15px;
  border:2px solid rgba(255,255,255,.15);border-top-color:var(--accent);
  border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Toast ───────────────────────────────────────────────── */
.toast{
  position:fixed;bottom:24px;right:24px;z-index:999;
  background:var(--surface2);border:1px solid var(--border);
  padding:13px 20px;border-radius:10px;font-size:.84rem;
  transform:translateY(16px);opacity:0;transition:all .3s;pointer-events:none;
  box-shadow:0 20px 40px -20px rgba(0,0,0,.6);
}
.toast.on{transform:translateY(0);opacity:1}
.toast.ok{border-left:3px solid var(--accent-ok)}
.toast.err{border-left:3px solid var(--accent-err)}

/* ── Login ───────────────────────────────────────────────── */
#loginScreen{
  position:fixed;inset:0;z-index:1000;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg);background-image:var(--bg-grad);
}
#loginScreen.hidden{display:none}
.login-box{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-xl);padding:40px 36px;
  width:100%;max-width:380px;text-align:center;
  box-shadow:0 40px 80px -30px rgba(0,0,0,.7);
}
.login-mark{
  width:56px;height:56px;border-radius:14px;margin:0 auto 18px;
  background:linear-gradient(135deg,var(--accent),var(--accent-warm));
  display:grid;place-items:center;color:#fff;font-weight:900;font-size:1.4rem;
  box-shadow:0 16px 40px -10px var(--accent-glow);
}
.login-logo{font-size:1.4rem;font-weight:800;letter-spacing:-.02em;margin-bottom:4px}
.login-logo span{color:var(--accent-2)}
.login-sub{
  font-family:var(--mono);font-size:.7rem;color:var(--muted);
  margin-bottom:28px;letter-spacing:.06em;text-transform:uppercase;
}
.login-lbl{
  font-family:var(--mono);font-size:.66rem;color:var(--muted);
  text-align:left;display:block;margin-bottom:6px;
  text-transform:uppercase;letter-spacing:.08em;
}
.login-inp{
  width:100%;background:var(--surface2);border:1px solid var(--border);
  color:var(--text);font-family:var(--mono);font-size:.9rem;
  padding:12px 16px;border-radius:10px;outline:none;
  transition:border-color .2s;margin-bottom:16px;
}
.login-inp:focus{border-color:var(--accent)}
.login-btn{
  width:100%;
  background:linear-gradient(135deg,var(--accent),#7c7ef4);
  color:#fff;font-family:var(--font);font-size:.85rem;font-weight:700;
  letter-spacing:.04em;padding:13px;border-radius:10px;
  border:none;cursor:pointer;transition:all .2s;
  box-shadow:0 12px 30px -10px var(--accent-glow);
}
.login-btn:hover{transform:translateY(-1px)}
.login-err{font-family:var(--mono);font-size:.74rem;color:var(--accent-err);margin-top:10px;min-height:1.2em}

/* ── Modale admin ────────────────────────────────────────── */
.modal-overlay{
  position:fixed;inset:0;z-index:2000;
  background:rgba(0,0,0,.7);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .2s;
}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);width:100%;max-width:420px;
  max-height:90vh;overflow-y:auto;
  box-shadow:0 40px 80px -20px rgba(0,0,0,.6);
}
.modal-hd{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}
.modal-title{font-size:1rem;font-weight:700}
.modal-close{background:none;border:none;color:var(--muted);font-size:1.1rem;cursor:pointer;padding:4px 8px;border-radius:6px}
.modal-close:hover{color:var(--text)}
.modal-body{padding:20px 24px 24px;display:flex;flex-direction:column;gap:12px}
.adm-grp{display:flex;flex-direction:column;gap:5px}
.adm-lbl{font-family:var(--mono);font-size:.68rem;color:var(--muted)}
.adm-inp{
  background:var(--surface2);border:1px solid var(--border);color:var(--text);
  font-family:var(--mono);font-size:.85rem;padding:10px 13px;border-radius:8px;
  outline:none;transition:border-color .2s;
}
.adm-inp:focus{border-color:var(--accent)}
.adm-btn{
  background:linear-gradient(135deg,var(--accent),#7c7ef4);color:#fff;
  font-family:var(--mono);font-size:.75rem;font-weight:500;
  padding:10px 16px;border-radius:8px;border:none;cursor:pointer;
  transition:all .2s;text-align:left;
}
.adm-btn:hover{transform:translateY(-1px)}
.adm-btn-danger{background:transparent;border:1px solid var(--accent-err);color:var(--accent-err)}
.adm-btn-danger:hover{background:var(--accent-err);color:#fff;transform:none}
.adm-msg{font-family:var(--mono);font-size:.72rem;min-height:1.2em}
.adm-msg.ok{color:var(--accent-ok)}
.adm-msg.err{color:var(--accent-err)}
.adm-divider{border:none;border-top:1px solid var(--border);margin:4px 0}

/* ── Correcteur / Traducteur (layout 2 colonnes simple) ──── */
.correcteur-layout{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.tw{position:relative}
.cc{position:absolute;bottom:10px;right:12px;font-family:var(--mono);font-size:.68rem;color:var(--muted)}
.big-ta{
  width:100%;height:300px;padding:16px;
  background:var(--surface2);border:1px solid var(--border);
  border-radius:var(--r-md);resize:vertical;outline:none;
  font-family:var(--mono);font-size:.86rem;line-height:1.75;color:var(--text);
  transition:border-color .2s;
}
.big-ta:focus{border-color:var(--accent)}
.res-box{
  width:100%;min-height:280px;padding:18px;
  background:var(--surface2);border:1px solid var(--border);border-radius:var(--r-md);
  font-family:var(--mono);font-size:.85rem;line-height:1.75;color:var(--text);
  overflow-y:auto;white-space:pre-wrap;
}
.res-box.ph{color:var(--muted);font-style:italic;font-size:.8rem}
.chips{display:flex;gap:7px;flex-wrap:wrap;margin:10px 0}
.chip{
  background:var(--surface2);border:1px solid var(--border);color:var(--muted);
  font-family:var(--mono);font-size:.72rem;padding:6px 12px;border-radius:6px;
  cursor:pointer;transition:all .2s;
}
.chip:hover{border-color:var(--accent-2);color:var(--text)}
.chip.on{background:var(--accent);border-color:var(--accent);color:#fff}
.lbl{font-size:.7rem;color:var(--muted);font-weight:700;letter-spacing:.08em;text-transform:uppercase;display:block;margin-bottom:6px}
.inp{
  width:100%;background:var(--surface2);border:1px solid var(--border);color:var(--text);
  font-family:var(--mono);font-size:.82rem;padding:10px 14px;border-radius:8px;
  outline:none;transition:border-color .2s;
}
.inp:focus{border-color:var(--accent)}
.div{height:1px;background:var(--border-soft);margin:18px 0}

/* ── Historique ──────────────────────────────────────────── */
.hist-empty{font-family:var(--mono);font-size:.82rem;color:var(--muted);text-align:center;padding:50px 0}
.hist-card{
  background:var(--surface2);border:1px solid var(--border);
  border-radius:var(--r-md);padding:16px 20px;margin-bottom:10px;
  display:flex;flex-direction:column;gap:10px;transition:border-color .2s;
}
.hist-card:hover{border-color:var(--accent-2)}
.hist-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.hist-title{font-size:.95rem;font-weight:600}
.hist-meta{font-family:var(--mono);font-size:.68rem;color:var(--muted);display:flex;gap:12px;flex-wrap:wrap}
.hist-badge{font-family:var(--mono);font-size:.6rem;padding:2px 7px;border-radius:4px;white-space:nowrap}
.hist-badge-ok{background:rgba(52,211,153,.12);color:var(--accent-ok)}
.hist-badge-exp{background:rgba(248,113,113,.12);color:var(--accent-err)}
.hist-badge-day{background:rgba(99,102,241,.12);color:var(--accent-2)}
.hist-actions{display:flex;gap:8px;flex-wrap:wrap}
.hist-btn{
  font-family:var(--mono);font-size:.7rem;padding:6px 12px;border-radius:7px;
  border:1px solid var(--border);background:none;color:var(--muted);cursor:pointer;
  transition:all .2s;
}
.hist-btn:hover{border-color:var(--accent);color:var(--text)}
.hist-btn-del{border-color:rgba(248,113,113,.4);color:var(--accent-err)}
.hist-btn-del:hover{background:var(--accent-err);color:#fff;border-color:var(--accent-err)}
.hist-btn-transcribe{border-color:rgba(99,102,241,.4);color:var(--accent-2)}
.hist-btn-transcribe:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.hist-btn-transcribe.loading{opacity:.6;pointer-events:none}
.hist-result{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.hist-result-tabs{display:flex;gap:6px}
.hist-rtab{
  font-family:var(--mono);font-size:.68rem;padding:5px 10px;border-radius:6px;
  border:1px solid var(--border);background:none;color:var(--muted);cursor:pointer;
  transition:all .2s;
}
.hist-rtab.active{border-color:var(--accent);color:var(--accent-2)}
.hist-cr-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding-top:4px}
.hist-cr-type{
  background:var(--surface3);border:1px solid var(--border);color:var(--text);
  font-family:var(--mono);font-size:.72rem;padding:5px 8px;border-radius:6px;outline:none;
}
.hist-cr{
  background:var(--surface3);border-radius:8px;padding:12px 14px;
  font-size:.78rem;color:var(--text-soft);white-space:pre-wrap;line-height:1.6;
  max-height:200px;overflow-y:auto;display:none;
}
.hist-cr.open{display:block}
audio{width:100%;height:36px;accent-color:var(--accent)}

/* ── Responsive ──────────────────────────────────────────── */
@media(max-width:880px){
  header{padding:14px 18px;flex-wrap:wrap}
  .logo-sub{display:none}
  .tabs{padding:18px 18px 0}
  .container{margin:0 12px 24px;padding:22px 18px 28px}
  .source-grid,.correcteur-layout{grid-template-columns:1fr}
  .stepper{gap:4px}
  .step-pill{padding:7px 12px;font-size:.7rem}
  .step-arrow{display:none}
}

/* CR type cards en light */
[data-theme="light"] .cr-type-btn{background:#fff;border-color:var(--border);color:var(--text);}
[data-theme="light"] .cr-chip{background:#fff;border-color:var(--border);color:var(--text);}
[data-theme="light"] .cr-chip small{color:var(--muted);}
[data-theme="light"] .cr-chip:hover{border-color:var(--accent);}
[data-theme="light"] .cr-chip.sel{background:rgba(196,112,58,.08);border-color:var(--accent);color:var(--text);box-shadow:0 0 0 3px rgba(196,112,58,.12);}
[data-theme="light"] .cr-chip.sel small{color:var(--accent);}
[data-theme="light"] .cr-type-btn .cr-type-title{color:var(--text);}
[data-theme="light"] .cr-type-btn .cr-type-desc{color:var(--muted);}
[data-theme="light"] .cr-type-btn:hover{border-color:var(--accent);}
[data-theme="light"] .cr-type-btn.active{border-color:var(--accent);background:rgba(196,112,58,.06);}
[data-theme="light"] .cr-type-btn.active .cr-type-title{color:var(--accent);}
[data-theme="light"] .cr-type-btn:not(.active) .cr-type-title{color:var(--muted-2);}

/* ── Historique light ────────────────────────────────────── */
[data-theme='light'] .hist-card{background:var(--surface);border-color:var(--border);}
[data-theme='light'] .hist-cr{background:var(--surface2);color:var(--text)!important;}
[data-theme='light'] .hist-card .hist-title{color:var(--text);}
[data-theme='light'] .hist-card .hist-meta{color:var(--muted);}
[data-theme='light'] .hist-btn{background:var(--surface2);border-color:var(--border);color:var(--muted);}
[data-theme='light'] .hist-btn:hover{border-color:var(--accent);color:var(--accent);}
[data-theme='light'] .hist-rtab{background:var(--surface2);border-color:var(--border);color:var(--muted);}
[data-theme='light'] .hist-rtab.active{border-color:var(--accent);color:var(--accent);background:rgba(196,112,58,.08);}
[data-theme='light'] .hist-cr-type{background:var(--surface);border-color:var(--border);color:var(--muted);}
[data-theme='light'] .hist-cr-type.active{border-color:var(--accent);color:var(--text);}
[data-theme='light'] .hist-cr-type select{background:var(--surface);border-color:var(--border);color:var(--text);}
[data-theme='light'] select{background:#fff;border-color:var(--border);color:var(--text);}
[data-theme='light'] audio{color-scheme:light;}
