:root{font-family:Inter,Segoe UI,-apple-system,BlinkMacSystemFont,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.4;font-weight:400;--viewport-height: 100dvh;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px);--screen-gutter: clamp(8px, 2vw, 20px);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}*,*:before,*:after{box-sizing:border-box}html,body,#root{width:100%;height:100%;min-height:100%}html,body{margin:0;padding:0;min-width:320px;overflow:hidden}body{background:linear-gradient(135deg,#0f5a2a,#f4b942);color:#1f2937}img{max-width:100%;display:block}button{font-family:inherit;font-size:inherit}.modal-close-x{position:absolute;top:8px;right:8px;z-index:3;width:24px;height:24px;padding:0;border:none;border-radius:4px;background:url(/img/close-x.png) no-repeat center/contain;cursor:pointer;font-size:0;opacity:.9}.achievements-panel{background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:12px;padding:14px;box-shadow:0 4px 10px #00000024}.achievements-panel .achievements-header{margin-bottom:10px}.achievements-panel .achievements-header h3{margin:0;color:#78350f;font-size:1rem}.achievements-panel .achievements-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px}.achievements-panel .achievement-item{background:#fffffff0;border-radius:8px;padding:10px;display:flex;gap:8px}.achievements-panel .achievement-badge{font-size:1.5rem;line-height:1}.achievements-panel .achievement-content{min-width:0}.achievements-panel .achievement-name{margin:0 0 3px;color:#78350f;font-size:.84rem;font-weight:700}.achievements-panel .achievement-desc{margin:0 0 4px;color:#92400e;font-size:.74rem;line-height:1.3}.achievements-panel .achievement-unlocks{margin:0;color:#b91c1c;font-size:.7rem;font-weight:700}@media(max-width:560px){.achievements-panel .achievements-list{grid-template-columns:1fr}}@font-face{font-family:Pacifico;src:url(/PacificoRegular.ttf) format("truetype")}.app-shell{width:100%;min-height:100dvh;max-height:100dvh;display:flex;flex-direction:column;overflow:hidden}.app-main,.app{width:100%;flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.app-shell.game-route .app-main{width:min(100%,1000px);margin:0 auto;padding-inline:clamp(8px,1.4vw,14px);padding-bottom:max(var(--safe-bottom),6px)}body{background:linear-gradient(135deg,#0f5a2a,#f4b942)}body.game-page{background:linear-gradient(135deg,#9ca3af,#cbd5e1)}.screen{flex:1;min-height:0;width:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;padding-top:max(var(--safe-top),clamp(8px,1.6vh,14px));padding-right:calc(var(--screen-gutter) + var(--safe-right));padding-bottom:max(var(--safe-bottom),clamp(8px,1.6vh,14px));padding-left:calc(var(--screen-gutter) + var(--safe-left))}.screen-content{width:100%;max-width:580px;max-height:100%;background:#fff;border-radius:18px;box-shadow:0 18px 48px #00000038;padding:clamp(16px,2.8vh,30px) clamp(14px,3.4vw,28px);text-align:center;overflow:auto;display:flex;flex-direction:column;gap:clamp(10px,1.6vh,18px)}.screen-logo{width:clamp(136px,42vw,240px);height:auto;margin:0 auto}.main-title{margin:0;font-size:clamp(1.75rem,4.8vw,2.7rem);font-weight:700;line-height:1.1;color:#0f5a2a;font-family:Pacifico,cursive;font-style:italic}.tagline{margin:0;font-size:clamp(.92rem,2.2vw,1.12rem);line-height:1.4;color:#5b6472}.opening-content-wrapper{display:grid;grid-template-columns:1fr;align-items:center;gap:clamp(10px,1.6vh,18px)}.opening-description,.rules-list,.tips-list{text-align:left;color:#4b5563;line-height:1.45;font-size:clamp(.88rem,2.1vw,1rem);display:flex;flex-direction:column;gap:clamp(8px,1.2vh,12px)}.opening-description p,.rules-list p,.tips-list p{margin:0}.opening-content-wrapper .opening-description p{color:#0f5a2a;font-weight:700}.rules-list p,.tips-list p{padding-left:1rem;position:relative}.rules-list p:before,.tips-list p:before{content:"•";position:absolute;left:0;color:#0f5a2a;font-weight:700}.jay-intro-image{width:min(100%,220px);max-height:min(24vh,210px);margin:0 auto;object-fit:contain}.button-group{display:flex;flex-direction:column;gap:10px;width:100%}.start-button,.primary-button,.secondary-button{width:100%;border-radius:10px;border:2px solid transparent;padding:clamp(10px,1.9vh,14px) clamp(14px,3vw,26px);font-size:clamp(.92rem,2.1vw,1.04rem);font-weight:700;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease}.start-button,.primary-button{background:linear-gradient(135deg,#0f5a2a,#16a34a);color:#fff}.secondary-button{background:#fff;color:#0f5a2a;border-color:#0f5a2a}.start-button:hover,.primary-button:hover,.secondary-button:hover{transform:translateY(-1px)}.start-button:active,.primary-button:active,.secondary-button:active{transform:translateY(0)}.mode-selection-screen .screen-content{max-width:640px}.mode-subtitle{margin:0;font-size:clamp(.95rem,2.3vw,1.1rem);color:#5b6472;font-weight:600}.mode-selection-buttons{display:grid;grid-template-columns:1fr;gap:clamp(10px,1.8vh,18px)}.mode-button{border:none;border-radius:12px;padding:clamp(14px,2.2vh,22px) clamp(14px,3vw,20px);color:#fff;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:8px;box-shadow:0 4px 14px #0f5a2a3d;transition:transform .2s ease,box-shadow .2s ease}.mode-button:hover{transform:translateY(-1px)}.mode-button:active{transform:translateY(0)}.mode-name{font-size:clamp(1.05rem,2.9vw,1.45rem);font-weight:700;font-family:Georgia,serif}.mode-description{font-size:clamp(.84rem,1.9vw,.98rem);line-height:1.4;opacity:.95}.sequential-mode{background:linear-gradient(135deg,#0f5a2a,#16a34a)}.chaotic-mode{background:linear-gradient(135deg,#f4b942,#f59e0b)}.progress-indicator{margin-top:auto;display:flex;flex-direction:column;align-items:center;gap:8px}.progress-text{font-size:.78rem;color:#8a94a5;letter-spacing:.04em;font-weight:600}.progress-dots{display:flex;align-items:center;gap:8px}.dot{width:8px;height:8px;border-radius:50%;background-color:#f4b942}.dot.active{background-color:#0f5a2a}.legal-disclaimer{margin:0;font-size:clamp(.68rem,1.5vw,.78rem);color:#6b7280;line-height:1.35;text-align:center}@media(min-width:620px){.button-group{flex-direction:row}.opening-content-wrapper{grid-template-columns:minmax(0,1fr) minmax(170px,220px);align-items:center}.mode-selection-buttons{grid-template-columns:1fr 1fr}}@media(max-height:820px){.screen-content{gap:clamp(8px,1.2vh,14px);padding:clamp(14px,2vh,24px) clamp(12px,2.8vw,22px)}.main-title{font-size:clamp(1.55rem,4.1vw,2.2rem)}.tagline{font-size:clamp(.88rem,1.9vw,1rem)}.jay-intro-image{max-height:min(19vh,170px)}.mode-button{padding:clamp(12px,1.8vh,18px) clamp(12px,2.4vw,16px)}}@media(max-height:700px){.screen{padding-top:max(var(--safe-top),6px);padding-bottom:max(var(--safe-bottom),6px)}.screen-content{border-radius:14px;padding:12px;gap:8px}.screen-logo{width:clamp(112px,34vw,180px)}.main-title{font-size:clamp(1.4rem,3.5vw,1.95rem)}.opening-description,.rules-list,.tips-list{font-size:.84rem;gap:6px}.start-button,.primary-button,.secondary-button{padding:9px 12px;font-size:.88rem}.progress-indicator{gap:6px}.dot{width:7px;height:7px}}.tax-toggle{display:flex;align-items:center}.tax-toggle label{display:inline-flex;align-items:center;gap:6px;cursor:pointer;white-space:nowrap;font-size:clamp(.72rem,1.45vw,.84rem);color:#334155;font-weight:600}.tax-toggle input[type=checkbox]{width:16px;height:16px;accent-color:#4f46e5}.stock-card{width:100%;min-height:clamp(54px,8.2vh,68px);border-radius:8px;padding:6px 8px;border:1px solid #4f46e5;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;cursor:pointer;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;position:relative;overflow:hidden;transition:transform .15s ease,box-shadow .15s ease}.stock-card:hover:not(.disabled){transform:translateY(-1px);box-shadow:0 6px 12px #4f46e53d}.stock-card.disabled{cursor:not-allowed}.stock-card.disabled-locked{background:linear-gradient(135deg,#9ca3af,#6b7280);border-color:#6b7280}.stock-card.disabled-future-ipo{background:linear-gradient(135deg,#fde68a,#fcd34d);border-color:#f59e0b}.stock-card.disabled-future-ipo .symbol,.stock-card.disabled-future-ipo .stock-name{color:#1f2937}.stock-card .symbol{font-size:clamp(.78rem,1.6vw,.96rem);font-weight:700;line-height:1.1}.stock-card .stock-name{margin:0;font-size:clamp(.55rem,1.1vw,.7rem);line-height:1.2;opacity:.92;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.lock-badge{position:absolute;top:3px;right:3px;padding:1px 4px;border-radius:4px;background:#facc15;color:#1f2937;font-size:.56rem;font-weight:700;line-height:1}@media(max-width:560px){.stock-card{min-height:52px;padding:5px 7px}.tax-toggle label{font-size:.74rem}}@media(max-height:700px){.stock-card{min-height:46px}.stock-card .symbol{font-size:.72rem}.stock-card .stock-name{font-size:.52rem}}.modal-overlay{position:fixed;inset:0;z-index:1900;display:flex;align-items:center;justify-content:center;padding:max(var(--safe-top),10px) max(var(--safe-right),10px) max(var(--safe-bottom),10px) max(var(--safe-left),10px);background:#0000008c}.modal-content{width:min(96vw,520px);max-height:calc(100dvh - max(var(--safe-top),10px) - max(var(--safe-bottom),10px) - 8px);background:#fff;border-radius:12px;box-shadow:0 20px 50px #00000052;overflow:hidden;position:relative;animation:modalSlideIn .22s ease}.modal-content.trade-modal{display:flex;flex-direction:column;overflow:auto}.modal-content.trade-modal.flash{animation:modalFlash .5s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes modalFlash{0%,to{background:#fff}50%{background:#ecfdf5}}.portfolio-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:10px;background:#f8fafc;border-bottom:1px solid #e5e7eb;flex-shrink:0}.stat-box{border-radius:8px;padding:8px;text-align:center;background:#fff;border:1px solid #e5e7eb}.stat-label{margin-bottom:2px;font-size:.68rem;color:#64748b;text-transform:uppercase;letter-spacing:.04em;font-weight:700}.stat-value{font-size:clamp(.96rem,2.2vw,1.15rem);color:#4f46e5;font-weight:700}.stock-tile{padding:10px;text-align:center;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e5e7eb;flex-shrink:0}.stock-symbol{margin:0;font-size:clamp(1.25rem,3.5vw,1.55rem);font-weight:700;line-height:1.1}.stock-tile .stock-name{margin:2px 0;font-size:.74rem;opacity:.92;display:block;overflow:visible;text-overflow:clip;-webkit-line-clamp:unset;-webkit-box-orient:initial}.stock-price{font-size:.86rem;font-weight:700}.price-chart-container{padding:10px;border-bottom:1px solid #e5e7eb;background:#f8fafc;flex-shrink:0}.chart-title{margin-bottom:6px;color:#64748b;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;font-weight:700}.price-chart{width:100%;min-height:0;height:clamp(92px,16vh,140px);border:1px solid #d6dae3;border-radius:8px;padding:6px;display:flex;align-items:flex-end;justify-content:space-between;gap:2px;background:#fff;overflow-x:auto}.chart-bar-wrapper{flex:1 1 0;min-width:4px;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:2px}.chart-bar{width:100%;min-height:2px;border-radius:3px;background:linear-gradient(to top,#4f46e5,#7c3aed)}.chart-bar.positive{background:linear-gradient(to top,#059669,#10b981)}.chart-bar.negative{background:linear-gradient(to top,#d97706,#f59e0b)}.chart-year{font-size:.5rem;line-height:1;color:#64748b;white-space:nowrap;writing-mode:vertical-rl;text-orientation:mixed}.trading-buttons-grid{padding:10px;display:grid;grid-template-columns:1fr 1fr;gap:8px;background:#fff;flex-shrink:0}.button-column{display:flex;flex-direction:column;gap:6px}.trade-button{border:none;border-radius:8px;padding:9px 6px;font-size:.74rem;line-height:1.2;font-weight:700;letter-spacing:.03em;cursor:pointer;color:#fff}.buy-column .trade-button{background:linear-gradient(135deg,#3b82f6,#2563eb)}.sell-column .trade-button{background:linear-gradient(135deg,#ef4444,#dc2626)}.trade-button:disabled{opacity:.45;cursor:not-allowed}.modal-footer-trade{padding:10px;border-top:1px solid #e5e7eb;background:#fff;flex-shrink:0}.return-home-button{width:100%;border:none;border-radius:8px;padding:10px 12px;font-size:.86rem;font-weight:700;letter-spacing:.03em;color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed);cursor:pointer}.modal-close-x{position:absolute;top:8px;right:8px;z-index:3;width:24px;height:24px;padding:0;border:none;border-radius:4px;background:url(/img/close-x.png) no-repeat center/contain;cursor:pointer;font-size:0;opacity:.9}.modal-close-x:hover{opacity:.7}.close-button{display:none}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;font-size:1.2rem;color:#1f2937}.modal-body{padding:18px}.modal-footer{display:flex;gap:8px;padding:0 18px 18px}.cancel-button{flex:1;border:none;border-radius:8px;padding:10px 12px;font-size:.86rem;font-weight:600;background:#eef2ff;color:#3730a3}@media(max-height:740px){.modal-overlay{padding:max(var(--safe-top),6px) max(var(--safe-right),6px) max(var(--safe-bottom),6px) max(var(--safe-left),6px)}.modal-content{max-height:calc(100dvh - max(var(--safe-top),6px) - max(var(--safe-bottom),6px))}.portfolio-stats,.stock-tile,.price-chart-container,.trading-buttons-grid,.modal-footer-trade{padding:8px}.price-chart{height:clamp(80px,13vh,108px)}.trade-button{padding:8px 6px;font-size:.68rem}}.achievement-toaster{position:fixed;top:calc(max(var(--safe-top),10px) + 2px);left:50%;transform:translate(-50%);z-index:2300;width:min(92vw,340px);padding:12px 14px;border-radius:10px;color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed);box-shadow:0 12px 30px #4f46e573;animation:achievementIn .25s ease,achievementOut .25s ease 4.7s forwards}@keyframes achievementIn{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes achievementOut{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-8px)}}.toaster-content{display:flex;align-items:center;gap:10px}.toaster-emoji{font-size:1.5rem;line-height:1}.toaster-text{display:flex;flex-direction:column;gap:1px}.toaster-name{font-size:.92rem;font-weight:700}.toaster-desc{font-size:.78rem;opacity:.95}.achievements-modal{width:min(94vw,500px);max-height:calc(100dvh - max(var(--safe-top),12px) - max(var(--safe-bottom),12px));background:#fff;border-radius:12px;box-shadow:0 20px 50px #00000052;overflow:hidden;display:flex;flex-direction:column;position:relative;animation:achievementsModalIn .2s ease}@keyframes achievementsModalIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.achievements-modal .modal-header{padding:14px 16px;border-bottom:1px solid #e5e7eb;flex-shrink:0}.achievements-modal .modal-header h2{margin:0;font-size:clamp(1rem,2.6vw,1.3rem)}.achievements-modal .achievements-list{padding:10px;overflow:auto;display:flex;flex-direction:column;gap:8px}.achievements-modal .achievement-item{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;border-radius:8px;border:1px solid #e5e7eb;background:#f8fafc;padding:10px}.achievements-modal .achievement-item.unlocked{background:linear-gradient(135deg,#dcfce7,#f0fdf4);border-color:#22c55e}.achievements-modal .achievement-item.locked{opacity:.72}.achievements-modal .achievement-emoji{font-size:1.45rem}.achievements-modal .achievement-info{min-width:0;display:flex;flex-direction:column;gap:2px}.achievements-modal .achievement-name{margin:0;color:#1f2937;font-size:.9rem;font-weight:700}.achievements-modal .achievement-desc{margin:0;color:#64748b;font-size:.78rem;line-height:1.25}.achievements-modal .achievement-status{font-size:1rem;color:#4f46e5}@media(max-width:560px){.achievements-modal{width:98vw}.achievements-modal .modal-header{padding:12px 14px}.achievements-modal .achievements-list{padding:8px;gap:6px}.achievements-modal .achievement-item{padding:8px;gap:8px}}.investments-modal{width:min(96vw,560px);max-height:calc(100dvh - max(var(--safe-top),12px) - max(var(--safe-bottom),12px));background:#fff;border-radius:12px;padding:clamp(14px,2.2vh,22px);box-shadow:0 20px 50px #0000004d;overflow:auto;position:relative;animation:investmentsModalIn .2s ease}@keyframes investmentsModalIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.investments-modal h2{margin:0 22px 12px 0;font-size:clamp(1rem,2.8vw,1.35rem);line-height:1.2;color:#111827;text-align:center;font-family:Georgia,serif}.portfolio-summary{border:1px solid #e5e7eb;border-radius:8px;background:#f8fafc;padding:10px;margin-bottom:10px}.investments-modal .summary-stat{display:flex;justify-content:space-between;gap:10px;padding:5px 0;font-size:.88rem}.investments-modal .summary-label{color:#6b7280;font-weight:700}.investments-modal .summary-value{color:#1f2937;font-weight:700}.investments-modal .summary-value.warning{color:#b45309}.no-investments{margin:0;padding:12px;color:#6b7280;font-size:.9rem;text-align:center;border:1px dashed #cbd5e1;border-radius:8px}.investments-list{margin:10px 0;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.investments-header,.investment-row{display:grid;grid-template-columns:minmax(54px,.9fr) minmax(58px,.7fr) minmax(84px,1.2fr) minmax(88px,1.2fr);gap:8px;align-items:center;padding:8px 10px}.investments-header{background:#eef2ff;border-bottom:1px solid #dbe1f2;font-size:.72rem;font-weight:700;letter-spacing:.02em;color:#334155}.investment-row{border-bottom:1px solid #eef2f7}.investment-row:last-child{border-bottom:none}.investment-row.unavailable{background:#f8fafc;opacity:.65}.investments-modal .column{min-width:0;font-size:.8rem}.investments-modal .column.symbol{color:#4f46e5;font-weight:700}.investments-modal .column.quantity,.investments-modal .column.purchasePrice,.investments-modal .column.currentValue{text-align:right}.investments-modal .column.currentValue{color:#0f766e;font-weight:700}.investments-modal .status-indicator{margin-top:10px;border:1px solid #e5e7eb;border-radius:8px;padding:10px;background:#f8fafc}.investments-modal .status-list{display:flex;flex-direction:column;gap:2px}.investments-modal .status-item{display:grid;grid-template-columns:20px minmax(90px,1fr) minmax(110px,1fr);align-items:center;gap:8px;border-radius:6px;color:#6b7280;font-size:.78rem;padding:6px}.investments-modal .status-item.active{color:#111827;background:#fff;font-weight:700}.investments-modal .status-radio{color:#4f46e5;font-size:1rem;line-height:1}.investments-modal .status-name{font-weight:700}.investments-modal .status-range{text-align:right}.investments-close-button{width:100%;margin-top:12px;border:none;border-radius:8px;padding:10px 12px;font-size:.86rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed);cursor:pointer}@media(max-width:560px){.investments-modal{width:98vw;padding:12px}.investments-header,.investment-row{grid-template-columns:minmax(46px,.8fr) minmax(44px,.55fr) minmax(74px,1fr) minmax(76px,1fr);gap:6px;padding:7px}.investments-header{font-size:.64rem}.investments-modal .column{font-size:.72rem}.investments-modal .status-item{grid-template-columns:16px minmax(80px,1fr) minmax(82px,1fr);gap:6px;font-size:.7rem;padding:5px}}@media(max-height:700px){.investments-modal{padding:10px}.investments-modal h2{margin-bottom:8px;font-size:1rem}.investments-modal .portfolio-summary,.investments-modal .status-indicator{padding:8px}.investments-modal .summary-stat{font-size:.8rem}.investments-modal .column{font-size:.7rem}}.tips-modal-overlay{position:fixed;inset:0;z-index:2100;display:flex;align-items:center;justify-content:center;padding:max(var(--safe-top),10px) max(var(--safe-right),10px) max(var(--safe-bottom),10px) max(var(--safe-left),10px);background:#00000094}.tips-modal-content{width:min(96vw,520px);max-height:calc(100dvh - max(var(--safe-top),10px) - max(var(--safe-bottom),10px));border-radius:12px;background:#fff;box-shadow:0 20px 50px #00000052;padding:clamp(14px,2.2vh,24px);overflow:auto;position:relative;display:flex;flex-direction:column;gap:10px}.tips-modal-title{margin:0;padding:0 24px 8px 0;border-bottom:1px solid #e5e7eb;color:#1f2937;font-size:clamp(1.02rem,2.5vw,1.3rem);font-weight:700;text-align:left}.tips-modal-body{display:grid;grid-template-columns:minmax(120px,160px) minmax(0,1fr);align-items:center;gap:12px}.tips-modal-image{width:100%;max-height:min(30vh,220px);object-fit:contain;border-radius:8px}.tips-modal-text-section{min-width:0}.tips-modal-text{margin:0;color:#475569;font-family:Georgia,serif;font-style:italic;font-weight:700;line-height:1.35}.tips-text-large{font-size:clamp(1.02rem,2.4vw,1.2rem)}.tips-text-medium{font-size:clamp(.9rem,2vw,1.02rem)}.tips-text-small{font-size:clamp(.8rem,1.7vw,.92rem)}.tips-quote-attribution{display:inline-block;margin-top:8px;font-size:.9em}.tips-modal-footer{margin-top:auto;display:flex;align-items:center;justify-content:center;gap:10px}.tips-modal-button{border:none;border-radius:8px;padding:10px 14px;font-size:.86rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#4f46e5,#7c3aed);cursor:pointer}.tips-next-button{width:36px;height:36px;border-radius:8px;border:1px solid #0f5a2a;background:#fff;color:#0f5a2a;font-size:1rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}@media(max-width:560px){.tips-modal-content{width:98vw;padding:12px}.tips-modal-body{grid-template-columns:1fr;text-align:center}.tips-modal-image{margin:0 auto;max-width:140px;max-height:120px}}@media(max-height:700px){.tips-modal-content{padding:10px;gap:8px}.tips-modal-title{font-size:1rem;padding-bottom:6px}.tips-modal-image{max-height:100px}.tips-modal-button{padding:8px 12px;font-size:.8rem}.tips-next-button{width:32px;height:32px}}.tips-toggle-container{display:inline-flex;align-items:center;gap:6px;padding:0}.tips-toggle-label{font-size:clamp(.68rem,1.4vw,.8rem);font-weight:700;color:#334155;white-space:nowrap}.tips-toggle{position:relative;width:44px;height:24px;border:none;border-radius:999px;background:#cbd5e1;cursor:pointer;transition:background-color .2s ease;padding:0}.tips-toggle.enabled{background:#4f46e5}.toggle-slider{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 4px #00000040;transition:left .2s ease}.tips-toggle.enabled .toggle-slider{left:22px}.unavailable-stock-overlay{position:fixed;inset:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:max(var(--safe-top),10px) max(var(--safe-right),10px) max(var(--safe-bottom),10px) max(var(--safe-left),10px);background:#0000008c}.unavailable-stock-modal{width:min(92vw,420px);max-height:calc(100dvh - max(var(--safe-top),10px) - max(var(--safe-bottom),10px));overflow:auto;background:#fff;border-radius:12px;box-shadow:0 18px 44px #00000052;padding:clamp(14px,2vh,22px);text-align:center;position:relative}.unavailable-stock-modal h2{margin:0 22px 10px 0;color:#4f46e5;font-size:clamp(1rem,2.6vw,1.3rem)}.unavailable-stock-modal p{margin:0;color:#475569;font-size:clamp(.84rem,1.8vw,.95rem);line-height:1.45}.game-over-modal-overlay{position:fixed;inset:0;z-index:2050;display:flex;align-items:center;justify-content:center;padding:max(var(--safe-top),10px) max(var(--safe-right),10px) max(var(--safe-bottom),10px) max(var(--safe-left),10px);background:#000000ad}.game-over-modal{width:min(95vw,560px);max-height:calc(100dvh - max(var(--safe-top),10px) - max(var(--safe-bottom),10px));background:#fff;border-radius:14px;box-shadow:0 24px 54px #00000054;padding:clamp(14px,2.2vh,26px);position:relative;overflow:auto}.game-over-content{display:flex;flex-direction:column;gap:clamp(10px,1.7vh,16px)}.game-over-title{margin:0;font-size:clamp(1.28rem,4vw,2rem);line-height:1.15;font-weight:700}.game-over-modal--struggling .game-over-title{color:#b91c1c}.game-over-modal--goat .game-over-title{color:#0f766e}.game-over-modal--thriving .game-over-title,.game-over-modal--striving .game-over-title,.game-over-modal--surviving .game-over-title{color:#1d4ed8}.game-over-message{margin:0;color:#334155;font-size:clamp(.85rem,1.9vw,1rem);line-height:1.45}.game-over-portfolio-summary{border-radius:8px;border:1px solid #e5e7eb;background:#f8fafc;padding:10px}.game-over-modal .portfolio-summary-item{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:5px 0;font-size:.84rem}.game-over-modal .portfolio-summary-item.year-display{border-bottom:1px solid #d9dee9;margin-bottom:4px;font-weight:700;color:#4f46e5}.game-over-modal .portfolio-summary-item.total{border-top:1px solid #d9dee9;margin-top:4px;font-weight:700}.game-over-modal .summary-label{color:#6b7280;font-weight:700}.game-over-modal .summary-value{color:#1f2937;font-weight:700}.game-over-modal .summary-value.warning{color:#b45309}.game-over-image{width:min(100%,240px);max-height:min(26vh,220px);object-fit:contain;margin:0 auto}.game-over-button{border:none;border-radius:10px;padding:10px 14px;font-size:.9rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#0f5a2a,#16a34a);cursor:pointer}@media(max-height:700px){.game-over-modal{padding:12px}.game-over-content{gap:8px}.game-over-title{font-size:1.2rem}.game-over-message{font-size:.8rem}.portfolio-summary-item{font-size:.76rem}.game-over-image{max-height:120px}.game-over-button{padding:9px 12px;font-size:.8rem}}.dashboard{flex:1;min-height:0;width:100%;max-width:980px;margin:0 auto;padding:clamp(8px,1.5vh,14px);display:flex;flex-direction:column;gap:clamp(8px,1.3vh,14px);overflow:hidden;border-radius:16px;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:inset 0 0 0 1px #ffffff14}.dashboard-header{background:#fff;border-radius:10px;padding:clamp(8px,1.2vh,12px) clamp(10px,1.8vw,16px);box-shadow:0 2px 10px #0000001f;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;flex-shrink:0}.portfolio-info{flex:1;min-width:min(100%,420px);display:flex;flex-direction:column;gap:8px;font-size:.86rem}.portfolio-grid{border:1px solid #d9dce3;border-radius:8px;overflow:hidden}.grid-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr))}.header-row{background:#eef1f8;border-bottom:1px solid #d9dce3}.value-row{background:#fff}.grid-cell{min-width:0;padding:clamp(4px,.8vh,7px) 4px;border-right:1px solid #e5e7eb;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grid-cell:last-child{border-right:none}.header-cell{font-size:clamp(.6rem,1.3vw,.76rem);color:#475569;font-weight:700;white-space:normal;line-height:1.2}.value-cell{font-size:clamp(.72rem,1.4vw,.9rem);color:#4f46e5;font-weight:700}.value-cell.positive{color:#15803d}.value-cell.negative{color:#b91c1c}.value-cell.warning{color:#b45309}.portfolio-info-extra{display:flex;flex-wrap:wrap;gap:8px 14px}.stat{display:flex;flex-direction:column;gap:2px}.stat label{font-size:.63rem;color:#718096;text-transform:uppercase;letter-spacing:.04em;font-weight:700}.stat span{font-size:clamp(.8rem,1.8vw,.96rem);color:#4f46e5;font-weight:700}.stat.highlight span{color:#6d28d9}.header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.trophy-button,.investments-button{width:38px;height:38px;border:none;border-radius:8px;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #4c51bf47;display:inline-flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;transition:transform .15s ease}.trophy-button:hover,.investments-button:hover{transform:translateY(-1px)}.trophy-button:active,.investments-button:active{transform:translateY(0)}.headline-box{display:flex;align-items:center;justify-content:center;gap:clamp(8px,1.6vw,16px);flex-shrink:0;min-height:0}.newspaper-container{position:relative;width:100%;max-width:360px;min-width:200px;aspect-ratio:504 / 396;overflow:hidden;flex-shrink:1}.newspaper-img{width:100%;height:100%;object-fit:contain}.headline-content{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:24% 12% 10%}.headline-text{margin:0;color:#111827;font-size:clamp(.8rem,1.55vw,.96rem);line-height:1.22;font-weight:700;font-family:Georgia,serif;text-align:center;display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:4}.headline-refresh-btn{position:absolute;right:8%;bottom:8%;border:none;border-radius:6px;background:#ffffffe6;color:#334155;width:30px;height:30px;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s ease}.headline-refresh-btn:disabled{opacity:.4;cursor:not-allowed}.year-controls{width:clamp(88px,16vw,112px);display:flex;flex-direction:column;align-items:stretch;gap:8px;flex-shrink:0}.current-year-display{text-align:center}.current-year-value{display:block;font-family:Georgia,serif;font-size:clamp(1.2rem,2.6vw,1.9rem);color:#fbbf24;font-weight:700;line-height:1.1}.time-travel-button{border:none;border-radius:10px;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;font-size:clamp(.66rem,1.4vw,.78rem);font-weight:700;letter-spacing:.03em;text-transform:uppercase;padding:clamp(8px,1.6vh,12px) 6px;line-height:1.25;cursor:pointer;box-shadow:0 3px 10px #4f46e559}.time-travel-button:hover{transform:translateY(-1px)}.stocks-grid{flex:1;min-height:0;background:#fff;border-radius:10px;padding:clamp(8px,1.2vh,12px);box-shadow:0 2px 10px #0000001a;overflow:auto;display:grid;grid-template-columns:1fr;gap:10px}.stocks-section{display:flex;flex-direction:column;align-items:center;gap:8px}.section-title{margin:0;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:#334155;font-weight:700}.grid,.grid.premium-grid{width:100%;max-width:400px;margin:0 auto;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:clamp(6px,1.1vw,10px)}.notification-toaster{position:fixed;top:calc(max(var(--safe-top),12px) + 4px);right:calc(max(var(--safe-right),12px) + 2px);max-width:min(92vw,440px);border-radius:10px;padding:10px 12px;z-index:2200;display:flex;align-items:center;gap:10px;box-shadow:0 10px 22px #0000003d;animation:notificationSlideIn .24s ease}.notification-toaster.notification-warning{background:linear-gradient(135deg,#fde68a,#f59e0b);color:#78350f}.notification-toaster.notification-info{background:linear-gradient(135deg,#93c5fd,#3b82f6);color:#1e3a8a}.notification-toaster.notification-success{background:linear-gradient(135deg,#86efac,#22c55e);color:#14532d}.notification-content{flex:1;font-size:.9rem;line-height:1.3;font-weight:600}.notification-close{border:none;background:transparent;color:inherit;width:24px;height:24px;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;padding:0}@keyframes notificationSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media(min-width:880px){.grid,.grid.premium-grid{max-width:100%}}@media(max-width:860px){.dashboard{width:100%;border-radius:14px}.portfolio-info{width:100%;min-width:0;order:2}.header-actions{width:100%;justify-content:flex-end;order:1}.headline-box{gap:8px}.newspaper-container{max-width:320px}.year-controls{width:92px}}@media(max-width:560px){.dashboard{padding:8px;gap:8px;border-radius:12px}.dashboard-header{padding:8px}.header-cell{font-size:.56rem}.value-cell{font-size:.7rem}.headline-box{flex-direction:column;align-items:center}.newspaper-container{max-width:min(100%,300px);min-width:0}.headline-content{padding:23% 12% 12%}.headline-text{font-size:.8rem;-webkit-line-clamp:4}.year-controls{width:min(100%,220px);flex-direction:row;justify-content:center;align-items:center;gap:10px}.current-year-value{font-size:1.1rem}.time-travel-button{font-size:.62rem;padding:8px 12px}.grid,.grid.premium-grid{gap:6px}.notification-toaster{left:max(var(--safe-left),8px);right:max(var(--safe-right),8px);max-width:none}}@media(max-height:800px){.dashboard{padding:8px;gap:8px}.dashboard-header{padding:8px 10px}.headline-box{gap:8px}.newspaper-container{max-width:clamp(200px,40vw,320px)}.headline-text{-webkit-line-clamp:3}.stocks-grid{padding:8px;gap:8px}}@media(max-height:690px){.portfolio-info-extra{gap:6px 10px}.stat label{font-size:.58rem}.stat span{font-size:.76rem}.newspaper-container{max-width:250px}.year-controls{width:auto}.current-year-value{font-size:.9rem}.time-travel-button{padding:6px 4px;font-size:.56rem}.section-title{font-size:.72rem}}.game-menu{flex-shrink:0;width:100%;max-width:980px;margin:0 auto;padding:max(var(--safe-top),6px) clamp(8px,1.6vw,14px) 6px;display:flex;align-items:center;justify-content:space-between;gap:10px}.game-mode-display{font-size:clamp(.72rem,1.5vw,.88rem);font-weight:700;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.24)}.menu-buttons{display:flex;align-items:center;gap:8px}.menu-button{border-radius:8px;border:1px solid transparent;padding:clamp(7px,1.3vh,10px) clamp(10px,2vw,16px);font-size:clamp(.72rem,1.5vw,.86rem);font-weight:700;cursor:pointer;transition:transform .15s ease}.menu-button:hover{transform:translateY(-1px)}.menu-button:active{transform:translateY(0)}.menu-button.test-tips{background:#fffbeb;border-color:#facc15;color:#854d0e}.menu-button.new-game{background:#fff;border-color:#6366f1;color:#4f46e5}@media(max-width:640px){.game-menu{flex-wrap:wrap;justify-content:center;padding-top:max(var(--safe-top),4px)}.game-mode-display{width:100%;text-align:center}}.app-footer{flex-shrink:0;width:100%;padding:6px 14px max(var(--safe-bottom),8px);text-align:center;font-size:clamp(.7rem,1.4vw,.84rem);color:#334155;background:#ffffff61;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.app-footer p{margin:0;line-height:1.2}.app-footer a{color:#3730a3;font-weight:700}.app-footer a:hover{text-decoration:underline}
