:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg-color:#0c0a09;--bg-deep:#060504;--bg-elevated:#15110f;--panel-bg:#181310cc;--panel-bg-hover:#251d18e6;--panel-border:#b89e7a1f;--panel-border-hover:#cca76640;--accent-gold:#ddaf5f;--accent-gold-bright:#f4c87b;--accent-gold-dim:#ac8239;--accent-gold-glow:#ddaf5f66;--accent-red:#d15e47;--accent-red-glow:#d15e4766;--accent-teal:#4ebca9;--accent-teal-glow:#4ebca966;--accent-blue:#5c85d6;--text-primary:#eeebe8;--text-secondary:#c6c0b9;--text-muted:#958e83;--text-disabled:#5e5a55;--glass-blur:blur(20px);--blur-heavy:blur(40px);--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-xl:0 16px 48px #0009;--shadow-premium:0 20px 50px #00000080;--shadow-glow-gold:0 0 20px var(--accent-gold-glow), 0 0 40px #e0b56c26;--shadow-glow-red:0 0 20px var(--accent-red-glow);--shadow-glow-teal:0 0 20px var(--accent-teal-glow);--ease-out-expo:cubic-bezier(.16, 1, .3, 1);--ease-out-back:cubic-bezier(.34, 1.56, .64, 1);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.4s;--transition-fast:all var(--duration-fast) var(--ease-out-expo);--transition-normal:all var(--duration-normal) var(--ease-out-expo);--transition-slow:all var(--duration-slow) var(--ease-out-expo);font-family:Inter,system-ui,-apple-system,sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#app{background-color:var(--bg-color);height:100%;color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(80% 50% at 50% -20%,#4d3a1933 0%,#0000 50%),radial-gradient(60% 40% at 100% 100%,#361c1726 0%,#0000 50%),radial-gradient(circle at 20% 80%,#1b322e14 0%,#0000 40%);overflow-x:hidden}::selection{background:var(--accent-gold);color:var(--bg-color)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-elevated);border-radius:4px}::-webkit-scrollbar-thumb{transition:background var(--transition-fast);background:#75695766;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent-gold-dim)}h1,h2,h3,h4,h5,h6,.title-mark,.faction-mark strong{letter-spacing:-.025em;font-family:Outfit,sans-serif;font-weight:600;line-height:1.2}h1{font-size:clamp(2.5rem,6vw,4.5rem);font-weight:800}h2{font-size:clamp(1.5rem,3vw,2rem)}h3{font-size:clamp(1.1rem,2vw,1.35rem)}h4{font-size:1rem}p{color:var(--text-secondary);line-height:1.65}:focus-visible{outline:2px solid var(--accent-gold);outline-offset:2px;border-radius:4px}button{border:1px solid var(--panel-border);color:var(--text-primary);cursor:pointer;transition:var(--transition-normal);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);box-shadow:var(--shadow-sm), inset 0 1px 0 #ffffff0d;background:linear-gradient(#2b211de6 0%,#1f1814e6 100%);border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.7rem 1.4rem;font-family:inherit;font-size:.875rem;font-weight:500;display:inline-flex;position:relative;overflow:hidden}button:before{content:"";pointer-events:none;background:linear-gradient(#ffffff0f 0%,#0000 50%);position:absolute;inset:0}button:after{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff26 0%,#0000 70%);border-radius:50%;width:0;height:0;transition:width .6s,height .6s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}button:hover:not(:disabled){border-color:var(--accent-gold);box-shadow:var(--shadow-lg), var(--shadow-glow-gold);background:linear-gradient(#4f3e22f2 0%,#372d1bf2 100%);transform:translateY(-2px)}button:hover:not(:disabled):after{width:300px;height:300px}button:active:not(:disabled){box-shadow:var(--shadow-sm);background:linear-gradient(#3e321ef2 0%,#282115f2 100%);transform:translateY(0)}button:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(30%)}button.primary,button.active{background:linear-gradient(180deg, var(--accent-gold-bright) 0%, var(--accent-gold) 100%);color:var(--bg-color);border-color:var(--accent-gold-bright);box-shadow:var(--shadow-md), 0 0 30px var(--accent-gold-glow);font-weight:600}button.primary:hover:not(:disabled),button.active:hover:not(:disabled){background:linear-gradient(180deg, #fad89e 0%, var(--accent-gold-bright) 100%);box-shadow:var(--shadow-lg), 0 0 50px var(--accent-gold-glow)}button.danger{background:linear-gradient(#63281df2 0%,#451f17f2 100%);border-color:#b8452e80}button.danger:hover:not(:disabled){border-color:var(--accent-red);box-shadow:var(--shadow-lg), var(--shadow-glow-red);background:linear-gradient(#7a2e1ff2 0%,#572419f2 100%)}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-24px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes glow{0%,to{box-shadow:0 0 8px var(--accent-gold-glow), 0 0 16px #e0b56c33}50%{box-shadow:0 0 20px var(--accent-gold-glow), 0 0 40px #e0b56c59}}@keyframes glowPulse{0%,to{box-shadow:0 0 5px var(--accent-gold-glow);opacity:1}50%{box-shadow:0 0 15px var(--accent-gold-glow);opacity:.9}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes shimmerSweep{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes borderGlow{0%,to{border-color:var(--accent-gold-dim)}50%{border-color:var(--accent-gold)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.animate-fade-in{animation:fadeIn var(--duration-slow) var(--ease-out-expo)}.animate-fade-in-scale{animation:fadeInScale var(--duration-normal) var(--ease-out-expo)}.animate-slide-up{animation:slideUp var(--duration-slow) var(--ease-out-expo)}.animate-slide-down{animation:slideDown var(--duration-slow) var(--ease-out-expo)}.animate-slide-left{animation:slideInLeft var(--duration-slow) var(--ease-out-expo)}.animate-slide-right{animation:slideInRight var(--duration-slow) var(--ease-out-expo)}.animate-pulse{animation:2s ease-in-out infinite pulse}.animate-glow{animation:2s ease-in-out infinite glow}.animate-glow-pulse{animation:1.5s ease-in-out infinite glowPulse}.animate-float{animation:3s ease-in-out infinite float}.animate-bounce{animation:1s ease-in-out infinite bounce}.animate-shake{animation:.5s ease-in-out shake}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.stagger-6{animation-delay:.3s}.app-shell{isolation:isolate;background:radial-gradient(circle at top,#d8b16a14 0%,#0000 28%),radial-gradient(circle at 12% 18%,#5c7ea81f 0%,#0000 18%),radial-gradient(circle at 88% 12%,#75472e24 0%,#0000 20%),linear-gradient(#0b0908 0%,#060505 100%);flex-direction:column;min-height:100vh;padding:2rem;display:flex;position:relative;overflow:hidden}.app-shell:before,.app-shell:after{content:"";pointer-events:none;z-index:0;position:absolute;inset:0}.app-shell:before{opacity:.55;background:linear-gradient(90deg,#0000 0%,#fff5dc06 48%,#0000 100%),repeating-linear-gradient(90deg,#0000 0 96px,#e2c99806 96px 97px),repeating-linear-gradient(#0000 0 96px,#e2c99805 96px 97px)}.app-shell:after{background:radial-gradient(circle at 20% 120%,#415c7d2e 0%,#0000 28%),radial-gradient(circle at 82% -10%,#a16f4029 0%,#0000 24%)}.title-screen,.campaign-screen{width:100%;max-width:1600px;animation:fadeIn var(--duration-slow) var(--ease-out-expo);z-index:1;margin:0 auto;position:relative}.title-screen{grid-template-rows:minmax(0,auto) minmax(0,1fr);gap:1.5rem;min-height:calc(100vh - 4rem);display:grid}.title-screen:before,.campaign-screen:before{content:"";pointer-events:none;z-index:0;position:absolute;inset:auto}.title-screen:before{opacity:.82;background:radial-gradient(circle,#d8b16a1a 0%,#d8b16a05 34%,#0000 64%),repeating-radial-gradient(circle,#0000 0 34px,#d8b16a0b 34px 35px);border-radius:50%;width:34rem;height:34rem;top:-7rem;right:-2rem}.campaign-screen:before{opacity:.7;background:radial-gradient(circle,#5c7ea81a 0%,#0000 68%);border-radius:999px;width:46rem;height:24rem;top:-12rem;left:12%}.title-save-status,.save-status-card,.campaign-start-brief{gap:.65rem;display:grid}.title-save-status{margin-top:1rem}.status-card.compact,.save-status-card,.campaign-start-brief{border:1px solid var(--panel-border);background:#1e1815b8;border-radius:12px;padding:.9rem 1rem}.status-card.compact strong,.save-status-card strong,.campaign-start-brief strong{color:var(--text-primary)}.inline-actions{flex-wrap:wrap;gap:.6rem;display:flex}.title-alert{background:#432019d9;border:1px solid #d75b4259;border-radius:12px;justify-content:space-between;align-items:center;gap:.75rem;padding:.8rem 1rem;display:flex}.release-settings-modal{max-width:560px}.settings-grid{gap:.85rem;margin:1rem 0;display:grid}.settings-row{border:1px solid var(--panel-border);background:#1e1815b8;border-radius:12px;justify-content:space-between;align-items:center;gap:1rem;padding:.8rem 1rem;display:flex}.settings-row select{min-width:150px}.settings-overlay-row{margin-top:.75rem}.title-panel,.side-panel,.hud-panel,.selector-panel,.map-panel,.event-panel,.detail-card{background:linear-gradient(180deg, var(--panel-bg) 0%, #120e0dd9 100%);border:1px solid var(--panel-border);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);box-shadow:var(--shadow-xl), inset 0 1px 0 #ffffff08;border-radius:16px;position:relative;overflow:hidden}.title-panel:before,.side-panel:before,.hud-panel:before,.selector-panel:before,.map-panel:before,.event-panel:before,.detail-card:before{content:"";background:linear-gradient(90deg, transparent 0%, var(--accent-gold-glow) 50%, transparent 100%);pointer-events:none;height:1px;position:absolute;top:0;left:0;right:0}.title-panel:after,.side-panel:after,.hud-panel:after,.selector-panel:after,.map-panel:after,.event-panel:after,.detail-card:after{content:"";pointer-events:none;background:linear-gradient(90deg,#0000 0%,#ffffff08 50%,#0000 100%);height:1px;position:absolute;bottom:0;left:0;right:0}.title-hero{grid-template-columns:minmax(0,1.3fr) minmax(280px,.7fr);gap:1.5rem;min-height:0;max-height:min(54vh,520px);margin-bottom:0;display:grid}.title-panel{min-height:0;padding:2.35rem 2.5rem;position:relative}.title-hero>.title-panel{overflow:auto}.title-panel:before{background:linear-gradient(90deg, transparent 0%, var(--accent-gold) 20%, var(--accent-gold-bright) 50%, var(--accent-gold) 80%, transparent 100%);height:2px}.title-mark{color:var(--accent-gold);text-transform:uppercase;letter-spacing:.35em;text-shadow:0 0 30px var(--accent-gold-glow);margin-bottom:1.25rem;font-size:.75rem;display:block}.title-panel h1{background:linear-gradient(135deg, var(--text-primary) 0%, var(--accent-gold) 50%, var(--accent-gold-bright) 100%);-webkit-text-fill-color:transparent;text-shadow:none;-webkit-background-clip:text;background-clip:text;margin-bottom:1.5rem;font-size:clamp(2.5rem,7vw,5rem);font-weight:800;line-height:.9}.title-panel p{color:var(--text-secondary);max-width:52ch;margin:0;font-size:1.1rem;line-height:1.7}.title-selected-banner{box-shadow:var(--shadow-md);background:radial-gradient(circle at 0,#c4a87024,#0000 26%),linear-gradient(#1c150fe0 0%,#0e0a07eb 100%);border:1px solid #e2c99829;border-radius:16px;gap:.7rem;margin-top:1.35rem;padding:.95rem 1rem;display:grid}.title-selected-banner-head{align-items:center;gap:.9rem;min-width:0;display:flex}.title-selected-copy{gap:.18rem;min-width:0;display:grid}.title-selected-kicker{color:var(--text-muted);text-transform:uppercase;letter-spacing:.18em;font-size:.68rem}.title-selected-copy strong{color:var(--text-primary);font-family:Cinzel,serif;font-size:1rem}.title-selected-copy span:last-child{color:var(--text-secondary);font-size:.76rem}.title-selected-sigil{flex-shrink:0}.title-selected-banner-chips{flex-wrap:wrap;gap:.55rem;display:flex}.title-actions{flex-wrap:wrap;gap:.75rem;margin-top:1.5rem;display:flex}.title-actions button{flex:170px;padding:.9rem 1.75rem;font-size:.95rem}.era-selector{border:1px solid var(--panel-border);box-shadow:var(--shadow-md), inset 0 1px 0 #ffffff05;background:linear-gradient(#1f1814b3 0%,#120e0db3 100%);border-radius:12px;align-items:center;gap:1.25rem;margin-top:2rem;padding:1.25rem;display:flex}.era-selector label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;white-space:nowrap;font-size:.8rem}.era-selector select{border:1px solid var(--panel-border);color:var(--text-primary);cursor:pointer;transition:var(--transition-normal);box-shadow:var(--shadow-sm);background:linear-gradient(#251d18e6 0%,#181311e6 100%);border-radius:8px;flex:1;padding:.65rem 1.25rem;font-family:inherit;font-size:.95rem}.era-selector select:hover{border-color:var(--accent-gold-dim);box-shadow:var(--shadow-md), 0 0 20px var(--accent-gold-glow)}.era-selector select:focus{border-color:var(--accent-gold);box-shadow:var(--shadow-md), 0 0 0 3px #e0b56c26;outline:none}.title-grid{grid-template-columns:repeat(2,1fr);align-content:start;gap:1.25rem;display:grid}.stat-card{transition:var(--transition-normal);background:linear-gradient(#18131099 0%,#0f0c0a99 100%);border:1px solid #99866614;border-radius:12px;padding:1.75rem;position:relative;overflow:hidden}.stat-card:before{content:"";background:linear-gradient(90deg, transparent, var(--accent-gold), transparent);opacity:0;height:3px;transition:opacity var(--transition-normal);position:absolute;top:0;left:0;right:0}.stat-card:after{content:"";background:radial-gradient(circle at 50% 0%, var(--accent-gold-glow) 0%, transparent 60%);opacity:0;transition:opacity var(--transition-normal);pointer-events:none;position:absolute;inset:0}.stat-card:hover{box-shadow:var(--shadow-lg), 0 0 40px #e0b56c1a;background:linear-gradient(#251d18cc 0%,#181311cc 100%);border-color:#b38d4d33;transform:translateY(-4px)}.stat-card:hover:before,.stat-card:hover:after{opacity:1}.stat-card strong{color:var(--accent-gold);text-shadow:0 0 30px var(--accent-gold-glow);z-index:1;margin-bottom:.4rem;font-family:Outfit;font-size:1.75rem;display:block;position:relative}.stat-card span{color:var(--text-muted);z-index:1;font-size:.85rem;position:relative}.title-grid .stat-card{min-height:0}.title-grid .stat-card strong{font-size:1.5rem}.title-grid .stat-card span{font-size:.8rem}.selector-panel{padding:2rem}.title-selector-panel{grid-template-rows:auto minmax(0,1fr);min-height:0;padding:1.5rem;display:grid}.selector-toolbar{border-bottom:1px solid var(--panel-border);justify-content:space-between;align-items:center;margin-bottom:1.75rem;padding-bottom:1rem;display:flex}.selector-toolbar h2{color:var(--text-primary)}.selector-layout{grid-template-columns:1fr 1.3fr;gap:2rem;display:grid}.title-selector-layout{min-height:0}.nation-list{flex-direction:column;gap:.6rem;max-height:65vh;padding-right:.75rem;display:flex;overflow-y:auto}.title-selector-layout .nation-list{min-height:0;max-height:none}.nation-card{border:1px solid var(--panel-border);transition:var(--transition-normal);background:linear-gradient(#31262180 0%,#241d1980 100%);border-radius:10px;padding:1.1rem 1.25rem;position:relative;overflow:hidden}.nation-card:before{content:"";background:linear-gradient(180deg, var(--accent-gold) 0%, var(--accent-gold-dim) 100%);width:3px;transition:transform var(--transition-normal);transform-origin:bottom;position:absolute;top:0;bottom:0;left:0;transform:scaleY(0)}.nation-card:after{content:"";background:linear-gradient(90deg, var(--accent-gold-glow) 0%, transparent 50%);opacity:0;transition:opacity var(--transition-normal);pointer-events:none;position:absolute;inset:0}.nation-card:hover{border-color:var(--accent-gold-dim);box-shadow:var(--shadow-lg), 0 0 30px #e0b56c14;background:linear-gradient(#43342db3 0%,#302621b3 100%);transform:translate(6px)}.nation-card:hover:before{transform:scaleY(1)}.nation-card:hover:after{opacity:1}.nation-card.active{border-color:var(--accent-gold);box-shadow:var(--shadow-md), 0 0 40px var(--accent-gold-glow);background:linear-gradient(#54401c80 0%,#3b2e1680 100%)}.nation-card.active:before{background:linear-gradient(180deg, var(--accent-gold-bright) 0%, var(--accent-gold) 100%);transform:scaleY(1)}.nation-card h3{color:var(--text-primary);margin-bottom:.4rem;font-size:1rem}.nation-card-identity{color:var(--text-muted);margin-top:.55rem;font-size:.72rem;line-height:1.35;display:block}.detail-card{animation:fadeInScale var(--duration-slow) var(--ease-out-expo);flex-direction:column;gap:1.5rem;padding:2rem;display:flex}.faction-mark{box-shadow:var(--shadow-md), inset 0 1px 0 #ffffff08;background:linear-gradient(135deg,#45341799 0%,#120e0ccc 100%);border:1px solid #b38d4d26;border-radius:12px;padding:1.5rem;position:relative;overflow:hidden}.faction-mark:before{content:"";background:linear-gradient(90deg, transparent, var(--accent-gold), transparent);height:2px;position:absolute;top:0;left:0;right:0}.faction-mark:after{content:"";background:radial-gradient(circle at 30% 20%, var(--accent-gold-glow) 0%, transparent 50%);pointer-events:none;position:absolute;inset:0}.faction-mark strong{color:var(--accent-gold-bright);text-shadow:0 0 30px var(--accent-gold-glow);z-index:1;font-size:1.75rem;display:block;position:relative}.faction-mark span{color:var(--text-muted);z-index:1;font-size:.9rem;position:relative}.pill{text-transform:uppercase;letter-spacing:.06em;border:1px solid var(--panel-border);color:var(--text-secondary);transition:var(--transition-fast);background:#4d3c334d;border-radius:6px;align-items:center;padding:.3rem .7rem;font-size:.7rem;font-weight:600;display:inline-flex}.pill:hover{border-color:var(--accent-gold-dim);color:var(--text-primary);background:#5c473d66}.pill.gold{color:var(--accent-gold);background:#60482059;border-color:#bf914066;box-shadow:0 0 15px #e0b56c1a}.pill.red{color:var(--accent-red);background:#602b2059;border-color:#bf554066;box-shadow:0 0 15px #d15e471a}.pill.teal{color:var(--accent-teal);background:#26595159;border-color:#4db3a266;box-shadow:0 0 15px #55aaaa1a}.pill.blue{color:var(--accent-blue);background:#20356059;border-color:#406abf66;box-shadow:0 0 15px #6495ed1a}.pill.muted{color:var(--text-muted,#888);box-shadow:none;background:#66666640;border-color:#8080804d}.campaign-layout{grid-template-columns:340px 1fr 380px;gap:1.5rem;height:calc(100vh - 10rem);display:grid}.panel-header{border-bottom:1px solid var(--panel-border);justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.panel-header h3{color:var(--text-primary)}.hud-panel,.event-panel,.map-panel{flex-direction:column;display:flex}.map-panel{flex-grow:1}.keyboard-hints{border:1px solid var(--panel-border);color:var(--text-muted);box-shadow:var(--shadow-sm);background:linear-gradient(#1f1814b3 0%,#120e0db3 100%);border-radius:8px;flex-wrap:wrap;gap:1.25rem;margin-bottom:.75rem;padding:.65rem 1rem;font-size:.75rem;display:flex}.keyboard-hints span{align-items:center;gap:.35rem;display:flex}.keyboard-hints kbd{border:1px solid var(--panel-border);min-width:1.5rem;color:var(--text-secondary);transition:var(--transition-fast);background:linear-gradient(#312621e6 0%,#241d19e6 100%);border-radius:4px;justify-content:center;align-items:center;padding:.2rem .5rem;font-family:inherit;font-size:.7rem;font-weight:600;display:inline-flex;box-shadow:0 2px #0000004d,inset 0 1px #ffffff08}.keyboard-hints:hover kbd{border-color:var(--accent-gold-dim);color:var(--accent-gold);box-shadow:0 2px 0 #0000004d, 0 0 15px var(--accent-gold-glow)}.map-frame{box-shadow:var(--shadow-xl), 0 28px 90px #00000085, inset 0 0 110px #00000075, inset 0 1px 0 #ffffff0a;background:radial-gradient(circle at 50% 42%,#1c384a4d 0%,#0000 62%),radial-gradient(#202e3c6b 0%,#0000 72%),linear-gradient(#131c26f5 0%,#0b0f14fc 100%);border:1px solid #4766851f;border-radius:12px;flex-grow:1;position:relative;overflow:hidden}.map-svg-frame{isolation:isolate}.map-svg-shell{width:100%;height:100%;position:relative;overflow:hidden}.map-svg-shell:before{content:"";pointer-events:none;z-index:1;mix-blend-mode:screen;background:radial-gradient(circle,#0000 42%,#04080e42 100%),linear-gradient(118deg,#ffedbe14 0%,#0000 28%,#4680aa0a 70%,#0000 100%);position:absolute;inset:0}.map-svg-shell:after{content:"";pointer-events:none;z-index:1;background:radial-gradient(circle at 0 0,#ffecb40d,#0000 22%),radial-gradient(circle at 100% 100%,#789cc30f,#0000 22%);border:1px solid #e2c9981f;border-radius:14px;position:absolute;inset:.5rem;box-shadow:inset 0 0 0 1px #fff9e908,inset 0 0 110px #00000038,0 0 60px #0000002e}.map-svg-root{cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;display:block}.map-svg-root:active{cursor:grabbing}.map-province-path{transition:fill-opacity var(--duration-fast) var(--ease-out-expo), stroke-opacity var(--duration-fast) var(--ease-out-expo), filter var(--duration-fast) var(--ease-out-expo)}.map-province-path:hover{filter:brightness(1.18)saturate(1.08)}.map-land-layer{filter:saturate(1.02)contrast(1.08)}.map-sea-layer{filter:saturate(1.08)contrast(1.04)}.map-graticule-layer,.map-current-layer,.map-highlight-layer,.map-coastline-layer,.map-river-layer,.map-capital-standard-layer{mix-blend-mode:screen}.map-current-layer path{animation:22s linear infinite atlasCurrentDrift}.map-province-path-land{filter:saturate(.98)}.map-province-path-sea{mix-blend-mode:screen}.map-land-relief-layer,.map-terrain-detail-layer{mix-blend-mode:soft-light}.map-ocean-texture-layer{mix-blend-mode:screen}.map-sovereignty-shadow-layer,.map-province-border-shadow-layer{mix-blend-mode:multiply}.map-province-border-layer{mix-blend-mode:screen;filter:drop-shadow(0 0 .7px #ffebbe29)}.map-sovereignty-layer{mix-blend-mode:screen;filter:drop-shadow(0 0 2px #f4ddb03d)}.map-highlight-layer,.map-coastline-layer{mix-blend-mode:screen}.map-label-text{text-transform:uppercase;letter-spacing:.12em;paint-order:stroke fill;stroke:#02050af5;stroke-width:1.65px;filter:drop-shadow(0 1px 1px #000000b8);font-family:Cinzel,Cormorant Garamond,serif}.map-world-label-text{text-transform:uppercase;paint-order:stroke fill;stroke:#040910d1;stroke-width:1.2px;filter:drop-shadow(0 1px 2px #0000008c);font-family:Cormorant Garamond,serif;font-style:italic}.map-owner-tag-text{paint-order:stroke fill;stroke:#030507fa;stroke-width:1.5px;filter:drop-shadow(0 1px 1px #000000db);font-family:Outfit,sans-serif}.map-river-layer{mix-blend-mode:screen}.map-badge text,.map-capital-standard-layer text{font-family:Outfit,sans-serif}.map-zoom-readout{z-index:3;text-align:center;min-width:4.2rem;color:var(--text-primary);letter-spacing:.08em;text-transform:uppercase;box-shadow:var(--shadow-md);pointer-events:none;background:linear-gradient(#241d19e6 0%,#181311f0 100%);border:1px solid #cca76638;border-radius:999px;padding:.35rem .65rem;font-size:.78rem;position:absolute;top:.9rem;right:.95rem}.map-ownership-key{z-index:3;width:min(680px,100% - 15rem);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);pointer-events:none;background:linear-gradient(#1e1815db 0%,#15110feb 100%);border:1px solid #cca7662e;border-radius:14px;gap:.4rem;padding:.5rem .65rem;display:grid;position:absolute;top:.85rem;left:50%;transform:translate(-50%)}.map-ownership-key-title{color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase;font-size:.62rem}.map-ownership-key-list{justify-content:center;align-items:center;gap:.35rem;min-width:0;display:flex}.map-ownership-key-item{min-width:0;color:var(--text-secondary);background:#00000038;border:1px solid #ffffff0f;border-radius:9px;grid-template-columns:auto auto minmax(0,1fr);align-items:center;gap:.32rem;padding:.32rem .45rem;font-size:.66rem;display:grid}.map-ownership-key-item.selected{background:#d8b16a1a;border-color:#d8b16a9e}.map-ownership-key-item.player{box-shadow:inset 0 -2px #d8b16ab8}.map-ownership-key-item strong{color:var(--text-primary);letter-spacing:.06em;font-size:.68rem}.map-ownership-key-item>span:last-child{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.map-ownership-color{border:1px solid #fff4d680;border-radius:3px;width:.72rem;height:.72rem;box-shadow:0 0 0 1px #00000094}.map-compass-rose{opacity:.5;width:82px;height:82px;top:4.35rem;right:1rem}.map-minimap{z-index:3;width:min(220px,24vw);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);background:linear-gradient(#1e1815d6 0%,#15110feb 100%);border:1px solid #cca7662e;border-radius:14px;gap:.45rem;padding:.6rem;display:grid;position:absolute;bottom:.9rem;right:.9rem}.map-minimap span{letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary);font-size:.7rem}.map-minimap-svg{aspect-ratio:17/9;cursor:pointer;background:linear-gradient(#172430f2 0%,#0e141bfa 100%);border:1px solid #4766853d;border-radius:10px;width:100%;display:block;overflow:hidden}.map-overlay-controls{z-index:10;gap:.5rem;display:flex;position:absolute;top:1rem;left:1rem}.map-overlay-controls button{border-color:var(--panel-border);background:linear-gradient(#251d18f2 0%,#181311f2 100%);padding:.5rem 1rem;font-size:.75rem}.map-overlay-controls button.active{background:linear-gradient(180deg, var(--accent-gold-bright) 0%, var(--accent-gold) 100%);color:var(--bg-color);border-color:var(--accent-gold-bright);box-shadow:var(--shadow-md), 0 0 30px var(--accent-gold-glow);animation:2s ease-in-out infinite glow}.map-legend{z-index:10;-webkit-backdrop-filter:var(--blur-heavy);backdrop-filter:var(--blur-heavy);border:1px solid var(--panel-border);min-width:150px;animation:fadeIn var(--duration-normal) var(--ease-out-expo);box-shadow:var(--shadow-xl);background:linear-gradient(#181310eb 0%,#0f0c0af2 100%);border-radius:10px;flex-direction:column;gap:.5rem;padding:1rem;display:flex;position:absolute;bottom:1rem;right:1rem}.legend-item{color:var(--text-muted);transition:color var(--transition-fast);align-items:center;gap:.6rem;padding:.25rem 0;font-size:.75rem;display:flex}.legend-item:hover{color:var(--text-primary)}.legend-color{width:12px;height:12px;box-shadow:var(--shadow-sm);border:1px solid #ffffff14;border-radius:3px}.map-tooltip{-webkit-backdrop-filter:var(--blur-heavy);backdrop-filter:var(--blur-heavy);border:1px solid var(--accent-gold);box-shadow:var(--shadow-xl), 0 0 40px var(--accent-gold-glow);pointer-events:none;z-index:1000;max-width:280px;animation:fadeIn var(--duration-fast) var(--ease-out-expo);background:linear-gradient(#120e0cf7 0%,#0c0a08fa 100%);border-radius:10px;padding:1rem 1.25rem;font-size:.85rem;position:absolute}.map-tooltip:before{content:"";background:linear-gradient(90deg, transparent, var(--accent-gold), transparent);height:2px;position:absolute;top:0;left:0;right:0}.map-tooltip strong{color:var(--accent-gold);text-shadow:0 0 20px var(--accent-gold-glow);margin-bottom:.5rem;font-size:.95rem;display:block}.map-tooltip-kicker{margin-bottom:.3rem;display:block}.map-tooltip span{color:var(--text-muted);margin-top:.35rem;font-size:.8rem;line-height:1.5;display:block}.kv-grid{gap:.5rem;display:grid}.kv{border-bottom:1px solid #e9e6e20a;justify-content:space-between;align-items:center;padding:.6rem 0;display:flex}.kv span{color:var(--text-muted);font-size:.85rem}.kv strong{color:var(--text-primary);font-size:.95rem;font-weight:600}.risk-ledger{border-top:1px solid var(--panel-border);margin-top:1.25rem;padding-top:1rem}.risk-ledger h4{color:var(--accent-red);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem;font-size:.85rem}.risk-card{cursor:pointer;transition:var(--transition-normal);background:linear-gradient(#3d1b1466 0%,#2d151066 100%);border:1px solid #b8452e33;border-radius:8px;margin-bottom:.6rem;padding:.9rem;position:relative;overflow:hidden}.risk-card:before{content:"";background:linear-gradient(180deg, var(--accent-red) 0%, #a33d2980 100%);width:3px;position:absolute;top:0;bottom:0;left:0}.risk-card:hover{box-shadow:var(--shadow-lg), 0 0 30px #d15e4726;background:linear-gradient(#54251c80 0%,#3c1c1580 100%);border-color:#cc4d3366;transform:translate(6px)}.risk-card strong{color:var(--accent-red);margin-bottom:.25rem;font-size:.85rem;display:block}.risk-card span{color:#d6c5c2cc;font-size:.8rem}.event-list{flex-direction:column;flex-grow:1;gap:.6rem;display:flex;overflow-y:auto}.event-item{border-left:4px solid var(--panel-border);transition:var(--transition-normal);background:linear-gradient(#2b211d80 0%,#1e181580 100%);border-radius:8px;padding:.9rem 1rem;position:relative;overflow:hidden}.event-item:after{content:"";background:linear-gradient(90deg, var(--accent-gold-glow) 0%, transparent 50%);opacity:0;transition:opacity var(--transition-normal);pointer-events:none;position:absolute;inset:0}.event-item:hover{background:linear-gradient(#372b2599 0%,#2a221d99 100%)}.event-item:hover:after{opacity:1}.event-item.alert{border-left-color:var(--accent-red);animation:2s ease-in-out infinite glowPulse}.event-item.victory{border-left-color:var(--accent-teal)}.event-item .date{color:var(--accent-gold);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.3rem;font-size:.7rem;display:block}.event-item p{color:var(--text-secondary);margin:0;font-size:.85rem;line-height:1.5}.inspect-button{background:#3c322080;border-color:#856e474d;margin-top:.5rem;padding:.35rem .75rem;font-size:.7rem}.inspect-button:hover{border-color:var(--accent-gold-dim);background:#594726b3}.status-card{border:1px solid var(--panel-border);transition:var(--transition-normal);background:linear-gradient(#31262180 0%,#241d1980 100%);border-radius:10px;margin-bottom:.6rem;padding:1rem;position:relative;overflow:hidden}.status-card:before{content:"";background:var(--accent-gold);opacity:0;width:3px;height:100%;transition:opacity var(--transition-fast);position:absolute;top:0;left:0}.status-card:hover{border-color:var(--panel-border-hover);background:linear-gradient(#3d302999 0%,#30262199 100%)}.status-card:hover:before{opacity:1}.status-card.frontier-power{border-left:3px solid var(--accent-gold)}.status-card.diplomacy-card{border-left:3px solid var(--accent-teal)}.status-card.diplomacy-card:before{background:var(--accent-teal)}.status-card.dormant{opacity:.85;border-left:3px solid #93836c4d}.status-card strong{color:var(--text-primary);margin-bottom:.25rem;font-size:.95rem;display:block}.status-card span{color:var(--text-muted);margin-top:.2rem;font-size:.8rem;display:block}.nation-status-list{flex-direction:column;gap:.5rem;display:flex}.frontier-actions{flex-wrap:wrap;gap:.4rem;margin-top:.75rem;display:flex}.frontier-actions button{background:linear-gradient(#2b211db3 0%,#1e1815b3 100%);padding:.35rem .75rem;font-size:.7rem}.frontier-actions button:hover{background:linear-gradient(#47381fcc 0%,#302717cc 100%)}.input,.select{border:1px solid var(--panel-border);color:var(--text-primary);transition:var(--transition-normal);box-shadow:var(--shadow-sm);background:linear-gradient(#251d18e6 0%,#181311e6 100%);border-radius:8px;padding:.65rem 1rem;font-family:inherit;font-size:.9rem}.input:focus,.select:focus{border-color:var(--accent-gold);box-shadow:var(--shadow-md), 0 0 0 3px #e0b56c1f;background:linear-gradient(#2b211df2 0%,#1e1815f2 100%);outline:none}.input::placeholder{color:var(--text-muted);opacity:.7}.atlas-search{background:linear-gradient(#1f1814f2 0%,#120e0df2 100%);border-color:#7a6b5226}.atlas-search:focus{border-color:var(--accent-gold);box-shadow:var(--shadow-md), 0 0 0 3px #e0b56c1a}.muted{color:var(--text-muted);font-size:.9rem;line-height:1.6}.meta-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.actions{gap:.75rem;margin-top:1rem;display:flex}.actions button{flex:1}.observer-panel{box-shadow:var(--shadow-lg);background:linear-gradient(#171c26f2 0%,#101318f7 100%);border:1px solid #406abf33;border-radius:10px;margin-top:.75rem;padding:.75rem;position:relative;overflow:hidden}.observer-panel:before{content:"";background:linear-gradient(90deg, transparent, var(--accent-blue), transparent);height:2px;position:absolute;top:0;left:0;right:0}.observer-panel .panel-header{border-bottom-color:#406abf26}.observer-panel h3{color:var(--accent-blue);text-shadow:0 0 20px #6495ed4d;font-size:.8rem}.observer-stats{grid-template-columns:repeat(2,1fr);gap:.4rem;display:grid}.observer-stats .stat-row{transition:background var(--transition-fast);border-radius:4px;justify-content:space-between;align-items:center;padding:.3rem .5rem;font-size:.7rem;display:flex}.observer-stats .stat-row:hover{background:#242e424d}.observer-stats .stat-row span{color:var(--text-muted)}.observer-stats .stat-row strong{color:var(--text-primary);font-weight:600}.tutorial-overlay{z-index:1000;animation:slideUp var(--duration-slow) var(--ease-out-expo);position:fixed;bottom:2rem;left:50%;transform:translate(-50%)}.tutorial-panel{-webkit-backdrop-filter:var(--blur-heavy);backdrop-filter:var(--blur-heavy);border:1px solid var(--accent-gold);max-width:450px;box-shadow:var(--shadow-xl), 0 0 60px var(--accent-gold-glow);background:linear-gradient(#1f1814fa 0%,#120e0dfc 100%);border-radius:16px;padding:1.75rem}.tutorial-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.tutorial-step{color:var(--accent-gold);text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;font-weight:600}.tutorial-dismiss{color:var(--text-muted);cursor:pointer;opacity:.6;transition:opacity var(--transition-fast);background:0 0;border:none;padding:0;font-size:1.5rem;line-height:1}.tutorial-dismiss:hover{opacity:1;background:0 0;border:none}.tutorial-panel h4{color:var(--text-primary);margin-bottom:.5rem;font-size:1.15rem}.tutorial-panel p{color:var(--text-secondary);margin-bottom:1.25rem;font-size:.9rem;line-height:1.6}.tutorial-actions{justify-content:flex-end;gap:.75rem;display:flex}.tutorial-actions button{padding:.5rem 1.25rem;font-size:.85rem}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;animation:fadeIn var(--duration-normal) var(--ease-out-expo);background:#000000d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.battle-report-modal{-webkit-backdrop-filter:var(--blur-heavy);backdrop-filter:var(--blur-heavy);border:1px solid var(--accent-gold);width:92%;max-width:720px;max-height:88vh;box-shadow:var(--shadow-xl), 0 0 80px var(--accent-gold-glow);animation:slideUp var(--duration-slow) var(--ease-out-expo);background:linear-gradient(#1d1816fa 0%,#110f0dfc 100%);border-radius:20px;overflow-y:auto}.battle-report-modal .modal-header{border-bottom:1px solid var(--panel-border);background:linear-gradient(#251d1880 0%,#0000 100%);justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.battle-report-modal .modal-header h2{color:var(--accent-gold);text-shadow:0 0 30px var(--accent-gold-glow);font-size:1.5rem}.battle-report-modal .close-button{color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;padding:0;font-size:2rem;line-height:1}.battle-report-modal .close-button:hover{color:var(--text-primary);background:0 0;border:none}.battle-context{border-bottom:1px solid var(--panel-border);background:linear-gradient(#251d1880 0%,#0000 100%);align-items:center;gap:1rem;padding:1rem 2rem;display:flex}.terrain-chip{color:var(--accent-gold);text-transform:capitalize;background:#60482080;border-radius:6px;align-items:center;padding:.3rem .8rem;font-size:.85rem;display:inline-flex;box-shadow:0 0 15px #e0b56c26}.terrain-note{color:var(--accent-teal);font-size:.85rem}.supply-note{color:var(--accent-red);font-size:.85rem}.battle-summary-grid{grid-template-columns:1fr auto 1fr;align-items:start;gap:1.5rem;padding:2rem;display:grid}.battle-side{border:1px solid var(--panel-border);text-align:center;box-shadow:var(--shadow-lg);background:linear-gradient(#29221e80 0%,#1d181680 100%);border-radius:14px;padding:1.5rem}.battle-side .faction-mark{margin-bottom:1rem;padding:1rem}.battle-side h3{color:var(--text-primary);margin-bottom:.3rem;font-size:1.1rem}.battle-role{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem;font-size:.7rem;display:block}.battle-vs{flex-direction:column;justify-content:center;align-items:center;padding:1rem;display:flex}.vs-text{color:var(--accent-red);text-shadow:0 0 30px var(--accent-red-glow);letter-spacing:-.02em;font-size:2.5rem;font-weight:800}.vs-subtitle{color:var(--text-muted);margin-top:.5rem;font-size:.75rem}.force-stats{text-align:left;font-size:.9rem}.force-stats .stat{border-bottom:1px solid #99866614;justify-content:space-between;padding:.4rem 0;display:flex}.force-stats .stat:last-child{border-bottom:none}.force-stats .stat span{color:var(--text-muted)}.force-stats .stat.total{border-top:2px solid var(--panel-border);margin-top:.6rem;padding-top:.6rem;font-weight:600}.force-stats .stat.total strong{color:var(--accent-gold);font-size:1.15rem}.battle-outcome{padding:1.5rem 2rem 2rem}.result-banner{text-align:center;text-transform:uppercase;letter-spacing:.06em;border-radius:10px;margin-bottom:1.5rem;padding:1.1rem;font-size:1.3rem;font-weight:700}.result-banner.victory{color:var(--accent-gold-bright);border:1px solid var(--accent-gold);box-shadow:var(--shadow-md), 0 0 40px var(--accent-gold-glow);background:linear-gradient(135deg,#5a4116b3,#496b2480)}.result-banner.defeat{color:var(--accent-red);box-shadow:var(--shadow-md), 0 0 30px var(--accent-red-glow);background:linear-gradient(135deg,#541c1c80,#3d221480);border:1px solid #9336}.casualty-summary{border:1px solid var(--panel-border);box-shadow:var(--shadow-lg);background:linear-gradient(#231d1a80 0%,#17141280 100%);border-radius:14px;padding:1.5rem}.casualty-summary h4{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem;font-size:.8rem}.casualty-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}.casualty-header{justify-content:space-between;align-items:center;margin-bottom:.4rem;display:flex}.casualty-header strong{color:var(--text-primary);font-size:.95rem}.loss-percent{color:var(--accent-red);font-weight:600}.loss-bar{background:#3d3029cc;border-radius:5px;height:10px;margin-bottom:.5rem;overflow:hidden;box-shadow:inset 0 1px 3px #0000004d}.loss-fill{background:linear-gradient(90deg, var(--accent-gold) 0%, var(--accent-red) 100%);height:100%;transition:width .6s var(--ease-out-expo);border-radius:5px;position:relative}.loss-fill:after{content:"";background:linear-gradient(90deg,#0000 0%,#fff3 50%,#0000 100%) 0 0/200% 100%;animation:2s infinite shimmer;position:absolute;inset:0}.loss-detail{color:var(--text-muted);font-size:.8rem}.casualty-breakdown{border-top:1px solid var(--panel-border);margin-top:1.25rem;padding-top:1rem}.casualty-breakdown h5{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.75rem;font-size:.7rem}.breakdown-grid{flex-wrap:wrap;gap:1rem;display:flex}.breakdown-item{gap:.5rem;font-size:.85rem;display:flex}.breakdown-item span{color:var(--text-muted)}.breakdown-item strong{color:var(--accent-red)}.battle-report-modal .modal-footer{border-top:1px solid var(--panel-border);background:linear-gradient(#0000 0%,#18131080 100%);justify-content:flex-end;padding:1rem 2rem;display:flex}@media (width<=1400px){.campaign-layout{grid-template-columns:300px 1fr 340px}}@media (width<=1200px){.campaign-layout{grid-template-rows:auto 1fr;grid-template-columns:280px 1fr}.event-panel{grid-column:span 2;max-height:280px}}@media (width<=900px){.title-screen{grid-template-rows:auto auto;min-height:auto}.campaign-layout{grid-template-rows:auto auto 1fr auto;grid-template-columns:1fr}.event-panel{grid-column:span 1;max-height:220px}.title-hero{grid-template-columns:1fr;max-height:none}.title-hero>.title-panel{overflow:visible}.selector-layout{grid-template-columns:1fr}.selector-toolbar{flex-direction:column;align-items:stretch;gap:.85rem}.selector-toolbar .meta-row{width:100%}.selector-toolbar .atlas-search{width:100%!important;margin-left:0!important}.title-selector-layout .title-nation-dossier{order:-1}.title-selector-layout .nation-list{max-height:min(65vh,640px);padding-right:.4rem}.title-status-grid{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.ripple-container{position:relative;overflow:hidden}.ripple-effect{pointer-events:none;background:radial-gradient(circle,#e0b56c66 0%,#0000 70%);border-radius:50%;animation:.6s ease-out forwards rippleExpand;position:absolute;transform:scale(0)}@keyframes rippleExpand{0%{opacity:1;transform:scale(0)}to{opacity:0;transform:scale(4)}}@keyframes screenShake{0%,to{transform:translate(0)}10%{transform:translate(-2px)rotate(-.5deg)}20%{transform:translate(2px)rotate(.5deg)}30%{transform:translate(-2px)rotate(-.3deg)}40%{transform:translate(2px)rotate(.3deg)}50%{transform:translate(-1px)}60%{transform:translate(1px)}70%{transform:translate(-.5px)}80%{transform:translate(.5px)}90%{transform:translate(-.25px)}}.screen-shake{animation:.4s ease-out screenShake}.loading-overlay{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:9999;animation:fadeIn var(--duration-normal) var(--ease-out-expo);background:#0a0a0feb;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loading-spinner{border:3px solid var(--panel-border);border-top-color:var(--accent-gold);width:60px;height:60px;box-shadow:var(--shadow-glow-gold);border-radius:50%;margin-bottom:1.5rem;animation:1s linear infinite spin}.loading-text{color:var(--text-secondary);letter-spacing:.05em;font-size:.95rem}.loading-subtext{color:var(--text-muted);margin-top:.5rem;font-size:.8rem;animation:1.5s ease-in-out infinite pulse}.skeleton{background:linear-gradient(90deg,#231d1a80 0%,#352c27cc 50%,#231d1a80 100%) 0 0/200% 100%;border-radius:6px;animation:1.5s ease-in-out infinite shimmer}.skeleton-text{height:14px;margin-bottom:.5rem}.skeleton-text.short{width:40%}.skeleton-text.medium{width:70%}.skeleton-text.long{width:100%}.skeleton-card{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:12px;padding:1.5rem}.skeleton-circle{border-radius:50%;width:48px;height:48px}.year-display{align-items:center;gap:.5rem;display:inline-flex;position:relative}.year-value{color:var(--accent-gold);text-shadow:0 0 20px var(--accent-gold-glow);transition:transform .3s var(--ease-out-back);font-family:Outfit,sans-serif;font-size:1.25rem;font-weight:700}.year-value.changing{animation:yearIncrement .5s var(--ease-out-back)}@keyframes yearIncrement{0%{opacity:1;transform:translateY(0)}50%{opacity:.5;transform:translateY(-10px)}51%{transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.year-delta{color:var(--accent-gold-bright);animation:deltaFloat 1s var(--ease-out-expo) forwards;pointer-events:none;font-size:.75rem;font-weight:600;position:absolute;top:-20px;right:-10px}@keyframes deltaFloat{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}.event-icon{border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-right:.5rem;display:inline-flex}.event-icon svg{width:14px;height:14px}.event-icon.battle{color:var(--accent-red);box-shadow:0 0 10px var(--accent-red-glow);background:linear-gradient(135deg,#a33d294d,#7333264d)}.event-icon.move{color:var(--accent-teal);box-shadow:0 0 10px var(--accent-teal-glow);background:linear-gradient(135deg,#3181744d,#2659514d)}.event-icon.diplomacy{color:var(--accent-blue);background:linear-gradient(135deg,#2d4a864d,#23365c4d)}.event-icon.crisis{color:var(--accent-gold);box-shadow:0 0 10px var(--accent-gold-glow);background:linear-gradient(135deg,#8f68244d,#6048204d)}.event-icon.emergence{color:#b870db;background:linear-gradient(135deg,#682d864d,#49235c4d)}.event-icon.rebellion{color:#e05252;background:linear-gradient(135deg,#8f24244d,#6020204d)}.event-icon.collapse{color:#bf4040;background:linear-gradient(135deg,#6b2e2e4d,#4521214d)}.event-icon.settlement{color:#53c653;background:linear-gradient(135deg,#2e6b2e4d,#2145214d)}[data-tooltip]{cursor:help;position:relative}[data-tooltip]:after{content:attr(data-tooltip);border:1px solid var(--accent-gold);color:var(--text-secondary);white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s var(--ease-out-expo);z-index:1000;box-shadow:var(--shadow-xl), 0 0 20px var(--accent-gold-glow);pointer-events:none;background:linear-gradient(#1d1816fa,#110f0dfc);border-radius:8px;padding:.5rem .75rem;font-size:.75rem;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)translateY(4px)}[data-tooltip]:hover:after{opacity:1;visibility:visible;transform:translate(-50%)translateY(0)}.resource-bar{align-items:center;gap:.5rem;padding:.4rem 0;display:flex}.resource-bar-track{background:#2c242199;border-radius:4px;flex:1;height:8px;overflow:hidden;box-shadow:inset 0 1px 3px #0006}.resource-bar-fill{height:100%;transition:width .5s var(--ease-out-expo);border-radius:4px;position:relative}.resource-bar-fill:after{content:"";background:linear-gradient(90deg,#0000 0%,#ffffff26 50%,#0000 100%);animation:2s ease-in-out infinite shimmer;position:absolute;inset:0}.resource-bar-fill.treasury{background:linear-gradient(90deg,#8f7424,#d9ac26)}.resource-bar-fill.legitimacy{background:linear-gradient(90deg,#265973,#2e8ab8)}.resource-bar-fill.loyalty{background:linear-gradient(90deg,#267359,#2eb88a)}.resource-bar-fill.danger{background:linear-gradient(90deg,#8f3624,#d94426);animation:1s ease-in-out infinite pulseDanger}.resource-bar-fill.warning{background:linear-gradient(90deg,#8f7424,#d9ac26)}@keyframes pulseDanger{0%,to{opacity:1}50%{opacity:.7}}.resource-bar-value{text-align:right;min-width:36px;font-size:.8rem;font-weight:600}.resource-bar-value.positive{color:var(--accent-teal)}.resource-bar-value.negative{color:var(--accent-red)}@keyframes numberBump{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.number-bump{animation:numberBump .3s var(--ease-out-back)}.zoom-indicator{border:1px solid var(--panel-border);color:var(--text-muted);z-index:10;box-shadow:var(--shadow-sm);animation:fadeIn var(--duration-normal) var(--ease-out-expo);background:linear-gradient(#1d1816e6,#110f0de6);border-radius:6px;align-items:center;gap:.5rem;padding:.4rem .8rem;font-size:.7rem;display:flex;position:absolute;bottom:1rem;left:1rem}.zoom-indicator svg{opacity:.6;width:12px;height:12px}.severity-gauge{gap:3px;margin-left:auto;display:flex}.severity-pip{width:4px;height:12px;transition:background .2s var(--ease-out-expo);background:#493d3680;border-radius:2px}.severity-pip.active.low{background:var(--accent-teal);box-shadow:0 0 6px var(--accent-teal-glow)}.severity-pip.active.medium{background:var(--accent-gold);box-shadow:0 0 6px var(--accent-gold-glow)}.severity-pip.active.high{background:var(--accent-red);box-shadow:0 0 6px var(--accent-red-glow);animation:1s ease-in-out infinite pipPulse}@keyframes pipPulse{0%,to{opacity:1}50%{opacity:.6}}.doctrine-republic .panel-header,.doctrine-republic .hud-panel{border-top:2px solid #406abf}.doctrine-monarchy .panel-header,.doctrine-monarchy .hud-panel{border-top:2px solid #8245a1}.doctrine-imperial .panel-header,.doctrine-imperial .hud-panel{border-top:2px solid #d99726}.doctrine-tribal .panel-header,.doctrine-tribal .hud-panel{border-top:2px solid #428a42}.doctrine-satrapy .panel-header,.doctrine-satrapy .hud-panel{border-top:2px solid #704785}.doctrine-confederation .panel-header,.doctrine-confederation .hud-panel{border-top:2px solid #8f7a3d}.doctrine-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:4px;align-items:center;padding:.2rem .5rem;font-size:.65rem;font-weight:600;display:inline-flex}.doctrine-badge.republic{color:#5c85d6;background:#20356066}.doctrine-badge.monarchy{color:#b579d2;background:#48265966}.doctrine-badge.imperial{color:var(--accent-gold);background:#6c4c1366}.doctrine-badge.tribal{color:#59c059;background:#21452166}.doctrine-badge.satrapy{color:#a770c2;background:#38244266}.doctrine-badge.confederation{color:#c6a953;background:#473d1f66}.title-hero{position:relative;overflow:hidden}.title-hero:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(circle at 20% 30%,#664a1926 0%,#0000 25%),radial-gradient(circle at 80% 70%,#4d22191f 0%,#0000 25%),radial-gradient(circle,#1b322e1a 0%,#0000 30%);animation:20s ease-in-out infinite heroAtmosphere;position:absolute;inset:-50%}@keyframes heroAtmosphere{0%,to{opacity:1;transform:translate(0)scale(1)}25%{opacity:.9;transform:translate(2%,-2%)scale(1.05)}50%{opacity:1;transform:translate(-2%,2%)scale(1.02)}75%{opacity:.95;transform:translate(1%,1%)scale(1.03)}}.particle-field{pointer-events:none;z-index:0;position:absolute;inset:0;overflow:hidden}.particle{background:var(--accent-gold);opacity:0;border-radius:50%;width:3px;height:3px;animation:8s ease-in-out infinite particleFloat;position:absolute}@keyframes particleFloat{0%{opacity:0;transform:translateY(100vh)scale(0)}10%{opacity:.6}90%{opacity:.6}to{opacity:0;transform:translateY(-20vh)scale(1)}}.battle-report-modal{position:relative}.battle-report-modal:before{content:"";background:conic-gradient(from 0deg, transparent 0deg, var(--accent-gold-glow) 10deg, transparent 20deg);opacity:0;pointer-events:none;width:200%;height:200%;animation:1.5s ease-out forwards battleReveal;position:absolute;top:-50%;left:-50%}@keyframes battleReveal{0%{opacity:.3;transform:rotate(0)scale(.5)}50%{opacity:.15}to{opacity:0;transform:rotate(360deg)scale(1)}}.result-banner{position:relative;overflow:hidden}.result-banner:before{content:"";width:0;height:0;animation:victoryBurst .6s var(--ease-out-expo) forwards;background:radial-gradient(circle,#fff3 0%,#0000 70%);border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes victoryBurst{0%{opacity:1;width:0;height:0}to{opacity:0;width:300px;height:300px}}.result-banner.victory:before{background:radial-gradient(circle,#e0b56c66 0%,#0000 70%)}.force-count{font-variant-numeric:tabular-nums;transition:color .3s var(--ease-out-expo)}.force-count.decreasing{animation:countDecrease .5s var(--ease-out-expo);color:var(--accent-red)}.force-count.increasing{animation:countIncrease .5s var(--ease-out-expo);color:var(--accent-teal)}@keyframes countDecrease{0%{transform:scale(1)}30%{color:var(--accent-red);transform:scale(.9)}to{transform:scale(1)}}@keyframes countIncrease{0%{transform:scale(1)}30%{color:var(--accent-teal);transform:scale(1.1)}to{transform:scale(1)}}.capital-marker{position:relative}.capital-marker:after{content:"";background:var(--accent-gold);border:2px solid var(--bg-color);width:8px;height:8px;box-shadow:0 0 8px var(--accent-gold-glow);border-radius:50%;animation:2s ease-in-out infinite capitalPulse;position:absolute;top:-4px;right:-4px}@keyframes capitalPulse{0%,to{box-shadow:0 0 8px var(--accent-gold-glow);transform:scale(1)}50%{box-shadow:0 0 12px var(--accent-gold);transform:scale(1.2)}}.fleet-marker{position:relative}.fleet-marker:before{content:"⚓";color:var(--accent-blue);text-shadow:0 0 6px #6495ed80;font-size:10px;position:absolute;top:-6px;left:50%;transform:translate(-50%)}.compass-rose{opacity:.4;z-index:5;width:60px;height:60px;transition:opacity .3s var(--ease-out-expo);position:absolute;top:1rem;right:1rem}.compass-rose:hover{opacity:.8}.compass-rose svg{width:100%;height:100%;animation:60s linear infinite compassSpin}@keyframes compassSpin{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}.movement-path{pointer-events:none;z-index:5;position:absolute}.movement-arrow{stroke:var(--accent-gold);stroke-width:2px;stroke-dasharray:8 4;fill:none;filter:drop-shadow(0 0 4px var(--accent-gold-glow));animation:1s linear infinite pathDash}@keyframes pathDash{to{stroke-dashoffset:-12px}}.movement-arrow-head{fill:var(--accent-gold);filter:drop-shadow(0 0 4px var(--accent-gold-glow))}.era-showcase{gap:.75rem;margin-top:1rem;padding-bottom:.35rem;display:flex;overflow-x:auto}.era-card{border:1px solid var(--panel-border);text-align:center;cursor:pointer;transition:var(--transition-normal);background:linear-gradient(#1d181680,#110f0d80);border-radius:10px;flex:0 0 148px;min-height:7.75rem;padding:.9rem .85rem}.era-card:hover{border-color:var(--accent-gold-dim);background:linear-gradient(#29221e99,#1d181699);transform:translateY(-2px)}.era-card.active{border-color:var(--accent-gold);box-shadow:0 0 20px var(--accent-gold-glow);background:linear-gradient(#40331c80,#29211480)}.era-card h4{color:var(--text-primary);margin-bottom:.25rem;font-size:.75rem}.era-card span{color:var(--text-muted);font-size:.65rem}.era-card .era-preview{color:var(--accent-teal);margin-top:.5rem;font-size:.7rem}.tutorial-spotlight{z-index:999;pointer-events:none;border-radius:12px;animation:2s ease-in-out infinite spotlightPulse;position:fixed;box-shadow:0 0 0 9999px #000000b3}@keyframes spotlightPulse{0%,to{box-shadow:0 0 0 9999px #000000b3, 0 0 0 2px var(--accent-gold)}50%{box-shadow:0 0 0 9999px #000000b3, 0 0 0 3px var(--accent-gold), 0 0 20px var(--accent-gold-glow)}}.tutorial-arrow{z-index:1000;border:8px solid #0000;width:0;height:0;animation:1s ease-in-out infinite arrowBounce;position:absolute}.tutorial-arrow.down{border-top-color:var(--accent-gold);animation-name:arrowBounceDown}.tutorial-arrow.up{border-bottom-color:var(--accent-gold);animation-name:arrowBounceUp}@keyframes arrowBounceDown{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}@keyframes arrowBounceUp{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.success-check{background:var(--accent-teal);color:#fff;width:20px;height:20px;animation:successPop .4s var(--ease-out-back);border-radius:50%;justify-content:center;align-items:center;font-size:12px;display:inline-flex}@keyframes successPop{0%{transform:scale(0)}60%{transform:scale(1.2)}to{transform:scale(1)}}.order-queued-indicator{border:1px solid var(--accent-gold-dim);color:var(--accent-gold);animation:fadeIn var(--duration-fast) var(--ease-out-expo);background:#6048204d;border-radius:4px;align-items:center;gap:.35rem;padding:.2rem .5rem;font-size:.65rem;display:inline-flex}.order-queued-indicator:before{content:"";background:var(--accent-gold);border-radius:50%;width:6px;height:6px;animation:1.5s ease-in-out infinite queuedPulse}@keyframes queuedPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.fab-container{z-index:100;position:fixed;bottom:2rem;right:2rem}.fab{background:linear-gradient(135deg, var(--accent-gold-bright), var(--accent-gold));width:56px;height:56px;box-shadow:var(--shadow-lg), 0 0 30px var(--accent-gold-glow);cursor:pointer;transition:var(--transition-normal);color:var(--bg-color);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.fab:hover{box-shadow:var(--shadow-xl), 0 0 50px var(--accent-gold-glow);transform:scale(1.1)rotate(90deg)}.fab svg{width:24px;height:24px}.fab-menu{opacity:0;visibility:hidden;transition:var(--transition-normal);flex-direction:column;gap:.75rem;display:flex;position:absolute;bottom:70px;right:0;transform:translateY(10px)}.fab.expanded .fab-menu{opacity:1;visibility:visible;transform:translateY(0)}.fab-action{white-space:nowrap;padding:.6rem 1rem;font-size:.8rem}.diplomatic-timeline{border-top:1px solid var(--panel-border);gap:.5rem;margin-top:.75rem;padding-top:.75rem;display:flex;overflow-x:auto}.timeline-event{flex-direction:column;align-items:center;gap:.25rem;min-width:50px;display:flex}.timeline-dot{background:var(--accent-gold-dim);border-radius:50%;width:8px;height:8px}.timeline-dot.war{background:var(--accent-red)}.timeline-dot.peace{background:var(--accent-teal)}.timeline-dot.alliance{background:#a6c}.timeline-dot.pact{background:var(--accent-blue)}.timeline-year{color:var(--text-muted);font-size:.6rem}.timeline-label{color:var(--text-disabled);text-transform:uppercase;font-size:.55rem}.treaty-countdown{background:#1f2c4766;border-radius:4px;align-items:center;gap:.35rem;padding:.15rem .4rem;font-size:.7rem;display:inline-flex}.treaty-countdown .count{color:var(--accent-blue);font-variant-numeric:tabular-nums;font-weight:700}.treaty-countdown.expiring{background:#4d401966;animation:2s ease-in-out infinite expiringPulse}.treaty-countdown.expiring .count{color:var(--accent-gold)}@keyframes expiringPulse{0%,to{opacity:1}50%{opacity:.7}}.territory-pulse{position:relative}.territory-pulse:before{content:"";border:2px solid var(--accent-gold);border-radius:inherit;pointer-events:none;animation:1.5s ease-out forwards territoryPulse;position:absolute;inset:-4px}@keyframes territoryPulse{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.5)}}.milestone-badges{gap:.5rem;margin-top:.75rem;display:flex}.milestone-badge{border:1px solid var(--accent-gold-dim);color:var(--accent-gold);transition:var(--transition-normal);background:linear-gradient(135deg,#664a1966,#45341766);border-radius:20px;align-items:center;gap:.35rem;padding:.3rem .6rem;font-size:.65rem;display:flex}.milestone-badge:hover{box-shadow:0 0 15px var(--accent-gold-glow);transform:scale(1.05)}.milestone-badge svg{width:12px;height:12px}.milestone-badge.locked{opacity:.4;filter:grayscale(50%)}.tip-of-day{border:1px solid var(--accent-gold-dim);max-width:280px;box-shadow:var(--shadow-lg);z-index:50;animation:slideInLeft var(--duration-slow) var(--ease-out-expo);background:linear-gradient(#1d1816f2,#110f0df2);border-radius:10px;padding:.75rem 1rem;position:fixed;bottom:1rem;left:1rem}.tip-of-day-header{align-items:center;gap:.5rem;margin-bottom:.4rem;display:flex}.tip-of-day-header svg{width:14px;height:14px;color:var(--accent-gold)}.tip-of-day-header span{text-transform:uppercase;letter-spacing:.08em;color:var(--accent-gold);font-size:.65rem;font-weight:600}.tip-of-day p{color:var(--text-secondary);font-size:.8rem;line-height:1.4}.tip-of-day-dismiss{color:var(--text-muted);cursor:pointer;opacity:.5;background:0 0;border:none;padding:.2rem;font-size:1rem;transition:opacity .2s;position:absolute;top:.4rem;right:.4rem}.tip-of-day-dismiss:hover{opacity:1;background:0 0;border:none}.unread-indicator{background:var(--accent-red);color:#fff;border-radius:4px;justify-content:center;align-items:center;min-width:8px;height:8px;padding:0 4px;font-size:.6rem;font-weight:700;animation:1.5s ease-in-out infinite unreadPulse;display:inline-flex}@keyframes unreadPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.province-highlight{border:2px solid var(--accent-gold);pointer-events:none;border-radius:50%;animation:.8s ease-out forwards provinceHighlight;position:absolute;inset:-8px}@keyframes provinceHighlight{0%{opacity:0;transform:scale(.8)}50%{opacity:1}to{opacity:0;transform:scale(1.2)}}.province-actions-panel{border:1px solid var(--accent-gold-dim);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:var(--shadow-xl), 0 0 40px var(--accent-gold-glow);z-index:100;animation:slideUp var(--duration-normal) var(--ease-out-expo);background:linear-gradient(#1d1816f2,#110f0dfa);border-radius:12px;gap:.5rem;padding:.75rem 1rem;display:flex;position:absolute;bottom:1rem;left:50%;transform:translate(-50%)}.province-actions-panel:before{content:"";background:linear-gradient(90deg, transparent, var(--accent-gold), transparent);height:1px;position:absolute;top:0;left:20%;right:20%}.quick-action-btn{cursor:pointer;min-width:60px;transition:var(--transition-fast);background:0 0;border:1px solid #0000;border-radius:8px;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem .75rem;display:flex}.quick-action-btn:hover{border-color:var(--accent-gold-dim);background:#47381f80;transform:translateY(-2px)}.quick-action-btn:active{transform:translateY(0)}.quick-action-btn svg{width:20px;height:20px;color:var(--text-secondary);transition:color var(--transition-fast)}.quick-action-btn:hover svg{color:var(--accent-gold)}.quick-action-btn span{color:var(--text-muted);font-size:.65rem}.quick-action-btn:hover span{color:var(--text-secondary)}.quick-action-btn.active{border-color:var(--accent-gold);background:#60482066}.quick-action-btn.active svg,.quick-action-btn.active span{color:var(--accent-gold)}.stat-change-indicator{animation:statChangeFloat 1.2s var(--ease-out-expo) forwards;pointer-events:none;white-space:nowrap;z-index:100;font-size:.75rem;font-weight:700;position:absolute}.stat-change-indicator.positive{color:var(--accent-teal);text-shadow:0 0 10px var(--accent-teal-glow)}.stat-change-indicator.negative{color:var(--accent-red);text-shadow:0 0 10px var(--accent-red-glow)}@keyframes statChangeFloat{0%{opacity:1;transform:translateY(0)scale(1)}20%{transform:translateY(-5px)scale(1.1)}to{opacity:0;transform:translateY(-30px)scale(.8)}}@keyframes countUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes countDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.stat-value{position:relative;overflow:hidden}.stat-value.animating-up .stat-current{animation:countUp .3s var(--ease-out-expo)}.stat-value.animating-down .stat-current{animation:countDown .3s var(--ease-out-expo)}.stat-old{color:var(--text-muted);opacity:0;text-decoration:line-through;position:absolute;top:0;left:0}.stat-current{display:inline-block}.toast-container{z-index:5000;pointer-events:none;flex-direction:column;gap:.75rem;display:flex;position:fixed;top:1rem;right:1rem}.toast{border:1px solid var(--panel-border);box-shadow:var(--shadow-xl);pointer-events:auto;min-width:280px;max-width:380px;animation:toastSlideIn .4s var(--ease-out-expo);background:linear-gradient(#1d1816fa,#110f0dfc);border-radius:12px;align-items:flex-start;gap:.75rem;padding:1rem 1.25rem;display:flex}.toast.exiting{animation:toastSlideOut .3s var(--ease-out-expo) forwards}@keyframes toastSlideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.toast-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.toast-icon.success{color:var(--accent-teal);background:#20604a66}.toast-icon.error{color:var(--accent-red);background:#602b2066}.toast-icon.info{color:var(--accent-blue);background:#20356066}.toast-icon.warning{color:var(--accent-gold);background:#60482066}.toast-content{flex:1}.toast-title{color:var(--text-primary);margin-bottom:.25rem;font-size:.9rem;font-weight:600}.toast-message{color:var(--text-secondary);font-size:.8rem;line-height:1.4}.toast-close{color:var(--text-muted);cursor:pointer;opacity:.5;background:0 0;border:none;flex-shrink:0;padding:.2rem;font-size:1.2rem;transition:opacity .2s}.toast-close:hover{opacity:1;background:0 0;border:none}.toast-progress{background:var(--panel-border);border-radius:0 0 12px 12px;height:3px;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.toast-progress-bar{background:var(--accent-gold);height:100%;animation:linear forwards toastProgressShrink}.rich-tooltip{border:1px solid var(--accent-gold);box-shadow:var(--shadow-xl), 0 0 50px var(--accent-gold-glow);pointer-events:none;z-index:1000;min-width:260px;max-width:320px;animation:tooltipFadeIn .2s var(--ease-out-expo);background:linear-gradient(#171311fa,#0b0a09fc);border-radius:14px;padding:0;position:absolute;overflow:hidden}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.rich-tooltip-header{border-bottom:1px solid var(--panel-border);background:linear-gradient(#362a1799,#0000);padding:1rem 1.25rem}.rich-tooltip-header h4{color:var(--accent-gold);text-shadow:0 0 20px var(--accent-gold-glow);margin-bottom:.25rem;font-size:1rem}.rich-tooltip-header span{color:var(--text-muted);font-size:.75rem}.rich-tooltip-section{border-bottom:1px solid #e9e6e20a;padding:.75rem 1.25rem}.rich-tooltip-section:last-child{border-bottom:none}.rich-tooltip-section h5{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem;font-size:.65rem}.rich-tooltip-row{justify-content:space-between;align-items:center;padding:.2rem 0;font-size:.8rem;display:flex}.rich-tooltip-row span:first-child{color:var(--text-secondary)}.rich-tooltip-row span:last-child{color:var(--text-primary);font-weight:500}.rich-tooltip-row .highlight{color:var(--accent-gold)}.rich-tooltip-row .danger{color:var(--accent-red)}.rich-tooltip-row .success{color:var(--accent-teal)}.rich-tooltip-footer{color:var(--text-muted);text-align:center;background:#0f0c0b80;padding:.6rem 1.25rem;font-size:.7rem;font-style:italic}.context-menu{border:1px solid var(--panel-border);min-width:180px;box-shadow:var(--shadow-xl);z-index:3000;animation:contextMenuFadeIn .15s var(--ease-out-expo);background:linear-gradient(#1d1816fa,#110f0dfc);border-radius:10px;padding:.5rem 0;position:fixed}@keyframes contextMenuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu-item{color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast);align-items:center;gap:.75rem;padding:.6rem 1rem;font-size:.85rem;display:flex}.context-menu-item:hover{color:var(--text-primary);background:#362a1780}.context-menu-item svg{opacity:.6;width:16px;height:16px}.context-menu-item:hover svg{opacity:1;color:var(--accent-gold)}.context-menu-separator{background:var(--panel-border);height:1px;margin:.5rem 0}.context-menu-shortcut{color:var(--text-disabled);background:#2c242180;border-radius:4px;margin-left:auto;padding:.1rem .4rem;font-size:.7rem}.movement-indicator{z-index:50;flex-direction:column;gap:.5rem;display:flex;position:absolute;top:3.5rem;right:1rem}.movement-queue-item{border:1px solid var(--accent-gold-dim);color:var(--text-secondary);animation:slideInRight .3s var(--ease-out-expo);background:linear-gradient(#362a17b3,#221c11b3);border-radius:8px;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.75rem;display:flex}.movement-queue-item .province-name{color:var(--accent-gold);font-weight:500}.movement-queue-item .arrow{color:var(--text-muted)}.movement-queue-item .target-name{color:var(--accent-teal);font-weight:500}.movement-queue-item .type-badge{color:var(--accent-teal);text-transform:uppercase;background:#26595180;border-radius:4px;margin-left:auto;padding:.15rem .4rem;font-size:.6rem}.tutorial-overlay{z-index:9000;animation:tutorialFadeIn .3s var(--ease-out-expo);background:#000000bf;position:fixed;inset:0}@keyframes tutorialFadeIn{0%{opacity:0}to{opacity:1}}.tutorial-highlight{box-shadow:0 0 0 4px var(--accent-gold), 0 0 30px var(--accent-gold-glow);z-index:9001;pointer-events:none;border-radius:12px;animation:2s ease-in-out infinite tutorialPulse;position:fixed}@keyframes tutorialPulse{0%,to{box-shadow:0 0 0 4px var(--accent-gold), 0 0 30px var(--accent-gold-glow)}50%{box-shadow:0 0 0 6px var(--accent-gold), 0 0 50px var(--accent-gold-glow)}}.tutorial-card{border:1px solid var(--accent-gold);width:90%;max-width:500px;box-shadow:var(--shadow-xl), 0 0 60px var(--accent-gold-glow);z-index:9002;animation:tutorialCardSlideUp .4s var(--ease-out-expo);background:linear-gradient(#1d1816fa,#110f0dfc);border-radius:16px;padding:1.5rem 2rem;position:fixed;bottom:2rem;left:50%;transform:translate(-50%)}@keyframes tutorialCardSlideUp{0%{opacity:0;transform:translate(-50%)translateY(20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.tutorial-card-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.tutorial-step-indicator{gap:.5rem;display:flex}.tutorial-step-dot{background:var(--panel-border);width:8px;height:8px;transition:var(--transition-fast);border-radius:50%}.tutorial-step-dot.active{background:var(--accent-gold);box-shadow:0 0 10px var(--accent-gold-glow)}.tutorial-step-dot.completed{background:var(--accent-teal)}.tutorial-card h3{color:var(--accent-gold);margin-bottom:.5rem;font-size:1.25rem}.tutorial-card p{color:var(--text-secondary);margin-bottom:1.25rem;font-size:.95rem;line-height:1.6}.tutorial-card-actions{justify-content:space-between;align-items:center;display:flex}.tutorial-skip{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:.5rem;font-size:.8rem}.tutorial-skip:hover{color:var(--text-secondary);background:0 0}.tutorial-nav{gap:.5rem;display:flex}.tutorial-nav button{padding:.5rem 1rem;font-size:.85rem}.achievement-badge{border:1px solid var(--accent-gold-dim);color:var(--accent-gold);transition:var(--transition-normal);cursor:pointer;background:linear-gradient(135deg,#664a1966,#45341766);border-radius:20px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.8rem;display:inline-flex}.achievement-badge:hover{box-shadow:0 0 20px var(--accent-gold-glow);transform:scale(1.05)}.achievement-badge svg{width:18px;height:18px}.achievement-badge.locked{opacity:.4;filter:grayscale(60%);cursor:not-allowed}.achievement-badge.locked:hover{box-shadow:none;transform:none}.achievement-progress{background:#3b302b80;border-radius:2px;width:60px;height:4px;margin-left:.25rem;overflow:hidden}.achievement-progress-fill{background:var(--accent-gold);height:100%;transition:width .3s var(--ease-out-expo)}@keyframes achievementUnlock{0%{opacity:0;transform:scale(0)rotate(-10deg)}50%{transform:scale(1.2)rotate(5deg)}to{opacity:1;transform:scale(1)rotate(0)}}.achievement-unlock{animation:achievementUnlock .6s var(--ease-out-back)}.ambient-indicator{border:1px solid var(--panel-border);color:var(--text-muted);cursor:pointer;transition:var(--transition-fast);z-index:50;background:#1d1816e6;border-radius:20px;align-items:center;gap:.5rem;padding:.4rem .8rem;font-size:.7rem;display:flex;position:fixed;bottom:1rem;left:1rem}.ambient-indicator:hover{border-color:var(--accent-gold-dim);color:var(--text-secondary)}.ambient-indicator svg{width:14px;height:14px}.ambient-indicator.muted svg{color:var(--accent-red)}.mini-stats-bar{border-bottom:1px solid var(--panel-border);background:#171311cc;gap:1.5rem;padding:.5rem 1rem;font-size:.75rem;display:flex}.mini-stat{color:var(--text-muted);align-items:center;gap:.4rem;display:flex}.mini-stat svg{opacity:.6;width:12px;height:12px}.mini-stat .value{color:var(--text-secondary);font-weight:500}.mini-stat.positive .value{color:var(--accent-teal)}.mini-stat.negative .value{color:var(--accent-red)}.shortcuts-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:8000;animation:fadeIn var(--duration-normal) var(--ease-out-expo);background:#000000e6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.shortcuts-panel{border:1px solid var(--accent-gold);width:90%;max-width:700px;max-height:80vh;box-shadow:var(--shadow-xl), 0 0 80px var(--accent-gold-glow);animation:scaleIn var(--duration-normal) var(--ease-out-expo);background:linear-gradient(#1d1816fa,#110f0dfc);border-radius:20px;overflow:hidden}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.shortcuts-header{border-bottom:1px solid var(--panel-border);background:linear-gradient(#362a174d,#0000);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.shortcuts-header h2{color:var(--accent-gold);font-size:1.25rem}.shortcuts-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:1.5rem;transition:color .2s}.shortcuts-close:hover{color:var(--text-primary);background:0 0}.shortcuts-body{max-height:calc(80vh - 80px);padding:1.5rem;overflow-y:auto}.shortcuts-category{margin-bottom:1.5rem}.shortcuts-category:last-child{margin-bottom:0}.shortcuts-category h3{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid var(--panel-border);margin-bottom:.75rem;padding-bottom:.5rem;font-size:.8rem}.shortcut-row{justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.shortcut-row span{color:var(--text-secondary);font-size:.9rem}.shortcut-keys{gap:.35rem;display:flex}.shortcut-keys kbd{border:1px solid var(--panel-border);min-width:1.75rem;color:var(--text-secondary);background:linear-gradient(#312621e6,#241d19e6);border-radius:5px;justify-content:center;align-items:center;padding:.25rem .5rem;font-family:inherit;font-size:.75rem;font-weight:600;display:inline-flex;box-shadow:0 2px #0000004d,inset 0 1px #ffffff08}.notification-badge{position:relative}.notification-count{background:var(--accent-red);color:#fff;min-width:18px;height:18px;animation:badgePop .3s var(--ease-out-back);border-radius:9px;justify-content:center;align-items:center;padding:0 5px;font-size:.65rem;font-weight:700;display:flex;position:absolute;top:-6px;right:-6px}@keyframes badgePop{0%{transform:scale(0)}50%{transform:scale(1.3)}to{transform:scale(1)}}.notification-count.pulse{animation:badgePop .3s var(--ease-out-back), badgePulse 2s ease-in-out .3s infinite}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.ambient-indicator{z-index:100;background:linear-gradient(135deg, var(--panel-bg), var(--panel-bg-2));border:1px solid var(--panel-border);width:44px;height:44px;color:var(--text-secondary);cursor:pointer;transition:all .2s var(--ease-out-expo);border-radius:12px;justify-content:center;align-items:center;display:flex;position:fixed;bottom:20px;right:20px;box-shadow:0 4px 12px #0000004d}.ambient-indicator:hover{color:var(--gold);border-color:var(--gold-dim);transform:translateY(-2px);box-shadow:0 6px 20px #0006,0 0 20px #d4af371a}.ambient-indicator svg{transition:transform .2s var(--ease-out-expo)}.ambient-indicator:hover svg{transform:scale(1.1)}.notification-badge{z-index:90;background:linear-gradient(135deg, var(--accent-red), #c0392b);color:#fff;min-width:22px;height:22px;animation:badgePop .3s var(--ease-out-back);border-radius:11px;justify-content:center;align-items:center;padding:0 6px;font-size:.7rem;font-weight:700;display:flex;position:fixed;top:80px;right:20px;box-shadow:0 2px 8px #e74c3c66}.shortcuts-overlay{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .2s var(--ease-out-expo);background:#000000d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.shortcuts-panel{background:linear-gradient(145deg, var(--panel-bg), var(--panel-bg-2));border:1px solid var(--panel-border);width:90%;max-width:600px;max-height:80vh;animation:scaleIn .3s var(--ease-out-back);border-radius:16px;padding:1.5rem;overflow-y:auto;box-shadow:0 25px 80px #00000080,0 0 60px #d4af370d}.shortcuts-header{border-bottom:1px solid var(--panel-border);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.shortcuts-header h3{color:var(--gold);margin:0;font-size:1.25rem;font-weight:600}.shortcuts-close{border:1px solid var(--panel-border);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:all .2s var(--ease-out-expo);background:0 0;border-radius:8px;justify-content:center;align-items:center;display:flex}.shortcuts-close:hover{background:var(--accent-red);border-color:var(--accent-red);color:#fff}.shortcuts-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1.5rem;display:grid}.shortcuts-section h4{color:var(--gold);text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid var(--panel-border);margin-bottom:.75rem;padding-bottom:.5rem;font-size:.75rem;font-weight:600}.shortcuts-list{flex-direction:column;gap:.5rem;display:flex}.shortcut-item{justify-content:space-between;align-items:center;padding:.4rem 0;display:flex}.shortcut-item span{color:var(--text-secondary);font-size:.85rem}.toast-container{z-index:500;pointer-events:none;flex-direction:column-reverse;gap:.5rem;display:flex;position:fixed;bottom:80px;right:20px}.toast{pointer-events:auto;background:linear-gradient(135deg, var(--panel-bg), var(--panel-bg-2));border:1px solid var(--panel-border);min-width:280px;max-width:400px;animation:slideInRight .3s var(--ease-out-expo);border-radius:12px;align-items:center;gap:.75rem;padding:.875rem 1rem;display:flex;box-shadow:0 8px 32px #0006}.toast-success{border-left:3px solid var(--accent-green)}.toast-error{border-left:3px solid var(--accent-red)}.toast-warning{border-left:3px solid var(--accent-gold)}.toast-info{border-left:3px solid var(--accent-blue)}.toast-icon{flex-shrink:0;justify-content:center;align-items:center;display:flex}.toast-success .toast-icon{color:var(--accent-green)}.toast-error .toast-icon{color:var(--accent-red)}.toast-warning .toast-icon{color:var(--accent-gold)}.toast-info .toast-icon{color:var(--accent-blue)}.toast-message{color:var(--text-primary);flex:1;font-size:.9rem}.toast-close{width:24px;height:24px;color:var(--text-muted);cursor:pointer;transition:all .2s var(--ease-out-expo);background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.toast-close:hover{background:var(--panel-border);color:var(--text-primary)}.toast-progress{background:var(--gold);border-radius:0 0 12px 12px;height:3px;animation:4s linear forwards toastProgress;position:absolute;bottom:0;left:0}@keyframes toastProgress{0%{width:100%}to{width:0%}}.shortcuts-panel::-webkit-scrollbar{width:6px}.toast-container::-webkit-scrollbar{width:6px}.shortcuts-panel::-webkit-scrollbar-track{background:var(--panel-bg)}.toast-container::-webkit-scrollbar-track{background:var(--panel-bg)}.shortcuts-panel::-webkit-scrollbar-thumb{background:var(--panel-border);border-radius:3px}.toast-container::-webkit-scrollbar-thumb{background:var(--panel-border);border-radius:3px}.app-shell{min-height:100vh;position:relative}.campaign-layout-map-first{grid-template-columns:240px minmax(0,1fr) 320px;grid-template-areas:"rail map detail";align-items:stretch;gap:1rem;height:calc(100vh - 8.5rem);min-height:760px}.command-rail{flex-direction:column;grid-area:rail;gap:.9rem;min-height:0;padding:1.1rem;display:flex;overflow-y:auto}.detail-panel{flex-direction:column;grid-area:detail;gap:.9rem;min-height:0;padding:1.1rem;display:flex;overflow-y:auto}.map-stage{flex-direction:column;grid-area:map;gap:.85rem;min-width:0;min-height:0;display:flex}.command-rail .panel-header,.detail-panel .panel-header{margin-bottom:0;padding-bottom:.75rem}.panel-header.compact{margin-bottom:.35rem;padding-bottom:.45rem}.panel-subtitle{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin-top:.25rem;font-size:.72rem;display:block}.command-rail-tags{margin-top:-.1rem}.realm-summary-grid,.province-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem;display:grid}.province-summary-card{box-shadow:var(--shadow-sm);background:linear-gradient(#241d19e0 0%,#181311eb 100%);border:1px solid #a190781f;border-radius:12px;gap:.3rem;padding:.85rem .95rem;display:grid}.province-summary-card span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.09em;font-size:.7rem}.province-summary-card strong{color:var(--text-primary);font-size:1rem}.detail-card{gap:.85rem;padding:1.15rem 1.2rem}.detail-card h4{text-transform:uppercase;letter-spacing:.08em;color:var(--text-primary);font-size:.9rem}.dossier-list{gap:.6rem;display:grid}.dossier-item{text-align:left;background:linear-gradient(#241d19b3 0%,#181311c7 100%);border:1px solid #a190781a;border-radius:12px;gap:.25rem;padding:.8rem .9rem;display:grid}.dossier-item strong{color:var(--text-primary);font-size:.84rem}.dossier-item span{color:var(--text-secondary);font-size:.82rem;line-height:1.45}.dossier-item.actionable{cursor:pointer;transition:var(--transition-fast)}.dossier-item.actionable:hover{box-shadow:var(--shadow-md);border-color:#d3ac6947;transform:translateY(-1px)}.actions-vertical{flex-direction:column;margin-top:0}.actions-vertical button{width:100%}.command-hints{grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem .75rem;margin-bottom:0;padding:.85rem .95rem;display:grid}.command-hints span{font-size:.72rem}.map-stage-toolbar{box-shadow:var(--shadow-md);background:linear-gradient(#1e1815e6 0%,#15110ff5 100%);border:1px solid #a3907524;border-radius:16px;justify-content:space-between;align-items:stretch;gap:1rem;padding:1rem 1.05rem;display:flex;position:relative;overflow:hidden}.map-stage-toolbar:before{content:"";pointer-events:none;background:radial-gradient(circle at 0 0,#e2c9981f,#0000 24%),linear-gradient(90deg,#0000,#fff9e908,#0000);position:absolute;inset:0}.map-stage-toolbar:after{content:"";pointer-events:none;background:linear-gradient(90deg,#0000,#e2c99838,#0000);height:1px;position:absolute;inset:auto 1.2rem .3rem}.map-toolbar-cluster{flex:1.2;align-content:start;gap:.7rem;min-width:0;display:grid}.map-toolbar-kicker,.map-control-kicker,.map-tooltip-kicker{color:var(--text-muted);text-transform:uppercase;letter-spacing:.14em;font-size:.68rem}.map-overlay-inline{z-index:auto;grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem;display:grid;position:static;inset:auto}.map-overlay-inline button.map-overlay-mode{text-align:left;border-radius:12px;gap:.15rem;min-width:0;padding:.56rem .7rem .52rem;display:grid;transform:none}.map-overlay-mode-title{color:var(--text-primary);font-size:.88rem;font-weight:700}.map-overlay-mode-hint{color:var(--text-muted);letter-spacing:.04em;font-size:.7rem}.map-overlay-controls button.active .map-overlay-mode-hint{color:#110e08d1}.map-stage-status{flex:1;gap:.65rem;display:grid}.map-status-grid{grid-template-columns:repeat(3,minmax(0,1fr));min-width:min(100%,560px)}.map-status-card{box-shadow:var(--shadow-sm);background:radial-gradient(circle at 0 0,#e2c99814,#0000 32%),linear-gradient(#271f1bd1 0%,#1b1613e0 100%);border:1px solid #a390751f;border-radius:12px;gap:.28rem;padding:.58rem .7rem;display:grid}.map-status-card span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.11em;font-size:.68rem}.map-status-card strong{color:var(--text-primary);font-family:Cinzel,serif;font-size:.82rem}.map-status-card small{color:var(--text-secondary);font-size:.68rem;line-height:1.3}.map-stage-chip{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;background:#2a221de0;border:1px solid #a3907524;border-radius:999px;align-items:center;padding:.38rem .75rem;font-size:.7rem;display:inline-flex}.map-stage-chip.subtle{color:var(--text-muted);background:#1e1815b8}.map-panel-primary{flex-direction:column;min-height:0;padding:.85rem;display:flex;overflow:hidden}.map-panel-primary .map-frame,.map-frame{flex:1;height:100%;min-height:720px}.map-frame canvas{display:block;width:100%!important;height:100%!important}.map-footnote{box-shadow:var(--shadow-md);background:radial-gradient(circle at 0 0,#c4a8701a,#0000 22%),linear-gradient(#1e1815d1 0%,#15110fe6 100%);border:1px solid #a390751f;border-radius:16px;grid-template-columns:minmax(0,1.25fr) minmax(0,1.7fr);align-items:start;gap:.7rem .9rem;padding:.65rem .8rem;display:grid}.map-focus-readout{gap:.3rem;min-width:0;display:grid}.map-focus-readout strong{color:var(--text-primary);font-size:.92rem}.map-focus-readout span{color:var(--text-secondary);font-size:.76rem;line-height:1.42}.map-inline-strip{flex-wrap:wrap;align-content:flex-start;gap:.45rem;display:flex}.map-inline-legend{grid-column:2}.map-inline-chip{background:linear-gradient(#271f1bbd 0%,#1b1613d1 100%),linear-gradient(90deg,#e2c9980f,#0000 45%);border:1px solid #a390751a;border-radius:12px;gap:.12rem;padding:.45rem .58rem;display:inline-grid}.map-inline-chip strong{color:var(--text-primary);font-size:.72rem}.map-inline-chip span{color:var(--text-secondary);font-size:.66rem;line-height:1.3}.map-inline-legend-chip{grid-template-columns:auto minmax(0,1fr);align-items:start;column-gap:.45rem}.map-inline-legend-chip .map-legend-swatch{grid-row:1/span 2}.map-inline-legend-chip strong,.map-inline-legend-chip span:not(.map-legend-swatch){grid-column:2}.map-legend-swatch{border-radius:999px;width:11px;height:11px;margin-top:.28rem;box-shadow:0 0 0 1px #ffffff14}.map-legend-swatch.green{background:#7d8c5c}.map-legend-swatch.gold{background:#d8b16a}.map-legend-swatch.red{background:#d26f58}.map-legend-swatch.teal{background:#4eb7a5}.map-legend-swatch.amber{background:#f3c67c}.map-control-dock{z-index:3;width:min(260px,30vw);position:absolute;bottom:1rem;left:1rem}.map-control-card{box-shadow:var(--shadow-lg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);background:linear-gradient(#1e1815db 0%,#15110feb 100%);border:1px solid #a3907529;border-radius:14px;gap:.7rem;padding:.8rem;display:grid}.map-control-stack{grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem;display:grid}.map-control-button{justify-items:center;gap:.15rem;min-height:56px;padding:.55rem .45rem;display:grid}.map-control-button span{font-size:1rem;font-weight:700}.map-control-button small{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.09em;font-size:.65rem}.map-control-card p{color:var(--text-secondary);font-size:.74rem;line-height:1.45}@keyframes atlasCurrentDrift{0%{stroke-dashoffset:0}to{stroke-dashoffset:-36px}}@media (prefers-reduced-motion:reduce){.map-current-layer path{animation:none}}.province-action-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem;display:grid}.province-primary-order{grid-column:1/-1}.compare-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.chronicle-card .event-list-compact{max-height:360px;padding-right:.2rem;overflow-y:auto}.chronicle-card .event-item{padding:.75rem .85rem}.observer-dossier-card .observer-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.compare-dossier-card,.observer-dossier-card{display:none}.map-tooltip{max-width:300px;top:1rem;left:1rem;right:auto}.tutorial-overlay{pointer-events:none;background:0 0;justify-content:flex-end;align-items:flex-end;padding:1rem 1rem 1.5rem;display:flex;inset:0;transform:none}.tutorial-panel{pointer-events:auto;max-width:360px;padding:1.05rem 1.1rem}@media (width<=1500px){.campaign-layout-map-first{grid-template-columns:220px minmax(0,1fr) 290px}.map-panel-primary .map-frame,.map-frame{min-height:680px}}@media (width<=1180px){.campaign-layout-map-first{grid-template-columns:minmax(0,1fr) 320px;grid-template-areas:"map detail""rail detail";height:auto;min-height:0}.command-hints{grid-template-columns:repeat(3,minmax(0,1fr))}.map-stage-toolbar{flex-direction:column}.map-footnote{grid-template-columns:1fr}.map-inline-legend{grid-column:auto}.map-status-grid{grid-template-columns:repeat(3,minmax(0,1fr));min-width:0}.map-overlay-inline{grid-template-columns:repeat(2,minmax(0,1fr))}.map-panel-primary .map-frame,.map-frame{min-height:620px}}@media (width<=920px){.campaign-layout-map-first{grid-template-columns:1fr;grid-template-areas:"map""rail""detail";height:auto;min-height:0}.map-stage-toolbar{flex-direction:column}.map-footnote{grid-template-columns:1fr}.map-inline-legend{grid-column:auto}.map-status-grid,.map-overlay-inline,.command-hints{grid-template-columns:repeat(2,minmax(0,1fr))}.map-panel-primary .map-frame,.map-frame{min-height:560px}.tutorial-overlay{justify-content:stretch;align-items:flex-end;padding:1rem}.tutorial-panel{max-width:none}.map-control-dock{width:min(220px,44vw)}}@media (width<=720px){.map-status-grid,.map-overlay-inline{grid-template-columns:1fr}.map-minimap,.map-control-dock{width:min(180px,42vw)}.map-ownership-key{width:auto;left:.75rem;right:5.7rem;transform:none}.map-ownership-key-list{justify-content:flex-start;overflow:hidden}.map-ownership-key-item{flex:none}.map-ownership-key-item>span:last-child{display:none}}.profile-hub,.campaign-naming-card,.save-library-modal,.cloud-backup-panel,.save-slot-card,.save-profile-chip,.save-profile-creator,.empty-save-state{border:1px solid var(--panel-border);box-shadow:var(--shadow-md);background:linear-gradient(#221a16eb 0%,#181311eb 100%)}.profile-hub{border-radius:18px;gap:.85rem;padding:1rem;display:grid}.title-status-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.title-status-grid .inline-actions,.title-status-grid .title-alert{grid-column:1/-1}.profile-hub-header,.save-column-header{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.profile-hub-header span,.save-column-header span{color:var(--text-muted);font-size:.82rem}.profile-strip{flex-wrap:wrap;gap:.55rem;display:flex}.profile-chip,.save-profile-chip{text-align:left;justify-content:flex-start}.profile-chip{min-height:2.6rem}.profile-create-row,.save-profile-creator{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.65rem;display:grid}.campaign-naming-card{border-radius:14px;gap:.55rem;margin-top:1rem;padding:.9rem 1rem;display:grid}.campaign-naming-card span{color:var(--text-muted);font-size:.82rem}.title-nation-dossier{grid-template-rows:repeat(5,auto);align-content:start;gap:.9rem;min-height:0;padding:1.15rem;display:grid;overflow-y:auto}.title-dossier-chips{flex-wrap:wrap;gap:.55rem;display:flex}.title-dossier-copy{gap:.75rem;padding-right:.35rem;display:grid}.title-dossier-copy p{margin:0}.polity-identity-showcase{background:radial-gradient(circle at 0 0,#d8b16a1a,#0000 28%),linear-gradient(#28201af0,#181310f5);border:1px solid #c4a16433;border-radius:16px;gap:.85rem;padding:1rem;display:grid}.polity-identity-heading{gap:.25rem;display:grid}.polity-identity-heading>span,.polity-balance-column>span,.polity-unit-card>span,.government-mechanic-grid article>span{color:var(--accent-gold);letter-spacing:.1em;text-transform:uppercase;font-size:.65rem}.polity-identity-heading strong{color:var(--text-primary);font-family:Cinzel,serif;font-size:1rem}.polity-identity-heading p,.polity-balance-column p,.polity-unit-card p,.government-mechanic-grid p{color:var(--text-secondary);margin:0;line-height:1.48}.polity-balance-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;display:grid}.polity-balance-column{background:#0000002e;border:1px solid #a390751f;border-radius:12px;align-content:start;gap:.42rem;padding:.75rem;display:grid}.polity-balance-column.strengths{box-shadow:inset 3px 0 #4eb7a5b3}.polity-balance-column.weaknesses{box-shadow:inset 3px 0 #d26f58b8}.polity-balance-column p{padding-left:.85rem;font-size:.76rem;position:relative}.polity-balance-column p:before{content:"";opacity:.55;background:currentColor;border-radius:999px;width:.36rem;height:.36rem;position:absolute;top:.52em;left:0}.polity-unit-grid,.government-mechanic-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.65rem;display:grid}.polity-unit-card,.government-mechanic-grid article{background:linear-gradient(#2a221db8,#181311d6);border:1px solid #a390751f;border-radius:12px;align-content:start;gap:.36rem;padding:.75rem;display:grid}.polity-unit-card strong,.government-mechanic-grid strong{color:var(--text-primary);font-size:.82rem}.polity-unit-card p,.government-mechanic-grid p{font-size:.73rem}.polity-unit-card small,.government-mechanic-grid small{color:var(--text-muted);font-size:.67rem;line-height:1.4}.polity-unit-card .limitation,.government-mechanic-grid small{color:#c58e81}.campaign-polity-identity{gap:.7rem;padding:.9rem}.polity-identity-heading.compact strong{font-size:.86rem}.polity-identity-heading.compact p{font-size:.74rem}.campaign-polity-unit-line{gap:.35rem;display:grid}.campaign-polity-unit-line span{color:var(--text-secondary);font-size:.72rem}.campaign-polity-unit-line b{min-width:3.5rem;color:var(--accent-gold);letter-spacing:.08em;text-transform:uppercase;font-size:.61rem;display:inline-block}.campaign-polity-balance{gap:.4rem;display:grid}.campaign-polity-balance span{color:var(--text-secondary);background:#0000002e;border-radius:9px;padding:.45rem .55rem;font-size:.69rem;line-height:1.38}.campaign-polity-balance .positive{border-left:3px solid #4eb7a5bf}.campaign-polity-balance .negative{border-left:3px solid #d26f58bf}.campaign-government-mechanic{border-top:1px solid #a390751f;gap:.25rem;padding-top:.65rem;display:grid}.campaign-government-mechanic strong{color:var(--text-primary);font-size:.78rem}.campaign-government-mechanic span,.campaign-government-mechanic small{color:var(--text-secondary);font-size:.69rem;line-height:1.4}.campaign-government-mechanic small{color:#c58e81}@media (width<=820px){.polity-balance-grid,.polity-unit-grid,.government-mechanic-grid{grid-template-columns:1fr}}.campaign-launch-card{border:1px solid var(--panel-border);background:linear-gradient(#2a231de0 0%,#181310eb 100%);border-radius:16px;gap:.8rem;padding:1rem;display:grid}.campaign-launch-card .campaign-naming-card{margin-top:0}.campaign-launch-actions button{flex:180px}.save-library-modal{width:min(1180px,100vw - 3rem);max-height:min(88vh,920px);overflow:hidden}.cloud-backup-panel{border-radius:16px;gap:.75rem;margin-bottom:1rem;padding:.9rem 1rem;display:grid}.cloud-backup-heading,.cloud-recovery-key,.cloud-backup-connect{align-items:center;gap:.7rem;display:flex}.cloud-backup-heading{justify-content:space-between}.cloud-backup-heading>div{gap:.2rem;display:grid}.cloud-backup-heading span,.cloud-recovery-key label,.cloud-backup-connect>span{color:var(--text-muted);font-size:.8rem}.cloud-backup-connect .input,.cloud-recovery-key .input{min-width:0;font-family:var(--font-mono);flex:360px;font-size:.78rem}.cloud-backup-connected{gap:.65rem;display:grid}.cloud-backup-connected p{margin:0}.cloud-backup-error{color:var(--accent-red);background:#432019a6;border:1px solid #d75b4259;border-radius:10px;padding:.65rem .75rem;font-size:.82rem}.save-library-layout{grid-template-columns:minmax(260px,320px) minmax(0,1fr);gap:1rem;min-height:420px;display:grid}.save-profile-column,.save-slot-column{gap:.85rem;min-height:0;display:grid}.save-profile-list,.save-slot-grid{gap:.75rem;min-height:0;padding-right:.25rem;display:grid;overflow:auto}.save-profile-chip{border-radius:14px;gap:.25rem;padding:.85rem .95rem;display:grid}.save-profile-chip span{color:var(--text-muted);font-size:.8rem}.save-slot-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.save-slot-card{border-radius:16px;gap:.8rem;padding:1rem;display:grid}.save-slot-card.active{border-color:var(--accent-gold);box-shadow:var(--shadow-lg), var(--shadow-glow-gold)}.save-slot-card.manual{border-color:#49ab9b40}.save-slot-header{justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.save-slot-header>div{gap:.2rem;display:grid}.save-slot-header span{color:var(--text-muted);font-size:.8rem}.save-slot-card p{font-size:.9rem}.save-slot-meta{flex-wrap:wrap;gap:.45rem;display:flex}.save-slot-meta span{color:var(--text-secondary);background:#352f27f2;border-radius:999px;padding:.28rem .55rem;font-size:.76rem}.empty-save-state{color:var(--text-secondary);border-radius:16px;gap:.3rem;padding:1rem;display:grid}@media (width<=980px){.save-library-layout{grid-template-columns:1fr}.profile-create-row,.save-profile-creator,.cloud-backup-connect,.cloud-recovery-key{grid-template-columns:1fr;align-items:stretch}.cloud-backup-connect,.cloud-recovery-key{display:grid}.save-slot-grid{grid-template-columns:1fr}}.char-card{background:var(--panel-bg);border:1px solid var(--panel-border);transition:var(--transition-normal);cursor:default;border-radius:12px;flex-direction:column;gap:.75rem;padding:1rem;display:flex}.char-card[role=button]{cursor:pointer}.char-card[role=button]:hover{border-color:var(--accent-gold);background:var(--panel-bg-hover);box-shadow:var(--shadow-md)}.char-dead{opacity:.55;filter:grayscale(40%)}.char-ruler{border-color:var(--accent-gold-dim);background:linear-gradient(180deg, #282115e6 0%, var(--panel-bg) 100%)}.char-card-compact{flex-direction:row;align-items:center;gap:.6rem;padding:.5rem .75rem}.char-card-header{align-items:flex-start;gap:.75rem;display:flex}.char-card-portrait,.char-card-portrait-mini{background:linear-gradient(135deg, var(--accent-gold-dim) 0%, #53452dcc 100%);border:2px solid var(--panel-border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex;position:relative}.char-card-portrait-mini{width:32px;height:32px}.char-portrait-initial{color:var(--text-primary);font-family:Cinzel,serif;font-size:1.2rem;font-weight:700}.char-card-portrait-mini .char-portrait-initial{font-size:.85rem}.char-crown-badge{background:var(--accent-gold);border:2px solid var(--bg-elevated);border-radius:50%;width:16px;height:16px;position:absolute;top:-4px;right:-4px}.char-crown-badge:after{content:"";border-left:5px solid #0000;border-right:5px solid #0000;border-bottom:7px solid var(--bg-color);width:0;height:0;position:absolute;top:2px;left:3px}.char-card-identity{flex-direction:column;gap:.2rem;min-width:0;display:flex}.char-card-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-family:Cinzel,serif;font-size:1rem;font-weight:600;overflow:hidden}.char-card-age{color:var(--text-muted);font-size:.8rem}.char-card-info-mini{flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.char-card-info-mini strong{white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;overflow:hidden}.char-card-info-mini span{color:var(--text-muted);font-size:.72rem}.char-card-identity .identity-pill,.char-card-compact .identity-pill{align-self:flex-start}.char-card-stats{flex-direction:column;gap:.35rem;display:flex}.char-stat-row{grid-template-columns:70px 1fr 24px;align-items:center;gap:.5rem;display:grid}.char-stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem}.char-stat-bar-track{background:#352f27cc;border-radius:3px;height:6px;overflow:hidden}.char-stat-bar-fill{background:linear-gradient(90deg, var(--accent-gold-dim) 0%, var(--accent-gold) 100%);height:100%;transition:width .4s var(--ease-out-expo);border-radius:3px}.char-stat-value{color:var(--text-primary);text-align:right;font-size:.75rem;font-weight:600}.char-card-traits{flex-wrap:wrap;gap:.35rem;display:flex}.identity-pill,.char-trait-chip{--identity-accent:var(--accent-gold);--identity-bg:#513f1f38;--identity-border:#bc934e47;background:linear-gradient(180deg, var(--identity-bg) 0%, #0f0b08d1 100%);color:var(--identity-accent);border:1px solid var(--identity-border);border-radius:999px;align-items:center;gap:.35rem;padding:.24rem .55rem;font-size:.72rem;display:inline-flex;box-shadow:inset 0 1px #ffffff0a}.identity-pill.tone-red,.char-trait-chip.tone-red{--identity-accent:var(--accent-red);--identity-bg:#4e211842;--identity-border:#ba503b47}.identity-pill.tone-teal,.char-trait-chip.tone-teal{--identity-accent:var(--accent-teal);--identity-bg:#1b413b47;--identity-border:#44a79647}.identity-pill.tone-gold,.char-trait-chip.tone-gold{--identity-accent:var(--accent-gold);--identity-bg:#513f1f3d;--identity-border:#bc934e47}.identity-pill.tone-muted,.char-trait-chip.tone-muted{--identity-accent:#b7b2a7;--identity-bg:#4d46423d;--identity-border:#8478713d}.identity-pill.tone-violet,.char-trait-chip.tone-violet{--identity-accent:#b7a6e8;--identity-bg:#33254b47;--identity-border:#7e5db647}.identity-pill{letter-spacing:.08em;text-transform:uppercase;font-size:.68rem;font-weight:700}.identity-pill span:last-child{line-height:1}.identity-glyph{width:1.15rem;height:1.15rem;color:var(--identity-accent);box-shadow:inset 0 0 0 1px var(--identity-border);background:radial-gradient(circle at 30% 25%,#ffffff29,#0000 48%),#0807056b;border-radius:999px;flex-shrink:0;place-items:center;display:inline-grid}.identity-glyph-art{width:.92rem;height:.92rem;overflow:visible}.char-trait-label{text-transform:capitalize;color:#e2dbcf}.char-trait-chip:hover,.identity-pill:hover{border-color:color-mix(in srgb, var(--identity-accent) 40%, transparent);transform:translateY(-1px)}.char-trait-chip .identity-glyph{width:1.25rem;height:1.25rem}.char-card-compact .identity-pill{margin-left:auto}.char-card-record{color:var(--text-muted);gap:.75rem;font-size:.75rem;display:flex}.dynasty-panel{flex-direction:column;gap:1rem;padding:1rem;display:flex}.dynasty-panel-header{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.dynasty-panel-header h3{color:var(--accent-gold);font-family:Cinzel,serif}.dynasty-panel-controls{gap:.35rem;display:flex}.dynasty-panel-controls button{padding:.35rem .7rem;font-size:.75rem}.dynasty-ruler-banner{border:1px solid var(--accent-gold-dim);background:linear-gradient(#28211599 0%,#0000 100%);border-radius:12px;overflow:hidden}.dynasty-ruler-banner .char-card{background:0 0;border:none}.dynasty-summary-grid{grid-template-columns:repeat(4,1fr);gap:.5rem;display:grid}.dynasty-summary-card{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:8px;flex-direction:column;align-items:center;gap:.35rem;padding:.5rem;display:flex}.dynasty-summary-card .identity-pill{justify-content:center}.dynasty-summary-card strong{color:var(--accent-gold);font-size:1.1rem}.dynasty-tree-view{flex-direction:column;gap:1rem;display:flex}.dynasty-generation{border-left:2px solid var(--panel-border);flex-direction:column;gap:.5rem;padding-left:1rem;display:flex}.dynasty-gen-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;font-weight:600}.dynasty-gen-members{flex-direction:column;gap:.35rem;display:flex}.dynasty-list-view{flex-direction:column;gap:1rem;display:flex}.dynasty-section{flex-direction:column;gap:.5rem;padding:.5rem 0;display:flex}.dynasty-section h4{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem;font-size:.85rem}.dynasty-member-grid{flex-direction:column;gap:.35rem;display:flex}.dynasty-detail-overlay{-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.dynasty-detail-content{flex-direction:column;gap:.75rem;width:100%;max-width:400px;display:flex}.dynasty-detail-content>button{align-self:flex-end}.army-panel{flex-direction:column;gap:1rem;padding:1rem;display:flex}.army-panel-header{justify-content:space-between;align-items:flex-start;display:flex}.army-panel-header h3{color:var(--accent-red)}.army-list{flex-direction:column;gap:.5rem;display:flex}.army-card{background:var(--panel-bg);border:1px solid var(--panel-border);cursor:pointer;transition:var(--transition-normal);border-radius:12px;flex-direction:column;gap:.6rem;padding:.85rem;display:flex}.army-card:hover{border-color:var(--accent-red);background:var(--panel-bg-hover)}.army-card-selected{border-color:var(--accent-red);box-shadow:var(--shadow-glow-red)}.army-card-header{justify-content:space-between;align-items:flex-start;display:flex}.army-card-name{font-family:Outfit,sans-serif;font-size:.95rem}.army-card-location{color:var(--text-muted);font-size:.75rem}.army-card-strength{flex-direction:column;align-items:flex-end;display:flex}.army-card-strength strong{color:var(--accent-red);font-size:1.2rem}.army-card-strength span{color:var(--text-muted);font-size:.7rem}.army-card-body{flex-direction:column;gap:.5rem;display:flex}.army-troop-breakdown{gap:1rem;display:flex}.army-troop-row{align-items:baseline;gap:.4rem;display:flex}.army-troop-row span{color:var(--text-muted);font-size:.75rem}.army-troop-row strong{font-size:.85rem}.army-card-meta{flex-direction:column;gap:.3rem;display:flex}.army-meta-row{justify-content:space-between;align-items:center;font-size:.8rem;display:flex}.army-meta-row>span:first-child{color:var(--text-muted)}.army-morale-bar{background:#352f27cc;border-radius:4px;width:80px;height:8px;position:relative;overflow:hidden}.army-morale-fill{height:100%;transition:width .4s var(--ease-out-expo);border-radius:4px}.army-morale-fill.teal{background:var(--accent-teal)}.army-morale-fill.gold{background:var(--accent-gold)}.army-morale-fill.red{background:var(--accent-red)}.army-morale-label{color:var(--text-primary);text-shadow:0 1px 2px #00000080;font-size:.6rem;font-weight:600;position:absolute;top:-1px;right:4px}.army-general-slot{border:1px dashed var(--panel-border);background:#1d1a1699;border-radius:8px;padding:.5rem}.army-general-info{align-items:center;gap:.5rem;display:flex}.army-general-portrait{background:var(--accent-gold-dim);width:28px;height:28px;color:var(--text-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-family:Cinzel,serif;font-size:.75rem;font-weight:700;display:flex}.army-general-info div{flex-direction:column;display:flex}.army-general-info strong{font-size:.8rem}.army-general-info span{color:var(--text-muted);font-size:.7rem}.army-general-empty{color:var(--text-muted);flex-direction:column;align-items:center;gap:.15rem;font-size:.8rem;display:flex}.army-general-warning{color:var(--accent-red);font-size:.72rem}.army-empty-state{text-align:center;color:var(--text-secondary);background:var(--panel-bg);border:1px dashed var(--panel-border);border-radius:12px;gap:.3rem;padding:1.5rem;display:grid}.detail-tab-bar{background:#0000004d;border-radius:10px;gap:2px;margin-bottom:.5rem;padding:.25rem;display:flex}.detail-tab-bar button{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:.45rem .75rem;font-size:.8rem;font-weight:600;transition:background .15s,color .15s}.detail-tab-bar button:hover{color:var(--text-primary);background:#ffffff0f}.detail-tab-bar button.active{color:var(--text-primary);background:#ffffff1a;box-shadow:0 1px 4px #0000004d}.ruler-banner-card{cursor:pointer;transition:background .15s}.ruler-banner-card:hover{background:#ffffff0f}.ruler-banner-row{align-items:center;gap:.6rem;margin-bottom:.4rem;display:flex}.ruler-banner-portrait{width:2.2rem;height:2.2rem;color:var(--text-primary);background:linear-gradient(135deg,#ffd7004d,#ffd7001a);border:2px solid #ffd70080;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex}.ruler-banner-info{flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.ruler-banner-info strong{white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;overflow:hidden}.ruler-banner-info span{color:var(--text-secondary);font-size:.7rem}.ruler-banner-stats{gap:.3rem;display:flex}.ruler-banner-stats span{width:1.6rem;height:1.6rem;color:var(--text-primary);background:#ffffff0f;border-radius:6px;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.province-army-list{flex-direction:column;gap:.4rem;display:flex}.province-army-item{background:#ffffff08;border-radius:8px;justify-content:space-between;align-items:center;gap:.5rem;padding:.4rem .5rem;display:flex}.province-army-item div{flex-direction:column;gap:.1rem;min-width:0;display:flex}.province-army-item strong{font-size:.8rem}.province-army-item span{color:var(--text-secondary);font-size:.7rem}.appt-panel{flex-direction:column;gap:.6rem;display:flex}.appt-panel-header{flex-direction:column;gap:.15rem;display:flex}.appt-panel-header h4{margin:0;font-size:.95rem}.appt-warning{background:#ff503c1f;border:1px solid #ff503c4d;border-radius:8px;flex-direction:column;gap:.15rem;padding:.5rem .6rem;font-size:.78rem;display:flex}.appt-warning strong{color:#ff6b5a}.appt-warning span{color:var(--text-secondary);font-size:.7rem}.appt-section{flex-direction:column;gap:.5rem;padding:.5rem 0;display:flex}.appt-section h5{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin:0 0 .3rem;font-size:.82rem}.appt-slot-list{flex-direction:column;gap:.5rem;display:flex}.appt-slot{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:10px;padding:.5rem}.appt-slot-header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.appt-slot-header div{flex-direction:column;gap:.1rem;display:flex}.appt-slot-header strong{font-size:.82rem}.appt-slot-header span{color:var(--text-secondary);font-size:.7rem}.appt-slot-assigned{align-items:center;gap:.3rem;display:flex}.appt-recall-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:1px solid #ffffff26;border-radius:6px;padding:.2rem .5rem;font-size:.7rem}.appt-recall-btn:hover{color:#ff6b5a;background:#ff503c26}.appt-candidates{border-top:1px solid #ffffff0f;flex-direction:column;gap:.3rem;margin-top:.4rem;padding-top:.4rem;display:flex}.appt-char-option{border-radius:8px;align-items:center;gap:.5rem;padding:.35rem .4rem;transition:background .12s;display:flex}.appt-char-option:hover{background:#ffffff0a}.appt-char-option.appt-char-assigned{opacity:.5}.appt-char-portrait{background:#ffffff14;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:1.8rem;height:1.8rem;font-size:.85rem;font-weight:700;display:flex}.appt-char-info{flex-direction:column;flex:1;gap:.05rem;min-width:0;display:flex}.appt-char-info strong{font-size:.78rem}.appt-char-info span{color:var(--text-secondary);font-size:.65rem}.appt-char-option button{color:#5eead4;cursor:pointer;background:#5eead41a;border:1px solid #5eead44d;border-radius:6px;flex-shrink:0;padding:.2rem .6rem;font-size:.7rem}.appt-char-option button:hover:not(:disabled){background:#5eead433}.appt-char-option button:disabled{opacity:.4;cursor:default}.appt-empty{text-align:center;color:var(--text-secondary);flex-direction:column;gap:.2rem;padding:1rem;font-size:.78rem;display:flex}.campaign-layout-map-first{grid-template-columns:minmax(280px,320px) minmax(0,1fr) minmax(320px,380px);align-items:start;gap:1rem;height:auto;min-height:calc(100vh - 8.4rem)}.campaign-layout-map-first.no-command-rail{grid-template-columns:minmax(0,1fr) minmax(320px,380px);grid-template-areas:"map detail"}.campaign-layout-map-first.no-detail-panel{grid-template-columns:minmax(280px,320px) minmax(0,1fr);grid-template-areas:"rail map"}.campaign-layout-map-first.no-command-rail.no-detail-panel{grid-template-columns:minmax(0,1fr);grid-template-areas:"map"}.campaign-layout-map-first.is-immersive .command-rail,.campaign-layout-map-first.is-immersive .detail-panel{box-shadow:0 28px 70px #00000057}.command-rail,.detail-panel{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:linear-gradient(#1e150df5 0%,#100b08f5 100%),radial-gradient(circle at top,#c4a87024,#0000 48%);border:1px solid #c4a87029;max-height:calc(100vh - 8.4rem);position:sticky;top:1rem}.campaign-command-bar{box-shadow:var(--shadow-lg);background:radial-gradient(circle at 0 0,#c4a8702e,#0000 32%),linear-gradient(#18120cf0 0%,#0d0906f5 100%);border:1px solid #c4a87029;border-radius:18px;grid-template-columns:minmax(220px,1.2fr) minmax(0,1fr) minmax(0,1.2fr) auto;align-items:center;gap:.9rem;padding:1rem 1.05rem;display:grid;position:relative;overflow:hidden}.campaign-command-bar:before{content:"";pointer-events:none;background:linear-gradient(90deg,#0000 0%,#fff9e909 45%,#0000 100%),radial-gradient(circle at 100% 0,#5b7ea41f,#0000 24%);position:absolute;inset:0}.campaign-command-bar:after{content:"";background:linear-gradient(90deg,#0000,#e2c99866,#0000);height:1px;position:absolute;inset:auto 0 0}.campaign-command-brand{align-items:center;gap:.85rem;min-width:0;display:flex}.campaign-command-brand-copy{gap:.18rem;min-width:0;display:grid}.campaign-command-brand-copy strong{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-family:Cinzel,serif;font-size:1.15rem;overflow:hidden}.campaign-command-brand-copy span:last-child{color:var(--text-secondary);font-size:.78rem}.campaign-command-kicker,.campaign-command-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.14em;font-size:.68rem}.campaign-command-sigil{flex-shrink:0}.campaign-command-stat-strip{grid-template-columns:repeat(4,minmax(0,1fr));gap:.5rem;display:grid}.campaign-command-stat{background:radial-gradient(circle at 0 0,#e2c99814,#0000 28%),#ffffff09;border:1px solid #c4a8701f;border-radius:12px;gap:.18rem;padding:.55rem .7rem;display:grid}.campaign-command-stat span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:.68rem}.campaign-command-stat strong{color:var(--text-primary);font-family:Cinzel,serif;font-size:.82rem}.campaign-command-groups{gap:.55rem;display:grid}.campaign-command-group{flex-wrap:wrap;align-items:center;gap:.42rem;display:flex}.campaign-command-group button,.drawer-tab-row button,.atlas-toggle-row button,.atlas-chip,.atlas-compare-button,.drawer-close{color:var(--text-secondary);transition:var(--transition-fast);background:#ffffff0a;border:1px solid #c4a87029;border-radius:999px;padding:.42rem .78rem;font-size:.75rem;line-height:1}.campaign-command-group button.active,.drawer-tab-row button.active,.atlas-toggle-row button.active,.atlas-compare-button.active{color:#f8f1dd;background:linear-gradient(#c6aa7147 0%,#76582c5c 100%);border-color:#e2c99873}.campaign-command-group button:hover,.drawer-tab-row button:hover,.atlas-toggle-row button:hover,.atlas-chip:hover,.atlas-compare-button:hover,.drawer-close:hover{color:var(--text-primary);border-color:#e2c9985c;transform:translateY(-1px)}.campaign-command-actions{justify-items:end;gap:.45rem;min-width:150px;display:grid}.campaign-command-utility{flex-wrap:wrap;justify-content:flex-end;gap:.4rem;display:flex}.campaign-command-utility button{color:var(--text-secondary);transition:var(--transition-fast);background:#ffffff0a;border:1px solid #c4a87029;border-radius:999px;padding:.38rem .72rem;font-size:.74rem;line-height:1}.campaign-command-utility button:hover{color:var(--text-primary);border-color:#e2c9985c;transform:translateY(-1px)}.campaign-command-orders{text-align:right;gap:.12rem;display:grid}.campaign-command-orders strong{color:var(--text-primary);max-width:15rem;font-size:.8rem}.campaign-command-endturn{min-width:10rem}.campaign-mandate-banner{box-shadow:var(--shadow-md);background:radial-gradient(circle at 0 0,#e2c99824,#0000 34%),linear-gradient(#18120ceb 0%,#0d0906f2 100%);border:1px solid #c4a87029;border-radius:18px;grid-template-columns:minmax(0,1.3fr) minmax(220px,.9fr) minmax(0,1fr);align-items:start;gap:.9rem;padding:.95rem 1.05rem;display:grid}.campaign-mandate-banner.ongoing{border-color:#c4a8702e}.campaign-mandate-banner.victory{box-shadow:var(--shadow-lg), 0 0 36px #bfa35c1f;background:radial-gradient(circle at 0 0,#bfa35c42,#0000 38%),linear-gradient(135deg,#1f210ff5 0%,#120e07f2 100%);border-color:#bfa35c6b}.campaign-mandate-banner.defeat{box-shadow:var(--shadow-lg), 0 0 30px #a64e421f;background:radial-gradient(circle at 0 0,#a64e4238,#0000 36%),linear-gradient(135deg,#26120ef5 0%,#120a08f2 100%);border-color:#a64e4261}.campaign-mandate-copy{gap:.28rem;display:grid}.campaign-mandate-kicker{color:var(--text-muted);text-transform:uppercase;letter-spacing:.16em;font-size:.7rem}.campaign-mandate-copy strong{color:var(--text-primary);font-family:Cinzel,serif;font-size:1.08rem}.campaign-mandate-copy p{color:var(--text-secondary);margin:0;line-height:1.45}.campaign-mandate-objective{color:var(--accent-gold-bright);font-size:.78rem;line-height:1.45}.campaign-mandate-metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem;display:grid}.campaign-mandate-metric{background:#ffffff0a;border:1px solid #c4a87024;border-radius:12px;gap:.2rem;padding:.62rem .72rem;display:grid}.campaign-mandate-metric span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;font-size:.66rem}.campaign-mandate-metric strong{color:var(--text-primary);font-size:.9rem}.campaign-mandate-guidance{gap:.5rem;display:grid}.campaign-mandate-progress{color:var(--accent-gold);letter-spacing:.06em;text-transform:uppercase;font-size:.77rem}.campaign-mandate-notes{flex-wrap:wrap;gap:.45rem;display:flex}.campaign-mandate-note{color:var(--text-secondary);background:#ffffff0b;border:1px solid #c4a87029;border-radius:999px;align-items:center;padding:.45rem .65rem;font-size:.76rem;line-height:1.35;display:inline-flex}.campaign-mandate-actions{flex-wrap:wrap;gap:.55rem;display:flex}.campaign-mandate-actions button{color:var(--text-secondary);transition:var(--transition-fast);background:#ffffff0b;border:1px solid #c4a8702e;border-radius:999px;padding:.58rem .88rem}.campaign-mandate-actions button:hover{color:var(--text-primary);border-color:#e2c9985c;transform:translateY(-1px)}.command-drawer-header,.detail-drawer-header{align-items:flex-start;gap:1rem}.drawer-close{flex-shrink:0}.drawer-tab-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:.35rem;display:grid}.drawer-tab-row button{width:100%}.detail-drawer-header{margin-bottom:.1rem}.atlas-summary-head{justify-content:space-between;align-items:flex-start;gap:.8rem;display:flex}.atlas-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.atlas-controls-card{gap:.8rem}.atlas-control-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem;display:grid}.atlas-control-field{gap:.3rem;display:grid}.atlas-control-field span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;font-size:.68rem}.atlas-toggle-row,.atlas-chip-row{flex-wrap:wrap;gap:.45rem;display:flex}.atlas-chip{font-size:.72rem}.atlas-region-list{gap:.7rem;display:grid}.atlas-region-card{gap:.8rem;padding:1rem 1.05rem}.atlas-region-header{text-align:left;background:0 0;border:0;justify-content:space-between;align-items:flex-start;gap:.85rem;width:100%;padding:0;display:flex}.atlas-region-header strong{color:var(--text-primary);font-size:.95rem}.atlas-region-header span{color:var(--text-secondary);margin-top:.18rem;font-size:.75rem;display:block}.atlas-region-header.collapsed strong{color:var(--text-secondary)}.atlas-region-metrics{flex-wrap:wrap;justify-content:flex-end;gap:.4rem;display:flex}.atlas-region-metrics span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem}.atlas-entry-list{gap:.5rem;display:grid}.atlas-entry-row{grid-template-columns:minmax(0,1fr) auto;align-items:stretch;gap:.5rem;display:grid}.atlas-entry-row.selected .atlas-entry{border-color:#e2c9986b;box-shadow:0 0 0 1px #e2c9982e}.atlas-entry-row.compared .atlas-entry{border-color:#5eead457}.atlas-entry{text-align:left;background:linear-gradient(#251b12b8 0%,#130d0acc 100%);border:1px solid #c4a8701a;border-radius:14px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:.7rem;width:100%;padding:.65rem .75rem;display:grid}.atlas-entry:hover{border-color:#e2c99842;transform:translateY(-1px)}.atlas-entry-sigil{width:2.6rem;height:2.6rem}.atlas-entry-body{gap:.14rem;min-width:0;display:grid}.atlas-entry-body strong{color:var(--text-primary);font-size:.85rem}.atlas-entry-body span{color:var(--text-secondary);font-size:.72rem;line-height:1.4}.atlas-entry-meta{flex-wrap:wrap;justify-content:flex-end;gap:.35rem;display:flex}.atlas-compare-button{align-self:center}.atlas-empty-state{text-align:center}.powers-drawer-card{gap:1rem}.faction-mark{align-items:center;gap:.9rem;padding:.95rem 1rem;display:flex}.faction-mark-copy{gap:.15rem;display:grid}.faction-mark strong{margin:0;font-size:1.08rem}.faction-mark span{margin:0;font-size:.78rem}.faction-mark-sigil{flex-shrink:0}.faction-sigil{--sigil-accent:#d6b06a;--sigil-field:#1a1610;--sigil-field-soft:#2a2118;--sigil-shadow:#d6b06a42;width:3rem;height:3rem;box-shadow:0 16px 30px -18px var(--sigil-shadow);background:radial-gradient(circle at 30% 20%,#ffffff1f,#0000 38%);border-radius:18px;place-items:center;display:grid;position:relative}.faction-sigil-art{filter:drop-shadow(0 6px 12px #0003);width:100%;height:100%}.faction-sigil-disc{fill:var(--sigil-field);stroke:#ecdfbf2e;stroke-width:1.6px}.faction-sigil-inner{fill:var(--sigil-field-soft)}.faction-sigil-shield{fill:color-mix(in srgb, var(--sigil-accent) 72%, white 8%)}.faction-sigil-crest{fill:#fff8e3e0}.faction-sigil-text{color:#fff6e0eb;text-shadow:0 1px 6px #0006;font-family:Cinzel,serif;font-size:.72rem;font-weight:700;position:absolute}.portrait-token{--portrait-accent:#b68a53;--portrait-ring:#b68a5373;--portrait-shadow:#b68a5347;--portrait-field:#1b1610;--portrait-field-soft:#2b241b;--portrait-bust:#f1e4c6e0;--portrait-mark:#b68a53;box-shadow:0 12px 24px -18px var(--portrait-shadow);border-radius:50%;place-items:center;display:grid;position:relative;overflow:hidden}.portrait-token-xs{width:1.85rem;height:1.85rem}.portrait-token-sm{width:2.3rem;height:2.3rem}.portrait-token-md{width:3rem;height:3rem}.portrait-token-art{width:100%;height:100%}.portrait-token-disc{fill:var(--portrait-field);stroke:var(--portrait-ring);stroke-width:2px}.portrait-token-halo{fill:var(--portrait-field-soft)}.portrait-token-shoulders,.portrait-token-head{fill:var(--portrait-bust)}.portrait-token-profile{fill:none;stroke:#3120126b;stroke-width:1.4px;stroke-linecap:round}.portrait-token-diadem{fill:none;stroke:var(--portrait-mark);stroke-width:2px;stroke-linecap:round;stroke-linejoin:round}.portrait-token-monogram{color:#fff4dce0;letter-spacing:.06em;text-transform:uppercase;background:#00000057;border-radius:999px;min-width:1.1rem;padding:.08rem .18rem;font-size:.52rem;font-weight:700;position:absolute;bottom:.1rem;right:.12rem}.portrait-token.is-deceased{filter:grayscale()}.char-card-portrait,.char-card-portrait-mini,.ruler-banner-portrait,.army-general-portrait,.appt-char-portrait{background:0 0;border:0;border-radius:0;width:auto;height:auto;padding:0}.char-card-portrait-mini .portrait-token-xs{width:2rem;height:2rem}.ruler-banner-portrait.portrait-token-sm{width:2.55rem;height:2.55rem}.army-general-portrait.portrait-token-xs,.appt-char-portrait.portrait-token-xs{width:1.9rem;height:1.9rem}@media (width<=1480px){.campaign-command-bar{grid-template-columns:minmax(220px,.9fr) minmax(0,1.4fr)}.campaign-command-actions{justify-items:stretch}.campaign-command-orders{text-align:left}}@media (width<=1200px){.campaign-layout-map-first,.campaign-layout-map-first.no-command-rail,.campaign-layout-map-first.no-detail-panel,.campaign-layout-map-first.no-command-rail.no-detail-panel{grid-template-columns:minmax(0,1fr);grid-template-areas:"map""rail""detail";height:auto;min-height:0}.command-rail,.detail-panel{max-height:none;position:static}.campaign-mandate-banner{grid-template-columns:minmax(0,1fr)}.campaign-command-stat-strip,.atlas-control-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.campaign-mandate-metrics{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (width<=780px){.campaign-command-stat-strip,.atlas-control-grid,.atlas-summary-grid,.realm-summary-grid,.province-summary-grid{grid-template-columns:minmax(0,1fr)}.campaign-mandate-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.atlas-entry-row{grid-template-columns:minmax(0,1fr)}.atlas-entry{grid-template-columns:auto minmax(0,1fr)}.atlas-entry-meta{grid-column:1/-1;justify-content:flex-start}}@media (height<=820px){.campaign-mandate-banner{gap:.7rem;padding:.75rem .9rem}.campaign-mandate-copy p{font-size:.92rem}.campaign-mandate-objective,.campaign-mandate-progress{font-size:.72rem}.campaign-mandate-metric{padding:.5rem .62rem}.campaign-mandate-notes{display:none}}.portal-shell{--portal-gold:#d9b76f;--portal-gold-bright:#f3d79b;--portal-ink:#090807;--portal-panel:#18120cf0;--portal-panel-soft:#231a11d1;--portal-line:#dab97533;color:#eee5d2;background:radial-gradient(circle at 50% -10%,#c69e572b,#0000 34rem),radial-gradient(circle at 8% 34%,#46668429,#0000 28rem),radial-gradient(circle at 92% 42%,#763f2a26,#0000 28rem),linear-gradient(#0d0b09 0%,#080706 52%,#060505 100%);min-height:100vh;position:relative;overflow-x:hidden}.web-portal-document,.web-portal-body,.web-portal-body #app{height:auto;min-height:100%;overflow-y:auto}.portal-shell:before{content:"";pointer-events:none;opacity:.28;background:repeating-linear-gradient(90deg,#0000 0 119px,#dab97509 119px 120px),repeating-linear-gradient(#0000 0 119px,#dab97506 119px 120px);position:fixed;inset:0}.portal-header{z-index:100;border-bottom:1px solid var(--portal-line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#080706e0;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:1.5rem;min-height:76px;padding:.75rem clamp(1rem,3vw,3.5rem);display:grid;position:sticky;top:0}.portal-brand{text-align:left;background:0 0;border:0;align-items:center;gap:.75rem;padding:0;display:flex}.portal-brand:hover{background:0 0;border:0}.portal-brand-mark{width:2.8rem;height:2.8rem;color:var(--portal-gold-bright);letter-spacing:.12em;background:radial-gradient(circle at 50% 30%,#f3d79b33,#0000 42%),#20170f;border:1px solid #f3d79b6b;border-radius:50% 50% 46% 46%;place-items:center;font-family:Cinzel,serif;font-size:.82rem;display:grid;box-shadow:0 0 28px #dab97524}.portal-brand>span:last-child{gap:.05rem;display:grid}.portal-brand strong{color:#f7ecd7;letter-spacing:.04em;font-family:Cinzel,serif;font-size:.94rem}.portal-brand small{color:#9e927f;text-transform:uppercase;letter-spacing:.16em;font-size:.64rem}.portal-nav{justify-content:center;align-items:center;gap:.2rem;min-width:0;display:flex}.portal-nav a,.portal-header-actions button,.portal-header-actions a,.portal-footer a,.web-game-utility button{color:#afa38f;box-shadow:none;background:0 0;border:0;text-decoration:none}.portal-nav a{letter-spacing:.04em;border-radius:999px;padding:.6rem .78rem;font-size:.75rem}.portal-nav a:hover,.portal-nav a.active{color:#f3e7cf;background:#dab9751a;border:0}.portal-header-actions{justify-content:flex-end;align-items:center;gap:.55rem;display:flex}.portal-primary-action{font-weight:700;color:#171008!important;background:linear-gradient(#e4c787 0%,#b98e48 100%)!important;border:1px solid #f3d79b7a!important;box-shadow:0 12px 28px #a06f312e!important}.portal-primary-action:hover{background:linear-gradient(#f1d89f 0%,#cba15b 100%)!important}.portal-primary-action.compact{padding:.55rem .85rem}.portal-main{z-index:1;width:min(1500px,100% - clamp(2rem,6vw,7rem));min-height:calc(100vh - 160px);margin:0 auto;position:relative}.portal-hero{grid-template-columns:minmax(0,1.05fr) minmax(420px,.95fr);align-items:center;gap:clamp(2rem,6vw,7rem);min-height:min(760px,100vh - 77px);padding:clamp(3rem,8vh,7rem) 0;display:grid}.portal-hero-copy{justify-items:start;gap:1.45rem;display:grid}.portal-kicker,.portal-section-heading>span,.portal-nation-card>div>span,.portal-strategy-grid article>span,.portal-lore-ledger article>span,.portal-topic-card>span,.portal-auth-card .portal-section-heading>span{color:var(--portal-gold);text-transform:uppercase;letter-spacing:.18em;font-size:.7rem}.portal-hero h1{color:#f7ecd7;letter-spacing:-.045em;text-shadow:0 24px 80px #0000009e;margin:0;font-family:Cinzel,serif;font-size:clamp(3.8rem,8vw,8rem);font-weight:500;line-height:.88}.portal-hero-copy>p{color:#bdb19d;max-width:680px;margin:0;font-size:clamp(1rem,1.4vw,1.22rem);line-height:1.75}.portal-hero-actions,.portal-account-actions,.portal-gate-actions{flex-wrap:wrap;gap:.75rem;display:flex}.portal-hero-actions button,.portal-hero-actions a{border:1px solid var(--portal-line);color:#b9ad98;min-height:3rem;font:inherit;background:#ffffff05;border-radius:8px;justify-content:center;align-items:center;padding:.7rem 1.15rem;text-decoration:none;display:inline-flex}.portal-hero-ledger{border-top:1px solid var(--portal-line);color:#918673;flex-wrap:wrap;gap:.8rem 1.5rem;padding-top:.75rem;font-size:.8rem;display:flex}.portal-hero-ledger strong{color:#e9d4a8;margin-right:.3rem;font-family:Cinzel,serif}.portal-hero-art{isolation:isolate;place-items:center;min-height:560px;display:grid;position:relative}.portal-world-disc{aspect-ratio:1;color:#ead7af;z-index:2;background:radial-gradient(circle at 38% 34%,#dec58e59,#0000 5%),radial-gradient(circle at 56% 56%,#74958b3b,#0000 12%),radial-gradient(circle at 50% 48%,#44341f 0%,#1e1710 48%,#0d0a08 70%);border:1px solid #dfc08154;border-radius:50%;align-content:center;place-items:center;width:clamp(260px,30vw,430px);display:grid;position:relative;box-shadow:inset -36px -30px 70px #0000009e,0 0 100px #cda55b26}.portal-world-disc:before,.portal-world-disc:after{content:"";border:1px solid #dfc08129;border-radius:50%;position:absolute}.portal-world-disc:before{inset:15% -2%}.portal-world-disc:after{inset:-2% 24%}.portal-world-disc span{font-family:Cinzel,serif;font-size:clamp(3rem,7vw,6rem)}.portal-world-disc strong{color:#9d8c6e;letter-spacing:.32em;font-size:.82rem}.portal-world-orbit{z-index:1;border:1px solid #dab97529;border-radius:50%;position:absolute}.orbit-one{aspect-ratio:1.4;width:95%;transform:rotate(-18deg)}.orbit-two{aspect-ratio:.72;width:72%;transform:rotate(31deg)}.portal-hero-sigil-row{z-index:3;gap:.55rem;display:flex;position:absolute;bottom:1rem;left:50%;transform:translate(-50%)}.portal-hero-sigil-row .faction-sigil{filter:drop-shadow(0 8px 14px #00000080);width:2.9rem;height:3.3rem}.portal-feature-band{border-top:1px solid var(--portal-line);border-bottom:1px solid var(--portal-line);grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:clamp(3rem,7vw,7rem);display:grid}.portal-feature-band article{border-right:1px solid var(--portal-line);padding:1.6rem clamp(1rem,2.5vw,2.5rem)}.portal-feature-band article:last-child{border-right:0}.portal-feature-band span{color:#e5cc99;font-family:Cinzel,serif}.portal-feature-band p{color:#9f9481;margin:.55rem 0 0;line-height:1.55}.portal-definition-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.9rem;display:grid}.portal-definition-grid article{border:1px solid var(--portal-line);background:linear-gradient(145deg,#dab9750e,#0000 52%),#0e0b08d1;border-radius:16px;flex-direction:column;align-items:flex-start;min-height:280px;padding:clamp(1.25rem,2.5vw,2rem);display:flex}.portal-definition-grid article>span{color:var(--portal-gold);text-transform:uppercase;letter-spacing:.17em;font-size:.68rem}.portal-definition-grid h3{color:#ead9b8;margin:1rem 0 0;font-family:Cinzel,serif;font-size:1.35rem;font-weight:500}.portal-definition-grid p{color:#a99d89;margin:.8rem 0 1.5rem;line-height:1.65}.portal-definition-grid a{color:#d9ba78;text-underline-offset:.25em;margin-top:auto}.portal-faq-list{gap:.7rem;max-width:980px;display:grid}.portal-faq-list details{border:1px solid var(--portal-line);background:#0f0c09c7;border-radius:12px}.portal-faq-list summary{color:#e7d7b8;cursor:pointer;padding:1rem 1.2rem;font-family:Cinzel,serif}.portal-faq-list p{color:#a99d89;margin:0;padding:0 1.2rem 1.2rem;line-height:1.7}.portal-section{padding:clamp(3rem,7vw,7rem) 0}.portal-section-heading{gap:.7rem;max-width:860px;margin-bottom:2rem;display:grid}.portal-section-heading.compact{margin-bottom:.5rem}.portal-section-heading h2{color:#f4e8d0;margin:0;font-family:Cinzel,serif;font-size:clamp(2rem,4vw,4.4rem);font-weight:500;line-height:1.05}.portal-section-heading p{color:#a99d89;margin:0;line-height:1.65}.portal-era-ribbon,.portal-strategy-grid,.portal-step-grid,.portal-account-grid,.portal-admin-metrics{gap:.8rem;display:grid}.portal-era-ribbon{grid-template-columns:repeat(9,minmax(120px,1fr));padding-bottom:.7rem;overflow-x:auto}.portal-era-ribbon article,.portal-strategy-grid article,.portal-step-grid article,.portal-account-grid article,.portal-admin-metrics article{border:1px solid var(--portal-line);background:linear-gradient(#291e12bd,#110d09e0);border-radius:14px;padding:1.1rem}.portal-era-ribbon article{min-width:150px}.portal-era-ribbon span,.portal-account-grid strong,.portal-admin-metrics strong{color:#ead6aa;font-family:Cinzel,serif}.portal-era-ribbon p{color:#8f8371;text-transform:capitalize;margin:.4rem 0 0;font-size:.76rem}.portal-filter-bar,.portal-admin-toolbar{grid-template-columns:minmax(0,1fr) minmax(180px,260px);gap:.75rem;margin-bottom:1.2rem;display:grid}.portal-shell input,.portal-shell select,.portal-shell textarea{color:#eee2ca;background:#050504bd;border:1px solid #dab97538;border-radius:10px;outline:none;width:100%;padding:.75rem .85rem}.portal-shell input:focus,.portal-shell select:focus,.portal-shell textarea:focus{border-color:#f3d79b9e;box-shadow:0 0 0 3px #dab97514}.portal-nation-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.85rem;display:grid}.portal-campaign-grid{grid-template-columns:repeat(auto-fit,minmax(min(100%,410px),1fr));gap:1rem;display:grid}.portal-campaign-card{border:1px solid var(--portal-line);background:linear-gradient(145deg,#261b11eb,#0d0b08f5);border-radius:16px;gap:1rem;padding:1.2rem;display:grid}.portal-campaign-card.authored{border-color:#dab97561;box-shadow:inset 0 3px #dab97566}.portal-campaign-card>header,.portal-campaign-launch{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.portal-campaign-card>header span,.portal-campaign-launch span{color:#8f8371;letter-spacing:.06em;text-transform:uppercase;font-size:.72rem}.portal-campaign-card>header strong{color:#d8bd84;letter-spacing:.08em;text-transform:uppercase;border:1px solid #dab97540;border-radius:999px;flex:none;padding:.34rem .55rem;font-size:.68rem}.portal-campaign-card h3{color:#f0e4cd;margin:.25rem 0 0;font-family:Cinzel,serif;font-size:1.45rem}.portal-campaign-card>p,.portal-campaign-context{color:#b0a38e;margin:0;line-height:1.6}.portal-campaign-context{color:#8f8371;background:#00000029;border-left:2px solid #dab97552;padding:.85rem;font-size:.82rem}.portal-campaign-card>footer{gap:.85rem;padding-top:.2rem;display:grid}.portal-campaign-card label{color:#c9b994;gap:.4rem;font-size:.78rem;display:grid}.portal-campaign-launch{align-items:center}.portal-campaign-launch .portal-primary-action{flex:none}.portal-nation-card{border:1px solid var(--portal-line);background:radial-gradient(circle at 0 0,#dab97514,#0000 34%),#16100bd1;border-radius:14px;grid-template-columns:auto minmax(0,1fr);gap:.9rem;padding:1rem;transition:transform .18s,border-color .18s;display:grid}.portal-nation-card:hover{border-color:#f3d79b61;transform:translateY(-2px)}.portal-nation-sigil{width:3.2rem;height:3.8rem}.portal-nation-card h3,.portal-strategy-grid h3,.portal-lore-ledger h3,.portal-topic-card h3,.portal-forum-compose h3,.portal-controls-ledger h3{color:#f0e4cd;margin:.24rem 0 .45rem;font-family:Cinzel,serif}.portal-nation-card p,.portal-strategy-grid p,.portal-lore-ledger p,.portal-topic-card p{color:#a79b87;margin:0;line-height:1.55}.portal-nation-identity{border-top:1px solid #dab9751f;gap:.25rem;margin-top:.7rem;padding-top:.65rem;display:grid}.portal-nation-identity strong{color:#dac79f;font-size:.75rem}.portal-nation-identity span{color:#897d6a;font-size:.7rem;line-height:1.4}.portal-nation-card footer{color:#837765;text-transform:capitalize;border-top:1px solid #dab9751f;grid-column:1/-1;justify-content:space-between;gap:.75rem;padding-top:.7rem;font-size:.72rem;display:flex}.portal-strategy-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.portal-strategy-grid article{min-height:230px}.portal-step-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.portal-step-grid article>span{color:#dab9756b;font-family:Cinzel,serif;font-size:2rem}.portal-step-grid h3{color:#ead6aa;font-family:Cinzel,serif}.portal-step-grid p{color:#a19684;line-height:1.55}.portal-controls-ledger{border:1px solid var(--portal-line);background:#18120cc2;border-radius:14px;max-width:920px;margin-top:1.2rem;padding:1.2rem}.portal-controls-ledger>div{border-top:1px solid #dab9751a;grid-template-columns:140px minmax(0,1fr);gap:1rem;padding:.7rem 0;display:grid}.portal-controls-ledger span{color:var(--portal-gold)}.portal-controls-ledger strong{color:#b7aa95;font-weight:400}.portal-lore-ledger{border-left:1px solid #dab9754d;max-width:980px;margin-left:.5rem}.portal-lore-ledger article{padding:1rem 1rem 2rem 2rem;position:relative}.portal-lore-ledger article:before{content:"";background:var(--portal-gold);border-radius:50%;width:.7rem;height:.7rem;position:absolute;top:1.35rem;left:-.38rem;box-shadow:0 0 18px #dab97573}.portal-forum-layout{grid-template-columns:minmax(0,1fr) minmax(280px,390px);align-items:start;gap:1rem;display:grid}.portal-topic-list{gap:.7rem;display:grid}.portal-topic-card,.portal-forum-compose,.portal-auth-card,.portal-gate-card{border:1px solid var(--portal-line);background:radial-gradient(circle at top left, #dab97514, transparent 35%), var(--portal-panel);border-radius:16px;padding:1.2rem;box-shadow:0 24px 70px #00000047}.portal-topic-card{width:100%;color:inherit;text-align:left;display:block}.portal-topic-card:hover{border-color:#c69b4db8;transform:translateY(-1px)}.portal-topic-card footer{color:#786e5e;margin-top:.75rem;font-size:.72rem}.portal-topic-thread{gap:1rem;display:grid}.portal-thread-back{justify-self:start}.portal-thread-original,.portal-thread-replies article,.portal-thread-compose{border:1px solid var(--portal-line);background:#0d1419b8;border-radius:14px;padding:1.15rem}.portal-thread-original>span,.portal-thread-original footer,.portal-thread-replies header span{color:var(--portal-muted)}.portal-thread-original h3{color:#f0e4cd;margin:.3rem 0 .7rem;font-family:Cinzel,serif}.portal-thread-original p,.portal-thread-replies p{white-space:pre-wrap}.portal-thread-replies{gap:.65rem;display:grid}.portal-thread-replies header{justify-content:space-between;gap:1rem;font-size:.78rem;display:flex}.portal-thread-compose{gap:.7rem;display:grid}.portal-thread-compose textarea{min-height:110px}.portal-thread-compose button{justify-self:end}.portal-forum-compose{gap:.75rem;display:grid;position:sticky;top:94px}.portal-forum-compose textarea{resize:vertical;min-height:180px}.portal-empty-state{border:1px dashed var(--portal-line);color:#8f8371;text-align:center;border-radius:14px;padding:2rem}.portal-auth-card{gap:.85rem;width:min(100%,520px);margin:clamp(2rem,8vh,7rem) auto;display:grid}.portal-auth-card label{color:#b8aa94;gap:.35rem;font-size:.78rem;display:grid}.portal-auth-tabs{background:#00000047;border-radius:12px;grid-template-columns:1fr 1fr;gap:.35rem;padding:.3rem;display:grid}.portal-auth-tabs button.active{color:#f0dfbd;background:#dab9751f}.portal-consent-checks{gap:.55rem;display:grid}.portal-check-row{align-items:start;grid-template-columns:auto minmax(0,1fr)!important}.portal-check-row input{accent-color:#c59d57;width:1rem;height:1rem;margin-top:.15rem}.portal-form-error{color:#efaa99;background:#7e2a1d2e;border:1px solid #d05b4461;border-radius:10px;margin:0;padding:.7rem .8rem}.portal-legal-note{color:#776d5e;margin:0;font-size:.7rem;line-height:1.5}.portal-modal-backdrop,.portal-gate-overlay{z-index:4000;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#030303d1;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.portal-modal{width:min(100%,560px);position:relative}.portal-modal .portal-auth-card{margin:0}.portal-modal-close{z-index:2;border-radius:50%;width:2rem;height:2rem;padding:0;position:absolute;top:.75rem;right:.75rem}.portal-gate-card{gap:1rem;width:min(100%,650px);padding:clamp(1.3rem,4vw,2.4rem);display:grid}.portal-gate-card h1{color:#f3e6cc;margin:0;font-family:Cinzel,serif;font-size:clamp(2rem,6vw,3.8rem);font-weight:500}.portal-gate-card>p{color:#b8ad99;margin:0;line-height:1.65}.portal-gate-points{color:#918675;gap:.45rem;display:grid}.portal-gate-points span:before{content:"◆";color:var(--portal-gold);margin-right:.5rem;font-size:.6rem}.portal-text-action{background:0 0!important;border-color:#0000!important}.portal-account-grid,.portal-admin-metrics{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.portal-account-grid article,.portal-admin-metrics article{gap:.45rem;display:grid}.portal-account-grid span,.portal-admin-metrics span{color:#897d6a;text-transform:uppercase;letter-spacing:.1em;font-size:.7rem}.portal-account-actions{margin-top:1.1rem}.portal-password-form{border:1px solid var(--portal-line);background:var(--portal-panel);border-radius:16px;grid-template-columns:minmax(220px,1fr) repeat(2,minmax(200px,.72fr)) auto;align-items:end;gap:1rem;margin:1rem 0;padding:1.2rem;display:grid}.portal-password-form h3,.portal-password-form p{margin:0}.portal-password-form h3{color:#f0e4cd;font-family:Cinzel,serif}.portal-password-form>div>span{color:var(--portal-gold);letter-spacing:.16em;text-transform:uppercase;font-size:.7rem}.portal-password-form>div>p{color:var(--portal-muted);margin-top:.35rem;font-size:.78rem}.portal-form-success{color:#8fd4ad;margin:0}.portal-password-warning{color:#e8c880;background:#7e551b24;border:1px solid #dab9756b;border-radius:12px;margin:1rem 0 0;padding:.8rem 1rem}.portal-admin-table-wrap{border:1px solid var(--portal-line);border-radius:14px;overflow:auto}.portal-admin-table{border-collapse:collapse;background:#0e0b08d1;width:100%;min-width:960px}.portal-admin-table th,.portal-admin-table td{text-align:left;border-bottom:1px solid #dab9751a;padding:.8rem;font-size:.78rem}.portal-admin-table th{color:#bda87d;text-transform:uppercase;letter-spacing:.08em}.portal-admin-table td{color:#a79c89}.portal-admin-table td:first-child{gap:.2rem;display:grid}.portal-admin-table td:first-child span{color:#786e5e}.portal-ad-slot{z-index:2;background:#0a0806ad;border:1px solid #dab97524;border-radius:12px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:.8rem;width:min(1180px,100% - 2rem);min-height:72px;margin:.75rem auto;padding:.55rem .8rem;display:grid;position:relative}.portal-ad-slot>span{color:#716756;text-transform:uppercase;letter-spacing:.12em;writing-mode:vertical-rl;font-size:.6rem}.portal-ad-placeholder{color:#887c68;text-align:center;align-content:center;place-items:center;min-height:54px;display:grid}.portal-ad-placeholder small{color:#665d4f}.soe-ad{box-sizing:border-box;z-index:2;background:#0a08069e;border:1px solid #dab9751f;border-radius:12px;flex-direction:column;align-items:center;gap:.4rem;width:max-content;max-width:min(100% - 1.5rem,100vw - 1rem);margin:.85rem auto;padding:.5rem .6rem;display:flex;position:relative;overflow:hidden}.soe-ad-label{color:#6f6553;text-transform:uppercase;letter-spacing:.16em;font-size:.58rem}.soe-ad-frame{background:#ffffff05;border-radius:6px;overflow:hidden}.soe-ad-native{width:min(1180px,100% - 2rem)}.soe-ad-native-host{width:100%;min-height:90px}.soe-ad-inline{margin:1.5rem auto}.web-game-frame>.soe-ad{margin:.3rem auto;padding:.25rem .4rem}.soe-ad-ingame-top{z-index:1200;position:sticky;top:42px}@media (width<=760px){.soe-ad{margin:.6rem auto}.soe-ad-ingame-top{display:none}}.portal-footer{border-top:1px solid var(--portal-line);color:#766c5d;z-index:2;justify-content:space-between;gap:1rem;width:min(1500px,100% - 2rem);margin:3rem auto 0;padding:2rem 0;display:flex;position:relative}.portal-footer>div,.portal-footer>nav{flex-wrap:wrap;align-items:center;gap:.7rem;display:flex}.portal-footer strong{color:#b4a489;font-family:Cinzel,serif}.portal-copyright{color:#6c6354;flex-basis:100%;font-size:.72rem}.portal-copyright a{color:#c2a86f;padding:0;text-decoration:none}.portal-copyright a:hover{text-decoration:underline}.portal-footer a{padding:.35rem .45rem}.portal-loading{color:#9d907b;background:#090807;align-content:center;place-items:center;gap:.5rem;min-height:100vh;display:grid}.portal-loading span{color:#d6b875;font-family:Cinzel,serif;font-size:clamp(2rem,6vw,4rem)}.web-game-frame{background:#080706;min-height:100vh}.web-game-utility{z-index:2500;color:#9f927e;background:#0d0a08;border-bottom:1px solid #dab97524;justify-content:space-between;align-items:center;min-height:42px;padding:.35rem 1rem;font-size:.75rem;display:flex;position:sticky;top:0}.web-game-frame>.app-shell{min-height:calc(100vh - 150px)}.web-game-frame>.portal-ad-slot{min-height:58px;margin:.35rem auto;padding:.3rem .6rem}.web-game-frame>.portal-ad-slot .portal-ad-placeholder{min-height:40px}@media (width<=1180px){.portal-header{grid-template-columns:auto 1fr}.portal-nav{order:3;grid-column:1/-1;justify-content:flex-start;padding-bottom:.15rem;overflow-x:auto}.portal-header-actions{justify-self:end}.portal-hero{grid-template-columns:1fr minmax(320px,.7fr)}.portal-strategy-grid,.portal-definition-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.portal-step-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=820px){.portal-header{gap:.6rem;padding:.7rem 1rem;position:relative}.portal-brand small{display:none}.portal-header-actions>button:first-child:not(.portal-primary-action){text-overflow:ellipsis;max-width:120px;overflow:hidden}.portal-main{width:min(100% - 1.5rem,1500px)}.portal-hero{grid-template-columns:1fr;min-height:0;padding:3rem 0 1rem}.portal-hero-copy{text-align:center;justify-items:center}.portal-hero-art{order:-1;min-height:380px}.portal-world-disc{width:min(72vw,330px)}.portal-feature-band,.portal-definition-grid{grid-template-columns:1fr}.portal-feature-band article{border-right:0;border-bottom:1px solid var(--portal-line)}.portal-strategy-grid,.portal-step-grid,.portal-forum-layout{grid-template-columns:1fr}.portal-forum-compose{position:static}.portal-filter-bar,.portal-admin-toolbar,.portal-password-form{grid-template-columns:1fr}.portal-footer{flex-direction:column}.portal-ad-slot{grid-template-columns:1fr}.portal-ad-slot>span{writing-mode:initial;text-align:center}.web-game-frame>.app-shell,.web-game-frame .title-screen,.web-game-frame .campaign-screen{min-height:auto;overflow:visible}.web-game-frame .campaign-command-stat-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.web-game-frame .campaign-command-stat{padding:.48rem .58rem}.web-game-frame .campaign-command-groups{gap:.4rem}.web-game-frame .campaign-command-group{flex-wrap:nowrap;padding-bottom:.2rem;overflow-x:auto}.web-game-frame .campaign-command-group button{flex:none}.web-game-frame .campaign-command-bar{order:1}.web-game-frame .map-stage-toolbar{order:2}.web-game-frame .map-panel-primary{order:3}.web-game-frame .campaign-mandate-banner{order:4}.web-game-frame .map-footnote{order:5}.web-game-frame .map-overlay-inline{grid-template-columns:repeat(3,minmax(0,1fr))}.web-game-frame .map-overlay-mode-hint,.web-game-frame .map-status-card small{display:none}.web-game-frame .map-status-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.web-game-frame .map-status-card{min-height:0;padding:.55rem}}@media (width<=560px){.portal-header{grid-template-columns:minmax(0,1fr) auto}.portal-brand strong{font-size:.78rem}.portal-brand-mark{width:2.35rem;height:2.35rem}.portal-header-actions .portal-primary-action{display:none}.portal-nav a{flex:none}.portal-hero h1{letter-spacing:-.055em;overflow-wrap:anywhere;max-width:100%;font-size:clamp(2.8rem,15vw,4.3rem)}.portal-hero-art{min-height:310px}.portal-hero-ledger{justify-content:center}.portal-hero-actions,.portal-hero-actions button,.portal-hero-actions a{width:100%}.portal-nation-grid,.portal-campaign-grid{grid-template-columns:1fr}.portal-campaign-card>header,.portal-campaign-launch{flex-direction:column;align-items:stretch}.portal-campaign-launch .portal-primary-action{width:100%}.portal-nation-card{grid-template-columns:auto minmax(0,1fr)}.portal-controls-ledger>div{grid-template-columns:1fr;gap:.25rem}.portal-gate-actions button,.portal-account-actions button{width:100%}.web-game-frame>.portal-ad-header{display:none}.web-game-frame>.app-shell{padding:.65rem}}@media (prefers-reduced-motion:reduce){.portal-shell *,.portal-shell :before,.portal-shell :after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}html{scroll-behavior:smooth}.portal-hero h1{background:linear-gradient(166deg,#fdf1d2 0%,#edcb88 44%,#c99a50 74%,#f0d49c 100%) 0 0/220%;-webkit-text-fill-color:transparent;color:#0000;text-shadow:none;filter:drop-shadow(0 18px 60px #0009);-webkit-background-clip:text;background-clip:text;animation:11s ease-in-out infinite portalHeroSheen}@keyframes portalHeroSheen{0%,to{background-position:0%}50%{background-position:110%}}.portal-hero-copy>*{animation:portalRise .72s var(--ease-out-expo,cubic-bezier(.16, 1, .3, 1)) both}.portal-hero-copy>:first-child{animation-delay:40ms}.portal-hero-copy>:nth-child(2){animation-delay:.12s}.portal-hero-copy>:nth-child(3){animation-delay:.2s}.portal-hero-copy>:nth-child(4){animation-delay:.28s}.portal-hero-copy>:nth-child(5){animation-delay:.36s}@keyframes portalRise{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}.portal-feature-band article,.portal-definition-grid article,.portal-strategy-grid article,.portal-step-grid article,.portal-lore-ledger article,.portal-era-ribbon article,.portal-nation-card,.portal-campaign-card,.portal-topic-card,.portal-account-grid article,.portal-faq-list details{transition:transform .28s var(--ease-out-expo,cubic-bezier(.16, 1, .3, 1)), box-shadow .28s ease, border-color .28s ease}.portal-feature-band article:hover,.portal-definition-grid article:hover,.portal-strategy-grid article:hover,.portal-step-grid article:hover,.portal-lore-ledger article:hover,.portal-era-ribbon article:hover,.portal-nation-card:hover,.portal-campaign-card:hover,.portal-topic-card:hover{border-color:#f3d79b6b;transform:translateY(-4px);box-shadow:0 18px 42px #00000075,0 0 0 1px #f3d79b0f}.portal-primary-action{transition:transform .2s var(--ease-out-back,cubic-bezier(.34, 1.56, .64, 1)), filter .2s ease, background .2s ease}.portal-primary-action:hover{filter:drop-shadow(0 12px 24px #daa0506b);transform:translateY(-2px)}.portal-primary-action:active{transform:translateY(0)}.portal-brand-mark{transition:box-shadow .3s ease, transform .3s var(--ease-out-back,cubic-bezier(.34, 1.56, .64, 1))}.portal-brand:hover .portal-brand-mark{transform:rotate(-3deg)scale(1.05);box-shadow:0 0 38px #dab97552}.portal-nav a{position:relative}.portal-nav a:after{content:"";background:linear-gradient(90deg, transparent, var(--portal-gold-bright), transparent);height:1.5px;transition:transform .26s var(--ease-out-expo,cubic-bezier(.16, 1, .3, 1));border-radius:2px;position:absolute;bottom:.34rem;left:.78rem;right:.78rem;transform:scaleX(0)}.portal-nav a:hover:after,.portal-nav a.active:after{transform:scaleX(1)}.portal-shell a:focus-visible,.portal-shell button:focus-visible,.portal-shell input:focus-visible,.portal-shell select:focus-visible,.portal-shell textarea:focus-visible,.portal-shell summary:focus-visible,.web-game-utility button:focus-visible{outline:2px solid var(--portal-gold-bright,#f3d79b);outline-offset:3px;border-radius:8px}.soe-ad{transition:border-color .3s,box-shadow .3s}.soe-ad:hover{border-color:#dab97538;box-shadow:0 10px 26px #00000052}.soe-ad-label{opacity:.72}
