/* ═══════════════════════════════════════════════════════════
   SNAPLAX V7 — STYLES
   Charte FTL v1.1 intégrée exactement
═══════════════════════════════════════════════════════════ */

/* ─── TOKENS FTL ─────────────────────────────────────────── */
:root {
  /* Palette FTL exacte */
  --bleu-nuit:   #0D2240;
  --bleu-marine: #1A3A6B;
  --mauve:       #B088E8;
  --mauve-fonce: #7A56C2;
  --acier:       #7A90A8;
  --ivoire:      #F0EEE8;

  /* Surfaces light mode */
  --bg:       #F5F3ED;
  --surface:  #FFFFFF;
  --surf2:    #EEF1F6;
  --border:   #D6DCE8;
  --text:     #0D2240;
  --muted:    #7A90A8;

  /* Catégories — 5 couleurs uniques, jamais réutilisées */
  --cat-debile:  #8C9AAA;   /* Débiles  — gris neutre, discret */
  --cat-divers:  #4A7FC1;   /* Divers   — bleu ardoise */
  --cat-comics:  #B088E8;   /* Comics   — mauve FTL */
  --cat-lacrosse:#2EA86B;   /* Lacrosse — vert action */
  --cat-media:   #F28C28;   /* Média/FTL— orange */

  /* Sémantiques */
  --danger:  #C93434;
  --success: #2EA86B;
  --warn:    #E8A020;

  /* Typographies FTL */
  --f-display: 'Barlow Condensed', sans-serif;
  --f-body:    'DM Sans', sans-serif;
  --f-mono:    'JetBrains Mono', monospace;

  /* Géométrie */
  --r:    12px;
  --rs:   7px;
  --rpill:20px;

  /* Ombres */
  --sh:  0 1px 4px rgba(13,34,64,.07), 0 2px 12px rgba(13,34,64,.04);
  --sh2: 0 4px 24px rgba(13,34,64,.13), 0 2px 8px rgba(13,34,64,.07);
}

[data-theme="dark"] {
  --bg:      #070F1C;
  --surface: #0D1E36;
  --surf2:   #12263F;
  --border:  #1C2E50;
  --text:    #DCE4F2;
  --muted:   #5A6A8A;
  --sh:  0 1px 4px rgba(0,0,0,.3);
  --sh2: 0 4px 24px rgba(0,0,0,.5);
}

/* ─── RESET ──────────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden}
body{
  background:var(--bg);color:var(--text);
  font-family:var(--f-body);font-size:15px;line-height:1.5;
  transition:background .25s,color .25s;
}
button{font-family:var(--f-body);cursor:pointer}
input,textarea{font-family:var(--f-body)}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}

/* ─── SHELL ──────────────────────────────────────────────── */
#app{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}

/* ─── HEADER ─────────────────────────────────────────────── */
#hdr{
  display:flex;align-items:center;
  padding:0 20px;height:52px;
  background:var(--bleu-nuit);
  flex-shrink:0;z-index:20;gap:0;
}
.logo{display:flex;align-items:center;gap:9px;margin-right:20px;flex-shrink:0}
.logo-img{width:30px;height:30px;border-radius:7px;object-fit:contain;background:white;padding:2px;flex-shrink:0}
.logo-name{font-family:var(--f-display);font-size:20px;font-weight:800;color:white;letter-spacing:.5px;text-transform:uppercase}
.logo-name span{color:var(--mauve)}
.nav{display:flex;gap:2px;flex:1;min-width:0}
.nav-btn{
  font-family:var(--f-display);font-size:12px;font-weight:700;letter-spacing:.6px;
  padding:6px 12px;border-radius:var(--rpill);border:none;
  background:transparent;color:rgba(255,255,255,.55);
  transition:all .18s;text-transform:uppercase;white-space:nowrap;
}
.nav-btn:hover{color:white;background:rgba(255,255,255,.1)}
.nav-btn.active{background:var(--mauve-fonce);color:white}
.hdr-r{margin-left:auto;display:flex;align-items:center;gap:8px;flex-shrink:0}
.hdr-stat{
  font-family:var(--f-mono);font-size:10px;color:rgba(255,255,255,.45);
  background:rgba(255,255,255,.07);border-radius:var(--rpill);
  padding:3px 9px;white-space:nowrap;
}
.hdr-stat b{color:rgba(255,255,255,.85);font-weight:500}
#theme-btn{
  width:30px;height:30px;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.2);
  background:transparent;color:rgba(255,255,255,.65);font-size:14px;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;flex-shrink:0;
}
#theme-btn:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.4)}
@media(max-width:520px){.hdr-stat{display:none}.logo-name{font-size:17px}.nav-btn{padding:5px 9px;font-size:11px}}

