@import url('https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700;800&family=Inter:wght@300;400;500;600;700&family=IBM+Plex+Mono:wght@300;400;500;600&display=swap');

/* ══ AURORA GLASS BASE ══ */
:root {
  --bg:#020c18;--bg2:rgba(14,165,233,.06);--bg3:rgba(14,165,233,.04);--bg4:rgba(255,255,255,.07);
  --border:rgba(14,165,233,.10);--border2:rgba(14,165,233,.15);
  --text:#f0f9ff;--text2:rgba(240,249,255,.75);--text3:rgba(125,211,252,.45);
  --green:#34d399;--red:#f87171;--blue:#7dd3fc;
  --purple:#a5b4fc;--yellow:#fde68a;--orange:#fb923c;
  --cyan:#67e8f9;--gold:#fbbf24;--eth:#818cf8;
  --accent:#0ea5e9;
  --sidebar:232px;
  --aurora1:rgba(14,165,233,.20);
  --aurora2:rgba(6,182,212,.14);
  --aurora3:rgba(59,130,246,.08);
  --glow:rgba(14,165,233,.35);
  --sidebar-bg:rgba(2,12,28,.50);
  --topbar-bg:rgba(2,12,28,.45);
  --shadow:0 1px 4px rgba(0,0,0,.3),0 2px 16px rgba(0,0,0,.2);
  --shadow-md:0 4px 24px rgba(0,0,0,.4);
  --shadow-lg:0 12px 48px rgba(0,0,0,.6),0 2px 8px rgba(0,0,0,.3);
  --radius:14px;--radius-sm:10px;--radius-lg:18px;
  --font-mono:'IBM Plex Mono',monospace;
}

/* ── PALETTES ── */
[data-palette="violet"] {
  --bg:#060614;--accent:#8b5cf6;
  --aurora1:rgba(99,102,241,.22);--aurora2:rgba(16,185,129,.15);--aurora3:rgba(236,72,153,.10);
  --glow:rgba(99,102,241,.40);
  --sidebar-bg:rgba(10,8,30,.50);--topbar-bg:rgba(6,6,20,.45);
  --border:rgba(99,102,241,.12);--border2:rgba(99,102,241,.18);
  --text3:rgba(165,180,252,.45);--blue:#a5b4fc;--cyan:#c4b5fd;
}
[data-palette="ocean"] {
  --bg:#020c18;--accent:#0ea5e9;
  --aurora1:rgba(14,165,233,.20);--aurora2:rgba(6,182,212,.14);--aurora3:rgba(59,130,246,.08);
  --glow:rgba(14,165,233,.35);
  --sidebar-bg:rgba(2,12,28,.50);--topbar-bg:rgba(2,12,28,.45);
  --border:rgba(14,165,233,.10);--border2:rgba(14,165,233,.15);
  --text3:rgba(125,211,252,.45);--blue:#7dd3fc;--cyan:#67e8f9;
}
[data-palette="crimson"] {
  --bg:#100608;--accent:#dc2626;
  --aurora1:rgba(220,38,38,.18);--aurora2:rgba(245,158,11,.14);--aurora3:rgba(239,68,68,.07);
  --glow:rgba(220,38,38,.35);
  --sidebar-bg:rgba(16,6,8,.50);--topbar-bg:rgba(16,6,8,.45);
  --border:rgba(220,38,38,.12);--border2:rgba(220,38,38,.18);
  --text3:rgba(252,165,165,.45);--blue:#fca5a5;--cyan:#fde68a;--green:#fbbf24;
}
[data-palette="emerald"] {
  --bg:#030f0a;--accent:#10b981;
  --aurora1:rgba(16,185,129,.18);--aurora2:rgba(5,150,105,.12);--aurora3:rgba(52,211,153,.07);
  --glow:rgba(16,185,129,.35);
  --sidebar-bg:rgba(3,15,10,.50);--topbar-bg:rgba(3,15,10,.45);
  --border:rgba(16,185,129,.10);--border2:rgba(16,185,129,.16);
  --text3:rgba(110,231,183,.45);--blue:#6ee7b7;--cyan:#5eead4;
}
[data-palette="golden"] {
  --bg:#09080e;--accent:#f59e0b;
  --aurora1:rgba(245,158,11,.18);--aurora2:rgba(99,102,241,.14);--aurora3:rgba(251,146,60,.07);
  --glow:rgba(245,158,11,.35);
  --sidebar-bg:rgba(9,8,14,.50);--topbar-bg:rgba(9,8,14,.45);
  --border:rgba(245,158,11,.10);--border2:rgba(245,158,11,.16);
  --text3:rgba(253,230,138,.45);--blue:#fde68a;--cyan:#fb923c;
}

