
:root{--bg:#161910;--surface:#1c2112;--surface2:#232916;--border:#32391c;--text:#e0dbc8;--muted:#8a8868;--dim:#464c28;--accent:#b88c28;--accent2:#7a5c18;--accent-rgb:184,140,40;--link:#6a9fc8;--link-h:#8abde0;--axis-c:#c97070;--allied-c:#6fbc8a;--accord-c:#c8a850;--btn-text:#0c0f08;--overlay:rgba(0,0,0,.8);--sw:240px;--topbar:52px;--fh:'Cinzel',Georgia,serif;--fh2:'Black Ops One',Georgia,serif;--fb:'Barlow',system-ui,sans-serif;--fm:'Share Tech Mono',monospace}
[data-theme="light"]{--bg:#ede5ce;--surface:#e4dbbe;--surface2:#d8ceac;--border:#b8a87a;--text:#1c1408;--muted:#5a4e36;--dim:#9a8a6a;--accent:#8b2020;--accent2:#6a1818;--accent-rgb:139,32,32;--link:#3a5c8a;--link-h:#2a4c7a;--axis-c:#8b2020;--allied-c:#1a5c30;--accord-c:#7a5c18;--btn-text:#f5ede0;--overlay:rgba(0,0,0,.6)}
[data-theme="light"] .b-vs{background:rgba(26,92,48,.1);color:#1a6b35}
[data-theme="light"] .b-u{background:rgba(160,32,32,.1);color:#a02020}
[data-theme="light"] .b-imm{background:rgba(100,20,180,.1);color:#6414b4}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;transition:background-color .25s,color .15s}
body{background:var(--bg);color:var(--text);font-family:var(--fb);font-size:16px;line-height:1.8;display:flex;flex-direction:column;min-height:100vh;transition:background-color .25s,color .15s}
[data-theme="light"] body{background-image:repeating-linear-gradient(90deg,transparent,transparent 119px,rgba(150,130,80,.05) 119px,rgba(150,130,80,.05) 120px),repeating-linear-gradient(0deg,transparent,transparent 29px,rgba(150,130,80,.04) 29px,rgba(150,130,80,.04) 30px)}

/* TOP NAV */
.topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar);background:var(--surface);border-bottom:1px solid var(--border);z-index:300;display:flex;align-items:center;justify-content:center;gap:10px;padding:0 1rem}
.topbar-brand{position:absolute;left:1.25rem;font-family:var(--fh2);font-size:20px;color:var(--accent);letter-spacing:.5px;line-height:1}
.topbar-brand span{display:block;font-size:9px;font-style:normal;letter-spacing:2px;color:var(--muted);text-transform:uppercase;margin-top:1px}
/* Shared topbar button base — explicit height so all buttons are identical regardless of font/emoji metrics */
.tab-btn,.tab-btn-dl,.theme-toggle,.lang-btn,.topbar-purchase{height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;border:1px solid var(--border);box-sizing:border-box;white-space:nowrap;cursor:pointer;transition:all .15s}
.tab-btn{padding:0 20px;background:transparent;color:var(--muted);font-family:var(--fb);font-size:13px;font-weight:500;letter-spacing:.3px}
.tab-btn:hover{border-color:var(--muted);color:var(--text)}
.tab-btn.active{border-color:var(--accent);color:var(--accent);background:rgba(var(--accent-rgb),.08)}
.tab-btn-dl{border-color:var(--dim);color:var(--dim);text-decoration:none;font-size:12px;padding:0 14px}
.tab-btn-dl:hover{border-color:var(--muted);color:var(--text)!important;text-decoration:none}
.topbar-right{position:absolute;right:1.25rem;display:flex;align-items:center;gap:8px}
.topbar-purchase{font-size:13px;font-family:var(--fb);color:var(--muted);text-decoration:none;padding:0 12px;border-color:var(--border);background:transparent}
.topbar-purchase:hover{color:var(--text);border-color:var(--muted)}
.theme-toggle{background:none;color:var(--muted);font-size:15px;padding:0 10px;flex-shrink:0}
.theme-toggle:hover{color:var(--text);border-color:var(--muted)}

/* MODAL SHARED STYLES — used by Campaign Manager modals */
.unlock-overlay{display:none;position:fixed;inset:0;z-index:700;background:var(--overlay);align-items:center;justify-content:center;padding:20px 16px}
.unlock-overlay.open{display:flex}
.unlock-panel{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:2rem;width:100%;box-shadow:0 8px 32px rgba(0,0,0,.45)}
.unlock-title{font-family:var(--fh);font-size:18px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--accent);margin-bottom:.4rem}
.unlock-submit{width:100%;padding:11px;background:var(--accent);color:var(--btn-text);border:none;border-radius:4px;font-family:var(--fh);font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:opacity .15s}
.unlock-submit:hover{opacity:.9}
.unlock-submit:disabled{opacity:.4;cursor:not-allowed}

/* PURCHASE PANEL */
.purchase-overlay{display:none;position:fixed;inset:0;z-index:600;background:var(--overlay);align-items:flex-start;justify-content:center;overflow-y:auto;padding:40px 16px}
.purchase-overlay.open{display:flex}
.purchase-modal{background:var(--surface);border:1px solid var(--border);border-radius:10px;width:100%;max-width:1100px;position:relative;display:flex;flex-direction:column;margin:0 auto}
.purchase-close{position:absolute;top:12px;right:14px;background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;padding:4px 8px;z-index:1}
.purchase-close:hover{color:var(--text)}
.purchase-header{padding:2rem 2rem 1rem}
.purchase-title{font-family:var(--fh);font-size:20px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--accent);margin-bottom:.4rem}
.purchase-subtitle{font-size:13px;color:var(--muted);line-height:1.6}
/* Tab bar */
.purchase-tabs{display:flex;gap:0;padding:0 2rem;border-bottom:1px solid var(--border)}
.purchase-tab{font-family:var(--fb);font-size:12px;font-weight:600;letter-spacing:.4px;padding:8px 18px;background:transparent;border:1px solid transparent;border-bottom:none;border-radius:4px 4px 0 0;color:var(--muted);cursor:pointer;transition:color .15s;margin-bottom:-1px;white-space:nowrap}
.purchase-tab:hover{color:var(--text)}
.purchase-tab.active{background:var(--surface);border-color:var(--border);border-bottom-color:var(--surface);color:var(--accent)}
/* Grid */
.purchase-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem;padding:1.5rem 2rem}
.purchase-loading{color:var(--muted);font-size:13px;text-align:center;padding:2rem;grid-column:1/-1}
.purchase-footer{font-size:12px;color:var(--muted);line-height:1.6;padding:1rem 2rem 1.5rem;border-top:1px solid var(--border);text-align:center}
.purchase-footer strong{color:var(--text)}
/* Rules cover page — screen only: hidden; shows only in @media print */
.rules-print-cover{display:none}
/* EXPORT CODES MODAL */
.topbar-export{border-color:var(--dim);font-size:12px}
.export-codes-panel{max-width:500px;display:flex;flex-direction:column;gap:.75rem}
.export-codes-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.export-codes-close{background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;padding:2px 6px;line-height:1}
.export-codes-close:hover{color:var(--text)}
.export-codes-hint{font-size:12px;color:var(--muted);line-height:1.5;margin:0}
.export-row{display:flex;align-items:center;gap:.5rem;padding:.6rem 0;border-bottom:1px solid var(--border)}
.export-row:last-child{border-bottom:none}
.export-label{font-family:var(--fh);font-size:11px;font-weight:600;letter-spacing:.4px;color:var(--accent);min-width:120px;flex-shrink:0}
.export-code{font-family:var(--fm);font-size:11px;color:var(--text);flex:1;word-break:break-all;line-height:1.4}
.export-copy-btn{flex-shrink:0;padding:4px 10px;border-radius:4px;font-family:var(--fh);font-size:9px;font-weight:700;letter-spacing:.5px;cursor:pointer;border:1px solid var(--border);color:var(--muted);background:transparent;white-space:nowrap;transition:all .15s}
.export-copy-btn:hover{border-color:var(--muted);color:var(--text)}
.export-empty{font-size:13px;color:var(--muted);text-align:center;padding:1.5rem 0;margin:0}
.export-codes-footer{padding-top:.5rem;border-top:1px solid var(--border)}
.export-copy-all-btn{width:100%;padding:9px;background:transparent;border:1px solid var(--border);border-radius:4px;font-family:var(--fh);font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:all .15s}
.export-copy-all-btn:hover{border-color:var(--accent);color:var(--accent)}
/* Cards */
.purchase-card{background:transparent;border:none;border-radius:8px;aspect-ratio:2/3;perspective:1000px;cursor:pointer}
.purchase-card-inner{position:relative;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}
.purchase-card.flipped .purchase-card-inner{transform:rotateY(180deg)}
.purchase-card-front,.purchase-card-back{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:8px;overflow:hidden;border:1px solid var(--border)}
.purchase-card-front{background:var(--dim)}
.purchase-card-back{background:var(--bg);transform:rotateY(180deg);display:flex;flex-direction:column;overflow-x:hidden;overflow-y:auto;border-color:var(--muted)}
.purchase-card-portrait{width:100%;height:100%;object-fit:cover;display:block}
.purchase-card-portrait-hint{position:absolute;bottom:0;left:0;right:0;padding:10px 12px;background:linear-gradient(transparent,rgba(0,0,0,.75));font-family:var(--fh);font-size:9px;letter-spacing:1.2px;text-transform:uppercase;color:rgba(255,255,255,.6);text-align:center;pointer-events:none}
.purchase-card-body{padding:1rem;display:flex;flex-direction:column;gap:.5rem;flex:1;overflow-y:auto}
.purchase-card-name-row{display:flex;align-items:baseline;gap:.5rem;flex-wrap:wrap}
.purchase-card-name{font-family:var(--fh);font-size:14px;font-weight:600;letter-spacing:.5px;color:var(--text);margin:0}
.purchase-card-desc{font-size:12px;color:var(--muted);line-height:1.55;margin:0;flex:1}
.purchase-card-factions{font-size:11px;color:var(--muted);margin:0}
.purchase-card-factions span{color:var(--dim);text-transform:uppercase;letter-spacing:.5px;font-size:10px}
.purchase-card-cta{margin-top:.25rem}
.purchase-card-btn{display:inline-block;padding:7px 14px;border-radius:4px;font-family:var(--fb);font-size:12px;font-weight:600;letter-spacing:.3px;cursor:pointer;text-decoration:none;border:1px solid var(--accent);color:var(--accent);background:rgba(var(--accent-rgb),.08);transition:all .15s;text-align:center;width:100%;box-sizing:border-box}
.purchase-card-btn:hover{background:rgba(var(--accent-rgb),.2);color:var(--accent)}
.purchase-card-ks-badge{display:block;font-family:var(--fh);font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);border:1px solid var(--border);border-radius:4px;padding:5px 10px;text-align:center}
/* Side badge on individual faction cards */
.purchase-card-side{font-family:var(--fh);font-size:9px;font-weight:700;letter-spacing:1px;padding:2px 6px;border-radius:3px;white-space:nowrap}
.purchase-card-side--allied{background:rgba(80,140,200,.15);color:#7ab0d8;border:1px solid rgba(80,140,200,.25)}
.purchase-card-side--axis{background:rgba(200,80,80,.12);color:var(--axis-c);border:1px solid rgba(200,80,80,.2)}
.purchase-card-side--accord{background:rgba(160,120,200,.12);color:#b89fd8;border:1px solid rgba(160,120,200,.2)}
/* Per-card unlock row */
.purchase-card-unlock{display:flex;flex-direction:column;gap:.35rem;margin-top:.5rem}
.purchase-card-unlock-input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:6px 8px;font-size:11px;font-family:var(--fb);color:var(--text);outline:none;transition:border-color .15s}
.purchase-card-unlock-input::placeholder{color:var(--dim)}
.purchase-card-unlock-input:focus{border-color:var(--muted)}
.purchase-card-unlock-btn{width:100%;padding:6px 10px;border-radius:4px;font-family:var(--fh);font-size:10px;font-weight:700;letter-spacing:.5px;cursor:pointer;border:1px solid var(--border);color:var(--muted);background:transparent;transition:all .15s}
.purchase-card-unlock-btn:hover:not(:disabled){border-color:var(--muted);color:var(--text)}
.purchase-card-unlock-btn:disabled{opacity:.5;cursor:not-allowed}
.purchase-card-unlock-msg{font-size:11px;min-height:16px;padding:0 2px}
.purchase-card-unlock-msg.ok{color:#6ab06a}
.purchase-card-unlock-msg.err{color:#cc5050}

/* LAYOUT WRAPPER */
.app{display:flex;flex:1;padding-top:var(--topbar)}

/* SIDEBAR */
.sidebar{width:var(--sw);height:calc(100vh - var(--topbar));background:var(--surface);border-right:1px solid var(--border);position:fixed;top:var(--topbar);left:0;overflow:hidden;z-index:100;display:flex;flex-direction:column;scrollbar-width:thin;scrollbar-color:var(--dim) transparent;transition:transform .2s}
.brand{padding:1.25rem 1.25rem 1rem;border-bottom:1px solid var(--border);flex-shrink:0}
.sidebar nav{overflow-y:auto;flex:1;scrollbar-width:thin;scrollbar-color:var(--dim) transparent}
.brand-title{font-family:var(--fh2);font-size:26px;color:var(--accent);letter-spacing:.5px;line-height:1.1}
.brand-sub{font-size:10px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-top:4px}
.nav-section{padding:0.6rem 0;border-bottom:1px solid var(--border)}
.nav-label{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--dim);padding:0 1.25rem 0.4rem}
.nav-link{display:block;padding:5px 1.25rem;color:var(--muted);text-decoration:none;font-size:14px;transition:all .12s;border-left:2px solid transparent;line-height:1.4}
.nav-link:hover{color:var(--text);background:var(--surface2)}
.nav-link.active{color:var(--accent);border-left-color:var(--accent);background:var(--surface2)}
.nav-link.sub{padding-left:2rem;font-size:13px}
.nav-link.locked{color:var(--dim);font-size:12px}
.nav-link.locked::before{content:'⬡ ';font-size:10px}
.nav-footer{margin-top:auto;padding:1rem 1.25rem;font-size:11px;color:var(--dim);border-top:1px solid var(--border);line-height:1.6}

/* VIEWS */
.view{display:none;flex:1}
.view.active{display:block}

/* RULES VIEW */
.rules-layout{display:flex}
.main{margin-left:var(--sw);flex:1;max-width:860px;padding:3rem 3.5rem 3rem}

/* TYPE */
h1.pg{font-family:var(--fh2);font-size:56px;color:var(--accent);letter-spacing:1px;line-height:1.05;margin-bottom:.5rem}
.pg-sub{font-size:13px;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:2.5rem;border-bottom:1px solid var(--border);padding-bottom:1.5rem;font-family:var(--fm)}
h2{font-family:var(--fh2);font-size:30px;color:var(--text);margin:3rem 0 1rem;padding-bottom:.6rem;border-bottom:1px solid var(--border);scroll-margin-top:1.5rem}
h3{font-family:var(--fh2);font-size:20px;color:var(--accent);margin:1.75rem 0 .7rem}
h4{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin:1.25rem 0 .5rem;font-family:var(--fb)}
p{margin-bottom:1rem}
a{color:var(--link)}
a:hover{color:var(--link-h)}
strong{color:var(--text);font-weight:600}
ul,ol{margin:.5rem 0 1rem 1.25rem}
li{margin-bottom:.35rem}

/* RULES ASIDE BOX */
.rules-aside{background:var(--surface);border:1px solid rgba(120,160,200,.3);border-left:3px solid #7ab0d0;border-radius:5px;padding:1rem 1.25rem;margin:1.25rem 0 1.75rem;font-size:13px;color:var(--muted);line-height:1.7}
.rules-aside strong{color:var(--text)}

/* TABLES */
.tw{overflow-x:auto;margin:1rem 0 1.5rem;border-radius:5px;border:1px solid var(--border)}
table{width:100%;border-collapse:collapse;font-size:14px}
thead{background:var(--surface2)}
th{padding:8px 12px;text-align:left;font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border);font-family:var(--fb);font-weight:600}
tbody tr{border-bottom:1px solid var(--border)}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--surface2)}
td{padding:8px 12px;vertical-align:top}
.td-id{color:var(--muted);font-family:var(--fm);font-size:11px}
.td-name{font-weight:500;color:var(--text)}
.td-desc{color:var(--muted);font-size:12px;line-height:1.5}
.td-mono{font-family:var(--fm);font-size:12px;color:var(--muted)}