/* ─── STATUS BAR ─────────────────────────────────────────── */
#statusbar{
  background:var(--bleu-marine);
  padding:4px 20px;flex-shrink:0;
  display:flex;align-items:center;gap:14px;
  font-family:var(--f-mono);font-size:10px;color:rgba(255,255,255,.45);
  letter-spacing:.03em;min-height:24px;overflow:hidden;
}
#statusbar .sb-item{display:flex;align-items:center;gap:4px;white-space:nowrap}
#statusbar b{color:rgba(255,255,255,.8)}
#statusbar .danger{color:#e07070}
#statusbar .warn{color:#f0b060}

/* ─── PANELS ─────────────────────────────────────────────── */
.panel{display:none;flex:1;overflow:hidden;flex-direction:column}
.panel.active{display:flex}

/* ═══════════════════════════════════════════════════════════
   CAPTURE PANEL
═══════════════════════════════════════════════════════════ */

/* FILTER BAR */
.filterbar{
  padding:7px 16px;background:var(--surface);
  border-bottom:1.5px solid var(--border);flex-shrink:0;
  display:flex;gap:5px;align-items:center;
  overflow-x:auto;scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
  mask-image:linear-gradient(to right,transparent 0,black 10px,black 90%,transparent 100%);
}
.filterbar::-webkit-scrollbar{display:none}
.flbl{
  font-family:var(--f-mono);font-size:9px;color:var(--muted);
  letter-spacing:.1em;text-transform:uppercase;
  margin-right:2px;flex-shrink:0;
}
.fbtn{
  font-family:var(--f-mono);font-size:10px;padding:4px 11px;
  border-radius:var(--rpill);border:1.5px solid var(--border);
  background:transparent;color:var(--muted);flex-shrink:0;
  transition:all .15s;white-space:nowrap;
}
.fbtn:hover{color:var(--text);border-color:var(--muted)}
.fbtn.on{background:var(--bleu-nuit);color:white;border-color:var(--bleu-nuit)}
.fbtn[data-f="sub-debile"].on  {background:var(--cat-debile); border-color:var(--cat-debile)}
.fbtn[data-f="sub-divers"].on  {background:var(--cat-divers); border-color:var(--cat-divers)}
.fbtn[data-f="sub-comics"].on  {background:var(--cat-comics); border-color:var(--cat-comics)}
.fbtn[data-f="sub-lacrosse"].on{background:var(--cat-lacrosse);border-color:var(--cat-lacrosse)}
.fbtn[data-f="sub-media"].on   {background:var(--cat-media);  border-color:var(--cat-media)}
.fbtn[data-f="overdue"].on     {background:var(--danger);     border-color:var(--danger)}

.search-wrap{margin-left:auto;position:relative;flex-shrink:0}
.search-wrap input{
  background:var(--surf2);border:1.5px solid var(--border);
  border-radius:var(--rs);color:var(--text);
  font-family:var(--f-mono);font-size:11px;
  padding:5px 10px 5px 24px;outline:none;width:130px;
  transition:border-color .2s;
}
.search-wrap input:focus{border-color:var(--mauve)}
.search-wrap::before{
  content:'⌕';position:absolute;left:7px;top:50%;
  transform:translateY(-50%);font-size:13px;color:var(--muted);pointer-events:none;
}

/* ITEM LIST */
.itemlist{
  flex:1;overflow-y:auto;
  padding:10px 14px 100px;
  display:flex;flex-direction:column;gap:7px;
}
.empty-state{
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;height:100%;gap:10px;
  color:var(--muted);text-align:center;padding:40px;
}
.empty-icon{font-size:30px;opacity:.2}
.empty-state p{font-family:var(--f-mono);font-size:11px;line-height:1.7}