/* BASE */
*{margin:0;padding:0;box-sizing:border-box;}
body{
  font-family:'Sora','Inter',sans-serif;
  background:var(--bg);color:var(--text);
  height:100vh;display:flex;overflow:hidden;font-size:13px;
  -webkit-font-smoothing:antialiased;
  position:relative;
}
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse 70% 55% at 10% 20%,var(--aurora1) 0,transparent 60%),
    radial-gradient(ellipse 60% 50% at 90% 78%,var(--aurora2) 0,transparent 60%),
    radial-gradient(ellipse 45% 40% at 52% 45%,var(--aurora3) 0,transparent 55%);
  transition:background .5s;
}
.sidebar,.main{position:relative;z-index:1;}
.overlay,.claude-overlay{z-index:200;}

/* SCROLLBAR */
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:10px;}
::-webkit-scrollbar-track{background:transparent;}

/* ── SIDEBAR ── */
.sidebar{
  width:var(--sidebar);min-width:var(--sidebar);
  background:var(--sidebar-bg);
  backdrop-filter:saturate(200%) blur(28px);
  -webkit-backdrop-filter:saturate(200%) blur(28px);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;height:100vh;overflow-y:auto;
  transition:background .4s;
}
.sidebar-logo{padding:20px 16px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;}
.logo-icon{width:30px;height:30px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;color:#fff;transition:background .4s,box-shadow .4s;box-shadow:0 2px 16px var(--glow);}

.logo-name{font-size:13px;font-weight:600;line-height:1.2;letter-spacing:-.01em;}
.logo-sub{font-size:10px;color:var(--text3);font-family:'IBM Plex Mono',monospace;}

.sidebar-section{padding:20px 0 4px;}
.sidebar-label{
  padding:0 14px 6px;
  font-size:10px;font-family:'IBM Plex Mono',monospace;
  letter-spacing:.10em;text-transform:uppercase;color:var(--text3);
  display:flex;align-items:center;justify-content:space-between;
  cursor:pointer;user-select:none;transition:color .15s;
}
.sidebar-label:hover{color:var(--text2);}
.sidebar-label-toggle{font-size:13px;line-height:1;padding-right:12px;transition:transform .2s;font-family:monospace;letter-spacing:0;}
.sidebar-section-body{overflow:hidden;transition:max-height .28s cubic-bezier(.4,0,.2,1),opacity .22s ease;}
.sidebar-section-body.collapsed{max-height:0!important;opacity:0;pointer-events:none;}

.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:7px 12px;margin:1px 8px;
  cursor:pointer;
  border-radius:var(--radius-sm);
  transition:background .12s;
  border-left:none;
}
.nav-item:hover{background:rgba(0,0,0,.04);}
.nav-item:hover{background:rgba(255,255,255,.06);}
.nav-item.active{background:rgba(255,255,255,.08);border:1px solid var(--border);}

.nav-item.active .nav-item-name{color:var(--blue);font-weight:600;}
.nav-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;opacity:.45;}
.nav-item.active .nav-icon{opacity:1;}
.nav-item-info{flex:1;min-width:0;}
.nav-item-name{font-size:12px;font-weight:500;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.nav-item-sub{font-size:10px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px;font-family:'IBM Plex Mono',monospace;}
.nav-badge{font-size:10px;font-family:'IBM Plex Mono',monospace;padding:1px 7px;border-radius:20px;background:var(--bg4);color:var(--text3);flex-shrink:0;}
.sidebar-footer{margin-top:auto;padding:12px 14px;border-top:1px solid var(--border);}
.live-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s infinite;margin-right:6px;vertical-align:middle;}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(52,199,89,.4);}50%{opacity:.6;box-shadow:0 0 0 4px rgba(52,199,89,0);}}

@keyframes pulse-dark{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(50,215,75,.4);}50%{opacity:.6;box-shadow:0 0 0 4px rgba(50,215,75,0);}}
.footer-status{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--text3);display:flex;align-items:center;}