/* BADGES */
.b{display:inline-block;padding:1px 7px;border-radius:3px;font-size:11px;font-family:var(--fm);font-weight:600;letter-spacing:.3px}
.b-vs{background:rgba(74,138,92,.2);color:#6fcf97}
.b-s{background:rgba(100,116,139,.15);color:#94a3b8}
.b-u{background:rgba(138,74,74,.2);color:#f87171}
.b-axis{background:rgba(180,80,80,.12);color:var(--axis-c)}
.b-allied{background:rgba(74,140,100,.12);color:var(--allied-c)}
.b-accord{background:rgba(184,140,40,.12);color:var(--accord-c)}
.b-imm{background:rgba(168,85,247,.12);color:#c084fc}
.b-acc{background:rgba(var(--accent-rgb),.15);color:var(--accent)}

/* RULE CALLOUTS */
.rule{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:0 4px 4px 0;padding:1rem 1.25rem;margin:1.25rem 0}
.rule h4{margin-top:0;color:var(--accent)}
.rule ul,.rule ol{margin:.5rem 0 0 1.75rem}
.rule li{margin-bottom:.3rem;color:var(--text);padding-left:.25rem}
.rule li::marker{color:var(--accent)}
.rule ul,.rule ol{margin:.5rem 0 0 1.75rem}
.rule li{margin-bottom:.3rem;color:var(--text);padding-left:.25rem}
.rule li::marker{color:var(--accent)}
.note{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:.75rem 1rem;margin:.75rem 0;font-size:13px;color:var(--muted);font-style:italic}

/* FACTION BLOCKS */
.faction-block{background:var(--surface);border:1px solid var(--border);border-radius:6px;overflow:hidden;margin:1.5rem 0}
.faction-head{padding:1rem 1.25rem;border-bottom:1px solid var(--border);display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.faction-name{font-family:var(--fh2);font-size:24px;color:var(--text)}
.faction-body{padding:1.25rem;display:flex;gap:1.5rem;align-items:flex-start}
.faction-archetypes{flex:1;min-width:0}
.faction-img-viewer{display:none}
.faction-img-frame{width:260px;height:380px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;overflow:hidden;position:relative}
.faction-img-frame img{width:100%;height:100%;object-fit:cover;display:block}
.faction-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--dim);font-size:11px;font-family:var(--fm);letter-spacing:.5px;text-align:center;padding:1rem}
.faction-img-nav{display:flex;align-items:center;gap:8px;width:100%}
.faction-img-btn{background:var(--surface2);border:1px solid var(--border);border-radius:3px;color:var(--muted);cursor:pointer;padding:4px 10px;font-size:14px;transition:all .12s;flex-shrink:0}
.faction-img-btn:hover{color:var(--text);border-color:var(--muted)}
.faction-img-label{flex:1;text-align:center;font-size:10px;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);font-family:var(--fh);font-weight:600}
.faction-rule{font-size:14px;color:var(--text);background:var(--surface2);border-left:2px solid var(--accent2);padding:.75rem 1rem;margin:0 0 1.25rem;border-radius:0 4px 4px 0;line-height:1.65;opacity:.9}
.faction-rule strong{color:var(--accent);display:block;margin-bottom:4px;font-size:11px;letter-spacing:.5px;text-transform:uppercase}
.foes-row{font-size:13px;color:var(--muted);margin-bottom:.75rem}
.foes-row span{color:var(--text);font-family:var(--fm)}

/* ARCHETYPE CARDS */
.arch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:10px;margin-top:1rem}
.arch-card{background:var(--surface2);border:1px solid var(--border);border-radius:5px;padding:14px}
.arch-cls{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.arch-nm{font-family:var(--fh2);font-size:20px;color:var(--accent);margin-bottom:6px}
.arch-dsc{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:9px}
.arch-stats{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:9px}
.stat-pill{font-family:var(--fm);font-size:12px;padding:3px 9px;background:var(--surface);border:1px solid var(--border);border-radius:3px;color:var(--muted)}
.stat-pill span{color:var(--text);font-weight:600}
.arch-abil{display:flex;flex-wrap:wrap;gap:5px}
.abil-tag{font-size:11px;padding:3px 9px;background:rgba(var(--accent-rgb),.1);border:1px solid rgba(var(--accent-rgb),.25);border-radius:3px;color:var(--accent);font-family:var(--fm)}

/* FILTER */
.filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:1rem;align-items:center}
.filter-bar input,.filter-bar select{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:6px 10px;color:var(--text);font-size:13px;font-family:var(--fb);outline:none}
.filter-bar input{width:220px}
.filter-bar input:focus,.filter-bar select:focus{border-color:var(--accent)}
.filter-count{font-size:12px;color:var(--muted);margin-left:auto}

/* PHASE CARDS */
.phase-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:1rem 0 1.5rem}
.phase-card{background:var(--surface);border:1px solid var(--border);border-radius:5px;padding:1rem;text-align:center}
.phase-n{font-family:var(--fm);font-size:28px;color:var(--accent);opacity:.3;display:block}
.phase-name{font-family:var(--fh);font-size:15px;font-style:italic;color:var(--text)}
.phase-d{font-size:12px;color:var(--muted);margin-top:5px;line-height:1.4}

