

:root {
  --bg:#080c12; --surface:#0d1520; --surface2:#111d2e; --surface3:#162436;
  --border:#1e3048; --accent:#00c8ff; --gold:#f5c842;
  --text:#e2eaf5; --text2:#8aa5c0; --text3:#4a6a85;
}
*{margin:0;padding:0;box-sizing:border-box;}
html,body{height:100%;overflow:hidden;}
body{font-family:'Exo 2',sans-serif;background:var(--bg);color:var(--text);overscroll-behavior:none;display:flex;flex-direction:column;height:100vh;height:100dvh;}

/* ── Global scrollbar styling — dark theme to match site ── */
#detail-modal-body, #ps-modal, .tuner-collapse-body,
#item-tag-editor, .tuner-left, .tuner-right, .tdiff-body,
.dropdown-list, .item-table-wrap {
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}
#detail-modal-body::-webkit-scrollbar,
#ps-modal::-webkit-scrollbar,
.tuner-collapse-body::-webkit-scrollbar,
#item-tag-editor::-webkit-scrollbar,
.tuner-left::-webkit-scrollbar,
.tuner-right::-webkit-scrollbar,
.tdiff-body::-webkit-scrollbar,
.dropdown-list::-webkit-scrollbar,
.item-table-wrap::-webkit-scrollbar { width: 5px; height: 5px; }
#detail-modal-body::-webkit-scrollbar-track,
#ps-modal::-webkit-scrollbar-track,
.tuner-collapse-body::-webkit-scrollbar-track,
#item-tag-editor::-webkit-scrollbar-track,
.tuner-left::-webkit-scrollbar-track,
.tuner-right::-webkit-scrollbar-track,
.tdiff-body::-webkit-scrollbar-track,
.dropdown-list::-webkit-scrollbar-track,
.item-table-wrap::-webkit-scrollbar-track { background: transparent; }
#detail-modal-body::-webkit-scrollbar-thumb,
#ps-modal::-webkit-scrollbar-thumb,
.tuner-collapse-body::-webkit-scrollbar-thumb,
#item-tag-editor::-webkit-scrollbar-thumb,
.tuner-left::-webkit-scrollbar-thumb,
.tuner-right::-webkit-scrollbar-thumb,
.tdiff-body::-webkit-scrollbar-thumb,
.dropdown-list::-webkit-scrollbar-thumb,
.item-table-wrap::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 3px;
}
#detail-modal-body::-webkit-scrollbar-thumb:hover,
#ps-modal::-webkit-scrollbar-thumb:hover,
.tuner-left::-webkit-scrollbar-thumb:hover,
.tuner-right::-webkit-scrollbar-thumb:hover { background: var(--text3); }
body::before{content:'';position:fixed;inset:0;
  background-image:linear-gradient(rgba(0,200,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,200,255,.03) 1px,transparent 1px);
  background-size:40px 40px;pointer-events:none;z-index:0;}
.app{z-index:1;display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden;align-items:stretch;padding-bottom:env(safe-area-inset-bottom);}

/* ══════════════════════════════════════════════════
   TWO-COLUMN LAYOUT
══════════════════════════════════════════════════ */
.two-col{
  display:flex;flex:1;min-height:0;overflow:hidden;align-items:stretch;
}
.left-col{
  flex:1;min-width:0;align-self:stretch;display:grid;grid-template-rows:auto auto auto auto 1fr auto;overflow:hidden;
}


/* ── Abilities panel ────────────────────────────────── */

@media(max-width:700px){
  
  .hero-section{flex-wrap:wrap;}
}











.ability-card{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  width:80px;flex-shrink:0;cursor:default;position:relative;
  user-select:none;
  -webkit-user-select:none;
  -webkit-touch-callout:none;
}
.ability-card.dragging{opacity:.4;}
.ability-card.drag-over .ability-icon-wrap{border-color:var(--accent) !important;}
.ability-icon-wrap{
  width:76px;height:76px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:var(--surface3);border-radius:6px;border:1px solid var(--border);
  overflow:hidden;
}
.ability-name{
  font-size:10px;color:var(--text);text-align:center;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;
  font-family:'Rajdhani',sans-serif;font-weight:600;
}
.ability-drag-handle{
  font-size:10px;color:var(--text3);letter-spacing:2px;cursor:grab;opacity:.5;
  line-height:1;
  user-select:none;
  -webkit-user-select:none;
  -webkit-touch-callout:none;
  touch-action:none;
  padding:8px 4px;
  margin:-8px -4px;
}
.ability-drag-handle:hover{opacity:1;color:var(--accent);}
/* Touch drag active state */
.ability-card.touch-drag-active{
  outline:2px solid var(--accent);
  outline-offset:-2px;
}
.ability-arrow{
  font-size:14px;color:var(--text3);flex-shrink:0;align-self:center;
  padding-bottom:24px;
}
.item-agg-label{
  font-family:'Rajdhani',sans-serif;font-size:8px;font-weight:700;
  letter-spacing:.4px;text-transform:uppercase;color:var(--text3);
  text-align:center;width:100%;white-space:nowrap;overflow:hidden;
  text-overflow:ellipsis;cursor:pointer;line-height:1.2;
  transition:color .15s;
}
.item-agg-label:hover{color:var(--accent);}
.item-agg-label.active{color:var(--accent);}






