/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --bg:        #F5F3EE;
  --bg2:       #FFFFFF;
  --bg3:       #F0EDE6;
  --bg4:       #E8E4DC;
  --border:    #DDD9D0;
  --border2:   #C5C2BA;
  --text:      #1C1B18;
  --text2:     #3D3B36;
  --text3:     #706D66;
  --text4:     #9A9790;
  --accent:    #0A1E3D;
  --accent2:   #142E54;
  --accent-lt: #E8EDF5;
  --red:       #B82A1F;
  --red-lt:    #FCE9E7;
  --green:     #1A7F4B;
  --green-lt:  #E8F5EE;
  --orange:    #B85C00;
  --orange-lt: #FEF3E8;
  --yellow:    #8B6914;
  --yellow-lt: #FEF9E8;
  --france:    #002395;
  --mono:      'JetBrains Mono', monospace;
  --serif:     'Playfair Display', Georgia, serif;
  --sans:      'Source Sans 3', system-ui, sans-serif;
  --radius:    6px;
  --radius-sm: 3px;
  --shadow:    0 1px 3px rgba(0,0,0,.07),0 1px 2px rgba(0,0,0,.04);
  --shadow-md: 0 4px 16px rgba(0,0,0,.1),0 1px 4px rgba(0,0,0,.06);
  --shadow-lg: 0 12px 40px rgba(0,0,0,.14),0 4px 12px rgba(0,0,0,.08);
  --gold:      #C9A84C;
  --ease:      cubic-bezier(.25,.46,.45,.94);
  /* ── Z-INDEX — hiérarchie centralisée ── */
  --z-sticky:1;--z-nav:190;--z-topbar:200;--z-drawer:300;--z-panel:400;
  --z-dropdown:510;--z-tooltip:520;--z-onboarding:530;
  --z-modal:600;--z-modal-legal:700;--z-modal-top:750;--z-skip:9999;
}
[data-theme="dark"]{
  --bg:#080A10;--bg2:#1A1D27;--bg3:#232733;--bg4:#2C3040;
  --border:#333847;--border2:#444B5C;
  --text:#E8E9ED;--text2:#B8BAC4;--text3:#8A8E9C;--text4:#6B7080;
  --accent:#4D7CFF;--accent2:#3A63E0;--accent-lt:rgba(77,124,255,.12);
  --red:#FF4B5C;--red-lt:rgba(255,75,92,.12);
  --green:#00D68F;--green-lt:rgba(0,214,143,.12);
  --orange:#FF8C42;--orange-lt:rgba(255,140,66,.12);
  --yellow:#FFD93D;--yellow-lt:rgba(255,217,61,.12);
  --shadow:0 2px 8px rgba(0,0,0,.3),0 1px 3px rgba(0,0,0,.2);
  --shadow-md:0 8px 24px rgba(0,0,0,.4),0 2px 8px rgba(0,0,0,.3);
  --shadow-lg:0 20px 60px rgba(0,0,0,.5),0 8px 20px rgba(0,0,0,.3);
}
[data-theme="dark"] #site-footer{background:#0D1526!important;}
[data-theme="dark"] #topbar{background:#0A1020!important;}

html{font-size:16px;}
body{background:var(--bg);color:var(--text);font-family:var(--sans);min-height:100vh;transition:background .3s,color .3s;}
button{font-family:var(--sans);cursor:pointer;touch-action:manipulation;}
button:focus-visible,.filter-btn:focus-visible,.tab:focus-visible{outline:2px solid var(--accent);outline-offset:2px;}
a{text-decoration:none;color:inherit;}
a:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px;}
::-webkit-scrollbar{width:4px;height:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px;}
::-webkit-scrollbar-thumb:hover{background:var(--text4);}
[data-theme="dark"] #topbar{background:#0D1526;}
[data-theme="dark"] #ticker-bar{background:#0D1120;}
[data-theme="dark"] ::-webkit-scrollbar-track{background:#1A1D27;}
[data-theme="dark"] ::-webkit-scrollbar-thumb{background:#444B5C;}

/* ── ANIMATIONS ── */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes shimmer{from{background-position:-200% 0}to{background-position:200% 0}}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
/* Respect accessibilité — désactive animations si préférence système */
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;}}

/* ── TOPBAR ── */
#topbar{
  display:flex;align-items:center;
  height:46px;background:var(--accent);
  border-bottom:none;
  position:sticky;top:0;z-index:var(--z-topbar);
  padding:0 20px;gap:14px;
}
.tb-logo{
  display:flex;align-items:center;gap:8px;
  flex-shrink:0;
}
.tb-live-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--red);animation:pulse 2s infinite;
  flex-shrink:0;
}
.tb-brand{
  font-family:var(--mono);font-size:13px;
  font-weight:700;letter-spacing:.08em;color:#fff;
  white-space:nowrap;
}
.tb-brand span{color:rgba(255,255,255,.6);}
.tb-divider{width:1px;height:16px;background:rgba(255,255,255,.15);flex-shrink:0;}
.tb-item{
  font-family:var(--mono);font-size:10px;
  color:rgba(255,255,255,.5);white-space:nowrap;
}
.tb-item strong{color:rgba(255,255,255,.8);font-weight:500;}
.tb-right{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0;}
#clock{
  font-family:var(--mono);font-size:12px;font-weight:600;
  color:rgba(255,255,255,.8);letter-spacing:.04em;
}
#upill{
  font-family:var(--mono);font-size:9px;font-weight:600;
  padding:3px 8px;border-radius:20px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.4);letter-spacing:.06em;cursor:pointer;
  transition:all .15s;white-space:nowrap;
}
#upill.hot{background:#B82A1F;border-color:#B82A1F;color:#fff;}
.btn-refresh{
  display:flex;align-items:center;gap:5px;
  height:26px;padding:0 10px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius);
  color:#fff;font-family:var(--sans);font-size:11px;font-weight:500;
  transition:all .15s;white-space:nowrap;
}
.btn-refresh:hover{background:rgba(255,255,255,.2);}
.btn-refresh svg{width:11px;height:11px;}

/* ── TICKER ── */
#ticker-bar{
  height:36px;
  background:#111827;
  overflow:hidden;display:flex;align-items:center;
  border-bottom:1px solid rgba(255,255,255,.06);
}
#ticker-inner{
  display:flex;gap:0;white-space:nowrap;
  animation:ticker 120s linear infinite;
  font-family:var(--mono);font-size:11px;
}
#ticker-inner:hover{animation-play-state:paused;}
.t-item{
  display:inline-flex;align-items:center;gap:6px;
  padding:0 18px;height:36px;
  border-right:1px solid rgba(255,255,255,.06);
}
.t-sym{color:rgba(255,255,255,.45);font-size:9px;letter-spacing:.1em;font-weight:600;text-transform:uppercase;}
.t-price{color:rgba(255,255,255,.92);font-weight:600;font-size:11px;}
.t-chg{font-size:10px;font-weight:600;letter-spacing:.02em;}
.t-up{color:#4ADE80;}
.t-dn{color:#F87171;}
.t-alert{
  display:inline-flex;align-items:center;gap:6px;
  color:#FCD34D;font-weight:600;font-size:10px;
  padding:0 18px;height:36px;
  border-right:1px solid rgba(255,255,255,.06);
  letter-spacing:.02em;
}
.t-sep{color:rgba(255,255,255,.35);padding:0 2px;}

/* ── NAV TABS ── */
#nav-tabs{
  display:flex;align-items:flex-end;
  background:var(--bg2);
  border-bottom:1px solid var(--border);
  padding:0 24px;
  position:sticky;top:46px;z-index:var(--z-nav);
}
.tab{display:inline-flex;align-items:center;gap:6px;height:40px;padding:0 18px;font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.01em;color:var(--text3);border:none;background:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:color var(--t1),border-color var(--t1);}
.tab:hover{color:var(--text);}
.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600;}
.tab-dot{width:6px;height:6px;border-radius:50%;background:var(--red);animation:pulse 2s infinite;display:none;pointer-events:none;}
.tab.active .tab-dot{display:block;}

/* ── MAIN ── */
#main{
  max-width:1200px;margin:0 auto;padding:20px 32px;
  background:var(--bg);
  min-height:calc(100vh - 140px);
}
.pane{display:none;animation:fadeIn .2s ease;}
.pane.active{display:block;}

