:root{color:#111827;background:#f5f7f6;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select,textarea{font:inherit}button{align-items:center;background:#0f766e;border:1px solid #0f766e;border-radius:6px;color:#fff;cursor:pointer;display:inline-flex;font-weight:700;gap:.5rem;justify-content:center;min-height:2.5rem;padding:.6rem .9rem}button:hover{background:#115e59;border-color:#115e59}button:disabled{cursor:not-allowed;opacity:.55}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid #93c5fd;outline-offset:2px}.app-shell{min-height:100vh;padding:2rem}main{margin:0 auto;max-width:1400px}.topbar{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.topbar h1,.briefing h1{font-size:clamp(2rem,4vw,4rem);line-height:1;margin:.15rem 0 0}.eyebrow{color:#9f3a21;font-size:.78rem;font-weight:800;letter-spacing:0;margin:0;text-transform:uppercase}.composer,.share-layout{align-items:start;display:grid;gap:1.25rem;grid-template-columns:minmax(0,1fr) 410px}.composer-main,.error-panel,.share-url-box,.qr-panel,.briefing{background:#fff;border:1px solid #d7ddd8;border-radius:8px;box-shadow:0 18px 60px #0f172a14}.composer-main,.error-panel,.share-url-box,.qr-panel{padding:1.25rem}.composer-main label{display:block;font-size:.95rem;font-weight:800;margin-bottom:.55rem}textarea{background:#fbfcfb;border:1px solid #b8c3bd;border-radius:6px;color:#111827;display:block;min-height:520px;padding:1rem;resize:vertical;width:100%}input,select{background:#fbfcfb;border:1px solid #b8c3bd;border-radius:6px;color:#111827;min-height:2.25rem;padding:.45rem .55rem;width:100%}.composer-footer,.actions,.qr-panel-header,.regiment-heading,.version-strip{align-items:center;display:flex;gap:.75rem}.composer-footer,.qr-panel-header,.regiment-heading{justify-content:space-between}.composer-footer{margin-top:.8rem}.actions{flex-wrap:wrap}.secondary-button{background:#fff;border-color:#b8c3bd;color:#111827}.secondary-button:hover{background:#eef3f1;border-color:#94a3b8}.notice-grid{display:grid;gap:1rem}.notice-block{background:#111827;border:1px solid #243244;border-radius:8px;color:#e5edf5;padding:1rem}.notice-block strong{color:#fff;display:block;margin-bottom:.45rem}.notice-block p{color:#cbd5e1;font-size:.92rem;line-height:1.45;margin:.35rem 0}.warning-text{color:#b42318;font-weight:700}.muted{color:#64748b}.share-layout{grid-template-columns:minmax(0,1fr) minmax(340px,430px)}.roster-tabs{background:#e8efec;border:1px solid #cbd5cf;border-radius:8px;display:flex;gap:.25rem;margin-bottom:1rem;padding:.25rem}.roster-tabs button{flex:1 1 0}.roster-tabs button.active{background:#0f766e;border-color:#0f766e;color:#fff}.briefing{overflow:hidden}.briefing>header{background:linear-gradient(135deg,#fff,#eef7f4);border-bottom:1px solid #d7ddd8;padding:1.5rem}.chips{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1rem}.chips span{align-items:center;background:#f5f7f6;border:1px solid #cbd5cf;border-radius:999px;color:#334155;display:inline-flex;font-size:.9rem;font-weight:700;gap:.35rem;padding:.4rem .65rem}.chips .chip-valid{background:#ecfdf3;border-color:#86efac;color:#166534}.chips .chip-warning{background:#fffbeb;border-color:#fbbf24;color:#92400e}.facts{display:grid;gap:0;grid-template-columns:repeat(2,minmax(0,1fr));margin:0}.facts div{border-bottom:1px solid #e2e8f0;min-width:0;padding:1rem 1.5rem}.facts dt{color:#64748b;font-size:.78rem;font-weight:800;margin-bottom:.25rem;text-transform:uppercase}.facts dd{color:#111827;font-weight:700;margin:0;overflow-wrap:anywhere}.section-band{padding:1.25rem 1.5rem 1.5rem}.section-band h2,.quickref-editor h2,.share-url-box h2,.qr-panel h2,.error-panel h2{font-size:1.2rem;line-height:1.2;margin:0 0 .9rem}.table-notes p{color:#334155;line-height:1.55;margin:0;white-space:pre-wrap}.pre-game-brief>div,.army-rules>div{display:grid;gap:.75rem}.brief-card,.army-rule-card{background:#fbfcfb;border:1px solid #d7ddd8;border-left:5px solid #64748b;border-radius:8px;padding:.85rem 1rem}.brief-card h3,.army-rule-card h3{color:#111827;font-size:.98rem;margin:0 0 .45rem}.brief-card p,.army-rule-card p{color:#334155;line-height:1.5;margin:.4rem 0 0;white-space:pre-wrap}.brief-card ul,.army-rule-card ul{display:grid;gap:.35rem;margin:.4rem 0 0;padding-left:1.1rem}.brief-card li,.army-rule-card li{color:#334155;line-height:1.45}.tone-deployment{border-left-color:#8a6f22}.tone-mobility{border-left-color:#0f766e}.tone-attack{border-left-color:#8b1d18}.tone-durability{border-left-color:#5b2d74}.tone-control{border-left-color:#2563eb}.tone-buff{border-left-color:#9f3a21}.regiments{display:grid;gap:.8rem}.regiment{border:1px solid #d7ddd8;border-radius:8px;overflow:hidden}.regiment-heading{background:#f5f7f6;border-bottom:1px solid #d7ddd8;padding:.85rem 1rem}.regiment-heading h3{font-size:1rem;margin:0}.regiment-heading span{color:#0f766e;font-size:.82rem;font-weight:800}.unit-list,.notes-list,.terrain-list,.debug-panel ul{list-style:none;margin:0;padding:0}.unit-row{border-bottom:1px solid #edf2ef;padding:.85rem 1rem}.unit-row:last-child{border-bottom:0}.unit-row>div:first-child{align-items:center;display:flex;gap:.75rem;justify-content:space-between}.unit-name{font-weight:700;overflow-wrap:anywhere}.unit-points{background:#e8f5f2;border-radius:999px;color:#0f766e;font-size:.82rem;font-weight:800;padding:.2rem .5rem}.notes-list{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.55rem}.notes-list li{background:#fff7ed;border:1px solid #fed7aa;border-radius:999px;color:#9a3412;font-size:.82rem;font-weight:700;padding:.2rem .5rem}.quick-ref-summary{border-top:1px dashed #d7ddd8;margin-top:.7rem;padding-top:.7rem}.quick-facts-line{display:flex;flex-wrap:wrap;gap:.35rem;margin:0 0 .55rem}.quick-facts-line span{background:#f8fafc;border:1px solid #cbd5e1;border-radius:999px;color:#334155;font-size:.78rem;font-weight:800;padding:.18rem .45rem}.quick-ref-summary dl{display:flex;flex-wrap:wrap;gap:.45rem;margin:0}.quick-ref-summary dl div{align-items:baseline;background:#f1f5f9;border:1px solid #d7e0ea;border-radius:6px;display:inline-flex;gap:.35rem;padding:.25rem .45rem}.quick-ref-summary dt{color:#475569;font-size:.72rem;font-weight:800;text-transform:uppercase}.quick-ref-summary dd{color:#111827;font-size:.85rem;font-weight:800;margin:0}.quick-ref-summary .stat-save{background:#eaf6e7;border-color:#86b981}.quick-ref-summary .stat-save dd{color:#1f6d31}.quick-ref-summary .stat-ward{background:#fff1f0;border-color:#d98b80}.quick-ref-summary .stat-ward dd{color:#8b1d18}.advantage-targets{border:1px dashed #9ca3af;border-radius:6px;color:#111827;display:inline-block;font-size:.86rem;font-weight:700;line-height:1.35;margin:.6rem 0 0;padding:.28rem .5rem}.advantage-targets strong{font-weight:900}.weapon-profile-lines{display:grid;gap:.35rem;margin-top:.6rem}.weapon-profile-lines p{color:#334155;margin:0}.quick-ref-tags{display:flex;flex-wrap:wrap;gap:.35rem;list-style:none;margin:.55rem 0 0;padding:0}.quick-ref-tags li{background:#eef2ff;border:1px solid #c7d2fe;border-radius:999px;color:#3730a3;font-size:.78rem;font-weight:700;padding:.2rem .45rem}.quick-ref-tags.detail-tags li{background:#fff;border-color:#9ca3af;border-style:dashed;color:#111827;font-weight:800}.quick-ref-summary p{color:#475569;font-size:.9rem;line-height:1.45;margin:.55rem 0 0;white-space:pre-wrap}.terrain-list{display:flex;flex-wrap:wrap;gap:.5rem}.terrain-list li{background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;color:#1d4ed8;font-weight:700;padding:.45rem .7rem}.version-strip{border-top:1px solid #e2e8f0;color:#64748b;flex-wrap:wrap;font-size:.9rem;padding:1rem 1.5rem}.debug-panel{border-top:1px solid #e2e8f0;padding:1rem 1.5rem}.debug-panel summary{cursor:pointer;font-weight:800}.debug-panel h3{font-size:.95rem;margin:1rem 0 .5rem}.debug-panel li{border-top:1px solid #edf2ef;overflow-wrap:anywhere;padding:.45rem 0}.share-url-box{margin:1rem 0}.quickref-editor{background:#fff;border:1px solid #d7ddd8;border-radius:8px;box-shadow:0 18px 60px #0f172a14;margin-top:1rem;padding:1.25rem}.quickref-editor-header,.quickref-unit-heading{align-items:center;display:flex;gap:.75rem;justify-content:space-between}.quickref-editor-header span,.quickref-unit-heading span{color:#64748b;font-size:.82rem;font-weight:800}.table-notes-input{display:block;margin-top:1rem}.table-notes-input span,.brief-editor-grid span,.quickref-basics span,.quickref-fields span,.quickref-note span{color:#475569;display:block;font-size:.75rem;font-weight:800;margin-bottom:.25rem;text-transform:uppercase}.table-notes-input textarea{min-height:7rem}.editor-subsection{border-top:1px solid #e2e8f0;margin-top:1rem;padding-top:1rem}.editor-subsection h3{font-size:1rem;margin:0 0 .75rem}.brief-editor-grid{display:grid;gap:.75rem;grid-template-columns:repeat(2,minmax(0,1fr))}.brief-editor-grid label,.quickref-basics label{display:block}.brief-editor-grid textarea{min-height:5.6rem}.quickref-regiments{display:grid;gap:1rem;margin-top:1rem}.quickref-regiment{border-top:1px solid #e2e8f0;padding-top:1rem}.quickref-regiment h3,.quickref-unit h4{font-size:1rem;margin:0}.quickref-regiment>div{display:grid;gap:.75rem;margin-top:.75rem}.quickref-unit{border:1px solid #d7ddd8;border-radius:8px;overflow:hidden}.quickref-unit-summary{cursor:pointer;display:block;padding:.9rem}.quickref-unit-summary>div:first-child{align-items:center;display:flex;gap:.75rem;justify-content:space-between}.quickref-unit-summary span{color:#64748b;font-size:.82rem;font-weight:800}.quickref-unit-body{border-top:1px solid #e2e8f0;padding:.9rem}.compact-button{min-height:2.1rem;padding:.25rem .55rem}.selected-disclosure-tags{margin-top:.65rem}.selected-disclosure-tags h5,.disclosure-tag-sections h5{color:#475569;font-size:.75rem;font-weight:800;margin:0 0 .4rem;text-transform:uppercase}.quickref-fields{display:grid;gap:.65rem;grid-template-columns:repeat(7,minmax(0,1fr));margin-top:.8rem}.fast-profile-entry{background:#f8fafc;border:1px solid #d7e0ea;border-radius:8px;margin-top:.85rem;padding:.85rem}.fast-profile-entry>div:first-child,.fast-profile-actions,.weapon-profile-heading{align-items:center;display:flex;gap:.6rem;justify-content:space-between}.fast-profile-entry h5,.weapon-profile-heading h5{color:#475569;font-size:.75rem;font-weight:800;margin:0;text-transform:uppercase}.fast-profile-entry>div:first-child span{color:#0f766e;font-size:.78rem;font-weight:800}.fast-profile-entry input{margin-top:.65rem}.fast-profile-keypad{display:grid;gap:.45rem;grid-template-columns:repeat(5,minmax(0,1fr));margin-top:.65rem}.fast-profile-keypad button{min-height:2.35rem;padding:.35rem .45rem}.fast-profile-actions{flex-wrap:wrap;justify-content:flex-end;margin-top:.65rem}.quickref-basics{display:grid;gap:.65rem;grid-template-columns:minmax(8rem,12rem);margin-top:.8rem}.quickref-tags-editor{margin-top:.85rem}.quickref-tags-editor summary{cursor:pointer;font-weight:800}.quickref-tags-editor>div{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.65rem}.quickref-tags-editor>.disclosure-tag-sections{display:grid;gap:.8rem}.weapon-profile-editor>div{display:grid;gap:1rem;margin-top:.65rem}.weapon-profile-editor section{border:1px solid #d7e0ea;border-radius:8px;padding:.75rem}.weapon-profile-row{border-top:1px solid #e2e8f0;display:grid;gap:.55rem;grid-template-columns:repeat(4,minmax(0,1fr));margin-top:.65rem;padding-top:.65rem}.weapon-profile-row label,.quickref-tags-editor .weapon-profile-row label{align-items:stretch;background:transparent;border:0;border-radius:0;display:block;padding:0}.weapon-profile-row span{color:#475569;display:block;font-size:.72rem;font-weight:800;margin-bottom:.2rem;text-transform:uppercase}.remove-profile-button{align-self:end}.disclosure-tag-sections section>div{display:flex;flex-wrap:wrap;gap:.45rem}.quickref-tags-editor label{align-items:center;background:#f8fafc;border:1px solid #d7e0ea;border-radius:999px;display:inline-flex;gap:.35rem;padding:.35rem .55rem}.quickref-tags-editor input{min-height:auto;width:auto}.quickref-tags-editor span{color:#334155;font-size:.82rem;font-weight:700}.custom-disclosure-fields{display:grid;gap:.65rem;grid-template-columns:repeat(2,minmax(0,1fr))}.quickref-tags-editor .custom-disclosure-fields label{align-items:stretch;background:transparent;border:0;border-radius:0;display:block;padding:0}.custom-disclosure-fields span{display:block;font-size:.75rem;margin-bottom:.25rem;text-transform:uppercase}.quickref-note{display:block;margin-top:.85rem}.share-url-box p{background:#f5f7f6;border:1px solid #d7ddd8;border-radius:6px;color:#334155;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.82rem;line-height:1.5;margin:0 0 1rem;overflow-wrap:anywhere;padding:.8rem}.qr-panel{position:sticky;top:1rem}.segmented{background:#eef3f1;border:1px solid #cbd5cf;border-radius:8px;display:flex;padding:.2rem}.segmented button{background:transparent;border-color:transparent;color:#334155;min-height:2rem;padding:.25rem .65rem}.segmented button.active{background:#fff;border-color:#b8c3bd;color:#111827}.qr-canvas{background:#fff;border:1px solid #d7ddd8;border-radius:8px;display:block;height:auto;margin:1rem auto;max-width:100%;width:100%}.download-button{width:100%}.error-panel{margin-bottom:1rem}.error-panel p{color:#334155}@media(max-width:980px){.composer,.share-layout{grid-template-columns:1fr}.qr-panel{position:static}.quickref-fields{grid-template-columns:repeat(3,minmax(0,1fr))}.weapon-profile-row{grid-template-columns:repeat(2,minmax(0,1fr))}.brief-editor-grid{grid-template-columns:1fr}}@media(max-width:720px){.app-shell{padding:1rem}.topbar,.composer-footer,.actions,.qr-panel-header{align-items:stretch;flex-direction:column}.topbar h1,.briefing h1{font-size:2.25rem}textarea{min-height:420px}.facts{grid-template-columns:1fr}.quickref-fields{grid-template-columns:repeat(2,minmax(0,1fr))}.quickref-basics{grid-template-columns:1fr}.roster-tabs,.fast-profile-actions{align-items:stretch;flex-direction:column}.fast-profile-keypad{grid-template-columns:repeat(2,minmax(0,1fr))}.weapon-profile-row,.custom-disclosure-fields{grid-template-columns:1fr}.actions button,.secondary-button{width:100%}}@media print{:root,body{background:#fff}.app-shell{padding:0}main{max-width:none}.topbar,.roster-tabs,.quickref-editor,.notice-grid,.actions,.download-button,.segmented{display:none}.share-layout{display:block}.briefing,.share-url-box,.qr-panel{border-color:#cbd5e1;box-shadow:none;break-inside:avoid}.share-url-box,.qr-panel{margin-top:1rem}.qr-panel{position:static}.qr-canvas{max-width:360px}}
