@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;0,700;1,400&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:ital,wght@0,400;0,500;0,600;1,400&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0e1a;--bg-deep: #060910;--surface: #12182b;--surface-elevated: #1a2240;--surface-hover: #1e2a4a;--border: #1e2a4a;--border-light: #2a3a66;--text: #e8e4da;--text-muted: #7a8ba8;--text-dim: #3d4e6e;--gold: #c8a45e;--gold-bright: #e0be72;--gold-dim: #705a30;--gold-glow: rgba(200, 164, 94, .1);--turquoise: #4ac7b0;--turquoise-dim: #2a7868;--emerald: #4ecb8d;--red: #d4605a;--crimson: #b8443a;--warn: #e0a84c;--font-serif: "Cormorant Garamond", serif;--font-sans: "Inter", sans-serif;--font-mono: "JetBrains Mono", monospace}html,body{height:100%;background:var(--bg-deep);color:var(--text);font-family:var(--font-sans);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;opacity:.025;background-image:radial-gradient(circle at 25% 25%,var(--gold) .5px,transparent .5px),radial-gradient(circle at 75% 75%,var(--gold) .5px,transparent .5px),radial-gradient(circle at 50% 50%,var(--turquoise) .7px,transparent .7px);background-size:60px 60px,60px 60px,80px 80px}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;opacity:.015;background-image:repeating-linear-gradient(45deg,transparent,transparent 199px,var(--gold-dim) 199px,var(--gold-dim) 200px),repeating-linear-gradient(-45deg,transparent,transparent 199px,var(--gold-dim) 199px,var(--gold-dim) 200px)}#app{min-height:100vh;display:flex;flex-direction:column;position:relative;z-index:1}.screen{display:none;flex:1;flex-direction:column}.screen.active{display:flex;animation:screenIn .5s ease-out}@keyframes screenIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes spin{to{transform:rotate(360deg)}}.btn{padding:.85rem 1.5rem;border:none;font-family:var(--font-sans);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .25s ease;letter-spacing:.06em;border-radius:0;position:relative;overflow:hidden}.btn:disabled{opacity:.3;cursor:default}.btn-primary{background:linear-gradient(135deg,var(--gold-dim),var(--gold),var(--gold-bright));background-size:200% 200%;color:var(--bg-deep)}.btn-primary:hover:not(:disabled){background-position:100% 100%;box-shadow:0 4px 24px #c8a45e33}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-secondary{background:transparent;color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface);border-color:var(--gold-dim);color:var(--gold)}.btn-sm{padding:.25rem .5rem;font-size:.55rem;letter-spacing:.06em;font-family:var(--font-sans);font-weight:600;text-transform:uppercase;background:transparent;border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:all .2s ease}.btn-sm:hover{border-color:var(--gold-dim);color:var(--gold);background:#c8a45e0f}input[type=text],select{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:.85rem 1.1rem;font-family:var(--font-sans);font-size:.95rem;outline:none;transition:all .25s ease;border-radius:0}input[type=text]:focus,select:focus{border-color:var(--gold);box-shadow:0 0 0 3px #c8a45e14,inset 0 0 20px #c8a45e05}input[type=text]::placeholder{color:var(--text-dim)}input:disabled,select:disabled{opacity:.5;cursor:default}.hidden{display:none!important}.lobby{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.lobby-card{width:100%;max-width:420px;padding:2.5rem 2rem;background:var(--surface);border:1px solid var(--border);position:relative;animation:screenIn .6s ease-out}.lobby-card:before{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border:1px solid rgba(200,164,94,.08);pointer-events:none}.lobby-card:after{content:"";position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent)}.lobby-emblem{width:48px;height:48px;margin:0 auto 1.25rem;position:relative;animation:spin 30s linear infinite}.lobby-emblem:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gold-dim);clip-path:polygon(50% 0%,65% 25%,100% 25%,75% 50%,100% 75%,65% 75%,50% 100%,35% 75%,0% 75%,25% 50%,0% 25%,35% 25%)}.lobby-emblem:after{content:"";position:absolute;top:6px;right:6px;bottom:6px;left:6px;background:var(--gold);clip-path:polygon(50% 0%,65% 25%,100% 25%,75% 50%,100% 75%,65% 75%,50% 100%,35% 75%,0% 75%,25% 50%,0% 25%,35% 25%);opacity:.6}.lobby-header{text-align:center;margin-bottom:2rem}.lobby-header h1{font-family:var(--font-serif);font-size:clamp(2.8rem,6vw,4.2rem);font-weight:700;line-height:1.05;background:linear-gradient(135deg,var(--gold-bright) 0%,var(--gold) 40%,var(--gold-dim) 70%,var(--gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.lobby-subtitle{color:var(--turquoise);margin-top:.75rem;font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;font-family:var(--font-sans);font-weight:500}.lobby-divider{display:flex;align-items:center;gap:.75rem;margin:1.5rem 0;color:var(--text-dim);font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;font-family:var(--font-serif)}.lobby-divider:before,.lobby-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent)}.lobby-divider span{display:flex;align-items:center;gap:.35rem}.lobby-divider span:before,.lobby-divider span:after{content:"◆";font-size:.4rem;color:var(--gold-dim)}.lobby-form{display:flex;flex-direction:column;gap:1rem}.field{display:flex;flex-direction:column;gap:.4rem}.field label{font-family:var(--font-sans);font-size:.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;font-weight:600}.lobby-footer{margin-top:1.5rem;text-align:center;font-size:.6rem;color:var(--text-dim);font-family:var(--font-serif);letter-spacing:.08em}.lobby-status{text-align:center;font-size:.8rem;padding:.5rem 1rem;color:var(--text-muted)}.lobby-status.error{color:var(--red)}.game-layout{flex:1;display:flex;flex-direction:column;min-height:0;position:relative}.game-main{flex:1;display:grid;grid-template-columns:1fr 320px;min-height:0;overflow:hidden}.game-header{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1.25rem;background:#0a0e1ad9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);flex-shrink:0;gap:1rem;position:relative;z-index:10}.game-header:after{content:"";position:absolute;bottom:-1px;left:8%;right:8%;height:1px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);opacity:.4}.gh-player,.gh-opponent{display:flex;align-items:center;gap:.6rem}.gh-player-name{font-family:var(--font-serif);font-weight:600;font-size:.9rem;color:var(--text)}.gh-player-badge{font-size:.5rem;letter-spacing:.1em;text-transform:uppercase;padding:.15rem .4rem;background:var(--gold-glow);border:1px solid rgba(200,164,94,.15);color:var(--gold);font-family:var(--font-sans);font-weight:600;display:flex;align-items:center;gap:.25rem}.gh-player-badge:before{content:"♛";font-size:.65rem}.gh-capital-label{font-size:.5rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-sans)}.gh-capital{font-family:var(--font-mono);font-size:.95rem;font-weight:500;color:var(--gold);font-variant-numeric:tabular-nums}.gh-center{display:flex;align-items:center;gap:1rem}.gh-quarter{display:flex;align-items:center;gap:.5rem;font-family:var(--font-serif);font-size:.7rem;color:var(--text-muted);font-style:italic}.gh-quarter-num{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--gold-dim);color:var(--gold);font-family:var(--font-serif);font-weight:700;font-size:.8rem;position:relative;font-style:normal}.gh-quarter-num:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border:1px solid rgba(200,164,94,.08)}.gh-vs{color:var(--text-dim);font-family:var(--font-serif);font-size:.7rem;font-style:italic;padding:0 .5rem}.gh-opponent .gh-player-name{color:var(--text-muted)}.gh-difficulty{font-size:.5rem;letter-spacing:.06em;text-transform:uppercase;padding:.12rem .35rem;border:1px solid var(--border);color:var(--text-dim);font-family:var(--font-sans)}.dash-panel{display:flex;flex-direction:column;overflow:hidden;padding:1rem 1.25rem}.dash-header{flex-shrink:0;margin-bottom:.5rem}.dash-header h2{font-family:var(--font-serif);font-size:.7rem;color:var(--text-muted);letter-spacing:.05em;font-weight:600;padding-bottom:.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.75rem;font-style:italic}.dash-header h2:before{content:"";width:3px;height:10px;background:var(--gold-dim);flex-shrink:0}.asset-grid{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:.75rem;overflow-y:auto;padding-right:.25rem;align-content:start}.asset-card{background:var(--surface);border:1px solid var(--border);padding:.75rem;transition:border-color .3s ease,box-shadow .3s ease,transform .3s ease;cursor:default;position:relative}.asset-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold-dim),var(--gold),transparent);opacity:.5}.asset-card:after{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border:1px solid rgba(200,164,94,.04);pointer-events:none}.asset-card:hover{border-color:#c8a45e1f;transform:translateY(-1px);box-shadow:0 4px 20px #c8a45e0a}.asset-card:hover:before{opacity:1}.asset-top{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem}.asset-name{font-family:var(--font-serif);font-weight:600;font-size:.85rem;color:var(--text)}.asset-type{font-size:.5rem;text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-sans);font-weight:600;padding:.08rem .3rem;background:var(--bg);border:1px solid var(--border)}.asset-type[data-type=sukuk]{color:var(--turquoise);border-color:var(--turquoise-dim)}.asset-type[data-type=equity]{color:var(--gold);border-color:var(--gold-dim)}.asset-type[data-type=commodity]{color:var(--emerald);border-color:#4ecb8d33}.asset-type[data-type=realestate]{color:var(--crimson);border-color:#b8443a33}.asset-impurity{font-size:.5rem;color:var(--text-dim);font-family:var(--font-mono);font-variant-numeric:tabular-nums;display:flex;align-items:center;gap:.2rem;margin-left:auto}.asset-impurity-dot{display:inline-block;width:5px;height:5px}.asset-price-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.4rem}.asset-price{font-family:var(--font-mono);font-size:1.1rem;font-weight:500;font-variant-numeric:tabular-nums;letter-spacing:-.02em;transition:color .2s ease}.asset-change{font-family:var(--font-mono);font-size:.65rem;font-weight:500;font-variant-numeric:tabular-nums}.asset-change.positive{color:var(--emerald)}.asset-change.negative{color:var(--red)}.chart-wrap{width:100%;height:120px}.chart-wrap canvas{display:block;width:100%;height:100%}.asset-grid::-webkit-scrollbar{width:3px}.asset-grid::-webkit-scrollbar-track{background:transparent}.asset-grid::-webkit-scrollbar-thumb{background:var(--border)}.event-timeline{margin-bottom:.75rem;display:flex;gap:.5rem;flex-wrap:wrap}.event-timeline-empty{color:var(--text-dim);font-size:.65rem;font-family:var(--font-serif);font-style:italic}.event-card{display:flex;align-items:flex-start;gap:.5rem;padding:.4rem .6rem;background:var(--surface);border:1px solid var(--border);min-width:160px;flex:1;transition:border-color .2s ease}.event-card:hover{border-color:var(--gold-dim)}.event-card-icon{font-size:.85rem;line-height:1;flex-shrink:0;width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:var(--bg);border:1px solid var(--border);border-radius:50%}.event-card-title{font-size:.55rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-sans)}.event-card-desc{font-size:.7rem;color:var(--text);margin-top:.1rem;line-height:1.4;font-family:var(--font-sans)}.event-card-body{flex:1}.command-panel{display:flex;flex-direction:column;gap:0;border-left:1px solid var(--border);background:#0a0e1a66;overflow:hidden}.cp-section{padding:.75rem 1rem;border-bottom:1px solid var(--border);position:relative}.cp-section:last-child{border-bottom:none;flex:1;overflow-y:auto}.cp-label{font-family:var(--font-sans);font-size:.5rem;color:var(--text-dim);letter-spacing:.15em;text-transform:uppercase;font-weight:600;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.cp-label:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--border),transparent)}.portfolio-meter{display:flex;flex-direction:column;gap:.4rem}.pm-capital-row{display:flex;align-items:baseline;justify-content:space-between}.pm-capital-label{font-size:.5rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-sans)}.pm-capital-value{font-family:var(--font-mono);font-size:1.3rem;font-weight:500;color:var(--gold-bright);font-variant-numeric:tabular-nums;letter-spacing:-.02em;transition:color .3s ease}.pm-stats{display:grid;grid-template-columns:1fr 1fr;gap:.4rem}.pm-stat{display:flex;flex-direction:column;gap:.05rem;padding:.35rem .45rem;background:#0003;border:1px solid var(--border);position:relative}.pm-stat:before{content:"";position:absolute;top:0;left:0;width:2px;height:100%;background:var(--gold-dim);opacity:.3}.pm-stat-label{font-size:.45rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-sans)}.pm-stat-value{font-family:var(--font-mono);font-size:.85rem;font-weight:500;font-variant-numeric:tabular-nums;color:var(--text);transition:color .3s ease}.pm-stat-value.positive{color:var(--emerald)}.pm-stat-value.negative{color:var(--red)}.pm-bar-wrap{margin-top:.15rem}.pm-bar-label{display:flex;justify-content:space-between;font-size:.45rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em;font-family:var(--font-sans);margin-bottom:.15rem}.pm-bar{height:4px;background:var(--border);overflow:hidden;position:relative}.pm-bar-fill{height:100%;background:linear-gradient(90deg,var(--emerald),var(--gold));transition:width .5s ease;position:relative}.pm-bar-fill:after{content:"◆";position:absolute;right:-4px;top:-6px;font-size:.4rem;color:var(--gold);line-height:1}.pm-impurity-warn .pm-stats{box-shadow:inset 0 0 20px #b8443a0f}.countdown-section{display:flex;align-items:center;gap:.65rem}.countdown-label{font-size:.5rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;font-family:var(--font-sans);white-space:nowrap}.countdown-bar{flex:1;height:4px;background:var(--border);overflow:hidden;position:relative}.countdown-fill{height:100%;background:var(--gold);transition:width 1s linear,background .5s ease;position:relative}.countdown-fill:after{content:"";position:absolute;right:0;top:-1px;bottom:-1px;width:4px;background:inherit;filter:blur(3px);opacity:.5}.countdown-text{font-family:var(--font-mono);font-size:.85rem;font-weight:500;min-width:32px;text-align:right;font-variant-numeric:tabular-nums;color:var(--text);transition:color .3s ease}.countdown-urgent .countdown-bar{animation:pulse .5s ease-in-out infinite}.allocator{display:flex;flex-direction:column;gap:.3rem}.allocator-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.3rem}.allocator-header h3{font-family:var(--font-serif);font-size:.8rem;color:var(--text);font-weight:600}.allocator-presets{display:flex;gap:.25rem}.remaining{font-family:var(--font-mono);font-size:.65rem;color:var(--text-muted);font-variant-numeric:tabular-nums;text-align:right;padding:.1rem 0}.remaining.over{color:var(--crimson);animation:pulse 1s ease-in-out infinite}.alloc-rows{display:flex;flex-direction:column;gap:.1rem}.alloc-row{display:flex;align-items:center;gap:.5rem;padding:.25rem .35rem;transition:background .2s ease;border:1px solid transparent}.alloc-row:hover{background:#ffffff05;border-color:var(--border)}.alloc-label{display:flex;flex-direction:column;min-width:90px;gap:.05rem}.alloc-name{color:var(--text-muted);font-family:var(--font-serif);font-weight:600;font-size:.75rem}.alloc-impurity-label{font-size:.5rem;color:var(--text-dim);font-family:var(--font-mono)}.alloc-pct{font-weight:500;min-width:34px;text-align:right;color:var(--gold);font-family:var(--font-mono);font-size:.75rem;font-variant-numeric:tabular-nums}.alloc-slider{flex:1;-moz-appearance:none;appearance:none;-webkit-appearance:none;height:3px;background:var(--border);outline:none;padding:0;cursor:pointer;transition:background .2s ease}.alloc-slider:hover{background:var(--border-light)}.alloc-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;background:var(--bg-deep);border:2px solid var(--gold-dim);cursor:pointer;transition:all .15s ease;transform:rotate(45deg);border-radius:0}.alloc-slider::-webkit-slider-thumb:hover{border-color:var(--gold);box-shadow:0 0 10px #c8a45e40;transform:rotate(45deg) scale(1.2)}.alloc-slider::-moz-range-thumb{width:12px;height:12px;background:var(--bg-deep);border:2px solid var(--gold-dim);cursor:pointer;border-radius:0}.alloc-slider:active::-webkit-slider-thumb{border-color:var(--gold);box-shadow:0 0 12px #c8a45e4d}.alloc-impurity{font-size:.5rem;color:var(--text-dim);min-width:32px;text-align:right;font-family:var(--font-mono);font-variant-numeric:tabular-nums}.alloc-submit-btn{width:100%;margin-top:.4rem;padding:.65rem 1rem;font-size:.7rem}.recap-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#060910d9;z-index:50;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .3s ease}.recap-card{background:var(--surface);border:1px solid var(--border);padding:2rem;max-width:640px;width:90%;max-height:80vh;overflow-y:auto;position:relative}.recap-card:before{content:"";position:absolute;top:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent)}.recap-card:after{content:"";position:absolute;bottom:0;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent)}.recap-title{margin:0 0 .25rem;font-family:var(--font-serif);font-size:1.3rem;font-weight:700;color:var(--gold);text-align:center}.recap-subtitle{text-align:center;font-family:var(--font-serif);font-size:.7rem;color:var(--text-muted);font-style:italic;margin-bottom:1.25rem}.recap-divider{height:1px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent);margin:1rem 0}.recap-section{margin-bottom:1rem}.recap-section h3{font-family:var(--font-serif);font-size:.7rem;color:var(--text-muted);font-weight:600;margin:0 0 .5rem;font-style:italic}.recap-events{display:flex;flex-direction:column;gap:.4rem}.recap-event{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;background:var(--bg);font-size:.75rem;border:1px solid var(--border)}.recap-event-icon{font-size:.85rem;flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);border-radius:50%}.recap-no-events{color:var(--text-dim);font-style:italic;font-size:.7rem;font-family:var(--font-serif)}.recap-assets{display:grid;grid-template-columns:1fr 1fr;gap:.4rem}.recap-asset{display:flex;align-items:center;gap:.4rem;padding:.35rem .5rem;background:var(--bg);font-size:.7rem;border:1px solid var(--border)}.recap-asset-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--font-serif);font-weight:600;font-size:.7rem}.recap-asset-perf{font-weight:600;font-size:.8rem;font-family:var(--font-mono);font-variant-numeric:tabular-nums}.recap-asset-perf.positive{color:var(--emerald)}.recap-asset-perf.negative{color:var(--red)}.recap-asset-impurity{font-size:.5rem;color:var(--text-dim);font-family:var(--font-mono)}.recap-players{display:flex;align-items:center;gap:1rem}.recap-player{flex:1;padding:.65rem;background:var(--bg);border:1px solid var(--border)}.recap-player-name{font-family:var(--font-serif);font-weight:700;font-size:.85rem;margin-bottom:.2rem}.recap-player-capital{font-family:var(--font-mono);font-size:1rem;font-weight:500;color:var(--gold);font-variant-numeric:tabular-nums}.recap-player-alloc{font-size:.6rem;color:var(--text-muted);margin-top:.2rem;line-height:1.4;font-family:var(--font-mono)}.recap-vs{font-family:var(--font-serif);font-weight:700;color:var(--text-dim);font-size:.8rem;font-style:italic;display:flex;flex-direction:column;align-items:center;gap:.15rem}.results{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:2.5rem}.results-header{text-align:center}.results-header h1{font-family:var(--font-serif);font-size:clamp(2rem,4vw,2.8rem);font-weight:700;margin-bottom:.5rem;letter-spacing:-.01em}.winner-banner{font-family:var(--font-serif);font-size:1.1rem;font-weight:600;color:var(--gold);display:flex;align-items:center;justify-content:center;gap:.5rem}.winner-banner:before{content:"♛";font-size:1.2rem}.results-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;width:100%;max-width:640px}.result-card{background:var(--surface);border:1px solid var(--border);padding:1.5rem;display:flex;flex-direction:column;gap:.75rem;transition:border-color .3s ease;position:relative}.result-card.winner{border-color:var(--gold-dim);box-shadow:0 0 30px #c8a45e0f,inset 0 0 30px #c8a45e05}.result-card.winner:before{content:"";display:block;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:-1.5rem -1.5rem 0}.result-card h3{font-family:var(--font-serif);font-size:1rem;font-weight:600;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.stat{display:flex;justify-content:space-between;font-size:.8rem}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.6rem;font-family:var(--font-sans)}.stat-value{font-variant-numeric:tabular-nums;font-family:var(--font-mono)}.stat-value.positive{color:var(--emerald);font-weight:500}.stat-value.negative{color:var(--red);font-weight:500}.stat-value.highlight{color:var(--gold);font-weight:500;font-size:.9rem}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#060910d9;z-index:999;animation:fadeIn .3s ease;pointer-events:none}.onboarding-card{background:var(--surface);border:1px solid var(--border);padding:2rem;max-width:480px;width:90%;text-align:center;pointer-events:auto;position:relative}.onboarding-card:before{content:"";position:absolute;top:0;left:15%;right:15%;height:1px;background:linear-gradient(90deg,transparent,var(--gold-dim),transparent)}.onboarding-card:after{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border:1px solid rgba(200,164,94,.04);pointer-events:none}.onboarding-step-indicator{font-size:.6rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-sans);margin-bottom:.75rem}.onboarding-title{font-family:var(--font-serif);font-size:1.15rem;font-weight:600;color:var(--gold);margin:0 0 .75rem}.onboarding-desc{font-size:.85rem;color:var(--text);line-height:1.6;margin:0 0 1.25rem;font-family:var(--font-sans)}.onboarding-dots{display:flex;justify-content:center;gap:.5rem;margin-bottom:1.25rem}.onboarding-dot{width:6px;height:6px;background:var(--border);transition:background .2s;transform:rotate(45deg)}.onboarding-dot.active{background:var(--gold-dim)}.onboarding-actions{display:flex;gap:.75rem;justify-content:center}.spectator-mode{padding:1rem}.spectator-badge{display:inline-block;padding:.2rem .5rem;background:#c8a45e1a;border:1px solid var(--gold-dim);color:var(--gold);font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-sans);margin-bottom:1rem}.spectator-grid{display:flex;gap:1rem;margin-bottom:1rem}.spectator-player{flex:1;padding:1rem;background:var(--surface);border:1px solid var(--border);position:relative}.spectator-player:before{content:"";position:absolute;top:0;left:0;width:2px;height:100%;background:var(--gold-dim);opacity:.3}.spectator-player h3{margin:0 0 .5rem;font-family:var(--font-serif);font-size:.85rem;color:var(--text-muted);font-weight:600}.spectator-capital{font-family:var(--font-mono);font-size:1.3rem;font-weight:500;color:var(--gold);font-variant-numeric:tabular-nums}.spectator-score{font-size:.65rem;color:var(--text-muted);margin-top:.2rem;font-family:var(--font-mono)}.spectator-round{font-size:.7rem;color:var(--text-muted);text-align:center;font-family:var(--font-serif);font-style:italic}@media (max-width: 900px){.game-main{grid-template-columns:1fr}.command-panel{border-left:none;border-top:1px solid var(--border);max-height:50vh}.asset-grid{grid-template-columns:1fr}}@media (max-width: 768px){.game-header{flex-wrap:wrap;padding:.5rem .75rem;gap:.5rem}.gh-center{order:3;width:100%;justify-content:center}.results-grid{grid-template-columns:1fr;max-width:360px}.pm-stats,.recap-assets{grid-template-columns:1fr}.recap-players{flex-direction:column}.alloc-label{min-width:70px}.spectator-grid{flex-direction:column}}@media (max-width: 480px){.lobby-card{padding:1.5rem 1rem}.lobby-header h1{font-size:2rem}.lobby-emblem{width:36px;height:36px}}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:var(--border)}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}