/* ── FILTER ROW ── */
.filter-row{
  display:flex;align-items:center;gap:6px;
  padding-bottom:6px;margin-bottom:6px;
  border-bottom:none;flex-wrap:wrap;
}
.filter-btn{font-family:var(--sans);font-size:11px;font-weight:500;height:26px;padding:0 11px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg2);color:var(--text3);cursor:pointer;transition:background var(--t1),border-color var(--t1),color var(--t1),box-shadow var(--t1);white-space:nowrap;}
.filter-btn:hover:not(.active){background:var(--bg3);border-color:var(--border2);color:var(--text);}
.filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 1px 3px rgba(10,30,61,.18);}
.sig-count{font-family:var(--mono);font-size:11px;color:var(--text4);margin-left:auto;}

/* ── NEWS LAYOUT ── */
#news-layout{display:grid;grid-template-columns:1fr;gap:20px;}
#news-layout.split{grid-template-columns:1fr 400px;}
#news-list{display:flex;flex-direction:column;gap:4px;}

/* ── NEWS CARD ── */
.news-card{
  display:flex;gap:0;
  background:var(--bg2);
  border:none;
  transition:background .15s var(--ease),box-shadow .15s var(--ease);
  border-bottom:1px solid var(--bg4);
  border-radius:0;
  cursor:pointer;transition:all .15s;
  overflow:hidden;
}
.news-card:hover{background:var(--bg3);box-shadow:inset 3px 0 0 var(--accent);}
.news-card.selected{background:var(--accent-lt);}
.nc-stripe{width:4px;flex-shrink:0;border-radius:4px 0 0 4px;}
.nc-body{padding:14px 18px;flex:1;}
.nc-meta{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap;}
.nc-badge{
  font-family:var(--mono);font-size:9px;font-weight:700;
  padding:2px 7px;border-radius:2px;letter-spacing:.1em;
  text-transform:uppercase;
}
.badge-CRITIQUE{background:var(--red-lt);color:var(--red);}
.badge-ÉLEVÉ   {background:var(--orange-lt);color:var(--orange);}
.badge-MODÉRÉ  {background:var(--bg3);color:var(--text3);}
.badge-FAIBLE{background:var(--bg3);color:var(--text3);opacity:.6;}
.nc-source{font-size:13px;font-weight:700;color:var(--text2);}
.nc-time{font-size:11px;color:var(--text4);margin-left:auto;font-family:var(--mono);}
.nc-title {font-family:var(--serif);font-size:16px;font-weight:600;color:var(--text);line-height:1.45;}
.nc-score{
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  min-width:40px;padding:6px 8px;
  font-family:var(--mono);font-size:18px;font-weight:700;line-height:1;
  flex-shrink:0;text-align:center;
}
.nc-score span{font-size:9px;font-weight:500;opacity:.5;}
.nc-title.read{color:var(--text3);font-weight:400;}
.nc-unread-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0;margin-top:2px;pointer-events:none;}

/* ── DETAIL PANEL ── */
#detail-panel{
  position:sticky;top:108px;
  height:calc(100vh - 120px);overflow-y:auto;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);box-shadow:var(--shadow);
  display:none;
}
#detail-panel.open{display:flex;flex-direction:column;}
.dp-header{
  padding:16px;border-bottom:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:12px;flex-shrink:0;
}
.dp-close{background:none;border:none;color:var(--text3);font-size:20px;cursor:pointer;}
.dp-close:hover{color:var(--text);}
.dp-body{padding:16px;flex:1;overflow-y:auto;}
.dp-title{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--text);line-height:1.4;margin-bottom:16px;}
.dp-section{margin-bottom:16px;}
.dp-section-label{
  font-family:var(--mono);font-size:9px;font-weight:600;
  letter-spacing:.2em;color:var(--text4);text-transform:uppercase;
  margin-bottom:8px;padding-bottom:6px;
  border-bottom:1px solid var(--border);
}
.dp-section-text{font-size:13px;color:var(--text2);line-height:1.7;}
.dp-link{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 14px;border:1px solid var(--border);border-radius:var(--radius);
  font-size:12px;font-weight:600;color:var(--accent);
  transition:all .15s;margin-bottom:12px;
}
.dp-link:hover{background:var(--accent-lt);}
.ai-trigger-btn{
  width:100%;padding:10px;
  background:var(--accent);border:none;border-radius:var(--radius);
  font-family:var(--sans);font-size:13px;font-weight:600;color:#fff;
}
.ai-trigger-btn:hover{background:var(--accent2);}
.ai-loading{font-family:var(--mono);font-size:11px;color:var(--text3);letter-spacing:.15em;animation:pulse 1.5s infinite;padding:8px 0;}
.ai-result{display:flex;flex-direction:column;gap:12px;}
.score-row{display:flex;align-items:center;gap:10px;margin-bottom:4px;}
.score-label{font-family:var(--mono);font-size:10px;color:var(--text3);min-width:55px;}
.score-pips{display:flex;gap:3px;}
.score-pip{width:8px;height:10px;border-radius:2px;pointer-events:none;}
.score-val{font-family:var(--mono);font-size:12px;color:var(--accent);}
.ai-row-label{font-family:var(--mono);font-size:9px;letter-spacing:.18em;color:var(--text4);margin-bottom:4px;text-transform:uppercase;}
.ai-row-text{font-size:13px;color:var(--text2);line-height:1.7;}

/* ── MACRO ACCORDION ── */
.macro-accordion{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;overflow:hidden;border-left:2px solid transparent;transition:border-left-color var(--t1);}
.macro-hdr{display:flex;align-items:center;padding:10px 16px;background:var(--bg);cursor:pointer;user-select:none;gap:14px;transition:background var(--t1);}
.macro-hdr:hover{background:var(--bg3);}
.macro-hdr-label{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.16em;color:var(--text3);flex-shrink:0;white-space:nowrap;text-transform:uppercase;}
.macro-hdr-vals{display:flex;gap:14px;flex:1;flex-wrap:wrap;font-family:var(--mono);font-size:10px;color:var(--text4);overflow:hidden;}
.macro-hdr-val{display:flex;gap:5px;align-items:center;white-space:nowrap;}
.macro-hdr-val b{color:var(--text);font-weight:600;}
.macro-hdr-sep{color:var(--text4);font-family:var(--mono);font-size:11px;flex-shrink:0;padding:0 2px;opacity:.5;}
.macro-hdr-chevron{font-size:13px;color:var(--text4);transition:transform .2s var(--ease);flex-shrink:0;font-family:var(--mono);}
.macro-hdr.open .macro-hdr-chevron{transform:rotate(90deg);}
.macro-body{display:none;}
.macro-body.open{display:block;}
.macro-tbl{width:100%;border-collapse:collapse;}
.macro-tbl tr{border-bottom:1px solid var(--border);}
.macro-tbl tr:last-child{border-bottom:none;}
.macro-tbl tr:hover td{background:var(--bg2);}
.macro-tbl td{padding:7px 14px;font-family:var(--mono);font-size:11px;vertical-align:middle;color:var(--text);}
.macro-tbl .col-name{color:var(--text3);font-size:10px;letter-spacing:.04em;}
.macro-tbl .col-val{font-weight:700;font-size:13px;white-space:nowrap;}
.macro-tbl .col-chg{font-size:10px;white-space:nowrap;}
.macro-tbl .col-spark{padding-right:16px;}
.macro-tbl .col-date{color:var(--text4);font-size:9px;white-space:nowrap;}

