:root{color-scheme:dark;font-family:IBM Plex Sans,sans-serif;--bg: #08131d;--bg-alt: #0f1d2b;--bg-soft: rgba(12, 28, 42, .72);--panel: rgba(10, 23, 35, .78);--panel-strong: rgba(12, 27, 42, .92);--stroke: rgba(202, 213, 225, .14);--text: #eef2f6;--muted: #9aabba;--accent: #ffcc7a;--red: #f1a340;--neutral: #f7f7f7;--green: #998ec3;--shadow: 0 18px 60px rgba(0, 0, 0, .34)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at top left,rgba(200,54,45,.16),transparent 30%),radial-gradient(circle at top right,rgba(31,138,82,.15),transparent 28%),linear-gradient(180deg,#09131c,#08111a 55%,#060d14);color:var(--text)}button,input{font:inherit}button{border:0;cursor:pointer}#root{min-height:100vh}.app-shell{padding:28px;height:100vh;display:flex;flex-direction:column;overflow:hidden}.topbar{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;margin-bottom:20px}.topbar h1,.panel-heading h2{font-family:Space Grotesk,sans-serif;margin:0;letter-spacing:-.04em}.topbar h1{font-size:clamp(2rem,3vw,3.2rem)}.subtitle{max-width:760px;margin:10px 0 0;color:var(--muted);line-height:1.55}.eyebrow{margin:0 0 6px;color:var(--accent);text-transform:uppercase;letter-spacing:.18em;font-size:.76rem;font-weight:700}.toolbar-actions{display:flex;gap:12px;flex-wrap:wrap}.primary-button,.secondary-button,.ghost-button{border-radius:999px;padding:12px 18px;transition:transform .18s ease,opacity .18s ease,background-color .18s ease}.primary-button{background:linear-gradient(135deg,#f4b04e,#ffdb95);color:#0c1520;font-weight:700}.primary-button.is-reset-state{background:linear-gradient(135deg,#a0a8b3,#c4cad2);color:#111922}.secondary-button{background:#ffffff14;color:var(--text)}.ghost-button{background:#ffffff14;color:var(--text);padding:9px 14px}.primary-button:hover,.secondary-button:hover,.ghost-button:hover{transform:translateY(-1px)}.primary-button:disabled,.secondary-button:disabled,.ghost-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.card{background:var(--panel);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--stroke);border-radius:24px;box-shadow:var(--shadow)}.notif-bell{position:relative}.notif-bell__trigger{position:relative;display:flex;align-items:center;justify-content:center;width:42px;height:42px;padding:0;border-radius:999px}.notif-bell__trigger--unread{background:#ffcc7a1f}.notif-bell__badge{position:absolute;top:4px;right:4px;min-width:17px;height:17px;padding:0 4px;border-radius:999px;background:var(--accent);color:#0c1520;font-size:.65rem;font-weight:800;line-height:17px;text-align:center;pointer-events:none}.notif-dropdown{position:absolute;top:calc(100% + 10px);right:0;width:340px;max-height:480px;display:flex;flex-direction:column;padding:0;overflow:hidden;z-index:200;border-radius:20px}.notif-dropdown__header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px 10px;border-bottom:1px solid var(--stroke);flex-shrink:0}.notif-dropdown__empty{padding:32px 18px;text-align:center;color:var(--muted);font-size:.9rem}.notif-dropdown__list{margin:0;padding:8px 0;list-style:none;overflow-y:auto}.notif-item{display:flex;flex-direction:column;gap:4px;padding:12px 18px;border-bottom:1px solid var(--stroke);transition:background .15s ease}.notif-item:last-child{border-bottom:none}.notif-item--unread{background:#ffcc7a0f}.notif-item--unread .notif-item__message:before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--accent);margin-right:8px;flex-shrink:0;vertical-align:middle}.notif-item__message{font-size:.88rem;color:var(--text);line-height:1.45}.notif-item__meta{font-size:.76rem;color:var(--muted);padding-left:15px}.status-strip{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin-bottom:18px}.status-card{padding:16px 18px}.status-card span{display:block;color:var(--muted);margin-bottom:6px}.status-card strong{font-size:1.32rem}.status-bar-row{display:flex;align-items:center;gap:10px}.status-bar-row strong{flex-shrink:0;min-width:3.2ch}.status-bar-track{flex:1;height:8px;border-radius:4px;background:#ffffff14;overflow:hidden}.status-bar-fill{height:100%;border-radius:4px;transition:width .4s ease}.dictatorship-fill{background:var(--red)}.neutral-fill{background:var(--neutral)}.democracy-fill{background:var(--green)}.outcome-running{color:var(--neutral)}.outcome-won{color:var(--green)}.outcome-lost{color:var(--red)}.layout-grid{display:grid;grid-template-columns:0 minmax(0,1fr);gap:18px;align-items:start;transition:grid-template-columns .22s ease;flex:1;min-height:0}.layout-grid.parameters-open{grid-template-columns:340px minmax(0,1fr)}.parameter-dock{overflow:hidden;min-width:0;transition:opacity .18s ease,max-height .22s ease}.parameter-dock.is-closed{opacity:0;pointer-events:none;max-height:0}.parameter-dock.is-open{opacity:1;max-height:2000px}.parameter-dock .parameter-panel{position:sticky;top:20px;max-height:calc(100vh - 40px)}.panel-toggle{position:fixed;left:10px;top:50%;transform:translateY(-50%);width:28px;height:66px;border-radius:999px;border:1px solid var(--stroke);background:#08131de0;color:var(--text);display:grid;place-items:center;z-index:220;box-shadow:var(--shadow);transition:background-color .18s ease,transform .18s ease}.panel-toggle:hover{background:#112334f2}.panel-toggle.is-open{transform:translateY(-50%) translate(2px)}.main-stage{display:grid;gap:18px;height:100%;min-height:0;align-content:start}.visual-row{display:grid;grid-template-columns:minmax(0,60%) minmax(0,40%);gap:18px;height:100%;min-height:0}.feed-panel,.parameter-panel,.graph-panel,.chart-panel{padding:18px}.graph-panel{display:flex;flex-direction:column;height:100%;min-height:0}.feed-panel{height:100%;min-height:0;display:flex;flex-direction:column}.panel-heading{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:16px}.counter-pill,.meta-chip,.type-chip,.status-label{border-radius:999px;padding:6px 10px;font-size:.8rem;background:#ffffff14}.empty-state{min-height:220px;display:grid;place-items:center;text-align:center;color:var(--muted);border:1px dashed rgba(255,255,255,.14);border-radius:18px}.post-list{display:grid;gap:12px;flex:1;min-height:0;grid-auto-rows:max-content;align-content:start;overflow:auto;padding-right:4px}.post-card{border-radius:18px;padding:14px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,#ffffff0f,#ffffff08);transition:border-color .18s ease,transform .18s ease,background-color .18s ease}.post-card:hover{transform:translateY(-1px)}.post-card.is-highlighted{border-color:#fff}.post-card.is-censored{opacity:.58;filter:grayscale(.68)}.post-card.dictatorship{box-shadow:inset 0 0 0 1px #f1a3403d}.post-card.democracy{box-shadow:inset 0 0 0 1px #998ec33d}.post-card.neutral{box-shadow:inset 0 0 0 1px #858b9438}.post-card__header,.post-card__footer{display:flex;justify-content:space-between;gap:8px;align-items:center}.post-card__body{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin:12px 0;color:var(--muted)}.post-card__metrics{min-width:0;flex:1}.post-card__body p{margin:5px 0}.post-avatar{width:72px;height:72px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:#ffffff0d;flex-shrink:0}.graph-svg,.chart-svg{width:100%;display:block}.graph-svg{flex:1;min-height:0;height:100%}.chart-svg{min-height:280px}.node-label{fill:#111;font-size:10px;font-weight:700;pointer-events:none}.legend-inline{display:flex;gap:14px;flex-wrap:wrap;color:var(--muted);font-size:.9rem}.legend-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px}.legend-dot.dictatorship{background:var(--red)}.legend-dot.neutral{background:var(--neutral)}.legend-dot.democracy{background:var(--green)}.parameter-panel{max-height:520px;overflow:auto}.parameter-groups{display:grid;gap:14px}.parameter-group{padding:14px;background:#ffffff0a;border-radius:18px}.parameter-group h3{margin:0 0 12px;font-size:1rem}.parameter-field{display:grid;gap:8px;margin-bottom:10px;color:var(--muted)}.parameter-label-row{display:flex;align-items:center;gap:8px}.info-tooltip{display:inline-flex;width:18px;height:18px;border-radius:999px;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;line-height:1;color:var(--text);background:#ffffff29;border:1px solid rgba(255,255,255,.22);cursor:help;flex-shrink:0}.tooltip-portal{padding:10px 12px;border-radius:10px;color:var(--text);background:#060c12f5;border:1px solid rgba(255,255,255,.14);box-shadow:0 10px 28px #00000080;font-size:.78rem;line-height:1.5;z-index:9999}.parameter-field input[type=number],.parameter-field select{width:100%;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#060c12a8;color:var(--text);padding:10px 12px}.parameter-field input[type=checkbox]{width:18px;height:18px}.footer-note{margin-top:12px;flex-shrink:0;color:var(--muted)}.error-banner{margin-bottom:16px;padding:12px 14px;border-radius:16px;color:#ffd8d5;background:#c8362d33;border:1px solid rgba(200,54,45,.36)}@media (max-width: 1280px){.visual-row{grid-template-columns:1fr}.parameter-panel{max-height:none}}@media (max-width: 980px){.app-shell{padding:18px}.topbar,.layout-grid{grid-template-columns:1fr;display:grid}.status-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.feed-panel{position:static;min-height:0}.layout-grid,.layout-grid.parameters-open,.layout-grid.parameters-closed{grid-template-columns:1fr}.panel-toggle{top:auto;bottom:20px;transform:none}.panel-toggle.is-open{transform:translate(2px)}}@media (max-width: 720px){.status-strip{grid-template-columns:1fr}.toolbar-actions,.panel-heading,.post-card__header,.post-card__footer{flex-direction:column;align-items:flex-start}}
