/* ===== TRADING BRIDGE — page components (light) ===== */

/* RISK BANNER */
.risk-banner{background:var(--bg-panel-2);border-bottom:1px solid var(--border);font-size:.8rem;color:var(--text-muted);padding:.55rem 0}
.risk-banner .container{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}
.risk-banner strong{color:var(--text)}

/* HERO VISUAL CARD */
.hero-visual .panel{box-shadow:0 18px 40px -24px rgba(20,24,31,.25)}
.hero-stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}
.hero-stat{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r);padding:.85rem;text-align:center}
.hero-stat .num{font-size:1.3rem;font-weight:800;color:var(--system);font-variant-numeric:tabular-nums}
.hero-stat .lbl{font-size:.72rem;color:var(--text-muted);margin-top:.25rem}
.badge-row{display:flex;gap:.5rem;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;gap:.35rem;background:var(--bg-panel);border:1px solid var(--border);color:var(--text-muted);font-size:.74rem;font-weight:600;padding:.35rem .7rem;border-radius:999px}

/* TICKER MARQUEE */
.ticker-marquee{background:var(--bg-panel);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.ticker-viewport{overflow:hidden;cursor:pointer}
.ticker-track{display:flex;gap:2.5rem;padding:.7rem 0;white-space:nowrap;width:max-content;animation:tickerScroll 32s linear infinite}
.ticker-viewport:hover .ticker-track,.ticker-viewport:focus-within .ticker-track,.ticker-viewport.is-paused .ticker-track{animation-play-state:paused}
.ticker-item{display:inline-flex;gap:.55rem;align-items:center;font-size:.82rem;font-weight:600;font-variant-numeric:tabular-nums}
.ticker-item .sym{color:var(--text)}
.ticker-item .up{color:var(--bull)}
.ticker-item .down{color:var(--bear)}
@keyframes tickerScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.ticker-track{animation:none}}

/* COMPARISON MATRIX / DENSE TABLE */
.matrix-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--r);background:var(--bg-elevated)}
table.matrix,table.dense{width:100%;border-collapse:collapse;font-size:.88rem}
table.matrix th,table.dense th{background:var(--bg-panel-2);color:var(--text);text-align:left;font-weight:700;padding:.85rem 1rem;border-bottom:1px solid var(--border)}
table.matrix td,table.dense td{padding:.8rem 1rem;border-bottom:1px solid var(--border-soft);color:var(--text);font-variant-numeric:tabular-nums}
table.matrix tr:last-child td,table.dense tr:last-child td{border-bottom:0}
table.matrix tbody tr:hover,table.dense tbody tr:hover{background:var(--bg-panel)}
.cell-yes{color:var(--bull);font-weight:700}
.cell-no{color:var(--bear);font-weight:700}

/* PLATFORM MOCK FRAME */
.mock-frame{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--bg-elevated);box-shadow:0 18px 40px -28px rgba(20,24,31,.3)}
.mock-bar{display:flex;align-items:center;gap:.4rem;padding:.6rem .9rem;background:var(--bg-panel-2);border-bottom:1px solid var(--border)}
.mock-dot{width:10px;height:10px;border-radius:50%;background:var(--border)}
.mock-bar .mock-title{margin-left:.6rem;font-size:.78rem;color:var(--text-muted);font-weight:600}
.mock-body{display:grid;grid-template-columns:1fr;gap:1px;background:var(--border-soft)}
@media(min-width:640px){.mock-body{grid-template-columns:2fr 1fr}}
.mock-pane{background:var(--bg-elevated);padding:1rem;min-height:120px}
.mock-chart{background:linear-gradient(180deg,rgba(37,99,235,.08),transparent);border-radius:var(--r);height:160px;display:flex;align-items:flex-end;gap:4px;padding:.6rem}
.mock-chart i{flex:1;background:var(--system);opacity:.55;border-radius:2px 2px 0 0;display:block}
.mock-row{display:flex;justify-content:space-between;padding:.45rem 0;border-bottom:1px solid var(--border-soft);font-size:.8rem;font-variant-numeric:tabular-nums}

