.hex-container{position:absolute;pointer-events:none}.hex-highlight{position:absolute;width:100%;height:100%;background-color:#ffff004d;clip-path:polygon(0% 50%,25% 0%,75% 0%,100% 50%,75% 100%,25% 100%);pointer-events:none}.hex-unusable{position:absolute;width:100%;height:100%;background-color:#000c;pointer-events:none;clip-path:polygon(0% 50%,25% 0%,75% 0%,100% 50%,75% 100%,25% 100%)}.game-board.dragging .hex-highlight{background-color:#ff06}.game-interface--mobile .board-container,.game-interface--mobile .game-board,.game-interface--mobile .counter,.game-interface--mobile .counter-stack,.game-interface--mobile .counter-tray,.game-interface--mobile .tray-counter{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.hex-id{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-body);color:#ff0;font-weight:700;text-shadow:1px 1px 1px black;font-size:.8vw}.counter{transition:transform .1s ease-out;touch-action:none}.tray-counter{touch-action:none}.counter-context-menu{position:fixed;min-width:140px;background:var(--paper-50);border:1px solid var(--border-light);border-radius:10px;box-shadow:var(--shadow-soft);padding:4px;z-index:5000}.counter-context-menu-item{width:100%;background:transparent;border:none;padding:6px 10px;text-align:left;font-size:13px;cursor:pointer;color:var(--ink-700);border-radius:6px;text-transform:uppercase;letter-spacing:.08em}.counter-context-menu-item:hover{background:var(--paper-75)}.counter-context-menu-item.danger{color:var(--red-600)}.counter-context-menu-item.danger:hover{background:var(--red-100)}.counter-context-menu-divider{height:1px;margin:4px 6px;background:var(--border-light)}.los-overlay{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:6}.los-line{stroke:#b5312c8c;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.los-endpoint{fill:#f6f0e2a6;stroke:#b5312c99;stroke-width:2}@keyframes pulse-highlight{0%{box-shadow:0 0 #ffff00b3}70%{box-shadow:0 0 0 10px #ff06}to{box-shadow:0 0 0 12px #ff00}}.counter-highlight{animation:pulse-highlight 1s ease-out;z-index:100;border-radius:50%!important}.touch-drag-preview{position:fixed;transform:translate(-50%,-50%);pointer-events:none;z-index:2000;width:52px;height:52px;border-radius:8px;box-shadow:0 10px 20px #16120a59;background:#fffc;display:flex;align-items:center;justify-content:center}.touch-drag-preview img{width:100%;height:100%;object-fit:contain}.counter:hover{transform:translate(-50%,-50%) scale(1.1)!important;z-index:20!important;box-shadow:0 4px 8px #00000080!important}.counter-stack .counter:hover{transform:scale(1.1)!important;z-index:20!important;box-shadow:0 4px 8px #00000080!important}.counter-stack:hover .counter{transform:none!important}.hex-off-limit{background-color:#000c;z-index:5;clip-path:polygon(0 0,100% 0,100% 100%,0 100%);overflow:hidden}.board-container{position:relative;overflow:auto;scrollbar-width:thin;scrollbar-color:var(--olive-700) var(--paper-75);width:100%;height:645px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;border:1px solid var(--border-light);border-radius:12px;margin:0 auto;background-color:var(--paper-50)}.game-interface--mobile .board-container{overflow-y:auto}.game-interface--mobile .board-container.is-touch-dragging{touch-action:none}.board-container::-webkit-scrollbar{height:8px}.board-container::-webkit-scrollbar-track{background:var(--paper-75);border-radius:4px}.board-container::-webkit-scrollbar-thumb{background-color:var(--olive-700);border-radius:4px}.board-container .game-board{position:relative;margin:0 auto;box-sizing:border-box;overflow:hidden;cursor:grab}.board-container .game-board:active{cursor:grabbing}.counter-tray{--tray-arrow-left: 50%;pointer-events:auto;z-index:1000;border:2px solid var(--olive-700);border-radius:12px;box-shadow:var(--shadow-soft);background-color:var(--paper-75);background-image:linear-gradient(180deg,#ffffff80,#fff0);position:absolute;transform:translateY(calc(-100% - 35px));padding:10px;display:flex;flex-wrap:wrap;gap:10px;max-width:300px}.counter-tray-arrow{position:absolute;bottom:-12px;left:var(--tray-arrow-left);transform:translate(-50%);width:0;height:0;border-left:12px solid transparent;border-right:12px solid transparent;border-top:12px solid var(--olive-700);filter:drop-shadow(0 2px 2px rgba(0,0,0,.2));z-index:-1}.counter-tray-arrow-inner{position:absolute;bottom:-9px;left:var(--tray-arrow-left);transform:translate(-50%);width:0;height:0;border-left:9px solid transparent;border-right:9px solid transparent;border-top:9px solid var(--paper-75);z-index:0}.tray-counter{overflow:hidden;border-radius:6px;border:none}.tray-counter img{transform:scale(1.04);transform-origin:center;display:block}.counter-tray:before{content:"";position:absolute;bottom:-25px;left:var(--tray-arrow-left);transform:translate(-50%);width:50px;height:30px;background-color:transparent;pointer-events:auto}.counter-tray--below{transform:translateY(35px)}.counter-tray--below .counter-tray-arrow{top:-12px;bottom:auto;border-top:none;border-bottom:12px solid var(--olive-700)}.counter-tray--below .counter-tray-arrow-inner{top:-9px;bottom:auto;border-top:none;border-bottom:9px solid var(--paper-75)}.counter-tray--below:before{top:-25px;bottom:auto}.counter-tray .insert-indicator{background-color:var(--olive-700)}.counter-bin{width:100%;max-width:1800px;margin-bottom:20px;background-color:transparent;border:none;border-radius:0;box-shadow:none;overflow:visible}.counter-tabs{display:flex;margin-bottom:-1px;background-color:transparent;border-bottom:none;gap:0}.category-tabs{display:flex;flex-wrap:wrap;margin-bottom:0;padding:10px 12px 6px;background-color:var(--paper-75);border:1px solid var(--border-light);border-bottom:1px dashed var(--border-light);border-radius:0 14px 0 0}.tab-button{padding:8px 16px;border:1px solid var(--border-light);border-bottom:1px solid var(--border-light);border-radius:10px 10px 0 0;background-color:var(--paper-100);cursor:pointer;margin-right:0;color:var(--ink-700);position:relative;z-index:1;transition:background-color .2s;text-transform:uppercase;letter-spacing:.1em;font-size:.75rem;font-weight:600}.tab-button+.tab-button{margin-left:-1px}.tab-button:hover{background-color:var(--paper-75)}.tab-button.active{background-color:var(--paper-75);border-bottom:1px solid var(--paper-75);margin-bottom:-1px;z-index:2;color:var(--ink-900)}.category-button{padding:5px 12px;margin-right:5px;margin-bottom:5px;border:1px solid var(--border-light);border-radius:999px;background-color:var(--paper-100);cursor:pointer;font-size:.72rem;transition:all .2s;color:var(--ink-700);text-transform:uppercase;letter-spacing:.08em}.category-button:hover{background-color:var(--paper-75)}.category-button.active{background-color:var(--olive-700);color:#fff;border-color:#3a4621}.counter-container{display:flex;flex-wrap:wrap;gap:5px;padding:10px;max-height:300px;overflow-y:auto;background-color:var(--paper-75);border:1px solid var(--border-light);border-top:none;border-radius:0 0 14px 14px;scrollbar-width:thin;scrollbar-color:var(--olive-700) var(--paper-100);animation:tray-switch .2s ease;will-change:transform,opacity;box-shadow:var(--shadow-soft)}.counter-container::-webkit-scrollbar{width:8px}.counter-container::-webkit-scrollbar-track{background:var(--paper-100)}.counter-container::-webkit-scrollbar-thumb{background-color:var(--olive-700);border-radius:6px}.counter-item{width:60px;height:60px;cursor:pointer;transition:transform .2s;display:flex;justify-content:center;align-items:center;border-radius:8px;border:none;background-color:transparent;touch-action:none}.counter-item:hover{transform:scale(1.05) translateY(-2px);box-shadow:0 6px 12px #1e160c2e}.counter-image{max-width:100%;max-height:100%;object-fit:contain}.counter-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-radius:6px;color:#fff;font-size:10px;text-align:center;box-shadow:0 2px 4px #1e160c33;padding:4px}.empty-message{width:100%;text-align:center;padding:30px;color:#7c6f59;font-style:italic}@keyframes tray-switch{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.counter-container{animation:none}}.chart-modal-overlay{position:fixed;inset:0;background-color:#1e160ca6;display:flex;justify-content:center;align-items:center;z-index:2000}.chart-modal{position:relative;max-width:90%;max-height:90%;background-color:var(--paper-50);background-image:linear-gradient(180deg,#ffffff80,#fff0),repeating-linear-gradient(0deg,rgba(96,80,48,.04) 0,rgba(96,80,48,.04) 1px,transparent 1px,transparent 28px);border-radius:14px;padding:20px;border:1px solid var(--border-light);box-shadow:var(--shadow-soft);overflow:hidden}.chart-modal--expanded{width:96vw;height:96vh;max-width:none;max-height:none;padding:16px}.chart-modal:before{content:"";position:absolute;top:0;left:0;height:5px;width:100%;background:linear-gradient(90deg,var(--olive-700),var(--olive-300))}.chart-modal-actions{position:absolute;top:10px;right:10px;display:flex;align-items:center;gap:8px;z-index:2}.chart-modal-close{background:linear-gradient(180deg,#586a34,var(--olive-800));color:#fff;border:1px solid #35411f;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;font-weight:700;box-shadow:0 4px 10px #1e160c33}.chart-modal-close:hover{background:linear-gradient(180deg,#516231,#36421f)}.chart-modal-expand{background:linear-gradient(180deg,#60703bf2,#465329f2);color:var(--paper-50);border:1px solid #35411f;border-radius:999px;width:34px;height:34px;padding:0;cursor:pointer;box-shadow:0 4px 10px #1e160c33;display:inline-flex;align-items:center;justify-content:center}.chart-modal-expand:hover{background:linear-gradient(180deg,#586934f2,#384220f2)}.chart-modal-content{max-height:calc(90vh - 40px);overflow:auto}.chart-modal--expanded .chart-modal-content{max-height:100%;height:100%}.chart-modal-image{max-width:100%;max-height:calc(90vh - 40px);object-fit:contain;border-radius:0;border:1px solid var(--border-light);background-color:#fffaf0;box-shadow:var(--shadow-tight);display:block}.chart-modal--expanded .chart-modal-image{max-width:none;max-height:none;width:auto;height:auto}@media(prefers-reduced-motion:reduce){.chart-modal{transition:none}}.game-interface{display:flex;flex-direction:column;align-items:center;width:100%;max-width:100vw;overflow:hidden;padding:16px 18px 28px;gap:8px}.game-board-shell{margin-bottom:20px;width:100%;max-width:1800px}.game-panels{display:flex;width:100%;max-width:1800px;margin-bottom:20px;gap:20px;flex-direction:row;flex-wrap:wrap}.counter-panel{width:calc(50% - 10px);min-width:300px;flex:1 1 300px}.responsive-header{display:grid;grid-template-columns:1fr auto 1fr;grid-template-rows:auto;align-items:center;width:100%;max-width:1800px;margin-bottom:16px;padding:12px 16px;gap:10px;background-color:var(--paper-50);background-image:linear-gradient(90deg,var(--olive-700),var(--olive-300)),linear-gradient(180deg,#ffffff80,#fff0),repeating-linear-gradient(0deg,rgba(96,80,48,.04) 0,rgba(96,80,48,.04) 1px,transparent 1px,transparent 28px);background-size:100% 5px,auto,auto;background-position:top left,top left,top left;background-repeat:no-repeat,no-repeat,repeat;border:1px solid var(--border-light);border-radius:14px;box-shadow:var(--shadow-soft);position:relative;overflow:visible}.header-center{display:flex;flex-direction:column;align-items:center;justify-self:center;gap:8px;width:fit-content}@media(max-width:1100px){.responsive-header{grid-template-columns:1fr;grid-template-rows:auto auto auto}.header-title{justify-self:center!important;margin-bottom:10px}.scenario-header-title{font-size:1.35rem;text-align:center}.turn-track-container{justify-self:center!important;width:auto!important;display:flex!important;justify-content:center!important}.turn-track-container>div{justify-content:center!important}.header-center{width:auto}.header-buttons{justify-self:center!important;margin-top:10px}}@media(max-width:900px){.game-interface{padding:12px 14px 24px}.game-panels{gap:16px}.counter-panel,.game-log-panel{width:100%}}.game-interface--mobile{padding:0;gap:0;height:100svh;overflow:hidden}.game-interface--mobile .responsive-header{display:none}.game-interface--mobile .game-board-shell{margin:0;width:100%;max-width:none}.game-interface--mobile .board-container{position:fixed;top:var(--mobile-top-bar-height, 72px);bottom:var(--mobile-bottom-bar-height, 70px);left:0;right:0;height:auto;border-radius:0;margin:0;overflow-y:auto;overscroll-behavior:contain;touch-action:pan-x pan-y}.game-interface--mobile .game-panels{display:none}.mobile-top-bar{position:fixed;top:0;left:0;right:0;height:var(--mobile-top-bar-height, 72px);display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--paper-50);border-bottom:1px solid var(--border-light);box-shadow:var(--shadow-soft);z-index:1200;pointer-events:auto}.mobile-turn-phase{display:flex;flex-direction:column;gap:8px;flex:1;align-items:center}.game-interface--mobile .turn-track{gap:3px;justify-content:center;width:100%}.game-interface--mobile .turn-track-box{width:26px;height:26px;font-size:.65rem;padding:0;touch-action:manipulation}.game-interface--mobile .turn-track-box--end{width:34px}.game-interface--mobile .turn-track-marker{width:22px;height:22px}.game-interface--mobile .phase-track{gap:0;align-self:center;width:fit-content}.game-interface--mobile .phase-chip{padding:4px 6px;font-size:.6rem;letter-spacing:.06em}.mobile-menu-button{border:1px solid var(--border-light);background:linear-gradient(180deg,#586a34,var(--olive-800));border-color:var(--olive-800);color:var(--paper-50);width:40px;height:40px;border-radius:10px;display:grid;place-items:center;box-shadow:var(--shadow-soft)}.mobile-menu-panel{position:fixed;top:var(--mobile-top-bar-height, 72px);left:0;right:0;background:var(--paper-75);border-bottom:1px solid var(--border-light);box-shadow:var(--shadow-soft);padding:14px;z-index:1195;transform:translateY(-100%);animation:mobile-menu-slide .25s ease-out forwards}.mobile-menu-overlay{position:fixed;inset:0;z-index:1150;background:#1e160c40}@keyframes mobile-menu-slide{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.mobile-menu-title{font-family:var(--font-display);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:10px;color:var(--ink-800)}.mobile-menu-actions{display:grid;gap:8px}.mobile-menu-link{background:var(--paper-100);border:1px solid var(--border-light);border-radius:10px;padding:8px 12px;text-align:left;font-size:.85rem;color:var(--ink-800);text-decoration:none}.mobile-menu-link--danger{color:#fff;background:var(--red-600);border-color:#8d2a26}.mobile-menu-section{display:grid;gap:6px}.mobile-menu-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-600)}.mobile-bottom-bar{position:fixed;bottom:0;left:0;right:0;height:var(--mobile-bottom-bar-height, 70px);background:var(--paper-50);border-top:1px solid var(--border-light);display:grid;grid-template-columns:1fr 1.2fr 1fr;align-items:center;gap:6px;padding:8px 10px;z-index:1200}.mobile-bottom-button{display:flex;flex-direction:column;gap:4px;align-items:center;justify-content:center;padding:6px 8px;border-radius:12px;border:1px solid transparent;background:transparent;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-700);width:100%;height:100%}.mobile-bottom-button-label{display:flex;align-items:center;gap:6px}.mobile-bottom-button.is-active{background:var(--paper-100);border-color:var(--border-light);color:var(--olive-700);box-shadow:inset 0 0 0 1px #fff9}.mobile-bottom-button--dice{gap:0}.mobile-bottom-dice{display:flex;align-items:center;gap:6px;min-height:18px}.mobile-bottom-dice--hidden{visibility:hidden}.mobile-bottom-dice .game-log-die--small{width:24px;height:24px;border-radius:6px}.mobile-dice-placeholder{font-size:.8rem;color:var(--ink-500);letter-spacing:.12em}.mobile-sheet{position:fixed;left:0;right:0;bottom:var(--mobile-bottom-bar-height, 70px);height:var(--mobile-sheet-height, 45svh);background:var(--paper-75);border-top:1px solid var(--border-light);box-shadow:0 -16px 30px #20180e33;transform:translateY(110%);transition:transform .25s ease;z-index:1100;overflow:hidden;overscroll-behavior:contain;touch-action:none;pointer-events:auto;display:flex;flex-direction:column}.mobile-sheet.is-open{transform:translateY(0)}.mobile-sheet-handle{height:24px;display:flex;align-items:center;justify-content:center;cursor:grab;touch-action:none}.mobile-sheet-grip{width:48px;height:5px;border-radius:999px;background:var(--border-light);box-shadow:inset 0 1px #fff9}.mobile-sheet-content{flex:1;min-height:0;display:flex;flex-direction:column}.mobile-sheet .counter-bin,.mobile-sheet .game-log-panel{max-width:none;height:100%}.mobile-sheet .game-log-panel{width:100%;min-width:0;display:flex;flex-direction:column}.mobile-sheet .counter-bin{display:flex;flex-direction:column;min-height:0;margin-bottom:0}.mobile-sheet .counter-container{flex:1;min-height:0;max-height:none;touch-action:pan-y;align-content:flex-start}.mobile-sheet .game-log-panel{margin-bottom:0}.mobile-sheet .game-log-container{width:100%;flex:1;min-height:0;max-height:none;touch-action:pan-y}.game-interface--mobile .game-log-entry{padding:8px 10px}.game-interface--mobile .game-log-version{width:14px;height:14px;font-size:9px;margin-right:4px}.game-interface--mobile .game-log-player{width:76px;margin-right:6px}.game-interface--mobile .log-seat-pill{max-width:76px;padding:2px 6px;gap:4px}.mobile-dice-flyover{position:fixed;left:50%;top:62%;display:flex;align-items:center;gap:12px;pointer-events:none;z-index:1250;opacity:0;--dice-x: 0px;--dice-y: 0px;transform:translate(-50%,-50%) scale(1);transition:transform .6s ease,opacity .35s ease}.mobile-dice-flyover .game-log-die{width:52px;height:52px;border-radius:10px;box-shadow:0 10px 24px #16120a59}.mobile-dice-flyover .game-log-die--red,.mobile-dice-flyover .game-log-die--white{border-width:2px}.mobile-dice-flyover[data-stage=start],.mobile-dice-flyover[data-stage=hold]{opacity:1;transform:translate(-50%,-50%) scale(1)}.mobile-dice-flyover[data-stage=move]{opacity:1;transform:translate(-50%,-50%) translate(var(--dice-x),var(--dice-y)) scale(.46)}.mobile-toast{position:fixed;left:50%;bottom:calc(var(--mobile-bottom-bar-height, 70px) + 14px);transform:translate(-50%);max-width:min(90vw,420px);background:#281c12eb;color:#fff;padding:10px 14px;border-radius:12px;box-shadow:0 10px 24px #16120a59;font-size:.8rem;text-align:center;z-index:1400}.game-interface--mobile .game-log-header{flex-direction:row;align-items:center;gap:8px;padding:8px 6px}.game-interface--mobile .game-log-header-left{display:none}.game-interface--mobile .game-log-header-right,.game-interface--mobile .game-log-controls{width:100%;justify-content:space-between}.game-interface--mobile .game-log-segmented{gap:6px;flex-wrap:nowrap}.game-interface--mobile .game-log-segment{padding:6px;min-width:36px;justify-content:center;font-size:.65rem}.game-interface--mobile .game-log-segment--toggle{min-width:36px}.game-interface--mobile .game-control-button.pill{height:32px;padding:0 10px;min-width:36px;justify-content:center}.game-interface--mobile .game-log-roll-icon,.game-interface--mobile .game-log-sync-icon{margin-right:0}.game-interface--mobile .button-label,.game-interface--mobile .game-log-header .game-log-dice{display:none}.game-interface--mobile .phase-track .tooltip-text{position:fixed;left:var(--tooltip-left, 50%);right:auto;top:var(--tooltip-top, calc(var(--mobile-top-bar-height, 72px) + 12px));bottom:auto;transform:translate(-50%);max-width:min(92vw,360px);width:min(92vw,360px)}.game-interface--mobile .phase-track .tooltip-text:after{display:block;top:-6px;bottom:auto;left:var(--tooltip-arrow-left, 50%);border-width:0 6px 6px;border-color:transparent transparent var(--ink-900)}.scenario-header-title{font-size:1.6rem;font-weight:400;color:var(--olive-700);font-family:var(--font-display);letter-spacing:.12em;text-transform:uppercase;justify-self:start}.turn-track-container{display:flex;align-items:center;justify-self:center;width:fit-content;height:100%}.phase-track{display:inline-flex;align-items:stretch;border-radius:999px;border:1px solid var(--border-light);background:var(--paper-100);box-shadow:inset 0 1px #fff9}.phase-chip{padding:6px 10px;background:transparent;color:var(--ink-700);font-size:.7rem;font-weight:600;letter-spacing:.08em;font-family:var(--font-display);cursor:default;transition:background-color .2s ease,color .2s ease}.phase-track .tooltip:not(:last-child) .phase-chip{border-right:1px solid var(--border-light)}.phase-track>.phase-chip:not(:last-child){border-right:1px solid var(--border-light)}.phase-chip:hover,.phase-track .tooltip[data-open=true] .phase-chip{background:var(--paper-75);color:var(--olive-700)}.phase-tooltip{display:flex;flex-direction:column;gap:8px}.phase-tooltip-title{font-family:var(--font-display);font-size:.85rem;letter-spacing:.12em;text-transform:uppercase}.phase-tooltip-empty{font-size:.75rem;color:#ffffffb3}.phase-tooltip-list{display:flex;flex-direction:column;gap:8px}.phase-tooltip-item{display:flex;gap:8px;align-items:center}.phase-tooltip-icon{width:28px;height:28px;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:#ffffff14;object-fit:contain}.phase-tooltip-icon--fallback{display:flex;align-items:center;justify-content:center;font-size:.6rem;text-transform:uppercase}.phase-tooltip-text{display:flex;flex-direction:column;gap:2px}.phase-tooltip-label{font-size:.75rem;font-weight:600}.phase-tooltip-note{font-size:.68rem;color:#ffffffb3;line-height:1.3}.turn-track{display:flex;flex-direction:row;align-items:center;flex-wrap:wrap;justify-content:center;gap:4px}.turn-track-box{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:2px solid var(--olive-700);border-radius:8px;margin:0 2px;background-color:var(--paper-75);background-clip:padding-box;background-origin:padding-box;color:var(--olive-700);font-weight:700;font-size:.95rem;font-family:var(--font-display);letter-spacing:.06em;position:relative;cursor:pointer;text-transform:uppercase;box-shadow:inset 0 1px #ffffff80}.turn-track-box--end{background-color:var(--paper-100);color:var(--ink-700)}.turn-track-box--half{background-image:linear-gradient(135deg,transparent 50%,var(--red-600) 50%)}.turn-track-marker{position:absolute;top:50%;left:50%;width:30px;height:30px;background-size:contain;background-repeat:no-repeat;background-position:center;z-index:2;transform:translate(-50%,-50%);pointer-events:none}.turn-track-empty{color:var(--olive-700);font-style:italic}.header-buttons{display:flex;gap:10px;justify-self:end;position:relative;flex-wrap:wrap}.charts-dropdown{position:relative}.header-caret{margin-left:2px}.header-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:6px 12px;color:#fff;border:1px solid #35411f;border-radius:8px;cursor:pointer;font-size:.75rem;font-weight:600;height:36px;min-width:100px;box-sizing:border-box;text-decoration:none;background:linear-gradient(180deg,#586a34,var(--olive-800));text-transform:uppercase;letter-spacing:.08em;box-shadow:0 4px 10px #1e160c33;transition:transform .1s ease,box-shadow .1s ease,background-color .2s ease}.header-button.red{background:linear-gradient(180deg,#cb3d35,var(--red-600));border-color:#8d2a26}.header-button svg{flex-shrink:0;min-width:16px;min-height:16px}.header-button:focus,.header-button:hover{outline:none;box-shadow:none}.header-button:hover{background:linear-gradient(180deg,#516231,#36421f)}.header-button.red:hover{background:linear-gradient(180deg,#d4433a,#a02c27)}.header-button:active{transform:scale(.97);box-shadow:0 2px 6px #1e160c33}.game-control-button{display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#586a34,var(--olive-800));color:#fff;border:1px solid #35411f;cursor:pointer;box-shadow:0 4px 10px #1e160c33;font-weight:600;text-transform:uppercase;letter-spacing:.08em;transition:background-color .2s,transform .1s,box-shadow .1s}.game-control-button.round{width:32px;height:32px;border-radius:50%;padding:0}.game-control-button.pill{height:32px;border-radius:16px;padding:0 12px;font-size:12px}.game-control-button.red{background:linear-gradient(180deg,#cb3d35,var(--red-600));border-color:#8d2a26}.game-control-button:hover:not(:disabled){background:linear-gradient(180deg,#516231,#36421f)}.game-control-button.red:hover:not(:disabled){background:linear-gradient(180deg,#d4433a,#a02c27)}.game-control-button:disabled{opacity:.5;cursor:not-allowed}.game-control-button:active:not(:disabled){transform:scale(.95);box-shadow:0 0 2px #0000004d}.game-log-row{transition:background-color .2s}.game-log-row--even{background-color:var(--paper-75)}.game-log-row--odd{background-color:var(--paper-50)}.game-log-row--current{background-color:#bac67a8c}.game-log-row:hover:not(.game-log-row--current){background-color:var(--bg-hover)}.game-log-panel{width:calc(50% - 10px);min-width:300px;flex:1 1 300px;height:fit-content}.game-log-header{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px dashed var(--border-light)}.game-log-header-left,.game-log-header-right{display:flex;align-items:center;gap:12px}.game-log-header-right{gap:8px}.game-log-controls{display:flex;align-items:center;gap:10px}.game-log-segmented{display:flex;align-items:center;gap:8px}.game-log-segment{border:1px solid #35411f;background:linear-gradient(180deg,#586a34,var(--olive-800));padding:6px 12px;display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#fff;cursor:pointer;border-radius:999px;box-shadow:0 4px 10px #1e160c33;transition:transform .1s ease,box-shadow .1s ease,background-color .2s ease}.game-log-segment--toggle{min-width:150px;justify-content:center}.game-log-segment:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.game-log-segment:hover:not(:disabled){background:linear-gradient(180deg,#516231,#36421f);box-shadow:0 6px 12px #1e160c40}.game-log-segment:active:not(:disabled){transform:scale(.97);box-shadow:0 2px 6px #1e160c33}.game-log-segment.is-active{background:linear-gradient(180deg,#d4433a,var(--red-600));border-color:#8d2a26}.game-log-segment-icon{color:currentColor}.button-label{display:inline-flex}.game-log-roll-icon,.game-log-sync-icon{margin-right:6px}.game-log-dice{display:flex;align-items:center;gap:8px}.game-log-dice.is-rolling .game-log-die--red{animation:dice-roll-left .65s ease}.game-log-dice.is-rolling .game-log-die--white{animation:dice-roll-right .7s ease .05s}.game-log-die{position:relative;width:28px;height:28px;border-radius:6px;display:flex;box-shadow:0 2px 6px #1e160c2e}.game-log-die--small{width:16px;height:16px;border-radius:4px;box-shadow:0 1px 2px #1e160c2e}.game-log-die--red{background-color:var(--red-600);border:1px solid #8d2a26}.game-log-die--white{background-color:#fffaf0;border:1px solid var(--border-light)}.game-log-container{height:300px;overflow-y:auto;border-radius:12px;background-color:var(--paper-50);border:1px solid var(--border-light);box-shadow:var(--shadow-tight);scrollbar-width:thin;scrollbar-color:var(--olive-700) var(--paper-75)}.game-log-container::-webkit-scrollbar{width:8px}.game-log-container::-webkit-scrollbar-track{background:var(--paper-75)}.game-log-container::-webkit-scrollbar-thumb{background-color:var(--olive-700);border-radius:6px}.game-log-entry{padding:10px 12px;display:flex;align-items:center;border-left:3px solid transparent;cursor:pointer}.game-log-entry.game-log-row--current{border-left-color:var(--olive-700)}.game-log-row--muted{opacity:.6}.game-log-version{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background-color:var(--paper-100);color:var(--ink-700);font-size:13px;font-weight:700;margin-right:8px;border:1px solid var(--border-light)}.game-log-version--current{background-color:var(--olive-700);color:#fff;border-color:var(--olive-700)}.game-log-player{display:flex;align-items:center;justify-content:flex-end;width:160px;margin-right:8px}.game-log-player-fallback{font-weight:600;color:var(--ink-700);white-space:nowrap}.log-seat-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;border:1px solid var(--border-light);background-color:var(--paper-75);box-shadow:inset 0 1px #ffffff80;max-width:160px}.log-seat-pill--p1{border-color:#a9b575}.log-seat-pill--p2{border-color:#b9a575}.log-seat-pill-label{font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--olive-700)}.log-seat-pill-name{font-size:.75rem;font-weight:600;color:var(--ink-700);text-transform:none;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.game-log-action-icon{width:30px;display:flex;align-items:center;justify-content:center;margin-right:8px;color:var(--olive-700)}.game-log-detail{flex:1;color:var(--ink-700)}.game-log-detail-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;row-gap:4px}.game-log-hex{display:inline-flex;align-items:center;justify-content:center;width:38px;height:28px;font-size:.7rem;font-weight:700;letter-spacing:.08em;color:var(--ink-700);background-color:#4a5a2a8c;box-shadow:0 1px 2px #1e160c1f;text-transform:uppercase;clip-path:polygon(25% 0%,75% 0%,100% 50%,75% 100%,25% 100%,0% 50%);position:relative;z-index:0}.game-log-hex:before{content:"";position:absolute;inset:2px;background-color:var(--paper-100);clip-path:polygon(25% 0%,75% 0%,100% 50%,75% 100%,25% 100%,0% 50%);z-index:0}.game-log-hex-text{position:relative;z-index:1}.game-log-counter-thumb{width:24px;height:24px;object-fit:contain;border:1px solid var(--border-light);border-radius:4px;background-color:#fffaf0}.game-log-counter-thumb--muted{opacity:.6}.game-log-tag{display:inline-flex;align-items:center;gap:4px;background-color:var(--paper-75);padding:2px 6px;border-radius:6px;font-size:.85rem;color:var(--ink-700);border:1px solid var(--border-light)}.game-log-tag--muted{color:#6a5f4a}.game-log-faction-icon{width:16px;height:16px;object-fit:contain}.game-log-empty{padding:20px;text-align:center;color:#7c6f59;font-style:italic}@keyframes dice-roll-left{0%{transform:rotate(0) scale(1)}20%{transform:rotate(12deg) translateY(-2px) scale(1.03)}45%{transform:rotate(-16deg) translateY(2px) scale(.97)}70%{transform:rotate(9deg) translateY(-1px) scale(1.02)}to{transform:rotate(0) scale(1)}}@keyframes dice-roll-right{0%{transform:rotate(0) scale(1)}15%{transform:rotate(-10deg) translateY(2px) scale(1.02)}38%{transform:rotate(14deg) translateY(-1px) scale(.98)}65%{transform:rotate(-7deg) translateY(1px) scale(1.01)}to{transform:rotate(0) scale(1)}}@media(prefers-reduced-motion:reduce){.game-log-dice.is-rolling .game-log-die--red,.game-log-dice.is-rolling .game-log-die--white{animation:none}}.game-error{width:100%;max-width:1800px;margin-bottom:20px;color:var(--red-600);padding:12px 14px;border:1px solid var(--red-600);border-left-width:4px;border-radius:10px;background-color:var(--red-100);white-space:pre-line}.charts-menu{position:absolute;top:100%;right:0;background-color:var(--paper-50);border:1px solid var(--border-light);border-radius:10px;box-shadow:var(--shadow-tight);z-index:1000;width:220px;margin-top:5px}.charts-menu-item{padding:8px 12px;cursor:pointer;transition:background-color .2s;text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;color:var(--ink-700)}.charts-menu-item+.charts-menu-item{border-top:1px dashed var(--border-light)}.charts-menu-item:hover{background-color:var(--paper-75)}@font-face{font-family:Work Sans;src:url(/assets/WorkSans-VariableFont_wght-ByHdcl4f.ttf) format("truetype");font-weight:100 900;font-style:normal;font-display:swap}@font-face{font-family:Work Sans;src:url(/assets/WorkSans-Italic-VariableFont_wght-0wzwTKD-.ttf) format("truetype");font-weight:100 900;font-style:italic;font-display:swap}@font-face{font-family:Anton;src:url(/assets/Anton-Regular-D-s4rlHi.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:var(--font-body);color:var(--ink-900);background-color:var(--paper-50);background-image:radial-gradient(circle at 12% 10%,#ffffffa6 0,#fff0 45%),radial-gradient(circle at 85% 18%,#0000000d 0,#0000 45%),repeating-linear-gradient(0deg,rgba(96,80,48,.08) 0,rgba(96,80,48,.08) 1px,transparent 1px,transparent 36px),repeating-linear-gradient(90deg,rgba(96,80,48,.05) 0,rgba(96,80,48,.05) 1px,transparent 1px,transparent 36px);background-attachment:fixed}button,input,select,textarea{font-family:inherit}:root{--font-body: "Work Sans", "Segoe UI", sans-serif;--font-display: "Anton", "Work Sans", sans-serif;--paper-50: #f6f0e2;--paper-75: #efe6d4;--paper-100: #e5dbc4;--paper-200: #d9caa7;--ink-900: #1e1a14;--ink-700: #3c352c;--olive-800: #3f4b25;--olive-700: #4a5a2a;--olive-600: #5f6f38;--olive-300: #bac67a;--red-600: #b5312c;--red-500: #cb3d35;--red-100: #f6e4e0;--bg-light: #f5efe1;--bg-hover: #e9e0ca;--border-light: #cdbfa6;--rule-line: rgba(96, 80, 48, .35);--shadow-soft: 0 14px 32px rgba(30, 22, 12, .18);--shadow-tight: 0 4px 12px rgba(30, 22, 12, .12);--focus-ring: rgba(74, 90, 42, .25)}.App{width:100%;margin:0 auto;padding:32px 0 48px;display:flex;justify-content:center;min-height:100vh}.landing-container{display:flex;width:100%;max-width:1240px;min-height:600px;margin:0 auto;gap:28px;padding:24px;align-items:stretch}.landing-container--mobile{flex-direction:column;max-width:100%;min-height:100svh;padding:0;gap:0;margin:0}.mobile-lobby{width:100%;display:flex;flex-direction:column;gap:0;padding:0 10px 10px}.mobile-logo{margin:0;padding:6px 10px;width:100%}.landing-container--mobile .app-logo{max-width:260px;margin-bottom:0}.mobile-logo .logo-subheading{display:none}.mobile-lobby-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));border:1px solid var(--border-light);border-radius:10px;overflow:hidden;background:var(--paper-75)}.mobile-lobby-tab{background:transparent;border:none;padding:10px 8px;font-family:var(--font-display);font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-700);cursor:pointer}.mobile-lobby-tab.is-active{background:linear-gradient(180deg,#586a34,var(--olive-800));color:var(--paper-50)}.mobile-lobby-panel{display:flex;flex-direction:column;gap:8px;margin-top:8px}.mobile-lobby-card{background-color:var(--paper-50);background-image:linear-gradient(180deg,#ffffff8c,#fff0),repeating-linear-gradient(0deg,rgba(96,80,48,.04) 0,rgba(96,80,48,.04) 1px,transparent 1px,transparent 28px);border-radius:12px;border:1px solid var(--border-light);box-shadow:var(--shadow-tight);padding:12px}.mobile-lobby-card--tabbed{padding:0;overflow:hidden;background:var(--paper-75)}.mobile-lobby-tabs--attached{border:none;border-bottom:1px solid var(--border-light);border-radius:0;background:var(--paper-75)}.mobile-lobby-tabs--attached .mobile-lobby-tab+.mobile-lobby-tab{border-left:1px solid var(--border-light)}.mobile-lobby-tabs--attached .mobile-lobby-tab:first-child{border-top-left-radius:12px}.mobile-lobby-tabs--attached .mobile-lobby-tab:last-child{border-top-right-radius:12px}.mobile-lobby-card-body{padding:10px;background:var(--paper-50)}.landing-container--mobile .logo-container{margin:0;padding:6px 10px;width:100%;border:1px solid var(--border-light);border-top:none;border-radius:0 0 12px 12px;background:linear-gradient(180deg,#ffffffb3,#fff0)}.mobile-about-button{margin-top:4px;align-self:center;background:transparent;border:none;color:var(--olive-700);font-family:var(--font-display);font-size:.82rem;text-transform:uppercase;letter-spacing:.16em;cursor:pointer;padding:6px 12px;border-radius:999px}.mobile-about-button:active{background:#4a5a2a1f;color:var(--olive-800)}.mobile-claim-card{padding:12px}.mobile-claim-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:8px;margin-bottom:10px;border-bottom:1px solid var(--border-light)}.mobile-claim-title{font-family:var(--font-display);font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;color:var(--olive-700)}.mobile-home-link{font-family:var(--font-display);font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:var(--olive-700);text-decoration:none;padding:4px 10px;border-radius:999px;border:1px solid transparent}.mobile-home-link:active{background:#4a5a2a1f;color:var(--olive-800);border-color:#4a5a2a33}.about-modal-overlay{position:fixed;inset:0;background:#1e160ca6;display:flex;align-items:center;justify-content:center;padding:16px;z-index:2000}.about-modal{position:relative;width:min(640px,100%);max-height:90vh;background:var(--paper-50);border-radius:16px;border:1px solid var(--border-light);box-shadow:var(--shadow-soft);overflow:hidden}.about-modal-close{position:absolute;top:10px;right:10px;border:none;border-radius:999px;width:32px;height:32px;background:linear-gradient(180deg,#586a34,var(--olive-800));color:var(--paper-50);font-size:16px;font-weight:700;cursor:pointer}.about-modal-header{display:flex;flex-direction:column;align-items:center;padding:20px 20px 10px;border-bottom:1px solid var(--border-light);background-image:linear-gradient(180deg,#fff9,#fff0)}.about-modal-logo{width:min(300px,80%);height:auto;margin-bottom:8px}.about-modal-title{font-family:var(--font-display);font-size:1rem;letter-spacing:.16em;text-transform:uppercase;color:var(--olive-700)}.about-modal-content{padding:16px 20px 20px;overflow:auto;max-height:calc(90vh - 140px)}.share-modal-overlay{position:fixed;inset:0;background:#1e160ca6;display:flex;align-items:center;justify-content:center;padding:14px;z-index:2100}.share-modal{position:relative;width:min(520px,100%);max-height:90vh}.share-modal-close{position:absolute;top:-12px;right:-6px;border:none;border-radius:999px;width:32px;height:32px;background:linear-gradient(180deg,#586a34,var(--olive-800));color:var(--paper-50);font-size:16px;font-weight:700;cursor:pointer;z-index:2}.share-card{margin:0;padding:20px}.landing-container--mobile .share-card{padding:16px}.share-copy-field{width:100%;height:44px;padding:0 12px;border:1px solid var(--border-light);border-radius:10px;background:var(--paper-75);box-shadow:inset 0 1px 2px #1e160c1f;display:flex;align-items:center;justify-content:space-between;gap:10px;text-align:left;cursor:pointer}.share-copy-field.copied{border-color:#9eae64;background:#dfe7c3;color:#3b441f}.share-copy-text{font-size:.9rem;color:var(--ink-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-copy-icon{color:var(--olive-700);display:inline-flex}.share-copy-field.copied .share-copy-icon{color:#3b441f}.landing-container--mobile .form-group{margin-bottom:12px}.landing-container--mobile .form-group label{margin-bottom:4px;font-size:.65rem;letter-spacing:.1em}.landing-container--mobile input,.landing-container--mobile .scenario-dropdown{height:42px;padding:10px 12px}.landing-container--mobile .scenario-picker{margin-bottom:10px;border-radius:12px}.landing-container--mobile .scenario-picker-header{padding:8px 10px;gap:6px}.landing-container--mobile .scenario-preview{padding:10px;gap:8px}.landing-container--mobile .scenario-preview-meta{gap:6px;padding-top:8px}.landing-container--mobile .scenario-preview-map-label{font-size:.55rem;padding:2px 6px}.landing-container--mobile .scenario-preview-faction-icon{width:22px;height:22px;padding:2px}.landing-container--mobile .scenario-preview-link{padding:4px 10px;font-size:.68rem}.landing-container--mobile .saved-games-section{margin-top:6px}.landing-container--mobile .saved-games-header{margin-bottom:8px;font-size:.75rem}.landing-container--mobile .saved-games-list{gap:8px}.landing-container--mobile .saved-game-item{padding:10px;gap:8px}.landing-container--mobile .saved-game-time{font-size:.75rem}.landing-container--mobile .saved-game-actions{gap:8px}.landing-container--mobile .saved-game-icons{gap:4px}.landing-container--mobile .join-code{margin-top:12px;padding-top:12px}.landing-container--mobile .help-text{font-size:.8rem}.landing-container--mobile .saved-games-note{margin-top:8px;font-size:.75rem}.landing-container--mobile .form-actions{margin-top:16px;gap:10px}.landing-container--mobile .large-button{padding:12px 16px;font-size:16px}.landing-info-column{flex:1;padding:36px;background-color:var(--paper-50);background-image:linear-gradient(180deg,#ffffff8c,#fff0),repeating-linear-gradient(0deg,rgba(96,80,48,.04) 0,rgba(96,80,48,.04) 1px,transparent 1px,transparent 28px);border-radius:16px;border:1px solid var(--border-light);box-shadow:var(--shadow-soft);position:relative;overflow:hidden;animation:panel-rise .5s ease both}.landing-info-column:before{content:"";position:absolute;inset:0;border-radius:16px;border:1px solid rgba(255,255,255,.4);pointer-events:none}.landing-info-column:after{content:"";position:absolute;top:0;left:0;height:6px;width:100%;background:linear-gradient(90deg,var(--olive-700),var(--olive-300))}.logo-container{display:flex;flex-direction:column;align-items:center;margin-bottom:26px;padding:18px 18px 12px;border:1px dashed var(--rule-line);border-radius:12px;background:linear-gradient(180deg,#ffffffb3,#fff0)}.app-logo{max-width:500px;width:100%;height:auto;margin-bottom:5px;filter:drop-shadow(0 6px 10px rgba(20,16,9,.2))}.logo-subheading{font-family:var(--font-display);color:var(--olive-700);font-size:1.15rem;letter-spacing:.18em;text-align:center;margin-bottom:30px;line-height:1.2;text-transform:uppercase}.landing-info-column h1{color:var(--olive-700);font-size:2.4rem;margin-bottom:20px;border-bottom:3px solid var(--olive-700);padding-bottom:10px;text-align:center;font-family:var(--font-display);letter-spacing:.08em;font-weight:400;text-transform:uppercase}.landing-info-column h2{color:var(--ink-900);font-size:1.3rem;margin-top:0;margin-bottom:14px;font-family:var(--font-display);letter-spacing:.12em;font-weight:400;text-transform:uppercase}.info-section{margin-bottom:22px}.info-section+.info-section{padding-top:18px;border-top:1px dashed var(--rule-line)}.info-section p{line-height:1.6;margin-bottom:15px;color:var(--ink-700)}.info-section a{color:var(--olive-700);text-decoration:none;font-weight:500;transition:color .2s}.info-section a:hover{color:#3a4621;text-decoration:underline}.info-section ol{padding-left:22px;margin:0;list-style:upper-roman}.info-section li{margin-bottom:10px;line-height:1.5}.toast{position:fixed;right:24px;bottom:24px;background-color:var(--ink-900);color:#fff;padding:10px 14px;border-radius:10px;font-size:.88rem;letter-spacing:.02em;border:1px solid rgba(255,255,255,.08);box-shadow:var(--shadow-tight);z-index:50;animation:toast-in .2s ease,toast-out .3s ease 1.9s forwards}@keyframes toast-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes toast-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(6px)}}@keyframes panel-rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes list-rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.tooltip{position:relative;display:inline-flex;align-items:center}.tooltip-text{position:absolute;left:50%;bottom:calc(100% + 8px);transform:translate(-50%,4px);background-color:var(--ink-900);color:#fff;padding:6px 8px;border-radius:6px;font-size:12px;line-height:1.2;letter-spacing:.02em;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease;z-index:10}.tooltip-text--rich{white-space:normal;padding:10px 12px;min-width:220px;max-width:320px;text-align:left}.tooltip-text:after{content:"";position:absolute;left:50%;bottom:-6px;transform:translate(-50%);border-width:6px 6px 0;border-style:solid;border-color:var(--ink-900) transparent transparent}.tooltip[data-open=true] .tooltip-text{opacity:1;transform:translate(-50%)}.tooltip-bottom .tooltip-text{top:calc(100% + 8px);bottom:auto;transform:translate(-50%,-4px)}.tooltip-bottom .tooltip-text:after{top:-6px;bottom:auto;border-width:0 6px 6px;border-color:transparent transparent var(--ink-900)}.tooltip-bottom[data-open=true] .tooltip-text{transform:translate(-50%)}.landing-action-column{flex:0 0 420px;display:flex;flex-direction:column;justify-content:flex-start;gap:18px}.action-card{background-color:var(--paper-50);background-image:linear-gradient(180deg,#ffffff8c,#fff0),repeating-linear-gradient(0deg,rgba(96,80,48,.04) 0,rgba(96,80,48,.04) 1px,transparent 1px,transparent 28px);border-radius:16px;border:1px solid var(--border-light);box-shadow:var(--shadow-soft);padding:32px;position:relative;overflow:hidden;animation:panel-rise .5s ease .08s both}.action-card:before{content:"";position:absolute;top:0;left:0;height:6px;width:100%;background:linear-gradient(90deg,var(--olive-700),rgba(186,198,122,.6))}.action-card h2{color:var(--ink-900);font-size:1.5rem;margin-bottom:22px;text-align:center;font-family:var(--font-display);letter-spacing:.12em;font-weight:400;text-transform:uppercase}.saved-games-section{margin-top:10px}.saved-games-header{font-size:.9rem;font-weight:600;color:var(--ink-700);margin-bottom:12px;text-align:left;text-transform:uppercase;letter-spacing:.12em}.saved-games-list{display:flex;flex-direction:column;gap:12px}.saved-game-item{background:linear-gradient(180deg,#ffffffbf,#fff0),var(--bg-light);border:1px solid var(--border-light);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-tight);animation:list-rise .4s ease both}.saved-game-item:nth-child(1){animation-delay:.04s}.saved-game-item:nth-child(2){animation-delay:.08s}.saved-game-item:nth-child(3){animation-delay:.12s}.saved-game-item:nth-child(4){animation-delay:.16s}.saved-game-meta{display:flex;flex-direction:column;gap:4px}.saved-game-title{font-weight:600;color:var(--ink-900);margin-bottom:4px;letter-spacing:.02em}.saved-game-subtitle{font-size:.9rem;color:var(--ink-700)}.saved-game-time{font-size:.85rem;color:#7c6f59;margin-top:6px}.saved-game-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.saved-game-icons{display:flex;gap:6px;align-items:center;margin-left:auto}.saved-games-empty{color:var(--ink-700);font-size:.95rem;text-align:center;padding:10px 0}.saved-games-note{color:#7c6f59;font-size:.85rem;text-align:center;margin-top:12px;letter-spacing:.02em}.join-code{margin-top:16px;padding-top:16px;border-top:1px dashed var(--border-light)}.join-code-row{display:flex;gap:10px;align-items:stretch}.join-code-row input{flex:1;min-width:0}.join-code-button{height:48px}.help-text{color:#6a5f4a;font-size:.9rem;margin-top:8px;line-height:1.4}.invite-note{background-color:var(--paper-75);border:1px solid var(--border-light);color:var(--ink-700);padding:10px 12px;border-radius:10px;font-size:.9rem;margin-bottom:16px}.input-with-action{display:flex;gap:10px;align-items:stretch}.input-with-action input{flex:1;min-width:0}.icon-button{border:1px solid var(--border-light);background-color:var(--paper-75);color:var(--ink-700);width:48px;height:48px;border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:inset 0 1px #ffffff80}.icon-button:hover{background-color:#efe6d4;border-color:#b9ab91}.icon-button.compact{width:34px;height:34px}.icon-button.copied{background-color:#dfe7c3;border-color:#9eae64;color:#3b441f}.form-group{margin-bottom:20px;width:100%}.form-group label{display:block;margin-bottom:8px;font-weight:600;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-700)}input,.scenario-dropdown{box-sizing:border-box;width:100%;padding:12px 14px;border:1px solid var(--border-light);border-radius:10px;font-size:16px;transition:all .2s ease;background-color:var(--paper-75);height:48px;box-shadow:inset 0 1px 2px #1e160c1f}input:focus,.scenario-dropdown:focus{border-color:var(--olive-700);outline:none;box-shadow:0 0 0 3px var(--focus-ring);background-color:#fff}.scenario-dropdown{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%234a5a2a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.scenario-picker{margin-bottom:18px;border-radius:16px;border:1px solid var(--border-light);background:var(--paper-75);box-shadow:var(--shadow-tight);overflow:hidden}.scenario-picker-header{padding:12px;border-bottom:1px dashed var(--rule-line);display:flex;flex-direction:column;gap:8px}.scenario-picker-header label{font-family:var(--font-display);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--olive-700)}.scenario-picker .scenario-dropdown{font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase}.scenario-preview{margin:0;padding:14px;display:flex;flex-direction:column;gap:12px}.scenario-preview-map{position:relative;border-radius:12px;overflow:hidden;border:1px solid rgba(96,80,48,.35);background:var(--paper-100);width:100%;aspect-ratio:1800 / 645;display:flex;align-items:center;justify-content:center}.scenario-preview-map-image{width:100%;height:100%;object-fit:contain;filter:saturate(.95) contrast(.95)}.scenario-preview-map:after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,#ffffff73,#0000 55%)}.scenario-preview-map-label{position:absolute;bottom:6px;right:6px;padding:2px 8px;border-radius:999px;border:1px solid var(--border-light);background:#f6f0e2eb;color:var(--ink-700);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;z-index:2;pointer-events:none}.scenario-preview-meta{display:flex;flex-direction:column;gap:8px;border-top:1px dashed var(--rule-line);padding-top:10px}.scenario-preview-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.scenario-preview-row--meta{align-items:center;justify-content:space-between;width:100%}.scenario-preview-group{display:inline-flex;align-items:center;gap:8px}.scenario-preview-group--turns{margin-left:auto;text-align:right}.scenario-preview-label{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-700)}.scenario-preview-value{font-size:.85rem;color:var(--ink-900)}.scenario-preview-icons{display:flex;gap:6px;flex-wrap:wrap}.scenario-preview-faction-icon{width:26px;height:26px;border-radius:7px;border:1px solid rgba(96,80,48,.45);background:#ffffffb3;box-shadow:0 2px 6px #1e160c26;padding:3px}.scenario-preview-link{display:inline-flex;align-items:center;gap:6px;text-decoration:none;color:var(--olive-700);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;padding:6px 12px;border-radius:999px;border:1px solid var(--border-light);background:var(--paper-100);transition:all .2s ease}.scenario-preview-link:hover{border-color:var(--olive-700);color:var(--olive-800);box-shadow:0 6px 12px #1e160c1f}.scenario-preview-link--require{font-style:italic;text-transform:none;letter-spacing:.04em}.button-group{display:flex;gap:10px;justify-content:center}.form-actions{display:flex;flex-direction:column;gap:15px;margin-top:30px;width:100%}.primary-button,.secondary-button{padding:12px 20px;border:1px solid transparent;border-radius:10px;font-size:16px;cursor:pointer;transition:all .2s ease;text-align:center;text-transform:uppercase;letter-spacing:.08em}.primary-button{background:linear-gradient(180deg,#586a34,var(--olive-800));border-color:var(--olive-800);color:#fff;font-weight:600;box-shadow:0 6px 14px #1e160c33}.primary-button:hover{background:linear-gradient(180deg,#516231,#36421f);transform:translateY(-1px);box-shadow:0 10px 18px #1e160c33}.secondary-button{background-color:var(--paper-75);color:var(--ink-700);border:1px solid var(--border-light);font-weight:500}.secondary-button:hover{background-color:#efe6d4;border-color:#b9ab91}.large-button{padding:14px 20px;font-size:18px;width:100%}.small-button{padding:8px 12px;font-size:13px;letter-spacing:.06em}.divider{display:flex;align-items:center;text-align:center;margin:25px 0;color:#7c6f59;text-transform:uppercase;letter-spacing:.2em;font-size:.7rem}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px dashed var(--border-light)}.divider:before{margin-right:10px}.divider:after{margin-left:10px}.error{background-color:var(--red-100);color:var(--red-600);padding:12px;border-radius:10px;margin-bottom:20px;border:1px solid var(--red-600);border-left-width:4px;font-size:14px}.error--inline{margin-bottom:12px}@media(prefers-reduced-motion:reduce){.landing-info-column,.action-card,.saved-game-item{animation:none}}@media(max-width:720px){.App{padding:0}}@media(max-width:900px){.landing-container{flex-direction:column;padding:18px}.landing-container--mobile{padding:0}.landing-info-column,.landing-action-column{flex:none;width:100%}.landing-info-column,.action-card{padding:28px}.logo-subheading{font-size:1rem;letter-spacing:.12em}.join-code-row,.input-with-action{flex-direction:column}.icon-button:not(.compact),.join-code-button{width:100%}.scenario-preview{padding:14px}.scenario-preview-map{width:100%}}
