@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600&family=Space+Grotesk:wght@500;600;700&display=swap";:root{color-scheme:dark;font-family:IBM Plex Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--font-display: "Space Grotesk", "IBM Plex Sans", sans-serif;--bg: #0f1114;--bg-soft: #15181d;--panel: rgba(22, 26, 31, .92);--panel-2: #1b2026;--text: #f5f5f0;--text-muted: rgba(245, 245, 240, .65);--accent: #62ffe6;--accent-soft: rgba(98, 255, 230, .7);--success: #5ce39a;--warning: #f7c04a;--error: #ff5c5c;--border: rgba(255, 255, 255, .08);--shadow-soft: 0 16px 40px rgba(0, 0, 0, .35)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,#1b222a,#0f1114 45%),linear-gradient(120deg,rgba(98,255,230,.08),transparent 40%);color:var(--text)}#root{min-height:100vh}h1,h2,h3,h4{font-family:var(--font-display);margin:0 0 8px}p{margin:0}a{color:inherit;text-decoration:none}button,input{font-family:inherit}button{cursor:pointer;transition:transform .15s ease,border .15s ease}button:active{transform:translateY(1px)}.app-shell{min-height:100vh;padding:0 24px 28px;display:flex;flex-direction:column;gap:32px}.app-header{display:flex;align-items:center;justify-content:space-between;gap:24px}.brand{display:flex;align-items:center;gap:16px}.brand-link{text-decoration:none;color:inherit;transition:transform .15s ease,opacity .15s ease}.brand-link:hover{opacity:.9}.brand-mark{width:48px;height:48px;border-radius:14px;background:linear-gradient(140deg,#62ffe6,#f8c970);color:#101112;display:grid;place-items:center;font-weight:700;letter-spacing:.08em}.brand-title{font-family:var(--font-display);font-size:1.2rem;letter-spacing:.02em}.brand-subtitle{color:var(--text-muted);font-size:.85rem}.app-content,.page{display:flex;flex-direction:column;gap:32px}.hero{display:grid;grid-template-columns:1.3fr .7fr;gap:24px;align-items:end}.eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:.75rem;color:var(--accent-soft);margin-bottom:12px}.lede{color:var(--text-muted);max-width:52ch}.search-box{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:20px;display:grid;gap:12px}.search-box label{color:var(--text-muted);font-size:.85rem}.search-box input{width:100%;background:var(--panel-2);border:1px solid transparent;border-radius:12px;padding:12px 14px;color:var(--text);font-size:.95rem;transition:border .2s ease}.search-box input:focus{outline:none;border-color:var(--accent)}.grid{display:grid;gap:20px}.teams-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.team-card,.operative-card,.counter-card,.ability-card,.weapon-block{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:18px;box-shadow:var(--shadow-soft)}.team-card-header,.operative-card-header,.weapon-header,.ability-header,.section-header,.team-header{display:flex;justify-content:space-between;align-items:center;gap:16px}.team-meta{display:flex;gap:8px;color:var(--text-muted);font-size:.85rem}.team-description{margin-top:16px;color:var(--text-muted);line-height:1.6}.primary-link,.ghost-link{padding:10px 16px;border-radius:999px;font-size:.9rem;letter-spacing:.02em;border:1px solid transparent;transition:.2s ease;white-space:nowrap}.primary-link{background:linear-gradient(130deg,#62ffe6,#f8c970);color:#101112}.ghost-link{border-color:var(--border);color:var(--text)}.team-header{align-items:flex-start}.team-summary{display:grid;gap:12px;min-width:220px;padding:16px;border-radius:16px;background:var(--panel);border:1px solid var(--border)}.summary-label{color:var(--text-muted);font-size:.8rem}.summary-value{font-weight:600}.trackables-panel{display:grid;gap:16px}.panel-header h2{margin:0 0 6px}.trackables-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}.counter-card{display:grid;gap:10px;text-align:center}.counter-label{color:var(--text-muted);font-size:.85rem}.counter-value{font-size:2rem;font-weight:700}.counter-actions{display:flex;justify-content:center;gap:8px}.counter-btn{width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);font-weight:600}.operatives-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.operative-card h3{margin:0 0 6px}.operative-keywords{color:var(--text-muted);font-size:.85rem}.operative-stats,.operative-stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:12px;margin-top:16px}.stat-pill{background:var(--panel-2);border:1px solid var(--border);border-radius:12px;padding:12px;display:grid;gap:6px;text-align:center}.stat-label{font-size:.75rem;color:var(--text-muted)}.stat-value{font-size:1.15rem;font-weight:600}.operative-section{display:grid;gap:16px}.weapon-header h4{margin:0 0 4px}.weapon-type{font-size:.85rem;color:var(--text-muted)}.weapon-profiles{display:grid;gap:12px;margin-top:12px}.weapon-profile{padding:12px;background:var(--panel-2);border-radius:12px;border:1px solid var(--border)}.profile-name{font-weight:600;margin-bottom:8px}.profile-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:10px;font-size:.9rem}.profile-label{color:var(--text-muted);display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em}.profile-value{font-weight:600}.ability-list{display:grid;gap:14px}.ability-card h3{margin:0}.tag{background:#62ffe61f;color:var(--accent);border:1px solid rgba(98,255,230,.3);padding:4px 10px;border-radius:999px;font-size:.75rem;white-space:nowrap}.empty-state{text-align:center;padding:40px;border:1px dashed var(--border);border-radius:18px;color:var(--text-muted)}@media(max-width:980px){.app-shell{padding:24px}.hero{grid-template-columns:1fr}.app-header,.team-header{flex-direction:column;align-items:flex-start}}.landing-shell{width:100%;min-height:100svh;height:100svh;display:grid;place-items:center;padding:0}.landing-link{width:100%;height:100%;display:grid;align-items:center;justify-content:center;text-decoration:none;padding:18px;background:radial-gradient(circle at top,#ff5a5a2e,#0f111433);transition:transform .2s ease,box-shadow .2s ease}.landing-link:hover{transform:scale(1.01)}.landing-logo{width:min(640px,80vw);height:auto;filter:drop-shadow(0 0 30px rgba(255,72,72,.55)) drop-shadow(0 0 60px rgba(255,72,72,.25));animation:glow-pulse 3.6s ease-in-out infinite}@keyframes glow-pulse{0%,to{filter:drop-shadow(0 0 26px rgba(255,72,72,.45)) drop-shadow(0 0 55px rgba(255,72,72,.2))}50%{filter:drop-shadow(0 0 34px rgba(255,88,88,.7)) drop-shadow(0 0 75px rgba(255,88,88,.35))}}.multiplayer{position:relative;align-items:center;text-align:center;padding-top:48px}.multiplayer-board-link{position:absolute;top:18px;right:18px}.multiplayer-header{max-width:48ch}.multiplayer-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center}.multiplayer-actions .primary-link,.multiplayer-actions .ghost-link{min-width:180px;padding:14px 22px;font-size:1rem;cursor:pointer}.multiplayer-actions .primary-link:disabled,.multiplayer-actions .ghost-link:disabled{opacity:.6;cursor:not-allowed}.multiplayer-form,.multiplayer-lobby{width:min(520px,100%);background:var(--panel);border:1px solid var(--border);border-radius:20px;padding:24px;box-shadow:var(--shadow-soft);display:grid;gap:20px}.multiplayer-field{display:grid;gap:8px;text-align:left}.multiplayer-field label{color:var(--text-muted);font-size:.9rem}.multiplayer-field input{width:100%;background:var(--panel-2);border:1px solid transparent;border-radius:12px;padding:12px 14px;color:var(--text);font-size:1rem}.multiplayer-field input:focus{outline:none;border-color:var(--accent)}.multiplayer-room{background:var(--panel-2);border:1px solid var(--border);border-radius:16px;padding:16px;display:grid;gap:6px}.room-label{color:var(--text-muted);font-size:.8rem;letter-spacing:.14em;text-transform:uppercase}.room-code{font-size:2rem;font-weight:700;letter-spacing:.2em}.room-hint{color:var(--text-muted);font-size:.9rem}.multiplayer-players{display:grid;gap:12px}.player-card{background:var(--panel-2);border:1px solid var(--border);border-radius:16px;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.player-host{border-color:color-mix(in srgb,var(--accent) 65%,var(--border))}.player-name{margin:0;font-weight:600}.player-role{margin:4px 0 0;color:var(--text-muted);font-size:.85rem}.player-status{font-size:.85rem;padding:6px 12px;border-radius:999px;border:1px solid var(--border)}.player-status.ready{background:color-mix(in srgb,var(--success) 18%,transparent);border-color:color-mix(in srgb,var(--success) 40%,var(--border));color:var(--success)}.player-status.waiting{background:color-mix(in srgb,var(--warning) 12%,transparent);border-color:color-mix(in srgb,var(--warning) 40%,var(--border));color:var(--warning)}.room-footer{margin:0;color:var(--text-muted)}.multiplayer-error{color:var(--error);margin:0}.multiplayer-status{color:var(--text-muted);margin:0}.critops-card{position:relative;width:100%;height:auto;display:flex;flex-direction:column;border-radius:12px;overflow:hidden;background:#f4f1e6;color:#2e2a24;font-family:Arial Narrow,Helvetica Neue Condensed,Helvetica Neue,sans-serif;font-weight:900;letter-spacing:.02em;text-shadow:none;border:1px solid rgba(170,170,170,.6)}.critops-card:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 25% 20%,rgba(255,255,255,.45),transparent 50%),radial-gradient(circle at 70% 70%,rgba(0,0,0,.05),transparent 55%),repeating-linear-gradient(115deg,rgba(0,0,0,.02) 0px,rgba(0,0,0,.02) 1px,transparent 1px,transparent 6px);pointer-events:none;mix-blend-mode:multiply}.critops-card__header{display:grid;gap:2px}.critops-card__title{margin:0;padding:4px 8px 3px;background:#0b0b0b;color:#fff;font-size:clamp(.55rem,1.25vw,.75rem);text-transform:uppercase;letter-spacing:.2em;text-align:center}.critops-card__body{padding:1.5% 3% 2.5%;display:grid;gap:1.5%;grid-template-rows:auto 1fr auto;min-height:0}.critops-card--two-column .critops-card__body{display:block;column-count:2;column-width:auto;column-gap:.15rem;column-fill:balance;flex:1 1 auto}.critops-card--two-column .critops-card__body{padding-left:2.25%;padding-right:2.25%}.critops-card--two-column .critops-card__header,.critops-card--two-column .critops-card__section{break-inside:avoid;page-break-inside:avoid}.critops-card__name{display:flex;align-items:baseline;gap:4px;padding:.05rem .2rem;background:#a61e1e;color:#fff;font-size:clamp(.52rem,1.05vw,.72rem);text-transform:uppercase;line-height:1}.critops-card__number{font-size:1em}.critops-card__opname{font-size:1.15em}.critops-card__section{display:grid;gap:1px}.critops-card__section-box{display:grid;gap:2px}.critops-card__section-box--mission{--mission-box-padding: 3px;border:1px solid #a61e1e;padding:var(--mission-box-padding)}.critops-card__section-head{display:flex;justify-content:space-between;align-items:baseline;gap:2px}.critops-card__section-title{margin:0;font-size:clamp(.5rem,1vw,.68rem);font-weight:900;text-transform:uppercase;letter-spacing:.02em;color:#a61e1e;line-height:1.05}.critops-card__cost{font-size:clamp(.55rem,1.1vw,.72rem);letter-spacing:.02em;text-transform:uppercase;color:#f1e7d6b3;line-height:1.05}.critops-card__subtitle{margin:0;display:inline-block;width:fit-content;padding:.1rem .3rem;background:#a61e1e;color:#fff;font-size:clamp(.55rem,1.1vw,.72rem);text-transform:uppercase;letter-spacing:.02em;line-height:1.05}.critops-card__subtitle-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:nowrap;gap:4px;width:100%}.critops-card__section-box--mission .critops-card__subtitle-row{width:calc(100% + (var(--mission-box-padding) * 2));margin:calc(-1 * var(--mission-box-padding)) calc(-1 * var(--mission-box-padding)) var(--mission-box-padding);padding:.1rem .3rem;background:#a61e1e;box-sizing:border-box}.critops-card__section-box--mission .critops-card__subtitle{margin:0;padding:0;flex:1 1 auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.critops-card__section-box--mission .critops-card__cost{margin:0;padding:0;color:#fff;flex:0 0 auto;white-space:nowrap}.critops-card__text{margin:0;font-size:clamp(.52rem,1vw,.7rem);font-weight:900;letter-spacing:.01em;line-height:1.2;overflow-wrap:anywhere;word-break:break-word}.critops-card__bullets{margin:0;padding:0;list-style:none;display:grid;gap:2px}.critops-card__bullets--plain .critops-card__bullet-label{display:inline-flex;align-items:center;font-size:0;letter-spacing:0}.critops-card__bullets--plain .critops-card__bullet-label:before{content:"";width:.35rem;height:.35rem;border-radius:50%;background:#111;display:inline-block}.critops-card__bullets--plain .critops-card__bullet:before{content:"";width:.35rem;height:.35rem;border-radius:50%;background:#111;display:inline-block;margin-top:.15rem}.critops-card__bullets--plain .critops-card__bullet-text{font-size:clamp(.52rem,1vw,.7rem);font-weight:900;letter-spacing:.01em;line-height:.9}.critops-card__bullet{display:flex;align-items:flex-start;gap:4px}.critops-card__bullet--action .critops-card__bullet-label{color:#f2c94c}.critops-card__bullet--restriction .critops-card__bullet-label{color:#ef4444}.critops-card__bullet-label{display:inline-flex;align-items:center;gap:6px;font-size:clamp(.5rem,1vw,.65rem);text-transform:uppercase;letter-spacing:.02em;color:#f1e7d6a6}.critops-card__bullet-text{flex:1 1 auto;font-size:clamp(.75rem,1.6vw,.95rem);font-weight:900;letter-spacing:.01em;line-height:1.2;overflow-wrap:anywhere;word-break:break-word}.critops-card__section-box--mission .critops-card__bullet-text{font-size:clamp(.52rem,1vw,.7rem);font-weight:900;letter-spacing:.01em;line-height:1.15;overflow-wrap:anywhere;word-break:break-word}.critops-card__bullet--action .critops-card__bullet-label,.critops-card__bullet--restriction .critops-card__bullet-label{font-size:0;letter-spacing:0}.critops-card__bullet--action .critops-card__bullet-label:before{content:"";width:0;height:0;border-top:.28rem solid transparent;border-bottom:.28rem solid transparent;border-left:.45rem solid #1f9d55}.critops-card__bullet--restriction .critops-card__bullet-label:before{content:"";width:.45rem;height:.45rem;background:#a61e1e;transform:rotate(45deg);display:inline-block}.killop{--killop-y-label-width: clamp(.7rem, 1.3vw, 1rem);--killop-y-values-width: clamp(.85rem, 1.6vw, 1.2rem);width:100%;height:100%;display:grid;grid-template-rows:auto auto 1fr;justify-items:stretch;border-radius:10px;background:#fff;color:#2e2a24;border:1px solid #ffffff;font-family:Arial Narrow,Helvetica Neue Condensed,Helvetica Neue,sans-serif;font-weight:900;letter-spacing:.02em;overflow:hidden}.killop *{font-weight:900}.killop__title{margin:0;display:block;padding:5px 6px;width:100%;box-sizing:border-box;justify-self:stretch;background:#0b0b0b;color:#fff;font-size:clamp(.45rem,.9vw,.65rem);text-transform:uppercase;letter-spacing:.2em;text-align:center}.killop__axis-row{display:grid;grid-template-columns:var(--killop-y-label-width) var(--killop-y-values-width) 1fr;grid-template-rows:auto auto;gap:.5px;padding:.12rem .15rem 0;font-size:clamp(.38rem,.7vw,.52rem);text-transform:uppercase}.killop__x-square{grid-column:1 / 3;grid-row:1 / 3;background:#a61e1e;border-radius:0;padding:0;margin:0}.killop__x-label{grid-column:3;grid-row:1;display:grid;place-items:center;padding:.1rem .15rem;background:#0b0b0b;color:#fff;font-size:clamp(.4rem,.7vw,.55rem);letter-spacing:.12em;text-transform:uppercase;text-align:center}.killop__x-values{grid-column:3;grid-row:2;display:grid;grid-template-columns:repeat(5,1fr);gap:0}.killop__body{display:grid;grid-template-columns:var(--killop-y-label-width) var(--killop-y-values-width) 1fr;gap:.5px;padding:.05rem .15rem .15rem}.killop__y-label{display:grid;place-items:center;width:var(--killop-y-label-width);padding:.1rem .15rem;background:#0b0b0b;color:#fff;font-size:clamp(.4rem,.7vw,.55rem);letter-spacing:.01em;text-transform:uppercase;text-align:center;writing-mode:vertical-rl;transform:rotate(180deg)}.killop__axis-col{display:grid;grid-template-rows:repeat(10,1fr);gap:0;font-size:clamp(.38rem,.7vw,.52rem);text-transform:uppercase;width:var(--killop-y-values-width)}.killop__axis-label{color:#a61e1e}.killop__axis-value{display:grid;place-items:center;color:#0b0b0b;background:#b5b5b5;border-radius:0}.killop__grid{display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(10,1fr);gap:.5px}.killop__cell{display:grid;place-items:center;background:#0f121714;border:1px solid rgba(0,0,0,.15);border-radius:3px;font-size:clamp(.38rem,.7vw,.52rem)}.board-op-group{display:flex;flex-direction:column;height:100%}.board-side__placeholder{display:grid;place-items:center;border-radius:10px;border:1px dashed rgba(170,170,170,.6);color:#f1e7d6a6;font-family:Arial Narrow,Helvetica Neue Condensed,Helvetica Neue,sans-serif;font-weight:900;letter-spacing:.2em;text-transform:uppercase;font-size:.7rem}.board-view{--inch-scale: .5003;min-height:100vh;background:radial-gradient(circle at top,#141820,#0f1114 52%);color:var(--text);display:grid;grid-template-rows:auto 1fr}.board-toolbar{padding:16px 18px 0;display:flex;justify-content:flex-start;align-items:center;gap:12px}.board-toggle{background:#0f1217cc;border:1px solid var(--border);border-radius:999px;padding:6px;display:inline-flex;gap:6px}.board-arrangement-button{border:1px solid var(--border);background:#0f1217cc;color:var(--text);padding:8px 16px;border-radius:999px;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase}.board-arrangement-button:disabled{opacity:.6;cursor:not-allowed}.board-toggle-button{border:none;background:transparent;color:var(--text-muted);padding:6px 14px;border-radius:999px;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase}.board-toggle-button.is-active{background:var(--panel-2);color:var(--text)}.board-surface{display:grid;place-items:center;padding:18px 18px 120px;overflow:auto}.board-card-overlay{position:fixed;--card-height: calc(120mm * var(--inch-scale));--card-width: calc(70mm * var(--inch-scale) * 1.2);width:var(--card-width);height:var(--card-height);display:block;pointer-events:none;z-index:5;border-radius:12px;overflow:hidden}.board-op-group{position:fixed;display:grid;grid-template-rows:auto auto auto auto;gap:1em;pointer-events:none;z-index:6;height:calc(var(--board-height) * 1in * var(--inch-scale))}.board-op-group.is-map-02{grid-auto-flow:row;height:fit-content;align-content:start}.board-op-group.is-map-01{height:fit-content;align-content:start}.board-op-group .board-side__slot--primary{grid-row:1}.board-op-group .board-side__placeholder--tac{grid-row:2}.board-op-group .board-side__placeholder--cat{grid-row:3}.board-op-group .board-side__slot--secondary{grid-row:4}.board-op-group.is-map-01 .board-side__slot--primary{grid-row:3}.board-op-group.is-map-01 .board-side__placeholder--tac{grid-row:1}.board-op-group.is-map-01 .board-side__placeholder--cat{grid-row:2}.board-op-group .board-side__slot--killop{width:fit-content;height:fit-content;display:grid;justify-items:start;align-items:center;justify-self:start;align-self:center}.board-op-group.is-map-02 .board-side__slot--killop{height:fit-content}.board-op-group.is-map-02.is-right .board-side__slot--killop{justify-self:end;justify-items:end;align-self:end;margin-left:0;width:calc(var(--killop-size) + .05in)}.board-op-group .board-side__slot--killop .board-killop-overlay{width:100%;height:auto;aspect-ratio:1 / 1;margin:0}.board-op-group.is-map-02 .board-side__placeholder--cat{grid-row:1}.board-op-group.is-map-02 .board-side__slot--primary{grid-row:3}.board-op-group.is-map-02.is-left .board-side__slot--primary{grid-row:2}.board-op-group.is-map-02.is-left .board-side__placeholder--tac{grid-row:3}.board-op-group.is-map-02.is-left .board-side__placeholder--cat{grid-row:4}.board-op-group.is-map-02.is-left .board-side__slot--secondary{grid-row:1}.board-op-group.is-map-01.is-left{left:.1in;bottom:.1in}.board-op-group.is-map-01.is-left .board-side__slot--card{translate:0px 0}.board-op-group.is-map-01.is-left .board-side__slot--killop{translate:-8px 0}.board-op-group.is-map-01.is-right{right:.1in;top:.1in;justify-content:flex-end}.board-op-group.is-map-01.is-right .board-side__slot--card{translate:6px 0}.board-op-group.is-map-01.is-right .board-side__slot--killop{margin-right:0;translate:9px 0}.board-op-group.is-map-01 .board-killop-overlay{height:var(--map1-card-height)}.board-op-group.is-map-02.is-left{left:.1in;top:.1in;align-items:flex-start}.board-op-group.is-map-02.is-right{right:.1in;bottom:.1in;align-items:flex-end;justify-content:flex-end}.board-op-group.is-map-02 .board-side__placeholder{width:var(--killop-size);height:var(--killop-size);align-self:center;justify-self:center;transform-origin:center}.board-op-group.is-map-02.is-left .board-side__placeholder{transform:rotate(90deg)}.board-op-group.is-map-02.is-right .board-side__placeholder{transform:rotate(-90deg)}.board-killop-overlay{position:fixed;--killop-size: calc(60mm * var(--inch-scale) * 1.95);--killop-gap: .1in;width:var(--killop-size);height:var(--killop-size);display:block;pointer-events:none;z-index:6;border-radius:10px;overflow:hidden}.board-killop-overlay.is-map-01{width:calc(var(--killop-size) + .05in)}.board-killop-overlay.is-map-02{--map2-killop-height: clamp( calc(70mm * var(--inch-scale) * 3.2), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 4.8) );height:var(--map2-killop-height);max-height:none}.board-killop-overlay.is-map-02.is-op-01{--map2-killop-height: clamp( calc(70mm * var(--inch-scale) * 1.9), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 2.5) )}.board-killop-overlay.is-map-02.is-op-02{--map2-killop-height: clamp( calc(70mm * var(--inch-scale) * 1.8), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 2.4) )}.board-killop-overlay.is-map-02.is-op-03{--map2-killop-height: clamp( calc(70mm * var(--inch-scale) * 1.7), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 2.2) )}.board-killop-overlay.is-map-02.is-op-04{--map2-killop-height: clamp( calc(70mm * var(--inch-scale) * 3), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 4.4) )}.board-killop-overlay.is-map-02.is-op-05{--map2-killop-height: clamp( calc(70mm * var(--inch-scale) * 2.3), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 3.1) )}.board-killop-overlay.is-map-02.is-op-06{--map2-killop-height: clamp( calc(70mm * var(--inch-scale) * 2.8), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 4.05) )}.board-killop-overlay.is-map-02.is-op-07{--map2-killop-height: clamp( calc(70mm * var(--inch-scale) * 2.2), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 3.1) )}.board-killop-overlay.is-map-02.is-op-09{--map2-killop-height: clamp( calc(70mm * var(--inch-scale) * 2.4), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 3.4) )}.board-card-overlay.is-bottom-left{left:.1in;bottom:.1in}.board-card-overlay.is-top-left{left:.1in;top:.1in}.board-card-overlay.is-top-right{right:.1in;top:.1in;transform:rotate(180deg)}.board-card-overlay.is-bottom-right{right:.1in;bottom:.1in}.board-card-overlay.is-map-02{--card-height: calc(120mm * var(--inch-scale));--card-width: clamp( calc(70mm * var(--inch-scale) * 3.2), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 4.8) );width:var(--card-height);height:var(--card-width);max-height:none;overflow:hidden}.board-card-overlay.is-map-02.is-op-01{--card-width: clamp( calc(70mm * var(--inch-scale) * 1.9), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 2.5) )}.board-card-overlay.is-map-02.is-op-02{--card-width: clamp( calc(70mm * var(--inch-scale) * 1.8), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 2.4) )}.board-card-overlay.is-map-02.is-op-03{--card-width: clamp( calc(70mm * var(--inch-scale) * 1.7), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 2.2) )}.board-card-overlay.is-map-02.is-op-04{--card-width: clamp( calc(70mm * var(--inch-scale) * 3), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 4.4) )}.board-card-overlay.is-map-02.is-op-05{--card-width: clamp( calc(70mm * var(--inch-scale) * 2.3), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 3.1) )}.board-card-overlay.is-map-02.is-op-06{--card-width: clamp( calc(70mm * var(--inch-scale) * 2.8), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 4.05) )}.board-card-overlay.is-map-02.is-op-09{--card-width: clamp( calc(70mm * var(--inch-scale) * 2.4), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 3.4) )}.board-card-overlay.is-map-02.is-op-07{--card-width: clamp( calc(70mm * var(--inch-scale) * 2.2), calc(100vw - .1in) , calc(70mm * var(--inch-scale) * 3.1) )}.board-card-overlay.is-map-02 .critops-card{height:100%;max-height:none;overflow:hidden}.board-card-overlay.is-map-02 .critops-card__body{padding-bottom:calc(2.5% + .2rem);overflow:hidden}.board-card-overlay.is-map-01{--map1-card-height: calc(var(--card-height) + .85in);--card-width: clamp( calc(70mm * var(--inch-scale) * 1.2), calc( (100vw - (var(--board-width) * 1in * var(--inch-scale))) / 2 - .2in ), calc(70mm * var(--inch-scale) * 2.4) );height:var(--map1-card-height);min-height:var(--map1-card-height);max-height:none;overflow:hidden}.board-card-overlay.is-map-01 .critops-card{height:100%;min-height:100%;max-height:none;overflow:hidden}.board-card-overlay.is-map-01 .critops-card__body{grid-template-rows:auto auto auto;padding-bottom:calc(2.5% + .5rem);overflow:hidden}.board-card-overlay.is-map-01.is-op-04{--map1-card-height: calc(var(--card-height) + 1.95in)}.board-card-overlay.is-map-01.is-op-05{--map1-card-height: calc(var(--card-height) + 1.55in)}.board-card-overlay.is-map-01.is-op-06{--map1-card-height: calc(var(--card-height) + 2.66in)}.board-card-overlay.is-map-01.is-op-06 .critops-card__body{padding-bottom:calc(2.5% + .75rem)}.board-card-overlay.is-map-01.is-op-07{--map1-card-height: calc(var(--card-height) + 1.65in)}.board-card-overlay.is-map-01.is-op-09{--map1-card-height: calc(var(--card-height) + 1.55in)}.board-card-overlay.is-map-01.is-op-08{--map1-card-height: calc(var(--card-height) + 2.35in)}.board-killop-overlay.is-map-01.is-left{left:.1in;bottom:calc(.1in + var(--map1-card-height) + var(--killop-gap))}.board-killop-overlay.is-map-01.is-right{right:.1in;top:calc(.1in + var(--map1-card-height) + var(--killop-gap));transform:rotate(180deg)}.board-killop-overlay.is-map-02.is-left{left:.1in;top:calc(.1in + var(--card-height) + var(--killop-gap))}.board-killop-overlay.is-map-02.is-right{margin-bottom:0}.board-op-group.is-map-02.is-left .board-killop-overlay,.board-op-group.is-map-02.is-right .board-killop-overlay{translate:0 0}.board-op-group .board-card-overlay,.board-op-group .board-killop-overlay{position:relative;inset:auto}.board-card-overlay.is-map-02.is-top-left,.board-card-overlay.is-map-02.is-bottom-right{transform:none;transform-origin:initial;translate:0 0}.board-side__inner{width:100%;height:100%;display:grid;place-items:center}.board-side__inner--card.is-left{width:var(--card-width);height:var(--card-height);transform:rotate(90deg);transform-origin:top left;translate:var(--card-height) 0}.board-side__inner--card.is-right{width:var(--card-width);height:var(--card-height);transform:rotate(-90deg);transform-origin:top left;translate:0 var(--card-width)}.board-side__inner--killop.is-left{width:var(--killop-size);height:var(--killop-size);transform:rotate(90deg);transform-origin:top left;translate:var(--killop-size) 0}.board-op-group.is-map-02.is-left .board-side__slot--killop{width:calc(var(--killop-size) + .05in);margin-left:-8px}.board-op-group.is-map-02.is-left .board-side__inner--killop.is-left{width:calc(var(--killop-size) + .05in);height:calc(var(--killop-size) + .05in);translate:calc(var(--killop-size) + .05in) 0}.board-side__inner--killop.is-right{width:var(--killop-size);height:var(--killop-size);transform:rotate(-90deg);transform-origin:top left;translate:0 var(--killop-size)}.board-op-group.is-map-02.is-right .board-side__inner--killop.is-right{width:calc(var(--killop-size) + .05in);height:calc(var(--killop-size) + .05in);translate:0 calc(var(--killop-size) + .05in)}.board-frame{position:relative;width:calc(var(--board-width) * 1in * var(--inch-scale));height:calc(var(--board-height) * 1in * var(--inch-scale));border:1px solid var(--border);background:linear-gradient(140deg,rgba(255,255,255,.05),transparent);box-shadow:var(--shadow-soft);overflow:hidden}.board-grid{position:absolute;inset:0;background-image:linear-gradient(to right,rgba(0,0,0,.7) 1px,transparent 1px),linear-gradient(to top,rgba(0,0,0,.7) 1px,transparent 1px);background-size:calc(100% / var(--board-width) * var(--grid-cell)) calc(100% / var(--board-height) * var(--grid-cell));z-index:2;pointer-events:none}.board-overlay{position:absolute;inset:0;width:100%;height:100%;z-index:3}.board-terrain-fill{fill:#16181c59;stroke:#000000b3;stroke-width:.08}.board-wall{stroke-width:.12}.board-wall-heavy{stroke:#000000e6}.board-wall-light{stroke:#a0a0a0e6}.board-wall-door{stroke:#fffffff2}.board-terrain-label{fill:#aaaaaad9;font-weight:600;text-anchor:start;dominant-baseline:hanging;pointer-events:none}.board-centerline{stroke:#a0a0a099;stroke-width:.08;stroke-dasharray:.35 .25}.board-objective circle{fill:#dc3c3ce6;stroke:#000000f2;stroke-width:.08}.board-objective-slice{stroke:#000000f2;stroke-width:.08}.board-zone{position:absolute;border:1px solid rgba(255,255,255,.2);background:#ffffff0a;z-index:1}.zone-a-territory{background:#d2b08a33;border-color:#f806}.zone-b-territory{background:#b8bcc233;border-color:#b8bcc266}.zone-a-drop{background:#d2b08a4d;border-color:#d2b08a66}.zone-b-drop{background:#b8bcc24d;border-color:#b8bcc266}.select-army{gap:28px}.select-army-header{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:end}.select-army-search{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:20px;display:grid;gap:12px}.select-army-search label{color:var(--text-muted);font-size:.85rem}.select-army-search input{width:100%;background:var(--panel-2);border:1px solid transparent;border-radius:12px;padding:12px 14px;color:var(--text);font-size:.95rem;transition:border .2s ease}.select-army-search input:focus{outline:none;border-color:var(--accent)}.select-army-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}.select-army-card{text-decoration:none;color:inherit;transition:transform .15s ease,border .15s ease}.select-army-card:hover{transform:translateY(-2px);border-color:#62ffe666}.select-army-card:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.select-army-card{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:18px;box-shadow:var(--shadow-soft);display:grid;gap:14px}.select-army-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.status-dot{width:12px;height:12px;border-radius:50%;background:var(--error);box-shadow:0 0 8px color-mix(in srgb,var(--error) 70%,transparent);flex:0 0 auto}.status-dot--red{background:var(--error);box-shadow:0 0 8px color-mix(in srgb,var(--error) 70%,transparent)}.status-dot--yellow{background:var(--warning);box-shadow:0 0 8px color-mix(in srgb,var(--warning) 70%,transparent)}.status-dot--green{background:var(--success);box-shadow:0 0 8px color-mix(in srgb,var(--success) 70%,transparent)}.select-army-card h2{margin:0 0 6px}.select-army-meta{display:flex;gap:8px;color:var(--text-muted);font-size:.85rem}.select-army-description{color:var(--text-muted);line-height:1.6}@media(max-width:1100px){.select-army-header{grid-template-columns:1fr}.select-army-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.select-army-grid{grid-template-columns:1fr}}.unit-selection{gap:24px}.unit-selection-header{display:flex;align-items:flex-end;justify-content:space-between;gap:20px}.unit-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}.unit-card{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:18px;box-shadow:var(--shadow-soft);display:grid;gap:12px;cursor:pointer;transition:border .15s ease,box-shadow .15s ease,transform .15s ease}.unit-card:hover{transform:translateY(-2px)}.unit-card:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.unit-card.selected{border-color:color-mix(in srgb,var(--success) 80%,transparent);box-shadow:0 0 0 1px color-mix(in srgb,var(--success) 40%,transparent),0 18px 45px #00000059}.unit-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.unit-card-badges{display:inline-flex;align-items:center;gap:10px}.unit-role{font-size:.85rem;color:var(--text-muted)}.unit-instance{font-size:.75rem;color:var(--accent);border:1px solid rgba(98,255,230,.4);padding:2px 8px;border-radius:999px}.unit-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;text-align:center;background:var(--panel-2);border-radius:14px;border:1px solid var(--border);padding:12px}.unit-stat-label{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.unit-stat-value{display:block;margin-top:6px;font-weight:600}.unit-keywords{color:var(--text-muted);font-size:.85rem}.unit-lock-button{width:100%;padding:16px 20px;border-radius:14px;background:linear-gradient(130deg,var(--success),#2dd47e);color:#101112;font-weight:600;text-align:center;text-decoration:none;letter-spacing:.02em;box-shadow:var(--shadow-soft);transition:transform .15s ease,box-shadow .15s ease}.unit-lock-button:hover{transform:translateY(-1px)}.unit-lock-button:focus-visible{outline:2px solid var(--accent);outline-offset:3px}@media(max-width:1100px){.unit-selection-header{flex-direction:column;align-items:flex-start}.unit-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.unit-grid{grid-template-columns:1fr}}.equipment-selection{gap:24px;min-height:calc(100vh - 120px)}.equipment-header{display:flex;align-items:flex-end;justify-content:space-between;gap:20px}.equipment-group{display:grid;gap:16px}.equipment-group-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.equipment-count{color:var(--text-muted);font-size:.85rem}.equipment-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:16px}.equipment-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:14px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:10px;overflow:hidden;cursor:pointer;transition:border .15s ease,box-shadow .15s ease,transform .15s ease}.equipment-card:hover{transform:translateY(-2px)}.equipment-card:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.equipment-card.selected{border-color:color-mix(in srgb,var(--success) 80%,transparent);box-shadow:0 0 0 1px color-mix(in srgb,var(--success) 40%,transparent),0 18px 45px #00000059}.equipment-card h2,.equipment-card h3{margin:0 0 6px}.equipment-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.equipment-toggle{border:1px solid var(--border);background:var(--panel-2);color:var(--text);border-radius:10px;width:28px;height:28px;font-size:.9rem;display:grid;place-items:center;padding:0}.equipment-card.expanded .equipment-toggle{transform:rotate(180deg)}.equipment-description{color:#1a1a17;font-size:.85rem;line-height:1.5;background:transparent;border:none;padding:0;margin:0;max-height:0;overflow:hidden;transition:max-height .2s ease,padding .2s ease,margin .2s ease,background .2s ease}.equipment-card.expanded .equipment-description{background:linear-gradient(135deg,#f2efe7,#e6e0d2);border:1px solid rgba(0,0,0,.08);padding:12px;margin-top:6px;max-height:240px;overflow:auto;box-shadow:inset 0 0 0 1px #fff6}.equipment-footer{margin-top:auto}.equipment-start-button{width:100%;padding:18px 20px;border-radius:14px;border:none;background:linear-gradient(130deg,var(--success),#2dd47e);color:#101112;font-weight:700;font-size:1rem;letter-spacing:.02em;box-shadow:var(--shadow-soft)}.equipment-start-hint{margin:12px 0 0;color:var(--text-muted);font-size:.9rem;text-align:center}@media(max-width:1400px){.equipment-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(max-width:1100px){.equipment-header{flex-direction:column;align-items:flex-start}.equipment-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:720px){.equipment-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.game-card{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:18px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:14px;height:100%}.game-card.stance-engage{border-color:var(--border);box-shadow:var(--shadow-soft),0 0 0 2px #ff7a3a59}.game-card.stance-conceal{border-color:var(--border);box-shadow:var(--shadow-soft),0 0 0 2px #5aa7ff59}.game-card.is-dimmed{opacity:.6;filter:grayscale(.2)}.game-card.is-dead{opacity:.15;filter:grayscale(1)}.game-card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:nowrap}.game-card-title{display:inline-flex;align-items:center;gap:10px;min-width:0;flex:1}.game-card-name{background:none;border:none;padding:0;margin:0;font-family:var(--font-display);font-size:1.1rem;color:var(--text);cursor:pointer;white-space:normal;overflow:visible;text-overflow:clip;flex:1}.game-card-name:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.game-card-header-stats{display:inline-flex;flex-wrap:wrap;gap:8px;white-space:nowrap}.state-pill{border-radius:999px;padding:4px 10px;border:1px solid transparent;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600;cursor:pointer}.state-ready{background:color-mix(in srgb,var(--success) 25%,transparent);border-color:color-mix(in srgb,var(--success) 60%,transparent);color:var(--success)}.state-active{background:color-mix(in srgb,var(--warning) 25%,transparent);border-color:color-mix(in srgb,var(--warning) 60%,transparent);color:var(--warning)}.state-expended{background:color-mix(in srgb,var(--error) 25%,transparent);border-color:color-mix(in srgb,var(--error) 60%,transparent);color:var(--error)}.state-dead{background:var(--panel-2);border-color:var(--border);color:var(--text)}.state-pill:disabled{cursor:not-allowed;opacity:.9}.game-card-health{display:flex;align-items:center;gap:12px}.health-bar{position:relative;flex:1;height:14px;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;overflow:hidden;cursor:pointer}.health-bar:after{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(to right,transparent,transparent calc(100% / var(--segments) - 2px),rgba(0,0,0,.5) calc(100% / var(--segments) - 2px),rgba(0,0,0,.5) calc(100% / var(--segments)));pointer-events:none}.health-bar:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.health-bar-fill{height:100%;background:linear-gradient(120deg,var(--success),#2dd47e);transition:width .12s ease}.health-bar-fill.critical{background:linear-gradient(120deg,var(--error),#ff7a6b)}.game-stat-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:6px;background:var(--panel-2);border:1px solid var(--border)}.game-stat-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.game-stat-value{font-size:.8rem;font-weight:600;color:var(--text)}.game-stat-value.apl-up{color:var(--success)}.game-stat-value.apl-down{color:var(--error)}.apl-button{background:none;border:none;padding:0;cursor:pointer}.stat-critical{color:var(--error)}.stat-boosted{color:var(--success)}.stat-stunned{color:var(--error)}.game-weapon-table{display:grid;gap:6px;font-size:.8rem}.game-card-details{display:grid;gap:12px;max-height:0;overflow:hidden;transition:max-height .2s ease,opacity .2s ease;opacity:0}.game-card-details.open{max-height:1000px;opacity:1}.game-card-status{display:flex;align-items:center;justify-content:space-between;gap:6px;margin:0 0 calc(.25rem - 18px);margin-top:auto}.stance-pill{border-radius:999px;padding:3px 10px;border:1px solid transparent;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;cursor:pointer;background:var(--panel-2);color:var(--text)}.legionary-pill{border-radius:999px;padding:6px 12px;border:1px solid transparent;font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;font-weight:700;display:inline-flex;align-items:center;justify-content:center;min-height:26px;background:var(--panel-2);color:var(--text)}.legionary-pill.mark-khorne{background:#3b0e0e;border-color:#ff5c5c;color:#ff9b9b}.legionary-pill.mark-nurgle{background:#113324;border-color:#5ce39a;color:#9ff0c6}.legionary-pill.mark-slaanesh{background:#3b2c12;border-color:#f7c04a;color:#ffd78a}.legionary-pill.mark-tzeentch{background:#2b1b4a;border-color:#b68cff;color:#d5b7ff}.legionary-pill.mark-undivided{background:#2a2d31;border-color:#9aa0a6;color:#c9ced6}.legionary-pill.mark-unset{background:#1f2329;border-color:#6b727a;color:#b7bdc6}.stance-pill.stance-engage{background:color-mix(in srgb,#ff7a3a 25%,transparent);border-color:color-mix(in srgb,#ff7a3a 60%,transparent);color:#ff7a3a}.stance-pill.stance-conceal{background:color-mix(in srgb,#5aa7ff 25%,transparent);border-color:color-mix(in srgb,#5aa7ff 60%,transparent);color:#5aa7ff}.status-pill-list{display:inline-flex;flex-wrap:wrap;gap:4px;min-height:24px;margin:0;justify-content:flex-start;flex:1}.status-divider{color:var(--text-muted);font-size:.9rem;line-height:1;font-weight:700;align-self:stretch;display:inline-flex;align-items:center}.status-pill{padding:2px 8px;border-radius:999px;border:1px solid var(--border);background:var(--panel-2);font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text);cursor:pointer}.status-pill.injured,.status-pill.status-error{color:var(--error);border-color:color-mix(in srgb,var(--error) 60%,transparent);background:color-mix(in srgb,var(--error) 18%,transparent)}.status-pill.status-warning{color:var(--warning);border-color:color-mix(in srgb,var(--warning) 60%,transparent);background:color-mix(in srgb,var(--warning) 18%,transparent)}.status-add-button{width:28px;height:28px;border-radius:50%;border:1px solid var(--border);background:var(--panel-2);color:var(--text);font-size:1rem;line-height:1;cursor:pointer}.status-add-button:hover{border-color:color-mix(in srgb,var(--accent) 60%,transparent)}.mark-modal{position:fixed;inset:0;display:grid;place-items:center;z-index:70}.mark-modal-backdrop{position:absolute;inset:0;background:#07080ab3}.mark-modal-content{position:relative;z-index:1;width:min(420px,92vw);background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow-soft)}.mark-modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.mark-modal-close{border:1px solid var(--border);background:var(--panel-2);color:var(--text);padding:6px 10px;cursor:pointer}.mark-modal-body{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}.status-modal,.apl-modal{position:fixed;inset:0;display:grid;place-items:center;z-index:60}.apl-modal-backdrop{position:absolute;inset:0;background:#07080ab3}.apl-modal-content{position:relative;z-index:1;width:min(360px,90vw);background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow-soft)}.apl-modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.apl-modal-close{border:1px solid var(--border);background:var(--panel-2);color:var(--text);padding:6px 10px;cursor:pointer}.apl-modal-body{display:grid;grid-template-columns:1fr auto 1fr;gap:10px;align-items:center}.apl-adjust-button{border:1px solid var(--border);background:var(--panel-2);color:var(--text);padding:10px 12px;border-radius:8px;font-size:1rem;cursor:pointer}.apl-adjust-value{text-align:center;font-weight:600;font-variant-numeric:tabular-nums}.status-modal-backdrop{position:absolute;inset:0;background:#07080ab3}.status-modal-content{position:relative;z-index:1;width:min(420px,90vw);background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow-soft)}.status-modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.status-modal-close{border:1px solid var(--border);background:var(--panel-2);color:var(--text);padding:6px 10px;cursor:pointer}.status-modal-body{display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr))}.status-option{border:1px solid var(--border);background:var(--panel-2);color:var(--text);padding:8px 10px;border-radius:8px;text-align:left;cursor:pointer;font-size:.85rem}.status-option.selected{border-color:color-mix(in srgb,var(--accent) 65%,transparent);color:var(--accent)}.status-option-description{display:block;font-size:.75rem;color:var(--text-muted);margin-top:4px}.status-detail-body{color:var(--text-muted);line-height:1.5;white-space:pre-line}.game-weapon-row{display:grid;grid-template-columns:1.9fr repeat(3,minmax(0,.35fr)) 1.1fr;gap:4px;align-items:center;padding:6px 8px;border:1px solid var(--border);background:var(--panel-2)}.game-weapon-header{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);background:transparent;border:none;padding:0 2px 2px}.weapon-name{color:var(--text);font-weight:600}.weapon-rules{color:var(--text-muted);display:inline-flex;flex-wrap:wrap;gap:6px}.weapon-rule-khorne-added,.weapon-rule-khorne-added.weapon-rule-button{color:#ff9b9b}.weapon-rule-tzeentch-added,.weapon-rule-tzeentch-added.weapon-rule-button{color:#d5b7ff}.weapon-rule{color:var(--text-muted);font-size:.75rem}.weapon-rule-button{border:none;background:transparent;color:var(--text);padding:0;cursor:pointer}.rule-modal{position:fixed;inset:0;display:grid;place-items:center;z-index:50}.rule-modal-backdrop{position:absolute;inset:0;background:#07080ab3}.rule-modal-content{position:relative;z-index:1;width:min(520px,90vw);background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow-soft)}.rule-modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.rule-modal-close{border:1px solid var(--border);background:var(--panel-2);color:var(--text);padding:6px 10px;cursor:pointer}.rule-modal-body{color:var(--text-muted);line-height:1.5;white-space:pre-line}.rule-modal-body p{margin:0 0 10px}.rule-modal-suggestions{display:grid;gap:6px}.rule-modal-suggestions-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.rule-modal-suggestions ul{margin:0;padding-left:18px}.hit-critical{color:var(--error);font-weight:600}.game-abilities{display:grid;gap:8px;font-size:.8rem}.abilities-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.ability-row{background:var(--panel-2);border:1px solid var(--border);padding:6px 10px}.ability-name{font-weight:600;color:var(--text);cursor:pointer;list-style:none;display:flex;align-items:center;gap:8px;justify-content:space-between}.ability-title{min-width:0;flex:1}.cost-badge{font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);border:1px solid var(--border);border-radius:999px;padding:2px 8px;background:var(--panel);white-space:nowrap}.ability-name::-webkit-details-marker{display:none}.ability-name:before{content:"›";color:var(--text-muted);font-size:.9rem;transition:transform .15s ease}.ability-row[open] .ability-name:before{transform:rotate(90deg)}.ability-description{color:var(--text-muted);line-height:1.5;margin-top:6px}.ability-empty{color:var(--text-muted)}.game-card-slot{font-size:.7rem;color:var(--accent);border:1px solid rgba(98,255,230,.4);padding:2px 8px;border-radius:999px}.opponent-backdrop{position:fixed;inset:0;background:#0607098c;opacity:0;pointer-events:none;transition:opacity .18s ease;z-index:22}.opponent-backdrop.open{opacity:1;pointer-events:auto}.opponent-panel{position:fixed;top:0;right:0;height:100vh;width:100vw;max-width:100vw;background:var(--panel);border-left:1px solid var(--border);padding:calc(20px + env(safe-area-inset-top)) calc(22px + env(safe-area-inset-right)) calc(20px + env(safe-area-inset-bottom)) calc(22px + env(safe-area-inset-left));transform:translate(100%);transition:transform .22s ease;z-index:23;display:grid;grid-template-rows:auto 1fr;gap:16px;overflow:hidden}.opponent-panel.open{transform:translate(0)}.opponent-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;border-bottom:1px solid var(--border);padding-bottom:12px}.opponent-panel-actions{display:inline-flex;gap:10px;align-items:center}.opponent-refresh:disabled{opacity:.6;cursor:not-allowed}.opponent-refresh-note{margin:0 0 12px;color:var(--text-muted);font-size:.85rem}.opponent-eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:.7rem;color:var(--accent-soft);margin:0 0 6px}.opponent-subtitle{margin:6px 0 0;color:var(--text-muted)}.opponent-panel-body{overflow-y:auto;padding-right:4px}.opponent-grid{grid-template-columns:1fr}.opponent-debug{margin-top:16px;padding:10px 12px;border-radius:10px;border:1px dashed var(--border);background:var(--panel-2);color:var(--text-muted);font-size:.75rem;display:grid;gap:4px}.game-nav{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:6px 0;border-bottom:1px solid var(--border)}.game-nav-stats{display:inline-flex;align-items:center;gap:18px}.game-nav-stat{display:grid;gap:6px;justify-items:center}.game-nav-stat-label{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);min-width:22px;text-align:center}.game-nav-stat-controls{display:inline-flex;align-items:center;gap:8px;padding:6px 8px;border-radius:10px;background:var(--panel-2);border:1px solid var(--border)}.game-nav-stat-button{width:26px;height:26px;border-radius:8px;border:1px solid transparent;background:var(--panel);color:var(--text);cursor:pointer;font-size:1rem;line-height:1}.game-nav-stat-button:hover{border-color:color-mix(in srgb,var(--accent) 55%,transparent)}.game-nav-stat-value{min-width:32px;text-align:center;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}.game-nav-left{display:inline-flex;align-items:center;gap:12px;position:relative}.opponent-toggle{padding:8px 14px}.game-nav-menu{position:relative}.game-menu-button{width:40px;height:34px;border-radius:10px;border:1px solid var(--border);background:var(--panel);display:grid;gap:5px;padding:6px 9px;cursor:pointer}.game-menu-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.game-menu-bar{display:block;height:2px;border-radius:999px;background:var(--text)}.game-menu-backdrop{position:fixed;inset:0;background:#0607098c;opacity:0;pointer-events:none;transition:opacity .18s ease;z-index:20}.game-menu-backdrop.open{opacity:1;pointer-events:auto}.game-menu-drawer{position:fixed;top:0;left:0;height:100vh;width:min(34vw,420px);max-width:85vw;background:var(--panel);border-right:1px solid var(--border);padding:18px 16px;transform:translate(-100%);transition:transform .22s ease;z-index:21;display:grid;align-content:start;gap:12px;overflow-y:auto}.game-menu-drawer.open{transform:translate(0)}.game-menu-panel{display:grid;gap:10px}.game-menu-group{border:1px solid var(--border);background:var(--panel-2);border-radius:10px;padding:6px 10px}.game-menu-summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;font-size:.9rem;color:var(--text);font-weight:600;gap:12px}.game-menu-summary::-webkit-details-marker{display:none}.game-menu-summary:after{content:"›";color:var(--text-muted);transform:rotate(0);transition:transform .15s ease}.game-menu-group[open] .game-menu-summary:after{transform:rotate(90deg)}.game-menu-content{margin-top:8px;padding-top:8px;border-top:1px solid var(--border);color:var(--text-muted);font-size:.85rem}.game-menu-equipment{display:grid;gap:8px}.game-menu-equipment-item{border:1px solid var(--border);border-radius:8px;padding:6px 8px;background:var(--panel)}.game-menu-equipment-name{list-style:none;cursor:pointer;color:var(--text);font-weight:600;display:flex;align-items:center;justify-content:space-between;gap:10px}.game-menu-equipment-name::-webkit-details-marker{display:none}.game-menu-equipment-name:after{content:"›";color:var(--text-muted);transition:transform .15s ease}.game-menu-equipment-item[open] .game-menu-equipment-name:after{transform:rotate(90deg)}.game-menu-equipment-rule{margin-top:6px;color:var(--text-muted);line-height:1.4;white-space:pre-line}.game-menu-weapon-table{margin-bottom:8px}.game-menu-equipment-text{white-space:pre-line}.game-menu-ploys{display:grid;gap:8px}.game-menu-ploy-item{border:1px solid var(--border);border-radius:8px;padding:6px 8px;background:var(--panel)}.game-menu-ploy-name{list-style:none;cursor:pointer;color:var(--text);font-weight:600;display:flex;align-items:center;justify-content:space-between;gap:10px}.game-menu-ploy-title{min-width:0;flex:1}.cost-badge{font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);border:1px solid var(--border);border-radius:999px;padding:2px 8px;background:var(--panel-2);white-space:nowrap}.game-menu-ploy-name::-webkit-details-marker{display:none}.game-menu-ploy-name:after{content:"›";color:var(--text-muted);transition:transform .15s ease}.game-menu-ploy-item[open] .game-menu-ploy-name:after{transform:rotate(90deg)}.game-menu-ploy-description{margin-top:6px;color:var(--text-muted);line-height:1.4;white-space:pre-line}.game-menu-empty{color:var(--text-muted)}.game-nav-timer{font-family:var(--font-display);font-size:1.05rem;letter-spacing:.1em;color:var(--accent);display:inline-flex;align-items:center;gap:8px;line-height:1;min-width:110px;justify-content:flex-start;font-variant-numeric:tabular-nums}.game-nav-title{font-family:var(--font-display);font-size:1.1rem}.game-nav-subtitle{color:var(--text-muted);font-size:.9rem}.game-nav-links{display:flex;gap:12px}.game-nav-links .ghost-link{background:none;border:none;padding:0;font:inherit;cursor:pointer}.game-page{gap:24px}.game-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;align-items:stretch}@media(max-width:1100px){.game-nav{flex-direction:column;align-items:flex-start}.game-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:720px){.game-grid{grid-template-columns:1fr}}