/* LOCKED */
.locked-block{border:1px solid var(--border);border-radius:6px;overflow:hidden;margin:2rem 0}
.locked-hd{background:var(--surface2);padding:1rem 1.25rem;display:flex;align-items:center;gap:12px}
.locked-title{font-family:var(--fh);font-size:18px;color:var(--muted);font-style:italic}
.locked-items{padding:1rem 1.25rem;background:var(--surface)}
.locked-item{padding:5px 0;border-bottom:1px solid var(--border);font-size:13px;color:var(--dim)}
.locked-item:last-child{border-bottom:none}

/* LORE VIEW */
.lore-main{margin-left:var(--sw);max-width:860px;padding:3rem 3.5rem 3rem}
.lore-hero{margin-bottom:3rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}
.lore-hero h1{font-family:var(--fh2);font-size:52px;color:var(--accent);line-height:1.1;margin-bottom:.4rem}
.lore-hero p{color:var(--text);font-size:15px;font-style:italic;max-width:560px;opacity:.7}
.lore-ch-num{font-family:var(--fm);font-size:12px;color:var(--accent);min-width:28px;flex-shrink:0}
.lore-ch-tag{font-size:10px;padding:2px 10px;border-radius:3px;background:var(--surface2);color:var(--muted);border:1px solid var(--border);font-family:var(--fm);letter-spacing:.5px;flex-shrink:0}
.lore-section{margin-bottom:3rem;padding-bottom:2.5rem;border-bottom:1px solid var(--border);scroll-margin-top:80px}
.lore-section:last-child{border-bottom:none}
.lore-sec-hd{display:flex;align-items:baseline;gap:14px;margin-bottom:1.25rem}
.lore-sec-title{font-family:var(--fh2);font-size:28px;color:var(--accent);flex:1;margin:0;padding:0;border:none}
.lore-section p{color:var(--text);font-size:16px;line-height:1.9;margin-bottom:1.1rem}

