
:root{
  --bg:#0a0e1a;--surf:#111827;--card:#1a2236;--brd:#2a3550;
  --gold:#f5a623;--gold2:#e8941a;--txt:#e8eaf0;--muted:#8892a4;
  --grn:#22c55e;--red:#ef4444;--blu:#3b82f6;--pur:#8b5cf6;--acc:#1e3a5f;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;height:100dvh;background:var(--bg);color:var(--txt);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;font-size:13px;line-height:1.5;overflow:hidden;display:flex;flex-direction:column}

/* NAV */
#topnav{position:relative;z-index:300;background:var(--surf);border-bottom:1px solid var(--brd);height:52px;display:flex;align-items:center;padding:0 12px;gap:8px;flex-shrink:0}
.logo{display:flex;align-items:center;gap:7px;text-decoration:none;flex-shrink:0}
.logo-box{width:26px;height:26px;background:var(--gold);border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#0a0e1a}
.logo-txt{font-size:13px;font-weight:500;color:var(--txt)}
.logo-txt span{color:var(--gold)}

/* SEARCH */
.search-wrap{flex:1;max-width:480px;position:relative}
#searchInput{width:100%;background:var(--card);border:1px solid var(--brd);color:var(--txt);padding:7px 12px 7px 34px;border-radius:8px;font-size:12px;outline:none}
#searchInput:focus{border-color:var(--gold)}
#searchInput::placeholder{color:var(--muted)}
.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:14px;pointer-events:none}
#searchResults{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surf);border:1px solid var(--brd);border-radius:8px;z-index:999;display:none;max-height:320px;overflow-y:auto}
.sr-item{padding:9px 14px;cursor:pointer;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--brd)}
.sr-item:last-child{border-bottom:none}
.sr-item:hover{background:var(--acc)}
.sr-sym{font-size:12px;font-weight:500;min-width:80px}
.sr-name{font-size:11px;color:var(--muted)}
.sr-cat{font-size:9px;color:var(--gold);background:#2d2010;padding:2px 5px;border-radius:3px;margin-left:auto}

.nav-tabs{display:flex;gap:1px;flex-shrink:0}
.nt{padding:5px 9px;border-radius:5px;border:none;background:none;color:var(--muted);font-size:11px;cursor:pointer;white-space:nowrap}
.nt:hover,.nt.active{background:var(--card);color:var(--txt)}
.nt.active{color:var(--gold)}

.nav-right{margin-left:auto;display:flex;align-items:center;gap:6px;flex-shrink:0}
.plan-pill{padding:3px 8px;border-radius:20px;font-size:10px;font-weight:500;cursor:pointer}
.plan-pill.free{background:#1e2d40;color:#60a5fa}
.plan-pill.pro{background:#2d1f4a;color:#a78bfa}
.plan-pill.premium{background:#2d2010;color:var(--gold)}
.btn-cta{background:var(--gold);color:#0a0e1a;border:none;padding:5px 12px;border-radius:6px;font-size:11px;font-weight:600;cursor:pointer}
.btn-cta:hover{background:var(--gold2)}
.btn-login{background:var(--card);border:1px solid var(--brd);color:var(--txt);padding:5px 10px;border-radius:6px;font-size:11px;cursor:pointer}

/* TICKER */
/* The ticker bar wraps many symbols. Allow horizontal scrolling so text isn't truncated.
   We enable horizontal scrolling and prevent vertical overflow. */
#tickerBar{background:var(--card);border-bottom:1px solid var(--brd);height:40px;flex-shrink:0;overflow-x:auto;overflow-y:hidden;white-space:nowrap}

/* BREAKING */
#breaking{background:#1a0808;border-bottom:1px solid #4a1818;height:24px;display:flex;align-items:center;gap:8px;padding:0 12px;overflow:hidden;flex-shrink:0}
.b-badge{background:var(--red);color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:3px;flex-shrink:0}
.b-scroll{flex:1;overflow:hidden;white-space:nowrap;font-size:10px}
.b-inner{display:inline-block;animation:bscroll 45s linear infinite}
@keyframes bscroll{from{transform:translateX(100%)}to{transform:translateX(-100%)}}
@keyframes pulse-gold{0%,100%{box-shadow:0 0 0 0 rgba(245,166,35,.4)}50%{box-shadow:0 0 0 8px rgba(245,166,35,0)}}

/* LAYOUT PRINCIPAL */
#layout{display:flex;flex:1;min-height:0;overflow:hidden}

/* SIDEBAR */
#sidebar{width:190px;flex-shrink:0;background:var(--surf);border-right:1px solid var(--brd);overflow-y:auto;display:flex;flex-direction:column}
.sb-sec{padding:8px 12px 3px;font-size:9px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.7px}
.sb-item{display:flex;align-items:center;gap:7px;padding:5px 12px;cursor:pointer;color:var(--muted);font-size:11px;border-left:2px solid transparent;transition:all .1s}
.sb-item:hover,.sb-item.active{background:var(--acc);color:var(--txt);border-left-color:var(--gold)}
.sb-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.sb-chg{margin-left:auto;font-size:10px}

/* MAIN */
#main{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}
.view{display:none;flex:1;overflow:auto;height:100%}
.view.active{display:flex;flex-direction:column;overflow:hidden}
/* VUE MARCHES - GRILLE */
.markets-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:10px}
.mcard{background:var(--card);border:1px solid var(--brd);border-radius:8px;overflow:hidden;cursor:pointer;transition:border-color .15s;position:relative}
.mcard:hover{border-color:var(--gold)}
.mcard-head{padding:8px 10px 4px;display:flex;justify-content:space-between;align-items:center}
.mc-sym{font-size:12px;font-weight:500}
.mc-cat{font-size:9px;color:var(--muted);background:var(--brd);padding:1px 5px;border-radius:3px}
/* Overlay qui bloque les clics TradingView dans les mini widgets de la page Marches */
.mcard .tv-block-overlay{position:absolute;top:30px;left:0;right:0;bottom:0;z-index:10;cursor:pointer;background:transparent}
/* Bouton TV discret en haut droite de chaque card */
.mcard .tv-ext-btn{position:absolute;top:6px;right:6px;z-index:20;background:rgba(10,14,26,.85);border:1px solid rgba(245,166,35,.4);color:var(--gold);padding:2px 7px;border-radius:3px;font-size:8px;font-weight:600;cursor:pointer;text-decoration:none;opacity:0;transition:opacity .2s;letter-spacing:.3px}
.mcard:hover .tv-ext-btn{opacity:1}

/* VUE CHART - plein ecran */
#chartContainer{flex:1;display:flex;flex-direction:column}
#chartTopBar{background:var(--surf);border-bottom:1px solid var(--brd);padding:8px 12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex-shrink:0}
#chartSymbol{font-size:15px;font-weight:500}
.tfs{display:flex;gap:2px;margin-left:auto}
.tf{background:none;border:none;color:var(--muted);padding:3px 7px;border-radius:4px;font-size:11px;cursor:pointer}
.tf:hover,.tf.active{background:var(--acc);color:var(--txt)}
#tvChart{flex:1;min-height:0}

/* VUE NEWS */
#newsContainer{flex:1;overflow:hidden}

/* PANEL DROIT */
#rpanel{width:250px;flex-shrink:0;background:var(--surf);border-left:1px solid var(--brd);overflow-y:auto;display:flex;flex-direction:column}
.rp-block{border-bottom:1px solid var(--brd);flex-shrink:0}
.rp-title{padding:8px 10px 5px;font-size:9px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}

/* MODAL */
.modal-wrap{display:none;position:fixed;inset:0;z-index:999;background:rgba(0,0,0,.8);align-items:center;justify-content:center;padding:16px}
.modal-wrap.open{display:flex}
.modal{background:var(--surf);border:1px solid var(--brd);border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto}
.modal-head{padding:18px 18px 0;display:flex;justify-content:space-between;align-items:center}
.modal-close{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer}
.modal-body{padding:18px}
.plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}
@media(max-width:550px){.plans-grid{grid-template-columns:1fr}}
.pcard{background:var(--card);border:1px solid var(--brd);border-radius:8px;padding:12px;position:relative}
.pcard.feat{border-color:var(--gold)}
.pp-pop{position:absolute;top:-9px;left:50%;transform:translateX(-50%);background:var(--gold);color:#0a0e1a;font-size:9px;font-weight:700;padding:2px 8px;border-radius:8px;white-space:nowrap}
.pp-name{font-size:13px;font-weight:500;margin-bottom:2px}
.pp-price{font-size:20px;font-weight:500;color:var(--gold)}
.pp-price span{font-size:10px;color:var(--muted);font-weight:400}
.pp-desc{font-size:10px;color:var(--muted);margin-bottom:8px}
.pp-feats{list-style:none;font-size:10px}
.pp-feats li{padding:1px 0;color:var(--muted);display:flex;align-items:center;gap:4px}
.pp-feats li.on{color:var(--txt)}
.fc{color:var(--grn)}.fx{color:var(--brd)}
.btn-plan{width:100%;padding:7px;border-radius:6px;font-size:11px;font-weight:500;cursor:pointer;margin-top:8px;border:1px solid var(--brd);background:var(--surf);color:var(--txt)}
.btn-plan:hover{border-color:var(--gold);color:var(--gold)}
.btn-plan.gold{background:var(--gold);color:#0a0e1a;border-color:var(--gold)}
.fi{width:100%;background:var(--card);border:1px solid var(--brd);color:var(--txt);padding:8px 11px;border-radius:6px;font-size:12px;outline:none;margin-bottom:10px}
.fi:focus{border-color:var(--gold)}
.flabel{font-size:10px;color:var(--muted);display:block;margin-bottom:3px}
.auth-switch{font-size:11px;color:var(--muted);text-align:center;margin-top:8px;cursor:pointer}
.auth-switch span{color:var(--gold)}
.err-msg{color:var(--red);font-size:11px;text-align:center;margin-bottom:6px;min-height:14px}
.ok-msg{color:var(--grn);font-size:11px;text-align:center;margin-bottom:6px;min-height:14px}


/* DEMO TRADING */
#demoTVChart{flex:1;min-height:400px;width:100%;display:block;overflow:hidden}
#demoTVChart iframe{width:100%;height:100%;min-height:400px;border:none;display:block}
#tvHlsVideo{width:100%;height:100%;background:#000;display:block}
.tv-player-wrap>div:last-child{flex:1;min-height:0;overflow:hidden}

@keyframes pulse2{0%,100%{opacity:1}50%{opacity:.4}}

.lev-btn{background:var(--card);border:1px solid var(--brd);color:var(--muted);padding:3px 6px;border-radius:4px;font-size:9px;cursor:pointer;transition:all .1s}
.lev-btn:hover,.lev-btn.active{background:rgba(245,166,35,.15);border-color:var(--gold);color:var(--gold);font-weight:600}

.demo-bal-btn{background:var(--card);border:1px solid var(--brd);color:var(--muted);padding:4px 6px;border-radius:5px;font-size:9px;cursor:pointer;flex:1;transition:all .15s}
.demo-bal-btn:hover,.demo-bal-btn.active{background:var(--acc);color:var(--gold);border-color:var(--gold)}
.pos-row{background:var(--card);border-radius:5px;padding:6px 8px;margin-bottom:4px;font-size:10px}
.pos-sym{font-weight:500;font-size:11px}
.pos-dir-buy{color:#22c55e;font-weight:600}
.pos-dir-sell{color:#ef4444;font-weight:600}
.pos-close{background:none;border:1px solid var(--brd);color:var(--muted);padding:2px 7px;border-radius:3px;font-size:9px;cursor:pointer;float:right}
.pos-close:hover{border-color:var(--red);color:var(--red)}
.hist-row{font-size:9px;padding:3px 0;border-bottom:1px solid var(--brd);display:flex;justify-content:space-between}


/* DARK / LIGHT MODE */
body.light{
  --bg:#f0f2f5;--surf:#ffffff;--card:#f8f9fb;--brd:#dde1ea;
  --txt:#1a1f2e;--muted:#5a6478;--acc:#e8edf5;
}
body.light #topnav,body.light #sidebar,body.light #rpanel,body.light .modal{background:var(--surf)}
body.light #breaking{background:#fff0f0;border-color:#ffcccc}

/* LANG SELECTOR */
#langSel{background:var(--card);border:1px solid var(--brd);color:var(--txt);padding:3px 6px;border-radius:5px;font-size:10px;cursor:pointer;outline:none}

/* THEME TOGGLE */
#themeBtn{background:none;border:1px solid var(--brd);color:var(--muted);padding:3px 8px;border-radius:5px;font-size:12px;cursor:pointer}
#themeBtn:hover{border-color:var(--gold);color:var(--gold)}

/* NEWS CARDS */
.news-card{background:var(--card);border:1px solid var(--brd);border-radius:8px;padding:12px 14px;margin-bottom:8px;cursor:pointer;transition:border-color .15s}
.news-card:hover{border-color:var(--gold)}
.news-card-head{display:flex;align-items:center;gap:6px;margin-bottom:6px;flex-wrap:wrap}
.news-src{font-size:10px;font-weight:600;padding:2px 7px;border-radius:4px}
.src-reuters{background:#ff8000;color:#fff}
.src-bloomberg{background:#1a1aff;color:#fff}
.src-ft{background:#ff0000;color:#fff}
.src-cnbc{background:#003366;color:#fff}
.src-wsj{background:#1e1e1e;color:#fff}
.src-cc{background:#1e88e5;color:#fff}
.src-mw{background:#22c55e;color:#fff}
.src-inv{background:#8b5cf6;color:#fff}
.src-default{background:var(--brd);color:var(--muted)}
.news-imp{font-size:9px;padding:2px 6px;border-radius:3px;font-weight:700}
.imp-high{background:#ef4444;color:#fff}
.imp-med{background:#f5a623;color:#0a0e1a}
.imp-low{background:#2a3550;color:#8892a4}
.news-time{font-size:10px;color:var(--muted);margin-left:auto}
.news-title{font-size:13px;font-weight:500;line-height:1.4;margin-bottom:4px;color:var(--txt)}
.news-preview{font-size:11px;color:var(--muted);line-height:1.5}
.news-tags{display:flex;gap:4px;margin-top:6px;flex-wrap:wrap}
.ntag{font-size:9px;padding:1px 6px;border-radius:3px;background:var(--acc);color:var(--muted)}
.ntag.forex{background:#1e2d40;color:#60a5fa}
.ntag.crypto{background:#2d1f4a;color:#a78bfa}
.ntag.indices{background:#1a2e1a;color:#4ade80}
.ntag.commo{background:#2d2010;color:#f5a623}
.ntag.stocks{background:#1a1e2e;color:#93c5fd}
.ntag.macro{background:#2a1020;color:#f87171}

/* PROFIL CLIENT */
.profile-section{background:var(--card);border:1px solid var(--brd);border-radius:8px;padding:14px;margin-bottom:10px}
.profile-label{font-size:10px;color:var(--muted);margin-bottom:3px;text-transform:uppercase;letter-spacing:.5px}
.profile-val{font-size:13px;color:var(--txt);font-weight:500}
.plan-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}
.plan-badge.free{background:#1e2d40;color:#60a5fa}
.plan-badge.pro{background:#2d1f4a;color:#a78bfa}
.plan-badge.premium{background:var(--gold);color:#0a0e1a}

/* NEWSLETTER */
.nl-form{display:flex;gap:6px;margin-top:8px}
.nl-form input{flex:1;background:var(--card);border:1px solid var(--brd);color:var(--txt);padding:7px 10px;border-radius:6px;font-size:12px;outline:none}
.nl-form input:focus{border-color:var(--gold)}
.nl-form button{background:var(--gold);color:#0a0e1a;border:none;padding:7px 14px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer}

/* NEWS FILTERS active */
.news-filter-btn{background:var(--surf);border:1px solid var(--brd);color:var(--muted);padding:5px 12px;border-radius:5px;font-size:11px;cursor:pointer;transition:all .15s}
.news-filter-btn:hover,.news-filter-btn.active{background:var(--acc);border-color:var(--gold);color:var(--gold)}

/* SOURCE IMPORTANCE */

/* MODAL ARTICLE */
#artBody p{ margin-bottom:12px; color:var(--txt); font-size:13px; line-height:1.8; }
#modal-article .modal-body::-webkit-scrollbar{ width:5px; }
#modal-article .modal-body::-webkit-scrollbar-track{ background:var(--bg); }
#modal-article .modal-body::-webkit-scrollbar-thumb{ background:var(--brd); border-radius:3px; }


/* CHAINES TV */
.tv-view-wrap{display:flex;flex:1;height:100%;overflow:hidden;min-height:0}
.tv-sidebar{width:280px;flex-shrink:0;background:var(--surf);border-right:1px solid var(--brd);display:flex;flex-direction:column;overflow:hidden}
.tv-player-wrap{flex:1;display:flex;flex-direction:column;background:#000;min-width:0;overflow:hidden}
.tv-player-frame{flex:1;min-height:0;border:none;width:100%}
.tv-lang-tabs{display:flex;gap:0;border-bottom:1px solid var(--brd);flex-shrink:0}
.tv-lt{flex:1;padding:8px 4px;border:none;background:none;color:var(--muted);font-size:10px;cursor:pointer;border-bottom:2px solid transparent;text-align:center;transition:all .15s}
.tv-lt:hover{color:var(--txt)}
.tv-lt.active{color:var(--red);border-bottom-color:var(--red)}
.tv-ch-list{overflow-y:auto;flex:1}
.tv-ch-item{display:flex;align-items:center;gap:9px;padding:9px 12px;cursor:pointer;border-bottom:1px solid var(--brd);transition:background .1s}
.tv-ch-item:hover,.tv-ch-item.active{background:var(--acc)}
.tv-ch-item.active{border-left:3px solid var(--red)}
.tv-ch-logo{width:36px;height:36px;border-radius:6px;background:var(--card);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;overflow:hidden}
.tv-ch-logo img{width:100%;height:100%;object-fit:cover;border-radius:6px}
.tv-ch-info{flex:1;min-width:0}
.tv-ch-name{font-size:12px;font-weight:500;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tv-ch-cat{font-size:9px;color:var(--muted);margin-top:1px}
.tv-ch-live{font-size:8px;color:var(--red);border:1px solid var(--red);border-radius:3px;padding:1px 4px;flex-shrink:0}
.tv-player-bar{background:var(--surf);border-bottom:1px solid var(--brd);padding:8px 14px;display:flex;align-items:center;gap:10px;flex-shrink:0}
.tv-now-name{font-size:13px;font-weight:500;color:var(--txt)}
.tv-now-cat{font-size:10px;color:var(--muted)}
.tv-warn{background:#1a0808;border:1px solid #4a1818;border-radius:6px;padding:8px 12px;margin:10px;font-size:10px;color:var(--muted);line-height:1.6}


/* ── SYSTEME DE VERROU ABONNEMENT ── */
.lock-overlay{position:absolute;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;background:rgba(10,14,26,.82);backdrop-filter:blur(3px);border-radius:inherit;flex-direction:column;gap:8px;cursor:pointer}
.lock-overlay:hover{background:rgba(10,14,26,.88)}
.lock-badge{background:var(--surf);border:1px solid var(--gold);border-radius:8px;padding:10px 18px;text-align:center;pointer-events:none}
.lock-badge .lock-icon{font-size:20px;margin-bottom:4px}
.lock-badge .lock-plan{font-size:11px;font-weight:700;color:var(--gold);margin-bottom:2px}
.lock-badge .lock-desc{font-size:10px;color:var(--muted)}
.btn-upgrade-sm{background:var(--gold);color:#0a0e1a;border:none;padding:5px 14px;border-radius:5px;font-size:11px;font-weight:700;cursor:pointer;margin-top:6px}
/* Overlay sur les vues entières */
.view-lock-wrap{position:relative;flex:1;display:flex;flex-direction:column;overflow:hidden}
/* Badge plan requis sur les onglets nav */
.nt-locked::after{content:attr(data-plan);background:var(--gold);color:#0a0e1a;font-size:7px;font-weight:700;padding:1px 4px;border-radius:8px;margin-left:4px;vertical-align:middle}
/* Blur sur les articles news limités */
.news-blur{filter:blur(5px);pointer-events:none;user-select:none}
.news-lock-row{position:relative;margin-bottom:8px}
.news-lock-badge{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:10}
.news-lock-badge button{background:var(--surf);border:1px solid var(--gold);color:var(--gold);padding:6px 16px;border-radius:20px;font-size:11px;font-weight:600;cursor:pointer}
/* Barre plan en haut des vues verrouillées */
.plan-required-bar{background:linear-gradient(90deg,#2d1f00,#1a1200);border-bottom:1px solid var(--gold);padding:8px 14px;display:flex;align-items:center;gap:10px;flex-shrink:0}
.plan-req-label{font-size:11px;font-weight:600;color:var(--gold)}
.plan-req-desc{font-size:10px;color:var(--muted);flex:1}
.plan-req-btn{background:var(--gold);color:#0a0e1a;border:none;padding:5px 14px;border-radius:5px;font-size:11px;font-weight:700;cursor:pointer}
/* Sidebar items verrouillés */
.sb-item-locked{opacity:.5;cursor:default!important}
.sb-item-locked:hover{background:none!important;border-left-color:transparent!important}
/* Chaines TV verrouillees */
.tv-ch-item.tv-ch-locked{opacity:.6;cursor:pointer}
.tv-ch-item.tv-ch-locked:hover{background:rgba(245,166,35,.06);border-bottom-color:rgba(245,166,35,.3)}
.tv-ch-lock-badge{font-size:8px;color:var(--gold);border:1px solid var(--gold);border-radius:3px;padding:1px 4px;flex-shrink:0;background:rgba(245,166,35,.1)}
.tv-lt.tv-lt-locked{opacity:.55}
/* Boutons TF/indicateurs verrouilles */
.tf.tf-locked{opacity:.4;position:relative;cursor:pointer}
.tf.tf-locked::after{content:"PRO";position:absolute;top:-6px;right:-2px;background:var(--gold);color:#0a0e1a;font-size:6px;font-weight:700;padding:1px 3px;border-radius:3px}
/* Mur d'upgrade actualites */
.news-upgrade-wall{background:linear-gradient(135deg,#1a1200,#0f1a2a);border:1px solid var(--gold);border-radius:10px;padding:20px;text-align:center;margin-top:12px}
.news-upgrade-icon{font-size:32px;margin-bottom:8px}
.news-upgrade-title{font-size:14px;font-weight:600;color:var(--gold);margin-bottom:6px}
.news-upgrade-desc{font-size:11px;color:var(--muted);line-height:1.6;margin-bottom:12px}
.news-upgrade-btn{background:var(--gold);color:#0a0e1a;border:none;padding:9px 20px;border-radius:6px;font-size:12px;font-weight:700;cursor:pointer}
.news-upgrade-btn:hover{background:var(--gold2)}

.imp-bar{display:flex;align-items:center;gap:4px;margin-bottom:4px}
.imp-dot{width:8px;height:8px;border-radius:50%}


/* FOOTER */
#site-footer{background:var(--surf);border-top:1px solid var(--brd);padding:0;flex-shrink:0;max-height:46px;overflow:hidden;transition:max-height .3s ease;box-shadow:0 -4px 16px rgba(0,0,0,.15)}
#site-footer.open{max-height:min(88vh,900px);overflow:auto}
.footer-toggle{height:46px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;cursor:pointer;background:var(--surf);border-bottom:1px solid transparent;font-size:11px;font-weight:700;color:var(--gold);letter-spacing:.4px}
#site-footer.open .footer-toggle{border-bottom-color:var(--brd)}
.footer-toggle small{font-size:10px;color:var(--muted);font-weight:500;letter-spacing:0}
.footer-toggle-icon{transition:transform .2s ease}
#site-footer.open .footer-toggle-icon{transform:rotate(180deg)}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));border-top:1px solid var(--brd)}
.footer-col{padding:20px 18px;border-right:1px solid var(--brd);min-width:0}
.footer-col:last-child{border-right:none}
.footer-col-title{font-size:11px;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid var(--brd)}
.footer-link{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--muted);text-decoration:none;padding:4px 0;cursor:pointer;line-height:1.5;transition:color .12s}
.footer-link:hover{color:var(--txt)}
.footer-desc{font-size:10px;color:var(--muted);line-height:1.7;margin-bottom:6px}
.footer-bottom{padding:12px 20px;display:flex;justify-content:space-between;align-items:center;font-size:10px;color:var(--muted);flex-wrap:wrap;gap:6px;border-top:1px solid var(--brd);background:var(--bg)}
.tg-badge{display:inline-flex;align-items:center;gap:6px;background:#0d1e2e;border:1px solid #0088cc;border-radius:20px;padding:5px 12px;font-size:10px;color:#0088cc;cursor:pointer;text-decoration:none;transition:all .15s}
.tg-badge:hover{background:#0088cc;color:#fff}
.tg-float{position:fixed;bottom:20px;right:20px;z-index:400;background:#0088cc;border:none;border-radius:50px;padding:10px 18px;color:#fff;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:7px;box-shadow:0 4px 20px rgba(0,136,204,.4)}
.tg-float:hover{background:#0077bb}
.footer-col,.footer-desc,.footer-link,#site-footer p,#site-footer span,#site-footer a{overflow-wrap:anywhere;word-break:break-word}


/* ======================================================
   NAV MOBILE — barre fixe 56px en bas
   ====================================================== */
#mobile-nav{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:700;
  background:var(--surf);border-top:2px solid var(--brd);
  height:56px;
  grid-template-columns:repeat(6,1fr);
  align-items:center;
  box-shadow:0 -3px 16px rgba(0,0,0,.3);
}
.mob-tab{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2px;padding:4px 2px;border:none;background:none;
  color:var(--muted);font-size:9px;font-weight:500;cursor:pointer;
  border-top:2px solid transparent;height:56px;width:100%;
}
.mob-tab .mob-icon{font-size:20px;line-height:1.2}
.mob-tab.active{color:var(--gold);border-top-color:var(--gold)}
.mob-tab-tv.active{color:#ef4444;border-top-color:#ef4444}

/* Drawer menu mobile */
#mob-sidebar-overlay{display:none;position:fixed;inset:0;z-index:650;background:rgba(0,0,0,.7)}
#mob-sidebar-overlay.open{display:block}
#mob-sidebar-drawer{
  position:fixed;top:0;left:0;bottom:56px;width:290px;z-index:660;
  background:var(--surf);border-right:1px solid var(--brd);
  transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;-webkit-overflow-scrolling:touch;
}
#mob-sidebar-drawer.open{transform:translateX(0)}
.mob-drawer-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px;border-bottom:1px solid var(--brd);
  position:sticky;top:0;background:var(--surf);z-index:1;
}
.mob-drawer-close{background:none;border:1px solid var(--brd);color:var(--muted);padding:5px 12px;border-radius:6px;font-size:12px;cursor:pointer}

/* ======================================================
   TABLETTE (769 – 1100px)
   ====================================================== */
@media(min-width:769px) and (max-width:1100px){
  #sidebar{width:155px}
  /* On tablets, keep the right panel visible but a bit narrower instead of hiding it completely */
  #rpanel{width:200px;flex-shrink:0;display:block}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .footer-col:nth-child(2){border-right:none}
  .footer-col:nth-child(1),.footer-col:nth-child(2){border-bottom:1px solid var(--brd)}
  .nav-tabs .nt{padding:5px 6px;font-size:10px}
}

/* ======================================================
   MOBILE ≤ 768px  — règle principale
   ====================================================== */
@media(max-width:768px){
  *{-webkit-tap-highlight-color:transparent;box-sizing:border-box}
  html,body{overflow:hidden;height:100dvh;height:100vh;display:flex;flex-direction:column}
  #topnav{height:48px;padding:0 10px;gap:6px;flex-shrink:0}
  .logo-txt,.nav-tabs,#langSel,.btn-cta{display:none}
  .search-wrap{flex:1;max-width:none}
  #searchInput{font-size:14px;padding:7px 10px 7px 30px}
  .plan-pill{font-size:9px;padding:2px 7px}.btn-login{font-size:11px;padding:5px 10px;white-space:nowrap}
  #tickerBar{height:54px;flex-shrink:0;overflow:hidden}
  #breaking{height:22px;padding:0 8px;font-size:10px;flex-shrink:0}
  #layout{flex:1;min-height:0;display:flex;overflow:hidden;padding-bottom:56px}
  #sidebar,#rpanel{display:none!important}
  #main{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}
  .view{display:none!important}
  .view.active{display:flex!important;flex-direction:column;overflow:hidden;flex:1;min-height:0}
  #view-markets.active{overflow-y:auto!important;-webkit-overflow-scrolling:touch}
  .markets-grid{grid-template-columns:1fr;padding:10px;gap:10px}
  .mcard{border-radius:10px;padding:12px}
  .mcard .tradingview-widget-container{height:88px!important}
  #view-chart.active{display:flex!important;flex-direction:column!important;overflow:hidden!important}
  #chartContainer{flex:1!important;min-height:0!important;display:flex!important;flex-direction:column!important;overflow:hidden!important}
  #chartTopBar{flex-shrink:0;display:flex;flex-wrap:wrap;align-items:center;gap:3px;padding:6px 8px;background:var(--surf);border-bottom:1px solid var(--brd)}
  #chartTopBar>span:nth-child(2),#tvExternalLink{display:none}
  #chartSymbol{font-size:13px;font-weight:600}
  .tfs{order:10;width:100%;display:flex;gap:2px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:2px 0;scrollbar-width:none}
  .tfs::-webkit-scrollbar{display:none}
  .tf{font-size:11px;padding:5px 10px;flex-shrink:0;border-radius:5px}
  #chartTopBar>div:last-of-type{order:11;width:100%;display:flex;gap:3px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  #tvChart{flex:1!important;min-height:0!important;width:100%!important;overflow:hidden!important;display:block!important}
  #view-news.active{overflow:hidden}
  .news-filters{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:6px 8px;gap:5px;flex-shrink:0;scrollbar-width:none}
  .news-filter-btn{white-space:nowrap;flex-shrink:0;font-size:11px;padding:5px 12px;border-radius:16px}
  #newsListWrap{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:8px}
  #view-news>div:first-child{flex-shrink:0}
  #view-news>div>div:last-child:not(#newsListWrap){display:none}
  #view-screener>div>div:first-child{overflow-x:auto;-webkit-overflow-scrolling:touch;padding:6px 8px;scrollbar-width:none}
  #view-screener .news-filter-btn{white-space:nowrap;flex-shrink:0}
  #screenerContainer{flex:1;min-height:0}
  .tv-view-wrap{flex-direction:column!important;height:100%;overflow:hidden}
  .tv-sidebar{width:100%!important;height:auto;max-height:45vh;border-right:none!important;border-bottom:1px solid var(--brd);flex-shrink:0;display:flex;flex-direction:column;overflow:hidden}
  .tv-lang-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-shrink:0;display:flex;scrollbar-width:none;border-bottom:1px solid var(--brd)}
  .tv-lang-tabs::-webkit-scrollbar{display:none}
  .tv-lt{white-space:nowrap;flex:none;padding:10px 16px;font-size:12px;border-radius:0;border-bottom:2px solid transparent}
  .tv-lt.active{border-bottom-color:var(--gold);color:var(--gold)}
  .tv-ch-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
  .tv-ch-item{padding:10px 14px;display:flex;align-items:center;gap:10px;cursor:pointer}
  .tv-player-wrap{flex:1;min-height:0;display:flex;flex-direction:column}
  .tv-player-wrap>div:last-child{flex:1;min-height:200px;overflow:hidden}
  #tvHlsVideo{width:100%;height:100%;background:#000;display:block}
  #view-demo.active{display:flex!important;flex-direction:column!important;overflow:hidden!important}
  #view-demo.active>div{flex:1!important;display:flex!important;flex-direction:column!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch}
  #view-demo.active>div>div:first-child{flex-shrink:0!important;height:260px!important;min-height:260px!important;width:100%!important;display:flex!important;flex-direction:column!important;overflow:hidden!important}
  #demoTVChart{height:220px!important;min-height:220px!important;width:100%!important;display:block!important;overflow:hidden!important;background:#000}
  #demoTVChart iframe{width:100%!important;height:220px!important;border:none!important;display:block!important}
  #view-demo.active>div>div:last-child{flex-shrink:0!important;width:100%!important;border-left:none!important;border-top:1px solid var(--brd)!important}
  .demo-bal-btn{font-size:11px;padding:6px 8px;flex:1}
  .lev-btn{font-size:10px;padding:5px 8px;border-radius:5px}
  #demoAssetSel{font-size:13px;padding:5px 8px}
  #view-analysis.active,#view-macro.active{overflow-y:auto!important;-webkit-overflow-scrolling:touch}
  .modal-wrap{padding:0!important;align-items:flex-end!important}
  .modal{border-radius:20px 20px 0 0!important;max-height:92vh;width:100%!important;max-width:100%!important;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:env(safe-area-inset-bottom,16px)}
  .modal-head{padding:16px;position:sticky;top:0;background:var(--surf);z-index:5;border-bottom:1px solid var(--brd)}
  .modal-body{padding:16px!important;padding-bottom:24px!important}
  #loginBtn,#regBtn{font-size:16px!important;padding:15px!important;min-height:50px!important;border-radius:8px!important;display:block!important;width:100%!important;-webkit-appearance:none!important}
  .fi{font-size:16px!important;padding:13px!important;min-height:46px!important;-webkit-appearance:none!important;border-radius:8px!important}
  #googleBtn{padding:13px!important;font-size:14px!important;min-height:46px!important}
  .plans-grid{grid-template-columns:1fr!important;gap:10px}
  .sig-levels{grid-template-columns:repeat(5,1fr);gap:3px}
  .sig-lv{padding:4px 2px;border-radius:4px}.sig-lv .lv-label{font-size:8px}.sig-lv .lv-val{font-size:10px;font-weight:600}
  .tg-float{bottom:64px;right:10px;padding:9px 14px;font-size:12px;border-radius:24px}
  #mobile-nav{display:grid!important}
  #site-footer{display:none!important}
  #mob-sidebar-drawer{bottom:56px}
  #mob-sidebar-drawer .sb-item{font-size:14px;padding:12px 16px;min-height:46px}
  #searchResults{max-height:55vh;border-radius:0 0 12px 12px}
}

/* MODAL LEGAL */
.legal-content{font-size:12px;line-height:1.8;color:var(--muted)}
.legal-content h3{font-size:14px;font-weight:500;color:var(--txt);margin:16px 0 6px}
.legal-content h4{font-size:12px;font-weight:500;color:var(--gold);margin:10px 0 4px}
.legal-content p{margin-bottom:8px}
.legal-content ul{padding-left:16px;margin-bottom:8px}
.legal-content li{margin-bottom:3px}
.legal-tabs{display:flex;gap:2px;margin-bottom:14px;background:var(--card);border-radius:8px;padding:3px}
.lt{padding:6px 12px;border-radius:6px;border:none;background:none;color:var(--muted);font-size:11px;cursor:pointer;transition:all .15s}
.lt.active{background:var(--surf);color:var(--txt)}

/* MODAL XM DISCLAIMER */
.vantage-modal .country-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:10px 0}
.country-ok{background:#0f2a1a;border:1px solid #1a4a2a;border-radius:6px;padding:8px;font-size:11px}
.country-no{background:#2a0f0f;border:1px solid #4a1a1a;border-radius:6px;padding:8px;font-size:11px}
.country-ok li,.country-no li{list-style:none;padding:2px 0;line-height:1.6}

/* TELEGRAM SIGNAL CARD */
.tg-signal{background:var(--card);border:1px solid var(--brd);border-radius:8px;padding:12px;margin-bottom:8px}
.tg-signal.buy{border-left:3px solid var(--grn)}
.tg-signal.sell{border-left:3px solid var(--red)}
.sig-head{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.sig-dir{font-size:13px;font-weight:700;padding:3px 10px;border-radius:4px}
.sig-dir.buy{background:#0f2a1a;color:var(--grn)}
.sig-dir.sell{background:#2a0f0f;color:var(--red)}
.sig-levels{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;margin-top:8px}
.sig-lv{background:var(--surf);border-radius:4px;padding:5px 4px;text-align:center}
.sig-lv .lv-label{font-size:8px;color:var(--muted);margin-bottom:1px}
.sig-lv .lv-val{font-size:11px;font-weight:500}

/* SIDEBAR nav tabs */
.sb-mini-nav{display:flex;flex-wrap:wrap;gap:3px;padding:6px 8px;border-bottom:1px solid var(--brd);background:var(--bg)}
.sb-mini-btn{background:var(--card);border:1px solid var(--brd);color:var(--muted);font-size:10px;cursor:pointer;padding:3px 7px;border-radius:4px;transition:all .15s;white-space:nowrap}
.sb-mini-btn:hover,.sb-mini-btn.active{background:var(--acc);border-color:var(--gold);color:var(--gold);font-weight:500}

@media(min-width:769px) and (max-width:900px){
  #sidebar,#rpanel{display:none}
  .markets-grid{grid-template-columns:1fr}
  .nav-tabs{display:none}
}


/* ===== IMN FINAL MOBILE/PERF OVERRIDES ===== */
#tickerBar{height:52px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;white-space:nowrap}
#tickerBar .tradingview-widget-container{height:52px !important}
#tickerBar::-webkit-scrollbar{display:none}
#breaking{height:28px}
.b-scroll{font-size:12px}
.view:not(.active){display:none !important}
#view-chart:not(.active),#view-news:not(.active),#view-demo:not(.active),#view-tv:not(.active),#view-analysis:not(.active),#view-macro:not(.active),#view-screener:not(.active),#view-markets:not(.active){display:none !important}

@media(max-width:768px){
  #topnav{height:56px;gap:6px;padding:0 8px}
  .logo-box{width:28px;height:28px}
  .search-wrap{min-width:0}
  #searchInput{font-size:12px;padding:7px 8px 7px 30px}
  .btn-login{font-size:11px;padding:6px 10px}
  .plan-pill{font-size:10px;padding:4px 8px}
  #tickerBar{height:58px !important;overflow-x:auto !important;overflow-y:hidden !important}
  #tickerBar .tradingview-widget-container{height:58px !important}
  #breaking{height:26px !important;padding:0 6px}
  .b-badge{font-size:11px}
  .b-scroll{font-size:11px}

  /* prevent chart from leaking into other views */
  #view-chart{display:none !important}
  #view-chart.active{display:flex !important;flex-direction:column !important;overflow:hidden !important}
  #tvChart{min-height:420px !important; height:calc(100dvh - 250px) !important}
  #chartContainer{min-height:0;overflow:hidden}
  #chartTopBar{padding:8px 10px;gap:6px;border-bottom:1px solid var(--brd)}
  #chartSymbol{font-size:15px}
  .tfs{gap:4px;padding:4px 0}
  .tf{font-size:11px;padding:6px 10px;min-width:34px}
  #alertsList{padding:6px 10px !important}

  /* keep market cards only on markets page */
  #view-markets.active{overflow-y:auto !important;padding-bottom:82px}

  /* news newsletter compact */
  #view-news .nl-form{display:grid !important;grid-template-columns:1fr auto !important;gap:8px !important;align-items:center}
  #view-news .nl-form input{min-width:0;font-size:12px;padding:10px 12px}
  #view-news .nl-form button{padding:10px 14px;font-size:12px;white-space:nowrap}
  #view-news > div:first-child > div:last-child{padding:8px 10px !important}
  #view-news > div:first-child > div:last-child > span:first-child{display:none}
  .news-filter-btn{font-size:11px;padding:7px 10px}
  .news-card{padding:12px 12px;margin-bottom:10px}
  .news-title{font-size:20px;line-height:1.25}
  .news-preview{font-size:13px;line-height:1.45}

  /* demo mobile tighter */
  #view-demo.active{overflow-y:auto !important;padding-bottom:82px}
  #view-demo>div{display:flex !important;flex-direction:column !important;overflow-y:auto !important}
  #view-demo>div>div:first-child{min-height:180px !important;max-height:220px !important}
  #view-demo>div>div:last-child{width:100% !important;padding:10px !important}
  #view-demo select, #view-demo input{font-size:12px}

  /* TV mobile compact */
  .tv-sidebar{max-height:155px !important}
  .tv-ch-item{padding:7px 10px}
  .tv-ch-name{font-size:11px}
  .tv-player-bar{padding:8px 10px !important;gap:8px;flex-wrap:wrap}
  #tvFallback{padding:12px !important}
  #tvFallback button, #tvFallback a{font-size:12px}
  .tv-warn{padding:8px 10px;font-size:11px;margin:8px}

  /* telegram float less intrusive */
  .tg-float{bottom:66px !important;right:10px !important;padding:10px 14px !important;font-size:11px !important;max-width:52vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

  /* mobile nav above safari bottom bar */
  #mobile-nav{height:64px !important;padding-bottom:env(safe-area-inset-bottom, 0)}
  .mob-tab{height:64px !important;font-size:9px}

  /* footer never blocks mobile */
  #site-footer{display:none !important}
}