/* ── MARCHÉS ── */
.mkt-heroes{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;margin-bottom:16px;}
.mkt-hero{padding:12px 14px 10px;border:1px solid var(--border);border-radius:var(--radius);border-top:2px solid var(--accent);cursor:pointer;background:var(--bg2);transition:box-shadow .18s var(--ease),border-top-color .18s var(--ease),transform .18s var(--ease);box-shadow:var(--shadow);}
.mkt-hero:hover{box-shadow:var(--shadow-md);border-top-color:var(--gold);transform:translateY(-1px);}
.mkt-hero-sym{font-family:var(--mono);font-size:8px;font-weight:700;color:var(--text4);letter-spacing:.16em;margin-bottom:8px;text-transform:uppercase;}
.mkt-hero-price{font-family:var(--mono);font-size:20px;font-weight:700;color:var(--text);line-height:1;margin-bottom:2px;letter-spacing:-.02em;}
.mkt-hero-chg{font-family:var(--mono);font-size:11px;font-weight:700;}
.mkt-hero-label{font-family:var(--mono);font-size:9px;color:var(--text4);margin-top:6px;letter-spacing:.06em;}
.mkt-table{width:100%;border-collapse:collapse;}
.mkt-table thead{position:sticky;top:0;z-index:1;}
.mkt-table th{font-family:var(--mono);font-size:8.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text4);text-align:left;padding:7px 12px;border-bottom:1px solid var(--border);background:var(--bg);}
.mkt-table th:last-child,.mkt-table td:last-child{text-align:right;}
.mkt-table th:nth-child(3),.mkt-table td:nth-child(3){text-align:right;}
.mkt-table th:nth-child(4),.mkt-table td:nth-child(4){text-align:right;}
.mkt-table td{padding:8px 12px;border-bottom:1px solid var(--border);font-size:12px;color:var(--text);transition:background .1s;}
.mkt-table tbody tr:last-child td{border-bottom:none;}
.mkt-table tr{cursor:pointer;}
.mkt-table tr:hover td{background:var(--bg2);}
.mkt-td-sym{font-family:var(--mono);font-size:10px;font-weight:700;color:var(--text);letter-spacing:.06em;}
.mkt-td-name{font-family:var(--sans);font-size:12px;color:var(--text2);}
.mkt-td-price{font-family:var(--mono);font-weight:700;font-size:13px;}
.mkt-td-chg{font-family:var(--mono);font-weight:700;font-size:11px;}
.mkt-td-status{font-size:9px;font-family:var(--mono);letter-spacing:.06em;}
.macro-accordion{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;overflow:hidden;border-left:2px solid transparent;transition:border-left-color var(--t1);}
.macro-accordion:has(.macro-body.open){border-left-color:var(--accent);}
.macro-body.open{border-top:1px solid var(--border);}
.mkt-footer{font-family:var(--mono);font-size:9px;color:var(--text4);margin-top:12px;letter-spacing:.04em;}
/* ── TILE BASE STYLES ── */
.tile{padding:14px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);position:relative;transition:border-color .18s var(--ease),box-shadow .18s var(--ease),transform .18s var(--ease);box-shadow:var(--shadow);}
.tile-clickable{cursor:pointer;}.tile-clickable:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-1px);}
.tile-offmarket{opacity:.65;}
.tile-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:4px;}
.tile-sym{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--text3);letter-spacing:.04em;}
.tile-label{font-family:var(--sans);font-size:12px;font-weight:600;color:var(--text);}
.tile-price{font-family:var(--mono);font-size:17px;font-weight:700;color:var(--text);}
.tile-chg{font-family:var(--mono);font-size:12px;font-weight:700;}
.tile-note{font-size:10px;color:var(--text4);margin-top:3px;font-family:var(--mono);}
.up{color:var(--green);}.dn{color:var(--red);}
.spark-wrap{position:absolute;top:0;right:0;opacity:.5;}
.tiles{display:none;}
.tile-loading{
  background:linear-gradient(90deg,var(--bg3) 25%,var(--bg4) 50%,var(--bg3) 75%);
  background-size:200% 100%;animation:shimmer 1.5s infinite;
  height:60px;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:8px;
}
.mkt-footer{font-family:var(--mono);font-size:10px;color:var(--text4);margin-top:14px;letter-spacing:.04em;}

/* ── UTILITY ── */
.sec-label{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.16em;color:var(--text4);text-transform:uppercase;}

/* ── GEO ── */
#geo-container{
  border:1px solid var(--border);border-radius:var(--radius);
  border-top:2px solid var(--accent);
  overflow:hidden;
  background:var(--bg2);box-shadow:var(--shadow-md);
}
#geo-topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 16px;border-bottom:1px solid var(--border);
  flex-wrap:wrap;gap:8px;background:var(--bg3);
}
.geo-title{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.12em;color:var(--text3);text-transform:uppercase;}
.geo-legend{display:flex;gap:16px;}
.geo-legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text3);}
.geo-legend-dot{width:7px;height:7px;border-radius:50%;pointer-events:none;}
#world-map{width:100%;display:block;max-height:600px;}
#geo-stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--border);}
.geo-stat{padding:12px 16px;text-align:center;border-right:1px solid var(--border);}
.geo-stat:last-child{border-right:none;}
.geo-stat-n{font-family:var(--mono);font-size:26px;font-weight:600;line-height:1;}
.geo-stat-l{font-family:var(--sans);font-size:10px;color:var(--text3);letter-spacing:.12em;margin-top:4px;text-transform:uppercase;}
#geo-info-panel{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);
  display:none;animation:fadeIn .2s ease;
  box-shadow:0 8px 40px rgba(0,0,0,.18);
  max-height:420px;width:400px;overflow-y:auto;
  position:fixed;z-index:300;
}
.geo-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:8px;}
.geo-card{
  background:var(--bg2);padding:14px 16px;
  border:1px solid var(--border);border-radius:var(--radius);
  border-left:3px solid transparent;
  box-shadow:var(--shadow);transition:all .2s ease;
}
.geo-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.geo-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;}
.geo-card-name{font-family:var(--sans);font-size:14px;font-weight:700;color:var(--text);}
.geo-card-int{font-family:var(--mono);font-size:26px;font-weight:600;line-height:1;}
.geo-card-row{display:flex;gap:8px;align-items:center;margin-bottom:6px;}
.geo-card-desc{font-size:12px;color:var(--text3);line-height:1.6;}
.type-chip{font-family:var(--mono);font-size:9px;font-weight:700;padding:2px 8px;border-radius:3px;border:1px solid;text-transform:uppercase;}
.trend-label{font-family:var(--mono);font-size:10px;font-weight:700;text-transform:uppercase;}