/* ARMY BUILDER VIEW */
.ab-view{margin-left:var(--sw);max-width:980px;padding:3rem 3.5rem 3rem}
.mg-card{background:var(--surface2);border:1px solid var(--border);border-radius:5px;padding:14px 16px;margin-bottom:12px}
.mg-card-label{font-size:11px;letter-spacing:1.2px;text-transform:uppercase;color:var(--accent);font-family:var(--fh);font-weight:600;margin-bottom:8px}
.mg-card-die{display:inline-block;font-family:var(--fm);font-size:12px;color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:3px;padding:2px 9px;margin-bottom:8px}
.mg-card-name{font-family:var(--fh2);font-size:24px;color:var(--text);margin-bottom:8px}
.mg-card-effect{font-size:15px;color:var(--text);line-height:1.7;margin-bottom:6px}
.mg-card-flavour{font-size:13px;color:var(--muted);font-style:italic;border-left:2px solid var(--border);padding-left:10px;margin-top:10px;line-height:1.7}
.mg-card-reward{font-size:14px;color:var(--accent);margin-top:8px;font-weight:600}

.fm-main{margin-left:var(--sw);max-width:980px;padding:3rem 3.5rem 3rem}
.cm-main{margin-left:var(--sw);max-width:980px;padding:3rem 3.5rem 3rem}
.cm-tab{padding:10px 20px;background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);font-family:var(--fh);font-size:13px;font-weight:600;letter-spacing:.8px;cursor:pointer;margin-bottom:-1px;transition:all .15s}
.cm-tab.active{border-bottom-color:var(--accent);color:var(--accent)}
.cm-tab:hover{color:var(--text)}
.cm-section-title{font-family:var(--fh2);font-size:28px;color:var(--text);margin-bottom:.4rem}
.cm-subtitle{font-size:13px;color:var(--muted);margin-bottom:2rem}
.cm-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:1.25rem;margin-bottom:12px}
.cm-card-title{font-family:var(--fh2);font-size:20px;color:var(--accent);margin-bottom:.4rem}
.cm-stat-row{display:flex;align-items:baseline;gap:8px;margin-bottom:6px}
.cm-stat-label{font-size:11px;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);font-family:var(--fh);min-width:120px}
.cm-stat-val{font-size:15px;color:var(--text);font-family:var(--fm)}
.cm-hunter-card{background:var(--surface);border:1px solid rgba(var(--accent-rgb),.3);border-radius:6px;padding:1.25rem;margin-bottom:12px}
.cm-hunter-card.kia{border-color:var(--border);opacity:.5}
.cm-hunter-name{font-family:var(--fh2);font-size:22px;color:var(--accent);margin-bottom:2px}
.cm-hunter-meta{font-size:11px;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);font-family:var(--fh);margin-bottom:10px}
.cm-mh-bar{height:8px;background:var(--border);border-radius:4px;overflow:hidden;margin:6px 0 10px}
.cm-mh-fill{height:100%;border-radius:4px;background:var(--accent);transition:width .3s}
.cm-ap-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(var(--accent-rgb),.12);border:1px solid rgba(var(--accent-rgb),.35);border-radius:4px;padding:6px 14px;font-family:var(--fm);font-size:20px;color:var(--accent);font-weight:700}
.cm-asset-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:1rem 1.25rem;margin-bottom:10px;display:flex;align-items:center;gap:16px}
.cm-asset-name{font-family:var(--fh2);font-size:18px;color:var(--text);flex:1}
.cm-asset-effect{font-size:13px;color:var(--muted);line-height:1.6;margin-top:3px}
.cm-tier-badge{font-family:var(--fm);font-size:11px;padding:3px 8px;border-radius:3px;border:1px solid var(--border);color:var(--muted);white-space:nowrap}
.cm-tier-badge.active{background:rgba(var(--accent-rgb),.15);border-color:rgba(var(--accent-rgb),.5);color:var(--accent)}
.cm-aux-card{background:var(--surface);border:1px solid rgba(120,160,200,.35);border-radius:6px;padding:1.25rem}
.cm-aux-card.cm-aux-empty{display:flex;align-items:center;gap:16px;border-style:dashed;opacity:.85}
.cm-aux-name{font-family:var(--fh2);font-size:20px;color:var(--text);margin-bottom:3px}
.cm-aux-label{font-family:var(--fm);font-size:10px;letter-spacing:1px;color:#7ab0d0;background:rgba(120,160,200,.12);border:1px solid rgba(120,160,200,.3);border-radius:3px;padding:1px 6px;vertical-align:middle;margin-left:6px}
.cm-aux-stats{font-size:11px;font-family:var(--fm);color:var(--muted);letter-spacing:.5px;margin-bottom:4px}
.cm-aux-hint{font-size:13px;color:var(--dim);font-style:italic}
.cm-aux-ability-pos{font-size:12px;color:var(--text);line-height:1.6;margin-top:6px}
.cm-aux-ability-neg{font-size:12px;color:#cc6050;line-height:1.6;margin-top:3px}
.cm-log-entry{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:1rem 1.25rem;margin-bottom:8px}
.cm-log-num{font-family:var(--fm);font-size:11px;color:var(--accent);margin-bottom:4px}
.cm-log-title{font-size:14px;color:var(--text);font-weight:600;margin-bottom:4px}
.cm-log-meta{font-size:12px;color:var(--muted);line-height:1.6}
/* ── Downtime Phase ── */
.dt-card{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:10px 12px}
.dt-card-head{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}
.dt-hname{font-size:14px;font-weight:600;font-style:italic;color:var(--text)}
.dt-hcls{font-size:10px;color:var(--muted);font-family:var(--fm);flex:1}
.dt-badge{font-size:9px;font-family:var(--fm);letter-spacing:.7px;text-transform:uppercase;padding:2px 6px;border-radius:3px;font-weight:600}
.dt-badge-dep{background:rgba(200,60,40,.12);color:#cc3820;border:1px solid rgba(200,60,40,.3)}
.dt-badge-rest{background:rgba(60,160,80,.12);color:#2a8a3a;border:1px solid rgba(60,160,80,.3)}
.dt-action-row{display:flex;gap:8px;align-items:center;margin-bottom:6px}
.dt-result{font-size:12px;line-height:1.6;color:var(--text);min-height:18px;padding:2px 0}
.dt-die{font-family:var(--fm);font-size:11px;background:var(--surface);border:1px solid var(--border);border-radius:3px;padding:1px 6px;color:var(--muted);margin-right:6px}
.dt-ok{color:#2a8a3a;font-weight:600}
.dt-ko{color:var(--muted)}
.dt-flag{color:#c89230;font-weight:600}
.cm-btn{padding:9px 20px;border-radius:4px;font-family:var(--fh);font-size:12px;font-weight:600;letter-spacing:.5px;cursor:pointer;border:1px solid rgba(var(--accent-rgb),.4);background:rgba(var(--accent-rgb),.12);color:var(--accent);transition:all .15s}
.cm-btn:hover{background:rgba(var(--accent-rgb),.25)}
.cm-btn-muted{padding:9px 20px;border-radius:4px;font-family:var(--fh);font-size:12px;font-weight:600;letter-spacing:.5px;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--muted);transition:all .15s}
.cm-btn-muted:hover{color:var(--text);border-color:var(--muted)}
.fm-btn{display:block;width:100%;padding:10px 14px;background:rgba(var(--accent-rgb),.15);border:1px solid rgba(var(--accent-rgb),.4);border-radius:4px;color:var(--accent);font-family:var(--fh);font-size:12px;font-weight:600;letter-spacing:.5px;cursor:pointer;text-align:left;transition:all .15s;margin-bottom:6px}
.fm-btn:hover,.fm-btn.active{background:rgba(var(--accent-rgb),.28);border-color:var(--accent)}
.fm-btn.locked{background:transparent;border-color:var(--border);color:var(--dim);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:6px}
.fm-btn.locked:hover{border-color:rgba(var(--accent-rgb),.3);color:var(--muted)}
.fm-locked-hint{font-size:10px;letter-spacing:.4px;color:var(--accent);opacity:0;transition:opacity .15s;flex-shrink:0}
.fm-btn.locked:hover .fm-locked-hint{opacity:1}
.fm-btn-wrap{padding:.5rem 1.25rem}
.fm-btn-section{padding:12px 14px 4px;font-family:var(--fh);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--dim);border-top:1px solid var(--border);margin-top:4px}
.fm-faction-block{margin-bottom:2rem}
.fm-faction-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}
.fm-print-btn{margin-left:auto;padding:5px 14px;border:1px solid var(--border);border-radius:4px;background:transparent;color:var(--muted);font-family:var(--fb);font-size:12px;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}
.fm-print-btn:hover{border-color:var(--muted);color:var(--text)}
.fm-faction-name{font-family:var(--fh2);font-size:32px;color:var(--text)}
.fm-faction-meta{font-size:13px;color:var(--muted);margin-bottom:1.5rem}
.fm-lore-row{display:flex;gap:1.5rem;align-items:flex-start;margin:.9rem 0}
.fm-lore-row .fm-faction-lore{flex:1;margin:0}
.fm-lore-img{flex-shrink:0;width:390px;border-radius:4px;overflow:hidden;border:1px solid rgba(var(--accent-rgb),.25)}
.fm-lore-img img{width:100%;height:auto;display:block}
.fm-faction-lore{margin:.9rem 0;padding:.85rem 1.1rem;border-left:2px solid var(--accent2);background:var(--surface2)}
.fm-faction-lore p{font-size:13px;color:var(--muted);line-height:1.75;margin:0 0 .65rem}
.fm-faction-lore p:last-child{margin-bottom:0}
.fm-dossier-list{display:flex;flex-direction:column;gap:16px}
.fm-dossier-card{background:var(--surface);border:1px solid rgba(var(--accent-rgb),.4);border-radius:6px;overflow:hidden;display:flex;min-height:180px;box-shadow:inset 0 0 0 1px rgba(var(--accent-rgb),.08)}
.fm-dossier-card:hover{border-color:rgba(var(--accent-rgb),.7)}
.fm-dossier-body{flex:3;padding:24px 30px;display:flex;flex-direction:column;justify-content:flex-start;gap:12px}
.fm-dossier-token{flex:1;display:flex;align-items:center;justify-content:center;padding:20px 16px;background:var(--surface2);border-left:1px solid rgba(var(--accent-rgb),.2);min-width:0}
.fm-dossier-cls{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-family:var(--fh)}
.fm-dossier-name{font-family:var(--fh2);font-size:32px;color:var(--accent);line-height:1.1}
.fm-dossier-desc{font-size:15px;color:var(--muted);line-height:1.65;max-width:600px}
.fm-dossier-stats{display:flex;flex-wrap:wrap;gap:7px}
.fm-dossier-abils{display:flex;flex-wrap:wrap;gap:7px}
.fm-dossier-abil-list{display:flex;flex-direction:column;gap:8px;margin-top:2px;border-top:1px solid var(--border);padding-top:12px}
.fm-dossier-abil-item{display:flex;gap:12px;align-items:baseline}
.fm-dossier-abil-name{font-family:var(--fm);font-size:12px;color:var(--accent);white-space:nowrap;min-width:180px}
.fm-dossier-abil-desc{font-size:14px;color:var(--muted);line-height:1.55}

.ab-view-hd{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
.ab-view-hd h1{font-family:var(--fh2);font-size:46px;color:var(--accent);margin-bottom:.3rem}
.ab-view-hd p{color:var(--muted);font-size:14px}

/* HOMEPAGE */
.homepage{position:fixed;inset:0;z-index:1000;background:var(--bg);overflow:hidden;display:flex;flex-direction:column}
.hp-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 30%,rgba(120,70,10,.15) 0%,transparent 60%),radial-gradient(ellipse at 85% 90%,rgba(60,30,60,.13) 0%,transparent 50%),radial-gradient(ellipse at 10% 80%,rgba(30,40,80,.10) 0%,transparent 50%);pointer-events:none;z-index:0}

/* Three-column stage */
.hp-stage{position:relative;z-index:1;flex:1;display:grid;grid-template-columns:1fr 760px 1fr;min-height:0}

/* Divider lines between columns */
.hp-center{position:relative}
.hp-center::before,.hp-center::after{content:'';position:absolute;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent 0%,rgba(var(--accent-rgb),.18) 10%,rgba(var(--accent-rgb),.3) 50%,rgba(var(--accent-rgb),.18) 90%,transparent 100%);pointer-events:none}
.hp-center::before{left:0}
.hp-center::after{right:0}

/* Side panels */
.hp-panel{overflow-y:auto;padding:4rem 2.5rem 3rem;display:flex;flex-direction:column;gap:0;scrollbar-width:thin;scrollbar-color:var(--dim) transparent}
.hp-panel-label{font-family:var(--fm);font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--dim);margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}
.hp-panel p{font-size:15.5px;color:var(--muted);line-height:1.9;margin-bottom:1.1rem}
.hp-panel p:first-of-type{color:var(--text);opacity:.85}
.hp-panel-right{padding-top:4rem}
.hp-free-box{background:rgba(var(--accent-rgb),.05);border:1px solid rgba(var(--accent-rgb),.18);border-radius:5px;padding:1.1rem 1.25rem;margin-top:1rem}
.hp-free-box-title{font-family:var(--fh);font-size:11.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);margin-bottom:.5rem;font-weight:600}
.hp-free-box p{font-size:14.5px;color:var(--muted);line-height:1.7;margin:0}