/* ── MAIN ── */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;}
.topbar{
  height:52px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 28px;
  background:var(--topbar-bg);
  backdrop-filter:saturate(200%) blur(24px);
  -webkit-backdrop-filter:saturate(200%) blur(24px);
  flex-shrink:0;
}
.topbar-title{font-size:15px;font-weight:600;letter-spacing:-.02em;}
.topbar-right{display:flex;align-items:center;gap:8px;}
.btn{
  font-family:'Inter',sans-serif;
  font-size:12px;font-weight:500;
  padding:6px 14px;border-radius:20px;
  cursor:pointer;
  border:1px solid var(--border2);
  background:var(--bg2);color:var(--text2);
  transition:all .15s;
}
.btn:hover{background:var(--bg3);color:var(--text);}
.btn-green{
  background:rgba(52,199,89,.12);
  border-color:rgba(52,199,89,.25);
  color:var(--green);
}
.btn-green:hover{background:rgba(52,199,89,.2);border-color:var(--green);}
.content{flex:1;overflow-y:auto;padding:24px 28px;}

/* ── PAGES ── */
.page{display:none;}.page.active{display:block;}

/* ── KPI ── */
.kpi-row{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;
  margin-bottom:16px;
}
.kpi{
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid var(--border);
  padding:18px 20px;
  border-radius:var(--radius);
}
.kpi-label{font-size:11px;font-weight:500;letter-spacing:.01em;text-transform:uppercase;color:var(--text3);margin-bottom:10px;}
.kpi-val{font-size:22px;font-weight:700;font-family:'IBM Plex Mono',monospace;letter-spacing:-.03em;line-height:1;margin-bottom:6px;}
.kpi-sub{font-size:11px;font-family:'IBM Plex Mono',monospace;color:var(--text3);display:flex;align-items:center;gap:5px;}

/* ── LAYOUT ── */
.two-col{display:grid;grid-template-columns:1fr 320px;gap:12px;margin-bottom:12px;}
.panel{
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);}
.panel-title{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text3);}
.panel-body{padding:18px;}
.chart-wrap{position:relative;height:180px;}

