@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}body{background:var(--c-bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:var(--c-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.simulator-pro{min-height:100vh;display:flex;flex-direction:column;background:var(--c-bg)}.header-pro{padding:16px 24px;background:var(--c-surface);border-bottom:1px solid var(--c-border);flex-shrink:0}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;width:100%}.app-footer{padding:12px 24px;background:var(--c-surface);border-top:1px solid var(--c-border);text-align:center;font-size:var(--fs-xs);color:var(--c-text-tertiary);flex-shrink:0}.header-left{display:flex;align-items:center;gap:12px}.logo-link{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit}.logo-image{width:56px;height:56px;background:url(/EconomySimulator/logo.png) center/contain no-repeat}.logo-link h1{font-size:18px;font-weight:600;color:var(--c-text)}.logo-link p{font-size:12px;color:var(--c-text-secondary);font-weight:400}.back-link{margin-left:24px;font-size:var(--fs-sm);color:var(--c-accent);text-decoration:none;padding:6px 12px;border:1px solid var(--c-border);border-radius:0;transition:all .2s ease}.back-link:hover{background:var(--c-accent);color:var(--c-surface);border-color:var(--c-accent)}.header-left h1{font-size:18px;font-weight:600;color:var(--c-text);letter-spacing:-.5px}.header-left .subtitle{font-size:12px;color:var(--c-text-secondary);margin-top:.125rem;font-weight:400}.toolbar{display:flex;gap:.5rem;align-items:center}.sync-cluster{display:flex;align-items:center;gap:.375rem;padding:.25rem .5rem}.sync-cluster.connected{background:#10b9810f;border:1px solid rgba(16,185,129,.3)}.sync-cluster.disconnected{background:transparent;border:1px solid var(--c-border)}.sync-status-dot{width:8px;height:8px;border-radius:50%}.sync-cluster.connected .sync-status-dot{background:var(--c-green);box-shadow:0 0 0 2px #10b98140}.sync-cluster.disconnected .sync-status-dot{background:var(--c-text-tertiary);box-shadow:0 0 0 2px #a8a29e33}.sync-label{font-size:var(--fs-xs);color:var(--c-green);font-weight:600;padding:0 .25rem}.sync-label-kind{font-size:var(--fs-xs);font-weight:600;color:var(--c-text-secondary);text-transform:uppercase;letter-spacing:.5px}.sync-cluster.connected .sync-label-kind{color:var(--c-green)}.btn-mini{padding:.25rem .625rem;font-size:var(--fs-xs)}.btn-icon{background:transparent;border:none;color:var(--c-text-tertiary);padding:.125rem .375rem;font-size:var(--fs-md);line-height:1;cursor:pointer;border-radius:0;transition:color .15s ease}.btn-icon:hover{color:var(--c-red)}.toast{position:fixed;top:1rem;right:1rem;z-index:1000;display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;max-width:440px;background:var(--c-surface);border:1px solid var(--c-border);box-shadow:0 8px 24px #0000001f;font-size:var(--fs-sm);animation:toast-slide-in .2s ease-out}.toast-success{border-left:4px solid var(--c-green)}.toast-error{border-left:4px solid var(--c-red)}.toast-info{border-left:4px solid var(--c-blue)}.toast-message{color:var(--c-text);flex:1}.toast-close{background:transparent;border:none;color:var(--c-text-tertiary);padding:0 .25rem;cursor:pointer;font-size:var(--fs-sm);line-height:1;flex-shrink:0}.toast-close:hover{color:var(--c-text)}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.btn{background:var(--c-accent);border:none;color:var(--c-surface);padding:.5rem 1rem;font-family:inherit;font-size:var(--fs-md);font-weight:500;cursor:pointer;border-radius:0;transition:all .2s ease;white-space:nowrap}.btn:hover{background:var(--c-accent);filter:brightness(.9)}.btn:active{transform:scale(.96)}.btn-secondary{background:var(--c-hover);color:var(--c-text)}.btn-secondary:hover{background:var(--c-border)}.main-content{display:flex;flex:1;max-width:1400px;margin:0 auto;width:100%;padding:1.5rem 0;gap:1.5rem}.sidebar{width:220px;background:var(--c-surface);border:1px solid var(--c-border);padding:1rem .75rem;flex-shrink:0;position:sticky;top:1rem;align-self:flex-start;max-height:calc(100vh - 2rem);overflow-y:auto;border-radius:0}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:var(--c-border);border-radius:0}.nav-item{padding:.625rem .75rem;margin-bottom:.25rem;background:transparent;border:none;color:var(--c-text-secondary);font-family:inherit;font-size:var(--fs-sm);font-weight:500;cursor:pointer;transition:all .2s ease;text-align:left;width:100%;display:flex;align-items:center;justify-content:space-between;gap:.5rem}.nav-item-badge{padding:.125rem .5rem;background:var(--c-accent);color:var(--c-surface);border-radius:999px;font-size:var(--fs-xs);font-weight:600;min-width:1.5rem;text-align:center}.nav-item-badge.warn{background:var(--c-orange)}.nav-item-badge.fail{background:var(--c-red)}.nav-item:hover{background:var(--c-hover);color:var(--c-text)}.nav-item.active{background:var(--c-hover);color:var(--c-accent);font-weight:600}.content-area{flex:1;padding:0 2rem;min-width:0}.metrics-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem;margin-bottom:1rem}.metric-card{background:var(--c-surface);border:1px solid var(--c-border);padding:1rem;transition:all .2s ease}.metric-card:hover{border-color:var(--c-accent);background:var(--c-hover)}.metric-label{font-size:var(--fs-xs);color:var(--c-text-secondary);font-weight:500;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px;min-height:2rem;display:flex;align-items:flex-start;gap:.25rem}.metric-value{font-size:var(--fs-xl);font-weight:700;color:var(--c-text);letter-spacing:-1px;line-height:1.2;margin-bottom:.375rem}.metric-subtext{font-size:var(--fs-sm);color:var(--c-text-secondary);line-height:1.4;min-height:1.125rem}.metric-card.success .metric-value{color:var(--c-green)}.metric-card.warning .metric-value{color:var(--c-orange)}.metric-card.danger .metric-value{color:var(--c-red)}.metric-card.highlight{background:linear-gradient(135deg,var(--c-blue) 0%,var(--c-purple) 100%);border:none}.metric-card.highlight .metric-label{color:var(--c-hover)}.metric-card.highlight .metric-value{color:var(--c-surface)}.metric-card.sink-source-health{padding:1rem}.health-gauge-row{display:flex;align-items:center;gap:.5rem;margin:.5rem 0 .25rem}.gauge-emoji-left,.gauge-emoji-right{font-size:var(--fs-lg);flex-shrink:0}.health-gauge-wrapper{position:relative;flex:1}.gauge-needle-indicator{position:absolute;top:-14px;transform:translate(-50%);font-size:var(--fs-sm);color:var(--c-text);transition:left .5s cubic-bezier(.4,0,.2,1);z-index:10;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.health-gauge{position:relative;height:10px;display:flex;border-radius:0;overflow:hidden;box-shadow:inset 0 1px 2px #0000001a}.gauge-zone{flex:1;transition:all .3s ease}.gauge-zone.red{background:linear-gradient(90deg,var(--c-red) 0%,var(--c-orange) 100%)}.gauge-zone.pink{background:linear-gradient(90deg,var(--c-orange) 0%,var(--c-green) 100%)}.gauge-zone.green{background:linear-gradient(90deg,var(--c-green) 0%,var(--c-yellow) 100%)}.gauge-zone.yellow{background:linear-gradient(90deg,var(--c-yellow) 0%,var(--c-orange) 100%)}.gauge-zone.orange{background:linear-gradient(90deg,var(--c-orange) 0%,var(--c-red) 100%)}.sink-source-health .metric-detail{font-size:var(--fs-sm);color:var(--c-text);margin-top:.25rem;text-align:center;font-weight:500}.section-title{font-size:var(--fs-lg);font-weight:600;color:var(--c-text);letter-spacing:-.4px;margin-bottom:1rem}button.section-title{display:flex;align-items:center;gap:.5rem;width:100%;background:none;border:none;padding:0;margin-bottom:1rem;cursor:pointer;text-align:left;font-family:inherit;font-size:var(--fs-lg);font-weight:600;letter-spacing:-.4px;color:var(--c-text)}.section-title-caret{display:inline-block;transition:transform .15s ease;font-size:.7em;color:var(--c-text-tertiary)}.section-title-caret.open{transform:rotate(90deg)}.section-title-count{margin-left:.375rem;padding:.125rem .5rem;background:var(--c-accent);color:var(--c-surface);border-radius:999px;font-size:var(--fs-xs);font-weight:600;min-width:1.5rem;text-align:center}.chart-container{background:var(--c-surface);border:1px solid var(--c-border);padding:1.5rem;margin-bottom:1rem;transition:all .2s ease;min-width:0}.chart-container:hover{border-color:var(--c-accent);background:var(--c-hover)}.charts-grid-2x3{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-bottom:1rem}.charts-grid-2x3 .chart-container{margin-bottom:0}@media(max-width:960px){.charts-grid-2x3{grid-template-columns:1fr}}.chart-title{font-size:var(--fs-md);font-weight:600;color:var(--c-text);margin-bottom:1rem;letter-spacing:-.3px}.card{background:var(--c-surface);border:1px solid var(--c-border);padding:1rem;transition:all .2s ease}.card:hover{border-color:var(--c-accent);background:var(--c-hover)}.config-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid var(--c-border)}.config-row:last-child{border-bottom:none}.config-row label{font-size:var(--fs-sm);color:var(--c-text);font-weight:500}.config-row input[type=range]{-webkit-appearance:none;width:220px;height:3px;background:var(--c-border);border-radius:0;outline:none}.config-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--c-blue);cursor:pointer;transition:transform .15s}.config-row input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}.config-row input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--c-blue);cursor:pointer;border:none}.recommendation-card{background:var(--c-surface);border:1px solid var(--c-border);border-left:4px solid;padding:1rem;margin-bottom:.75rem;transition:all .2s ease}.recommendation-card:hover{border-color:var(--c-accent);background:var(--c-hover)}.recommendation-success{border-left-color:var(--c-green)}.recommendation-warning{border-left-color:var(--c-orange)}.recommendation-danger{border-left-color:var(--c-red)}.recommendation-info{border-left-color:var(--c-accent)}.recommendation-header{display:flex;gap:.75rem;margin-bottom:.75rem}.recommendation-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:var(--fs-md);font-weight:700;flex-shrink:0}.recommendation-success .recommendation-icon{background:var(--c-hover);color:var(--c-green)}.recommendation-warning .recommendation-icon{background:var(--c-hover);color:var(--c-orange)}.recommendation-danger .recommendation-icon{background:var(--c-hover);color:var(--c-red)}.recommendation-info .recommendation-icon{background:var(--c-hover);color:var(--c-accent)}.recommendation-content{flex:1}.recommendation-title{font-size:var(--fs-md);font-weight:600;color:var(--c-text);margin-bottom:.25rem}.recommendation-description{font-size:var(--fs-md);color:var(--c-text-secondary);line-height:1.5}.recommendation-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-left:40px}.recommendation-btn{background:var(--c-hover);border:1px solid rgba(0,0,0,.1);color:var(--c-blue);padding:.5rem 1rem;font-family:inherit;font-size:var(--fs-md);font-weight:500;cursor:pointer;border-radius:0;transition:all .15s}.recommendation-btn:hover{background:var(--c-border);border-color:#0ea5e94d}.recommendation-btn:active{transform:scale(.96)}.debug-warning{background:var(--c-surface);border:1px solid var(--c-border);border-left:3px solid;padding:.875rem 1rem;margin-bottom:.5rem;font-size:var(--fs-md);display:flex;align-items:center;gap:.5rem;transition:all .2s ease}.debug-warning:hover{border-color:var(--c-accent);background:var(--c-hover)}.debug-warning-icon{font-size:var(--fs-md)}.debug-warning-danger{border-left-color:var(--c-red);color:var(--c-text)}.debug-warning-warning{border-left-color:var(--c-orange);color:var(--c-text)}.debug-warning-info{border-left-color:var(--c-accent);color:var(--c-text)}@media(max-width:1024px){.metrics-grid{grid-template-columns:repeat(2,1fr)}}:root{--c-bg: #fafaf9;--c-surface: #ffffff;--c-hover: #f5f5f4;--c-border: #e7e5e4;--c-text: #1c1917;--c-text-secondary: #78716c;--c-text-tertiary: #a8a29e;--c-accent: #0d9488;--c-blue: #0ea5e9;--c-green: #10b981;--c-red: #ef4444;--c-orange: #f97316;--c-yellow: #fbbf24;--c-purple: #8b5cf6;--segment-whale: var(--c-red);--segment-dolphin: var(--c-blue);--segment-minnow: var(--c-orange);--segment-free: var(--c-text-tertiary);--c-bg-overlay: rgba(0, 0, 0, .03);--c-border-light: rgba(0, 0, 0, .06);--c-border-medium: rgba(0, 0, 0, .1);--c-shadow-light: rgba(0, 0, 0, .05);--c-shadow-medium: rgba(0, 0, 0, .1);--c-shadow-heavy: rgba(0, 0, 0, .15);--c-tooltip-bg: rgba(28, 25, 23, .95);--gauge-red: var(--c-red);--gauge-green: var(--c-green);--gauge-yellow: var(--c-yellow);--gauge-orange: var(--c-orange);--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "Courier New", monospace;--fs-xs: .75rem;--fs-sm: .875rem;--fs-md: 1rem;--fs-lg: 1.375rem;--fs-xl: 2rem;--fs-heading: 1.625rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: .75rem;--space-lg: 1rem;--space-xl: 1.5rem;--space-2xl: 2rem;--space-3xl: 3rem;--sidebar-width: 200px;--content-max-width: 1400px;--radius-sm: 0;--radius-md: 0;--radius-lg: 0;--radius-xl: 0;--radius-full: 0;--shadow-sm: 0 1px 2px var(--c-shadow-light);--shadow-md: 0 2px 4px var(--c-shadow-medium);--shadow-lg: 0 4px 12px var(--c-shadow-heavy);--transition-fast: all .15s ease;--transition-normal: all .2s ease;--transition-slow: all .3s ease}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{font-family:var(--font-family);font-size:var(--fs-sm);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:var(--c-bg);color:var(--c-text);min-height:100vh}#root{min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--c-bg)}::-webkit-scrollbar-thumb{background:var(--c-border);border-radius:0}::-webkit-scrollbar-thumb:hover{background:var(--c-text-tertiary)}::selection{background:var(--c-accent);color:var(--c-surface)}:focus-visible{outline:2px solid var(--c-accent);outline-offset:2px}a{color:var(--c-accent);text-decoration:none}a:hover{text-decoration:underline}