/* Center column */
.hp-center{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;gap:0;text-align:center}
.hp-eyebrow{font-family:var(--fm);font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);opacity:.65;margin-bottom:2rem}
.hp-logo{width:100%;max-width:720px;filter:drop-shadow(0 0 28px rgba(var(--accent-rgb),.22));margin-bottom:2.5rem}
[data-theme="light"] .hp-logo{filter:drop-shadow(0 0 28px rgba(139,32,32,.22))}
.hp-line{width:60px;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);margin:0 auto 2.5rem}
.hp-btns{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:2rem}
.hp-btn{padding:13px 32px;border:1px solid var(--border);border-radius:4px;background:transparent;color:var(--muted);font-family:var(--fh);font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:all .2s}
.hp-btn:hover{color:var(--text);border-color:var(--muted)}
.hp-btn.primary{border-color:rgba(var(--accent-rgb),.5);color:var(--accent);background:rgba(var(--accent-rgb),.07)}
.hp-btn.primary:hover{border-color:var(--accent);background:rgba(var(--accent-rgb),.15)}
.hp-stamp{font-family:var(--fm);font-size:9px;letter-spacing:1.5px;color:var(--dim);opacity:.4;margin-top:.5rem}
.site-footer{position:fixed;bottom:0;left:0;right:0;padding:6px 1.5rem;padding-left:calc(var(--sw) + 1.5rem);border-top:1px solid var(--border);background:var(--surface);color:var(--muted);font-family:var(--fm);font-size:10px;letter-spacing:.6px;display:flex;align-items:center;justify-content:center;gap:10px;z-index:50}
.site-footer-sep{color:var(--dim)}