/* CARDS */
.card{
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--r);padding:11px 13px;
  display:flex;flex-direction:column;gap:7px;
  box-shadow:var(--sh);
  transition:box-shadow .2s,opacity .2s;
  animation:cardIn .22s cubic-bezier(.22,.68,0,1.2);
  position:relative;overflow:hidden;
  touch-action:pan-y;user-select:none;
  will-change:transform;
}
@keyframes cardIn{from{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:none}}
.card:hover{box-shadow:var(--sh2)}
.card.done{opacity:.36}
.card.done .ctext{text-decoration:line-through;text-decoration-color:var(--muted)}
.card.overdue{border-left:3px solid var(--danger);padding-left:11px;border-radius:0 var(--r) var(--r) 0}
.card.committed{border-left:3px solid var(--mauve);padding-left:11px;border-radius:0 var(--r) var(--r) 0}
.card.swiping-left {background:rgba(201,52,52,.06)}
.card.swiping-right{background:rgba(46,168,107,.06)}

/* swipe reveal labels */
.card::before,.card::after{
  position:absolute;top:50%;transform:translateY(-50%);
  font-family:var(--f-mono);font-size:10px;font-weight:500;
  opacity:0;transition:opacity .15s;pointer-events:none;
  letter-spacing:.06em;text-transform:uppercase;
}
.card::before{content:'Archiver';left:12px;color:var(--danger)}
.card::after {content:'Fait';right:12px;color:var(--success)}
.card.swiping-left::before{opacity:.7}
.card.swiping-right::after{opacity:.7}

/* card structure */
.ctop{display:flex;gap:9px;align-items:flex-start}
.ccat-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;margin-top:5px}
.cbody{flex:1;min-width:0}
.cmeta{display:flex;gap:5px;align-items:center;margin-bottom:2px;flex-wrap:wrap}
.cbadge{
  font-family:var(--f-mono);font-size:8px;font-weight:500;
  letter-spacing:.07em;text-transform:uppercase;
  padding:2px 6px;border-radius:8px;
}
.ctime{font-family:var(--f-mono);font-size:9px;color:var(--muted)}
.overdue-pill{
  font-family:var(--f-mono);font-size:8px;
  background:var(--danger);color:white;
  padding:1px 6px;border-radius:7px;
}
.ctext{font-size:14px;font-weight:600;line-height:1.45;color:var(--text);word-break:break-word}
.cfaction{
  display:inline-flex;align-items:center;gap:5px;
  font-family:var(--f-mono);font-size:9px;font-weight:500;
  color:var(--mauve-fonce);
  background:rgba(176,136,232,.1);
  border:1px solid rgba(176,136,232,.25);
  border-radius:8px;padding:2px 8px;margin-top:2px;
}
.cremind{margin-top:3px;font-family:var(--f-mono);font-size:10px;color:var(--danger)}
.cactions{display:flex;gap:4px;flex-shrink:0;align-items:flex-start;margin-top:1px}
.actn{
  background:transparent;border:1.5px solid var(--border);
  border-radius:var(--rs);color:var(--muted);font-size:12px;
  width:28px;height:28px;display:flex;align-items:center;justify-content:center;
  transition:all .15s;flex-shrink:0;
}
.actn:hover{background:var(--surf2);color:var(--text)}
.actn.ck:hover{color:var(--success);border-color:var(--success)}
.actn.dl:hover{color:var(--danger);border-color:var(--danger)}
.actn.cp{
  width:auto;padding:0 8px;font-family:var(--f-mono);font-size:9px;
  color:var(--mauve-fonce);border-color:rgba(176,136,232,.35);
  letter-spacing:.04em;
}
.actn.cp:hover{background:rgba(176,136,232,.1);border-color:var(--mauve);color:var(--mauve-fonce)}
.actn.cp.ok{color:var(--success);border-color:var(--success);background:rgba(46,168,107,.08)}

/* FAB */
#fab{
  position:fixed;bottom:24px;right:20px;z-index:30;
  width:54px;height:54px;border-radius:50%;border:none;
  background:var(--bleu-nuit);color:white;font-size:24px;line-height:1;
  box-shadow:0 4px 18px rgba(13,34,64,.35);
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
#fab:hover{background:var(--bleu-marine);transform:scale(1.06)}
#fab:active{transform:scale(.95)}