/* ── PERF ── */
.perf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:12px;}
.perf-cell{
  background:var(--bg2);
  padding:16px 18px;text-align:center;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.perf-period{font-size:10px;font-weight:500;color:var(--text3);letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px;}
.perf-val{font-size:20px;font-weight:700;font-family:'IBM Plex Mono',monospace;letter-spacing:-.02em;}

/* ── TABLE ── */
.data-table{width:100%;border-collapse:collapse;}
.data-table th{
  padding:9px 14px;text-align:left;
  font-size:11px;font-weight:500;letter-spacing:.03em;text-transform:uppercase;
  color:var(--text3);border-bottom:1px solid var(--border);
  white-space:nowrap;
}
.data-table th:first-child{padding-left:18px;}.data-table th:last-child{padding-right:18px;}
.data-table td{padding:11px 14px;border-bottom:1px solid var(--border);vertical-align:middle;white-space:nowrap;}
.data-table td:first-child{padding-left:18px;}.data-table td:last-child{padding-right:18px;}
.data-table tbody tr:last-child td{border-bottom:none;}
.data-table tbody tr:hover td{background:rgba(0,0,0,.02);}
.data-table tbody tr:hover td{background:rgba(255,255,255,.03);}
.data-table tfoot td{border-top:1px solid var(--border);border-bottom:none;padding:9px 14px;font-family:'IBM Plex Mono',monospace;font-size:11px;}
.chain-section-header td{
  background:var(--bg3)!important;
  font-family:'IBM Plex Mono',monospace;font-size:10px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  padding:7px 18px!important;
  border-top:1px solid var(--border)!important;
  border-bottom:1px solid var(--border)!important;
}

/* ── ATOMS ── */
.asset-name-cell{display:flex;flex-direction:column;gap:2px;}
.asset-name{font-size:13px;font-weight:500;color:var(--text);}
.asset-sub{font-size:10px;color:var(--text3);font-family:'IBM Plex Mono',monospace;}
.mono{font-family:'IBM Plex Mono',monospace;font-size:12px;}
.up{color:var(--green);}.down{color:var(--red);}.dim{color:var(--text3);}
.chg-badge{
  font-family:'IBM Plex Mono',monospace;font-size:11px;
  padding:2px 8px;border-radius:20px;
  display:inline-flex;align-items:center;gap:3px;font-weight:500;
}
.chg-up{background:rgba(52,199,89,.12);color:var(--green);}
.chg-up{background:rgba(52,211,153,.12);}
.chg-down{background:rgba(255,59,48,.10);color:var(--red);}
.chg-down{background:rgba(248,113,113,.12);}
.chg-na{background:var(--bg4);color:var(--text3);}
.cat-dot{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-family:'IBM Plex Mono',monospace;}
.dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.alloc-list{display:flex;flex-direction:column;gap:12px;}
.alloc-row{display:flex;flex-direction:column;gap:4px;}
.alloc-top{display:flex;justify-content:space-between;align-items:center;font-size:11px;}
.alloc-bar-bg{height:4px;background:var(--bg4);border-radius:4px;overflow:hidden;}
.alloc-bar-fill{height:100%;border-radius:4px;transition:width .4s ease;}
.mini-bar-wrap{display:flex;align-items:center;gap:8px;}
.mini-bar-bg{flex:1;height:4px;background:var(--bg4);border-radius:4px;max-width:80px;}
.mini-bar-fill{height:100%;border-radius:4px;}
.addr-cell{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--text3);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.spot-bar{display:flex;gap:8px;flex-wrap:wrap;padding:14px 18px;border-bottom:1px solid var(--border);}
.spot-card{background:var(--bg3);border-radius:var(--radius-sm);padding:10px 14px;min-width:112px;}
.spot-name{font-size:10px;font-weight:500;color:var(--text3);margin-bottom:4px;}
.spot-price{font-family:'IBM Plex Mono',monospace;font-size:13px;font-weight:500;}
.spot-chg{font-size:11px;font-family:'IBM Plex Mono',monospace;margin-top:2px;}

/* ── MODAL ── */
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.35);backdrop-filter:blur(8px);z-index:200;align-items:center;justify-content:center;}
.overlay.open{display:flex;}
.modal{
  background:var(--bg2);
  border-radius:var(--radius-lg);
  width:460px;max-width:95vw;max-height:90vh;overflow-y:auto;
  animation:fadeUp .2s cubic-bezier(.34,1.26,.64,1);
  box-shadow:var(--shadow-lg);
}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px) scale(.97);}to{opacity:1;transform:translateY(0) scale(1);}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border);}
.modal-title-text{font-size:15px;font-weight:600;letter-spacing:-.01em;}
.modal-close{
  background:var(--bg3);border:none;color:var(--text3);
  font-size:16px;cursor:pointer;
  width:28px;height:28px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s,color .15s;
}
.modal-close:hover{background:var(--bg4);color:var(--text);}
.modal-body{padding:22px;}
.form-group{margin-bottom:16px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
label{display:block;font-size:11px;font-weight:500;color:var(--text3);margin-bottom:6px;}
input,select{
  width:100%;background:var(--bg3);
  border:1.5px solid transparent;
  border-radius:var(--radius-sm);
  color:var(--text);
  font-family:'IBM Plex Mono',monospace;font-size:13px;
  padding:9px 12px;outline:none;
  transition:border-color .15s,background .15s;
  appearance:none;
}
input:focus,select:focus{border-color:var(--accent);background:var(--bg2);}
/* Force les options lisibles sur Windows Chrome */
select option{
  background:#ffffff !important;
  color:#1d1d1f !important;
}
[data-theme="dark"] select option{
  background:#2c2c2e !important;
  color:#f5f5f7 !important;
}
.btn-submit{
  width:100%;
  background:var(--accent);
  border:none;color:#fff;
  font-family:'Sora','Inter',sans-serif;font-size:13px;font-weight:600;
  padding:12px;border-radius:var(--radius-sm);
  cursor:pointer;margin-top:8px;
  transition:opacity .15s,transform .1s,box-shadow .3s;
  letter-spacing:-.01em;
  box-shadow:0 0 20px var(--glow);
}
.btn-submit:hover{opacity:.88;}
.btn-submit:active{transform:scale(.99);}

.btn-cancel{
  width:100%;background:var(--bg3);
  border:none;color:var(--text2);
  font-family:'Inter',sans-serif;font-size:13px;font-weight:500;
  padding:11px;border-radius:var(--radius-sm);
  cursor:pointer;margin-top:6px;
  transition:background .15s;
}
.btn-cancel:hover{background:var(--bg4);}
.icon-btn{
  background:none;border:1px solid var(--border2);color:var(--text3);
  width:26px;height:26px;border-radius:6px;cursor:pointer;font-size:11px;
  display:inline-flex;align-items:center;justify-content:center;
  transition:all .12s;margin-left:2px;
}
.icon-btn:hover{border-color:var(--red);color:var(--red);background:rgba(255,59,48,.06);}
.icon-btn.edit:hover{border-color:var(--blue);color:var(--blue);background:rgba(0,122,255,.06);}
.icon-btn.sync:hover{border-color:var(--cyan);color:var(--cyan);background:rgba(50,173,230,.06);}
.toast{
  position:fixed;bottom:24px;right:24px;
  background:var(--bg2);
  border-radius:12px;
  padding:12px 18px;
  font-size:12px;font-weight:500;color:var(--text);
  z-index:300;transform:translateY(70px) scale(.95);opacity:0;
  transition:all .28s cubic-bezier(.34,1.26,.64,1);
  display:flex;align-items:center;gap:10px;
  box-shadow:var(--shadow-lg);
}
.toast.show{transform:translateY(0) scale(1);opacity:1;}
.toast.success::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0;}
.toast.error::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--red);flex-shrink:0;}
.toast.info::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--blue);flex-shrink:0;}
.empty{text-align:center;padding:48px 20px;color:var(--text3);font-family:'IBM Plex Mono',monospace;font-size:12px;}
.empty-icon{font-size:30px;margin-bottom:12px;opacity:.25;}
.toolbar{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap;}
.spin{width:12px;height:12px;border:2px solid rgba(0,122,255,.2);border-top-color:var(--accent);border-radius:50%;animation:rotate .6s linear infinite;display:inline-block;}
@keyframes rotate{to{transform:rotate(360deg);}}
.info-box{
  background:var(--bg3);border-radius:var(--radius-sm);
  padding:12px 14px;font-size:11px;font-family:'IBM Plex Mono',monospace;
  color:var(--text3);margin-bottom:14px;line-height:1.7;
}
.info-box b{color:var(--text2);}
.fetch-row{display:flex;gap:8px;align-items:flex-end;}
.fetch-row input{flex:1;}

