:root{--bg: #0e0e1a;--bg2: #13132a;--bg3: #1a1a35;--bg4: #21213f;--card: #191930;--card2: #1f1f3d;--border: #2a2a50;--border2: #383860;--gold: #c9a84c;--gold-light: #e8cc70;--gold-dark: #8a6e28;--gold-dim: #3a2e10;--text: #ddd8c0;--text-muted: #8a8470;--text-dim: #504c3c;--red: #c04848;--red-light: #e06060;--red-dim: #3a1010;--green: #4a9a4a;--green-light: #60c060;--amber: #c08040;--amber-dim: #382010;--radius: 10px;--radius-sm: 6px;--radius-xs: 4px;--shadow: 0 4px 16px rgba(0,0,0,.6);--shadow-sm: 0 2px 8px rgba(0,0,0,.4);--header-h: 56px;--tab-h: 44px;--max-w: 1100px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:system-ui,-apple-system,Segoe UI,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}h1,h2,h3,h4{font-weight:700;line-height:1.2}button{cursor:pointer;font:inherit}input{font:inherit}ul,ol{list-style:none}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);border:1px solid transparent;font-size:14px;font-weight:600;transition:background .15s,border-color .15s,opacity .15s;white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--gold);color:#1a1000;border-color:var(--gold)}.btn-primary:not(:disabled):hover{background:var(--gold-light);border-color:var(--gold-light)}.btn-ghost{background:transparent;color:var(--text);border-color:var(--border2)}.btn-ghost:not(:disabled):hover{background:var(--bg4);border-color:var(--border2)}.btn-danger{background:var(--red-dim);color:var(--red-light);border-color:var(--red)}.btn-danger:not(:disabled):hover{background:var(--red);color:#fff}.btn-sm{padding:5px 10px;font-size:13px}.btn-xs{padding:3px 7px;font-size:12px;border-radius:var(--radius-xs)}.btn-back{padding:8px 12px}.home-view{max-width:var(--max-w);margin:0 auto;padding:24px 16px 80px}.home-header{display:flex;align-items:center;gap:16px;padding:24px 0 32px}.home-logo{font-size:40px;filter:sepia(1) saturate(4) hue-rotate(10deg)}.home-title{font-size:clamp(22px,5vw,32px);color:var(--gold-light);letter-spacing:-.5px}.home-subtitle{color:var(--text-muted);font-size:14px;margin-top:2px}.home-section{margin-bottom:40px}.section-title{font-size:13px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:14px;border-bottom:1px solid var(--border);padding-bottom:8px}.saved-list{display:flex;flex-direction:column;gap:10px}.saved-card{display:flex;align-items:center;gap:16px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;transition:border-color .15s}.saved-card:hover{border-color:var(--gold-dark)}.saved-card-info{flex:1;min-width:0}.saved-card-name{font-weight:700;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.saved-card-sub{font-size:13px;color:var(--text-muted);margin-top:2px}.saved-card-actions{display:flex;gap:6px;flex-shrink:0}.type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.type-card{position:relative;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;text-align:left;transition:border-color .15s,background .15s,transform .1s;cursor:pointer;color:var(--text);width:100%}.type-card:hover{border-color:var(--gold-dark);background:var(--card2);transform:translateY(-1px)}.type-card-name{font-size:16px;font-weight:700;margin-bottom:4px;color:var(--gold-light)}.type-card-complexity{font-size:16px;margin-bottom:4px}.type-card-style{font-size:12px;color:var(--text-muted);margin-bottom:8px}.type-card-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted)}.special-tag{color:var(--amber);font-size:11px}.draft-badge{position:absolute;top:8px;right:8px;background:var(--amber-dim);color:var(--amber);border:1px solid var(--amber);font-size:10px;font-weight:700;padding:1px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.5px}.draft-details{margin-top:16px}.draft-details>summary{cursor:pointer;color:var(--text-muted);font-size:14px;padding:6px 0;-webkit-user-select:none;user-select:none}.draft-details>summary:hover{color:var(--text)}.draft-grid{margin-top:12px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;z-index:100;display:flex;align-items:center;justify-content:center;padding:16px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);width:100%;max-width:460px;max-height:90dvh;display:flex;flex-direction:column;box-shadow:var(--shadow);animation:modal-in .15s ease-out}@keyframes modal-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:20px 20px 16px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:20px;color:var(--gold-light)}.modal-header h3{font-size:17px;color:var(--gold-light)}.modal-close{background:none;border:none;color:var(--text-muted);font-size:18px;padding:4px 8px;border-radius:var(--radius-xs);flex-shrink:0;line-height:1}.modal-close:hover{color:var(--text);background:var(--bg4)}.modal-body{padding:16px 20px;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid var(--border)}.wb-details-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.wb-detail{background:var(--bg4);border-radius:var(--radius-sm);padding:10px 12px}.wb-detail-label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:2px}.special-rules-block{background:var(--bg4);border-left:3px solid var(--amber);border-radius:var(--radius-sm);padding:12px;margin-bottom:16px;font-size:13px}.special-rule-entry+.special-rule-entry{margin-top:8px}.name-section{margin-top:4px}.name-label{display:block;font-size:13px;color:var(--text-muted);margin-bottom:6px}.name-input{width:100%;background:var(--bg4);border:1px solid var(--border2);border-radius:var(--radius-sm);padding:10px 12px;color:var(--text);font-size:15px;outline:none;transition:border-color .15s}.name-input:focus{border-color:var(--gold-dark)}.name-input::placeholder{color:var(--text-dim)}.builder-view{display:flex;flex-direction:column;height:100dvh;overflow:hidden}.builder-header{display:flex;align-items:center;gap:8px;background:var(--bg2);border-bottom:1px solid var(--border);padding:8px 12px;min-height:var(--header-h);flex-shrink:0}.builder-header-center{flex:1;min-width:0}.builder-wb-name{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.builder-wb-type{font-size:12px;color:var(--text-muted)}.builder-stats-row{display:flex;gap:6px}.stat-chip{display:flex;flex-direction:column;align-items:center;background:var(--bg4);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px 10px;min-width:60px}.stat-chip--warn{border-color:var(--amber);background:var(--amber-dim)}.stat-chip--danger{border-color:var(--red);background:var(--red-dim)}.stat-chip-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.stat-chip-value{font-size:14px;font-weight:700;color:var(--gold-light)}.stat-chip--warn .stat-chip-value{color:var(--amber)}.stat-chip--danger .stat-chip-value{color:var(--red-light)}.mobile-tabs{display:flex;background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0}.tab-btn{flex:1;padding:10px;background:none;border:none;color:var(--text-muted);font-size:14px;font-weight:600;border-bottom:2px solid transparent;transition:color .15s,border-color .15s;display:flex;align-items:center;justify-content:center;gap:6px}.tab-btn.active{color:var(--gold);border-bottom-color:var(--gold)}.tab-btn:hover:not(.active){color:var(--text)}.tab-count{background:var(--gold-dim);color:var(--gold);font-size:11px;padding:1px 6px;border-radius:10px;font-weight:700}.builder-panels{display:flex;flex:1;overflow:hidden}.panel{flex:1;overflow-y:auto;padding:16px}@media (max-width: 767px){.panel{display:none}.panel--active{display:block}}@media (min-width: 768px){.mobile-tabs{display:none}.panel{display:block}.hire-panel{width:380px;flex:none;border-right:1px solid var(--border)}.roster-panel{flex:1}}.hire-inner{display:flex;flex-direction:column;gap:20px}.hire-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}.hire-section-title{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:0;padding-bottom:0;border-bottom:none}.hire-section>.hire-section-title{margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}.hero-slots-info{display:flex;align-items:center;gap:8px}.hero-slots-count{font-size:11px;color:var(--text-muted)}.hero-slots-max{font-size:11px;color:var(--gold-dark)}.btn-gold{background:var(--gold-dim);color:var(--gold-light);border:1px solid var(--gold-dark)}.btn-gold:hover:not(:disabled){background:var(--gold-dark);color:var(--gold-light)}.hire-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;margin-bottom:8px;transition:border-color .15s}.hire-card:hover{border-color:var(--border2)}.hire-card--disabled{opacity:.55}.hire-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:8px}.hire-card-title{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.hire-card-name{font-weight:700;font-size:15px}.leader-tag{background:var(--gold-dim);color:var(--gold);font-size:10px;font-weight:700;padding:1px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.hire-card-count-cost{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.hire-card-cap{font-size:12px;color:var(--text-muted)}.hire-card-cost{font-size:15px;font-weight:700;color:var(--gold)}.hire-card-stats{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--text-muted);margin-bottom:8px;font-variant-numeric:tabular-nums}.hire-card-skills{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.skill-tag{background:var(--bg4);border:1px solid var(--border);border-radius:3px;font-size:11px;padding:1px 6px;color:var(--text-muted)}.hire-btn{width:100%;justify-content:center}.empty-roster{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:60px 20px;text-align:center;color:var(--text-muted)}.empty-icon{font-size:40px;opacity:.3}.roster-list{display:flex;flex-direction:column;gap:10px}.roster-unit{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:12px;transition:border-color .15s}.roster-unit:hover{border-color:var(--border2)}.roster-unit-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.roster-unit-left{display:flex;align-items:center;gap:8px}.roster-unit-name{font-weight:700;font-size:15px}.roster-unit-cat{font-size:10px;font-weight:700;padding:2px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.5px}.roster-cat--hero{background:var(--gold-dim);color:var(--gold)}.roster-cat--henchman{background:var(--bg4);color:var(--text-muted)}.roster-unit-right{display:flex;align-items:center;gap:8px}.roster-unit-cost{font-size:14px;font-weight:700;color:var(--gold)}.equip-list{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.equip-list-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted)}.equip-icon{flex-shrink:0}.equip-name{flex:1}.equip-cost{font-size:12px;color:var(--text-dim)}.equip-open-btn{width:100%;justify-content:center;border-style:dashed}.no-equip-tag{font-size:12px;color:var(--text-dim);font-style:italic}.equip-modal{max-width:500px;max-height:85dvh}@media (max-width: 600px){.modal-overlay{align-items:flex-end;padding:0}.equip-modal{max-width:100%;border-bottom-left-radius:0;border-bottom-right-radius:0;max-height:90dvh;animation:slide-up .2s ease-out}@keyframes slide-up{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}}.equip-modal-body{padding:8px 20px 16px}.slot-bar{font-size:12px;color:var(--text-muted);margin-top:4px}.slot-pip{display:inline-block;width:10px;height:10px;border-radius:50%;border:1.5px solid var(--border2);background:transparent;vertical-align:middle;margin:0 1px}.slot-pip--used{background:var(--gold);border-color:var(--gold)}.equip-group{margin-bottom:16px}.equip-group--unavail{opacity:.45}.equip-group-title{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);padding:6px 0;border-bottom:1px solid var(--border);margin-bottom:6px}.equip-row{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius-sm);border:1px solid transparent;cursor:pointer;transition:background .12s,border-color .12s;margin-bottom:2px}.equip-row:not(.equip-row--off):hover{background:var(--bg4);border-color:var(--border)}.equip-row--on{background:var(--gold-dim);border-color:var(--gold-dark)}.equip-row--off{opacity:.4;cursor:not-allowed}.equip-row-check{width:18px;height:18px;border-radius:4px;border:1.5px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--gold);flex-shrink:0;background:var(--bg3)}.equip-row--on .equip-row-check{border-color:var(--gold-dark);background:var(--gold-dim)}.equip-row-info{flex:1;min-width:0}.equip-row-name{font-weight:600;font-size:14px}.equip-row-effect{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.equip-row-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}.equip-row-slot{font-size:11px;color:var(--text-dim)}.equip-row-cost{font-size:13px;font-weight:700;color:var(--gold)}.no-equip-msg{color:var(--text-muted);font-style:italic;text-align:center;padding:20px 0}.equip-remove-btn{flex-shrink:0;background:transparent;border:1px solid var(--border2);color:var(--text-muted);border-radius:var(--radius-xs);padding:2px 7px;font-size:11px;line-height:1.6;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.equip-remove-btn:hover{background:var(--red-dim);border-color:var(--red);color:var(--red-light)}.view-warband{max-width:var(--max-w);margin:0 auto;padding:0 0 80px}.view-header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.view-header-center{flex:1;min-width:0;text-align:center}.view-title{font-size:clamp(16px,4vw,24px);color:var(--gold-light)}.view-type{font-size:13px;color:var(--text-muted)}.view-summary-bar{display:flex;gap:1px;background:var(--border);margin-bottom:24px}.summary-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:14px 8px;background:var(--bg2);gap:2px}.summary-label{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted)}.summary-value{font-size:17px;font-weight:700;color:var(--gold)}.text-danger{color:var(--red-light)!important}.view-unit-section{padding:0 16px;margin-bottom:28px}.view-unit-section h2{font-size:13px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.unit-table{width:100%;border-collapse:collapse;font-size:13px;min-width:780px}.unit-table th{background:var(--bg4);color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.8px;padding:8px 10px;text-align:left;white-space:nowrap}.unit-table th:not(:first-child){text-align:center}.unit-table td{padding:10px;border-bottom:1px solid var(--border);text-align:center;vertical-align:top}.unit-table tr:last-child td{border-bottom:none}.unit-table tr:hover td{background:var(--bg3)}.view-unit-cell{text-align:left!important}.view-unit-name{font-weight:700}.view-cost-cell{font-weight:700;color:var(--gold);white-space:nowrap}.view-unit-skills{display:flex;flex-wrap:wrap;gap:4px;margin-top:5px}.skill-tag{display:inline-block;font-size:11px;padding:2px 7px;border-radius:20px;background:var(--bg4);color:var(--text-muted);text-decoration:none;white-space:nowrap;border:1px solid var(--border)}.skill-tag:hover{color:var(--gold-light);border-color:var(--gold)}.unit-card-skills{display:flex;flex-wrap:wrap;gap:4px;padding:8px 14px;border-top:1px solid var(--border)}.equip-row-view td{border-bottom:none;padding-top:3px;padding-bottom:3px}.equip-row-view:last-child td{border-bottom:1px solid var(--border)}.unit-table tr:hover.equip-row-view td{background:var(--bg3)}.equip-row-name-cell{text-align:left!important;padding-left:24px!important;font-size:12px;color:var(--text-muted)}.equip-row-stats-cell{text-align:left!important;font-size:12px;color:var(--text-muted)}.view-desktop{display:block}.view-mobile{display:none}@media (max-width: 700px){.view-desktop{display:none}.view-mobile{display:flex;flex-direction:column;gap:10px}}.unit-card{background:var(--bg2);border:1px solid var(--border);border-radius:8px;overflow:hidden}.unit-card-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--bg3);border-bottom:1px solid var(--border)}.unit-card-name{font-weight:700;font-size:15px}.unit-card-cost{font-weight:700;color:var(--gold);font-size:14px}.unit-card-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border-bottom:1px solid var(--border)}.unit-card-stat{display:flex;flex-direction:column;align-items:center;padding:8px 4px;background:var(--bg2);gap:2px}.unit-card-stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted)}.unit-card-stat-value{font-size:15px;font-weight:600}.unit-card-equip{padding:8px 14px;display:flex;flex-direction:column;gap:4px}.unit-card-equip-line{font-size:13px}.unit-card-equip-stats{color:var(--text-muted);font-size:12px}.view-empty{text-align:center;padding:60px 20px;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:14px}.view-special-rules{padding:0 16px}.view-special-rules h2{font-size:13px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}.view-special-rule{background:var(--bg3);border-left:3px solid var(--amber);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;margin-bottom:8px}@media print{body{background:#fff;color:#000;font-size:12px}.view-header .btn,.view-header{position:static;background:#fff;border-bottom:1px solid #ccc}.view-header .btn{display:none}.view-summary-bar{border:1px solid #ccc;margin-bottom:16px}.summary-item{background:#f5f5f5}.summary-label{color:#555}.summary-value,.text-danger{color:#000!important;font-size:14px}.view-title{color:#000}.view-type{color:#555}.unit-table th{background:#eee;color:#555}.unit-table td{border-bottom:1px solid #ddd}.unit-table tr:hover td{background:none}.view-unit-name,.view-cost-cell{color:#000}.equip-row-name-cell,.equip-row-stats-cell{color:#555}.view-special-rule{border-left-color:#555;background:#f9f9f9}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}