/* STEPS / RAIL */
.steps-list{display:grid;gap:1rem}
@media(min-width:780px){.steps-list.cols-3{grid-template-columns:repeat(3,1fr)}.steps-list.cols-4{grid-template-columns:repeat(4,1fr)}}
.step{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r);padding:1.4rem 1.2rem;position:relative}
.step .step-num{width:38px;height:38px;border-radius:50%;background:var(--system);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;margin-bottom:.8rem;font-variant-numeric:tabular-nums}
.step h3{font-size:1.02rem;margin-bottom:.4rem}
.step p{font-size:.88rem;color:var(--text-muted);margin:0}
.steps-rail{counter-reset:none}

/* INFO / FEATURE CARDS GRID */
.card-grid{display:grid;gap:1.1rem;grid-template-columns:1fr}
@media(min-width:640px){.card-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:780px){.card-grid.cols-3{grid-template-columns:repeat(3,1fr)}}
.info-card,.card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r);padding:1.4rem;transition:transform .2s,box-shadow .2s}
.info-card:hover,.card:hover{transform:translateY(-3px);box-shadow:0 14px 30px -22px rgba(20,24,31,.3)}
.info-card h3,.card h3{font-size:1.05rem;margin-bottom:.5rem}
.info-card p,.card p{font-size:.9rem;color:var(--text-muted);margin:0}
.card-icon{width:44px;height:44px;border-radius:var(--r);background:var(--bg-panel-2);color:var(--system);display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:800;margin-bottom:.9rem}

/* PANELS */
.panel{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg);padding:clamp(1.3rem,3vw,2rem)}
.panel-grid{display:grid;gap:1.1rem;grid-template-columns:1fr}
@media(min-width:780px){.panel-grid.cols-2{grid-template-columns:repeat(2,1fr)}.panel-grid.cols-3{grid-template-columns:repeat(3,1fr)}}

/* TABS UI */
.tab-list{display:flex;flex-wrap:wrap;gap:.5rem;border-bottom:1px solid var(--border);margin-bottom:1.4rem}
.tab-btn{background:none;border:0;border-bottom:2px solid transparent;padding:.7rem 1rem;font:inherit;font-weight:600;color:var(--text-muted);cursor:pointer}
.tab-btn.is-active{color:var(--system);border-bottom-color:var(--system)}
.tab-panel{display:none}
.tab-panel.is-active{display:block}

/* SEG CONTROL */
.seg-control{display:inline-flex;background:var(--bg-panel-2);border:1px solid var(--border);border-radius:999px;padding:.25rem;gap:.25rem;margin-bottom:1.4rem}
.seg-btn{background:none;border:0;padding:.5rem 1.1rem;border-radius:999px;font:inherit;font-weight:600;color:var(--text-muted);cursor:pointer}
.seg-btn.is-active{background:var(--bg-elevated);color:var(--system);box-shadow:0 1px 3px rgba(20,24,31,.12)}