/* ── BILAN ── */
.bilan-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-bottom:20px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}
.kpi-card{
  padding:18px 22px;
  border-right:1px solid var(--border);
  transition:background .15s;
  position:relative;
}
.kpi-card:last-child{border-right:none;}
.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:transparent;transition:background .2s;}
.kpi-card:hover{background:var(--bg3);}
.kpi-card:hover::before{background:var(--accent);}
.kpi-label{font-family:var(--mono);font-size:8px;font-weight:700;letter-spacing:.2em;color:var(--text4);text-transform:uppercase;margin-bottom:10px;}
.kpi-val{font-family:var(--mono);font-size:32px;font-weight:700;line-height:1;letter-spacing:-.02em;}
.domain-bar{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);padding:16px;margin-bottom:20px;
  box-shadow:var(--shadow);
}
.domain-bar-title{font-family:var(--mono);font-size:10px;letter-spacing:.15em;color:var(--text3);text-transform:uppercase;margin-bottom:12px;}
.domain-row{display:flex;align-items:center;gap:12px;margin-bottom:8px;}
.domain-name{font-size:12px;font-weight:600;color:var(--text2);min-width:90px;}
.domain-track{flex:1;height:4px;background:var(--bg3);border-radius:2px;}
.domain-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .6s ease;}
.domain-count{font-family:var(--mono);font-size:11px;color:var(--text3);min-width:24px;text-align:right;}
.bilan-box{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);box-shadow:var(--shadow);
}
.bilan-box-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:10px;
}
.bilan-date{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--text3);}
.gen-btn{
  height:34px;padding:0 20px;
  background:var(--accent);border:none;border-radius:var(--radius);
  font-family:var(--sans);font-size:12px;font-weight:700;color:#fff;
  letter-spacing:.03em;transition:background .2s var(--ease),box-shadow .2s var(--ease);
  box-shadow:0 1px 4px rgba(10,30,61,.3);
}
.gen-btn:hover{background:var(--accent2);box-shadow:0 4px 12px rgba(10,30,61,.35);}
/* ── Anti-surcharge: metadata IA ── */
.ai-meta{display:flex;align-items:center;gap:10px;padding:8px 12px;margin-bottom:12px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);font-size:11px;color:var(--text3);font-family:var(--mono);}
.ai-meta .conf-badge{padding:2px 8px;border-radius:10px;font-weight:700;font-size:10px;text-transform:uppercase;}
.conf-high{background:rgba(26,127,75,.12);color:#1A7F4B;}
.conf-med{background:rgba(255,140,0,.12);color:#FF8C00;}
.conf-low{background:rgba(255,34,51,.12);color:#FF2233;}
.ai-meta .refresh-btn{margin-left:auto;background:none;border:1px solid var(--border);border-radius:var(--radius);padding:2px 10px;font-size:10px;color:var(--text2);cursor:pointer;font-family:var(--sans);}
.ai-meta .refresh-btn:hover{border-color:var(--accent);color:var(--accent);}
.ai-divergence{padding:8px 14px;margin-bottom:10px;background:rgba(255,200,32,.08);border:1px solid rgba(255,200,32,.3);border-radius:var(--radius);font-size:12px;color:#C8A020;}
.regen-btn{
  height:34px;padding:0 14px;
  background:none;border:1px solid var(--border);border-radius:var(--radius);
  font-size:12px;color:var(--text3);display:none;
}
.regen-btn:hover{border-color:var(--text3);color:var(--text);}
.bilan-body{padding:24px;}
.bilan-headline{font-family:var(--serif);font-size:22px;font-weight:600;color:var(--text);line-height:1.4;margin-bottom:12px;}
.bilan-synthese{font-size:14px;color:var(--text2);line-height:1.9;margin-bottom:24px;border-left:2px solid var(--gold);padding-left:18px;}
.section-title{font-family:var(--mono);font-size:9px;letter-spacing:.2em;color:var(--text4);text-transform:uppercase;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border);}
.theme-row{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px;}
.theme-poids{font-family:var(--mono);font-size:9px;font-weight:700;padding:3px 8px;border-radius:3px;letter-spacing:.08em;flex-shrink:0;margin-top:3px;border:1px solid;text-transform:uppercase;}
.theme-poids.MAJEUR    {border-color:var(--red);color:var(--red);background:var(--red-lt);}
.theme-poids.STRUCTUREL{border-color:var(--orange);color:var(--orange);background:var(--orange-lt);}
.theme-poids.ÉMERGENT  {border-color:var(--accent);color:var(--accent);background:var(--accent-lt);}
.theme-name{font-family:var(--sans);font-size:14px;font-weight:700;color:var(--text);margin-bottom:3px;}
.theme-ana {font-size:12px;color:var(--text3);line-height:1.6;}
.bilan-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px;}
.bilan-box-sm{padding:14px;border-radius:var(--radius);border:1px solid var(--border);}
.bilan-box-lbl{font-family:var(--mono);font-size:9px;letter-spacing:.15em;text-transform:uppercase;margin-bottom:6px;}
.bilan-box-txt{font-size:13px;color:var(--text2);line-height:1.7;}
.outlook-box{padding:14px;border-radius:var(--radius);border:1px solid var(--border);background:var(--accent-lt);}
.gen-spin{font-family:var(--mono);font-size:11px;color:var(--text3);letter-spacing:.15em;animation:pulse 1.5s infinite;display:none;}
.bilan-ph{font-size:14px;color:var(--text3);line-height:1.8;padding:24px;}
.bilan-section{margin-bottom:20px;}
.bilan-section-title{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.08em;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border);}
.bilan-card{padding:14px 16px;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:8px;}
.bilan-card-resume{font-size:14px;font-weight:600;color:var(--text);line-height:1.6;margin-bottom:4px;}
.bilan-card-impact{font-size:13px;color:var(--text2);line-height:1.7;}
.bilan-card-blind{font-size:13px;color:var(--text2);line-height:1.7;margin-top:8px;padding-top:8px;border-top:1px dashed var(--border);}
.bilan-tag{display:inline-block;font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.1em;padding:2px 8px;border-radius:3px;margin-top:6px;}
.tag-risk{background:rgba(192,57,43,.1);color:#C0392B;}
.tag-opp{background:rgba(26,127,75,.1);color:#1A7F4B;}
.ai-cat-btn{
  font-family:var(--mono);font-size:9px;font-weight:700;
  padding:5px 14px;border-radius:var(--radius-sm);
  border:1px solid var(--accent);background:var(--accent);color:#fff;
  cursor:pointer;white-space:nowrap;letter-spacing:.1em;text-transform:uppercase;
  transition:background .18s var(--ease),border-color .18s var(--ease),color .18s var(--ease),box-shadow .18s var(--ease);
  box-shadow:0 1px 4px rgba(10,30,61,.25);
}
.ai-cat-btn:hover{background:var(--accent2);box-shadow:0 3px 10px rgba(10,30,61,.3);}
.ai-cat-secondary{
  background:transparent !important;border-color:var(--border2) !important;
  color:var(--text2) !important;box-shadow:none !important;
}
.ai-cat-secondary:hover{border-color:var(--accent) !important;color:var(--accent) !important;background:var(--accent-lt) !important;}
.ai-cat-btn.loading{opacity:.55;pointer-events:none;}
#ai-cat-modal{
  display:none;position:fixed;inset:0;z-index:510;
  background:rgba(0,0,0,.5);backdrop-filter:blur(4px);
  justify-content:center;align-items:center;
}
#ai-cat-modal.open{display:flex;}
.ai-cat-box{
  background:var(--bg2);border:1px solid var(--border);border-radius:10px;
  width:min(90vw,720px);max-height:85vh;overflow-y:auto;
  box-shadow:var(--shadow-lg);
}
.ai-cat-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:20px 24px 16px;border-bottom:1px solid var(--border);
  position:sticky;top:0;background:var(--bg2);z-index:1;
}
.ai-cat-title{font-family:var(--serif);font-size:18px;font-weight:700;}
.ai-cat-close{background:none;border:none;font-size:18px;color:var(--text3);cursor:pointer;padding:4px 8px;}
.ai-cat-close:hover{color:var(--text);}
.ai-cat-body{padding:20px 24px;}

/* ── FOCUS VIEWS (France, USA, Chine, Afrique) ── */
.fr-header{
  display:flex;align-items:center;gap:16px;
  margin-bottom:20px;padding-bottom:16px;
  border-bottom:1px solid var(--border);
}
.fr-flag{display:flex;height:24px;border-radius:2px;overflow:hidden;box-shadow:var(--shadow);}
.fr-flag-b{width:10px;background:#002395;}
.fr-flag-w{width:10px;background:#FFFFFF;border-left:1px solid var(--border);border-right:1px solid var(--border);}
.fr-flag-r{width:10px;background:#ED2939;}
.fr-title{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--text);}
.fr-subtitle{font-size:13px;color:var(--text3);margin-left:auto;}
.fr-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;}
.fr-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:16px;}
.fr-card{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;
}
.fr-card-header{
  padding:12px 16px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.fr-card-title{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);}
.fr-card-badge{font-family:var(--mono);font-size:10px;color:var(--text4);}
.fr-card-body{padding:16px;}
.fr-news-item{
  padding:10px 0;border-bottom:1px solid var(--border);
  cursor:pointer;transition:all .12s;
}
.fr-news-item:last-child{border-bottom:none;}
.fr-news-item:hover{padding-left:4px;}
.fr-news-title{font-size:13px;font-weight:500;color:var(--text);line-height:1.5;margin-bottom:4px;}
.fr-news-meta{font-size:11px;color:var(--text4);display:flex;gap:8px;}
.fr-sondage-item{padding:10px 0;border-bottom:1px solid var(--border);}
.fr-sondage-item:last-child{border-bottom:none;}
.fr-sondage-label{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:6px;display:flex;justify-content:space-between;}
.fr-sondage-bar{height:8px;background:var(--bg3);border-radius:4px;overflow:hidden;}
.fr-sondage-fill{height:100%;border-radius:4px;transition:width .8s ease;}
.fr-perso-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 0;border-bottom:1px solid var(--border);
}
.fr-perso-item:last-child{border-bottom:none;}
.fr-perso-avatar{
  width:36px;height:36px;border-radius:50%;
  background:var(--accent);display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:12px;font-weight:700;color:#fff;flex-shrink:0;
}
.fr-perso-name{font-size:13px;font-weight:700;color:var(--text);}
.fr-perso-role{font-size:11px;color:var(--text3);}
.fr-perso-score{font-family:var(--mono);font-size:16px;font-weight:600;margin-left:auto;}
.fr-econ-item{
  display:flex;justify-content:space-between;align-items:center;
  padding:8px 0;border-bottom:1px solid var(--border);
}
.fr-econ-item:last-child{border-bottom:none;}
.fr-econ-label{font-size:12px;color:var(--text2);}
.fr-econ-val{font-family:var(--mono);font-size:14px;font-weight:600;}
.fr-econ-chg{font-family:var(--mono);font-size:11px;}
.fr-loading{text-align:center;padding:40px;font-family:var(--mono);font-size:11px;color:var(--text4);letter-spacing:.15em;animation:pulse 1.5s infinite;}

