@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@500;600;700&family=Inter:wght@400;500;600;700&family=Lora:ital,wght@0,400;0,600;0,700;1,400;1,600&display=swap";*{box-sizing:border-box}:root{--color-birch-cream: #E8DFC8;--color-ochre: #B8621F;--color-bronze: #8B5A2B;--color-warm-stone: #C9A876;--color-gold: #B8922F;--color-ember: #E85A1C;--color-gem-blue: #4A90C2;--color-charcoal: #1A1A1A;--color-deep-forest: #2E4E3F;--color-hearth-red: #B54821;--color-cobblestone: #2c241c;--color-dark-oak: #432d18;--color-dark-oak-shadow: #170d04;--color-deep-bronze-mat: #1e1208;--color-text: #1a1a1a;--color-text-muted: rgba(26, 26, 26, .72);--color-text-inverse: #d6cdb8;--color-text-inverse-muted: rgba(214, 205, 184, .82);--color-muted: #5a3a15;--color-muted-on-dark: #d8caa6;--color-bg-page: #2c241c;--color-bg-panel: rgba(42, 38, 32, .55);--color-bg-panel-deep: rgba(28, 25, 21, .55);--color-border: rgba(120, 105, 85, .28);--color-border-mid: rgba(120, 105, 85, .4);--color-accent: #8d7a5e;--color-error: #B54821;--color-error-soft: #c98770;--color-shortfall: #c0392b;--color-focus: #4A90C2;--font-display: "Montserrat", system-ui, -apple-system, "Segoe UI", sans-serif;--font-body: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--font-numeric: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--font-family-body: var(--font-body);--font-family-display: var(--font-display);--font-family-numeric: var(--font-numeric);--font-xs: 11px;--font-sm: 13px;--font-md: 16px;--font-lg: 20px;--font-xl: 24px;--font-2xl: 32px;--font-3xl: 40px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-6: 24px;--space-8: 32px;--space-12: 48px;--space-16: 64px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 10px;--radius-xl: 16px;--radius-pill: 999px;--shadow-soft: 0 2px 8px rgba(0, 0, 0, .3);--shadow-strong: 0 4px 16px rgba(0, 0, 0, .5);--transition-fast: .12s ease;--transition-default: .2s ease;--transition-slow: .4s ease}html,body{margin:0;padding:0}body{font-family:var(--font-body);font-size:16px;line-height:1.5;color:#1a1a1a;min-height:100vh;background:radial-gradient(ellipse 100% 55% at 50% -8%,rgba(255,175,80,.38),transparent 55%),radial-gradient(ellipse 110% 60% at 50% 115%,rgba(0,0,0,.55),transparent 50%),#2c241c;background-attachment:fixed}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;letter-spacing:.01em}button{font-family:var(--font-display)}.container{max-width:760px;margin:2.5rem auto;padding:0 1.75rem 1.75rem;background:#e8dfc8;border:2px solid #3a2010;border-radius:6px;box-shadow:0 0 0 1px #0f0803d9,0 0 0 5px #462d16b3,0 0 0 7px #140c06f2,0 22px 54px #000000bf;overflow:hidden}.container.container-wide{max-width:1280px}.top-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:0 -1.75rem 1.25rem;padding:.95rem 1.5rem;background:linear-gradient(180deg,#c46e2a,#a05218 40%,#6e3e15);border-bottom:2px solid #2a1505;box-shadow:inset 0 1px #ffdcaa8c,inset 0 -5px 10px #00000080}.top-bar-left{display:flex;align-items:center;gap:1.25rem}.top-bar strong{font-family:var(--font-body);font-size:1.35rem;font-weight:700;color:#2a1505;letter-spacing:.07em;text-shadow:0 1px 0 rgba(255,230,180,.5),0 -1px 0 rgba(40,20,5,.5)}.top-bar-faith{font-family:var(--font-body);font-size:1rem;color:#2a1505;letter-spacing:.04em;text-shadow:0 1px 0 rgba(255,230,180,.4),0 -1px 0 rgba(40,20,5,.4)}.top-bar-faith strong{font-size:1.05rem;letter-spacing:.04em}h1{font-family:var(--font-body);font-size:1.6rem;font-weight:700;color:#2a1505;margin:1.5rem 0 .75rem;letter-spacing:.04em;text-shadow:0 1px 0 rgba(255,230,180,.5)}h2{font-family:var(--font-body);font-size:1.15rem;font-weight:700;color:#2e4e3f;margin:1.5rem 0 .6rem;letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid rgba(139,90,43,.4);padding-bottom:.3rem}a{color:#8b5a2b;text-decoration:underline;text-underline-offset:2px}a:hover{color:#b54821}button{position:relative;font:inherit;font-weight:600;letter-spacing:.05em;color:#f1e2c3;padding:.6rem 1.6rem;border:0;border-radius:3px;cursor:pointer;background:linear-gradient(180deg,#432d18,#2a1a0a,#170d04);box-shadow:inset 0 0 0 2px #b8922f,inset 0 1px #ffc88240,inset 0 -2px 5px #0009;text-shadow:0 -1px 0 rgba(0,0,0,.75);transition:box-shadow .18s ease,background .18s ease}button:hover:not(:disabled){box-shadow:inset 0 0 0 2px #e8b441,inset 0 0 22px #e85a1c99,inset 0 1px #ffdcaa59,inset 0 -2px 5px #0009}button:active:not(:disabled){background:linear-gradient(180deg,#2a1a0a,#0d0702)}button:disabled{filter:grayscale(.5) brightness(.55);cursor:not-allowed}button.secondary{background:linear-gradient(180deg,#3a2818,#221608,#110a02);color:#d8c8a0;text-shadow:0 -1px 0 rgba(0,0,0,.7);box-shadow:inset 0 0 0 2px #6e4622,inset 0 1px #ffc88233,inset 0 -2px 4px #00000080}button.secondary:hover:not(:disabled){box-shadow:inset 0 0 0 2px #9a6c33,inset 0 0 18px #e85a1c6b,inset 0 1px #ffc88240,inset 0 -2px 4px #00000080}form{display:flex;flex-direction:column;gap:.85rem;max-width:380px}label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;font-weight:600;letter-spacing:.03em;color:#2a1505}input,select{font:inherit;padding:.55rem .7rem;border:1px solid #8b5a2b;border-radius:3px;background:#f8f1de;color:#1a1a1a;box-shadow:inset 0 1px 2px #2814052e}input:focus,select:focus{outline:none;border-color:#4a90c2;background:#fff8e6;box-shadow:inset 0 1px 2px #28140526,0 0 0 2px #4a90c259}.world-list,.player-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.65rem}.world-row,.player-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1rem;background:var(--color-warm-stone);border:1px solid var(--color-border-mid);border-radius:var(--radius-md);box-shadow:var(--shadow-soft)}.world-row strong,.player-row strong{font-family:var(--font-body);font-size:1.05rem;color:var(--color-charcoal);letter-spacing:.02em}.world-row .meta,.player-row .meta{font-size:.85rem;color:var(--color-text-muted);margin-top:.15rem;font-style:italic}.player-row-emblem{width:40px;height:40px;object-fit:contain;flex-shrink:0;background:#28180c1f;border:1px solid rgba(110,70,34,.4);border-radius:3px;padding:2px}.player-row-text,.world-row-text{flex:1;min-width:0}.player-row-link{display:flex;align-items:center;gap:1rem;width:100%;text-decoration:none;color:inherit}.player-row-link:hover .player-row-text strong{color:var(--color-gem-blue)}.player-row-chevron{font-size:1.5rem;color:var(--color-deep-forest);font-weight:700;line-height:1}.player-row-link:hover .player-row-chevron{color:var(--color-gem-blue)}.back-link{font-family:var(--font-body);font-style:italic;color:#f1e2c3;text-decoration:none;font-size:.95rem;letter-spacing:.03em;text-shadow:0 1px 0 rgba(255,220,170,.4),0 -1px 0 rgba(40,20,5,.5)}.back-link:hover{color:#ffd88a}.city-identity{display:flex;align-items:center;gap:1rem;padding:.75rem 0}.city-identity-emblem{width:56px;height:56px;object-fit:contain;background:#28180c1f;border:1px solid rgba(110,70,34,.45);border-radius:4px;padding:3px}.city-identity-text{display:flex;flex-direction:column;gap:.15rem}.city-identity-tribe{font-family:var(--font-body);font-size:1.1rem;font-weight:700;letter-spacing:.04em;color:#2a1505}.resource-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.65rem}@media(min-width:600px){.resource-grid{grid-template-columns:repeat(4,1fr)}}.resource-name{font-family:var(--font-body);font-size:.85rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#5a3a15}.resource-value{font-family:var(--font-body);font-size:1.6rem;font-weight:700;color:#2a1505;margin-top:.15rem;text-shadow:0 1px 0 rgba(255,230,180,.5)}.resource-cap{font-size:.9rem;font-weight:600;color:#5a3a15}.resource-rate{font-family:var(--font-body);font-style:italic;font-size:.78rem;color:#2e4e3f;margin-top:.1rem;letter-spacing:.04em}.resource-timber .resource-name{color:#5a3a15}.resource-stone .resource-name{color:#4a3e33}.resource-iron .resource-name{color:#3a2a18}.resource-grain .resource-name{color:#8b6e0f}.resource-gold .resource-name{color:#a8851a}.fields-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.buildings-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem}@media(max-width:520px){.buildings-grid{grid-template-columns:repeat(4,1fr)}}button.field-slot,button.building-slot{clip-path:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;padding:.6rem .4rem;min-height:70px;border-radius:3px;cursor:pointer;letter-spacing:.02em;transition:box-shadow .15s ease}button.field-slot,button.building-slot:not(.empty){background:linear-gradient(180deg,#f4eacf,#e6d8b3);color:#2a1505;text-shadow:0 1px 0 rgba(255,230,180,.4);box-shadow:inset 0 0 0 1px #8b5a2b,inset 0 1px #ffffff8c,inset 0 -2px 4px #8b5a2b2e}button.field-slot:hover:not(.selected),button.building-slot:not(.empty):hover:not(.selected){box-shadow:inset 0 0 0 2px #b8922f,inset 0 0 14px #e85a1c40,inset 0 1px #ffffff80,inset 0 -2px 4px #8b5a2b2e}button.field-slot.selected,button.building-slot:not(.empty).selected{box-shadow:inset 0 0 0 2px #e8b441,inset 0 0 18px #e85a1c73,inset 0 1px #ffe6b473,inset 0 -2px 4px #8b5a2b33}button.building-slot.empty{background:linear-gradient(180deg,#3a2818,#221608,#110a02);color:#8a6e3c;box-shadow:inset 0 0 0 1px #6e4622,inset 0 1px #ffc88226,inset 0 -2px 4px #00000073}button.building-slot.empty:hover:not(.selected){box-shadow:inset 0 0 0 2px #9a6c33,inset 0 0 16px #e85a1c4d,inset 0 1px #ffc88233,inset 0 -2px 4px #00000073;color:#cfa057}button.building-slot.empty.selected{box-shadow:inset 0 0 0 2px #e8b441,inset 0 0 22px #e85a1c8c,inset 0 1px #ffdcaa59,inset 0 -2px 5px #00000080;color:#f1e2c3}button.building-slot.wall-placeholder{background:linear-gradient(180deg,#3a2818,#221608,#110a02);box-shadow:inset 0 0 0 1px #6e4622,inset 0 1px #ffc88226,inset 0 -2px 4px #00000073}button.building-slot.wall-placeholder .building-slot-img{opacity:.55;filter:grayscale(.4)}button.building-slot.wall-placeholder:hover:not(.selected){box-shadow:inset 0 0 0 2px #9a6c33,inset 0 0 16px #e85a1c4d,inset 0 1px #ffc88233,inset 0 -2px 4px #00000073}button.building-slot.wall-placeholder:hover:not(.selected) .building-slot-img{opacity:.85;filter:grayscale(.1)}.slot-name{font-family:var(--font-body);font-size:.9rem;font-weight:700;text-align:center;line-height:1.2}.slot-level{font-family:var(--font-body);font-style:italic;font-size:.78rem;color:#5a3a15}button.building-slot:not(.empty) .slot-level{color:#5a3a15}.slot-empty-plus{font-family:var(--font-body);font-size:1.8rem;font-weight:700;line-height:1}.current-build-banner{margin-top:.5rem;padding:.6rem .85rem;background:linear-gradient(180deg,#e85a1c2e,#b8621f1f);border:1px solid rgba(184,98,31,.55);border-radius:3px;color:#4a2a08;font-family:var(--font-body);font-size:.95rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.current-build-text{flex:1;min-width:0}button.current-build-cancel{padding:.4rem 1rem;flex-shrink:0}.requirement-warning{font-style:italic}.city-stats-row{margin-top:.5rem;display:flex;gap:.75rem;flex-wrap:wrap}.city-stat{flex:1 1 0;min-width:140px;padding:.5rem .75rem;background:#382616a6;border:1px solid rgba(184,98,31,.35);border-radius:3px;display:flex;justify-content:space-between;align-items:baseline;font-family:var(--font-body);color:#f0d9b5}.city-stat-label{font-size:.8rem;letter-spacing:.05em;opacity:.85;text-transform:uppercase}.city-stat-value{font-size:1.1rem;font-weight:700}.city-stat-bad{border-color:#dc503cb3}.city-stat-bad .city-stat-value{color:#ff8a6a}.training-queue{margin-top:.5rem;padding:.5rem .75rem;background:#281e1499;border:1px solid rgba(184,98,31,.35);border-radius:3px;font-family:var(--font-body);color:#f0d9b5;width:26rem;max-width:100%}.training-queue-header{font-weight:700;letter-spacing:.05em;text-transform:uppercase;font-size:.85rem;margin-bottom:.4rem;opacity:.9}.training-queue-list{list-style:none;padding:0;margin:0}.training-queue-row{display:flex;align-items:center;justify-content:space-between;padding:.35rem 0;gap:.75rem;padding:.3rem 0;border-top:1px dashed rgba(184,98,31,.25)}.training-queue-row:first-child{border-top:none}.training-queue-text{flex:1;min-width:0;font-size:.95rem}button.training-queue-cancel{padding:.3rem .85rem;flex-shrink:0}.progress-card{display:flex;align-items:center;gap:.85rem;padding:.6rem .85rem;background:linear-gradient(180deg,#3a2818,#2a1f17);border:1px solid rgba(184,98,31,.35);border-radius:4px;color:#f5e8c8;margin-bottom:.5rem;box-shadow:inset 0 1px #ffdcaa14,0 1px 2px #00000059}.progress-card-list-item .progress-card{margin-bottom:0;box-shadow:none;border-radius:0;border-top:1px dashed rgba(184,98,31,.25)}.progress-card-list-item:first-child .progress-card{border-top:none}.progress-card-icon{flex-shrink:0;width:4.5rem;height:4.5rem;margin:-.6rem 0 -.6rem -.7rem;padding:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.progress-card-icon img{width:100%;height:100%;object-fit:contain}.progress-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.3rem}.progress-card-heading{display:flex;align-items:baseline;justify-content:space-between;gap:.6rem;font-size:1.05rem;color:#f5e8c8}.progress-card-heading strong{font-family:var(--font-display);letter-spacing:.01em}.progress-card-list-item{list-style:none}.progress-card-cancel{margin-left:auto;padding:.3rem .85rem;font-size:.85rem}.progress-card-bar-row{display:flex;align-items:center;gap:.75rem}.progress-card-bar-times{width:16rem;display:flex;flex-direction:column;gap:.3rem}.progress-card-queued{list-style:none;padding:0;margin:0;display:flex;gap:.3rem}.progress-card-queued-item{width:1.8rem;height:1.8rem;padding:1px;background:#00000040;border:1px solid rgba(184,98,31,.3);border-radius:3px;display:flex;align-items:center;justify-content:center}.progress-card-queued-item img{max-width:100%;max-height:100%;object-fit:contain}.progress-card-progress{width:100%;height:.5rem;background:#00000059;border-radius:999px;border:1px solid rgba(0,0,0,.25);overflow:hidden}.progress-card-progress-fill{height:100%;background:linear-gradient(90deg,#4ec24b,#7ed14b);border-radius:999px;transition:width .5s linear}.progress-card-times{display:flex;align-items:center;gap:1.25rem;font-size:.9rem;color:#d8cfb6}.progress-card-time{display:inline-flex;align-items:center;gap:.35rem}.progress-card-times .countdown-in{color:#f5e8c8;font-weight:500}.progress-card-times .countdown-at{color:#d8cfb6}.progress-card-times .countdown-sep{color:#b8a98c}.army-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.22rem;max-width:8.5rem}.army-row{padding:.4rem .75rem;background:#382616a6;border:1px solid rgba(184,98,31,.4);border-radius:3px;font-family:var(--font-body);color:#f0d9b5}.army-name{font-weight:700}.army-count{margin-left:.5rem;opacity:.85}.training-list{list-style:none;padding:0;margin:.5rem 0;display:flex;flex-direction:column;gap:.4rem}.training-row{display:flex;flex-direction:column;gap:.6rem;padding:.6rem .75rem;background:#281e148c;border:1px solid rgba(184,98,31,.35);border-radius:3px}.training-row-top{display:grid;grid-template-columns:auto 1fr;gap:.8rem;align-items:stretch}.training-row-bottom{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;gap:.35rem .85rem;align-items:center;padding-top:.3rem;border-top:1px dashed rgba(184,98,31,.25)}.training-row-bottom .training-count-display{grid-column:1;grid-row:1}.training-row-bottom .training-slider{grid-column:2;grid-row:1}.training-row-bottom .training-row-detail{grid-column:1 / -1;grid-row:2;text-align:right}.training-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:#140e0880;border:1px dashed rgba(184,98,31,.35);border-radius:3px;font-size:1.8rem;color:#f0d9b599}.training-stats{min-width:0}.training-stats-name{font-family:var(--font-body);font-size:1.5rem;font-weight:700;letter-spacing:.01em;color:#2e4e3f;margin-bottom:.35rem;line-height:1.2}.training-stats-name-lvl{font-weight:400;color:#2e4e3fb3;font-size:.85rem}.training-stats-grid{display:flex;flex-direction:column;gap:.35rem;font-family:var(--font-body);font-size:1.35rem;color:#1a1a1a;line-height:1.2}.training-stats-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.2rem 1rem}.training-stats-row>div{display:flex;align-items:baseline;gap:.35rem;min-width:0}.training-stats-row>div .training-stat-label{flex:0 0 auto;min-width:5.5em;text-align:right}.training-stats-row>div .training-stat-value{flex:1 1 auto;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}.training-stats-grid .training-stat-label{font-size:1.1rem;letter-spacing:.05em;opacity:.7}.training-stat-label{font-size:.7rem;letter-spacing:.05em;opacity:.7;margin-right:.25rem}.training-count-display{font-family:var(--font-body);white-space:nowrap}.training-count-number{font-size:1.2rem;font-weight:700;color:#f0d9b5}.training-slider{width:100%;accent-color:#b8621f}.training-row-detail{font-size:.85rem}.training-total{margin-top:.5rem;padding:.5rem .75rem;display:flex;justify-content:space-between;align-items:baseline;background:#382616a6;border:1px solid rgba(184,98,31,.45);border-radius:3px;font-family:var(--font-body)}.training-total-label{font-size:.85rem;letter-spacing:.05em;opacity:.85;text-transform:uppercase;color:#f0d9b5}.training-total-value{font-size:1rem;color:#f0d9b5}.training-total-bad{color:#ff8a6a}.building-modal{display:flex;flex-direction:column;gap:.8rem;--bm-text: #d6cdb8;--bm-text-muted: rgba(214, 205, 184, .6);--bm-bg-soft: rgba(42, 38, 32, .55);--bm-bg-deeper: rgba(28, 25, 21, .55);--bm-border: rgba(120, 105, 85, .28);--bm-border-mid: rgba(120, 105, 85, .4);--bm-accent: #8d7a5e;--bm-bad: #c98770}.building-modal .modal-top{display:flex;flex-direction:row;gap:var(--space-4);align-items:flex-start;padding:var(--space-3);background:var(--bm-bg-deeper);border:1px solid var(--bm-border);border-radius:var(--radius-lg)}.building-modal .modal-top-left{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);width:220px}.building-modal .modal-top-illustration{width:220px;height:220px;object-fit:contain;border-radius:var(--radius-md);background:var(--bm-bg-soft);border:1px solid var(--bm-border)}.building-modal .modal-top-right{flex:1 1 auto;display:flex;flex-direction:column;gap:var(--space-3);min-width:0}.building-modal .modal-top-level{font-family:var(--font-family-display);font-size:var(--font-2xl);font-weight:700;color:var(--bm-text);line-height:1.1;letter-spacing:.02em}.building-modal .modal-top-description{font-family:var(--font-family-body);font-size:var(--font-md);line-height:1.5;color:var(--bm-text)}.building-modal .modal-top-effect{font-family:var(--font-family-numeric);font-size:var(--font-lg);font-weight:600;color:var(--bm-accent)}.building-modal .modal-top-effect-secondary{font-size:var(--font-md);color:var(--bm-text-muted);margin-top:calc(var(--space-1) * -1)}.building-modal .modal-top-effect-label{font-family:var(--font-family-body);font-weight:400;color:var(--bm-text-muted)}.building-modal .modal-top-effect-value{font-family:var(--font-family-numeric)}.building-modal .modal-top-population{display:inline-flex;align-items:center;gap:var(--space-2)}.building-modal .modal-top-population-icon{width:1.4rem;height:1.4rem;object-fit:contain;vertical-align:middle}.building-modal .modal-upgrade-population-icon{width:1.3rem;height:1.3rem;object-fit:contain;vertical-align:middle}.building-modal .modal-upgrade-value-change-secondary{margin-top:calc(var(--space-1) * -1)}.building-modal .modal-upgrade-unlocks{flex-wrap:wrap}.building-modal .modal-upgrade-unlock-level{font-family:var(--font-family-numeric);font-variant-numeric:tabular-nums;color:var(--bm-text-muted);font-weight:700}.building-modal .modal-upgrade-unlock-names{color:var(--bm-accent);font-weight:600}.building-modal .modal-upgrade-unlock-sep{color:var(--bm-text-muted)}.building-modal .modal-upgrade-line{display:flex;flex-direction:row;align-items:flex-end;justify-content:space-between;gap:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--bm-bg-soft);border:1px solid var(--bm-border);border-radius:var(--radius-md);flex-wrap:wrap}.building-modal .modal-upgrade-actions{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-end;justify-content:flex-end;gap:var(--space-2)}.building-modal .modal-upgrade-left{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:var(--space-2)}.building-modal .modal-upgrade-level{font-family:var(--font-family-display);font-size:var(--font-lg);font-weight:600;color:var(--bm-text)}.building-modal .modal-upgrade-value-change{display:inline-flex;align-items:baseline;gap:var(--space-1);padding:var(--space-1) var(--space-3);background:var(--bm-bg-deeper);border:1px solid var(--bm-border-mid);border-radius:var(--radius-sm);font-family:var(--font-family-numeric);font-size:var(--font-md);align-self:flex-start}.building-modal .modal-upgrade-value-label{font-family:var(--font-family-body);color:var(--bm-text-muted)}.building-modal .modal-upgrade-value-current,.building-modal .modal-upgrade-value-arrow{color:var(--bm-text-muted)}.building-modal .modal-upgrade-value-next{color:var(--bm-accent);font-weight:700}.building-modal .modal-upgrade-value-phantom{color:var(--bm-accent);font-weight:600;font-style:italic;opacity:.6}.building-modal .modal-upgrade-cost{flex:0 0 auto;font-family:var(--font-family-numeric);font-size:var(--font-md);color:var(--bm-text);display:inline-flex;flex-direction:column;align-items:flex-start;align-self:flex-start;gap:var(--space-2);margin-top:var(--space-1)}.building-modal .modal-upgrade-cost-label{font-family:var(--font-family-body);font-weight:600;color:var(--bm-text-muted)}.building-modal .modal-upgrade-cost-row{display:inline-flex;align-items:flex-start;gap:var(--space-2);flex-wrap:wrap}.building-modal .modal-upgrade-cost .cost-inline-icon{width:1.6rem;height:1.6rem;max-width:1.6rem;max-height:1.6rem}.building-modal .modal-upgrade-cost .cost-inline-value{font-size:var(--font-md);color:var(--bm-text)}.building-modal .modal-upgrade-time{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--bm-text);font-family:var(--font-family-numeric);font-size:var(--font-md)}.building-modal .modal-upgrade-afford{font-family:var(--font-family-numeric);font-variant-numeric:tabular-nums;font-size:var(--font-sm);color:var(--bm-text-muted)}.building-modal .modal-upgrade-afford-label{font-family:var(--font-family-body);font-weight:600;color:var(--bm-text-muted)}.building-modal .modal-upgrade-afford .countdown-in{color:var(--bm-text);font-weight:600}.building-modal .modal-upgrade-afford .countdown-at{color:var(--bm-text-muted)}.building-modal .modal-upgrade-afford-never{color:var(--bm-text-muted);font-style:italic}.building-modal .modal-upgrade-time-label{font-family:var(--font-family-body);font-weight:600;color:var(--bm-text-muted)}.building-modal .modal-upgrade-button{font-family:var(--font-family-body);font-size:var(--font-md);font-weight:600;padding:var(--space-2) var(--space-4);flex:0 0 auto}.building-modal .modal-upgrade-max{font-family:var(--font-family-display);font-size:var(--font-lg);font-weight:700;color:var(--bm-text);letter-spacing:.04em;flex:0 0 auto}.building-modal .modal-top-max-row{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-2)}.building-modal .dev-mode-toggle-inline{display:inline-flex;align-items:center;gap:.3rem;font-family:var(--font-family-body);font-size:.78rem;color:var(--bm-text-muted);flex:0 0 auto;cursor:pointer;-webkit-user-select:none;user-select:none}.building-modal .dev-mode-toggle-inline input[type=checkbox]{width:.9rem;height:.9rem;margin:0;cursor:pointer}.building-modal .building-section{padding:.6rem .75rem .75rem;background:var(--bm-bg-deeper);border:1px solid var(--bm-border);border-radius:3px;color:var(--bm-text)}.building-modal .building-section-header{margin:0 0 .5rem;font-family:var(--font-body);font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;color:var(--bm-text);border-bottom:1px solid var(--bm-border);padding-bottom:.3rem}.building-modal .building-section-hint{margin:0 0 .75rem;font-size:.78rem;line-height:1.35;color:var(--bm-text-muted, #8a7f72);font-style:italic}.building-section-actions{margin-top:.5rem;justify-content:flex-end}.current-research-banner{margin-bottom:.5rem;padding:.45rem .7rem;background:#50412d73;border:1px solid rgba(120,105,85,.4);border-radius:3px;font-family:var(--font-body);font-size:.9rem;color:var(--bm-text, #d6cdb8)}.building-modal .armory-group{margin-top:1rem}.building-modal .armory-group:first-of-type{margin-top:.5rem}.building-modal .armory-group-header{margin:0 0 .4rem;font-family:var(--font-body);font-size:.85rem;letter-spacing:.04em;text-transform:uppercase;color:var(--bm-text-muted, #a39785);border-bottom:1px solid var(--bm-border);padding-bottom:.2rem}.building-modal .armory-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem}.building-modal .armory-row{background:var(--bm-bg-soft, rgba(58, 50, 40, .45));border:1px solid var(--bm-border);border-radius:4px;padding:.6rem .75rem;display:flex;flex-direction:column;gap:.5rem}.armory-row-header{display:flex;align-items:center;gap:.6rem}.armory-row-icon{width:36px;height:36px;border-radius:3px;object-fit:cover}.armory-row-id{font-size:.95rem}.armory-stats{display:flex;flex-direction:column;gap:.2rem;font-family:var(--font-body);font-size:.88rem;padding-left:2.6rem}.armory-stat-row{display:grid;grid-template-columns:6.5rem 4.5rem 1rem 4.5rem auto;align-items:baseline;column-gap:.4rem}.armory-stat-label{color:var(--bm-text-muted, #a39785);letter-spacing:.04em;text-transform:uppercase;font-size:.75rem}.armory-stat-before{color:var(--bm-text-muted, #a39785);text-align:right}.armory-stat-arrow{color:var(--bm-text-muted, #a39785);text-align:center}.armory-stat-after{color:var(--bm-text, #d6cdb8);text-align:right;font-weight:600}.armory-stat-note{font-size:.78rem;font-style:italic;padding-left:2.6rem;margin-top:.2rem}.armory-row-action{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding-top:.4rem;border-top:1px dashed var(--bm-border)}.armory-row-cost{display:flex;flex-direction:column;gap:.15rem;font-size:.85rem;color:var(--bm-text, #d6cdb8)}.armory-row-cost em{font-style:italic;color:var(--bm-text-muted, #a39785)}.armory-row-action button{white-space:nowrap}.building-modal .training-row{background:var(--bm-bg-soft);border-color:var(--bm-border)}.building-modal .training-row-bottom{border-top-color:var(--bm-border)}.building-modal .training-icon{background:var(--bm-bg-deeper);border-color:var(--bm-border);color:var(--bm-text-muted)}.building-modal .training-stats-grid{color:var(--bm-text)}.building-modal .training-stat-label{color:var(--bm-text-muted);opacity:1}.building-modal .training-count-number{color:var(--bm-text)}.building-modal .training-slider{accent-color:var(--bm-accent)}.building-modal .training-total{background:var(--bm-bg-soft);border-color:var(--bm-border-mid);color:var(--bm-text)}.building-modal .training-total-label,.building-modal .training-total-value{color:var(--bm-text)}.building-modal .training-total-bad{color:var(--bm-bad)}.building-modal .buildable-row{background:var(--bm-bg-soft);border-color:var(--bm-border)}.building-modal .buildable-name strong,.building-modal .buildable-desc{color:var(--bm-text)}.building-modal .muted,.building-modal .upgrade-description{color:var(--bm-text-muted)}.building-modal .upgrade-spec{color:var(--bm-text)}.building-modal .upgrade-spec dt{color:var(--bm-text-muted)}.modal-overlay{position:fixed;inset:0;z-index:100;background:#000000a6;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-content{width:100%;max-width:520px;max-height:88vh;display:flex;flex-direction:column;background:#e8dfc8;border:2px solid #3a2010;border-radius:6px;box-shadow:0 0 0 1px #0f0803d9,0 0 0 5px #462d16b3,0 0 0 7px #140c06f2,0 22px 54px #000000bf;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.7rem 1rem;background:linear-gradient(180deg,#c46e2a,#a05218 40%,#6e3e15);border-bottom:2px solid #2a1505;box-shadow:inset 0 1px #ffdcaa80,inset 0 -3px 6px #00000059;font-family:var(--font-body);color:#2a1505;text-shadow:0 1px 0 rgba(255,220,170,.5),0 -1px 0 rgba(40,20,5,.45)}button.modal-close{clip-path:none;background:transparent;border:0;box-shadow:none;color:#2a1505;text-shadow:0 1px 0 rgba(255,220,170,.5);padding:0 .4rem;font-size:1.4rem;line-height:1;letter-spacing:0}button.modal-close:hover:not(:disabled){box-shadow:none;color:#b54821}.modal-body{padding:1rem 1.1rem;overflow-y:auto}.modal-actions{justify-content:flex-end;margin-top:.5rem}.upgrade-modal{display:flex;flex-direction:column;align-items:stretch;gap:.6rem}.upgrade-icon-placeholder{align-self:center;width:72px;height:72px;display:flex;align-items:center;justify-content:center;font-size:2.4rem;background:#28180c1f;border:1px solid rgba(110,70,34,.4);border-radius:4px}.upgrade-level{align-self:center;font-family:var(--font-body);font-size:1.15rem;font-weight:700;letter-spacing:.1em;color:#2e4e3f;text-shadow:0 1px 0 rgba(255,230,180,.5)}.upgrade-description{font-family:var(--font-body);font-style:italic;font-size:.92rem;color:#2a1505;line-height:1.4;padding:.4rem .6rem;background:#ffffff59;border-left:3px solid #8b5a2b;border-radius:2px}.upgrade-spec{display:grid;grid-template-columns:max-content 1fr;gap:.25rem .7rem;margin:0;font-family:var(--font-body)}.upgrade-spec dt{font-weight:700;color:#2e4e3f;font-size:.85rem;letter-spacing:.04em;text-transform:uppercase}.upgrade-spec dd{margin:0;color:#2a1505}.empty-slot-modal{display:flex;flex-direction:column;gap:.6rem}.buildable-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.buildable-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.6rem .7rem;background:#fff6;border:1px solid rgba(139,90,43,.4);border-radius:3px}.buildable-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.buildable-name{font-size:1rem}.buildable-desc{font-family:var(--font-body);font-style:italic;font-size:.85rem;color:#2a1505}.dev-mode-toggle{display:flex;align-items:center;gap:.5rem;padding:.45rem .6rem;background:#e85a1c1f;border:1px dashed rgba(184,98,31,.7);border-radius:3px;font-family:var(--font-body);font-size:.85rem;color:#4a2a08;font-weight:600;letter-spacing:.02em;cursor:pointer}.dev-mode-toggle input[type=checkbox]{width:1rem;height:1rem;margin:0;cursor:pointer}.world-row span.muted{display:inline-block;font-family:var(--font-body);font-style:italic;font-size:.8rem;color:var(--color-text-muted);padding:.3rem .7rem;background:#1a1a1a1a;border:1px solid var(--color-border-mid);border-radius:var(--radius-pill)}.join-form{margin-top:.6rem;padding:1rem;width:100%;background:var(--color-birch-cream);border:1px solid var(--color-border-mid);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:.8rem;box-shadow:var(--shadow-soft)}.join-form-heading{font-family:var(--font-display);font-size:1rem;color:var(--color-deep-forest);letter-spacing:.02em}.tribe-section-label{font-family:var(--font-body);font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-charcoal);margin-top:.2rem}.join-form label{color:#1a1a1a}.tribe-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.65rem}@media(max-width:520px){.tribe-grid{grid-template-columns:repeat(2,1fr)}}button.tribe-card{clip-path:none;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem .5rem;background:var(--color-warm-stone);color:var(--color-charcoal);border:1px solid var(--color-border-mid);border-radius:var(--radius-md);cursor:pointer;letter-spacing:.04em;font-weight:600;font-size:.92rem;text-shadow:none;box-shadow:var(--shadow-soft);transition:box-shadow var(--transition-fast),filter var(--transition-fast)}button.tribe-card:hover:not(.selected):not(:disabled){filter:brightness(1.05);box-shadow:var(--shadow-soft),inset 0 0 0 1px var(--color-deep-forest)}button.tribe-card.selected{box-shadow:inset 0 0 0 2px var(--color-gem-blue),var(--shadow-soft)}.tribe-card-emblem{width:88px;height:88px;object-fit:contain;background:#1a1a1a14;border:1px solid var(--color-border-mid);border-radius:var(--radius-sm);padding:4px}.tribe-card-name{display:block}.tribe-detail{display:flex;gap:1rem;padding:.9rem;background:var(--color-birch-cream);border:1px solid var(--color-border-mid);border-radius:var(--radius-md);box-shadow:var(--shadow-soft)}.tribe-detail-emblem{width:96px;height:96px;object-fit:contain;flex-shrink:0;background:#1a1a1a14;border:1px solid var(--color-border-mid);border-radius:var(--radius-sm);padding:6px}.tribe-detail-text{display:flex;flex-direction:column;gap:.45rem;font-size:.92rem;color:var(--color-charcoal)}.tribe-detail-text h4{margin:0;font-family:var(--font-display);font-size:1.15rem;letter-spacing:.04em;color:var(--color-deep-forest);text-shadow:none}.tribe-detail-row{margin:0}.tribe-detail-row strong{color:var(--color-deep-forest)}@media(max-width:520px){.tribe-detail{flex-direction:column;align-items:center}.tribe-detail-text{align-self:stretch}}.error{color:#6e1f1f;padding:.55rem .8rem;background:#b548211f;border:1px solid rgba(181,72,33,.45);border-radius:3px;font-size:.875rem}.muted{color:var(--color-muted);font-size:.875rem}.ingame-content,.ingame-top-panel{--color-muted: var(--color-muted-on-dark)}.modal-content:not(.modal-content--dark),.tile-info-panel{--color-muted: #5a3a15}.row{display:flex;gap:.5rem}.resource-card-icon{width:1.4em;height:1.4em;vertical-align:-.2em;margin-right:.4em;object-fit:contain}.field-slot{display:flex;flex-direction:column;align-items:center}.field-slot-img{width:100%;max-width:88px;height:64px;object-fit:contain;margin-bottom:.35rem;display:block}.upgrade-icon-img{width:100%;height:100%;object-fit:contain}.army-row{display:flex;align-items:center;gap:.5rem}.army-icon{width:1.5em;height:1.5em;object-fit:contain;flex-shrink:0}.training-icon-img{width:100%;height:100%;object-fit:contain}.buildable-icon{width:1.5em;height:1.5em;vertical-align:-.3em;margin-right:.4em;object-fit:contain}.training-focus{display:flex;flex-direction:column;align-items:center;padding:.75rem;margin-bottom:.75rem;background:#0000000a;border-radius:4px}.training-focus-img{max-width:240px;max-height:200px;width:auto;height:auto;object-fit:contain}.training-focus-name{margin-top:.4rem;font-weight:600;font-size:1rem}.training-row{cursor:pointer;transition:background .12s ease}.training-row:hover{background:#00000008}.training-row.focused{background:#c189321f;outline:1px solid rgba(193,137,50,.4)}.resource-card .resource-name{font-size:1.15rem;display:flex;align-items:center;gap:.55rem}.resource-card-icon{width:2.2rem;height:2.2rem;max-width:2.2rem;max-height:2.2rem;object-fit:contain;vertical-align:middle;margin-right:0;display:inline-block;flex-shrink:0}.resource-card .resource-value{font-size:1.55rem}.resource-card .resource-rate{font-size:.95rem}button.field-slot{min-height:150px;padding:.9rem .75rem;gap:.4rem}.field-slot-img{width:100%;max-width:112px;height:84px;max-height:84px;object-fit:contain;display:block;margin-bottom:.4rem}button.field-slot .slot-level{font-size:.9rem}button.building-slot:not(.empty){min-height:150px;padding:.75rem .6rem .65rem;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:.3rem}.building-slot-img{width:100%;max-width:120px;height:96px;max-height:96px;object-fit:contain;display:block}button.building-slot:not(.empty) .slot-name{font-size:.98rem;text-align:center;line-height:1.2}button.building-slot:not(.empty) .slot-level{font-size:.88rem}button.building-slot.empty{min-height:150px}button.building-slot.empty .slot-empty-plus{font-size:2.4rem}.buildable-row--building{align-items:flex-start;gap:.85rem}.buildable-building-img{width:96px;height:96px;max-width:96px;max-height:96px;object-fit:contain;flex-shrink:0;display:block;border-radius:4px}.army-row{gap:.6rem;padding:.14rem .55rem}.army-icon{width:1.85rem;height:1.85rem;max-width:1.85rem;max-height:1.85rem;object-fit:contain;flex-shrink:0}.army-name,.army-count{font-size:1rem}.training-icon{width:96px;height:96px}.training-row{padding:.85rem}.training-focus{padding:1rem;margin-bottom:.9rem}.training-focus-img{max-width:320px;max-height:280px;width:auto;height:auto;object-fit:contain;display:block}.training-focus-name{margin-top:.55rem;font-size:1.2rem;font-weight:700}.buildable-row{padding:.8rem .85rem;gap:.85rem}.buildable-name{font-size:1.05rem;display:flex;align-items:center;gap:.5rem}.buildable-icon{width:2rem;height:2rem;max-width:2rem;max-height:2rem;vertical-align:middle;margin-right:0;object-fit:contain;flex-shrink:0}.buildable-desc{font-size:.95rem;margin-top:.25rem}.cost-inline{display:inline-flex;align-items:center;gap:.55rem;flex-wrap:wrap;vertical-align:middle}.cost-inline.compact{gap:.35rem}.cost-inline-pair{display:inline-flex;align-items:center;gap:.18rem}.cost-inline-icon{width:1.3rem;height:1.3rem;max-width:1.3rem;max-height:1.3rem;object-fit:contain;display:inline-block;vertical-align:middle;flex-shrink:0}.cost-inline.compact .cost-inline-icon{width:1.05rem;height:1.05rem;max-width:1.05rem;max-height:1.05rem}.cost-inline-value{font-variant-numeric:tabular-nums;font-weight:600}.cost-inline-pair--short .cost-inline-value,.building-modal .modal-upgrade-cost .cost-inline-pair--short .cost-inline-value,.cost-text-short{color:var(--color-shortfall);font-weight:700}.cost-free{font-style:italic;color:#5a3a15b3}.upgrade-icon-placeholder{width:120px;height:120px}.upgrade-icon-img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block}.city-identity-emblem{width:80px;height:80px;max-width:80px;max-height:80px;object-fit:contain}.city-identity-tribe{font-size:1.15rem}.container h2{font-size:1.55rem;margin-top:1.4rem;margin-bottom:.7rem}.building-section-header{font-size:1.2rem}.upgrade-modal,.building-modal,.empty-slot-modal{padding:1.1rem}.modal-actions{margin-top:.85rem}.modal-overlay{padding:1.5rem}.modal-content:not(.modal-content--bare){width:auto;max-width:96vw;height:min(94vh,1100px);max-height:none;aspect-ratio:4 / 5}.modal-content:not(.modal-content--bare) .modal-body{flex:1 1 auto;min-height:0;overflow-y:auto}.modal-body{padding:1.5rem 1.75rem}.modal-header-title{flex:1 1 auto;min-width:0}.modal-header-with-image{display:inline-flex;align-items:center;gap:.85rem;font-size:1.2rem}.modal-header-image{width:64px;height:64px;max-width:64px;max-height:64px;object-fit:contain;border-radius:4px;background:#ffffff40;padding:2px;flex-shrink:0}.modal-header-text{font-weight:700}.building-modal{--bm-text: #1a1a1a;--bm-text-muted: rgba(26, 26, 26, .65);--bm-bg-soft: rgba(232, 223, 200, .55);--bm-bg-deeper: rgba(220, 210, 185, .45);--bm-border: rgba(139, 58, 31, .3);--bm-border-mid: rgba(139, 58, 31, .5);--bm-accent: #8B3A1F;--bm-bad: #b53521}.building-section-header{color:#8b3a1f;font-weight:700;font-size:1.2rem;border-bottom:2px solid rgba(139,58,31,.3);padding-bottom:.5rem;margin-top:0;margin-bottom:.85rem;letter-spacing:.02em}.training-stats-name strong,.buildable-name strong{color:#2e4e3f;font-size:1.05rem}.building-modal .upgrade-description,.building-modal .buildable-desc,.building-modal p,.building-modal dd,.building-modal dt,.building-modal .training-stats-grid,.building-modal .upgrade-spec{color:#1a1a1a}.upgrade-modal{--bm-text: #1a1a1a}.upgrade-modal .upgrade-description,.upgrade-modal dd,.upgrade-modal dt{color:#1a1a1a}.empty-slot-modal{--bm-text: #1a1a1a}.empty-slot-modal .buildable-desc,.empty-slot-modal .buildable-name strong{color:#2e4e3f}.building-modal .upgrade-description{font-size:1rem;padding:.7rem .9rem;background:#8b3a1f0f;border-left:3px solid #8B3A1F;border-radius:0 3px 3px 0;margin-bottom:1rem;line-height:1.45}.building-modal .building-section{background:#e8dfc866;border:1px solid rgba(139,58,31,.18);border-radius:4px;padding:1rem 1.1rem;margin-bottom:1rem}.empty-slot-modal .buildable-row--building{background:#e8dfc880;border:1px solid rgba(139,58,31,.18)}.building-slot-img,.field-slot-img,.buildable-building-img,.modal-header-image{pointer-events:none;-webkit-user-select:none;user-select:none}button.field-slot{position:relative;min-height:0;padding:0;gap:0;width:100%;aspect-ratio:1 / 1;max-width:220px;margin:0 auto;overflow:hidden;display:block}button.field-slot .field-slot-img{width:100%;height:100%;max-width:100%;max-height:100%;object-fit:cover;margin:0;display:block;border-radius:0}.field-slot-label{position:absolute;left:0;right:0;bottom:0;padding:.45rem .6rem .5rem;background:linear-gradient(180deg,#140c0500,#140c058c 35%,#140c05d9);color:#f5e8c8;text-align:center;pointer-events:none;text-shadow:0 1px 2px rgba(0,0,0,.8)}button.field-slot .slot-name{font-size:1rem;font-weight:700;line-height:1.15;color:#f5e8c8;letter-spacing:.01em}button.field-slot .slot-level{font-size:.82rem;font-style:italic;color:#f5e8c8d9;margin-top:.1rem}button.field-slot:hover:not(.selected),button.field-slot.selected{transform:translateY(-1px)}button.building-slot:not(.empty){position:relative;min-height:0;padding:0;gap:0;width:100%;aspect-ratio:1 / 1;max-width:220px;margin:0 auto;overflow:hidden;display:block}button.building-slot:not(.empty) .building-slot-img{width:100%;height:100%;max-width:100%;max-height:100%;object-fit:cover;margin:0;display:block;border-radius:0}.building-slot-label{position:absolute;left:0;right:0;bottom:0;padding:.35rem .6rem .4rem;background:linear-gradient(180deg,#140c0500,#140c058c 35%,#140c05d9);text-align:center;pointer-events:none;text-shadow:0 1px 2px rgba(0,0,0,.8)}button.building-slot:not(.empty) .slot-level{font-size:.88rem;font-style:italic;color:#f5e8c8;margin-top:0}button.building-slot.empty{width:100%;aspect-ratio:1 / 1;max-width:220px;margin:0 auto;min-height:0;display:flex;align-items:center;justify-content:center}.training-icon{align-self:stretch;width:100px;flex-shrink:0;padding:2px;background:#e8dfc880;border:1px solid rgba(139,58,31,.18);border-radius:4px;display:flex;align-items:center;justify-content:center}.training-icon-img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block}.training-row{cursor:pointer;border:2px solid transparent;border-radius:4px;padding:.35rem .7rem;margin-bottom:.3rem;background:#e8dfc84d;transition:background .12s ease,border-color .12s ease}.training-row:hover:not(.focused){background:#e8dfc88c}.training-row.focused{background:#8b3a1f1f;border-color:#8b3a1f;box-shadow:0 0 0 1px #8b3a1f2e}.training-stat-label:after{content:":"}.training-row.focused .training-stats-name{color:#1a1a1a}.training-row.focused .training-stats-name-lvl{color:#1a1a1a8c}.training-row.focused .training-stat-value{font-weight:700;color:#8b3a1f;font-variant-numeric:tabular-nums}.research-section-headerline{display:flex;align-items:baseline;gap:.6rem;flex-wrap:wrap;border-bottom:1px solid var(--bm-border);padding-bottom:.3rem;margin-bottom:.6rem}.research-section-headerline .building-section-header{margin:0;border-bottom:none;padding-bottom:0;flex:0 0 auto}.research-section-headerline .building-section-hint{margin:0;flex:1 1 14rem}.research-list{list-style:none;padding:0;margin:0}.research-row{border:2px solid transparent;border-radius:4px;padding:.45rem .7rem;margin-bottom:.6rem;background:#e8dfc84d}.research-action-row{display:flex;align-items:center;gap:1rem;margin-top:.5rem;padding-bottom:.5rem;border-bottom:1px solid rgba(74,58,40,.18)}.research-action-time,.research-action-cost{display:inline-flex;align-items:center;gap:.4rem;color:#1a1a1a;font-size:.95rem}.research-action-label{color:#6a5535;font-size:.85rem}.research-action-status{flex:1;font-style:italic;color:#6a5535;font-size:.85rem;text-align:right}.research-action-status.muted{opacity:.55}.research-action-afford{margin-left:.5rem;font-size:.85rem;font-variant-numeric:tabular-nums}.research-action-afford .countdown-at{color:#6a5535}.research-action-afford-never{margin-left:.5rem;font-size:.8rem;font-style:italic;color:#8a2a1f}.training-controls{margin-top:1rem;padding:1rem 1.1rem;background:#2e4e3f14;border:1px solid rgba(46,78,63,.25);border-radius:4px}.training-controls-name{font-size:1.1rem;margin-bottom:.65rem;color:#1a1a1a}.training-controls-name strong{color:#2e4e3f}.training-controls-slider-row{display:flex;align-items:center;gap:.85rem;margin-bottom:.5rem}.training-controls-slider-row .training-slider{flex:1}.training-controls-slider-row .training-count-display{min-width:4.5rem;font-size:1.05rem;color:#1a1a1a}.training-controls-slider-row .training-count-number{font-weight:700;font-variant-numeric:tabular-nums}.training-controls-preview{font-size:.95rem;color:#1a1a1a;display:flex;flex-direction:column;gap:.25rem;margin-bottom:.5rem}.training-controls-preview-row{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-family-numeric, "Inter", system-ui, sans-serif)}.training-controls-preview-label{font-family:var(--font-family-body, "Lora", Georgia, serif);font-weight:600;color:#1a1a1ab3}.training-controls-preview-value{font-variant-numeric:tabular-nums}.training-controls{position:sticky;bottom:-1rem;margin-bottom:-1rem;margin-left:-1.1rem;margin-right:-1.1rem;padding-left:1.1rem;padding-right:1.1rem;padding-bottom:1rem;z-index:5;background:linear-gradient(180deg,#e8dfc8f2,#e8dfc8 30% 100%);border-top:2px solid rgba(139,58,31,.35);border-radius:0;box-shadow:0 -8px 16px #00000014}.training-selected-panel.research-banner-panel{position:sticky;top:-1rem;bottom:auto;z-index:5;margin:-1rem -1.1rem 1rem;padding:1rem 1.1rem;border-bottom:2px solid rgba(139,58,31,.35);box-shadow:0 8px 16px #00000014}.research-banner-bottom{margin-top:auto;display:flex;flex-direction:column;gap:.6rem}.research-banner-countdown{font-family:var(--font-numeric);font-variant-numeric:tabular-nums;font-size:1.1rem}.research-banner-countdown .countdown-in{color:#1a1a1a;font-weight:700}.research-banner-countdown .countdown-at{color:#1a1a1a99}.research-banner-countdown .countdown-sep{color:#1a1a1a73}.research-banner-progress{width:100%;height:1.1rem;background:#281a0e2e;border:1px solid rgba(40,26,14,.2);border-radius:999px;overflow:hidden}.research-banner-progress-fill{height:100%;background:linear-gradient(90deg,#4ec24b,#7ed14b);border-radius:999px;transition:width .5s linear}.training-selected-panel{position:sticky;bottom:-1rem;margin:1rem -1.1rem -1rem;padding:1rem 1.1rem;z-index:5;background:linear-gradient(180deg,#e8dfc8f2,#e8dfc8 30% 100%);border-top:2px solid rgba(139,58,31,.35);border-radius:0;box-shadow:0 -8px 16px #00000014;display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:stretch}.training-selected-illustration{align-self:stretch;width:260px;display:flex;align-items:center;justify-content:center;background:#e8dfc880;border:none;border-radius:0;flex-shrink:0;position:relative;cursor:pointer;padding:0;transition:transform .15s ease,box-shadow .15s ease}.training-selected-illustration:hover:not(:disabled){transform:scale(1.03);box-shadow:0 4px 12px #2814052e}.training-selected-illustration:disabled{cursor:default}.training-selected-zoom-icon{position:absolute;bottom:6px;right:6px;width:28px;height:28px;padding:5px;background:#281e14a6;border-radius:50%;color:#f5e8c8;display:flex;align-items:center;justify-content:center;pointer-events:none}.training-zoom-img{display:block;margin:0 auto;max-width:min(80vw,720px);max-height:70vh;width:auto;height:auto;object-fit:contain}.training-selected-illustration-img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block}.training-selected-body{display:flex;flex-direction:column;gap:.45rem;min-width:0}.training-selected-name{font-family:var(--font-body);font-size:2.4rem;font-weight:700;letter-spacing:.01em;color:#1a1a1a;line-height:1.15}.training-selected-name-lvl{font-weight:400;color:#1a1a1a8c;font-size:1.4rem}.training-selected-description{font-family:var(--font-body);font-size:1rem;line-height:1.4;color:#1a1a1ac7;font-style:italic}.training-selected-preview{display:flex;flex-direction:column;gap:.4rem;font-size:1.5rem;color:#1a1a1a;margin-top:auto}.training-selected-preview .cost-inline-icon{width:1.8rem;height:1.8rem;max-width:1.8rem;max-height:1.8rem}.training-selected-preview .cost-inline-value{font-size:1.5rem}.training-selected-controls-row{display:flex;align-items:center;gap:1rem;margin-top:.6rem}.training-selected-controls-row .training-slider{flex:1;min-width:0}.training-count-input{width:80px;padding:.45rem .55rem;font-family:var(--font-numeric);font-size:1.4rem;font-variant-numeric:tabular-nums;text-align:center;border:1px solid rgba(139,58,31,.35);border-radius:4px;background:#fffcf099;color:#1a1a1a}.training-count-input:focus{outline:2px solid #8B3A1F;outline-offset:-1px}.training-count-input:disabled{opacity:.5;cursor:not-allowed}.training-selected-train-btn{flex-shrink:0}.build-queue-panel{margin:.75rem 0 1.25rem}.build-queue-header{margin:0 0 .5rem;font-size:1.2rem}.build-queue-grid{display:flex;flex-wrap:nowrap;align-items:stretch;gap:.5rem}.build-queue-slot0{flex:0 0 240px;align-self:center}.build-queue-slot0 .progress-card{width:100%;height:auto;margin-bottom:0}.build-queue-slot0 .progress-card{padding:.26rem .55rem .26rem .46rem;gap:.5rem;overflow:hidden}.build-queue-slot0 .progress-card-icon{width:7rem;height:7rem;margin:-.3rem 0}.build-queue-slot0 .progress-card-heading{margin-bottom:.08rem;font-size:.85rem}.build-queue-slot0 .progress-card-progress{margin-bottom:.12rem}.build-queue-slot0 .progress-card-times{flex-wrap:nowrap;font-size:.8rem;gap:.6rem}.build-queue-slot0 .progress-card-cancel{padding:.1rem .55rem;font-size:.75rem}.build-queue-slot0-empty{display:flex;align-items:center;justify-content:center;border:2px dashed rgba(139,58,31,.3);border-radius:4px;background:#8b3a1f0a;min-height:60px}.build-queue-cell{position:relative;flex:1 1 0;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:.22rem;padding:.3rem .35rem;border:2px solid rgba(139,58,31,.3);border-radius:8px;background:#fffcf08c}.build-queue-cell--reserved{border-color:#3a7d44;background:#3a7d441a}.build-queue-cell--ready{border-color:#c8911f;background:#c8911f1f;box-shadow:0 0 0 1px #c8911f59}.build-queue-cell--short{border-color:#c8911f73;opacity:.85}.build-queue-cell-art{position:relative;width:100%;max-width:60px;aspect-ratio:1 / 1}.build-queue-cell-icon{width:100%;height:100%;object-fit:contain}.build-queue-cell-level-ring{position:absolute;top:0;left:0;display:inline-flex;align-items:center;justify-content:center;width:1.65rem;height:1.65rem;border-radius:50%;border:2px solid #b8922f;background:#1c1915e0;color:#f1e2c3;font-family:var(--font-numeric);font-variant-numeric:tabular-nums;font-weight:700;font-size:.85rem;line-height:1}.countdown{font-variant-numeric:tabular-nums}.countdown-at{color:var(--color-text-muted)}.build-queue-cell-eta{display:flex;flex-direction:column;align-items:center;line-height:1.15;text-align:center}.build-queue-cell-eta .countdown{display:flex;flex-direction:column;align-items:center}.build-queue-cell-eta .countdown-sep{display:none}.build-queue-cell-eta .countdown-in{font-family:var(--font-numeric);font-variant-numeric:tabular-nums;font-size:.8rem;font-weight:600;color:#5a3920}.build-queue-cell-eta .countdown-at{font-family:var(--font-numeric);font-variant-numeric:tabular-nums;font-size:.7rem;color:#5a392099}.build-queue-cell-eta-never{font-size:.95rem;font-weight:700;color:#5a39208c}.build-queue-cell-arrows{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:space-between;padding-bottom:.18rem;pointer-events:none}.build-queue-cell-arrows button{pointer-events:auto;width:1.25rem;height:1.6rem;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:.78rem;line-height:1;border:none;border-radius:3px;background:#1c19156b;color:#fff5e1eb;cursor:pointer}.build-queue-cell-arrows button:disabled{opacity:.22;cursor:default}.build-queue-cell-cancel-dot{position:absolute;top:0;right:0;width:1.35rem;height:1.35rem;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;border:2px solid #e8dfc8;background:#b23a2a;color:#fff;font-size:.95rem;font-weight:700;line-height:1;cursor:pointer}.build-queue-cell-cancel-dot:hover{background:#c8442f}.build-queue-reserve{width:100%;padding:.13rem .3rem;font-size:.74rem;background:#3a7d44;color:#fff}.modal-upgrade-buttons,.buildable-actions{display:flex;gap:.5rem;align-items:center}.modal-upgrade-button--secondary,.modal-upgrade-button--queue{background:#8b3a1f1f;color:#5a3920}.build-queue-section{margin:.75rem 0 1.25rem}.build-queue-caption{margin:.5rem 0 .4rem;font-size:.95rem}.build-queue-cell--empty{border-style:dashed;border-color:#8b3a1f40;background:#8b3a1f08;opacity:.7;justify-content:center}.build-queue-slot0-empty .slot-empty-plus,.build-queue-cell--empty .slot-empty-plus{font-size:1.8rem;font-weight:700;color:#8b3a1f73;line-height:1}.build-queue-strip{position:fixed;left:0;right:0;bottom:0;z-index:90;box-sizing:border-box;max-height:46vh;overflow-y:auto;padding:.3rem 1rem .4rem;background:#e8dfc8;border-top:2px solid #3a2010;box-shadow:inset 0 2px #fff0cd80,0 -6px 18px #0006}.build-queue-strip .build-queue-panel{margin:0}.build-queue-strip-head{display:flex;align-items:baseline;gap:.75rem;margin-bottom:.3rem}.build-queue-strip-title{font-family:var(--font-heading, inherit);font-size:1rem;font-weight:700;letter-spacing:.03em;color:#5a3920}.build-queue-strip-error{font-size:.85rem}.build-queue-strip--empty{display:flex;align-items:center;min-height:44px;font-size:.95rem}.ingame-shell{display:flex;flex-direction:column;height:100dvh;overflow:hidden}.ingame-shell>.ingame-top-panel{flex:0 0 auto}.ingame-content{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden;padding-bottom:158px}body,input,button,select,textarea{font-family:var(--font-body)}h1,h2,h3,.modal-header,.modal-header-with-image,.building-section-header{font-family:var(--font-display);letter-spacing:.04em}h1,h2,h3,.building-section-header{line-height:1.2}.city-identity-tribe,.top-bar,.player-row-text{font-family:var(--font-body);letter-spacing:0}.top-bar-stats{display:inline-flex;align-items:center;gap:1.5rem;margin-left:auto;margin-right:1.5rem}.top-bar-stat{font-size:1.05rem;letter-spacing:.02em}.top-bar-stat strong{font-variant-numeric:tabular-nums;margin-left:.15rem}.top-bar-stat-icon{width:1.3rem;height:1.3rem;object-fit:contain;vertical-align:middle;margin-right:.15rem}.resource-card-top{display:flex;align-items:center;gap:.4rem;font-size:.95rem}.resource-card-top .resource-card-icon{width:1.5rem;height:1.5rem;max-width:1.5rem;max-height:1.5rem;margin-right:.15rem}.resource-card-name{font-weight:700;letter-spacing:.04em;font-family:var(--font-display);flex:1}.resource-card-rate{font-size:.85rem;color:#1a1a1ab8;font-variant-numeric:tabular-nums}.resource-card-numbers{display:flex;align-items:baseline;gap:.35rem;font-variant-numeric:tabular-nums}.resource-card-value{font-size:1.4rem;font-weight:700}.resource-card-cap{font-size:.9rem;color:#1a1a1a99}.resource-bar{height:14px;width:100%;background:#140c052e;border-radius:4px;overflow:hidden;margin-top:0}.resource-bar-fill{height:100%;background:linear-gradient(180deg,#8b3a1fd9,#8b3a1f99);transition:width .2s ease}.resource-bar-fill.at-cap{background:linear-gradient(180deg,#b53521,#8b2618)}.resource-bar-fill.negative{background:repeating-linear-gradient(45deg,#b53521 0 6px,#8b2618 6px 12px)}.resource-card .resource-name{font-size:.95rem}.slot-level-badge{position:absolute;top:.4rem;right:.4rem;min-width:1.8rem;height:1.8rem;padding:0 .4rem;display:flex;align-items:center;justify-content:center;background:#8b3a1f;color:#f5e8c8;border-radius:999px;font-family:var(--font-numeric);font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;font-size:.95rem;font-weight:700;text-shadow:0 1px 1px rgba(0,0,0,.4);box-shadow:0 1px 2px #00000073,inset 0 1px #ffffff38;pointer-events:none;z-index:2}.field-slot-label{padding:.45rem .6rem .5rem}button.field-slot .slot-name{font-size:1rem}.building-slot-label{display:none}.top-bar-faith{margin-left:auto}.city-identity{display:flex;align-items:center;gap:1.4rem;padding:.85rem 1rem;flex-wrap:wrap}.city-identity-text{flex:0 0 auto}.city-identity-city{display:flex;flex-direction:column;gap:.35rem;flex:0 0 auto;border-left:1px solid rgba(139,58,31,.25);padding-left:1.2rem}.city-identity-cityname{font-family:var(--font-display);font-size:1.15rem;font-weight:700;letter-spacing:.03em;color:#1a1a1a;display:inline-flex;align-items:center;gap:.4rem}.city-rename-button{background:transparent;border:1px solid transparent;box-shadow:none;text-shadow:none;color:var(--color-muted-on-dark);font-size:.95rem;cursor:pointer;padding:.1rem .35rem;border-radius:3px;font-weight:400;letter-spacing:0}.city-rename-button:hover:not(:disabled){box-shadow:none;background:#f0d9b526;border-color:#f0d9b559;color:#f0d9b5}.city-nav-arrows{position:absolute;top:100%;right:0;margin-top:3px;display:inline-flex;align-items:center;gap:.05rem;z-index:1}.city-nav-arrow{background:transparent;border:1px solid transparent;box-shadow:none;text-shadow:none;color:var(--color-muted-on-dark);font-size:1.15rem;line-height:1;cursor:pointer;padding:.05rem .3rem;border-radius:3px;font-weight:700}.city-nav-arrow:hover:not(:disabled){box-shadow:none;background:#f0d9b526;border-color:#f0d9b559;color:#f0d9b5}.city-identity-cityname-edit{display:inline-flex;align-items:center;gap:.4rem}.city-rename-input{font-family:var(--font-display);font-size:1.05rem;font-weight:700;padding:.2rem .5rem;border:1px solid rgba(139,58,31,.5);border-radius:3px;background:#fff8e8;color:#1a1a1a;width:16ch}.city-rename-save,.city-rename-cancel{font-family:var(--font-body);font-size:.85rem;padding:.2rem .6rem;border-radius:3px;border:1px solid rgba(139,58,31,.5);cursor:pointer}.city-rename-save{background:#c5a370;color:#1a1a1a;font-weight:600}.city-rename-cancel{background:#fffaebd9;color:#5a3920}.city-rename-error{font-size:.8rem;margin-top:.25rem}.city-identity-stats{display:flex;align-items:center;gap:1.5rem;margin-left:auto;border-left:1px solid rgba(139,58,31,.25);padding-left:1.2rem}.city-identity-stat{display:inline-flex;align-items:center;gap:.4rem}.city-identity-stat-icon{width:1.6rem;height:1.6rem;object-fit:contain}.city-identity-stat-value{font-size:1.4rem;font-weight:700;font-variant-numeric:tabular-nums;color:#1a1a1a}.city-identity-stat-value .muted{font-size:.85rem}.resource-rows{display:flex;flex-direction:column;gap:.9rem}.resource-row{display:grid;grid-template-columns:minmax(260px,1fr) 3fr;gap:1rem;align-items:stretch}.resource-row .resource-card{align-self:stretch}.resource-row-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.resource-row-fields button.field-slot{max-width:none;margin:0}.slot-level-badge{position:absolute;top:.5rem;left:.5rem;right:auto;width:2.6rem;height:2.6rem;min-width:0;padding:0;background:#f5e8c8;color:#1a1a1a;border:3px solid #8B3A1F;border-radius:999px;font-family:var(--font-numeric);font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;font-size:1.1rem;font-weight:700;text-shadow:none;display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 1px #f5e8c8e6,0 2px 4px #00000059;pointer-events:none;z-index:2}.slot-queued-badges{position:absolute;top:.5rem;left:3.3rem;right:.4rem;display:flex;flex-wrap:wrap;gap:.2rem;pointer-events:none;z-index:3}.slot-queued-plus{width:1.2rem;height:1.2rem;flex:0 0 auto;display:flex;align-items:center;justify-content:center;background:#3a7d44;color:#f5e8c8;border:2px solid rgba(245,232,200,.85);border-radius:999px;font-family:var(--font-body);font-size:.85rem;font-weight:700;line-height:1;box-shadow:0 1px 3px #0006}.slot-queued-badges--empty{left:.5rem}:root{--num-font: var(--font-numeric)}.num{font-family:var(--font-numeric);font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}.resource-card-value,.resource-card-cap,.resource-card-rate,.resource-card-numbers,.city-identity-stat-value,.top-bar-stat strong,.top-bar-faith strong,.slot-level-badge,.cost-inline-value,.training-count-number,.training-count-display,.training-row-detail,.resource-card .resource-value,.resource-card .resource-cap,.resource-card .resource-rate,.training-controls-slider-row .training-count-display,.training-controls-preview,.upgrade-spec dd{font-family:var(--num-font);font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}.resource-columns{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;align-items:start}.resource-column{display:flex;flex-direction:column;gap:.75rem;min-width:0}.resource-card{display:grid;grid-template-rows:auto auto auto;gap:.6rem;align-items:center;justify-content:center;padding:.7rem .9rem .65rem;min-height:0;background:linear-gradient(180deg,#f4eacf,#e6d8b3);border:1px solid #8b5a2b;border-radius:4px;box-shadow:inset 0 1px #ffffff8c,inset 0 -2px 4px #8b5a2b2e,0 1px 2px #28140526}.resource-card-head{display:grid;grid-template-columns:auto 1fr;gap:.8rem;align-items:stretch}.resource-card-icon-frame{width:88px;height:88px;display:flex;align-items:center;justify-content:center;background:#f5e8c899;border:1px solid rgba(139,58,31,.18);border-radius:6px;flex-shrink:0}.resource-card-icon-frame .resource-card-icon{width:72px;height:72px;max-width:72px;max-height:72px;object-fit:contain;display:block;margin:0}.resource-card-head-text{display:flex;flex-direction:column;justify-content:center;gap:.1rem;min-width:0}.resource-card-name{font-family:var(--font-body);font-size:1.15rem;font-weight:700;letter-spacing:.01em;color:#1a1a1a;text-transform:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.resource-card-rate{font-size:.9rem;color:#1a1a1ad1}.resource-card-numbers{display:flex;justify-content:flex-start;align-items:baseline;gap:0;padding-top:.15rem}.resource-card-value{font-size:1.65rem;font-weight:700;color:#1a1a1a;letter-spacing:-.01em}.resource-card-cap{font-size:1rem;color:#1a1a1ac7}.resource-column-fields{display:flex;flex-direction:column;gap:.75rem}.resource-column-fields button.field-slot{max-width:none;margin:0;width:100%}.city-columns{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);grid-template-areas:"fields    training" "buildings .";gap:1.25rem 1.5rem;align-items:start}.city-column-fields{grid-area:fields}.city-cell-training{grid-area:training}.buildings-section{grid-area:buildings;min-width:0}@media(max-width:900px){.city-columns{grid-template-columns:1fr;grid-template-areas:"fields" "buildings" "training";gap:.5rem}}.city-column{min-width:0}.ingame-top-panel{position:sticky;top:0;z-index:95;background:#2c241c;border-bottom:2px solid #3a2010;box-shadow:0 6px 14px #00000080}.ingame-top-panel-inner{max-width:1280px;margin:0 auto;position:relative;z-index:1;background:#2c241c;padding:.35rem 1.75rem .45rem}.ingame-top-panel .top-bar{margin:0 0 .4rem;flex-wrap:wrap}.ingame-nav{display:inline-flex;align-items:center;gap:1rem}.ingame-city-name{display:inline-flex;align-items:center;gap:.25rem}.ingame-top-panel-empty{padding:.6rem .25rem;font-style:italic}.ingame-panel-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);column-gap:1.5rem;align-items:start}.ingame-panel-left{display:flex;flex-direction:column;gap:.55rem;min-width:0}.ingame-panel-left .resource-cards-grid{margin-top:0}@media(max-width:900px){.ingame-panel-grid{grid-template-columns:1fr;gap:.6rem}}.ingame-identity{display:flex;align-items:stretch;gap:1.1rem;min-width:0}.ingame-identity-emblem{width:92px;height:92px;object-fit:contain;flex-shrink:0}.ingame-identity-text{display:flex;flex-direction:column;justify-content:space-between;gap:.4rem;min-width:0}.ingame-identity-top{display:flex;flex-direction:column;gap:.15rem}.ingame-identity-name-row{display:flex;align-items:center;flex-wrap:wrap;gap:.55rem .85rem}.ingame-identity-name{font-family:var(--font-display);font-weight:700;font-size:1.85rem;letter-spacing:.03em;color:#f0d9b5}.ingame-identity-title{font-family:var(--font-body);font-size:1rem;font-style:italic;letter-spacing:.03em;color:var(--color-muted-on-dark)}.ingame-identity-stats{display:flex;flex-wrap:wrap;align-items:center;gap:.3rem 1.1rem;color:#f0d9b5;font-family:var(--font-body)}.ingame-identity-stat{display:inline-flex;align-items:center;gap:.4rem;font-size:1.15rem;letter-spacing:.02em}.ingame-identity-stat strong{font-weight:700}.ingame-identity-stat-icon{width:1.6rem;height:1.6rem;object-fit:contain}.ingame-army-cell{min-width:0;display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.ingame-army-units{min-width:0}.ingame-panel-actions{display:flex;flex-direction:column;gap:.4rem;flex-shrink:0}.panel-action-button{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:.8rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#f0d9b5;background:linear-gradient(180deg,#3a2e22,#2a2018);border:1px solid #5a4632;border-radius:4px;padding:.4rem 1rem;cursor:pointer;box-shadow:inset 0 1px #ffdcaa1f;transition:background .15s ease,color .15s ease,border-color .15s ease}.panel-action-button:hover{background:linear-gradient(180deg,#4a3a2a,#352920);border-color:#7a6244;color:#ffe9c4}@keyframes reports-unread-pulse{0%,to{box-shadow:0 0 0 1px #f0c85a80,0 0 8px 1px #e6b44673}50%{box-shadow:0 0 0 1px #f0c85abf,0 0 18px 4px #e6b446b3}}.panel-action-button.is-unread{color:#1a120c;background:linear-gradient(180deg,#e6b54a,#c8902e);border-color:#f0c85a;animation:reports-unread-pulse 2.4s ease-in-out infinite}.panel-action-button.is-unread:hover{color:#1a120c;background:linear-gradient(180deg,#f0c45a,#d89a34);border-color:#ffdf7a}@media(prefers-reduced-motion:reduce){.panel-action-button.is-unread{animation:none;box-shadow:0 0 0 1px #f0c85a99,0 0 12px 2px #e6b44699}}.ingame-army-label{font-family:var(--font-display);font-size:.85rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-muted-on-dark);margin:0 0 .25rem;display:flex;align-items:center;gap:.45rem}.ingame-army-empty{margin:0;font-size:.9rem}.ingame-army-units--clickable{cursor:pointer;border-radius:6px;padding:.15rem .3rem;margin:-.15rem -.3rem;transition:background .15s ease}.ingame-army-units--clickable:hover{background:#ffdcaa12}.ingame-army-units--clickable:focus-visible{outline:2px solid rgba(240,200,90,.6);outline-offset:1px}.reinf-badge{display:inline-flex;align-items:center;gap:.2rem;font-family:var(--font-display);font-size:.78rem;font-weight:700;letter-spacing:.02em;color:#cfe2f0;background:linear-gradient(180deg,#2c3f52,#21303f);border:1px solid #44607a;border-radius:999px;padding:.05rem .5rem .05rem .4rem;box-shadow:inset 0 1px #b4d2f026}.reinf-badge-shield{width:.85rem;height:.85rem;color:#8fb8da;flex-shrink:0}.reinf-badge--own{color:#f0dcae;background:linear-gradient(180deg,#4a3a26,#382b1c);border-color:#6e5636;box-shadow:inset 0 1px #ffdcaa26}.reinf-badge--own .reinf-badge-shield{color:#d9b877}.army-breakdown{display:flex;flex-direction:column;gap:1rem}.army-breakdown-net{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;padding:.5rem .75rem;border-radius:6px;background:#78966e1f;border:1px solid rgba(120,150,110,.35)}.army-breakdown-net--bad{background:#aa463c24;border-color:#be5a4680}.army-breakdown-net-label{font-family:var(--font-display);font-size:.8rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--color-muted-on-dark)}.army-breakdown-net-value{font-size:1.1rem;font-weight:700;color:#bfe0a8}.army-breakdown-net--bad .army-breakdown-net-value{color:#f0a090}.army-breakdown-section{display:flex;flex-direction:column;gap:.45rem}.army-breakdown-section-title{font-family:var(--font-display);font-size:.9rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#e6d2a8;border-bottom:1px solid rgba(200,175,130,.25);padding-bottom:.25rem}.army-breakdown-empty,.army-breakdown-hint{margin:0;font-size:.85rem}.army-breakdown-tiles{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;align-items:flex-start;gap:.3rem}.army-breakdown-tile{display:inline-flex;align-items:center;gap:.4rem;padding:.2rem .5rem;border-radius:5px;background:#ffdcaa0f}.army-breakdown-tile-name{font-size:.85rem;color:#e8dcc0}.reinf-group{border-left:3px solid #44607a;background:#3c5a7824;border-radius:0 6px 6px 0;padding:.5rem .6rem;display:flex;flex-direction:column;gap:.4rem}.reinf-group+.reinf-group{margin-top:.45rem}.reinf-group .army-breakdown-tile{background:#78a0c81f}.reinf-group-head{display:flex;align-items:baseline;justify-content:space-between;gap:.6rem}.reinf-group-sender{font-family:var(--font-display);font-weight:700;font-size:.95rem;color:#cfe2f0}.reinf-group-grain{font-size:.82rem}.reinf-group-note{margin:0;font-size:.78rem}.reinf-group--own{border-left-color:#8a6d3f;background:#96784621}.reinf-group--own .army-breakdown-tile{background:#dcbe821f}.reinf-group--own .reinf-group-sender{color:#f0dcae}.resource-cards-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;align-items:start;margin-top:.25rem}@media(max-width:600px){.resource-cards-grid{grid-template-columns:repeat(2,1fr)}}.resource-fields-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem;align-items:start}.field-slot--empty{border:none;background:none;box-shadow:none;cursor:default}.army-columns{display:grid;grid-template-columns:auto auto;justify-content:start;gap:0 .55rem;align-items:start}.army-col{min-width:0}.ingame-army-units .army-list{max-width:7rem}.ingame-army-units .army-columns{gap:0 .4rem}.ingame-army-units .army-row{gap:.3rem;padding:.14rem .45rem}.ingame-army-units .army-count{margin-left:0}.resource-cards-grid .resource-card{padding:.45rem .7rem .4rem;gap:.3rem}.resource-cards-grid .resource-card-head{grid-template-columns:auto 1fr;justify-items:start;align-items:center;gap:.6rem}.resource-cards-grid .resource-card-icon-frame{width:44px;height:44px}.resource-cards-grid .resource-card-icon-frame .resource-card-icon{width:36px;height:36px;max-width:36px;max-height:36px}.resource-cards-grid .resource-card-head-text{align-items:flex-start;text-align:left}.resource-cards-grid .resource-card-name{font-size:1rem}.resource-cards-grid .resource-card-rate{font-size:.82rem}.resource-cards-grid .resource-card-numbers{justify-content:flex-start;margin-top:.1rem}.resource-cards-grid .resource-card-value{font-size:1.3rem}.resource-cards-grid .resource-card-cap{font-size:.9rem}.buildings-section .buildings-grid{grid-template-columns:repeat(5,1fr)}.training-queue-idle{margin:.2rem 0 .1rem;font-style:italic;font-size:.9rem;color:#f0d9b5;opacity:.55}.section-heading-row{display:flex;align-items:center;justify-content:flex-start;gap:.5rem;margin:1.5rem 0 .6rem;border-bottom:1px solid rgba(139,90,43,.4);padding-bottom:.3rem}.section-heading-row h2{margin:0;border-bottom:none;padding-bottom:0}button.section-toggle{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;background:none;border:none;border-radius:4px;box-shadow:none;padding:0;margin:0;color:#2e4e3f;text-shadow:none;line-height:1;cursor:pointer}button.section-toggle:hover:not(:disabled){box-shadow:none;color:#b54821}.section-toggle-chevron{display:inline-block;font-size:1.5rem;transition:transform .18s ease}button.section-toggle[aria-expanded=false] .section-toggle-chevron{transform:rotate(-90deg)}.top-bar-stat strong{font-weight:700}.city-identity-stat-value{letter-spacing:-.01em}.resource-card-rate-bad{color:#b53521;font-weight:700}.hex-grid-wrap{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:#e8dfc866;border:1px solid rgba(139,58,31,.18);border-radius:6px;overflow:auto}.hex-grid{display:block;max-width:100%;height:auto;flex-shrink:0}.hex-canvas-wrap{flex:1 1 auto;min-width:0;height:72vh;min-height:420px;border-radius:6px;overflow:hidden;background:#1a120c;position:relative}.hex-canvas{display:block}.ingame-content .container.map-view{display:flex;flex-direction:column;height:calc(100% - .5rem);min-height:0;margin-top:.5rem;margin-bottom:0;overflow:hidden}.container.map-view .hex-grid-wrap{flex:1 1 auto;min-height:0;overflow:hidden}.container.map-view .hex-grid-row{flex:1 1 auto;min-height:0;align-items:stretch}.container.map-view .tile-info-panel{align-self:flex-start}.container.map-view .hex-canvas-wrap{height:auto;min-height:0}.map-top-nav{margin:0 0 .75rem}.map-back-link{display:inline-block;padding:.35rem .8rem;background:#1a120cb8;border:1px solid rgba(120,98,68,.6);border-radius:4px;color:#f0d9b5;text-decoration:none;font-family:var(--font-body);font-size:.9rem;letter-spacing:.02em}.map-back-link:hover{background:#1a120ce0;border-color:#a07c4a;color:#fff}.hex-grid-row{display:flex;flex-direction:row;gap:1rem;align-items:flex-start}.tile-info-panel{order:-1;flex:1 1 220px;min-width:220px;max-width:320px;padding:.85rem 1rem;background:#fffaeba6;border:1px solid rgba(58,42,24,.25);border-radius:4px;font-family:var(--font-body);font-size:.95rem;color:#1a1a1a}.tile-info-card{display:flex;flex-direction:column;gap:.7rem}.tile-info-card-head{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}.tile-info-heading{margin:0;font-size:1.05rem;font-weight:600}.tile-info-terrain{font-size:.8rem;text-transform:capitalize;font-style:italic;color:#6a4a2a}.tile-info-identity{display:flex;align-items:center;gap:.6rem}.tile-info-emblem{width:44px;height:44px;object-fit:contain;flex-shrink:0}.tile-info-identity-text{min-width:0}.tile-info-owner-name{font-size:1.1rem;font-weight:700;color:#3a2410}.tile-info-owner-tribe{font-size:.85rem;text-transform:capitalize}.tile-info-details{display:grid;grid-template-columns:auto 1fr;gap:.2rem .8rem;margin:0;font-size:.9rem}.tile-info-details dt{color:#6a5a40}.tile-info-details dd{margin:0;text-align:right;font-weight:600;color:#2a1a0c}.tile-info-empty{margin:0}.tile-info-section-title{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:#6a5a40;margin-bottom:.3rem}.tile-info-land{display:flex;gap:.5rem}.tile-info-land-cell{display:inline-flex;flex-direction:column;align-items:center;gap:.12rem}.tile-info-land-count{font-weight:700;font-size:.95rem;color:#2a1a0c;font-variant-numeric:tabular-nums}.tile-info-land-icon{width:34px;height:34px;object-fit:contain}.tile-info-actions{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem}.tile-info-action-link{color:#8b3a1f;font-weight:600;text-decoration:none}.tile-info-action-link:hover{text-decoration:underline}.send-march-types{display:flex;flex-wrap:wrap;gap:.5rem;margin:.75rem 0}.send-march-type-btn{padding:.5rem .9rem;background:#fffaebcc;border:1px solid rgba(58,42,24,.4);border-radius:4px;font-family:var(--font-body);font-size:.95rem;color:#1a1a1a;cursor:pointer;text-transform:capitalize}.send-march-type-btn.active{background:#c5a370;border-color:#6a3f1a;font-weight:600}.send-march-type-btn:disabled{opacity:.45;cursor:not-allowed}.send-march-target{margin:0 0 .5rem;font-family:var(--font-body);font-size:1rem}.send-march-target-coord{color:#5a3920;font-weight:600}.send-march-unit-list{list-style:none;padding:0;margin:.75rem 0;display:flex;flex-direction:column;gap:.5rem}.send-march-unit-row{display:flex;align-items:center;gap:.6rem;padding:.4rem .6rem;background:#fffaeb99;border:1px solid rgba(58,42,24,.18);border-radius:3px}.send-march-unit-row.is-disabled{opacity:.4}.send-march-unit-icon{width:34px;height:34px;object-fit:contain;flex-shrink:0}.send-march-unit-name{flex:0 0 92px;font-family:var(--font-body);font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.send-march-unit-slider{flex:1 1 auto;min-width:0;accent-color:#a05218;cursor:pointer}.send-march-unit-input{flex:0 0 54px;width:54px;padding:.25rem .4rem;font-family:var(--font-body);font-size:.95rem;text-align:right}.send-march-unit-max{flex:0 0 auto;min-width:44px;padding:.25rem .45rem;background:#fffaeb80;border:1px solid rgba(58,42,24,.35);border-radius:3px;font-family:var(--font-body);font-size:.85rem;color:#5a4a30;cursor:pointer;font-variant-numeric:tabular-nums}.send-march-unit-max:hover:not(:disabled){background:#c5a370;color:#1a1a1a}.send-march-unit-max:disabled{cursor:not-allowed}.send-march-preview{margin:.75rem 0;padding:.6rem .8rem;min-height:9rem;background:#e8dfc899;border:1px solid rgba(139,58,31,.18);border-radius:4px;font-family:var(--font-body);font-size:.95rem}.send-march-preview-line{display:flex;justify-content:space-between;gap:1rem}.send-march-preview-label{color:#5a4a30}.send-march-preview-value{font-weight:600}.send-march-preview-detail{display:block;font-size:.85rem;color:#5a4a30;margin-top:.25rem;font-style:italic}.send-march-actions{display:flex;gap:.6rem;justify-content:flex-end;margin-top:.5rem}.send-march-type-placeholder{border-style:dashed}.send-march-ability-panel{margin:.6rem 0 .25rem;padding:.6rem .75rem;border:1px solid var(--color-border-mid);border-left-width:3px;border-radius:var(--radius-md);background:#1c191566;font-family:var(--font-body);font-size:.88rem}.send-march-ability-panel.is-eligible{border-left-color:#6b8e4e}.send-march-ability-panel.is-ineligible{border-left-color:#8d7a5e}.send-march-ability-title{font-family:var(--font-display);font-weight:700;letter-spacing:.02em;color:#f0d9b5;margin-bottom:.4rem}.send-march-ability-reqs{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.2rem}.send-march-ability-reqs li{display:flex;align-items:baseline;gap:.4rem;color:#cabfa6}.send-march-ability-mark{flex-shrink:0;font-weight:700}.send-march-ability-reqs li.req-ok{color:#9bc06f}.send-march-ability-reqs li.req-ok .send-march-ability-mark{color:#6b8e4e}.send-march-ability-reqs li.req-no{color:#c98770}.send-march-ability-reqs li.req-no .send-march-ability-mark{color:#b54821}.send-march-ability-reqs li.req-info{color:#a89a7e}.send-march-ability-status{margin-top:.45rem;font-weight:600}.send-march-ability-status.is-eligible{color:#9bc06f}.send-march-ability-status.is-ineligible{color:#a89a7e}.send-march-ability-note{margin-top:.35rem;color:#a89a7e;font-style:italic;font-size:.82rem}.send-march-lockin-row{display:flex;justify-content:flex-end;margin-top:.75rem}.send-march-lockin{padding:.5rem 1.1rem;font-family:var(--font-display);font-weight:700;letter-spacing:.03em;border:1px solid #7a6244;border-radius:4px;background:linear-gradient(180deg,#4a3a2a,#352920);color:#f0d9b5;cursor:pointer}.send-march-lockin:hover:not(:disabled){border-color:#a07c4a;color:#ffe9c4}.send-march-lockin:disabled{opacity:.5;cursor:not-allowed}.send-march-lockin.is-locked{background:linear-gradient(180deg,#e6b54a,#c8902e);border-color:#f0c85a;color:#1a120c}.hex-grid-legend{display:flex;flex-wrap:wrap;gap:.85rem 1.25rem;list-style:none;padding:0;margin:0;font-family:var(--font-body);font-size:.95rem;color:#1a1a1a}.hex-grid-legend li{display:inline-flex;align-items:center;gap:.4rem}.hex-grid-swatch{display:inline-block;width:1.1rem;height:1.1rem;border:1px solid rgba(58,42,24,.6);border-radius:2px;flex-shrink:0}.marches-banner{margin:1rem 0;padding:.85rem 1rem;background:#fffaeba6;border:1px solid rgba(139,58,31,.25);border-radius:4px;font-family:var(--font-body)}.marches-banner-heading{margin:0 0 .6rem;font-size:1.05rem;color:#5a3920}.marches-banner-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.marches-banner-row{padding:.6rem .75rem;background:#e8dfc880;border:1px solid rgba(58,42,24,.18);border-radius:3px;display:flex;flex-direction:column;gap:.3rem}.marches-banner-row-incoming{background:#ffdcc8a6;border-color:#b43c1e73}.marches-banner-row-returning{background:#dcebdc8c}.marches-banner-row-main{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;align-items:baseline}.marches-banner-direction{font-size:1rem;color:#1a1a1a}.marches-banner-countdown{color:#5a4a30}.marches-banner-countdown strong{color:#1a1a1a}.marches-banner-row-meta{display:flex;gap:.85rem;flex-wrap:wrap;align-items:center;font-size:.9rem}.marches-banner-units{color:#5a4a30;font-style:italic}.marches-banner-report-link{color:#8b3a1f;font-weight:600;text-decoration:none}.marches-banner-report-link:hover{text-decoration:underline}.marches-banner-cancel{padding:.3rem .7rem;background:#fffaebd9;border:1px solid rgba(180,60,30,.55);border-radius:3px;color:#8b3a1f;cursor:pointer;font-family:var(--font-body)}.marches-banner-cancel:hover{background:#ffdcc8d9}.marches-strip-layer{position:absolute;left:0;right:0;bottom:0;z-index:0;pointer-events:none}.marches-strip-layer-inner{position:relative;max-width:1280px;height:0;margin:0 auto}.marches-strip-group{position:absolute;bottom:0;display:flex;align-items:flex-start;gap:.5rem}.marches-strip-incoming{left:1.75rem}.marches-strip-outgoing{left:58%}.marches-strip-box{pointer-events:auto;position:relative;box-sizing:border-box;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;min-width:64px;height:58px;padding:.3rem .55rem .32rem;border:1px solid;border-top:none;border-radius:0 0 7px 7px;cursor:pointer;font-family:var(--font-body);transform:translateY(48%);box-shadow:0 5px 10px #0000006b;transition:transform .15s ease,filter .12s ease}.marches-strip-box:hover{transform:translateY(80%);filter:brightness(1.06)}.marches-strip-time{font-weight:700;font-size:.92rem;font-variant-numeric:tabular-nums;letter-spacing:.01em;line-height:1.05}.marches-strip-type{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;opacity:.82;line-height:1.1;white-space:nowrap}.marches-strip-count{position:absolute;left:-7px;bottom:-7px;min-width:19px;height:19px;padding:0 5px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:#1a120c;border:1px solid rgba(255,255,255,.3);color:#f0d9b5;font-size:.72rem;font-weight:700}.marches-strip-box-hostile{background:linear-gradient(180deg,#c0533f,#8f3526);border-color:#d9694f;color:#fff}.marches-strip-box-friendly{background:linear-gradient(180deg,#6b8e4e,#4a6634);border-color:#84a861;color:#fff}.marches-strip-box-outgoing{background:linear-gradient(180deg,#e6b54a,#c8902e);border-color:#f0c85a;color:#1a120c}.watchtower-modal{display:flex;flex-direction:column;gap:.9rem}.watchtower-columns{display:grid;grid-template-columns:minmax(240px,320px) 1fr;gap:1.5rem;align-items:start}@media(max-width:720px){.watchtower-columns{grid-template-columns:1fr}}.watchtower-col{display:flex;flex-direction:column;gap:1.1rem;min-width:0}.watchtower-section-title{margin:0 0 .5rem;font-family:var(--font-display);font-size:.95rem;font-weight:700;letter-spacing:.04em}.watchtower-title-hostile{color:#e7917a}.watchtower-title-friendly{color:#a6cd80}.watchtower-title-outgoing{color:#e6b54a}.watchtower-cards{display:flex;flex-direction:column;align-items:flex-start;gap:.6rem}.watchtower-cards-row{flex-direction:row;flex-wrap:wrap;align-items:flex-start}.watchtower-card{box-sizing:border-box;width:260px;max-width:100%;display:flex;flex-direction:column;gap:.5rem;padding:.65rem .8rem;border:1px solid #4a3a28;border-left-width:3px;border-radius:4px;background:#ffffff0d;text-align:left;font-family:var(--font-body)}.watchtower-card-hostile{border-left-color:#d9694f;background:#c0533f29}.watchtower-card-friendly{border-left-color:#84a861;background:#6b8e4e29}.watchtower-card-outgoing{border-left-color:#e6b54a;background:#e6b54a1f}.watchtower-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.watchtower-card-title{font-family:var(--font-display);font-size:.98rem;font-weight:700;color:#f0e6cc}.watchtower-card-toggle{flex-shrink:0;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border:1px solid #5a4632;border-radius:4px;background:#00000038;color:#d8cca8;font-size:1.05rem;line-height:1;cursor:pointer}.watchtower-card-toggle:hover{color:#fff;border-color:#7a6244}.watchtower-card-when{display:flex;flex-direction:column;gap:.05rem}.watchtower-when-in{color:#e8dfc8;font-size:.95rem;font-variant-numeric:tabular-nums}.watchtower-when-at{font-size:.85rem}.watchtower-card-army{display:grid;grid-template-columns:auto;justify-content:start;align-items:start}.watchtower-army-col{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.25rem}.watchtower-unit{display:inline-flex;align-items:center;gap:.3rem}.watchtower-unit-icon{width:30px;height:30px;object-fit:contain}.watchtower-unit-count{font-size:.9rem;color:var(--color-muted-on-dark);font-variant-numeric:tabular-nums}.watchtower-card-unknown{font-size:.9rem;font-style:italic}.watchtower-card-actions{display:flex;gap:.45rem;align-items:center;margin-top:.1rem;flex-wrap:wrap}.watchtower-card-actions .marches-banner-report-link{color:#e0a06a}.watchtower-card-actions .marches-banner-cancel{padding:.18rem .5rem;font-size:.78rem;background:#00000040;border-color:#d9694f99;color:#e7917a}.watchtower-card-actions .marches-banner-cancel:hover{background:#c0533f40}.watchtower-ability-activate{padding:.18rem .5rem;font-size:.78rem;background:linear-gradient(180deg,#e6b54a,#c8902e);border:1px solid #f0c85a;border-radius:3px;color:#1a120c;font-family:var(--font-display);font-weight:700;letter-spacing:.01em;cursor:pointer}.watchtower-ability-activate:hover:not(:disabled){border-color:#ffe9a0;filter:brightness(1.07)}.watchtower-ability-activate:disabled{background:#00000040;border-color:#8d7a5e80;color:#9a8b6e;cursor:not-allowed}.watchtower-ability-armed{font-family:var(--font-body);font-size:.85rem;font-weight:600;color:#9bc06f;white-space:nowrap}.watchtower-ability-picker{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.watchtower-ability-picker-label{display:flex;align-items:center;gap:.3rem;font-family:var(--font-body);font-size:.8rem;color:#cabfa6}.watchtower-ability-cancelpick{padding:.2rem .45rem;background:#00000040;border:1px solid rgba(141,122,94,.5);border-radius:3px;color:#cabfa6;cursor:pointer}.watchtower-card-collapsed{position:relative;width:118px;height:60px;padding:.32rem .55rem;justify-content:flex-start;gap:0;cursor:pointer}.watchtower-collapsed-type{font-family:var(--font-display);font-weight:700;font-size:.9rem;line-height:1.15;color:#f0e6cc}.watchtower-collapsed-time{font-size:.8rem;line-height:1.1;color:#e8dfc8;font-variant-numeric:tabular-nums}.watchtower-card-count{position:absolute;left:6px;bottom:4px;min-width:17px;height:17px;padding:0 4px;display:flex;align-items:center;justify-content:center;border-radius:9px;background:#1a120c;border:1px solid rgba(255,255,255,.28);color:#f0d9b5;font-size:.68rem;font-weight:700}.reports-list-heading{margin:1rem 0 .6rem;color:#5a3920}.reports-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem}.reports-list-row{padding:0}.reports-list-link{display:grid;grid-template-columns:80px 1fr 160px;gap:.6rem;align-items:center;padding:.6rem .85rem;background:#fffaeba6;border:1px solid rgba(58,42,24,.18);border-radius:3px;text-decoration:none;color:#1a1a1a;font-family:var(--font-body)}.reports-list-link:hover{background:#e8dfc8d9}.reports-list-type{font-weight:600;color:#5a3920}.reports-list-when{color:#5a4a30;text-align:right;font-size:.9rem}.statistics-heading{margin:1rem 0 .6rem;color:#5a3920}.statistics-sections{display:flex;flex-direction:column;gap:.6rem}.report-view{font-family:var(--font-body);color:#1a1a1a}.report-header{background:#8b3a1fd9;color:#fff;padding:1rem 1.25rem;border-radius:4px 4px 0 0}.report-header-type{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:#fffaebcc;margin-bottom:.25rem}.report-header-title{margin:0;font-size:1.4rem;color:#fff}.report-header-title .muted{color:#fffaebbf;font-weight:400;font-size:1rem}.report-header-meta{margin:.35rem 0 0;color:#fffaebd9;font-size:.9rem}.report-outcome{padding:1rem 1.25rem;background:#fffaebbf;border-left:1px solid rgba(139,58,31,.25);border-right:1px solid rgba(139,58,31,.25)}.report-outcome-headline{margin:0;font-size:1.15rem;font-weight:600}.report-outcome-detail{margin:.35rem 0 0;color:#5a4a30}.report-outcome-attacker_took_field,.report-outcome-defender_empty,.report-outcome-scout_succeeded,.report-outcome-scout_unguarded_succeeded{background:#e8f5e1d9}.report-outcome-defender_held,.report-outcome-attacker_empty,.report-outcome-scout_blocked{background:#ffe6dcd9}.report-outcome-mutual_attrition,.report-outcome-no_combat_both_empty{background:#f5f0dcd9}.report-section{padding:1rem 1.25rem;background:#fffaeb8c;border:1px solid rgba(139,58,31,.18);border-top:none}.report-section:last-of-type{border-radius:0 0 4px 4px}.report-section h3{margin:0 0 .6rem;color:#5a3920}.report-section h4{margin:.6rem 0 .3rem;color:#5a3920;font-size:.95rem}.report-collapsible{padding:0;background:#fffaeb80;border:1px solid rgba(139,58,31,.18);border-top:none}.report-collapsible-summary{cursor:pointer;padding:.6rem 1.25rem;font-weight:600;color:#5a3920}.report-collapsible-body{padding:.4rem 1.25rem 1rem}.report-resolution-dl{display:grid;grid-template-columns:max-content 1fr;gap:.3rem 1rem;margin:0}.report-resolution-dl dt{color:#5a4a30;font-style:italic}.report-resolution-dl dd{margin:0;font-weight:600}.report-casualty-table,.report-loot-table{border-collapse:collapse;width:100%;margin:.4rem 0}.report-casualty-table th,.report-casualty-table td,.report-loot-table th,.report-loot-table td{padding:.35rem .6rem;text-align:left;border:1px solid rgba(58,42,24,.18)}.report-casualty-table th,.report-loot-table th{background:#e8dfc899;font-weight:600;color:#5a3920}.report-shell{background:#e8dfc8;border:1px solid #3a2010;border-radius:6px;box-shadow:0 10px 30px #00000073;overflow:hidden}.report-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.6rem 1rem;background:#8b3a1feb;color:#fff5eb}.report-toolbar-back{background:transparent;border:1px solid rgba(255,245,235,.55);color:#fff5eb;border-radius:4px;padding:.3rem .7rem;font-size:.9rem;cursor:pointer}.report-toolbar-back:hover{background:#ffffff1f}.report-toolbar-meta{display:flex;align-items:baseline;gap:.8rem}.report-toolbar-type{text-transform:uppercase;letter-spacing:.08em;font-weight:600;font-size:.85rem;color:#ffe9d2}.report-toolbar-when{font-size:.85rem;color:#fff5ebbf}.report-outcome-factual{background:#f5f0dce6}.report-shell .report-outcome-headline{font-size:1.4rem}.report-emblem-banner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;padding:1.1rem 1.25rem;background:#fffaeb99;border-left:1px solid rgba(139,58,31,.18);border-right:1px solid rgba(139,58,31,.18)}.report-emblem-party{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.2rem}.report-emblem-side{font-size:.72rem;letter-spacing:.1em;color:#8a6a45;text-transform:uppercase}.report-emblem-crest{width:4rem;height:4rem;object-fit:contain}.report-emblem-name{font-weight:700;color:#3a2818;font-size:1.05rem}.report-emblem-origin{font-size:.8rem;color:#6a553a}.report-emblem-center{display:flex;align-items:center;justify-content:center}.report-emblem-action{width:3rem;height:3rem;border-radius:50%;background:#8b3a1f1f;border:1px solid rgba(139,58,31,.3);display:flex;align-items:center;justify-content:center;font-size:1.4rem}.report-action-glyph{line-height:1}.report-units-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;padding:1.1rem 1.25rem;background:#fffaeb8c;border:1px solid rgba(139,58,31,.18);border-top:none}.report-units-party{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.report-units-crest{width:1.8rem;height:1.8rem;object-fit:contain}.report-units-party-text{display:flex;flex-direction:column;line-height:1.15}.report-units-party-title{font-weight:700;color:#3a2818}.report-units-party-origin{font-size:.78rem;color:#6a553a}.report-units{width:100%;border-collapse:collapse;font-size:.95rem}.report-units thead th{text-align:left;font-weight:600;color:#5a3920;font-size:.8rem;letter-spacing:.04em;border-bottom:1px solid rgba(58,42,24,.25);padding:.3rem .5rem}.report-units th.report-units-num,.report-units td.report-units-num{text-align:right;font-variant-numeric:tabular-nums}.report-units td{padding:.2rem .5rem;border-bottom:1px solid rgba(58,42,24,.12);vertical-align:middle;color:#2a1f14}.report-units td.report-units-num{font-size:1.15rem;font-weight:500}.report-units-icon{width:2.4rem;height:2.4rem;object-fit:contain;display:block}.report-units-lost{color:#b0402f}.report-units-empty{color:#6a553a;font-style:italic}.report-reveal-buildings{display:flex;gap:.75rem;margin-bottom:.6rem}.report-building-tile{display:flex;flex-direction:column;align-items:center;gap:.2rem}.report-building-img{width:3rem;height:3rem;object-fit:contain}.report-building-caption{font-size:.8rem;color:#5a3920;font-weight:600}.report-reveal-resources{display:flex;flex-wrap:wrap;gap:.9rem;margin-bottom:.5rem}.report-reveal-pair{display:inline-flex;align-items:center;gap:.3rem}.report-reveal-icon{width:1.4rem;height:1.4rem;object-fit:contain}.report-reveal-value{font-weight:600;font-variant-numeric:tabular-nums;color:#2a1f14}.report-info-line{margin:.3rem 0 0;color:#2a1f14}.report-info-label{color:#5a3920}.report-emblem-link{color:#8b3a1f;text-decoration:underline}.report-emblem-link:hover{color:#a8492a}.report-strength-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.5rem;margin:.4rem 0 .6rem}.report-resolution-note{grid-column:1 / -1;margin:0 0 .3rem;font-size:.82rem;font-style:italic;color:#6a553a}.report-collapsible-body h4.report-collapsible-h4{margin:.7rem 0 .3rem;color:#5a3920;font-size:.95rem}.city-switcher{position:relative;display:inline-block;width:235px}.city-switcher-button{width:100%;padding:.25rem .55rem;background:#f0d9b50f;border:1px solid rgba(240,217,181,.35);box-shadow:none;text-shadow:none;border-radius:4px;font-family:var(--font-body);color:#f0d9b5;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem}.city-switcher-button:hover:not(:disabled){box-shadow:none;background:#f0d9b529}.city-switcher-active{font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.city-switcher-coord{font-size:.8em;font-style:italic;font-weight:400;opacity:.8}.city-switcher-caret{color:var(--color-muted-on-dark);font-size:.85rem;flex-shrink:0}.city-switcher-list{position:absolute;top:100%;left:0;margin:2px 0 0;padding:4px 0;list-style:none;background:#fff8e8;border:1px solid rgba(58,42,24,.5);border-radius:3px;box-shadow:0 4px 12px #0000002e;min-width:220px;z-index:100}.city-switcher-option{padding:0}.city-switcher-option-button{width:100%;text-align:left;background:transparent;border:none;padding:.45rem .8rem;font-family:var(--font-body);color:#1a1a1a;cursor:pointer}.city-switcher-option-button:hover{background:#e8dfc8cc}.city-switcher-option-active .city-switcher-option-button{background:#c7a87a8c;font-weight:600}.great-ceremony-checks{list-style:none;padding:0;margin:.5rem 0 .75rem;font-family:var(--font-body);font-size:.95rem}.great-ceremony-checks li{padding:.25rem 0}.great-ceremony-checks .check-ok{color:#6cbf5a}.great-ceremony-checks .check-fail{color:#df7a52}.faith-ceremony-level-picker{display:flex;flex-direction:column;gap:.35rem;margin:.5rem 0 .75rem;font-family:var(--font-body)}.faith-ceremony-level-picker label{display:block;font-size:.95rem}.faith-ceremony-level-picker input[type=range]{width:100%}.building-modal .spirit-lodge-section{margin-top:.5rem;color:var(--bm-text);font-family:var(--font-body)}.building-modal .spirit-lodge-section h3{font-family:var(--font-family-display);font-size:var(--font-md);font-weight:700;letter-spacing:.03em;color:var(--bm-text);margin:0 0 .6rem;padding-top:.9rem;border-top:1px solid var(--bm-border)}.building-modal .spirit-lodge-section h3:first-child{padding-top:0;border-top:none}.building-modal .spirit-lodge-section .muted{color:var(--bm-text-muted)}.building-modal .wounded-pool-list{list-style:none;margin:0 0 .85rem;padding:0;display:flex;flex-wrap:wrap;gap:.5rem}.building-modal .wounded-pool-row{display:inline-flex;align-items:center;gap:.55rem;padding:.45rem .8rem;background:var(--bm-bg-soft);border:1px solid var(--bm-border);border-radius:var(--radius-md);color:var(--bm-text);font-family:var(--font-body);font-size:var(--font-sm);cursor:pointer;box-shadow:none;text-shadow:none}.building-modal .wounded-pool-row:hover:not(.selected){border-color:var(--bm-border-mid);background:var(--bm-bg-deeper)}.building-modal .wounded-pool-row.selected{border-color:var(--bm-accent);background:#8d7a5e38;color:#f0e6cf}.building-modal .wounded-name{font-weight:600}.building-modal .wounded-count{font-variant-numeric:tabular-nums;font-weight:700;color:var(--bm-accent)}.building-modal .wounded-pool-row.selected .wounded-count{color:#f0e6cf}.building-modal .heal-control{display:flex;flex-direction:column;align-items:flex-start;gap:.55rem;padding:.8rem .9rem;background:var(--bm-bg-soft);border:1px solid var(--bm-border);border-radius:var(--radius-lg);margin-bottom:.5rem}.building-modal .heal-control-row{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;color:var(--bm-text);font-size:var(--font-sm);font-weight:600}.building-modal .heal-count-input{width:5rem;padding:.35rem .5rem;background:var(--bm-bg-deeper);border:1px solid var(--bm-border-mid);border-radius:var(--radius-sm);color:var(--bm-text);font-family:var(--font-body);font-variant-numeric:tabular-nums;font-size:var(--font-sm)}.building-modal .heal-count-input:focus{outline:none;border-color:var(--bm-accent)}.building-modal .heal-preview{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;font-size:var(--font-sm);color:var(--bm-text)}.building-modal .heal-preview-label,.building-modal .heal-preview-time{color:var(--bm-text-muted)}.building-modal .heal-control .requirement-warning{color:var(--bm-bad);font-size:var(--font-sm)}.building-modal .heal-submit{margin-top:.1rem}.building-modal .heal-unit{display:inline-flex;align-items:center;gap:.35rem}.building-modal .wounded-icon,.building-modal .heal-unit-icon,.building-modal .healing-job-icon{width:1.6rem;height:1.6rem;object-fit:contain;display:inline-block;vertical-align:middle;flex-shrink:0}.building-modal .healing-job-name{display:inline-flex;align-items:center;gap:.4rem;font-weight:600}.building-modal .healing-queue-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem}.building-modal .healing-queue-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.5rem .8rem;background:var(--bm-bg-soft);border:1px solid var(--bm-border);border-radius:var(--radius-md);color:var(--bm-text);font-size:var(--font-sm)}.building-modal .healing-job-eta{color:var(--bm-accent);font-variant-numeric:tabular-nums}.settle-mode-banner{margin:.5rem 0 .85rem;padding:.65rem 1rem;background:#fff0c8e6;border:1px solid rgba(180,140,50,.65);border-radius:4px;display:flex;align-items:center;justify-content:space-between;gap:1rem;font-family:var(--font-body);color:#5a3920}.settle-mode-banner button{padding:.3rem .7rem;background:#fffaebe6;border:1px solid rgba(180,60,30,.55);border-radius:3px;color:#8b3a1f;font-family:var(--font-body);cursor:pointer}.settle-confirm{font-family:var(--font-body);font-size:.95rem;color:#1a1a1a}.settle-confirm p{margin:.5rem 0}.settle-confirm .modal-actions{margin-top:1rem;display:flex;gap:.6rem;justify-content:flex-end}.hub-container{max-width:1040px}.hub-top-bar{background:var(--color-warm-stone);border-bottom-color:var(--color-deep-forest);box-shadow:none}.hub-top-bar strong{font-family:var(--font-display);letter-spacing:.04em;color:var(--color-deep-forest);text-shadow:none}.hub-top-bar .back-link{color:var(--color-deep-forest);font-style:normal;text-shadow:none}.hub-top-bar .back-link:hover{color:var(--color-hearth-red)}.hub-grid{display:grid;grid-template-columns:1fr 1.45fr;gap:var(--space-8);padding:var(--space-6) 0 var(--space-4);align-items:start}@media(max-width:820px){.hub-grid{grid-template-columns:1fr;gap:var(--space-6)}}.hub-half{display:flex;flex-direction:column;gap:var(--space-4);min-width:0}.hub-section-title{margin:0;font-size:var(--font-lg);color:var(--color-deep-forest);letter-spacing:.04em}.worldlist-page .hub-section-title{margin:1.5rem 0 .9rem}.worldlist-page .hub-section-title:first-of-type{margin-top:.5rem}.hub-game-row{display:flex;flex-wrap:wrap;gap:var(--space-4)}.hub-game-card{display:flex;flex-direction:column;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border-mid);background:var(--color-warm-stone)}.hub-game-art{width:100%;aspect-ratio:16 / 9;background:#1a1a1a2e}.hub-game-body{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4)}.hub-game-name{margin:0;font-size:var(--font-lg);letter-spacing:.04em}.hub-game-tagline{margin:0;font-size:var(--font-sm)}.hub-game-flagship{flex:2 1 280px;background:var(--color-deep-forest);border-color:var(--color-gem-blue);box-shadow:inset 0 0 0 1px var(--color-gem-blue),var(--shadow-soft)}.hub-game-flagship .hub-game-art{background:#00000047}.hub-game-flagship .hub-game-name{color:var(--color-birch-cream)}.hub-game-flagship .hub-game-tagline{color:var(--color-text-inverse-muted)}.hub-play-button{align-self:flex-start;margin-top:var(--space-2);display:inline-block;padding:var(--space-3) var(--space-8);border-radius:var(--radius-md);background:var(--color-hearth-red);color:var(--color-birch-cream);font-family:var(--font-display);font-weight:700;font-size:var(--font-md);letter-spacing:.06em;text-decoration:none;text-transform:uppercase;transition:filter var(--transition-fast),transform var(--transition-fast)}.hub-play-button:hover{filter:brightness(1.12)}.hub-play-button:active{transform:translateY(1px)}.hub-game-disabled{flex:1 1 150px;opacity:.6;cursor:default;background:var(--color-warm-stone)}.hub-game-disabled .hub-game-name{color:var(--color-charcoal)}.hub-manual{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background:var(--color-warm-stone);border-left:3px solid var(--color-gem-blue);text-decoration:none;color:var(--color-charcoal);transition:filter var(--transition-fast)}.hub-manual:hover{filter:brightness(1.06)}.hub-manual-label{font-family:var(--font-display);font-weight:600;letter-spacing:.03em}.hub-identity{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);background:var(--color-warm-stone);border-left:3px solid var(--color-gem-blue);text-decoration:none;color:var(--color-charcoal);transition:filter var(--transition-fast)}.hub-identity:hover{filter:brightness(1.06)}.hub-avatar{flex:0 0 auto;width:56px;height:56px;display:grid;place-items:center;border-radius:var(--radius-md);background:var(--color-charcoal);color:var(--color-birch-cream);font-family:var(--font-display);font-weight:700;font-size:var(--font-xl);line-height:1}.hub-avatar-lg{width:88px;height:88px;font-size:var(--font-2xl)}.hub-identity-text{display:flex;flex-direction:column;gap:2px;min-width:0}.hub-identity-name{font-family:var(--font-display);font-weight:600;font-size:var(--font-lg);color:var(--color-charcoal)}.hub-identity-meta{font-size:var(--font-sm);color:var(--color-text-muted)}.hub-nav{display:flex;flex-direction:column;gap:var(--space-2)}.hub-nav-item{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background:var(--color-warm-stone)}.hub-nav-disabled{opacity:.6;cursor:default}.hub-nav-label{font-family:var(--font-display);font-weight:600;letter-spacing:.03em;color:var(--color-charcoal)}.hub-nav-sub{font-size:var(--font-xs);color:var(--color-text-muted)}.hub-nav-sub-ember{color:var(--color-ember);font-weight:600}.hub-tag{margin-left:auto;padding:2px var(--space-2);border-radius:var(--radius-pill);font-family:var(--font-body);font-size:var(--font-xs);font-weight:600;letter-spacing:.04em;white-space:nowrap}.hub-tag-soon{background:#1a1a1a24;color:var(--color-text-muted)}.hub-tag-scope{background:#4a90c22e;color:var(--color-gem-blue)}.hub-card-identity{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) 0}.hub-card-name{margin:0}.modal-content.modal-content--bare{width:auto;max-width:96vw;height:min(94vh,1100px);aspect-ratio:4 / 5;background:transparent;border:none;border-radius:0;box-shadow:none;display:block;overflow-y:auto}.modal-content--bare .reports-detail-card{min-height:100%;box-sizing:border-box}.modal-content--bare .report-view{max-width:100%;margin:0}.reports-detail-card{background:#e8dfc8;border:2px solid #3a2010;border-radius:6px;box-shadow:0 10px 30px #0000008c;padding:1.1rem 1.25rem}.reports-detail-card .report-view{margin:0}.modal-content.modal-content--dark{background:#2a1f17;border:1px solid #4a3a28;color:#e8dfc8}.modal-content--dark .modal-header{background:#1a120c;border-bottom:1px solid #4a3a28;box-shadow:none;color:#f5e8c8;text-shadow:none}.modal-content--dark .modal-header-title{color:#f5e8c8}.modal-content--dark button.modal-close{color:#c9b896;text-shadow:none}.modal-content--dark button.modal-close:hover:not(:disabled){color:#fff}.modal-content--dark .modal-body{color:#e8dfc8}.modal-content--dark .muted{color:#c9bd9f}.modal-content--dark button.reports-filter-btn{background:#fff5e114;border-color:#4a3a28;color:#d8cca8}.modal-content--dark button.reports-filter-btn.is-active{background:#8b5a2b;border-color:#b8862a;color:#f5e8c8}.modal-content--dark button.reports-list-button{background:#fff5e10d;border-color:#4a3a28;color:#e8dfc8}.modal-content--dark button.reports-list-button:hover:not(:disabled){background:#fff5e11f}.modal-content--dark .reports-list-type{color:#e8b96a}.modal-content--dark .reports-list-when{color:#a89a7e}.ingame-top-panel .top-bar{background:#1a120c;border-bottom:1px solid #4a3a28;box-shadow:none}.ingame-top-panel .top-bar strong{color:#f5e8c8;text-shadow:none}.ingame-top-panel .back-link{color:#d8cca8;text-shadow:none}.ingame-top-panel .back-link:hover{color:#fff}.ingame-top-panel .top-bar{padding:.25rem .1rem;margin:0 0 .35rem}.ingame-top-panel .top-bar strong{font-size:1rem;letter-spacing:.05em}.ingame-top-panel .top-bar .back-link{font-size:.82rem}.ingame-top-panel .ingame-nav{gap:.85rem}.modal-content--dark .building-modal,.modal-content--dark .upgrade-modal,.modal-content--dark .empty-slot-modal{--bm-text: #d6cdb8;--bm-text-muted: rgba(214, 205, 184, .78);--bm-bg-soft: rgba(255, 255, 255, .05);--bm-bg-deeper: rgba(0, 0, 0, .22);--bm-border: rgba(120, 95, 60, .45);--bm-border-mid: rgba(120, 95, 60, .6);--bm-accent: #e0b257;--bm-bad: #d98c5c}.modal-content--dark .upgrade-level{color:#e0b257}.modal-content--dark .upgrade-description{color:#d6cdb8;background:#ffffff0d}.modal-content--dark .upgrade-spec dt{color:#d6cdb8c7}.modal-content--dark .upgrade-spec dd{color:#d6cdb8}.modal-content--dark .buildable-row{background:#ffffff0d}.modal-content--dark .buildable-desc{color:#d6cdb8}.modal-content--dark .training-stats-name,.modal-content--dark .training-stats-name strong,.modal-content--dark .buildable-name strong{color:#e0b257}.modal-content--dark .building-modal .upgrade-description,.modal-content--dark .building-modal .buildable-desc,.modal-content--dark .building-modal p,.modal-content--dark .building-modal dd,.modal-content--dark .building-modal dt,.modal-content--dark .building-modal .training-stats-grid,.modal-content--dark .building-modal .upgrade-spec{color:var(--bm-text)}.modal-content--dark .training-stats-name,.modal-content--dark .training-stats-name strong{color:#e0b257}.modal-content--dark .dev-mode-toggle{color:#e7c08a;background:#e85a1c29}.wt-overview{display:flex;flex-direction:column;gap:8px}.modal-content--dark .wt-overview{--bm-text: #d6cdb8;--bm-text-muted: rgba(214, 205, 184, .78);--bm-bg-soft: rgba(255, 255, 255, .05);--bm-bg-deeper: rgba(0, 0, 0, .22);--bm-border: rgba(120, 95, 60, .45);--bm-border-mid: rgba(120, 95, 60, .6);--bm-accent: #e0b257;--bm-bad: #d98c5c}.wt-overview-title{margin:0 0 4px;font-family:var(--font-display);font-size:15px;letter-spacing:.05em;text-transform:uppercase;color:var(--bm-accent, #8a5a18)}.wt-modal-header{display:flex;align-items:center;gap:14px;padding:8px 10px;margin-bottom:10px;border:1px solid rgba(120,95,60,.45);border-radius:6px;background:#0000002e}.wt-modal-portrait{width:72px;height:72px;object-fit:contain}.wt-modal-name{font-family:var(--font-display);font-size:1.15rem;font-weight:700;color:#e0b257}.wt-modal-level{font-size:.9rem;color:#d6cdb8d9}.wt-modal-upgrade{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;gap:3px;font-size:.85rem}.wt-modal-upgrade-levels{font-weight:700;color:#e0b257}.wt-modal-upgrade-row{display:flex;align-items:baseline;gap:6px}.wt-modal-upgrade-max{font-family:var(--font-display);font-weight:700;font-size:1rem;letter-spacing:.08em;color:#e0b257;align-self:center}.wt-overview-tabs{display:flex;gap:6px;margin-bottom:12px}.wt-overview-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:7px 8px;font-family:inherit;font-size:14px;color:var(--bm-text, #2b2317);background:var(--bm-bg-soft, rgba(0, 0, 0, .05));border:1px solid var(--bm-border, rgba(120, 95, 60, .45));border-radius:6px;cursor:pointer}.wt-overview-tab-active{color:var(--bm-accent, #8a5a18);border-color:var(--bm-accent, #8a5a18);background:var(--bm-bg-deeper, rgba(0, 0, 0, .08));font-weight:700}.wt-overview-tab-count{font-size:12px;padding:1px 7px;border-radius:9px;background:var(--bm-bg-deeper, rgba(0, 0, 0, .12));border:1px solid var(--bm-border, rgba(120, 95, 60, .45))}.wt-overview-body{display:flex;flex-direction:column;gap:8px}.wt-overview-subtitle{margin:8px 0 2px;font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--bm-text-muted, rgba(43, 35, 23, .7))}.wt-overview-subtitle-hostile{color:#c0392b}.wt-overview-subtitle-friendly{color:#4a7a4a}.wt-overview-card{padding:8px 10px;border:1px solid var(--bm-border, rgba(120, 95, 60, .45));border-radius:6px;background:var(--bm-bg-soft, rgba(0, 0, 0, .04))}.wt-overview-card-hostile{border-left:3px solid #c0392b}.wt-overview-card-friendly{border-left:3px solid #4a7a4a}.wt-overview-card-title{font-weight:700;font-size:14px;margin-bottom:2px}.wt-overview-group{margin-top:6px;padding-top:6px;border-top:1px dashed var(--bm-border, rgba(120, 95, 60, .45))}.wt-overview-group-label{font-size:13px;font-weight:600}.wt-overview-meta{font-size:12.5px}.wt-overview-group-actions{margin-top:5px}.wt-overview-withdraw{padding:.18rem .6rem;font-size:.78rem;background:linear-gradient(180deg,#e6b54a,#c8902e);border:1px solid #f0c85a;border-radius:3px;color:#1a120c;font-family:var(--font-display);font-weight:700;letter-spacing:.01em;cursor:pointer}.wt-overview-withdraw:hover{border-color:#ffe9a0;filter:brightness(1.07)}.wt-overview-units{list-style:none;display:flex;flex-direction:column;gap:4px;margin:4px 0;padding:0}.wt-overview-unit{display:flex;align-items:center;gap:4px}.wt-overview-unit-icon{width:26px;height:26px;object-fit:contain}.wt-overview-unit-count{font-size:13px;font-weight:600}.mission-book{display:flex;flex-direction:column;gap:10px}.mission-book-tabs{display:flex;gap:6px}.mission-book-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:7px 8px;font-family:inherit;font-size:14px;border:1px solid rgba(120,95,60,.45);border-radius:6px;background:#0000000d;cursor:pointer}.mission-book-tab-active{font-weight:700;border-color:#8a5a18;color:#8a5a18;background:#00000014}.mission-book-tab.has-claimable{box-shadow:0 0 0 2px #60964673}.mission-book-tab-count{font-size:12px;padding:1px 7px;border-radius:9px;border:1px solid rgba(120,95,60,.45)}.mission-book-section-title{margin:8px 0 4px;font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:#2b2317b3}.mission-book-card{padding:10px 12px;border:1px solid rgba(120,95,60,.45);border-radius:6px;background:#0000000a}.mission-book-card--completed_unclaimed{border-color:#609646b3}.mission-book-card--locked{opacity:.65}.mission-book-card-head{display:flex;align-items:center;gap:8px}.mission-book-icon{width:28px;height:28px;object-fit:contain}.mission-book-card-title{font-weight:700;font-size:15px}.mission-book-progress{margin-left:auto;font-weight:700;color:#8a5a18}.mission-book-card-body{margin:6px 0;font-size:13.5px;line-height:1.4}.mission-book-locked-note{margin:4px 0;font-size:12.5px}.mission-book-card-foot{display:flex;align-items:center;justify-content:space-between;gap:10px}.mission-book-upcoming{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.mission-book-upcoming-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px dashed rgba(120,95,60,.45);border-radius:6px;opacity:.7}.mission-book-done-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:3px;font-size:13px}.mission-book-track-done{font-size:13.5px}.reinforce-picker{display:flex;flex-direction:column;gap:10px}.reinforce-picker-intro{margin:0;font-size:13.5px}.reinforce-picker-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.reinforce-picker-row{width:100%;text-align:left;display:flex;flex-direction:column;gap:6px;padding:10px 12px;font-family:inherit;font-size:14px;border:1px solid rgba(120,95,60,.45);border-radius:6px;background:#0000000a;cursor:pointer}.reinforce-picker-row-selected{border-color:#8a5a18;box-shadow:0 0 0 2px #8a5a1859}.reinforce-picker-head{display:flex;align-items:baseline;gap:10px}.reinforce-picker-name{font-weight:700}.reinforce-picker-coord{color:#2b2317b3}.reinforce-picker-distance{margin-left:auto;font-weight:700;color:#8a5a18}.reinforce-picker-units{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:3px}.reinforce-picker-unit{display:flex;align-items:center;gap:5px}.reinforce-picker-unit-icon{width:22px;height:22px;object-fit:contain}.reinforce-picker-empty{font-size:12.5px}.reinforce-picker-actions{display:flex;justify-content:flex-end}.send-march-origin{display:flex;align-items:baseline;gap:8px;margin:0 0 4px}.send-march-change-origin{font-family:inherit;font-size:12.5px;padding:2px 8px;border:1px solid rgba(120,95,60,.45);border-radius:5px;background:#0000000d;cursor:pointer}.modal-content--dark .send-march-type-btn{color:#e8dfc8;background:#ffffff0f;border-color:#4a3a28}.modal-content--dark .send-march-type-btn.active{background:#8b5a2b;border-color:#b8862a;color:#f5e8c8}.modal-content--dark .send-march-target-coord{color:#e0b257}.modal-content--dark .send-march-unit-row{background:#ffffff0d;border-color:#4a3a28}.modal-content--dark .send-march-unit-input{background:#00000040;border-color:#4a3a28;color:#e8dfc8}.modal-content--dark .send-march-unit-slider{accent-color:#c8902e}.modal-content--dark .send-march-unit-max{background:#00000040;border-color:#4a3a28;color:var(--color-muted-on-dark)}.modal-content--dark .send-march-unit-max:hover:not(:disabled){background:#c8902e;color:#1a120c}.modal-content--dark .send-march-preview{background:#00000038;border-color:#4a3a28}.modal-content--dark .send-march-unit-available,.modal-content--dark .send-march-preview-label,.modal-content--dark .send-march-preview-detail{color:#c9bd9f}.modal-content--dark label,.modal-content--dark .settle-confirm{color:#e8dfc8}button.modal-upgrade-button--reserve{background:#3a7d44;border-color:#2f6638;color:#fff}button.modal-upgrade-button--reserve:hover:not(:disabled){background:#45914f}.tribe-bg-layer{position:fixed;inset:0;z-index:-1;background-position:center;background-size:cover;background-repeat:no-repeat;background-attachment:fixed;pointer-events:none}.ingame-content .container{background:#1e160ea6;border-color:#785f3c8c;box-shadow:0 0 0 1px #0f0803d9,0 0 0 4px #46321a8c,0 18px 44px #000000b3}.ingame-content h2{color:#d8cca8;border-bottom-color:#966e3c66}.ingame-content .section-toggle{color:#d8cca8}.ingame-content .section-toggle:hover{color:#f4ead2}.ingame-content .city-column-fields h2{color:#d9a441}.ingame-content .city-cell-training h2{color:#9fb06a}.ingame-content .buildings-section h2{color:#c9a37a}.ingame-content button.field-slot,.ingame-content button.building-slot{background:#2a2018;border:1px solid #4a3a28}.ingame-content .building-slot.empty{background:#ffffff08;border:1px solid rgba(120,95,60,.4)}.ingame-content .marches-banner{background:#2b2014;border-color:#b48c3c66}.ingame-content .marches-banner-heading{color:#e0b257}.ingame-content .marches-banner-row{background:#ffffff0d;border-color:#4a3a28}.ingame-content .marches-banner-direction,.ingame-content .marches-banner-countdown strong{color:#e8dfc8}.ingame-content .marches-banner-countdown,.ingame-content .marches-banner-units{color:#a89a7e}.build-queue-strip{background:#15110d;border-top-color:#4a3a28}.build-queue-strip-title{color:var(--color-muted-on-dark)}.build-queue-strip .build-queue-cell{background:#ffffff0d}.build-queue-strip .build-queue-cell--empty,.build-queue-strip .build-queue-slot0-empty{background:#ffffff05}.build-queue-strip .build-queue-cell-eta .countdown-in{color:#d8cca8}.build-queue-strip .build-queue-cell-eta .countdown-at{color:#a89a7e}.build-queue-strip .slot-empty-plus{color:#d8cca866}.modal-content--dark .training-stats-grid{color:#e8dfc8}.modal-content--dark .training-stat-label{color:#b3a489;opacity:1}.modal-content--dark .training-stat-value,.modal-content--dark .training-stats-name,.modal-content--dark .training-stats-name strong{color:#e8dfc8}.modal-content--dark .training-stats-name-lvl{color:#e8dfc88c}.modal-content--dark .training-row.focused .training-stats-name,.modal-content--dark .training-row.focused .training-stats-name strong{color:#e7c873}.modal-content--dark .training-row.focused .training-stat-value{color:#e0b257}.modal-content--dark .armory-stat-label,.modal-content--dark .armory-stat-before,.modal-content--dark .armory-stat-arrow,.modal-content--dark .armory-group-header,.modal-content--dark .armory-row-cost em,.modal-content--dark .armory-stat-note{color:#b3a489}.modal-content--dark .armory-row-cost{color:#e8dfc8}.modal-content--dark .armory-stat-after{color:#e0b257}.modal-content--dark .building-modal .building-section,.modal-content--dark .building-section{background:#ffffff0a;border-color:#785f3c66}.modal-content--dark .building-modal .building-section-header,.modal-content--dark .building-section-header{color:#e0b257;border-bottom-color:#785f3c66}.modal-content--dark .building-modal .building-section-hint,.modal-content--dark .building-section-hint{color:#b3a489}.modal-content--dark .training-row{background:#ffffff0d;border-color:#785f3c66}.modal-content--dark .training-row:hover:not(.focused){background:#ffffff1a}.modal-content--dark .training-row.focused{background:#e0b25729;border-color:#e0b257;box-shadow:0 0 0 1px #e0b2574d}.modal-content--dark .armory-row,.modal-content--dark .building-modal .armory-row{background:#ffffff0d;border-color:#785f3c66}.modal-content--dark .training-row.focused .training-stats-name-lvl{color:#e8dfc88c}.panel-goal-pin{display:flex;flex-direction:column;gap:2px;padding:.3rem .6rem;border-radius:4px;background:linear-gradient(180deg,#3a2e22,#2a2018);border:1px solid #5a4632;color:#f0d9b5;max-width:200px;cursor:default}.panel-goal-pin-name{font-family:var(--font-display);font-weight:700;font-size:.68rem;letter-spacing:.05em;text-transform:uppercase;color:var(--color-muted-on-dark)}.panel-goal-pin-trackers{display:flex;flex-wrap:wrap;gap:.4rem;font-size:var(--font-xs);color:var(--color-text-inverse-muted)}.panel-goal-pin-trackers .num{white-space:nowrap}.first-steps-intro{margin:0 0 var(--space-3);color:var(--color-text-inverse-muted);font-size:var(--font-sm)}.first-steps-error{margin:0 0 var(--space-3)}.first-steps-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.first-steps-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);background:#ffffff0d;border:1px solid rgba(120,95,60,.4)}.first-steps-item--active{border-color:var(--color-gold)}.first-steps-item--completed_unclaimed{border-color:var(--color-gold);background:#e0b2571a}.first-steps-item--claimed,.first-steps-item--upcoming{opacity:.65}.first-steps-item-marker{flex:0 0 auto;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid var(--color-border-mid);background:var(--color-bg-panel-deep);color:var(--color-text-inverse);font-size:var(--font-xs)}.first-steps-item--claimed .first-steps-item-marker,.first-steps-item--completed_unclaimed .first-steps-item-marker{border-color:var(--color-gold);color:var(--color-gold)}.first-steps-item-main{display:flex;flex-direction:column;gap:3px;flex:1 1 auto;min-width:0}.first-steps-item-title{font-family:var(--font-display);font-weight:600;font-size:var(--font-sm)}.first-steps-item-body{font-size:var(--font-xs);color:var(--color-text-inverse-muted)}.first-steps-reward{display:inline-flex;align-items:center;gap:var(--space-2);margin-top:3px;font-size:var(--font-xs)}.first-steps-reward-label{color:var(--color-text-inverse-muted)}.first-steps-reward-part{display:inline-flex;align-items:center;gap:3px}.first-steps-reward-icon{width:14px;height:14px;object-fit:contain}.first-steps-item-side{flex:0 0 auto;display:flex;align-items:center}.first-steps-claim-button{font-family:var(--font-display);font-size:var(--font-xs);font-weight:600;letter-spacing:.03em;padding:5px 14px;border-radius:var(--radius-sm);border:1px solid var(--color-gold);background:#b8922f2e;color:#e0b257;cursor:pointer;transition:background var(--transition-fast)}.first-steps-claim-button:hover:not(:disabled){background:#b8922f52}.first-steps-claim-button:disabled{opacity:.6;cursor:default}.first-steps-state{font-size:var(--font-xs);white-space:nowrap}.first-steps-state--claimed{color:var(--color-text-inverse-muted)}.first-steps-state--active{color:#e0b257}.first-steps-state--upcoming{color:var(--color-text-inverse-muted)}.roster-intro{max-width:78ch;margin:0 0 var(--space-4);color:#3d2e1a}.roster-filters{display:flex;flex-wrap:wrap;gap:var(--space-4) var(--space-6);padding:var(--space-4);margin-bottom:var(--space-4);background:#241c12;border:1px solid var(--color-border-mid);border-radius:var(--radius-lg)}.roster-filter-group{display:flex;flex-direction:column;gap:var(--space-2);min-width:0}.roster-filter-head{display:flex;align-items:baseline;gap:var(--space-2)}.roster-filter-label{font-family:var(--font-display);font-size:var(--font-xs);letter-spacing:.08em;text-transform:uppercase;color:#d8cfb6}.roster-filter-actions{display:inline-flex;align-items:baseline;gap:var(--space-1);color:#cdbf9f;font-size:var(--font-xs)}.roster-link-btn{background:none;border:none;padding:0;cursor:pointer;color:#7fc0ee;font-size:var(--font-xs);font-family:var(--font-body)}.roster-link-btn:hover{text-decoration:underline}.roster-chips{display:flex;flex-wrap:wrap;gap:var(--space-1) var(--space-2)}.roster-chip{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--radius-pill);border:1px solid var(--color-border-mid);background:#2e2418;color:#cdbf9f;font-size:var(--font-sm);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.roster-chip input{margin:0;cursor:pointer}.roster-chip--on{background:#4a90c247;border-color:#7fc0ee;color:#eaf3fb}.roster-search{padding:6px 10px;border-radius:var(--radius-md);border:1px solid var(--color-border-mid);background:#1b140c;color:#f2ead4;font-size:var(--font-sm);min-width:160px}.roster-search::placeholder{color:#d6cdb88c}.roster-meta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-2);color:#d8cfb6;font-size:var(--font-sm)}.roster-count strong{color:#f5eedb}.roster-legend{display:inline-flex;align-items:center;gap:6px;font-size:var(--font-xs)}.roster-legend em{color:var(--color-gem-blue);font-style:italic}.roster-legend-swatch{display:inline-block;width:12px;height:12px;border-radius:3px;background:#4a90c22e;border:1px solid var(--color-gem-blue)}.roster-table-wrap{max-height:calc(100vh - 320px);overflow:auto;border:1px solid var(--color-border-mid);border-radius:var(--radius-lg);background:#1b140c}.roster-table{border-collapse:separate;border-spacing:0;width:100%;font-size:var(--font-sm);color:#f2ead4;font-variant-numeric:tabular-nums}.roster-table thead th{position:sticky;top:0;z-index:2;background:#322615;border-bottom:2px solid var(--color-warm-stone);padding:0}.roster-th-btn{display:flex;align-items:center;gap:4px;width:100%;padding:8px 10px;background:none;border:none;cursor:pointer;color:#f4ecd8;font-family:var(--font-display);font-size:var(--font-xs);letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.roster-th--num .roster-th-btn{justify-content:flex-end}.roster-th-btn:hover{color:#fff;background:#ffffff12}.roster-th-arrow{opacity:.4;font-size:10px}.roster-th-arrow--active{opacity:1;color:#7fc0ee}.roster-th--derived{background:#1c2a38}.roster-th--derived .roster-th-btn{color:#bcdcf4;font-style:italic}.roster-table tbody td{padding:6px 10px;border-bottom:1px solid rgba(120,105,85,.22);white-space:nowrap;color:#ede3c9;background:#221a10}.roster-table tbody tr:nth-child(2n) td{background:#2c2317}.roster-th--num,.roster-td--num{text-align:right}.roster-td--num{font-variant-numeric:tabular-nums}.roster-th--text,.roster-td--text{text-align:left}.roster-td--name{font-weight:600;color:#fbf4e0}.roster-table tbody td.roster-td--derived{background:#1e2b39;color:#d8ecfc;font-style:italic}.roster-table tbody tr:nth-child(2n) td.roster-td--derived{background:#233241}.roster-table tbody tr:hover td{background:#3a2c19}.roster-table tbody tr:hover td.roster-td--derived{background:#2c4054}.roster-empty{text-align:center;padding:var(--space-8);color:var(--color-text-inverse-muted);font-style:italic}.roster-formula-legend{margin-top:var(--space-3);font-size:var(--font-xs);color:#d8cfb6;line-height:1.7}.roster-formula-legend strong{color:#f2ead4}.roster-formula-name{color:#bcdcf4;font-style:italic}.roster-tabs{display:inline-flex;gap:4px;margin-bottom:var(--space-4);padding:4px;background:#241c12;border:1px solid var(--color-border-mid);border-radius:var(--radius-pill)}.roster-tab{appearance:none;border:none;background:none;cursor:pointer;padding:6px 20px;border-radius:var(--radius-pill);font-family:var(--font-display);font-size:var(--font-sm);letter-spacing:.04em;color:#cdbf9f;transition:background var(--transition-fast),color var(--transition-fast)}.roster-tab:hover{color:#f2ead4}.roster-tab--on{background:var(--color-ochre);color:#fff}.roster-analysis{display:flex;flex-direction:column;gap:var(--space-4)}.roster-analysis-controls{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2) var(--space-3);padding:var(--space-3) var(--space-4);background:#241c12;border:1px solid var(--color-border-mid);border-radius:var(--radius-lg)}.roster-analysis-label{font-family:var(--font-display);font-size:var(--font-xs);letter-spacing:.08em;text-transform:uppercase;color:#d8cfb6}.roster-analysis-select{padding:6px 10px;border-radius:var(--radius-md);border:1px solid var(--color-border-mid);background:#1b140c;color:#f2ead4;font-size:var(--font-sm);min-width:210px}.roster-analysis-select option{background:#241c12;color:#f2ead4}.roster-analysis-note{font-size:var(--font-xs);color:#cdbf9f}.roster-analysis-empty{padding:var(--space-8);text-align:center;color:var(--color-text-inverse-muted);font-style:italic;background:#1b140c;border:1px solid var(--color-border);border-radius:var(--radius-lg)}.roster-charts{display:flex;flex-direction:column;gap:var(--space-6)}.roster-chart{background:#1b140c;border:1px solid var(--color-border-mid);border-radius:var(--radius-lg);overflow:hidden}.roster-chart-head{display:flex;align-items:baseline;flex-wrap:wrap;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:#322615;border-bottom:2px solid var(--color-warm-stone)}.roster-chart-title{font-family:var(--font-display);font-size:var(--font-md);letter-spacing:.03em;color:#f4ecd8}.roster-chart-hint{font-size:var(--font-xs);color:#cdbf9f}.roster-chart-body{display:flex;flex-direction:column;gap:3px;padding:var(--space-3) var(--space-4)}.roster-bar-row{display:grid;grid-template-columns:210px 1fr 56px;align-items:center;gap:var(--space-3)}.roster-bar-label{display:flex;align-items:center;justify-content:flex-start;gap:6px;min-width:0;font-size:var(--font-sm);color:#ede3c9}.roster-bar-label .roster-emblem,.roster-bar-label .roster-unit-icon{width:28px;height:28px;flex-shrink:0}.roster-bar-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.roster-bar-track{display:block;height:18px;background:#7869552e;border-radius:3px;overflow:hidden}.roster-bar-fill{display:block;height:100%;min-width:2px;border-radius:3px;background:linear-gradient(90deg,var(--color-bronze),var(--color-ochre))}.roster-bar-value{font-size:var(--font-sm);font-variant-numeric:tabular-nums;color:#f2ead4;text-align:right}.roster-emblem{width:30px;height:30px;object-fit:contain;display:block}.roster-unit-icon{width:34px;height:34px;object-fit:contain;border-radius:3px;flex-shrink:0}.roster-td--tribe{padding-top:2px;padding-bottom:2px}.roster-unit-id{display:inline-flex;align-items:center;gap:8px;min-width:0}.roster-unit-name{white-space:nowrap}.alliance-view{display:flex;flex-direction:column;gap:var(--space-3)}.alliance-lead{margin:0;font-family:var(--font-display);font-size:var(--font-md)}.alliance-hint{margin:0;font-size:var(--font-sm)}.alliance-field{display:flex;flex-direction:column;gap:var(--space-1)}.alliance-field-label{font-family:var(--font-display);font-size:var(--font-sm);letter-spacing:.02em}.alliance-input{padding:var(--space-2) var(--space-3);border:1px solid var(--color-bronze);border-radius:3px;background:#00000040;color:var(--color-text-inverse);font-family:var(--font-body);font-size:var(--font-md)}.alliance-input--tag{max-width:9rem;text-transform:uppercase;letter-spacing:.08em}.alliance-actions{display:flex;gap:var(--space-2);margin-top:var(--space-1)}.alliance-error{margin:0;color:var(--color-error);font-size:var(--font-sm)}.alliance-header{display:flex;align-items:baseline;gap:var(--space-2);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-bronze)}.alliance-name{font-family:var(--font-display);font-size:var(--font-lg);font-weight:700}.alliance-tag{font-family:var(--font-numeric);font-size:var(--font-md);color:var(--color-gold)}.alliance-banner{margin:0;padding:var(--space-2) var(--space-3);border-radius:3px;background:#00000040;font-size:var(--font-sm)}.alliance-banner--warn{border-left:3px solid var(--color-ember)}.alliance-count{margin:0;font-family:var(--font-numeric);font-size:var(--font-sm)}.alliance-roster{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-1)}.alliance-roster-row{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:3px;background:#0003}.alliance-roster-main{display:flex;align-items:center;gap:var(--space-3)}.alliance-roster-alias{flex:1 1 auto;min-width:0;font-family:var(--font-display);font-size:var(--font-md)}.alliance-you{color:var(--color-gold);font-size:var(--font-sm)}.alliance-roster-rank{flex:0 0 auto;font-size:var(--font-sm);color:var(--color-text-inverse);opacity:.85}.alliance-roster-markers{flex:0 0 auto;display:flex;gap:var(--space-1)}.alliance-marker{font-family:var(--font-display);font-size:var(--font-xs);letter-spacing:.03em;padding:1px 6px;border-radius:3px}.alliance-marker--owner{background:var(--color-gold);color:var(--color-charcoal)}.alliance-marker--vault{border:1px solid var(--color-bronze);color:var(--color-text-inverse)}.alliance-self{margin-top:var(--space-2)}.alliance-leaving{display:flex;flex-direction:column;gap:var(--space-2)}.alliance-section-title{margin:0 0 var(--space-1);font-family:var(--font-display);font-size:var(--font-sm);letter-spacing:.03em;text-transform:uppercase;opacity:.85}.alliance-ok{margin:0;color:var(--color-gold);font-size:var(--font-sm)}.alliance-invites{display:flex;flex-direction:column;gap:var(--space-1);padding-bottom:var(--space-2);margin-bottom:var(--space-1);border-bottom:1px solid var(--color-bronze)}.alliance-invite-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-1)}.alliance-invite-row{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:3px;background:#0003}.alliance-invite-text{font-size:var(--font-sm)}.alliance-invite-actions{display:flex;gap:var(--space-2)}.alliance-leadership{display:flex;flex-direction:column;gap:var(--space-1);padding-top:var(--space-2);margin-top:var(--space-1);border-top:1px solid var(--color-bronze)}.alliance-invite-form{display:flex;gap:var(--space-2);align-items:stretch}.alliance-invite-form .alliance-input{flex:1 1 auto;min-width:0}.alliance-roster-controls{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.alliance-rank-control{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--font-sm)}.alliance-rank-select{padding:var(--space-1) var(--space-2);border:1px solid var(--color-bronze);border-radius:3px;background:#00000040;color:var(--color-text-inverse);font-family:var(--font-body);font-size:var(--font-sm)}.alliance-rank-select option{color:#f2ead4;background:#241c12}.alliance-transfer-banner,.alliance-dissolving{display:flex;flex-direction:column;gap:var(--space-2)}.alliance-owner-actions{display:flex;gap:var(--space-2);padding-top:var(--space-2);margin-top:var(--space-1);border-top:1px solid var(--color-bronze)}.alliance-danger{border-color:var(--color-error);color:var(--color-error)}