/* ── THEME TOGGLE ── */
.theme-toggle{
  width:38px;height:22px;border-radius:11px;
  background:var(--bg4);border:none;
  cursor:pointer;position:relative;
  transition:background .25s;flex-shrink:0;display:flex;align-items:center;padding:0 3px;
}
.theme-toggle{background:var(--bg4);}
[data-theme="dark"] .theme-toggle{background:var(--accent);}
.theme-toggle::after{
  content:'';width:16px;height:16px;border-radius:50%;
  background:#fff;
  transition:transform .25s cubic-bezier(.34,1.26,.64,1);
  box-shadow:0 1px 4px rgba(0,0,0,.2);
}
[data-theme="dark"] .theme-toggle::after{transform:translateX(16px);}

.toggle-wrap{display:flex;align-items:center;gap:7px;font-size:12px;cursor:pointer;user-select:none;}
.toggle-icon{font-size:13px;line-height:1;}

/* ── SECTION TOGGLES (Gérer les dossiers) ── */
.section-toggle-row{display:flex;align-items:center;gap:14px;padding:14px 18px;border-bottom:1px solid var(--border);transition:background .1s;}
.section-toggle-row:last-child{border-bottom:none;}
.stgl-icon{width:36px;height:36px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}
.stgl-info{flex:1;min-width:0;}
.stgl-name-wrap{display:flex;align-items:center;gap:6px;}
.stgl-name{font-size:13px;font-weight:600;color:var(--text);cursor:pointer;padding:2px 6px;border-radius:6px;border:1.5px solid transparent;transition:border-color .15s,background .15s;min-width:60px;}
.stgl-name:hover{border-color:var(--border2);background:var(--bg3);}
.stgl-name:focus{outline:none;border-color:var(--accent);background:var(--bg2);}
.stgl-name[contenteditable="true"]{border-color:var(--accent);background:var(--bg2);}
.stgl-edit-hint{font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--text3);opacity:0;transition:opacity .15s;}
.stgl-name-wrap:hover .stgl-edit-hint{opacity:1;}
.stgl-sub{font-size:11px;color:var(--text3);font-family:'IBM Plex Mono',monospace;margin-top:2px;}
.stgl-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.stgl-switch{width:44px;height:26px;border-radius:13px;border:none;cursor:pointer;position:relative;flex-shrink:0;transition:background .25s;outline:none;}
.stgl-switch::after{content:'';position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .25s cubic-bezier(.34,1.26,.64,1);box-shadow:0 1px 4px rgba(0,0,0,.2);}
.stgl-switch.on{background:var(--green);}
.stgl-switch.off{background:var(--border2);}
.stgl-switch.on::after{transform:translateX(18px);}
.stgl-warn{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--yellow);background:rgba(255,159,10,.1);border-radius:4px;padding:2px 8px;margin-top:4px;}