/* Mobile — collapse panels below center */
@media(max-width:900px){
  .homepage{overflow-y:auto}
  .hp-stage{grid-template-columns:1fr;grid-template-rows:auto auto auto}
  .hp-stage::before,.hp-stage::after{display:none}
  .hp-center{order:1;padding:3.5rem 1.5rem 2rem}
  .hp-panel-left{order:2;padding:2rem 1.5rem 1rem;border-top:1px solid var(--border)}
  .hp-panel-right{order:3;padding:1.5rem 1.5rem 3rem;border-top:1px solid var(--border)}
  .hp-logo{max-width:260px}
}

/* MOBILE */
.menu-btn{display:none;position:fixed;top:calc(var(--topbar) + 10px);left:12px;z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:7px 11px;color:var(--text);cursor:pointer;font-size:15px}
@media(max-width:768px){.menu-btn{display:block}.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main{margin-left:0;padding:1.5rem 1.25rem 5rem}.lore-main,.ab-view{padding:1.5rem 1.25rem 5rem}.topbar-brand span{display:none}}
.nav-label{cursor:pointer;user-select:none;display:flex;justify-content:space-between;align-items:center;padding-right:1.25rem}
.nav-label::after{content:'▾';font-size:9px;color:var(--dim);transition:transform .2s;margin-left:4px}
.nav-section.collapsed .nav-label::after{transform:rotate(-90deg)}
.nav-section.collapsed .nav-link{display:none}
.ab-stepper{display:flex;margin-bottom:2rem;border:1px solid var(--border);border-radius:5px;overflow:hidden}
.ab-step{flex:1;padding:10px 8px;text-align:center;cursor:pointer;border-right:1px solid var(--border);transition:all .15s}
.ab-step:last-child{border-right:none}
.ab-step .sn{font-family:var(--fm);font-size:22px;color:var(--dim);display:block;line-height:1}
.ab-step .sl{font-size:11px;color:var(--muted);margin-top:4px;display:block}
.ab-step.active{background:var(--surface2)}
.ab-step.active .sn{color:var(--accent)}
.ab-step.active .sl{color:var(--text)}
.ab-step.done .sn{color:var(--text)}
.ab-step.done .sl{color:var(--muted)}
.ab-step-blank{border-left:1px solid var(--border)!important}
.ab-step-blank .sn{color:var(--accent)!important;font-size:18px}
.ab-step-blank .sl{color:var(--accent)!important}
.ab-step-blank:hover{background:rgba(var(--accent-rgb),.08)}
.fp-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:1.5rem}
.fp-card{background:var(--surface);border:2px solid var(--border);border-radius:6px;padding:1.25rem;cursor:pointer;transition:all .15s}
.fp-card:hover{border-color:var(--muted)}
.fp-card.sel{border-color:var(--accent);background:var(--surface2)}
.fp-name{font-family:var(--fh2);font-size:24px;color:var(--text);margin-bottom:8px}
.fp-desc{font-size:14px;color:var(--text);line-height:1.65;margin:10px 0;opacity:.85}
.fp-rule-txt{font-size:13px;color:var(--text);background:var(--surface2);border-left:2px solid var(--accent2);padding:8px 12px;border-radius:0 3px 3px 0;line-height:1.6;opacity:.9}
.fp-card.sel .fp-rule-txt{background:var(--bg)}
.squad-list{display:flex;flex-direction:column;gap:12px}
.hunter-slot{background:var(--surface);border:1px solid var(--border);border-radius:6px;overflow:hidden}
.hs-hd{display:flex;align-items:center;gap:10px;padding:9px 14px;background:var(--surface2);border-bottom:1px solid var(--border)}
.hs-n{font-family:var(--fm);font-size:12px;color:var(--muted);min-width:18px}
.hs-title{font-family:var(--fh2);font-size:17px;color:var(--accent);flex:1}
.hs-del{background:none;border:none;cursor:pointer;color:var(--muted);font-size:12px;padding:3px 8px;border-radius:3px;transition:all .12s}
.hs-del:hover{color:var(--axis-c);background:rgba(180,80,80,.1)}
.hs-bd{padding:12px 14px;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hs-lbl{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--dim);margin-bottom:5px;display:block}
.ab-sel{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:7px 9px;color:var(--text);font-size:12px;font-family:var(--fb);outline:none;cursor:pointer;transition:border-color .12s;margin-bottom:2px}
.ab-sel:focus{border-color:var(--accent)}
.ab-sel:disabled{opacity:.4;cursor:not-allowed}
.ab-sel option{background:var(--surface)}
.hs-info{margin-top:8px}
.hs-warn{font-size:11px;color:var(--axis-c);padding:3px 8px;border-radius:3px;background:rgba(180,80,80,.08);border:1px solid rgba(180,80,80,.2);margin-top:5px;display:block}
.ab-add-slot{width:100%;padding:11px;background:var(--surface);border:1px dashed var(--border);border-radius:5px;color:var(--muted);font-size:13px;cursor:pointer;font-family:var(--fb);text-align:center;transition:all .15s;margin-top:4px}
.ab-add-slot:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--surface2)}
.ab-add-slot:disabled{opacity:.35;cursor:not-allowed}
.ab-nav{display:flex;gap:10px;margin-top:1.5rem;justify-content:flex-end}
.ab-btn{padding:8px 20px;border-radius:4px;font-size:13px;font-family:var(--fb);cursor:pointer;border:1px solid var(--border);transition:all .15s}
.ab-btn-p{background:var(--accent);color:var(--btn-text);border-color:var(--accent);font-weight:600}
.ab-btn-p:hover{opacity:.9}
.ab-btn-p:disabled{opacity:.4;cursor:not-allowed}
.ab-btn-s{background:var(--surface2);color:var(--text)}
.ab-btn-s:hover{border-color:var(--muted)}
.sm-faction-bar{display:flex;align-items:flex-start;justify-content:space-between;padding:1rem 1.25rem;background:var(--surface2);border:1px solid var(--border);border-radius:6px;margin-bottom:1.25rem;gap:12px}
.sm-fname{font-family:var(--fh2);font-size:24px}
.sm-hunters{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:12px;margin-bottom:1.5rem}
.sm-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;overflow:hidden}
.sm-ch{padding:9px 14px;background:var(--surface2);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:baseline}
.sm-cname{font-family:var(--fh2);font-size:19px;color:var(--accent)}
.sm-ccls{font-size:11px;color:var(--muted);font-family:var(--fm);letter-spacing:.5px}
.sm-cb{padding:12px 14px;font-size:13px}
.sm-row{display:flex;justify-content:space-between;align-items:baseline;padding:4px 0;border-bottom:1px solid var(--border);gap:8px}
.sm-row:last-child{border-bottom:none}
.sm-row-l{color:var(--muted);white-space:nowrap;flex-shrink:0;font-size:12px}
.sm-row-r{color:var(--text);text-align:right;display:flex;flex-wrap:wrap;gap:3px;justify-content:flex-end;align-items:center;font-size:13px}
.sa-block{background:var(--surface);border:1px solid var(--border);border-radius:6px;overflow:hidden;margin-bottom:1.5rem}
.sa-hd{padding:9px 14px;background:var(--surface2);border-bottom:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text)}
.sa-body{padding:10px 14px}
.sa-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--border)}
.sa-row:last-child{border-bottom:none}
.sa-entity{font-size:12px;color:var(--muted);min-width:130px}
.sa-badges{display:flex;gap:4px;min-width:90px}
.sa-bar{flex:1;height:8px;background:var(--border);border-radius:3px;overflow:hidden}
.sa-bar-fill{height:100%;border-radius:3px;transition:width .3s}
.sa-pct{font-size:13px;font-family:var(--fm);color:var(--muted);min-width:36px;text-align:right}
@media(max-width:600px){.fp-grid,.hs-bd,.sm-hunters{grid-template-columns:1fr}}
@media print{
  /* ── 1. Hide UI chrome ─────────────────────────────────────────────────── */
  /* site-footer is position:fixed — Chrome prints fixed elements on every page,
     it also corrupts the page-height calculation causing row breaks to fail.
     Copyright info is already in the @page margin boxes (Chrome/Edge). */
  .sidebar,.menu-btn,.ab-nav,.ab-stepper,.ab-add-slot,.hs-del,.filter-bar,.topbar,
  .print-header,.print-footer,.site-footer,.tour-dim,.tour-spotlight,.tour-card,
  .tour-replay-btn,.fm-print-btn,.ab-view-hd,.locked-hd,.locked-cta,
  .pack-locked-teaser{display:none!important}

  /* ── 2. Rules cover page ──────────────────────────────────────────────── */
  /* height:100vh is unreliable in Firefox print (maps to screen viewport, not
     paper). Use a fixed mm height matching A4 content area (297 - 22 - 20 = 255mm). */
  .rules-print-cover{display:flex!important;flex-direction:column;align-items:center;justify-content:center;
    height:255mm;min-height:255mm;page-break-after:always;break-after:page;text-align:center;gap:1.5rem}
  .rules-print-cover-logo{width:260px;height:auto}
  .rules-print-cover-title{font-family:'Cinzel',Georgia,serif;font-size:42px;font-weight:700;
    letter-spacing:4px;color:#b88c28;text-transform:uppercase}
  .rules-print-cover-subtitle{font-family:'Cinzel',Georgia,serif;font-size:18px;letter-spacing:6px;
    text-transform:uppercase;color:#7a5c18}
  .rules-print-cover-author{font-family:'Barlow',sans-serif;font-size:12px;letter-spacing:2px;
    color:#8a8868;margin-top:2rem}

  /* ── 3. Layout reset ───────────────────────────────────────────────────── */
  .main,.fm-main{margin:0!important;padding:0!important;max-width:100%!important}
  .sm-hunters{grid-template-columns:repeat(2,1fr)}

  /* ── 3. Colour & base typography ──────────────────────────────────────── */
  /* print-color-adjust must be inside a selector — bare declarations are invalid
     CSS inside @media and cause Chrome's parser to drop the next rule entirely,
     leaving all on-screen backgrounds intact when "Background graphics" is on. */
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact;background:white!important;color:#111!important;border-color:#ccc!important;box-shadow:none!important;text-shadow:none!important}
  body{font-size:10pt!important;line-height:1.55!important}
  p,li{orphans:3;widows:3}
  h1,h2,h3,h4,.pg,.lore-sec-title{color:#b07a10!important}
  h1{font-size:20pt!important}
  h2{font-size:15pt!important}
  h3{font-size:12pt!important}
  h4{font-size:10.5pt!important}

  /* ── 4. Fix overflow containers (ROOT CAUSE of row cuts) ──────────────── */
  /* .tw has overflow-x:auto — scroll containers block page-break propagation */
  .tw{overflow:visible!important;border:none!important;border-radius:0!important;margin:.5rem 0 1rem!important}
  .locked-block{overflow:visible!important}

  /* ── 5. Tables ────────────────────────────────────────────────────────── */
  table{border-collapse:collapse!important;width:100%!important;font-size:9.5pt!important;break-inside:auto}
  thead{display:table-header-group}  /* repeat header on each page for long tables */
  tfoot{display:table-footer-group}
  th{background:#f0f0f0!important;color:#333!important;border:1px solid #ccc!important;font-size:8.5pt!important;padding:4px 6px!important}
  td{border:1px solid #ddd!important;padding:4px 7px!important;vertical-align:top!important}
  tr{break-inside:avoid!important;page-break-inside:avoid!important}
  td{break-inside:avoid!important;page-break-inside:avoid!important}

  /* ── 6. Page break rules ──────────────────────────────────────────────── */
  /* Headings stay glued to what follows */
  h2{break-before:auto!important;break-after:avoid!important;page-break-after:avoid!important}
  h3{break-after:avoid!important;page-break-after:avoid!important}
  h4{break-after:avoid!important;page-break-after:avoid!important}
  /* Self-contained blocks that must not split */
  .note,.rules-aside,.faction-rule,.phase-card,.phase-row{break-inside:avoid!important;page-break-inside:avoid!important}
  /* Phase row: keep grid layout */
  .phase-row{display:flex!important;gap:8px!important}
  /* Large repeated sections are allowed to break — do NOT use section{avoid} */

  /* ── 7. Colour adjustments for print ──────────────────────────────────── */
  .faction-rule,.note,.tip{border:1px solid #ccc!important;border-left:3px solid #b07a10!important}
  .phase-card{border:1px solid #ccc!important}
  .rules-aside{border:1px solid #bbd4e8!important;border-left:3px solid #7ab0d0!important;background:#f8fbfd!important;color:#333!important}
  .stat-pill,.abil-tag,.b{border:1px solid #ccc!important;color:#333!important}
  .b-allied{color:#1a6b35!important;border-color:#1a6b35!important}
  .b-axis{color:#a02020!important;border-color:#a02020!important}
  .b-accord{color:#7a5c18!important;border-color:#7a5c18!important}
  .b-imm{color:#7a20c0!important;border-color:#7a20c0!important}

  /* ── 8. Field Manual dossier cards ───────────────────────────────────── */
  /* Token hidden in print; block layout avoids Chrome flex+break-inside bug */
  .fm-dossier-token{display:none!important}
  .fm-lore-img{display:none!important}
  .fm-lore-row{display:block!important;margin:.5rem 0!important}
  .fm-lore-row .fm-faction-lore{margin:0!important}
  .fm-dossier-list{display:block!important}
  .fm-dossier-list > *{margin-bottom:10px!important}
  .fm-dossier-card{display:block!important;min-height:0!important;height:auto!important;overflow:visible!important;break-inside:avoid!important;page-break-inside:avoid!important;border:1px solid #ccc!important;padding:10px 14px!important}
  .fm-dossier-body{display:block!important;padding:0!important}
  .fm-dossier-cls{display:block!important;font-size:9px!important;color:#666!important;margin-bottom:2px!important}
  .fm-dossier-name{display:block!important;font-size:17px!important;color:#b07a10!important;line-height:1.15!important;margin-bottom:5px!important}
  .fm-dossier-desc{display:block!important;font-size:10px!important;line-height:1.35!important;max-width:none!important;margin-bottom:5px!important}
  .fm-dossier-stats{display:flex!important;flex-wrap:wrap!important;gap:4px!important;margin-bottom:5px!important}
  .stat-pill{font-size:10px!important;padding:2px 7px!important}
  .fm-dossier-abils{display:flex!important;flex-wrap:wrap!important;gap:4px!important;margin-bottom:0!important;break-after:avoid!important;page-break-after:avoid!important}
  .abil-tag{border:1px solid #ccc!important;color:#333!important;font-size:10px!important;padding:1px 6px!important}
  .fm-dossier-abil-list{display:block!important;border-top:1px solid #ddd!important;padding-top:6px!important;margin-top:5px!important;break-before:avoid!important;page-break-before:avoid!important;break-inside:avoid!important;page-break-inside:avoid!important}
  .fm-dossier-abil-item{display:block!important;margin-bottom:5px!important;break-inside:avoid!important;page-break-inside:avoid!important}
  .fm-dossier-abil-item:last-child{margin-bottom:0!important}
  .fm-dossier-abil-name{display:inline!important;font-size:10px!important;color:#8b5e10!important;font-weight:700!important;margin-right:6px!important;min-width:0!important}
  .fm-dossier-abil-desc{display:inline!important;font-size:10px!important;color:#333!important;line-height:1.45!important}
  .fm-faction-lore{border-left:2px solid #b07a10!important;background:#fafafa!important}
  .fm-faction-lore p{color:#333!important;font-size:11px!important;line-height:1.55!important}
  .fm-faction-head{border-bottom:1px solid #ccc!important}
  .fm-faction-name{color:#b07a10!important}
}
/* ── Page size & margin — all browsers (Firefox, Chrome, Edge, Safari) ─────── */
/* Kept separate from the named margin boxes below so Firefox can parse this
   block without being confused by the @top-left / @bottom-right at-rules it
   does not yet implement. */
@page{
  size:A4;
  margin:22mm 12mm 20mm;
}

/* ── Firefox-only page margin override ───────────────────────────────────── */
/* @supports (-moz-appearance:none) is true only in Gecko (Firefox).
   Firefox does not render @page named margin boxes so it falls back to its own
   native print headers (title + URL rows) which eat into the top margin.
   We also suppress the title via JS (see beforeprint handler), but the footer
   row (page-of-X + date) still occupies ~8mm. Adding a few extra mm of top &
   bottom margin ensures those native rows never overlap the content. */
@supports (-moz-appearance:none){
  @page{ margin:28mm 12mm 26mm; }
}

/* ── Named margin boxes — running header/footer — Chrome/Edge only ──────────── */
/* Firefox silently ignores @top-left, @top-right, @bottom-left, @bottom-right.
   The size/margin above still apply; Firefox users won't see the decorative
   headers/footers but the page layout is otherwise identical. */
@page{
  @top-left{
    content:"GHOST FRONT";
    font-family:'Cinzel',Georgia,serif;
    font-size:8.5pt;
    font-weight:700;
    color:#b07a10;
    letter-spacing:1.5px;
    text-transform:uppercase;
    vertical-align:bottom;
    padding-bottom:3mm;
    border-bottom:0.4pt solid #ccc;
  }
  @top-right{
    content:"Rulebook  ·  Free Edition";  /* overridden dynamically by beforeprint */
    font-family:'Barlow',system-ui,sans-serif;
    font-size:7.5pt;
    color:#888;
    vertical-align:bottom;
    padding-bottom:3mm;
    border-bottom:0.4pt solid #ccc;
  }
  @bottom-left{
    content:"ghost-front.com  ·  Licensed for personal use";
    font-family:'Barlow',system-ui,sans-serif;
    font-size:7.5pt;
    color:#888;
    font-style:italic;
    vertical-align:top;
    padding-top:3mm;
    border-top:0.4pt solid #ccc;
  }
  @bottom-right{
    content:"Page " counter(page) " of " counter(pages);
    font-family:'Barlow',system-ui,sans-serif;
    font-size:7.5pt;
    color:#888;
    vertical-align:top;
    padding-top:3mm;
    border-top:0.4pt solid #ccc;
  }
}

/* ── ONBOARDING TOUR ─────────────────────────────────────────── */
.tour-overlay{position:fixed;inset:0;z-index:2000;pointer-events:none}
.tour-dim{position:fixed;inset:0;background:rgba(0,0,0,.62);z-index:2001;transition:opacity .25s}
.tour-spotlight{position:fixed;z-index:2002;border-radius:6px;box-shadow:0 0 0 9999px rgba(0,0,0,.62);pointer-events:none;transition:all .25s cubic-bezier(.4,0,.2,1)}
.tour-card{position:fixed;z-index:2003;background:var(--surface2);border:1px solid rgba(var(--accent-rgb),.45);border-radius:8px;width:310px;padding:1.25rem 1.25rem 1rem;box-shadow:0 8px 32px rgba(0,0,0,.6);transition:all .25s cubic-bezier(.4,0,.2,1)}
.tour-card::before{content:'';position:absolute;width:10px;height:10px;background:var(--surface2);border:1px solid rgba(var(--accent-rgb),.45);transform:rotate(45deg)}
.tour-card.arrow-top::before{top:-6px;left:20px;border-bottom:none;border-right:none}
.tour-card.arrow-bottom::before{bottom:-6px;left:20px;border-top:none;border-left:none}
.tour-card.arrow-left::before{left:-6px;top:20px;border-right:none;border-bottom:none}
.tour-card.arrow-right::before{right:-6px;top:20px;border-left:none;border-top:none}
.tour-eyebrow{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);font-family:var(--fm);margin-bottom:.4rem}
.tour-title{font-family:var(--fh2);font-size:17px;color:var(--text);margin-bottom:.5rem}
.tour-body{font-size:13px;color:var(--muted);line-height:1.65;margin-bottom:1rem}
.tour-footer{display:flex;align-items:center;justify-content:space-between;gap:8px}
.tour-step{font-size:11px;color:var(--dim);font-family:var(--fm)}
.tour-btns{display:flex;gap:8px;align-items:center}
.tour-btn-next{padding:6px 18px;background:var(--accent);color:var(--btn-text);border:none;border-radius:4px;font-family:var(--fh);font-size:11px;font-weight:700;letter-spacing:.8px;cursor:pointer;transition:opacity .15s}
.tour-btn-next:hover{opacity:.85}
.tour-btn-skip{padding:6px 10px;background:none;border:none;color:var(--dim);font-size:11px;cursor:pointer;font-family:var(--fb)}
.tour-btn-skip:hover{color:var(--muted)}
.tour-replay-btn{position:fixed;bottom:22px;right:22px;z-index:1500;width:36px;height:36px;border-radius:50%;background:var(--surface);border:1px solid var(--border);color:var(--dim);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;font-family:var(--fb)}
.tour-replay-btn:hover{border-color:var(--accent);color:var(--accent)}

/* ── Language picker ─────────────────────────────────────────── */
.lang-picker{position:relative;display:flex;align-items:center}
.lang-btn{background:none;border:1px solid var(--border);border-radius:4px;color:var(--muted);font-family:var(--fm);font-size:12px;padding:7px 10px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:5px}
.lang-btn:hover{border-color:var(--muted);color:var(--text)}
.lang-dropdown{display:none;position:absolute;top:calc(100% + 6px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:5px;padding:4px;min-width:130px;z-index:500;box-shadow:0 4px 16px rgba(0,0,0,.4)}
.lang-dropdown.open{display:block}
.lang-option{display:block;width:100%;padding:6px 10px;background:none;border:none;color:var(--muted);font-family:var(--fm);font-size:12px;text-align:left;cursor:pointer;border-radius:3px;transition:all .1s}
.lang-option:hover{background:var(--surface2);color:var(--text)}
.lang-option.active{color:var(--accent)}
