@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=IM+Fell+English:ital@0;1&display=swap";:root{--parchment-light: #e2d6b8;--parchment: #d4c4a0;--parchment-dark: #c4b48a;--parchment-darker: #b09f72;--font-parchment: "IM Fell English", Georgia, serif;--ink: #3d2914;--ink-light: #5a4230;--ink-faded: #8b7355;--gold: #c9a227;--gold-light: #ddb83d;--gold-dark: #a07d1c;--shadow: rgba(61, 41, 20, .3);--font-size-base: clamp(.8125rem, 1.5vw + .65rem, 1rem);--font-size-sm: clamp(.75rem, 1.2vw + .55rem, .875rem);--font-size-lg: clamp(.9rem, 1.8vw + .6rem, 1.1rem);--space-touch: clamp(.5rem, 2vmin, .75rem)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:IM Fell English,Georgia,serif;background:var(--parchment);color:var(--ink);min-height:100vh;min-height:100dvh;cursor:url(/assets/cursor/ring_cursor.svg) 16 16,auto}h1,h2,h3,h4,h5,h6{font-family:Cinzel,serif}button{font-family:Cinzel,serif;font-size:clamp(.8rem,1.2vw + .6rem,.9rem);padding:var(--space-touch) clamp(.75rem,2vw,1rem);background:linear-gradient(180deg,var(--parchment) 0%,var(--parchment-dark) 100%);border:2px solid var(--ink-faded);border-radius:3px;color:var(--ink);cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.05em}button,a[href],[role=button]:not(.unit-token):not(.all-stacks-drag-btn),[role=tab],[role=menuitem],[tabindex]:not([tabindex="-1"]):not(.all-stacks-drag-btn):not(.unit-token),input[type=button],input[type=submit],input[type=checkbox],input[type=radio],input[type=range],summary,[class*=btn]:not(.all-stacks-drag-btn),[class*=button],[style*="cursor:pointer"],[style*="cursor: pointer"],[data-sfx-click=true]{cursor:url(/assets/cursor/sting_pointer.svg) 4 4,pointer!important}button:hover:not(:disabled){background:linear-gradient(180deg,var(--parchment-dark) 0%,var(--parchment) 100%);border-color:var(--ink);box-shadow:2px 2px 5px var(--shadow)}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:linear-gradient(180deg,var(--gold) 0%,var(--gold-dark) 100%);border-color:var(--gold-dark)}button.primary:hover:not(:disabled){background:linear-gradient(180deg,var(--gold-dark) 0%,var(--gold) 100%)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--parchment-dark)}::-webkit-scrollbar-thumb{background:var(--ink-faded);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--ink-light)}@media(max-width:767px){.modal-overlay{padding:max(.35rem,env(safe-area-inset-top,0px)) max(.35rem,env(safe-area-inset-right,0px)) max(.35rem,env(safe-area-inset-bottom,0px)) max(.35rem,env(safe-area-inset-left,0px));align-items:center;justify-content:center;box-sizing:border-box}.modal.stats-modal,.modal.specials-modal,.modal.unit-stats-modal,.modal.help-modal,.modal.purchase-modal,.modal.lobby-modal,.modal.combat-modal{min-width:0!important;width:100%!important;max-width:100%!important;max-height:min(92dvh,92vh)!important;border-radius:8px}.stats-modal-body,.specials-modal-body,.unit-stats-modal-body,.help-modal-body{max-height:min(55dvh,420px)!important}}.stronghold-alliance-bar{display:flex;flex-direction:column;align-items:center;gap:.1rem;width:100%}.stronghold-alliance-bar--header{gap:.1rem}.stronghold-alliance-bar--game-list{gap:.15rem}.stronghold-alliance-bar__track{position:relative;width:100%;align-self:stretch}.stronghold-alliance-bar__segments{display:flex;width:100%;border-radius:3px;overflow:hidden;border:1px solid var(--ink-faded);background:var(--parchment-dark)}.stronghold-alliance-bar--header .stronghold-alliance-bar__segments{height:clamp(.68rem,1.1vw,.88rem)}.stronghold-alliance-bar--game-list .stronghold-alliance-bar__segments{height:.55rem;background:var(--parchment-dark, #e8e0d0)}.stronghold-alliance-bar__good{background:#f5f5f0;min-width:0}.stronghold-alliance-bar__neutral{background:#888;min-width:0}.stronghold-alliance-bar__evil{background:#2a2a2a;min-width:0}.stronghold-alliance-bar__marker{position:absolute;top:0;bottom:0;width:1px;transform:translate(-50%);pointer-events:none;z-index:2;border-radius:.5px}.stronghold-alliance-bar__marker--evil-threshold{background:#111;box-shadow:0 0 0 1px #ffffff59}.stronghold-alliance-bar__marker--good-threshold{background:#f0f0f0;box-shadow:0 0 0 1px #00000073}.stronghold-alliance-bar__label{font-family:var(--font-parchment);color:var(--ink-faded);white-space:nowrap;line-height:1.1}.stronghold-alliance-bar--header .stronghold-alliance-bar__label{font-size:clamp(.5rem,.65vw + .35rem,.58rem)}.stronghold-alliance-bar--game-list .stronghold-alliance-bar__label{font-size:.65rem}.header{--header-faction-accent: var(--ink-faded);position:relative;display:flex;align-items:center;justify-content:space-between;flex-wrap:nowrap;min-width:0;padding:clamp(.45rem,.85vw,.72rem) clamp(.45rem,1.15vw,1.05rem);background-color:var(--parchment);background-image:linear-gradient(180deg,rgba(255,255,255,.06) 0%,transparent 50%,rgba(0,0,0,.04) 100%),url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");border-bottom:2px solid var(--ink-faded);box-shadow:0 2px 8px var(--shadow);z-index:100;gap:clamp(.22rem,.55vw,.55rem)}.header.header--faction-turn{border-bottom:4px solid var(--header-faction-accent);box-shadow:0 2px 8px var(--shadow)}.header-center-title{flex:1 1 120px;min-width:min(9.5rem,28vw);display:flex;flex-direction:column;justify-content:center;gap:.08rem;margin-left:clamp(.12rem,.65vw,.32rem);pointer-events:none;max-width:min(46rem,calc(26vw + 14rem))}.header-center-title-brand{font-family:Cinzel,serif;font-size:clamp(.78rem,.85vw + .5rem,1.2rem);font-weight:700;color:var(--ink);letter-spacing:.03em;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-center-title-subrow{display:flex;align-items:baseline;gap:.35rem;min-width:0;line-height:1.2}.header-center-title-setup{flex:0 1 auto;min-width:0;font-family:var(--font-parchment);font-size:clamp(.72rem,.55vw + .58rem,.95rem);color:var(--ink-light);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-center-title-subsep{flex:0 0 auto;color:var(--ink-faded);font-size:clamp(.65rem,.5vw + .52rem,.85rem);-webkit-user-select:none;user-select:none}.header-center-title-game{flex:1 1 auto;min-width:0;font-family:var(--font-parchment);font-size:clamp(.72rem,.55vw + .58rem,.95rem);color:var(--ink-light);font-style:italic;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(min-width:1600px){.header-center-title{max-width:min(52rem,calc(22vw + 18rem));min-width:10rem}}@media(min-width:1900px){.header-center-title{max-width:min(56rem,calc(20vw + 22rem))}}@media(max-width:1320px){.header-spacer{display:none}}.header-stats-btn{margin-right:.12rem}.header-stronghold-bar-wrap{margin-left:clamp(.15rem,.75vw,.48rem);margin-right:clamp(.15rem,.75vw,.48rem)}.header-turn-ticker{margin-left:clamp(.12rem,.65vw,.38rem)}.faction-header{margin-left:clamp(.2rem,.85vw,.55rem)}.turn-status{margin-left:clamp(.18rem,.8vw,.52rem);flex-shrink:1;min-width:0}.header-menu-btn{flex:0 0 auto;display:flex;align-items:center;justify-content:center;padding:0 clamp(.45rem,1.2vw,.6rem);height:clamp(34px,4.2vw,40px);font-family:var(--font-parchment);font-size:.9rem;background:var(--parchment-dark);border:2px solid var(--ink-faded);border-radius:4px;color:var(--ink);text-decoration:none;cursor:pointer}.header-menu-btn:hover{border-color:var(--ink);background:var(--parchment)}.header-help-btn,.header-combat-sim-btn{flex:0 0 auto;width:clamp(34px,4.2vw,40px);height:clamp(34px,4.2vw,40px);padding:0;display:flex;align-items:center;justify-content:center;background:var(--parchment-dark);border:2px solid var(--ink-faded);border-radius:4px;color:var(--ink);cursor:pointer;font-family:var(--font-parchment);font-size:.75rem;text-transform:none;letter-spacing:normal;line-height:1}.header-help-btn:hover,.header-combat-sim-btn:hover{border-color:var(--ink);background:var(--parchment);box-shadow:0 1px 4px var(--shadow)}.header-help-icon{width:clamp(24px,3.2vw,30px);height:clamp(24px,3.2vw,30px);flex-shrink:0;display:block}.header-help-icon path{stroke-width:2.6px}.header-combat-sim-icon-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center;line-height:0;min-width:22px;min-height:20px}.header-combat-sim-emoji{font-size:17px;line-height:1;display:block}.header-combat-sim-die{position:absolute;right:-4px;bottom:-3px;width:11px;height:11px;flex-shrink:0;display:block;pointer-events:none}.header-combat-sim-die rect{fill:#3d2a1f;stroke:#2a1a12;stroke-width:.9}.header-combat-sim-die circle{fill:#d8c9a8}.header-unit-stats-btn{flex:0 0 auto;width:clamp(34px,4.2vw,40px);height:clamp(34px,4.2vw,40px);padding:0;display:flex;align-items:center;justify-content:center;background:var(--parchment-dark);border:2px solid var(--ink-faded);border-radius:4px;color:var(--ink);cursor:pointer}.header-unit-stats-btn:hover{border-color:var(--ink);background:var(--parchment);box-shadow:0 1px 4px var(--shadow)}.header-specials-btn{flex:0 0 auto;width:clamp(34px,4.2vw,40px);height:clamp(34px,4.2vw,40px);padding:0;display:flex;align-items:center;justify-content:center;position:relative;font-family:var(--font-parchment);font-size:.65rem;font-weight:700;background:var(--parchment-dark);border:2px solid var(--ink-faded);border-radius:4px;color:var(--ink);cursor:pointer}.header-specials-star{position:absolute;font-size:clamp(22px,2.8vw,28px);line-height:1;color:#1a1a1a;z-index:0}.header-specials-sp{position:relative;z-index:1;font-size:clamp(.52rem,.5vw + .45rem,.6rem);color:#c4a574;text-shadow:0 0 1px rgba(0,0,0,.3)}.header-specials-btn:hover{border-color:var(--ink);background:var(--parchment);box-shadow:0 1px 4px var(--shadow)}.header-unit-stats-icon{width:clamp(24px,3.2vw,30px);height:clamp(24px,3.2vw,30px);object-fit:contain;filter:brightness(0)}.header-stats-btn{flex:0 0 auto;width:clamp(34px,4.2vw,40px);height:clamp(34px,4.2vw,40px);padding:0;display:flex;align-items:center;justify-content:center;background:var(--parchment-dark);border:2px solid var(--ink-faded);border-radius:4px;cursor:pointer;color:var(--ink)}.header-stats-btn:hover{border-color:var(--ink);background:var(--parchment);box-shadow:0 1px 4px var(--shadow)}.stats-icon{width:clamp(18px,2.4vw,22px);height:clamp(18px,2.4vw,22px);fill:currentColor}.header-spacer{flex:1;min-width:1rem}.faction-header{flex:0 1 auto;display:flex;align-items:center;min-width:0;padding:clamp(.15rem,.5vw,.25rem) clamp(.35rem,1vw,.55rem);border-radius:4px;border:2px solid var(--ink-faded);background:#fff3}.faction-header .faction-title{font-family:Cinzel,serif;font-size:clamp(.92rem,1.35vw + .45rem,1.35rem);font-weight:600;color:var(--ink);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:min(11rem,22vw)}.turn-status{display:flex;align-items:center;gap:clamp(.28rem,.8vw,.68rem);font-family:var(--font-parchment);font-size:clamp(.72rem,.7vw + .5rem,.98rem);color:var(--ink-light)}.phase-divider{color:var(--ink-faded)}.turn-number{font-weight:600}.current-phase{font-style:italic;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:min(14rem,36vw)}@media(max-width:1280px){.current-phase{max-width:min(11rem,34vw)}}.current-power{font-weight:700;color:var(--gold-dark);font-size:.95em}.stats-modal .modal-header,.specials-modal .modal-header,.unit-stats-modal .modal-header,.help-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.75rem;border-bottom:2px solid var(--ink-faded);background:linear-gradient(180deg,var(--parchment-light) 0%,var(--parchment) 100%);border-radius:5px 5px 0 0}.stats-modal .modal-header h2,.specials-modal .modal-header h2,.unit-stats-modal .modal-header h2,.help-modal .modal-header h2{font-family:Cinzel,serif;font-size:1.55rem;color:var(--ink);margin:0}.stats-modal .close-btn,.specials-modal .close-btn,.unit-stats-modal .close-btn,.help-modal .close-btn{background:none;border:none;font-size:1.6rem;color:var(--ink-faded);cursor:pointer;padding:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center}.stats-modal .close-btn:hover,.specials-modal .close-btn:hover,.unit-stats-modal .close-btn:hover,.help-modal .close-btn:hover{color:var(--ink)}.stats-modal-body,.specials-modal-body,.unit-stats-modal-body,.help-modal-body{padding:1.75rem 2rem;background:var(--parchment-dark);max-height:min(60vh,500px);overflow-y:auto}.help-modal-body{max-height:min(70vh,560px)}.unit-stats-modal-body{padding-top:0;overflow-x:auto}.help-section{margin-bottom:1.25rem;font-family:var(--font-parchment)}.help-section:last-child{margin-bottom:0}.help-section h3{font-size:1.05rem;color:var(--ink);margin:0 0 .5rem}.help-section p{margin:0;font-size:.95rem;color:var(--ink-light);line-height:1.45}.help-icon-list{margin:0;padding-left:1.25rem;font-size:.95rem;color:var(--ink-light);line-height:1.5}.help-icon-list li{margin-bottom:.35rem}.help-icon{display:inline-block;margin-right:.2rem;font-style:normal}.specials-modal-intro{margin:0 0 1rem;font-family:var(--font-parchment);font-size:1rem;color:var(--ink-light)}.specials-list{margin:0;font-family:var(--font-parchment)}.specials-term{font-weight:600;color:var(--ink);margin-top:1rem;margin-bottom:.25rem}.specials-term:first-child{margin-top:0}.specials-desc{margin:0 0 0 1rem;font-size:.95rem;color:var(--ink-light);line-height:1.45}.specials-unit-list{margin:.5rem 0 0;padding-left:1.25rem;list-style:disc;font-size:.9rem;color:var(--ink-light)}.specials-unit-list li{margin-bottom:.2rem}.stats-modal-key,.unit-stats-modal-key{margin:0;padding:.6rem 1rem;font-size:.85rem;font-family:var(--font-parchment);color:var(--ink-faded);text-align:center;border-top:1px solid var(--ink-faded);border-radius:0 0 5px 5px}.unit-stats-specials-definitions{padding:.75rem 1rem 1rem;font-size:.9rem;color:var(--ink-light);border-top:1px solid var(--ink-faded);background:var(--parchment)}.stats-modal .header-stats-table,.unit-stats-modal .header-stats-table{border-collapse:collapse;font-family:var(--font-parchment);font-size:1.2rem}.stats-modal .header-stats-table th,.stats-modal .header-stats-table td,.unit-stats-modal .header-stats-table th,.unit-stats-modal .header-stats-table td{padding:.5rem 1rem;text-align:left;font-family:var(--font-parchment)}.stats-modal .header-stats-table th,.unit-stats-modal .header-stats-table th{font-weight:700;color:var(--ink);border-bottom:1px solid var(--ink-faded)}.stats-modal .header-stats-table th.stats-col-faction,.unit-stats-modal .header-stats-table th.stats-col-unit{min-width:6rem}.stats-modal .header-stats-table th.stats-col-num,.unit-stats-modal .header-stats-table th.stats-col-num{text-align:right;min-width:2.75rem}.unit-stats-modal .header-stats-table th.stats-col-specials{text-align:left;min-width:18rem;width:22%}.unit-stats-modal .header-stats-table td.stats-col-specials{font-size:.82rem;max-width:none;white-space:nowrap}.unit-stats-modal{min-width:960px;max-width:min(1100px,96vw)}.unit-stats-modal .header-stats-table thead th{position:sticky;top:0;z-index:3;background-color:var(--parchment-dark);box-shadow:0 1px 0 var(--ink-faded)}.stats-modal .stats-alliance-row td{font-weight:700;font-size:1.25rem;color:var(--ink);padding-top:.6rem}.stats-modal .stats-alliance-cell{border-bottom:1px solid var(--ink-faded)}.stats-modal .stats-faction-row td{color:var(--ink-light);font-size:1.12rem}.stats-modal .stats-faction-row .stats-col-faction{font-style:italic;padding-left:.75rem;display:flex;align-items:center;gap:.5rem}.unit-stats-modal .unit-stats-faction-row td{font-weight:700;font-size:1.15rem;color:var(--ink);padding-top:.5rem;border-bottom:1px solid var(--ink-faded)}.unit-stats-modal .unit-stats-faction-row .stats-col-unit{padding-left:.75rem;display:flex;align-items:center;gap:.5rem}.stats-modal .stats-faction-icon{width:18px;height:18px;object-fit:contain;flex-shrink:0;background:transparent}.unit-stats-modal .unit-stats-faction-icon{width:22px;height:22px;object-fit:contain;flex-shrink:0;background:transparent}.unit-stats-modal .unit-stats-unit-row td{color:var(--ink-light);font-size:1.1rem;padding-left:2rem}.unit-stats-modal .unit-stats-unit-row td{font-family:var(--font-parchment)}.unit-stats-modal .unit-stats-unit-row .stats-col-unit .unit-name-text{font-size:.95rem}.unit-stats-modal .unit-stats-unit-row td.stats-col-num.stats-col-specials{font-size:.85rem;font-family:var(--font-parchment)}.unit-stats-modal .unit-stats-unit-row .stats-col-unit{display:flex;align-items:center;gap:.5rem;padding-left:2rem}.unit-stats-modal .unit-stats-unit-icon{width:20px;height:20px;object-fit:contain;flex-shrink:0}.stats-modal .stats-col-num,.unit-stats-modal .stats-col-num{text-align:right}.stats-modal .stats-placeholder{margin:0;font-size:1.05rem;color:var(--ink-faded)}.header-stronghold-bar-wrap{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:.1rem;width:clamp(68px,9vw,118px);min-width:64px;max-width:132px}@media(min-width:1600px){.header-stronghold-bar-wrap{width:clamp(80px,8vw,150px);max-width:168px;gap:.12rem}}@media(max-width:900px){.header-stronghold-bar-wrap{margin-left:.35rem;margin-right:.35rem}}.header-turn-ticker{flex:0 0 auto;display:flex;align-items:center;gap:clamp(.18rem,.45vw,.36rem);height:clamp(40px,4.5vw,50px);padding:0 clamp(.28rem,.85vw,.48rem);border:2px solid var(--ink-faded);border-radius:6px;background:#ffffff26}.header-turn-ticker-slot{width:clamp(28px,3.2vw,35px);height:clamp(28px,3.2vw,35px);flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:50%;padding:2px;border:2px solid var(--ink-faded);background:transparent;box-shadow:0 1px 2px #00000026;overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease}.header-turn-ticker-slot--current{border:none;box-shadow:0 0 0 3px #d4a017,0 0 0 4px #b8860b,0 0 14px 3px #e87e22bf,0 0 24px 6px #e67e2280;animation:turn-ticker-ring-glow 2s ease-in-out infinite}@keyframes turn-ticker-ring-glow{0%,to{box-shadow:0 0 0 3px #d4a017,0 0 0 4px #b8860b,0 0 14px 3px #e87e22bf,0 0 24px 6px #e67e2280}50%{box-shadow:0 0 0 3px #d4a017,0 0 0 4px #b8860b,0 0 20px 5px #e87e22e6,0 0 32px 10px #e67e2299}}.header-turn-ticker-icon{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}@media(max-width:1280px){.header-turn-ticker{height:clamp(38px,5vw,44px);gap:.2rem;padding:0 .32rem}.header-turn-ticker-slot{width:clamp(26px,3.5vw,30px);height:clamp(26px,3.5vw,30px)}}@media(max-width:1024px){.faction-header .faction-title{font-size:clamp(.85rem,1.5vw + .5rem,1.35rem);max-width:min(10rem,28vw)}.turn-status{font-size:clamp(.68rem,.95vw + .45rem,.9rem);gap:.38rem}.header{padding:.5rem .62rem;gap:.32rem}.header-stronghold-bar-wrap{width:clamp(64px,11vw,100px);min-width:60px}}@media(max-width:900px){.header-center-title{flex:1 1 120px;min-width:min(10rem,36vw);max-width:min(36rem,calc(42vw + 8rem))}.header-stronghold-bar-wrap{width:clamp(64px,22vw,140px);min-width:60px}}@media(max-width:900px)and (orientation:portrait){.header{flex-wrap:nowrap;justify-content:flex-start;align-items:center;gap:.26rem;padding:.38rem max(.42rem,env(safe-area-inset-right,0px)) .38rem max(.42rem,env(safe-area-inset-left,0px));overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;scrollbar-width:thin;scrollbar-color:rgba(139,115,85,.95) rgba(61,41,20,.1)}.header::-webkit-scrollbar{height:5px}.header::-webkit-scrollbar-track{background:#3d29141a;border-radius:999px;margin:0 .25rem}.header::-webkit-scrollbar-thumb{background:#8b7355bf;border-radius:999px}.header::-webkit-scrollbar-thumb:hover{background:var(--ink-faded)}.header-spacer{display:none}.header-menu-btn{flex:0 0 auto;height:28px;min-height:28px;padding:0 .4rem;font-size:.72rem}.header-help-btn,.header-combat-sim-btn,.header-specials-btn,.header-unit-stats-btn,.header-stats-btn{flex:0 0 auto;width:28px;height:28px;min-width:28px;min-height:28px}.header-help-icon{width:18px;height:18px}.header-unit-stats-icon{width:20px;height:20px}.header-combat-sim-emoji{font-size:13px}.header-combat-sim-die{width:9px;height:9px;right:-3px;bottom:-2px}.header-specials-star{font-size:22px}.header-specials-sp{font-size:.52rem}.header-stats-btn .stats-icon{width:16px;height:16px}.header-stronghold-bar-wrap{flex:0 0 auto;width:clamp(84px,30vw,176px);min-width:84px;margin-left:.18rem;margin-right:.18rem}.header-stronghold-bar-wrap .stronghold-alliance-bar__segments{height:.95rem}.header-stronghold-bar-wrap .stronghold-alliance-bar__label{font-size:.52rem}.header-center-title{flex:0 0 auto;min-width:min(11rem,42vw);max-width:12rem;margin-left:.14rem}.header-center-title-brand{font-size:clamp(.72rem,2.6vw,.88rem)}.header-center-title-game{font-size:clamp(.65rem,2.4vw,.8rem)}.header-turn-ticker{flex:0 0 auto;margin-left:.18rem;height:36px;min-height:36px;padding:0 .3rem;gap:.22rem}.header-turn-ticker-slot{width:26px;height:26px}.faction-header{flex:0 0 auto;margin-left:.2rem;padding:.15rem .45rem}.faction-header .faction-title{font-size:clamp(.72rem,2.8vw,1rem)}.turn-status{flex:0 0 auto;margin-left:.2rem;flex-wrap:nowrap;white-space:nowrap;font-size:clamp(.64rem,2.4vw,.82rem);gap:.28rem}}.stats-modal,.specials-modal,.unit-stats-modal,.help-modal{background:var(--parchment);border:3px solid var(--ink-faded);border-radius:8px;box-shadow:0 4px 20px #0006;min-width:520px;max-width:92vw;max-height:90vh;display:flex;flex-direction:column}@media(min-width:1024px){.stats-modal,.specials-modal{min-width:640px;max-width:min(980px,94vw)}.stats-modal-body,.specials-modal-body{max-height:min(74vh,680px)}.unit-stats-modal-body{max-height:min(72vh,620px)}.stats-modal .header-stats-table,.stats-modal .header-stats-table th,.stats-modal .header-stats-table td{font-size:1.32rem}.stats-modal .stats-alliance-row td{font-size:1.38rem}.stats-modal .stats-faction-row td{font-size:1.24rem}.stats-modal .stats-placeholder{font-size:1.1rem}.specials-modal-intro{font-size:1.08rem}.specials-term{font-size:1.1rem}.specials-desc{font-size:1.05rem}.specials-unit-list{font-size:.98rem}}.help-modal{width:min(950px,96vw);max-width:min(950px,100vw);min-width:min(520px,96vw)}@media(max-width:900px)and (orientation:landscape){.header{padding:.42rem .55rem;gap:.3rem}.header-menu-btn,.header-help-btn,.header-combat-sim-btn,.header-specials-btn,.header-unit-stats-btn,.header-stats-btn{width:32px;height:32px;min-width:32px;min-height:32px}.header-unit-stats-icon,.header-help-icon{width:24px;height:24px}.header-combat-sim-emoji{font-size:14px}.header-center-title-brand{font-size:.9rem}.header-center-title-game{font-size:.72rem}.header-stronghold-bar-wrap{width:148px;margin-left:.28rem;margin-right:.28rem}.header-stronghold-bar-wrap .stronghold-alliance-bar__segments{height:.95rem}.header-stronghold-bar-wrap .stronghold-alliance-bar__label{font-size:.52rem}.header-turn-ticker{height:38px;gap:.22rem;padding:0 .3rem}.header-turn-ticker-slot{width:25px;height:25px}.faction-header .faction-title{font-size:.95rem}.turn-status{font-size:.78rem;gap:.38rem}}@media(max-width:767px){.modal.stats-modal,.modal.unit-stats-modal{max-height:min(90dvh,92vh)!important;border-width:2px;border-radius:8px}.stats-modal .modal-header,.unit-stats-modal .modal-header{padding:.5rem .65rem}.stats-modal .modal-header h2,.unit-stats-modal .modal-header h2{font-size:clamp(.92rem,3.4vw,1.1rem)}.stats-modal .close-btn,.unit-stats-modal .close-btn{width:30px;height:30px;font-size:1.35rem}.modal.stats-modal .stats-modal-body,.modal.unit-stats-modal .unit-stats-modal-body{padding:.5rem .45rem!important;max-height:min(72dvh,80vh)!important}.stats-modal .header-stats-table,.unit-stats-modal .header-stats-table{font-size:clamp(.65rem,2.4vw,.78rem)}.stats-modal .header-stats-table th,.stats-modal .header-stats-table td,.unit-stats-modal .header-stats-table th,.unit-stats-modal .header-stats-table td{padding:.28rem .4rem}.stats-modal .header-stats-table th.stats-col-faction,.unit-stats-modal .header-stats-table th.stats-col-unit{min-width:0}.stats-modal .header-stats-table th.stats-col-num,.unit-stats-modal .header-stats-table th.stats-col-num{min-width:1.75rem}.stats-modal .stats-alliance-row td{font-size:clamp(.78rem,2.8vw,.95rem);padding-top:.45rem}.stats-modal .stats-faction-row td{font-size:clamp(.68rem,2.5vw,.82rem)}.stats-modal .stats-faction-row .stats-col-faction{padding-left:.4rem;gap:.35rem}.stats-modal .stats-faction-icon{width:15px;height:15px}.stats-modal .stats-placeholder{font-size:clamp(.72rem,2.5vw,.85rem)}.unit-stats-modal .unit-stats-faction-row td{font-size:clamp(.75rem,2.7vw,.9rem);padding-top:.4rem}.unit-stats-modal .unit-stats-faction-icon{width:18px;height:18px}.unit-stats-modal .unit-stats-unit-row td{font-size:clamp(.65rem,2.4vw,.78rem);padding-left:.85rem}.unit-stats-modal .unit-stats-unit-row .stats-col-unit{padding-left:.85rem;gap:.35rem}.unit-stats-modal .unit-stats-unit-row .stats-col-unit .unit-name-text{font-size:clamp(.64rem,2.3vw,.76rem)}.unit-stats-modal .unit-stats-unit-icon{width:16px;height:16px}.unit-stats-modal .header-stats-table th.stats-col-specials{min-width:5.5rem;width:auto;max-width:42vw}.unit-stats-modal .header-stats-table td.stats-col-specials{font-size:clamp(.58rem,2.1vw,.68rem);white-space:normal;word-break:break-word;line-height:1.25}.unit-stats-modal .unit-stats-unit-row td.stats-col-num.stats-col-specials{font-size:clamp(.58rem,2.1vw,.68rem)}.stats-modal-key,.unit-stats-modal-key{padding:.4rem .5rem;font-size:clamp(.62rem,2.2vw,.72rem)}.unit-stats-specials-definitions{padding:.5rem .55rem .65rem;font-size:clamp(.68rem,2.3vw,.8rem)}}.unit-token{position:relative;width:clamp(36px,10vmin,42px);height:clamp(36px,10vmin,42px);background:var(--parchment);border:2px solid var(--ink-faded);border-radius:4px;box-shadow:1px 1px 3px var(--shadow);overflow:visible;transition:all .15s ease;pointer-events:auto;touch-action:none}.unit-token[role=button]:not(.disabled){cursor:grab!important}.unit-token[role=button]:not(.disabled) img,.unit-token[role=button]:not(.disabled) .count,.unit-token[role=button]:not(.disabled) .unit-token-passenger-badge,.unit-token[role=button]:not(.disabled) .unit-token-caution{cursor:inherit!important}.unit-token.dragging-overlay img,.unit-token.dragging-overlay .count,.unit-token.dragging-overlay .unit-token-passenger-badge{cursor:inherit!important}.unit-token.unit-token--naval{width:clamp(52px,15vmin,63px);height:clamp(52px,15vmin,63px)}.unit-token:hover:not(.disabled){transform:scale(1.15);border-color:var(--ink);box-shadow:2px 2px 6px var(--shadow);z-index:10}.unit-token.selected{transform:scale(1.2);border-color:var(--gold);box-shadow:0 0 8px var(--gold);z-index:10}.unit-token.dragging[role=button],.unit-token.dragging{cursor:grabbing!important;opacity:.5}.unit-token.dragging-overlay[role=button],.unit-token.dragging-overlay{cursor:grabbing!important;transform:scale(1.3);border-color:var(--gold);box-shadow:0 0 12px var(--gold);z-index:1000}.unit-token.disabled[role=button],.unit-token.disabled{cursor:not-allowed!important;opacity:.6}.unit-token img{width:100%;height:100%;object-fit:contain}.unit-token .count{position:absolute;bottom:-4px;right:-4px;min-width:clamp(14px,4vmin,18px);height:clamp(14px,4vmin,18px);background:var(--ink);color:var(--parchment);font-family:Cinzel,serif;font-size:clamp(.55rem,2vmin,.65rem);font-weight:700;display:flex;align-items:center;justify-content:center;border-radius:999px;padding:0 3px}.unit-token-passenger-badge{position:absolute;top:-6px;left:-6px;min-width:24px;height:24px;padding:0 5px;font-size:14px;font-weight:700;line-height:24px;text-align:center;color:#fff;background:var(--gold-dark, #6b5344);border-radius:999px;border:2px solid rgba(255,255,255,.5)}.unit-token-caution{position:absolute;top:-4px;right:-4px;font-size:1.1rem;line-height:1;pointer-events:none;filter:drop-shadow(0 0 1px rgba(0,0,0,.9))}.mobilization-tray{flex-shrink:0;background:var(--parchment);border-top:3px solid;padding:.75rem 1rem;display:flex;flex-direction:column;gap:.5rem}.tray-empty{font-family:IM Fell English,serif;font-style:italic;color:var(--ink-light)}.tray-header{font-family:Cinzel,serif;font-size:.85rem;color:var(--ink);text-align:center}.tray-mobilize-all-row{display:flex;justify-content:center;align-items:center;width:100%}.tray-units{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.purchase-stack{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;background:var(--parchment-light);border:3px solid var(--ink-faded);border-radius:6px;cursor:grab;min-width:80px;transition:transform .1s,box-shadow .1s}.purchase-stack.dragging-source{transition:none;pointer-events:none}.purchase-stack-overlay{cursor:grabbing;box-shadow:0 8px 16px #00000040}.purchase-stack:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0003;border-color:var(--ink)}.purchase-stack.selected{border-color:#2e7d32;background:#e8f5e9;box-shadow:0 0 0 2px #2e7d32}.purchase-icon{width:48px;height:48px;object-fit:contain}.purchase-count{font-family:Cinzel,serif;font-size:1.25rem;font-weight:700;color:var(--ink);background:var(--parchment);border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;margin-top:-14px;border:1px solid var(--ink-faded)}.purchase-name{font-size:.75rem;color:var(--ink);text-align:center;white-space:nowrap}.purchase-stack.camp-item{cursor:pointer}.purchase-icon.camp-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:2rem}.mobilize-all-btn{display:inline-flex;align-items:center;justify-content:center;padding:.2rem .65rem;min-width:0;background:var(--parchment-light);border:2px solid var(--ink-faded);border-radius:4px;cursor:grab;-webkit-user-select:none;user-select:none;transition:transform .1s,box-shadow .1s}.mobilize-all-btn.dragging-source{transition:none;pointer-events:none}.mobilize-all-btn:hover{transform:translateY(-1px);box-shadow:0 3px 6px #0000002e;border-color:var(--ink)}.mobilize-all-label{font-family:Cinzel,serif;font-weight:700;font-size:.72rem;letter-spacing:.04em;color:var(--ink);text-align:center;line-height:1.2}.map-container{flex:1;min-height:0;position:relative;overflow:hidden;background:var(--parchment-dark);display:flex;flex-direction:column}.map-container .map-content,.map-main{flex:1;min-height:0;position:relative;display:flex;flex-direction:column}.map-main>.map-wrapper{flex:1;min-height:0;width:100%}.map-wrapper{width:100%;height:100%;overflow:hidden;cursor:grab;touch-action:none}.map-wrapper:active{cursor:grabbing}.map-inner{position:relative;transform-origin:0 0;background:var(--parchment-dark)}.map-inner-content{position:absolute;left:8px;top:8px}.map-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:auto;z-index:0}.map-art-on-top{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:1}.map-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;display:block;z-index:2}.territory-path{fill-opacity:.52;cursor:pointer;pointer-events:auto;transition:fill-opacity .2s ease,stroke .2s ease;stroke:var(--territory-stroke, #444);stroke-width:2;stroke-linejoin:round;stroke-linecap:round;paint-order:stroke fill;filter:drop-shadow(0 0 2px var(--territory-glow-rgba, rgba(0, 0, 0, .25))) drop-shadow(0 0 4px var(--territory-glow-rgba-soft, rgba(0, 0, 0, .15)))}.territory-path-fill.territory-path--svg-glow{filter:none}.territory-path-stroke:not(.territory-path--svg-glow){filter:drop-shadow(0 0 2px var(--territory-glow-rgba, rgba(0, 0, 0, .25))) drop-shadow(0 0 4px var(--territory-glow-rgba-soft, rgba(0, 0, 0, .15)))}.territory-path-stroke{pointer-events:none}@media(pointer:fine){.territory-path:hover{fill-opacity:.6;stroke:var(--territory-stroke, #333);stroke-width:2}}.territory-path.selected{fill-opacity:.6;stroke:var(--gold);stroke-width:3}.territory-path.highlight{fill-opacity:.68;stroke:var(--gold-dark);stroke-width:10;stroke-dasharray:8 5;paint-order:stroke fill}.territory-path.drop-target{fill-opacity:.82;stroke:var(--gold);stroke-width:12;stroke-dasharray:none;filter:drop-shadow(0 0 4px var(--territory-glow-rgba, rgba(0, 0, 0, .3))) drop-shadow(0 0 8px var(--territory-glow-rgba-soft, rgba(0, 0, 0, .2))) brightness(1.25);transition:fill-opacity .15s ease,stroke .15s ease,filter .15s ease}.territory-path--sea{fill-opacity:.5;stroke:#0d1319;stroke-width:4;filter:drop-shadow(0 0 2px rgba(45,66,88,.6)) drop-shadow(0 0 4px rgba(20,35,50,.4))}.territory-path--sea:hover{fill-opacity:.62;stroke:#0d1319;stroke-width:4}.territory-path--sea.selected{fill-opacity:.6;stroke:var(--gold);stroke-width:5}.territory-path--sea.highlight{stroke:var(--gold-dark);stroke-width:8}.territory-path--sea.drop-target{fill-opacity:.75;stroke:var(--gold);stroke-width:10;filter:drop-shadow(0 0 4px rgba(255,215,0,.5)) brightness(1.2)}.map-wrapper.panning{cursor:grabbing}.territory-markers-layer{position:absolute;top:0;left:0;width:100%;height:100%;z-index:8;pointer-events:none}.territory-markers{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:6px;transform:translate(-50%,-50%)}.territory-markers-row{display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px;max-width:180px}.territory-markers-row--power-camp{display:flex;flex-direction:row;flex-wrap:wrap;gap:6px;align-items:center;justify-content:center;max-width:200px}.territory-markers-row--power-camp .territory-power-badge--inline{flex:0 0 44px;position:relative;z-index:2}.territory-markers-row--power-camp .territory-marker{flex:0 0 auto;position:relative;z-index:1}.territory-marker{display:flex;align-items:center;justify-content:center;border-radius:2px}.territory-marker.camp-marker{filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}.sea-zone-number{position:absolute;top:-30px;left:calc(50% - 72px);transform:translate(-50%);min-width:52px;height:52px;padding:0 10px;font-size:26px;font-weight:800;line-height:52px;text-align:center;color:#e8e8e8;text-shadow:0 1px 3px rgba(0,0,0,.8),0 0 1px rgba(0,0,0,1);background:#00000040;border-radius:50%;pointer-events:none}.territory-power-badge{position:absolute;top:-30px;left:50%;transform:translate(-50%);min-width:52px;height:52px;padding:0 10px;font-size:26px;font-weight:800;line-height:52px;text-align:center;color:#e8e8e8;background:#00000040;border-radius:50%;text-shadow:0 1px 3px rgba(0,0,0,.8),0 0 1px rgba(0,0,0,1);pointer-events:none}.territory-power-badge.territory-power-badge--above-logo{top:-52px}.territory-power-badge.territory-power-badge--inline{position:relative;left:auto;top:auto;z-index:2;transform:none;min-width:44px;width:44px;height:44px;padding:0;font-size:22px;font-weight:800;line-height:44px;box-sizing:border-box;flex-shrink:0;color:#e8e8e8;background:#00000040;border-radius:50%;text-shadow:0 1px 3px rgba(0,0,0,.8),0 0 1px rgba(0,0,0,1)}.territory-marker.camp-marker .camp-marker-emoji{font-size:34px;line-height:1;display:inline-block}.territory-marker.port-marker{width:40px;height:40px;min-width:40px;min-height:40px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #00000040;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}.territory-marker.port-marker .port-marker-emoji{font-size:25px;line-height:1;display:flex;align-items:center;justify-content:center;width:100%;height:100%;text-align:center;transform:translate(-1px,1px)}.territory-marker.home-marker{filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}.territory-marker.home-marker .home-marker-emoji{font-size:28px;line-height:1;display:inline-block}.territory-marker.terrain-marker{font-size:28px;line-height:1;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4))}.territory-marker.faction-marker{background:transparent;padding:1px;border-radius:50%;box-shadow:none}.territory-marker.faction-marker--capital{padding:2px;box-shadow:0 1px 4px #0006}.territory-marker.faction-marker img{display:block;border-radius:50%;object-fit:cover}.stronghold-faction-hp-group{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;gap:0}.stronghold-hp-bars{display:flex;flex-direction:column-reverse;align-items:center;gap:2px;margin-left:6px;--faction-color: #888}.stronghold-hp-bar{width:6px;height:8px;border-radius:2px;background:#000;border:1px solid #fff;box-sizing:border-box}.stronghold-hp-bar[data-filled=true]{background:#fff;border-color:#fffc}.territory-marker.neutral-stronghold-marker{width:44px;height:44px;border-radius:50%;background:transparent;border:8px solid #b8860b;box-shadow:0 0 0 3px #d4a017,0 0 8px 2px #e87e2280}.unit-layer{position:absolute;top:0;left:0;width:100%;height:100%;z-index:9;pointer-events:none}.territory-units{position:absolute;display:flex;gap:2px;transform:translate(-50%,-50%);z-index:5;pointer-events:auto}.all-stacks-drag-btn-wrap{position:absolute;top:-26px;left:50%;transform:translate(-50%);z-index:25;pointer-events:auto}.all-stacks-drag-btn{display:flex;align-items:center;justify-content:center;height:24px;min-width:38px;padding:0 8px;box-sizing:border-box;border:1px solid var(--ink-faded);border-radius:12px;background:var(--parchment);color:var(--ink);font-size:.72rem;line-height:1;text-transform:none;letter-spacing:0;cursor:grab!important;touch-action:none}.all-stacks-drag-btn.dragging{opacity:.7;cursor:grabbing!important}.all-stacks-drag-btn:hover{border-color:var(--ink);background:var(--parchment-light)}.bulk-drag-overlay-stacks{display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;gap:10px;pointer-events:none;cursor:grabbing;filter:drop-shadow(0 6px 14px rgba(0,0,0,.25))}.bulk-drag-overlay-stacks .unit-token.dragging-overlay{flex:0 0 auto;transform:none;box-sizing:border-box}.territory-units-token-row{display:flex;gap:2px;position:relative;align-items:flex-start}.territory-units--stacked,.territory-units--stacked .territory-units-token-row{gap:0}.territory-units--stacked .territory-units-token-row>span.unit-token-tap-wrapper{margin-left:-26px;margin-top:0;transition:margin-left .2s ease,margin-top .2s ease}.territory-units--stacked .territory-units-token-row>span.unit-token-tap-wrapper:nth-of-type(1){margin-left:0;z-index:10}.territory-units--stacked .territory-units-token-row>span.unit-token-tap-wrapper:nth-of-type(2){margin-top:2px;z-index:9}.territory-units--stacked .territory-units-token-row>span.unit-token-tap-wrapper:nth-of-type(3){margin-top:4px;z-index:8}.territory-units--stacked .territory-units-token-row>span.unit-token-tap-wrapper:nth-of-type(4){margin-top:6px;z-index:7}.territory-units--stacked .territory-units-token-row>span.unit-token-tap-wrapper:nth-of-type(5){margin-top:8px;z-index:6}.territory-units--stacked .territory-units-token-row>span.unit-token-tap-wrapper:nth-of-type(6){margin-top:10px;z-index:5}.territory-units--stacked .territory-units-token-row>span.unit-token-tap-wrapper:nth-of-type(7){margin-top:12px;z-index:4}.territory-units--stacked .territory-units-token-row>span.unit-token-tap-wrapper:nth-of-type(8){margin-top:14px;z-index:3}.territory-units--stacked .territory-units-token-row>span.unit-token-tap-wrapper:nth-of-type(9){margin-top:16px;z-index:2}.territory-units--stacked .territory-units-token-row>span.unit-token-tap-wrapper:nth-of-type(10){margin-top:18px;z-index:1}.territory-units--stacked .territory-units-token-row>span.unit-token-tap-wrapper:nth-of-type(11){margin-top:20px;z-index:0}.territory-units--stacked .territory-units-token-row>span.unit-token-tap-wrapper:nth-of-type(12){margin-top:22px;z-index:-1}.territory-units--stacked .territory-units-token-row>span.unit-token-tap-wrapper:nth-of-type(13){margin-top:24px;z-index:-2}.territory-units--stacked .territory-units-token-row>span.unit-token-tap-wrapper:nth-of-type(14){margin-top:26px;z-index:-3}.territory-units--stacked .territory-units-token-row>span.unit-token-tap-wrapper:nth-of-type(15){margin-top:28px;z-index:-4}.territory-units--stacked .territory-units-token-row>span.unit-token-tap-wrapper:nth-of-type(16){margin-top:30px;z-index:-5}.territory-units--stacked:hover{gap:4px}.territory-units--stacked:hover .territory-units-token-row>span.unit-token-tap-wrapper{margin-left:0;margin-top:0}.territory-units--stacked.territory-units--stack-expanded .territory-units-token-row>span.unit-token-tap-wrapper{margin-left:0;margin-top:0}.territory-units-expand-overlay{display:none;position:absolute;inset:0;z-index:20;cursor:pointer}@media(pointer:coarse){.territory-units--stacked:not(.territory-units--stack-expanded) .territory-units-token-row>.territory-units-expand-overlay{display:block}}.unit-token-tap-wrapper{display:inline-block;vertical-align:top}.sea-zone-tray-open-btn{flex-shrink:0;align-self:center;font-family:Cinzel,serif;font-size:.65rem;font-weight:600;padding:.28rem .45rem;border:2px solid var(--gold);border-radius:4px;background:var(--parchment);color:var(--ink);cursor:pointer;line-height:1.1;box-shadow:0 1px 3px var(--shadow);touch-action:manipulation}.sea-zone-tray-open-btn:hover{background:var(--parchment-light)}@media(pointer:coarse){.sea-zone-tray-open-btn{min-height:2.5rem;min-width:2.75rem;padding:.4rem .55rem;font-size:.75rem}}@media(pointer:fine){.map-controls .controls-row button,.map-controls-key-btn,.map-controls-toggle{min-width:0;min-height:0}}@media(pointer:coarse){.map-controls .controls-row button,.map-controls-key-btn,.map-controls-toggle{min-width:2.75rem;min-height:2.75rem;padding:.5rem}}.map-controls{position:absolute;top:.72rem;left:.72rem;display:flex;flex-direction:column;align-items:center;gap:.1rem;z-index:10;background:var(--parchment);border:2px solid var(--gold);border-radius:5px;padding:.38rem;box-shadow:2px 2px 8px var(--shadow)}.map-controls--collapsed{padding:.28rem}.map-controls-toggle{width:26px;height:26px;padding:0;font-size:.7rem;display:flex;align-items:center;justify-content:center;background:#5d4e37;border:1px solid #c9a227;border-radius:3px;color:#f4e4bc;cursor:pointer;transition:all .15s ease;margin-bottom:.1rem}.map-controls-top-row{display:flex;align-items:center;justify-content:space-between;width:100%;gap:.28rem;margin-bottom:.18rem}.map-controls-toggle--hide{margin-bottom:0}.map-controls-key-btn{width:26px;height:26px;padding:0;display:flex;align-items:center;justify-content:center;background:#5d4e37;border:1px solid #c9a227;border-radius:3px;cursor:pointer;transition:all .15s ease;color:#f4e4bc}.map-controls-key-btn .map-controls-key-icon{width:16px;height:16px;stroke:#f4e4bc}.map-controls-key-btn:hover{background:#c9a227}.map-controls-key-btn:hover .map-controls-key-icon{stroke:#2c1810}.map-controls-toggle:hover{background:#c9a227;color:#2c1810}.map-controls--collapsed .map-controls-toggle{margin-bottom:0}.controls-row{display:flex;gap:.1rem;justify-content:center}.controls-row.zoom-controls{margin-top:.22rem;padding-top:.22rem;border-top:1px solid var(--gold)}.map-controls .controls-row button{width:26px;height:26px;padding:0;font-size:.82rem;display:flex;align-items:center;justify-content:center;background:#5d4e37;border:1px solid #c9a227;border-radius:3px;color:#f4e4bc;cursor:pointer;transition:all .15s ease;text-transform:none;letter-spacing:0}.map-controls .controls-row button:hover{background:#c9a227;color:#2c1810}.map-controls .controls-row button:active{transform:scale(.95)}.map-key-strip{flex-shrink:0;display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;padding:.4rem .75rem;justify-content:center;text-align:center;background:var(--parchment);border:2px solid var(--gold);border-radius:5px;box-shadow:2px 2px 8px var(--shadow);font-family:var(--font-parchment);font-size:.8rem;color:var(--ink)}.map-key-item{display:inline-flex;align-items:center;gap:.35rem}.map-key-icon{display:inline-flex;align-items:center;justify-content:center;font-size:.9em}.map-key-img{height:1.1em;width:auto;display:block;object-fit:contain}.movement-hint{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);background:var(--parchment);border:2px solid var(--gold);border-radius:4px;padding:.5rem 1rem;font-family:Cinzel,serif;font-size:.85rem;color:var(--ink);box-shadow:2px 2px 8px var(--shadow);z-index:10}.move-arrow{pointer-events:none;filter:drop-shadow(1px 1px 2px rgba(0,0,0,.4));animation:arrow-pulse 2s ease-in-out infinite}.move-arrow-load-emoji{pointer-events:none;fill:#1565c0;stroke:#ffffffe6;stroke-width:1.5px;paint-order:stroke fill}@keyframes arrow-pulse{0%,to{opacity:.9}50%{opacity:.6}}@media(max-width:900px)and (orientation:landscape){.map-controls{top:.45rem;left:.45rem;padding:.24rem;gap:.08rem;border-width:1px}.map-controls .map-controls-key-btn{width:24px;height:24px;min-width:24px;min-height:24px;max-width:24px;max-height:24px;padding:0;box-sizing:border-box}.map-controls .map-controls-key-btn .map-controls-key-icon{width:14px;height:14px}.map-controls-toggle{width:24px;height:24px;min-width:24px;min-height:24px;max-width:24px;max-height:24px;padding:0;font-size:.64rem}.map-controls .controls-row button{width:24px;height:24px;min-width:24px;min-height:24px;max-width:24px;max-height:24px;padding:0;font-size:.76rem;border-width:1px;box-sizing:border-box}}@media(max-width:900px)and (orientation:portrait){.map-controls{top:.42rem;left:.42rem;padding:.28rem;gap:.08rem;border-width:1px}.map-controls .map-controls-key-btn{width:26px;height:26px;min-width:26px;min-height:26px;max-width:26px;max-height:26px;padding:0;box-sizing:border-box}.map-controls .map-controls-key-btn .map-controls-key-icon{width:16px;height:16px}.map-controls-toggle{width:26px;height:26px;min-width:26px;min-height:26px;max-width:26px;max-height:26px;padding:0;font-size:.68rem}.map-controls .controls-row button{width:26px;height:26px;min-width:26px;min-height:26px;max-width:26px;max-height:26px;padding:0;font-size:.8rem;border-width:1px;box-sizing:border-box}}.naval-tray{flex-shrink:0;background:var(--parchment);border-top:3px solid;padding:.4rem .75rem;display:flex;flex-direction:column;gap:.25rem}.naval-tray-header{display:flex;align-items:center;justify-content:space-between;gap:.25rem}.naval-tray-title{font-family:Cinzel,serif;font-size:.8rem;color:var(--ink);font-weight:600}.naval-tray-close{font-size:1.25rem;line-height:1;padding:.1rem .3rem;background:transparent;border:1px solid var(--ink-faded);border-radius:4px;color:var(--ink);cursor:pointer;transition:background .15s,border-color .15s}.naval-tray-close:hover{background:var(--parchment-light);border-color:var(--ink)}.naval-tray-boats{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;align-items:flex-end}.naval-tray-empty{font-family:IM Fell English,serif;font-style:italic;color:var(--ink-light);padding:.25rem;font-size:.85rem}.naval-tray-load-prompt{font-size:.8rem;color:var(--ink);margin:0 0 .2rem}.naval-tray-boat-card{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.35rem;background:var(--parchment-light);border:2px solid var(--ink-faded);border-radius:5px;min-width:72px;transition:transform .1s,box-shadow .1s}.naval-tray-boat-card-inner{display:flex;flex-direction:column;align-items:center;gap:.2rem;cursor:grab}.naval-tray-load-btn{font-size:.65rem;padding:.2rem .35rem;background:var(--ink);color:var(--parchment);border:none;border-radius:4px;cursor:pointer;white-space:nowrap}.naval-tray-load-btn:hover{background:var(--ink-light)}.naval-tray-boat-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026;border-color:var(--ink)}.naval-tray-boat-card--drop-over{box-shadow:0 0 0 2px var(--ink);background:var(--parchment)}.naval-tray-boat-card-inner--no-drag{cursor:default}.naval-tray-passenger-icon--draggable{cursor:grab}.naval-tray-passengers{display:flex;flex-wrap:wrap;gap:1px;justify-content:center;min-height:22px}.naval-tray-passenger-icon{width:22px;height:22px;object-fit:contain}.naval-tray-boat-icon{width:48px;height:48px;object-fit:contain}.naval-tray-boat-name{font-size:.65rem;color:var(--ink);text-align:center;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}.naval-tray-allocation-hint{font-family:IM Fell English,serif;font-size:.72rem;color:var(--ink-light);margin:0 0 .35rem;line-height:1.35;text-align:center}.naval-tray-passenger-icon-wrap{display:inline-flex;align-items:center;justify-content:center;border-radius:4px;box-sizing:border-box}.naval-tray-passenger-icon-wrap:focus-visible{outline:2px solid var(--ink);outline-offset:1px}.naval-tray-passenger-icon-wrap--selected{box-shadow:0 0 0 2px var(--ink);background:#0000000f}.naval-tray-boat-card--awaiting-tap{cursor:pointer}@media(pointer:coarse){.naval-tray-load-btn{min-height:2.25rem;padding:.35rem .5rem;font-size:.72rem}}.sidebar{flex:1;display:flex;flex-direction:column;gap:.75rem;padding:.75rem;min-width:0;min-height:0;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch}.panel{background:var(--parchment);border:1px solid var(--ink-faded);border-radius:4px;padding:.75rem}.sidebar.sidebar--turn-accent{--sidebar-panel-accent: var(--ink-faded)}.sidebar.sidebar--turn-accent .panel.actions-panel,.sidebar.sidebar--turn-accent .panel.territory-panel,.sidebar.sidebar--turn-accent .panel.event-log{border-width:2px;border-color:color-mix(in srgb,var(--sidebar-panel-accent) 50%,var(--ink-faded));box-shadow:0 0 0 1px color-mix(in srgb,var(--sidebar-panel-accent) 20%,transparent)}.panel.territory-panel{flex-shrink:0}.panel h2{font-family:Cinzel,serif;font-size:.95rem;font-weight:600;color:var(--ink);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.actions-panel{display:flex;flex-direction:column;gap:.5rem;flex:0 0 auto;align-self:stretch}.phase-actions{display:flex;flex-direction:column;gap:.5rem;max-height:min(85vh,48rem);overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.phase-actions:empty{display:none}.move-confirm{background:var(--parchment-light);border:2px solid var(--ink);border-radius:4px;padding:.75rem;margin-bottom:.5rem}.move-confirm h3{font-family:Cinzel,serif;font-size:.85rem;font-weight:600;color:var(--ink);margin-bottom:.5rem;text-transform:uppercase}.move-details{font-size:.85rem;color:var(--ink);margin-bottom:.5rem;line-height:1.4}.move-details .unit-name{font-weight:600}.move-details .move-route{color:var(--ink-faded);font-size:.8rem}.mobilization-all-stacks{display:flex;flex-direction:column;gap:.2rem;margin-bottom:.5rem}.mobilization-all-stack{font-size:.8rem;color:var(--ink)}.count-controls{display:flex;align-items:center;justify-content:center;gap:1rem;margin:.75rem 0}.count-btn{width:32px;height:32px;border:1px solid var(--ink-faded);border-radius:4px;background:var(--parchment);color:var(--ink);font-size:1.2rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center}.count-btn:hover:not(:disabled){background:var(--parchment-light);border-color:var(--ink)}.count-btn:disabled{opacity:.4;cursor:not-allowed}.count-value{font-size:1.5rem;font-weight:600;font-family:Cinzel,serif;color:var(--ink);min-width:2rem;text-align:center}.max-hint{font-size:.75rem;color:var(--ink-faded);text-align:center;margin-bottom:.5rem}.charge-path-prompt{font-size:.8rem;color:var(--ink);margin-bottom:.5rem}.charge-path-options{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem}.charge-path-btn{padding:.5rem .75rem;text-align:left;background:var(--parchment);border:2px solid var(--gold-dark);border-radius:4px;color:var(--ink);font-size:.72rem;font-family:var(--font-parchment);cursor:pointer}.charge-path-btn:hover{background:var(--gold-light);border-color:var(--gold);color:var(--ink)}.move-confirm-buttons{display:flex;gap:.5rem}.confirm-move-btn{flex:1;background:#2e7d32;color:#fff;border:1px solid #1b5e20;padding:.5rem}.confirm-move-btn.naval-move-btn{background:#0d47a1;border-color:#002171}.confirm-move-btn.naval-move-btn:hover{background:#1565c0}.confirm-move-btn.attack-btn{background:#c62828;border-color:#8b1c1c;font-family:Cinzel,serif;font-size:.85rem;font-weight:600;border-radius:3px;cursor:pointer}.confirm-move-btn.attack-btn:hover{background:#d32f2f;border-color:#8b1c1c}.attack-btn{flex:1;background:#c62828;color:#fff;border:1px solid #8b1c1c;padding:.5rem;cursor:pointer;border-radius:3px;font-family:Cinzel,serif;font-size:.85rem;font-weight:600}.attack-btn:hover{background:#d32f2f;cursor:pointer;border-radius:3px;font-family:Cinzel,serif;font-size:.85rem}.confirm-move-btn:hover{background:#388e3c}.cancel-move-btn{flex:1;background:var(--parchment);color:var(--ink);border:1px solid var(--ink-faded);padding:.5rem;cursor:pointer;border-radius:3px;font-family:Cinzel,serif;font-size:.85rem}.cancel-move-btn:hover{background:var(--parchment-light)}.pending-moves{margin-top:.5rem;border-top:1px solid var(--ink-faded);padding-top:.5rem}.pending-moves h3{font-family:Cinzel,serif;font-size:.8rem;font-weight:600;color:var(--ink);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.naval-standoff-notice{border-color:#b8860b}.naval-standoff-notice__text{font-size:.78rem;line-height:1.45;color:var(--ink);margin:0 0 .35rem}.naval-standoff-notice__list{margin:0;padding-left:1.1rem;font-size:.8rem;color:var(--ink)}.move-group{margin-bottom:.5rem}.move-group-header{font-family:Cinzel,serif;font-size:.85rem;font-weight:600;color:var(--ink);margin-bottom:.25rem;padding:.25rem .5rem;background:var(--parchment-light);border-radius:3px}.pending-move-item{display:flex;justify-content:space-between;align-items:center;padding:.25rem .5rem;font-size:.8rem;color:var(--ink);border-bottom:1px dotted var(--ink-faded)}.pending-move-item:last-child{border-bottom:none}.move-info{flex:1}.move-type-label{text-transform:capitalize;opacity:.95;margin-left:.15rem}.cancel-move-x{background:none;border:none;color:#8b0000;font-size:1rem;font-weight:700;cursor:pointer;padding:0 .25rem;line-height:1}.cancel-move-x:hover{color:#a00000}.pending-battles{margin-top:.5rem;border-top:1px solid var(--ink-faded);padding-top:.5rem}.pending-battles h3{font-family:Cinzel,serif;font-size:.8rem;font-weight:600;color:var(--ink);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.battle-btn{width:100%;background:#8b0000;color:#fff;border:1px solid #5a0000;padding:.5rem;font-family:var(--font-parchment);cursor:pointer;margin-bottom:.25rem;border-radius:3px}.battle-btn:hover:not(:disabled){background:#a00000}.battle-btn:disabled,.battle-btn.battle-btn--blocked{background:#6a6a6a;border-color:#4a4a4a;cursor:not-allowed;opacity:.75}.spectate-battles-panel{flex-shrink:0;margin-bottom:.5rem}.spectate-battles-panel h2{font-family:Cinzel,serif;font-size:1rem;font-weight:600;color:var(--ink);margin:0 0 .5rem}.spectate-battles-list{display:flex;flex-direction:column;gap:.35rem}.spectate-battle-btn{width:100%;padding:.5rem .75rem;font-family:var(--font-parchment);font-size:.95rem;background:var(--parchment-dark, #e8e0d0);border:2px solid var(--ink-faded);border-radius:4px;cursor:pointer;color:var(--ink);transition:box-shadow .2s ease,border-color .2s ease}.spectate-battle-btn:disabled{cursor:not-allowed;opacity:.75;color:var(--ink-faded)}.spectate-battle-btn--blocked{background:#d8d0c4;border-style:dashed}.spectate-battle-btn--active{border-color:#c62828;background:#c6282814;color:var(--ink);cursor:pointer;box-shadow:0 0 10px #c6282866}.spectate-battle-btn--active:hover{box-shadow:0 0 14px #c628288c}.confirm-dialog{background:var(--parchment-light);border:2px solid var(--ink);border-radius:4px;padding:.75rem;margin-top:.5rem}.confirm-dialog p{font-size:.85rem;color:var(--ink);margin-bottom:.75rem;line-height:1.4}.confirm-buttons{display:flex;gap:.5rem}.confirm-yes{flex:1;background:#8b0000;color:#fff;border:1px solid #5a0000;padding:.5rem;cursor:pointer;border-radius:3px;font-size:.8rem}.confirm-yes:hover{background:#a00000}.confirm-no{flex:1;background:var(--parchment);color:var(--ink);border:1px solid var(--ink-faded);padding:.5rem;cursor:pointer;border-radius:3px;font-size:.8rem}.confirm-no:hover{background:var(--parchment-light)}.territory-panel h2{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;margin:-.75rem -.75rem .5rem;border-radius:3px 3px 0 0}.territory-panel h2 .faction-icon{width:24px;height:24px;object-fit:contain}.territory-title-content{display:flex;align-items:baseline;gap:.4rem;flex:1;min-width:0}.territory-name{font-size:1rem;flex:1;min-width:0}.power-production{font-weight:400;font-size:.8rem;color:var(--ink-light)}.power-terrain{font-weight:400;font-size:.8rem;color:var(--ink-light);margin-left:auto;flex-shrink:0}.terrain-type{font-size:.7rem;font-weight:400;color:var(--ink-light);font-style:italic;margin-left:auto;flex-shrink:0}.capital-badge{font-family:Cinzel,serif;font-size:.95rem;font-weight:700;color:#9a7b2e;margin-bottom:.25rem}.stronghold-badge{font-family:Cinzel,serif;font-size:.9rem;font-weight:700;color:#7a5c15;margin-bottom:.25rem}.camp-badge{font-family:Cinzel,serif;font-size:.85rem;font-weight:700;color:#5c4a10;margin-bottom:.25rem}.home-to-badge{font-size:.75rem;color:var(--ink-light);margin-bottom:.25rem;font-style:italic}.defender-casualty-order{margin-top:.75rem;padding-top:.5rem;border-top:1px solid var(--ink-faded)}.defender-casualty-order-label{display:block;font-size:.68rem;color:var(--ink-faded);margin-bottom:.35rem}.defender-casualty-order-pills{display:flex;gap:.3rem;flex-wrap:wrap}.defender-pill{font-size:.68rem;padding:.25rem .45rem;border:1px solid var(--ink-faded);border-radius:999px;background:var(--parchment-dark, #e8e0d0);color:var(--ink-faded);cursor:pointer;transition:border-color .15s ease,color .15s ease,background .15s ease}.defender-casualty-order-pills button.defender-pill{font-family:inherit;font-size:.68rem;font-weight:inherit;letter-spacing:inherit;text-transform:none}.defender-pill--readonly{cursor:default;pointer-events:none}.defender-pill:hover{color:var(--ink);border-color:var(--gold-dark, #8b7355)}.defender-pill--active{color:var(--ink);border-color:var(--gold-dark, #8b7355);background:var(--parchment);box-shadow:inset 0 0 0 1px #8b73554d}.territory-info{font-size:.9rem;color:var(--ink-light);line-height:1.5;padding:.5rem 0}.territory-panel.has-territory{border-width:2px;border-color:var(--ink);box-shadow:0 2px 8px #00000014;min-height:12.5rem}.territory-panel{position:relative;overflow:hidden}.territory-panel .territory-panel-bg-image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;opacity:.22;pointer-events:none;z-index:0}.territory-panel>*:not(.territory-panel-bg-image){position:relative;z-index:1}.territory-units-list{display:flex;flex-direction:column;gap:.35rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--ink-faded)}.territory-unit-row{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--ink);line-height:1.3;padding:.25rem .4rem;background:var(--parchment-light);border-radius:4px;border:1px solid var(--ink-faded)}.territory-unit-icon-wrap{display:inline-flex;width:28px;height:28px;align-items:center;justify-content:center;flex-shrink:0;border-radius:3px;border:2px solid var(--faction-border, var(--ink-faded));background:var(--parchment);box-sizing:border-box}.territory-unit-icon-wrap .territory-unit-icon{width:100%;height:100%;object-fit:contain;border-radius:2px}.territory-unit-icon{width:28px;height:28px;object-fit:contain;flex-shrink:0;border-radius:3px;background:var(--parchment)}.territory-unit-label{font-family:Cinzel,serif;font-weight:500;min-width:0;flex:1}.territory-unit-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 .35rem;font-size:.75rem;font-weight:700;font-family:Cinzel,serif;color:var(--ink);background:var(--parchment);border:1px solid var(--ink-faded);border-radius:999px;flex-shrink:0}.units-inline{font-size:.85rem;color:var(--ink);line-height:1.6}.units-by-movement{display:flex;flex-direction:column;gap:.25rem}.unit-movement-row{font-size:.85rem;color:var(--ink);line-height:1.4}.unit-list{margin-top:.5rem;border-top:1px solid var(--ink-faded);padding-top:.5rem}.unit-entry{display:flex;justify-content:space-between;padding:.25rem 0;font-size:.9rem}.event-log{flex:0 1 auto;min-height:130px;display:flex;flex-direction:column;min-width:0}.event-log h2{flex-shrink:0}.event-log-filters{display:flex;flex-wrap:wrap;gap:.5rem .75rem;margin-bottom:.5rem;flex-shrink:0}.event-log-filter{display:inline-flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--ink)}.event-log-filter-label{font-family:var(--font-display, "Cinzel", serif);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-light);white-space:nowrap}.event-log-filter-select{padding:.35rem 1.25rem .35rem .5rem;font-size:.8rem;font-family:var(--font-parchment);border:1px solid var(--ink-faded);border-radius:4px;background:var(--parchment-light, #f5f0e6);color:var(--ink);min-width:0;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238a8478' d='M6 8L2 4h8z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .4rem center}.event-log-filter-select:hover{border-color:var(--ink-light)}.event-log-filter-select:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 1px var(--ink-faded)}.log-entries{flex:0 1 auto;min-height:0;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;font-size:.8rem;max-height:min(200px,30vh)}.log-entry{padding:.3rem 0;border-bottom:1px solid var(--ink-faded);color:var(--ink-light)}.log-entry:last-child{border-bottom:none}.log-entry.combat{color:#c62828}.log-entry.move{color:#2e7d32}.empty-state,.phase-instruction{font-family:var(--font-parchment);color:var(--ink-faded);font-size:1.05rem;text-align:center;line-height:1.35;margin:0 0 .5rem}.phase-instruction.aerial-must-move-msg{color:var(--gold-dark, #9a7b2e);font-weight:600}.phase-instruction .aerial-must-move-where{font-weight:400;color:var(--ink-faded)}.phase-instruction.combat-phase-idle{margin-bottom:0}.empty-state{padding:1rem}.retreat-selection{background:var(--parchment-light);border:2px solid var(--gold-dark);border-radius:6px;padding:1rem;margin-top:.5rem}.retreat-selection h3{font-family:Cinzel,serif;font-size:.9rem;margin:0 0 .5rem;color:var(--ink)}.retreat-from{font-size:.85rem;color:var(--ink-light);margin-bottom:.75rem}.retreat-options{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.retreat-option{padding:.5rem .75rem;background:var(--parchment);border:2px solid var(--ink-faded);border-radius:4px;font-family:IM Fell English,serif;font-size:.9rem;cursor:pointer;text-align:left;transition:all .2s}.retreat-option:hover{background:var(--gold-light);border-color:var(--gold-dark)}.no-retreat{font-style:italic;color:#c62828;font-size:.85rem}.cancel-retreat{width:100%;padding:.5rem;background:transparent;border:1px solid var(--ink-faded);color:var(--ink-light);font-size:.8rem;cursor:pointer}.cancel-retreat:hover{background:var(--parchment)}@media(max-width:767px){.sidebar{padding:max(.35rem,env(safe-area-inset-right,0px)) .4rem max(.5rem,env(safe-area-inset-bottom,0px)) .4rem;gap:.38rem;font-size:clamp(.72rem,2.4vw,.9rem)}.actions-panel{gap:.38rem;flex-shrink:0}.phase-actions{gap:.38rem;max-height:min(42vh,20rem);max-height:min(42dvh,20rem)}.event-log{flex:0 1 auto;min-height:100px}.territory-panel.has-territory{min-height:6.5rem}.sidebar .phase-instruction{font-size:clamp(.68rem,2.3vw,.8rem);line-height:1.35}.sidebar button{padding:.3rem .48rem;font-size:clamp(.65rem,2.2vw,.76rem)}.sidebar .count-btn{width:24px;height:24px;min-width:24px;min-height:24px;font-size:.9rem;padding:0}.sidebar .count-controls{gap:.65rem;margin:.5rem 0}.sidebar .count-value{font-size:1.15rem;min-width:1.5rem}.sidebar .max-hint{font-size:.65rem;margin-bottom:.35rem}.sidebar .charge-path-prompt{font-size:.72rem;margin-bottom:.35rem}.sidebar .confirm-move-btn,.sidebar .cancel-move-btn,.sidebar .attack-btn{padding:.32rem .42rem;font-size:clamp(.65rem,2.2vw,.76rem)}.sidebar .charge-path-btn{padding:.32rem .45rem;font-size:clamp(.62rem,2vw,.72rem)}.sidebar .move-confirm{padding:.5rem;margin-bottom:.38rem;border-width:1px}.sidebar .move-confirm-buttons{gap:.38rem}.panel{padding:.45rem}.panel h2{font-size:clamp(.72rem,2.2vw,.85rem);margin-bottom:.38rem;letter-spacing:.04em}.move-confirm h3{font-size:clamp(.68rem,2.3vw,.78rem);margin-bottom:.38rem}.move-details{font-size:clamp(.68rem,2.3vw,.78rem)}.move-details .move-route{font-size:.72rem}.pending-moves h3,.pending-battles h3{font-size:clamp(.68rem,2.2vw,.76rem);margin-bottom:.38rem}.move-group-header{font-size:clamp(.68rem,2.2vw,.78rem);padding:.18rem .38rem}.pending-move-item{font-size:clamp(.65rem,2.1vw,.74rem);padding:.18rem .38rem}.cancel-move-x{font-size:.88rem;padding:0 .18rem}.battle-btn{padding:.38rem;font-size:clamp(.68rem,2.2vw,.78rem)}.spectate-battles-panel h2{font-size:clamp(.72rem,2.2vw,.85rem)}.spectate-battle-btn{padding:.32rem .45rem;font-size:clamp(.65rem,2.1vw,.75rem)}.defender-casualty-order-label{font-size:.6rem}.defender-pill{font-size:.6rem;padding:.18rem .35rem}.defender-casualty-order-pills button.defender-pill{font-size:.6rem}.territory-panel h2{padding:.22rem .38rem;margin:-.45rem -.45rem .32rem;gap:.28rem;font-size:clamp(.66rem,1.95vw,.76rem);letter-spacing:.035em}.territory-panel h2 .faction-icon{width:17px;height:17px}.territory-name{font-size:clamp(.68rem,2.1vw,.8rem)}.power-terrain{font-size:clamp(.5rem,1.75vw,.62rem)}.territory-info{font-size:clamp(.58rem,1.95vw,.72rem);padding:.28rem 0;line-height:1.35}.capital-badge,.stronghold-badge{font-size:clamp(.62rem,1.95vw,.72rem);margin-bottom:.1rem}.camp-badge{font-size:clamp(.56rem,1.8vw,.66rem);margin-bottom:.08rem}.home-to-badge{font-size:clamp(.52rem,1.65vw,.62rem)}.territory-unit-row{font-size:clamp(.6rem,1.95vw,.7rem);gap:.28rem;padding:.14rem .25rem}.territory-unit-label{font-size:clamp(.6rem,1.95vw,.7rem)}.territory-unit-icon-wrap,.territory-unit-icon{width:22px;height:22px}.territory-unit-count-badge{min-width:1rem;height:1rem;font-size:.6rem;padding:0 .22rem}.units-inline,.unit-movement-row{font-size:clamp(.65rem,2.2vw,.75rem)}.event-log-filters{gap:.28rem .4rem;margin-bottom:.28rem}.event-log-filter{font-size:.65rem;gap:.22rem}.event-log-filter-label{font-size:.52rem;letter-spacing:.025em}.event-log-filter-select{padding:.18rem .95rem .18rem .32rem;font-size:.62rem;background-position:right .22rem center}.log-entries{font-size:clamp(.62rem,2.1vw,.7rem);max-height:min(140px,26vh)}.log-entry{padding:.18rem 0}}.combat-sim-panel{padding:0;font-size:.9rem;background:transparent;min-width:100%;max-width:100%;overflow-y:auto}.combat-sim-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.75rem}.combat-sim-title{margin:0;font-size:1rem;font-weight:600;color:var(--ink)}.combat-sim-close{flex-shrink:0;width:22px;height:22px;padding:0;font-size:.7rem;display:flex;align-items:center;justify-content:center;background:#5d4e37;border:1px solid #c9a227;border-radius:3px;color:#f4e4bc;cursor:pointer}.combat-sim-close:hover{background:#c9a227;color:#2c1810}.combat-sim-pill-row{display:flex;gap:.25rem;margin-bottom:.5rem}.combat-sim-pill{padding:.35rem .75rem;font-size:.85rem;font-weight:500;background:var(--parchment);color:var(--ink);border:2px solid var(--ink-faded);border-radius:999px;cursor:pointer;transition:background .15s,border-color .15s}.combat-sim-pill:hover{border-color:var(--ink);background:var(--parchment-dark)}.combat-sim-pill--active{background:var(--ink);color:var(--parchment);border-color:var(--ink)}.combat-sim-pill-row--inline{margin-bottom:0;display:inline-flex;flex-wrap:wrap;gap:.25rem}.combat-sim-pill--small{padding:.25rem .5rem;font-size:.8rem}.combat-sim-options-row{display:flex;gap:1.5rem;margin-top:.75rem;align-items:flex-start}.combat-sim-options-col{flex:1;display:flex;flex-direction:column;gap:.35rem}.combat-sim-option-line{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.combat-sim-option-name{font-size:.8rem;font-weight:500;color:var(--ink);min-width:6rem}.combat-sim-checkbox-wrap{display:inline-flex;align-items:center;cursor:pointer}.combat-sim-checkbox{width:1.1rem;height:1.1rem;accent-color:#5d4e37;cursor:pointer;border-radius:3px}.combat-sim-retreat-row .combat-sim-option-name{min-width:0}.combat-sim-retreat-row{align-items:center;gap:.35rem}.combat-sim-retreat-row .combat-sim-checkbox-wrap{flex-shrink:0}.combat-sim-retreat-label{font-size:.8rem;font-weight:500;color:var(--ink);white-space:nowrap}.combat-sim-retreat-input{width:2.5rem;padding:.25rem .35rem;font-size:.8rem;border:1px solid var(--ink-faded);border-radius:4px;background:var(--parchment);color:var(--ink)}.combat-sim-retreat-input::placeholder{color:var(--ink-faded)}.combat-sim-retreat-suffix{font-size:.8rem;color:var(--ink)}.combat-sim-options-label{font-size:.8rem;font-weight:600;color:var(--ink-light)}.combat-sim-pct-pill{display:inline-block;padding:.15rem .5rem;border-radius:999px;color:#fff;font-weight:600;font-size:.9rem}.combat-sim-label{display:block;margin-top:.5rem;margin-bottom:.2rem;font-weight:500;color:var(--ink)}.combat-sim-dropdowns-row{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}.combat-sim-attacker-stack{display:flex;flex-direction:column;gap:.15rem;flex:1 1 200px;min-width:min(100%,220px)}.combat-sim-attacker-stack>.combat-sim-field{flex:0 0 auto;min-width:0;width:100%}.combat-sim-attacker-stack>.combat-sim-field:first-child .combat-sim-label{margin-top:0}.combat-sim-field--attacking-territory .combat-sim-label{margin-top:.45rem}.combat-sim-swap-wrap{flex-shrink:0;display:flex;align-items:center;justify-content:center;align-self:center;padding-bottom:0}.combat-sim-swap-btn{width:2.25rem;height:2.25rem;display:flex;align-items:center;justify-content:center;padding:0;font-size:1.25rem;line-height:1;color:var(--ink);background:var(--parchment);border:2px solid var(--ink-faded);border-radius:6px;cursor:pointer;transition:background .15s,border-color .15s}.combat-sim-swap-btn:hover:not(:disabled){background:var(--parchment-dark);border-color:var(--ink)}.combat-sim-swap-btn:disabled{opacity:.4;cursor:not-allowed}.combat-sim-field{flex:1;min-width:160px}.combat-sim-dropdowns-row>.combat-sim-field{flex:1 1 200px;min-width:min(160px,100%)}@media(max-width:640px){.combat-sim-attacker-stack{flex:1 1 100%;min-width:100%}.combat-sim-dropdowns-row>.combat-sim-field{flex:1 1 100%;min-width:100%}.combat-sim-options-row{flex-direction:column;gap:.75rem}.combat-sim-units-row{flex-direction:column;gap:1rem}.combat-sim-attack-defense-section:before{display:none}.combat-sim-unit-name-text{white-space:normal;word-break:break-word;overflow:visible;text-overflow:unset}.combat-sim-add-defender-list{left:0;right:0;min-width:0;width:100%;max-width:none;max-height:min(50vh,16rem)}.combat-sim-add-defender-option{padding:.65rem .85rem;font-size:.9rem}.combat-sim-pill{min-height:44px;padding:.4rem 1rem;display:inline-flex;align-items:center;justify-content:center}.combat-sim-pill--small{min-height:40px;padding:.35rem .7rem;font-size:.82rem}.combat-sim-swap-btn{width:44px;height:44px;font-size:1.35rem}.combat-sim-select{min-height:44px;padding:.5rem .6rem;font-size:1rem}.combat-sim-special-unit{word-break:break-word;white-space:normal}}@media(max-width:767px){.combat-sim-preview-shelf-row{overflow-x:auto;-webkit-overflow-scrolling:touch;gap:.5rem}.combat-sim-preview-shelf-row .combat-sim-preview-shelf{flex:1 1 0;min-width:min(110px,46%)}}@media(max-width:767px)and (orientation:portrait){.combat-sim-unit-row{flex-wrap:nowrap;align-items:center;gap:.3rem;max-width:100%;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;padding-bottom:2px}.combat-sim-unit-icon-wrap{flex-shrink:0}.combat-sim-unit-main{flex:1 1 auto;min-width:0;flex-direction:column;align-items:flex-start;gap:.08rem}.combat-sim-unit-name-text{font-size:.82rem;line-height:1.2}.combat-sim-unit-stat{font-size:.7rem;line-height:1.25;font-weight:500}.combat-sim-unit-row-controls{flex:0 0 auto;flex-shrink:0;margin-left:auto;padding-top:0}.combat-sim-unit-row--defender .combat-sim-unit-row-controls{flex-wrap:nowrap;gap:.25rem}.combat-sim-count-stepper{flex-shrink:0}.combat-sim-count-btn{min-width:26px;width:26px;min-height:28px;height:28px;font-size:.85rem}.combat-sim-input--stepper{width:1.65rem;min-width:1.5rem;max-width:2.1rem;min-height:28px;height:28px;font-size:.72rem;padding:0 .04rem}.combat-sim-defender-remove{min-width:26px;min-height:28px;width:26px;height:28px;font-size:.9rem;padding:0}}.combat-sim-select{width:100%;padding:.4rem .5rem;border:1px solid var(--ink-faded);border-radius:4px;background:var(--parchment);color:var(--ink);font-size:.9rem}.combat-sim-logos-section{margin-top:.5rem}.combat-sim-logos-row{display:flex;gap:0;align-items:stretch;min-height:48px}.combat-sim-logos-col{flex:1;display:flex;justify-content:center;align-items:center;min-height:48px}.combat-sim-logos-vs{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:0 .75rem;flex-shrink:0}.combat-sim-vs-text{font-family:Cinzel,serif;font-size:1.25rem;font-weight:700;color:#5d4e37}.combat-sim-faction-logo{width:40px;height:40px;object-fit:contain}.combat-sim-divider{margin:.5rem 0;border:none;border-top:1px solid var(--ink-faded)}.combat-sim-attack-defense-section{position:relative}.combat-sim-attack-defense-section:before{content:"";position:absolute;left:50%;top:.5rem;bottom:.5rem;width:1px;margin-left:-.5px;background:var(--ink-faded);pointer-events:none}.combat-sim-units-row{display:flex;gap:1.5rem;margin-top:.5rem;align-items:flex-start}.combat-sim-units-col{flex:1;min-width:0}.combat-sim-units-header{font-size:.95rem;font-weight:600;margin-bottom:0;padding-bottom:.35rem;border-bottom:1px solid var(--ink-faded)}.combat-sim-units{margin-top:.35rem;margin-bottom:.5rem}.combat-sim-unit-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}.combat-sim-unit-icon-wrap{flex-shrink:0;width:24px;height:24px;margin-top:0;display:flex;align-items:center;justify-content:center;border-radius:3px;overflow:hidden;background:var(--parchment-dark)}.combat-sim-unit-icon{width:20px;height:20px;object-fit:contain}.combat-sim-unit-main{flex:1;min-width:0;display:flex;flex-direction:row;flex-wrap:wrap;align-items:baseline;gap:.15rem .4rem}.combat-sim-unit-name-text{font-size:.85rem;font-weight:500;color:var(--ink);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.combat-sim-unit-stat{font-size:.78rem;font-weight:600;color:var(--ink-faded)}.combat-sim-unit-row-controls{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.combat-sim-count-stepper{display:flex;align-items:stretch;border:1px solid var(--ink-faded);border-radius:6px;overflow:hidden;background:var(--parchment)}.combat-sim-count-btn{min-width:1.65rem;width:1.65rem;min-height:1.55rem;height:1.55rem;padding:0;font-size:.95rem;font-weight:600;line-height:1;color:var(--ink);background:var(--parchment-dark);border:none;cursor:pointer;transition:background .15s,color .15s}.combat-sim-count-btn:hover:not(:disabled){background:var(--ink-faded);color:var(--parchment)}.combat-sim-count-btn:disabled{opacity:.35;cursor:not-allowed}.combat-sim-input{padding:.35rem .4rem;border:1px solid var(--ink-faded);border-radius:4px;background:var(--parchment);font-size:.9rem;font-weight:600;text-align:center;color:var(--ink)}.combat-sim-input--stepper{width:2.25rem;min-width:2rem;max-width:3.5rem;flex:0 0 auto;min-height:1.55rem;height:1.55rem;padding:.15rem;border:none;border-left:1px solid var(--ink-faded);border-right:1px solid var(--ink-faded);border-radius:0;-moz-appearance:textfield}.combat-sim-input--stepper::-webkit-outer-spin-button,.combat-sim-input--stepper::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.combat-sim-unit-count-badge{flex-shrink:0;min-width:1.5rem;text-align:right;font-weight:600;font-size:.9rem;color:var(--ink)}.combat-sim-defender-remove{flex-shrink:0;min-width:1.55rem;min-height:1.55rem;width:1.55rem;height:1.55rem;padding:0;display:flex;align-items:center;justify-content:center;font-size:.85rem;line-height:1;color:#c00;background:transparent;border:1px solid rgba(204,0,0,.45);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.combat-sim-defender-remove:hover{background:#c00;color:var(--parchment)}.combat-sim-territory-units .combat-sim-unit-row--readonly,.combat-sim-unit-row--readonly{padding:.1rem 0}.combat-sim-divider--thin{margin:.35rem 0;border:none;border-top:1px solid var(--ink-faded)}.combat-sim-add-defender-wrap{position:relative;margin-top:.5rem}.combat-sim-add-defender-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .5rem;font-size:.8rem;color:var(--ink);background:transparent;border:1px dashed var(--ink-faded);border-radius:4px;cursor:pointer;transition:background .15s,border-color .15s}.combat-sim-add-defender-btn:hover{background:var(--parchment-light);border-color:var(--ink)}.combat-sim-add-defender-btn:hover .combat-sim-add-defender-faction{color:var(--ink)}.combat-sim-add-defender-plus{font-weight:700;font-size:.95rem}.combat-sim-add-defender-list{position:absolute;left:0;top:100%;margin:.25rem 0 0;padding:.25rem 0;min-width:12rem;max-height:12rem;overflow-y:auto;list-style:none;background:var(--parchment);border:1px solid var(--ink-faded);border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:10}.combat-sim-add-defender-option{padding:.35rem .75rem;font-size:.85rem;cursor:pointer;color:var(--ink)}.combat-sim-add-defender-option:hover{background:var(--ink-faded);color:var(--parchment)}.combat-sim-add-defender-option:hover .combat-sim-add-defender-faction{color:var(--parchment)}.combat-sim-add-defender-faction{font-size:.8rem;color:var(--ink-faded)}.combat-sim-error{margin:.5rem 0 0;color:#a00;font-size:.85rem}.combat-sim-actions{display:flex;align-items:stretch;gap:.5rem;margin-top:.75rem}.combat-sim-clear{flex-shrink:0;padding:.5rem 1rem;min-width:5rem;font-size:.9rem;font-weight:500;background:var(--parchment);color:var(--ink);border:2px solid var(--ink-faded);border-radius:6px;cursor:pointer;transition:background .15s}.combat-sim-clear:hover{background:var(--ink-faded);color:var(--parchment)}.combat-sim-calculate-wrap{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.combat-sim-calculate{width:100%;min-width:0;padding:.5rem .75rem;font-weight:600;font-size:.9rem;letter-spacing:.05em;background:var(--gold-dark);color:var(--parchment);border:2px solid var(--gold);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.combat-sim-calculate:hover:not(:disabled){background:var(--gold);color:var(--ink)}.combat-sim-calculate:disabled{opacity:.7;cursor:not-allowed}.combat-sim-progress-track{height:6px;background:var(--ink-faded);border-radius:3px;overflow:hidden}.combat-sim-progress-fill{height:100%;background:var(--gold);border-radius:3px;transition:width .12s ease-out}.combat-sim-lower{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--ink-faded);display:flex;gap:.6rem;align-items:flex-start}.combat-sim-lower-left{flex:0 0 40%;min-width:0;max-width:40%}.combat-sim-terrain-specials-box{padding:.75rem;background:var(--parchment-light);border:1px solid var(--ink-faded);border-radius:6px;min-width:0}.combat-sim-terrain-specials-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem;padding-bottom:.35rem;border-bottom:1px solid var(--ink-faded)}.combat-sim-terrain-specials-header .combat-sim-specials-title{margin:0;padding-bottom:0;border-bottom:none}.combat-sim-terrain{margin:0;font-size:.95rem;font-weight:600;color:var(--ink);flex-shrink:0}.combat-sim-specials{margin-top:0}.combat-sim-specials-title{margin:0 0 .5rem;padding-bottom:.35rem;border-bottom:1px solid var(--ink-faded);font-size:.95rem;font-weight:600;color:var(--ink)}.combat-sim-specials-list{display:flex;flex-direction:column;gap:.5rem}.combat-sim-archer-note{margin:.35rem 0 0;font-size:.8rem;color:var(--ink-light);font-style:italic}.combat-sim-special-group{font-size:.9rem}.combat-sim-special-title{font-weight:600;color:var(--ink);margin-right:.5rem;display:inline-block}.combat-sim-special-units{display:flex;flex-direction:column;gap:.15rem;margin-top:.25rem;margin-left:0}.combat-sim-special-unit{font-size:.75rem;color:var(--ink);display:block}.combat-sim-units-in-battle-box{margin-top:1rem;padding:.75rem;background:var(--parchment-light);border:1px solid var(--ink-faded);border-radius:6px;min-width:0}.combat-sim-units-in-battle-title{margin:0 0 .5rem;padding-bottom:.35rem;border-bottom:1px solid var(--ink-faded);font-size:.95rem;font-weight:600;color:var(--ink)}.combat-sim-units-in-battle-header-row{display:flex;gap:1rem;margin-bottom:.35rem}.combat-sim-units-in-battle-header-row .combat-sim-units-in-battle-side-label{flex:1;min-width:0;margin-bottom:0}.combat-sim-units-in-battle-row{display:flex;gap:1rem;align-items:flex-start}.combat-sim-units-in-battle-col{flex:1;min-width:0}.combat-sim-units-in-battle-side-label{font-family:Cinzel,serif;font-weight:600;font-size:.85rem;color:var(--ink);margin-bottom:.35rem;text-align:center}.combat-sim-preview-shelf-row{display:flex;gap:1rem;margin-bottom:.35rem;align-items:flex-start}.combat-sim-preview-shelf-row .combat-sim-preview-shelf{flex:1 1 0;min-width:0}.combat-sim-preview-shelves{display:flex;flex-direction:column;gap:.35rem}.combat-sim-preview-shelf{display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;background:#00000008;border-radius:4px;min-height:44px}.combat-sim-preview-shelf--empty{background:transparent;min-height:0;padding:0;gap:0}.combat-sim-preview-shelf--empty .combat-sim-preview-unit-stack{display:none}.combat-sim-preview-stat-label{font-family:Cinzel,serif;font-size:.9rem;font-weight:700;color:var(--ink);min-width:26px;width:26px;height:26px;text-align:center;line-height:26px;background:var(--parchment);border:2px solid var(--ink-faded);border-radius:4px;flex-shrink:0}.combat-sim-preview-unit-stack{display:flex;flex-wrap:wrap;gap:.25rem;align-items:center;flex:1 1 auto;min-width:0;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch}.combat-sim-preview-unit-group{position:relative;width:30px;height:30px;background:var(--parchment);border:2px solid var(--ink-faded);border-radius:4px;overflow:visible;flex-shrink:0}.combat-sim-preview-unit-group img{width:100%;height:100%;object-fit:contain}.combat-sim-preview-specials-badge{position:absolute;top:-1px;left:-1px;min-width:10px;height:10px;padding:0 1px;background:#000000bf;color:var(--parchment);font-family:Cinzel,serif;font-size:.45rem;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;border-radius:0 0 3px;letter-spacing:-.5px;z-index:1}.combat-sim-preview-unit-count{position:absolute;bottom:-2px;right:-2px;min-width:14px;height:14px;background:var(--ink);color:var(--parchment);font-family:Cinzel,serif;font-size:.6rem;font-weight:700;display:flex;align-items:center;justify-content:center;border-radius:7px;padding:0 2px}.combat-sim-lower-right{flex:1 1 60%;min-width:200px}.combat-sim-results{padding:.75rem;background:var(--parchment-light);border:1px solid var(--ink-faded);border-radius:6px;min-width:200px;max-width:100%}.combat-sim-percentiles{margin-top:.75rem;padding:.75rem;background:var(--parchment-light);border:1px solid var(--ink-faded);border-radius:6px;min-width:200px;max-width:100%}.combat-sim-percentiles-table{width:100%;table-layout:fixed;border-collapse:collapse;font-size:.7rem;color:var(--ink)}.combat-sim-percentiles-table th,.combat-sim-percentiles-table td{padding:.2rem .4rem;text-align:left;vertical-align:middle}.combat-sim-percentiles-table th:first-child,.combat-sim-percentiles-table td:first-child{width:22%}.combat-sim-percentiles-table th:nth-child(2),.combat-sim-percentiles-table td:nth-child(2){width:14%}.combat-sim-percentiles-table th:nth-child(3),.combat-sim-percentiles-table td:nth-child(3){width:32%}.combat-sim-percentiles-table th:nth-child(4),.combat-sim-percentiles-table td:nth-child(4){width:32%}.combat-sim-percentiles-th-label{padding-right:.75rem}.combat-sim-percentiles-th{font-weight:600;font-size:.85rem;padding-bottom:.25rem;border-bottom:1px solid var(--ink-faded)}.combat-sim-percentiles-td-label{font-size:.68rem;font-weight:500;color:var(--ink);white-space:nowrap;padding-right:.5rem}.combat-sim-percentile-pill{display:inline-block;padding:.15rem .35rem;border-radius:999px;color:#fff;text-shadow:0 1px 1px rgba(0,0,0,.3);font-size:.68rem;font-weight:500}.combat-sim-percentiles-td{font-size:.7rem;color:var(--ink)}.combat-sim-percentiles-table td:nth-child(3),.combat-sim-percentiles-table td:nth-child(4){font-size:.62rem}.combat-sim-results-top-row th{padding-bottom:.5rem;border-bottom:1px solid var(--ink-faded);font-weight:600;font-size:.95rem;color:var(--ink);text-align:left}.combat-sim-results-rounds-th{text-align:left}.combat-sim-results-top-row .combat-sim-results-th{text-align:center}.combat-sim-results-table{width:100%;table-layout:fixed;border-collapse:collapse;font-size:.95rem;color:var(--ink)}.combat-sim-results-table th,.combat-sim-results-table td{padding:.25rem .5rem;text-align:left}.combat-sim-results-table th:first-child,.combat-sim-results-table td:first-child{width:55%;padding-right:2.5rem;box-sizing:border-box}.combat-sim-results-table tbody td:first-child{font-size:.8rem;font-weight:500;color:var(--ink);white-space:nowrap}.combat-sim-results-th-label{white-space:nowrap}.combat-sim-results-th{font-weight:600;padding-left:.5rem;padding-right:.5rem}.combat-sim-results-table th:nth-child(2),.combat-sim-results-table td:nth-child(2),.combat-sim-results-table th:nth-child(3),.combat-sim-results-table td:nth-child(3){width:22.5%;min-width:0;box-sizing:border-box;text-align:center}.combat-sim-results-td-label{font-weight:500;color:var(--ink);white-space:nowrap}.combat-sim-results-td{padding-left:.5rem;padding-right:.5rem}.combat-sim-results-td-variance{font-size:.75rem}.combat-sim-dl{margin:0;display:grid;grid-template-columns:1fr auto;gap:.35rem 1.25rem;font-size:.95rem}.combat-sim-dl dt{margin:0;color:var(--ink);font-weight:500}.combat-sim-dl dd{margin:0;text-align:right;color:var(--ink)}.combat-sim-muted{margin:0;font-size:.85rem;color:var(--ink-faded)}@media(max-width:767px){.combat-sim-lower{flex-direction:column;align-items:stretch;gap:.75rem}.combat-sim-lower-left{flex:1 1 auto;max-width:none;width:100%}.combat-sim-lower-right{flex:1 1 auto;min-width:0;width:100%}.combat-sim-results,.combat-sim-percentiles{min-width:0;width:100%;box-sizing:border-box;padding:.5rem}.combat-sim-results-table{font-size:.8rem;table-layout:auto}.combat-sim-results-table th:first-child,.combat-sim-results-table td:first-child{width:auto;max-width:58%;padding-right:.5rem;white-space:normal;word-break:break-word}.combat-sim-results-table tbody td:first-child{white-space:normal}.combat-sim-results-table th:nth-child(2),.combat-sim-results-table td:nth-child(2),.combat-sim-results-table th:nth-child(3),.combat-sim-results-table td:nth-child(3){width:auto}.combat-sim-percentiles-table{font-size:.62rem;table-layout:auto}.combat-sim-percentiles-table th:first-child,.combat-sim-percentiles-table td:first-child{width:auto}.combat-sim-percentiles-th{font-size:.75rem}.combat-sim-dl{grid-template-columns:1fr;gap:.2rem .5rem;font-size:.85rem}.combat-sim-dl dd{text-align:left}.combat-sim-percentiles-td-label{white-space:normal;word-break:break-word}.combat-sim-percentiles-td:nth-child(3),.combat-sim-percentiles-td:nth-child(4){white-space:normal;word-break:break-word;-webkit-hyphens:auto;hyphens:auto}}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--parchment);border:3px solid var(--ink-faded);border-radius:8px;box-shadow:0 4px 20px #0006;max-width:90vw;max-height:90vh;display:flex;flex-direction:column}.purchase-modal{width:min(720px,94vw);max-width:100%;min-width:0;min-height:0;max-height:min(92vh,900px)}.purchase-modal-tabs{display:flex;gap:0;padding:0 1rem;border-bottom:2px solid var(--ink-faded);background:var(--parchment-dark)}.purchase-tab{padding:.6rem 1.2rem;font-family:Cinzel,serif;font-size:.95rem;color:var(--ink-light);background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;margin-bottom:-2px}.purchase-tab:hover{color:var(--ink)}.purchase-tab.active{color:var(--ink);font-weight:600;border-bottom-color:var(--gold-dark)}.purchase-modal-camp-icon{font-size:2rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--parchment-light);border:2px solid var(--ink-faded);border-radius:4px}.purchase-other-empty{padding:1.5rem 1rem;color:var(--ink-faded);font-style:italic;margin:0}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:2px solid var(--ink-faded);background:linear-gradient(180deg,var(--parchment-light) 0%,var(--parchment) 100%);border-radius:5px 5px 0 0}.modal-header h2{font-family:Cinzel,serif;font-size:1.3rem;color:var(--ink);margin:0}.mobilization-capacity{margin:.5rem 0 .75rem;font-size:1.05rem;color:var(--ink-light);text-align:center}.mobilization-capacity strong{color:var(--ink)}.close-btn{background:none;border:none;font-size:1.5rem;color:var(--ink-faded);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.close-btn:hover{color:var(--ink);background:none;box-shadow:none}.resources-display{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--parchment-dark);border-bottom:1px solid var(--ink-faded)}.resource-row{display:flex;align-items:center;justify-content:center;gap:.75rem}.resource-label{font-family:Cinzel,serif;color:var(--ink-light);min-width:60px;text-align:right}.resource-value{font-family:Cinzel,serif;font-size:1.2rem;font-weight:700;color:var(--gold-dark);min-width:40px;text-align:center}.resource-separator{color:var(--ink-faded)}.resource-remaining{font-family:Cinzel,serif;font-size:1.2rem;font-weight:700;color:var(--gold-dark);min-width:40px;text-align:center}.resource-remaining.negative{color:#c62828}.purchase-modal .unit-list{padding:1rem;overflow-y:auto;max-height:min(520px,58vh);border:none;margin:0}.unit-row{display:flex;align-items:center;gap:1rem;padding:.75rem;border-bottom:1px solid var(--ink-faded)}.unit-row:last-child{border-bottom:none}.unit-info{display:flex;align-items:center;gap:.75rem;flex:1}.unit-icon-wrap{display:inline-flex;width:48px;height:48px;align-items:center;justify-content:center;background:var(--parchment-light);border:3px solid var(--faction-border, var(--ink-faded));border-radius:4px;padding:2px;box-sizing:border-box}.unit-icon-wrap .unit-icon{width:100%;height:100%;object-fit:contain;border:none;background:transparent}.unit-icon{width:48px;height:48px;object-fit:contain;background:var(--parchment-light);border:2px solid var(--ink-faded);border-radius:4px;padding:2px}.unit-details{display:flex;flex-direction:column;gap:.2rem;min-width:0}.unit-stat-stack{display:flex;flex-direction:column;gap:.12rem;min-width:0}.unit-stats-specials-row{font-size:.78rem;line-height:1.35;min-height:calc(.78rem * 1.35)}.unit-name{font-family:Cinzel,serif;font-size:1.05rem;font-weight:600;color:var(--ink)}.unit-stats{font-size:.875rem;color:var(--ink-faded);font-family:monospace}.unit-stats-specials{display:block;font-size:inherit;line-height:inherit;color:var(--ink-faded);color:color-mix(in srgb,var(--ink-faded) 82%,var(--parchment));font-family:var(--font-parchment);white-space:normal;word-break:break-word}.unit-cost{width:56px;text-align:center}.cost-value{font-family:Cinzel,serif;font-size:1.02rem;font-weight:700;color:var(--gold-dark)}.quantity-controls{display:flex;align-items:center;gap:.5rem}.quantity-controls button{width:28px;height:28px;padding:0;font-size:1.1rem;display:flex;align-items:center;justify-content:center}.quantity{width:30px;text-align:center;font-family:Cinzel,serif;font-weight:700;font-size:1.1rem}.unit-stats-key{margin:0;padding:.5rem 1rem;font-size:.7rem;font-family:var(--font-parchment);color:var(--ink-faded);text-align:center;border-top:1px solid var(--ink-faded)}.modal-footer{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-top:2px solid var(--ink-faded);background:linear-gradient(180deg,var(--parchment) 0%,var(--parchment-dark) 100%);border-radius:0 0 5px 5px}.purchase-summary{font-family:Cinzel,serif;font-size:.9rem;color:var(--ink-light)}.modal-actions{display:flex;gap:.75rem}@media(max-width:767px){.modal-overlay:has(.purchase-modal){padding:max(.35rem,env(safe-area-inset-top,0px)) max(.35rem,env(safe-area-inset-right,0px)) max(.35rem,env(safe-area-inset-bottom,0px)) max(.35rem,env(safe-area-inset-left,0px));align-items:flex-end;justify-content:center;box-sizing:border-box}.modal.purchase-modal{width:100%!important;max-width:100%!important;min-width:0!important;max-height:min(94dvh,94vh)!important;border-radius:10px 10px 0 0;display:flex;flex-direction:column;min-height:0;box-sizing:border-box}.purchase-modal .modal-header{padding:.65rem .85rem;padding-top:max(.65rem,env(safe-area-inset-top,0px));flex-shrink:0}.purchase-modal .close-btn{min-width:44px;min-height:44px;touch-action:manipulation}.purchase-modal .modal-header h2{font-size:clamp(1rem,4vw,1.25rem)}.purchase-modal-tabs{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;padding:0 .5rem;gap:0;scrollbar-width:thin;flex-shrink:0}.purchase-tab{padding:.5rem .85rem;font-size:.82rem;white-space:nowrap;flex-shrink:0}.purchase-modal .resources-display{padding:.6rem .75rem;flex-shrink:0}.purchase-modal .resource-row{flex-wrap:nowrap;justify-content:flex-start;gap:.35rem .5rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;padding-bottom:2px}.purchase-modal .resource-label{min-width:0;flex-shrink:0;font-size:.7rem;text-align:left}.purchase-modal .resource-value,.purchase-modal .resource-remaining{font-size:.82rem;flex-shrink:0;white-space:nowrap}.purchase-modal .resource-separator{flex-shrink:0}.purchase-modal .mobilization-capacity{margin:.3rem .45rem .45rem;font-size:clamp(.68rem,2.8vw,.88rem);line-height:1.3;text-align:center;flex-shrink:0}.purchase-modal .unit-list{flex:0 1 auto;min-height:min(120px,20vh);max-height:min(52dvh,56vh);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:.55rem .7rem}.purchase-modal .unit-stats-key{font-size:clamp(.56rem,2.4vw,.65rem);line-height:1.35;padding:.35rem .65rem;flex-shrink:0}.purchase-modal .unit-row{display:flex;flex-wrap:nowrap;align-items:flex-start;gap:.4rem;padding:.5rem .2rem}.purchase-modal .unit-info{flex:1 1 0;min-width:0;align-items:flex-start}.purchase-modal .unit-icon-wrap{flex-shrink:0;margin-top:.12rem}.purchase-modal .unit-stat-stack{min-width:0;max-width:100%;gap:.06rem}.purchase-modal .unit-cost,.purchase-modal .quantity-controls{align-self:center;margin-top:0}.purchase-modal .unit-name{font-size:clamp(.72rem,2.6vw,.88rem);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.purchase-modal .unit-stats{font-size:clamp(.58rem,2.6vw,.68rem);word-break:break-word}.purchase-modal .unit-stats--inline{font-size:clamp(.52rem,2.4vw,.62rem);letter-spacing:-.02em;white-space:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;max-width:100%;scrollbar-width:thin;padding-bottom:2px;display:block;word-break:normal}.purchase-modal .unit-stats-specials-row{font-size:clamp(.55rem,2.2vw,.65rem);line-height:1.35;min-height:1.35em;max-width:100%;overflow-wrap:break-word;word-break:break-word}.purchase-modal .unit-stats-specials{font-size:inherit;line-height:inherit;max-width:100%}.purchase-modal .unit-details{min-width:0}.purchase-modal .unit-cost{flex:0 0 auto;width:auto;min-width:2.25rem;text-align:right}.purchase-modal .unit-cost .cost-value{white-space:nowrap;display:inline-block}.purchase-modal .quantity-controls{flex:0 0 auto;margin-left:0;gap:.35rem}.purchase-modal .quantity-controls button{width:36px;height:36px;min-width:36px;min-height:36px;font-size:1.05rem;line-height:1;touch-action:manipulation;border-radius:6px}.purchase-modal .modal-footer{flex-direction:column;align-items:stretch;gap:.75rem;padding:.75rem .85rem;padding-bottom:max(.75rem,calc(.5rem + env(safe-area-inset-bottom,0px)));flex-shrink:0}.purchase-modal .purchase-summary{font-size:.76rem;text-align:center}.purchase-modal .cost-value{font-size:clamp(.62rem,2.2vw,.72rem);line-height:1.2}.purchase-modal .quantity{min-width:1.5rem;width:auto;font-size:.8rem;padding:0 .15rem}.purchase-modal .purchase-modal-camp-icon{font-size:1.35rem;width:32px;height:32px;flex-shrink:0;margin-top:.1rem}.purchase-modal .unit-icon-wrap,.purchase-modal .unit-icon-wrap .unit-icon{width:34px;height:34px}.purchase-modal .modal-actions{flex-direction:column;width:100%;gap:.5rem}.purchase-modal .modal-actions button{width:100%;min-height:2.75rem;justify-content:center}}.combat-modal{position:relative;width:1100px;max-width:min(96vw,1200px);overflow:hidden;display:flex;flex-direction:column;min-height:0}@media(min-width:768px){.modal.combat-modal{min-height:60vh;max-height:99vh}}.combat-modal .modal-header{display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.combat-modal .modal-footer{flex-shrink:0}.combat-header-indicators{display:flex;align-items:center;gap:.75rem}.round-indicator{font-family:IM Fell English,serif;font-size:1rem;color:var(--ink-light);font-style:italic}.combat-modal-close-x{flex-shrink:0;width:2rem;height:2rem;padding:0;border:1px solid var(--ink-faded);border-radius:4px;background:var(--parchment-dark);font-size:1.5rem;line-height:1;color:var(--ink);cursor:pointer}.combat-modal-close-x:hover{background:var(--ink-faded);color:var(--parchment)}.combat-spectator-label{font-size:.85rem;color:var(--ink-light);font-style:italic}.combat-arena{position:relative;display:flex;flex-direction:column;gap:.75rem;padding:1rem;flex:1;min-height:0;overflow:hidden}.combat-result-overlay{position:absolute;inset:0;z-index:5;display:flex;align-items:center;justify-content:center;padding:1rem;box-sizing:border-box;pointer-events:none;background:#18120c38;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);animation:combatResultOverlayIn .35s ease-out}@keyframes combatResultOverlayIn{0%{opacity:0}to{opacity:1}}.combat-ladder-strip{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.combat-ladder-icon{font-size:1.25rem;line-height:1}.combat-ladder-count{font-family:Cinzel,serif;font-size:.9rem;font-weight:600;color:var(--ink)}.combat-ladder-units{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}.combat-ladder-unit-token{width:28px;height:28px;border-radius:4px;overflow:hidden;border:1px solid var(--ink-faded);background:var(--parchment);display:flex;align-items:center;justify-content:center}.combat-ladder-unit-token img{width:100%;height:100%;object-fit:contain}.combat-arena-sides{display:flex;gap:1rem;flex:1;min-height:0;align-items:stretch}.combat-side{flex:1;min-width:0;min-height:0;overflow:hidden;display:flex;flex-direction:column;gap:.65rem;padding:1rem;background:var(--parchment-light);border:3px solid var(--ink-faded);border-radius:6px}.combat-side-meta{display:flex;flex-direction:column;align-items:center;gap:.14rem;padding-top:.3rem;border-top:1px solid var(--ink-faded);flex-shrink:0}.combat-side-casualty-order,.combat-side-cumulative-hits{font-size:.7rem;color:var(--ink-faded);margin:0;line-height:1.15;text-align:center}.combat-side-cumulative-hits-text{font-weight:500}.combat-side-cumulative-hits-markers{display:flex;flex-wrap:wrap;justify-content:center;gap:.06rem .15rem;margin-top:.06rem;max-width:100%}.combat-side-cumulative-hit-x{font-size:.62rem;line-height:1;color:#b33;font-weight:700;opacity:.9}.combat-side-cumulative-hits-more{font-size:.65rem;color:var(--ink-faded);align-self:center}.combat-defender-column{display:flex;flex-direction:column;flex:1;min-width:0;min-height:0;overflow:hidden;align-items:stretch}.combat-stronghold-hp{display:flex;align-items:center;justify-content:center;gap:.35rem;padding:.25rem .5rem;font-size:.85rem;color:var(--ink);background:#0000000f;border-radius:4px}.combat-stronghold-hp--header{justify-content:flex-start;gap:.32rem;padding:.2rem .55rem;font-size:.93rem;white-space:nowrap;max-width:min(100%,13rem);min-width:0}.combat-stronghold-hp-icon{font-size:1.1rem}.combat-stronghold-hp--header .combat-stronghold-hp-icon{font-size:1.18rem;line-height:1;flex-shrink:0}.combat-stronghold-hp-value{font-weight:600}.combat-stronghold-hp--header .combat-stronghold-hp-value{min-width:0;overflow:hidden;text-overflow:ellipsis}.side-header{display:flex;align-items:center;gap:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--ink-faded);min-width:0}.side-header-trailing{display:flex;align-items:center;gap:.55rem;margin-left:auto;flex-shrink:0;min-width:0}.side-role-badge{font-family:Cinzel,serif;font-size:.75rem;font-weight:700;color:var(--ink-light);width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--parchment);border:1px solid var(--ink-faded);border-radius:4px;flex-shrink:0}.side-header .faction-icon{width:32px;height:32px;object-fit:contain}.side-title{font-family:Cinzel,serif;font-weight:600;font-size:1rem;min-width:0;flex:1 1 auto}.vs-divider{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 .5rem;gap:1rem;min-width:100px;flex-shrink:0}.vs-divider-terror{font-family:IM Fell English,serif;font-size:1rem;color:var(--ink-light);order:-1}.vs-divider>span{font-family:Cinzel,serif;font-size:1.5rem;font-weight:700;color:var(--ink-faded)}.center-roll{font-size:1rem;padding:.6rem 1.5rem;white-space:nowrap}.rolling-indicator{font-family:IM Fell English,serif;font-style:italic;color:var(--ink-light);animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.units-shelves{flex:1;min-height:0;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:.35rem;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch}.unit-row-shelf{display:flex;align-items:center;gap:.75rem;padding:.28rem .45rem;background:#00000008;border-radius:4px;box-sizing:border-box;width:100%;max-width:100%;flex:0 0 auto;height:fit-content;flex-shrink:0;min-height:62px;opacity:.5;transition:opacity .3s ease}.unit-row-shelf.revealed{opacity:1}.unit-row-shelf--siegework-split,.unit-row-shelf--attacker-ladder{align-items:flex-start;min-height:62px}.unit-row-shelf--attacker-ladder>.attacker-ladder-grid,.unit-row-shelf--attacker-ladder>.attacker-ladder-segments{flex:1 1 auto;min-width:0}.attacker-ladder-grid{display:grid;grid-template-columns:auto 1fr;grid-template-rows:min-content min-content;align-items:start;align-content:start;gap:.22rem;width:100%;min-width:0}.attacker-ladder-units{grid-row:1 / span 2;grid-column:1;flex:0 0 auto}.attacker-ladder-dice-row{grid-column:2;display:flex;align-items:flex-start;gap:.4rem;width:100%}.attacker-ladder-dice-stack{flex:1 1 auto;min-width:0;flex-wrap:wrap;justify-content:flex-start}.siegework-split-rows{display:flex;flex-direction:column;gap:.22rem;flex:1;min-width:0}.siegework-split-row{display:flex;align-items:flex-start;gap:.4rem;width:100%}.siegework-split-row-label{flex:0 0 2.25rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em;color:var(--ink-faded);padding-top:.2rem;text-align:right}.siegework-split-row-label--spacer{visibility:hidden}.siegework-split-row-units-dice{display:flex;align-items:flex-start;gap:.5rem;flex:1;min-width:0}.stat-label.stat-label--plain{color:transparent;-webkit-user-select:none;user-select:none;pointer-events:none;background:transparent;border-color:transparent;box-shadow:none}.stat-label{font-family:Cinzel,serif;font-size:1rem;font-weight:700;color:var(--ink);min-width:28px;width:28px;height:28px;text-align:center;line-height:28px;background:var(--parchment);border:2px solid var(--ink-faded);border-radius:4px;flex-shrink:0;box-sizing:border-box}.unit-stack{display:flex;flex-wrap:wrap;gap:.25rem;min-width:80px}.dice-stack{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem;flex:1;justify-content:flex-end}.dice-stack-reroll-label{font-size:.65rem;font-weight:600;color:var(--ink-faded);text-transform:uppercase;margin-left:.25rem;margin-right:.15rem}.combat-unit-group{position:relative;width:40px;height:40px;background:var(--parchment);border:3px solid var(--ink-faded);border-radius:4px;overflow:visible;transition:all .3s ease}.combat-unit-group img{width:100%;height:100%;object-fit:contain}.unit-specials-badge{position:absolute;top:-1px;left:-1px;min-width:12px;height:12px;padding:0 2px;background:#000000bf;color:var(--parchment);font-family:Cinzel,serif;font-size:.5rem;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;border-radius:0 0 4px;letter-spacing:-.5px;z-index:1}.combat-unit-passenger-badge{position:absolute;bottom:-4px;left:-4px;min-width:18px;height:18px;padding:0 4px;font-family:Cinzel,serif;font-size:.65rem;font-weight:700;line-height:18px;text-align:center;color:#fff;background:var(--gold-dark, #6b5344);border-radius:999px;border:2px solid rgba(255,255,255,.45);z-index:1;pointer-events:none}.unit-count{position:absolute;bottom:-4px;right:-4px;min-width:18px;height:18px;background:var(--ink);color:var(--parchment);font-family:Cinzel,serif;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;border-radius:9px;padding:0 4px}.unit-stack-eliminated-x{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:#c62828;text-shadow:0 0 2px white,0 0 4px white;pointer-events:none;z-index:2}.combat-unit-group.eliminated img{opacity:.5}.hits-badge{position:absolute;top:-2px;right:-2px;min-width:14px;height:14px;background:#c62828;color:#fff;font-family:Cinzel,serif;font-size:.6rem;font-weight:700;display:flex;align-items:center;justify-content:center;border-radius:7px;padding:0 2px;line-height:1}.combat-unit{position:relative;width:36px;height:36px;background:var(--parchment);border:2px solid var(--ink-faded);border-radius:4px;overflow:hidden;transition:all .3s ease}.combat-unit img{width:100%;height:100%;object-fit:contain}.combat-unit.casualty{opacity:.3;filter:grayscale(100%);border-color:#c62828}.combat-unit.casualty:after{content:"×";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5rem;font-weight:700;color:#c62828}.health-badge{position:absolute;bottom:-2px;right:-2px;min-width:14px;height:14px;background:#c62828;color:#fff;font-family:Cinzel,serif;font-size:.6rem;font-weight:700;display:flex;align-items:center;justify-content:center;border-radius:7px;padding:0 3px}.die{position:relative;width:32px;height:32px;background:var(--parchment);border:2px solid var(--ink-faded);border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3px;transition:all .2s ease}.die.placeholder{background:transparent;border-color:transparent}.die.die-blank-slot{background:#ffffff0f;border:2px dashed var(--ink-faded);box-shadow:none}.die-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:1px;width:100%;height:100%}.die .dot{width:5px;height:5px;border-radius:50%;background:transparent;justify-self:center;align-self:center}.die .dot.visible{background:var(--ink-light)}.die .tenth-dot{position:absolute;top:-1px;left:50%;transform:translate(-50%);width:5px;height:5px;border-radius:50%;background:var(--ink-light)}.die.hit{background:#c62828;border-color:#8b1c1c;box-shadow:0 0 8px #c6282880}.die.hit .dot.visible,.die.hit .tenth-dot{background:#fff}.die.miss{background:#f5f5f5;border-color:#ccc}.die.miss .dot.visible,.die.miss .tenth-dot{background:#999}.die.rerolled{outline:2px solid #c62828;outline-offset:1px}.die-reroll-x{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#c62828;text-shadow:0 0 2px white,0 0 4px white;pointer-events:none}.die.landing{animation:diceLand .3s ease-out}@keyframes diceLand{0%{transform:scale(0) translateY(-30px);opacity:0}50%{transform:scale(1.3) translateY(0);opacity:1}70%{transform:scale(.9)}85%{transform:scale(1.05)}to{transform:scale(1)}}.hits-display{margin:0;padding:0;text-align:center;opacity:0;transform:translateY(6px);transition:opacity .4s ease,transform .4s ease}.hits-display.visible{opacity:1;transform:translateY(0)}.hits-count{font-family:Cinzel,serif;font-weight:700;font-size:.95rem;line-height:1;margin:0;padding:0;display:inline-block;color:var(--gold-dark)}.combat-result-overlay .combat-result{pointer-events:auto;padding:.85rem 1.75rem;text-align:center;border:2px solid rgba(40,32,24,.45);border-radius:10px;box-shadow:0 4px 24px #0000002e,inset 0 1px #ffffff59;animation:combatResultCardIn .55s cubic-bezier(.22,1,.36,1)}@keyframes combatResultCardIn{0%{opacity:0;transform:scale(.92) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.result-text{font-family:Cinzel,serif;font-size:1.3rem;font-weight:700;color:var(--ink);text-shadow:0 1px 0 rgba(255,255,255,.25)}.combat-actions{display:flex;flex-direction:row;flex-wrap:wrap;gap:.5rem;align-items:center;justify-content:flex-start;width:100%}.combat-actions>.confirm-buttons,.combat-actions>.retreat-confirm,.combat-actions>.retreat-selection{width:100%;justify-content:center}.combat-btn-close,.combat-btn-continue{min-width:100px;font-size:1rem;padding:.5rem 1.25rem;background:linear-gradient(180deg,var(--parchment) 0%,var(--parchment-dark) 100%);border:2px solid var(--ink-faded);color:var(--ink)}.combat-btn-close:hover,.combat-btn-continue:hover{background:linear-gradient(180deg,var(--parchment-dark) 0%,var(--parchment) 100%)}.combat-btn-start,.combat-btn-retreat{min-width:100px;font-size:1rem;padding:.5rem 1.25rem;background:#c62828;border:2px solid #8b1c1c;color:#fff}.combat-btn-start:hover,.combat-btn-retreat:hover{background:#d32f2f}.combat-btn-retreat.disabled,.combat-btn-retreat:disabled{background:#6d6d6d;border-color:#4a4a4a;color:#bbb;cursor:not-allowed}.combat-btn-retreat.disabled:hover,.combat-btn-retreat:disabled:hover{background:#6d6d6d}.combat-options-pills{display:flex;flex-direction:row;align-items:center;gap:1rem;margin-left:auto}.combat-options-row{display:flex;flex-direction:column;align-items:center;gap:.2rem}.combat-options-field-label{font-size:.7rem;color:var(--ink-faded);text-transform:none;font-family:inherit}.combat-pill-group{display:inline-flex;border:2px solid var(--ink-faded);border-radius:6px;overflow:hidden;background:var(--parchment-dark, #e8e0d0)}.combat-pill{font-size:.8rem;padding:.35rem .6rem;border:none;border-radius:0;background:transparent;color:var(--ink-faded);cursor:pointer;transition:color .15s ease,background .15s ease}.combat-pill--segmented-left{border-right:1px solid var(--ink-faded)}.combat-pill--segmented-right{border-left:1px solid transparent}.combat-pill:hover{color:var(--ink);background:#8b73551f}.combat-pill--active{color:var(--ink);background:var(--parchment);box-shadow:inset 0 0 0 1px #8b735540}.combat-pill:disabled{opacity:.55;cursor:not-allowed}.combat-pill:disabled:hover{color:var(--ink-faded);background:transparent}.retreat-btn{background:#8b4513;border-color:#5d2e0d;color:var(--parchment)}.retreat-btn:hover{background:sienna}.retreat-confirm{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%}.confirm-message{font-family:IM Fell English,serif;font-size:1rem;color:var(--ink);text-align:center;margin:0}.confirm-buttons{display:flex;gap:.75rem}button.danger{background:#c62828;border-color:#8b1c1c;color:#fff}button.danger:hover{background:#d32f2f}.retreat-selection{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%}.selection-message{font-family:IM Fell English,serif;font-size:1rem;color:var(--ink);text-align:center;margin:0}.retreat-options{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;max-width:100%}.retreat-option{background:var(--parchment);border:2px solid var(--gold-dark);color:var(--ink);padding:.5rem 1rem;font-family:IM Fell English,serif;font-size:.9rem;cursor:pointer;transition:all .2s ease}.retreat-option:hover{background:var(--gold-light);border-color:var(--gold-dark);transform:translateY(-2px)}.cancel-retreat{font-size:.85rem;padding:.4rem 1rem;opacity:.8}.cancel-retreat:hover{opacity:1}.close-btn{font-size:1.1rem;padding:.75rem 2rem}@media(max-width:767px){.combat-modal{width:100%;max-height:min(92dvh,92vh);min-height:0}.combat-modal .modal-header{flex-wrap:wrap;align-items:flex-start;gap:.35rem;padding:.45rem .65rem;border-bottom:1px solid var(--ink-faded)}.combat-modal .modal-header h2{flex:1 1 100%;min-width:0;margin:0;font-size:clamp(.88rem,3.8vw,1.05rem);line-height:1.25;word-break:break-word}.combat-header-indicators{flex-wrap:wrap;gap:.35rem;max-width:100%}.round-indicator{font-size:.85rem}.combat-modal .modal-header:has(.combat-modal-close-x){position:relative;padding-right:2.75rem}.combat-modal-close-x{position:absolute;top:.35rem;right:.35rem}.combat-arena{padding:.35rem .45rem;min-height:0;flex:1 1 auto;-webkit-overflow-scrolling:touch;overflow-x:hidden;overflow-y:auto}.combat-arena-sides>.combat-side,.combat-arena-sides>.vs-divider,.combat-arena-sides>.combat-defender-column{flex:0 0 auto}.combat-defender-column,.combat-side{overflow:visible;min-height:0}.combat-arena-sides{flex-direction:column;gap:.4rem;align-items:stretch;min-height:0}.combat-defender-column{width:100%;min-width:0}.combat-side{padding:.45rem .5rem;min-width:0;gap:.52rem}.combat-side-meta{padding-top:.22rem;gap:.1rem}.side-title{font-size:.88rem}.side-header .faction-icon{width:26px;height:26px}.side-role-badge{width:20px;height:20px;font-size:.65rem}.side-header-trailing{gap:.32rem}.combat-stronghold-hp--header{font-size:.76rem;padding:.13rem .36rem;max-width:9.25rem;gap:.22rem}.combat-stronghold-hp--header .combat-stronghold-hp-icon{font-size:.95rem}.vs-divider{flex-direction:row;flex-wrap:wrap;justify-content:center;align-items:center;min-width:0;width:100%;padding:.3rem .35rem;gap:.35rem .75rem;border-top:1px solid var(--ink-faded);border-bottom:1px solid var(--ink-faded);background:#3d29140f}.vs-divider>span{font-size:1.15rem}.vs-divider-terror{font-size:.85rem;order:0}.rolling-indicator{font-size:.8rem;width:100%;text-align:center}.units-shelves{flex:0 0 auto;min-height:0;overflow:visible;gap:.35rem}.unit-row-shelf{flex-wrap:wrap;align-items:flex-start;gap:.35rem;padding:.26rem .35rem;flex-shrink:0;min-height:60px}.unit-row-shelf--siegework-split,.unit-row-shelf--attacker-ladder{min-height:60px}.stat-label{font-size:.85rem;min-width:24px;width:24px;height:24px;line-height:24px}.unit-stack{min-width:0;flex:1 1 auto}.combat-unit-group{width:32px;height:32px;border-width:2px}.unit-count{min-width:15px;height:15px;font-size:.6rem;bottom:-3px;right:-3px}.dice-stack{justify-content:flex-start;flex:1 1 100%;min-width:0}.die{width:26px;height:26px;padding:2px}.die .dot{width:4px;height:4px}.die-reroll-x{font-size:18px}.hits-count{font-size:.88rem}.combat-side-casualty-order,.combat-side-cumulative-hits{font-size:.65rem}.combat-result-overlay .combat-result{padding:.45rem .85rem}.result-text{font-size:1.05rem}.combat-ladder-unit-token{width:24px;height:24px}.combat-modal .modal-footer{flex-direction:column;align-items:stretch;gap:.55rem;padding:.55rem .65rem;padding-bottom:max(.55rem,env(safe-area-inset-bottom,0px))}.combat-modal .combat-actions{flex-direction:row;flex-wrap:wrap;align-items:stretch;gap:.45rem;width:100%}.combat-modal .combat-actions>.combat-btn-close,.combat-modal .combat-actions>.combat-btn-start,.combat-modal .combat-actions>.combat-btn-retreat,.combat-modal .combat-actions>.combat-btn-continue{flex:1 1 calc(50% - .25rem);min-width:min(140px,42vw);min-height:44px;box-sizing:border-box}.combat-modal .combat-actions>.combat-spectator-label{flex:1 1 100%;width:100%;text-align:center;padding:.35rem 0}.combat-modal .combat-options-pills{margin-left:0;width:100%;flex:1 1 100%;flex-direction:column;align-items:stretch;gap:.45rem}.combat-modal .combat-options-row{width:100%}.combat-modal .combat-pill-group{display:flex;width:100%;justify-content:stretch}.combat-modal .combat-pill{flex:1;font-size:.75rem;padding:.4rem .35rem;min-height:40px}.combat-modal .retreat-confirm .confirm-buttons,.combat-modal .retreat-selection .retreat-options{flex-direction:column;width:100%}.combat-modal .retreat-option{width:100%;min-height:44px}}.lobby-view-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:900;padding:1.5rem;box-sizing:border-box}.lobby-view{display:flex;flex-direction:column;background:var(--parchment, #f4efe0);font-family:var(--font-parchment);color:var(--ink);max-width:480px;width:100%;max-height:calc(100vh - 3rem);overflow:auto;-webkit-overflow-scrolling:touch;border-radius:12px;box-shadow:0 12px 40px #00000059;border:2px solid var(--gold-dark, rgba(139, 115, 85, .4))}.lobby-view__header{padding:1.5rem 2rem;text-align:center;border-bottom:1px solid var(--ink-faded, rgba(0, 0, 0, .2))}.lobby-view__title{font-family:Cinzel,serif;font-size:1.75rem;margin:0 0 .5rem;color:var(--ink)}.lobby-view__code{margin:0;font-size:1rem;color:var(--ink-faded)}.lobby-view__code-value{font-family:ui-monospace,monospace;letter-spacing:.15em;color:var(--ink)}.lobby-view__scenario{padding:1.25rem 2rem}.lobby-view__scenario-name{margin:0 0 .35rem;font-size:1rem;font-weight:600;color:var(--ink)}.lobby-view__scenario-desc{margin:0;font-size:.9rem;color:var(--ink-faded)}.lobby-view__scenario-factions{color:var(--ink-faded)}.lobby-view__factions{flex:1;padding:0 2rem 1.5rem}.lobby-view__error{margin:0 0 .75rem;padding:.5rem .75rem;background:#c628281a;color:#c62828;border-radius:6px;font-size:.9rem}.lobby-view__alliance-shortcuts{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;margin-bottom:.75rem;padding:.5rem 0}.lobby-view__alliance-row{display:inline-flex;align-items:center;gap:.5rem}.lobby-view__alliance-label{font-size:.9rem;font-weight:500;color:var(--ink);white-space:nowrap}.lobby-view__faction-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem;max-width:420px}.lobby-view__faction-row{display:flex;align-items:center;gap:1rem;padding:.6rem .9rem;background:var(--parchment-dark, #e8e0d0);border:2px solid transparent;border-radius:8px;transition:border-color .15s ease,background .15s ease}.lobby-view__faction-row:hover{border-color:var(--gold-dark, rgba(139, 115, 85, .4))}.lobby-view__faction-logo-wrap{display:flex;align-items:stretch;flex-shrink:0;gap:8px}.lobby-view__faction-color-bar{width:10px;flex-shrink:0;min-height:40px;border-radius:0;opacity:.8}.lobby-view__faction-logo{flex-shrink:0;width:40px;height:40px;border-radius:6px;overflow:hidden;background:#0000000f}.lobby-view__faction-logo img{width:100%;height:100%;object-fit:contain}.lobby-view__faction-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.lobby-view__faction-name{font-weight:600;font-size:1rem}.lobby-view__faction-claimant{font-size:.85rem;color:var(--ink-faded)}.lobby-view__faction-actions{flex-shrink:0}.lobby-view__pill{display:inline-block;padding:.35rem .75rem;font-size:.85rem;font-weight:500;border-radius:999px;border:2px solid transparent;cursor:default;transition:background .15s ease,border-color .15s ease,color .15s ease}.lobby-view__pill--claim{background:var(--gold-dark, #8b7355);color:#fff;border-color:var(--gold-dark, #8b7355);cursor:pointer;font-family:inherit}.lobby-view__pill--claim:hover:not(:disabled){background:#7a6449;border-color:#7a6449}.lobby-view__pill--claim:disabled{opacity:.7;cursor:not-allowed}.lobby-view__pill--claimed{background:transparent;color:var(--gold-dark, #8b7355);border-color:var(--gold-dark, #8b7355);cursor:pointer;font-family:inherit}.lobby-view__pill--claimed:hover:not(:disabled){background:#8b73551a}.lobby-view__pill--taken{background:#00000014;color:var(--ink-faded);border-color:#0000001f}.lobby-view__pill--disabled{background:#0000000d;color:var(--ink-faded);border-color:transparent}.lobby-view__binary-pills{display:inline-flex;border:2px solid var(--gold-dark, #8b7355);border-radius:8px;overflow:hidden;background:#8b735514}.lobby-view__binary-pills .lobby-view__pill{margin:0;border:none;border-radius:0;min-width:4.5rem;padding:.4rem .85rem;font-family:inherit;background:transparent;color:var(--ink-faded);cursor:pointer;border-right:1px solid rgba(139,115,85,.35);transition:background .15s ease,color .15s ease}.lobby-view__binary-pills .lobby-view__pill:last-child{border-right:none}.lobby-view__binary-pills .lobby-view__pill:hover:not(:disabled){background:#8b73551f;color:var(--ink)}.lobby-view__binary-pills .lobby-view__pill--selected{background:var(--gold-dark, #8b7355);color:#fff;font-weight:600}.lobby-view__binary-pills .lobby-view__pill--selected:hover:not(:disabled){background:#7a6449;color:#fff}.lobby-view__binary-pills .lobby-view__pill:disabled{opacity:.8;cursor:not-allowed}.lobby-view__footer{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 2rem;border-top:1px solid var(--ink-faded, rgba(0, 0, 0, .2));gap:1rem}.lobby-view__menu-btn{display:inline-block;padding:.5rem 1rem;font-size:.95rem;font-weight:500;font-family:inherit;color:var(--ink);background:var(--parchment-dark, #e8e0d0);border:2px solid var(--ink-faded);border-radius:6px;text-decoration:none;cursor:pointer;transition:border-color .15s ease,background .15s ease}.lobby-view__menu-btn:hover{border-color:var(--gold-dark, #8b7355);background:#8b735514}.lobby-view__start-area{display:flex;align-items:center;justify-content:flex-end}.lobby-view__start-btn{padding:.5rem 1.25rem;font-size:1rem;font-family:inherit;border-radius:6px;border:2px solid var(--gold-dark, #8b7355);background:var(--gold-dark, #8b7355);color:#fff;cursor:pointer}.lobby-view__start-btn:hover:not(:disabled){background:#7a6449;border-color:#7a6449}.lobby-view__start-btn:disabled{opacity:.6;cursor:not-allowed}.lobby-view__waiting{font-size:.95rem;color:var(--ink-faded);font-style:italic}.lobby-view__confirm-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.lobby-view__confirm-box{background:var(--parchment);padding:1.5rem 1.75rem;border-radius:10px;max-width:420px;box-shadow:0 8px 24px #0003}.lobby-view__confirm-text{margin:0 0 1.25rem;font-size:.95rem;line-height:1.5;color:var(--ink)}.lobby-view__confirm-actions{display:flex;justify-content:flex-end;gap:.75rem}.lobby-view__confirm-btn{padding:.45rem 1rem;font-size:.95rem;font-family:inherit;border-radius:6px;border:2px solid var(--ink-faded);background:transparent;color:var(--ink);cursor:pointer}.lobby-view__confirm-btn.primary{background:var(--gold-dark, #8b7355);border-color:var(--gold-dark, #8b7355);color:#fff}.lobby-view__confirm-btn.primary:hover:not(:disabled){background:#7a6449;border-color:#7a6449}.lobby-view__confirm-btn:disabled{opacity:.7;cursor:not-allowed}@media(max-width:767px){.lobby-view-overlay{align-items:stretch;justify-content:flex-end;padding:max(.5rem,env(safe-area-inset-top,0px)) max(.5rem,env(safe-area-inset-right,0px)) max(.5rem,env(safe-area-inset-bottom,0px)) max(.5rem,env(safe-area-inset-left,0px))}.lobby-view{max-width:none;width:100%;max-height:min(100dvh,100vh);border-radius:12px 12px 0 0;margin:0 auto;box-sizing:border-box}.lobby-view__header{padding:1rem 1rem .85rem}.lobby-view__title{font-size:clamp(1.15rem,4.5vw,1.75rem);word-break:break-word}.lobby-view__code{font-size:.9rem}.lobby-view__scenario{padding:1rem}.lobby-view__factions{padding:0 1rem 1rem}.lobby-view__faction-list{max-width:none}.lobby-view__alliance-shortcuts{flex-direction:column;align-items:stretch;gap:.65rem}.lobby-view__alliance-row{flex-direction:column;align-items:stretch;gap:.45rem}.lobby-view__alliance-label{white-space:normal}.lobby-view__binary-pills{width:100%;justify-content:stretch}.lobby-view__binary-pills .lobby-view__pill{flex:1 1 0;min-width:0;min-height:2.75rem;display:inline-flex;align-items:center;justify-content:center}.lobby-view__faction-row{display:grid;grid-template-columns:auto minmax(0,1fr);grid-template-rows:auto auto;gap:.5rem .75rem;align-items:start;padding:.65rem .75rem}.lobby-view__faction-logo-wrap{grid-column:1;grid-row:1}.lobby-view__faction-info{grid-column:2;grid-row:1;min-width:0}.lobby-view__faction-actions{grid-column:1 / -1;grid-row:2;width:100%;justify-self:stretch}.lobby-view__faction-actions .lobby-view__binary-pills{width:100%}.lobby-view__faction-actions>.lobby-view__pill{width:100%;min-height:2.75rem;text-align:center;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center}.lobby-view__faction-actions .lobby-view__pill--taken,.lobby-view__faction-actions .lobby-view__pill--disabled{display:flex;align-items:center;justify-content:center;min-height:2.5rem}.lobby-view__footer{flex-direction:column;align-items:stretch;padding:1rem;gap:.75rem}.lobby-view__start-area{justify-content:stretch;width:100%}.lobby-view__menu-btn{text-align:center;min-height:2.75rem;display:flex;align-items:center;justify-content:center;box-sizing:border-box}.lobby-view__start-btn{width:100%;min-height:2.85rem;box-sizing:border-box}.lobby-view__waiting{text-align:center}.lobby-view__confirm-overlay{padding:max(.75rem,env(safe-area-inset-top,0px)) max(.75rem,env(safe-area-inset-right,0px)) max(.75rem,env(safe-area-inset-bottom,0px)) max(.75rem,env(safe-area-inset-left,0px));box-sizing:border-box}.lobby-view__confirm-box{max-width:none;width:min(100%,420px);margin:0 auto;max-height:min(90dvh,90vh);overflow-y:auto;-webkit-overflow-scrolling:touch}.lobby-view__confirm-actions{flex-wrap:wrap;justify-content:stretch;gap:.5rem}.lobby-view__confirm-actions .lobby-view__confirm-btn{flex:1 1 calc(50% - .25rem);min-height:2.75rem}}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden;position:relative}.game-over-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:1000;pointer-events:none}.game-over-banner{padding:1.5rem 2.5rem;border:3px solid;border-radius:8px;box-shadow:0 4px 24px #0000004d;display:flex;flex-direction:column;align-items:center;gap:.5rem}.game-over-title{font-family:var(--font-display);font-size:1rem;font-weight:600;letter-spacing:.1em;color:var(--ink)}.game-over-winner{font-family:var(--font-display);font-size:1.75rem;font-weight:700;color:var(--ink)}.forfeit-notification-toast{position:fixed;top:.75rem;left:50%;transform:translate(-50%);z-index:999;display:flex;align-items:flex-start;gap:.75rem;max-width:min(90vw,420px);padding:.75rem 1rem;background:var(--parchment, #f5f0e6);border:1px solid var(--ink-faded, #8a8478);border-radius:6px;box-shadow:0 4px 12px #00000026;font-family:var(--font-parchment);font-size:.9rem;color:var(--ink)}.forfeit-notification-toast p{margin:0;flex:1;line-height:1.4}.forfeit-notification-toast-close{flex-shrink:0;width:1.5rem;height:1.5rem;padding:0;border:none;background:transparent;font-size:1.25rem;line-height:1;color:var(--ink-light);cursor:pointer;border-radius:2px}.forfeit-notification-toast-close:hover{color:var(--ink);background:#0000000f}.app.loading,.app.error{align-items:center;justify-content:center;padding:2rem}.loading-spinner,.error-message{font-family:var(--font-parchment);color:var(--ink);text-align:center}.loading-spinner{font-size:1.25rem}.error-message h2{margin-bottom:.5rem}.error-message p{margin-bottom:1rem;color:var(--ink-light)}.main-content{flex:1;display:flex;overflow:hidden;position:relative;min-height:0}.main-content>.sidebar-wrapper:not(.collapsed){align-self:stretch;min-height:0;display:flex;flex-direction:column;max-height:100%}.main-content>.sidebar-wrapper:not(.collapsed)>.sidebar{flex:1;min-height:0}.map-and-tray{flex:1;min-width:0;display:flex;flex-direction:column;min-height:0}.sidebar-wrapper{flex-shrink:0;background:var(--parchment-light);border-left:2px solid var(--ink-faded);position:relative;transition:width .2s ease;min-width:0;min-height:0}@media(max-width:767px){.sidebar-wrapper:not(.collapsed){max-width:min(100vw,100%)}.sidebar-resize-handle{display:none}}.sidebar-wrapper.collapsed{width:0;min-width:0;overflow:visible;border-left:none}.sidebar-resize-handle{flex-shrink:0;width:6px;cursor:col-resize;background:var(--ink-faded);transition:background .15s}.sidebar-resize-handle:hover,.sidebar-resize-handle:active{background:var(--gold-dark)}.sidebar-toggle{position:absolute;left:-32px;top:8px;width:28px;height:28px;padding:0;border:2px solid var(--ink-faded);border-right:none;border-radius:6px 0 0 6px;background:var(--parchment-light);cursor:pointer;font-size:1rem;line-height:1;z-index:10;box-shadow:-2px 0 4px #0000001a}.sidebar-wrapper.collapsed .sidebar-toggle{left:auto;right:0;border-right:2px solid var(--ink-faded);border-radius:6px;box-shadow:2px 0 4px #0000001a}.sidebar-toggle:hover{background:var(--parchment)}@media(max-width:767px){.sidebar-toggle{left:-26px;width:24px;height:24px;font-size:.82rem;border-width:1px}.sidebar-wrapper.collapsed .sidebar-toggle{border-width:1px}}.combat-sim-modal-overlay{position:fixed;inset:0;z-index:1000;background:#0006;display:flex;align-items:center;justify-content:center;padding:max(1rem,env(safe-area-inset-top,0px)) max(1rem,env(safe-area-inset-right,0px)) max(1rem,env(safe-area-inset-bottom,0px)) max(1rem,env(safe-area-inset-left,0px));overflow:auto;box-sizing:border-box}.combat-sim-modal{background:var(--parchment);border:2px solid var(--ink-faded);border-radius:8px;box-shadow:0 8px 32px var(--shadow);min-width:min(560px,100%);max-width:min(92vw,900px);width:min(92vw,900px);max-height:calc(100vh - 4rem);max-height:min(calc(100dvh - 2rem),calc(100vh - 4rem));min-height:min(420px,70dvh);display:flex;flex-direction:column;flex-shrink:0}@media(max-width:767px){.combat-sim-modal-overlay{align-items:flex-end;padding:0;padding-bottom:env(safe-area-inset-bottom,0px)}.combat-sim-modal{min-width:0!important;width:100%!important;max-width:100%!important;border-radius:12px 12px 0 0;min-height:min(50dvh,360px);max-height:min(92dvh,92vh)!important}.combat-sim-modal-body{min-height:0}}.combat-sim-modal-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--ink-faded);flex-shrink:0}.combat-sim-modal-header h2{margin:0;font-size:1.15rem;font-weight:600;color:var(--ink)}.combat-sim-modal .close-btn{background:none;border:none;font-size:1.6rem;color:var(--ink-faded);cursor:pointer;padding:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center}.combat-sim-modal .close-btn:hover{color:var(--ink)}.combat-sim-modal-body{padding:1rem;overflow:auto;flex:1;min-height:320px}.map-wrap{flex:1;min-height:0;position:relative;display:flex;flex-direction:column}.main-menu{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:var(--parchment)}.main-menu--loading{font-family:var(--font-parchment);color:var(--ink-faded)}.main-menu__title{font-family:Cinzel,serif;font-size:2.5rem;color:var(--ink);margin-bottom:.5rem;text-align:center}.main-menu__subtitle{font-family:var(--font-parchment);font-size:1.35rem;color:var(--ink-light);margin-bottom:.75rem}.main-menu__quote{font-family:var(--font-parchment);font-size:1.2rem;color:var(--ink-faded);font-style:italic;margin-bottom:2rem;text-align:center;max-width:320px}.main-menu__quote-attribution{white-space:nowrap}.main-menu__actions{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:280px}.main-menu__btn{padding:.75rem 1.25rem;font-size:1rem}@media(max-width:767px){.main-menu{padding:max(1rem,env(safe-area-inset-top,0px)) max(1rem,env(safe-area-inset-right,0px)) max(1.5rem,env(safe-area-inset-bottom,0px)) max(1rem,env(safe-area-inset-left,0px));justify-content:flex-start;padding-top:max(2rem,env(safe-area-inset-top,0px));align-items:center;text-align:center}.main-menu__title{font-size:clamp(1.5rem,7vw,2.5rem);width:100%;max-width:min(320px,100%);box-sizing:border-box}.main-menu__quote{margin-left:auto;margin-right:auto}.main-menu__actions{max-width:min(280px,100%);width:100%;align-self:center;align-items:stretch}.main-menu__btn{width:100%;box-sizing:border-box}.main-menu--loading{text-align:center;width:100%}}.main-menu__user{margin-top:1.5rem;font-family:var(--font-parchment);font-size:.9rem;color:var(--ink-faded);text-align:center}.auth-page{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:var(--parchment);box-sizing:border-box}@media(max-width:767px){.auth-page{padding:max(1rem,env(safe-area-inset-top,0px)) max(.75rem,env(safe-area-inset-right,0px)) max(1.25rem,env(safe-area-inset-bottom,0px)) max(.75rem,env(safe-area-inset-left,0px));align-items:center}.auth-page__title{text-align:center;width:100%;max-width:320px;box-sizing:border-box}.auth-form{width:100%;max-width:320px;box-sizing:border-box}.auth-page__footer{text-align:center;width:100%;max-width:320px;box-sizing:border-box}}.auth-page__title{font-family:Cinzel,serif;font-size:1.75rem;color:var(--ink);margin-bottom:1.5rem}.auth-form{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:320px}.auth-form__error{color:#c62828;font-size:.9rem;margin:0}.auth-form__label{display:flex;flex-direction:column;gap:.35rem;font-family:var(--font-parchment);font-size:.95rem;color:var(--ink)}.auth-form__input{padding:.5rem .75rem;font-size:1rem;border:2px solid var(--ink-faded);border-radius:4px;background:var(--parchment-light)}.auth-form__submit{margin-top:.5rem}.auth-page__footer{margin-top:1.5rem;font-family:var(--font-parchment);font-size:.95rem;color:var(--ink-light)}.auth-page__footer a{color:var(--gold-dark)}.create-game-page{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:var(--parchment);box-sizing:border-box}@media(max-width:767px){.create-game-page{padding:max(1rem,env(safe-area-inset-top,0px)) max(.75rem,env(safe-area-inset-right,0px)) max(1.25rem,env(safe-area-inset-bottom,0px)) max(.75rem,env(safe-area-inset-left,0px));align-items:stretch}.create-game-form{max-width:none}}.create-game-page__title{font-family:Cinzel,serif;font-size:1.75rem;color:var(--ink);margin-bottom:1.5rem}.create-game-form{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:360px}.create-game-form__error{color:#c62828;font-size:.9rem;margin:0}.create-game-form__label{font-family:var(--font-parchment);font-size:.95rem;color:var(--ink);display:flex;flex-direction:column;gap:.35rem}.create-game-form__label--row{flex-direction:row;align-items:center}.create-game-form__field{display:flex;flex-direction:column;gap:.35rem}.create-game-form__field-label{font-family:var(--font-parchment);font-size:.95rem;color:var(--ink)}.create-game-form__hint{font-size:.9rem;color:var(--ink-faded);margin:0}.create-game-form__scenarios{display:flex;flex-direction:column;gap:.5rem}.create-game-form__scenario{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;padding:.6rem .75rem;font-size:.95rem;text-align:left;color:var(--ink-faded);background:var(--parchment-dark, #e8e0d0);border:2px solid var(--ink-faded);border-radius:6px;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.create-game-form__scenario:hover{color:var(--ink);border-color:var(--gold-dark, #8b7355)}.create-game-form__scenario--active{color:var(--ink);background:var(--parchment);border-color:var(--gold-dark, #8b7355);box-shadow:inset 0 0 0 2px #8b735533}.create-game-form__scenario-name{font-weight:600}.create-game-form__scenario-context{font-size:.75rem;color:var(--ink-faded)}.create-game-form__scenario--active .create-game-form__scenario-context{color:var(--ink)}.create-game-form__scenario-factions{display:block;margin-top:.35rem;font-size:.6rem;font-family:var(--font-parchment);color:var(--ink-faded)}.create-game-form__scenario--active .create-game-form__scenario-factions{color:var(--ink)}.create-game-form__picker{display:flex;border:2px solid var(--ink-faded);border-radius:6px;overflow:hidden;background:var(--parchment-dark, #e8e0d0)}.create-game-form__picker-option{flex:1;padding:.6rem 1rem;font-size:.95rem;font-weight:500;color:var(--ink-faded);background:transparent;border:none;cursor:pointer;transition:background .15s ease,color .15s ease}.create-game-form__picker-option:first-of-type{border-right:1px solid var(--ink-faded)}.create-game-form__picker-option:hover{color:var(--ink);background:#0000000a}.create-game-form__picker-option--active{color:var(--ink);background:var(--parchment);box-shadow:inset 0 0 0 2px var(--gold-dark, #8b7355)}.create-game-form__input{padding:.5rem .75rem;font-size:1rem;border:2px solid var(--ink-faded);border-radius:4px;background:var(--parchment-light)}.create-game-form__submit{margin-top:.5rem}.create-game-page__menu-btn{display:inline-block;margin-top:1.5rem;padding:.5rem 1.25rem;font-size:.95rem;font-weight:500;color:var(--ink);background:var(--parchment-dark, #e8e0d0);border:2px solid var(--ink-faded);border-radius:6px;text-decoration:none;cursor:pointer;transition:border-color .15s ease,background .15s ease}.create-game-page__menu-btn:hover{border-color:var(--gold-dark, #8b7355);background:#8b735514}.game-list-page{min-height:100vh;min-height:100dvh;padding:2rem;padding-top:max(2rem,env(safe-area-inset-top,0px));background:var(--parchment);box-sizing:border-box}.game-list-page__header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:flex-start;gap:.75rem 1rem;margin-bottom:1.5rem}.game-list-page__hint{font-size:.95rem;color:#5c5346;margin:0 0 1rem;font-family:var(--font-parchment, system-ui, sans-serif)}.game-list-page__menu-btn{display:inline-block;margin-bottom:0;flex-shrink:0;padding:.5rem 1.25rem;font-size:.95rem;font-weight:500;color:var(--ink);background:var(--parchment-dark, #e8e0d0);border:2px solid var(--ink-faded);border-radius:6px;text-decoration:none;cursor:pointer;transition:border-color .15s ease,background .15s ease}.game-list-page__menu-btn:hover{border-color:var(--gold-dark, #8b7355);background:#8b735514}.game-list__error{color:#c62828}.game-list__empty{font-family:var(--font-parchment);color:var(--ink-faded)}.game-list{list-style:none;padding:0;margin:0;max-width:min(620px,100%);width:100%}.game-list__item{margin-bottom:.75rem}.game-list__card{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:var(--parchment-dark, #e8e0d0);border:1px solid rgba(0,0,0,.1);border-radius:8px;cursor:pointer;text-align:left;width:100%;transition:box-shadow .15s ease,border-color .15s ease}.game-list__card:hover{box-shadow:0 2px 8px #00000014;border-color:var(--gold-dark, #8b7355)}.game-list__card-main{flex:1;min-width:0}.game-list__name{margin:0 0 .5rem;font-size:1.1rem;font-weight:600;color:var(--ink)}.game-list__turn-info{display:flex;flex-direction:column;gap:.25rem;font-size:.9rem;color:var(--ink-faded)}.game-list__faction-row{display:inline-flex;flex-wrap:wrap;align-items:center;gap:.35rem .5rem;max-width:100%}.game-list__faction-icon{width:28px;height:28px;object-fit:contain}.game-list__faction-name,.game-list__player-name{font-size:1.15rem;font-weight:400;color:var(--ink)}.game-list__stronghold-bar-wrap{flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;width:96px;min-width:96px}.game-list__turn-meta{display:flex;align-items:center;gap:.35rem}.game-list__turn-meta--lobby{font-size:1.15rem;font-weight:400;color:var(--ink)}.game-list__lobby-stats{font-size:.9rem;color:var(--ink-faded)}.game-list__meta-sep{opacity:.6}.game-list__created{display:block;font-size:.8rem;color:var(--ink-faded);margin-top:.25rem}.game-list__card-actions{display:flex;flex-shrink:0;align-items:center;gap:.5rem}.game-list__delete-btn{flex-shrink:0;padding:.5rem .75rem;font-size:.85rem;font-weight:500;color:#c62828;background:transparent;border:1px solid #c62828;cursor:pointer;border-radius:6px;transition:background .15s ease,color .15s ease}.game-list__delete-btn:hover{background:#c62828;color:#fff}.game-list__forfeit-btn{flex-shrink:0;padding:.5rem .75rem;font-size:.85rem;font-weight:500;color:var(--gold-dark, #8b7355);background:transparent;border:1px solid var(--gold-dark, #8b7355);cursor:pointer;border-radius:6px;transition:background .15s ease,color .15s ease}.game-list__forfeit-btn:hover{background:var(--gold-dark, #8b7355);color:#fff}.game-list__modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:max(.75rem,env(safe-area-inset-top)) max(.75rem,env(safe-area-inset-right)) max(.75rem,env(safe-area-inset-bottom)) max(.75rem,env(safe-area-inset-left));box-sizing:border-box}.game-list__modal{background:var(--parchment);padding:1.5rem;border-radius:8px;max-width:min(400px,100%);width:min(400px,100%);max-height:min(90vh,90dvh);overflow-y:auto;box-shadow:0 4px 20px #0003;-webkit-overflow-scrolling:touch}.game-list__modal-title{margin:0 0 .75rem;font-size:1.25rem}.game-list__modal-text{margin:0 0 1rem;font-size:.95rem;color:var(--ink)}.game-list__modal-input{width:100%;padding:.5rem .75rem;margin-bottom:1rem;font-size:1rem;border:1px solid var(--ink-faded);border-radius:4px;box-sizing:border-box}.game-list__modal-actions{display:flex;gap:.5rem;justify-content:flex-end}.game-list__modal-btn{padding:.5rem 1rem;border-radius:4px;cursor:pointer;border:1px solid var(--ink-faded);background:var(--parchment-dark)}.game-list__modal-btn--danger{background:#c62828;color:#fff;border-color:#c62828}.game-list__modal-btn--danger:disabled{opacity:.5;cursor:not-allowed}.game-list__name{font-weight:600;display:block}.game-list__meta{font-size:.85rem;color:var(--ink-faded)}@media(max-width:767px){.game-list-page{padding:max(.75rem,env(safe-area-inset-left,0px)) max(.75rem,env(safe-area-inset-right,0px)) 1.25rem;padding-top:max(.75rem,env(safe-area-inset-top,0px))}.game-list-page__header{margin-bottom:1rem}.game-list__item{margin-bottom:.65rem}.game-list__card{flex-direction:column;align-items:stretch;gap:.65rem;padding:.85rem 1rem}.game-list__name{font-size:clamp(1rem,4vw,1.1rem);word-break:break-word}.game-list__faction-name,.game-list__player-name,.game-list__turn-meta--lobby{font-size:clamp(.95rem,3.8vw,1.15rem)}.game-list__stronghold-bar-wrap{width:100%;min-width:0;max-width:none;align-items:stretch}.game-list__stronghold-bar-wrap .stronghold-alliance-bar{width:100%;min-width:0}.game-list__stronghold-bar-wrap .stronghold-alliance-bar__label{text-align:center;align-self:center}.game-list__card-actions{width:100%;justify-content:stretch;gap:.5rem}.game-list__forfeit-btn,.game-list__delete-btn{flex:1 1 0;min-width:0;min-height:2.75rem;display:inline-flex;align-items:center;justify-content:center;text-align:center}.game-list__modal{width:100%;max-width:none;padding:1.1rem}.game-list__modal-actions{flex-wrap:wrap;justify-content:stretch;gap:.5rem}.game-list__modal-actions .game-list__modal-btn{flex:1 1 calc(50% - .25rem);min-height:2.75rem}}.join-game-page{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;background:var(--parchment);box-sizing:border-box}@media(max-width:767px){.join-game-page{padding:max(1rem,env(safe-area-inset-top,0px)) max(.75rem,env(safe-area-inset-right,0px)) max(1.25rem,env(safe-area-inset-bottom,0px)) max(.75rem,env(safe-area-inset-left,0px));align-items:center}.join-game-page__title{width:100%;text-align:center}.join-game-form{width:min(100%,280px);max-width:280px;align-self:center}.join-game-page__menu-btn{align-self:center}}.join-game-page__title{font-family:Cinzel,serif;font-size:1.75rem;color:var(--ink);margin-bottom:1.5rem}.join-game-form{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:280px}.join-game-form__error{color:#c62828;font-size:.9rem;margin:0}.join-game-form__label{font-family:var(--font-parchment);font-size:.95rem;color:var(--ink);display:flex;flex-direction:column;gap:.35rem}.join-game-form__input{padding:.5rem .75rem;font-size:1.25rem;letter-spacing:.2em;text-align:center;border:2px solid var(--ink-faded);border-radius:4px;background:var(--parchment-light)}.join-game-form__submit{margin-top:.5rem}.join-game-page__menu-btn{display:inline-block;margin-top:1.5rem;padding:.5rem 1.25rem;font-size:.95rem;font-weight:500;color:var(--ink);background:var(--parchment-dark, #e8e0d0);border:2px solid var(--ink-faded);border-radius:6px;text-decoration:none;cursor:pointer;transition:border-color .15s ease,background .15s ease}.join-game-page__menu-btn:hover{border-color:var(--gold-dark, #8b7355);background:#8b735514}.profile-page{font-family:var(--font-parchment);min-height:100vh;min-height:100dvh;padding:2rem;padding-top:max(2rem,env(safe-area-inset-top,0px));background:var(--parchment);box-sizing:border-box}.profile-page h1,.profile-page button,.profile-page input{font-family:inherit}.profile-page button{text-transform:none;letter-spacing:normal}@media(max-width:767px){.profile-page{padding:max(.75rem,env(safe-area-inset-top,0px)) max(.75rem,env(safe-area-inset-right,0px)) 1.25rem max(.75rem,env(safe-area-inset-left,0px))}.profile-page__panels{max-width:none}}.profile-page__title{font-size:1.65rem;font-weight:600;color:var(--ink);margin-bottom:1.5rem}.profile-page__panels{display:flex;flex-direction:column;gap:1rem;max-width:360px}.profile-page__panel{padding:1.25rem;background:var(--parchment-light);border:2px solid var(--ink-faded);border-radius:8px;box-sizing:border-box}.profile-page__audio{margin:0}.profile-page__audio-title{font-size:1rem;font-weight:600;color:var(--ink);margin:0 0 .35rem}.profile-page__audio-slider-label{display:flex;flex-direction:column;gap:.35rem;font-size:.95rem;color:var(--ink);margin-bottom:.65rem}.profile-page__audio-slider-row{display:flex;align-items:center;gap:.75rem}.profile-page__audio-range{flex:1;min-width:0;height:1.25rem;accent-color:var(--gold-dark);cursor:pointer}.profile-page__audio-range:disabled{opacity:.45;cursor:not-allowed}.profile-page__audio-pct{font-size:.88rem;color:var(--ink-light);min-width:2.5rem;text-align:right;font-variant-numeric:tabular-nums}.profile-page__audio-mute{display:flex;align-items:center;gap:.5rem;font-size:.92rem;color:var(--ink);cursor:pointer}.profile-page__audio-actions{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-top:.35rem}.profile-page__audio-save{margin-left:auto;padding:.42rem .85rem;font-size:.9rem;color:var(--ink);background:var(--parchment-dark, #e8e0d0);border:2px solid var(--ink-faded);border-radius:6px;cursor:pointer;transition:border-color .15s ease,background .15s ease}.profile-page__audio-save:hover:not(:disabled){border-color:var(--gold-dark, #8b7355);background:#8b73551f}.profile-page__audio-save:disabled{opacity:.55;cursor:not-allowed}.profile-page__audio-mute input{width:1.05rem;height:1.05rem;accent-color:var(--gold-dark);cursor:pointer}.profile-page__msg--subtle{font-size:.82rem;color:var(--ink-faded);font-style:italic;margin:.35rem 0 0}.profile-page__panel p{margin:0 0 .75rem}.profile-page__email{margin:0 0 .75rem;font-size:.95rem;color:var(--ink);line-height:1.35}.profile-page__username-block{margin-bottom:1rem}.profile-page__username-display{margin:0 0 .75rem}.profile-page__username-edit-form{display:flex;flex-direction:column;gap:.5rem}.profile-page__username-actions{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;margin-top:.25rem}.profile-page__username-cancel{padding:.45rem .75rem;font-size:.9rem;color:var(--ink-faded);background:transparent;border:none;border-radius:6px;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.profile-page__username-cancel:hover:not(:disabled){color:var(--ink)}.profile-page__username-cancel:disabled{opacity:.5;cursor:not-allowed}.profile-page__field-label{display:flex;flex-direction:column;gap:.35rem;font-size:.95rem;color:var(--ink)}.profile-page__input{padding:.5rem .75rem;font-size:1rem;border:2px solid var(--ink-faded);border-radius:4px;background:var(--parchment-light);color:var(--ink);box-sizing:border-box}.profile-page__msg{margin:0;font-size:.85rem}.profile-page__msg--error{color:#c62828}.profile-page__msg--success{color:#2e7d32}.profile-page__username-block>.profile-page__msg--success{margin-top:.5rem}.profile-page__username-action{align-self:flex-start;padding:.45rem 1rem;font-size:.95rem;color:var(--ink);background:var(--parchment-dark, #e8e0d0);border:2px solid var(--ink-faded);border-radius:6px;cursor:pointer;transition:border-color .15s ease,background .15s ease}.profile-page__username-action:hover:not(:disabled){border-color:var(--gold-dark, #8b7355);background:#8b73551f}.profile-page__username-action:disabled{opacity:.55;cursor:not-allowed}.profile-page__logout{margin-top:.25rem}.profile-page__menu-btn{display:inline-block;margin-top:1.5rem;padding:.5rem 1.25rem;font-family:inherit;font-size:.95rem;font-weight:500;color:var(--ink);background:var(--parchment-dark, #e8e0d0);border:2px solid var(--ink-faded);border-radius:6px;text-decoration:none;cursor:pointer;transition:border-color .15s ease,background .15s ease}.profile-page__menu-btn:hover{border-color:var(--gold-dark, #8b7355);background:#8b735514}