/* ═══════════════════════════════════════════════════════════
   BOTTOM SHEET
═══════════════════════════════════════════════════════════ */
#sheet-backdrop{
  position:fixed;inset:0;z-index:40;
  background:rgba(7,15,28,.6);backdrop-filter:blur(4px);
  opacity:0;pointer-events:none;transition:opacity .25s;
}
#sheet-backdrop.on{opacity:1;pointer-events:auto}
#sheet{
  position:fixed;bottom:0;left:0;right:0;z-index:50;
  background:var(--surface);border-radius:18px 18px 0 0;
  padding-bottom:env(safe-area-inset-bottom,0);
  transform:translateY(100%);
  transition:transform .3s cubic-bezier(.32,.72,0,1);
  max-height:90vh;overflow-y:auto;
}
#sheet.on{transform:translateY(0)}
.sheet-handle{width:36px;height:4px;border-radius:2px;background:var(--border);margin:12px auto 0}
.sheet-content{padding:14px 20px 28px}
.sheet-title{
  font-family:var(--f-display);font-size:15px;font-weight:700;
  color:var(--muted);margin-bottom:12px;
  letter-spacing:.4px;text-transform:uppercase;
}

/* Pills */
.pills{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:10px}
.pill{
  font-family:var(--f-body);font-size:13px;font-weight:500;
  padding:6px 14px;border-radius:var(--rpill);
  border:2px solid var(--border);background:transparent;
  color:var(--muted);transition:all .15s;
}
.pill:hover{border-color:var(--muted);color:var(--text)}
.pill.on{font-weight:600;color:white}

/* Type pills active colors */
.pill[data-t="idee"].on    {background:var(--mauve-fonce);border-color:var(--mauve-fonce)}
.pill[data-t="tache"].on   {background:var(--cat-lacrosse);border-color:var(--cat-lacrosse)}
.pill[data-t="question"].on{background:var(--cat-divers);border-color:var(--cat-divers)}
.pill[data-t="rappel"].on  {background:var(--danger);border-color:var(--danger)}

/* Category pills active colors */
.pill[data-c="debile"].on  {background:var(--cat-debile); border-color:var(--cat-debile)}
.pill[data-c="divers"].on  {background:var(--cat-divers); border-color:var(--cat-divers)}
.pill[data-c="comics"].on  {background:var(--cat-comics); border-color:var(--cat-comics)}
.pill[data-c="lacrosse"].on{background:var(--cat-lacrosse);border-color:var(--cat-lacrosse)}
.pill[data-c="media"].on   {background:var(--cat-media);  border-color:var(--cat-media)}

/* Sheet textarea */
.sheet-ta-wrap{position:relative}
.sheet-ta{
  width:100%;background:var(--surf2);border:2px solid var(--border);
  border-radius:var(--r);color:var(--text);font-size:15px;font-weight:500;
  padding:12px 42px 12px 14px;resize:none;outline:none;
  transition:border-color .2s;min-height:56px;line-height:1.5;
}
.sheet-ta:focus{border-color:var(--mauve)}
.sheet-ta::placeholder{color:var(--muted);font-weight:400}
.mic-btn{
  position:absolute;right:8px;bottom:8px;
  width:28px;height:28px;border-radius:50%;border:none;
  background:var(--surf2);color:var(--muted);font-size:14px;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
.mic-btn:hover{background:var(--bleu-nuit);color:white}
.mic-btn.on{background:var(--danger);color:white;animation:mpulse 1s ease-in-out infinite}
.mic-btn.off{opacity:.3;pointer-events:none}
@keyframes mpulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}
.mic-status{
  font-family:var(--f-mono);font-size:10px;color:var(--danger);
  min-height:14px;margin-top:4px;display:flex;align-items:center;gap:5px;
}
.mwave{display:flex;gap:2px;align-items:center}
.mwave i{width:3px;background:var(--danger);border-radius:2px;display:block;animation:mw .8s ease-in-out infinite}
.mwave i:nth-child(1){height:5px}.mwave i:nth-child(2){height:10px;animation-delay:.1s}
.mwave i:nth-child(3){height:7px;animation-delay:.2s}.mwave i:nth-child(4){height:12px;animation-delay:.15s}
.mwave i:nth-child(5){height:5px;animation-delay:.05s}
@keyframes mw{0%,100%{transform:scaleY(1)}50%{transform:scaleY(1.8)}}

.remdate-row{display:none;align-items:center;gap:8px;margin-top:8px}
.remdate-row.on{display:flex}
.remdate-row label{font-family:var(--f-mono);font-size:10px;color:var(--muted);white-space:nowrap;flex-shrink:0}
input[type=datetime-local]{
  flex:1;background:var(--surf2);border:2px solid var(--border);
  border-radius:var(--rs);color:var(--text);font-family:var(--f-mono);
  font-size:11px;padding:7px 10px;outline:none;
}
input[type=datetime-local]:focus{border-color:var(--mauve)}