/* ── CHART MODAL ── */
#chart-modal{
  display:none;position:fixed;inset:0;z-index:520;
  background:rgba(0,0,0,.5);backdrop-filter:blur(4px);
  align-items:center;justify-content:center;
}
#chart-modal.open{display:flex;}
.chart-box{
  background:var(--bg2);border:1px solid var(--border);border-radius:10px;
  width:min(680px,92vw);padding:28px;position:relative;
  box-shadow:var(--shadow-lg);animation:fadeIn .22s var(--ease);
}
.chart-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;}
.chart-title{font-family:var(--serif);font-size:20px;font-weight:600;color:var(--text);}
.chart-meta{font-family:var(--mono);font-size:11px;color:var(--text3);margin-top:4px;}
.chart-close{background:none;border:none;color:var(--text3);font-size:22px;cursor:pointer;}.chart-close:hover{color:var(--text);}
#newsletter-btn:hover,#auth-btn:hover{background:rgba(255,255,255,.2)!important;}
.chart-price-row{display:flex;align-items:baseline;gap:12px;margin-bottom:20px;}
.chart-price{font-family:var(--mono);font-size:30px;font-weight:600;color:var(--text);}
.chart-chg{font-family:var(--mono);font-size:16px;font-weight:600;}
#chart-canvas{width:100%;display:block;}
.chart-loading{text-align:center;padding:40px;font-family:var(--mono);font-size:11px;color:var(--text3);letter-spacing:.15em;animation:pulse 1.5s infinite;}
.chart-period{display:flex;gap:6px;margin-top:12px;}
.chart-period-btn{height:26px;padding:0 12px;background:none;border:1px solid var(--border);border-radius:20px;font-family:var(--mono);font-size:11px;color:var(--text3);cursor:pointer;transition:all .12s;}
.chart-period-btn:hover{border-color:var(--accent);color:var(--accent);}
.chart-period-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;}

/* ── LOADING ── */
#loading-overlay{padding:60px 0;text-align:center;}
.loading-title{font-family:var(--mono);font-size:12px;color:var(--text3);letter-spacing:.2em;text-transform:uppercase;margin-bottom:20px;}
.loading-sources{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;max-width:500px;margin:0 auto;}
.loading-src{display:flex;align-items:center;gap:8px;padding:5px 8px;}
.loading-dot-anim{width:5px;height:5px;border-radius:50%;background:var(--accent);animation:pulse 1.5s infinite;pointer-events:none;}
.loading-src-name{font-family:var(--mono);font-size:11px;color:var(--text3);}

/* ── MOBILE PANEL ── */
#mob-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:var(--z-drawer);}
#mob-panel{
  display:none;position:fixed;bottom:0;left:0;right:0;
  max-height:80vh;overflow-y:auto;
  background:var(--bg2);border-top:1px solid var(--border);
  border-radius:14px 14px 0 0;padding:20px;z-index:var(--z-panel);
  animation:slideUp .3s ease;
}
.mob-handle{width:36px;height:3px;background:var(--border2);border-radius:2px;margin:0 auto 16px;}

/* ── RESPONSIVE ── */
@media(min-width:901px){.mobile-only{display:none!important;}}

@media(max-width:900px){
  #main{padding:16px 18px;border-left:none;border-right:none;box-shadow:none;}
  #news-layout.split{grid-template-columns:1fr;}
  .bilan-kpis{grid-template-columns:repeat(2,1fr);}
  .kpi-card:nth-child(2n){border-right:none;}
  .kpi-card:nth-child(1),.kpi-card:nth-child(2){border-bottom:1px solid var(--border);}
  .bilan-grid{grid-template-columns:1fr;}
  #geo-stats{grid-template-columns:repeat(2,1fr);}
  .tiles{grid-template-columns:repeat(2,1fr);}
  .fr-grid,.fr-grid-3{grid-template-columns:1fr;}
  .desktop-only{display:none!important;}
  .tb-item{display:none;}
  .geo-cards{grid-template-columns:1fr;}
}

