:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.auth-container{background:#0f3460;border:2px solid #e94560;border-radius:8px;padding:40px;max-width:400px;width:100%;box-shadow:0 8px 32px #0000004d}.auth-header{text-align:center;margin-bottom:30px}.auth-header h1{font-size:2.5rem;color:#e94560;margin:0 0 10px;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.auth-header p{color:#a8dadc;font-size:.9rem;margin:0;font-style:italic}.auth-form{margin-bottom:20px}.auth-form h2{color:#a8dadc;font-size:1.3rem;margin:0 0 20px;text-align:center}.form-group{margin-bottom:15px}.form-group label{display:block;color:#a8dadc;font-size:.9rem;margin-bottom:5px;font-weight:500}.form-group input{width:100%;padding:10px 12px;border:1px solid #457b9d;border-radius:4px;background:#1d3557;color:#a8dadc;font-size:.95rem;transition:border-color .3s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#e94560;box-shadow:0 0 5px #e945604d}.form-group input:disabled{background:#0f3460;color:#6b7280;cursor:not-allowed}.error-message{background:#8b0000;color:#ffcccb;padding:12px;border-radius:4px;margin-bottom:15px;font-size:.9rem;border-left:4px solid #ff6b6b}.success-message{background:#006400;color:#90ee90;padding:12px;border-radius:4px;margin-bottom:15px;font-size:.9rem;border-left:4px solid #32cd32}.btn-primary{width:100%;padding:12px;background:linear-gradient(135deg,#e94560,#d93652);color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #e945604d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#f54d6d,#e94560);box-shadow:0 6px 16px #e9456066;transform:translateY(-2px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.auth-toggle{text-align:center;color:#a8dadc;font-size:.9rem;margin-top:20px}.link-button{background:none;border:none;color:#e94560;cursor:pointer;font-weight:600;text-decoration:underline;padding:0;font-size:.9rem;transition:color .3s}.link-button:hover{color:#f54d6d}@media(max-width:480px){.auth-container{padding:30px 20px}.auth-header h1{font-size:2rem}.auth-form h2{font-size:1.1rem}}.global-hud{position:fixed;top:0;left:0;right:0;height:50px;background:linear-gradient(180deg,#1a0f0a,#2d1810);border-bottom:2px solid #8b4513;display:flex;align-items:center;justify-content:space-around;padding:0 20px;z-index:1000;box-shadow:0 2px 8px #00000080;gap:30px}.hud-section{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;text-align:center}.hud-help{position:relative;display:flex;align-items:center;flex:0 0 auto}.hud-help-button{background:#ffffff14;border:1px solid rgba(230,197,107,.4);color:#f4e4c1;border-radius:10px;padding:6px 10px;cursor:pointer;font-size:14px}.hud-help-panel{position:absolute;top:44px;right:0;background:#140c06f7;border:1px solid rgba(230,197,107,.45);border-radius:10px;padding:10px;min-width:160px;box-shadow:0 10px 24px #00000073;z-index:1200}.hud-help-title{font-size:.8rem;color:#f2dfb5;margin-bottom:8px;text-transform:uppercase;letter-spacing:1px}.hud-help-reset{width:100%;border:none;background:#e6c56b;color:#201a0c;padding:6px 8px;border-radius:8px;cursor:pointer;font-weight:600}.hud-label{font-size:11px;color:#a0826d;text-transform:uppercase;letter-spacing:1px;font-weight:600}.hud-value{font-size:16px;font-weight:700;color:#f4e4c1;font-family:Cinzel,Georgia,serif;min-width:80px}.hud-value.processing{color:#ff9d42;animation:pulse-orange 1s ease-in-out infinite}.hud-cap-alert{font-size:18px;color:#7a6a55;line-height:1}.hud-cap-alert.active{color:tomato;animation:pulse-cap-alert .9s ease-in-out infinite;text-shadow:0 0 10px rgba(255,99,71,.6)}.hud-narrative-alert{font-size:18px;color:#7a6a55;line-height:1;font-weight:700}.hud-narrative-alert.active{color:#ffb347;animation:pulse-cap-alert .9s ease-in-out infinite;text-shadow:0 0 10px rgba(255,179,71,.65)}.hud-resource-icon.pressure{color:#ff4d4f;animation:pulse-resource-pressure .9s ease-in-out infinite;text-shadow:0 0 8px rgba(255,77,79,.65)}.hud-energy{display:flex;flex-direction:column;gap:4px;align-items:center}.hud-energy-track{width:80px;height:6px;background:#ffffff1a;border:1px solid rgba(230,197,107,.35);border-radius:6px;overflow:hidden}.hud-energy-fill{height:100%;background:linear-gradient(90deg,#5bc75b,#e6c56b);transition:width .3s ease}.hud-energy-text{font-size:11px;color:#f4e4c1}@keyframes pulse-orange{0%,to{opacity:1;text-shadow:0 0 10px rgba(255,157,66,.5)}50%{opacity:.6;text-shadow:0 0 20px rgba(255,157,66,.8)}}@keyframes pulse-cap-alert{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.65}}@keyframes pulse-resource-pressure{0%,to{opacity:1;transform:scale(1)}50%{opacity:.65;transform:scale(1.08)}}@media(max-width:1024px){.global-hud{font-size:12px;padding:0 15px;gap:20px}.hud-label{font-size:9px}.hud-value{font-size:14px;min-width:60px}}@media(max-width:768px){.global-hud{height:45px;padding:0 10px;gap:15px}.hud-label{font-size:8px}.hud-value{font-size:12px;min-width:50px}.hud-section{gap:2px}}@media(max-width:480px){.global-hud{height:40px;gap:10px;justify-content:space-between}.hud-value{font-size:11px;min-width:40px}.hud-label{display:none}}.world-ticker-container{position:fixed;top:50px;left:0;right:0;height:35px;background:#0d0604;border-bottom:1px solid #5a3a2a;display:flex;align-items:center;z-index:999;overflow:hidden}.ticker-label{flex-shrink:0;padding:0 15px;background:#2d1810;height:100%;display:flex;align-items:center;font-size:11px;font-weight:700;color:#d4a574;letter-spacing:2px;text-transform:uppercase;border-right:2px solid #8b4513;white-space:nowrap}.world-ticker{flex:1;overflow:hidden;white-space:nowrap;position:relative}.ticker-content{display:inline-flex;animation:scroll-ticker 60s linear infinite;padding-right:100%}.ticker-event{display:inline-flex;align-items:center;gap:8px;padding:0 15px;color:#c9b896;font-size:13px;flex-shrink:0}.tick-id{font-weight:700;color:#8b6f47;font-family:Courier New,monospace;font-size:11px}.event-description{color:#e8d4b5;max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.event-separator{color:#5a3a2a;margin:0 5px;flex-shrink:0}@keyframes scroll-ticker{0%{transform:translate(0)}to{transform:translate(-50%)}}@media(max-width:1024px){.ticker-label{font-size:10px;padding:0 10px}.ticker-event{font-size:12px;padding:0 10px}}@media(max-width:768px){.world-ticker-container{height:30px}.ticker-label{font-size:9px;padding:0 8px}.ticker-event{font-size:11px;padding:0 8px;gap:6px}.event-description{max-width:150px;font-size:10px}}@media(max-width:480px){.world-ticker-container{height:25px}.ticker-label{font-size:8px;padding:0 5px}.ticker-event{font-size:10px;padding:0 5px;gap:4px}.event-description{max-width:100px}}.breaking-banner{position:fixed;top:86px;left:260px;right:20px;z-index:1200;display:flex;align-items:center;gap:12px;padding:14px 18px;background:linear-gradient(90deg,#5b0000,#ac1f12);border:1px solid #f27d72;border-radius:10px;color:#fff3e9;box-shadow:0 10px 24px #00000059;animation:breaking-pulse 1s ease-in-out infinite alternate}.breaking-pill{font-size:.75rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;background:#fff3e9;color:#721500;border-radius:999px;padding:4px 9px;white-space:nowrap}.breaking-text{font-size:.98rem;font-weight:700}@keyframes breaking-pulse{0%{filter:saturate(1)}to{filter:saturate(1.25)}}@media(max-width:768px){.breaking-banner{left:12px;right:12px;top:74px;flex-direction:column;align-items:flex-start}}.sidebar{width:250px;height:calc(100vh - 85px);background:linear-gradient(180deg,#1a0f0a,#0d0604);border-right:2px solid #8b4513;display:flex;flex-direction:column;position:fixed;left:0;top:85px;overflow-y:auto;z-index:900}.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-track{background:#1a0f0a}.sidebar::-webkit-scrollbar-thumb{background:#5a3a2a;border-radius:4px}.sidebar::-webkit-scrollbar-thumb:hover{background:#8b4513}.sidebar-header{padding:20px;border-bottom:1px solid #5a3a2a;flex-shrink:0}.sidebar-header h3{font-family:Cinzel,Georgia,serif;color:#f4e4c1;font-size:18px;margin:0 0 5px;font-weight:700}.sidebar-header p{color:#a0826d;font-size:12px;margin:0;letter-spacing:1px}.nav-category{border-bottom:1px solid #3a2010;flex-shrink:0}.category-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none;background:linear-gradient(90deg,transparent 0%,rgba(139,69,19,.1) 100%)}.category-header:hover{background:linear-gradient(90deg,transparent 0%,rgba(139,69,19,.3) 100%);padding-left:25px}.category-header.expanded{background:linear-gradient(90deg,transparent 0%,rgba(139,69,19,.2) 100%)}.category-label{font-size:13px;font-weight:700;color:#d4a574;text-transform:uppercase;letter-spacing:1px}.category-toggle{color:#8b6f47;font-size:10px;transition:transform .2s}.category-header.expanded .category-toggle{transform:rotate(0)}.category-items{background:#0000004d;padding:5px 0;border-top:1px solid rgba(139,69,19,.2)}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 20px 12px 35px;cursor:pointer;transition:all .2s;border-left:3px solid transparent;-webkit-user-select:none;user-select:none}.nav-item:hover{background:#8b45134d;border-left-color:#8b4513;padding-left:40px}.nav-item.active{background:#8b451380;border-left-color:#d4a574;padding-left:40px}.nav-icon{font-size:18px;flex-shrink:0;display:inline-block;width:20px;text-align:center}.nav-label{color:#e8d4b5;font-size:14px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-help{background:#ffffff14;border:1px solid rgba(212,165,116,.4);color:#e8d4b5;font-size:11px;line-height:1;width:18px;height:18px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;margin-left:6px;flex:0 0 auto}.nav-item.active .nav-label{color:#f4e4c1;font-weight:600}.nav-item.locked{cursor:not-allowed;opacity:.6}.nav-item.locked:hover{background:#8b451326;border-left-color:transparent;padding-left:35px}.nav-lock{font-size:12px;color:#d4a574}.sidebar-footer{margin-top:auto;border-top:1px solid #5a3a2a;padding:10px 0;flex-shrink:0;background:linear-gradient(180deg,transparent 0%,rgba(139,69,19,.1) 100%)}.sidebar-footer .nav-item{padding-left:20px}.sidebar-footer .nav-item:hover,.sidebar-footer .nav-item.active{padding-left:25px}@media(max-width:1024px){.sidebar{width:220px}.sidebar-header{padding:15px}.sidebar-header h3{font-size:16px}.category-header{padding:12px 15px}.nav-item{padding:10px 15px 10px 30px}.nav-item:hover,.nav-item.active{padding-left:35px}.nav-label{font-size:13px}}@media(max-width:768px){.sidebar{width:200px;z-index:950}.sidebar-header{padding:12px}.sidebar-header h3{font-size:14px}.sidebar-header p{font-size:10px}.category-header{padding:10px 12px}.category-label{font-size:11px}.nav-item{padding:8px 12px 8px 25px}.nav-item:hover,.nav-item.active{padding-left:30px}.nav-icon{font-size:16px;width:16px}.nav-label{font-size:12px}}@media(max-width:480px){.sidebar{width:180px}.nav-label{font-size:11px}.category-label{font-size:10px}.nav-item{padding:8px 10px 8px 20px}.nav-item:hover,.nav-item.active{padding-left:25px}.nav-icon{font-size:14px}}.realm-pulse{display:flex;align-items:center;gap:18px;padding:12px 20px;margin:0 0 18px;border-radius:10px;border:1px solid rgba(139,69,19,.6);background:linear-gradient(90deg,#120a06f2,#23140cf2);box-shadow:0 10px 24px #00000059;flex-wrap:wrap}.pulse-item{display:flex;flex-direction:column;gap:4px;min-width:120px}.pulse-label{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:#a0826d}.pulse-value{font-size:16px;font-weight:600;color:#f4e4c1}.pulse-item.good .pulse-value{color:#8dd18d}.pulse-item.bad .pulse-value{color:#d17b6a}.pulse-item.warn .pulse-value{color:#e4c06a}@media(max-width:900px){.realm-pulse{gap:12px}.pulse-item{min-width:100px}}.realm-priorities{margin-bottom:20px;padding:16px 18px;border-radius:10px;border:1px solid rgba(69,123,157,.6);background:linear-gradient(135deg,#0f3460f2,#1a4d6df2);box-shadow:0 10px 24px #00000040}.realm-priorities-header h3{margin:0 0 6px;color:#e94560}.realm-priorities-header p{margin:0 0 12px;color:#a8dadc;font-size:.9rem}.realm-priorities-empty{color:#a8dadc;font-style:italic}.realm-priorities-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.priority-card{border:1px solid rgba(69,123,157,.7);border-radius:8px;padding:12px 14px;background:#0f346099}.priority-card.warning{border-color:#e4c06acc}.priority-card.urgent,.priority-card.critical{border-color:#e94560e6}.priority-header{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.priority-title{color:#f4e4c1;font-weight:600}.priority-reward{color:#90ee90;font-size:.85rem}.priority-description{color:#a8dadc;font-size:.85rem;margin:0 0 10px}.priority-progress{display:flex;align-items:center;gap:8px}.priority-progress-bar{flex:1;height:8px;border-radius:6px;background:#ffffff1a;overflow:hidden}.priority-progress-fill{height:100%;background:linear-gradient(90deg,#457b9d,#e94560);transition:width .3s ease}.priority-progress-value{color:#f4e4c1;font-size:.8rem}.map-view{background:linear-gradient(135deg,#0f3460,#1a4d6d);border-radius:8px;border:1px solid #457b9d}.tactical-map-view .tactical-layout{min-height:620px}.tactical-grid{min-width:0}.tactical-canvas{background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px),radial-gradient(circle at top,#1f3b5f,#0a1428 70%);background-size:40px 40px,40px 40px,cover}.settlement-node{position:absolute;transform:translate(-50%,-50%);cursor:pointer;z-index:5}.dynasty-aura{position:absolute;width:80px;height:80px;border-radius:50%;left:50%;top:50%;transform:translate(-50%,-50%);border:1px solid;filter:blur(1px)}.settlement-pin{width:26px;height:26px;border-radius:50%;border:2px solid #9ca3af;background:#0b1220;display:flex;align-items:center;justify-content:center;position:relative;z-index:2}.settlement-glyph{font-size:.9rem;color:#f9fafb}.settlement-node.selected .settlement-pin{transform:scale(1.15);box-shadow:0 0 12px #facc15a6}.settlement-label{margin-top:6px;background:#030712cc;border:1px solid #334155;border-radius:6px;padding:4px 8px;min-width:110px;text-align:center}.settlement-label strong{display:block;font-size:.82rem;color:#e2e8f0}.settlement-label span{font-size:.72rem;color:#94a3b8}.legend-icon.siege{color:#f97316}.tactical-intel .intel-section{margin-top:14px}.tactical-intel .intel-section h4{margin:0 0 8px;color:#f1f5f9;font-size:.92rem}.intel-list{display:flex;flex-direction:column;gap:6px}.intel-row{display:flex;justify-content:space-between;font-size:.82rem;color:#cbd5e1;background:#08172acc;border:1px solid #334155;border-radius:4px;padding:6px 8px}.chronicle-list .chronicle-row{background:#08172acc;border:1px solid #334155;border-radius:4px;padding:8px}.chronicle-list .chronicle-row p{margin:4px 0 0;color:#cbd5e1;font-size:.78rem;line-height:1.35}.chronicle-cat{font-size:.68rem;letter-spacing:.04em;color:#94a3b8}.chronicle-cat.cat-war{color:#fb923c}.map-container{display:flex;gap:20px;margin-top:20px;height:500px}.map-grid{flex:1;display:flex;flex-direction:column;gap:10px}.map-legend{display:flex;gap:20px;padding:10px;background:#1a4d6d;border-radius:4px;border:1px solid #457b9d;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:8px;color:#a8dadc;font-size:.9rem}.legend-icon{font-size:1.2rem}.legend-icon.settlement{color:#e94560}.legend-icon.character{color:#90ee90}.ws-status{color:#90ee90}.map{flex:1;background:linear-gradient(135deg,#0a1428,#0f3460);border:2px solid #457b9d;border-radius:6px;position:relative;overflow:hidden}.settlement{position:absolute;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;transition:all .3s;left:20%;top:30%;z-index:10}.settlement:nth-child(2){left:40%;top:25%}.settlement:nth-child(3){left:60%;top:35%}.settlement:nth-child(4){left:30%;top:55%}.settlement:nth-child(5){left:70%;top:60%}.settlement-icon{font-size:1.8rem;color:#e94560;text-shadow:0 0 10px rgba(233,69,96,.5);transition:all .3s}.settlement.selected .settlement-icon{font-size:2.2rem;filter:drop-shadow(0 0 8px #e94560)}.settlement-name{background:#1a4d6d;color:#a8dadc;padding:4px 8px;border-radius:3px;font-size:.8rem;border:1px solid #457b9d;white-space:nowrap;opacity:0;transition:opacity .3s}.settlement:hover .settlement-name,.settlement.selected .settlement-name{opacity:1}.population{font-size:.75rem;color:#6b7280;margin-top:2px}.character-marker{position:absolute;width:20px;height:20px;display:flex;align-items:center;justify-content:center;z-index:5;transition:all .3s}.character-dot{font-size:1rem;color:#90ee90;text-shadow:0 0 6px rgba(144,238,144,.5);transition:all .3s}.character-marker:hover .character-dot{font-size:1.3rem;filter:drop-shadow(0 0 4px #90ee90)}.map-sidebar{width:280px;background:#1a4d6d;border:1px solid #457b9d;border-radius:6px;padding:15px;overflow-y:auto;display:flex;flex-direction:column}.map-sidebar h3{color:#e94560;margin:0 0 15px;font-size:1.2rem;border-bottom:1px solid #457b9d;padding-bottom:10px}.settlement-details{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.detail-item{display:flex;justify-content:space-between;padding:8px;background:#0f3460;border-radius:4px;border-left:3px solid #457b9d}.detail-item .label{color:#a8dadc;font-weight:600;font-size:.85rem}.detail-item .value{color:#90ee90;font-weight:600}.settlement-characters{margin-top:auto}.settlement-characters h4{color:#a8dadc;margin:0 0 10px;font-size:.95rem;border-bottom:1px solid #457b9d;padding-bottom:8px}.character-list{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto}.character-entry{background:#0f3460;padding:10px;border-radius:4px;border-left:2px solid #90ee90}.char-name{color:#90ee90;font-weight:600;font-size:.9rem}.char-profession{color:#a8dadc;font-size:.8rem;margin-top:2px}.char-skill{color:#6b7280;font-size:.75rem;margin-top:2px}.character-list .empty{color:#6b7280;font-style:italic;text-align:center;padding:20px}.settlements-panel{margin-top:20px;background:#1a4d6d;border:1px solid #457b9d;border-radius:6px;padding:15px;max-height:200px;overflow:hidden;display:flex;flex-direction:column}.settlements-panel h3{color:#e94560;margin:0 0 10px;font-size:1rem;border-bottom:1px solid #457b9d;padding-bottom:8px}.settlement-scroll{overflow-y:auto;display:flex;flex-direction:column;gap:6px}.settlement-row{background:#0f3460;padding:10px;border-radius:4px;border-left:3px solid #457b9d;cursor:pointer;transition:all .3s;display:flex;justify-content:space-between;align-items:center;gap:10px}.settlement-row:hover{border-left-color:#e94560;background:#1a4d6d}.settlement-row.active{border-left-color:#e94560;background:#1a4d6d;box-shadow:inset 4px 0 #e94560}.row-name{flex:1;color:#a8dadc;font-weight:600;font-size:.9rem}.row-pop{color:#90ee90;font-size:.8rem;white-space:nowrap}.row-ruler{color:#6b7280;font-size:.8rem;white-space:nowrap}.map-sidebar::-webkit-scrollbar,.character-list::-webkit-scrollbar,.settlement-scroll::-webkit-scrollbar{width:6px}.map-sidebar::-webkit-scrollbar-track,.character-list::-webkit-scrollbar-track,.settlement-scroll::-webkit-scrollbar-track{background:#0f3460}.map-sidebar::-webkit-scrollbar-thumb,.character-list::-webkit-scrollbar-thumb,.settlement-scroll::-webkit-scrollbar-thumb{background:#457b9d;border-radius:3px}.map-sidebar::-webkit-scrollbar-thumb:hover,.character-list::-webkit-scrollbar-thumb:hover,.settlement-scroll::-webkit-scrollbar-thumb:hover{background:#e94560}@media(max-width:1024px){.map-container{height:600px}.map-sidebar{width:240px}}@media(max-width:768px){.map-container{flex-direction:column;height:auto}.map{height:300px}.map-sidebar{width:100%;max-height:250px}.settlements-panel{max-height:200px}}.guided-bubble{position:fixed;right:24px;bottom:24px;z-index:2000;pointer-events:none}.guided-bubble-card{width:min(360px,90vw);background:#0f0f0ff2;border:1px solid rgba(230,197,107,.45);border-radius:12px;padding:14px 16px;color:#f5f0df;box-shadow:0 10px 30px #00000073;pointer-events:auto}.guided-bubble-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.guided-bubble-title{font-weight:600;font-size:1rem;color:#f2dfb5}.guided-bubble-close{background:transparent;border:none;color:#c7b58c;cursor:pointer;font-size:.9rem}.guided-bubble-message{margin:0 0 12px;font-size:.9rem;line-height:1.4;color:#e8dcc2}.guided-bubble-action{background:#e6c56b;color:#201a0c;border:none;padding:8px 12px;border-radius:8px;cursor:pointer;font-weight:600}.character-sheet{background:linear-gradient(135deg,#0f3460,#1a4d6d);border-radius:8px;border:1px solid #457b9d;padding:20px}.sheet-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-top:20px}.card{background:#1a4d6d;border:1px solid #457b9d;border-radius:6px;padding:20px;transition:all .3s}.card:hover{border-color:#e94560;box-shadow:0 4px 12px #e9456033}.card h3{color:#e94560;font-size:1.1rem;margin:0 0 15px;border-bottom:1px solid #457b9d;padding-bottom:10px}.card.full-width{grid-column:1 / -1}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:15px}.info-item{display:flex;flex-direction:column;gap:5px}.info-item .label{color:#a8dadc;font-size:.85rem;font-weight:600;text-transform:uppercase}.info-item .value{color:#90ee90;font-weight:600;word-break:break-word}.info-item .value.alive{color:#90ee90}.info-item .value.dead{color:#ff6b6b}.health-display{background:#0f3460;border-radius:4px;height:30px;overflow:hidden;border:1px solid #457b9d;margin-bottom:10px}.health-bar{height:100%;transition:width .3s ease;box-shadow:inset 0 2px 4px #0000004d}.health-text{text-align:center;color:#a8dadc;font-weight:600;font-size:.95rem}.currency-display{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px;background:linear-gradient(135deg,#0f3460,#1a4d6d);border-radius:6px;border:1px solid #457b9d}.gold-amount{font-size:2rem;font-weight:700;color:gold;text-shadow:0 0 10px rgba(255,215,0,.3)}.currency-label{color:#a8dadc;font-size:.9rem;font-weight:600}.profession-info{display:flex;flex-direction:column;gap:10px}.profession-name{color:#90ee90;font-weight:600;font-size:1.1rem}.profession-tier{color:#a8dadc;font-size:.9rem}.skill-display{display:flex;flex-direction:column;gap:15px}.skill-bar-container{background:#0f3460;border-radius:4px;height:20px;overflow:hidden;border:1px solid #457b9d}.skill-bar{height:100%;background:linear-gradient(90deg,#457b9d,#e94560);transition:width .3s ease;box-shadow:inset 0 1px 2px #0000004d}.skill-info{display:flex;flex-direction:column;gap:5px}.skill-level{color:#a8dadc;font-size:.9rem}.skill-level strong{color:#90ee90;font-size:1.1rem}.skill-rank{color:#e94560;font-weight:600;font-size:.95rem}.skill-xp{color:#6b7280;font-size:.85rem}.estate-info{display:flex;flex-direction:column;gap:12px}.estate-item{display:flex;justify-content:space-between;align-items:center;padding:10px;background:#0f3460;border-radius:4px;border-left:3px solid #457b9d}.estate-item .label{color:#a8dadc;font-weight:600;font-size:.9rem}.estate-item .value{color:#90ee90;font-weight:600}.inventory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.inventory-item{background:#0f3460;border:1px solid #457b9d;border-radius:6px;padding:12px;text-align:center;transition:all .3s}.inventory-item:hover{border-color:#e94560;box-shadow:0 4px 8px #e9456033}.item-name{color:#a8dadc;font-size:.9rem;font-weight:600;margin-bottom:8px}.item-quantity{color:#90ee90;font-size:1.3rem;font-weight:700}.empty-state{text-align:center;color:#6b7280;padding:20px;font-style:italic}.profession-path{display:flex;flex-direction:column;gap:18px}.profession-path-title{color:#a8dadc;font-size:.9rem;font-weight:600;text-transform:uppercase;margin-bottom:10px}.profession-path-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.profession-card{border:1px solid #457b9d;border-radius:8px;padding:12px;background:#0f3460b3;display:flex;flex-direction:column;gap:6px;min-height:90px}.profession-card.active{border-color:#90ee90;box-shadow:0 6px 14px #90ee9033}.profession-card.available{border-color:#457b9d}.profession-card.locked{border-color:#6b7280;color:#9ca3af;background:#0f346059;position:relative}.profession-card.locked .profession-name,.profession-card.locked .profession-status{color:#9ca3af}.profession-requirement{font-size:.75rem;color:#a8dadc;opacity:0;transition:opacity .2s ease}.profession-card.locked:hover .profession-requirement{opacity:1}@media(max-width:768px){.sheet-grid{grid-template-columns:1fr}.card.full-width{grid-column:1}.health-bar,.skill-bar-container{height:25px}.gold-amount{font-size:1.5rem}.inventory-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}}.view-container{padding:20px;color:#a8dadc;min-height:calc(100vh - 200px)}.view-container h2{color:#e94560;font-size:1.8rem;margin:0 0 20px;border-bottom:2px solid #457b9d;padding-bottom:10px}.error-banner{background:#8b0000;color:#ffcccb;padding:12px 15px;border-radius:4px;margin-bottom:20px;border-left:4px solid #ff6b6b}.tabs{display:flex;gap:10px;margin-bottom:20px;border-bottom:2px solid #457b9d;flex-wrap:wrap}.tab{background:none;border:none;color:#a8dadc;padding:10px 20px;cursor:pointer;font-size:.95rem;font-weight:500;border-bottom:3px solid transparent;transition:all .3s}.tab:hover{color:#e94560}.tab.active{color:#e94560;border-bottom-color:#e94560}.market-board{background:linear-gradient(135deg,#0f3460,#1a4d6d);border-radius:8px;border:1px solid #457b9d}.market-header{display:flex;align-items:center;gap:12px;justify-content:space-between}.market-status-badge{padding:6px 12px;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:1px;color:#0f172a;text-transform:uppercase;box-shadow:0 0 12px #90ee9066}.market-status-badge.stable{background:#90ee90;box-shadow:0 0 14px #90ee908c}.market-status-badge.unstable{background:#facc15;box-shadow:0 0 16px #facc158c}.market-status-badge.crisis{background:#f87171;box-shadow:0 0 18px #f8717199}.price-table{margin-top:20px}.price-table h3{color:#a8dadc;margin:0 0 15px}.price-table table{width:100%;border-collapse:collapse;font-size:.95rem}.price-table thead{background:#1a4d6d;border-bottom:2px solid #457b9d}.price-table th{padding:12px;text-align:left;color:#e94560;font-weight:600}.price-table td{padding:12px;border-bottom:1px solid #457b9d}.price-table .resource-name{color:#a8dadc;font-weight:500}.price-table .price{color:#90ee90;font-weight:600}.price-table .change{font-weight:600}.price-table .change.up{color:#90ee90}.price-table .change.down{color:#ff6b6b}.orders-section{margin-top:20px}.filter-controls{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}.filter-controls button{background:#1a4d6d;border:1px solid #457b9d;color:#a8dadc;padding:8px 16px;border-radius:4px;cursor:pointer;transition:all .3s;font-weight:500}.filter-controls button:hover{border-color:#e94560;color:#e94560}.filter-controls button.active{background:#e94560;color:#fff;border-color:#e94560}.order-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:15px}.order-card{background:#1a4d6d;border:1px solid #457b9d;border-radius:6px;padding:15px;transition:all .3s}.order-card:hover{border-color:#e94560;box-shadow:0 4px 12px #e9456033}.order-card.sell{border-left:4px solid #90ee90}.order-card.buy{border-left:4px solid #6b9eff}.order-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.order-type{font-weight:600;color:#e94560;font-size:.9rem}.seller{color:#a8dadc;font-size:.85rem}.order-details{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.order-details>div:first-child{flex:1}.quantity{display:block;color:#a8dadc;font-size:.85rem;margin-top:2px}.price-info{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.price-info .price{color:#90ee90;font-weight:700;font-size:1.1rem}.price-info .gold{color:#a8dadc;font-size:.75rem}.empty-state{text-align:center;padding:40px 20px;color:#6b7280;font-style:italic}.btn-small{padding:8px 12px;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;font-weight:600;transition:all .3s}.btn-accept{background:#457b9d;color:#a8dadc;width:100%;margin-top:10px}.btn-accept:hover{background:#5a9bc5;color:#fff}.btn-cancel{background:none;border:none;color:#ff6b6b;cursor:pointer;font-weight:600;padding:5px 10px;transition:color .3s}.btn-cancel:hover{color:#f88}@media(max-width:768px){.view-container{padding:15px}.tabs{overflow-x:auto}.order-list{grid-template-columns:1fr}.order-details{flex-direction:column;align-items:flex-start;gap:8px}.price-info{align-items:flex-start}}.action-banner{padding:10px 14px;border-radius:6px;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between;font-size:.9rem;font-weight:600}.action-ok{background:#4ab74a2e;border:1px solid #4ab74a;color:#8fe88f}.action-err{background:#dc35452e;border:1px solid #dc3545;color:#ff8080}.new-order-form{max-width:420px;margin:0 auto}.new-order-form h3{margin-bottom:16px;color:#a8dadc}.order-type-toggle{display:flex;gap:8px;margin-bottom:16px}.order-type-toggle button{flex:1;padding:10px;background:#1a1a2e;border:1px solid #333;color:#ccc;cursor:pointer;border-radius:6px;font-size:.95rem;transition:all .2s}.order-type-toggle button.active{background:#2a4a6e;border-color:#457b9d;color:#a8dadc;font-weight:700}.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.form-row label{font-size:.85rem;color:#888;text-transform:uppercase;letter-spacing:.05em}.form-row input,.form-row select{padding:9px 12px;background:#1a1a2e;border:1px solid #333;border-radius:6px;color:#e0e0e0;font-size:.95rem}.form-row input:focus,.form-row select:focus{outline:none;border-color:#457b9d}.order-total{padding:10px 14px;background:#1a1a2e;border:1px solid #444;border-radius:6px;color:gold;font-weight:700;margin-bottom:16px}.btn-place-order{width:100%;padding:12px;background:#2a5c2a;border:1px solid #4ab74a;border-radius:6px;color:#8fe88f;font-size:1rem;font-weight:700;cursor:pointer;transition:background .2s}.btn-place-order:hover:not(:disabled){background:#357a35}.btn-place-order:disabled{opacity:.5;cursor:not-allowed}.launch-form{background:#1a1a2e;border:1px solid #457b9d;border-radius:8px;padding:16px;margin-top:16px}.launch-form h4{margin:0 0 12px;color:#a8dadc}.form-actions{display:flex;gap:10px;margin-top:12px}.chat-view{display:flex;flex-direction:column;padding:20px}.chat-container{display:flex;gap:20px;flex:1;min-height:500px}.chat-main{flex:1;display:flex;flex-direction:column;background:linear-gradient(135deg,#0f3460,#1a4d6d);border:1px solid #457b9d;border-radius:8px;overflow:hidden}.message-list{flex:1;overflow-y:auto;padding:15px;display:flex;flex-direction:column;gap:10px}.message{background:#1a4d6d;padding:12px;border-radius:6px;border-left:3px solid #457b9d}.message .sender{color:#e94560;font-weight:600;font-size:.9rem}.message .timestamp{color:#6b7280;font-size:.75rem;margin-left:10px}.message .text{color:#a8dadc;margin:8px 0 0;word-wrap:break-word}.message-input-form{border-top:1px solid #457b9d;padding:15px;background:#0f3460}.input-group{display:flex;gap:10px;margin-bottom:8px}.message-input{flex:1;background:#1a4d6d;border:1px solid #457b9d;color:#a8dadc;padding:10px 12px;border-radius:4px;font-size:.95rem}.message-input:focus{outline:none;border-color:#e94560;box-shadow:0 0 5px #e945604d}.btn-send{background:#e94560;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-weight:600;transition:all .3s}.btn-send:hover:not(:disabled){background:#f54d6d;transform:translateY(-2px)}.btn-send:disabled{opacity:.6;cursor:not-allowed}.input-footer{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:#6b7280}.ws-status{font-weight:600}.ws-status.connected{color:#90ee90}.ws-status.disconnected{color:#ff6b6b}.char-count{color:#a8dadc}.chat-sidebar{width:250px;background:linear-gradient(135deg,#0f3460,#1a4d6d);border:1px solid #457b9d;border-radius:8px;padding:15px;overflow-y:auto}.online-users h4{color:#e94560;margin:0 0 15px;font-size:.95rem;border-bottom:1px solid #457b9d;padding-bottom:10px}.user-list{display:flex;flex-direction:column;gap:8px}.user-item{display:flex;gap:10px;align-items:center;padding:8px;border-radius:4px;background:#1a4d6d;transition:all .3s}.user-item:hover{background:#234566;border-left:3px solid #e94560;padding-left:5px}.status-dot{color:#90ee90;font-size:.6rem}.user-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.user-info .username{color:#a8dadc;font-weight:500;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-info .profession{color:#6b7280;font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message-list::-webkit-scrollbar,.chat-sidebar::-webkit-scrollbar{width:8px}.message-list::-webkit-scrollbar-track,.chat-sidebar::-webkit-scrollbar-track{background:#0f3460}.message-list::-webkit-scrollbar-thumb,.chat-sidebar::-webkit-scrollbar-thumb{background:#457b9d;border-radius:4px}.message-list::-webkit-scrollbar-thumb:hover,.chat-sidebar::-webkit-scrollbar-thumb:hover{background:#e94560}@media(max-width:768px){.chat-container{flex-direction:column;gap:15px}.chat-sidebar{width:100%;max-height:300px}.message-list{min-height:300px}}.estate-dashboard{background:linear-gradient(135deg,#0f3460,#1a4d6d);border-radius:8px;border:1px solid #457b9d}.empty-estate{text-align:center;padding:60px 20px;color:#a8dadc}.empty-estate p{font-size:1.2rem;margin-bottom:10px}.empty-estate .subtext{color:#6b7280;font-size:.95rem;font-style:italic}.estate-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;padding:20px;margin-top:20px}.estate-card{background:#1a4d6d;border:1px solid #457b9d;border-radius:6px;padding:20px;transition:all .3s}.estate-card:hover{border-color:#e94560;box-shadow:0 4px 12px #e9456033}.estate-card.full-width{grid-column:1 / -1}.estate-card h3{color:#e94560;margin:0 0 15px;font-size:1.1rem;border-bottom:1px solid #457b9d;padding-bottom:10px}.overview-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.overview-item{display:flex;flex-direction:column;gap:5px;background:#0f3460;padding:12px;border-radius:4px;border-left:3px solid #457b9d}.overview-item .label{color:#a8dadc;font-size:.85rem;font-weight:600;text-transform:uppercase}.overview-item .value{color:#90ee90;font-weight:600;font-size:1.1rem}.overview-item .value.large{font-size:1.4rem}.dynasty-info{display:flex;flex-direction:column;gap:15px}.info-block{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#0f3460;border-radius:4px;border-left:3px solid #457b9d}.info-block .label{color:#a8dadc;font-weight:600;font-size:.9rem}.info-block .value{color:#90ee90;font-weight:600}.title-badge{background:linear-gradient(135deg,#e94560,#f54d6d);padding:6px 12px;border-radius:20px;font-size:.9rem;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.fortification-display{display:flex;flex-direction:column;gap:15px}.fort-bar{background:#0f3460;border-radius:6px;height:30px;overflow:hidden;border:1px solid #457b9d}.fort-progress{height:100%;background:linear-gradient(90deg,#457b9d,#90ee90);transition:width .5s ease;box-shadow:inset 0 2px 4px #0000004d}.fort-info{display:flex;justify-content:space-between;align-items:center;gap:20px}.fort-level{color:#90ee90;font-weight:600;font-size:1rem}.fort-description{color:#a8dadc;font-size:.9rem;text-align:right}.production-list{display:flex;flex-direction:column;gap:10px}.storage-hud{gap:12px}.storage-row{background:#0f3460;border:1px solid #457b9d;border-radius:4px;padding:10px}.storage-row-header{display:flex;justify-content:space-between;color:#a8dadc;font-size:.85rem;margin-bottom:6px}.storage-track{height:10px;background:#102b4b;border-radius:99px;overflow:hidden}.storage-fill{height:100%;transition:width .25s ease}.storage-food{background:linear-gradient(90deg,#22c55e,#86efac)}.storage-ore{background:linear-gradient(90deg,#64748b,#cbd5e1)}.storage-gold{background:linear-gradient(90deg,#f59e0b,#fde68a)}.storage-tools-note{color:#90ee90;font-size:.82rem;margin:2px 0 0}.ledger-card{border-color:#b48a52}.industrial-ledger{background:linear-gradient(180deg,#f1e3c5,#e4cfaa);border:1px solid #b48a52;border-radius:6px;color:#3d2a13;padding:12px}.ledger-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px}.ledger-cell{background:#fff8e673;border:1px solid rgba(97,61,26,.25);border-radius:4px;padding:8px}.ledger-k{font-size:.72rem;color:#6a4a26;text-transform:uppercase;letter-spacing:.04em}.ledger-v{font-size:.95rem;color:#2f1e0f;font-weight:700;margin-top:2px}.ledger-overflow{margin-top:10px;padding-top:8px;border-top:1px dashed rgba(97,61,26,.5);font-size:.85rem;color:#5b3d1f}.ledger-health{margin-top:10px;display:grid;gap:8px}.ledger-health-row{display:grid;grid-template-columns:70px 1fr 140px;gap:8px;align-items:center}.ledger-health-label{font-size:.8rem;color:#4f341a;font-weight:600}.ledger-health-track{height:10px;background:#5a3c1e33;border-radius:999px;overflow:hidden}.ledger-health-fill{height:100%}.ledger-health-fill.food{background:linear-gradient(90deg,#4caf50,#8bc34a)}.ledger-health-fill.gold{background:linear-gradient(90deg,#eab308,#facc15)}.ledger-health-fill.ore{background:linear-gradient(90deg,#64748b,#cbd5e1)}.ledger-health-value{font-size:.78rem;color:#4f341a;text-align:right}.ledger-warning{margin-top:8px;padding:8px;background:#dc26261f;border:1px solid rgba(220,38,38,.35);color:#7f1d1d;border-radius:4px;font-size:.82rem;font-weight:600}.placeholder{text-align:center;color:#6b7280;padding:20px;font-style:italic}.management-actions{display:flex;flex-direction:column;gap:10px;margin-bottom:15px}.action-btn{background:linear-gradient(135deg,#457b9d,#5a9bc5);color:#fff;border:none;padding:12px 20px;border-radius:4px;cursor:pointer;font-weight:600;transition:all .3s;font-size:.95rem}.action-btn:hover:not(:disabled){background:linear-gradient(135deg,#5a9bc5,#6ba8d3);transform:translateY(-2px);box-shadow:0 4px 12px #e9456033}.action-btn:disabled{opacity:.5;cursor:not-allowed}.note{color:#6b7280;font-size:.85rem;font-style:italic;text-align:center}.tenants-list{display:flex;flex-direction:column;gap:10px}.events-timeline{display:flex;flex-direction:column;gap:15px;max-height:300px;overflow-y:auto}.timeline-item{display:flex;gap:15px;justify-content:space-between;align-items:flex-start;padding:12px;background:#0f3460;border-radius:4px;border-left:3px solid #457b9d;transition:all .3s}.timeline-item-pending{border-left-color:#f59e0b;background:linear-gradient(90deg,#f59e0b1f,#0f3460 45%)}.timeline-main{display:flex;flex-direction:column;gap:6px}.timeline-actions{display:flex;flex-wrap:wrap;gap:8px}.crier-btn{padding:8px 12px;font-size:.8rem}.timeline-result{color:#90ee90;font-size:.84rem}.timeline-item:hover{border-left-color:#e94560;background:#1a4d6d}.timeline-date{color:#6b7280;font-size:.85rem;font-weight:600;white-space:nowrap;min-width:80px}.timeline-event{color:#a8dadc;font-size:.95rem}.events-timeline::-webkit-scrollbar{width:6px}.events-timeline::-webkit-scrollbar-track{background:#0f3460}.events-timeline::-webkit-scrollbar-thumb{background:#457b9d;border-radius:3px}.events-timeline::-webkit-scrollbar-thumb:hover{background:#e94560}@media(max-width:768px){.estate-grid{grid-template-columns:1fr;padding:15px;gap:15px}.overview-grid{grid-template-columns:1fr}.fort-info{flex-direction:column;align-items:flex-start}.fort-description{text-align:left}}.event-log{background:linear-gradient(135deg,#0f3460,#1a4d6d);border-radius:8px;border:1px solid #457b9d;display:flex;flex-direction:column;gap:20px}.log-controls{padding:20px;background:#1a4d6d;border-bottom:1px solid #457b9d;border-radius:6px 6px 0 0;display:flex;flex-direction:column;gap:15px}.search-box{display:flex}.search-input{width:100%;padding:10px 15px;background:#0f3460;border:1px solid #457b9d;border-radius:4px;color:#a8dadc;font-size:.95rem;transition:border-color .3s}.search-input::placeholder{color:#6b7280}.search-input:focus{outline:none;border-color:#e94560;box-shadow:0 0 8px #e9456033}.type-filters{display:flex;gap:8px;flex-wrap:wrap}.filter-btn{background:#0f3460;border:1px solid #457b9d;color:#a8dadc;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .3s;white-space:nowrap}.filter-btn:hover{border-color:#e94560;color:#e94560}.filter-btn.active{background:#e94560;border-color:#e94560;color:#fff;box-shadow:0 4px 8px #e945604d}.events-list{padding:20px;display:flex;flex-direction:column;gap:15px;max-height:600px;overflow-y:auto;flex:1}.empty-log{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#6b7280;text-align:center}.empty-log p{margin:0;font-size:1.1rem}.empty-log .hint{font-size:.9rem;margin-top:10px;font-style:italic}.event-item{background:#1a4d6d;border:1px solid #457b9d;border-left:4px solid #90ee90;border-radius:6px;padding:15px;transition:all .3s}.event-item:hover{box-shadow:0 4px 12px #e9456033;background:#234566}.event-header{display:flex;gap:12px;margin-bottom:10px;align-items:flex-start}.event-icon{font-size:1.4rem;flex-shrink:0}.event-title-group{flex:1;display:flex;justify-content:space-between;align-items:baseline;gap:10px}.event-title{color:#a8dadc;margin:0;font-size:1rem;font-weight:600}.event-time{color:#6b7280;font-size:.8rem;white-space:nowrap}.event-description{color:#a8dadc;font-size:.95rem;margin:8px 0 0 40px}.event-meta{display:flex;gap:15px;margin-top:10px;margin-left:40px;font-size:.8rem}.event-type{font-weight:600;text-transform:uppercase;letter-spacing:.5px}.event-id{color:#6b7280}.events-list::-webkit-scrollbar{width:8px}.events-list::-webkit-scrollbar-track{background:#0f3460}.events-list::-webkit-scrollbar-thumb{background:#457b9d;border-radius:4px}.events-list::-webkit-scrollbar-thumb:hover{background:#e94560}.log-footer{padding:15px 20px;background:#1a4d6d;border-top:1px solid #457b9d;border-radius:0 0 6px 6px}.log-info{margin:0;color:#a8dadc;font-size:.9rem;text-align:center}@media(max-width:768px){.log-controls{padding:15px;gap:10px}.type-filters{gap:6px}.filter-btn{padding:6px 10px;font-size:.8rem}.events-list{padding:15px;max-height:500px;gap:10px}.event-item{padding:12px}.event-title-group{flex-direction:column;gap:4px}.event-description,.event-meta{margin-left:30px}.event-icon{font-size:1.2rem}}.production-view{padding:20px}.yield-card{border:1px solid rgba(139,69,19,.6);background:linear-gradient(135deg,#1c100ae6,#0a0604f2);box-shadow:0 12px 28px #00000059}.yield-content{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.yield-value{display:flex;align-items:baseline;gap:10px}.yield-amount{font-size:32px;font-weight:700;color:#f4e4c1}.yield-resource{font-size:18px;color:#d4a574;text-transform:uppercase;letter-spacing:1px}.yield-meta{font-size:12px;color:#a0826d}.yield-card.flash{animation:yield-flash 1.2s ease-out}@keyframes yield-flash{0%{box-shadow:0 0 #f4e4c100;border-color:#8b451399}20%{box-shadow:0 0 18px #f4e4c180;border-color:#f4e4c1e6}to{box-shadow:0 12px 28px #00000059;border-color:#8b451399}}.inventory-view{padding:20px}.sell-status{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-radius:6px;margin-bottom:14px;font-size:.9rem}.sell-status-ok{background:#1a3a1a;border:1px solid #4caf50;color:#81c784}.sell-status-err{background:#3a1a1a;border:1px solid #e57373;color:#ef9a9a}.sell-status-close{background:none;border:none;color:inherit;cursor:pointer;font-size:1rem;padding:0 0 0 12px}.sell-modal-overlay{position:fixed;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:999}.sell-modal{background:#1e1a14;border:1px solid #8b6914;border-radius:8px;padding:24px;width:340px;max-width:95vw;box-shadow:0 8px 32px #0009}.sell-modal h3{margin:0 0 18px;color:#d4a849;font-size:1.05rem}.sell-form-row{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}.sell-form-row label{font-size:.85rem;color:#b8a070}.sell-hint{color:#7a6040;font-size:.8rem}.sell-form-row input{background:#2a2418;border:1px solid #5a4a2a;color:#e8d5a0;padding:8px 10px;border-radius:4px;font-size:.95rem}.sell-form-row input:focus{outline:none;border-color:#d4a849}.sell-total{font-size:.9rem;color:#d4a849;margin-bottom:14px}.sell-form-error{color:#ef9a9a;font-size:.85rem;margin-bottom:10px}.sell-modal-actions{display:flex;gap:10px;justify-content:flex-end}.btn-cancel-form{background:#2a2418;border:1px solid #5a4a2a;color:#b8a070;padding:8px 16px;border-radius:4px;cursor:pointer}.btn-cancel-form:hover{border-color:#8b6914;color:#d4a849}.btn-sell-confirm{background:#4a3a0a;border:1px solid #d4a849;color:#d4a849;padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:600}.btn-sell-confirm:hover:not(:disabled){background:#6a5a1a}.btn-sell-confirm:disabled{opacity:.5;cursor:not-allowed}.btn-sell-row{background:#2a3a0a;border:1px solid #5a7a1a;color:#a8c84a;padding:4px 10px;border-radius:4px;cursor:pointer;font-size:.8rem;white-space:nowrap}.btn-sell-row:hover:not(:disabled){background:#3a5a0a;border-color:#7a9a2a}.btn-sell-row:disabled{opacity:.4;cursor:not-allowed}.price-trends-view,.war-room-view{padding:20px}.war-map-container{display:flex;flex-direction:column;gap:16px;padding:20px;background:#0a0a0a;border:1px solid #2a2a2a;border-radius:8px}.war-map-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #333;padding-bottom:12px}.war-map-header h2{margin:0;color:#fff;font-size:1.4rem}.war-map-legend{display:flex;gap:20px;font-size:.85rem;color:#aaa}.legend-war{color:#c0392b;font-weight:700;margin-right:4px}.legend-alliance{color:#27ae60;font-weight:700;margin-right:4px}.legend-settlement{color:gold;margin-right:4px}.war-map-svg{width:100%;max-width:800px;height:auto;background:#0d0d0d;border:1px solid #333;border-radius:6px;margin:10px 0}.war-line{cursor:pointer;transition:opacity .2s}.war-line:hover{opacity:1;filter:drop-shadow(0 0 6px rgba(192,57,43,.8))}.alliance-line{cursor:pointer;transition:opacity .2s}.alliance-line:hover{opacity:1;filter:drop-shadow(0 0 6px rgba(39,174,96,.8))}.settlement-node{cursor:pointer;transition:all .2s}.settlement-node.home{animation:homePulse 1.6s ease-in-out infinite;filter:drop-shadow(0 0 10px rgba(245,197,66,.9))}.settlement-node.home:hover{r:18}.settlement-node:hover{r:18;filter:drop-shadow(0 0 8px rgba(255,255,255,.6))}.settlement-label{pointer-events:none;font-weight:500}.dynasty-label{pointer-events:none;font-style:italic}@keyframes homePulse{0%{opacity:.85;filter:drop-shadow(0 0 6px rgba(245,197,66,.6))}50%{opacity:1;filter:drop-shadow(0 0 12px rgba(245,197,66,.95))}to{opacity:.85;filter:drop-shadow(0 0 6px rgba(245,197,66,.6))}}.war-map-tooltip{position:absolute;background:#0a0a0af2;border:1px solid #c0392b;border-radius:4px;padding:8px 12px;color:#fff;font-size:.8rem;line-height:1.4;white-space:pre-wrap;z-index:1000;box-shadow:0 4px 12px #000c;pointer-events:none}.war-map-message{text-align:center;padding:40px;color:#666;font-size:1rem;font-style:italic}.war-map-empty{padding:60px 20px;text-align:center;color:#666;font-size:1rem}.war-map-stats{display:flex;gap:30px;padding:12px;background:#ffffff05;border:1px solid #2a2a2a;border-radius:6px;color:#aaa;font-size:.9rem}.war-map-stats div{display:flex;align-items:center}.war-map-grid-panel{margin-top:12px;padding:12px;border:1px solid #3c2f20;border-radius:8px;background:linear-gradient(180deg,#1c140d,#120d08)}.war-map-grid-panel h3{margin:0 0 10px;color:#f2dfb5;font-size:1rem}.war-map-grid{display:grid;grid-template-columns:repeat(10,minmax(56px,1fr));gap:6px}.war-map-grid-cell{min-height:34px;border:1px dashed #6a5a40;background:#251a11;color:#d7c39a;font-size:.7rem;border-radius:4px;cursor:pointer}.war-map-grid-cell.occupied{background:#3d2b1d;border-style:solid;cursor:not-allowed}.war-map-grid-cell.claimed-mine{background:#1f3a23;border-style:solid;cursor:not-allowed}.war-map-grid-cell.claimed-other{background:#4a1f1f;border-style:solid;cursor:not-allowed}.war-map-claim-msg{margin-top:8px;color:#e2cf9f;font-size:.85rem}.diplomacy-view,.faction-ledger-view{padding:20px}.character-registry-view{padding:20px;color:#d4af37}.view-header{margin-bottom:30px;border-bottom:2px solid #8b7355;padding-bottom:15px}.view-header h2{margin:0;font-size:28px;color:wheat;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.view-header p{margin:5px 0 0;color:#d4af37;font-size:14px}.error-banner{background-color:#8b0000;color:#fcc;padding:12px;border-radius:4px;margin-bottom:20px;border-left:4px solid #ff4444}.registry-controls{display:flex;gap:15px;margin-bottom:20px}.search-input,.sort-select{padding:10px;background-color:#1a1410;border:1px solid #8b7355;color:#d4af37;border-radius:4px;font-size:14px}.search-input{flex:1;min-width:300px}.search-input::placeholder{color:#8b7355}.search-input:focus,.sort-select:focus{outline:none;border-color:#d4af37;box-shadow:0 0 8px #d4af374d}.registry-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:25px;padding:15px;background-color:#1a141080;border:1px solid #8b7355;border-radius:4px}.stat{display:flex;justify-content:space-between;align-items:center}.stat-label{color:#8b7355;font-size:12px;text-transform:uppercase}.stat-value{font-weight:700;color:wheat;font-size:18px}.loading,.no-results{text-align:center;padding:40px;color:#8b7355;font-size:16px}.character-table{overflow-x:auto;border:1px solid #8b7355;border-radius:4px;background-color:#1a14104d}.character-table table{width:100%;border-collapse:collapse;font-size:14px}.character-table thead{background-color:#8b73554d;border-bottom:2px solid #8b7355}.character-table th{padding:12px;text-align:left;color:wheat;font-weight:700;text-transform:uppercase;font-size:12px}.character-table td{padding:12px;border-bottom:1px solid #3d3228;color:#d4af37}.character-table tr:hover{background-color:#d4af371a}.character-table tr.deceased{opacity:.6;background-color:#8b00001a}.character-table .name{font-weight:700;color:wheat}.character-table .gold{color:gold;font-weight:700}.health-bar{position:relative;height:20px;background-color:#1a1410;border:1px solid #8b7355;border-radius:3px;overflow:hidden;min-width:100px}.health-fill{height:100%;background:linear-gradient(90deg,#228b22,#32cd32);transition:width .3s ease}.health-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:11px;font-weight:700;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.8)}.status{padding:4px 8px;border-radius:3px;font-size:12px;font-weight:700}.status.alive{background-color:#228b224d;color:#90ee90}.status.dead{background-color:#8b00004d;color:#f66}.status.incapacitated{background-color:#b8860b4d;color:gold}.pagination{display:flex;justify-content:center;align-items:center;gap:20px;margin-top:25px;padding-top:20px;border-top:1px solid #8b7355}.btn-prev,.btn-next{padding:10px 20px;background-color:#8b7355;color:wheat;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:700;transition:background-color .3s ease}.btn-prev:hover:not(:disabled),.btn-next:hover:not(:disabled){background-color:#d4af37;color:#1a1410}.btn-prev:disabled,.btn-next:disabled{opacity:.5;cursor:not-allowed}.page-info{color:#d4af37;font-weight:700}.chronicle-view{padding:20px;max-width:1200px;margin:0 auto}.chronicle-header{margin-bottom:25px;border-bottom:2px solid #5a3a2a;padding-bottom:15px}.chronicle-header h2{font-family:Cinzel,Georgia,serif;color:#f4e4c1;font-size:28px;margin:0 0 8px;font-weight:700}.chronicle-subtitle{color:#a0826d;font-size:14px;margin:0}.chronicle-toggle{margin-top:10px;display:inline-flex;align-items:center;gap:8px;color:#f4e4c1;font-size:12px;text-transform:uppercase;letter-spacing:.6px}.chronicle-toggle input{accent-color:#8b4513}.chronicle-controls{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}.chronicle-search{flex:1;min-width:200px;padding:10px 12px;background:#1a0f0a;border:1px solid #5a3a2a;color:#f4e4c1;border-radius:4px;font-size:14px;font-family:inherit}.chronicle-search:focus{outline:none;border-color:#8b4513;box-shadow:0 0 8px #8b45134d}.chronicle-search::placeholder{color:#7a6450}.chronicle-filter{padding:10px 12px;background:#1a0f0a;border:1px solid #5a3a2a;color:#f4e4c1;border-radius:4px;font-size:14px;font-family:inherit;cursor:pointer}.chronicle-filter:focus{outline:none;border-color:#8b4513}.chronicle-clear{padding:10px 20px;background:#8b4513;color:#f4e4c1;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:700;transition:all .2s}.chronicle-clear:hover:not(:disabled){background:sienna;box-shadow:0 2px 8px #8b451366}.chronicle-clear:disabled{opacity:.5;cursor:not-allowed}.chronicle-stats{display:flex;gap:20px;margin-bottom:20px;padding:15px 20px;background:#2d1810;border:1px solid #5a3a2a;border-radius:8px}.stat-item{display:flex;flex-direction:column;gap:5px}.stat-label{font-size:12px;color:#a0826d;text-transform:uppercase;letter-spacing:1px;font-weight:600}.stat-value{font-size:20px;font-weight:700;color:#f4e4c1;font-family:Cinzel,Georgia,serif}.chronicle-events{display:flex;flex-direction:column;gap:10px;max-height:600px;overflow-y:auto;padding-right:8px}.chronicle-events::-webkit-scrollbar{width:8px}.chronicle-events::-webkit-scrollbar-track{background:#1a0f0a;border-radius:4px}.chronicle-events::-webkit-scrollbar-thumb{background:#5a3a2a;border-radius:4px}.chronicle-events::-webkit-scrollbar-thumb:hover{background:#8b4513}.event-entry{background:#1a0f0a;border:1px solid #5a3a2a;border-radius:6px;padding:15px;transition:all .2s}.event-entry:hover{border-color:#8b4513;background:#2d1810;box-shadow:0 2px 8px #8b451333}.event-meta{display:flex;gap:15px;margin-bottom:10px;font-size:12px;flex-wrap:wrap}.event-tick{color:#8b6f47;font-weight:700;font-family:Courier New,monospace;background:#8b451333;padding:2px 8px;border-radius:3px}.event-type{color:#d4a574;text-transform:uppercase;letter-spacing:1px;font-weight:600;background:#d4a5741a;padding:2px 8px;border-radius:3px}.event-time{color:#7a6450;margin-left:auto}.event-description{color:#e8d4b5;font-size:14px;margin-bottom:8px;line-height:1.4}.event-details{display:flex;gap:15px;flex-wrap:wrap}.event-detail{color:#a0826d;font-size:12px;background:#a0826d1a;padding:2px 8px;border-radius:3px}.no-events{text-align:center;padding:60px 20px;color:#7a6450}.no-events p{font-size:16px;margin:0}@media(max-width:768px){.chronicle-view{padding:15px}.chronicle-header h2{font-size:22px}.chronicle-controls{flex-direction:column}.chronicle-search{min-width:100%}.chronicle-stats{flex-direction:column;gap:10px}.event-meta{flex-direction:column;gap:5px}.event-time{margin-left:0}}.chronicle-loading,.chronicle-error{color:#b8a88a;font-style:italic;padding:12px 0}.chronicle-db-entries{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.chronicle-db-entry{border-radius:6px;padding:12px 16px;border-left:4px solid #666;background:#ffffff0a}.chronicle-db-entry.personal-entry{border-left-color:#d4af37;box-shadow:0 0 12px #d4af3740}.chronicle-db-entry.severity-1{border-left-color:#6b9e6b}.chronicle-db-entry.severity-2{border-left-color:#c9a24e}.chronicle-db-entry.severity-3{border-left-color:#c0392b;background:#c0392b14}.entry-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:6px;font-size:12px}.entry-category{padding:2px 8px;border-radius:3px;font-weight:700;text-transform:uppercase;font-size:11px}.cat-bio{background:#64b46440;color:#90ee90}.cat-market{background:#c8a23240;color:gold}.cat-war{background:#c0392b40;color:#ff7b6b}.cat-economic{background:#5082c840;color:#87ceeb}.entry-severity{font-size:11px;color:#b8a88a}.entry-tick{color:#7a9bb5;font-size:11px}.entry-time{color:#666;font-size:11px;margin-left:auto}.entry-summary{font-size:14px;color:#e0d5c5;line-height:1.4}.entry-personal{font-size:12px;color:#d4af37}.chronicle-share{margin-top:10px;padding:6px 12px;background:#d4af3733;color:#f4e4c1;border:1px solid rgba(212,175,55,.6);border-radius:4px;cursor:pointer;font-size:12px;text-transform:uppercase;letter-spacing:.6px}.chronicle-share:hover{background:#d4af3759}.sev-1{color:#6b9e6b}.sev-2{color:#c9a24e}.sev-3{color:#c0392b;font-weight:700}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:#0a1428;color:#a8dadc}#root{display:flex;min-height:100vh}.app{width:100vw;height:100vh;overflow:hidden;background:#0d0604;display:flex;flex-direction:column}.main-content{margin-left:250px;margin-top:85px;height:calc(100vh - 85px);overflow-y:auto;padding:20px;background:#0d0604;flex:1}.view-placeholder{display:flex;align-items:center;justify-content:center;min-height:400px;font-size:1.5rem;color:#6b7280;text-align:center;padding:20px}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0a1428,#0f3460);color:#a8dadc}.spinner{border:4px solid #457b9d;border-top:4px solid #e94560;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-screen p{font-size:1.1rem;margin-top:20px}.maintenance-screen{min-height:100vh;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:24px;text-align:center;color:#f8ece0;background:radial-gradient(circle at top,#6d1f16,#2e0e09 44%,#110707)}.maintenance-screen h1{font-size:2rem;letter-spacing:.05em}.maintenance-screen p{max-width:560px;color:#f2d6c1}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:#0f3460}::-webkit-scrollbar-thumb{background:#457b9d;border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#e94560}@media(max-width:768px){.view-placeholder{font-size:1.2rem;min-height:300px}}