/* ── ICON PICKER ── */
.icon-grid{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;}
.icon-opt{width:36px;height:36px;border-radius:var(--radius-sm);border:1.5px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;transition:all .15s;}
.icon-opt:hover{border-color:var(--accent);}
.icon-opt.selected{border-color:var(--accent);background:rgba(0,122,255,.08);}
.ip-cell{width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;border-radius:var(--radius-sm);border:1.5px solid transparent;background:var(--bg3);transition:background .1s,border-color .1s;}
.ip-cell:hover{background:var(--bg4);}
.ip-cell.ip-sel{border-color:var(--accent);background:rgba(0,122,255,.08);}

/* ── COLOR SWATCHES ── */
.color-swatches{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;}
.color-swatch{width:28px;height:28px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .15s,border-color .15s,box-shadow .15s;}
.color-swatch:hover{transform:scale(1.15);}
.color-swatch.selected{border-color:var(--text);transform:scale(1.1);box-shadow:0 2px 8px rgba(0,0,0,.15);}

/* ── CRYPTO SEARCH ── */
.crypto-search-wrap{position:relative;}
.crypto-modal-dropdown{
  background:#0d1726;
  border:1px solid rgba(14,165,233,.25);
  border-radius:var(--radius-sm);
  max-height:240px;overflow-y:auto;
  position:absolute;left:0;right:0;top:calc(100% + 4px);
  z-index:100;box-shadow:0 8px 32px rgba(0,0,0,.6);display:none;
}
.crypto-modal-dropdown.open{display:block;animation:fadeUp .14s ease;}
.crypto-modal-item{
  padding:9px 13px;font-size:12px;cursor:pointer;
  display:flex;align-items:center;gap:8px;
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:background .1s;
  color:#e0f0ff;
}
.crypto-modal-item:last-child{border-bottom:none;}
.crypto-modal-item:hover{background:rgba(14,165,233,.15);}
.crypto-modal-img{width:22px;height:22px;border-radius:50%;background:var(--bg4);flex-shrink:0;}
.crypto-modal-rank{font-size:9px;font-family:'IBM Plex Mono',monospace;color:var(--text3);width:24px;text-align:right;flex-shrink:0;}

/* ── KNOWLEDGE SECTION ── */
.know-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:14px;}
.know-hero{background:var(--bg2);border-radius:var(--radius);overflow:hidden;margin-bottom:14px;box-shadow:var(--shadow);}
.know-hero-head{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;}
.know-hero-icon{font-size:24px;}
.know-hero-title{font-size:16px;font-weight:700;color:var(--text);letter-spacing:-.02em;}
.know-hero-sub{font-size:11px;color:var(--text3);font-family:'IBM Plex Mono',monospace;margin-top:2px;}
.know-hero-body{padding:20px 24px;}
.know-rule{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border);}
.know-rule:last-child{border-bottom:none;padding-bottom:0;}
.know-rule-num{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:10px;font-family:'IBM Plex Mono',monospace;font-weight:700;flex-shrink:0;margin-top:1px;}
.know-rule-text{font-size:13px;color:var(--text2);line-height:1.65;}
.know-rule-text b{color:var(--text);font-weight:600;}
.know-card{background:var(--bg2);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);}
.know-card-head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;}
.know-card-icon{font-size:15px;}
.know-card-title{font-size:12px;font-weight:600;letter-spacing:.03em;color:var(--text);}
.know-card-body{padding:16px 18px;}
.know-card-body p{font-size:12px;color:var(--text2);line-height:1.7;margin-bottom:8px;}
.know-card-body p:last-child{margin-bottom:0;}
.know-card-body b{color:var(--text);}

/* ── PYRAMID ── */
.pyramid-wrap{display:flex;flex-direction:column;align-items:center;gap:5px;padding:16px 0;}
.pyramid-level{display:flex;align-items:center;gap:12px;width:100%;}
.pyramid-bar{border-radius:6px;height:44px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;}
.pyramid-info{flex:1;}
.pyramid-name{font-size:12px;font-weight:600;color:var(--text);}
.pyramid-desc{font-size:11px;color:var(--text3);margin-top:2px;line-height:1.5;}
.pyramid-pct{font-family:'IBM Plex Mono',monospace;font-size:11px;font-weight:700;color:#000;letter-spacing:.05em;}

/* ── RULE CARDS ── */
.rules-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.rule-card{background:var(--bg2);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow);}
.rule-card-icon{font-size:20px;margin-bottom:10px;}
.rule-card-title{font-size:12px;font-weight:700;color:var(--text);margin-bottom:6px;letter-spacing:-.01em;}
.rule-card-text{font-size:11px;color:var(--text3);line-height:1.65;}
.rule-card-text b{color:var(--text2);}
.know-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:500;padding:3px 9px;border-radius:20px;margin-bottom:10px;}
.know-badge-green{background:rgba(52,199,89,.12);color:var(--green);}
.know-badge-blue{background:rgba(0,122,255,.10);color:var(--blue);}
.know-badge-gold{background:rgba(198,136,44,.12);color:var(--gold);}
.know-badge-red{background:rgba(255,59,48,.10);color:var(--red);}