.capture-btn{
  margin-top:14px;width:100%;padding:13px;border:none;
  border-radius:var(--r);background:var(--bleu-nuit);color:white;
  font-family:var(--f-display);font-size:16px;font-weight:800;
  letter-spacing:.8px;text-transform:uppercase;transition:all .18s;
}
.capture-btn:hover{background:var(--bleu-marine);transform:translateY(-1px)}
.capture-btn:active{transform:none}

/* ═══════════════════════════════════════════════════════════
   GATE OVERLAY
═══════════════════════════════════════════════════════════ */
#gate{
  position:fixed;inset:0;z-index:60;
  background:rgba(5,12,26,.68);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:20px;
}
#gate.on{display:flex}
.gate-card{
  background:var(--surface);max-width:460px;width:100%;
  border-radius:18px;overflow:hidden;box-shadow:var(--sh2);
  animation:gIn .26s cubic-bezier(.22,.68,0,1.2);
}
@keyframes gIn{from{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:none}}
.gate-stripe{height:4px;background:linear-gradient(90deg,var(--bleu-nuit),var(--mauve))}
.gate-body{padding:22px 24px 20px}
.gate-eyebrow{
  font-family:var(--f-mono);font-size:9px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--mauve-fonce);margin-bottom:6px;
  display:flex;align-items:center;gap:6px;
}
.gate-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--mauve);display:inline-block;
  animation:gdot 1.6s ease-in-out infinite;
}
@keyframes gdot{0%,100%{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}
.gate-title{
  font-family:var(--f-display);font-size:20px;font-weight:700;
  color:var(--text);margin-bottom:10px;letter-spacing:.2px;
}
.gate-preview{
  font-size:14px;font-weight:600;color:var(--text);
  background:var(--surf2);border-radius:var(--rs);
  padding:9px 13px;margin-bottom:14px;
  border-left:3px solid var(--mauve);word-break:break-word;
}
.gate-sub-label{
  font-family:var(--f-mono);font-size:9px;color:var(--muted);
  margin-bottom:6px;letter-spacing:.06em;text-transform:uppercase;
}
.gate-pills{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:12px}
.gate-pill{
  font-family:var(--f-body);font-size:12px;padding:5px 12px;
  border-radius:var(--rpill);border:2px solid var(--border);
  background:transparent;color:var(--muted);transition:all .15s;
}
.gate-pill:hover{border-color:var(--muted);color:var(--text)}
.gate-pill.on{background:var(--bleu-nuit);color:white;border-color:var(--bleu-nuit)}
.gate-input{
  width:100%;background:var(--surf2);border:2px solid var(--border);
  border-radius:var(--rs);color:var(--text);font-size:14px;font-weight:500;
  padding:11px 13px;resize:none;outline:none;
  transition:border-color .2s;min-height:50px;
}
.gate-input:focus{border-color:var(--mauve)}
.gate-input::placeholder{color:var(--muted);font-weight:400}
.gate-actions{display:flex;gap:8px;margin-top:12px;align-items:center}
.gate-skip{
  font-family:var(--f-mono);font-size:11px;padding:9px 16px;
  border-radius:var(--rs);border:1.5px solid var(--border);
  background:transparent;color:var(--muted);transition:all .15s;
}
.gate-skip:hover{color:var(--text);border-color:var(--muted)}
.gate-commit{
  flex:1;font-family:var(--f-display);font-size:15px;font-weight:800;letter-spacing:.6px;
  padding:11px 20px;border-radius:var(--rs);border:none;
  background:var(--bleu-nuit);color:white;text-transform:uppercase;transition:all .18s;
}
.gate-commit:hover{background:var(--bleu-marine);transform:translateY(-1px)}
.gate-hint{font-family:var(--f-mono);font-size:9px;color:var(--muted);margin-top:8px;text-align:center;opacity:.6}

/* ═══════════════════════════════════════════════════════════
   ARTICLE PANEL
═══════════════════════════════════════════════════════════ */
#panel-article{flex-direction:row}
.art-main{flex:1;display:flex;flex-direction:column;overflow:hidden;border-right:1.5px solid var(--border)}
.art-side{width:255px;flex-shrink:0;display:flex;flex-direction:column;overflow:hidden}

/* Article header */
.art-hdr{
  padding:12px 20px;border-bottom:1.5px solid var(--border);flex-shrink:0;
  display:flex;gap:10px;align-items:center;flex-wrap:wrap;
}
.art-title-in{
  flex:1;background:transparent;border:none;color:var(--text);
  font-family:var(--f-display);font-size:17px;font-weight:700;
  outline:none;letter-spacing:.3px;min-width:150px;
}
.art-title-in::placeholder{color:var(--border)}
.artbtn{
  font-family:var(--f-mono);font-size:10px;font-weight:500;letter-spacing:.06em;
  padding:6px 12px;border-radius:var(--rs);border:1.5px solid var(--border);
  background:transparent;color:var(--muted);transition:all .15s;white-space:nowrap;
}
.artbtn:hover{color:var(--text);border-color:var(--muted);background:var(--surf2)}
.artbtn.primary{background:var(--bleu-nuit);color:white;border-color:var(--bleu-nuit)}
.artbtn.primary:hover{background:var(--bleu-marine)}
.artbtn.mic-on{border-color:var(--danger);color:var(--danger);background:rgba(201,52,52,.07)}
.art-save-status{
  font-family:var(--f-mono);font-size:9px;color:var(--success);
  letter-spacing:.06em;opacity:0;transition:opacity .3s;margin-left:auto;white-space:nowrap;
}
.art-save-status.on{opacity:1}
.art-save-status.err{color:var(--danger);opacity:1}

/* Article categories */
.art-cats{
  padding:6px 20px;border-bottom:1.5px solid var(--border);flex-shrink:0;
  display:flex;gap:5px;align-items:center;flex-wrap:wrap;
}
.catbtn{
  font-family:var(--f-mono);font-size:10px;padding:3px 10px;
  border-radius:var(--rpill);border:2px solid var(--border);
  background:transparent;color:var(--muted);transition:all .15s;
}
.catbtn:hover{color:var(--text);border-color:var(--muted)}
.catbtn[data-c="debile"].on  {background:var(--cat-debile); border-color:var(--cat-debile); color:white}
.catbtn[data-c="divers"].on  {background:var(--cat-divers); border-color:var(--cat-divers); color:white}
.catbtn[data-c="comics"].on  {background:var(--cat-comics); border-color:var(--cat-comics); color:white}
.catbtn[data-c="lacrosse"].on{background:var(--cat-lacrosse);border-color:var(--cat-lacrosse);color:white}
.catbtn[data-c="media"].on   {background:var(--cat-media);  border-color:var(--cat-media);  color:white}
.wc-label{font-family:var(--f-mono);font-size:10px;color:var(--muted);margin-left:auto;white-space:nowrap}
.wc-label b{color:var(--mauve-fonce)}

/* Editor */
.art-body{flex:1;overflow-y:auto;padding:16px 20px 8px}
.art-ta{
  width:100%;height:100%;background:transparent;border:none;
  color:var(--text);font-family:var(--f-body);font-size:15px;
  line-height:1.9;outline:none;resize:none;min-height:220px;
}
.art-ta::placeholder{color:var(--border)}
.art-mic-status{
  font-family:var(--f-mono);font-size:10px;color:var(--danger);
  min-height:14px;padding:3px 20px;display:flex;align-items:center;gap:5px;flex-shrink:0;
}
.art-toolbar{
  padding:8px 20px;border-top:1.5px solid var(--border);flex-shrink:0;
  display:flex;gap:6px;flex-wrap:wrap;align-items:center;
}

/* Article sidebar */
.art-side-title{
  padding:12px 16px;border-bottom:1.5px solid var(--border);flex-shrink:0;
  display:flex;align-items:center;gap:7px;
  font-family:var(--f-mono);font-size:9px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--muted);
}
.art-side-count{background:var(--surf2);border-radius:8px;padding:1px 6px;font-size:9px;color:var(--text)}
.saved-list{overflow-y:auto;padding:10px 14px;flex:1;display:flex;flex-direction:column;gap:6px}
.art-item{
  background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);
  padding:10px 12px;cursor:pointer;transition:all .2s;
  animation:cardIn .2s ease;
}
.art-item:hover{border-color:var(--mauve);box-shadow:var(--sh)}
.art-item-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.art-item-meta{display:flex;gap:7px;font-family:var(--f-mono);font-size:9px;color:var(--muted)}
.art-item-del{
  margin-top:5px;background:none;border:none;color:var(--muted);
  font-size:11px;cursor:pointer;padding:0;float:right;
}
.art-item-del:hover{color:var(--danger)}