/* ACCORDION */
.accordion-item,.faq-item,.checklist-item{border:1px solid var(--border);border-radius:var(--r);background:var(--bg-elevated);margin-bottom:.7rem;overflow:hidden}
.accordion-trigger{width:100%;text-align:left;background:none;border:0;padding:1.05rem 1.2rem;font:inherit;font-weight:600;color:var(--text);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.accordion-trigger::after{content:"+";font-size:1.3rem;color:var(--system);transition:transform .2s;flex-shrink:0}
.open>.accordion-trigger::after,.open .accordion-trigger::after{content:"\2212"}
.accordion-body,.faq-body,.checklist-body{max-height:0;overflow:hidden;transition:max-height .3s ease}
.accordion-body>div,.faq-body>div,.checklist-body>div,.accordion-inner{padding:0 1.2rem 1.15rem;color:var(--text-muted);font-size:.9rem}

/* TIMELINE */
.timeline{position:relative;padding-left:1.6rem}
.timeline::before{content:"";position:absolute;left:6px;top:.4rem;bottom:.4rem;width:2px;background:var(--border)}
.timeline-item{position:relative;padding-bottom:1.4rem}
.timeline-item::before{content:"";position:absolute;left:-1.6rem;top:.3rem;width:13px;height:13px;border-radius:50%;background:var(--system);border:2px solid var(--bg-base)}
.timeline-item h3{font-size:1rem;margin-bottom:.3rem}
.timeline-item p{font-size:.88rem;color:var(--text-muted);margin:0}
.timeline-item .date{font-size:.75rem;color:var(--system);font-weight:700}

/* CHIPS / FILTER */
.chip,.filter-chip{display:inline-flex;align-items:center;background:var(--bg-panel);border:1px solid var(--border);color:var(--text-muted);font:inherit;font-size:.82rem;font-weight:600;padding:.45rem .95rem;border-radius:999px;cursor:pointer;transition:background .15s,color .15s}
.chip:hover,.filter-chip:hover{border-color:var(--system)}
.chip.is-active,.filter-chip.is-active{background:var(--system);color:#fff;border-color:var(--system)}
.chip-row{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:1.3rem}
.is-hidden{display:none !important}

/* SEARCH INPUT */
.search-box{display:flex;gap:.6rem;margin-bottom:1.3rem}
.search-box input{flex:1;padding:.8rem 1rem;border:1px solid var(--border);border-radius:var(--r);font:inherit;background:var(--bg-elevated);color:var(--text)}
.search-box input:focus{outline:2px solid var(--system);outline-offset:1px}

/* TOC */
.toc-list{list-style:none;display:grid;gap:.5rem;grid-template-columns:1fr}
@media(min-width:640px){.toc-list{grid-template-columns:repeat(2,1fr)}}
.toc-list a{display:block;padding:.7rem 1rem;border:1px solid var(--border);border-radius:var(--r);color:var(--text);text-decoration:none;font-size:.88rem;font-weight:600}
.toc-list a:hover{border-color:var(--system);color:var(--system)}

/* LEGAL BODY */
.legal-body h2{margin:2rem 0 .7rem;font-size:1.25rem}
.legal-body h2:first-child{margin-top:0}
.legal-body p,.legal-body li{color:var(--text-muted);font-size:.92rem;margin-bottom:.7rem}
.legal-body ul{padding-left:1.3rem;margin-bottom:1rem}

/* CTA BAND */
.cta-band{background:var(--bg-panel-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:clamp(1.8rem,4vw,3rem);text-align:center}
.cta-band .section-head{margin-left:auto;margin-right:auto;text-align:center}
.dual-cta{display:flex;gap:.9rem;flex-wrap:wrap;justify-content:center;margin-top:1.2rem}
.hero-cta-row{display:flex;gap:.9rem;flex-wrap:wrap}

/* TRUST BADGES */
.trust-row{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}
.trust-badge{display:flex;align-items:center;gap:.5rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r);padding:.8rem 1.2rem;font-size:.85rem;font-weight:600;color:var(--text)}
.trust-badge .ic{color:var(--bull);font-weight:800}

/* COMPARISON CARDS (account types) */
.compare-cards{display:grid;gap:1.2rem;grid-template-columns:1fr}
@media(min-width:780px){.compare-cards{grid-template-columns:repeat(3,1fr)}}
.compare-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.6rem;display:flex;flex-direction:column}
.compare-card.featured{border-color:var(--system);box-shadow:0 0 0 1px var(--system)}
.compare-card .price{font-size:1.8rem;font-weight:800;color:var(--system);margin:.5rem 0;font-variant-numeric:tabular-nums}
.compare-card ul{list-style:none;margin:1rem 0;display:grid;gap:.55rem}
.compare-card li{font-size:.88rem;color:var(--text-muted);display:flex;gap:.5rem}
.compare-card li::before{content:"\2713";color:var(--bull);font-weight:800}
.compare-card .btn{margin-top:auto}

/* STRIP */
.strip{display:grid;gap:1rem;grid-template-columns:1fr;background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.4rem}
@media(min-width:640px){.strip{grid-template-columns:repeat(3,1fr)}}
.strip-item{text-align:center}
.strip-item .num{font-size:1.6rem;font-weight:800;color:var(--system);font-variant-numeric:tabular-nums}
.strip-item .lbl{font-size:.8rem;color:var(--text-muted)}

/* TIER TABLE highlight */
.tier-highlight td{background:var(--bg-panel)}

/* CONTACT INFO */
.contact-grid{display:grid;gap:1.1rem;grid-template-columns:1fr}
@media(min-width:640px){.contact-grid{grid-template-columns:repeat(2,1fr)}}

/* REVEAL */
.js-ready .reveal{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}
.js-ready .reveal.is-visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.js-ready .reveal{opacity:1;transform:none;transition:none}}