/* ── SUB-NAV GROUPS ── */
.nav-group-toggle{cursor:pointer;user-select:none;}
.nav-group-arrow{font-size:13px;color:var(--text3);transition:transform .2s;flex-shrink:0;line-height:1;}
.nav-group-toggle.open .nav-group-arrow{transform:rotate(90deg);}
.nav-sub-group{display:none;padding:2px 0 4px 0;margin-left:16px;padding-left:12px;border-left:2px solid var(--border);}
.nav-sub-group.open{display:block;}
.nav-sub-item{
  padding:6px 10px;margin:1px 4px 1px 0;
  font-size:11px;color:var(--text3);cursor:pointer;
  border-radius:6px;
  transition:background .1s,color .1s;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.nav-sub-item:hover{background:rgba(0,0,0,.04);color:var(--text2);}
.nav-sub-item:hover{background:rgba(255,255,255,.06);}
.nav-sub-item.active{background:rgba(0,122,255,.10);color:var(--accent);font-weight:500;}

/* ── COMPARATEUR CRYPTO ── */
.cc-dropdown{background:var(--bg2);border-radius:var(--radius-sm);max-height:180px;overflow-y:auto;display:none;box-shadow:var(--shadow-lg);z-index:50;position:relative;}
.cc-dropdown.open{display:block;}
.cc-drop-item{padding:9px 14px;font-size:12px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .1s;border-bottom:1px solid var(--border);}
.cc-drop-item:last-child{border-bottom:none;}
.cc-drop-item:hover{background:var(--bg3);}
.cc-drop-img{width:22px;height:22px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--bg4);}
.cc-drop-name{font-weight:500;color:var(--text);}
.cc-drop-sym{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--text3);margin-left:4px;}
.cc-drop-cap{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--text3);margin-left:auto;}
.cc-empty-card{text-align:center;padding:24px 12px;color:var(--text3);border:1.5px dashed var(--border2);border-radius:var(--radius-sm);}
.cc-filled-card{background:var(--bg3);border-radius:var(--radius-sm);padding:16px;}
.cc-filled-top{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.cc-filled-img{width:38px;height:38px;border-radius:50%;object-fit:cover;background:var(--bg4);}
.cc-filled-name{font-size:14px;font-weight:700;color:var(--text);}
.cc-filled-sym{font-size:11px;font-family:'IBM Plex Mono',monospace;color:var(--text3);}
.cc-stat{display:flex;justify-content:space-between;font-size:11px;padding:5px 0;border-bottom:1px solid var(--border);}
.cc-stat:last-child{border-bottom:none;}
.cc-stat-label{color:var(--text3);font-family:'IBM Plex Mono',monospace;}
.cc-stat-val{color:var(--text);font-weight:600;font-family:'IBM Plex Mono',monospace;}
.cc-top10-row{display:flex;align-items:center;gap:6px;padding:3px 0;}
.cc-top10-rank{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--text3);width:18px;text-align:right;flex-shrink:0;}
.cc-top10-bar-bg{flex:1;height:6px;background:var(--bg4);border-radius:3px;overflow:hidden;}
.cc-top10-bar-fill{height:100%;border-radius:3px;background:var(--blue);transition:width .4s;}
.cc-top10-name{font-size:11px;font-family:'IBM Plex Mono',monospace;color:var(--text2);width:60px;flex-shrink:0;}
.cc-top10-cap{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--text3);width:70px;text-align:right;flex-shrink:0;}