/* Mobile article view */
.art-mobile-header{
  padding:14px 16px;border-bottom:1.5px solid var(--border);flex-shrink:0;
  display:flex;gap:10px;align-items:center;
}
.art-mobile-title{font-family:var(--f-display);font-size:17px;font-weight:700;color:var(--text);letter-spacing:.3px}
.art-mobile-list{flex:1;overflow-y:auto;padding:12px 14px 80px;display:flex;flex-direction:column;gap:7px}

@media(max-width:760px){
  #panel-article{flex-direction:column}
  .art-side,.art-desktop-only{display:none}
}

/* ═══════════════════════════════════════════════════════════
   SETTINGS PANEL
═══════════════════════════════════════════════════════════ */
#panel-settings{
  padding:18px;overflow-y:auto;gap:12px;
  flex-direction:column;
}
.settings-sec{
  background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--r);padding:14px 16px;
}
.settings-title{
  font-family:var(--f-display);font-size:13px;font-weight:700;
  color:var(--muted);margin-bottom:11px;
  letter-spacing:.4px;text-transform:uppercase;
}
.settings-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:8px 0;border-bottom:1px solid var(--border);
}
.settings-row:last-child{border-bottom:none}
.settings-label{color:var(--text);font-size:13px}
.settings-hint{font-family:var(--f-mono);font-size:10px;color:var(--muted);margin-top:2px}
.settings-btn{
  font-family:var(--f-mono);font-size:10px;padding:6px 13px;
  border-radius:var(--rs);border:1.5px solid var(--border);
  background:transparent;color:var(--muted);transition:all .15s;
}
.settings-btn:hover{color:var(--text);border-color:var(--muted);background:var(--surf2)}
.settings-btn.primary{background:var(--bleu-nuit);color:white;border-color:var(--bleu-nuit)}
.settings-btn.danger:hover{color:var(--danger);border-color:var(--danger)}

