*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:none;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{min-height:100dvh;font-family:'General Sans','Helvetica Neue',sans-serif;background:#08080c;color:#e8e8ec;overflow:hidden;line-height:1.5}
button{cursor:pointer;background:none;border:none;font:inherit;color:inherit}
input[type=range]{-webkit-appearance:none;appearance:none;cursor:pointer}
:root{
  --font-d:'Cabinet Grotesk','Helvetica Neue',sans-serif;
  --g:#00ff88;--g2:#00cc6a;--r:#ff3355;--y:#ffd700;--b:#4a9ef0;
  --purple:#c070ff;--orange:#ff8844;--cyan:#00ddff;
  --bg:#08080c;--s1:#0e0e14;--s2:#14141c;--s3:#1c1c28;
  --brd:#222233;--txt:#e8e8ec;--txt2:#9999aa;--txt3:#666678;
  --rad:12px;--rad2:16px;
}
#app{width:100vw;height:100dvh;display:flex;flex-direction:column;overflow:hidden;position:relative}

/* ===== SCREEN TRANSITIONS ===== */
.screen{display:flex;flex-direction:column;height:100%;animation:screenIn .4s ease}
@keyframes screenIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ===== TITLE SCREEN ===== */
.title-screen{align-items:center;justify-content:center;text-align:center;gap:16px;padding:20px;position:relative;overflow:hidden}
.title-bg{position:absolute;inset:0;z-index:0}
.title-bg img{width:100%;height:100%;object-fit:cover;opacity:.6;filter:saturate(1.15) brightness(1.05)}
.title-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,#08080c 0%,rgba(8,8,12,.2) 35%,rgba(8,8,12,.5) 100%)}
.title-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:12px;max-width:400px}
.title-presents{font-size:11px;font-weight:700;letter-spacing:.25em;color:#fff;text-transform:uppercase;text-shadow:0 0 20px rgba(255,255,255,.3)}
.title-name{font-family:var(--font-d);font-weight:800;font-size:clamp(2.4rem,9vw,3.8rem);line-height:1;color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.5)}
.title-name span{color:var(--g);text-shadow:0 0 30px rgba(0,255,136,.4)}
.title-tagline{font-size:14px;color:#ccccd4;max-width:320px;line-height:1.5;text-shadow:0 1px 8px rgba(0,0,0,.6)}
.title-config{display:flex;flex-direction:column;gap:10px;width:100%;margin-top:4px}
.config-label{font-size:10px;font-weight:700;letter-spacing:.15em;color:#aaabb8;text-transform:uppercase;text-shadow:0 1px 4px rgba(0,0,0,.5)}
.config-row{display:flex;gap:8px}
.config-btn{flex:1;padding:10px 6px;border:1.5px solid rgba(255,255,255,.15);border-radius:10px;background:rgba(14,14,20,.7);backdrop-filter:blur(8px);font-size:12px;font-weight:600;color:#bbbbc8;text-align:center;transition:all .15s;white-space:nowrap;min-width:0}
.config-btn:hover{border-color:rgba(255,255,255,.3);color:#fff}
.config-btn.active{border-color:var(--g);background:rgba(0,255,136,.1);color:var(--g)}
.btn-play{font-family:var(--font-d);font-weight:700;font-size:17px;padding:15px 44px;border-radius:14px;background:var(--g);color:#08080c;border:none;margin-top:8px;transition:all .15s;text-transform:uppercase;letter-spacing:.05em}
.btn-play:hover{background:var(--g2);transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,255,136,.3)}
.title-footer{font-size:10px;color:#777788;margin-top:6px;text-shadow:0 1px 4px rgba(0,0,0,.5)}
.title-footer a{color:#777788;text-decoration:none}
.title-footer a:hover{color:#aaa;text-decoration:underline}

/* ===== GAME SCREEN ===== */
.game-screen{background:var(--bg)}
.game-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--brd);background:var(--s1);flex-shrink:0}
.hdr-left{display:flex;align-items:center;gap:10px}
.hdr-logo{font-family:var(--font-d);font-weight:700;font-size:13px;color:var(--g)}
.hdr-year{font-size:12px;font-weight:600;color:var(--txt2);background:var(--s2);padding:4px 12px;border-radius:20px}
.hdr-right{display:flex;align-items:center;gap:6px}
.hdr-nw{text-align:right}
.hdr-nw-label{font-size:10px;color:var(--txt3);text-transform:uppercase;letter-spacing:.06em}
.hdr-nw-val{font-family:var(--font-d);font-weight:700;font-size:16px;color:var(--g);font-variant-numeric:tabular-nums}

/* News ticker (top banner - permanently rolling) */
.news-ticker{background:var(--s2);border-bottom:1px solid var(--brd);overflow:hidden;height:28px;display:flex;align-items:center;flex-shrink:0;position:relative}
.ticker-track{display:flex;gap:40px;animation:tickerScroll 45s linear infinite;white-space:nowrap}
.ticker-item{font-size:11px;font-weight:500;white-space:nowrap;display:flex;align-items:center;gap:6px}
.ticker-item .up{color:var(--g)}.ticker-item .down{color:var(--r)}.ticker-item .flat{color:var(--txt3)}
.ticker-item .sym{color:var(--txt);font-weight:600}
@keyframes tickerScroll{0%{transform:translateX(0)}100%{transform:translateX(-33.33%)}}

/* Game body */
.game-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 16px;display:flex;flex-direction:column;gap:10px}
.game-body::-webkit-scrollbar{width:0}

/* Portfolio allocation */
.alloc-section{display:flex;flex-direction:column;gap:8px}
.alloc-header{display:flex;justify-content:space-between;align-items:center}
.alloc-title{font-weight:700;font-size:14px;color:var(--txt)}
.alloc-total{font-size:12px;font-weight:600;font-variant-numeric:tabular-nums}
.alloc-total.ok{color:var(--g)}
.alloc-total.over{color:var(--r)}
.alloc-total.under{color:var(--y)}
.alloc-warn{font-size:11px;color:var(--r);font-weight:500;text-align:center;padding:4px 0;animation:fadeIn .3s}

/* Risk indicator */
.risk-indicator{display:flex;align-items:center;gap:6px;padding:5px 10px;background:var(--s2);border-radius:8px;border:1px solid var(--brd)}
.ri-emoji{font-size:14px}
.ri-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}

/* Fee notice */
.fee-notice{display:flex;align-items:center;gap:6px;padding:6px 10px;background:rgba(255,215,0,.06);border:1px solid rgba(255,215,0,.2);border-radius:8px;font-size:11px;color:var(--y);font-weight:500;animation:fadeIn .3s}

.alloc-bar{display:flex;height:6px;border-radius:3px;overflow:hidden;background:var(--s3);gap:1px}
.alloc-seg{transition:width .3s;border-radius:2px}

.alloc-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
@media(min-width:480px){.alloc-grid{grid-template-columns:1fr 1fr 1fr}}

.asset-card{background:var(--s1);border:1px solid var(--brd);border-radius:var(--rad);padding:10px;display:flex;flex-direction:column;gap:6px;position:relative;transition:border-color .15s}
.asset-card.warn{border-color:var(--r);background:rgba(255,51,85,.04)}
.asset-top{display:flex;justify-content:space-between;align-items:center}
.asset-name{font-size:12px;font-weight:600;display:flex;align-items:center;gap:5px}
.asset-icon{font-size:16px}
.asset-pct{font-family:var(--font-d);font-weight:700;font-size:18px;font-variant-numeric:tabular-nums}
.asset-meta{font-size:10px;color:var(--txt3);line-height:1.3}
.asset-slider{width:100%;height:5px;border-radius:3px;background:var(--s3);outline:none}
.asset-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;border:2px solid var(--bg);box-shadow:0 1px 6px rgba(0,0,0,.5);margin-top:-1px}
.asset-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;border:2px solid var(--bg);box-shadow:0 1px 6px rgba(0,0,0,.5)}

/* Color coding */
.c-eq{color:#4a9ef0}.bg-eq{background:#4a9ef0}
.c-bond{color:#c070ff}.bg-bond{background:#c070ff}
.c-cash{color:#8888a0}.bg-cash{background:#8888a0}
.c-fd{color:#00ddff}.bg-fd{background:#00ddff}
.c-crypto{color:#ff8844}.bg-crypto{background:#ff8844}
.c-gamble{color:#ff3355}.bg-gamble{background:#ff3355}

.asset-slider.eq::-webkit-slider-thumb{background:#4a9ef0}
.asset-slider.bond::-webkit-slider-thumb{background:#c070ff}
.asset-slider.cash::-webkit-slider-thumb{background:#8888a0}
.asset-slider.fd::-webkit-slider-thumb{background:#00ddff}
.asset-slider.crypto::-webkit-slider-thumb{background:#ff8844}
.asset-slider.gamble::-webkit-slider-thumb{background:#ff3355}

/* News carousel (scrolling headlines feed) */
.news-carousel{overflow:hidden;border-radius:var(--rad);background:var(--s1);border:1px solid var(--brd);height:110px;position:relative}
.news-carousel::before,.news-carousel::after{content:'';position:absolute;left:0;right:0;height:20px;z-index:1;pointer-events:none}
.news-carousel::before{top:0;background:linear-gradient(to bottom,var(--s1),transparent)}
.news-carousel::after{bottom:0;background:linear-gradient(to top,var(--s1),transparent)}
.news-carousel-track{display:flex;flex-direction:column;gap:0;animation:newsScroll 35s linear infinite}
.news-carousel-item{padding:5px 10px;font-size:10px;font-weight:500;display:flex;align-items:center;gap:6px;white-space:nowrap;border-bottom:1px solid rgba(34,34,51,.3)}
.news-carousel-item .news-dot{font-size:6px}
.news-carousel-item.pos{color:var(--g)}
.news-carousel-item.pos .news-dot{color:var(--g)}
.news-carousel-item.neg{color:var(--r)}
.news-carousel-item.neg .news-dot{color:var(--r)}
.news-carousel-item.neu{color:var(--y)}
.news-carousel-item.neu .news-dot{color:var(--y)}
@keyframes newsScroll{0%{transform:translateY(0)}100%{transform:translateY(-33.33%)}}

/* Event flash */
.event-flash{background:var(--s1);border:1px solid var(--brd);border-radius:var(--rad);padding:12px;display:flex;gap:10px;align-items:flex-start;animation:flashIn .3s ease}
@keyframes flashIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
.event-flash .ef-icon{font-size:28px;flex-shrink:0}
.event-flash .ef-body{flex:1}
.event-flash .ef-title{font-weight:700;font-size:13px;color:var(--txt)}
.event-flash .ef-desc{font-size:11px;color:var(--txt2);line-height:1.4;margin-top:2px}
.event-flash .ef-impact{font-size:11px;font-weight:600;margin-top:4px}
.event-flash .ef-impact.pos{color:var(--g)}
.event-flash .ef-impact.neg{color:var(--r)}

/* Fee deducted notice on year-end */
.fee-deducted{font-size:11px;color:var(--y);background:rgba(255,215,0,.06);border:1px solid rgba(255,215,0,.15);border-radius:8px;padding:6px 10px;text-align:center;font-weight:500}

/* Decision modal */
.decision-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:100;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .2s}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.decision-card{background:var(--s1);border:1.5px solid var(--g);border-radius:var(--rad2);padding:24px;max-width:360px;width:100%;display:flex;flex-direction:column;gap:12px;text-align:center;animation:popIn .3s cubic-bezier(.16,1,.3,1)}
@keyframes popIn{from{opacity:0;transform:scale(.85) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}
.decision-emoji{font-size:40px}
.decision-title{font-family:var(--font-d);font-weight:700;font-size:18px;color:var(--txt)}
.decision-desc{font-size:13px;color:var(--txt2);line-height:1.5}
.decision-risk{font-size:11px;font-weight:600;padding:3px 10px;border-radius:6px;display:inline-block;margin:0 auto}
.decision-risk.low{background:rgba(0,255,136,.1);color:var(--g)}
.decision-risk.med{background:rgba(255,215,0,.1);color:var(--y)}
.decision-risk.high{background:rgba(255,136,68,.1);color:var(--orange)}
.decision-risk.extreme{background:rgba(255,51,85,.1);color:var(--r)}
.decision-btns{display:flex;gap:10px;margin-top:4px}
.decision-btn{flex:1;padding:12px;border-radius:10px;font-weight:700;font-size:13px;border:1.5px solid;transition:all .15s}
.decision-btn.yes{border-color:var(--g);color:var(--g);background:rgba(0,255,136,.06)}
.decision-btn.yes:hover{background:rgba(0,255,136,.15)}
.decision-btn.no{border-color:var(--r);color:var(--r);background:rgba(255,51,85,.06)}
.decision-btn.no:hover{background:rgba(255,51,85,.15)}

/* Footer action */
.game-footer{padding:10px 16px;border-top:1px solid var(--brd);background:var(--s1);flex-shrink:0}
.btn-advance{width:100%;padding:14px;border-radius:12px;background:var(--g);color:#08080c;font-family:var(--font-d);font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.04em;border:none;transition:all .15s}
.btn-advance:hover{background:var(--g2);transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,255,136,.25)}
.btn-advance:disabled{opacity:.25;cursor:not-allowed;transform:none;box-shadow:none;background:var(--txt3);color:var(--s1)}

/* ===== YEAR-END RESULTS ===== */
.yearend-screen{background:var(--bg)}
.ye-header{text-align:center;padding:20px 16px 8px}
.ye-title{font-family:var(--font-d);font-weight:800;font-size:20px;color:var(--txt)}
.ye-sub{font-size:12px;color:var(--txt2);margin-top:4px}
.ye-body{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:12px}
.ye-body::-webkit-scrollbar{width:0}

/* Performance table */
.perf-table{width:100%;border-collapse:collapse;background:var(--s1);border-radius:var(--rad);overflow:hidden;border:1px solid var(--brd)}
.perf-table th{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--txt3);padding:8px 10px;text-align:left;background:var(--s2);border-bottom:1px solid var(--brd)}
.perf-table td{padding:8px 10px;font-size:12px;font-weight:500;border-bottom:1px solid rgba(34,34,51,.5);font-variant-numeric:tabular-nums}
.perf-table tr:last-child td{border-bottom:none}
.perf-table .pos{color:var(--g)}
.perf-table .neg{color:var(--r)}
.perf-table .asset-cell{display:flex;align-items:center;gap:6px}
.perf-table .dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.perf-table .yr-note{font-size:10px;color:var(--txt3);font-weight:400;max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* NW display */
.ye-nw{text-align:center;padding:12px;background:var(--s1);border:1px solid var(--brd);border-radius:var(--rad2)}
.ye-nw-label{font-size:10px;color:var(--txt3);text-transform:uppercase;letter-spacing:.08em}
.ye-nw-val{font-family:var(--font-d);font-weight:800;font-size:28px;color:var(--g);font-variant-numeric:tabular-nums}
.ye-nw-change{font-size:13px;font-weight:600;margin-top:2px;font-variant-numeric:tabular-nums}

.ye-footer{padding:10px 16px;border-top:1px solid var(--brd);background:var(--s1);flex-shrink:0}

/* ===== FINAL RESULTS ===== */
.results-screen{background:var(--bg)}
.res-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:14px}
.res-body::-webkit-scrollbar{width:0}
.res-header{text-align:center;padding-top:16px}
.res-title{font-family:var(--font-d);font-weight:800;font-size:22px}
.res-sub{font-size:12px;color:var(--txt2);margin-top:4px}

/* Buy & Hold comparison card */
.bnh-card{display:flex;gap:12px;align-items:flex-start;padding:14px;border-radius:var(--rad2);border:1.5px solid}
.bnh-card.beat{border-color:var(--g);background:rgba(0,255,136,.06)}
.bnh-card.lost{border-color:var(--r);background:rgba(255,51,85,.06)}
.bnh-icon{font-size:28px;flex-shrink:0}
.bnh-title{font-family:var(--font-d);font-weight:700;font-size:14px}
.bnh-card.beat .bnh-title{color:var(--g)}
.bnh-card.lost .bnh-title{color:var(--r)}
.bnh-detail{font-size:11px;color:var(--txt2);line-height:1.5;margin-top:4px}

/* Rank badge */
.rank-card{display:flex;align-items:center;gap:14px;padding:16px;background:var(--s1);border:1.5px solid var(--y);border-radius:var(--rad2);text-align:left}
.rank-emoji{font-size:40px}
.rank-name{font-family:var(--font-d);font-weight:700;font-size:18px;color:var(--y)}
.rank-desc{font-size:12px;color:var(--txt2)}

/* Stats */
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.stat-card{background:var(--s1);border:1px solid var(--brd);border-radius:var(--rad);padding:12px;text-align:center}
.stat-label{font-size:10px;color:var(--txt3);text-transform:uppercase;letter-spacing:.06em}
.stat-val{font-family:var(--font-d);font-weight:700;font-size:18px;margin-top:4px;font-variant-numeric:tabular-nums}

/* Sharpe explainer */
.sharpe-box{background:var(--s1);border:1px solid var(--brd);border-radius:var(--rad2);padding:14px;display:flex;flex-direction:column;gap:6px}
.sharpe-box .sb-title{font-weight:700;font-size:13px;display:flex;align-items:center;gap:6px}
.sharpe-box .sb-val{font-family:var(--font-d);font-weight:700;font-size:24px;text-align:center;margin:4px 0}
.sharpe-box .sb-explain{font-size:11px;color:var(--txt2);line-height:1.5}
.sharpe-box .sb-meter{height:8px;border-radius:4px;background:var(--s3);overflow:hidden;margin-top:4px}
.sharpe-box .sb-fill{height:100%;border-radius:4px;transition:width .5s}

/* Benchmark comparison */
.bench-card{background:var(--s1);border:1px solid var(--brd);border-radius:var(--rad2);padding:14px;display:flex;flex-direction:column;gap:8px}
.bench-title{font-weight:700;font-size:13px;display:flex;align-items:center;gap:6px}
.bench-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid rgba(34,34,51,.4);font-size:12px}
.bench-row:last-child{border:none}
.bench-label{color:var(--txt2)}
.bench-val{font-weight:700;font-variant-numeric:tabular-nums}

/* Leaderboard */
.lb-card{background:var(--s1);border:1px solid var(--brd);border-radius:var(--rad2);padding:14px;display:flex;flex-direction:column;gap:6px}
.lb-title{font-weight:700;font-size:13px;display:flex;align-items:center;gap:6px;margin-bottom:4px}
.lb-row{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;font-size:12px}
.lb-row.you{background:rgba(0,255,136,.08);border:1px solid rgba(0,255,136,.2)}
.lb-rank{font-family:var(--font-d);font-weight:700;font-size:14px;min-width:24px;text-align:center}
.lb-name{flex:1;font-weight:500}
.lb-score{font-family:var(--font-d);font-weight:700;font-variant-numeric:tabular-nums}

/* Chart */
.chart-card{background:var(--s1);border:1px solid var(--brd);border-radius:var(--rad2);padding:14px}
.chart-card canvas{width:100%!important;height:200px!important}

/* Newsletter */
.newsletter-card{background:linear-gradient(135deg,rgba(0,255,136,.08),rgba(0,221,255,.06));border:1.5px solid var(--g);border-radius:var(--rad2);padding:16px;text-align:center;display:flex;flex-direction:column;gap:8px}
.nl-title{font-family:var(--font-d);font-weight:700;font-size:15px;color:var(--g)}
.nl-desc{font-size:12px;color:var(--txt2)}
.nl-btn{display:inline-block;padding:10px 24px;border-radius:10px;background:var(--g);color:#08080c;font-weight:700;font-size:13px;text-decoration:none;transition:all .15s;align-self:center}
.nl-btn:hover{background:var(--g2);transform:translateY(-1px)}

/* Play again blue button (replaces share) */
.btn-replay-blue{width:100%;padding:14px;border-radius:12px;border:1.5px solid var(--b);color:var(--b);background:rgba(74,158,240,.06);font-family:var(--font-d);font-weight:700;font-size:14px;text-transform:uppercase;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-replay-blue:hover{background:rgba(74,158,240,.12);transform:translateY(-1px)}

.pplx-foot{text-align:center;padding:8px;font-size:10px}
.pplx-foot a{color:var(--txt3);text-decoration:none}
.pplx-foot a:hover{text-decoration:underline}

/* ===== ANIMATIONS ===== */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-4px)}40%{transform:translateX(4px)}60%{transform:translateX(-2px)}80%{transform:translateX(2px)}}
.shake{animation:shake .4s ease}
.pulse{animation:pulse 1s ease infinite}

/* ===== RESPONSIVE ===== */
@media(min-width:640px){
  .game-body,.ye-body,.res-body{max-width:520px;margin:0 auto;width:100%}
  .title-content{max-width:440px}
}