/* ── SIMULATEUR ── */
.sim-layout{display:grid;grid-template-columns:340px 1fr;gap:14px;align-items:start;}
.sim-panel{background:var(--bg2);border-radius:var(--radius);padding:20px 22px;box-shadow:var(--shadow);}
.sim-field{margin-bottom:18px;}
.sim-field:last-child{margin-bottom:0;}
.sim-label{display:flex;justify-content:space-between;align-items:center;font-size:11px;font-weight:500;color:var(--text3);margin-bottom:7px;text-transform:uppercase;letter-spacing:.06em;}
.sim-val{font-size:13px;font-weight:700;color:var(--text);font-family:'IBM Plex Mono',monospace;}
.sim-input{width:100%;background:var(--bg3);border:1.5px solid transparent;border-radius:var(--radius-sm);color:var(--text);font-family:'IBM Plex Mono',monospace;font-size:13px;font-weight:600;padding:8px 12px;outline:none;transition:border-color .15s;}
.sim-input:focus{border-color:var(--accent);}
.sim-slider{-webkit-appearance:none;width:100%;height:5px;border-radius:5px;background:var(--bg4);outline:none;cursor:pointer;margin-top:4px;}
.sim-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--accent);border:2.5px solid var(--bg2);box-shadow:0 2px 6px rgba(0,122,255,.35);cursor:pointer;}
.sim-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--accent);border:2.5px solid var(--bg2);cursor:pointer;}
.sim-slider-row{display:flex;justify-content:space-between;font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--text3);margin-top:3px;}
.sim-split-label{display:flex;justify-content:space-between;font-size:11px;font-family:'IBM Plex Mono',monospace;margin-bottom:4px;}
.sim-split-left{color:var(--blue);font-weight:600;}
.sim-split-right{color:var(--text3);}
.sim-result-hero{background:var(--bg2);border-radius:var(--radius);padding:22px 24px;margin-bottom:12px;text-align:center;box-shadow:var(--shadow);}
.sim-result-headline{font-size:13px;color:var(--text2);line-height:1.7;margin-bottom:16px;}
.sim-result-headline b{color:var(--text);font-size:16px;}
.sim-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px;}
.sim-kpi{background:var(--bg2);padding:14px 16px;text-align:center;border-radius:var(--radius-sm);box-shadow:var(--shadow);}
.sim-kpi-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:5px;}
.sim-kpi-val{font-size:16px;font-weight:700;font-family:'IBM Plex Mono',monospace;color:var(--text);}
.sim-kpi-val.accent{color:var(--green);}
.sim-chart-wrap{background:var(--bg2);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow);}
.sim-chart-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;}
.sim-legend{display:flex;gap:14px;}
.sim-legend-item{display:flex;align-items:center;gap:5px;font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--text3);}
.sim-legend-dot{width:8px;height:8px;border-radius:3px;}
.sim-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin:18px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border);}

/* ── CLAUDE MODAL ── */
.claude-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(10px);z-index:500;align-items:center;justify-content:center;}
.claude-overlay.open{display:flex;}
.claude-modal{background:var(--bg2);border-radius:var(--radius-lg);width:500px;max-width:95vw;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:fadeUp .2s cubic-bezier(.34,1.26,.64,1);}
.claude-head{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;}
.claude-head-icon{width:38px;height:38px;background:rgba(0,122,255,.12);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0;}
.claude-body{padding:22px 24px;}
.claude-step{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px;}
.claude-step-num{width:26px;height:26px;border-radius:6px;font-size:11px;font-family:'IBM Plex Mono',monospace;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;}
.claude-step-text{font-size:12px;color:var(--text2);line-height:1.65;}
.claude-step-text b{color:var(--text);}
.claude-textarea{width:100%;background:var(--bg3);border:1.5px solid transparent;border-radius:var(--radius-sm);color:var(--text);font-family:'IBM Plex Mono',monospace;font-size:11px;padding:11px 13px;outline:none;resize:vertical;min-height:80px;transition:border-color .15s;line-height:1.65;}
.claude-textarea:focus{border-color:var(--blue);}
.claude-pin-input{width:100%;background:var(--bg3);border:1.5px solid transparent;border-radius:var(--radius-sm);color:var(--text);font-family:'IBM Plex Mono',monospace;font-size:16px;padding:12px 14px;outline:none;text-align:center;letter-spacing:.3em;transition:border-color .15s;margin-bottom:8px;}
.claude-pin-input:focus{border-color:var(--blue);}
.btn-claude{width:100%;background:rgba(0,122,255,.12);border:none;color:var(--blue);font-family:'Inter',sans-serif;font-size:13px;font-weight:600;padding:12px;border-radius:var(--radius-sm);cursor:pointer;margin-top:8px;transition:background .15s;}
.btn-claude:hover{background:rgba(0,122,255,.2);}
.success-box{background:rgba(52,199,89,.08);border-radius:var(--radius-sm);padding:18px 20px;text-align:center;display:none;}
.success-box.show{display:block;}