/* Debug panel */
#debug-panel{display:flex;flex-direction:column;gap:4px}
.debug-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0}
.debug-key{font-family:var(--f-mono);font-size:10px;color:var(--muted);letter-spacing:.04em}
.debug-val{font-family:var(--f-mono);font-size:10px;color:var(--text)}
.debug-val.ok {color:var(--success)}
.debug-val.err{color:var(--danger)}
.debug-val.warn{color:var(--warn)}

/* Migration banner */
#migration-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:100;
  background:var(--bleu-marine);color:white;
  padding:16px 20px;display:none;flex-direction:column;gap:10px;
  box-shadow:0 -4px 24px rgba(13,34,64,.3);
}
#migration-banner.on{display:flex}
#migration-banner p{font-size:13px;line-height:1.55}
#migration-banner b{color:var(--mauve)}
.mig-btns{display:flex;gap:8px}
.mig-btn{
  font-family:var(--f-mono);font-size:11px;padding:8px 16px;
  border-radius:var(--rs);border:none;cursor:pointer;
}
.mig-btn-export{background:var(--mauve);color:var(--bleu-nuit);font-weight:700}
.mig-btn-skip{background:rgba(255,255,255,.15);color:rgba(255,255,255,.8)}

/* ═══════════════════════════════════════════════════════════
   TOAST
═══════════════════════════════════════════════════════════ */
#toast{
  position:fixed;bottom:90px;left:50%;
  transform:translateX(-50%) translateY(10px);
  background:var(--bleu-nuit);color:white;border-radius:10px;
  padding:9px 16px;font-family:var(--f-mono);font-size:12px;
  opacity:0;transition:all .26s;pointer-events:none;z-index:200;
  white-space:nowrap;box-shadow:var(--sh2);
  display:flex;align-items:center;gap:10px;
}
#toast.on{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
.toast-undo{
  font-family:var(--f-mono);font-size:11px;color:var(--mauve);
  background:none;border:none;cursor:pointer;
  text-decoration:underline;text-underline-offset:2px;
}

/* Storage error banner */
#storage-error{
  position:fixed;top:52px;left:0;right:0;z-index:80;
  background:var(--danger);color:white;padding:8px 20px;
  font-family:var(--f-mono);font-size:11px;display:none;
  align-items:center;justify-content:space-between;
}
#storage-error.on{display:flex}