@media(max-width:600px){
  /* ── TOPBAR MOBILE ── */
  html{font-size:17px;}
  #topbar{
    height:42px;padding:0 8px;gap:4px;
  }
  .tb-logo svg{width:18px;height:18px;}
  .tb-brand{font-size:9px;letter-spacing:.03em;}
  .tb-right{gap:4px;}
  #clock{display:none;}
  #newsletter-btn{display:none;}
  #tb-refresh-status{display:none;}
  .tb-meta{display:none!important;} /* hide source count + MAJ on mobile */
  #clock{font-size:9px;}
  #upill{display:none!important;} /* hide unread count on mobile - saves space */
  .btn-refresh{height:24px;padding:0 6px;font-size:9px;}
  .btn-refresh svg{width:9px;height:9px;}
  #theme-toggle{height:22px!important;width:22px!important;font-size:11px!important;}
  #sw-fr,#sw-en{height:18px!important;padding:0 5px!important;font-size:8px!important;}
  #newsletter-btn{display:none!important;} /* accessible via footer on mobile */
  #auth-btn{font-size:9px!important;height:22px!important;padding:0 8px!important;}

  /* ── TICKER MOBILE ── */
  #ticker-bar{height:28px;}
  .t-item{padding:0 10px;height:28px;}
  .t-sym{font-size:8px;}
  .t-price{font-size:10px;}
  .t-chg{font-size:9px;}
  .t-alert{padding:0 10px;height:28px;font-size:9px;}

  /* ── TABS MOBILE — horizontal scroll ── */
  #nav-tabs{
    padding:0 8px;gap:0;
    overflow-x:auto;overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    position:sticky;top:42px;z-index:190;
  }
  #nav-tabs::-webkit-scrollbar{display:none;}
  .tab{display:inline-flex;align-items:center;gap:6px;height:40px;padding:0 18px;font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.01em;color:var(--text3);border:none;background:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:color var(--t1),border-color var(--t1);}

  /* ── MAIN MOBILE ── */
  #main{padding:8px 10px;background:var(--bg);border:none;box-shadow:none;}

  /* ── FILTER ROW MOBILE ── */
  .filter-row{
    gap:4px;padding-bottom:4px;margin-bottom:4px;
    overflow-x:auto;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;flex-wrap:nowrap;
  }
  .filter-row::-webkit-scrollbar{display:none;}
  .filter-btn{font-family:var(--sans);font-size:11px;font-weight:500;height:26px;padding:0 11px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg2);color:var(--text3);cursor:pointer;transition:background var(--t1),border-color var(--t1),color var(--t1),box-shadow var(--t1);white-space:nowrap;}
  .ai-cat-btn{
    font-size:10px;padding:4px 8px;flex-shrink:0;white-space:nowrap;
  }
  .sig-count{display:none;}
  #filter-bar-2 div[style*="width:1px"]{display:none;}
  #filter-bar-2 span[style*="IMPACT"],
  #filter-bar-2 span[style*="TRI"],
  #filter-bar-2 span[style*="PÉRIODE"]{display:none;}
  #search-input{font-size:13px!important;height:32px!important;border-radius:8px!important;}

  /* ── NEWS CARDS MOBILE ── */
  .news-card{border-radius:6px;}
  .news-card:hover{transform:none;}
  .nc-body{padding:10px 12px;}
  .nc-meta{gap:5px;margin-bottom:4px;}
  .nc-badge{font-size:9px;padding:2px 6px;}
  .nc-source{font-size:11px;}
  .nc-domain{font-size:10px;}
  .nc-time{font-size:10px;}
  .nc-lang{font-size:8px;padding:1px 4px;}
  .nc-title{font-size:15px;line-height:1.45;}
  .source-cred{font-size:8px;padding:1px 4px;}

  /* ── MOBILE DETAIL PANEL (overlay) ── */
  #mob-panel{border-radius:16px 16px 0 0!important;max-height:75vh!important;}
  #mob-panel .dp-title{font-size:16px;line-height:1.4;}
  #mob-panel .dp-section-text{font-size:12px;line-height:1.6;}
  #mob-panel .dp-close{top:12px!important;right:12px!important;width:32px!important;height:32px!important;font-size:16px!important;}

  /* ── TILES MOBILE ── */
  .tiles{grid-template-columns:1fr 1fr;gap:6px;}
  .tile{padding:10px;}
  .tile:hover{transform:none;box-shadow:var(--shadow);}
  .tile-price{font-family:var(--mono);font-size:17px;font-weight:700;color:var(--text);}
  .tile-sym{font-size:10px;}
  .tile-label{font-family:var(--sans);font-size:12px;font-weight:600;color:var(--text);}
  .tile-chg{font-size:10px;}

  /* ── GEO MOBILE ── */
  #geo-stats{grid-template-columns:repeat(2,1fr);}
  .geo-stat{padding:8px 10px;}
  .geo-stat-n{font-family:var(--mono);font-size:26px;font-weight:600;line-height:1;}
  .geo-stat-l{font-size:8px;}
  .geo-cards{grid-template-columns:1fr;}
  .geo-card{padding:10px 12px;}
  .geo-card-name{font-size:13px;}
  .geo-card-int{font-size:22px;}
  .geo-legend{gap:8px;flex-wrap:wrap;}
  .geo-legend-item{font-size:9px;}
  .geo-title{font-size:9px;letter-spacing:.08em;}
  #geo-topbar{padding:8px 12px;gap:6px;}
  #world-map{max-height:200px;}

  /* ── BILAN MOBILE ── */
  .bilan-kpis{grid-template-columns:1fr 1fr;gap:0;}
  #bilan-preview{grid-template-columns:1fr!important;}
  .kpi-card{padding:14px 16px;}
  .kpi-label{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.14em;color:var(--text4);text-transform:uppercase;margin-bottom:6px;}
  .kpi-val{font-size:26px;}
  .bilan-box-header{padding:12px 14px;gap:6px;}
  .bilan-date{font-size:10px;}
  .gen-btn{height:30px;padding:0 14px;font-size:11px;}
  .regen-btn{height:30px;padding:0 10px;font-size:11px;}
  .bilan-body{padding:14px;}
  .bilan-headline{font-size:17px;margin-bottom:8px;}
  .bilan-synthese{font-size:12px;line-height:1.7;padding-left:12px;margin-bottom:16px;}
  .bilan-section-title{font-size:11px;}
  .bilan-grid{grid-template-columns:1fr;}
  .theme-row{flex-direction:column;gap:6px;}
  .theme-poids{align-self:flex-start;}
  .domain-bar{padding:12px;}
  .domain-name{min-width:70px;font-size:11px;}

  /* ── MODALS MOBILE ── */
  .ai-cat-box{width:100%;max-height:92vh;border-radius:12px 12px 0 0;}
  .ai-cat-header{padding:14px 16px 12px;}
  .ai-cat-title{font-size:16px;}
  .ai-cat-body{padding:14px 16px;}
  .intel-box{width:100%;max-height:92vh;border-radius:12px 12px 0 0;}
  .intel-header{padding:14px 16px 12px;}
  .intel-title{font-size:16px;}
  .intel-body{padding:14px 16px;}
  .chart-box{width:100%;padding:16px;border-radius:12px 12px 0 0;}
  .chart-title{font-size:16px;}
  .chart-price{font-size:22px;}
  .chart-chg{font-size:13px;}
  .chart-period-btn{height:24px;padding:0 10px;font-size:10px;}

  /* ── FILTER BAR 2 MOBILE — compact ── */
  #filter-bar-2{
    flex-wrap:wrap!important;
    gap:4px!important;
    padding-bottom:2px!important;
    margin-bottom:2px!important;
  }
  #filter-bar-2>div:first-child{
    flex:1 1 100%!important;
    min-width:100%!important;
    margin-bottom:2px;
  }

  /* ── INTELLIGENCE BUTTONS MOBILE — grid 3x2 ── */
  #filter-bar-3{
    display:grid!important;
    grid-template-columns:1fr 1fr 1fr;
    gap:4px!important;
    padding:4px 0 8px!important;
    margin:0!important;
  }
  #filter-bar-3 .ai-cat-btn{
    font-size:9px!important;
    padding:6px 2px!important;
    border-radius:6px;
    min-height:30px;
    text-align:center;
    white-space:nowrap;
  }

  /* ── ENTITY/CROSS GRIDS MOBILE ── */
  .entity-card{padding:10px 12px;}
  .entity-name{font-size:12px;}
  .cross-signal{padding:10px 12px;}
  .cross-signal-theme{font-size:13px;}

  /* ── AGENDA MOBILE ── */
  #pane-agenda .filter-btn{font-family:var(--sans);font-size:11px;font-weight:500;height:26px;padding:0 11px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg2);color:var(--text3);cursor:pointer;transition:background var(--t1),border-color var(--t1),color var(--t1),box-shadow var(--t1);white-space:nowrap;}
  #agenda-form>div{grid-template-columns:1fr!important;}
  #agenda-calendar div[style*="grid-template-columns:repeat(7"]{font-size:8px;}
  #agenda-calendar div[style*="min-height:70px"]{min-height:50px!important;}

  /* ── BILAN PANELS MOBILE ── */
  .bilan-panels{grid-template-columns:1fr!important;}

  /* ── DOSSIERS MOBILE ── */
  .dossier-grid{grid-template-columns:1fr!important;}
  .dossier-grid-3{grid-template-columns:1fr!important;}
  .dossier-card{padding:16px!important;}
  #dossiers-gen-btn{width:100%;margin-top:8px;}

  /* ── WATCHLIST MOBILE ── */
  #wl-input{font-size:14px!important;height:34px!important;}
  #wl-stats{grid-template-columns:1fr!important;}

  /* ── LOADING MOBILE ── */
  .loading-sources{grid-template-columns:1fr 1fr;gap:4px;}
  .loading-title{font-size:11px;letter-spacing:.12em;}

  /* ── FOCUS VIEWS MOBILE ── */
  .fr-header{gap:10px;margin-bottom:12px;padding-bottom:10px;}
  .fr-title{font-size:17px;}
  .fr-subtitle{font-size:11px;}
  .fr-grid,.fr-grid-3{grid-template-columns:1fr;gap:10px;}
  .fr-card-title{font-size:10px;}
  .fr-news-title{font-size:12px;}
  .fr-news-meta{font-size:10px;}

  /* ── GEO PANEL MOBILE ── */
  #geo-info-panel{width:calc(100vw - 24px)!important;left:12px!important;right:12px!important;}

  /* ── AUTH/NEWSLETTER/LEGAL MODALS MOBILE ── */
  #auth-modal>div>div:last-child,
  #newsletter-modal>div>div:first-child,
  #newsletter-modal form{padding-left:20px!important;padding-right:20px!important;}
  #legal-modal>div{padding:20px!important;}

  /* ── FOOTER MOBILE ── */
  #site-footer{padding:24px 16px 16px!important;}
  #site-footer>div:first-child{grid-template-columns:1fr 1fr!important;gap:16px!important;}
  #site-footer>div:last-child{flex-direction:column;text-align:center;gap:4px;}

  /* ── MARKET HERO MOBILE ── */
  .mkt-heroes{grid-template-columns:1fr 1fr!important;gap:8px!important;}
  .mkt-hero{padding:10px 12px!important;}
  .mkt-hero-price{font-family:var(--mono);font-size:20px;font-weight:700;color:var(--text);line-height:1;margin-bottom:2px;letter-spacing:-.02em;}
  .mkt-hero-label{font-family:var(--mono);font-size:9px;color:var(--text4);margin-top:6px;letter-spacing:.06em;}
  .mkt-hero-sym{font-family:var(--mono);font-size:8px;font-weight:700;color:var(--text4);letter-spacing:.16em;margin-bottom:8px;text-transform:uppercase;}
  /* Market table mobile */
  #mkt-table-wrap{font-size:12px;}
  #mkt-table-wrap th,#mkt-table-wrap td{padding:6px 8px!important;}

  /* ── LANDING PAGE MOBILE ── */
  #landing nav{padding:12px 16px;}
  #landing nav span{font-size:18px!important;}
  #landing section{padding:0 16px!important;margin-top:40px!important;}
  #landing h1{font-size:26px!important;line-height:1.25!important;}
  #landing p{font-size:15px!important;}
  #landing section>div[style*="grid"]{grid-template-columns:1fr!important;gap:16px!important;}
  #pricing-section>div[style*="grid"]{grid-template-columns:1fr!important;gap:16px!important;}
  #landing button,#landing a[href="#pricing-section"]{
    width:100%!important;padding:14px 24px!important;font-size:13px!important;
    display:block!important;text-align:center!important;box-sizing:border-box!important;
  }
  #landing div[style*="display:flex;gap:12px"]{flex-direction:column!important;}

  /* ── ONBOARDING MOBILE ── */
  #onboarding-overlay>div{padding:24px!important;max-width:92vw!important;}
  #onboarding-overlay>div>div:first-child{font-size:32px!important;}
  #onboarding-overlay button{padding:10px 14px!important;font-size:12px!important;}

  /* ── CRISIS BANNER MOBILE ── */
  #crisis-banner{font-size:10px!important;padding:6px 12px!important;}

  /* ── GEO INFO PANEL BOTTOM SHEET ── */
  #geo-info-panel{
    bottom:0!important;top:auto!important;
    border-radius:12px 12px 0 0!important;
    max-height:70vh!important;
  }
}

