:root{
  --bg:#0b1020; --panel:#121935; --panel2:#0f1530; --line:#1f2a4d;
  --text:#e6ecff; --muted:#8c9ac9;
  --up:#26a69a; --down:#ef5350; --accent:#5b8cff; --gold:#ffb74d;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font:14px/1.4 -apple-system,Segoe UI,Roboto,Inter,sans-serif}
.hidden{display:none!important}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0}
table{border-collapse:collapse;width:100%}

/* ======== Icons ======== */
.i{display:inline-block;width:18px;height:18px;stroke-width:2;vertical-align:-3px}
.i.sm{width:14px;height:14px;vertical-align:-2px}
.i.lg{width:24px;height:24px;vertical-align:-4px}
.i.dot{width:10px;height:10px}
.i.dot.on{color:var(--up);fill:var(--up)}
.i.dot.off{color:var(--down);fill:var(--down)}
.flag{display:inline-block;width:24px;height:18px;vertical-align:-4px;border-radius:2px;box-shadow:0 0 0 1px rgba(255,255,255,.06);object-fit:cover}

/* ======== Topbar ======== */
.topbar{display:flex;align-items:center;gap:18px;padding:10px 18px;background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.brand{font-weight:700;font-size:18px;display:flex;align-items:center;gap:6px}
.brand .logo{color:var(--accent)} .brand small{color:var(--muted);font-weight:400}
.nav{display:flex;gap:6px;flex:1}
.nav a{padding:7px 12px;border-radius:8px;color:var(--muted);font-weight:500;display:inline-flex;align-items:center;gap:6px}
.nav a:hover{background:var(--panel2);color:var(--text)}
.nav a.active{background:var(--accent);color:#fff}
.status{display:flex;align-items:center;gap:8px;color:var(--muted);font-variant-numeric:tabular-nums}
.country-block h3{display:flex;align-items:center;gap:8px}
.exchange-card .ex-status{display:inline-flex;align-items:center;gap:4px}
.exchange-card.open  .ex-status{color:var(--up)}
.exchange-card.closed .ex-status{color:var(--muted)}

/* ======== Pages ======== */
.page{padding:20px 28px;max-width:1400px;margin:0 auto}
.page-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;margin-bottom:18px}
.page-header h1{font-size:24px}
.filters{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.filters label{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:13px}
.filters select{background:var(--panel);color:var(--text);border:1px solid var(--line);border-radius:6px;padding:6px 10px;font-size:13px}
.filters .check{cursor:pointer}
.disclaimer-banner{margin:24px 0 0;padding:12px 14px;background:var(--panel2);border:1px solid var(--line);border-radius:8px;font-size:12px;color:var(--muted)}

/* ======== KPI strip ======== */
.kpi-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:22px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:14px}
.kpi span{display:block;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.kpi b{font-size:18px}
.kpi .up{color:var(--up)} .kpi .down{color:var(--down)}

/* ======== Indices grid (home) ======== */
.indices-grid{display:flex;flex-direction:column;gap:18px}
.country-block h3{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:8px}
.indices-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.index-card{display:block;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:12px 14px;cursor:pointer;transition:transform .12s,border-color .12s}
.index-card:hover{transform:translateY(-2px);border-color:var(--accent)}
.index-card.up   {border-left:3px solid var(--up)}
.index-card.down {border-left:3px solid var(--down)}
.index-card.flat {border-left:3px solid var(--muted)}
.idx-name{font-weight:600;margin-bottom:6px}
.idx-price{font-size:18px;font-variant-numeric:tabular-nums}
.idx-change{font-size:13px;margin-top:2px;font-variant-numeric:tabular-nums}
.index-card.up   .idx-change{color:var(--up)}
.index-card.down .idx-change{color:var(--down)}
.idx-sym{margin-top:4px;color:var(--muted);font-size:11px}

/* ======== Exchanges ======== */
.exchanges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}
.exchange-card{display:flex;gap:12px;align-items:center;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:12px}
.exchange-card.open{border-left:3px solid var(--up)}
.exchange-card.closed{border-left:3px solid var(--muted);opacity:.85}
.ex-flag{font-size:30px}
.ex-info{flex:1;min-width:0}
.ex-name{font-weight:600}
.ex-meta{font-size:11px;color:var(--muted)}
.ex-status{font-size:11px;font-weight:600}

/* ======== Detail page ======== */
.layout{display:grid;grid-template-columns:280px 1fr;min-height:calc(100vh - 56px)}
.sidebar{background:var(--panel2);border-right:1px solid var(--line);padding:14px}
.sidebar h3{margin:14px 0 8px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.sidebar .hint{font-size:11px;color:var(--muted);line-height:1.5;margin-top:14px;padding-top:14px;border-top:1px dashed var(--line)}
.sidebar .hint code{background:var(--panel);padding:1px 4px;border-radius:3px;color:var(--accent)}
.search-wrap{position:relative}
.search-wrap input{width:100%;padding:9px 12px;border:1px solid var(--line);background:var(--panel);color:var(--text);border-radius:8px;outline:none}
.search-wrap input:focus{border-color:var(--accent)}
.search-results{position:absolute;top:100%;left:0;right:0;background:var(--panel);border:1px solid var(--line);border-radius:8px;margin-top:6px;max-height:320px;overflow-y:auto;z-index:30}
.search-results .item{padding:9px 12px;cursor:pointer;border-bottom:1px solid var(--line)}
.search-results .item:hover{background:var(--panel2)}
.search-results .item small{color:var(--muted);margin-left:8px}

.watchlist{list-style:none;margin:0;padding:0}
.watchlist li{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;border-radius:6px;cursor:pointer;margin-bottom:2px}
.watchlist li:hover{background:var(--panel)}
.watchlist li.active{background:var(--panel);outline:1px solid var(--accent)}
.watchlist .sym{font-weight:600}
.watchlist .pct{font-variant-numeric:tabular-nums;font-size:12px}
.watchlist .pct.up{color:var(--up)} .watchlist .pct.down{color:var(--down)}
.watchlist .rm{margin-left:6px;opacity:.4;cursor:pointer}
.watchlist .rm:hover{opacity:1;color:var(--down)}

.main{padding:18px 22px;min-width:0}
.header-row{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:12px;gap:16px;flex-wrap:wrap}
.header-row h1{font-size:22px;margin:0 0 4px}
.quote-line{display:flex;gap:10px;align-items:baseline;flex-wrap:wrap}
.price{font-size:26px;font-weight:700;font-variant-numeric:tabular-nums}
.change{font-variant-numeric:tabular-nums}
.change.up{color:var(--up)} .change.down{color:var(--down)}
.provider-tag{font-size:11px;color:var(--muted);padding:2px 6px;background:var(--panel);border-radius:4px}

.controls{display:flex;gap:10px;align-items:center}
.resolutions{display:flex;background:var(--panel);border:1px solid var(--line);border-radius:8px;overflow:hidden}
.resolutions button{background:transparent;color:var(--text);border:none;padding:7px 11px;cursor:pointer;font-size:12px}
.resolutions button:hover{background:var(--panel2)}
.resolutions button.active{background:var(--accent);color:#fff}
.btn-primary{background:var(--accent);color:#fff;border:none;padding:9px 16px;border-radius:8px;cursor:pointer;font-weight:600}
.btn-primary:hover:not(:disabled){filter:brightness(1.1)}
.btn-primary:disabled{opacity:.6;cursor:wait}

.chart{height:480px;background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden}

.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;margin-top:14px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:14px}
.card h4{margin:0 0 10px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.kv{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px dashed var(--line);font-variant-numeric:tabular-nums}
.kv:last-child{border-bottom:none} .kv span{color:var(--muted)}
.disclaimer{margin:10px 0 0;font-size:11px;color:var(--muted);line-height:1.4}

/* ======== Playbook ======== */
.playbook{margin-top:18px;background:linear-gradient(180deg,var(--panel) 0%,var(--panel2) 100%);border:1px solid var(--line);border-radius:14px;padding:18px}
.pb-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:10px;flex-wrap:wrap}
.pb-header h2{font-size:16px;display:flex;align-items:center;gap:8px}
.pb-pill{padding:4px 10px;border-radius:20px;font-size:12px;background:var(--panel2);border:1px solid var(--line);color:var(--muted)}
.pb-pill.up{color:var(--up);border-color:var(--up)}
.pb-pill.down{color:var(--down);border-color:var(--down)}
.pb-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px}
.pb-card{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:14px}
.pb-card h4{margin:0 0 10px;font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);display:flex;align-items:center;gap:6px}
.pb-card.pb-wide{grid-column:1/-1}
.pb-card ul{margin:0;padding-left:20px;line-height:1.6}
.pb-card ul li{margin-bottom:4px}
.pb-card p{margin:6px 0;line-height:1.5}
.pb-card .muted{color:var(--muted);font-size:12px}
.pb-card.pb-warn{background:#3a2a1f;border-color:#ffb74d33}
.pb-card.pb-warn h4{color:var(--gold)}
.pb-card .kv b small{color:var(--muted);font-weight:400}
.pb-disclaimer{display:flex;gap:8px;align-items:flex-start;margin-top:14px;line-height:1.6}
.pb-disclaimer .i{flex-shrink:0;margin-top:2px;color:var(--accent)}

/* ======== Stats alert ======== */
.stats-alert{margin-top:14px;background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:10px;padding:12px 16px}
.stats-alert.warn{border-left-color:var(--gold);background:#3a2a1f}
.stats-alert h3{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);display:flex;align-items:center;gap:6px;margin-bottom:6px}
.stats-alert p{margin:0 0 6px;line-height:1.5}
.stats-alert small{display:block;font-size:11px;color:var(--muted)}

/* ======== Calculador y What-if ======== */
.pb-calc, .pb-whatif{background:#0e1530}
.calc-form{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;margin:10px 0}
.calc-form label{display:flex;flex-direction:column;font-size:12px;color:var(--muted);gap:4px}
.calc-form input, .calc-form select{background:var(--panel);border:1px solid var(--line);color:var(--text);padding:8px 10px;border-radius:6px;width:140px;font-size:13px}
.calc-form button{margin-top:0}
.calc-result{margin-top:14px}
.cr-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-bottom:14px}
.cr-cell{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:10px}
.cr-cell span{display:block;font-size:11px;color:var(--muted);margin-bottom:3px;text-transform:uppercase;letter-spacing:.05em}
.cr-cell b{font-size:16px;display:flex;align-items:center;gap:6px}
.cr-cell b.up{color:var(--up)} .cr-cell b.down{color:var(--down)}
.cr-rr{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:8px 0}
.cr-rr-cell{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:10px;font-size:13px}
.cr-rr-cell b{display:block;color:var(--accent);font-size:14px;margin-bottom:4px}
.cr-rr-cell .up{color:var(--up);font-weight:600}
.cr-warn{margin:10px 0 0;padding-left:18px;color:var(--gold);font-size:13px}
.cr-warn li{margin:4px 0;display:list-item}
.cr-warn .i{color:var(--gold)}

.wif-summary{padding:12px 14px;background:var(--panel);border-radius:8px;border-left:3px solid var(--accent);margin:10px 0}
.wif-summary.up{border-left-color:var(--up)}
.wif-summary.down{border-left-color:var(--down)}
.wif-summary p{margin:0;line-height:1.6}
.wif-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px}
.wif-cell{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:10px}
.wif-cell span{display:block;font-size:11px;color:var(--muted);margin-bottom:3px;text-transform:uppercase;letter-spacing:.05em}
.wif-cell b{font-size:16px;display:block} .wif-cell b.up{color:var(--up)} .wif-cell b.down{color:var(--down)}
.wif-cell small{font-size:10px;color:var(--muted)}

/* ======== Tools page ======== */
.health-badge{padding:6px 14px;border-radius:20px;font-weight:600;font-size:13px;background:var(--panel);border:1px solid var(--line)}
.health-badge.verde{background:#1a3d2e;color:var(--up);border-color:var(--up)}
.health-badge.amarillo{background:#3a2a1f;color:var(--gold);border-color:var(--gold)}
.health-badge.rojo{background:#3a1f25;color:var(--down);border-color:var(--down)}

.verdict-card{display:flex;gap:14px;align-items:flex-start;padding:16px 18px;border-radius:10px;background:var(--panel);border:1px solid var(--line);margin-bottom:18px}
.verdict-card.verde{border-left:4px solid var(--up)}
.verdict-card.amarillo{border-left:4px solid var(--gold)}
.verdict-card.rojo{border-left:4px solid var(--down);background:#3a1f25}
.verdict-icon .i{color:var(--accent)}
.verdict-card.rojo .verdict-icon .i{color:var(--down)}
.verdict-card.verde .verdict-icon .i{color:var(--up)}
.verdict-text{flex:1;line-height:1.6}

.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:18px;flex-wrap:wrap}
.tab{background:transparent;border:none;color:var(--muted);padding:10px 16px;cursor:pointer;font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:6px;border-bottom:2px solid transparent;margin-bottom:-1px}
.tab:hover{color:var(--text)}
.tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.tab-pane{display:none}
.tab-pane.active{display:block}

.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-bottom:18px}
.form-grid label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}
.form-grid input, .form-grid select{background:var(--panel);border:1px solid var(--line);color:var(--text);padding:9px 11px;border-radius:6px;font-size:13px}
.form-grid input:focus, .form-grid select:focus{border-color:var(--accent);outline:none}
.form-grid small{font-size:10px;color:var(--muted)}

.checklist h3{font-size:14px;color:var(--muted);margin-bottom:14px}
.check-item{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:14px;margin-bottom:10px}
.ci-q{font-weight:600;display:flex;align-items:center;gap:8px;margin-bottom:6px}
.ci-help{font-size:12px;color:var(--muted);margin-bottom:10px;line-height:1.5}
.ci-actions{display:flex;gap:8px}
.ci-actions button{background:var(--panel2);border:1px solid var(--line);color:var(--text);padding:7px 18px;border-radius:6px;cursor:pointer;font-size:13px}
.ci-actions button:hover{border-color:var(--accent)}
.ci-actions button.selected{background:var(--accent);border-color:var(--accent);color:#fff}

.health-detail{margin-top:18px;display:grid;grid-template-columns:1fr;gap:10px}
.hd-block{padding:12px 14px;border-radius:8px;border:1px solid var(--line)}
.hd-block.bad{background:#3a1f25;border-color:var(--down)}
.hd-block.warn{background:#3a2a1f;border-color:var(--gold)}
.hd-block.good{background:#1a3d2e;border-color:var(--up)}
.hd-block h4{font-size:12px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.hd-block.bad h4{color:var(--down)}
.hd-block.warn h4{color:var(--gold)}
.hd-block.good h4{color:var(--up)}
.hd-block ul{margin:0;padding-left:20px;line-height:1.5}

.bt-trends{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;margin-bottom:18px}
.bt-trend{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:12px;display:flex;flex-direction:column;gap:4px}
.bt-trend span{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.bt-trend b{font-size:18px;font-variant-numeric:tabular-nums}
.bt-trend i{font-style:normal;color:var(--accent);font-weight:600}
.bt-symbols-wrap{margin:10px 0 18px;overflow-x:auto;background:var(--panel);border:1px solid var(--line);border-radius:10px}

.bm-target-card{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:16px;margin:14px 0}
.bm-target-card h3{margin-bottom:10px}
.bm-target-card h3 small{color:var(--muted);font-weight:400}
.bm-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-bottom:16px}
.bm-card{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:12px}
.bm-card h4{font-size:13px;margin-bottom:8px;color:var(--accent)}
.bm-verdicts{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:14px}
.bm-verdicts p{margin:8px 0;line-height:1.6;display:flex;gap:8px}
.bm-verdicts .i{color:var(--accent);flex-shrink:0;margin-top:2px}

/* ======== Crypto table ======== */
.crypto-table-wrap{overflow-x:auto;background:var(--panel);border:1px solid var(--line);border-radius:10px}
.crypto-table{font-size:13px;min-width:980px}
.crypto-table thead{background:var(--panel2);position:sticky;top:0}
.crypto-table th{padding:12px 10px;text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600;border-bottom:1px solid var(--line)}
.crypto-table td{padding:10px;border-bottom:1px solid var(--line)}
.crypto-table tr:hover{background:var(--panel2)}
.crypto-table .num{text-align:right;font-variant-numeric:tabular-nums}
.crypto-table .num.up{color:var(--up)} .crypto-table .num.down{color:var(--down)}
.coin-cell{display:flex;align-items:center;gap:10px}
.coin-cell img{border-radius:50%}
.coin-cell b{display:block} .coin-cell small{color:var(--muted);font-size:11px}

/* ======== Forex grid ======== */
.forex-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.fx-card{display:block;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:14px;cursor:pointer}
.fx-card:hover{border-color:var(--accent)}
.fx-card.up   {border-left:3px solid var(--up)}
.fx-card.down {border-left:3px solid var(--down)}
.fx-pair{font-weight:600}
.fx-rate{font-size:18px;font-variant-numeric:tabular-nums;margin:4px 0}
.fx-change{font-size:13px;font-variant-numeric:tabular-nums}
.fx-card.up .fx-change{color:var(--up)} .fx-card.down .fx-change{color:var(--down)}

/* ======== Misc ======== */
.empty{padding:24px;text-align:center;color:var(--muted)}
.error-card{padding:16px;background:#3a1f25;border:1px solid var(--down);border-radius:8px;color:#ffb4b4}

/* ======== Academia ======== */
.user-chip{padding:5px 10px;background:var(--panel2);border:1px solid var(--line);border-radius:20px;font-size:12px}
.academy-main .hero{margin-bottom:20px}
.academy-main h1{font-size:24px;display:flex;align-items:center;gap:10px;margin-bottom:6px}
.academy-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:24px}
.academy-stats .kpi span{display:flex;align-items:center;gap:6px}

.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}
.course-card{display:flex;gap:14px;background:var(--panel);border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:12px;padding:16px;cursor:pointer;transition:transform .15s,border-color .15s}
.course-card:hover{transform:translateY(-3px)}
.cc-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cc-icon .i{width:28px;height:28px}
.cc-body{flex:1;min-width:0}
.cc-level{display:inline-block;font-size:10px;text-transform:uppercase;letter-spacing:.08em;background:var(--panel2);padding:2px 8px;border-radius:10px;color:var(--muted);margin-bottom:6px}
.cc-body h3{font-size:16px;margin:4px 0}
.cc-body .muted{font-size:12px;margin:4px 0 8px}
.cc-meta{display:flex;gap:12px;font-size:11px;color:var(--muted);margin-bottom:8px}
.cc-meta span{display:inline-flex;align-items:center;gap:4px}
.cc-meta .up{color:var(--up)}
.progress-bar{height:6px;background:var(--panel2);border-radius:3px;overflow:hidden;margin:6px 0}
.progress-bar.lg{height:10px;border-radius:5px}
.progress-fill{height:100%;background:var(--accent);transition:width .3s}

.course-hero{margin-bottom:24px}
.course-hero h1{font-size:24px;display:flex;align-items:center;gap:10px}
.course-progress{margin-top:12px;max-width:500px}

.lesson-list{display:flex;flex-direction:column;gap:8px}
.lesson-row{display:flex;align-items:center;gap:14px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:12px 16px;cursor:pointer;transition:border-color .15s,transform .12s}
.lesson-row:hover{border-color:var(--accent);transform:translateX(3px)}
.lesson-row.done{background:#0f1f1a;border-left:3px solid var(--up)}
.lr-num{width:36px;height:36px;border-radius:50%;background:var(--panel2);display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}
.lesson-row.done .lr-num{background:transparent}
.lr-body{flex:1;min-width:0}
.lr-body h3{font-size:15px;margin:0 0 4px}
.lr-meta{display:flex;gap:12px;font-size:11px;color:var(--muted);flex-wrap:wrap}
.lr-meta span{display:inline-flex;align-items:center;gap:4px}
.lr-meta .up{color:var(--up)}

/* Lesson page */
.lesson-page{padding:24px 16px}
.lesson-container{max-width:820px;margin:0 auto}
.breadcrumb{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:12px;margin-bottom:14px;flex-wrap:wrap}
.breadcrumb a{color:var(--muted)} .breadcrumb a:hover{color:var(--accent)}
.lesson-body{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:30px;line-height:1.7}
.lesson-body h1{font-size:28px;margin-bottom:14px;color:var(--accent)}
.lesson-body h2{font-size:20px;margin:20px 0 10px;border-bottom:1px solid var(--line);padding-bottom:6px}
.lesson-body h3{font-size:16px;margin:16px 0 8px;color:var(--accent)}
.lesson-body p{margin:10px 0}
.lesson-body ul, .lesson-body ol{margin:10px 0;padding-left:24px}
.lesson-body li{margin:6px 0}
.lesson-body code{background:var(--panel2);padding:2px 6px;border-radius:4px;font-size:13px;color:var(--gold)}
.lesson-body pre{background:var(--panel2);padding:12px;border-radius:8px;overflow-x:auto;font-size:13px;line-height:1.5}
.lesson-body table{margin:12px 0;background:var(--panel2);border-radius:8px;overflow:hidden}
.lesson-body th, .lesson-body td{padding:8px 12px;border-bottom:1px solid var(--line);text-align:left}
.lesson-body th{background:var(--bg);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.lesson-body blockquote{border-left:3px solid var(--accent);padding:10px 16px;margin:14px 0;background:var(--panel2);border-radius:0 8px 8px 0;color:var(--muted)}
.lesson-body strong{color:var(--text)}

.video-block{margin-top:18px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px}
.video-block h3{margin-bottom:10px;display:flex;align-items:center;gap:8px}
.video-frame{position:relative;padding-bottom:56.25%;height:0;border-radius:8px;overflow:hidden;background:#000}
.video-frame iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}

.quiz-block{margin-top:18px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:24px}
.quiz-block h2{margin-bottom:8px;display:flex;align-items:center;gap:10px}
.quiz-q{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:18px;margin:14px 0;transition:border-color .2s}
.quiz-q.correct{border-left:3px solid var(--up)}
.quiz-q.wrong{border-left:3px solid var(--down)}
.qq-title{display:flex;gap:10px;align-items:flex-start;font-weight:600;margin-bottom:12px;line-height:1.5}
.qq-num{background:var(--accent);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}
.qq-options{display:flex;flex-direction:column;gap:8px}
.qq-opt{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--panel);border:1px solid var(--line);border-radius:8px;cursor:pointer;transition:border-color .15s}
.qq-opt:hover{border-color:var(--accent)}
.qq-opt input{margin:0;cursor:pointer}
.qq-opt.opt-correct{background:#0f2a1f;border-color:var(--up)}
.qq-opt.opt-wrong{background:#2a0f15;border-color:var(--down)}
.qq-feedback{margin-top:12px;padding:10px 14px;border-radius:8px;font-size:13px;display:flex;align-items:center;gap:8px;line-height:1.5}
.qq-feedback.good{background:#0f2a1f;color:var(--up)}
.qq-feedback.bad{background:#2a0f15;color:var(--down)}

.quiz-summary{margin-top:18px;padding:18px;border-radius:10px;text-align:center}
.quiz-summary.good{background:#0f2a1f;border:2px solid var(--up)}
.quiz-summary.bad{background:#2a0f15;border:2px solid var(--down)}
.quiz-summary h3{font-size:20px;margin-bottom:8px}

.lesson-nav{display:flex;justify-content:space-between;gap:10px;margin-top:24px}
.ln-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 18px;background:var(--panel);border:1px solid var(--line);border-radius:10px;color:var(--text);transition:border-color .15s}
.ln-btn:hover{border-color:var(--accent);color:var(--accent)}
.ln-btn.next{margin-left:auto;background:var(--accent);color:#fff;border-color:var(--accent)}

.celebrate{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:100;backdrop-filter:blur(4px)}
.celebrate-card{background:var(--panel);border:2px solid var(--gold);border-radius:16px;padding:40px;text-align:center;max-width:440px;animation:pop .4s ease}
.celebrate-card h2{margin:14px 0 8px;font-size:22px}
.celebrate-card p{margin-bottom:18px;color:var(--muted);line-height:1.5}
@keyframes pop {
  0%{transform:scale(.7);opacity:0}
  100%{transform:scale(1);opacity:1}
}

/* Login page */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:36px;max-width:440px;width:100%}
.login-card h1{font-size:22px;margin-bottom:8px;display:flex;align-items:center;gap:10px}
.login-card form{display:flex;flex-direction:column;gap:12px}
.login-card label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}
.login-card input{background:var(--panel2);border:1px solid var(--line);color:var(--text);padding:10px 12px;border-radius:8px;font-size:14px}
.login-card input:focus{border-color:var(--accent);outline:none}
.login-card .small{font-size:11px}
.info-banner{background:#1a3050;border-left:3px solid var(--accent);padding:10px 14px;border-radius:6px;margin-bottom:10px;font-size:13px}

/* Admin */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;backdrop-filter:blur(3px)}
.modal-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:28px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;position:relative}
.modal-close{position:absolute;top:12px;right:12px;background:transparent;border:none;color:var(--muted);cursor:pointer;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.modal-close:hover{background:var(--panel2);color:var(--text)}
.btn-link{background:transparent;border:1px solid var(--line);color:var(--accent);padding:5px 10px;border-radius:6px;font-size:12px;cursor:pointer;display:inline-flex;align-items:center;gap:4px}
.btn-link:hover{background:var(--accent);color:#fff}
.badge-admin{background:var(--gold);color:#000;padding:1px 7px;border-radius:10px;font-size:10px;font-weight:600}
.adm-course-block{margin:14px 0;background:var(--panel2);border-radius:8px;padding:12px}
.adm-course-block h4{margin-bottom:8px;color:var(--accent)}
.adm-course-block ul{list-style:none;padding-left:0;display:flex;flex-direction:column;gap:6px}
.adm-course-block li{display:flex;align-items:center;gap:8px;font-size:13px;line-height:1.5}

/* ======== Landing ======== */
body.landing{background:radial-gradient(ellipse at top,#1a2350 0%,#0b1020 60%);min-height:100vh}
.landing-bar{background:rgba(18,25,53,0.8);backdrop-filter:blur(8px)}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--line);padding:9px 16px;border-radius:8px;font-weight:600;display:inline-flex;align-items:center;gap:6px}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-primary.lg, .btn-ghost.lg{padding:14px 26px;font-size:15px}
.hero-landing{display:grid;grid-template-columns:1.3fr 1fr;gap:40px;padding:60px 40px;max-width:1200px;margin:0 auto;align-items:center}
.hero-content h1{font-size:42px;line-height:1.15;margin:14px 0}
.grad{background:linear-gradient(90deg,#5b8cff,#26a69a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;background:rgba(91,140,255,.15);border:1px solid var(--accent);color:var(--accent);font-size:12px}
.hero-sub{color:var(--muted);font-size:16px;line-height:1.7;margin:14px 0 22px;max-width:560px}
.hero-cta{display:flex;gap:12px;margin-bottom:30px;flex-wrap:wrap}
.hero-stats{display:flex;gap:32px;flex-wrap:wrap}
.hero-stats div{display:flex;flex-direction:column}
.hero-stats b{font-size:24px;color:var(--accent)}
.hero-stats span{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.hero-mock{display:flex;justify-content:center}
.mock-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px;width:100%;max-width:360px;box-shadow:0 12px 40px rgba(0,0,0,.4)}
.mock-row{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--panel2);border-radius:8px;margin-bottom:6px;font-size:13px}
.mock-row.up{color:var(--up)} .mock-row.down{color:var(--down)}
.mock-chart{height:120px;margin:14px 0;background:linear-gradient(180deg,#26a69a33 0%,transparent 100%);border-radius:8px;position:relative;overflow:hidden}
.mock-chart::before{content:"";position:absolute;left:0;right:0;bottom:0;height:60%;background:linear-gradient(180deg,transparent 0%,#26a69a44 100%);clip-path:polygon(0 70%,15% 50%,30% 60%,45% 30%,60% 45%,75% 25%,90% 35%,100% 15%,100% 100%,0 100%)}
.mock-pill{font-size:11px;color:var(--muted);text-align:center;padding:6px 10px;background:var(--panel2);border-radius:20px}

.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;padding:40px;max-width:1200px;margin:0 auto}
.feature{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:24px;text-align:center}
.feat-ico{width:60px;height:60px;background:rgba(91,140,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.feat-ico .i{width:30px;height:30px;color:var(--accent)}
.feature h3{font-size:16px;margin-bottom:8px}
.feature p{color:var(--muted);font-size:13px;line-height:1.6}

.section-title{text-align:center;font-size:28px;margin-bottom:8px}
.section-sub{text-align:center;color:var(--muted);max-width:600px;margin:0 auto 30px}
.how-section, .courses-section, .plans-section, .faq-section{padding:60px 40px;max-width:1200px;margin:0 auto}
.how-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.how-step{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:24px;position:relative}
.step-num{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;margin-bottom:12px}
.how-step h3{font-size:16px;margin-bottom:6px}
.how-step p{color:var(--muted);font-size:13px;line-height:1.6}

.landing-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.landing-course{cursor:default}
.landing-course:hover{transform:none}

.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-top:14px}
.plan-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:28px 24px;position:relative}
.plan-card.highlight{border:2px solid var(--accent);background:linear-gradient(180deg,#1a2050 0%,var(--panel) 100%)}
.plan-card.lifetime{border:2px solid var(--gold);background:linear-gradient(180deg,#2a1f08 0%,var(--panel) 100%);position:relative;overflow:hidden}
.plan-card.lifetime::before{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,183,77,0.1) 0%,transparent 60%);pointer-events:none}
.plan-card.lifetime .plan-price b{background:linear-gradient(90deg,#ffb74d,#ffd180);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ribbon-gold{background:var(--gold)!important;color:#000!important}
.plan-card.is-current{border-color:var(--up)}
.plan-ribbon{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;padding:4px 14px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.plan-current-badge{position:absolute;top:14px;right:14px;background:var(--up);color:#fff;padding:3px 10px;border-radius:14px;font-size:10px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.plan-card h3{font-size:20px;margin-bottom:6px}
.plan-card .muted{font-size:13px;margin-bottom:16px}
.plan-price{margin:14px 0;display:flex;align-items:baseline;gap:8px}
.plan-price b{font-size:34px;color:var(--text)}
.plan-price small{font-size:12px;color:var(--muted)}
.plan-features{list-style:none;padding:0;margin:18px 0}
.plan-features li{display:flex;align-items:flex-start;gap:8px;padding:6px 0;font-size:13px;line-height:1.5}
.plan-features .i{color:var(--up);flex-shrink:0;margin-top:3px}
.plan-cta{width:100%;justify-content:center;margin-top:14px}
.plan-cta:disabled{background:var(--panel2);color:var(--muted);cursor:default}
.admin-plan.inactive{opacity:.55}

.faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:8px}
.faq-list details{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:14px 18px;cursor:pointer}
.faq-list summary{font-weight:600;list-style:none}
.faq-list summary::after{content:"+";float:right;color:var(--muted);font-size:18px}
.faq-list details[open] summary::after{content:"−"}
.faq-list p{color:var(--muted);line-height:1.6;margin-top:10px;font-size:13px}

.cta-final{text-align:center;padding:80px 40px;max-width:900px;margin:0 auto}
.cta-final h2{font-size:36px;margin-bottom:14px}
.cta-final p{color:var(--muted);margin-bottom:28px;font-size:16px}
.footer-landing{padding:30px;text-align:center;border-top:1px solid var(--line);max-width:1200px;margin:0 auto}

/* ======== Showcase Simulador ======== */
.showcase-section{padding:80px 30px;max-width:1280px;margin:0 auto;position:relative}
.showcase-section::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:60%;height:400px;background:radial-gradient(ellipse at center,rgba(91,140,255,0.08) 0%,transparent 70%);pointer-events:none;z-index:-1}
.showcase-header{text-align:center;margin-bottom:40px}
.showcase-header .hero-badge{margin-bottom:14px}

/* ----- Mockup principal ----- */
.mockup-container{position:relative;margin-bottom:60px;perspective:1500px}
.mockup-window{background:#0b1020;border-radius:14px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,0.6),0 0 0 1px var(--line);max-width:1100px;margin:0 auto;transform:rotateX(2deg);transition:transform .3s}
.mockup-window:hover{transform:rotateX(0)}
.mockup-bar{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#1a2050;border-bottom:1px solid var(--line)}
.mockup-bar .dot{width:11px;height:11px;border-radius:50%;display:inline-block}
.mockup-bar .dot.red{background:#ff5f57}
.mockup-bar .dot.yellow{background:#ffbd2e}
.mockup-bar .dot.green{background:#28c93f}
.mockup-url{margin-left:14px;font-size:11px;color:var(--muted);background:var(--panel);padding:4px 10px;border-radius:5px;display:inline-flex;align-items:center;gap:5px}
.mockup-body{padding:18px;background:#0b1020}

.mk-kpis{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-bottom:14px}
.mk-kpi{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:11px}
.mk-kpi span{display:block;color:var(--muted);font-size:9px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}
.mk-kpi b{font-size:14px;display:block;font-variant-numeric:tabular-nums}
.mk-kpi small{font-size:9px;display:block;margin-top:1px}
.mk-kpi b.up,.mk-kpi small.up{color:var(--up)}
.mk-kpi b.down,.mk-kpi small.down{color:var(--down)}

.mk-grid{display:grid;grid-template-columns:200px 1fr 220px;gap:10px}
.mk-panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:10px;font-size:11px}
.mk-panel-title{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:8px;display:flex;align-items:center;gap:5px}
.mk-otype{display:flex;background:var(--panel2);border-radius:5px;padding:2px;margin-bottom:6px}
.mk-otype span{flex:1;padding:4px;text-align:center;font-size:10px;color:var(--muted);border-radius:3px}
.mk-otype span.active{background:var(--accent);color:#fff}
.mk-input{background:var(--panel2);padding:6px 8px;border-radius:5px;margin-bottom:5px;font-size:10px;font-variant-numeric:tabular-nums;display:flex;justify-content:space-between;align-items:center}
.mk-input .up{color:var(--up)}
.mk-side{display:flex;background:var(--panel2);border-radius:5px;padding:2px;margin-bottom:5px}
.mk-side span{flex:1;padding:4px;text-align:center;font-size:10px;border-radius:3px}
.mk-side span.active.up{background:var(--up);color:#fff}
.mk-side span.active.down{background:var(--down);color:#fff}
.mk-feedback{background:var(--panel2);border-radius:5px;padding:6px;margin:6px 0;display:flex;flex-direction:column;gap:3px}
.mk-fb-item{display:flex;gap:5px;font-size:9px;line-height:1.3;padding:3px 5px;border-radius:3px}
.mk-fb-item.up{background:rgba(38,166,154,0.1);color:var(--up)}
.mk-fb-item.warn{background:rgba(255,183,77,0.1);color:var(--gold)}
.mk-fb-item.danger{background:rgba(239,83,80,0.1);color:var(--down)}
.mk-fb-item.info{background:rgba(91,140,255,0.1);color:var(--accent)}
.mk-fb-item .i{flex-shrink:0;margin-top:1px}
.mk-btn{width:100%;background:var(--accent);color:#fff;border:none;padding:7px;border-radius:5px;cursor:pointer;font-size:11px;font-weight:600;margin-top:6px}

.mk-chart{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:10px;display:flex;flex-direction:column;min-height:280px}
.mk-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:11px}
.mk-tf{display:flex;background:var(--panel2);border-radius:4px;padding:2px}
.mk-tf span{padding:3px 8px;font-size:9px;color:var(--muted);border-radius:3px;cursor:default}
.mk-tf span.active{background:var(--accent);color:#fff}
.mk-candles{width:100%;flex:1;background:var(--panel)}

.mk-pos{display:flex;flex-direction:column;gap:5px}
.mk-pos-row{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;background:var(--panel2);border-radius:5px;font-size:10px}
.mk-pos-row > div:first-child{display:flex;flex-direction:column}
.mk-pos-row b{font-size:11px}
.mk-pos-row small{color:var(--muted);font-size:9px}
.mk-pos-row > div:last-child{text-align:right;font-variant-numeric:tabular-nums;font-weight:600;display:flex;flex-direction:column}
.mk-pos-row > div:last-child small{font-size:8px;font-weight:400}
.mk-pos-row .up{color:var(--up)}
.mk-pos-row .down{color:var(--down)}

/* Floating badges sobre el mockup */
.mk-float{position:absolute;background:var(--panel);border:1px solid var(--line);border-radius:30px;padding:8px 16px;display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;box-shadow:0 8px 24px rgba(0,0,0,0.4);animation:floatY 3s ease-in-out infinite}
.mk-float-tl{top:-20px;left:5%;color:var(--up);border-color:var(--up)}
.mk-float-br{bottom:-20px;right:5%;color:var(--accent);border-color:var(--accent);animation-delay:1.5s}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* ----- Features grid ----- */
.showcase-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:50px}
.showcase-feature{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:24px;transition:transform .15s,border-color .15s}
.showcase-feature:hover{transform:translateY(-4px);border-color:var(--accent)}
.sf-icon{width:54px;height:54px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.sf-icon .i{width:28px;height:28px}
.showcase-feature h3{font-size:16px;margin-bottom:8px}
.showcase-feature > p{color:var(--muted);font-size:13px;line-height:1.6;margin-bottom:14px}
.sf-mini{background:var(--panel2);border-radius:10px;padding:10px;display:flex;flex-direction:column;gap:5px}
.sf-fb{display:flex;gap:6px;align-items:center;font-size:11px;padding:5px 8px;border-radius:5px}
.sf-fb.up{background:rgba(38,166,154,0.1);color:var(--up)}
.sf-fb.warn{background:rgba(255,183,77,0.1);color:var(--gold)}
.sf-fb.danger{background:rgba(239,83,80,0.1);color:var(--down)}
.sf-stat{display:flex;justify-content:space-between;align-items:center;font-size:12px;padding:4px 8px;background:var(--panel);border-radius:5px}
.sf-stat span{color:var(--muted);font-size:11px}
.sf-stat b{font-size:14px;font-variant-numeric:tabular-nums}
.sf-stat b.up{color:var(--up)}
.sf-chart{width:100%;height:60px;margin-top:10px}
.sf-order{display:grid;grid-template-columns:auto 1fr auto;gap:6px;align-items:center;font-size:11px;padding:5px 8px;background:var(--panel);border-radius:5px}
.sf-order b{font-size:11px}
.sf-order small{color:var(--muted);font-size:10px}
.sf-journal{padding:8px}
.sf-jr-meta{font-size:11px;margin-bottom:5px}
.sf-jr-meta .up{color:var(--up)}
.sf-journal p{font-size:11px;line-height:1.5;color:var(--text);margin:5px 0;font-style:italic;border-left:2px solid var(--accent);padding-left:8px}
.sf-leader{display:grid;grid-template-columns:30px 1fr auto;gap:8px;align-items:center;font-size:12px;padding:5px 8px;background:var(--panel);border-radius:5px}
.sf-leader > span:first-child{font-size:14px;text-align:center}
.sf-leader b{font-size:11px}
.sf-leader > span:last-child{font-size:11px;font-weight:600}
.sf-leader.me-row{background:rgba(91,140,255,0.15);border:1px solid var(--accent)}
.sf-markets{display:flex;flex-wrap:wrap;gap:5px}
.sf-flag{font-size:11px;padding:4px 8px;background:var(--panel);border:1px solid var(--line);border-radius:14px}

/* ----- Stats banner ----- */
.showcase-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:30px 0;padding:30px;background:linear-gradient(135deg,#1a2050 0%,var(--panel) 100%);border:1px solid var(--accent);border-radius:14px}
.ss-stat{text-align:center}
.ss-stat .i{color:var(--accent);width:32px;height:32px;margin-bottom:8px}
.ss-stat b{display:block;font-size:24px;font-weight:700;color:var(--text);margin-bottom:4px;font-variant-numeric:tabular-nums}
.ss-stat span{color:var(--muted);font-size:12px}

/* ----- CTA ----- */
.showcase-cta{text-align:center;margin-top:40px;padding:40px;background:var(--panel);border:1px solid var(--line);border-radius:14px}
.showcase-cta h3{font-size:24px;margin-bottom:8px}
.showcase-cta p{margin-bottom:18px}

@media (max-width: 1100px){
  .showcase-features-grid{grid-template-columns:repeat(2,1fr)}
  .mk-grid{grid-template-columns:1fr}
  .mk-kpis{grid-template-columns:repeat(3,1fr)}
}
@media (max-width: 700px){
  .showcase-features-grid{grid-template-columns:1fr}
  .showcase-stats{grid-template-columns:repeat(2,1fr)}
  .mk-kpis{grid-template-columns:repeat(2,1fr)}
}

/* ======== Pensum landing ======== */
.pensum-section{padding:60px 40px;max-width:1200px;margin:0 auto}
.learning-path{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:30px;margin-bottom:40px}
.path-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.path-stage{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:18px;position:relative}
.path-stage.stage-1{border-left:3px solid var(--up)}
.path-stage.stage-2{border-left:3px solid var(--accent)}
.path-stage.stage-3{border-left:3px solid var(--gold)}
.path-stage.stage-4{border-left:3px solid #b388ff}
.ps-num{position:absolute;top:-14px;right:14px;width:32px;height:32px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}
.path-stage h4{font-size:15px;margin-bottom:4px}
.path-stage small{display:block;margin-bottom:10px}
.path-stage ul{margin:0;padding-left:18px;font-size:13px;line-height:1.6}

.pensum-list{display:flex;flex-direction:column;gap:10px;margin:18px 0}
.pensum-item{display:flex;gap:14px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:16px;align-items:center}
.pi-order{width:34px;height:34px;background:var(--panel2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;font-size:14px}
.pi-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pi-body{flex:1;min-width:0}
.pi-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;flex-wrap:wrap;margin-bottom:4px}
.pi-head h4{font-size:15px;margin:0}
.pi-tags{display:flex;gap:6px;flex-shrink:0}
.pi-tag{font-size:10px;padding:3px 9px;border-radius:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.pi-tag.level-principiante{background:rgba(38,166,154,0.2);color:var(--up)}
.pi-tag.level-intermedio{background:rgba(91,140,255,0.2);color:var(--accent)}
.pi-tag.level-avanzado{background:rgba(179,136,255,0.2);color:#b388ff}
.pi-tag.free{background:rgba(38,166,154,0.2);color:var(--up);border:1px solid var(--up)}
.pi-tag.premium{background:rgba(255,183,77,0.2);color:var(--gold);border:1px solid var(--gold)}
.pi-stats{display:flex;gap:14px;font-size:12px;color:var(--muted);margin-top:6px;flex-wrap:wrap}
.pi-stats span{display:inline-flex;align-items:center;gap:4px}

.time-summary{margin:30px 0;background:linear-gradient(135deg,#1a2050 0%,var(--panel2) 100%);border:1px solid var(--accent);border-radius:14px;padding:30px}
.time-summary h3{text-align:center;margin-bottom:18px;display:flex;align-items:center;justify-content:center;gap:10px}
.time-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.time-card{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:18px;text-align:center}
.time-card.highlight{border-color:var(--accent);background:rgba(91,140,255,0.08)}
.time-card b{display:block;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}
.time-big{display:block;font-size:24px;font-weight:700;color:var(--accent);margin-bottom:6px}
.time-card.highlight .time-big{color:var(--up)}
.time-card small{font-size:12px}

.learnings{margin-top:30px}
.learn-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:10px}
.learn-item{background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--up);border-radius:8px;padding:12px 14px;display:flex;gap:8px;align-items:flex-start;font-size:13px;line-height:1.5}
.learn-item .i{color:var(--up);flex-shrink:0;margin-top:2px}

/* ======== Footer landing ampliado ======== */
.footer-landing{padding:40px 30px 20px;border-top:1px solid var(--line);max-width:1200px;margin:60px auto 0;text-align:left}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:30px;margin-bottom:30px}
.footer-col h4{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--text);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.footer-col a{color:var(--muted);font-size:13px}
.footer-col a:hover{color:var(--accent)}
.footer-col p{font-size:13px;line-height:1.6}
.footer-bottom{padding-top:20px;border-top:1px solid var(--line);text-align:center;display:flex;flex-direction:column;gap:6px}
.dev-link{color:var(--accent)}
.dev-link b{color:var(--accent)}

/* ======== Footer mini (paginas internas) ======== */
.footer-mini{display:flex;justify-content:space-between;align-items:center;padding:18px 28px;border-top:1px solid var(--line);margin-top:40px;flex-wrap:wrap;gap:10px;background:var(--panel2)}

@media (max-width: 880px){
  .path-grid{grid-template-columns:1fr 1fr}
  .time-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}

/* ======== Subscription stuff ======== */
.welcome-banner{display:flex;gap:16px;align-items:flex-start;background:linear-gradient(90deg,#1a3050,var(--panel));border:1px solid var(--accent);border-radius:14px;padding:20px;margin-bottom:24px}
.welcome-banner h2{margin-bottom:6px}
.welcome-banner p{margin:6px 0;color:var(--muted);line-height:1.6}
.sub-bar{margin-top:14px;padding:10px 14px;background:var(--panel);border:1px solid var(--line);border-left:3px solid var(--up);border-radius:8px;font-size:13px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.sub-bar.warn{border-left-color:var(--gold)}
.current-sub-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px;margin-bottom:18px}
.cs-info{display:flex;gap:14px;align-items:center}
.cs-info h3{margin:0 0 4px}

.checkout-page{display:flex;align-items:center;justify-content:center;min-height:70vh}
.checkout-card{text-align:center;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:50px 40px;max-width:520px}
.checkout-card.success{border-top:4px solid var(--up)}
.checkout-card.failure{border-top:4px solid var(--down)}
.checkout-card.pending{border-top:4px solid var(--gold)}
.checkout-card h1{font-size:24px;margin:14px 0}
.checkout-card p{color:var(--muted);margin:8px 0;line-height:1.6}

.locked-card{text-align:center;padding:50px 30px;background:var(--panel2);border-radius:12px;border:1px dashed var(--gold)}
.locked-card h1{font-size:22px;margin:14px 0}
.locked-card p{color:var(--muted);line-height:1.7}

/* ======== Admin upgrades ======== */
.admin-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px;align-items:center}
.admin-filters label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}
.admin-filters input, .admin-filters select{background:var(--panel);border:1px solid var(--line);color:var(--text);padding:7px 10px;border-radius:6px;font-size:13px}
.admin-filters input:focus, .admin-filters select:focus{border-color:var(--accent);outline:none}
.admin-filters input[type="search"]{min-width:240px}

.pagination-bar{display:flex;justify-content:space-between;align-items:center;margin-top:14px;flex-wrap:wrap;gap:10px}
.pagination{display:flex;gap:4px}
.pagination button{background:var(--panel);border:1px solid var(--line);color:var(--text);padding:6px 11px;border-radius:6px;cursor:pointer;font-size:13px}
.pagination button:hover:not(:disabled){background:var(--panel2);border-color:var(--accent)}
.pagination button.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.pagination button:disabled{opacity:.4;cursor:default}
.pagination span{padding:6px 10px;color:var(--muted)}

.sub-badge{display:inline-block;padding:3px 9px;border-radius:14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.sub-badge.active{background:rgba(38,166,154,.2);color:var(--up);border:1px solid var(--up)}
.sub-badge.none{background:var(--panel2);color:var(--muted);border:1px solid var(--line)}
.row-actions{display:flex;gap:4px}

/* ======== Simulator ======== */
.sim-page .page-header{align-items:center}
.sim-kpi-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px;margin:14px 0 18px}
.sim-kpi{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:12px 14px}
.sim-kpi span{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.sim-kpi b{font-size:20px;font-variant-numeric:tabular-nums;display:block}
.sim-kpi small{font-size:11px;display:block;margin-top:2px}
.kpi-val.up{color:var(--up)} .kpi-val.down{color:var(--down)}
.sim-kpi b.up{color:var(--up)} .sim-kpi b.down{color:var(--down)}

.sim-grid{display:grid;grid-template-columns:280px 1fr 280px;gap:14px;margin-bottom:18px}
.sim-panel{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:10px}
.sim-panel h3{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);display:flex;align-items:center;gap:6px;margin-bottom:6px}
.sim-panel label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}
.sim-panel input{background:var(--panel2);border:1px solid var(--line);color:var(--text);padding:9px 10px;border-radius:6px;font-size:13px}
.sim-panel input:focus{border-color:var(--accent);outline:none}
.o-quote{padding:8px 10px;background:var(--panel2);border-radius:6px;font-size:13px}
.o-quote .up{color:var(--up)} .o-quote .down{color:var(--down)}
.o-side{display:flex;gap:6px;background:var(--panel2);border-radius:8px;padding:3px}
.o-side button{flex:1;background:transparent;border:none;color:var(--muted);padding:7px;border-radius:6px;cursor:pointer;font-size:13px;display:inline-flex;align-items:center;justify-content:center;gap:5px}
.o-side button.active{background:var(--accent);color:#fff}
.o-side button[data-side="sell"].active{background:var(--down)}
.o-quick{display:flex;gap:4px}
.o-quick button{flex:1;background:var(--panel2);border:1px solid var(--line);color:var(--text);padding:6px;border-radius:6px;cursor:pointer;font-size:11px}
.o-quick button:hover{border-color:var(--accent)}
.o-preview{font-size:12px;background:var(--panel2);padding:10px;border-radius:8px;display:flex;flex-direction:column;gap:4px}
.o-preview:empty{display:none}

.sim-chart-wrap{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.sim-chart{height:520px;width:100%}

.sim-positions .pos-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-bottom:1px solid var(--line);cursor:pointer;border-radius:6px}
.sim-positions .pos-row:hover{background:var(--panel2)}
.sim-positions .pos-row:last-child{border-bottom:none}
.pos-h{flex:1;display:flex;flex-direction:column}
.pos-h small{color:var(--muted);font-size:10px}
.pos-mv{font-variant-numeric:tabular-nums;font-size:13px}
.pos-pnl{text-align:right;font-variant-numeric:tabular-nums;font-size:13px;display:flex;flex-direction:column}
.pos-pnl small{font-size:10px}
.pos-pnl.up{color:var(--up)} .pos-pnl.down{color:var(--down)}

.toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%);background:var(--up);color:#fff;padding:12px 22px;border-radius:30px;font-size:14px;z-index:200;box-shadow:0 8px 24px rgba(0,0,0,.4);animation:slideIn .25s ease}
@keyframes slideIn { from{opacity:0;transform:translate(-50%,10px)} to{opacity:1;transform:translate(-50%,0)} }
.me-row{background:rgba(91,140,255,.12)}

/* ======== Simulator pro: tipos de orden, feedback, journal ======== */
.o-type{display:flex;background:var(--panel2);border-radius:8px;padding:3px;margin-bottom:4px}
.o-type button{flex:1;background:transparent;border:none;color:var(--muted);padding:6px;border-radius:5px;cursor:pointer;font-size:11px}
.o-type button.active{background:var(--accent);color:#fff}
.o-trigger{margin-top:4px}

.o-feedback{padding:10px;border-radius:8px;background:var(--panel2);font-size:12px;display:flex;flex-direction:column;gap:5px}
.o-feedback.risk-ok{border-left:3px solid var(--up)}
.o-feedback.risk-warn{border-left:3px solid var(--gold);background:#3a2a1f33}
.o-feedback.risk-danger{border-left:3px solid var(--down);background:#3a1f2533}
.fb-item{display:flex;gap:6px;align-items:flex-start;line-height:1.4}
.fb-good{color:var(--up)} .fb-good .i{color:var(--up)}
.fb-warn{color:var(--gold)} .fb-warn .i{color:var(--gold)}
.fb-danger{color:var(--down)} .fb-danger .i{color:var(--down)}
.fb-info{color:var(--accent)} .fb-info .i{color:var(--accent)}
.fb-meta{margin-top:6px;padding-top:6px;border-top:1px dashed var(--line);color:var(--muted);font-size:11px}

.ord-pending{} .ord-filled{opacity:.7} .ord-cancelled,.ord-expired{opacity:.5}
.ord-badge{padding:3px 9px;border-radius:14px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.ord-badge.pending{background:rgba(255,183,77,0.2);color:var(--gold);border:1px solid var(--gold)}
.ord-badge.filled{background:rgba(38,166,154,0.2);color:var(--up);border:1px solid var(--up)}
.ord-badge.cancelled,.ord-badge.expired{background:var(--panel2);color:var(--muted);border:1px solid var(--line)}

.tips-list{display:flex;flex-direction:column;gap:8px}
.tips-list > div{padding:10px 14px;border-radius:8px;display:flex;gap:8px;align-items:flex-start;line-height:1.5;font-size:13px}
.tip-good{background:rgba(38,166,154,0.1);border-left:3px solid var(--up);color:var(--text)}
.tip-warn{background:rgba(255,183,77,0.1);border-left:3px solid var(--gold)}
.tip-danger{background:rgba(239,83,80,0.1);border-left:3px solid var(--down)}
.tip-info{background:var(--panel2);border-left:3px solid var(--accent)}
.tip-good .i{color:var(--up)} .tip-warn .i{color:var(--gold)} .tip-danger .i{color:var(--down)} .tip-info .i{color:var(--accent)}

.bw-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.bw-card{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:18px;text-align:center}
.bw-card.up{border-left:3px solid var(--up)}
.bw-card.down{border-left:3px solid var(--down)}
.bw-card span{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);display:block;margin-bottom:6px}
.bw-card b{font-size:24px;display:block;margin-bottom:4px}
.bw-card.up b{color:var(--up)} .bw-card.down b{color:var(--down)}
.bw-card small{color:var(--muted)}

.journal-entry{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:14px;margin-bottom:10px}
.journal-entry.has-note{border-left:3px solid var(--accent)}
.je-meta{display:flex;justify-content:space-between;gap:10px;align-items:center;font-size:13px;margin-bottom:8px;flex-wrap:wrap}
.je-content{font-size:13px;line-height:1.6;background:var(--panel2);padding:10px;border-radius:6px;margin:8px 0;display:flex;flex-direction:column;gap:4px}
.je-content b{color:var(--muted)}

/* ======== Admin content editor ======== */
.content-admin{max-width:1400px}
.content-layout{display:grid;grid-template-columns:repeat(3, 1fr);gap:14px;margin-top:14px;align-items:flex-start}
.ca-col{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px;min-height:400px;display:flex;flex-direction:column;gap:10px}
.ca-col h3{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);display:flex;align-items:center;gap:6px;margin:0}
.ca-list{display:flex;flex-direction:column;gap:6px;max-height:600px;overflow-y:auto}
.ca-item{display:flex;align-items:center;gap:10px;padding:10px;background:var(--panel2);border:1px solid var(--line);border-radius:8px;cursor:pointer;transition:border-color .12s}
.ca-item:hover{border-color:var(--accent)}
.ca-item.active{border-color:var(--accent);background:rgba(91,140,255,.1)}
.ca-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ca-num{width:32px;height:32px;border-radius:50%;background:var(--panel);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;flex-shrink:0}
.ca-body{flex:1;min-width:0}
.ca-body b{display:block;font-size:13px;line-height:1.3}
.ca-body small{font-size:11px;color:var(--muted)}

.md-editor{margin:14px 0}
.md-toolbar{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:var(--panel2);border:1px solid var(--line);border-radius:8px 8px 0 0}
.md-split{display:block}
.md-split textarea, .md-preview{width:100%;background:var(--panel);border:1px solid var(--line);border-top:none;color:var(--text);padding:14px;border-radius:0 0 8px 8px;font-family:'Consolas','Monaco',monospace;font-size:13px;line-height:1.6;resize:vertical}
.md-preview{min-height:300px;font-family:inherit;background:var(--panel2)}

.opt-row{display:flex;gap:8px;align-items:center;padding:6px;background:var(--panel2);border-radius:6px;margin-bottom:6px}
.opt-row input[type="text"]{flex:1;background:var(--panel);border:1px solid var(--line);color:var(--text);padding:7px 9px;border-radius:5px;font-size:13px}
.opt-row input[type="checkbox"]{width:18px;height:18px;cursor:pointer}

.form-grid textarea{background:var(--panel);border:1px solid var(--line);color:var(--text);padding:9px 11px;border-radius:6px;font-size:13px;font-family:inherit;resize:vertical}
.form-grid textarea:focus{border-color:var(--accent);outline:none}

@media (max-width: 1100px){
  .sim-grid{grid-template-columns:1fr}
  .sim-chart{height:380px}
  .content-layout{grid-template-columns:1fr}
}

@media (max-width: 880px){
  .hero-landing{grid-template-columns:1fr;padding:30px 20px}
  .hero-content h1{font-size:28px}
  .layout{grid-template-columns:1fr}
  .sidebar{border-right:none;border-bottom:1px solid var(--line)}
  .chart{height:360px}
  .nav{order:3;width:100%;overflow-x:auto}
}
