*{box-sizing:border-box}body{color:#e7ecf3;background:#0d1118;margin:0;font-family:Inter,Segoe UI,Tahoma,sans-serif}#root{height:100vh}.app-shell{flex-direction:column;height:100%;display:flex}.topbar{background:#121a26;border-bottom:1px solid #273444;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1rem;display:flex}.topbar-group{align-items:center;gap:.5rem;font-size:.9rem;display:flex}.content{flex:1;grid-template-columns:1fr 320px;min-height:0;display:grid}.map-pane{min-height:0;position:relative}.side-pane{background:#111722;border-left:1px solid #273444;flex-direction:column;gap:.75rem;padding:.75rem;display:flex;overflow:auto}.panel,.add-node-tool{background:#162130;border:1px solid #2c3d52;border-radius:8px;padding:.75rem}.panel h2{margin:0 0 .5rem;font-size:1.05rem}.panel p,.add-node-tool p{color:#afbac8;margin:0 0 .45rem;font-size:.85rem}.entity-list{flex-direction:column;gap:.55rem;display:flex}.entity-item{background:#121d2b;border:1px solid #31465d;border-radius:8px;padding:.5rem}.entity-title-row{justify-content:space-between;align-items:center;margin-bottom:.45rem;display:flex}.swatch{border:1px solid #e5e7eb;width:22px;height:16px}.grid-inputs{grid-template-columns:repeat(2,minmax(0,1fr));gap:.35rem .5rem;display:grid}label{flex-direction:column;gap:.2rem;font-size:.78rem;display:flex}input[type=number]{color:#e7ecf3;background:#0f1723;border:1px solid #405875;border-radius:6px;padding:.25rem .35rem}button{color:#e7ecf3;cursor:pointer;background:#1d3552;border:1px solid #3e5d82;border-radius:6px;padding:.35rem .6rem}button:hover{background:#274d72}button:disabled{opacity:.4;cursor:not-allowed}.app-shell.start-phase{flex-direction:row;position:relative}.start-map-bg{position:absolute;inset:0}.start-screen{pointer-events:none;align-items:stretch;display:flex;position:absolute;inset:0}.start-panel{pointer-events:all;background:#0a0f19f2;border-right:1px solid #1e2e40;flex-direction:column;gap:.75rem;width:360px;padding:1.5rem 1.2rem;display:flex;overflow-y:auto}.start-panel h1{letter-spacing:.06em;color:#e7ecf3;margin:0;font-size:1.6rem}.start-subtitle{color:#7a9abf;margin:0;font-size:.9rem}.start-body-text{color:#5e7a96;margin:0;font-size:.82rem;line-height:1.55}.start-body-text strong{color:#90aecb}.identity-orb-wrap{flex-direction:column;align-items:center;gap:.5rem;padding:.75rem 0;display:flex}.identity-orb{border-radius:50%;width:90px;height:90px;transition:background .15s,box-shadow .25s}.identity-orb-label{font-variant-numeric:tabular-nums;font-size:.72rem;transition:color .15s}.axis-sliders{flex-direction:column;gap:.65rem;display:flex}.subfield-sliders{flex-direction:column;gap:1.25rem;margin-top:.5rem;display:flex}.subfield-group{background:#0003;border-radius:8px;flex-direction:column;gap:.65rem;padding:.5rem;display:flex}.subfield-group h3{letter-spacing:.05em;text-transform:uppercase;margin:0 0 .25rem;padding-bottom:.25rem;font-size:.85rem;font-weight:700}.color-picker-step{flex-direction:column;gap:1rem;display:flex}.hex-input-wrap{background:#0003;border:1px solid #1e2e40;border-radius:8px;align-items:center;gap:1rem;padding:1rem;display:flex}.color-input{cursor:pointer;background:0 0;border:none;border-radius:8px;width:60px;height:60px;padding:0}.color-input::-webkit-color-swatch-wrapper{padding:0}.color-input::-webkit-color-swatch{border:2px solid #3e5d82;border-radius:8px}.hex-display{color:#e7ecf3;font-family:monospace;font-size:1.5rem;font-weight:600}.axis-slider{flex-direction:column;gap:.2rem;display:flex}.axis-slider-header{justify-content:space-between;align-items:baseline;display:flex}.axis-label{font-size:.8rem;font-weight:600}.axis-value{color:#5e7a96;font-variant-numeric:tabular-nums;font-size:.72rem}.axis-description{color:#3d5268;margin:0;font-size:.7rem}.axis-range{cursor:pointer;background:0 0;width:100%;height:4px}.identity-confirm-btn{letter-spacing:.03em;width:100%;margin-top:.25rem;padding:.55rem;font-size:.9rem;font-weight:600;transition:background .2s,border-color .2s,color .2s}.chosen-self-badge{background:#ffffff08;border:1px solid;border-radius:6px;align-items:center;gap:.5rem;padding:.4rem .6rem;font-size:.78rem;display:flex}.chosen-self-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.change-self-btn{color:#5e7a96;background:0 0;border-color:#2c3d52;margin-left:auto;padding:.15rem .4rem;font-size:.72rem}.node-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.node-list-item{background:#162130;border:1px solid #2c3d52;border-radius:8px;padding:.6rem .75rem;transition:border-color .15s}.node-list-item.hovered{border-color:#ffd864}.node-list-header{align-items:center;gap:.5rem;margin-bottom:.3rem;display:flex}.node-swatch{border:1px solid #fff3;border-radius:50%;flex-shrink:0;width:14px;height:14px}.node-list-header strong{flex:1;font-size:.9rem}.military-badge{color:#a0b4c8;white-space:nowrap;font-size:.78rem}.node-summary{color:#7a9abf;margin:0 0 .45rem;font-size:.75rem}.claim-btn{background:#1d3552;border-color:#3e5d82;width:100%;padding:.4rem;font-size:.82rem}.rel-badge{letter-spacing:.04em;white-space:nowrap;border-radius:20px;flex-shrink:0;padding:.15rem .45rem;font-size:.68rem;font-weight:700}.rel-preview{background:#00000040;border:1px solid #1e2e40;border-radius:8px;flex-direction:column;gap:.45rem;padding:.6rem .75rem;display:flex}.rel-preview-label{letter-spacing:.06em;text-transform:uppercase;color:#4a5a6e;font-size:.68rem;font-weight:700}.rel-preview-rows{flex-direction:column;gap:.3rem;display:flex}.rel-preview-row{align-items:center;gap:.5rem;display:flex}.rel-preview-swatch{border-radius:50%;flex-shrink:0;width:10px;height:10px}.rel-preview-civ{color:#94a3b8;flex:1;font-size:.78rem}.civ-card-list{flex-direction:column;gap:.75rem;margin-top:.25rem;display:flex}.civ-card{background:#101a27;border:1px solid #1e2e40;border-left:3px solid;border-radius:8px;flex-direction:column;gap:.5rem;padding:.75rem;display:flex}.civ-header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.civ-header-left{align-items:center;gap:.55rem;display:flex}.civ-color-dot{border-radius:50%;flex-shrink:0;width:16px;height:16px}.civ-name{color:#e2e8f0;font-size:.92rem;font-weight:700;line-height:1.2;display:block}.civ-subtitle{color:#4a5a6e;letter-spacing:.04em;font-size:.68rem;display:block}.civ-description{color:#4a5a6e;margin:0;font-size:.75rem;line-height:1.5}.civ-node-list{border-top:1px solid #1e2e40;flex-direction:column;gap:1px;margin:0;padding:.4rem 0 0;list-style:none;display:flex}.civ-node-item{border-radius:5px;align-items:center;gap:.45rem;padding:.3rem .25rem;transition:background .1s;display:flex}.civ-node-item.hovered{background:#ffffff0a}.node-class-icon{text-align:center;flex-shrink:0;width:14px;font-size:.9rem;line-height:1}.civ-node-info{flex-direction:column;flex:1;gap:.05rem;min-width:0;display:flex}.civ-node-name{color:#c8d6e4;white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:500;overflow:hidden}.civ-node-class{color:#3d5268;letter-spacing:.03em;font-size:.64rem}.civ-node-military{color:#7a9abf;white-space:nowrap;flex-shrink:0;font-size:.72rem}.civ-begin-btn{color:#5e7a96;background:0 0;border-color:#2c3d52;flex-shrink:0;padding:.2rem .55rem;font-size:.72rem;transition:background .15s,color .15s,border-color .15s}.civ-begin-btn:hover{color:#c8d6e4;background:#ffffff0f;border-color:#3e5d82}.civ-begin-btn.capital{font-weight:600}.mode-toggle{gap:0}.mode-btn{letter-spacing:.02em;border-right-width:0;border-radius:0;font-weight:500;transition:background .15s,color .15s,border-color .15s,box-shadow .15s}.mode-btn:first-child{border-radius:6px 0 0 6px}.mode-btn:last-child{border-right-width:1px;border-radius:0 6px 6px 0}.mode-btn--state.active{color:#93c5fd;background:#1e3f6e;border-color:#4a82c4;box-shadow:0 0 8px #4a82c473}.mode-btn--religion.active{color:#6ee7a8;background:#14432a;border-color:#34a866;box-shadow:0 0 8px #34a86673}.mode-btn--culture.active{color:#d8b4fe;background:#3b1f5e;border-color:#9b5fe0;box-shadow:0 0 8px #9b5fe073}.mode-btn--language.active{color:#fcd27a;background:#3d2a00;border-color:#c89020;box-shadow:0 0 8px #c8902073}.timeline-controls{gap:.6rem}.play-pause-btn{color:#e7ecf3;cursor:pointer;background:#1e293b;border:1px solid #334155;border-radius:50%;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:.85rem;transition:background .15s,border-color .15s;display:flex}.play-pause-btn:hover{background:#263347;border-color:#4a90d9}.play-pause-btn.playing{color:#4ade80;background:#1a3a1a;border-color:#4ade80}.year-display{font-variant-numeric:tabular-nums;color:#94a3b8;min-width:5rem;font-size:.9rem}.map-view-toggle{gap:0}.map-view-toggle button{border-right-width:0;border-radius:0}.map-view-toggle button:first-child{border-radius:6px 0 0 6px}.map-view-toggle button:last-child{border-right-width:1px;border-radius:0 6px 6px 0}.map-view-toggle button.active{color:#fff;background:#2e5a8a;border-color:#5b8ec7}.inspector-header{justify-content:space-between;align-items:center;margin-bottom:.4rem;display:flex}.inspector-header h2{margin:0}.owner-badge{letter-spacing:.04em;border-radius:20px;padding:.2rem .5rem;font-size:.72rem;font-weight:600}.owner-badge.player{color:#ffd864;background:#ffd86426;border:1px solid #ffd86459}.owner-badge.npc{color:#7a9abf;background:#7896b41a;border:1px solid #7896b440}.military-row{flex-wrap:wrap;align-items:center;gap:.6rem;margin:.5rem 0;display:flex}.military-row strong{white-space:nowrap;font-size:.85rem}.military-row input[type=number]{width:64px}.attack-btn{color:#f0a0a0;background:#4a1c1c;border-color:#8a3030;font-size:.8rem}.attack-btn:hover{background:#6a2424}.out-of-range{color:#576880;font-size:.78rem;font-style:italic}.territory-tool{background:#162130;border:1px solid #2c3d52;border-radius:8px;flex-direction:column;gap:.6rem;padding:.75rem;display:flex}.territory-tool h2{margin:0;font-size:1.05rem}.territory-tool p{color:#afbac8;margin:0;font-size:.85rem}.territory-budget{flex-direction:column;gap:.3rem;display:flex}.budget-label{color:#afbac8;justify-content:space-between;font-size:.8rem;display:flex}.budget-bar{background:#1e2e40;border-radius:4px;height:8px;overflow:hidden}.budget-fill{background:#ffd864;border-radius:4px;height:100%;transition:width .1s}.budget-numbers{color:#7a9abf;margin:0;font-size:.75rem}.territory-actions{gap:.5rem;display:flex}.confirm-btn{color:#90ee90;background:#1a3d1a;border-color:#2e7d2e;flex:1}.confirm-btn:hover:not(:disabled){background:#254d25}.cancel-btn{color:#f0a0a0;background:#3a2020;border-color:#6a3030}.territory-hint{color:#576880;margin:0;font-size:.78rem;font-style:italic}.radius-control{flex-direction:column;gap:.35rem;display:flex}.radius-header{color:#afbac8;justify-content:space-between;font-size:.8rem;display:flex}.radius-value{color:#ffd864;font-weight:600}.radius-slider{appearance:none;cursor:pointer;background:#1e2e40;border-radius:3px;outline:none;width:100%;height:6px}.radius-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#ffd864;border:2px solid #162130;border-radius:50%;width:16px;height:16px}.radius-slider::-moz-range-thumb{cursor:pointer;background:#ffd864;border:2px solid #162130;border-radius:50%;width:16px;height:16px}.radius-hints{color:#576880;justify-content:space-between;font-size:.7rem;display:flex}.mech-debug-panel{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0a101cf5;border-top:1px solid #1e2e40;flex-shrink:0;padding:.5rem .75rem .6rem}.mech-debug-title{color:#6b7a8d;letter-spacing:.06em;text-transform:uppercase;align-items:center;gap:.5rem;margin-bottom:.4rem;font-size:.75rem;font-weight:600;display:flex}.mech-tick{color:#4a5568;text-transform:none;letter-spacing:0;margin-left:auto;font-size:.7rem;font-weight:400}.mech-cards-row{grid-template-columns:repeat(4,1fr);gap:.5rem;display:grid}.mech-card{background:#0f1a26;border:1px solid #1e2e40;border-radius:6px;overflow:hidden}.mech-card-title{color:#94a3b8;letter-spacing:.04em;text-transform:uppercase;border-bottom:1px solid #1e2e40;border-left:3px solid #0000;padding:.3rem .5rem;font-size:.7rem;font-weight:700}.mech-card-body{flex-direction:column;gap:.25rem;max-height:11rem;padding:.35rem .5rem;display:flex;overflow-y:auto}.mech-hint{color:#4a5a6e;margin-bottom:.15rem;font-size:.65rem}.debug-node-row{align-items:center;gap:.3rem;min-height:20px;display:flex}.debug-node-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.debug-node-name{color:#7a8fa8;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0;width:52px;font-size:.68rem;overflow:hidden}.mini-bar-wrap{flex:1;align-items:center;gap:.25rem;display:flex}.mini-bar-label{color:#4a5a6e;flex-shrink:0;width:28px;font-size:.65rem}.mini-bar-track{background:#1a2a3a;border-radius:3px;flex:1;height:5px;overflow:hidden}.mini-bar-fill{border-radius:3px;height:100%;transition:width .25s,background .25s}.mini-bar-value{color:#6b7a8d;text-align:right;flex-shrink:0;width:26px;font-size:.65rem}.mech-stat{color:#6b7a8d;text-align:right;font-variant-numeric:tabular-nums;flex-shrink:0;width:40px;font-size:.65rem}.mech-layer-vols{font-variant-numeric:tabular-nums;flex:1;gap:.3rem;font-size:.65rem;display:flex}.mech-total{color:#94a3b8;margin-left:auto;font-weight:600}.mode-tabs{border-bottom:1px solid #334155;gap:0;margin-bottom:1rem;display:flex}.mode-tab-btn{color:#64748b;cursor:pointer;letter-spacing:.03em;background:0 0;border:none;border-bottom:2px solid #0000;padding:.35rem .9rem .4rem;font-size:.82rem;font-weight:600;transition:color .15s,border-bottom-color .15s}.mode-tab-btn:hover{color:#94a3b8}.mode-tab-btn.active{color:currentColor}.axis-slider-header{justify-content:space-between;align-items:center;gap:.25rem;margin-bottom:.15rem;display:flex}.spectrum-pole-left,.spectrum-pole-right{opacity:.9;white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.62rem;font-weight:600;overflow:hidden}.spectrum-pole-right{text-align:right}.spectrum-bar-wrap{align-items:center;gap:.4rem;margin-bottom:.25rem;display:flex}.spectrum-pole{color:#64748b;white-space:nowrap;text-overflow:ellipsis;width:64px;font-size:.58rem;overflow:hidden}.spectrum-left{text-align:right}.spectrum-right{text-align:left}.spectrum-track{background:linear-gradient(90deg,#1e3a5f,#f0f4ff);border-radius:3px;flex:1;height:6px;position:relative}.spectrum-marker{background:#e2e8f0;border:2px solid #0f172a;border-radius:50%;width:10px;height:10px;position:absolute;top:50%;transform:translate(-50%,-50%)}.tri-layer-display{margin-bottom:.75rem}.tri-layer-header{color:#cbd5e1;align-items:center;gap:.4rem;margin-bottom:.35rem;font-size:.78rem;font-weight:700;display:flex}.tri-layer-strength{color:#64748b;font-variant-numeric:tabular-nums;margin-left:auto;font-size:.65rem}