/* ── ÉCRAN INTERMÉDIAIRE (376-480px — petits phones) ── */
/* Couvre le gap identifié entre les breakpoints 374px et 600px */
@media(max-width:480px){
  .bilan-panels{grid-template-columns:1fr!important;}   /* panels bilan en colonne */
  #bilan-preview{grid-template-columns:1fr!important;}  /* preview bilan en colonne */
  .mkt-heroes{grid-template-columns:1fr 1fr!important;} /* 2 heroes max sur petits phones */
  .geo-cards{grid-template-columns:1fr!important;}      /* geo cards en colonne */
  .kpi-card{padding:10px 12px;}
  .kpi-val{font-size:24px;}
}

/* ── TRÈS PETIT ÉCRAN (<375px) ── */
@media(max-width:374px){
  #stocks-grid{grid-template-columns:1fr 1fr!important;}
  .mkt-heroes{grid-template-columns:1fr!important;}     /* 1 colonne sur très petit */
}

/* ── INTEL SERVICE ── */
#intel-modal{
  display:none;position:fixed;inset:0;z-index:var(--z-onboarding);
  background:rgba(0,0,0,.5);backdrop-filter:blur(4px);
  justify-content:center;align-items:center;
}
#intel-modal.open{display:flex;}
.intel-box{
  background:var(--bg2);border:1px solid var(--border);border-radius:8px;
  width:min(92vw,820px);max-height:88vh;overflow-y:auto;
  box-shadow:0 20px 60px rgba(0,0,0,.2);
}
.intel-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:20px 24px 16px;border-bottom:1px solid var(--border);
  position:sticky;top:0;background:var(--bg2);z-index:1;
}
.intel-title{font-family:var(--serif);font-size:18px;font-weight:700;}
.intel-close{background:none;border:none;font-size:18px;color:var(--text3);cursor:pointer;padding:4px 8px;}
.intel-close:hover{color:var(--text);}
.intel-body{padding:20px 24px;}
.intel-classification{font-family:var(--mono);font-size:9px;letter-spacing:.2em;padding:3px 10px;border-radius:3px;font-weight:700;}
.entity-card{padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;background:var(--bg2);cursor:pointer;transition:all .15s;}
.entity-card:hover{border-color:var(--accent);box-shadow:var(--shadow);}
.entity-name{font-size:14px;font-weight:700;color:var(--text);}
.entity-type{font-family:var(--mono);font-size:9px;font-weight:700;padding:2px 8px;border-radius:3px;letter-spacing:.08em;}
.entity-mentions{font-family:var(--mono);font-size:11px;color:var(--text3);}
.cross-signal{padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;border-left:4px solid var(--accent);}
.cross-signal-theme{font-size:14px;font-weight:700;color:var(--text);margin-bottom:6px;}
.cross-signal-sources{font-size:11px;color:var(--text3);margin-bottom:6px;}
.cross-signal-articles{font-size:12px;color:var(--text2);line-height:1.6;}
.source-cred{font-family:var(--mono);font-size:9px;font-weight:700;padding:2px 6px;border-radius:3px;margin-left:4px;}
.cred-A{background:rgba(26,127,75,.1);color:#1A7F4B;}
.cred-B{background:rgba(0,35,149,.1);color:#002395;}
.cred-C{background:rgba(192,92,0,.1);color:#C05C00;}
.cred-D{background:rgba(192,57,43,.1);color:#C0392B;}

/* ── GATING FREE/PREMIUM ── */
.tab-pro{
  font-family:var(--mono) !important;font-size:7px !important;font-weight:800 !important;
  padding:2px 7px !important;border-radius:2px !important;
  background:#C9A84C !important;
  color:#1A1000 !important;letter-spacing:.16em !important;
  margin-left:5px;line-height:1.6 !important;
  display:inline-block !important;
  box-shadow:0 1px 4px rgba(150,100,0,.3) !important;
  position:relative;top:-1px;
  white-space:nowrap;text-transform:uppercase;
}
.gate-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(245,243,238,0) 0%,rgba(245,243,238,.92) 30%,rgba(245,243,238,1) 60%);
  display:flex;flex-direction:column;align-items:center;justify-content:flex-end;
  padding-bottom:40px;z-index:10;border-radius:var(--radius);
}
[data-theme="dark"] .gate-overlay{
  background:linear-gradient(to bottom,rgba(8,10,16,0) 0%,rgba(8,10,16,.92) 30%,rgba(8,10,16,1) 60%);
}
.gate-overlay-box{
  text-align:center;padding:28px 32px;
  background:var(--bg2);border:1px solid var(--border);border-radius:8px;
  box-shadow:0 8px 32px rgba(0,0,0,.12);max-width:380px;
}
.gate-lock{font-size:28px;margin-bottom:10px;}
.gate-title{font-family:var(--serif);font-size:17px;font-weight:700;color:var(--text);margin-bottom:6px;}
.gate-desc{font-size:12px;color:var(--text3);line-height:1.6;margin-bottom:18px;}
.gate-cta{
  display:inline-block;padding:10px 24px;
  background:var(--accent);color:#fff;border:none;border-radius:var(--radius);
  font-family:var(--sans);font-size:12px;font-weight:700;cursor:pointer;
  transition:background .15s;
}
.gate-cta:hover{background:var(--accent2);}
.pane-gated{position:relative;overflow:hidden;min-height:400px;}
@media(max-width:600px){
  .pane-gated{min-height:260px;}
  .gate-overlay{padding-bottom:24px;}
  .gate-overlay-box{padding:20px 18px;max-width:90vw;}
  .gate-cta{padding:9px 18px;font-size:11px;}
}


/* ══════════════════════════════════════════════════════
   OPTIMISATION PC & MOBILE — v2026-03-24
   ══════════════════════════════════════════════════════ */

/* ── PC : colonnes flex sans overflow ── */
.col-news,.col-side{min-width:0;}

/* ── PC : word-wrap sur titres de cards ── */
.card-title{word-break:break-word;overflow-wrap:anywhere;}

/* ── PC + Mobile : table avec scroll horizontal ── */
.tbl-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius);position:relative;}
.tbl-scroll::after{content:'';position:absolute;top:0;right:0;bottom:0;width:24px;background:linear-gradient(to right,transparent,var(--bg2));pointer-events:none;border-radius:0 var(--radius) var(--radius) 0;}

/* ── PC : macro-hdr-vals overflow ── */
.macro-hdr-vals{flex-shrink:1;min-width:0;overflow:hidden;}

/* ── Tabs scroll snap ── */
#nav-tabs{-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;}
.tab{scroll-snap-align:start;}

/* ── MOBILE 600px — touch targets 36px (obligatoire selon docs) ── */
@media(max-width:600px){
  .filter-btn{height:36px!important;padding:0 14px;font-size:12px;}
  .modal-body{max-height:80vh;overflow-y:auto;}
}

