/* Inter — sidebar UI font (self-hosted → public/fonts/) */
@font-face{font-family:'Inter';src:url('/fonts/Inter-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Inter';src:url('/fonts/Inter-Medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Inter';src:url('/fonts/Inter-SemiBold.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Inter';src:url('/fonts/Inter-Bold.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}

/* ═══════════════════════════════════════════════════════════════
   styles.css — YGO Deck Manager
   Sections :
     1. VARIABLES & RESET
     2. SHELL / LAYOUT
     3. TOPBAR
     4. PANEL HEADS
     5. DETAIL PANEL
     6. DECK PANEL
     7. SEARCH PANEL
     8. FILTER DRAWER
     9. MODALS
    10. STATS & SIMULATEUR
    11. TOOLTIPS & TOASTS
    12. TAGS & BANLIST
    13. LIGHTBOX
    14. MISC / RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */

/* ─── 1. VARIABLES & RESET ──────────────────────────────────── */
:root{
  --sans:'DM Sans',sans-serif;
  --ui:'Inter',var(--sans);
  --title:'Bebas Neue',sans-serif;
  --mono:'DM Mono',monospace;
  /* ── DARK par défaut ── */
  --bg:#07061a;--sur:#0f0d21;--sur2:#14122a;--sur3:#1a1835;
  --bor:#1e1c38;--bor2:#2a2848;
  --tx:#eeeef5;--tx2:#9090b8;--tx3:#6868a0;
  --blue:#7b9ff9;--blue2:#a78bfa;
  --gold:#f59e0b;--gold2:#fbbf24;
  --green:#4ade80;--red:#f87171;
  --orange:#fb923c;--purple:#c084fc;
  --pink:#f472b6;
  --sh:0 1px 3px rgba(0,0,0,.5),0 1px 2px rgba(0,0,0,.4);
  --sh2:0 4px 24px rgba(0,0,0,.6);
  --r:10px;--r2:6px;
  /* ── Prismatic gradients ── */
  --prism:linear-gradient(135deg,#7b9ff9,#a78bfa,#f472b6);
  --prism-soft:linear-gradient(135deg,rgba(123,159,249,.7),rgba(167,139,250,.7),rgba(244,114,182,.7));
  --prism-border:linear-gradient(135deg,#7b9ff9 0%,#a78bfa 50%,#f472b6 100%);
}
[data-theme="light"]{
  --bar-bg:rgba(255,255,255,.88);
  --bg:#f4f4f6;--sur:#ffffff;--sur2:#f0f0f3;--sur3:#e8e8ed;
  --bor:#e0e0e6;--bor2:#cacad2;
  --tx:#0a0a10;--tx2:#2e2e44;--tx3:#474762;
  --blue:#2563eb;--blue2:#1d4ed8;
  --gold:#b8860b;--gold2:#d4a017;
  --green:#16a34a;--red:#dc2626;
  --orange:#ea580c;--purple:#7c3aed;
  --sh:0 1px 3px rgba(0,0,0,.07),0 1px 2px rgba(0,0,0,.05);
  --sh2:0 4px 16px rgba(0,0,0,.09);
}
[data-theme="light"] #bar{background:linear-gradient(180deg,rgba(255,255,255,.97),rgba(248,247,255,.95));border-bottom-color:rgba(120,100,200,.12);box-shadow:0 2px 24px rgba(120,100,200,.08)}
[data-theme="light"] .tb{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.1);color:#1a1a2e;opacity:1}
[data-theme="light"] .tb:hover{background:rgba(37,99,235,.08);border-color:rgba(37,99,235,.25);color:#2563eb}
[data-theme="light"] .sh-input-wrap{background:#f0f0f3;border-color:#e0e0e6}
[data-theme="light"] .sh-input-wrap:focus-within{border-color:rgba(37,99,235,.6);box-shadow:0 0 0 3px rgba(37,99,235,.18)}
[data-theme="light"] .fmt-pill{background:#f0f0f3;border-color:#e0e0e6;color:#363646}
[data-theme="light"] .fmt-pill.on{background:linear-gradient(135deg,rgba(37,99,235,.15),rgba(124,58,237,.15));border-color:rgba(37,99,235,.35);color:#2563eb}
[data-theme="light"] .sec-hd{background:rgba(37,99,235,.04);border-bottom-color:rgba(37,99,235,.1)}
[data-theme="light"] .ph{background:rgba(37,99,235,.03);border-bottom-color:rgba(37,99,235,.1)}
[data-theme="light"] #sbar-wrap{background:rgba(37,99,235,.03);border-top-color:rgba(37,99,235,.08)}
[data-theme="light"] .sbar-link{color:#4338ca}
[data-theme="light"] .sbar-link:hover{color:#1e1b4b}
[data-theme="light"] .sb-deck-new{color:#4338ca;border-color:rgba(67,56,202,.3);background:rgba(67,56,202,.05)}
[data-theme="light"] .sb-deck-new:hover{color:#1e1b4b;border-color:rgba(67,56,202,.5);background:rgba(67,56,202,.1)}
[data-theme="light"] .tb.prim{background:linear-gradient(135deg,#2563eb,#7c3aed);box-shadow:0 2px 12px rgba(37,99,235,.3)}
[data-theme="light"] .d-name{background:linear-gradient(135deg,#0a0a10,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
[data-theme="light"] .sec-empty{color:#1e40af;background:rgba(37,99,235,.03);border-color:rgba(37,99,235,.18)}
[data-theme="light"] .sec-block[data-sec="side"] .sec-hd-name{color:#059669}
[data-theme="light"] .sec-block[data-sec="side"] .sec-hd-cnt{color:#059669;background:rgba(5,150,105,.1);border-color:rgba(5,150,105,.2)}
[data-theme="light"] .sec-block[data-sec="extra"] .sec-hd-name{color:#7c3aed}
[data-theme="light"] .sec-block[data-sec="extra"] .sec-hd-cnt{color:#7c3aed;background:rgba(124,58,237,.1);border-color:rgba(124,58,237,.2)}
[data-theme="light"] .sec-block[data-sec="main"] .sec-hd-name{color:#2563eb}
[data-theme="light"] .sec-block{border-color:rgba(37,99,235,.1);box-shadow:0 2px 8px rgba(0,0,0,.06)}
[data-theme="light"] .sec-hd{background:rgba(37,99,235,.04)}
[data-theme="light"] .sec-hd-cnt{background:rgba(37,99,235,.08);color:#1d4ed8;border-color:rgba(37,99,235,.15)}
[data-theme="light"] #p-det{border-left-color:rgba(37,99,235,.1)}
[data-theme="light"] .d-detail-card{background:linear-gradient(180deg,rgba(255,255,255,.88),rgba(248,249,255,.72));border-color:rgba(37,99,235,.12);box-shadow:0 10px 24px rgba(67,56,130,.08),inset 0 1px 0 rgba(255,255,255,.9)}
[data-theme="light"] .d-img-col{background:linear-gradient(135deg,rgba(37,99,235,.055),rgba(124,58,237,.045))}
[data-theme="light"] .d-info-col{border-left-color:rgba(37,99,235,.1)}
[data-theme="light"] .d-add:hover{background:rgba(37,99,235,.08);color:#2563eb}
[data-theme="light"] .d-lbl{color:#1e40af}
[data-theme="light"] .d-lbl::after{background:rgba(37,99,235,.12)}
[data-theme="light"] .d-desc{background:rgba(37,99,235,.03);border-color:rgba(37,99,235,.08)}
/* ── Light mode contrast fixes — éléments avec rgba trop clairs ── */
[data-theme="light"] .sh-vb{color:#1e40af;border-color:rgba(37,99,235,.2);background:rgba(37,99,235,.05)}
[data-theme="light"] .sh-vb:hover{color:#1e40af;border-color:rgba(37,99,235,.45);background:rgba(37,99,235,.1)}
[data-theme="light"] .sh-vb.on{color:#fff;background:linear-gradient(135deg,#2563eb,#7c3aed);border-color:transparent}
[data-theme="light"] .sh-tab{color:#474762}
[data-theme="light"] .sh-tab:hover{color:#1a1a2e;background:rgba(0,0,0,.03)}
[data-theme="light"] .sh-tab.on{color:#1d4ed8;border-bottom-color:#2563eb;background:linear-gradient(180deg,rgba(37,99,235,.1),transparent)}
[data-theme="light"] .pg-btn{color:#1e40af;border-color:rgba(37,99,235,.2);background:rgba(37,99,235,.06)}
[data-theme="light"] .pg-btn:hover:not(:disabled){color:#fff;background:#2563eb;border-color:#2563eb}
[data-theme="light"] #pg-info{color:#1e40af}
[data-theme="light"] .opt-btn{color:#1e40af;border-color:rgba(37,99,235,.25);background:rgba(37,99,235,.06)}
[data-theme="light"] .opt-btn:hover{color:#fff;background:#2563eb;border-color:#2563eb}
[data-theme="light"] .opt-btn.on{color:#fff;background:linear-gradient(135deg,#2563eb,#7c3aed);border-color:transparent}
[data-theme="light"] .opt-section-title{color:#2563eb;border-bottom-color:rgba(37,99,235,.15)}
[data-theme="light"] .opt-toggle{background:#d0d0de;border-color:#b8b8cc}
[data-theme="light"] .opt-toggle::after{background:#3a3a5c;box-shadow:0 1px 3px rgba(0,0,0,.25)}
[data-theme="light"] .opt-toggle.on{background:linear-gradient(135deg,#2563eb,#7c3aed);border-color:transparent}
[data-theme="light"] .opt-toggle.on::after{background:#fff}
[data-theme="light"] .fchip{color:#363646;background:rgba(0,0,0,.04);border-color:rgba(37,99,235,.18)}
[data-theme="light"] .fchip:hover{color:#1e40af;background:rgba(37,99,235,.08);border-color:rgba(37,99,235,.35)}
[data-theme="light"] .fchip.on{color:#fff;background:linear-gradient(135deg,#2563eb,#7c3aed);border-color:transparent}
[data-theme="light"] .sh-pagination{background:rgba(37,99,235,.03);border-top-color:rgba(37,99,235,.1)}
[data-theme="light"] .pg-zoom{color:#1e40af}
[data-theme="light"] .pg-zoom-val{color:#1a1a2e}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
html,body{height:100%;background:var(--bg);color:var(--tx);font-family:var(--sans);font-size:14px}
.builder-page html,.builder-page body,body.builder-page{overflow:hidden}
button{font-family:var(--sans);cursor:pointer}
input,select{font-family:var(--sans)}
::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:linear-gradient(180deg,rgba(123,159,249,.35),rgba(167,139,250,.35));border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,rgba(123,159,249,.6),rgba(244,114,182,.5))}
@keyframes fu{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes card-in{from{opacity:0;transform:translateY(10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes deck-sort{0%{opacity:.3;transform:scale(.88) translateY(-6px) rotate(-1.5deg)}60%{transform:scale(1.04) translateY(1px) rotate(.3deg)}100%{opacity:1;transform:scale(1) translateY(0) rotate(0)}}
@keyframes prism-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes prism-border-spin{from{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(360deg)}}
@keyframes profile-menu-in{from{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.fade{animation:fu .2s ease both}

/* ─── 2. SHELL / LAYOUT ─────────────────────────────────────── */
#app{display:flex;flex-direction:row;height:100vh;height:100dvh}
#app-content{display:flex;flex-direction:column;flex:1;min-width:0;height:100vh;height:100dvh;overflow:hidden}
#lay{display:flex;flex:1;min-width:0}
body.builder-page #lay{overflow:hidden;min-width:812px}

/* ─── SIDEBAR ─────────────────────────────────────────────── */
#sidebar{width:240px;flex-shrink:0;height:100vh;height:100dvh;display:flex;flex-direction:column;background:linear-gradient(180deg,rgba(10,8,24,.99) 0%,rgba(8,6,20,.99) 100%);border-right:1px solid rgba(123,159,249,.12);overflow:hidden;transition:width .22s cubic-bezier(.4,0,.2,1);position:relative;z-index:100;font-family:var(--ui);font-feature-settings:'cv02','cv03','cv04','cv11'}
#sidebar.sb-collapsed{width:64px}
.sb-head{display:flex;align-items:center;justify-content:space-between;padding:12px 10px 10px;flex-shrink:0;gap:6px;border-bottom:1px solid rgba(123,159,249,.08);min-height:56px}
.sb-logo{display:flex;align-items:center;gap:8px;text-decoration:none;overflow:hidden;min-width:0}
.sb-logo-img{width:30px;height:30px;object-fit:contain;flex-shrink:0}
.sb-logo-txt{font-size:13.5px;font-weight:700;color:#f0eeff;letter-spacing:-0.02em;white-space:nowrap;overflow:hidden;background:linear-gradient(135deg,#7b9ff9,#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.sb-collapse-btn{width:28px;height:28px;flex-shrink:0;border:none;border-radius:8px;background:rgba(123,159,249,.08);color:rgba(167,139,250,.7);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.18s}
.sb-collapse-btn:hover{background:rgba(123,159,249,.18);color:#c4b5fd}
.sb-deck-area{padding:8px 8px 4px;flex-shrink:0}
.sb-deck-id{width:100%;display:flex;align-items:center;gap:8px;padding:7px 8px;border:1px solid rgba(123,159,249,.18);border-radius:10px;background:rgba(123,97,255,.06);cursor:pointer;text-align:left;transition:.18s;color:var(--tx);font-family:inherit}
.sb-deck-id:hover{background:rgba(123,97,255,.14);border-color:rgba(123,159,249,.35)}
.sb-deck-art{width:28px;height:28px;object-fit:cover;border-radius:6px;flex-shrink:0}
.sb-deck-art-ph{font-size:18px;flex-shrink:0;width:28px;text-align:center;line-height:28px}
.sb-deck-text{flex:1;min-width:0;overflow:hidden}
.sb-deck-name{display:block;font-size:12.5px;font-weight:600;color:#f0eeff;letter-spacing:-0.015em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-deck-fmt{display:block;font-size:10.5px;color:rgba(167,139,250,.6);font-weight:500;letter-spacing:0.01em;margin-top:1px}
.sb-deck-edit-ic{font-size:12px;color:rgba(167,139,250,.45);flex-shrink:0;margin-left:auto}
.sb-deck-new{width:100%;display:flex;align-items:center;gap:8px;padding:8px;border:1px dashed rgba(123,159,249,.25);border-radius:10px;background:rgba(123,97,255,.04);cursor:pointer;transition:.18s;color:rgba(167,139,250,.7);font-family:var(--ui);font-size:12.5px;font-weight:500;letter-spacing:-0.01em}
.sb-deck-new:hover{background:rgba(123,97,255,.12);border-color:rgba(123,159,249,.4);color:#c4b5fd}
.sb-deck-new-ic{font-size:14px;flex-shrink:0;width:28px;text-align:center}
.sb-deck-new-txt{white-space:nowrap;overflow:hidden}
.sb-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:4px 0}
.sb-nav::-webkit-scrollbar{width:3px}
.sb-nav::-webkit-scrollbar-track{background:transparent}
.sb-nav::-webkit-scrollbar-thumb{background:rgba(123,159,249,.18);border-radius:99px}
.sb-section{padding:4px 6px}
.sb-section-lbl{font-size:10px;font-weight:600;color:rgba(167,139,250,.45);letter-spacing:0.06em;text-transform:uppercase;padding:6px 6px 3px;white-space:nowrap}
.sb-sep{height:1px;background:linear-gradient(90deg,transparent,rgba(123,159,249,.12),transparent);margin:4px 8px}
.sb-btn{width:100%;display:flex;align-items:center;gap:9px;padding:9px 10px;border:none;border-radius:9px;background:transparent;color:rgba(200,190,240,.8);cursor:pointer;font-family:var(--ui);font-size:13px;font-weight:500;letter-spacing:-0.01em;line-height:1.35;transition:.15s;text-align:left;white-space:nowrap;overflow:hidden;position:relative}
.sb-btn:hover{background:rgba(123,97,255,.1);color:#f0eeff}
.sb-btn:active{background:rgba(123,97,255,.18)}
.sb-btn.sb-btn-mes-decks{font-size:14px;font-weight:700;padding:11px 12px;color:#f0eeff;background:rgba(123,97,255,.13);border:1px solid rgba(123,97,255,.22);margin:6px 6px 4px;width:calc(100% - 12px)}
.sb-btn.sb-btn-mes-decks:hover{background:rgba(123,97,255,.22);border-color:rgba(123,97,255,.4)}
.sb-btn.sb-btn-mes-decks.sb-btn-green{color:#4ade80;background:rgba(74,222,128,.15);border-color:rgba(74,222,128,.4);box-shadow:0 0 0 3px rgba(74,222,128,.2);transition:color .2s,background .2s,border-color .2s,box-shadow .2s}
.sb-btn.sb-btn-primary{color:#7b9ff9}
.sb-btn.sb-btn-primary:hover{background:rgba(123,159,249,.12);color:#93c5fd}
.sb-btn.sb-btn-danger{color:#f87171}
.sb-btn.sb-btn-danger:hover{background:rgba(239,68,68,.1);color:#fca5a5}
.sb-btn.sb-btn-green{color:#4ade80}
.sb-btn.sb-btn-green:hover{background:rgba(74,222,128,.08);color:#86efac}
.sb-btn.sb-btn-purple{color:#a78bfa}
.sb-btn.sb-btn-purple:hover{background:rgba(167,139,250,.1);color:#c4b5fd}
.sb-btn.sb-btn-active{color:#c4b5fd;background:rgba(167,139,250,.1)}
.sb-btn.sb-btn-active:hover{background:rgba(167,139,250,.18)}
.sb-btn.sb-btn-profile{gap:8px}
.sb-btn .sb-chevron{margin-left:auto;font-size:10px;opacity:.6}
.sb-btn .sb-on-badge{margin-left:auto;font-size:9px;font-weight:800;background:linear-gradient(135deg,#7b9ff9,#a78bfa);color:#fff;padding:1px 6px;border-radius:99px;letter-spacing:.5px}
.sb-btn.sb-btn-sub{color:rgba(200,190,240,.6)}
.sb-btn.sb-btn-sub:hover{color:#f0eeff}
.sb-sub-chevron{margin-left:auto;font-size:10px;opacity:.5}
.sb-submenu{padding-left:10px;overflow:hidden}
.sb-btn.sb-sub-item{font-size:12px;font-weight:450;color:rgba(180,170,220,.65);letter-spacing:-0.005em;padding:6px 10px}
.sb-btn.sb-sub-item:hover{color:#f0eeff;background:rgba(123,97,255,.08)}
.sb-btn-row{display:flex;gap:3px}
.sb-btn.sb-btn-half{flex:1}
.sb-btn.sb-btn-tool{border:1px solid rgba(167,139,250,.18);background:rgba(167,139,250,.07);margin-bottom:3px;font-weight:600;color:#d4cafe}
.sb-btn.sb-btn-tool:hover{border-color:rgba(167,139,250,.4);background:rgba(123,97,255,.16);color:#f0eeff}
.sb-btn.sb-btn-tool.sb-btn-active{border-color:rgba(167,139,250,.7);background:rgba(123,97,255,.25);color:#e2d9ff;box-shadow:inset 0 1px 4px rgba(0,0,0,.3),0 0 0 2px rgba(167,139,250,.18)}
.sb-btn.sb-btn-tool.sb-btn-active .sb-ic{opacity:1}
.sb-btn.sb-btn-setup{background:linear-gradient(135deg,rgba(123,159,249,.18),rgba(74,222,128,.11));border-color:rgba(123,159,249,.38);color:#eef4ff}
.sb-btn.sb-btn-setup:hover{background:linear-gradient(135deg,rgba(123,159,249,.26),rgba(74,222,128,.16));border-color:rgba(123,159,249,.58)}
#sidebar.sb-collapsed .sb-btn.sb-btn-tool{padding:11px;border:1px solid rgba(167,139,250,.22);background:rgba(167,139,250,.09);margin-bottom:3px}
#sidebar.sb-collapsed .sb-btn.sb-btn-tool:hover{border-color:rgba(167,139,250,.5);background:rgba(123,97,255,.2)}
#sidebar.sb-collapsed .sb-btn.sb-btn-tool .sb-ic{opacity:.95;width:19px;height:19px}
#sidebar.sb-collapsed .sb-btn.sb-btn-tool.sb-btn-active{border-color:rgba(167,139,250,.7);background:rgba(123,97,255,.28);box-shadow:inset 0 1px 4px rgba(0,0,0,.3),0 0 0 2px rgba(167,139,250,.18)}
/* Tooltip sb-btn desktop only */
@media (hover:hover){
.sb-btn[data-tooltip]{position:relative}
.sb-btn[data-tooltip]::after{content:attr(data-tooltip);position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);white-space:nowrap;background:rgba(18,15,35,.95);color:#e2d9ff;font-size:11px;font-weight:500;padding:6px 10px;border-radius:8px;border:1px solid rgba(167,139,250,.2);pointer-events:none;opacity:0;transition:opacity .15s;z-index:9999;max-width:240px;white-space:normal;line-height:1.4}
.sb-btn[data-tooltip]:hover::after{opacity:1}
}
.sb-ic{flex-shrink:0;opacity:.8;width:17px;height:17px}
.sb-btn:hover .sb-ic{opacity:1}
.sb-avatar{width:22px;height:22px;border-radius:50%;object-fit:cover;flex-shrink:0}
.sb-footer{flex-shrink:0;padding:4px 6px 8px}
#sidebar.sb-collapsed .sb-btn{padding:10px;justify-content:center;gap:0}
#sidebar.sb-collapsed .sb-ic{opacity:.7}
#sidebar.sb-collapsed .sb-btn:hover .sb-ic{opacity:1}
#sidebar.sb-collapsed .sb-section-lbl,#sidebar.sb-collapsed .sb-deck-text,#sidebar.sb-collapsed .sb-deck-edit-ic,#sidebar.sb-collapsed .sb-deck-new-txt,#sidebar.sb-collapsed .sb-logo-txt{display:none}
#sidebar.sb-collapsed .sb-deck-id,#sidebar.sb-collapsed .sb-deck-new{justify-content:center;padding:8px}
#sidebar.sb-collapsed .sb-collapse-btn{margin:0 auto}
#sidebar.sb-collapsed .sb-head{flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:8px 6px}
#sidebar.sb-collapsed .sb-btn-row .sb-btn{justify-content:center}
[data-theme="light"] #sidebar{background:linear-gradient(180deg,rgba(248,247,255,.98),rgba(242,240,255,.97));border-right-color:rgba(120,100,200,.1)}
[data-theme="light"] .sb-btn{color:rgba(60,50,100,.75)}
[data-theme="light"] .sb-btn:hover{background:rgba(123,97,255,.08);color:rgba(40,30,80,.95)}
[data-theme="light"] .sb-section-lbl{color:rgba(100,80,160,.4)}
[data-theme="light"] .sb-logo-txt{-webkit-text-fill-color:initial;color:#5b21b6}
[data-theme="light"] .sb-sep{background:linear-gradient(90deg,transparent,rgba(100,80,180,.1),transparent)}
[data-theme="light"] .sb-deck-id{border-color:rgba(100,80,180,.15);background:rgba(100,80,180,.05)}
[data-theme="light"] .sb-deck-name{color:#1a1535}
[data-theme="light"] .sb-deck-fmt{color:rgba(90,70,150,.55)}
[data-theme="light"] .sb-collapse-btn{background:rgba(100,80,180,.08);color:rgba(80,60,140,.6)}
[data-theme="light"] .sb-collapse-btn:hover{background:rgba(100,80,180,.16)}
.sb-tip{position:fixed;z-index:9999;background:rgba(15,12,35,.96);border:1px solid rgba(123,97,255,.28);color:#e8e0ff;font-size:12px;font-weight:500;padding:6px 11px;border-radius:8px;pointer-events:none;white-space:nowrap;opacity:0;transform:translateY(-50%);transition:opacity .1s ease;letter-spacing:-.01em;box-shadow:0 4px 18px rgba(0,0,0,.45)}
.sb-tip.visible{opacity:1}
.sb-tip::before{content:'';position:absolute;top:50%;right:100%;transform:translateY(-50%);border:5px solid transparent;border-right-color:rgba(123,97,255,.28)}
.sb-tip::after{content:'';position:absolute;top:50%;right:calc(100% - 1px);transform:translateY(-50%);border:5px solid transparent;border-right-color:rgba(15,12,35,.96)}
[data-theme="light"] .sb-tip{background:rgba(248,247,255,.98);border-color:rgba(100,80,180,.22);color:rgba(40,30,80,.9);box-shadow:0 4px 18px rgba(0,0,0,.12)}
[data-theme="light"] .sb-tip::before{border-right-color:rgba(100,80,180,.22)}
[data-theme="light"] .sb-tip::after{border-right-color:rgba(248,247,255,.98)}

/* ─── MOBILE HEADER (hidden on desktop) ─────────────────────── */
#mob-header{display:none;align-items:center;gap:8px;padding:0 0 0 12px;height:52px;background:linear-gradient(180deg,rgba(12,10,28,.98),rgba(9,8,22,.98));border-bottom:1px solid rgba(123,159,249,.12);flex-shrink:0}
#mob-header .mob-hamburger{border-radius:0;border-top:none;border-bottom:none;border-left:none;border-right:1px solid rgba(123,97,255,.2);width:48px;height:52px;flex-shrink:0;background:rgba(123,97,255,.08);margin-left:0;margin-right:0;order:-1}
.pnl{display:flex;flex-direction:column;overflow:hidden;background:var(--sur);border-right:1px solid var(--bor);min-width:180px}
.pnl:last-child{border-right:none}
#pnl-deck{min-width:200px;flex:1 1 0;margin:8px 0;background:var(--bg);background-image:radial-gradient(circle at 1px 1px,rgba(123,159,249,.06) 1px,transparent 0);background-size:24px 24px;border-right:none}
#pnl-search{flex-shrink:0;min-width:280px;background:var(--sur);margin:8px 0 8px 8px;border-radius:16px;border:1px solid transparent;background:var(--sur) padding-box,linear-gradient(160deg,rgba(123,159,249,.5),rgba(167,139,250,.3),rgba(244,114,182,.4),rgba(123,159,249,.2)) border-box;box-shadow:0 0 30px rgba(123,97,255,.12),0 0 60px rgba(167,139,250,.06);overflow:hidden}
#sbar-wrap{height:32px;background:linear-gradient(90deg,rgba(123,97,255,.05),rgba(10,8,24,.8));border-top:1px solid rgba(123,97,255,.12);padding:0 16px;display:flex;align-items:center;font-size:11px;color:rgba(167,139,250,.85);flex-shrink:0;letter-spacing:.2px;gap:16px}
.sbar-sep{width:1px;height:14px;background:rgba(123,97,255,.2);flex-shrink:0}
.sbar-link{font-size:11px;font-weight:600;color:rgba(167,139,250,.6);text-decoration:none;letter-spacing:.2px;transition:.15s;white-space:nowrap}
.sbar-link:hover{color:#c4b5fd}
.sbar-social{display:flex;align-items:center;gap:6px}
.sbar-social-btn{width:22px;height:22px;border-radius:6px;border:1px solid rgba(123,97,255,.15);background:rgba(123,97,255,.06);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.18s;text-decoration:none;font-size:12px;flex-shrink:0}
.sbar-social-btn:hover{background:rgba(123,97,255,.18);border-color:rgba(167,139,250,.4);transform:scale(1.1)}
.sbar-report-btn{background:none;border:none;padding:0;cursor:pointer;color:rgba(251,113,113,.6);font-size:11px;font-weight:600;letter-spacing:.2px;transition:.15s;white-space:nowrap}
.sbar-report-btn:hover{color:#fca5a5}
.sbar-premium{color:rgba(251,191,36,.75)!important}
.sbar-premium:hover{color:#fbbf24!important}
[data-theme="light"] .sbar-premium{color:#b45309!important}
[data-theme="light"] .sbar-premium:hover{color:#92400e!important}
/* ── Report modal ── */
.report-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:99998;display:flex;align-items:center;justify-content:center}
.report-modal{background:var(--sur);border:1px solid rgba(123,159,249,.2);border-radius:14px;width:min(480px,90vw);box-shadow:0 24px 60px rgba(0,0,0,.7);overflow:hidden}
.report-modal-hd{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.06);font-size:13px;font-weight:700;color:var(--tx1)}
.report-modal-close{background:none;border:none;cursor:pointer;color:var(--tx3);font-size:16px;line-height:1;padding:2px 4px;transition:.15s}
.report-modal-close:hover{color:var(--tx1)}
.report-modal-body{padding:20px}
.report-modal-desc{font-size:12px;color:var(--tx2);margin:0 0 14px;line-height:1.6}
.report-modal-desc strong{color:var(--tx1)}
.report-modal-textarea{width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(123,97,255,.2);border-radius:8px;color:var(--tx1);font-size:12px;padding:10px 12px;resize:vertical;font-family:inherit;outline:none;transition:.15s;box-sizing:border-box}
.report-modal-textarea:focus{border-color:rgba(167,139,250,.5);background:rgba(255,255,255,.06)}
.report-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:12px 20px;border-top:1px solid rgba(255,255,255,.06)}
.report-modal-cancel{background:none;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--tx2);font-size:12px;padding:8px 16px;cursor:pointer;transition:.15s}
.report-modal-cancel:hover{border-color:rgba(255,255,255,.2);color:var(--tx1)}
.report-modal-send{background:rgba(167,139,250,.15);border:1px solid rgba(167,139,250,.3);border-radius:8px;color:#c4b5fd;font-size:12px;font-weight:600;padding:8px 16px;cursor:pointer;text-decoration:none;transition:.15s}
.report-modal-send:hover{background:rgba(167,139,250,.25);border-color:rgba(167,139,250,.5)}
.report-modal-send.disabled{opacity:.35;pointer-events:none}
.resizer{width:6px;background:transparent;cursor:col-resize;flex-shrink:0;transition:background .15s;position:relative;z-index:200;border:none}
.resizer:hover,.resizer.act{background:rgba(167,139,250,.2)}

/* ─── 3. TOPBAR ─────────────────────────────────────────────── */
.logo{font-family:var(--title);font-size:24px;letter-spacing:2.5px;color:var(--tx);white-space:nowrap;flex-shrink:0;display:flex;align-items:center;gap:8px}
.logo b{background:linear-gradient(135deg,#7b9ff9,#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.vr{width:1px;height:28px;background:linear-gradient(180deg,transparent,rgba(123,159,249,.2),transparent);flex-shrink:0}
.sp{flex:1}
.dname{background:rgba(123,97,255,.06);border:1px solid rgba(123,159,249,.2);color:var(--tx);font-size:13px;font-weight:600;padding:6px 13px;border-radius:8px;width:168px;transition:.25s;letter-spacing:.2px}
.dname:focus{outline:none;border-color:transparent;background:rgba(123,97,255,.1);box-shadow:0 0 0 2px rgba(167,139,250,.4),0 0 0 4px rgba(244,114,182,.12)}
[data-theme="light"] .dname{background:rgba(120,100,200,.06);border-color:rgba(120,100,200,.2);color:#1a1535}
[data-theme="light"] .dname:focus{border-color:rgba(37,99,235,.6);background:rgba(37,99,235,.05);box-shadow:0 0 0 3px rgba(37,99,235,.18)}
.tb{background:rgba(255,255,255,.04);border:1px solid rgba(123,159,249,.12);color:var(--tx2);font-size:13px;font-weight:600;padding:7px 14px;border-radius:var(--r2);transition:.2s;white-space:nowrap;display:flex;align-items:center;gap:7px;letter-spacing:.1px;position:relative}
.tb .tb-icon,.tb>*:first-child{font-size:15px}
.tb.prim{background:linear-gradient(135deg,#6c63ff,#a855f7,#ec4899);border:none;color:#fff;box-shadow:0 2px 20px rgba(168,85,247,.45);font-weight:700;letter-spacing:.2px}
@media(hover:hover){
  .tb:hover{background:rgba(123,97,255,.12);border-color:rgba(167,139,250,.35);color:var(--tx);box-shadow:0 0 12px rgba(123,97,255,.12)}
  .tb.prim:hover{background:linear-gradient(135deg,#7c6fff,#b866f8,#f05aa8);box-shadow:0 4px 28px rgba(168,85,247,.65);transform:translateY(-2px)}
  .tb.dng:hover{border-color:var(--red);color:var(--red);background:rgba(248,113,113,.08)}
}
.thm{width:34px;height:34px;border-radius:50%;border:1px solid rgba(123,159,249,.2);background:rgba(123,159,249,.08);display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;transition:.2s;flex-shrink:0}
.thm:hover{background:rgba(123,159,249,.18);border-color:rgba(123,159,249,.4);transform:scale(1.08)}

/* ── Theme toggle btn (topbar) ── */
.theme-toggle-btn{width:32px;height:32px;border-radius:8px;border:1px solid rgba(123,159,249,.15);background:rgba(123,97,255,.06);display:flex;align-items:center;justify-content:center;font-size:15px;cursor:pointer;transition:.2s;flex-shrink:0;color:var(--tx2)}
.theme-toggle-btn:hover{background:rgba(123,97,255,.14);border-color:rgba(167,139,250,.4);transform:scale(1.08);color:var(--tx)}

/* ── Profile button ── */
.profile-btn{width:34px;height:34px;border-radius:50%;border:1px solid transparent;background:var(--sur2) padding-box,linear-gradient(135deg,#7b9ff9,#a78bfa,#f472b6) border-box;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.2s;flex-shrink:0;overflow:hidden;position:relative}
.profile-btn:hover{box-shadow:0 0 14px rgba(167,139,250,.4),0 0 28px rgba(244,114,182,.15);transform:scale(1.06)}
.profile-btn img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.profile-btn-fallback{font-size:15px;color:#c4b5fd}

/* ── Profile dropdown ── */
.sb-collapsed-popup{position:fixed;z-index:99999;min-width:200px;background:var(--sur);border:1px solid rgba(123,97,255,.25);border-radius:12px;box-shadow:0 12px 40px rgba(0,0,0,.65);overflow:hidden;animation:profile-menu-in .18s cubic-bezier(.22,1,.36,1) both;padding:4px 0}
.sb-collapsed-popup-title{padding:8px 14px 6px;font-size:10px;font-weight:700;color:rgba(167,139,250,.6);letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid rgba(123,97,255,.1);margin-bottom:3px}
.sb-collapsed-popup-item{display:flex;align-items:center;gap:8px;width:100%;padding:9px 14px;background:none;border:none;color:var(--tx2);font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;text-align:left;transition:background .12s,color .12s}
.sb-collapsed-popup-item:hover{background:rgba(123,97,255,.08);color:var(--tx)}
.profile-menu{position:fixed;z-index:99999;min-width:220px;background:var(--sur);border:1px solid rgba(123,97,255,.25);border-radius:14px;box-shadow:0 16px 48px rgba(0,0,0,.7),0 0 0 1px rgba(167,139,250,.06) inset;overflow:hidden;animation:profile-menu-in .18s cubic-bezier(.22,1,.36,1) both}
.profile-menu-header{padding:14px 16px 10px;border-bottom:1px solid rgba(123,97,255,.12);background:linear-gradient(135deg,rgba(123,97,255,.08),rgba(244,114,182,.04))}
.profile-menu-avatar{width:38px;height:38px;border-radius:50%;border:2px solid transparent;background:var(--sur3) padding-box,linear-gradient(135deg,#7b9ff9,#a78bfa,#f472b6) border-box;object-fit:cover;flex-shrink:0}
.profile-menu-avatar-fallback{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,rgba(123,97,255,.3),rgba(244,114,182,.2));display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.profile-menu-name{font-size:13px;font-weight:700;background:linear-gradient(135deg,#e0d8ff,#f9a8d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.profile-menu-plan{font-size:10px;color:var(--tx3);font-weight:500;letter-spacing:.3px}
.profile-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;background:none;border:none;color:var(--tx2);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;text-align:left;transition:background .12s,color .12s}
.profile-menu-item:hover{background:rgba(123,97,255,.08);color:var(--tx)}
.profile-menu-item-icon{font-size:15px;width:20px;text-align:center;flex-shrink:0}
.profile-menu-sep{height:1px;background:rgba(123,97,255,.1);margin:4px 12px}
.profile-menu-item.danger:hover{background:rgba(248,113,113,.08);color:var(--red)}

/* ─── 4. PANEL HEADS ────────────────────────────────────────── */
.ph{height:44px;border-bottom:1px solid rgba(123,97,255,.12);display:flex;align-items:center;padding:0 14px;gap:8px;flex-shrink:0;background:linear-gradient(135deg,rgba(123,97,255,.06),rgba(244,114,182,.03))}
.ph-t{font-family:var(--title);font-size:16px;letter-spacing:1.5px;color:var(--tx)}
.ph-c{font-size:10px;font-weight:600;color:var(--tx3);background:var(--sur2);padding:2px 8px;border-radius:99px;border:1px solid var(--bor)}

/* ─── 5. DETAIL PANEL ───────────────────────────────────────── */
#p-det{overflow:hidden;display:flex;flex-direction:column;flex-shrink:0;min-width:320px;margin:8px 8px 8px 8px;border-radius:16px;border:1px solid transparent;background:var(--bg) padding-box,linear-gradient(200deg,rgba(244,114,182,.4),rgba(167,139,250,.3),rgba(123,159,249,.5),rgba(167,139,250,.2)) border-box;box-shadow:0 0 30px rgba(123,97,255,.12),0 0 60px rgba(167,139,250,.06)}
#det-scroll{flex:1;overflow-y:auto;display:flex;flex-direction:column;min-height:0}
#det{display:none;flex:none;flex-direction:column;min-height:0}
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;color:var(--tx3)}
.empty-ico{font-size:44px;opacity:.18}
.empty-txt{font-family:var(--title);font-size:12px;letter-spacing:3px;text-align:center;line-height:2.2}

.d-detail-card{margin:10px 12px 0;overflow:hidden;flex:0 0 auto;border:1px solid rgba(123,159,249,.14);border-radius:12px;background:linear-gradient(180deg,rgba(123,159,249,.055),rgba(10,8,26,.06));box-shadow:0 10px 28px rgba(0,0,0,.16),inset 0 1px 0 rgba(255,255,255,.03)}
.d-top{display:flex;gap:0;flex-shrink:0;flex-wrap:nowrap;align-items:flex-start}
.d-img-col{flex:0 0 152px;width:152px;position:relative;min-width:100px;padding:8px;background:linear-gradient(135deg,rgba(123,159,249,.08),rgba(167,139,250,.06));align-self:stretch;display:flex;align-items:flex-start;justify-content:center}
.d-img{width:136px;height:auto;display:block;aspect-ratio:421/614;object-fit:contain;background:var(--sur3);border-radius:7px;transition:transform .18s ease,filter .18s ease,box-shadow .18s ease;box-shadow:0 8px 22px rgba(0,0,0,.28),inset 0 0 0 1px rgba(123,159,249,.08)}
.d-img-col:hover .d-img{transform:scale(1.02);filter:brightness(1.05);box-shadow:0 0 0 1px rgba(123,159,249,.35),0 10px 26px rgba(123,159,249,.16)}
.d-img-hint{display:none}
.d-img-col:hover .d-img-hint{transform:translateX(-50%) scale(1.06);box-shadow:0 0 10px rgba(123,97,255,.4);border-color:rgba(123,97,255,.8)}
.d-img-hint-icon{font-size:11px;line-height:1;flex-shrink:0}
.d-img-hint-text{font-size:9px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:#c4b5fd}

.d-info-col{flex:1;min-width:0;display:flex;flex-direction:column;padding:12px 14px;gap:7px;border-left:1px solid rgba(123,159,249,.12)}
.d-name{font-family:var(--title);font-size:19px;letter-spacing:1px;line-height:1.15;background:linear-gradient(135deg,#eeeef5,#a5c0ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.bdg{display:inline-flex;align-items:center;gap:5px;min-height:23px;padding:4px 11px;border-radius:999px;font-size:11px;font-weight:850;letter-spacing:.35px;border:1px solid;text-transform:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 2px 8px color-mix(in srgb,var(--bdg,var(--blue)) 12%,transparent)}
.bdg-dot{width:6px;height:6px;border-radius:50%;background:currentColor;box-shadow:0 0 8px currentColor;flex-shrink:0}
.bdg--type{font-family:var(--ui)}
.bdg--race{background:linear-gradient(135deg,rgba(167,139,250,.14),rgba(123,159,249,.07)) !important}
.bdg--level{font-family:var(--mono);letter-spacing:.2px}
.d-badges{display:flex;flex-wrap:wrap;gap:5px}
.d-ext{font-size:10px;color:var(--tx3)}
.d-stats-row{display:flex;gap:5px;align-items:center;flex-wrap:wrap}
.d-stat{background:rgba(123,159,249,.065);border:1px solid rgba(123,159,249,.14);border-radius:8px;padding:4px 11px;text-align:center;box-shadow:inset 0 1px 0 rgba(255,255,255,.035)}
.d-stat-l{font-size:8px;color:var(--tx3);letter-spacing:1px;text-transform:uppercase}
.d-stat-v{font-family:var(--title);font-size:16px;color:var(--blue)}
.d-ban{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;font-size:9px;font-weight:850;border:1px solid color-mix(in srgb,var(--ban,#16a34a) 70%,transparent);letter-spacing:.45px;white-space:nowrap;color:var(--ban,#16a34a);background:color-mix(in srgb,var(--ban,#16a34a) 13%,transparent);box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.d-ban::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor;box-shadow:0 0 8px currentColor;flex-shrink:0}
.d-meta-section{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:4px 0 10px}
.d-prix-link{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;font-size:9px;font-weight:850;border:1px solid rgba(251,191,36,.35);background:rgba(251,191,36,.08);color:#fbbf24;text-decoration:none;letter-spacing:.3px;white-space:nowrap;transition:background .15s,border-color .15s}
.d-prix-link:hover{background:rgba(251,191,36,.18);border-color:rgba(251,191,36,.6)}
.d-prix-link-val{font-family:var(--title);font-size:13px;letter-spacing:.3px}
.d-prix-link-lbl{font-size:8px;letter-spacing:.5px;text-transform:uppercase;opacity:.7}
.d-prix-link-arrow{font-size:11px;margin:0 1px}
.d-chart{height:40px;position:relative;margin-bottom:10px}
.d-add-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:6px;padding:10px 12px 0;flex-shrink:0;border-top:1px solid rgba(123,159,249,.1)}
.d-add{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:8px;padding:9px 8px;background:var(--sur2);border:1px solid var(--bor);border-radius:10px;color:var(--tx2);font-size:10px;font-weight:700;cursor:pointer;transition:transform .18s,background .18s,border-color .18s,color .18s,box-shadow .18s;letter-spacing:.5px;text-transform:uppercase}
.d-add-ico{font-size:16px;font-weight:300;line-height:1;font-family:system-ui;color:inherit}
.d-add-lbl{font-size:9px;font-weight:800;letter-spacing:.6px;color:inherit}
.d-add-count{min-width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:var(--sur3);border:1px solid var(--bor);color:var(--tx);font-size:10px;font-weight:900;line-height:1}
.d-add-label-wrap{display:flex;flex:1 1 auto;flex-direction:column;align-items:center;gap:2px;min-width:0}
.d-add-step{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:7px;border:1px solid var(--bor);background:var(--sur3);color:var(--tx2);font-size:15px;font-weight:900;line-height:1;cursor:pointer;font-family:inherit}
.d-add-step:active{background:rgba(123,159,249,.14);color:var(--tx)}
.d-add:hover{transform:translateY(-2px)}
.d-add--main{border-color:rgba(123,159,249,.3)}
.d-add--main:hover{background:rgba(123,159,249,.14);border-color:rgba(123,159,249,.6);color:#a5c0ff;box-shadow:0 4px 16px rgba(123,159,249,.2)}
.d-add--extra{border-color:rgba(167,139,250,.3)}
.d-add--extra:hover{background:rgba(167,139,250,.14);border-color:rgba(167,139,250,.6);color:#c4b5fd;box-shadow:0 4px 16px rgba(167,139,250,.2)}
.d-add--side{border-color:rgba(52,211,153,.25)}
.d-add--side:hover{background:rgba(52,211,153,.12);border-color:rgba(52,211,153,.5);color:#6ee7b7;box-shadow:0 4px 16px rgba(52,211,153,.15)}
.d-explorer-row{padding:8px 12px 10px;flex-shrink:0}
.d-explorer-btn{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:9px 12px;background:linear-gradient(135deg,rgba(123,159,249,.1),rgba(167,139,250,.1),rgba(244,114,182,.08));border:1px solid rgba(167,139,250,.3);border-radius:10px;color:var(--tx2);font-size:11px;font-weight:700;cursor:pointer;letter-spacing:.4px;transition:transform .18s,background .18s,border-color .18s,color .18s,box-shadow .18s}
.d-explorer-btn:hover{transform:translateY(-1px);background:linear-gradient(135deg,rgba(123,159,249,.2),rgba(167,139,250,.18),rgba(244,114,182,.14));border-color:rgba(167,139,250,.6);color:#c4b5fd;box-shadow:0 4px 20px rgba(167,139,250,.2)}
.d-explorer-btn svg{flex-shrink:0;opacity:.8}
.d-body{flex:none;overflow-y:visible;padding:12px;min-height:0}
.d-body,.d-add-row,.d-explorer-row{flex-shrink:0}
.d-body--secondary>.d-lbl:first-child,.d-body--secondary>.d-desc--legacy{display:none!important}
.d-body::-webkit-scrollbar{width:3px}
.d-body::-webkit-scrollbar-thumb{background:var(--bor2)}
.d-lbl{font-size:11px;font-weight:700;letter-spacing:1.5px;color:rgba(123,159,249,.9);text-transform:uppercase;margin-bottom:6px;display:flex;align-items:center;gap:6px}
.d-lbl::after{content:'';flex:1;height:1px;background:rgba(123,159,249,.15)}
.d-desc{font-size:11.5px;line-height:1.75;color:var(--tx2);margin-bottom:12px;background:rgba(0,0,0,.04);border-radius:6px;padding:8px 10px}
.d-desc{font-size:11.5px;line-height:1.8;color:var(--tx2);margin-bottom:12px;background:rgba(123,159,249,.04);border:1px solid rgba(123,159,249,.08);border-radius:8px;padding:10px 12px}
.d-sets{display:flex;flex-direction:column;gap:3px;margin-bottom:12px}
.d-set-row{display:flex;align-items:center;gap:8px;font-size:12px;padding:3px 0}
.d-set-name{flex:1;color:var(--blue);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px;text-decoration:none}
.d-set-name:hover{text-decoration:underline}
[data-theme="dark"] .d-set-name{color:#60a5fa}
.d-set-meta{color:var(--tx3);flex-shrink:0;font-size:11px;font-family:var(--mono)}
[data-theme="dark"] .d-set-meta{color:var(--tx2)}
.d-set-price{color:var(--green);font-weight:700;flex-shrink:0;font-size:12px}
.d-set-price--na{color:var(--tx3);font-weight:400;font-style:italic}
.d-set-date{color:var(--tx3);font-size:11px;font-family:var(--mono);flex-shrink:0}
.d-proba{margin-bottom:0}
.prow{display:flex;align-items:center;gap:7px;margin-bottom:4px}
.prow:last-child{margin-bottom:0}
.plbl{font-size:10px;color:var(--tx3);width:64px;flex-shrink:0}
[data-theme="dark"] .plbl{color:var(--tx2)}
[data-theme="dark"] .ppct{color:inherit}
.ptr{flex:1;height:4px;background:var(--sur2);border-radius:2px;overflow:hidden}
.pfill{height:100%;border-radius:2px;transition:width .5s cubic-bezier(.4,0,.2,1)}
.ppct{font-size:10px;font-weight:700;width:32px;text-align:right;flex-shrink:0}

/* ─── 6. DECK PANEL ─────────────────────────────────────────── */
.dscroll{flex:1;overflow-y:auto;padding:10px 12px 18px;display:flex;flex-direction:column;gap:16px}
.dscroll::-webkit-scrollbar{width:4px}
.dscroll::-webkit-scrollbar-thumb{background:var(--bor2)}
.sec-block{border-radius:14px;overflow:hidden;flex-shrink:0;display:flex;flex-direction:column;background:linear-gradient(180deg,rgba(15,14,32,.92),rgba(9,10,24,.94)) padding-box,linear-gradient(135deg,rgba(123,159,249,.26),rgba(167,139,250,.2),rgba(244,114,182,.16)) border-box;border:1px solid transparent;box-shadow:0 16px 42px rgba(0,0,0,.36),0 0 0 1px rgba(255,255,255,.015) inset}
.sec-block[data-sec="main"]{background:radial-gradient(circle at 18% 0,rgba(123,159,249,.08),transparent 42%),linear-gradient(180deg,rgba(13,15,34,.94),rgba(8,10,25,.95)) padding-box,linear-gradient(135deg,rgba(123,159,249,.42),rgba(123,159,249,.18)) border-box;box-shadow:0 16px 42px rgba(0,0,0,.36),0 0 24px rgba(123,159,249,.06)}
.sec-block[data-sec="extra"]{background:radial-gradient(circle at 18% 0,rgba(192,132,252,.09),transparent 42%),linear-gradient(180deg,rgba(20,12,34,.94),rgba(13,8,27,.95)) padding-box,linear-gradient(135deg,rgba(192,132,252,.42),rgba(192,132,252,.18)) border-box;box-shadow:0 16px 42px rgba(0,0,0,.36),0 0 24px rgba(192,132,252,.07)}
.sec-block[data-sec="side"]{background:radial-gradient(circle at 18% 0,rgba(52,211,153,.08),transparent 42%),linear-gradient(180deg,rgba(9,24,31,.94),rgba(7,15,25,.95)) padding-box,linear-gradient(135deg,rgba(52,211,153,.36),rgba(52,211,153,.16)) border-box;box-shadow:0 16px 42px rgba(0,0,0,.36),0 0 24px rgba(52,211,153,.05)}
.sec-hd{min-height:52px;display:flex;align-items:center;gap:10px;padding:0 18px;background:rgba(123,97,255,.035);border-bottom:1px solid rgba(123,159,249,.1);cursor:default;transition:background .15s}
.sec-hd[data-sec="main"]{background:linear-gradient(90deg,rgba(123,159,249,.09),rgba(123,159,249,.018));border-bottom-color:rgba(123,159,249,.13)}
.sec-hd[data-sec="extra"]{background:linear-gradient(90deg,rgba(192,132,252,.1),rgba(192,132,252,.022));border-bottom-color:rgba(192,132,252,.14)}
.sec-hd[data-sec="side"]{background:linear-gradient(90deg,rgba(52,211,153,.08),rgba(52,211,153,.018));border-bottom-color:rgba(52,211,153,.13)}
.sec-hd-name[data-sec="main"],.sec-block[data-sec="main"] .sec-hd-name{background:linear-gradient(135deg,#a5c0ff,#c4b5fd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.sec-hd-name[data-sec="extra"],.sec-block[data-sec="extra"] .sec-hd-name{background:linear-gradient(135deg,#d8b4fe,#f9a8d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.sec-hd-name[data-sec="side"],.sec-block[data-sec="side"] .sec-hd-name{background:linear-gradient(135deg,#6ee7b7,#a5c0ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.sec-block[data-sec="main"] .sec-hd-cnt{background:rgba(123,159,249,.1);color:rgba(165,192,255,.9);border:1px solid rgba(123,159,249,.25)}
.sec-block[data-sec="extra"] .sec-hd-cnt{background:rgba(192,132,252,.1);color:rgba(216,180,254,.9);border:1px solid rgba(192,132,252,.25)}
.sec-block[data-sec="side"] .sec-hd-cnt{background:rgba(16,185,129,.1);color:#10b981;border:1px solid rgba(16,185,129,.3)}
.sec-hd-icon{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;filter:drop-shadow(0 0 6px currentColor)}
.sec-hd-icon-img{width:34px;height:34px;object-fit:contain;display:block}
.sec-hd-name{font-family:var(--title);font-size:16px;letter-spacing:2.4px;flex:1;color:var(--tx);font-weight:700;line-height:1}
.sec-hd-cnt{min-width:58px;height:28px;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:rgba(196,181,253,.9);background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.1);padding:0 11px;border-radius:13px;flex-shrink:0;line-height:1}
.sec-hd-price{font-family:var(--title);font-size:13px;color:var(--gold)}
.sec-drop{padding:12px 18px 14px;min-height:86px;position:relative;transition:background .15s,outline .15s}
.sec-drop--collapsed{display:none}
.sec-block:has(.sec-drop--collapsed) .sec-hd{border-bottom-color:transparent}
.sec-block:has(.sec-empty) .sec-hd-controls{display:none}
.sec-collapse-btn{width:42px;height:28px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.1);color:var(--tx3);font-size:13px;font-weight:800;padding:0;border-radius:13px;cursor:pointer;transition:.18s;line-height:1;flex-shrink:0;display:flex;align-items:center;justify-content:center;min-width:42px}
.sec-collapse-btn:hover{background:rgba(123,159,249,.12);border-color:rgba(123,159,249,.3);color:var(--tx)}
.sec-block.drop-over .sec-hd{background:rgba(123,159,249,.15);border-color:rgba(123,159,249,.4)}
.sec-block.drop-over{outline:2px dashed rgba(123,159,249,.5);outline-offset:-2px;border-radius:var(--r);box-shadow:0 0 20px rgba(123,159,249,.1) inset}
.sec-empty{display:flex;align-items:center;justify-content:center;height:58px;font-size:13px;font-weight:600;color:rgba(123,159,249,.8);letter-spacing:.35px;background:rgba(4,7,20,.1);border:1px dashed rgba(123,159,249,.24);border-radius:10px;margin:0;transition:border-color .2s,box-shadow .2s,background .2s,color .2s}
.sec-block[data-sec="extra"] .sec-empty{color:rgba(192,132,252,.7);border-color:rgba(192,132,252,.2)}
.sec-block[data-sec="side"] .sec-empty{color:rgba(16,185,129,.7);border-color:rgba(16,185,129,.2)}
/* ── Drag active : pulse sur les zones d'accueil ── */
@keyframes drop-zone-pulse{0%,100%{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.01)}}
body.card-dragging .sec-block{transition:box-shadow .2s}
body.card-dragging .sec-empty{animation:drop-zone-pulse 1.4s ease-in-out infinite;border-style:dashed}
body.card-dragging .sec-block[data-sec="main"] .sec-empty{border-color:rgba(123,159,249,.55);box-shadow:0 0 10px rgba(123,159,249,.12) inset}
body.card-dragging .sec-block[data-sec="extra"] .sec-empty{border-color:rgba(192,132,252,.45);box-shadow:0 0 10px rgba(192,132,252,.1) inset}
body.card-dragging .sec-block[data-sec="side"] .sec-empty{border-color:rgba(16,185,129,.45);box-shadow:0 0 10px rgba(16,185,129,.1) inset}
body.card-dragging .sec-block.drop-over{box-shadow:0 0 32px rgba(123,159,249,.22) inset;outline-width:2px}
body.card-dragging .sec-block.drop-over .sec-empty{animation:none;border-style:solid;border-color:rgba(123,159,249,.9);background:rgba(123,159,249,.1);color:#c4b5fd;box-shadow:0 0 18px rgba(123,159,249,.25) inset}
body.card-dragging .sec-block[data-sec="extra"].drop-over .sec-empty{border-color:rgba(192,132,252,.9);background:rgba(192,132,252,.08);color:#d8b4fe;box-shadow:0 0 18px rgba(192,132,252,.2) inset}
body.card-dragging .sec-block[data-sec="side"].drop-over .sec-empty{border-color:rgba(16,185,129,.9);background:rgba(16,185,129,.08);color:#6ee7b7;box-shadow:0 0 18px rgba(16,185,129,.2) inset}
.cards-grid{display:grid;gap:3px}
.dc-card{position:relative;border-radius:var(--r2);overflow:hidden;cursor:grab;border:2px solid transparent;transition:border-color .12s,opacity .12s,transform .2s cubic-bezier(.22,1,.36,1),box-shadow .2s;user-select:none;min-width:0}
.dc-card.sorting{animation:deck-sort .38s cubic-bezier(.34,1.56,.64,1) both}
.dc-card:hover{border-color:rgba(123,159,249,.5);z-index:10;transform:translateY(-6px) scale(1.1);box-shadow:0 12px 32px rgba(0,0,0,.5),0 0 0 1px rgba(123,159,249,.2)}
.dc-card.on{border-color:var(--blue)}
.dc-card.deck-sel{border-color:rgba(168,85,247,.9) !important;box-shadow:0 0 0 2px rgba(168,85,247,.35),0 0 14px rgba(168,85,247,.4) !important;z-index:50 !important}
.dc-card.deck-sel .dc-card-overlay{opacity:1}
.deck-list-row.deck-sel{background:rgba(168,85,247,.1) !important;outline:1px solid rgba(168,85,247,.4);border-radius:5px}
.dc-card.drg{opacity:.25;outline:2px dashed var(--blue)}
.dc-card.deck-dov{outline:2px solid var(--blue);background:color-mix(in srgb,var(--blue) 12%,var(--sur2))}
.dc-card.dov{border-color:var(--blue);border-style:dashed;background:color-mix(in srgb,var(--blue) 8%,var(--sur2))}
.dc-card img{width:100%;height:100%;display:block;object-fit:cover;pointer-events:none;background:var(--sur3)}
.dc-card-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.75));padding:4px 4px 3px;opacity:0;transition:.15s}
.dc-card:hover .dc-card-overlay,.dc-card.on .dc-card-overlay{opacity:1}
.dc-card-name{font-size:9px;font-weight:700;color:#fff;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dc-card-price{font-size:8px;color:rgba(255,220,100,.9);font-weight:600}
.dc-card-rm{position:absolute;top:3px;right:3px;width:16px;height:16px;border-radius:50%;background:rgba(220,38,38,.9);border:none;color:#fff;font-size:10px;display:flex;align-items:center;justify-content:center;opacity:0;transition:.15s;cursor:pointer;line-height:1}
.dc-card:hover .dc-card-rm{opacity:1}
.dc-moves{position:absolute;top:3px;left:3px;display:flex;flex-direction:column;gap:2px;opacity:0;transition:.15s}
.dc-card:hover .dc-moves{opacity:1}
.dc-mv{width:16px;height:16px;border-radius:3px;background:rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:9px;display:flex;align-items:center;justify-content:center;cursor:pointer;line-height:1}
.dc-mv:hover{background:var(--blue)}
.sec-mv-row{display:flex;gap:4px;padding:0 5px 5px}
.sec-mv-btn{flex:1;padding:4px 0;background:var(--sur2);border:1px solid var(--bor);color:var(--tx3);font-size:10px;font-weight:600;border-radius:var(--r2);cursor:pointer;transition:.15s}
.sec-mv-btn:hover{border-color:var(--blue);color:var(--blue)}
.rm-card{display:flex;align-items:stretch;gap:0;border-bottom:1px solid var(--bor);cursor:pointer;transition:background .12s;position:relative;min-height:44px}
.rm-card:hover{background:rgba(123,159,249,.06);border-bottom-color:rgba(123,159,249,.15)}
.rm-card.on{background:rgba(123,159,249,.08);border-left:2px solid rgba(123,159,249,.5)}
.totrow{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.totl{font-size:11px;color:var(--tx3)}
.totv{font-family:var(--title);font-size:18px;color:var(--green)}
.size-row{display:flex;align-items:center;gap:8px;margin-bottom:0}
.size-lbl{font-size:10px;color:var(--tx3);white-space:nowrap}
/* Boutons de vue decklist */
.deck-view-btns{display:flex;gap:3px;align-items:center;padding:3px;border:1px solid rgba(167,139,250,.16);border-radius:10px;background:rgba(167,139,250,.055)}
.dl-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:transparent;color:var(--tx);font-size:12px;border-radius:6px;cursor:pointer;text-align:left;transition:.12s}
.dl-item:hover{background:var(--sur2)}
.deck-vb,.deck-head-action{width:30px;height:28px;border-radius:8px;border:1px solid transparent;background:transparent;color:rgba(200,190,240,.72);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s,color .15s,box-shadow .15s,transform .15s;padding:0;position:relative}
.deck-vb svg,.deck-head-action svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;pointer-events:none}
.deck-vb:hover,.deck-head-action:hover{background:rgba(123,97,255,.12);border-color:rgba(167,139,250,.28);color:#f0eeff}
.deck-vb:active,.deck-head-action:active{transform:translateY(1px)}
.deck-vb.on{background:rgba(123,97,255,.24);border-color:rgba(167,139,250,.58);color:#e2d9ff;box-shadow:inset 0 1px 4px rgba(0,0,0,.28),0 0 0 2px rgba(167,139,250,.13)}
.deck-head-action{border-color:rgba(167,139,250,.18);background:rgba(167,139,250,.07);color:#d4cafe}
.deck-head-action-sort{margin-right:2px}
.deck-head-action-tags{width:auto;padding:0 9px;gap:6px;margin-left:2px;font-family:var(--ui);font-size:12px;font-weight:600;letter-spacing:-.01em;color:rgba(248,113,113,.9);border-color:rgba(248,113,113,.2);background:rgba(248,113,113,.055)}
.deck-head-action-tags svg{width:14px;height:14px}
.deck-head-action-tags:hover{color:#fca5a5;background:rgba(248,113,113,.11);border-color:rgba(248,113,113,.38)}
.sec-hd-controls{display:flex;align-items:center;gap:6px;margin-left:auto;flex-shrink:0}
.btn-short{display:none}
.btn-txt{display:inline}
/* Mode artwork */
.dc-card-artwork{display:flex;flex-direction:column;overflow:visible !important}
.dc-card-artwork img{border-radius:4px 4px 0 0}
.dc-artwork-name{font-size:7px;font-weight:600;color:var(--tx2);text-align:center;padding:2px 2px 1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:var(--sur2);border-radius:0 0 4px 4px;line-height:1.3;flex-shrink:0}
/* Mode liste */
.deck-list-hdr{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--sur2);border-bottom:1px solid var(--bor);flex-shrink:0}
.deck-list-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:6px;flex:1;min-height:0;overflow-y:auto}
.deck-list-col{border:1px solid var(--bor);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column}
.deck-list-col-hd{display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--sur2);border-bottom:1px solid var(--bor);font-size:12px;flex-shrink:0}
.deck-list-items{flex:1;overflow-y:auto;padding:2px}
.deck-list-items::-webkit-scrollbar{width:3px}
.deck-list-items::-webkit-scrollbar-thumb{background:var(--bor2)}
.deck-list-row{display:flex;align-items:center;gap:5px;padding:3px 6px;border-radius:4px;cursor:pointer;transition:.1s;font-size:11px;min-height:26px}
.deck-list-row:hover{background:var(--sur2)}
.tag-mode-active .dc-card:hover{border-color:rgba(123,159,249,.5);z-index:10;transform:translateY(-6px) scale(1.1);box-shadow:0 12px 32px rgba(0,0,0,.5),0 0 0 1px rgba(123,159,249,.2)}
.tag-mode-active .dc-card:hover .dc-card-overlay,
.tag-mode-active .dc-card:hover .dc-card-rm,
.tag-mode-active .dc-card:hover .dc-moves{opacity:0}
.tag-mode-active .dc-card-rm,
.tag-mode-active .dc-moves,
.tag-mode-active .dlv-btn-rm,
body.card-group-mode-active .dc-card-rm,
body.card-group-mode-active .dc-moves,
body.card-group-mode-active .dlv-btn-rm,
body.combo-lines-mode-active .dc-card-rm,
body.combo-lines-mode-active .dc-moves,
body.combo-lines-mode-active .dlv-btn-rm{display:none!important}
.tag-help-copy-mobile{display:none}
.tag-mode-active .deck-list-row:hover{background:transparent}
.deck-list-color{width:3px;height:16px;border-radius:2px;flex-shrink:0}
.deck-list-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--tx)}
.deck-list-price{font-size:9px;color:var(--gold);font-family:var(--title);flex-shrink:0}

/* ─── 7. SEARCH PANEL ───────────────────────────────────────── */
.sh-searchbar{padding:10px 12px 8px;border-bottom:1px solid var(--bor);flex-shrink:0;background:var(--sur)}
.sh-input-wrap{display:flex;align-items:center;background:rgba(123,97,255,.05);border:1.5px solid rgba(123,159,249,.15);border-radius:10px;padding:0 10px;gap:6px;transition:.25s}
.sh-input-wrap:focus-within{border-color:transparent;background:rgba(123,97,255,.09);box-shadow:0 0 0 2px rgba(167,139,250,.4),0 0 0 4px rgba(244,114,182,.1)}
.sh-icon{font-size:14px;flex-shrink:0;opacity:.5}
.sh-input{flex:1;border:none;background:transparent;color:var(--tx);font-size:13px;padding:9px 0;outline:none}
.sh-input::placeholder{color:var(--tx3)}
.sh-clear-btn{background:none;border:none;color:var(--tx3);font-size:12px;cursor:pointer;padding:4px;border-radius:4px;flex-shrink:0}
.sh-clear-btn:hover{color:var(--red)}
.sh-meta{display:flex;align-items:center;gap:8px;margin-top:7px}
.pg-count-mob{display:none}
.sh-count{font-family:var(--title);font-size:18px;color:var(--blue)}
.sh-count-lbl{font-size:11px;color:var(--tx3)}
.sh-col-wrap{display:flex;align-items:center;gap:4px}
.sh-col-wrap input[type=range]{-webkit-appearance:none;appearance:none;height:3px;width:52px;background:var(--bor2);border-radius:2px;outline:none;cursor:pointer}
.sh-col-wrap input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:13px;height:13px;border-radius:50%;background:var(--blue);border:2px solid var(--sur);cursor:pointer}
#cols-val{font-size:10px;color:var(--tx3);min-width:12px;text-align:center}
.sh-tabs{display:flex;align-items:center;gap:6px;flex-wrap:wrap;border-bottom:1px solid rgba(123,159,249,.1);flex-shrink:0;background:linear-gradient(180deg,rgba(123,159,249,.045),rgba(123,159,249,.018));padding:6px 8px}
.sh-tab-group{display:flex;align-items:center;gap:3px;flex:1 1 auto;min-width:0;padding:3px;border:1px solid rgba(167,139,250,.14);border-radius:10px;background:rgba(4,5,14,.16)}
.sh-tab{flex:1;height:28px;padding:0 8px;border:1px solid transparent;border-radius:8px;background:transparent;color:rgba(200,190,240,.68);font-size:11px;font-weight:800;letter-spacing:.55px;text-transform:uppercase;cursor:pointer;transition:background .15s,border-color .15s,color .15s,box-shadow .15s;display:flex;align-items:center;justify-content:center;gap:5px;white-space:nowrap}
.sh-tab:hover{color:#f0eeff;background:rgba(123,97,255,.1);border-color:rgba(167,139,250,.22)}
.sh-tab.on{color:#e2d9ff;background:linear-gradient(180deg,rgba(123,97,255,.28),rgba(123,97,255,.16));border-color:rgba(167,139,250,.48);box-shadow:inset 0 1px 4px rgba(0,0,0,.26),0 0 0 2px rgba(167,139,250,.1)}
.sh-tab-count{display:none;min-width:16px;height:16px;padding:0 5px;border-radius:99px;background:rgba(167,139,250,.2);color:#e2d9ff;font-size:9px;font-weight:900;line-height:16px;text-align:center;letter-spacing:0}
.sh-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}
.sh-format-bar{display:flex;align-items:center;gap:5px;padding:6px 10px 7px;border-bottom:1px solid var(--bor);flex-shrink:0;flex-wrap:wrap;background:rgba(123,159,249,.018)}
.fmt-pill{height:28px;display:inline-flex;align-items:center;justify-content:center;gap:5px;background:rgba(167,139,250,.055);border:1px solid rgba(167,139,250,.16);color:rgba(200,190,240,.76);font-family:var(--ui);font-size:12px;font-weight:700;padding:0 12px;border-radius:8px;cursor:pointer;transition:background .15s,border-color .15s,color .15s,box-shadow .15s,transform .15s;letter-spacing:0;white-space:nowrap}
.fmt-pill:hover{border-color:rgba(167,139,250,.34);color:#f0eeff;background:rgba(123,97,255,.12)}
.fmt-pill:active{transform:translateY(1px)}
.fmt-pill.on{position:relative;isolation:auto;overflow:hidden;background:rgba(123,97,255,.24);border:1px solid rgba(167,139,250,.58) !important;color:#e2d9ff;box-shadow:inset 0 1px 4px rgba(0,0,0,.28),0 0 0 2px rgba(167,139,250,.13)}
.fmt-pill.on::before,.fmt-pill.on::after{content:none}
.fmt-pill.fmt-retro{border-style:solid;color:rgba(251,191,36,.82);background:rgba(245,158,11,.055);border-color:rgba(245,158,11,.18)}
.fmt-pill.fmt-retro:hover{color:#fde68a;background:rgba(245,158,11,.11);border-color:rgba(245,158,11,.34)}
.fmt-pill.fmt-retro.on{background:rgba(245,158,11,.18);border-color:rgba(245,158,11,.46) !important;color:#fde68a;box-shadow:inset 0 1px 4px rgba(0,0,0,.24),0 0 0 2px rgba(245,158,11,.11)}
.fmt-pill[data-fmt="goat"]{color:rgba(74,222,128,.86);background:rgba(34,197,94,.06);border-color:rgba(34,197,94,.2)}
.fmt-pill[data-fmt="goat"]:hover{color:#86efac;background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.36)}
.fmt-pill[data-fmt="goat"].on{color:#bbf7d0;background:rgba(34,197,94,.2);border-color:rgba(34,197,94,.5) !important;box-shadow:inset 0 1px 4px rgba(0,0,0,.24),0 0 0 2px rgba(34,197,94,.12)}
.fmt-pill[data-fmt="edison"]{color:rgba(251,191,36,.86);background:rgba(245,158,11,.06);border-color:rgba(245,158,11,.2)}
.fmt-pill[data-fmt="edison"]:hover{color:#fde68a;background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.36)}
.fmt-pill[data-fmt="edison"].on{color:#fde68a;background:rgba(245,158,11,.2);border-color:rgba(245,158,11,.5) !important;box-shadow:inset 0 1px 4px rgba(0,0,0,.24),0 0 0 2px rgba(245,158,11,.12)}
.fmt-pill[data-fmt="genesys"]{color:rgba(216,180,254,.9);background:rgba(168,85,247,.07);border-color:rgba(168,85,247,.22)}
.fmt-pill[data-fmt="genesys"]:hover{color:#e9d5ff;background:rgba(168,85,247,.14);border-color:rgba(168,85,247,.4)}
.fmt-pill[data-fmt="genesys"].on{color:#f3e8ff;background:rgba(168,85,247,.24);border-color:rgba(168,85,247,.55) !important;box-shadow:inset 0 1px 4px rgba(0,0,0,.24),0 0 0 2px rgba(168,85,247,.13)}
.fmt-pill[data-fmt="masterduel"]{color:rgba(147,197,253,.9);background:rgba(59,130,246,.07);border-color:rgba(59,130,246,.22)}
.fmt-pill[data-fmt="masterduel"]:hover{color:#bfdbfe;background:rgba(59,130,246,.14);border-color:rgba(59,130,246,.4)}
.fmt-pill[data-fmt="masterduel"].on{color:#dbeafe;background:rgba(59,130,246,.24);border-color:rgba(59,130,246,.55) !important;box-shadow:inset 0 1px 4px rgba(0,0,0,.24),0 0 0 2px rgba(59,130,246,.13)}
#active-pills-bar{background:var(--sur2);border-bottom:1px solid var(--bor);padding:5px 10px;gap:4px;flex-shrink:0}
.active-pill{display:inline-flex;align-items:center;gap:4px;background:var(--blue);color:#fff;border:none;border-radius:99px;padding:2px 8px 2px 10px;font-size:10px;font-weight:600;cursor:pointer;transition:.15s;white-space:nowrap}
.active-pill:hover{background:var(--blue2)}
.active-pill-x{font-size:10px;opacity:.8;margin-left:1px}
.active-pill-clear-all{background:var(--orange) !important}
.active-pill-clear-all:hover{filter:brightness(.9)}
#res-g{overflow:hidden;flex:1;display:grid;grid-template-columns:repeat(5,1fr);gap:5px;padding:6px;align-content:start;position:relative;z-index:0;isolation:isolate}.rg-wrap{position:relative;overflow:visible;animation:card-in .22s ease both;z-index:1}.rg-wrap:nth-child(2){animation-delay:.03s}.rg-wrap:nth-child(3){animation-delay:.06s}.rg-wrap:nth-child(4){animation-delay:.09s}.rg-wrap:nth-child(5){animation-delay:.12s}.rg-wrap:nth-child(n+6){animation-delay:.15s}
#res-g-loader{text-align:center;padding:12px;font-size:11px;color:var(--tx3);display:none}
#res-g-loader.visible{display:block}
.load-spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--bor2);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-right:6px}
.rg{border-radius:10px;overflow:visible;cursor:pointer;border:2px solid transparent;transition:border-color .18s,transform .2s cubic-bezier(.22,1,.36,1),box-shadow .2s;background:var(--sur3);position:relative;box-shadow:0 2px 8px rgba(0,0,0,.2);user-select:none;-webkit-user-drag:none}
.rg img{border-radius:8px 8px 0 0;overflow:hidden;display:block;width:100%;-webkit-user-drag:none;user-drag:none;pointer-events:none}

.rg:hover{border-color:rgba(123,159,249,.4)}.rg-wrap:hover{z-index:10}.rg-wrap:hover .rg{transform:translateY(-6px) scale(1.07);box-shadow:0 12px 32px rgba(0,0,0,.5),0 0 0 1px rgba(123,159,249,.15)}.rg-wrap:hover .rg-md-badge{transform:translateY(-6px) scale(1.07)}
.rg.on{border-color:rgba(123,159,249,.7);box-shadow:0 0 0 2px rgba(123,159,249,.2)}
.rg img{width:100%;display:block;aspect-ratio:421/614;object-fit:contain;background:rgba(20,18,30,.8);min-width:0;border-bottom:3px solid transparent}.rg-md-badge{position:absolute!important;top:-10px!important;right:-10px!important;width:30px!important;height:30px!important;aspect-ratio:unset!important;object-fit:contain!important;background:transparent!important;border:none!important;z-index:2;pointer-events:none;filter:drop-shadow(0 1px 4px rgba(0,0,0,.9))}
.rg-footer,.rg-name,.rg-type{display:none}
.rg-tag-badges{position:absolute;top:3px;left:0;right:0;display:flex;flex-wrap:wrap;justify-content:center;gap:2px;pointer-events:none;padding:0 2px}
#res{padding:4px;overflow-y:auto;min-height:0;display:none;flex-direction:column}
#res::-webkit-scrollbar{width:0;height:0}
.ri{padding:7px 10px;border-radius:8px;cursor:pointer;border:1px solid transparent;margin-bottom:2px;display:flex;align-items:center;gap:9px;transition:.18s,transform .2s cubic-bezier(.22,1,.36,1),box-shadow .2s;animation:card-in .2s ease both}
.ri:nth-child(2){animation-delay:.03s}.ri:nth-child(3){animation-delay:.06s}.ri:nth-child(4){animation-delay:.09s}.ri:nth-child(n+5){animation-delay:.12s}
.ri:hover{background:rgba(123,159,249,.06);border-color:rgba(123,159,249,.2);transform:translateX(5px) scale(1.01);box-shadow:0 4px 16px rgba(0,0,0,.15);z-index:2}
.ri.on{background:rgba(123,159,249,.08);border-color:rgba(123,159,249,.35)}
.ri-dragging{opacity:.5}
.ri-img{width:var(--zoom-li-img,36px);height:calc(var(--zoom-li-img,36px) * 1.44);object-fit:contain;border-radius:3px;flex-shrink:0;background:var(--sur3)}
.ri-name{font-size:var(--zoom-li-fs,12px);font-weight:600;color:var(--tx);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ri-type{font-size:10px;font-weight:500;display:flex;align-items:center;gap:4px}
.dot{display:inline-block;width:5px;height:5px;border-radius:50%;flex-shrink:0}
#res-m{overflow-y:auto;min-height:0;display:none;flex-direction:column;padding-left:6px}
#res-m::-webkit-scrollbar{width:0;height:0}
.sh-loader{text-align:center;padding:10px;font-size:11px;color:var(--tx3);display:none;flex-shrink:0}
.sh-loader.visible{display:block}
.sh-load-more{width:calc(100% - 12px);margin:0 6px 8px;padding:8px;background:var(--sur2);border:1px solid var(--bor);color:var(--tx2);font-size:11px;font-weight:600;border-radius:8px;cursor:pointer;transition:.15s;flex-shrink:0}
.sh-load-more:hover{background:var(--blue);border-color:var(--blue);color:#fff}
#pg-input::-webkit-outer-spin-button,#pg-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
#pg-input[type=number]{-moz-appearance:textfield}
#pg-input{background:rgba(123,159,249,.08);border:1px solid rgba(123,159,249,.2);color:rgba(123,159,249,.8);border-radius:6px;text-align:center;font-weight:700;font-size:11px}
.vbtn{background:rgba(123,159,249,.05);border:1px solid rgba(123,159,249,.12);color:rgba(123,159,249,.8);font-size:11px;padding:3px 8px;border-radius:6px;cursor:pointer;transition:.18s;font-weight:600}
.vbtn:hover{background:rgba(123,159,249,.12);border-color:rgba(123,159,249,.3);color:#a5c0ff}
.vbtn.on{background:linear-gradient(135deg,rgba(123,159,249,.25),rgba(167,139,250,.25));border-color:rgba(123,159,249,.4);color:#c4b5fd}

/* Boutons de pagination */
.sh-pagination{display:flex;align-items:center;justify-content:center;gap:3px;padding:8px 6px;border-top:1px solid rgba(123,159,249,.08);flex-shrink:0;background:rgba(123,159,249,.03)}
.pg-btn{width:26px;height:26px;border-radius:8px;border:1px solid rgba(123,159,249,.15);background:rgba(123,159,249,.06);color:rgba(123,159,249,.9);font-size:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.18s;line-height:1;flex-shrink:0}
.pg-btn:hover:not(:disabled){background:rgba(123,159,249,.2);border-color:rgba(123,159,249,.4);color:#a5c0ff;transform:scale(1.08)}
.pg-btn:disabled{opacity:.25;cursor:default}
#pg-info{font-size:11px;font-weight:700;color:rgba(123,159,249,.85);padding:0 4px;white-space:nowrap;min-width:60px;text-align:center;letter-spacing:.3px}

/* Boutons vue grille / liste / minimal */
.sh-view-btns{display:flex;gap:3px;align-items:center;padding:3px;border:1px solid rgba(167,139,250,.16);border-radius:10px;background:rgba(167,139,250,.055);flex-shrink:0}
.sh-vb{width:30px;height:28px;border-radius:8px;border:1px solid transparent;background:transparent;color:rgba(200,190,240,.72);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s,color .15s,box-shadow .15s,transform .15s;padding:0;position:relative;line-height:1;flex-shrink:0}
.sh-vb svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;pointer-events:none}
.sh-vb:hover{background:rgba(123,97,255,.12);border-color:rgba(167,139,250,.28);color:#f0eeff}
.sh-vb:active{transform:translateY(1px)}
.sh-vb.on{background:rgba(123,97,255,.24);border-color:rgba(167,139,250,.58);color:#e2d9ff;box-shadow:inset 0 1px 4px rgba(0,0,0,.28),0 0 0 2px rgba(167,139,250,.13)}

/* Affichage Minimal (#res-m) */
.rm-card{display:flex;align-items:stretch;gap:0;border-bottom:1px solid var(--bor);cursor:pointer;transition:background .12s;position:relative;min-height:34px;animation:card-in .18s ease both}
.rm-card:nth-child(2){animation-delay:.02s}.rm-card:nth-child(3){animation-delay:.04s}.rm-card:nth-child(4){animation-delay:.06s}.rm-card:nth-child(n+5){animation-delay:.08s}
.rm-card:hover{background:rgba(123,159,249,.06);border-bottom-color:rgba(123,159,249,.15)}
.rm-card.on{background:rgba(123,159,249,.08);border-left:2px solid rgba(123,159,249,.5)}
.rm-bar{width:3px;flex-shrink:0;border-radius:2px 0 0 2px}
.rm-img{width:var(--zoom-mi-img,28px);height:calc(var(--zoom-mi-img,28px) * 1.44);object-fit:contain;flex-shrink:0;background:var(--sur3);border-right:1px solid var(--bor)}
.rm-body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;padding:3px 8px;gap:1px}
.rm-name{font-size:11px;font-weight:600;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.rm-sub{font-size:9px;color:var(--tx3);display:flex;align-items:center;gap:5px;white-space:nowrap;overflow:hidden}
.rm-price{font-size:10px;font-weight:700;color:var(--gold);flex-shrink:0;padding:0 6px;display:flex;align-items:center}
.rm-add{width:24px;flex-shrink:0;background:none;border:none;border-left:1px solid var(--bor);color:var(--tx3);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s}
.rm-add:hover{background:var(--sur2);color:var(--blue)}

/* Options modal */
.opt-section{margin-bottom:20px;background:rgba(123,159,249,.03);border:1px solid rgba(123,159,249,.08);border-radius:12px;padding:14px 16px}
.opt-section:last-child{margin-bottom:0}
.opt-section-title{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(123,159,249,.85);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid rgba(123,159,249,.15)}
.opt-sublbl{font-size:11px;color:var(--tx3);margin-top:2px;line-height:1.4}
.opt-btn{padding:5px 12px;border-radius:8px;border:1px solid rgba(123,159,249,.15);background:rgba(123,159,249,.06);color:rgba(123,159,249,.8);font-size:11px;font-weight:600;cursor:pointer;transition:.2s;white-space:nowrap}
.opt-btn:hover{border-color:rgba(123,159,249,.35);background:rgba(123,159,249,.12);color:#a5c0ff}
.opt-btn.on{background:linear-gradient(135deg,rgba(123,159,249,.25),rgba(167,139,250,.25));border-color:rgba(123,159,249,.45);color:#c4b5fd}
.opt-ctrl{display:flex;gap:4px;align-items:center;flex-shrink:0}

/* ─── 8. FILTER DRAWER ──────────────────────────────────────── */
#filter-drawer{position:fixed;top:30px;width:318px;border-radius:0 16px 16px 0;display:flex;flex-direction:column;transform:translateX(-10px);opacity:0;pointer-events:none;transition:transform .25s cubic-bezier(.25,.46,.45,.94),opacity .25s;z-index:500;bottom:12px;border:2px solid transparent;background:linear-gradient(var(--sur),var(--sur)) padding-box,linear-gradient(135deg,#7b9ff9,#a78bfa,#f472b6) border-box}
#filter-drawer.open{transform:translateX(0);opacity:1;pointer-events:auto;z-index:9500}
#filter-drawer-hd{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid rgba(123,159,249,.1);flex-shrink:0;gap:8px;background:rgba(123,159,249,.05)}
#filter-drawer-hd .fd-title{font-family:var(--title);font-size:15px;letter-spacing:1px;flex:1}
#fd-badge{font-size:10px;font-weight:700;background:var(--blue);color:#fff;padding:2px 7px;border-radius:99px;display:none}
#fd-close,.sf-reset-inline{width:28px;height:28px;border-radius:50%;border:1px solid var(--bor);background:var(--sur2);color:var(--tx3);cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:.15s;flex-shrink:0}
#fd-close:hover,.sf-reset-inline:hover{background:var(--red);border-color:var(--red);color:#fff}
.sf-scroll{flex:1;overflow-y:auto;padding:10px 12px;display:flex;flex-direction:column;gap:10px}
.sf-scroll::-webkit-scrollbar{width:3px}
.sf-scroll::-webkit-scrollbar-thumb{background:var(--bor2)}
.sf-group{display:flex;flex-direction:column;gap:5px}
.sf-lbl{font-size:11px;font-weight:700;letter-spacing:1px;color:var(--tx3);text-transform:uppercase}
.sf-input{flex:1;background:var(--sur2);border:1px solid var(--bor);color:var(--tx);font-size:12px;padding:6px 9px;border-radius:6px;width:100%}
.sf-input:focus{outline:none;border-color:var(--blue)}
.sf-reset{width:100%;padding:8px;background:transparent;border:1px solid var(--bor);color:var(--tx3);font-size:13px;font-weight:600;border-radius:6px;cursor:pointer;transition:.15s;margin-top:4px}
.sf-reset:hover{border-color:var(--red);color:var(--red)}
.fchip{display:inline-flex;align-items:center;gap:4px;background:rgba(123,97,255,.05);border:1px solid rgba(123,159,249,.12);color:var(--tx3);font-size:13px;font-weight:600;padding:5px 12px;border-radius:99px;cursor:pointer;transition:.2s;white-space:nowrap;letter-spacing:.1px}
.fchip:hover{border-color:rgba(167,139,250,.4);color:#c4b5fd;background:rgba(123,97,255,.1)}
.fchip.on{background:linear-gradient(180deg,rgba(46,39,92,.96),rgba(32,27,68,.96)) padding-box,linear-gradient(135deg,#7b9ff9,#a78bfa,#f472b6) border-box;border:1px solid transparent;color:#fff;box-shadow:0 0 0 1px rgba(167,139,250,.35),0 0 12px rgba(123,159,249,.28),inset 0 1px 0 rgba(255,255,255,.1)}
[data-theme="dark"] .fchip.on{background:linear-gradient(180deg,rgba(43,37,88,.98),rgba(25,22,56,.98)) padding-box,linear-gradient(135deg,#93c5fd,#a78bfa,#f472b6) border-box;color:#fff;box-shadow:0 0 0 1px rgba(147,197,253,.4),0 0 14px rgba(123,159,249,.3),inset 0 1px 0 rgba(255,255,255,.12)}
.fchip.on span{color:#fff!important;text-shadow:0 1px 3px rgba(0,0,0,.65)}
.fchip-cat{background:color-mix(in srgb,var(--cc,var(--blue)) 10%,var(--sur2));border-color:color-mix(in srgb,var(--cc,var(--blue)) 30%,var(--bor));color:color-mix(in srgb,var(--cc,var(--blue)) 70%,var(--tx2))}
.fchip-cat.on{background:var(--cc,var(--blue));border-color:var(--cc,var(--blue));color:#fff}
.fchip-attr{width:34px;height:34px;padding:0;border-radius:8px;font-size:18px;justify-content:center}
.fchip-attr.on{background:var(--ac,var(--blue));border-color:var(--ac,var(--blue))}
.attr-icon{width:22px;height:22px;object-fit:contain;border-radius:50%}
.fchips{display:flex;flex-wrap:wrap;gap:4px}
.fchips-wrap{display:flex;flex-wrap:wrap;gap:4px}
.fchip-attr-img{padding:4px 3px;display:flex;flex-direction:column;align-items:center;gap:2px;min-width:0;flex:1;border-radius:8px !important}



#f-cat{flex-wrap:nowrap;gap:5px}
#f-cat .fchip-attr-img{flex:1;min-width:0;padding:4px}
#f-attr{flex-wrap:wrap;gap:5px;justify-content:center}
#f-attr .fchip-attr-img{flex:0 0 auto;width:44px;padding:5px 2px}
/* DARK et LIGHT = ligne 1 (2 items larges), les 5 autres = ligne 2 */
#f-attr .fchip-attr-img:nth-child(1),#f-attr .fchip-attr-img:nth-child(2){width:calc(50% - 5px)}
#f-attr .fchip-attr-img:nth-child(3),#f-attr .fchip-attr-img:nth-child(4),#f-attr .fchip-attr-img:nth-child(5),#f-attr .fchip-attr-img:nth-child(6),#f-attr .fchip-attr-img:nth-child(7){width:calc(20% - 5px)}
.ban-select-row{display:flex;gap:6px;align-items:center}
.ban-select-row .sf-lbl-inline{font-size:12px;font-weight:700;color:var(--tx3);width:40px;flex-shrink:0;letter-spacing:.2px}
.ban-select-row select{flex:1;background:var(--sur2);border:1px solid var(--bor);color:var(--tx);font-size:12px;padding:6px 8px;border-radius:6px;cursor:pointer}
.ban-select-row select:focus{outline:none;border-color:var(--blue)}
.sh-mini-group{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}
.sh-mini-lbl{font-size:11px;font-weight:700;color:var(--tx3);letter-spacing:.5px;text-transform:uppercase}
.sh-mini-sel,.sh-mini-inp{background:var(--sur2);border:1px solid var(--bor);color:var(--tx);font-size:12px;padding:5px 7px;border-radius:6px;width:100%;-webkit-appearance:none}
.sh-mini-sel:focus,.sh-mini-inp:focus{outline:none;border-color:var(--blue)}
.sh-mini-inp::placeholder{color:var(--tx3)}
.sh-reset{width:28px;height:28px;flex-shrink:0;background:transparent;border:1px solid var(--bor);color:var(--tx3);border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;align-self:flex-end;transition:.15s}
.sh-reset:hover{border-color:var(--red);color:var(--red)}

/* ─── DARK MODE OVERRIDES CONSOLIDÉS ────────────────────────── */
/* Filter drawer — textes */
[data-theme="dark"] .sf-lbl,
[data-theme="dark"] .ban-select-row .sf-lbl-inline,
[data-theme="dark"] .sh-mini-lbl { color: var(--tx); }
[data-theme="dark"] .sf-input,
[data-theme="dark"] .sh-mini-sel,
[data-theme="dark"] .sh-mini-inp,
[data-theme="dark"] .ban-select-row select { color: var(--tx); background: var(--sur2); }
[data-theme="dark"] .sf-reset { color: var(--tx); }
[data-theme="dark"] .fchip:not(.on) { color: var(--tx); }
[data-theme="dark"] #filter-drawer-hd .fd-title { color: var(--tx); }
/* Format pills */
[data-theme="dark"] .fmt-pill:not(.on) { color: var(--tx); }

/* ─── 9. MODALS ─────────────────────────────────────────────── */
.modal-bg{position:fixed;inset:0;z-index:9000;background:rgba(5,4,15,.82);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .15s}
.modal-bg.open{opacity:1;pointer-events:all}
.modal-bg.open .modal{transform:translateY(0) scale(1);opacity:1}
.modal{background:var(--sur);border:1px solid rgba(123,159,249,.15);border-radius:18px;width:min(96vw,1100px);max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 60px rgba(0,0,0,.6);overflow:hidden;transform:translateY(12px) scale(.98);opacity:0;transition:transform .18s cubic-bezier(.22,1,.36,1),opacity .15s;will-change:transform,opacity}
.modal-hd{display:flex;align-items:center;padding:18px 24px;border-bottom:1px solid rgba(123,159,249,.1);flex-shrink:0;gap:12px;background:rgba(123,159,249,.04)}
.modal-title{font-family:var(--title);font-size:20px;letter-spacing:2px;flex:1;background:linear-gradient(135deg,var(--tx),rgba(123,159,249,.9));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.modal-close{width:32px;height:32px;border-radius:50%;border:1px solid rgba(123,159,249,.15);background:rgba(123,159,249,.06);color:var(--tx3);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s}
.modal-close:hover{background:rgba(248,113,113,.2);border-color:rgba(248,113,113,.4);color:#f87171;transform:scale(1.1)}
.modal-body{flex:1;overflow-y:auto;padding:20px}
.modal-body::-webkit-scrollbar{width:4px}
.modal-body::-webkit-scrollbar-thumb{background:var(--bor2)}
.proba-setup-modal{border-radius:16px}
.proba-setup-body{display:flex;flex-direction:column;gap:16px;padding:18px}
.proba-setup-intro{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;border-bottom:1px solid rgba(123,159,249,.12);padding-bottom:14px}
.proba-setup-kicker{font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);margin-bottom:5px}
.proba-setup-intro h2{font-family:var(--ui);font-size:20px;line-height:1.2;letter-spacing:0;color:var(--tx);font-weight:800;margin:0}
.proba-setup-open-report,.proba-setup-footer button{border:1px solid rgba(123,159,249,.25);background:rgba(123,159,249,.08);color:var(--tx2);border-radius:8px;padding:8px 12px;font-size:12px;font-weight:750;white-space:nowrap}
.proba-setup-open-report:hover,.proba-setup-footer button:hover{border-color:rgba(123,159,249,.5);color:var(--tx);background:rgba(123,159,249,.14)}
.proba-setup-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.proba-setup-step{display:flex;align-items:center;gap:10px;text-align:left;border:1px solid var(--bor);background:var(--sur2);border-radius:8px;padding:10px;min-width:0;color:var(--tx2)}
.proba-setup-step.is-active{border-color:rgba(123,159,249,.55);background:rgba(123,159,249,.12);color:var(--tx)}
.proba-setup-step-index{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:7px;background:rgba(123,159,249,.13);color:var(--blue);font-size:12px;font-weight:900;flex-shrink:0}
.proba-setup-step-copy{display:flex;flex-direction:column;gap:2px;min-width:0}
.proba-setup-step-copy strong{font-size:12px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.proba-setup-step-copy small{font-size:11px;color:var(--tx3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.proba-setup-panel{display:grid;grid-template-columns:minmax(0,1fr) 190px;gap:16px;align-items:stretch;background:var(--sur2);border:1px solid var(--bor);border-radius:10px;padding:16px}
.proba-setup-step-label{font-size:10px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:var(--tx3);margin-bottom:7px}
.proba-setup-panel h3{font-size:18px;line-height:1.2;font-weight:850;color:var(--tx);margin:0 0 8px}
.proba-setup-panel p{font-size:13px;line-height:1.6;color:var(--tx2);max-width:520px;margin:0 0 14px}
.proba-setup-status{display:flex;flex-wrap:wrap;gap:7px}
.proba-setup-status span{font-size:11px;font-weight:800;color:var(--tx2);background:var(--sur3);border:1px solid var(--bor);border-radius:999px;padding:5px 8px}
.proba-setup-actions{display:flex;flex-direction:column;gap:8px}
.proba-setup-primary,.proba-setup-secondary{width:100%;border-radius:8px;padding:10px 12px;font-size:12px;font-weight:850}
.proba-setup-primary{border:1px solid rgba(123,159,249,.45);background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff}
.proba-setup-primary:hover{filter:brightness(1.06)}
.proba-setup-secondary{border:1px solid var(--bor);background:var(--sur3);color:var(--tx2)}
.proba-setup-secondary:hover:not(:disabled){border-color:rgba(123,159,249,.35);color:var(--tx)}
.proba-setup-secondary:disabled{opacity:.45;cursor:not-allowed}
.proba-setup-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--tx3);font-size:12px;border-top:1px solid rgba(123,159,249,.1);padding-top:14px}
.deck-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));grid-auto-rows:max-content;align-content:start;gap:12px;margin-bottom:16px}
.deck-card-saved{background:var(--sur);border:1px solid rgba(123,159,249,.12);border-radius:14px;cursor:pointer;transition:.25s;position:relative;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 2px 12px rgba(0,0,0,.25)}
.deck-card-saved:hover{border-color:rgba(123,159,249,.35);box-shadow:0 8px 28px rgba(123,159,249,.12);transform:translateY(-3px)}
.dcs-cover{height:200px;background:linear-gradient(135deg,rgba(123,159,249,.08),rgba(167,139,250,.08));position:relative;background-size:cover;background-position:center center;background-repeat:no-repeat;flex-shrink:0}
.dcs-cover-empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:32px;opacity:.2}
.dcs-cover-btn{position:absolute;bottom:5px;right:5px;background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.25);color:#fff;border-radius:5px;font-size:10px;padding:2px 6px;cursor:pointer;opacity:0;transition:.15s}
.deck-card-saved:hover .dcs-cover-btn{opacity:1}
.dcs-body{padding:9px 11px 10px;display:flex;flex-direction:column;gap:3px;align-items:center;text-align:center;flex-shrink:0}
.dcs-name-wrap{position:relative;width:100%;display:flex;justify-content:center;align-items:center;padding:0 20px}
.dcs-name{font-family:var(--title);font-size:17px;letter-spacing:1px;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;white-space:normal;text-align:center;width:100%;background:linear-gradient(135deg,var(--tx),rgba(123,159,249,.9));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.dcs-rename-btn{position:absolute;right:0;background:none;border:none;color:var(--tx3);font-size:11px;cursor:pointer;padding:1px 2px;opacity:0;transition:.15s;line-height:1}
.deck-card-saved:hover .dcs-rename-btn{opacity:1}
.dcs-rename-btn:hover{color:var(--blue)}
.dcs-archetype{font-size:9px;font-weight:700;letter-spacing:.8px;color:var(--blue);text-transform:uppercase;margin-top:-1px}
.dcs-info{font-size:10px;color:var(--tx2);line-height:1.7;margin-top:1px}
.dcs-price{font-family:var(--title);font-size:13px;color:var(--green);margin-top:2px}
.dcs-del{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:rgba(0,0,0,.5);color:#fff;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s;opacity:0}
.deck-card-saved:hover .dcs-del{opacity:1}
.dcs-del:hover{background:var(--red);border-color:var(--red)}
.dcs-folder-btn{position:absolute;bottom:6px;right:6px;width:22px;height:22px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:rgba(0,0,0,.5);color:#fff;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s;opacity:0}
.deck-card-saved:hover .dcs-folder-btn{opacity:1}
.dcs-folder-btn:hover{background:rgba(123,159,249,.5);border-color:rgba(123,159,249,.8)}
.dcs-drag-handle{position:absolute;top:6px;left:34px;color:rgba(255,255,255,.7);font-size:14px;cursor:grab;opacity:0;transition:.15s;line-height:1;text-shadow:0 1px 3px rgba(0,0,0,.5)}
.deck-card-saved:hover .dcs-drag-handle{opacity:1}
.dcs-dragging{opacity:.4;transform:scale(.97)}
.dcs-over{outline:2px dashed var(--blue);outline-offset:2px}
.dcs-fav-btn{position:absolute;top:6px;left:6px;background:rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.2);border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:13px;cursor:pointer;transition:.15s;line-height:1;padding:0;opacity:.6}
.deck-card-saved:hover .dcs-fav-btn{opacity:1}
.dcs-fav-btn.on{opacity:1;background:rgba(236,72,153,.55);border-color:rgba(236,72,153,.7)}
.dcs-fav{box-shadow:inset 0 0 0 2px rgba(236,72,153,.35)}
.dcs-visibility-badge{position:absolute;bottom:6px;left:6px;font-size:10px;font-weight:700;padding:2px 7px;border-radius:99px;border:1px solid rgba(255,255,255,.15);background:rgba(0,0,0,.7);color:rgba(255,255,255,.7);pointer-events:none;line-height:1.4}
.dcs-visibility-badge.pub{background:rgba(10,60,30,.75);border-color:rgba(34,197,94,.6);color:#4ade80;text-shadow:0 0 6px rgba(34,197,94,.5)}
.dcr-cover .dcs-visibility-badge{font-size:9px;padding:1px 5px}
.dcs-format-badge{font-size:9px;font-weight:700;letter-spacing:.8px;color:var(--tx3);background:var(--sur3);border:1px solid var(--bor);border-radius:4px;padding:1px 6px;display:inline-block}
/* Filtres */
.deck-filters{display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.deck-filter-btn{font-size:13px;font-weight:600;padding:5px 13px;border-radius:20px;border:1px solid rgba(123,159,249,.12);background:rgba(123,159,249,.05);color:var(--tx3);cursor:pointer;transition:.2s;white-space:nowrap}
.deck-filter-btn:hover{border-color:rgba(123,159,249,.3);color:#a5c0ff;background:rgba(123,159,249,.1)}
.deck-filter-btn.on{background:linear-gradient(135deg,rgba(123,159,249,.25),rgba(167,139,250,.25));border-color:rgba(123,159,249,.45);color:#c4b5fd}
.deck-filter-sep{width:1px;height:18px;background:var(--bor);margin:0 3px;flex-shrink:0}

/* ─── MODAL MES DECKS : layout responsive ─── */
.modal-decks-body{display:flex;padding:0;gap:0;overflow:hidden;min-height:0;flex:1}
.deck-folder-sidebar{width:220px;flex-shrink:0;border-right:1px solid var(--bor);overflow-y:auto;display:flex;flex-direction:column}
.deck-main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;padding:12px 14px 14px;gap:10px}
.deck-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.deck-toolbar .deck-filters{flex:1;min-width:0}
.deck-sidebar-toggle{display:none;width:34px;height:32px;border-radius:8px;border:1px solid rgba(123,159,249,.2);background:rgba(123,159,249,.08);color:var(--tx2);font-size:14px;cursor:pointer;align-items:center;justify-content:center;flex-shrink:0}
.deck-sidebar-toggle:hover{border-color:rgba(123,159,249,.45);color:#a5c0ff}

/* ─── TOGGLE VUE CARTES / LISTE ─── */
.deck-view-switch{display:inline-flex;flex-shrink:0;border:1px solid rgba(123,159,249,.15);border-radius:8px;overflow:hidden;background:rgba(123,159,249,.05)}
.deck-view-btn{width:32px;height:28px;border:none;background:transparent;color:var(--tx3);font-size:16px;line-height:1;cursor:pointer;transition:.15s;display:flex;align-items:center;justify-content:center}
.deck-view-btn + .deck-view-btn{border-left:1px solid rgba(123,159,249,.15)}
.deck-view-btn:hover{background:rgba(123,159,249,.1);color:#a5c0ff}
.deck-view-btn.on{background:linear-gradient(135deg,rgba(123,159,249,.3),rgba(167,139,250,.3));color:#c4b5fd}

#decks-grid{overflow-y:auto;flex:1;min-height:0}
.deck-modal-actions{display:flex;justify-content:center;gap:10px;padding-top:4px;flex-shrink:0;flex-wrap:wrap}
.deck-modal-actions .tb{padding:8px 28px}

/* ─── VUE LISTE : rangées horizontales ─── */
.deck-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.deck-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--sur);border:1px solid rgba(123,159,249,.12);border-radius:12px;cursor:pointer;transition:.18s;position:relative;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.deck-row:hover{border-color:rgba(123,159,249,.35);transform:translateY(-1px);box-shadow:0 6px 18px rgba(123,159,249,.12)}
.dcr-fav{box-shadow:inset 0 0 0 2px rgba(236,72,153,.35)}
.dcr-dragging{opacity:.4;transform:scale(.98)}
.dcr-over{outline:2px dashed var(--blue);outline-offset:2px}
.dcr-cover{width:64px;height:64px;border-radius:8px;background:linear-gradient(135deg,rgba(123,159,249,.08),rgba(167,139,250,.08));background-size:cover;background-position:center;background-repeat:no-repeat;flex-shrink:0;position:relative;overflow:hidden}
.dcr-cover-empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:22px;opacity:.25}
.dcr-fav-btn{background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.15);border-radius:50%;width:26px;height:26px;display:flex;align-items:center;justify-content:center;font-size:13px;cursor:pointer;opacity:.65;transition:.15s;line-height:1;padding:0;flex-shrink:0}
.dcr-fav-btn:hover{opacity:1}
.dcr-fav-btn.on{opacity:1;background:rgba(236,72,153,.35);border-color:rgba(236,72,153,.6)}
.dcr-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.dcr-title-row{display:flex;align-items:center;gap:6px;min-width:0}
.dcr-name{font-family:var(--title);font-size:15px;letter-spacing:.8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background:linear-gradient(135deg,var(--tx),rgba(123,159,249,.9));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;min-width:0}
.dcr-rename-btn{background:none;border:none;color:var(--tx3);font-size:11px;cursor:pointer;padding:1px 3px;opacity:0;transition:.15s;flex-shrink:0;line-height:1}
.deck-row:hover .dcr-rename-btn{opacity:1}
.dcr-rename-btn:hover{color:var(--blue)}
.dcr-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.dcr-archetype{font-size:9px;font-weight:700;letter-spacing:.8px;color:var(--blue);text-transform:uppercase}
.dcr-format-badge{font-size:9px;font-weight:700;letter-spacing:.8px;color:var(--tx3);background:var(--sur3);border:1px solid var(--bor);border-radius:4px;padding:1px 6px}
.dcr-stats{display:flex;gap:14px;flex-shrink:0}
.dcr-stat{display:flex;flex-direction:column;align-items:center;line-height:1.2;min-width:36px}
.dcr-stat b{font-family:var(--title);font-size:14px;color:var(--tx);font-weight:700}
.dcr-stat span{font-size:9px;color:var(--tx3);letter-spacing:.5px;text-transform:uppercase;margin-top:1px}
.dcr-date{font-size:10px;color:var(--tx3);flex-shrink:0;white-space:nowrap;min-width:70px;text-align:center}
.dcr-price{font-family:var(--title);font-size:13px;color:var(--green);flex-shrink:0;white-space:nowrap;min-width:70px;text-align:right}
.dcr-tools{display:flex;gap:4px;flex-shrink:0;align-items:center}
.dcr-cover-btn,.dcr-folder-btn{background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.15);color:var(--tx3);width:26px;height:26px;border-radius:6px;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:.15s;flex-shrink:0;padding:0}
.deck-row:hover .dcr-cover-btn,.deck-row:hover .dcr-folder-btn{opacity:1}
.dcr-cover-btn:hover{color:#a5c0ff;border-color:rgba(123,159,249,.4)}
.dcr-folder-btn:hover{color:#a5c0ff;border-color:rgba(123,159,249,.4)}
.dcr-del{width:26px;height:26px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:rgba(0,0,0,.5);color:#fff;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:0;transition:.15s;padding:0}
.deck-row:hover .dcr-del{opacity:1}
.dcr-del:hover{background:var(--red);border-color:var(--red)}

/* ─── MODAL MES DECKS : breakpoints ─── */
@media(max-width:900px){
  .modal-decks-body{flex-direction:column}
  .deck-folder-sidebar{width:100%;max-height:0;overflow:hidden;border-right:none;border-bottom:1px solid var(--bor);transition:max-height .22s ease}
  .deck-folder-sidebar.open{max-height:220px;overflow-y:auto}
  .deck-sidebar-toggle{display:flex}
  .dcr-date{display:none}
  .dcr-stats{gap:10px}
  .bfs-actions{opacity:1}
  .bfs-item{padding:8px 10px}
  .bfs-act-btn{padding:4px 6px;font-size:11px}
  /* Filtres : barre scroll horizontale */
  .deck-toolbar{flex-wrap:nowrap;gap:6px}
  .deck-toolbar .deck-filters{flex:1;min-width:0;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}
  .deck-toolbar .deck-filters::-webkit-scrollbar{display:none}
  .deck-filter-sep{display:none}
  .deck-filter-btn{white-space:nowrap;flex-shrink:0}
}
@media(max-width:640px){
  .deck-main-area{padding:10px 10px 12px;gap:8px}
  .deck-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}
  .dcs-cover{height:160px}
  .dcs-name{font-size:14px;letter-spacing:.5px}
  .dcs-body{padding:7px 9px 8px}
  /* Liste : empilement partiel */
  .deck-row{flex-wrap:wrap;padding:9px 10px;gap:8px}
  .dcr-body{flex:1 1 calc(100% - 110px);min-width:0}
  .dcr-stats{order:5;flex:1 1 100%;justify-content:flex-start;gap:18px;padding-top:6px;border-top:1px dashed rgba(123,159,249,.12)}
  .dcr-price{order:4;min-width:0;margin-left:auto}
  .dcr-tools{order:6;margin-left:auto}
  .dcr-cover-btn,.dcr-del,.dcr-rename-btn,.dcr-folder-btn{opacity:1}
  .dcs-del,.dcs-folder-btn{opacity:1}
  .deck-modal-actions .tb{padding:8px 16px;font-size:12px}
}
@media(max-width:420px){
  .deck-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:6px}
  .dcs-cover{height:140px}
  .dcs-name{font-size:13px}
  .dcr-cover{width:52px;height:52px}
  .dcr-name{font-size:13px}
  .dcr-stats{gap:12px}
  .dcr-stat{min-width:30px}
  .dcr-stat b{font-size:12px}
}
/* ─── BOUTON ··· ACTIONS MOBILE ─── */
.dcs-more-btn,.dcr-more-btn{display:none}
@media(hover:none){
  .dcs-folder-btn,.dcs-del,.dcs-rename-btn,.dcs-cover-btn,.dcs-drag-handle{display:none!important}
  .dcr-folder-btn,.dcr-cover-btn,.dcr-del,.dcr-rename-btn{display:none!important}
  .dcs-more-btn{display:flex;position:absolute;top:6px;right:6px;width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.4);background:rgba(0,0,0,.6);color:#fff;font-size:15px;font-weight:900;letter-spacing:1px;align-items:center;justify-content:center;cursor:pointer;z-index:2;-webkit-tap-highlight-color:transparent}
  .dcr-more-btn{display:flex;width:34px;height:34px;border-radius:9px;border:1px solid rgba(123,159,249,.28);background:rgba(123,159,249,.1);color:var(--tx2);font-size:15px;font-weight:900;letter-spacing:1px;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;padding:0;-webkit-tap-highlight-color:transparent}
}
/* ─── DECK ACTION BOTTOM SHEET ─── */
.deck-sheet-bg{position:fixed;inset:0;z-index:100000;background:rgba(5,4,15,.62);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);animation:_shBg .18s ease}
@keyframes _shBg{from{opacity:0}to{opacity:1}}
.deck-sheet{position:fixed;left:0;right:0;bottom:0;z-index:100001;background:var(--sur);border-radius:20px 20px 0 0;border:1px solid rgba(123,159,249,.2);border-bottom:none;padding:0 0 env(safe-area-inset-bottom,12px);box-shadow:0 -10px 48px rgba(0,0,0,.5);animation:_shIn .22s cubic-bezier(.22,1,.36,1);max-height:82vh;overflow-y:auto}
@keyframes _shIn{from{transform:translateY(100%)}to{transform:translateY(0)}}
.deck-sheet-handle{width:38px;height:4px;background:rgba(123,159,249,.22);border-radius:99px;margin:12px auto 2px}
.deck-sheet-title{font-size:12px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--tx2);padding:8px 20px 12px;border-bottom:1px solid rgba(123,159,249,.09);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.deck-sheet-item{display:flex;align-items:center;gap:14px;padding:15px 20px;font-size:14px;font-weight:600;color:var(--tx);cursor:pointer;transition:background .12s;user-select:none;-webkit-tap-highlight-color:transparent}
.deck-sheet-item:not(:last-child){border-bottom:1px solid rgba(123,159,249,.06)}
.deck-sheet-item:active{background:rgba(123,159,249,.09)}
.deck-sheet-item-icon{font-size:19px;width:30px;text-align:center;flex-shrink:0}
.deck-sheet-item.danger{color:var(--red)}
.deck-sheet-item.active{color:#a5c0ff}
.deck-sheet-item-check{margin-left:auto;color:#a5c0ff;font-size:16px;font-weight:700}
.deck-sheet-back{display:flex;align-items:center;gap:8px;padding:11px 20px;font-size:12px;font-weight:700;letter-spacing:.5px;color:var(--tx3);cursor:pointer;border-bottom:1px solid rgba(123,159,249,.09);user-select:none;-webkit-tap-highlight-color:transparent}
.deck-sheet-back:active{background:rgba(123,159,249,.07)}
.bfs-sheet-act{background:none;border:none;font-size:16px;cursor:pointer;padding:6px 8px;border-radius:7px;line-height:1;-webkit-tap-highlight-color:transparent;flex-shrink:0;color:var(--tx3)}
.bfs-sheet-act:active{background:rgba(123,159,249,.1);color:#a5c0ff}
.bfs-sheet-act.del:active{background:rgba(248,113,113,.1);color:#f87171}
/* Builder folder sidebar */
.bfs-title{font-size:9px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--tx2);padding:10px 10px 4px}
.bfs-item{display:flex;align-items:center;gap:4px;padding:6px 10px;font-size:12px;font-weight:600;color:var(--tx3);cursor:pointer;transition:.15s;overflow:hidden;user-select:none}
.bfs-item:hover{background:rgba(123,159,249,.08);color:var(--tx)}
.bfs-item.active{background:rgba(123,159,249,.12);color:#a5c0ff}
.bfs-item.bfs-drag-over{background:rgba(123,159,249,.22);outline:2px dashed rgba(123,159,249,.5);outline-offset:-2px}
.bfs-count{margin-left:auto;flex-shrink:0;font-size:9px;font-weight:700;background:rgba(123,159,249,.15);color:#7b9ff9;padding:1px 5px;border-radius:99px}
.bfs-new-btn{display:flex;align-items:center;gap:4px;margin:6px 8px 8px;padding:5px 8px;border-radius:7px;border:1px dashed rgba(123,159,249,.2);background:none;color:var(--tx3);font-size:10px;font-weight:600;cursor:pointer;width:calc(100% - 16px);font-family:inherit;transition:.15s}
.bfs-new-btn:hover{border-color:rgba(123,159,249,.4);color:#7b9ff9;background:rgba(123,159,249,.05)}
.bfs-rename-input{background:rgba(123,159,249,.08);border:1px solid rgba(123,159,249,.4);border-radius:4px;color:var(--tx);font-size:11px;padding:1px 5px;outline:none;font-family:inherit}
.bfs-actions{display:flex;gap:1px;opacity:0;flex-shrink:0;margin-left:2px;transition:.1s}
.bfs-item:hover .bfs-actions{opacity:1}
.bfs-act-btn{background:none;border:none;cursor:pointer;color:var(--tx3);font-size:9px;padding:1px 3px;border-radius:3px;transition:.1s;line-height:1;font-family:inherit}
.bfs-act-btn:hover{color:#7b9ff9;background:rgba(123,159,249,.12)}
.bfs-act-btn.danger:hover{color:#f87171;background:rgba(248,113,113,.12)}
/* Deck folder picker dropdown */
.dfp-item{padding:9px 14px;font-size:12px;font-weight:600;color:var(--tx3);cursor:pointer;transition:.12s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dfp-item:hover{background:rgba(123,159,249,.1);color:var(--tx)}
.dfp-item.dfp-active{color:#a5c0ff;background:rgba(123,159,249,.12)}
.opt-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid rgba(123,159,249,.06)}
.opt-row:last-child{border-bottom:none}
.opt-lbl{flex:1;font-size:13px;color:var(--tx)}
.opt-sublbl{font-size:11px;color:var(--tx3);margin-top:2px}
.opt-toggle{width:40px;height:22px;border-radius:11px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.1);cursor:pointer;position:relative;transition:.25s;flex-shrink:0}
.opt-toggle::after{content:'';position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:rgba(255,255,255,.6);transition:.25s;box-shadow:0 1px 4px rgba(0,0,0,.3)}
.opt-toggle.on{background:linear-gradient(135deg,#7b9ff9,#a78bfa);border-color:transparent;box-shadow:0 0 12px rgba(123,159,249,.4)}
.opt-toggle.on::after{left:21px;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.3)}

/* ─── Tag Mode ─── */
@keyframes tag-mode-btn-glow {
  0%   { box-shadow: 0 0 0 1px #7b9ff9, 0 0 10px rgba(123,159,249,.3); }
  33%  { box-shadow: 0 0 0 1px #a78bfa, 0 0 10px rgba(167,139,250,.35); }
  66%  { box-shadow: 0 0 0 1px #f472b6, 0 0 10px rgba(244,114,182,.3); }
  100% { box-shadow: 0 0 0 1px #7b9ff9, 0 0 10px rgba(123,159,249,.3); }
}
@keyframes tag-icon-pulse{0%,100%{filter:drop-shadow(0 0 3px #a78bfa) drop-shadow(0 0 6px #f472b6)}50%{filter:drop-shadow(0 0 6px #7b9ff9) drop-shadow(0 0 12px #a78bfa)}}

/* ── Tag mode button ── */
.tag-mode-btn{
  margin-left:auto;display:flex;align-items:center;gap:6px;
  padding:5px 12px;border-radius:20px;font-size:11px;font-weight:700;
  cursor:pointer;white-space:nowrap;font-family:inherit;
  transition:.2s;letter-spacing:.3px;
  background:rgba(123,97,255,.06);
  border:1px solid rgba(123,159,249,.15);
  color:var(--tx3);
  position:relative;
}
.tag-mode-btn:hover{
  background:rgba(123,97,255,.12);
  border-color:rgba(167,139,250,.35);
  color:#c4b5fd;
}
.tag-mode-btn.on{
  isolation:isolate;overflow:hidden;
  background:transparent;border:none;
  color:#e0d0ff;
}
.tag-mode-btn.on::before{
  content:'';position:absolute;width:300px;height:300px;
  top:50%;left:50%;
  transform:translate(-50%,-50%) rotate(0deg);
  background:conic-gradient(from 0deg,#7b9ff9,#a78bfa,#f472b6,#7b9ff9);
  animation:prism-border-spin 2.5s linear infinite;
  z-index:-2;
}
.tag-mode-btn.on::after{
  content:'';position:absolute;inset:1.5px;
  background:linear-gradient(135deg,rgba(123,97,255,.18),rgba(244,114,182,.1));
  border-radius:18px;z-index:-1;
}
.tag-mode-btn.on .tag-mode-icon{animation:tag-icon-pulse 2s ease-in-out infinite}
.tag-mode-icon{width:14px;height:14px;object-fit:contain;flex-shrink:0;transition:filter .2s}
@keyframes tag-deck-glow {
  0%   { box-shadow: inset 0 0 0 3px #7b9ff9aa, 0 0 20px #7b9ff944; }
  33%  { box-shadow: inset 0 0 0 3px #a78bfaaa, 0 0 20px #a78bfa44; }
  66%  { box-shadow: inset 0 0 0 3px #f472b6aa, 0 0 20px #f472b644; }
  100% { box-shadow: inset 0 0 0 3px #7b9ff9aa, 0 0 20px #7b9ff944; }
}
#pnl-deck.tag-mode-active {
  animation: tag-deck-glow 2s ease-in-out infinite;
}
/* Keyboard shortcut capture button */
.opt-btn.kbs-capturing {
  background: rgba(244,114,182,.15);
  border-color: rgba(244,114,182,.5);
  color: #f472b6;
  animation: tag-mode-btn-glow .8s ease-in-out infinite;
}

/* ─── 10. STATS & SIMULATEUR ────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.stat-chart-box{background:rgba(123,159,249,.04);border:1px solid rgba(123,159,249,.1);border-radius:14px;padding:18px}
.stat-chart-title{font-size:11px;font-weight:700;letter-spacing:2px;color:rgba(123,159,249,.9);text-transform:uppercase;margin-bottom:14px}
.stat-chart-wrap{height:220px;position:relative}
.stat-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.stat-bar-lbl{font-size:14px;color:var(--tx2);width:100px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stat-bar-track{flex:1;height:11px;background:var(--sur3);border-radius:4px;overflow:hidden}
.stat-bar-fill{height:100%;border-radius:4px;transition:width .4s}
.stat-bar-cnt{font-size:13px;font-weight:700;color:var(--tx3);width:30px;text-align:right;flex-shrink:0}
.stats-summary{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.stats-pill{background:rgba(123,159,249,.05);border:1px solid rgba(123,159,249,.12);border-radius:12px;padding:14px 20px;text-align:center;min-width:100px}
.stats-pill-n{font-family:var(--title);font-size:28px;background:linear-gradient(135deg,#7b9ff9,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stats-pill-l{font-size:11px;color:var(--tx3);letter-spacing:.8px;text-transform:uppercase}
.sim-hand{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:20px}
.sim-card{width:96px;border-radius:10px;overflow:hidden;border:2px solid rgba(123,159,249,.15);cursor:pointer;transition:transform .2s cubic-bezier(.22,1,.36,1),box-shadow .2s,border-color .18s;flex-shrink:0;position:relative;box-shadow:0 4px 16px rgba(0,0,0,.3)}
.sim-card:hover{border-color:rgba(123,159,249,.5);transform:translateY(-8px) scale(1.08);box-shadow:0 16px 36px rgba(0,0,0,.5),0 0 0 1px rgba(123,159,249,.2);z-index:10}
.sim-card img{width:100%;display:block;aspect-ratio:421/614;object-fit:contain;background:var(--sur3)}
.sim-card-sel{border-color:rgba(123,159,249,.8) !important;transform:translateY(-8px);box-shadow:0 0 20px rgba(123,159,249,.35),0 8px 24px rgba(0,0,0,.4)}
.sim-rest{display:flex;gap:5px;flex-wrap:wrap;justify-content:center}
.sim-mini{width:52px;border-radius:6px;overflow:hidden;border:1px solid rgba(123,159,249,.12);opacity:.5;transition:transform .2s cubic-bezier(.22,1,.36,1),opacity .18s,border-color .18s;cursor:pointer;flex-shrink:0}
.sim-mini:hover{opacity:1;border-color:rgba(123,159,249,.4);transform:scale(1.12);z-index:5;box-shadow:0 4px 12px rgba(0,0,0,.3)}
.sim-mini img{width:100%;display:block;aspect-ratio:421/614;object-fit:contain;background:var(--sur3)}
.sim-mini-swap{opacity:.75;border-color:var(--blue);cursor:crosshair;transition:.15s}
.sim-mini-swap:hover{opacity:1;border-color:var(--blue);transform:scale(1.08);box-shadow:0 0 8px color-mix(in srgb,var(--blue) 40%,transparent)}
.sim-btns{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}
.sim-btn{padding:9px 20px;border-radius:8px;border:1px solid var(--bor);background:var(--sur2);color:var(--tx);font-size:12px;font-weight:600;cursor:pointer;transition:.18s;white-space:nowrap}
.sim-btn:hover,.sim-btn.prim{background:var(--blue);border-color:var(--blue);color:#fff}
.sim-btn.danger{border-color:var(--red);color:var(--red)}
.sim-btn.danger:hover{background:var(--red);color:#fff}
.sim-info{text-align:center;font-size:12px;color:var(--tx3);margin-top:8px}
.sim-tabs{display:flex;gap:0;margin-bottom:16px;border-bottom:1px solid rgba(123,159,249,.15)}
.sim-tab{flex:1;padding:9px 12px;border:none;background:transparent;color:var(--tx3);font-size:12px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;cursor:pointer;border-bottom:2px solid transparent;transition:.15s;margin-bottom:-1px}
.sim-tab:hover{color:var(--tx)}
.sim-tab.active{color:var(--blue);border-bottom-color:var(--blue)}
.sim-freq-info{text-align:center;font-size:11px;color:var(--tx3);margin-bottom:12px;letter-spacing:.4px}
.sim-freq-header{display:grid;grid-template-columns:40px 1fr 1fr 1fr;gap:8px;padding:6px 10px;border-bottom:1px solid rgba(123,159,249,.12);font-size:10px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--tx3)}
.sim-freq-list{display:flex;flex-direction:column;gap:0}
.sim-freq-row{display:grid;grid-template-columns:40px 1fr 1fr 1fr;gap:8px;align-items:center;padding:7px 10px;border-bottom:1px solid rgba(123,159,249,.06);transition:background .12s}
.sim-freq-row:hover{background:rgba(123,159,249,.04)}
.sim-freq-img{width:40px;border-radius:5px;aspect-ratio:421/614;object-fit:contain;background:var(--sur3)}
.sim-freq-name{display:flex;flex-direction:column;gap:3px;min-width:0}
.sim-freq-nm{font-size:12px;font-weight:600;color:var(--tx);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sim-freq-copies{font-size:10px;color:var(--tx3);font-weight:700}
.sim-freq-col-stat{display:flex;flex-direction:column;gap:3px}
.sim-freq-col-card,.sim-freq-col-name{} /* placeholders for header alignment */
.sim-freq-nums{display:flex;align-items:baseline;gap:4px}
.sim-freq-n{font-size:13px;font-weight:800}
.sim-freq-denom{font-size:10px;color:var(--tx3)}
.sim-freq-bar-wrap{height:3px;background:var(--sur3);border-radius:2px;overflow:hidden}
.sim-freq-bar{height:100%;border-radius:2px;transition:width .3s}
.sim-freq-pct{font-size:10px;font-weight:700;color:var(--tx3)}

/* ─── 11. TOOLTIPS & TOASTS ─────────────────────────────────── */
#card-tooltip{display:none;position:fixed;z-index:9999;pointer-events:none;width:300px;border-radius:16px;overflow:hidden;font-family:'Outfit',sans-serif}
#card-tooltip.visible{display:block}
#ygo-toast{position:fixed;bottom:48px;left:50%;transform:translateX(-50%) translateY(20px);background:rgba(15,13,25,.97);border:1px solid rgba(123,159,249,.2);color:var(--tx);font-size:12px;font-weight:600;padding:10px 20px;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.5);z-index:9999;opacity:0;pointer-events:none;white-space:nowrap;transition:opacity .25s,transform .25s;letter-spacing:.2px}
#ygo-toast.toast-in{opacity:1;transform:translateX(-50%) translateY(0)}
#ygo-toast.toast-out{opacity:0;transform:translateX(-50%) translateY(20px)}

/* ─── 12. TAGS & BANLIST ────────────────────────────────────── */
#tag-menu{position:fixed;background:var(--sur);border:1px solid var(--bor);border-radius:8px;z-index:9999;box-shadow:0 8px 24px rgba(0,0,0,.2);min-width:160px;overflow:hidden;display:none}
#tag-menu.open{display:block}
.tag-menu-item{padding:8px 14px;font-size:12px;font-weight:600;cursor:pointer;transition:.12s;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--bor)}
.tag-menu-item:last-child{border-bottom:none}
.tag-menu-item:hover{background:var(--sur2)}
.tag-menu-item.active{color:var(--blue)}
.dc-dp-badge{background:#7c3aed!important;color:#fff!important;font-size:8px!important;width:auto!important;padding:0 4px!important;border-radius:8px!important;min-width:16px!important}
.dc-ban-badge{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;font-size:10px;font-weight:900;display:flex;align-items:center;justify-content:center;line-height:1;pointer-events:none;z-index:3;border:1.5px solid rgba(255,255,255,.8)}
.dc-ban-badge.banned{background:#dc2626;color:#fff;font-size:9px}
.dc-ban-badge.limited{background:#ea580c;color:#fff;font-size:11px;font-weight:900}
.dc-ban-badge.semi{background:#ca8a04;color:#fff;font-size:11px;font-weight:900}

/* ─── 13. VUE DÉTAIL CARTE (ex-lightbox) ────────────────────── */
/* Backdrop prismatique : flou + nuance subtile des couleurs signature */
#card-lightbox{position:fixed;inset:0;background:radial-gradient(ellipse at 30% 20%,rgba(123,159,249,.10),transparent 60%),radial-gradient(ellipse at 80% 80%,rgba(244,114,182,.08),transparent 60%),rgba(5,4,15,.88);backdrop-filter:blur(14px) saturate(130%);-webkit-backdrop-filter:blur(14px) saturate(130%);z-index:9990;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .28s ease;padding:2.5vh 2vw;box-sizing:border-box}
#card-lightbox.open{opacity:1;pointer-events:all}
#card-lightbox.open #lightbox-inner{transform:scale(1);opacity:1}
#lightbox-inner{position:relative;display:grid;grid-template-columns:300px auto 1fr;gap:14px;width:96vw;height:92vh;max-width:1800px;transform:scale(.98);opacity:0;transition:transform .32s cubic-bezier(.22,1,.36,1),opacity .24s ease}
#lb-window-btns{position:absolute;top:-14px;right:-14px;display:flex;gap:6px;z-index:20}
#lb-window-btns button{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:rgba(15,13,33,.9);color:#fff;font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .18s,background .18s,border-color .18s;line-height:1;backdrop-filter:blur(8px);box-shadow:0 6px 20px rgba(0,0,0,.5)}
#lb-btn-close:hover{background:rgba(220,38,38,.85);border-color:#dc2626;transform:scale(1.1)}
#lb-center-col{grid-column:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;height:100%;width:fit-content;overflow:hidden}
#lb-nav-bar{display:flex;align-items:center;gap:10px;flex-shrink:0}
#lb-nav-prev,#lb-nav-next{width:32px;height:32px;border-radius:50%;border:2px solid rgba(255,255,255,.2);background:rgba(255,255,255,.07);color:#fff;font-size:20px;font-weight:300;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s,transform .12s,opacity .15s;padding-bottom:2px}
#lb-nav-prev:hover:not(:disabled),#lb-nav-next:hover:not(:disabled){background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.5);transform:scale(1.1)}
#lb-nav-prev:disabled,#lb-nav-next:disabled{opacity:.25;cursor:default}
#lb-nav-clear{width:28px;height:28px;border-radius:50%;border:1.5px solid rgba(255,255,255,.15);background:rgba(255,255,255,.05);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}
#lb-nav-clear img{transition:opacity .15s,filter .15s}
#lb-nav-clear:hover{background:rgba(239,68,68,.18);border-color:rgba(239,68,68,.4)}
#lb-nav-clear:hover img{opacity:1!important;filter:sepia(1) saturate(5) hue-rotate(300deg)!important}
/* Icône poubelle neutre — blanche en dark, grise en light */
.icon-poubelle{opacity:.55;filter:invert(1);transition:opacity .15s,filter .15s}
[data-theme="light"] .icon-poubelle{filter:none;opacity:.6}
.icon-poubelle:hover{opacity:.85}
/* Icône poubelle rouge — action destructive, lisible dans les deux modes */
.icon-poubelle-red{filter:invert(1) sepia(1) saturate(5) hue-rotate(300deg);opacity:.8;transition:opacity .15s}
[data-theme="light"] .icon-poubelle-red{filter:sepia(1) saturate(8) hue-rotate(300deg)}
.icon-poubelle-red:hover{opacity:1}
#lb-nav-label{font-size:12px;font-weight:700;color:rgba(255,255,255,.65);min-width:48px;text-align:center;letter-spacing:.5px}
#lightbox-img{display:block;height:calc(92vh - 70px);width:auto;border-radius:18px;box-shadow:0 30px 80px rgba(0,0,0,.95),0 0 0 1px rgba(123,159,249,.18),0 0 60px rgba(123,159,249,.12);aspect-ratio:421/614;object-fit:contain;transition:transform .35s cubic-bezier(.22,1,.36,1),box-shadow .35s}
#lightbox-img:hover{transform:translateY(-4px) scale(1.015);box-shadow:0 40px 100px rgba(0,0,0,.95),0 0 0 1px rgba(167,139,250,.3),0 0 80px rgba(167,139,250,.2)}
#lb-info-panel{grid-column:1;display:flex;flex-direction:column;background:linear-gradient(180deg,rgba(20,18,42,.85),rgba(15,13,33,.75));border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:16px 16px 14px;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent;height:100%;box-sizing:border-box;box-shadow:0 8px 32px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.04)}
#lb-info-panel:empty{display:none}
#lb-info-panel::-webkit-scrollbar{width:3px}
#lb-info-panel::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:2px}
#lb-info-name{font-size:14px;font-weight:800;color:#fff;margin-bottom:12px;line-height:1.3;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:10px}
#lb-info-panel table{width:100%;border-collapse:collapse}
#lb-info-panel td{padding:5px 8px 5px 0;font-size:13px;vertical-align:top;line-height:1.4}
#lb-info-panel td:first-child{color:rgba(255,255,255,.65);font-size:10px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;white-space:nowrap;width:56px;padding-top:6px}
#lb-desc-label{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:rgba(255,255,255,.6);margin:12px 0 6px;border-top:1px solid rgba(255,255,255,.07);padding-top:10px}
#lb-desc-text{font-size:12.5px;color:rgba(255,255,255,.75);line-height:1.65;flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent;padding-right:2px;margin-bottom:12px}
#lb-desc-text::-webkit-scrollbar{width:3px}
#lb-desc-text::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}
#lb-info-actions{margin-top:auto;padding-top:10px;border-top:1px solid rgba(255,255,255,.07);display:flex;flex-direction:column;gap:8px;flex-shrink:0}
#lb-add-btns{display:flex;flex-direction:column;gap:6px}
.lb-btn-row{display:flex;gap:5px;align-items:center}
.lb-add-btn{flex:1;padding:7px 6px;border-radius:7px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:rgba(255,255,255,.8);font-size:11px;font-weight:700;cursor:pointer;transition:background .15s,border-color .15s,transform .12s;white-space:nowrap;text-align:left}
.lb-add-btn:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.25);transform:translateY(-1px)}
.lb-add-main:hover{background:rgba(59,130,246,.2);border-color:#3b82f6;color:#93c5fd}
.lb-add-extra:hover{background:rgba(168,85,247,.2);border-color:#a855f7;color:#d8b4fe}
.lb-add-side:hover{background:rgba(34,197,94,.15);border-color:#22c55e;color:#86efac}
.lb-rm-btn{flex-shrink:0;width:28px;height:28px;border-radius:6px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:rgba(255,255,255,.7);font-size:18px;font-weight:300;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s,color .15s,transform .12s;padding-bottom:1px}
.lb-rm-btn:hover{background:rgba(220,38,38,.2);border-color:#dc2626;color:#f87171;transform:scale(1.1)}
.lb-btn-count{display:inline-block;margin-left:4px;font-size:10px;font-weight:800;background:rgba(255,255,255,.12);color:rgba(255,255,255,.7);padding:1px 6px;border-radius:99px;vertical-align:middle;transition:background .15s,color .15s}
.lb-btn-count-max{background:rgba(220,38,38,.25);color:#f87171}
#lb-cm-link{display:flex;align-items:center;justify-content:center;gap:7px;padding:8px 10px;border-radius:7px;border:1px solid rgba(255,184,0,.25);background:rgba(255,184,0,.07);color:#fbbf24;font-size:12px;font-weight:700;text-decoration:none;transition:background .15s,border-color .15s,transform .12s}
#lb-cm-link:hover{background:rgba(255,184,0,.15);border-color:rgba(255,184,0,.5);transform:translateY(-1px);color:#fde68a}
#lb-toast{position:absolute;bottom:20px;left:50%;transform:translateX(-50%) translateY(12px);background:rgba(15,15,25,.95);border:1px solid rgba(255,255,255,.15);border-radius:10px;padding:10px 18px;font-size:13px;font-weight:600;color:#fff;white-space:nowrap;z-index:100;pointer-events:none;opacity:0;transition:opacity .2s,transform .2s;box-shadow:0 4px 24px rgba(0,0,0,.5)}
#lb-toast.visible{opacity:1;transform:translateX(-50%) translateY(0)}
#lb-toast.lb-toast-ok{border-color:rgba(74,222,128,.35);color:#4ade80}
#lb-toast.lb-toast-warn{border-color:rgba(251,191,36,.35);color:#fbbf24}
#lightbox-related{grid-column:3;display:flex;flex-direction:column;background:linear-gradient(180deg,rgba(20,18,42,.8),rgba(15,13,33,.7));border:1px solid rgba(255,255,255,.08);border-radius:16px;overflow:hidden;height:100%;box-sizing:border-box;min-width:0;box-shadow:0 8px 32px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.04)}
#lightbox-related:empty{display:none}
#lb-tab-bar{display:flex;gap:0;padding:9px 12px 0;flex-shrink:0;border-bottom:2px solid rgba(255,255,255,.1);background:rgba(0,0,0,.2);overflow-x:auto;scrollbar-width:none}
#lb-tab-bar::-webkit-scrollbar{display:none}
.lb-tab-btn{display:flex;align-items:center;gap:6px;padding:9px 16px 10px;border:none;border-bottom:3px solid transparent;background:transparent;color:rgba(255,255,255,.65);font-size:13px;font-weight:700;cursor:pointer;transition:color .15s,border-color .15s,background .15s;white-space:nowrap;margin-bottom:-2px;border-radius:6px 6px 0 0}
.lb-tab-btn:hover{color:rgba(255,255,255,.8);background:rgba(255,255,255,.06)}
.lb-tab-btn.active{color:#fff;border-bottom-color:#3b82f6;background:rgba(59,130,246,.1)}
.lb-tab-btn .lb-tab-icon{font-size:15px}
.lb-tab-lbl{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lb-tab-count{background:rgba(255,255,255,.1);color:rgba(255,255,255,.72);font-size:11px;font-weight:700;padding:2px 8px;border-radius:99px;flex-shrink:0}
.lb-tab-btn.active .lb-tab-count{background:rgba(59,130,246,.3);color:#93c5fd}
#lightbox-related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px;padding:14px;overflow-y:auto;overflow-x:hidden;flex:1;align-content:start;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}
#lightbox-related-grid::-webkit-scrollbar{width:4px}
#lightbox-related-grid::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:3px}
.lightbox-rel-card{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;border-radius:7px;padding:4px 3px;transition:background .15s,transform .18s,box-shadow .18s;border:1.5px solid transparent}
.lightbox-rel-card:hover{background:rgba(255,255,255,.08);transform:translateY(-2px);border-color:rgba(255,255,255,.15);box-shadow:0 4px 16px rgba(0,0,0,.4)}
.lightbox-rel-card img{width:100%;aspect-ratio:421/614;object-fit:cover;border-radius:4px;box-shadow:0 2px 8px rgba(0,0,0,.5);display:block}
.lightbox-rel-name{font-size:9px;color:rgba(255,255,255,.82);text-align:center;line-height:1.25;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;width:100%}
.lb-rel-pct{font-size:9px;font-weight:800;padding:1px 6px;border-radius:99px;text-align:center;letter-spacing:.3px;flex-shrink:0}


/* ─── ZOOM RECHERCHE ───────────────────────────────────────── */
.pg-zoom{width:26px;height:26px;border-radius:8px;border:1px solid rgba(123,159,249,.15);background:rgba(123,159,249,.06);color:rgba(123,159,249,.85);font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.18s;line-height:1;flex-shrink:0}
.pg-zoom:hover{border-color:rgba(123,159,249,.4);color:#a5c0ff;background:rgba(123,159,249,.12);transform:scale(1.08)}
.pg-zoom-val{font-size:10px;font-weight:700;color:var(--tx3);min-width:26px;text-align:center}
/* ─── 14. MISC / RESPONSIVE ─────────────────────────────────── */
@media(max-width:800px){
  #bar{flex-wrap:wrap;height:auto;padding:6px 10px;gap:6px}
  .sp{display:none}
}

/* ─── LIGHTBOX MOBILE (<1024px) avec onglets Carte / Synergies ─── */
/* Tab bar mobile : caché par défaut (desktop) */
#lb-mob-tabs { display: none; }

@media(max-width:1024px){
  /* Overlay plein écran */
  #card-lightbox { padding: 0; align-items: flex-start; background: var(--bg) !important; backdrop-filter: none !important; -webkit-backdrop-filter: none !important; }
  #lightbox-inner {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    width: 100%;
    height: 100dvh;
    max-width: 100%;
    transform: none !important;
    opacity: 1 !important;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    padding-bottom: calc(58px + env(safe-area-inset-bottom) + 16px);
  }

  /* Bouton fermer fixe en haut à droite */
  #lb-window-btns { position: fixed; top: 8px; right: 10px; z-index: 9999; }

  /* ─── Tab bar mobile (Carte & Effet / Extensions & Synergies) ─── */
  #lb-mob-tabs {
    display: flex;
    gap: 6px;
    padding: 12px 12px 10px 12px;
    padding-right: 54px; /* laisse place au bouton fermer */
    position: sticky;
    top: 0;
    z-index: 50;
    background: linear-gradient(180deg, var(--bg) 0%, var(--bg) 80%, transparent 100%);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    flex-shrink: 0;
  }
  .lb-mob-tab {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding: 10px 8px;
    border-radius: 11px;
    background: var(--sur2);
    border: 1px solid var(--bor);
    color: var(--tx2);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .3px;
    cursor: pointer;
    transition: background .18s, border-color .18s, color .18s, transform .15s;
    white-space: nowrap;
    min-width: 0;
  }
  .lb-mob-tab span { overflow: hidden; text-overflow: ellipsis; }
  .lb-mob-tab svg { flex-shrink: 0; opacity: .7 }
  .lb-mob-tab.on {
    background: linear-gradient(135deg, rgba(123,159,249,.15), rgba(167,139,250,.15), rgba(244,114,182,.1));
    border-color: rgba(167,139,250,.5);
    color: #c4b5fd;
  }
  .lb-mob-tab.on svg { opacity: 1; }
  [data-theme="light"] .lb-mob-tab.on { color: #6d28d9; }

  /* ─── Vue "Carte & Effet" : image + nav + info-panel ─── */
  #lb-center-col {
    grid-column: 1;
    order: 1;
    width: 100%;
    height: auto;
    padding: 8px 0 14px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    background: radial-gradient(ellipse at 50% 0%, rgba(123,159,249,.08), transparent 70%);
    flex-shrink: 0;
  }
  #lightbox-img {
    height: auto;
    width: 50vw;
    max-width: 200px;
    margin: 0 auto;
    border-radius: 12px;
  }
  #lb-nav-bar { width: 100%; justify-content: center; }

  #lb-info-panel {
    grid-column: 1;
    order: 2;
    height: auto;
    max-height: none;
    border-radius: 16px;
    margin: 0 12px 12px;
    width: calc(100% - 24px);
    box-sizing: border-box;
    flex-shrink: 0;
  }

  /* ─── Vue "Extensions & Synergies" ─── */
  #lightbox-related {
    grid-column: 1;
    order: 3;
    height: auto;
    min-height: 0;
    border-radius: 16px;
    margin: 4px 12px 12px;
    width: calc(100% - 24px);
    box-sizing: border-box;
    flex-shrink: 0;
  }
  #lightbox-related-grid { grid-template-columns: repeat(3, 1fr); max-height: none; overflow-y: visible; padding: 10px; gap: 10px; }
  #lb-tab-bar { overflow-x: auto; }
  .lb-tab-btn { font-size: 12px; padding: 8px 12px 9px; }

  /* Bascule des vues selon l'onglet actif */
  #lightbox-inner[data-mob-view="card"] #lightbox-related { display: none; }
  #lightbox-inner[data-mob-view="syn"] #lb-center-col,
  #lightbox-inner[data-mob-view="syn"] #lb-info-panel { display: none; }
}

/* ─── BAN / FORMAT TOAST ─── */
#ban-toast{
  position:fixed;bottom:60px;left:50%;transform:translateX(-50%) translateY(20px);
  background:rgba(10,8,20,.97);border:1px solid rgba(248,113,113,.3);border-radius:14px;
  color:#fff;font-size:13px;font-weight:600;padding:12px 24px;
  pointer-events:none;opacity:0;z-index:99999;white-space:nowrap;
  box-shadow:0 8px 32px rgba(248,113,113,.15),0 4px 16px rgba(0,0,0,.6);max-width:90vw;text-align:center;
  transition:none;
}
#ban-toast b{color:#ff6b6b}
@keyframes ban-in{from{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
@keyframes ban-out{from{opacity:1;transform:translateX(-50%) translateY(0)}to{opacity:0;transform:translateX(-50%) translateY(20px)}}
#ban-toast.ban-toast-in{animation:ban-in .25s ease forwards}
#ban-toast.ban-toast-out{animation:ban-out .3s ease forwards}
/* ═══════════════════════════════════════════════════════
   MODALS GÉNÉRIQUES (exports.js)
   ═══════════════════════════════════════════════════════ */

/* Backdrop commun */
.modal-overlay {
  position: fixed; inset: 0; z-index: 99999;
  background: rgba(0,0,0,.65);
  display: flex; align-items: center; justify-content: center;
}

/* Boîte de dialog */
.modal-box {
  background: var(--sur);
  border: 1px solid var(--bor2);
  border-radius: 14px;
  padding: 28px 32px;
  max-width: 420px;
  width: 92vw;
  box-shadow: 0 24px 80px rgba(0,0,0,.6);
  font-family: var(--sans);
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.modal-box--center { text-align: center; }

/* Titres / textes */
.modal-title {
  font-family: var(--title);
  font-size: 20px;
  letter-spacing: 1px;
  margin-bottom: 6px;
  color: var(--tx);
}
.modal-title--sm {
  font-family: var(--title);
  font-size: 18px;
  letter-spacing: .5px;
  color: var(--tx);
}
.modal-subtitle {
  font-size: 13px;
  color: var(--tx3);
  margin-bottom: 22px;
  line-height: 1.6;
}
.modal-subtitle--tx2 {
  font-size: 13px;
  color: var(--tx2);
  line-height: 1.6;
}

/* Conteneurs de boutons */
.modal-actions { display: flex; gap: 10px; justify-content: flex-end; }
.modal-actions--col { display: flex; flex-direction: column; gap: 8px; }

/* Boutons */
.modal-btn-primary {
  padding: 9px 20px;
  background: var(--blue);
  border: none;
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  border-radius: 8px;
  cursor: pointer;
  transition: background .15s;
}
.modal-btn-primary:hover { background: var(--blue2); }

.modal-btn-secondary {
  padding: 9px 20px;
  background: var(--sur2);
  border: 1px solid var(--bor);
  color: var(--tx);
  font-size: 13px;
  font-weight: 600;
  border-radius: 8px;
  cursor: pointer;
  transition: background .15s;
}
.modal-btn-secondary:hover { background: var(--sur3); }

.modal-btn-ghost {
  padding: 9px 0;
  background: transparent;
  border: none;
  color: var(--tx3);
  font-size: 12px;
  cursor: pointer;
}

.modal-btn-full { width: 100%; }

.modal-btn-cancel {
  margin-top: 16px;
  padding: 8px 20px;
  background: var(--sur2);
  border: 1px solid var(--bor);
  color: var(--tx2);
  font-size: 12px;
  font-weight: 600;
  border-radius: 8px;
  cursor: pointer;
  transition: background .15s;
}
.modal-btn-cancel:hover { background: var(--sur3); }

/* ─── Format picker ─── */
.fmt-pick-btns {
  display: flex; flex-wrap: wrap; gap: 8px; justify-content: center;
}
.fmt-pick-btn {
  padding: 10px 18px;
  font-size: 13px;
  font-weight: 700;
  border-radius: 8px;
  border-width: 1.5px;
  border-style: solid;
  cursor: pointer;
  transition: opacity .15s;
}
.fmt-pick-btn:hover { opacity: .75; }

/* ─── Spinner d'import ─── */
.import-spinner-overlay {
  position: fixed; inset: 0; z-index: 99999;
  background: rgba(0,0,0,.55);
  display: flex; align-items: center; justify-content: center;
  flex-direction: column; gap: 12px;
}
.import-spinner {
  width: 32px; height: 32px;
  border: 3px solid rgba(255,255,255,.15);
  border-top-color: var(--blue);
  border-radius: 50%;
  animation: spin .7s linear infinite;
}
.import-spinner-label {
  font-size: 12px; font-weight: 600;
  color: rgba(255,255,255,.8);
  letter-spacing: .5px;
}

/* ─── Drop zone YDK ─── */
#ydk-drop-overlay {
  position: absolute; inset: 0; z-index: 999;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; font-weight: 700;
  color: var(--blue);
  background: rgba(0,0,0,.35);
  border-radius: 4px;
  pointer-events: none;
  letter-spacing: .5px;
  outline: 3px dashed var(--blue);
  outline-offset: -3px;
}


/* Spinner dans le panneau deck (import YDK) */
.deck-panel-spinner {
  position: absolute; inset: 0; z-index: 9999;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 12px;
  background: rgba(0,0,0,.5);
  border-radius: 4px;
  pointer-events: none;
  
}


/* ─── Modal Stats — taille fixe pour éviter le redimensionnement entre onglets ─── */
#modal-stats .modal {
  height: 90vh;
  max-height: 90vh;
}
#modal-stats .modal-body {
  flex: 1;
  min-height: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

/* ── Stats tabs ── */
.stats-tabs{display:flex;border-bottom:1px solid rgba(123,159,249,.1);background:rgba(123,159,249,.03);flex-shrink:0}
.stats-tab{padding:10px 18px;border:none;border-bottom:2px solid transparent;background:transparent;color:var(--tx3);font-size:12px;font-weight:700;letter-spacing:.5px;cursor:pointer;transition:.2s;text-transform:uppercase}
.stats-tab:hover{color:var(--tx);background:rgba(123,159,249,.05)}
.stats-tab.on{color:#a5c0ff;border-bottom-color:rgba(123,159,249,.5);background:linear-gradient(180deg,rgba(123,159,249,.08),transparent)}

/* ── Proba cards ── */
.proba-card{background:rgba(123,159,249,.05);border:1px solid rgba(123,159,249,.1);border-radius:12px;padding:14px;margin-bottom:10px}
.proba-card-title{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:rgba(123,159,249,.9);margin-bottom:8px}

#modal-proba .proba-modal-shell{
  background:
    radial-gradient(circle at 12% -18%, rgba(20,184,166,.18), transparent 30%),
    radial-gradient(circle at 88% -16%, rgba(123,159,249,.2), transparent 34%),
    linear-gradient(180deg, rgba(19,19,34,.98), rgba(10,10,22,.98));
  border-color: rgba(123,159,249,.22);
}
#modal-proba .modal-hd{
  min-height: 58px;
  background: linear-gradient(90deg, rgba(12,12,24,.94), rgba(25,22,45,.92));
  border-bottom-color: rgba(123,159,249,.16);
}
.proba-modal-hd{flex-wrap:wrap;align-items:center;padding:10px 14px!important;gap:8px!important}
.proba-modal-hd .modal-title{flex:1;min-width:0}
.proba-modal-hd .modal-close{order:2;flex-shrink:0}
.proba-hd-actions{order:3;width:100%;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.proba-hd-btn{font-size:12px;font-weight:700;padding:6px 12px;background:var(--sur2);border:1px solid var(--bor);border-radius:6px;color:var(--tx2);cursor:pointer;white-space:nowrap;transition:border-color .15s,color .15s}
.proba-hd-btn:hover{border-color:var(--blue);color:var(--blue)}
#modal-proba .proba-modal-body{
  background: linear-gradient(180deg, rgba(255,255,255,.018), transparent 88px);
}
.proba-report-layout{gap:18px!important}
.proba-report-main,.proba-report-side{
  scrollbar-width: thin;
  scrollbar-color: rgba(123,159,249,.35) transparent;
}
.proba-report-main::-webkit-scrollbar,.proba-report-side::-webkit-scrollbar{width:7px}
.proba-report-main::-webkit-scrollbar-thumb,.proba-report-side::-webkit-scrollbar-thumb{background:rgba(123,159,249,.28);border-radius:99px}
.proba-hero-grid{
  background: linear-gradient(135deg, rgba(123,159,249,.08), rgba(20,184,166,.045));
  border: 1px solid rgba(123,159,249,.14);
  border-radius: 14px;
  padding: 10px;
}
.proba-grade-card,.proba-score-card,.proba-role-strip,.proba-odd-card,.proba-scenario-card,.proba-report-side{
  box-shadow: 0 10px 26px rgba(0,0,0,.18), 0 1px 0 rgba(255,255,255,.035) inset;
}
.proba-role-strip{align-content:center}
.proba-odds-grid{gap:8px!important}
.proba-odd-card{
  background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018))!important;
  transition: transform .16s ease, border-color .16s ease;
}
.proba-odd-card:hover,.proba-scenario-card:hover{
  transform: translateY(-1px);
  border-color: rgba(123,159,249,.26)!important;
}
.proba-scenario-grid{gap:8px!important}
.proba-risk-grid{gap:8px!important}
.proba-scenario-card{
  background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018))!important;
  border: 1px solid rgba(255,255,255,.055);
  transition: transform .16s ease, border-color .16s ease;
}
.proba-scenario-card--premium-new{
  position: relative;
  background: linear-gradient(180deg, rgba(20,184,166,.14), rgba(20,184,166,.035))!important;
  border-color: rgba(20,184,166,.28)!important;
}
.proba-report-side{
  background: linear-gradient(180deg, rgba(123,159,249,.075), rgba(255,255,255,.025))!important;
  border-color: rgba(123,159,249,.18)!important;
}

/* Premium polish: modales outils, stats, proba, simulateur, Small World */
.modal{background:linear-gradient(180deg,rgba(15,14,32,.96),rgba(9,10,24,.98)) padding-box,linear-gradient(135deg,rgba(123,159,249,.32),rgba(167,139,250,.24),rgba(244,114,182,.16)) border-box;border:1px solid transparent;box-shadow:0 28px 90px rgba(0,0,0,.62),0 0 0 1px rgba(255,255,255,.025) inset}
.modal-hd{min-height:58px;padding:0 18px;border-bottom:1px solid rgba(167,139,250,.12);background:linear-gradient(90deg,rgba(123,97,255,.105),rgba(123,159,249,.025));gap:10px}
.modal-title{font-family:var(--ui);font-size:12px;font-weight:900;letter-spacing:1.15px;text-transform:uppercase;color:#e2d9ff;background:none;-webkit-text-fill-color:initial}
.modal-close{width:32px;height:32px;border-radius:10px;border:1px solid rgba(167,139,250,.18);background:rgba(167,139,250,.07);color:rgba(200,190,240,.78);font-size:15px;transition:background .15s,border-color .15s,color .15s,transform .15s}
.modal-close:hover{background:rgba(248,113,113,.11);border-color:rgba(248,113,113,.38);color:#fca5a5;transform:translateY(-1px)}
#modal-proba .modal,#modal-stats .modal,#modal-sim .modal,#modal-sw .modal{border-radius:16px}
#modal-proba .modal-hd #proba-modal-handsize{height:32px!important;padding:0 34px 0 12px!important;border-radius:9px!important;border:1px solid rgba(167,139,250,.18)!important;background:rgba(167,139,250,.07)!important;color:#d4cafe!important;font-family:var(--ui)!important;font-size:12px!important;font-weight:750!important;color-scheme:dark}
.stats-tabs,.sim-tabs{display:flex;align-items:center;gap:3px;padding:4px;margin:0 0 14px;border:1px solid rgba(167,139,250,.14);border-radius:11px;background:rgba(4,5,14,.18);flex-shrink:0}
.stats-tab,.sim-tab{height:30px;padding:0 12px;border:1px solid transparent!important;border-radius:8px!important;background:transparent!important;color:rgba(200,190,240,.68)!important;font-family:var(--ui);font-size:11px!important;font-weight:850!important;letter-spacing:.55px;text-transform:uppercase;cursor:pointer;transition:background .15s,border-color .15s,color .15s,box-shadow .15s;margin:0!important;display:flex;align-items:center;justify-content:center;white-space:nowrap}
.stats-tab:hover,.sim-tab:hover{color:#f0eeff!important;background:rgba(123,97,255,.1)!important;border-color:rgba(167,139,250,.22)!important}
.stats-tab.on,.sim-tab.active{color:#e2d9ff!important;background:linear-gradient(180deg,rgba(123,97,255,.28),rgba(123,97,255,.16))!important;border-color:rgba(167,139,250,.48)!important;box-shadow:inset 0 1px 4px rgba(0,0,0,.26),0 0 0 2px rgba(167,139,250,.1)}
.stats-summary{gap:8px;margin-bottom:14px}
.stats-pill,.stat-chart-box,.chart-wrap,.proba-card{background:linear-gradient(180deg,rgba(167,139,250,.06),rgba(123,159,249,.025));border:1px solid rgba(167,139,250,.14);border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.16),0 1px 0 rgba(255,255,255,.025) inset}
.stats-pill{padding:12px 16px;min-width:92px}
.stats-pill-n{font-family:var(--ui);font-size:24px;font-weight:900;letter-spacing:-.02em;color:#d8b4fe;background:none;-webkit-text-fill-color:initial}
.stats-pill-l,.proba-card-title,.stat-chart-title{font-family:var(--ui);font-size:10px;font-weight:850;letter-spacing:.9px;color:rgba(200,190,240,.62)}
.proba-card{padding:13px;margin-bottom:9px}
.sim-btns{gap:7px;margin-bottom:14px}
.sim-btn{height:34px;padding:0 15px;border-radius:9px;border:1px solid rgba(167,139,250,.18);background:rgba(167,139,250,.07);color:#d4cafe;font-family:var(--ui);font-size:12px;font-weight:750;transition:background .15s,border-color .15s,color .15s,transform .15s,box-shadow .15s}
.sim-btn:hover{background:rgba(123,97,255,.14);border-color:rgba(167,139,250,.34);color:#f0eeff;transform:translateY(-1px)}
.sim-btn.prim{background:rgba(123,97,255,.24);border-color:rgba(167,139,250,.58);color:#e2d9ff;box-shadow:inset 0 1px 4px rgba(0,0,0,.24),0 0 0 2px rgba(167,139,250,.11)}
.sim-btn.danger{border-color:rgba(248,113,113,.22);background:rgba(248,113,113,.055);color:rgba(248,113,113,.92)}
.sim-btn.danger:hover{background:rgba(248,113,113,.13);border-color:rgba(248,113,113,.4);color:#fecaca}
.sim-freq-header{background:rgba(167,139,250,.045);border:1px solid rgba(167,139,250,.12);border-radius:10px 10px 0 0;border-bottom:none}
.sim-freq-list{border:1px solid rgba(167,139,250,.12);border-radius:0 0 10px 10px;overflow:hidden}
.sim-freq-row{border-bottom-color:rgba(167,139,250,.07)}
.sim-freq-row:hover{background:rgba(167,139,250,.045)}
#sw-body{background:linear-gradient(180deg,rgba(12,11,28,.96),rgba(8,9,22,.98))}
#sw-body>div>div:first-child{gap:3px!important;padding:6px!important;border-bottom:1px solid rgba(167,139,250,.12)!important;background:linear-gradient(180deg,rgba(123,97,255,.08),rgba(123,97,255,.025))!important}
#sw-body>div>div:first-child button{height:32px!important;padding:0 14px!important;border:1px solid transparent!important;border-radius:9px!important;background:transparent!important;color:rgba(200,190,240,.68)!important;font-family:var(--ui)!important;font-size:11px!important;font-weight:850!important;letter-spacing:.55px!important;text-transform:uppercase!important}
#sw-body>div>div:first-child button:hover{background:rgba(123,97,255,.1)!important;border-color:rgba(167,139,250,.22)!important;color:#f0eeff!important}
#sw-body>div>div:first-child button[style*="var(--blue)"]{background:linear-gradient(180deg,rgba(123,97,255,.28),rgba(123,97,255,.16))!important;border-color:rgba(167,139,250,.48)!important;color:#e2d9ff!important;box-shadow:inset 0 1px 4px rgba(0,0,0,.26),0 0 0 2px rgba(167,139,250,.1)!important}
#sw-body [style*="border-right:1px solid var(--bor)"]{border-right:1px solid rgba(167,139,250,.12)!important;background:rgba(255,255,255,.012)}
#sw-body [style*="background:var(--sur3)"]{background:linear-gradient(90deg,rgba(167,139,250,.08),rgba(123,159,249,.025))!important;border-bottom:1px solid rgba(167,139,250,.12)!important}
#sw-body [style*="text-transform:uppercase"]{font-family:var(--ui)!important;color:rgba(226,217,255,.86)!important;letter-spacing:.75px!important}
#sw-body [onclick][style*="display:flex;align-items:center;gap:8px"]{border:1px solid transparent!important;border-radius:9px!important;margin-bottom:2px!important;transition:background .15s,border-color .15s,transform .15s!important}
#sw-body [onclick][style*="display:flex;align-items:center;gap:8px"]:hover{background:rgba(167,139,250,.07)!important;border-color:rgba(167,139,250,.16)!important;transform:translateX(2px)}
#sw-body [style*="background:var(--blue)"]{background:rgba(123,97,255,.24)!important;border-color:rgba(167,139,250,.5)!important;box-shadow:inset 0 1px 4px rgba(0,0,0,.24),0 0 0 2px rgba(167,139,250,.1)}
#sw-body img{border-radius:5px!important;border-color:rgba(167,139,250,.14)!important;background:var(--sur3)}
#sw-body [style*="font-size:28px;opacity:.3"],#sw-body [style*="font-size:32px"]{display:none!important}

/* ── Hand simulator ── */
.hand-card{border-radius:10px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.5);border:2px solid rgba(123,159,249,.15);transition:.2s}
.hand-card:hover{border-color:rgba(123,159,249,.4);transform:translateY(-4px)}

/* ── Chart containers ── */
.chart-wrap{background:rgba(123,159,249,.03);border:1px solid rgba(123,159,249,.08);border-radius:12px;padding:14px;margin-bottom:12px}

/* ── DL menu items ── */
.dl-item{display:flex;align-items:center;gap:8px;width:100%;padding:9px 14px;border:none;background:transparent;color:var(--tx);font-size:13px;border-radius:8px;cursor:pointer;text-align:left;transition:.15s;font-weight:500}
.dl-item:hover{background:rgba(123,159,249,.1);color:#a5c0ff}

/* ─── Désactiver animations (opt-in) ─── */
.no-animations *,
.no-animations *::before,
.no-animations *::after {
  animation-duration: 0.001ms !important;
  animation-iteration-count: 1 !important;
  transition-duration: 0.001ms !important;
}
/* Sans transition, le transform au hover fait sauter la carte hors du curseur → oscillation de l'overlay */
.no-animations .dc-card:hover {
  transform: none;
}

/* Chrome drag fix : pnl-deck ne doit pas avoir overflow:hidden */
#pnl-deck{overflow:visible!important;}
#pnl-deck .dscroll{overflow-y:auto;overflow-x:visible;}

/* ════════════════════════════════════════════
   DeckHistory — versioning UI
════════════════════════════════════════════ */

/* Structure flex-colonne pour ancrer header + footer */
#ver-menu {
  min-width: 340px !important;
  max-height: 520px !important;
  /* display géré uniquement par JS pour que display:none fonctionne */
}

/* ── Header ── */
.dh-header {
  display: flex; align-items: center; gap: 11px;
  padding: 14px 16px 13px;
  border-bottom: 1px solid rgba(123,159,249,.1);
  flex-shrink: 0;
  background: linear-gradient(135deg, rgba(123,159,249,.04), transparent);
}
.dh-header-icon { font-size: 18px; flex-shrink: 0; opacity: .6; }
.dh-header-content { flex: 1; min-width: 0; }
.dh-header-title {
  font-size: 9px; font-weight: 800; letter-spacing: 1.4px;
  text-transform: uppercase; color: var(--tx3);
}
.dh-header-deck {
  font-size: 14px; font-weight: 700; color: var(--tx);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  margin-top: 3px;
}
.dh-count-pill {
  flex-shrink: 0; font-size: 10px; font-weight: 800;
  color: rgba(123,159,249,.7);
  background: rgba(123,159,249,.1);
  border: 1px solid rgba(123,159,249,.15);
  border-radius: 20px; padding: 3px 10px;
}
.dh-close-btn {
  flex-shrink: 0; background: none; border: none;
  color: var(--tx3); cursor: pointer;
  font-size: 13px; padding: 4px 6px; border-radius: 5px;
  transition: color .12s, background .12s; line-height: 1;
  margin-left: 4px;
}
.dh-close-btn:hover { color: var(--tx); background: rgba(123,159,249,.1); }

/* ── Zone scrollable des rows ── */
.dh-rows-scroll {
  flex: 1; overflow-y: auto; min-height: 0;
  padding: 6px 0;
}
.dh-rows-scroll::-webkit-scrollbar { width: 3px; }
.dh-rows-scroll::-webkit-scrollbar-thumb { background: rgba(123,159,249,.2); border-radius: 2px; }

/* ── Rows ── */
.dh-row {
  display: flex; align-items: center; gap: 12px;
  padding: 8px 14px; border-radius: 0;
  cursor: pointer; transition: background .1s;
  position: relative;
}
.dh-row::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0;
  width: 2px; background: transparent; transition: background .2s;
}
.dh-row:hover { background: rgba(123,159,249,.05); }
.dh-row:hover::before { background: rgba(123,159,249,.25); }
.dh-row--cur { background: rgba(123,159,249,.07); }
.dh-row--cur::before { background: rgba(123,159,249,.7) !important; }
.dh-row-thumb {
  width: 38px; height: 54px; object-fit: cover;
  border-radius: 5px; flex-shrink: 0;
  box-shadow: 0 3px 10px rgba(0,0,0,.45);
}
.dh-row-thumb--empty {
  width: 38px; height: 54px; border-radius: 5px;
  background: var(--sur3); flex-shrink: 0;
  border: 1px dashed rgba(123,159,249,.15);
}
.dh-row-info { flex: 1; min-width: 0; }
.dh-row-top { display: flex; align-items: center; gap: 7px; margin-bottom: 4px; }
.dh-row-label {
  font-size: 13px; font-weight: 600; color: var(--tx);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.dh-row-label--cur { color: rgba(123,159,249,.95); font-weight: 700; }
.dh-row-badge {
  font-size: 8px; font-weight: 800; letter-spacing: .6px;
  background: rgba(123,159,249,.15); color: rgba(123,159,249,.85);
  padding: 2px 7px; border-radius: 20px; flex-shrink: 0;
  text-transform: uppercase; border: 1px solid rgba(123,159,249,.2);
}
.dh-row-date { font-size: 10.5px; color: var(--tx3); line-height: 1.45; }
.dh-row-del-wrap { flex-shrink: 0; opacity: 0; transition: opacity .15s; }
.dh-row:hover .dh-row-del-wrap { opacity: 1; }
.dh-row-del {
  background: none; border: none; color: var(--tx3);
  cursor: pointer; font-size: 11px; padding: 5px 6px;
  border-radius: 5px; transition: color .12s, background .12s;
}
.dh-row-del:hover { color: var(--red); background: rgba(220,38,38,.08); }

/* ── Empty ── */
.dh-empty {
  padding: 32px 20px; font-size: 12px; color: var(--tx3);
  text-align: center; line-height: 1.9;
}

/* ── Séparateurs ── */
.dh-separator { display: none; }
.dh-separator--top {
  border-top: 1px solid rgba(123,159,249,.08);
  flex-shrink: 0;
}

/* ── Footer toggle ── */
.dh-toggle-label {
  display: flex; align-items: center; gap: 8px;
  font-size: 11px; color: var(--tx3);
  cursor: pointer; padding: 9px 16px;
  transition: color .12s;
}
.dh-toggle-label:hover { color: var(--tx2); }

/* Rename input */
.dh-rename-input {
  font-size: 12px; font-weight: 800;
  background: var(--sur3); border: 1px solid var(--blue);
  border-radius: 3px; color: var(--tx);
  padding: 2px 6px; width: 120px; outline: none;
}

/* Actions rapides dans le panneau Versions (mobile uniquement) */
.mob-ver-actions { display: none; }
#mob-ver-panel .mob-ver-actions {
  display: flex; flex-direction: column; gap: 8px;
  padding: 12px 12px 10px;
  border-bottom: 1px solid rgba(123,159,249,.12);
}
.mob-ver-btn-row { display: flex; gap: 8px; }
.mob-ver-btn {
  flex: 1; padding: 12px 14px;
  background: var(--sur2); border: 1px solid var(--bor);
  border-radius: 10px; color: var(--tx);
  font-size: 13px; font-weight: 700;
  cursor: pointer; text-align: left;
  font-family: inherit; transition: background .15s;
}
.mob-ver-btn:hover { background: var(--sur3); }
.mob-ver-btn--prim {
  background: linear-gradient(135deg, rgba(59,130,246,.12), rgba(123,97,255,.12));
  border-color: rgba(123,97,255,.3); color: #c4b5fd;
}
.mob-ver-btn--prim:hover {
  background: linear-gradient(135deg, rgba(59,130,246,.2), rgba(123,97,255,.2));
}
.mob-ver-btn--public {
  background: rgba(34,197,94,.08); border-color: rgba(34,197,94,.3); color: #22c55e;
}
.mob-ver-btn--public:hover { background: rgba(34,197,94,.15); }
.mob-ver-btn--private {
  background: rgba(167,139,250,.08); border-color: rgba(167,139,250,.3); color: #a78bfa;
}
.mob-ver-btn--private:hover { background: rgba(167,139,250,.15); }
.mob-ver-btn--danger {
  background: rgba(239,68,68,.08); border-color: rgba(239,68,68,.25); color: #f87171;
}
.mob-ver-btn--danger:hover { background: rgba(239,68,68,.14); }
.mob-ver-analysis { display: none; }
#mob-ver-panel .mob-ver-analysis {
  display: flex; flex-direction: column; gap: 8px;
  padding: 12px;
  border-top: 1px solid rgba(123,159,249,.12);
  border-bottom: 1px solid rgba(123,159,249,.12);
}
.mob-ver-section-title {
  font-size: 10px; font-weight: 800; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--tx3);
  padding: 0 2px;
}

/* Tooltip diff versions */
.dh-diff-tip {
  position: fixed; z-index: 9998;
  background: var(--sur); border: 1px solid var(--bor);
  border-radius: 10px; padding: 10px 12px;
  min-width: 180px; max-width: 260px;
  box-shadow: 0 8px 32px rgba(0,0,0,.5);
  pointer-events: none;
  opacity: 0; transform: translateX(-4px);
  transition: opacity .15s, transform .15s;
}
.dh-diff-tip--show { opacity: 1; transform: translateX(0); }
.dh-diff-title {
  font-size: 10px; font-weight: 800; letter-spacing: .8px;
  text-transform: uppercase; color: var(--tx3);
  margin-bottom: 8px;
}
.dh-diff-cur { color: rgba(123,159,249,.85); }
.dh-diff-equal {
  font-size: 11px; color: var(--tx3);
  text-align: center; padding: 6px 0;
}
.dh-diff-section { margin-bottom: 8px; }
.dh-diff-section:last-child { margin-bottom: 0; }
.dh-diff-lbl {
  font-size: 10px; font-weight: 700; letter-spacing: .5px;
  margin-bottom: 5px;
}
.dh-diff-section--add .dh-diff-lbl { color: #4ade80; }
.dh-diff-section--rem .dh-diff-lbl { color: #f87171; }
.dh-diff-cards {
  display: flex; flex-wrap: wrap; gap: 4px;
}
.dh-diff-card {
  position: relative; width: 34px; height: 48px;
  border-radius: 4px; overflow: hidden; flex-shrink: 0;
  box-shadow: 0 2px 6px rgba(0,0,0,.4);
}
.dh-diff-card img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.dh-diff-section--add .dh-diff-card { outline: 1.5px solid rgba(74,222,128,.5); }
.dh-diff-section--rem .dh-diff-card { outline: 1.5px solid rgba(248,113,113,.5); }
.dh-diff-card-empty {
  width: 100%; height: 100%;
  background: var(--sur3);
  border: 1px dashed rgba(123,159,249,.15);
}
.dh-diff-cnt {
  position: absolute; bottom: 2px; right: 2px;
  font-size: 9px; font-weight: 800;
  background: rgba(0,0,0,.75); color: #fff;
  border-radius: 3px; padding: 0 3px; line-height: 14px;
}

/* Menu contextuel clic droit */
.dh-ctx-menu {
  position: fixed; background: var(--sur);
  border: 1px solid var(--bor); border-radius: 8px;
  z-index: 99999; box-shadow: 0 8px 24px rgba(0,0,0,.25);
  min-width: 220px; overflow: hidden; display: none;
}
.dh-ctx-menu.open { display: block; }
.dh-ctx-item {
  padding: 9px 16px; font-size: 12px; font-weight: 600;
  cursor: pointer; transition: background .12s;
  display: flex; align-items: center; gap: 8px;
  border-bottom: 1px solid var(--bor); color: var(--tx);
}
.dh-ctx-item:last-child { border-bottom: none; }
.dh-ctx-item:hover { background: var(--sur2); }
.dh-ctx-item--danger { color: var(--red); }
.dh-ctx-item--danger:hover { background: rgba(220,38,38,.08); }
.dh-ctx-sep { border-top: 1px solid var(--bor); margin: 0; }

/* Image picker */
@keyframes dhFadeIn { from { opacity:0; transform:translateY(-4px) } to { opacity:1; transform:translateY(0) } }
.dh-img-picker {
  background: var(--sur2); border: 1px solid var(--bor);
  border-radius: 8px; padding: 8px; margin: 2px 6px 4px;
  animation: dhFadeIn .15s ease;
}
.dh-img-picker-hd {
  display: flex; align-items: center; justify-content: space-between;
  font-size: 10px; font-weight: 700; color: var(--tx3);
  text-transform: uppercase; letter-spacing: .5px; margin-bottom: 6px;
}
.dh-img-picker-close {
  background: none; border: none; color: var(--tx3);
  cursor: pointer; font-size: 12px; padding: 1px 4px;
  border-radius: 3px; transition: color .1s;
}
.dh-img-picker-close:hover { color: var(--red); }
.dh-img-picker-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(40px, 1fr));
  gap: 4px; max-height: 180px; overflow-y: auto;
}
.dh-img-card {
  background: none; border: 2px solid transparent;
  border-radius: 4px; padding: 0; cursor: pointer;
  overflow: hidden; transition: border-color .12s, transform .12s;
  aspect-ratio: 421/614;
}
.dh-img-card img { width: 100%; height: 100%; object-fit: cover; display: block; }
.dh-img-card:hover { border-color: var(--blue); transform: scale(1.06); }
.dh-img-card--active { border-color: var(--blue); box-shadow: 0 0 0 1px var(--blue); }
.dh-img-empty { font-size: 11px; color: var(--tx3); padding: 4px 2px; }

/* Fork modal */
.dh-fork-modal-bg {
  position: fixed; inset: 0; z-index: 999999;
  background: rgba(0,0,0,.55);
  display: flex; align-items: center; justify-content: center;
   animation: dhFadeIn .15s ease;
}
.dh-fork-modal {
  background: var(--sur); border: 1px solid var(--bor);
  border-radius: 14px; padding: 24px 28px;
  min-width: 340px; max-width: 440px;
  box-shadow: 0 24px 64px rgba(0,0,0,.5);
}
.dh-fork-modal-hd { font-size: 14px; font-weight: 800; color: var(--tx); margin-bottom: 10px; }
.dh-fork-modal-meta { display: flex; align-items: center; gap: 8px; margin-bottom: 14px; }
.dh-fork-badge { font-size: 10px; font-weight: 700; background: var(--blue); color: #fff; padding: 2px 7px; border-radius: 4px; }
.dh-fork-meta-txt { font-size: 11px; color: var(--tx3); }
.dh-fork-input {
  width: 100%; padding: 9px 12px;
  background: var(--sur2); border: 1px solid var(--bor);
  border-radius: 8px; color: var(--tx); font-size: 13px; font-weight: 600;
  outline: none; transition: border-color .15s;
  margin-bottom: 16px; box-sizing: border-box;
}
.dh-fork-input:focus { border-color: var(--blue); }
.dh-fork-actions { display: flex; gap: 8px; justify-content: flex-end; }
.dh-fork-btn {
  padding: 8px 18px; border-radius: 8px; font-size: 13px; font-weight: 700;
  cursor: pointer; border: 1px solid transparent; transition: background .15s, transform .1s;
}
.dh-fork-btn:hover { transform: translateY(-1px); }
.dh-fork-btn--cancel { background: var(--sur2); color: var(--tx3); border-color: var(--bor); }
.dh-fork-btn--cancel:hover { color: var(--tx); }
.dh-fork-btn--ok { background: var(--blue); color: #fff; box-shadow: 0 4px 12px rgba(59,130,246,.3); }
.dh-fork-btn--ok:hover { background: #2563eb; }

/* ── Extensions collapsible ── */
.d-lbl-toggle {
  cursor: pointer;
  user-select: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.d-lbl-toggle:hover { opacity: .85; }
.d-toggle-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px; height: 20px;
  border-radius: 5px;
  background: var(--sur3);
  border: 1px solid var(--bor);
  color: var(--tx);
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  flex-shrink: 0;
  transition: background .15s;
}
.d-lbl-toggle:hover .d-toggle-btn { background: var(--sur2); }
.d-sets--hidden { display: none; }

/* ═══════════════════════════════════════════════════════════════
   GROUPES DE CARTES (card_groups.js)
   ═══════════════════════════════════════════════════════════════ */

/* Panneau latéral slide-in */
.cg-panel {
  position: fixed;
  right: 0; top: 0; bottom: 0;
  width: 330px;
  background: var(--sur);
  border-left: 1px solid var(--bor);
  z-index: 9100;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform .3s cubic-bezier(.22,1,.36,1);
  box-shadow: -8px 0 40px rgba(0,0,0,.5);
  color: var(--tx);
}
.cg-panel.open { transform: translateX(0); }

/* Header du panneau */
.cg-panel-hd {
  display: flex; align-items: center; gap: 8px;
  padding: 13px 16px;
  border-bottom: 1px solid var(--bor);
  flex-shrink: 0;
  background: var(--sur2);
}
.cg-panel-title {
  font-family: var(--title);
  font-size: 13px;
  letter-spacing: 1.5px;
  color: var(--tx);
  flex: 1;
}
.cg-info-btn {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--sur3);
  border: 1px solid var(--bor);
  color: var(--tx2);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  flex-shrink: 0;
  transition: .15s;
  display: flex; align-items: center; justify-content: center;
}
.cg-info-btn:hover { border-color: var(--blue); color: var(--blue); }
.cg-info-btn--text {
  width: auto;
  min-width: 46px;
  padding: 0 9px;
  border-radius: 7px;
  font-size: 10px;
  letter-spacing: .7px;
}
.cg-exit {
  padding: 5px 14px;
  background: var(--red);
  border: none;
  border-radius: 99px;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  flex-shrink: 0;
  transition: filter .15s;
}
.cg-exit:hover { filter: brightness(1.15); }

/* Resize handle — bord gauche draggable du panel */
.cg-resize-handle {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 5px;
  cursor: col-resize;
  z-index: 10;
  transition: background .15s;
}
.cg-resize-handle:hover { background: rgba(123,159,249,.35); }

/* Section info collapsible */
.cg-info {
  max-height: 0;
  overflow: hidden;
  transition: max-height .3s ease;
  background: color-mix(in srgb, var(--blue) 8%, var(--sur2));
  border-bottom: 1px solid transparent;
}
.cg-info--open {
  max-height: 400px;
  border-bottom-color: var(--bor);
}
.cg-info-body {
  padding: 14px 16px;
  font-size: 12px;
  line-height: 1.6;
  color: var(--tx);
}
.cg-info-title {
  font-weight: 800;
  font-size: 13px;
  margin-bottom: 8px;
  color: var(--tx);
}
.cg-info-body p { margin: 0 0 8px; color: var(--tx2); }
.cg-info-row {
  display: flex; gap: 8px; align-items: baseline;
  font-size: 11px; color: var(--tx2);
  margin-bottom: 3px;
}

/* Corps du panneau */
.cg-panel-body {
  flex: 1;
  overflow-y: auto;
  padding: 10px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Message aucun groupe */
.cg-no-groups {
  padding: 20px;
  font-size: 12px;
  color: var(--tx3);
  text-align: center;
  font-style: italic;
}

/* Bloc groupe */
.cg-group {
  border: 2px solid var(--bor);
  border-radius: 8px;
  overflow: hidden;
  transition: border-color .2s;
}
.cg-group--active { border-color: var(--cg-border, var(--blue)) !important; }

/* Header du groupe */
.cg-group-hd {
  display: flex; align-items: center; gap: 7px;
  padding: 8px 12px;
  cursor: pointer;
  transition: background .15s;
  user-select: none;
}
.cg-group--active .cg-group-hd { background: var(--cg-bg, rgba(59,130,246,.2)); }
.cg-group-hd:hover { filter: brightness(1.08); }

/* Numéro du groupe */
.cg-num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 20px; height: 20px;
  border-radius: 50%;
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  flex-shrink: 0;
}

/* Input nom */
.cg-name {
  flex: 1; min-width: 0;
  background: transparent;
  border: none; outline: none;
  font-size: 12px; font-weight: 700;
  color: var(--tx);
  cursor: pointer;
}
.cg-name:focus {
  cursor: text;
  border-bottom: 1px solid var(--blue);
}

/* Compteur cartes */
.cg-cnt {
  font-size: 10px;
  color: var(--tx3);
  flex-shrink: 0;
  white-space: nowrap;
}

/* Bouton supprimer groupe */
.cg-del {
  padding: 2px 7px;
  background: var(--sur3);
  border: 1px solid var(--bor);
  border-radius: 4px;
  color: var(--tx3);
  font-size: 11px;
  cursor: pointer;
  flex-shrink: 0;
  transition: .15s;
}
.cg-del:hover { border-color: var(--red); color: var(--red); }

/* Miniatures cartes */
.cg-thumbs {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  padding: 8px 10px;
  background: var(--sur2);
}
.cg-thumb {
  width: 40px; height: 58px;
  object-fit: cover;
  border-radius: 3px;
  border: 1.5px solid transparent;
  cursor: pointer;
  transition: transform .15s, opacity .15s;
}
.cg-thumb:hover { transform: scale(1.1); opacity: .8; }

/* Texte hint vide */
.cg-hint {
  padding: 8px 12px;
  font-size: 11px;
  color: var(--tx3);
  background: var(--sur2);
  font-style: italic;
}

/* Bouton ajouter groupe */
.cg-add {
  width: 100%;
  padding: 10px;
  background: var(--blue);
  border: none;
  border-radius: 8px;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: filter .15s;
  flex-shrink: 0;
}
.cg-add:hover { filter: brightness(1.12); }

/* Bouton Sélectionner / Actif */
.cg-activate-btn {
  padding: 3px 9px;
  background: var(--sur3);
  border: 1px solid var(--bor);
  border-radius: 5px;
  color: var(--tx2);
  font-size: 10px;
  font-weight: 600;
  cursor: pointer;
  flex-shrink: 0;
  transition: .15s;
  white-space: nowrap;
}
.cg-activate-btn:hover { border-color: var(--blue); color: var(--blue); }
.cg-activate-btn--on {
  background: var(--green);
  border-color: var(--green);
  color: #fff;
}
.cg-activate-btn--on:hover { filter: brightness(1.1); border-color: var(--green); color: #fff; }

/* Splash dismiss: quand ce fichier est chargé et appliqué, le splash disparaît */
#fuwa-splash { opacity: 0; pointer-events: none; }

/* ─── 15. DECK CREATION DRAWER ──────────────────────────────── */

/* ── "Créer un nouveau deck" CTA button in topbar ── */
.create-deck-btn {
  background: linear-gradient(135deg, rgba(123,159,249,.12), rgba(167,139,250,.12));
  border: 1px solid rgba(123,159,249,.3) !important;
  color: var(--blue) !important;
  font-weight: 700;
  letter-spacing: .3px;
  gap: 7px;
  transition: background .2s, box-shadow .2s, transform .15s;
}
.create-deck-btn:hover {
  background: linear-gradient(135deg, rgba(123,159,249,.22), rgba(167,139,250,.22));
  border-color: rgba(123,159,249,.55) !important;
  box-shadow: 0 0 18px rgba(123,159,249,.22);
  transform: translateY(-1px);
  color: #fff !important;
}
.create-deck-icon {
  font-size: 13px;
  background: linear-gradient(135deg, #7b9ff9, #a78bfa);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
}

/* ── Deck identity pill (once deck is active) ── */
.deck-identity-btn {
  display: flex; align-items: center; gap: 9px;
  background: var(--sur) padding-box, linear-gradient(135deg,#7b9ff9,#a78bfa,#f472b6) border-box;
  border: 1px solid transparent !important;
  border-radius: 10px !important;
  padding: 5px 10px 5px 6px !important;
  max-width: 240px;
  box-shadow: 0 0 12px rgba(123,97,255,.15);
  transition: box-shadow .2s, background .2s;
}
.deck-identity-btn:hover {
  background: rgba(123,97,255,.12) padding-box, linear-gradient(135deg,#7b9ff9,#a78bfa,#f472b6) border-box;
  box-shadow: 0 0 20px rgba(167,139,250,.3), 0 0 40px rgba(244,114,182,.1);
}
.deck-identity-art {
  width: 30px; height: 30px;
  object-fit: cover; border-radius: 6px;
  border: 1px solid rgba(167,139,250,.35);
  flex-shrink: 0;
  box-shadow: 0 0 6px rgba(167,139,250,.25);
}
.deck-identity-info {
  display: flex; flex-direction: column; gap: 1px; min-width: 0;
}
.deck-identity-name {
  font-size: 12px; font-weight: 700;
  background: linear-gradient(135deg,#e0d8ff,#f9a8d4);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 140px;
}
.deck-identity-meta {
  font-size: 10px; color: rgba(196,181,253,.7); font-weight: 600; letter-spacing: .4px;
}
.deck-identity-edit {
  font-size: 13px; color: rgba(196,181,253,.5); margin-left: 2px; flex-shrink: 0;
  transition: color .15s;
}
.deck-identity-btn:hover .deck-identity-edit { color: #f9a8d4; }

/* ── Lock overlay on search panel ── */
@keyframes lockFadeOut {
  from { opacity: 1; backdrop-filter: blur(14px); }
  to   { opacity: 0; pointer-events: none; backdrop-filter: blur(0px); }
}
.builder-lock-overlay {
  position: absolute; inset: 0; z-index: 50;
  display: flex; align-items: center; justify-content: center;
  background: rgba(9,9,15,.72);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  transition: opacity .4s ease;
}
.builder-lock-overlay.unlocking {
  animation: lockFadeOut .42s ease forwards;
}
.builder-lock-content {
  display: flex; flex-direction: column; align-items: center;
  gap: 10px; text-align: center; padding: 24px;
}
.builder-lock-icon {
  font-size: 36px; opacity: .55; line-height: 1;
}
.builder-lock-title {
  font-family: var(--title); font-size: 15px; letter-spacing: 2px;
  color: var(--tx2);
}
.builder-lock-sub {
  font-size: 12px; color: var(--tx3); line-height: 1.7;
}
.builder-lock-cta {
  margin-top: 6px;
  background: linear-gradient(135deg, #7b9ff9, #a78bfa);
  border: none; border-radius: 10px;
  color: #fff; font-size: 12px; font-weight: 700;
  padding: 9px 22px; cursor: pointer; letter-spacing: .3px;
  display: flex; align-items: center; gap: 6px;
  transition: box-shadow .2s, transform .15s;
}
.builder-lock-cta:hover {
  box-shadow: 0 4px 24px rgba(123,159,249,.45);
  transform: translateY(-2px);
}

/* ── Drawer backdrop ── */
.drawer-backdrop {
  position: fixed; inset: 0; z-index: 9998;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
  opacity: 0; pointer-events: none;
  transition: opacity .3s ease;
}
.drawer-backdrop.open { opacity: 1; pointer-events: auto; }

/* ── Sliding drawer panel ── */
@keyframes drawerSlideIn  { from { transform: translateX(-100%); opacity: .6; } to { transform: translateX(0); opacity: 1; } }
@keyframes drawerSlideOut { from { transform: translateX(0);     opacity: 1;  } to { transform: translateX(-100%); opacity: .6; } }

.deck-drawer {
  position: fixed; left: 0; top: 0; bottom: 0; z-index: 9999;
  width: min(420px, 92vw);
  background: var(--sur);
  border-right: 1px solid rgba(123,159,249,.14);
  box-shadow: 6px 0 48px rgba(0,0,0,.7), 0 0 0 1px rgba(123,159,249,.06) inset;
  display: flex; flex-direction: column;
  transform: translateX(-100%);
  transition: transform .32s cubic-bezier(.16,1,.3,1), box-shadow .32s;
  will-change: transform;
}
.deck-drawer.open {
  transform: translateX(0);
  box-shadow: 8px 0 64px rgba(0,0,0,.8), 0 0 0 1px rgba(123,159,249,.1) inset;
}

/* Drawer header */
.deck-drawer-hd {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 20px 14px;
  border-bottom: 1px solid rgba(123,159,249,.1);
  flex-shrink: 0;
}
.deck-drawer-hd-left { display: flex; align-items: center; gap: 10px; }
.deck-drawer-icon {
  font-size: 15px;
  background: linear-gradient(135deg, #7b9ff9, #a78bfa);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.deck-drawer-title {
  font-family: var(--title); font-size: 17px; letter-spacing: 2px;
  color: var(--tx);
}
.deck-drawer-close {
  width: 30px; height: 30px; border-radius: 8px;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08);
  color: var(--tx3); font-size: 14px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s;
}
.deck-drawer-close:hover { background: rgba(248,113,113,.12); color: var(--red); }

/* Drawer scrollable body */
.deck-drawer-body {
  flex: 1; overflow-y: auto; padding: 20px;
  display: flex; flex-direction: column; gap: 18px;
}

/* Field rows */
.dd-field { display: flex; flex-direction: column; gap: 7px; }
.dd-label {
  font-size: 11px; font-weight: 700; letter-spacing: .8px;
  text-transform: uppercase; color: var(--tx3);
}

/* Artwork selector */
.dd-artwork-pick {
  position: relative; height: 160px;
  border-radius: 12px; overflow: hidden;
  border: 1.5px dashed rgba(123,159,249,.25);
  cursor: pointer; transition: border-color .2s;
  background: var(--sur2);
  display: flex; align-items: center; justify-content: center;
}
.dd-artwork-pick:hover, .dd-artwork-pick.active {
  border-color: rgba(123,159,249,.5);
}
.dd-artwork-preview {
  width: 100%; height: 100%; object-fit: cover;
}
.dd-artwork-overlay {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,.5); color: #fff;
  font-size: 12px; font-weight: 700; letter-spacing: .5px;
  opacity: 0; transition: opacity .2s; cursor: pointer;
}
.dd-artwork-pick:hover .dd-artwork-overlay { opacity: 1; }
.dd-artwork-placeholder {
  display: flex; flex-direction: column; align-items: center;
  gap: 8px; color: var(--tx3); font-size: 12px;
}

/* Art picker inline */
.dd-art-picker {
  background: var(--sur2);
  border: 1px solid rgba(123,159,249,.15);
  border-radius: 12px; overflow: hidden;
  display: flex; flex-direction: column;
  max-height: 260px;
}
.dd-art-picker-hd {
  display: flex; align-items: center; gap: 8px; padding: 8px 10px;
  border-bottom: 1px solid rgba(123,159,249,.1); flex-shrink: 0;
}
.dd-art-search {
  flex: 1; background: rgba(255,255,255,.05);
  border: 1px solid rgba(123,159,249,.2); border-radius: 7px;
  color: var(--tx); font-size: 12px; padding: 6px 10px;
}
.dd-art-search:focus { outline: none; border-color: rgba(123,159,249,.45); }
.dd-art-close {
  width: 26px; height: 26px; border-radius: 6px;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08);
  color: var(--tx3); font-size: 12px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.dd-art-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(54px,1fr));
  gap: 4px; padding: 8px; overflow-y: auto; flex: 1;
}
.dd-art-item {
  width: 100%; aspect-ratio: 421/614; object-fit: cover;
  border-radius: 5px; cursor: pointer; border: 2px solid transparent;
  transition: border-color .15s, transform .15s;
}
.dd-art-item:hover { border-color: var(--blue); transform: scale(1.07); }
.dd-art-empty { color: var(--tx3); font-size: 12px; padding: 16px; text-align: center; grid-column: 1/-1; }

/* Input / Select / Textarea */
.dd-input, .dd-select, .dd-textarea {
  background: var(--sur2);
  border: 1px solid rgba(123,159,249,.15);
  border-radius: 9px; color: var(--tx);
  font-family: var(--sans); font-size: 13px; padding: 9px 13px;
  transition: border-color .2s, box-shadow .2s;
}
.dd-input:focus, .dd-select:focus, .dd-textarea:focus {
  outline: none;
  border-color: rgba(123,159,249,.45);
  box-shadow: 0 0 0 3px rgba(123,159,249,.1);
}
.dd-textarea { resize: vertical; min-height: 72px; }
.dd-select { width: 100%; cursor: pointer; }

/* Toggle row */
.dd-toggle-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 11px 14px;
  background: var(--sur2); border-radius: 10px;
  border: 1px solid rgba(123,159,249,.1);
}
.dd-toggle-label { font-size: 13px; font-weight: 600; color: var(--tx); }
.dd-toggle-hint  { font-size: 11px; color: var(--tx3); margin-top: 2px; }
.dd-toggle {
  position: relative; width: 42px; height: 24px;
  border-radius: 99px; border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.08);
  cursor: pointer; flex-shrink: 0;
  transition: background .25s, border-color .25s;
}
.dd-toggle.on {
  background: linear-gradient(135deg, #7b9ff9, #a78bfa);
  border-color: transparent;
}
.dd-toggle-thumb {
  position: absolute; top: 3px; left: 3px;
  width: 16px; height: 16px; border-radius: 50%;
  background: rgba(255,255,255,.55);
  transition: transform .25s cubic-bezier(.34,1.56,.64,1), background .25s;
  display: block;
}
.dd-toggle.on .dd-toggle-thumb {
  transform: translateX(18px); background: #fff;
}

/* Drawer footer */
.deck-drawer-footer {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 20px;
  border-top: 1px solid rgba(123,159,249,.1);
  flex-shrink: 0;
  background: var(--sur);
}
.dd-btn-cancel {
  flex: 1; padding: 10px 0;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 10px; color: var(--tx2);
  font-size: 13px; font-weight: 600; cursor: pointer;
  transition: background .15s, color .15s;
}
.dd-btn-cancel:hover { background: rgba(255,255,255,.08); color: var(--tx); }
.dd-btn-save {
  flex: 2; padding: 10px 0;
  background: linear-gradient(135deg, #7b9ff9, #a78bfa);
  border: none; border-radius: 10px;
  color: #fff; font-size: 13px; font-weight: 700;
  letter-spacing: .3px; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 7px;
  box-shadow: 0 2px 18px rgba(123,159,249,.35);
  transition: box-shadow .2s, transform .15s, opacity .15s;
}
.dd-btn-save:hover:not(:disabled) {
  box-shadow: 0 4px 28px rgba(123,159,249,.55);
  transform: translateY(-1px);
}
.dd-btn-save:disabled { opacity: .45; cursor: not-allowed; transform: none; }

/* Light theme overrides */
[data-theme="light"] .deck-drawer {
  background: var(--sur);
  border-right-color: rgba(37,99,235,.12);
  box-shadow: 6px 0 32px rgba(37,99,235,.08);
}
[data-theme="light"] .dd-artwork-pick { border-color: rgba(37,99,235,.22); background: var(--sur2); }
[data-theme="light"] .dd-input, [data-theme="light"] .dd-select, [data-theme="light"] .dd-textarea {
  background: var(--sur2); border-color: rgba(37,99,235,.18);
}
[data-theme="light"] .dd-toggle-row { background: var(--sur2); border-color: rgba(37,99,235,.1); }
[data-theme="light"] .builder-lock-overlay { background: rgba(244,244,246,.78); }
[data-theme="light"] .builder-lock-title { color: var(--tx2); }
[data-theme="light"] .create-deck-btn { border-color: rgba(37,99,235,.3) !important; color: var(--blue) !important; }
/* ── Vue cartes/liste deck panel ── */
[data-theme="light"] .dscroll{background:linear-gradient(180deg,#f7f7fb,#f1f2f8)}
[data-theme="light"] .sec-block{background:linear-gradient(180deg,#ffffff,#f8f9ff) padding-box,linear-gradient(135deg,rgba(37,99,235,.22),rgba(124,58,237,.16),rgba(244,114,182,.12)) border-box;border-color:transparent;box-shadow:0 8px 24px rgba(67,56,130,.09),0 1px 0 rgba(255,255,255,.9) inset}
[data-theme="light"] .sec-block[data-sec="main"]{background:linear-gradient(180deg,#ffffff,#f7faff) padding-box,linear-gradient(135deg,rgba(37,99,235,.38),rgba(124,58,237,.16)) border-box;box-shadow:0 8px 24px rgba(37,99,235,.1)}
[data-theme="light"] .sec-block[data-sec="extra"]{background:linear-gradient(180deg,#ffffff,#faf7ff) padding-box,linear-gradient(135deg,rgba(124,58,237,.32),rgba(217,70,239,.14)) border-box;box-shadow:0 8px 24px rgba(124,58,237,.09)}
[data-theme="light"] .sec-block[data-sec="side"]{background:linear-gradient(180deg,#ffffff,#f4fffb) padding-box,linear-gradient(135deg,rgba(5,150,105,.32),rgba(37,99,235,.13)) border-box;box-shadow:0 8px 24px rgba(5,150,105,.08)}
[data-theme="light"] .sec-hd{background:linear-gradient(90deg,rgba(37,99,235,.06),rgba(255,255,255,.55));border-bottom-color:rgba(37,99,235,.12)}
[data-theme="light"] .sec-hd[data-sec="main"]{background:linear-gradient(90deg,rgba(37,99,235,.11),rgba(255,255,255,.62));border-bottom-color:rgba(37,99,235,.18)}
[data-theme="light"] .sec-hd[data-sec="extra"]{background:linear-gradient(90deg,rgba(124,58,237,.1),rgba(255,255,255,.62));border-bottom-color:rgba(124,58,237,.16)}
[data-theme="light"] .sec-hd[data-sec="side"]{background:linear-gradient(90deg,rgba(5,150,105,.1),rgba(255,255,255,.62));border-bottom-color:rgba(5,150,105,.15)}
[data-theme="light"] .sec-hd-name{-webkit-text-fill-color:initial;background:none}
[data-theme="light"] .sec-hd-name[data-sec="main"],[data-theme="light"] .sec-block[data-sec="main"] .sec-hd-name{color:#1d4ed8}
[data-theme="light"] .sec-hd-name[data-sec="extra"],[data-theme="light"] .sec-block[data-sec="extra"] .sec-hd-name{color:#7c3aed}
[data-theme="light"] .sec-hd-name[data-sec="side"],[data-theme="light"] .sec-block[data-sec="side"] .sec-hd-name{color:#047857}
[data-theme="light"] .sec-hd-icon{filter:none}
[data-theme="light"] .sec-hd-cnt{background:rgba(37,99,235,.08);color:#1d4ed8;border-color:rgba(37,99,235,.2)}
[data-theme="light"] .sec-block[data-sec="main"] .sec-hd-cnt{background:rgba(37,99,235,.1);color:#1d4ed8;border-color:rgba(37,99,235,.22)}
[data-theme="light"] .sec-block[data-sec="extra"] .sec-hd-cnt{background:rgba(124,58,237,.09);color:#6d28d9;border-color:rgba(124,58,237,.2)}
[data-theme="light"] .sec-block[data-sec="side"] .sec-hd-cnt{background:rgba(5,150,105,.09);color:#047857;border-color:rgba(5,150,105,.2)}
[data-theme="light"] .sec-drop{background:rgba(255,255,255,.36)}
[data-theme="light"] .sec-empty{background:rgba(37,99,235,.035);color:#1e40af;border-color:rgba(37,99,235,.2)}
[data-theme="light"] .sec-block[data-sec="extra"] .sec-empty{background:rgba(124,58,237,.035);color:#6d28d9;border-color:rgba(124,58,237,.18)}
[data-theme="light"] .sec-block[data-sec="side"] .sec-empty{background:rgba(5,150,105,.035);color:#047857;border-color:rgba(5,150,105,.18)}
[data-theme="light"] .sec-collapse-btn{background:rgba(255,255,255,.7);border-color:rgba(80,70,140,.16);color:#5b4b8f}
[data-theme="light"] .sec-collapse-btn:hover{background:rgba(124,58,237,.09);border-color:rgba(124,58,237,.28);color:#5b21b6}
[data-theme="light"] .dc-card:hover{box-shadow:0 12px 28px rgba(67,56,130,.22),0 0 0 1px rgba(37,99,235,.2)}
[data-theme="light"] .deck-list-hdr{background:linear-gradient(90deg,rgba(37,99,235,.07),rgba(255,255,255,.75));border-bottom-color:rgba(37,99,235,.12)}
[data-theme="light"] .deck-list-col{background:#fff;border-color:rgba(80,70,140,.14);box-shadow:0 6px 18px rgba(67,56,130,.06)}
[data-theme="light"] .deck-list-col-hd{background:linear-gradient(90deg,rgba(37,99,235,.055),rgba(255,255,255,.75));border-bottom-color:rgba(80,70,140,.12)}
[data-theme="light"] .deck-list-row:hover{background:rgba(37,99,235,.055)}
[data-theme="light"] .deck-view-switch{border-color:rgba(124,58,237,.2);background:rgba(124,58,237,.04)}
[data-theme="light"] .deck-view-btn{color:#5b21b6}
[data-theme="light"] .deck-view-btn + .deck-view-btn{border-left-color:rgba(124,58,237,.15)}
[data-theme="light"] .deck-view-btn:hover{background:rgba(124,58,237,.1);color:#5b21b6}
[data-theme="light"] .deck-view-btn.on{background:linear-gradient(135deg,#7c3aed,#a78bfa);color:#fff}
[data-theme="light"] .deck-view-btns{border-color:rgba(124,58,237,.18);background:rgba(124,58,237,.055)}
[data-theme="light"] .deck-vb,[data-theme="light"] .deck-head-action{color:rgba(70,55,120,.72)}
[data-theme="light"] .deck-vb:hover,[data-theme="light"] .deck-head-action:hover{background:rgba(124,58,237,.1);color:#5b21b6;border-color:rgba(124,58,237,.28)}
[data-theme="light"] .deck-vb.on{background:rgba(124,58,237,.18);color:#4c1d95;border-color:rgba(124,58,237,.4);box-shadow:inset 0 1px 3px rgba(60,30,120,.12),0 0 0 2px rgba(124,58,237,.1)}
[data-theme="light"] .deck-head-action{border-color:rgba(124,58,237,.18);background:rgba(124,58,237,.06);color:#5b21b6}
[data-theme="light"] .deck-head-action-tags{border-color:rgba(220,38,38,.18);background:rgba(220,38,38,.055);color:#b91c1c}
[data-theme="light"] .deck-head-action-tags:hover{border-color:rgba(220,38,38,.32);background:rgba(220,38,38,.1);color:#991b1b}
[data-theme="light"] .sh-tabs{background:linear-gradient(180deg,rgba(37,99,235,.04),rgba(37,99,235,.015));border-bottom-color:rgba(37,99,235,.12)}
[data-theme="light"] .sh-tab-group{background:rgba(255,255,255,.58);border-color:rgba(124,58,237,.14)}
[data-theme="light"] .sh-tab{color:rgba(70,55,120,.66)}
[data-theme="light"] .sh-tab:hover{background:rgba(124,58,237,.08);border-color:rgba(124,58,237,.2);color:#5b21b6}
[data-theme="light"] .sh-tab.on{background:linear-gradient(180deg,rgba(124,58,237,.16),rgba(124,58,237,.08));border-color:rgba(124,58,237,.34);color:#4c1d95;box-shadow:inset 0 1px 3px rgba(60,30,120,.1),0 0 0 2px rgba(124,58,237,.08)}
[data-theme="light"] .sh-tab-count{background:rgba(124,58,237,.14);color:#4c1d95}
[data-theme="light"] .sh-view-btns{border-color:rgba(124,58,237,.18);background:rgba(124,58,237,.055)}
[data-theme="light"] .sh-vb{color:rgba(70,55,120,.72)}
[data-theme="light"] .sh-vb:hover{background:rgba(124,58,237,.1);color:#5b21b6;border-color:rgba(124,58,237,.28)}
[data-theme="light"] .sh-vb.on{background:rgba(124,58,237,.18);color:#4c1d95;border-color:rgba(124,58,237,.4);box-shadow:inset 0 1px 3px rgba(60,30,120,.12),0 0 0 2px rgba(124,58,237,.1)}
[data-theme="light"] .sh-format-bar{background:rgba(37,99,235,.018);border-bottom-color:rgba(37,99,235,.1)}
[data-theme="light"] .fmt-pill{background:rgba(124,58,237,.045);border-color:rgba(124,58,237,.14);color:rgba(45,35,90,.72)}
[data-theme="light"] .fmt-pill:hover{background:rgba(124,58,237,.09);border-color:rgba(124,58,237,.28);color:#5b21b6}
[data-theme="light"] .fmt-pill.on{background:rgba(124,58,237,.16);border-color:rgba(124,58,237,.4) !important;color:#4c1d95;box-shadow:inset 0 1px 3px rgba(60,30,120,.1),0 0 0 2px rgba(124,58,237,.09)}
[data-theme="light"] .fmt-pill.fmt-retro{background:rgba(217,119,6,.055);border-color:rgba(217,119,6,.18);color:#92400e}
[data-theme="light"] .fmt-pill.fmt-retro:hover{background:rgba(217,119,6,.1);border-color:rgba(217,119,6,.3);color:#78350f}
[data-theme="light"] .fmt-pill.fmt-retro.on{background:rgba(217,119,6,.14);border-color:rgba(217,119,6,.38) !important;color:#78350f;box-shadow:inset 0 1px 3px rgba(120,53,15,.1),0 0 0 2px rgba(217,119,6,.08)}
[data-theme="light"] .fmt-pill[data-fmt="goat"]{background:rgba(22,163,74,.06);border-color:rgba(22,163,74,.18);color:#047857}
[data-theme="light"] .fmt-pill[data-fmt="goat"]:hover{background:rgba(22,163,74,.11);border-color:rgba(22,163,74,.32);color:#065f46}
[data-theme="light"] .fmt-pill[data-fmt="goat"].on{background:rgba(22,163,74,.16);border-color:rgba(22,163,74,.42) !important;color:#065f46;box-shadow:inset 0 1px 3px rgba(6,95,70,.1),0 0 0 2px rgba(22,163,74,.09)}
[data-theme="light"] .fmt-pill[data-fmt="edison"]{background:rgba(217,119,6,.055);border-color:rgba(217,119,6,.18);color:#92400e}
[data-theme="light"] .fmt-pill[data-fmt="edison"]:hover{background:rgba(217,119,6,.1);border-color:rgba(217,119,6,.3);color:#78350f}
[data-theme="light"] .fmt-pill[data-fmt="edison"].on{background:rgba(217,119,6,.14);border-color:rgba(217,119,6,.38) !important;color:#78350f;box-shadow:inset 0 1px 3px rgba(120,53,15,.1),0 0 0 2px rgba(217,119,6,.08)}
[data-theme="light"] .fmt-pill[data-fmt="genesys"]{background:rgba(124,58,237,.055);border-color:rgba(124,58,237,.18);color:#6d28d9}
[data-theme="light"] .fmt-pill[data-fmt="genesys"]:hover{background:rgba(124,58,237,.1);border-color:rgba(124,58,237,.32);color:#4c1d95}
[data-theme="light"] .fmt-pill[data-fmt="genesys"].on{background:rgba(124,58,237,.18);border-color:rgba(124,58,237,.42) !important;color:#4c1d95;box-shadow:inset 0 1px 3px rgba(60,30,120,.1),0 0 0 2px rgba(124,58,237,.09)}
[data-theme="light"] .fmt-pill[data-fmt="masterduel"]{background:rgba(37,99,235,.055);border-color:rgba(37,99,235,.18);color:#1d4ed8}
[data-theme="light"] .fmt-pill[data-fmt="masterduel"]:hover{background:rgba(37,99,235,.1);border-color:rgba(37,99,235,.32);color:#1e40af}
[data-theme="light"] .fmt-pill[data-fmt="masterduel"].on{background:rgba(37,99,235,.17);border-color:rgba(37,99,235,.42) !important;color:#1e3a8a;box-shadow:inset 0 1px 3px rgba(30,64,175,.1),0 0 0 2px rgba(37,99,235,.08)}
[data-theme="light"] .modal{background:linear-gradient(180deg,#ffffff,#f8f9ff) padding-box,linear-gradient(135deg,rgba(37,99,235,.22),rgba(124,58,237,.16),rgba(244,114,182,.12)) border-box;box-shadow:0 24px 70px rgba(67,56,130,.16),0 1px 0 rgba(255,255,255,.9) inset}
[data-theme="light"] .modal-hd{background:linear-gradient(90deg,rgba(37,99,235,.07),rgba(255,255,255,.65));border-bottom-color:rgba(37,99,235,.12)}
[data-theme="light"] .modal-title{color:#1a1535}
[data-theme="light"] .modal-close{background:rgba(124,58,237,.06);border-color:rgba(124,58,237,.18);color:#5b21b6}
[data-theme="light"] .modal-close:hover{background:rgba(220,38,38,.08);border-color:rgba(220,38,38,.26);color:#b91c1c}
[data-theme="light"] #modal-proba .modal-hd #proba-modal-handsize{background:rgba(124,58,237,.055)!important;border-color:rgba(124,58,237,.18)!important;color:#4c1d95!important;color-scheme:light}
[data-theme="light"] #modal-proba .proba-modal-shell{
  background:
    radial-gradient(circle at 12% -18%, rgba(20,184,166,.12), transparent 30%),
    radial-gradient(circle at 88% -16%, rgba(124,58,237,.13), transparent 34%),
    linear-gradient(180deg,#ffffff,#f8f9ff);
}
[data-theme="light"] #modal-proba .modal-hd{background:linear-gradient(90deg,rgba(37,99,235,.07),rgba(255,255,255,.75))}
[data-theme="light"] .proba-hero-grid{background:linear-gradient(135deg,rgba(37,99,235,.055),rgba(20,184,166,.035));border-color:rgba(80,70,140,.12)}
[data-theme="light"] .proba-odd-card,[data-theme="light"] .proba-scenario-card,[data-theme="light"] .proba-report-side{
  background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(248,249,255,.78))!important;
  border-color:rgba(124,58,237,.12)!important;
  box-shadow:0 8px 22px rgba(67,56,130,.07),0 1px 0 rgba(255,255,255,.9) inset;
}
[data-theme="light"] .proba-scenario-card--premium-new{
  background:linear-gradient(180deg,rgba(20,184,166,.1),rgba(255,255,255,.8))!important;
  border-color:rgba(13,148,136,.24)!important;
}
[data-theme="light"] .stats-tabs,[data-theme="light"] .sim-tabs{background:rgba(255,255,255,.62);border-color:rgba(124,58,237,.14)}
[data-theme="light"] .stats-tab,[data-theme="light"] .sim-tab{color:rgba(70,55,120,.66)!important}
[data-theme="light"] .stats-tab:hover,[data-theme="light"] .sim-tab:hover{background:rgba(124,58,237,.08)!important;border-color:rgba(124,58,237,.2)!important;color:#5b21b6!important}
[data-theme="light"] .stats-tab.on,[data-theme="light"] .sim-tab.active{background:linear-gradient(180deg,rgba(124,58,237,.16),rgba(124,58,237,.08))!important;border-color:rgba(124,58,237,.34)!important;color:#4c1d95!important;box-shadow:inset 0 1px 3px rgba(60,30,120,.1),0 0 0 2px rgba(124,58,237,.08)}
[data-theme="light"] .stats-pill,[data-theme="light"] .stat-chart-box,[data-theme="light"] .chart-wrap,[data-theme="light"] .proba-card{background:linear-gradient(180deg,rgba(255,255,255,.86),rgba(248,249,255,.74));border-color:rgba(124,58,237,.13);box-shadow:0 8px 22px rgba(67,56,130,.07),0 1px 0 rgba(255,255,255,.9) inset}
[data-theme="light"] .stats-pill-n{color:#5b21b6}
[data-theme="light"] .stats-pill-l,[data-theme="light"] .proba-card-title,[data-theme="light"] .stat-chart-title{color:rgba(70,55,120,.62)}
[data-theme="light"] .sim-btn{background:rgba(124,58,237,.055);border-color:rgba(124,58,237,.18);color:#5b21b6}
[data-theme="light"] .sim-btn:hover{background:rgba(124,58,237,.1);border-color:rgba(124,58,237,.32);color:#4c1d95}
[data-theme="light"] .sim-btn.prim{background:rgba(124,58,237,.18);border-color:rgba(124,58,237,.42);color:#4c1d95}
[data-theme="light"] .sim-btn.danger{background:rgba(220,38,38,.055);border-color:rgba(220,38,38,.18);color:#b91c1c}
[data-theme="light"] .sim-btn.danger:hover{background:rgba(220,38,38,.1);border-color:rgba(220,38,38,.32);color:#991b1b}
[data-theme="light"] .sim-freq-header,[data-theme="light"] .sim-freq-list{border-color:rgba(124,58,237,.12)}
[data-theme="light"] .sim-freq-header{background:rgba(124,58,237,.045)}
[data-theme="light"] .sim-freq-row:hover{background:rgba(124,58,237,.04)}
[data-theme="light"] #sw-body{background:linear-gradient(180deg,#ffffff,#f7f8ff)}
[data-theme="light"] #sw-body>div>div:first-child{background:linear-gradient(180deg,rgba(37,99,235,.05),rgba(255,255,255,.65))!important;border-bottom-color:rgba(37,99,235,.12)!important}
[data-theme="light"] #sw-body>div>div:first-child button{color:rgba(70,55,120,.66)!important}
[data-theme="light"] #sw-body>div>div:first-child button:hover{background:rgba(124,58,237,.08)!important;border-color:rgba(124,58,237,.2)!important;color:#5b21b6!important}
[data-theme="light"] #sw-body>div>div:first-child button[style*="var(--blue)"]{background:linear-gradient(180deg,rgba(124,58,237,.16),rgba(124,58,237,.08))!important;border-color:rgba(124,58,237,.34)!important;color:#4c1d95!important;box-shadow:inset 0 1px 3px rgba(60,30,120,.1),0 0 0 2px rgba(124,58,237,.08)!important}
[data-theme="light"] #sw-body [style*="border-right:1px solid var(--bor)"]{border-right-color:rgba(124,58,237,.12)!important;background:rgba(255,255,255,.55)}
[data-theme="light"] #sw-body [style*="background:var(--sur3)"]{background:linear-gradient(90deg,rgba(37,99,235,.055),rgba(255,255,255,.75))!important;border-bottom-color:rgba(80,70,140,.12)!important}
[data-theme="light"] #sw-body [style*="text-transform:uppercase"]{color:rgba(45,35,90,.78)!important}
[data-theme="light"] #sw-body [onclick][style*="display:flex;align-items:center;gap:8px"]:hover{background:rgba(124,58,237,.055)!important;border-color:rgba(124,58,237,.14)!important}
[data-theme="light"] #sw-body [style*="background:var(--blue)"]{background:rgba(124,58,237,.16)!important;border-color:rgba(124,58,237,.36)!important;box-shadow:inset 0 1px 3px rgba(60,30,120,.1),0 0 0 2px rgba(124,58,237,.08)}

/* Artwork field locked state */
.dd-field--locked .dd-label { opacity: .7; }
.dd-artwork-hint {
  font-size: 10px; font-weight: 500; letter-spacing: 0;
  color: var(--tx3); text-transform: none;
}
.dd-artwork-clear {
  background: none; border: none; color: var(--tx3);
  cursor: pointer; font-size: 11px; padding: 0 3px;
  line-height: 1; transition: color .15s;
}
.dd-artwork-clear:hover { color: var(--red); }

/* ═══════════════════════════════════════════════
   SharedNav — styles statiques (anti-FOUC)
   Les couleurs sont portées par les variables
   --sn-* définies dans le CRITICAL_CSS inline.
   ═══════════════════════════════════════════════ */
.sn-nav {
  position: sticky; top: 0; z-index: 1000;
  height: 68px; padding: 0 28px;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  background: var(--sn-bg);
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--sn-bor);
  font-family: var(--font-outfit), 'Outfit', sans-serif;
}
.sn-logo { display: flex; align-items: center; flex-shrink: 0; }
.sn-logo img { height: 38px; object-fit: contain; display: block; }
.sn-desktop-links { display: flex; align-items: center; gap: 4px; flex: 1; }
.sn-link {
  padding: 7px 16px; border-radius: 99px;
  font-size: 12px; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--sn-tx2); text-decoration: none;
  border: 1px solid transparent;
  transition: color .25s, background .25s, border-color .25s, letter-spacing .25s;
  white-space: nowrap;
}
.sn-link:hover { color: var(--sn-tx); background: rgba(120,100,200,.08); border-color: var(--sn-bor); letter-spacing: .16em; }
.sn-link.active { color: var(--sn-tx); background: rgba(120,100,200,.1); border-color: var(--sn-bor); }
.sn-nav-menu { position: relative; flex-shrink: 0; }
.sn-menu-trigger {
  display: inline-flex; align-items: center; gap: 2px;
  background: transparent; cursor: pointer; font-family: inherit;
}
.sn-menu-trigger:hover { letter-spacing: .14em; }
.sn-menu-dropdown {
  position: absolute; top: calc(100% + 10px); left: 0;
  transform: none;
  min-width: 220px; padding: 7px;
  background: var(--sn-dropBg); border: 1px solid var(--sn-bor);
  border-radius: 14px; box-shadow: 0 20px 60px rgba(0,0,0,.35);
  z-index: 9999; animation: snDropIn .15s ease;
}
.sn-menu-item {
  display: flex; align-items: center; gap: 9px;
  padding: 10px 12px; border-radius: 10px;
  color: var(--sn-tx2); text-decoration: none;
  font-size: 13px; font-weight: 700;
  transition: background .15s, color .15s;
}
.sn-menu-item:hover,
.sn-menu-item.active { color: var(--sn-tx); background: var(--sn-cardH); }
.sn-decks-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 7px 18px; border-radius: 99px;
  font-size: 12px; font-weight: 700;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--sn-dk-c); text-decoration: none;
  background: var(--sn-dk-bg);
  border: 1px solid var(--sn-dk-bor);
  transition: .25s; white-space: nowrap;
}
.sn-decks-btn:hover { background: var(--sn-dk-bgH); border-color: var(--sn-dk-borH); }
.sn-decks-btn.active { background: var(--sn-dk-bgA); }
.sn-premium {
  display: flex; align-items: center; gap: 6px;
  padding: 7px 18px; border-radius: 99px;
  font-size: 14px; font-weight: 600;
  color: var(--sn-pm-c); text-decoration: none;
  background: var(--sn-pm-bg);
  border: 1px solid rgba(251,191,36,.28);
  transition: .18s; white-space: nowrap;
}
.sn-premium:hover { background: var(--sn-pm-bgH); border-color: rgba(251,191,36,.45); }
.sn-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.sn-lang {
  display: flex; align-items: center; gap: 2px;
  background: rgba(120,100,200,.06);
  border: 1px solid var(--sn-bor); border-radius: 99px; padding: 3px;
}
.sn-lang-btn {
  padding: 4px 11px; border-radius: 99px;
  font-size: 11px; font-weight: 800; letter-spacing: .8px;
  cursor: pointer; border: none; background: transparent;
  color: var(--sn-tx2); transition: .18s; font-family: inherit;
}
.sn-lang-btn.on { background: linear-gradient(135deg,#7b9ff9,#a78bfa,#f472b6); color: #fff; }
.sn-icon-btn {
  width: 34px; height: 34px; border-radius: 99px;
  border: 1px solid var(--sn-bor); background: transparent;
  cursor: pointer; font-size: 15px;
  display: flex; align-items: center; justify-content: center;
  transition: .18s; color: var(--sn-tx2); flex-shrink: 0;
}
.sn-icon-btn:hover { background: rgba(120,100,200,.08); color: var(--sn-tx); }
.sn-cta {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 20px; border-radius: 99px;
  font-size: 14px; font-weight: 700; color: #fff;
  text-decoration: none; white-space: nowrap;
  background: linear-gradient(135deg,#7b9ff9,#a78bfa,#f472b6);
  transition: .2s; box-shadow: 0 0 20px rgba(123,159,249,.2);
}
.sn-cta:hover { transform: translateY(-1px); box-shadow: 0 0 32px rgba(123,159,249,.4); }
.sn-auth-wrap { position: relative; flex-shrink: 0; }
.sn-auth-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 5px 14px 5px 5px; border-radius: 99px;
  border: 1px solid var(--sn-bor); background: rgba(120,100,200,.06);
  color: var(--sn-tx); cursor: pointer; font-size: 14px; font-weight: 600;
  font-family: inherit; transition: .18s; white-space: nowrap;
}
.sn-auth-btn:hover { background: rgba(120,100,200,.12); }
.sn-auth-btn-sign {
  display: flex; align-items: center; gap: 7px;
  padding: 7px 16px; border-radius: 99px;
  border: 1px solid var(--sn-bor); background: rgba(120,100,200,.06);
  color: var(--sn-tx); cursor: pointer; font-size: 14px; font-weight: 600;
  font-family: inherit; transition: .18s; white-space: nowrap;
}
.sn-auth-btn-sign:hover { background: rgba(120,100,200,.12); }
.sn-auth-avatar { width: 26px; height: 26px; border-radius: 50%; object-fit: cover; }
.sn-auth-initials {
  width: 26px; height: 26px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg,#7b9ff9,#a78bfa);
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; color: #fff; font-weight: 700;
}
.sn-auth-name { max-width: 80px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sn-dropdown {
  position: absolute; top: calc(100% + 10px); right: 0;
  background: var(--sn-dropBg); border: 1px solid var(--sn-bor);
  border-radius: 16px; padding: 8px;
  min-width: 210px; box-shadow: 0 20px 60px rgba(0,0,0,.35);
  z-index: 9999;
  animation: snDropIn .15s ease;
}
@keyframes snDropIn { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: translateY(0); } }
.sn-drop-head { padding: 10px 12px 8px; border-bottom: 1px solid var(--sn-bor); margin-bottom: 4px; }
.sn-drop-item {
  display: flex; align-items: center; gap: 9px;
  padding: 9px 12px; border-radius: 10px;
  color: var(--sn-tx); text-decoration: none;
  font-size: 13px; font-weight: 500;
  transition: background .15s; cursor: pointer;
  border: none; background: transparent; width: 100%; font-family: inherit;
}
.sn-drop-item:hover { background: var(--sn-cardH); }
.sn-drop-sep { height: 1px; background: var(--sn-bor); margin: 4px 0; }
.sn-drop-login-title { font-size: 12px; color: var(--sn-tx2); text-align: center; padding: 4px 0 10px; }
.sn-drop-google {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; border-radius: 12px; margin-bottom: 6px;
  background: var(--sn-card); border: 1px solid var(--sn-bor);
  color: var(--sn-tx); text-decoration: none; font-size: 14px; font-weight: 600;
  transition: .15s;
}
.sn-drop-google:hover { background: var(--sn-cardH); }
.sn-drop-discord {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; border-radius: 12px;
  background: #5865F2; color: #fff;
  text-decoration: none; font-size: 14px; font-weight: 600;
  transition: .15s;
}
.sn-drop-discord:hover { background: #4752c4; }
.sn-hamburger {
  display: none;
  width: 38px; height: 38px; flex-shrink: 0;
  background: var(--sn-card); border: 1px solid var(--sn-bor);
  border-radius: 10px; cursor: pointer;
  flex-direction: column; align-items: center; justify-content: center; gap: 5px;
  transition: background .18s, border-color .18s;
  padding: 0;
}
.sn-hamburger:hover { background: var(--sn-cardH); }
.sn-ham-bar {
  display: block; width: 18px; height: 2px;
  background: var(--sn-tx2); border-radius: 2px;
  transition: transform .25s ease, opacity .2s ease, width .2s ease;
  transform-origin: center;
}
.sn-hamburger.open .sn-ham-bar { background: var(--sn-tx); }
.sn-hamburger.open .sn-ham-bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.sn-hamburger.open .sn-ham-bar:nth-child(2) { opacity: 0; width: 0; }
.sn-hamburger.open .sn-ham-bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.sn-backdrop {
  display: none;
  position: fixed; inset: 0; top: 60px;
  background: rgba(0,0,0,.5);
  z-index: 998;
  opacity: 0; transition: opacity .25s;
  pointer-events: none;
}
.sn-backdrop.open { opacity: 1; pointer-events: auto; }
.sn-mobile-menu {
  display: none;
  position: fixed; top: 60px; left: 0; right: 0;
  flex-direction: column;
  background: var(--sn-menuBg);
  backdrop-filter: blur(28px); -webkit-backdrop-filter: blur(28px);
  border-bottom: 1px solid var(--sn-bor);
  padding: 12px 14px 24px;
  z-index: 999;
  max-height: calc(100svh - 60px); overflow-y: auto;
  box-shadow: 0 16px 48px rgba(0,0,0,.35);
  opacity: 0; transform: translateY(-10px);
  transition: opacity .22s ease, transform .22s ease;
  pointer-events: none;
}
.sn-mobile-menu.open { opacity: 1; transform: translateY(0); pointer-events: auto; }
.sn-mob-link {
  display: flex; align-items: center;
  padding: 13px 16px; border-radius: 12px;
  font-size: 15px; font-weight: 600;
  color: var(--sn-tx2); text-decoration: none;
  background: var(--sn-card); border: 1px solid var(--sn-bor);
  transition: .15s; margin-bottom: 6px;
}
.sn-mob-link:hover, .sn-mob-link.active { color: var(--sn-tx); background: var(--sn-cardH); }
.sn-mob-link.active { border-color: rgba(120,100,200,.3); }
/* Bouton Explorer (Tous les decks) - mobile */
.sn-mob-explore {
  gap: 12px;
  background: linear-gradient(135deg, rgba(123,159,249,.1) 0%, rgba(167,139,250,.1) 100%);
  border-color: rgba(123,159,249,.3);
  color: var(--sn-tx);
  position: relative; overflow: hidden;
}
.sn-mob-explore::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(123,159,249,.06), rgba(167,139,250,.06));
  opacity: 0; transition: opacity .15s;
}
.sn-mob-explore:hover::before, .sn-mob-explore.active::before { opacity: 1; }
.sn-mob-explore:hover { color: var(--sn-tx); background: linear-gradient(135deg, rgba(123,159,249,.15), rgba(167,139,250,.15)); border-color: rgba(123,159,249,.45); }
.sn-mob-explore.active { background: linear-gradient(135deg, rgba(123,159,249,.18), rgba(167,139,250,.18)); border-color: rgba(123,159,249,.55); }
.sn-mob-explore-icon {
  width: 34px; height: 34px; border-radius: 10px; flex-shrink: 0;
  background: linear-gradient(135deg, #7b9ff9, #a78bfa);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 8px rgba(123,159,249,.35);
}
.sn-mob-explore-text { display: flex; flex-direction: column; gap: 1px; }
.sn-mob-explore-label { font-size: 15px; font-weight: 700; color: var(--sn-tx); line-height: 1.2; }
.sn-mob-explore-sub { font-size: 11px; font-weight: 500; color: var(--sn-tx2); line-height: 1.2; }
/* Profil card - mobile */
.sn-mob-profile-card {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; border-radius: 14px; margin-bottom: 10px;
  background: linear-gradient(135deg, rgba(123,159,249,.08), rgba(167,139,250,.08));
  border: 1px solid rgba(123,159,249,.2);
}
.sn-mob-profile-avatar-wrap {
  position: relative; flex-shrink: 0;
}
.sn-mob-profile-avatar-ring {
  width: 48px; height: 48px; border-radius: 50%;
  padding: 2px;
  background: linear-gradient(135deg, #7b9ff9, #a78bfa);
  display: flex; align-items: center; justify-content: center;
}
.sn-mob-profile-avatar-ring img,
.sn-mob-profile-avatar-ring .sn-auth-initials {
  width: 44px !important; height: 44px !important;
  border-radius: 50%; object-fit: cover; border: none;
}
.sn-mob-profile-info { flex: 1; min-width: 0; }
.sn-mob-profile-name { font-size: 15px; font-weight: 700; color: var(--sn-tx); line-height: 1.2; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sn-mob-profile-provider { font-size: 11px; color: var(--sn-tx2); margin-top: 2px; text-transform: capitalize; }
/* Grille d'actions compte - mobile */
.sn-mob-actions-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 8px; margin-bottom: 8px;
}
.sn-mob-action-tile {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 7px; padding: 16px 10px; border-radius: 12px;
  color: var(--sn-tx); text-decoration: none; font-size: 12px; font-weight: 600;
  background: var(--sn-card); border: 1px solid var(--sn-bor);
  transition: .15s; cursor: pointer; font-family: inherit; text-align: center;
}
.sn-mob-action-tile:hover { background: var(--sn-cardH); }
.sn-mob-action-tile-icon {
  width: 32px; height: 32px; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
}
.sn-mob-action-sub { display: flex; flex-direction: column; gap: 8px; margin-bottom: 8px; }
.sn-mob-action-row {
  display: flex; align-items: center; gap: 12px;
  padding: 13px 16px; border-radius: 12px;
  color: var(--sn-tx); text-decoration: none; font-size: 14px; font-weight: 600;
  background: var(--sn-card); border: 1px solid var(--sn-bor);
  transition: .15s; cursor: pointer; font-family: inherit; width: 100%;
}
.sn-mob-action-row:hover { background: var(--sn-cardH); }
.sn-mob-premium {
  display: flex; align-items: center; gap: 8px;
  padding: 13px 16px; border-radius: 12px;
  font-size: 15px; font-weight: 600;
  color: var(--sn-pm-c); text-decoration: none;
  background: var(--sn-pm-bg);
  border: 1px solid rgba(251,191,36,.25); margin-bottom: 6px;
  transition: .15s;
}
.sn-mob-cta {
  display: flex; align-items: center; justify-content: center;
  padding: 14px; border-radius: 12px;
  font-size: 15px; font-weight: 700; color: #fff;
  text-decoration: none; margin-bottom: 8px;
  background: linear-gradient(135deg,#7b9ff9,#a78bfa,#f472b6);
  box-shadow: 0 4px 20px rgba(123,159,249,.25);
}
.sn-mob-sep { height: 1px; background: var(--sn-bor); margin: 10px 0; }
.sn-mob-utils { display: flex; align-items: center; justify-content: space-between; padding: 6px 4px; gap: 8px; }
.sn-mob-auth-btn {
  display: flex; align-items: center; gap: 10px;
  padding: 13px 16px; border-radius: 12px; width: 100%;
  background: var(--sn-card); border: 1px solid var(--sn-bor);
  color: var(--sn-tx); cursor: pointer; font-size: 15px; font-weight: 600;
  font-family: inherit; transition: .15s; text-decoration: none;
}
.sn-mob-auth-btn:hover { background: var(--sn-cardH); }
.sn-mob-drop-google {
  display: flex; align-items: center; gap: 10px;
  padding: 13px 16px; border-radius: 12px; margin-bottom: 6px;
  background: var(--sn-card); border: 1px solid var(--sn-bor);
  color: var(--sn-tx); text-decoration: none; font-size: 15px; font-weight: 600;
}
.sn-mob-drop-discord {
  display: flex; align-items: center; gap: 10px;
  padding: 13px 16px; border-radius: 12px;
  background: #5865F2; color: #fff;
  text-decoration: none; font-size: 15px; font-weight: 600;
}
.sn-mob-drop-item {
  display: flex; align-items: center; gap: 10px;
  padding: 13px 16px; border-radius: 12px; width: 100%;
  color: var(--sn-tx); text-decoration: none; font-size: 15px; font-weight: 500;
  background: var(--sn-card); border: 1px solid var(--sn-bor);
  transition: .15s; cursor: pointer; font-family: inherit;
  margin-bottom: 6px;
}
.sn-mob-drop-item:hover { background: var(--sn-cardH); }
@media (max-width: 1024px) {
  .sn-nav { height: 60px; padding: 0 14px; }
  .sn-hamburger { display: flex !important; }
  .sn-desktop-links { display: none !important; }
  .sn-actions { display: none !important; }
  .sn-backdrop { display: block; }
  .sn-mobile-menu { display: flex; }
}
@media (min-width: 1025px) {
  .sn-hamburger { display: none !important; }
  .sn-mobile-menu { display: none !important; }
  .sn-backdrop { display: none !important; }
}

/* ── Notifications ── */
.sn-notif-wrap { position: relative; flex-shrink: 0; }
.sn-notif-btn  { position: relative; }

.sn-notif-badge {
  position: absolute;
  top: -4px; right: -4px;
  min-width: 17px; height: 17px;
  padding: 0 4px;
  border-radius: 99px;
  background: #f87171;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  line-height: 17px;
  text-align: center;
  pointer-events: none;
}

.sn-notif-dropdown {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  width: 340px;
  max-height: 460px;
  overflow-y: auto;
  z-index: 9999;
}

@media (max-width: 480px) {
  .sn-notif-dropdown {
    position: fixed;
    top: 58px;
    left: 8px;
    right: 8px;
    width: auto;
    max-height: 80vh;
  }
}

.sn-notif-empty {
  padding: 18px 12px;
  font-size: 13px;
  color: var(--sn-tx2);
  text-align: center;
}

.sn-notif-clear-all {
  background: none;
  border: none;
  color: #f87171;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 6px;
  font-family: inherit;
  opacity: .8;
  transition: opacity .15s;
}
.sn-notif-clear-all:hover { opacity: 1; }

.sn-notif-list {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 4px 8px 8px;
}

.sn-notif-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 9px 6px 9px 8px;
  border-radius: 10px;
  transition: background .15s;
}
.sn-notif-item:hover { background: var(--sn-cardH); }
.sn-notif-item.sn-notif-unread { background: rgba(123,159,249,.08); }

.sn-notif-link {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  flex: 1;
  min-width: 0;
  text-decoration: none;
  color: var(--sn-tx);
  font-size: 12px;
  font-weight: 500;
  padding: 2px 0;
}

.sn-notif-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  margin-top: 2px;
}
.sn-notif-avatar-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #7b9ff9, #a78bfa);
  font-size: 13px;
  font-weight: 700;
  color: #fff;
}

.sn-notif-text {
  flex: 1;
  min-width: 0;
  line-height: 1.5;
  white-space: normal;
  word-break: break-word;
}

.sn-notif-time {
  display: block;
  font-size: 10px;
  color: var(--sn-tx3, #7878b0);
  margin-top: 4px;
  font-weight: 400;
}

.sn-notif-del {
  background: none;
  border: none;
  color: var(--sn-tx2);
  cursor: pointer;
  padding: 7px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .15s, background .15s, color .15s;
  flex-shrink: 0;
  min-width: 30px;
  min-height: 30px;
  margin-top: 1px;
}
.sn-notif-item:hover .sn-notif-del { opacity: 1; }
.sn-notif-del:hover { background: rgba(248,113,113,.18); color: #f87171; }
@media (hover: none) {
  .sn-notif-del { opacity: 1; }
  /* Désactive complètement le hover sticky des cartes du deck sur tactile */
  .dc-card:hover,
  .dc-card:focus,
  .dc-card:active {
    transform: none !important;
    box-shadow: none !important;
    border-color: transparent !important;
    z-index: auto !important;
  }
  .dc-card.deck-sel,
  .dc-card.deck-sel:hover,
  .dc-card.deck-sel:focus,
  .dc-card.deck-sel:active {
    border-color: rgba(168,85,247,.9) !important;
    box-shadow: 0 0 0 2px rgba(168,85,247,.35),0 0 14px rgba(168,85,247,.4) !important;
    z-index: 50 !important;
  }
}

/* Mobile notif items */
.sn-notif-mob {
  padding: 10px 8px 10px 10px;
  border-radius: 12px;
  border: 1px solid var(--sn-bor);
  margin-bottom: 6px;
}
.sn-notif-mob .sn-notif-del { opacity: 1; }



/* ═══════════════════════════════════════════════════════════════
   15. RESPONSIVE — MOBILE  (< 768px)
   ═══════════════════════════════════════════════════════════════ */

/* ── Elements hidden/shown on mobile ── */
.mob-nav        { display: none; }
.mob-hamburger  { display: none; }
.mob-hide       { /* visible on desktop */ }
.rs-mob-btns    { display: none; }
.pg-side-toggle { display: none; }
#mob-ver-panel  { display: none; }
.mobile-card-sheet-hd,
.mobile-card-sheet-backdrop { display: none; }

/* ── Aperçu grand format (long press mobile) ── */
.mob-big-preview {
  position: fixed;
  inset: 0;
  z-index: 10000;
  background: rgba(0,0,0,.88);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  pointer-events: none;
  animation: mob-big-in .12s ease both;
}
.mob-big-preview.on { display: flex; }
.mob-big-preview img {
  max-width: 92vw;
  max-height: 78vh;
  border-radius: 10px;
  box-shadow: 0 20px 60px rgba(0,0,0,.7);
}
.mob-big-hint {
  position: absolute;
  bottom: 24px;
  left: 0; right: 0;
  text-align: center;
  font-size: 12px;
  color: rgba(255,255,255,.55);
  letter-spacing: .4px;
}
@keyframes mob-big-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

@media (max-width: 1024px) {

  /* ─── SIDEBAR → MASQUÉE, MOBILE HEADER → VISIBLE ───────────── */
  #sidebar { display: none !important; }
  #mob-header { display: flex !important; }
  #app { flex-direction: column !important; }

  /* Deck identity in mob-header */
  #mob-header .deck-identity-btn { max-width: 160px; padding: 4px 8px 4px 5px; box-shadow: none; }
  #mob-header .deck-identity-name { max-width: 100px; font-size: 11px; }
  #mob-header .deck-identity-meta { display: none; }
  #mob-header .deck-identity-art  { width: 26px; height: 26px; }

  /* Hamburger : visible à droite */
  .mob-hamburger { margin-left: 0; }

  /* Deck identity: smaller + shrinkable */
  .deck-identity-btn { max-width: 160px !important; min-width: 0 !important; flex-shrink: 1 !important; padding: 4px 8px 4px 5px !important; box-shadow: none !important; }
  .deck-identity-info { min-width: 0; flex: 1; overflow: hidden; }
  .deck-identity-name { max-width: none; font-size: 11px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .deck-identity-meta { display: none; }
  .deck-identity-art  { width: 26px; height: 26px; flex-shrink: 0; }

  /* Undo/Redo header buttons */
  .mob-hdr-btn {
    display: flex; align-items: center; justify-content: center;
    width: 32px; height: 32px; border-radius: 8px;
    border: 1px solid rgba(123,97,255,.2); background: transparent;
    color: var(--tx2); font-size: 15px; cursor: pointer;
    font-family: inherit; flex-shrink: 0; transition: .15s;
  }
  .mob-hdr-btn:active { background: rgba(123,97,255,.15); color: var(--tx); }
  .mob-tag-btn {
    display: flex; align-items: center; justify-content: center;
    width: 32px; height: 32px; border-radius: 8px; flex-shrink: 0;
    border: 1px solid rgba(167,139,250,.18); background: rgba(167,139,250,.07);
    color: #d4cafe; font-size: 15px; font-weight: 600; cursor: pointer;
    font-family: inherit; transition: .15s;
  }
  .mob-tag-btn:hover { border-color: rgba(167,139,250,.4); background: rgba(123,97,255,.16); color: #f0eeff; }
  .mob-tag-btn.mob-tag-btn-active { border-color: rgba(167,139,250,.7); background: rgba(123,97,255,.25); color: #e2d9ff; box-shadow: inset 0 1px 4px rgba(0,0,0,.3), 0 0 0 2px rgba(167,139,250,.18); }

  /* Hamburger */
  .mob-hamburger {
    display: flex;
    width: 36px; height: 36px;
    border-radius: 9px;
    border: 1px solid rgba(123,97,255,.25);
    background: rgba(123,97,255,.1);
    align-items: center; justify-content: center;
    cursor: pointer; flex-shrink: 0;
    color: var(--tx2); font-size: 18px;
    transition: .18s; font-family: inherit;
  }
  .mob-hamburger:hover, .mob-hamburger:active {
    background: rgba(123,97,255,.22);
    border-color: rgba(167,139,250,.5);
    color: var(--tx);
  }

  /* ─── LEFT DRAWER NAV (portal, fixed) ────────────────────── */
  .mob-sheet-backdrop {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.52);
    backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px);
    z-index: 99980;
    pointer-events: auto;
    touch-action: none;
    animation: mob-backdrop-in .2s ease both;
  }
  @keyframes mob-backdrop-in {
    from { opacity: 0; } to { opacity: 1; }
  }
  .mob-sheet {
    position: fixed;
    top: 0; left: 0; bottom: 0;
    width: min(82vw, 300px);
    background: var(--sur);
    border-radius: 0 18px 18px 0;
    border-right: 1px solid rgba(123,97,255,.2);
    z-index: 99981;
    padding: 0;
    box-shadow: 8px 0 48px rgba(0,0,0,.55);
    animation: mob-sheet-in .24s cubic-bezier(.22,1,.36,1) both;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
  }
  @keyframes mob-sheet-in {
    from { transform: translateX(-100%); }
    to   { transform: translateX(0); }
  }
  /* Header de la nav */
  .mob-nav-hd {
    display: flex; align-items: center; justify-content: space-between;
    padding: 0 12px 0 18px;
    height: 52px; flex-shrink: 0;
    border-bottom: 1px solid rgba(123,97,255,.12);
    background: linear-gradient(90deg,rgba(123,97,255,.12),rgba(123,97,255,.04));
  }
  .mob-nav-hd-title {
    font-family: var(--title, inherit); font-size: 13px; font-weight: 800;
    letter-spacing: 2.5px; text-transform: uppercase;
    background: linear-gradient(135deg,var(--tx),rgba(123,159,249,.9));
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  }
  .mob-nav-hd-close {
    width: 30px; height: 30px; border-radius: 8px; border: 1px solid rgba(123,97,255,.2);
    background: rgba(123,97,255,.08); color: var(--tx2); font-size: 14px;
    cursor: pointer; display: flex; align-items: center; justify-content: center; font-family: inherit;
  }
  .mob-nav-hd-close:active { background: rgba(239,68,68,.15); border-color: rgba(239,68,68,.4); color: #f87171; }
  /* Bouton Accueil */
  .mob-nav-home {
    display: flex; align-items: center; gap: 14px;
    padding: 14px 20px; font-size: 14px; font-weight: 700;
    color: var(--tx); text-decoration: none; cursor: pointer;
    border-bottom: 1px solid rgba(123,97,255,.1);
    background: rgba(123,97,255,.04);
    -webkit-tap-highlight-color: transparent; flex-shrink: 0;
  }
  .mob-nav-home:active { background: rgba(123,97,255,.12); }
  .mob-nav-home-icon { font-size: 19px; width: 28px; text-align: center; flex-shrink: 0; }
  /* Section user */
  .mob-sheet-handle { display: none; }
  .mob-sheet-user {
    display: flex; flex-direction: column; gap: 10px;
    padding: 14px 16px; border-bottom: 1px solid rgba(123,97,255,.1);
    flex-shrink: 0;
  }
  .mob-sheet-user-top { display: flex; align-items: center; gap: 10px; }
  .mob-sheet-avatar {
    width: 34px; height: 34px; border-radius: 50%; object-fit: cover; flex-shrink: 0;
  }
  .mob-sheet-avatar-ph {
    width: 34px; height: 34px; border-radius: 50%;
    background: rgba(123,97,255,.15);
    display: flex; align-items: center; justify-content: center; font-size: 17px; flex-shrink: 0;
  }
  .mob-sheet-user-meta {
    flex: 1; min-width: 0;
    display: flex; flex-direction: column; gap: 3px;
  }
  .mob-sheet-username {
    font-size: 14px; font-weight: 700; color: var(--tx); min-width: 0;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  }
  .mob-sheet-plan {
    display: inline-flex; align-items: center; align-self: flex-start;
    height: 18px; padding: 0 7px; border-radius: 99px;
    background: rgba(123,97,255,.12); border: 1px solid rgba(123,97,255,.26);
    color: #c4b5fd; font-size: 9px; font-weight: 800; letter-spacing: .35px;
  }
  .mob-sheet-plan--free { background:rgba(148,163,184,.1);border-color:rgba(148,163,184,.24);color:var(--tx3) }
  .mob-sheet-plan--challenger { background:rgba(205,127,50,.14);border-color:rgba(205,127,50,.38);color:#cd7f32 }
  .mob-sheet-plan--fondateur { background:rgba(245,158,11,.14);border-color:rgba(245,158,11,.38);color:#f59e0b }
  .mob-sheet-plan--legende { background:rgba(192,132,252,.14);border-color:rgba(192,132,252,.38);color:#c084fc }
  .mob-sheet-logout {
    padding: 7px 12px; border-radius: 8px; font-size: 11px; font-weight: 800;
    background: rgba(239,68,68,.1); border: 1px solid rgba(239,68,68,.3); color: #f87171;
    cursor: pointer; font-family: inherit; width: 100%;
  }
  .mob-sheet-login-btn {
    display: flex; align-items: center; justify-content: center; gap: 6px;
    padding: 9px 12px; border-radius: 8px; font-size: 12px; font-weight: 700;
    background: rgba(123,97,255,.12); border: 1px solid rgba(123,97,255,.3); color: var(--tx2);
    text-decoration: none; cursor: pointer;
  }
  .mob-sheet-divider { display: none; }
  /* Liste d'actions verticale */
  .mob-sheet-grid {
    display: flex; flex-direction: column; flex: 1;
  }
  .mob-sheet-grid-tools { /* unused in drawer */ }
  .mob-sheet-btn {
    display: flex; flex-direction: row; align-items: center;
    gap: 14px; padding: 14px 20px;
    border: none; border-bottom: 1px solid rgba(123,97,255,.07);
    background: transparent; color: var(--tx2);
    font-size: 14px; font-weight: 600; font-family: inherit;
    cursor: pointer; text-align: left; transition: background .12s;
    width: 100%; -webkit-tap-highlight-color: transparent;
  }
  .mob-sheet-btn:active { background: rgba(123,97,255,.1); color: var(--tx); }
  .mob-sheet-btn.prim { color: #c4b5fd; }
  .mob-sheet-btn.dng  { color: #f87171; }
  .mob-sheet-ico { font-size: 20px; line-height: 1; width: 28px; text-align: center; flex-shrink: 0; }
  .mob-sheet-btn--active { background: rgba(123,97,255,.12) !important; color: #c4b5fd !important; }
  /* Chevron pour les sous-menus */
  .mob-sheet-btn--active::after { content:'▾'; margin-left:auto; font-size:12px; opacity:.6; }
  .mob-sheet-btn:not(.mob-sheet-btn--active):has(+ .mob-sheet-submenu)::after,
  .mob-sheet-btn:not(.mob-sheet-btn--active)[data-submenu]::after { content:'›'; margin-left:auto; font-size:16px; opacity:.4; }
  /* Sous-menus inline */
  .mob-sheet-submenu {
    background: rgba(123,97,255,.04);
    border-bottom: 1px solid rgba(123,97,255,.1);
    overflow: hidden;
    animation: mob-sheet-sub-in .15s ease both;
  }
  @keyframes mob-sheet-sub-in {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: none; }
  }
  .mob-sheet-sub-item {
    display: flex; align-items: center; gap: 12px;
    width: 100%; padding: 12px 20px 12px 54px;
    background: none; border: none; border-bottom: 1px solid rgba(123,97,255,.06);
    color: var(--tx3); font-size: 13px; font-weight: 600;
    font-family: inherit; cursor: pointer; text-align: left; transition: .12s;
  }
  .mob-sheet-sub-item:last-child { border-bottom: none; }
  .mob-sheet-sub-item:active { background: rgba(123,97,255,.1); color: var(--tx); }

  .mob-sheet-lang {
    display: flex; align-items: center; justify-content: center; gap: 8px;
    padding: 14px 20px; margin-top: auto;
    border-top: 1px solid rgba(123,97,255,.1);
    flex-shrink: 0;
  }
  .mob-sheet-lang-btn {
    background: none; border: 1px solid rgba(123,97,255,.2); border-radius: 8px;
    color: var(--tx3); font-size: 12px; font-weight: 800; letter-spacing: 1.5px;
    padding: 5px 14px; cursor: pointer; font-family: inherit;
    -webkit-tap-highlight-color: transparent; transition: .12s;
  }
  .mob-sheet-lang-btn.active {
    background: rgba(123,97,255,.18); border-color: rgba(123,97,255,.5); color: #c4b5fd;
  }
  .mob-sheet-lang-btn:active { opacity: .7; }
  .mob-sheet-lang-sep { color: var(--tx3); opacity: .4; font-size: 13px; }

  .proba-setup-body { padding: 14px; gap: 12px; }
  .proba-setup-intro,
  .proba-setup-footer { flex-direction: column; align-items: stretch; }
  .proba-setup-intro h2 { font-size: 17px; }
  .proba-setup-steps { grid-template-columns: 1fr; }
  .proba-setup-panel { grid-template-columns: 1fr; padding: 14px; }
  .proba-setup-actions { display: grid; grid-template-columns: 1fr; }

  /* ─── DROPDOWNS : full-width depuis le haut sur mobile ─────── */
  #dl-menu, #tools-menu {
    top: 56px !important;
    left: 8px !important;
    right: 8px !important;
    width: auto !important;
    min-width: 0 !important;
    border-radius: 12px !important;
  }

  /* ─── MAIN LAYOUT ─────────────────────────────────────────── */
  body.builder-page #app-content { height: 100vh; height: 100dvh; overflow: hidden; }
  body.builder-page #lay { overflow: hidden; position: relative; flex: 1; min-width: 0; }

  .resizer { display: none !important; }

  /* All panels: base hidden, full-width, no margin/radius */
  #pnl-search,
  #pnl-deck,
  #p-det {
    display: none !important;
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    margin: 0 !important;
    border-radius: 0 !important;
    border: none !important;
    box-shadow: none !important;
    flex-shrink: 0 !important;
  }
  #pnl-deck {
    --tag-help-bottom: calc(78px + env(safe-area-inset-bottom));
  }
  #pnl-deck.tag-mode-active .tag-mode-overlay {
    position: fixed !important;
    inset: 0 !important;
    z-index: 1001 !important;
    box-shadow: none !important;
  }
  #pnl-deck.tag-mode-active .tag-mode-help {
    position: fixed !important;
    left: 50% !important;
    right: auto !important;
    bottom: calc(72px + env(safe-area-inset-bottom)) !important;
    z-index: 1002 !important;
    width: min(380px, calc(100vw - 24px)) !important;
  }
  .tag-help-copy-desktop{display:none}
  .tag-help-copy-mobile{display:inline}

  /* Show active tab */
  #lay[data-mob-tab="search"]  #pnl-search    { display: flex !important; }
  #lay[data-mob-tab="deck"]    #pnl-deck      { display: flex !important; }
  #lay[data-mob-tab="history"] #mob-ver-panel { display: flex !important; }

  .mobile-card-sheet-backdrop {
    display: block;
    position: fixed;
    inset: 0;
    z-index: 1180;
    background: rgba(0,0,0,.58);
    animation: mob-backdrop-in .18s ease both;
    transition: background .22s ease;
  }
  .mobile-card-sheet-backdrop.is-peek {
    background: rgba(0,0,0,.22);
    pointer-events: none;
  }
  #p-det.mobile-card-sheet-open {
    display: flex !important;
    position: fixed !important;
    top: auto !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: min(88dvh, 720px) !important;
    max-height: 88dvh !important;
    z-index: 1190 !important;
    border-radius: 16px 16px 0 0 !important;
    border: 1px solid rgba(123,159,249,.22) !important;
    border-bottom: 0 !important;
    background: var(--sur) !important;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    box-shadow: 0 -18px 52px rgba(0,0,0,.58), 0 0 0 1px rgba(123,159,249,.06) inset !important;
    overflow: hidden !important;
    animation: mob-sheet-in .22s cubic-bezier(.22,1,.36,1) both;
    transition: height .28s cubic-bezier(.22,1,.36,1), max-height .28s cubic-bezier(.22,1,.36,1), border-radius .2s ease;
    will-change: height;
  }
  #p-det.mobile-card-sheet-open[data-sheet-level="peek"] {
    height: min(42dvh, 360px) !important;
    max-height: 42dvh !important;
  }
  #p-det.mobile-card-sheet-open .mobile-card-sheet-hd {
    display: flex;
    position: relative;
    min-height: 58px;
    flex-shrink: 0;
    align-items: center;
    justify-content: flex-start;
    gap: 12px;
    padding: 10px 48px 10px 16px;
    background: linear-gradient(135deg,rgba(123,97,255,.06),rgba(244,114,182,.03));
    border-bottom: 1px solid rgba(123,159,249,.12);
    touch-action: none;
    cursor: grab;
  }
  .mobile-card-sheet-handle {
    position: absolute;
    top: 6px;
    left: 50%;
    transform: translateX(-50%);
    width: 34px;
    height: 4px;
    border-radius: 99px;
    background: rgba(123,159,249,.34);
  }
  .mobile-card-sheet-title {
    min-width: 0;
    max-width: 100%;
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding-top: 5px;
  }
  .mobile-card-sheet-kicker {
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--blue);
  }
  .mobile-card-sheet-title strong {
    font-family: var(--ui);
    font-size: 16px;
    line-height: 1.15;
    letter-spacing: 0;
    color: var(--tx);
    font-weight: 850;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .mobile-card-sheet-close {
    position: absolute;
    right: 12px;
    top: 12px;
    width: 34px;
    height: 34px;
    border-radius: 8px;
    border: 1px solid rgba(123,159,249,.22);
    background: rgba(123,159,249,.08);
    color: var(--tx2);
    font: 800 18px/1 system-ui, sans-serif;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
  }
  .mobile-card-sheet-close:active {
    background: rgba(123,159,249,.14);
    color: var(--tx);
  }

  /* Réserver l'espace en bas du deck panel pour la mob-nav (recherche/deck/cartes)
     sinon le Side Deck et les infos Carte sont cachés derrière la nav fixée.
     #det-scroll est l'élément qui scroll réellement, c'est lui qui doit porter le padding */
  #pnl-deck .dscroll,
  #det-scroll,
  .d-body {
    padding-bottom: calc(58px + env(safe-area-inset-bottom) + 16px) !important;
  }
  /* Fix Chrome/WebKit: padding-bottom sur un flex-column scroll container
     n'est pas respecté à la fin du scroll. On ajoute un spacer ::after dans
     .dscroll pour garantir que la dernière .sec-block (Side) soit visible
     au-dessus de la mob-nav fixée. */
  #pnl-deck .dscroll::after {
    content: '';
    display: block;
    flex-shrink: 0;
    height: calc(58px + env(safe-area-inset-bottom) + 16px);
  }
  body.builder-page.deck-tools-panel-open #pnl-deck .dscroll {
    padding-bottom: 16px !important;
  }
  body.builder-page.deck-tools-panel-open #pnl-deck .dscroll::after {
    height: calc(230px + 58px + env(safe-area-inset-bottom) + 20px);
  }

  /* ─── SEARCH PANEL ────────────────────────────────────────── */
  .sh-format-bar {
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 5px;
    scrollbar-width: none;
    padding-bottom: 6px;
  }
  .sh-format-bar::-webkit-scrollbar { display: none; }
  .fmt-pill { font-size: 12px; padding: 5px 11px; flex-shrink: 0; }

  /* Grid: gap et padding forcés avec !important pour écraser les inline styles du JSX.
     grid-template-columns est contrôlé par JS (inline style), pas !important ici. */
  #res-g {
    gap: 4px !important;
    padding: 6px 8px 16px !important;
    grid-template-columns: repeat(auto-fill, minmax(75px, 1fr));
    overflow-x: hidden !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    min-height: 0 !important;
  }
  /* Réserver l'espace en bas du panneau search (parent du grid) pour que
     #res-g flex:1 ait une hauteur correcte qui exclut pagination + mob-nav */
  #pnl-search #panel-results {
    padding-bottom: calc(50px + 58px + env(safe-area-inset-bottom) + 8px) !important;
  }
  #res-g .rg, #res-g .rg-wrap { min-width: 0; max-width: 100%; }
  #res-g .rg img { max-width: 100%; height: auto; }

  /* ─── DECK PANEL ──────────────────────────────────────────── */
  /* Cards: remove button always visible; arrows + overlay hidden */
  .dc-card-rm    { opacity: 1 !important; width: 18px; height: 18px; font-size: 9px; }
  .dc-ban-badge  { top: 2px !important; right: auto !important; left: 2px !important; z-index: 4 !important; }
  .dc-moves      { display: none !important; }
  .dc-card-overlay { display: none !important; }
  .dc-card:hover,
  .dc-card:focus,
  .dc-card:active { transform: none !important; box-shadow: none !important; border-color: transparent !important; z-index: auto !important; }
  .dc-card.deck-sel,
  .dc-card.deck-sel:hover,
  .dc-card.deck-sel:focus,
  .dc-card.deck-sel:active { border-color: rgba(168,85,247,.9) !important; box-shadow: 0 0 0 2px rgba(168,85,247,.35),0 0 14px rgba(168,85,247,.4) !important; z-index: 50 !important; }

  /* ─── RECHERCHE : suppression des hovers (tactile) ──────────── */
  /* Vue grille */
  .rg-wrap:hover { z-index: 1 !important; }
  .rg-wrap:hover .rg { transform: none !important; box-shadow: 0 2px 8px rgba(0,0,0,.2) !important; }
  .rg-wrap:hover .rg-md-badge { transform: none !important; }
  .rg:hover { border-color: transparent !important; }
  /* Vue liste */
  .ri:hover { background: transparent !important; border-color: transparent !important; transform: none !important; box-shadow: none !important; }

  /* Cartes du deck plus grandes sur mobile : override la grille inline (10 cols) */
  .cards-grid { grid-template-columns: repeat(6, 1fr) !important; gap: 4px !important; }
  /* Extra/Side : grille identique au main deck sur mobile (strip remplacé par _renderNormalGrid) */

  /* Sec head : scrollable horizontalement, pas de wrap */
  .sec-hd {
    padding: 10px 12px;
    overflow-x: auto;
    overflow-y: hidden;
    flex-wrap: nowrap !important;
    white-space: nowrap;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }
  .sec-hd::-webkit-scrollbar { display: none; }
  .sec-hd > * { flex-shrink: 0; }

  /* ─── MAIN DECK header : 2 lignes sur mobile ────────────── */
  /* Ligne 1 : icon + nom + compteur + prix + tags + collapse  */
  /* Ligne 2 : Groupes + Combos + ⇅ + vue (via order:10)      */
  .sec-hd[data-sec="main"] {
    flex-wrap: wrap !important;
    overflow-x: visible !important;
    overflow-y: visible !important;
    white-space: normal !important;
    align-items: center;
    row-gap: 6px;
  }
  .sec-hd[data-sec="main"] > * { flex-shrink: 1; }
  .sec-hd[data-sec="main"] .sec-hd-name { flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .sec-hd[data-sec="main"] .sec-hd-cnt,
  .sec-hd[data-sec="main"] .sec-hd-price,
  .sec-hd[data-sec="main"] .sec-collapse-btn { flex-shrink: 0; }
  .sec-hd-controls {
    order: 10;
    width: 100%;
    margin-left: 0 !important;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 2px;
  }
  .sec-hd-controls::-webkit-scrollbar { display: none; }
  .sec-hd-controls > * { flex-shrink: 0; }
  /* Vue toggle poussée à droite de la ligne 2 */
  .sec-hd-controls .deck-view-btns { margin-left: auto; }

  /* Boutons controls : version compacte sur mobile */
  .deck-head-action { width: 34px; height: 32px; }
  .deck-head-action-tags { width: 34px; padding: 0; gap: 0; }
  .deck-head-action-tags span { display: none; }
  /* Textes longs masqués sur mobile, version courte affichée */
  .btn-short { display: inline; }
  .btn-txt   { display: none; }
  /* Tags : icône seulement (img toujours visible, texte masqué via btn-txt) */
  #tag-mode-btn-deck { padding: 5px 8px; }

  /* ─── Collapse buttons : zone tactile agrandie ───────────── */
  .sec-collapse-btn {
    min-width: 34px;
    min-height: 32px;
    padding: 5px 10px;
    font-size: 11px;
  }

  /* ─── Boutons de mise en page (🃏 / 🎨 / ☰) ─────────────── */
  .deck-vb {
    width: 36px;
    height: 32px;
  }

  /* Vue decklist mobile : sections empilées, pas 3 colonnes serrées */
  .deck-list-hdr {
    padding: 9px 10px !important;
    gap: 5px !important;
  }
  .deck-list-cols {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    padding: 8px 10px calc(78px + env(safe-area-inset-bottom)) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }
  .deck-list-col {
    width: 100% !important;
    flex: 0 0 auto !important;
    min-height: 0 !important;
    border-radius: 12px !important;
    background: rgba(10,8,26,.46);
  }
  .deck-list-col-hd {
    min-height: 40px !important;
    padding: 8px 10px !important;
    font-size: 12px !important;
    position: sticky;
    top: 0;
    z-index: 2;
    backdrop-filter: blur(10px);
  }
  .deck-list-items {
    overflow: visible !important;
    padding: 5px !important;
  }
  .deck-list-row {
    min-height: 48px !important;
    padding: 6px 7px !important;
    gap: 8px !important;
    border-radius: 9px !important;
    font-size: 12px !important;
  }
  .deck-list-row > div:first-child {
    width: 4px !important;
    height: 34px !important;
  }
  .deck-list-row > img {
    width: 32px !important;
    height: 46px !important;
  }
  .deck-list-row > div:nth-child(3) > div:first-child {
    font-size: 13px !important;
    line-height: 1.18 !important;
  }
  .deck-list-row .dlv-btn-add,
  .deck-list-row .dlv-btn-rm {
    width: 30px !important;
    height: 30px !important;
    border-radius: 8px !important;
    font-size: 15px !important;
  }

  /* ─── BOUTONS MOB + / - (3 vues) ────────────────────────── */

  /* Force l'affichage des boutons +/- sur mobile (écrase le display:none global) */
  .rg-mob-btns { display: flex !important; }
  .ri-mob-btns { display: inline-flex !important; }
  .rm-mob-btns { display: inline-flex !important; }

  .rg-wrap {
    display: flex !important;
    flex-direction: column;
    overflow: visible !important; /* pas de clipping des boutons */
    border-radius: 6px;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
  }
  .ri, .rm-card { -webkit-touch-callout: none; -webkit-user-select: none; user-select: none; }

  /* Grille : hauteur de ligne = contenu réel (inclut la barre boutons) */
  #res-g { grid-auto-rows: max-content !important; }

  /* Base commune à tous les boutons +/- */
  .rs-mob-btn {
    padding: 0;
    background: transparent;
    border: none;
    font-size: 15px;
    font-weight: 800;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: inherit;
    transition: background .12s, color .12s, transform .1s;
    -webkit-tap-highlight-color: transparent;
  }
  .rs-mob-btn > span { display: block; transform: translateY(-1px); }
  .rs-mob-minus { color: #fca5a5; }
  .rs-mob-plus  { color: #86efac; }
  .rs-mob-minus:active { color: #fecaca; transform: scale(.92); }
  .rs-mob-plus:active  { color: #bbf7d0; transform: scale(.92); }

  /* ── Vue GRILLE : barre sous la carte ── */
  .rg-mob-btns {
    display: flex !important;
    width: 100%;
    flex-shrink: 0;
    background: linear-gradient(180deg, rgba(10,8,26,.6) 0%, rgba(10,8,26,.92) 100%);
    border-top: 1px solid rgba(167,139,250,.18);
    border-radius: 0 0 6px 6px;
  }
  .rg-mob-btns .rs-mob-btn { flex: 1; height: 26px; }
  .rg-mob-btns .rs-mob-minus { border-right: 1px solid rgba(167,139,250,.14); }
  .rg-mob-btns .rs-mob-minus:active { background: rgba(248,113,113,.22); }
  .rg-mob-btns .rs-mob-plus:active  { background: rgba(74,222,128,.22); }

  /* ── Vue LISTE : paire de boutons ronds à droite ── */
  .ri { padding-right: 6px; }
  .ri-mob-btns {
    display: inline-flex !important;
    gap: 4px;
    margin-left: auto;
    flex-shrink: 0;
    align-self: center;
  }
  .ri-mob-btns .rs-mob-btn {
    width: 32px; height: 32px;
    border-radius: 50%;
    border: 1px solid rgba(167,139,250,.2);
    background: rgba(10,8,26,.6);
  }
  .ri-mob-btns .rs-mob-minus { border-color: rgba(248,113,113,.35); }
  .ri-mob-btns .rs-mob-plus  { border-color: rgba(74,222,128,.35); }
  .ri-mob-btns .rs-mob-minus:active { background: rgba(248,113,113,.25); }
  .ri-mob-btns .rs-mob-plus:active  { background: rgba(74,222,128,.25); }

  /* ── Vue MINIMALE : paire de boutons ronds à droite ── */
  .rm-card { padding-right: 4px; }
  .rm-mob-btns {
    display: inline-flex !important;
    gap: 3px;
    margin-left: auto;
    flex-shrink: 0;
    align-self: center;
    padding-left: 4px;
  }
  .rm-mob-btns .rs-mob-btn {
    width: 26px; height: 26px;
    border-radius: 50%;
    border: 1px solid rgba(167,139,250,.2);
    background: rgba(10,8,26,.6);
    font-size: 14px;
  }
  .rm-mob-btns .rs-mob-minus { border-color: rgba(248,113,113,.35); }
  .rm-mob-btns .rs-mob-plus  { border-color: rgba(74,222,128,.35); }
  .rm-mob-btns .rs-mob-minus:active { background: rgba(248,113,113,.25); }
  .rm-mob-btns .rs-mob-plus:active  { background: rgba(74,222,128,.25); }

  /* ─── TOGGLE SIDE DECK dans la barre de pagination ──────── */
  .pg-side-toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-left: 6px;
    padding: 0 12px;
    height: 36px;
    border-radius: 10px;
    border: 1.5px solid rgba(59,130,246,.45);
    background: linear-gradient(180deg, rgba(59,130,246,.12) 0%, rgba(59,130,246,.04) 100%);
    color: #93c5fd;
    font-size: 13px;
    font-weight: 800;
    cursor: pointer;
    font-family: inherit;
    letter-spacing: .3px;
    transition: background .15s, border-color .15s, color .15s, transform .1s;
    flex-shrink: 0;
    box-shadow: 0 2px 6px rgba(59,130,246,.15);
  }
  .pg-side-toggle .pg-side-ic  { font-size: 15px; line-height: 1; }
  .pg-side-toggle .pg-side-lbl { font-size: 12px; }
  .pg-side-toggle:active { transform: scale(.96); }
  .pg-side-toggle.on {
    background: linear-gradient(180deg, #3b82f6 0%, #2563eb 100%);
    border-color: #60a5fa;
    color: #fff;
    box-shadow: 0 2px 10px rgba(59,130,246,.45), inset 0 0 0 1px rgba(255,255,255,.15);
  }

  /* Pagination mobile : FIXÉE en bas, juste au-dessus de la .mob-nav */
  #pnl-search .sh-pagination {
    display: flex !important;
    flex-wrap: nowrap;
    padding: 6px 8px;
    gap: 4px;
    flex-shrink: 0;
    position: fixed !important;
    left: 0;
    right: 0;
    bottom: calc(58px + env(safe-area-inset-bottom));
    z-index: 1001;
    background: linear-gradient(180deg, rgba(10,8,26,.96), rgba(10,8,26,.99));
    border-top: 1px solid rgba(123,97,255,.25);
    box-shadow: 0 -4px 14px rgba(0,0,0,.45);
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    min-height: 44px;
    align-items: center;
    justify-content: center;
  }
  /* Cacher la pagination si l'onglet actif n'est pas "search" */
  #lay:not([data-mob-tab="search"]) #pnl-search .sh-pagination {
    display: none !important;
  }
  #pnl-search .sh-pagination::-webkit-scrollbar { display: none; }
  .sh-pagination #pg-info { font-size: 11px; flex-shrink: 0; white-space: nowrap; }
  .sh-pagination #pg-info input { font-size: 11px !important; }
  .sh-pagination .pg-btn  { width: 32px; height: 32px; font-size: 13px; flex-shrink: 0; }
  .sh-pagination .pg-zoom { width: 30px; height: 30px; font-size: 15px; flex-shrink: 0; }
  .sh-pagination .pg-zoom-val { font-size: 10px; min-width: 32px; flex-shrink: 0; text-align: center; }
  /* Cacher first/last + zoom sur mobile (gain de place, garder prev/next) */
  .sh-pagination #pg-first,
  .sh-pagination #pg-last,
  .sh-pagination .pg-zoom,
  .sh-pagination .pg-zoom-val { display: none !important; }

  /* Compteur de cartes déplacé dans la pagination sur mobile */
  .sh-meta { display: none !important; }
  .pg-count-mob {
    display: inline !important;
    font-family: var(--title);
    font-size: 11px;
    color: var(--blue);
    white-space: nowrap;
    flex-shrink: 0;
    margin-right: 2px;
  }
  /* #res et #res-m (vues liste/compact) reçoivent juste un padding interne */
  #pnl-search #res,
  #pnl-search #res-m {
    padding-bottom: 16px !important;
    -webkit-overflow-scrolling: touch;
    min-height: 0 !important;
  }
  /* Cacher le suffixe "cartes" à côté du compteur sur petit écran pour gagner de la place */
  @media (max-width: 380px) {
    .sh-pagination #pg-info .pg-info-suffix { display: none; }
  }

  /* ─── LIGHT MODE — pagination + boutons +/- ─────────────── */
  [data-theme="light"] #pnl-search .sh-pagination {
    background: linear-gradient(180deg, rgba(255,255,255,.97), rgba(244,244,246,.99));
    border-top-color: rgba(37,99,235,.15);
    box-shadow: 0 -4px 14px rgba(0,0,0,.08);
  }

  /* Barre de boutons sous chaque carte (vue grille) */
  [data-theme="light"] .rg-mob-btns {
    background: linear-gradient(180deg, rgba(244,244,246,.7) 0%, rgba(244,244,246,.97) 100%);
    border-top-color: rgba(37,99,235,.12);
  }
  [data-theme="light"] .rs-mob-minus { color: #dc2626; }
  [data-theme="light"] .rs-mob-plus  { color: #16a34a; }
  [data-theme="light"] .rs-mob-minus:active { color: #b91c1c; }
  [data-theme="light"] .rs-mob-plus:active  { color: #15803d; }
  [data-theme="light"] .rg-mob-btns .rs-mob-minus:active { background: rgba(220,38,38,.1); }
  [data-theme="light"] .rg-mob-btns .rs-mob-plus:active  { background: rgba(22,163,74,.1); }

  /* Boutons ronds (vues liste et minimale) */
  [data-theme="light"] .ri-mob-btns .rs-mob-btn,
  [data-theme="light"] .rm-mob-btns .rs-mob-btn {
    background: #ffffff;
    border-color: rgba(37,99,235,.2);
  }
  [data-theme="light"] .ri-mob-btns .rs-mob-minus,
  [data-theme="light"] .rm-mob-btns .rs-mob-minus { border-color: rgba(220,38,38,.35); }
  [data-theme="light"] .ri-mob-btns .rs-mob-plus,
  [data-theme="light"] .rm-mob-btns .rs-mob-plus  { border-color: rgba(22,163,74,.35); }
  [data-theme="light"] .ri-mob-btns .rs-mob-minus:active,
  [data-theme="light"] .rm-mob-btns .rs-mob-minus:active { background: rgba(220,38,38,.1); }
  [data-theme="light"] .ri-mob-btns .rs-mob-plus:active,
  [data-theme="light"] .rm-mob-btns .rs-mob-plus:active  { background: rgba(22,163,74,.1); }

  /* ─── DETAIL PANEL (onglet Carte) ─────────────────────────── */
  /* Scroll global : #det-scroll gère tout, .d-body ne scroll plus seul */
  #p-det { margin: 0 !important; border-radius: 0 !important; box-shadow: none !important; background: var(--bg) !important; border: none !important; }
  /* #det-scroll est le seul scrolleur — ses enfants doivent être de hauteur naturelle */
  #det-scroll { -webkit-overflow-scrolling: touch; overflow-y: auto !important; }
  #p-det.mobile-card-sheet-open #det-scroll { padding-bottom: calc(16px + env(safe-area-inset-bottom)) !important; }
  #det { flex: none !important; min-height: 0; }
  #p-det.mobile-card-sheet-open .d-detail-card { margin: 14px; border: 1px solid var(--bor); border-radius: 10px; background: var(--sur2); box-shadow: none; }
  .d-detail-card { margin: 10px 10px 0; border-radius: 12px; }
  .d-top { flex-direction: row; flex-wrap: nowrap; flex-shrink: 0; align-items: stretch; border-bottom: 0 !important; background: linear-gradient(180deg,rgba(123,159,249,.04),transparent); }
  .d-img-col { width: 104px !important; min-width: 104px !important; display: flex; justify-content: center; align-items: center; padding: 10px 0 10px 10px; background: none; }
  .d-img {
    width: 86px !important;
    border-radius: 9px !important;
    box-shadow: 0 12px 34px rgba(0,0,0,.45), 0 0 0 1px rgba(123,159,249,.20) !important;
  }
  .d-img-hint { display: none; }
  .d-info-col { border-left: none !important; border-top: 0 !important; padding: 10px 12px 10px 8px; gap: 6px; text-align: left; align-items: stretch; }
  .d-name { display: none !important; }
  .d-badges, .d-stats-row, .d-prix-row { justify-content: flex-start; }
  .bdg { min-height: 18px; padding: 2px 7px; font-size: 8.5px; gap: 4px; }
  .bdg-dot { width: 4px; height: 4px; }
  .d-add-row { grid-template-columns: repeat(3,1fr); padding: 10px 14px 0; margin: 0; gap: 8px; border-radius: 0; background: transparent; }
  .d-add { min-height: 54px; padding: 6px 7px 7px; border: 1px solid var(--bor) !important; border-radius: 8px; background: var(--sur3) !important; box-shadow: none !important; color: var(--tx2) !important; font-size: 12px; letter-spacing: 0; text-transform: none; font-weight: 850; display: grid !important; grid-template-areas: "lbl lbl lbl" "minus cnt plus"; grid-template-columns: 28px 1fr 28px; grid-template-rows: auto auto; gap: 4px 5px; text-align: center; }
  .d-add--main { border-color: rgba(123,159,249,.45) !important; background: linear-gradient(135deg,var(--blue),var(--blue2)) !important; color: #fff !important; }
  .d-add--extra, .d-add--side { border-color: var(--bor) !important; background: var(--sur3) !important; color: var(--tx2) !important; }
  .d-add:active { filter: brightness(1.06); transform: none !important; }
  .d-add-ico { display: none; }
  .d-add-label-wrap { display: contents; }
  .d-add-lbl { grid-area: lbl; font-size: 11px; font-weight: 850; letter-spacing: .3px; align-self: end; text-align: center; }
  .d-add-count { grid-area: cnt; min-width: 24px; height: 24px; border-radius: 999px; background: rgba(123,159,249,.13); border-color: rgba(123,159,249,.24); color: var(--tx); font-size: 12px; align-self: center; justify-self: center; }
  .d-add--main .d-add-count { background: rgba(255,255,255,.18); border-color: rgba(255,255,255,.26); color: #fff; }
  .d-add-step--minus { grid-area: minus; }
  .d-add-step--plus { grid-area: plus; }
  .d-add-step { width: 28px; height: 28px; border-radius: 8px; background: rgba(0,0,0,.12); border-color: rgba(255,255,255,.14); color: inherit; font-size: 16px; align-self: center; }
  .d-add--extra .d-add-step,
  .d-add--side .d-add-step { background: var(--sur2); border-color: var(--bor); color: var(--tx2); }
  .d-explorer-row { padding: 8px 14px 12px; }
  .d-explorer-btn { min-height: 40px; border: 1px solid rgba(123,159,249,.25) !important; border-radius: 8px !important; background: rgba(123,159,249,.08) !important; box-shadow: none !important; color: var(--tx2) !important; font-size: 12px; font-weight: 750; letter-spacing: 0; }
  .d-explorer-btn:active { border-color: rgba(123,159,249,.5) !important; background: rgba(123,159,249,.14) !important; color: var(--tx) !important; transform: none !important; }
  /* .d-body ne scroll plus sur mobile : tout remonte à #det-scroll */
  .d-body { flex: none !important; overflow-y: visible !important; padding: 10px 14px 0; }
  .d-body--secondary { padding-top: 12px; }
  .d-desc { font-size: 12px; padding: 12px 14px; margin-bottom: 0; line-height: 1.65; border: 1px solid var(--bor); border-radius: 10px; background: var(--sur3); user-select: text; -webkit-user-select: text; }
  .d-lbl { font-size: 10px; margin-bottom: 6px; }
  .d-set-row { font-size: 11px; }
  .d-set-name { font-size: 12px; }
  .d-prix-val { font-size: 16px; }
  .d-prix-lbl { font-size: 8px; }
  .d-chart { height: 46px; margin-top: 1px; padding-bottom: 6px; box-sizing: border-box; }
  .d-chart canvas { display: block; }
  .d-stat { padding: 3px 8px; border-radius: 7px; }
  .d-stat-v { font-size: 12px; }

  /* ─── GROUPES PANEL → bottom sheet compact sur mobile ─────── */
  .cg-panel {
    top: auto !important;
    left: 0 !important;
    right: 0 !important;
    bottom: calc(58px + env(safe-area-inset-bottom)) !important;
    width: 100% !important;
    height: 230px;
    max-height: 230px;
    border-left: none !important;
    border-top: 1px solid var(--bor);
    border-radius: 16px 16px 0 0;
    transform: translateY(calc(100% + 2px)) !important;
    box-shadow: none;
    overflow: hidden;
  }
  .cg-panel.open {
    transform: translateY(0) !important;
    box-shadow: 0 -6px 24px rgba(0,0,0,.45);
  }
  .cg-panel--hidden { visibility: hidden !important; }

  /* ── Mobile panel header ── */
  .cg-mob-hd {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 0 14px 0 16px;
    height: 46px;
    flex-shrink: 0;
    background: var(--sur2);
    border-bottom: 1px solid var(--bor);
    position: relative;
  }
  .cg-mob-drag {
    position: absolute;
    top: 7px; left: 50%;
    transform: translateX(-50%);
    width: 36px; height: 4px;
    border-radius: 2px;
    background: var(--bor2);
    pointer-events: none;
  }
  .cg-mob-title {
    font-family: var(--title);
    font-size: 12px;
    letter-spacing: 1.5px;
    color: var(--tx);
    flex: 1;
    padding-top: 10px; /* descend sous le drag handle */
  }
  .cg-mob-add-btn {
    padding: 5px 11px;
    background: var(--blue);
    border: none;
    border-radius: 7px;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    cursor: pointer;
    flex-shrink: 0;
    transition: filter .15s;
  }
  .cg-mob-add-btn:active { filter: brightness(.88); }
  .cg-mob-exit {
    padding: 5px 10px !important;
    font-size: 11px !important;
    flex-shrink: 0;
  }

  /* ── Chips horizontaux de groupe ── */
  .cg-mob-chips-row {
    display: flex;
    gap: 6px;
    overflow-x: auto;
    padding: 8px 12px;
    flex-shrink: 0;
    height: 52px;
    align-items: center;
    background: var(--sur2);
    border-bottom: 1px solid var(--bor);
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .cg-mob-chips-row::-webkit-scrollbar { display: none; }

  .cg-mob-chip {
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 5px 8px 5px 5px;
    border-radius: 99px;
    border: 1.5px solid var(--bor2);
    background: var(--sur3);
    color: var(--tx2);
    font-size: 11px;
    font-weight: 600;
    white-space: nowrap;
    cursor: pointer;
    flex-shrink: 0;
    transition: border-color .15s, background .15s;
    user-select: none;
  }
  .cg-mob-chip--on {
    border-color: var(--c);
    background: var(--cbg);
    color: var(--tx);
  }
  .cg-mob-chip-dot {
    width: 18px; height: 18px;
    border-radius: 50%;
    color: #fff;
    font-size: 9px; font-weight: 800;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
  }
  .cg-mob-chip-name {
    max-width: 80px;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .cg-mob-chip-cnt {
    font-size: 9px;
    color: var(--tx3);
    background: var(--sur);
    border-radius: 99px;
    padding: 1px 5px;
    font-weight: 700;
    flex-shrink: 0;
  }
  .cg-mob-chip--on .cg-mob-chip-cnt {
    background: rgba(0,0,0,.25);
    color: #fff;
  }
  .cg-mob-chip-del {
    width: 15px; height: 15px;
    border-radius: 50%;
    background: var(--sur3);
    border: 1px solid var(--bor2);
    color: var(--tx3);
    font-size: 8px;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    margin-left: 1px;
    transition: .15s;
    line-height: 1;
  }
  .cg-mob-chip-del:active { border-color: var(--red); color: var(--red); }

  /* ── Barre groupe actif ── */
  .cg-mob-active-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px 14px;
    flex-shrink: 0;
    background: var(--sur);
    border-bottom: 1px solid var(--bor);
    min-height: 26px;
  }
  .cg-mob-active-label {
    font-size: 11px;
    font-weight: 700;
    flex: 1;
  }
  .cg-mob-active-cnt {
    font-size: 10px;
    color: var(--tx3);
  }

  /* ── Cartes du groupe actif ── */
  .cg-mob-cards-row {
    display: flex;
    gap: 6px;
    overflow-x: auto;
    padding: 8px 12px;
    align-items: center;
    flex: 1;
    background: var(--sur);
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .cg-mob-cards-row::-webkit-scrollbar { display: none; }

  .cg-mob-thumb {
    width: 34px; height: 49px;
    object-fit: cover;
    border-radius: 3px;
    border: 1.5px solid transparent;
    flex-shrink: 0;
    cursor: pointer;
    transition: opacity .15s;
  }
  .cg-mob-thumb:active { opacity: .65; }

  .cg-mob-hint {
    font-size: 11px;
    color: var(--tx3);
    font-style: italic;
    white-space: nowrap;
    line-height: 1.4;
    padding: 0 4px;
  }
  .cg-mob-hint--sub {
    font-size: 10px;
    padding-left: 8px;
    flex-shrink: 0;
  }

  /* ── Combos — barre de sélection en cours ── */
  .cl-mob-sel-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    flex-shrink: 0;
    height: 54px;
    background: color-mix(in srgb, var(--blue) 7%, var(--sur2));
    border-bottom: 1px solid var(--bor);
    overflow: hidden;
  }
  .cl-mob-pending-scroll {
    display: flex;
    gap: 5px;
    overflow-x: auto;
    align-items: center;
    flex: 1;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    height: 100%;
  }
  .cl-mob-pending-scroll::-webkit-scrollbar { display: none; }

  .cl-mob-pending-card {
    display: flex;
    align-items: center;
    gap: 3px;
    background: var(--sur3);
    border: 1px solid color-mix(in srgb, var(--blue) 35%, transparent);
    border-radius: 5px;
    padding: 3px 6px 3px 4px;
    flex-shrink: 0;
  }
  .cl-mob-qty {
    font-size: 9px;
    font-weight: 800;
    color: var(--blue);
    min-width: 14px;
  }
  .cl-mob-pending-img {
    width: 18px;
    height: 26px;
    object-fit: cover;
    border-radius: 2px;
    flex-shrink: 0;
  }
  .cl-mob-pending-name {
    font-size: 10px;
    font-weight: 600;
    color: var(--tx);
    max-width: 70px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .cl-mob-validate {
    padding: 6px 12px;
    background: var(--blue);
    border: none;
    border-radius: 7px;
    color: #fff;
    font-size: 12px;
    font-weight: 800;
    cursor: pointer;
    flex-shrink: 0;
    transition: filter .15s;
  }
  .cl-mob-validate:active { filter: brightness(.88); }

  /* ── Combos — liste des combos enregistrés ── */
  .cl-mob-combos-list {
    flex: 1;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 0;
    background: var(--sur);
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .cl-mob-combos-list::-webkit-scrollbar { display: none; }

  .cl-mob-combo-row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 7px 12px;
    border-bottom: 1px solid var(--bor);
    transition: opacity .2s;
  }
  .cl-mob-combo-row--hidden { opacity: .45; }

  .cl-mob-combo-badge {
    font-size: 9px;
    font-weight: 800;
    color: #fff;
    border-radius: 4px;
    padding: 2px 6px;
    white-space: nowrap;
    flex-shrink: 0;
  }
  .cl-mob-combo-thumbs {
    display: flex;
    gap: 3px;
    overflow-x: auto;
    flex: 1;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    align-items: center;
  }
  .cl-mob-combo-thumbs::-webkit-scrollbar { display: none; }

  .cl-mob-combo-thumb {
    width: 24px;
    height: 35px;
    object-fit: cover;
    border-radius: 2px;
    flex-shrink: 0;
  }
  .cl-mob-combo-eye,
  .cl-mob-combo-del {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 14px;
    padding: 4px;
    color: var(--tx3);
    flex-shrink: 0;
    line-height: 1;
    transition: color .15s;
  }
  .cl-mob-combo-eye:active { color: var(--gold); }
  .cl-mob-combo-del:active { color: var(--red); }

  /* ─── FOOTER: hidden on mobile ────────────────────────────── */
  #sbar-wrap { display: none !important; }

  /* ─── BOTTOM NAV ──────────────────────────────────────────── */
  .mob-nav {
    display: flex;
    position: fixed;
    left: 0; right: 0; bottom: 0;
    height: calc(58px + env(safe-area-inset-bottom));
    padding-bottom: env(safe-area-inset-bottom);
    flex-shrink: 0;
    background: var(--sur);
    border-top: 1px solid rgba(123,97,255,.18);
    z-index: 1000;
  }
  /* Reserve space at bottom of main layout so content isn't hidden under fixed mob-nav */
  body.builder-page #lay {
    padding-bottom: calc(58px + env(safe-area-inset-bottom));
  }
  .mob-nav-btn {
    flex: 1; display: flex; flex-direction: column;
    align-items: center; justify-content: center; gap: 2px;
    background: none; border: none; cursor: pointer;
    color: var(--tx3); font-size: 9px; font-weight: 700;
    letter-spacing: .6px; text-transform: uppercase;
    font-family: inherit; transition: color .15s;
    position: relative; padding: 0;
  }
  .mob-nav-icon { font-size: 19px; line-height: 1.2; }
  .mob-nav-btn:hover { color: var(--tx); }
  .mob-nav-btn.on  { color: #c4b5fd; }
  /* Prismatic top-line on active tab */
  .mob-nav-btn.on::before {
    content: '';
    position: absolute;
    top: 0; left: 15%; right: 15%;
    height: 2px;
    background: linear-gradient(90deg, #7b9ff9, #a78bfa, #f472b6);
    border-radius: 0 0 3px 3px;
  }

  /* ─── Flash "Deck" quand une carte est ajoutée ───────────── */
  @keyframes mob-deck-flash {
    0%   { transform: scale(1);    filter: none; }
    25%  { transform: scale(1.28); filter: drop-shadow(0 0 6px #a78bfa); }
    55%  { transform: scale(1.1);  filter: drop-shadow(0 0 4px #7b9ff9); }
    100% { transform: scale(1);    filter: none; }
  }
  @keyframes mob-deck-flash-bar {
    0%   { opacity: 0; transform: scaleX(0); }
    20%  { opacity: 1; transform: scaleX(1); }
    80%  { opacity: 1; }
    100% { opacity: 0; }
  }
  .mob-nav-btn.deck-flash { color: #c4b5fd; }
  .mob-nav-btn.deck-flash .mob-nav-icon {
    display: inline-block;
    animation: mob-deck-flash .9s cubic-bezier(.16,1,.3,1) forwards;
  }
  .mob-nav-btn.deck-flash::after {
    content: '';
    position: absolute;
    top: 0; left: 15%; right: 15%;
    height: 2px;
    background: linear-gradient(90deg, #7b9ff9, #a78bfa, #f472b6);
    border-radius: 0 0 3px 3px;
    transform-origin: center;
    animation: mob-deck-flash-bar .9s ease forwards;
  }

  /* ─── Flash "Carte" quand une carte est sélectionnée ────────── */
  .mob-nav-btn.carte-flash { color: #c4b5fd; }
  .mob-nav-btn.carte-flash .mob-nav-icon {
    display: inline-block;
    animation: mob-deck-flash .9s cubic-bezier(.16,1,.3,1) forwards;
  }
  .mob-nav-btn.carte-flash::after {
    content: '';
    position: absolute;
    top: 0; left: 15%; right: 15%;
    height: 2px;
    background: linear-gradient(90deg, #f472b6, #a78bfa, #7b9ff9);
    border-radius: 0 0 3px 3px;
    transform-origin: center;
    animation: mob-deck-flash-bar .9s ease forwards;
  }

  /* ─── PANNEAU VERSIONS (mobile) ─────────────────────────── */
  #mob-ver-panel {
    flex-direction: column;
    overflow-y: auto;
    padding-bottom: calc(58px + env(safe-area-inset-bottom) + 16px);
  }
  /* Le ctx-menu (dropdown de row) reste en fixed overlay sur mobile */
  .dh-ctx-menu {
    min-width: 260px;
    border-radius: 12px;
    box-shadow: 0 16px 48px rgba(0,0,0,.7);
  }
  .dh-ctx-item { padding: 13px 18px; font-size: 14px; }

  /* ─── MODALS: full screen on mobile ──────────────────────── */
  .modal {
    width: 100% !important;
    max-width: 100% !important;
    max-height: 90vh !important;
    border-radius: 16px 16px 0 0 !important;
    margin: auto 0 0 0 !important;
    align-self: flex-end;
  }
  .modal-bg { align-items: flex-end !important; }

  /* Filter drawer → MODALE plein écran sur mobile/tablette */
  #filter-drawer {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    border-radius: 0 !important;
    border: none !important;
    z-index: 99990 !important;
    transform: translateY(20px) !important;
    transition: transform .22s cubic-bezier(.22,1,.36,1), opacity .18s !important;
    padding-top: env(safe-area-inset-top) !important;
    padding-bottom: env(safe-area-inset-bottom) !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
  }
  #filter-drawer.open {
    transform: translateY(0) !important;
    z-index: 99991 !important;
  }
  /* Backdrop via ::before sur body (pas besoin de markup supplémentaire) */
  body.filter-drawer-open::before {
    content: '';
    position: fixed;
    inset: 0;
    background: rgba(5,4,15,.78);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    z-index: 99989;
    pointer-events: auto;
  }
  body.filter-drawer-open { overflow: hidden; }

  #filter-drawer-hd {
    position: sticky;
    top: 0;
    z-index: 2;
    background: var(--sur) !important;
    padding: 14px 16px !important;
  }
  #filter-drawer .sf-scroll {
    flex: 1 1 auto !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    max-height: none !important;
    padding-bottom: calc(16px + env(safe-area-inset-bottom)) !important;
  }
  #fd-close {
    width: 34px !important;
    height: 34px !important;
    font-size: 15px !important;
  }

  /* Profile menu: full width at bottom */
  .profile-menu {
    left: 8px !important;
    right: 8px !important;
    min-width: 0 !important;
    width: auto !important;
  }

  /* ─── LIGHTBOX (Explorer carte) ───────────────────────────── */
  /* Resize handle desktop-only — caché sur touch */
  .cg-resize-handle { display: none; }

  #card-lightbox { padding: 0 !important; align-items: stretch !important; }
  #lightbox-inner {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto auto !important;
    width: 100vw !important;
    height: 100dvh !important;
    max-width: 100vw !important;
    border-radius: 0 !important;
    overflow-y: auto !important;
    gap: 0 !important;
  }
  #lb-window-btns { top: 10px !important; right: 10px !important; }
  #lb-window-btns button { width: 30px !important; height: 30px !important; }

  /* Info panel : largeur pleine, pas de hauteur max artificielle */
  #lb-info-panel {
    grid-column: 1 !important;
    height: auto !important;
    max-height: none !important;
    border-radius: 0 !important;
    border: none !important;
    border-bottom: 1px solid rgba(255,255,255,.1) !important;
    padding: 48px 14px 12px !important;
  }
  #lb-info-name { font-size: 16px !important; }
  #lb-info-panel td { font-size: 12px !important; padding: 4px 8px 4px 0 !important; }
  #lb-info-actions { flex-direction: row !important; flex-wrap: wrap !important; gap: 6px !important; }

  /* Image centrée */
  #lb-center-col {
    grid-column: 1 !important;
    height: auto !important;
    padding: 14px 0 10px !important;
  }
  #lightbox-img { width: 46vw !important; height: auto !important; margin: 0 auto !important; }
  #lb-nav-bar { justify-content: center !important; }

  /* Cartes liées : scroll vertical dans hauteur fixe */
  #lightbox-related {
    grid-column: 1 !important;
    height: 52vh !important;
    border-radius: 0 !important;
    border: none !important;
    border-top: 1px solid rgba(255,255,255,.1) !important;
    flex-shrink: 0 !important;
  }
  #lightbox-inner[data-mob-view="syn"] {
    overflow: hidden !important;
  }
  #lightbox-inner[data-mob-view="syn"] #lightbox-related {
    display: flex !important;
    flex: 1 1 auto !important;
    height: auto !important;
    min-height: 0 !important;
  }
  #lightbox-inner[data-mob-view="syn"] #lightbox-related-grid {
    flex: 1 1 auto !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
  }
  #lightbox-related-grid {
    grid-template-columns: repeat(3,1fr) !important;
    gap: 8px !important;
    padding: 10px !important;
  }
  .lb-tab-btn { padding: 8px 10px 9px !important; font-size: 11px !important; gap: 4px !important; }
  .lb-tab-lbl { max-width: 80px !important; }
  .lb-tab-count { padding: 1px 6px !important; font-size: 10px !important; }
  .lightbox-rel-name { font-size: 8px !important; }
}

/* ─── 20. MODALES STATS / PROBA / SIM — RESPONSIVE MOBILE ─── */
@media (max-width: 1024px) {
  /* Modale générique — plein écran sur mobile */
  .modal-bg { padding: 0 !important; align-items: stretch !important; justify-content: stretch !important; }
  #modal-stats .modal,
  #modal-proba .modal,
  #modal-sim   .modal {
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    border-radius: 0 !important;
    border: none !important;
    margin: 0 !important;
  }
  #modal-stats .modal-hd,
  #modal-proba .modal-hd,
  #modal-sim   .modal-hd {
    padding: 10px 12px !important;
    gap: 8px !important;
    position: sticky;
    top: 0;
    z-index: 5;
    background: var(--sur);
  }
  #modal-stats .modal-title,
  #modal-proba .modal-title,
  #modal-sim   .modal-title {
    font-size: 14px !important;
    letter-spacing: 1px !important;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
  }
  #modal-stats .modal-close,
  #modal-proba .modal-close,
  #modal-sim   .modal-close {
    width: 44px !important;
    height: 44px !important;
    font-size: 18px !important;
    flex-shrink: 0;
  }
  #modal-stats .modal-body,
  #modal-proba .modal-body,
  #modal-sim   .modal-body {
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
    padding: 10px !important;
    padding-bottom: calc(12px + env(safe-area-inset-bottom)) !important;
  }

  /* ── STATS ── */
  #modal-stats .modal-body {
    display: block !important;
    flex-direction: initial !important;
  }
  #stats-tab-stats {
    display: block !important;
    grid-template-columns: 1fr !important;
    height: auto !important;
    overflow: visible !important;
  }
  /* Forcer single column dans le panneau stats (override inline JS) */
  #stats-tab-stats > div {
    border-right: none !important;
    overflow: visible !important;
    padding: 6px 4px !important;
  }
  #stats-tab-stats > div:first-child {
    border-bottom: 1px solid var(--bor);
    max-height: 220px;
    overflow-y: auto !important;
  }
  .stats-grid { grid-template-columns: 1fr !important; gap: 10px !important; }
  .stat-chart-box { padding: 12px !important; }
  .stat-chart-wrap { height: 180px !important; }
  .stat-chart-wrap canvas { width: 100% !important; max-width: 100% !important; height: auto !important; }
  .stats-summary { gap: 6px !important; margin-bottom: 10px !important; }
  .stats-pill { min-width: 0 !important; flex: 1 1 28% !important; padding: 8px 6px !important; }
  .stats-pill-n { font-size: 18px !important; }
  .stats-pill-l { font-size: 9px !important; }
  .stat-bar-lbl { width: 80px !important; font-size: 11px !important; }
  .stat-bar-cnt { font-size: 11px !important; width: 24px !important; }
  .stats-tabs { overflow-x: auto; -webkit-overflow-scrolling: touch; flex-wrap: nowrap !important; }
  .stats-tab { white-space: nowrap; flex-shrink: 0; padding: 8px 12px !important; font-size: 11px !important; }

  /* ── PROBA ── */
  #modal-proba .modal-body {
    display: block !important;
    flex-direction: initial !important;
    padding: 10px !important;
  }
  #modal-proba .modal-hd #proba-modal-handsize {
    font-size: 11px !important;
    padding: 6px 8px !important;
    max-width: 50vw;
    margin-right: 4px !important;
  }
  .proba-hd-btn{font-size:11px!important;padding:5px 9px!important}
  .proba-hd-actions{gap:5px!important}
  /* Empile les colonnes proba (right-col + groupes) */
  #proba-modal-body > div,
  #proba-modal-body #proba-right-col,
  #proba-modal-body [style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  .proba-report-layout,
  .proba-hero-grid,
  .proba-odds-grid,
  .proba-scenario-grid,
  .proba-risk-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }
  .proba-report-main,
  .proba-report-side {
    max-height: none !important;
    overflow: visible !important;
    padding-right: 0 !important;
  }
  .proba-report-side { margin-top: 10px; }
  .proba-hero-grid { padding: 8px !important; gap: 8px !important; }
  .proba-card { padding: 10px !important; margin-bottom: 8px !important; }

  /* ── SIM ── */
  .sim-card { width: 72px !important; }
  .sim-mini { width: 40px !important; }
  .sim-hand { gap: 5px !important; margin-bottom: 12px !important; }
  .sim-rest { gap: 3px !important; }
  .sim-btns { gap: 6px !important; }
  .sim-btn { padding: 10px 12px !important; font-size: 11px !important; flex: 1 1 30%; }
  .sim-info { font-size: 11px !important; }
  .sim-freq-row { grid-template-columns: 34px 1fr 1fr 1fr !important; gap: 5px !important; padding: 6px 6px !important; }
  .sim-freq-img { width: 34px !important; }
  .sim-freq-nm { font-size: 11px !important; }
  /* Override les zones inline en colonne */
  #sim-body > div[style*="grid-template-columns"],
  #sim-body > div[style*="display:flex"][style*="row"] {
    grid-template-columns: 1fr !important;
    flex-direction: column !important;
  }
}

@media (max-width: 480px) {
  #modal-stats .modal-title,
  #modal-proba .modal-title,
  #modal-sim   .modal-title { font-size: 12px !important; }
  .sim-card { width: 62px !important; }
  .sim-mini { width: 36px !important; }
  .sim-freq-row { grid-template-columns: 30px 1fr 1fr 1fr !important; gap: 4px !important; }
  .sim-freq-img { width: 30px !important; }
  .sim-freq-n { font-size: 11px !important; }
  .stats-pill { flex: 1 1 45% !important; }
  .stat-bar-lbl { width: 70px !important; font-size: 10px !important; }
}
/* Dashboard styles → app/dashboard/dashboard.css */

/* Proba modal — hauteur fixe desktop, auto mobile */
@media(max-width:640px){
  .proba-modal-shell { height: auto !important; max-height: 95vh !important; }
}

/* Premium overlay — light mode fix */
[data-theme="light"] .proba-premium-overlay {
  background: rgba(210,215,235,.88) !important;
}
[data-theme="light"] .proba-premium-overlay-title {
  color: #1a1a3a !important;
}
[data-theme="light"] .proba-premium-overlay-text {
  color: rgba(30,30,60,.65) !important;
}