.ab-dmg-dot{
  position:absolute;bottom:3px;right:3px;
  width:8px;height:8px;border-radius:50%;
  border:1px solid rgba(0,0,0,.6);pointer-events:none;
}
.ab-dmg-dot.physical{background:#f97316;}
.ab-dmg-dot.magical{background:#38bdf8;}
.ab-dmg-dot.true{background:#e2e8f0;}
.ab-dmg-dot.mixed{background:linear-gradient(135deg,#f97316 50%,#38bdf8 50%);}
.ab-dmg-pill.physical{background:rgba(249,115,22,.15);color:#f97316;border-color:rgba(249,115,22,.4);}
.ab-dmg-pill.magical{background:rgba(56,189,248,.15);color:#38bdf8;border-color:rgba(56,189,248,.4);}
.ab-dmg-pill.true{background:rgba(226,232,240,.12);color:#e2e8f0;border-color:rgba(226,232,240,.3);}
.ab-dmg-pill.mixed{background:rgba(168,85,247,.15);color:#c084fc;border-color:rgba(168,85,247,.4);}
.ab-dmg-pill.physical .ab-dmg-pill-dot{background:#f97316;}
.ab-dmg-pill.magical  .ab-dmg-pill-dot{background:#38bdf8;}
.ab-dmg-pill.true     .ab-dmg-pill-dot{background:#e2e8f0;}
.ab-dmg-pill.mixed    .ab-dmg-pill-dot{background:linear-gradient(135deg,#f97316 50%,#38bdf8 50%);}

/* legacy fallback */


/* Rich tooltip */
.tip-name-row{padding:10px 14px 8px;border-bottom:1px solid var(--border);}
.tip-name{font-family:'Rajdhani',sans-serif;font-size:15px;font-weight:700;color:var(--text);letter-spacing:.5px;}
.tip-stats{display:flex;flex-wrap:wrap;gap:5px;padding:10px 14px;border-bottom:1px solid var(--border);}
.tip-stat-pill{display:inline-flex;align-items:center;gap:5px;background:var(--surface3);
  border:1px solid rgba(0,200,255,.2);border-radius:4px;padding:4px 8px;}
.tip-stat-lbl{font-size:10px;color:var(--text);text-transform:uppercase;letter-spacing:.4px;
  font-family:'Rajdhani',sans-serif;font-weight:700;}
.tip-stat-val{font-family:'Rajdhani',sans-serif;font-size:13px;font-weight:700;color:var(--accent);}
.tip-effect{padding:8px 14px;border-bottom:1px solid rgba(30,48,72,.4);}
.tip-effect:last-child{border-bottom:none;}
.tip-eff-header{display:flex;align-items:center;gap:6px;margin-bottom:4px;}
.tip-eff-type{font-size:9px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;
  padding:1px 5px;border-radius:3px;font-family:'Rajdhani',sans-serif;flex-shrink:0;}
.tip-eff-name{font-family:'Rajdhani',sans-serif;font-size:12px;font-weight:700;color:var(--text);letter-spacing:.3px;}
.tip-eff-condition{font-size:11px;color:var(--accent);font-style:italic;margin:2px 0 4px 0;}
.tip-eff-body{font-size:11px;color:var(--text2);line-height:1.6;}
.tip-eff-body strong{color:var(--text);}
.tip-desc{padding:10px 14px;font-size:11px;color:var(--text2);line-height:1.6;}
.tip-desc strong{color:var(--text);}
/* ── Rec weights side panel ─────────────────────────────────────────── */
#rec-weights-panel {
  display: flex; flex-direction: row; flex-shrink: 0;
  background: var(--surface); border-left: 1px solid var(--border);
}
#rec-weights-toggle {
  display: none; flex-direction: column; align-items: center; justify-content: center;
  width: 22px; flex-shrink: 0; cursor: pointer;
  border-right: 1px solid var(--border);
  color: var(--text3); gap: 4px;
  transition: color .15s, background .15s;
  user-select: none;
  background: var(--surface);
}
#rec-weights-toggle:hover { color: var(--accent); background: var(--surface2); }
#rec-weights-toggle.panel-open { color: var(--accent); border-right-color: var(--accent); }
#rec-weights-toggle .rwt-label {
  font-size: 8px; writing-mode: vertical-rl; transform: rotate(180deg);
  font-family: 'Rajdhani', sans-serif; font-weight: 700;
  letter-spacing: .6px; text-transform: uppercase;
}
#rec-weights-toggle .rwt-arrow {
  font-size: 9px; transition: transform .2s;
}
#rec-weights-toggle.panel-open .rwt-arrow { transform: rotate(180deg); }
#rec-weights-content {
  width: 0; overflow: hidden; flex-shrink: 0;
  display: flex; flex-direction: column;
  transition: width .22s ease;
}
#rec-weights-content.open { width: 240px; }
.rwp-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 10px; border-bottom: 1px solid var(--border); flex-shrink: 0;
  min-width: 240px;
}
.rwp-title {
  font-family: 'Rajdhani', sans-serif; font-size: 10px; font-weight: 700;
  letter-spacing: .8px; text-transform: uppercase; color: var(--accent);
}
.rwp-save-btn:hover { background: rgba(0,200,255,.15); }
.rwp-action-row {
  display: flex; gap: 6px; padding: 10px 8px 4px; border-top: 1px solid var(--border); margin-top: 6px;
}
.rwp-reset-btn {
  font-family: 'Rajdhani', sans-serif; font-size: 9px; font-weight: 700;
  letter-spacing: .5px; text-transform: uppercase;
  background: transparent; border: 1px solid var(--border);
  color: var(--text3); cursor: pointer; border-radius: 3px;
  padding: 5px 10px; transition: all .15s; flex: 1;
}
.rwp-reset-btn:hover { border-color: var(--text2); color: var(--text2); }
.rwp-save-apply-btn {
  font-family: 'Rajdhani', sans-serif; font-size: 9px; font-weight: 700;
  letter-spacing: .5px; text-transform: uppercase;
  background: transparent; border: 1px solid var(--accent);
  color: var(--accent); cursor: pointer; border-radius: 3px;
  padding: 5px 10px; transition: all .15s; flex: 2;
}
.rwp-save-apply-btn:hover { background: rgba(0,200,255,.12); }
.rwp-save-apply-btn:disabled { opacity: .4; cursor: default; }
.rwp-body { overflow-y: auto; flex: 1; padding: 6px 0 0; min-width: 240px;
  scrollbar-width: thin; scrollbar-color: var(--border) transparent; }
.rwp-group-label {
  font-family: 'Rajdhani', sans-serif; font-size: 8px; font-weight: 700;
  letter-spacing: .8px; text-transform: uppercase; color: var(--text3);
  padding: 8px 10px 3px; border-top: 1px solid var(--border); margin-top: 4px;
}
.rwp-group-label:first-child { border-top: none; margin-top: 0; }
.rwp-row {
  display: grid; grid-template-columns: 1fr 16px 52px 16px 32px;
  align-items: center; gap: 3px; padding: 3px 8px; transition: background .1s;
}
.rwp-row:hover { background: var(--surface2); }
.rwp-tag { font-family: 'Rajdhani', sans-serif; font-size: 10px; font-weight: 600;
  color: var(--text2); text-transform: uppercase; letter-spacing: .2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rwp-arrow {
  background: transparent; border: 1px solid var(--border); border-radius: 2px;
  color: var(--text3); cursor: pointer; font-size: 9px; font-weight: 700;
  width: 16px; height: 16px; display: flex; align-items: center; justify-content: center;
  transition: all .1s; padding: 0; line-height: 1; font-family: 'Rajdhani', sans-serif;
  user-select: none;
}
.rwp-arrow:hover { border-color: var(--accent); color: var(--accent); background: rgba(0,200,255,.08); }
.rwp-slider {
  -webkit-appearance: none; width: 100%; height: 3px;
  background: var(--border); border-radius: 2px; outline: none; cursor: pointer;
}
.rwp-slider::-webkit-slider-thumb {
  -webkit-appearance: none; width: 11px; height: 11px; border-radius: 50%;
  background: var(--accent); cursor: pointer; box-shadow: 0 0 4px rgba(0,200,255,.3);
}
.rwp-val {
  font-family: 'Rajdhani', sans-serif; font-size: 11px; font-weight: 700;
  text-align: right; color: var(--accent); min-width: 28px;
}
.rwp-val.zero { color: var(--text3); }


.lc-section{
  border-bottom:1px solid var(--border);flex-shrink:0;
}

/* Hero section */
.hero-section{display:flex;flex-direction:column;background:var(--surface);flex-shrink:0;}
.hero-top-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border);min-height:52px;}
.hero-content-row{display:flex;align-items:center;gap:0;padding:12px 16px;min-height:185px;max-height:185px;}
.hero-divider{width:1px;background:var(--border);flex-shrink:0;margin:0 16px;align-self:stretch;min-height:110px;}
.hero-right-col{display:flex;flex-direction:column;flex:1;min-width:0;gap:0;justify-content:flex-start;height:161px;overflow:hidden;}
/* Build pills — larger in top row */
.build-pill-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-end;flex:1;}
.build-pill{font-family:'Rajdhani',sans-serif;font-size:14px;font-weight:700;letter-spacing:.5px;padding:5px 14px;border-radius:5px;cursor:pointer;border:1px solid var(--border);background:var(--surface2);color:var(--text2);transition:all .15s;display:flex;align-items:center;gap:6px;white-space:nowrap;}
.build-pill:hover{border-color:var(--accent);color:var(--text);}
.build-pill.active{background:rgba(0,200,255,.12);border-color:var(--accent);color:var(--accent);}
.build-pill-rec{border-style:dashed;color:var(--text3);}
.build-pill-rec:hover{border-color:var(--accent);color:var(--text);}
.build-pill-rec.active{background:rgba(0,200,255,.12);border-color:var(--accent);color:var(--accent);border-style:dashed;}
.build-pill-name{outline:none;min-width:20px;cursor:text;}
.build-pill-name:focus{color:var(--text);}
.build-pill-del{font-size:10px;opacity:.4;margin-left:2px;cursor:pointer;transition:opacity .15s;background:none;border:none;color:inherit;padding:0;line-height:1;}
.build-pill-del:hover{opacity:1;color:#ef4444;}
.build-pill-dup{font-size:11px;opacity:.4;margin-left:2px;cursor:pointer;transition:opacity .15s;background:none;border:none;color:inherit;padding:0;line-height:1;}
.build-pill-dup:hover{opacity:1;color:var(--accent);}
.build-pill-del:hover{opacity:1;color:#ef4444;}
.build-pill-role-icon{width:16px;height:16px;object-fit:contain;flex-shrink:0;opacity:.8;filter:brightness(0.9);}
.build-pill.active .build-pill-role-icon{opacity:1;filter:brightness(1.1);}
.build-pill-add{font-family:'Rajdhani',sans-serif;font-size:16px;font-weight:700;padding:4px 10px;border-radius:5px;cursor:pointer;border:1px solid var(--border);background:var(--surface2);color:var(--text3);transition:all .15s;line-height:1;position:relative;}
.build-pill-add:hover{border-color:var(--accent);color:var(--accent);}

/* ── View toggle tabs (Crest & Items / Abilities & Combo) ── */
.hero-view-header{display:flex;align-items:center;gap:8px;padding-bottom:8px;}
.view-tabs{display:flex;gap:4px;align-items:center;}
.view-tab{font-family:'Rajdhani',sans-serif;font-size:11px;font-weight:700;letter-spacing:.5px;padding:4px 12px;border-radius:4px;cursor:pointer;border:1px solid var(--border);background:var(--surface2);color:var(--text3);transition:all .15s;white-space:nowrap;}
.view-tab:hover{border-color:var(--text2);color:var(--text2);}
.view-tab.active{background:rgba(0,200,255,.1);border-color:var(--accent);color:var(--accent);}

/* ── Role pills in hero header ── */
.hero-role-pills{display:flex;align-items:center;gap:4px;flex-wrap:wrap;}
.hero-role-pill-wrap{position:relative;}
.hero-role-pill-btn.set{background:rgba(0,200,255,.1);border-color:var(--accent);color:var(--accent);}
.hero-role-pill-btn .pill-del{font-size:9px;opacity:.5;margin-left:4px;line-height:1;transition:opacity .15s;}
.hero-role-pill-btn .pill-del:hover{opacity:1;color:#ef4444;}
.hero-role-dd{position:absolute;top:calc(100% + 4px);right:0;z-index:9200;background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:4px 0;min-width:120px;box-shadow:0 6px 20px rgba(0,0,0,.5);display:none;}
.hero-role-dd.open{display:block;}
.hero-role-dd-opt{padding:6px 14px;font-family:'Rajdhani',sans-serif;font-size:11px;font-weight:700;color:var(--text2);cursor:pointer;white-space:nowrap;transition:background .1s;}
.hero-role-dd-opt:hover{background:var(--surface3);color:var(--accent);}
.hero-role-dd-opt.selected{color:var(--accent);}

/* Slot dots under each tile in hero view */

.hero-portrait-wrap{flex-shrink:0;align-self:flex-start;}
.hero-portrait{
  width:120px;height:120px;border-radius:8px;object-fit:cover;
  border:2px solid var(--accent);display:block;cursor:pointer;
}
.hero-portrait-placeholder{
  width:120px;height:120px;border-radius:8px;
  background:var(--surface3);border:2px dashed var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:30px;color:var(--text3);cursor:pointer;
}
.hero-info-col{display:flex;flex-direction:column;gap:4px;min-width:0;}
.hero-name-btn{
  font-family:'Rajdhani',sans-serif;font-size:22px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;color:var(--text);
  cursor:pointer;user-select:none;display:flex;align-items:center;gap:7px;
  transition:color .15s;background:none;border:none;padding:0;white-space:nowrap;
}
.hero-name-btn:hover{color:var(--accent);}
.hero-name-btn .arrow{font-size:10px;color:var(--text3);transition:transform .15s;}
.hero-name-btn.open .arrow{transform:rotate(180deg);}
.hero-class-tags{display:flex;flex-direction:column;gap:4px;align-items:flex-end;}
.role-pill{font-family:'Rajdhani',sans-serif;font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:1px 5px;border-radius:2px;background:var(--surface3);border:1px solid var(--border);color:var(--text3);white-space:nowrap;}
.playstyle-pill,.dmgtype-pill-magic,.dmgtype-pill-physical,.dmgtype-pill-basic,.dmgtype-pill-hybrid{
  font-family:'Rajdhani',sans-serif;font-size:9px;font-weight:700;
  letter-spacing:.5px;text-transform:uppercase;
  padding:1px 5px;border-radius:2px;
  background:var(--surface3);border:1px solid var(--border);
  color:var(--text3);white-space:nowrap;
}
.dmgtype-pill-magic   {background:rgba(56,189,248,.15);border-color:rgba(56,189,248,.4);color:#38bdf8;}

.dmgtype-pill-physical{background:rgba(249,115,22,.15);border-color:rgba(249,115,22,.4);color:#f97316;}
.dmgtype-pill-hybrid  {background:rgba(136,135,128,.15);border-color:rgba(136,135,128,.4);color:#b4b2a9;}

/* Hero dropdown */
.hero-dropdown-wrap{position:relative;}
.hero-dropdown-panel{
  position:absolute;top:calc(100% + 6px);left:0;
  width:max-content;min-width:320px;max-width:520px;
  background:var(--surface2);border:1px solid var(--border);
  border-radius:6px;box-shadow:0 16px 48px rgba(0,0,0,.65);
  z-index:300;display:none;flex-direction:column;max-height:480px;overflow:hidden;
}
.hero-dropdown-panel.open{display:flex;}
.dropdown-search{padding:10px;border-bottom:1px solid var(--border);flex-shrink:0;}
.dropdown-search input{
  width:100%;padding:6px 10px;background:var(--surface3);border:1px solid var(--border);
  border-radius:4px;color:var(--text);font-family:'Exo 2',sans-serif;font-size:12px;outline:none;
}
.dropdown-search input:focus{border-color:var(--accent);}
.dropdown-search input::placeholder{color:var(--text3);}
.dropdown-list{overflow-y:auto;flex:1;scrollbar-width:thin;scrollbar-color:var(--border) transparent;}
.dropdown-hero{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;transition:background .1s;}
.dropdown-hero:hover{background:var(--surface3);}
.dropdown-hero.active{background:rgba(0,200,255,.08);}
.dropdown-hero img{width:36px;height:36px;border-radius:4px;object-fit:cover;border:1px solid var(--border);flex-shrink:0;}
.dropdown-hero.active img{border-color:var(--accent);}
.dropdown-hero-name{font-family:'Rajdhani',sans-serif;font-size:14px;font-weight:600;color:var(--text2);flex:1;white-space:nowrap;}
.dropdown-hero.active .dropdown-hero-name{color:var(--accent);}
.dropdown-hero-tags{display:flex;flex-direction:column;gap:2px;flex-shrink:0;align-items:flex-end;}
/* ── Build crest section ───────────────────────────────────────────── */



.crest-effects-box{
  flex:1;min-width:0;font-size:11px;color:var(--text2);
}






.crest-name{font-size:8px;color:var(--gold);text-align:center;padding:2px 2px 3px;line-height:1.2;}
.crest-effects-box{
  width:160px;flex-shrink:0;
  background:var(--surface2);border:1px solid var(--border);
  border-radius:6px;padding:8px 10px;font-size:11px;color:var(--text2);
  min-height:68px;overflow:hidden;
}
.crest-effects-title{font-size:9px;color:var(--gold);text-transform:uppercase;letter-spacing:1px;font-weight:600;margin-bottom:3px;font-family:'Rajdhani',sans-serif;}
.item-slot.active-slot{border-color:var(--accent) !important;box-shadow:0 0 0 2px rgba(0,200,255,.25);}
.item-slot.filled.rarity-Epic     {border-color:rgba(168,85,247,.55);}
.item-slot.filled.rarity-Legendary{border-color:rgba(245,200,66,.55);}
.item-slot.filled.rarity-Rare     {border-color:rgba(59,130,246,.45);}
.item-slot .x-btn{
  position:absolute;top:2px;right:2px;background:rgba(239,68,68,.85);
  border:none;border-radius:2px;color:white;width:14px;height:14px;font-size:9px;
  cursor:pointer;display:none;align-items:center;justify-content:center;z-index:2;
}
.item-slot:hover .x-btn{display:flex;}

/* Hero stats in left col */
.lp-stat-row{display:flex;justify-content:space-between;align-items:center;padding:3px 0;}
.lp-stat-key{font-size:11px;color:var(--text3);}
.lp-stat-val{font-family:'Rajdhani',sans-serif;font-size:13px;font-weight:700;color:var(--text);}

/* ── RIGHT COLUMN: crest + slots + stats ──────── */
/* AI Hero Analysis */
.ai-key-overlay{position:absolute;inset:0;background:rgba(8,12,18,.92);z-index:200;display:flex;align-items:center;justify-content:center;border-radius:4px;}


/* Floating save/load buttons */
.fab-group{
  position:fixed;bottom:24px;right:24px;
  display:flex;flex-direction:column;align-items:flex-end;gap:8px;
  z-index:900;
}
.fab-menu{
  display:flex;flex-direction:column;align-items:flex-end;gap:6px;
  overflow:hidden;max-height:0;opacity:0;
  transition:max-height .25s ease, opacity .2s ease;
  pointer-events:none;
}
.fab-menu.open{max-height:300px;opacity:1;pointer-events:all;}
.fab-item{
  display:flex;align-items:center;gap:8px;cursor:pointer;
  background:var(--surface2);border:1px solid var(--border);
  border-radius:20px;padding:6px 14px 6px 10px;
  font-family:'Rajdhani',sans-serif;font-size:12px;font-weight:700;
  letter-spacing:.5px;color:var(--text2);white-space:nowrap;
  box-shadow:0 2px 8px rgba(0,0,0,.4);transition:all .15s;
}
.fab-item:hover{border-color:var(--accent);color:var(--accent);}
.fab-item-icon{font-size:14px;line-height:1;}
.fab-main{
  width:44px;height:44px;border-radius:50%;
  background:var(--accent);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;box-shadow:0 3px 10px rgba(0,200,255,.35);
  transition:all .15s;color:var(--bg);
}
.fab-main:hover{transform:scale(1.08);box-shadow:0 4px 16px rgba(0,200,255,.5);}
.fab-main.open{transform:rotate(45deg);}
.fab-dirty-dot{
  position:absolute;top:-2px;right:-2px;width:10px;height:10px;
  border-radius:50%;background:#f59e0b;border:2px solid var(--bg);
  display:none;animation:fab-pulse 1.8s ease-in-out infinite;
}
@keyframes fab-pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(245,158,11,.5);}
  50%{box-shadow:0 0 0 5px rgba(245,158,11,0);}
}
.fab-group.dirty .fab-dirty-dot{display:block;}
.fab-group.dirty #fab-main{box-shadow:0 3px 10px rgba(245,158,11,.4);}
.fab-item.dirty-save{border-color:#f59e0b;color:#f59e0b;}
.fab-item.dirty-save:hover{border-color:#fbbf24;color:#fbbf24;}
.save-toast{
  position:fixed;bottom:80px;right:24px;
  background:var(--surface2);border:1px solid var(--accent);border-radius:6px;
  color:var(--accent);font-family:'Rajdhani',sans-serif;font-size:13px;font-weight:700;
  padding:8px 16px;letter-spacing:.5px;pointer-events:none;
  opacity:0;transition:opacity .2s;z-index:999;white-space:nowrap;
}
.save-toast.show{opacity:1;}
/* Build sub-tabs row */

.build-notes-wrap{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;padding:6px 12px 8px;}



.setup-panel{flex-shrink:0;background:var(--surface);border-bottom:1px solid var(--border);}




















.setup-modal-done:hover{opacity:.85;}




























.build-notes-input{
  width:100%;box-sizing:border-box;background:var(--surface2);border:1px solid var(--border);
  border-radius:4px;color:var(--text2);font-family:'Exo 2',sans-serif;font-size:11px;line-height:1.6;
  padding:6px 10px;outline:none;resize:vertical;min-height:52px;transition:border-color .15s;
}
.build-notes-input:focus{border-color:var(--accent);}
.build-notes-input::placeholder{color:var(--text3);}



/* RIGHT PANEL */


/* Level selector (now lives in sticky thead) */
.level-sel{
  padding:2px 6px;background:var(--surface3);border:1px solid var(--border);
  border-radius:4px;color:var(--accent);font-family:'Rajdhani',sans-serif;
  font-size:12px;font-weight:700;outline:none;cursor:pointer;
  transition:border-color .15s;
}
.level-sel:focus{border-color:var(--accent);}

.item-search{
  padding:4px 10px;background:var(--surface3);border:1px solid var(--border);
  border-radius:4px;color:var(--text);font-family:'Exo 2',sans-serif;font-size:12px;
  outline:none;width:180px;transition:border-color .2s;flex-shrink:0;
}
.item-search:focus{border-color:var(--accent);}
.item-search::placeholder{color:var(--text3);}

/* Class filter */
.class-bar{
  display:flex;gap:5px;align-items:center;padding:6px 14px;
  background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:nowrap;overflow:visible;position:relative;min-width:0;
}
.class-bar-lbl{font-family:'Rajdhani',sans-serif;font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);flex-shrink:0;}
.cf-btn{
  padding:3px 10px;border-radius:3px;font-size:11px;font-weight:600;letter-spacing:.5px;
  cursor:pointer;transition:all .15s;background:var(--surface2);border:1px solid var(--border);
  color:var(--text3);font-family:'Exo 2',sans-serif;
}
.cf-btn:hover{border-color:var(--text2);color:var(--text2);}
.cf-btn.active{background:rgba(0,200,255,.1);border-color:var(--accent);color:var(--accent);}
/* Inactive role buttons — grey, no color */
.cf-btn.cls-Fighter,.cf-btn.cls-Mage,.cf-btn.cls-Support,
.cf-btn.cls-Tank,.cf-btn.cls-Assassin,.cf-btn.cls-Sharpshooter{
  border-color:var(--border);color:var(--text3);
}
/* Active role buttons — show their color */
.cf-btn.cls-Fighter.active    {background:rgba(255,107,43,.15);border-color:#ff8c5a;color:#ff8c5a;}
.cf-btn.cls-Mage.active       {background:rgba(168,85,247,.15);border-color:#c084fc;color:#c084fc;}
.cf-btn.cls-Support.active    {background:rgba(34,197,94,.15);border-color:#4ade80;color:#4ade80;}
.cf-btn.cls-Tank.active       {background:rgba(59,130,246,.15);border-color:#60a5fa;color:#60a5fa;}
.cf-btn.cls-Assassin.active   {background:rgba(239,68,68,.15);border-color:#f87171;color:#f87171;}
.cf-btn.cls-Sharpshooter.active{background:rgba(234,179,8,.15);border-color:#facc15;color:#facc15;}

/* Two-level pill filter */
.filter-wrap{display:flex;flex-direction:column;gap:0;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;}
.filter-row{display:flex;gap:5px;align-items:center;padding:6px 14px;flex-wrap:wrap;}

/* ── Column multi-select filter dropdown ─────────────────────────────────── */
.col-filter-th { cursor:default; }
.col-filter-active > .col-filter-trigger { color:var(--accent); }
.col-filter-trigger {
  display:flex;align-items:center;gap:3px;white-space:nowrap;
  font-family:'Rajdhani',sans-serif;font-size:11px;font-weight:700;
  letter-spacing:.4px;text-transform:uppercase;cursor:pointer;
  color:var(--text3);transition:color .15s;
}
.col-filter-trigger:hover { color:var(--text2); }
.col-filter-arrow { font-size:7px;opacity:.5;margin-left:1px; }
.col-filter-dropdown {
  position:fixed;z-index:9000;
  background:var(--surface2);border:1px solid var(--border);
  border-radius:5px;box-shadow:0 8px 24px rgba(0,0,0,.6);
  min-width:160px;padding:0;
  max-height:300px;display:flex;flex-direction:column;
}
.col-filter-dropdown > .col-filter-header { flex-shrink:0; }
.col-filter-dropdown > .col-filter-clear  { flex-shrink:0; }
.col-filter-options {
  overflow-y:auto;flex:1;
  scrollbar-width:thin;scrollbar-color:var(--border) transparent;
}
.col-filter-options::-webkit-scrollbar { width:4px; }
.col-filter-options::-webkit-scrollbar-track { background:transparent; }
.col-filter-options::-webkit-scrollbar-thumb { background:var(--border);border-radius:2px; }
.col-filter-header {
  font-family:'Rajdhani',sans-serif;font-size:9px;font-weight:700;
  letter-spacing:.7px;text-transform:uppercase;color:var(--text3);
  padding:7px 10px 5px;border-bottom:1px solid var(--border);
}
.col-filter-option {
  display:flex;align-items:center;gap:8px;
  padding:5px 10px;cursor:pointer;
  font-family:'Exo 2',sans-serif;font-size:11px;color:var(--text2);
  transition:background .1s,color .1s;white-space:nowrap;
}
.col-filter-option:hover { background:var(--surface3);color:var(--text); }
.col-filter-option.active { color:var(--accent); }
.col-filter-check {
  width:14px;height:14px;border-radius:2px;flex-shrink:0;
  border:1px solid var(--border);background:var(--surface3);
  font-size:9px;color:var(--accent);display:flex;align-items:center;
  justify-content:center;font-weight:700;transition:all .1s;
}
.col-filter-option.active .col-filter-check {
  background:rgba(0,200,255,.15);border-color:var(--accent);
}
.col-filter-clear {
  padding:5px 10px;font-family:'Rajdhani',sans-serif;font-size:10px;
  font-weight:700;letter-spacing:.4px;color:var(--text3);cursor:pointer;
  border-top:1px solid var(--border);transition:color .1s;
}
.col-filter-clear:hover { color:var(--accent); }

/* Item table */

/* Item th with count + level selector */
.th-item-row{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;white-space:nowrap;}
.th-item-count{font-size:10px;color:var(--text3);font-weight:400;letter-spacing:0;white-space:nowrap;}
.th-level-wrap{display:flex;align-items:center;gap:4px;flex-shrink:0;}
.th-level-lbl{font-size:9px;color:var(--text3);letter-spacing:1px;font-weight:600;font-family:'Rajdhani',sans-serif;}

/* Selected items pinned panel in right col */
.selected-items-panel{display:flex;flex-direction:column;flex-shrink:0;}








/* Build comparison panel */
.collapsible-section{border-bottom:1px solid var(--border);flex-shrink:0;}
.collapsible-arrow{font-size:10px;color:var(--accent);transition:transform .2s;flex-shrink:0;opacity:.7;}
.collapsible-arrow.open{transform:rotate(90deg);}
.collapsible-body{overflow:hidden;}

















.build-slot-trigger:hover{background:var(--surface3);}












.item-table-wrap{overflow-x:auto;overflow-y:auto;min-height:0;max-height:100%;scrollbar-width:thin;scrollbar-color:var(--border) transparent;touch-action:pan-x pan-y;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;}
.item-table{width:100%;border-collapse:separate;border-spacing:0;font-size:12px;}

.item-table thead{position:sticky;top:0;z-index:5;}
.item-table tfoot{position:sticky;bottom:0;z-index:5;}
.totals-row td{background:var(--surface2);border-top:2px solid var(--border);font-family:'Rajdhani',sans-serif;font-weight:700;font-size:13px;padding:4px 10px;white-space:nowrap;vertical-align:middle;}
.totals-row .totals-label{font-size:10px;letter-spacing:.6px;text-transform:uppercase;color:var(--text3);text-align:left;}
.totals-row .totals-val{color:var(--accent);text-align:center;}
.totals-row .totals-cost{color:var(--gold);text-align:center;}
.totals-row .totals-empty{color:var(--border);text-align:center;font-weight:600;}
@media (pointer: coarse) {
  .totals-row td { padding-top:8px; padding-bottom:8px; }
}
.item-table th{
  padding:6px 10px;background:var(--surface);color:var(--text3);
  font-family:'Rajdhani',sans-serif;font-size:11px;font-weight:600;
  letter-spacing:1px;text-transform:uppercase;text-align:left;
  border-bottom:2px solid var(--border);white-space:nowrap;
  cursor:pointer;user-select:none;transition:color .15s;
}
.item-table th:hover{color:var(--accent);}
.item-table th.sorted-asc::after{content:' ▲';color:var(--accent);}
.item-table th.sorted-desc::after{content:' ▼';color:var(--accent);}
.item-table td{padding:4px 10px;border-bottom:1px solid rgba(30,48,72,.4);color:var(--text2);white-space:nowrap;vertical-align:middle;}
.item-table tr{cursor:pointer;transition:background .1s;}
.item-table tbody tr:hover td{background:var(--surface2);}
.item-table tbody tr:hover .it-name{color:var(--accent);}
.item-table tr.row-in-build td{background:rgba(0,200,255,.05);}
.item-table tr.row-in-build .it-name{color:var(--accent);}
.item-table tr.row-active-slot td{background:rgba(0,200,255,.12);}
.item-table tr.row-active-slot .it-name{color:var(--accent);}
.item-table tr.row-active-slot td:first-child{border-left:2px solid var(--accent);}



/* Selected items pinned rows — look like a static hover */
.item-table tr.sel-pinned-row td{background:var(--surface2) !important;}
.item-table tr.sel-pinned-row .it-name{color:var(--text);}
.item-table tr.sel-pinned-divider{display:none;}
/* Hero stats pinned row */
.item-table tr.hero-stat-row{cursor:pointer;}
.item-table tr.crest-picker-row td{
  background:var(--surface);
  border-bottom:1px solid var(--border);
  font-family:'Rajdhani',sans-serif;font-size:11px;
}
.crest-picker-row.open td{ border-bottom:none; }
.crest-picker-row.open .crest-chevron{ transform:rotate(90deg); }
.crest-sub-row td{
  background:var(--surface2);border-bottom:1px solid var(--border);
}
.crest-sub-row:hover td{ background:var(--surface3); }
.hero-stat-row td{
  position:sticky;
  top:var(--thead-height, 28px);
  background:var(--surface2) !important;
  border-bottom:1px solid var(--border) !important;
  color:var(--text);
  z-index:4;
}
.item-table tr.hero-stat-row:hover td{background:var(--surface2) !important;}
.ability-stat-row td{
  background:var(--surface3);
  border-bottom:1px solid rgba(30,48,72,.4);
}
.ability-stat-row:hover td{ background:var(--surface2); }
.ability-stat-row:last-of-type td{ border-bottom:1px solid var(--border); }
.item-table td.toggle-col,
.item-table tr.hero-stat-row td.toggle-col,
.item-table tr.crest-picker-row td.toggle-col,
.item-table tr.crest-sub-row td.toggle-col{
  background:transparent !important;
  position:relative !important;
  z-index:3;
  width:18px !important;
  padding:0 !important;
  border:none !important;
}
.hs-name-cell{display:flex;align-items:center;gap:8px;}
.hs-name{font-family:'Rajdhani',sans-serif;font-size:13px;font-weight:700;color:var(--text);letter-spacing:.5px;}
.item-class-tag{
  font-family:'Rajdhani',sans-serif;font-size:9px;font-weight:700;
  letter-spacing:.5px;text-transform:uppercase;
  padding:1px 5px;border-radius:2px;
  background:var(--surface3);border:1px solid var(--border);
  color:var(--text3);white-space:nowrap;
}

/* Playstyle pills inherit base .item-class-tag style — same as Crest Item pill */

/* Aggression type badge */
.agg-badge{
  display:inline-flex;align-items:center;justify-content:center;
  font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
  padding:2px 6px;border-radius:3px;white-space:nowrap;flex-shrink:0;
}
.it-icon-wrap{
  position:relative;flex-shrink:0;border-radius:3px;
  line-height:0;width:36px;height:36px;
}
.it-icon-wrap.evolve-icon{
  border:1px solid rgba(0,200,255,.5) !important;
  border-radius:3px;
}
.evolve-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(0,200,255,.55) 0%, transparent 55%);
  border-radius:3px;
  pointer-events:none;
  z-index:1;
}
.it-icon{width:36px;height:36px;object-fit:contain;border-radius:3px;display:block;position:relative;z-index:0;flex-shrink:0;border:1px solid var(--border);background:var(--surface3);}
.it-name-wrap{display:flex;align-items:center;gap:8px;}
.it-name{color:var(--text);font-weight:600;min-width:120px;font-size:13px;cursor:default;}
.slot-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:9px;padding:0 5px;background:var(--accent);color:var(--bg);font-size:9px;font-weight:900;flex-shrink:0;}
.stat-cell{color:var(--accent);font-family:'Rajdhani',sans-serif;font-size:13px;font-weight:600;text-align:center;}
.stat-cell.empty{color:var(--border);}
.gold-cell{color:var(--gold);font-family:'Rajdhani',sans-serif;font-size:13px;font-weight:700;text-align:center;}

/* Hero stat cell in table */
.hero-stat-td{font-family:'Rajdhani',sans-serif;font-size:13px;font-weight:600;text-align:center;color:var(--text2);}
.hero-stat-td.hs-val{color:var(--text);}




/* Drag-to-reorder pinned rows */
.sel-pinned-row[draggable="true"]{
  cursor:grab;
  user-select:none;
  -webkit-user-select:none;
  -webkit-touch-callout:none;
}
.sel-pinned-row[draggable="true"]:active{cursor:grabbing;}
.sel-pinned-row.drag-over{outline:2px solid var(--accent);outline-offset:-2px;background:rgba(0,200,255,.07);}
.sel-pinned-row.dragging{opacity:.4;}
.drag-handle{
  display:inline-flex;align-items:center;justify-content:center;
  width:14px;height:100%;color:var(--text3);font-size:12px;cursor:grab;
  flex-shrink:0;margin-right:4px;letter-spacing:-1px;
  user-select:none;
  -webkit-user-select:none;
  -webkit-touch-callout:none;
  touch-action:none;
}
.drag-handle:hover{color:var(--text2);}

/* Loading */
.loading{text-align:center;padding:80px;color:var(--text3);font-size:15px;}
.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px;}
@keyframes spin{to{transform:rotate(360deg);}}


/* ── Playstyle info modal ──────────────────────────────────────────── */
#ps-modal-overlay{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:1000;
  align-items:center;justify-content:center;
}
#ps-modal-overlay.open{display:flex;}
#ps-modal{
  background:var(--surface2);border:1px solid var(--border);border-radius:8px;
  width:min(560px,92vw);max-height:85vh;overflow-y:auto;
  padding:24px;position:relative;
}
#ps-modal-close{
  position:absolute;top:12px;right:14px;background:none;border:none;
  color:var(--text3);cursor:pointer;font-size:18px;line-height:1;
  transition:color .15s;
}
#ps-modal-close:hover{color:var(--text);}
.ps-modal-tag{
  display:inline-block;font-family:'Rajdhani',sans-serif;font-size:10px;font-weight:700;
  letter-spacing:.5px;text-transform:uppercase;padding:2px 8px;border-radius:3px;
  background:var(--surface3);border:1px solid var(--border);color:var(--text3);margin-bottom:12px;
}
.ps-modal-title{
  font-family:'Rajdhani',sans-serif;font-size:22px;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;color:var(--text);margin-bottom:8px;
}
.ps-modal-desc{
  font-size:13px;color:var(--text2);line-height:1.7;margin-bottom:16px;
}
.ps-modal-section{
  font-family:'Rajdhani',sans-serif;font-size:9px;font-weight:700;letter-spacing:1px;
  text-transform:uppercase;color:var(--text3);margin-bottom:6px;margin-top:14px;
}
.ps-modal-heroes{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:4px;}
.ps-modal-hero{
  font-size:11px;padding:2px 8px;border-radius:3px;
  background:var(--surface3);border:1px solid var(--border);color:var(--text2);
}
.ps-modal-items{font-size:12px;color:var(--text2);line-height:1.8;}
.ps-modal-hero-chip{
  font-size:11px;padding:3px 10px;border-radius:3px;cursor:pointer;
  border:1px solid var(--border);color:var(--text3);background:var(--surface3);
  transition:background .15s,color .15s,border-color .15s;user-select:none;
}
.ps-modal-hero-chip.active{
  background:var(--accent);color:#000;border-color:var(--accent);font-weight:600;
}
.ps-modal-hero-chip:hover:not(.active){background:var(--surface1);color:var(--text);}
.ps-modal-apply-row{display:flex;gap:8px;margin-top:14px;align-items:center;flex-wrap:wrap;}
.ps-modal-btn{
  font-family:'Rajdhani',sans-serif;font-size:11px;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;padding:6px 14px;border-radius:4px;cursor:pointer;
  border:1px solid var(--border);background:var(--surface3);color:var(--text2);
  transition:background .15s,color .15s;
}
.ps-modal-btn:hover{background:var(--surface1);color:var(--text);}
.ps-modal-btn.primary{background:var(--accent);color:#000;border-color:var(--accent);}
.ps-modal-btn.primary:hover{opacity:.88;}
.ps-modal-saved{font-size:11px;color:var(--green,#4ade80);display:none;}
.ps-modal-tip{
  margin-top:16px;padding:10px 12px;border-radius:4px;
  border-left:2px solid var(--accent);background:rgba(0,200,255,.06);
  font-size:12px;color:var(--text2);line-height:1.6;
}

/* ── Item tag editor ─────────────────────────────────────────────────── */

.ite-btn:hover { background:var(--surface1); color:var(--text); }
.ite-btn.primary { background:var(--accent); color:#000; border-color:var(--accent); }
.ite-btn.primary:hover { opacity:.88; }

/* ── Full-screen detail modal ─────────────────────────────────────── */
.modal-nav-btn{
  position:fixed;top:50%;transform:translateY(-50%);
  background:var(--surface2);border:1px solid var(--border);border-radius:8px;
  color:var(--text2);font-size:24px;line-height:1;
  width:44px;height:64px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;z-index:10001;
}
#modal-nav-prev{left:max(12px, calc(50% - 340px));}
#modal-nav-next{right:max(12px, calc(50% - 340px));}
.modal-nav-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--surface);}
.modal-nav-btn:disabled{opacity:.2;cursor:default;border-color:var(--border);color:var(--text3);}
.modal-nav-counter{
  position:fixed;bottom:20px;left:50%;transform:translateX(-50%);
  font-size:12px;color:var(--text3);font-family:'Rajdhani',sans-serif;
  letter-spacing:.5px;z-index:10001;
  background:rgba(0,0,0,.5);padding:4px 10px;border-radius:10px;
}
.modal-item-icon-wrap{
  position:relative;flex-shrink:0;border-radius:8px;line-height:0;
}
.modal-item-icon-wrap.evolve-icon{
  border:1px solid rgba(0,200,255,.5) !important;
  border-radius:8px;
  isolation:isolate;
}
.modal-item-icon-wrap.evolve-icon::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(0,200,255,.55) 0%, transparent 55%);
  border-radius:8px;
  z-index:2;
  pointer-events:none;
}
.modal-item-icon-wrap.evolve-icon img{
  position:relative;
  z-index:1;
}
.modal-item-icon{
  width:96px;height:96px;border-radius:8px;object-fit:contain;
  border:1px solid var(--border);background:var(--surface2);
  flex-shrink:0;
}
#detail-modal{
  display:none;position:fixed;inset:0;z-index:9999;
  background:rgba(0,0,0,.75);backdrop-filter:blur(4px);
  align-items:center;justify-content:center;padding:16px;
}
#detail-modal.open{display:flex;}
#detail-modal-card{
  background:var(--surface);border:1px solid var(--border);border-radius:12px;
  width:100%;max-width:480px;max-height:90vh;
  display:flex;flex-direction:column;overflow:hidden;
  position:relative;
}
#detail-modal-card.pattern-modal{
  width:700px !important;
  max-width:95vw !important;
}
#detail-modal-topbar{
  display:flex;align-items:center;gap:12px;
  padding:12px 12px 12px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
#detail-modal-topbar-info{
  display:flex;flex-direction:column;gap:6px;flex:1;min-width:0;
}
#detail-modal-item-name{
  font-family:'Rajdhani',sans-serif;font-size:20px;font-weight:700;
  color:var(--text);letter-spacing:.5px;
}
#detail-modal-item-stats{
  display:flex;flex-wrap:wrap;gap:4px;
}
#detail-modal-body{
  overflow-y:auto;padding:16px;flex:1;
}
#detail-modal-close{
  background:var(--surface2);border:none;border-radius:6px;
  color:var(--text2);font-size:20px;line-height:1;
  width:36px;height:36px;cursor:pointer;display:flex;
  align-items:center;justify-content:center;
  flex-shrink:0;margin-left:auto;
  transition:background .15s;
}
#detail-modal-close:hover{background:var(--border);color:var(--text);}
/* ── Checkbox / toggle column ─────────────────────────────────────── */
.cb-cell{width:28px;text-align:center;padding:0 2px;}
.cb-toggle{
  width:20px;height:20px;display:flex;align-items:center;justify-content:center;
  background:none;border:1px solid var(--border);border-radius:4px;
  color:var(--text3);cursor:pointer;font-size:11px;line-height:1;
  transition:all .15s;flex-shrink:0;padding:0;
}
.row-in-build .cb-toggle, .row-active-slot .cb-toggle{
  border-color:var(--accent);color:var(--accent);background:rgba(0,200,255,.08);
}
.cb-toggle:hover{border-color:var(--text2);color:var(--text2);}
.it-name-wrap{display:flex;align-items:center;gap:6px;}

.it-name-link{cursor:pointer;}
.it-name-link:hover{color:var(--accent);text-decoration:underline;}
.pin-remove-btn{
  background:none;border:none;color:var(--text3);cursor:pointer;
  font-size:11px;padding:0 2px;line-height:1;transition:color .15s;
  flex-shrink:0;
}
.pin-remove-btn:hover{color:#ef4444;}


  /* iOS touch scroll lock */
  * { -webkit-tap-highlight-color: transparent; }
  
  
  
/* ── Weight Tuner Modal ──────────────────────────────────────────────────── */
#tuner-modal {
  display:none; position:fixed; inset:0; z-index:10000;
  background:var(--bg); flex-direction:column; overflow:hidden;
}
#tuner-modal.open { display:flex; }
.tuner-header {
  display:flex; align-items:center; gap:12px;
  padding:10px 16px; background:var(--surface);
  border-bottom:1px solid var(--border); flex-shrink:0;
}
.tuner-title {
  font-family:'Rajdhani',sans-serif; font-size:14px; font-weight:700;
  letter-spacing:1px; text-transform:uppercase; color:var(--accent);
}
.tuner-hero-name {
  font-family:'Rajdhani',sans-serif; font-size:13px; font-weight:600;
  color:var(--text2);
}
.tuner-body {
  display:grid; grid-template-columns:420px 1fr;
  flex:1; overflow:hidden;
}
.tuner-left {
  background:var(--surface); border-right:1px solid var(--border);
  overflow-y:auto; display:flex; flex-direction:column;
  scrollbar-width:thin; scrollbar-color:var(--border) transparent;
}
.tuner-right {
  overflow-y:auto; background:var(--bg);
  scrollbar-width:thin; scrollbar-color:var(--border) transparent;
}
.tuner-ps-header.first { border-top:none; margin-top:6px; }

/* Secondary section label — no change needed, already plain */
/* Collapsible secondary sections */
.tuner-collapse-btn {
  display:flex; align-items:center; gap:6px; width:100%;
  background:none; border:none; cursor:pointer;
  padding:8px 14px 4px; border-top:1px solid var(--border);
  font-family:'Rajdhani',sans-serif; font-size:9px; font-weight:700;
  letter-spacing:.8px; text-transform:uppercase; color:var(--text3);
  text-align:left; transition:color .15s;
}
.tuner-collapse-btn:hover { color:var(--text2); }
.tuner-collapse-arrow { font-size:8px; transition:transform .2s; margin-left:auto; }
.tuner-collapse-arrow.open { transform:rotate(180deg); }
.tuner-collapse-body { overflow:hidden; }
.tuner-collapse-body.collapsed { display:none; }
.tuner-val.zero { color:var(--text3); }
.tuner-item-card {
  display:grid; grid-template-columns:22px 32px 1fr auto;
  gap:8px; align-items:start;
  padding:8px 12px; background:var(--surface);
  border:1px solid var(--border); border-radius:5px; margin-bottom:5px;
  transition:border-color .2s;
}
.tuner-item-card.t1 { border-color:rgba(0,200,255,.4); background:rgba(0,200,255,.03); }
.tuner-item-card.t2 { border-color:rgba(0,200,255,.2); }
.tuner-item-card.t3 { border-color:rgba(0,200,255,.1); }
.tuner-rank {
  font-family:'Rajdhani',sans-serif; font-size:14px; font-weight:700;
  color:var(--text3); text-align:center; padding-top:3px;
}
.tuner-rank.hi { color:var(--accent); }
.tuner-item-icon {
  width:32px; height:32px; border-radius:3px; object-fit:contain;
  border:1px solid var(--border); background:var(--surface3);
}
.tuner-item-name {
  font-family:'Rajdhani',sans-serif; font-size:13px; font-weight:700;
  color:var(--text); margin-bottom:2px;
  cursor:pointer; transition:color .15s;
}
.tuner-item-name:hover { color:var(--accent); text-decoration:underline; text-underline-offset:2px; }
.tuner-tag-pills { display:flex; flex-wrap:wrap; gap:2px; margin-bottom:3px; }
.tuner-pill {
  font-family:'Rajdhani',sans-serif; font-size:8px; font-weight:700;
  letter-spacing:.3px; text-transform:uppercase;
  padding:1px 5px; border-radius:2px;
  background:var(--surface3); border:1px solid var(--border); color:var(--text3);
}
.tuner-pill.m1 { background:rgba(0,200,255,.18); border-color:rgba(0,200,255,.4); color:var(--accent); }
.tuner-pill.m2 { background:rgba(0,200,255,.11); border-color:rgba(0,200,255,.25); color:var(--accent); }
.tuner-pill.m3 { background:rgba(0,200,255,.06); border-color:rgba(0,200,255,.15); color:var(--text2); }
.tuner-pill.cap { opacity:.35; }
.tuner-breakdown { font-size:9px; color:var(--text3); line-height:1.5; margin-top:1px; }
.tuner-score {
  font-family:'Rajdhani',sans-serif; font-size:15px; font-weight:700;
  color:var(--text2); text-align:right;
}
.tuner-score.hi { color:var(--accent); }
.tuner-divider {
  display:flex; align-items:center; gap:8px; padding:6px 0 4px;
}
.tuner-divider-line { flex:1; height:1px; background:var(--border); }
.tuner-divider-label {
  font-family:'Rajdhani',sans-serif; font-size:9px; font-weight:700;
  letter-spacing:.8px; text-transform:uppercase; color:var(--text3);
}
.tuner-dirty-bar {
  display:none; align-items:center; gap:8px; padding:8px 16px;
  background:var(--surface); border-top:1px solid rgba(0,200,255,.25);
  font-family:'Rajdhani',sans-serif; font-size:10px; font-weight:700;
  letter-spacing:.4px; color:var(--accent); flex-shrink:0;
  position:fixed; bottom:0; left:0; right:0; z-index:10001;
  box-shadow:0 -4px 16px rgba(0,0,0,.4);
}
.tuner-dirty-bar.show { display:flex; }
.tuner-dirty-bar span { flex:1; }

.adj-badge {
  font-family:'Rajdhani',sans-serif; font-size:8px; font-weight:700;
  letter-spacing:.5px; text-transform:uppercase; padding:1px 5px;
  border-radius:2px; margin-left:6px; vertical-align:middle;
}
.adj-badge.promoted  { background:rgba(0,200,255,.12); border:1px solid rgba(0,200,255,.3); color:var(--accent); }
.adj-badge.replaced  { background:rgba(245,200,66,.12); border:1px solid rgba(245,200,66,.3); color:var(--gold); }
.adj-badge.crit-cap  { background:rgba(248,113,113,.12); border:1px solid rgba(248,113,113,.3); color:#f87171; }
/* ── Diff Preview Modal ─────────────────────────────────────────────────── */
#tuner-diff-modal {
  display:none; position:fixed; inset:0; z-index:10001;
  background:rgba(0,0,0,.75); backdrop-filter:blur(4px);
  align-items:center; justify-content:center; padding:20px;
}
#tuner-diff-modal.open { display:flex; }
.tdiff-card {
  background:var(--surface2); border:1px solid var(--border);
  border-radius:8px; width:100%; max-width:460px;
  box-shadow:0 20px 60px rgba(0,0,0,.6);
  overflow:hidden;
}
.tdiff-header {
  padding:14px 18px 10px;
  border-bottom:1px solid var(--border);
}
.tdiff-title {
  font-family:'Rajdhani',sans-serif; font-size:13px; font-weight:700;
  letter-spacing:.8px; text-transform:uppercase; color:var(--accent);
  margin-bottom:2px;
}
.tdiff-subtitle {
  font-size:11px; color:var(--text3);
}
.tdiff-body {
  padding:10px 18px 6px; max-height:60vh; overflow-y:auto;
  scrollbar-width:thin; scrollbar-color:var(--border) transparent;
}
.tdiff-group-label {
  font-family:'Rajdhani',sans-serif; font-size:9px; font-weight:700;
  letter-spacing:.8px; text-transform:uppercase; color:var(--text3);
  padding:6px 0 3px; border-bottom:1px solid var(--border); margin-bottom:2px;
}
.tdiff-row {
  display:flex; align-items:center; justify-content:space-between;
  padding:5px 0; border-bottom:1px solid rgba(255,255,255,.03);
}
.tdiff-tag {
  font-family:'Rajdhani',sans-serif; font-size:12px; font-weight:600;
  color:var(--text2); text-transform:uppercase; letter-spacing:.3px;
}
.tdiff-val { font-family:'Rajdhani',sans-serif; font-size:12px; }
.tdiff-footer {
  display:flex; justify-content:flex-end; gap:8px;
  padding:12px 18px; border-top:1px solid var(--border);
  background:var(--surface);
}