/* ── MOBILE 480px ── */
@media(max-width:480px){
  .mkt-table th{font-size:10px;}
  .filter-row{flex-wrap:wrap;gap:6px;}
  #map-zoom-ctrl button{width:24px!important;height:24px!important;font-size:13px!important;}
  #map-zoom-ctrl{bottom:6px!important;right:6px!important;gap:3px!important;}
}

/* ── MOBILE 374px ── */
@media(max-width:374px){
  .news-card{padding:10px 12px;}
  .topbar{padding:0 8px!important;}
  .brand,.tb-brand{font-size:13px!important;}
  .topbar-btn,.tb-btn{width:30px!important;height:30px!important;}
}

/* ── MACRO ACCORDION MOBILE ── */
@media(max-width:600px){
  .macro-body{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .macro-tbl td{padding:6px 8px;}
  .col-date{display:none;}
  .col-spark{display:none;}
  .col-name{max-width:100px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .macro-hdr{flex-wrap:wrap;gap:4px 14px;padding:10px 12px;}
  .macro-hdr-label{order:1;}
  .macro-hdr-chevron{order:2;margin-left:auto;}
  .macro-hdr-vals{order:3;flex:0 0 100%;flex-wrap:wrap;gap:4px 8px;white-space:normal;overflow:visible;}
  .macro-hdr-val{font-size:9px;gap:3px;white-space:nowrap;}
}
@media(max-width:374px){
  .macro-hdr-val:nth-child(n+4){display:none;}
  .macro-hdr-sep:nth-child(n+3){display:none;}
}

/* ── PROFIL DÉCIDEUR CHIPS ───────────────────────── */
.prof-chip{font-family:var(--sans);font-size:12px;font-weight:700;height:34px;padding:0 14px;border:1px solid var(--border);border-radius:var(--radius);background:none;color:var(--text3);cursor:pointer;transition:background .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease),box-shadow .2s var(--ease);white-space:nowrap;letter-spacing:.01em;}
.prof-chip.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 1px 4px rgba(10,30,61,.3);}
.prof-chip:hover:not(.active){border-color:var(--text3);color:var(--text);}
@media(max-width:767px){.prof-chip{height:30px;padding:0 10px;font-size:11px;}}

/* ── FILTER SHEET ────────────────────────────────── */
.fs-section-label{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.14em;color:var(--text4);text-transform:uppercase;margin:16px 0 8px;}
.fs-chip-row{display:flex;flex-wrap:wrap;gap:6px;}
.fs-chip{font-family:var(--sans);font-size:12px;font-weight:500;height:32px;padding:0 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg2);color:var(--text3);cursor:pointer;transition:background var(--t1),border-color var(--t1),color var(--t1);white-space:nowrap;}
.fs-chip.active{background:var(--accent);border-color:var(--accent);color:#fff;}
.fs-chip:hover:not(.active){background:var(--bg3);}
#filter-bar-2a::-webkit-scrollbar{display:none;}
#filter-sheet{box-shadow:0 -8px 32px rgba(0,0,0,.18);}

/* ── MOBILE / DESKTOP FILTER VISIBILITY ─────────── */
.mobile-only { display: none !important; }
.desktop-inline-filters { display: flex; }
@media(max-width: 767px){
  .mobile-only { display: flex !important; }
  .desktop-inline-filters { display: none !important; }
  #filter-sheet-btn { display: flex !important; }
}

/* ── FILTER ROW 1 WRAPPER ───────────────────────── */
#filter-row-1-wrap {
  display:flex;flex-direction:row;flex-wrap:nowrap;
  align-items:center;gap:0;margin-bottom:6px;
  overflow-x:auto;scrollbar-width:none;
}
#filter-row-1-wrap::-webkit-scrollbar{display:none;}
#filter-bar {
  display:flex;flex-direction:row;flex-wrap:nowrap;gap:6px;
  align-items:center;flex-shrink:0;overflow-x:visible;
}
@media(max-width:767px){
  .desktop-sep { display:none !important; }
  /* Sur mobile: urgence seule en ligne 1, catégories via #cat-mobile et bottom sheet */
  #filter-row-1-wrap { flex-wrap:wrap!important; gap:6px!important; overflow-x:visible; margin-bottom:4px; }
  /* Cacher les chips catégories (remplacées par #cat-mobile select + bottom sheet) */
  #filter-bar    { display:none!important; }
  /* Urgence prend toute la largeur */
  #filter-bar-2a { width:100%!important; flex:0 0 auto; overflow-x:auto; order:1; }
  .desktop-sep   { order:0; }
}

/* ── MOBILE FILTER REARRANGEMENT ────────────────── */
@media(max-width:767px){
  /* Row 1 urgence: scrollable, no wrap */
  #filter-bar-2a { flex-wrap:nowrap; overflow-x:auto; scrollbar-width:none; }
  #filter-bar-2a::-webkit-scrollbar { display:none; }

  /* Row 2: hide period-quick (already in sheet), keep only search + Filtres */
  #period-quick { display:none!important; }
  #filter-bar-2b { flex-wrap:nowrap; }
  #search-input { font-size:14px; }

  /* Row 3 AI buttons: single scrollable row, no wrap */
  #filter-bar-3 { flex-wrap:nowrap!important; overflow-x:auto; scrollbar-width:none; padding-bottom:2px; }
  #filter-bar-3::-webkit-scrollbar { display:none; }
  .ai-cat-btn { flex-shrink:0; }

  /* Show sig-count on mobile */
  .sig-count { display:inline!important; font-size:10px; }
}

/* ── FORCE AI BUTTONS SINGLE ROW ── */
@media(max-width:767px){
  #filter-bar-3 {
    display:flex!important;
    flex-wrap:nowrap!important;
    overflow-x:auto!important;
    -webkit-overflow-scrolling:touch;
  }
  #filter-bar-3 .ai-cat-btn { flex-shrink:0!important; }
}

/* categories now always visible via #filter-row-1-wrap */

/* ── TOAST NOTIFICATIONS ─────────────────────────── */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:9100;display:flex;flex-direction:column-reverse;gap:8px;pointer-events:none;max-width:360px;}
@media(max-width:767px){#toast-container{bottom:72px;right:12px;left:12px;max-width:100%;}}
.toast{background:var(--bg2);border-radius:8px;padding:12px 16px;font-size:13px;font-family:var(--sans);color:var(--text);box-shadow:0 4px 24px rgba(0,0,0,.3);pointer-events:all;display:flex;align-items:flex-start;gap:10px;transform:translateX(120%);opacity:0;transition:transform .28s cubic-bezier(.4,0,.2,1),opacity .28s;}
.toast.show{transform:translateX(0);opacity:1;}
.toast-success{border-left:3px solid #2ed573;}.toast-error{border-left:3px solid var(--red);}.toast-info{border-left:3px solid var(--accent);}.toast-warning{border-left:3px solid #ffa500;}
.toast-icon{font-size:14px;font-weight:700;flex-shrink:0;margin-top:1px;}
.toast-msg{flex:1;line-height:1.5;}
.toast-close{background:none;border:none;color:var(--text4);cursor:pointer;font-size:16px;padding:0;flex-shrink:0;line-height:1;transition:color .15s;margin-top:-1px;}
.toast-close:hover{color:var(--text);}

/* ── PASSWORD TOGGLE ─────────────────────────────── */
.pass-wrap{position:relative;display:flex;align-items:center;}
.pass-wrap input{width:100%;padding-right:38px!important;}
.pass-toggle{position:absolute;right:10px;background:none;border:none;cursor:pointer;color:var(--text4);padding:4px;line-height:1;transition:color .15s;font-size:16px;}
.pass-toggle:hover{color:var(--text2);}

/* ── TAB TRANSITIONS ─────────────────────────────── */
.pane{animation:none;}
.pane.tab-fade{animation:tabFadeIn .18s ease forwards;}
@keyframes tabFadeIn{from{opacity:0;transform:translateY(5px);}to{opacity:1;transform:translateY(0);}}

/* ── INPUT FOCUS STATES ──────────────────────────── */
.auth-input{width:100%;height:38px;padding:0 12px;background:var(--bg3);border:1.5px solid var(--border);border-radius:var(--radius);font-size:14px;color:var(--text);font-family:var(--sans);box-sizing:border-box;transition:border-color .15s,box-shadow .15s;outline:none;}
.auth-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(10,102,194,.12);}
.auth-input.error{border-color:var(--red)!important;}
.auth-input.success{border-color:#2ed573!important;}

