:root{
  --bg:#07090e;--bg2:#0c1018;--bg3:#111820;
  --panel:rgba(11,16,24,0.97);
  --border:rgba(255,255,255,0.06);--border2:rgba(255,255,255,0.1);
  --amber:#D42B2B;--amber-d:rgba(212,43,43,0.12);--amber-d2:rgba(212,43,43,0.05);
  --blue:#3b82f6;--blue-d:rgba(59,130,246,0.12);
  --green:#10b981;--green-d:rgba(16,185,129,0.12);
  --red:#ef4444;--red-d:rgba(239,68,68,0.12);
  --purple:#8b5cf6;--purple-d:rgba(139,92,246,0.12);
  --cyan:#06b6d4;--cyan-d:rgba(6,182,212,0.12);
  --orange:#f97316;--pink:#ec4899;
  --text:#dde4ee;--text2:#8899aa;--text3:#4a5a6a;
  --r:8px;
}
/* ── Light theme overrides ─────────────────────────── */
body.light{
  --bg:#f0f2f5;--bg2:#ffffff;--bg3:#e8eaed;
  --panel:rgba(255,255,255,0.97);
  --border:rgba(0,0,0,0.08);--border2:rgba(0,0,0,0.13);
  --amber:#C42020;--amber-d:rgba(196,32,32,0.09);--amber-d2:rgba(196,32,32,0.04);
  --blue:#1d6feb;--blue-d:rgba(29,111,235,0.1);
  --green:#059669;--green-d:rgba(5,150,105,0.1);
  --red:#dc2626;--red-d:rgba(220,38,38,0.1);
  --purple:#7c3aed;--purple-d:rgba(124,58,237,0.1);
  --cyan:#0891b2;--cyan-d:rgba(8,145,178,0.1);
  --text:#111827;--text2:#4b5563;--text3:#9ca3af;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);height:100vh;overflow:hidden;}
body::before{content:'';position:fixed;inset:0;
  background-image:linear-gradient(rgba(212,43,43,0.022) 1px,transparent 1px),linear-gradient(90deg,rgba(212,43,43,0.022) 1px,transparent 1px);
  background-size:48px 48px;pointer-events:none;z-index:0;}

/* ── AUTH ── */
/* ── Auth screen — light theme ─────────────────────── */
#authScreen{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  background:#f0f2f5;
}
#authScreen::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 50% at 20% 80%, rgba(212,43,43,.07) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 80% 20%, rgba(180,30,30,.05) 0%, transparent 55%);
  pointer-events:none;
}
.auth-wrap{position:relative;z-index:1;width:400px;}
.auth-brand{text-align:center;margin-bottom:1.75rem;}
.auth-brand-icon{
  width:90px;height:90px;margin:0 auto 1rem;
  background:#fff;border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(212,43,43,.15), 0 1px 4px rgba(0,0,0,.08);
  padding:10px;
}
.auth-brand-icon img{width:100%;height:100%;object-fit:contain;}
.auth-brand h1{font-size:1.75rem;font-weight:800;letter-spacing:-.5px;color:#1a1a2e;}
.auth-brand h1 span{color:#D42B2B;}
.auth-brand p{font-family:'JetBrains Mono',monospace;font-size:.65rem;color:#6b7280;text-transform:uppercase;letter-spacing:2.5px;margin-top:.3rem;}
.auth-card{
  background:#ffffff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  padding:2rem;
  box-shadow:0 8px 40px rgba(0,0,0,.1), 0 1px 3px rgba(0,0,0,.06);
}
.aform{display:none;flex-direction:column;gap:1rem;} .aform.on{display:flex;}
.af{display:flex;flex-direction:column;gap:.4rem;}
.af label{
  font-family:'JetBrains Mono',monospace;font-size:.62rem;
  text-transform:uppercase;letter-spacing:1.5px;color:#6b7280;font-weight:600;
}
.af input{
  background:#f8f9fb;border:1.5px solid #e5e7eb;
  border-radius:8px;padding:.7rem 1rem;
  color:#1a1a2e;font-family:'JetBrains Mono',monospace;font-size:.85rem;
  transition:all .2s;width:100%;
}
.af input:focus{outline:none;border-color:#D42B2B;background:#fff;box-shadow:0 0 0 3px rgba(212,43,43,.08);}
.af input::placeholder{color:#9ca3af;}
.abtn{
  padding:.8rem;margin-top:.25rem;
  background:linear-gradient(135deg,#D42B2B,#a01818);
  border:none;border-radius:9px;color:#fff;
  font-family:'JetBrains Mono',monospace;font-weight:700;
  font-size:.78rem;text-transform:uppercase;letter-spacing:2px;
  cursor:pointer;transition:all .25s;position:relative;overflow:hidden;
  box-shadow:0 4px 15px rgba(212,43,43,.3);
}
.abtn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(212,43,43,.4);}
.abtn:active{transform:translateY(0);}
.abtn span{position:relative;z-index:1;}
#authMsg{color:#374151 !important;}
#authMsg{font-family:'JetBrains Mono',monospace;font-size:.75rem;text-align:center;min-height:1.1rem;margin-top:.25rem;}

/* ── PROJECTS ── */
#projectsScreen{position:fixed;inset:0;z-index:999;display:none;flex-direction:column;background:var(--bg);}
#projectsScreen.on{display:flex;}
.ps-header{background:var(--bg2);border-bottom:1px solid var(--border);padding:0 2rem;height:60px;display:flex;align-items:center;justify-content:space-between;}
.ps-logo{display:flex;align-items:center;gap:.75rem;}
.ps-logo-ic{width:36px;height:36px;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:4px;box-shadow:0 1px 4px rgba(0,0,0,.15);flex-shrink:0;} .ps-logo-ic img{width:100%;height:100%;object-fit:contain;}
.ps-logo-tx{font-size:1.05rem;font-weight:700;} .ps-logo-tx span{color:var(--amber);}
.ps-actions{display:flex;align-items:center;gap:.75rem;}
.ps-user{font-family:'JetBrains Mono',monospace;font-size:.72rem;color:var(--text2);padding:.3rem .75rem;background:var(--amber-d);border:1px solid rgba(212,43,43,.2);border-radius:6px;}
.ps-logout,.hdr-logout,.hdr-back{padding:.3rem .75rem;background:var(--red-d);border:1px solid rgba(239,68,68,.2);border-radius:6px;color:var(--red);font-family:'JetBrains Mono',monospace;font-size:.7rem;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .2s;}
.ps-logout:hover,.hdr-logout:hover{background:rgba(239,68,68,.2);transform:none;box-shadow:none;} .ps-logout::before,.hdr-logout::before,.hdr-back::before{display:none;}
.hdr-back{background:var(--amber-d);border-color:rgba(212,43,43,.2);color:var(--amber);}
.hdr-back:hover{background:rgba(212,43,43,.2);}
.ps-body{flex:1;overflow-y:auto;padding:2.5rem;}
.ps-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;}
.ps-top h2{font-size:1.4rem;font-weight:700;} .ps-top p{font-family:'JetBrains Mono',monospace;font-size:.7rem;color:var(--text2);margin-top:.2rem;}
.new-proj-btn{padding:.6rem 1.25rem;background:linear-gradient(135deg,var(--amber),#b01e1e);border:none;border-radius:var(--r);color:#000;font-family:'JetBrains Mono',monospace;font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:1.5px;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px rgba(212,43,43,.2);}
.new-proj-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px rgba(212,43,43,.3);} .new-proj-btn::before{display:none;}
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;}
.proj-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .3s;position:relative;overflow:hidden;}
.proj-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--amber),#b01e1e);transform:scaleX(0);transform-origin:left;transition:transform .3s;}
.proj-card:hover{border-color:rgba(212,43,43,.3);transform:translateY(-3px);box-shadow:0 10px 30px rgba(0,0,0,.3);} .proj-card:hover::before{transform:scaleX(1);}
.proj-card-icon{font-size:1.75rem;margin-bottom:.75rem;}
.proj-card-name{font-size:1.05rem;font-weight:600;margin-bottom:.35rem;}
.proj-card-desc{font-size:.82rem;color:var(--text2);line-height:1.5;}
.proj-card-meta{display:flex;align-items:center;justify-content:space-between;margin-top:1rem;padding-top:.85rem;border-top:1px solid var(--border);}
.proj-card-date{font-family:'JetBrains Mono',monospace;font-size:.65rem;color:var(--text3);}
.proj-card-layers{font-family:'JetBrains Mono',monospace;font-size:.65rem;color:var(--amber);background:var(--amber-d);padding:2px 8px;border-radius:4px;}
.proj-card-del{width:24px;height:24px;background:var(--red-d);border:1px solid rgba(239,68,68,.2);border-radius:5px;color:var(--red);font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;margin-left:.5rem;}
.proj-card-del:hover{background:rgba(239,68,68,.25);transform:none;box-shadow:none;} .proj-card-del::before{display:none;}
.proj-empty{grid-column:1/-1;text-align:center;padding:4rem;color:var(--text2);font-family:'JetBrains Mono',monospace;font-size:.8rem;}
.proj-empty .pe-icon{font-size:3rem;opacity:.3;margin-bottom:1rem;}

/* ── APP LAYOUT ── */
#app{display:none;grid-template-columns:360px minmax(0,1fr) 340px;grid-template-rows:52px minmax(0,1fr) 38px;height:100vh;position:relative;z-index:1;min-width:0;transition:grid-template-columns .3s cubic-bezier(.4,0,.2,1);}
#app.on{display:grid;}

/* HEADER */
header{grid-column:1/-1;background:var(--panel);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 1rem;z-index:100;min-width:0;overflow:hidden;}
.hdr-l{display:flex;align-items:center;gap:.65rem;}
.hdr-logo{width:36px;height:36px;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:4px;box-shadow:0 1px 4px rgba(0,0,0,.2);flex-shrink:0;} .hdr-logo img{width:100%;height:100%;object-fit:contain;}
.hdr-title{font-size:.95rem;font-weight:700;} .hdr-title span{color:var(--amber);}
.hdr-sep{width:1px;height:20px;background:var(--border);margin:0 .2rem;}
.hdr-proj{display:flex;align-items:center;gap:.4rem;font-family:'JetBrains Mono',monospace;font-size:.7rem;color:var(--text2);}
.hdr-proj-name{color:var(--amber);font-weight:600;}
.hdr-r{display:flex;align-items:center;gap:.65rem;}
.hdr-stat{font-family:'JetBrains Mono',monospace;font-size:.62rem;text-align:right;}
.hdr-stat-l{color:var(--text3);text-transform:uppercase;letter-spacing:1px;} .hdr-stat-v{color:var(--amber);font-weight:700;font-size:.9rem;}
.hdr-user{font-family:'JetBrains Mono',monospace;font-size:.68rem;color:var(--text2);padding:.25rem .65rem;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:5px;}
.hdr-logout{font-size:.65rem;}

/* LEFT PANEL */
.lpanel{background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;min-width:0;min-height:0;height:100%;}
.lp-head{padding:.7rem .85rem .6rem;border-bottom:1px solid var(--border);flex-shrink:0;}
.lp-head-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.0rem;}
.lp-head-title{font-family:'JetBrains Mono',monospace;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--text);}
.lp-add-btn{padding:.28rem .65rem;background:linear-gradient(135deg,var(--amber),#b01e1e);border:none;border-radius:5px;color:#000;font-family:'JetBrains Mono',monospace;font-weight:700;font-size:.62rem;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .25s;box-shadow:0 2px 8px rgba(212,43,43,.2);}
.lp-add-btn:hover{transform:translateY(-1px);} .lp-add-btn::before{display:none;}

/* ══════════════════════════════════════
   FILTER BAR — REDESIGN
══════════════════════════════════════ */
.filter-bar{
  padding:.55rem .85rem;border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.filter-bar-row{display:flex;gap:.4rem;align-items:center;}
.filter-search{
  flex:1;display:flex;align-items:center;gap:.4rem;
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  border-radius:7px;padding:.42rem .65rem;transition:border-color .2s;
}
.filter-search:focus-within{border-color:rgba(255,255,255,.15);}
.filter-search-ic{color:var(--text3);font-size:.85rem;flex-shrink:0;}
.filter-search input{
  flex:1;background:none;border:none;color:var(--text);
  font-family:'JetBrains Mono',monospace;font-size:.72rem;outline:none;
}
.filter-search input::placeholder{color:var(--text3);}
.filter-toggle-btn{
  height:32px;padding:0 .65rem;background:rgba(255,255,255,.04);
  border:1px solid var(--border);border-radius:7px;
  color:var(--text2);font-family:'JetBrains Mono',monospace;
  font-size:.65rem;cursor:pointer;transition:all .2s;
  display:flex;align-items:center;gap:.3rem;white-space:nowrap;flex-shrink:0;
}
.filter-toggle-btn:hover{border-color:rgba(212,43,43,.4);color:var(--amber);}
.filter-toggle-btn::before{display:none;}
.filter-toggle-btn.on{
  background:var(--amber-d);border-color:rgba(212,43,43,.4);color:var(--amber);
}
.filter-active-badge{
  display:none;font-family:'JetBrains Mono',monospace;font-size:.6rem;
  background:var(--amber);color:#000;border-radius:10px;
  padding:1px 5px;font-weight:700;
}
.filter-toggle-btn.on .filter-active-badge{display:inline;}

/* ── FILTER PANEL REDESIGN ── */
.adv-filter{
  background:rgba(5,10,18,1);
  border-bottom:2px solid rgba(212,43,43,.2);
  flex-shrink:0;display:none;overflow-y:auto;max-height:44vh;
}
.adv-filter::-webkit-scrollbar{width:3px;}
.adv-filter::-webkit-scrollbar-thumb{background:var(--amber);border-radius:2px;}
.adv-filter.on{display:flex;flex-direction:column;}

/* Filter header */
.af-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:.6rem .85rem .5rem;
  border-bottom:1px solid var(--border);flex-shrink:0;
}
.af-header-title{
  font-family:'JetBrains Mono',monospace;font-size:.62rem;font-weight:700;
  text-transform:uppercase;letter-spacing:1.5px;color:var(--amber);
  display:flex;align-items:center;gap:.4rem;
}
.af-header-title-ic{font-size:.9rem;}

/* Logic toggle — pill style */
.af-logic-pills{display:flex;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:20px;padding:2px;}
.af-logic-btn{
  padding:.18rem .65rem;background:none;border:none;border-radius:20px;
  color:var(--text3);font-family:'JetBrains Mono',monospace;font-size:.6rem;
  font-weight:700;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .18s;
}
.af-logic-btn::before{display:none;}
.af-logic-btn.on{background:var(--amber);color:#000;}

/* Layer selector */
.af-layer-row{padding:.55rem .85rem .3rem;}
.af-layer-sel{
  background:rgba(255,255,255,.05);border:1px solid var(--border2);
  border-radius:7px;padding:.42rem .65rem;color:var(--text);
  font-family:'JetBrains Mono',monospace;font-size:.7rem;width:100%;
  transition:border-color .2s;
}
.af-layer-sel:focus{outline:none;border-color:var(--amber);}

/* Condition pills */
.af-conditions{display:flex;flex-direction:column;gap:.4rem;padding:.4rem .85rem;}
.af-cond{
  background:rgba(255,255,255,.03);border:1px solid var(--border);
  border-radius:8px;overflow:hidden;
  transition:border-color .2s;
}
.af-cond:hover{border-color:rgba(255,255,255,.1);}
.af-cond-num{
  display:flex;align-items:center;justify-content:center;
  width:20px;flex-shrink:0;
  background:rgba(212,43,43,.12);
  font-family:'JetBrains Mono',monospace;font-size:.58rem;font-weight:700;
  color:var(--amber);border-right:1px solid var(--border);
}
.af-cond-inner{flex:1;padding:.45rem .5rem;}
.af-cond-row1{display:grid;grid-template-columns:1fr 1fr;gap:.3rem;margin-bottom:.3rem;}
.af-cond-row2{display:flex;gap:.3rem;align-items:center;}
.af-cond-layout{display:flex;}
.af-inp{
  background:rgba(255,255,255,.04);border:1px solid var(--border2);
  border-radius:5px;padding:.35rem .5rem;color:var(--text);
  font-family:'JetBrains Mono',monospace;font-size:.68rem;
  flex:1;transition:border-color .2s;
}
.af-inp:focus{outline:none;border-color:var(--amber);}
.af-sel{
  background:rgba(255,255,255,.04);border:1px solid var(--border2);
  border-radius:5px;padding:.32rem .4rem;color:var(--text);
  font-family:'JetBrains Mono',monospace;font-size:.64rem;width:100%;
}
.af-cond-del{
  width:28px;flex-shrink:0;background:none;border:none;border-left:1px solid var(--border);
  color:var(--text3);font-size:.75rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .2s;
}
.af-cond-del:hover{background:var(--red-d);color:var(--red);}
.af-cond-del::before{display:none;}

/* ── QUICK TEXT SEARCH ── */
.af-quicksearch-wrap{
  margin:.4rem .85rem .3rem;
  background:rgba(59,130,246,.06);
  border:1px solid rgba(59,130,246,.2);
  border-radius:9px;padding:.55rem .65rem;
}
.af-quicksearch-label{
  display:flex;align-items:center;gap:.4rem;
  font-family:'JetBrains Mono',monospace;font-size:.6rem;
  color:var(--blue);margin-bottom:.4rem;
}
.af-qs-ic{font-size:.85rem;}
.af-quicksearch-label em{font-style:normal;color:rgba(59,130,246,.8);font-weight:700;}
.af-cs-toggle{
  margin-left:auto;display:flex;align-items:center;gap:.25rem;
  font-family:'JetBrains Mono',monospace;font-size:.6rem;
  color:var(--text2);cursor:pointer;
}
.af-cs-toggle input{accent-color:var(--blue);width:11px;height:11px;}
.af-quicksearch-row{display:flex;gap:.3rem;}
.af-qs-input{
  flex:1;background:rgba(255,255,255,.05);border:1px solid rgba(59,130,246,.25);
  border-radius:6px;padding:.38rem .55rem;color:var(--text);
  font-family:'JetBrains Mono',monospace;font-size:.7rem;
  transition:border-color .2s;
}
.af-qs-input:focus{outline:none;border-color:var(--blue);}
.af-qs-input::placeholder{color:var(--text3);}
.af-qs-clear{
  width:28px;background:none;border:1px solid var(--border);
  border-radius:6px;color:var(--text3);font-size:.7rem;cursor:pointer;
  transition:all .15s;flex-shrink:0;
}
.af-qs-clear:hover{color:var(--red);border-color:rgba(239,68,68,.4);}
.af-qs-clear::before{display:none;}
.af-qs-result{
  font-family:'JetBrains Mono',monospace;font-size:.6rem;
  color:var(--blue);margin-top:.35rem;min-height:.8rem;
}

/* ── Divider ── */
.af-divider{
  display:flex;align-items:center;gap:.5rem;
  margin:.5rem .85rem .2rem;
}
.af-divider::before,.af-divider::after{content:'';flex:1;height:1px;background:var(--border);}
.af-divider span{
  font-family:'JetBrains Mono',monospace;font-size:.58rem;
  color:var(--text3);white-space:nowrap;
}

/* ── Condition type chip ── */
.af-cond-type{
  font-family:'JetBrains Mono',monospace;font-size:.55rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.5px;
  padding:1px 5px;border-radius:3px;margin-bottom:.25rem;display:inline-block;
}
.af-cond-type.txt{background:rgba(59,130,246,.15);color:var(--blue);}
.af-cond-type.num{background:rgba(16,185,129,.15);color:var(--green);}
.af-cond-type.mix{background:rgba(212,43,43,.12);color:var(--amber);}

/* ── Case toggle inside condition ── */
.af-cond-opts{display:flex;align-items:center;gap:.5rem;margin-top:.25rem;}
.af-cond-case{
  display:flex;align-items:center;gap:.2rem;cursor:pointer;
  font-family:'JetBrains Mono',monospace;font-size:.58rem;color:var(--text3);
}
.af-cond-case input{accent-color:var(--amber);width:11px;height:11px;}

/* ── Between inputs ── */
.af-between{display:flex;gap:.25rem;align-items:center;}
.af-between-sep{font-family:'JetBrains Mono',monospace;font-size:.6rem;color:var(--text3);flex-shrink:0;}

/* Add condition */
.af-add-cond{
  width:calc(100% - 1.7rem);margin:.1rem .85rem .55rem;
  padding:.38rem;background:none;
  border:1px dashed rgba(255,255,255,.1);border-radius:7px;
  color:var(--text3);font-family:'JetBrains Mono',monospace;
  font-size:.62rem;cursor:pointer;transition:all .2s;
  display:flex;align-items:center;justify-content:center;gap:.35rem;
}
.af-add-cond:hover{border-color:var(--amber);color:var(--amber);}
.af-add-cond::before{display:none;}

/* Action bar */
.af-action-bar{
  display:flex;gap:.4rem;padding:.5rem .85rem .65rem;
  border-top:1px solid var(--border);
  background:rgba(255,255,255,.01);flex-shrink:0;margin-top:auto;
}
.af-apply{
  flex:2;padding:.42rem;
  background:linear-gradient(135deg,var(--amber),#b01e1e);
  border:none;border-radius:7px;color:#000;
  font-family:'JetBrains Mono',monospace;font-weight:700;
  font-size:.65rem;text-transform:uppercase;letter-spacing:1px;cursor:pointer;
  transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.35rem;
}
.af-apply:hover{filter:brightness(1.1);}
.af-apply::before{display:none;}
.af-clear{
  flex:1;padding:.42rem;background:rgba(255,255,255,.04);
  border:1px solid var(--border);border-radius:7px;color:var(--text2);
  font-family:'JetBrains Mono',monospace;font-size:.65rem;
  text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .2s;
}
.af-clear:hover{background:rgba(255,255,255,.07);color:var(--text);}
.af-clear::before{display:none;}

/* Result badge */
.af-result-bar{
  display:none;padding:.4rem .85rem;
  font-family:'JetBrains Mono',monospace;font-size:.65rem;
  color:var(--text2);background:rgba(212,43,43,.06);
  border-top:1px solid rgba(212,43,43,.15);
  align-items:center;gap:.5rem;
}
.af-result-bar.on{display:flex;}
.af-result-bar span{color:var(--amber);font-weight:700;font-size:.8rem;}
.af-result{display:none;}

.lp-body{flex:1;overflow-y:auto;padding:.6rem .5rem;min-height:0;}
.lp-body::-webkit-scrollbar{width:3px;} .lp-body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px;}

/* ── LAYER CARD PREMIUM ── */
.layer-card{
  position:relative;background:rgba(13,20,32,0.9);
  border:1px solid var(--border);border-radius:10px;
  margin-bottom:.45rem;overflow:hidden;
  transition:border-color .2s, box-shadow .2s, transform .15s;
}
.layer-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--lc-accent,var(--amber));
  opacity:.7;transition:opacity .2s, width .2s;
}
.layer-card:hover{border-color:rgba(255,255,255,.1);box-shadow:0 4px 16px rgba(0,0,0,.3);}
.layer-card:hover::before{opacity:1;width:4px;}
.layer-card.selected{
  border-color:rgba(212,43,43,.35);
  background:rgba(212,43,43,.04);
  box-shadow:0 0 0 1px rgba(212,43,43,.15);
}
.layer-card.selected::before{opacity:1;width:4px;}

/* Card header */
.lc-head{display:flex;align-items:center;gap:.55rem;padding:.65rem .75rem .5rem 1rem;cursor:pointer;}
.lc-vis-dot{
  width:8px;height:8px;border-radius:50%;flex-shrink:0;
  background:var(--lc-accent,var(--amber));
  box-shadow:0 0 6px var(--lc-accent,var(--amber));
  transition:opacity .2s;
}
.layer-card.hidden .lc-vis-dot{opacity:.2;box-shadow:none;}
.lc-name{flex:1;font-size:.82rem;font-weight:600;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em;}
.lc-type-pill{
  font-family:'JetBrains Mono',monospace;font-size:.55rem;text-transform:uppercase;
  letter-spacing:1.2px;color:var(--lc-accent,var(--amber));
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
  padding:2px 6px;border-radius:20px;flex-shrink:0;
}
.lc-feat-badge{
  font-family:'JetBrains Mono',monospace;font-size:.6rem;font-weight:700;
  color:var(--text3);background:rgba(255,255,255,.04);
  padding:2px 6px;border-radius:20px;flex-shrink:0;white-space:nowrap;
}

/* Card actions row */
.lc-actions{
  display:flex;align-items:center;gap:0;
  padding:.3rem .7rem .5rem 1rem;
  border-top:1px solid rgba(255,255,255,.04);
}
.lca{
  height:26px;padding:0 .5rem;background:none;border:none;
  color:var(--text3);font-size:.68rem;cursor:pointer;
  display:flex;align-items:center;gap:.3rem;
  font-family:'JetBrains Mono',monospace;font-size:.6rem;
  border-radius:5px;transition:all .18s;white-space:nowrap;
}
.lca::before{display:none;} .lca:hover{transform:none;box-shadow:none;}
.lca:hover{background:rgba(255,255,255,.06);color:var(--text);}
.lca-sep{width:1px;height:14px;background:var(--border);margin:0 .15rem;flex-shrink:0;}
.lca.vis-btn:hover{color:var(--amber);background:var(--amber-d);}
.lca.zm-btn:hover{color:var(--blue);background:var(--blue-d);}
.lca.pt-btn:hover{color:var(--green);background:var(--green-d);}
.lca.pt-btn.on{color:var(--green);background:var(--green-d);}
.lca.del-btn{margin-left:auto;}
.lca.del-btn:hover{color:var(--red);background:var(--red-d);}

.lp-empty{text-align:center;padding:3rem 1rem;color:var(--text2);font-family:'JetBrains Mono',monospace;font-size:.72rem;line-height:1.6;}
.lp-empty-ic{font-size:2rem;opacity:.25;margin-bottom:.75rem;}

/* MAP */
#map{background:#08111a;position:relative;min-width:0;min-height:0;overflow:hidden;}

/* Draw mode indicator */
#drawModeBar{position:absolute;bottom:48px;left:50%;transform:translateX(-50%);z-index:900;background:rgba(16,185,129,.9);border:1px solid var(--green);border-radius:8px;padding:.5rem 1.25rem;font-family:'JetBrains Mono',monospace;font-size:.75rem;color:#fff;display:none;align-items:center;gap:.75rem;backdrop-filter:blur(10px);}
#drawModeBar.on{display:flex;}
#drawModeBar button{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);border-radius:5px;color:#fff;font-family:'JetBrains Mono',monospace;font-size:.65rem;padding:.25rem .6rem;cursor:pointer;transition:all .2s;}
#drawModeBar button:hover{background:rgba(255,255,255,.35);transform:none;box-shadow:none;} #drawModeBar button::before{display:none;}

/* Filter highlight */
.feature-highlight{stroke:#D42B2B!important;stroke-width:3!important;fill-opacity:.5!important;}
/* ── DRAW MODE BAR ── */
#drawShapeBar{
  position:absolute;top:12px;left:50%;transform:translateX(-50%);
  z-index:902;background:rgba(139,92,246,.95);border:1px solid rgba(139,92,246,.5);
  border-radius:10px;padding:.5rem 1rem;font-family:'JetBrains Mono',monospace;
  font-size:.72rem;color:#fff;display:none;align-items:center;gap:.7rem;
  backdrop-filter:blur(14px);white-space:nowrap;box-shadow:0 4px 20px rgba(139,92,246,.3);
}
#drawShapeBar.on{display:flex;}
#drawShapeBar span{opacity:.8;}
#drawShapeBar strong{color:#e0d0ff;}
#drawShapeBar button{
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);
  border-radius:5px;color:#fff;font-family:'JetBrains Mono',monospace;
  font-size:.62rem;padding:.22rem .6rem;cursor:pointer;transition:background .2s;
}
#drawShapeBar button:hover{background:rgba(255,255,255,.3);transform:none;box-shadow:none;}
#drawShapeBar button::before{display:none;}
/* Draw result modal */
.draw-modal-fields{display:flex;flex-direction:column;gap:.55rem;max-height:45vh;overflow-y:auto;}
/* ── SELECTION MODE BAR ── */
#selModeBar{position:absolute;top:12px;left:50%;transform:translateX(-50%);z-index:901;background:rgba(59,130,246,.93);border:1px solid rgba(59,130,246,.6);border-radius:9px;padding:.45rem 1rem;font-family:'JetBrains Mono',monospace;font-size:.72rem;color:#fff;display:none;align-items:center;gap:.65rem;backdrop-filter:blur(12px);white-space:nowrap;}
#selModeBar.on{display:flex;}
.sel-count{font-weight:700;color:#ffd;font-size:.9rem;}
#selModeBar button{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.28);border-radius:5px;color:#fff;font-family:'JetBrains Mono',monospace;font-size:.62rem;padding:.22rem .6rem;cursor:pointer;transition:background .2s;white-space:nowrap;}
#selModeBar button:hover{background:rgba(255,255,255,.32);transform:none;box-shadow:none;} #selModeBar button::before{display:none;}
#selModeBar .sm-danger{background:rgba(239,68,68,.4);border-color:rgba(239,68,68,.5);}
#selModeBar .sm-success{background:rgba(16,185,129,.4);border-color:rgba(16,185,129,.5);}
/* ── FILTER VALUE DROPDOWN ── */
.af-val-wrap{position:relative;}
.af-val-drop{display:none;position:absolute;top:calc(100% + 2px);left:0;right:0;z-index:700;background:var(--bg2);border:1px solid var(--border2);border-radius:7px;max-height:170px;overflow:hidden;box-shadow:0 10px 24px rgba(0,0,0,.55);}
.af-val-drop.on{display:flex;flex-direction:column;}
.af-val-search{border:none;border-bottom:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--text);font-family:'JetBrains Mono',monospace;font-size:.67rem;padding:.32rem .55rem;outline:none;flex-shrink:0;}
.af-val-search::placeholder{color:var(--text3);}
.af-val-list{overflow-y:auto;flex:1;}
.af-val-list::-webkit-scrollbar{width:3px;} .af-val-list::-webkit-scrollbar-thumb{background:var(--border2);}
.af-val-item{padding:.3rem .55rem;font-family:'JetBrains Mono',monospace;font-size:.67rem;color:var(--text2);cursor:pointer;border-bottom:1px solid rgba(255,255,255,.03);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.af-val-item:hover{background:var(--amber-d);color:var(--amber);}
.af-val-toggle{background:rgba(255,255,255,.04);border:1px solid var(--border2);border-radius:4px 0 0 4px;color:var(--text2);font-size:.7rem;padding:0 .5rem;cursor:pointer;height:100%;transition:all .2s;border-right:none;}
.af-val-toggle:hover{border-color:var(--amber);color:var(--amber);transform:none;box-shadow:none;} .af-val-toggle::before{display:none;}
.af-inp-row{display:flex;align-items:stretch;}
.af-inp-row .af-inp{border-radius:0 4px 4px 0;}
/* ── SELECTION STATS ── */
.sel-stat{background:var(--blue-d);border:1px solid rgba(59,130,246,.25);border-radius:6px;padding:.4rem .65rem;font-family:'JetBrains Mono',monospace;font-size:.65rem;color:var(--blue);margin-top:.4rem;display:none;}
.sel-stat.on{display:block;}
.sel-stat strong{color:#fff;}
/* ── Dissolve/SJ improvements ── */
.gt-check-row{display:flex;align-items:center;gap:.5rem;font-family:'JetBrains Mono',monospace;font-size:.68rem;color:var(--text2);margin-bottom:.35rem;cursor:pointer;}
.gt-check-row input{accent-color:var(--amber);}

/* ══════════════════════════════════
   RIGHT PANEL — ICON SIDEBAR NAV
══════════════════════════════════ */
.rpanel{
  background:var(--panel);border-left:1px solid var(--border);
  display:flex;flex-direction:row;overflow:hidden;min-width:0;min-height:0;height:100%;
}

/* Vertical icon nav */
.rp-nav{
  width:52px;flex-shrink:0;background:rgba(7,10,16,.98);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;align-items:center;
  padding:.5rem 0;gap:.15rem;overflow:hidden;
}
.rpn{
  width:40px;height:40px;border:none;background:none;
  border-radius:9px;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:.18rem;transition:all .2s;position:relative;
  color:var(--text3);
}
.rpn::before{display:none;}
.rpn:hover{background:rgba(255,255,255,.06);color:var(--text2);}
.rpn.on{background:var(--amber-d);color:var(--amber);}
.rpn.on::after{
  content:'';position:absolute;left:0;top:20%;bottom:20%;
  width:2px;background:var(--amber);border-radius:0 2px 2px 0;
}
.rpn-ic{font-size:1.05rem;line-height:1;}
.rpn-lb{
  font-family:'JetBrains Mono',monospace;font-size:.42rem;
  text-transform:uppercase;letter-spacing:.5px;line-height:1;
}
.rp-nav-sep{width:28px;height:1px;background:var(--border);margin:.2rem 0;flex-shrink:0;}

/* Panel content area */
.rp-content{flex:1;overflow:hidden;display:flex;flex-direction:column;min-width:0;height:100%;}
.rp-body{flex:1;overflow-y:auto;padding:1rem .9rem;min-height:0;}
.rp-body::-webkit-scrollbar{width:3px;}
.rp-body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px;}
.rp-pane{display:none;} .rp-pane.on{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden;}
#rp-tools.on{display:flex;padding:0;}
#rp-tools .rp-body-inner{padding:.5rem .4rem;}

/* Label styling */
.gv-label {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  color: #fff;
  font-family: 'JetBrains Mono', monospace;
  font-weight: 800;
  font-size: .85rem;
  text-shadow: 0 0 4px #000, 0 0 4px #000;
}

/* Section titles */
.rp-section{margin-bottom:1.4rem;}
.rp-sec-title{
  font-family:'JetBrains Mono',monospace;font-size:.56rem;font-weight:700;
  text-transform:uppercase;letter-spacing:2px;color:var(--text3);
  margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem;
}
.rp-sec-title::after{content:'';flex:1;height:1px;background:var(--border);}

/* Panel header strip */
.rp-pane-hd{
  padding:.7rem 1rem .6rem;border-bottom:1px solid var(--border);
  font-size:.78rem;font-weight:700;color:var(--text);
  display:flex;align-items:center;gap:.5rem;flex-shrink:0;
}
.rp-pane-hd-ic{font-size:1rem;}
.sep{height:1px;background:var(--border);margin:.85rem 0;}

/* Attribute editor */
.attr-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;color:var(--text2);font-family:'JetBrains Mono',monospace;font-size:.72rem;text-align:center;gap:.6rem;border:1px dashed var(--border2);border-radius:10px;margin:.5rem 0;}
.attr-empty-ic{font-size:2rem;opacity:.2;}
.attr-fname{font-size:.88rem;font-weight:600;color:var(--amber);margin-bottom:.1rem;}
.attr-finfo{font-family:'JetBrains Mono',monospace;font-size:.62rem;color:var(--text2);margin-bottom:.85rem;}
.attr-row{display:grid;grid-template-columns:1fr 1.4fr 22px;gap:.4rem;align-items:center;margin-bottom:.5rem;padding:.3rem .4rem;border-radius:5px;transition:background .15s;}
.attr-row:hover{background:rgba(255,255,255,.02);}
.attr-key{font-family:'JetBrains Mono',monospace;font-size:.68rem;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.attr-val{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:5px;padding:.38rem .55rem;color:var(--text);font-family:'JetBrains Mono',monospace;font-size:.72rem;width:100%;transition:all .2s;}
.attr-val:focus{outline:none;border-color:var(--amber);}
.attr-del-k{width:20px;height:20px;background:none;border:none;color:var(--text3);font-size:.7rem;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:all .2s;}
.attr-del-k:hover{color:var(--red);background:var(--red-d);transform:none;box-shadow:none;} .attr-del-k::before{display:none;}
.attr-add-row{display:grid;grid-template-columns:1fr 1.4fr;gap:.35rem;margin-bottom:.6rem;}
.attr-new{background:rgba(255,255,255,.03);border:1px dashed var(--border2);border-radius:5px;padding:.3rem .5rem;color:var(--text);font-family:'JetBrains Mono',monospace;font-size:.7rem;width:100%;transition:all .2s;}
.attr-new::placeholder{color:var(--text3);} .attr-new:focus{outline:none;border-color:var(--amber);border-style:solid;}

/* Buttons */
.btn{width:100%;padding:.52rem;border:none;border-radius:7px;font-family:'JetBrains Mono',monospace;font-weight:700;font-size:.68rem;text-transform:uppercase;letter-spacing:1.5px;cursor:pointer;transition:all .3s;position:relative;overflow:hidden;}
.btn.primary{background:linear-gradient(135deg,var(--amber),#b01e1e);color:#000;box-shadow:0 3px 12px rgba(212,43,43,.2);}
.btn.primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(212,43,43,.3);}
.btn.primary::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,#b01e1e,var(--amber));opacity:0;transition:opacity .3s;}
.btn.primary:hover::after{opacity:1;}
.btn.secondary{background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text2);margin-top:.35rem;}
.btn.secondary:hover{background:rgba(255,255,255,.07);}
.btn.danger{background:var(--red-d);border:1px solid rgba(239,68,68,.25);color:var(--red);margin-top:.35rem;}
.btn.danger:hover{background:rgba(239,68,68,.2);}
.btn.success{background:var(--green-d);border:1px solid rgba(16,185,129,.25);color:var(--green);margin-top:.35rem;}
.btn.success:hover{background:rgba(16,185,129,.2);}
.btn.purple{background:var(--purple-d);border:1px solid rgba(139,92,246,.25);color:var(--purple);margin-top:.35rem;}
.btn.purple:hover{background:rgba(139,92,246,.2);}
.btn.cyan{background:var(--cyan-d);border:1px solid rgba(6,182,212,.25);color:var(--cyan);margin-top:.35rem;}
.btn.cyan:hover{background:rgba(6,182,212,.2);}
.btn::before{display:none;} .btn:hover{transform:translateY(-1px);}
.btn.secondary:hover,.btn.danger:hover,.btn.success:hover,.btn.purple:hover,.btn.cyan:hover{transform:none;}
.btn span{position:relative;z-index:1;}
.btn-sm{padding:.32rem .7rem;font-size:.62rem;width:auto;margin-top:0;}

/* ── ACCORDION TOOL CARDS ── */
.geo-tool-card{
  background:rgba(11,17,27,.95);
  border:1px solid var(--border);border-radius:10px;
  margin-bottom:.45rem;overflow:hidden;
  transition:border-color .2s;
}
.geo-tool-card:hover{border-color:rgba(255,255,255,.1);}
.geo-tool-card.open{border-color:rgba(255,255,255,.12);box-shadow:0 4px 20px rgba(0,0,0,.3);}

/* Accordion header — always visible, click to toggle */
.geo-tool-hd{
  display:flex;align-items:center;gap:.65rem;
  padding:.7rem .85rem;cursor:pointer;user-select:none;
  transition:background .15s;
}
.geo-tool-hd:hover{background:rgba(255,255,255,.03);}

.geo-tool-icon-wrap{
  width:30px;height:30px;border-radius:8px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;background:var(--gt-color-bg,rgba(212,43,43,.12));
  border:1px solid var(--gt-color-border,rgba(212,43,43,.2));
}
.geo-tool-name{flex:1;font-size:.82rem;font-weight:600;letter-spacing:-.01em;}
.geo-tool-chevron{
  color:var(--text3);font-size:.65rem;transition:transform .25s;
  flex-shrink:0;margin-left:auto;
}
.geo-tool-card.open .geo-tool-chevron{transform:rotate(90deg);}

/* Accordion body — slides open */
.geo-tool-body{
  display:none;padding:.1rem .85rem .85rem;
  border-top:1px solid var(--border);
  animation:slideDown .18s ease-out;
}
@keyframes slideDown{from{opacity:0;transform:translateY(-4px);}to{opacity:1;transform:translateY(0);}}
.geo-tool-card.open .geo-tool-body{display:block;}

.geo-tool-desc{
  font-family:'JetBrains Mono',monospace;font-size:.63rem;
  color:var(--text2);margin:.6rem 0 .75rem;line-height:1.6;
  padding:.5rem .6rem;background:rgba(255,255,255,.02);
  border-radius:6px;border-left:2px solid var(--gt-color-border,rgba(212,43,43,.3));
}
.gt-field{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.5rem;}
.gt-label{
  font-family:'JetBrains Mono',monospace;font-size:.57rem;
  text-transform:uppercase;letter-spacing:1.5px;color:var(--text3);
}
.gt-select{
  background:rgba(255,255,255,.04);border:1px solid var(--border2);
  border-radius:6px;padding:.42rem .6rem;color:var(--text);
  font-family:'JetBrains Mono',monospace;font-size:.73rem;
  width:100%;transition:border-color .2s;
}
.gt-select:focus{outline:none;border-color:var(--amber);}
.gt-input{
  background:rgba(255,255,255,.04);border:1px solid var(--border2);
  border-radius:6px;padding:.38rem .6rem;color:var(--text);
  font-family:'JetBrains Mono',monospace;font-size:.73rem;
  width:100%;transition:border-color .2s;
}
.gt-input:focus{outline:none;border-color:var(--amber);}

/* Color themes per tool */
.gt-sel  {--gt-color-bg:rgba(16,185,129,.1);--gt-color-border:rgba(16,185,129,.25);}
.gt-pt   {--gt-color-bg:rgba(59,130,246,.1);--gt-color-border:rgba(59,130,246,.25);}
.gt-dis  {--gt-color-bg:rgba(139,92,246,.1);--gt-color-border:rgba(139,92,246,.25);}
.gt-sj   {--gt-color-bg:rgba(6,182,212,.1);--gt-color-border:rgba(6,182,212,.25);}
.gt-draw {--gt-color-bg:rgba(236,72,153,.1);--gt-color-border:rgba(236,72,153,.25);}

/* Style */
.bm-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.45rem;}
.bm-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;}
.bm-card{background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:9px;padding:.75rem .5rem;text-align:center;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;}
.bm-card:hover{border-color:rgba(212,43,43,.3);background:rgba(255,255,255,.04);transform:translateY(-1px);}
.bm-card.on{border-color:var(--amber);background:var(--amber-d);}
.bm-card.on::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--amber);}
.bm-ic{font-size:1.4rem;margin-bottom:.3rem;}
.bm-nm{font-family:'JetBrains Mono',monospace;font-size:.58rem;text-transform:uppercase;letter-spacing:1px;color:var(--text2);}
.bm-card.on .bm-nm{color:var(--amber);}
.style-grid{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem;}
.swatch{width:28px;height:28px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:all .2s;position:relative;}
.swatch:hover{transform:scale(1.12);}
.swatch.on{border-color:#fff;transform:scale(1.15);box-shadow:0 0 10px currentColor;}

/* FOOTER */
footer{grid-column:1/-1;background:var(--panel);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 1rem;font-family:'JetBrains Mono',monospace;font-size:.63rem;min-width:0;overflow:hidden;}
.coords-bar{display:flex;gap:1.25rem;}
.ci span:first-child{color:var(--text3);margin-right:.3rem;} .ci span:last-child{color:var(--amber);font-weight:600;}
.footer-right{color:var(--text3);}

/* MODALS */
.overlay{position:fixed;inset:0;z-index:2000;background:rgba(4,8,12,.88);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;}
.overlay.on{opacity:1;pointer-events:all;}
.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:14px;box-shadow:0 30px 70px rgba(0,0,0,.6);transform:translateY(16px);transition:transform .3s;overflow:hidden;max-height:92vh;display:flex;flex-direction:column;}
.overlay.on .modal{transform:translateY(0);}
.modal-hd{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.4rem;border-bottom:1px solid var(--border);flex-shrink:0;}
.modal-title{font-size:.95rem;font-weight:700;}
.modal-close{width:26px;height:26px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:6px;color:var(--text2);font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;}
.modal-close:hover{background:var(--red-d);border-color:rgba(239,68,68,.3);color:var(--red);transform:none;box-shadow:none;} .modal-close::before{display:none;}
.modal-bd{padding:1.35rem;overflow-y:auto;flex:1;}
.mf{display:flex;flex-direction:column;gap:.85rem;}
.mfield{display:flex;flex-direction:column;gap:.35rem;}
.mfield label{font-family:'JetBrains Mono',monospace;font-size:.6rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text2);}
.mfield input,.mfield textarea,.mfield select{background:rgba(255,255,255,.04);border:1px solid var(--border2);border-radius:var(--r);padding:.58rem .82rem;color:var(--text);font-family:'JetBrains Mono',monospace;font-size:.8rem;transition:all .2s;width:100%;}
.mfield input:focus,.mfield textarea:focus{outline:none;border-color:var(--amber);}
.mfield textarea{resize:vertical;min-height:60px;}
.mrow{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;}
.mhint{padding:.55rem .8rem;background:var(--blue-d);border:1px solid rgba(59,130,246,.2);border-radius:6px;font-family:'JetBrains Mono',monospace;font-size:.65rem;color:var(--blue);margin-bottom:.75rem;}
.mwarn{padding:.55rem .8rem;background:var(--amber-d);border:1px solid rgba(212,43,43,.2);border-radius:6px;font-family:'JetBrains Mono',monospace;font-size:.65rem;color:var(--amber);margin-bottom:.75rem;}

/* Import */
.import-types{display:grid;grid-template-columns:repeat(4,1fr);gap:.45rem;margin-bottom:1.1rem;}
.itype{background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:8px;padding:.8rem .4rem;text-align:center;cursor:pointer;transition:all .25s;}
.itype:hover{border-color:rgba(212,43,43,.3);} .itype.on{border-color:var(--amber);background:var(--amber-d);}
.itype-ic{font-size:1.4rem;margin-bottom:.25rem;}
.itype-nm{font-family:'JetBrains Mono',monospace;font-size:.6rem;text-transform:uppercase;letter-spacing:1px;color:var(--text2);} .itype.on .itype-nm{color:var(--amber);}
.drop-zone{border:2px dashed var(--border2);border-radius:10px;padding:1.75rem;text-align:center;cursor:pointer;transition:all .3s;}
.drop-zone:hover,.drop-zone.drag{border-color:var(--amber);background:var(--amber-d2);}
.dz-ic{font-size:2.25rem;opacity:.45;margin-bottom:.4rem;} .dz-txt{font-size:.88rem;font-weight:500;} .dz-sub{font-size:.75rem;color:var(--text2);margin-top:.2rem;}
.excel-preview{background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:8px;overflow:auto;max-height:180px;margin-bottom:.85rem;}
.exp-table{width:100%;border-collapse:collapse;font-family:'JetBrains Mono',monospace;font-size:.66rem;}
.exp-table th{background:rgba(212,43,43,.08);color:var(--amber);padding:.38rem .55rem;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;}
.exp-table td{padding:.32rem .55rem;border-bottom:1px solid rgba(255,255,255,.03);color:var(--text2);white-space:nowrap;}
.col-map-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem;}
.cm-field{display:flex;flex-direction:column;gap:.28rem;}
.cm-field label{font-family:'JetBrains Mono',monospace;font-size:.6rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--text2);}
.cm-field select{background:rgba(255,255,255,.04);border:1px solid var(--border2);border-radius:6px;padding:.45rem .65rem;color:var(--text);font-family:'JetBrains Mono',monospace;font-size:.72rem;width:100%;}
.progress-bar{height:3px;background:var(--border);border-radius:2px;overflow:hidden;margin-top:.5rem;}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--amber),#b01e1e);border-radius:2px;transition:width .3s;}

/* Toast */
#toasts{position:fixed;bottom:48px;right:14px;z-index:9999;display:flex;flex-direction:column;gap:.35rem;}
.toast{padding:.6rem .95rem;border-radius:7px;font-family:'JetBrains Mono',monospace;font-size:.71rem;display:flex;align-items:center;gap:.45rem;backdrop-filter:blur(20px);animation:tin .3s ease-out;}
@keyframes tin{from{opacity:0;transform:translateX(14px);}to{opacity:1;transform:translateX(0);}}
.toast.ok{background:rgba(16,185,129,.15);border:1px solid rgba(16,185,129,.3);color:var(--green);}
.toast.err{background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.3);color:var(--red);}
.toast.inf{background:rgba(59,130,246,.15);border:1px solid rgba(59,130,246,.3);color:var(--blue);}
.toast.wrn{background:rgba(212,43,43,.15);border:1px solid rgba(212,43,43,.3);color:var(--amber);}

/* Loader */
#loader{position:fixed;inset:0;z-index:5000;background:rgba(4,8,12,.75);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;gap:.75rem;font-family:'JetBrains Mono',monospace;font-size:.8rem;color:var(--amber);}
#loader.off{display:none;}
.spin{width:15px;height:15px;border:2px solid rgba(212,43,43,.2);border-top-color:var(--amber);border-radius:50%;animation:sp .7s linear infinite;}
@keyframes sp{to{transform:rotate(360deg);}}

/* Result badge */
.result-badge{display:inline-block;padding:.25rem .6rem;border-radius:4px;font-family:'JetBrains Mono',monospace;font-size:.65rem;margin-top:.4rem;}
.rb-ok{background:var(--green-d);border:1px solid rgba(16,185,129,.25);color:var(--green);}
.rb-err{background:var(--red-d);border:1px solid rgba(239,68,68,.25);color:var(--red);}

select,option{background:var(--bg2);color:var(--text);}



/* Attribute editor scrollable */
#attrEditor { display: flex; flex-direction: column; min-height: 0; }
#attrRows { max-height: 40vh; overflow-y: auto; padding-right: .25rem; }
#attrRows::-webkit-scrollbar { width: 3px; }
#attrRows::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 2px; }

/* ── additions ── */

/* ════════════════════════════════════════════════════
   GEOVISOR PRO — ADDITIONS v10
   1. Light/Dark theme
   2. Collapsible panels
   3. Geospatial analysis tool card
   4. Freehand draw bar
   5. Filter save layer button
════════════════════════════════════════════════════ */

/* ── LIGHT THEME OVERRIDES ─────────────────────── */
body.light {
  --bg:     #f0f4f8;
  --bg2:    #e2e8f0;
  --bg3:    #cbd5e1;
  --panel:  rgba(255,255,255,0.97);
  --border: rgba(0,0,0,0.09);
  --border2:rgba(0,0,0,0.14);
  --text:   #0f172a;
  --text2:  #475569;
  --text3:  #94a3b8;
  --amber:  #b01e1e;
  --amber-d:rgba(217,119,6,0.1);
  --amber-d2:rgba(217,119,6,0.05);
  --blue:   #2563eb;
  --blue-d: rgba(37,99,235,0.1);
  --green:  #059669;
  --green-d:rgba(5,150,105,0.1);
  --red:    #dc2626;
  --red-d:  rgba(220,38,38,0.1);
  --purple: #7c3aed;
  --purple-d:rgba(124,58,237,0.1);
  --cyan:   #0891b2;
  --cyan-d: rgba(8,145,178,0.1);
}
body.light body::before { opacity: 0; }
body.light #map { background: #e8f0e8; }
body.light .layer-card { background: rgba(255,255,255,0.95); }
body.light .auth-card { background: rgba(255,255,255,0.9); box-shadow: 0 8px 40px rgba(0,0,0,0.12); }
body.light .proj-card { background: rgba(255,255,255,0.95); }
body.light .modal { background: #ffffff; }
body.light .overlay { background: rgba(0,0,0,0.4); }
body.light .geo-tool-card { background: rgba(248,250,252,0.9); }
body.light .geo-tool-hd { background: rgba(241,245,249,0.8); }
body.light .af-inp, body.light .af-sel, body.light .gt-select,
body.light .gt-input, body.light .attr-val, body.light .af-layer-sel {
  background: rgba(0,0,0,0.04);
}
body.light #drawModeBar { background: rgba(5,150,105,0.95); }
body.light #drawShapeBar { background: rgba(124,58,237,0.95); }
body.light #selModeBar { background: rgba(37,99,235,0.95); }
body.light #freehandBar { background: rgba(236,72,153,0.95); }

/* ── THEME TOGGLE BUTTON ──────────────────────── */
.theme-toggle {
  width: 32px; height: 32px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: rgba(255,255,255,.04);
  color: var(--text2);
  font-size: 1rem;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: all .2s;
  flex-shrink: 0;
}
.theme-toggle:hover { border-color: var(--amber); color: var(--amber); }
.theme-toggle::before { display: none; }

/* ── COLLAPSIBLE PANELS ──────────────────────── */
/* Panels — grid handles sizing, just hide overflow */
.lpanel { transition: opacity .25s; }
.rpanel { transition: opacity .25s; }
.lpanel.collapsed { overflow: hidden; opacity: 0; }
.rpanel.collapsed { overflow: hidden; opacity: 0; }

/* ── FLOATING MAP BUTTONS ──────────────────────── */
.map-float-btns {
  position: absolute;
  top: 10px; left: 10px;
  transform: none;
  z-index: 500;
  display: flex; flex-direction: row; gap: .4rem;
  pointer-events: none;
}
.map-float-btn {
  pointer-events: all;
  display: flex; align-items: center; gap: .35rem;
  padding: .38rem .85rem;
  background: var(--panel);
  border: 1.5px solid var(--border2);
  border-radius: 20px;
  color: var(--text);
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .8px;
  cursor: pointer;
  transition: all .18s;
  box-shadow: 0 3px 16px rgba(0,0,0,.5), 0 1px 4px rgba(0,0,0,.3);
  backdrop-filter: blur(12px);
}
.map-float-btn::before { display: none; }
.map-float-btn:hover {
  border-color: var(--amber);
  color: var(--amber);
  background: var(--amber-d);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(0,0,0,.45);
}
.map-float-btn.active {
  border-color: var(--amber);
  color: var(--amber);
  background: var(--amber-d);
}
.mfb-ic { font-size: .9rem; }
.mfb-lb { font-size: .58rem; }

/* ── FREEHAND DRAW BAR ───────────────────────── */
#freehandBar {
  position: absolute; bottom: 48px; left: 50%;
  transform: translateX(-50%);
  z-index: 902;
  background: rgba(236,72,153,.95);
  border: 1px solid rgba(236,72,153,.5);
  border-radius: 10px; padding: .5rem 1rem;
  font-family: 'JetBrains Mono', monospace;
  font-size: .72rem; color: #fff;
  display: none; align-items: center; gap: .7rem;
  backdrop-filter: blur(14px);
  box-shadow: 0 4px 20px rgba(236,72,153,.3);
  white-space: nowrap;
}
#freehandBar.on { display: flex; }
#freehandBar strong { color: #fce7f3; }
#freehandBar button {
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 5px; color: #fff;
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; padding: .22rem .6rem;
  cursor: pointer; transition: background .2s;
}
#freehandBar button:hover { background: rgba(255,255,255,.3); transform: none; box-shadow: none; }
#freehandBar button::before { display: none; }

/* ── ANALYSIS TOOL CARD COLOR ────────────────── */
.gt-analysis { --gt-color-bg: rgba(212,43,43,.1); --gt-color-border: rgba(212,43,43,.25); }

/* ── FILTER SAVE LAYER BUTTON ─────────────────── */
.af-save-layer-btn {
  width: 100%; padding: .4rem;
  background: linear-gradient(135deg, var(--green), #059669);
  border: none; border-radius: 7px; color: #fff;
  font-family: 'JetBrains Mono', monospace; font-weight: 700;
  font-size: .65rem; text-transform: uppercase; letter-spacing: 1px;
  cursor: pointer; transition: all .2s;
  display: flex; align-items: center; justify-content: center; gap: .4rem;
  margin-top: .4rem;
}
.af-save-layer-btn:hover { filter: brightness(1.1); }
.af-save-layer-btn::before { display: none; }
.af-save-layer-btn:disabled { opacity: .4; cursor: not-allowed; }

/* ── ANALYSIS RESULTS ────────────────────────── */
.analysis-stat-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: .4rem; margin-top: .5rem;
}
.analysis-stat {
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: 7px; padding: .5rem .6rem;
}
.analysis-stat-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: .55rem; text-transform: uppercase;
  letter-spacing: 1.5px; color: var(--text3);
  margin-bottom: .2rem;
}
.analysis-stat-val {
  font-family: 'JetBrains Mono', monospace;
  font-size: .82rem; font-weight: 700; color: var(--amber);
}

/* ── IMPROVED FILTER BUTTON ────────────────────── */
.filter-toggle-btn {
  background: var(--amber-d2) !important;
  border-color: rgba(212,43,43,.35) !important;
  color: var(--amber) !important;
  font-weight: 700;
}
.filter-toggle-btn:hover {
  background: var(--amber-d) !important;
  border-color: rgba(212,43,43,.6) !important;
}

/* ── ATTR EDITOR FLEX FIX ──────────────────────── */
#rp-attr .rp-body {
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding: .85rem .9rem;
}
#attrEditor {
  display: none;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}
#attrEditor.visible {
  display: flex;
}
#attrRows {
  flex: 1;
  overflow-y: auto;
  min-height: 0;
  padding-right: .3rem;
  margin-bottom: .5rem;
}
#attrRows::-webkit-scrollbar { width: 3px; }
#attrRows::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 2px; }

/* ══════════════════════════════════════════════
   FILTER MODULE — Floating panel
══════════════════════════════════════════════ */
.filter-module {
  position: fixed;
  top: 62px; right: 360px;
  width: 380px;
  max-height: calc(100vh - 80px);
  background: var(--panel);
  border: 1px solid var(--border2);
  border-radius: 14px;
  box-shadow: 0 8px 40px rgba(0,0,0,.55), 0 2px 8px rgba(0,0,0,.3);
  z-index: 1100;
  display: flex; flex-direction: column;
  overflow: hidden;
  backdrop-filter: blur(16px);
  transition: opacity .2s, transform .2s;
}
.filter-module.hidden { display: none !important; }

/* Header */
.fm-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: .7rem 1rem;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  background: rgba(212,43,43,.07);
}
.fm-title {
  display: flex; align-items: center; gap: .4rem;
  font-family: 'JetBrains Mono', monospace;
  font-size: .72rem; font-weight: 700; color: var(--amber);
  text-transform: uppercase; letter-spacing: .8px;
}
.fm-title-ic { font-size: 1rem; }
.fm-header-actions { display: flex; align-items: center; gap: .5rem; }
.fm-active-badge {
  display: none;
  font-family: 'JetBrains Mono', monospace;
  font-size: .55rem; font-weight: 700;
  background: var(--amber); color: #000;
  padding: 2px 8px; border-radius: 10px;
  text-transform: uppercase; letter-spacing: 1px;
}
.fm-active-badge.on { display: inline; }
.fm-close {
  width: 26px; height: 26px;
  background: rgba(255,255,255,.05);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text3); font-size: .75rem;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all .15s;
}
.fm-close:hover { color: var(--red); border-color: rgba(239,68,68,.4); background: var(--red-d); }
.fm-close::before { display: none; }

/* Body — scrollable */
.fm-body {
  flex: 1; overflow-y: auto; padding: .75rem 1rem;
  min-height: 0;
}
.fm-body::-webkit-scrollbar { width: 3px; }
.fm-body::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 2px; }
.fm-section { margin-bottom: .7rem; }
.fm-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: .6rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 1.2px;
  color: var(--text3); margin-bottom: .3rem; display: block;
}

/* Footer */
.fm-footer {
  flex-shrink: 0;
  padding: .65rem 1rem;
  border-top: 1px solid var(--border);
  background: rgba(0,0,0,.15);
}
.fm-result-row {
  margin-bottom: .45rem;
  font-family: 'JetBrains Mono', monospace;
  font-size: .65rem; color: var(--text2);
}
.fm-result-row.on {
  color: var(--amber);
  font-weight: 700;
}
.fm-actions { display: flex; gap: .4rem; }
.fm-btn-apply {
  flex: 2; padding: .45rem;
  background: linear-gradient(135deg, var(--amber), #b01e1e);
  border: none; border-radius: 7px; color: #000;
  font-family: 'JetBrains Mono', monospace; font-weight: 700;
  font-size: .65rem; text-transform: uppercase; letter-spacing: .8px;
  cursor: pointer; transition: filter .2s;
}
.fm-btn-apply:hover { filter: brightness(1.1); }
.fm-btn-apply::before { display: none; }
.fm-btn-clear {
  flex: 1; padding: .45rem;
  background: rgba(239,68,68,.1);
  border: 1px solid rgba(239,68,68,.25);
  border-radius: 7px; color: var(--red);
  font-family: 'JetBrains Mono', monospace; font-weight: 700;
  font-size: .65rem; text-transform: uppercase; letter-spacing: .8px;
  cursor: pointer; transition: all .2s;
}
.fm-btn-clear:hover { background: rgba(239,68,68,.2); }
.fm-btn-clear::before { display: none; }

/* ── HEADER FILTER BUTTON ─────────────────────── */
.hdr-filter-btn {
  display: flex; align-items: center; gap: .35rem;
  padding: .3rem .65rem;
  background: var(--amber-d2);
  border: 1px solid rgba(212,43,43,.3);
  border-radius: 7px;
  color: var(--amber);
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .6px;
  cursor: pointer; transition: all .18s;
  position: relative;
}
.hdr-filter-btn:hover { background: var(--amber-d); border-color: var(--amber); }
.hdr-filter-btn::before { display: none; }
.hdr-filter-btn.active { background: var(--amber-d); border-color: var(--amber); }
.hfb-lb { font-size: .58rem; }
.hfb-badge {
  background: var(--amber); color: #000;
  font-size: .5rem; font-weight: 900;
  padding: 1px 4px; border-radius: 8px;
  letter-spacing: .5px;
}
.hfb-badge.hidden { display: none !important; }

/* ── HEADER PANEL TOGGLE BUTTONS ────────────────── */
.hdr-panel-toggles {
  display: flex; gap: .3rem; align-items: center;
  padding: 0 .4rem;
  border-left: 1px solid var(--border);
  border-right: 1px solid var(--border);
  margin: 0 .2rem;
}
.hdr-ptoggle {
  display: flex; align-items: center; gap: .25rem;
  padding: .28rem .55rem;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: 6px; color: var(--text2);
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .5px;
  cursor: pointer; transition: all .15s;
}
.hdr-ptoggle:hover { border-color: var(--amber); color: var(--amber); background: var(--amber-d); }
.hdr-ptoggle.active { border-color: rgba(99,102,241,.4); color: #818cf8; background: rgba(99,102,241,.1); }
.hdr-ptoggle::before { display: none; }
.hpt-lb { font-size: .55rem; }

/* ── ATTR EDITOR CLASS-BASED SHOW/HIDE ──────────── */
.hidden { display: none !important; }
.attr-editor-panel {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}
.attr-editor-panel.hidden { display: none !important; }

/* ══════════════════════════════════════════
   ATTRIBUTE TABLE MODAL
══════════════════════════════════════════ */
#attrTableModal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 2000;
  background: rgba(0,0,0,.6);
  align-items: flex-start;
  justify-content: center;
  padding: 48px 24px 24px;
  backdrop-filter: blur(4px);
}
.atm-wrap {
  background: var(--bg2);
  border: 1px solid var(--border2);
  border-radius: 14px;
  box-shadow: 0 20px 60px rgba(0,0,0,.7);
  width: 100%;
  max-width: 1100px;
  max-height: calc(100vh - 72px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
/* Header */
.atm-head {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .75rem 1.1rem;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  background: rgba(212,43,43,.06);
}
.atm-head-ic { font-size: 1.1rem; }
.atm-title {
  flex: 1;
  font-family: 'JetBrains Mono', monospace;
  font-size: .72rem;
  font-weight: 700;
  color: var(--amber);
  text-transform: uppercase;
  letter-spacing: .6px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.atm-head-actions { display: flex; align-items: center; gap: .5rem; flex-shrink: 0; }
.atm-search {
  padding: .3rem .65rem;
  background: rgba(255,255,255,.05);
  border: 1px solid var(--border2);
  border-radius: 6px;
  color: var(--text);
  font-family: 'JetBrains Mono', monospace;
  font-size: .65rem;
  width: 200px;
  transition: border-color .15s;
}
.atm-search:focus { outline: none; border-color: var(--amber); }
.atm-btn {
  padding: .3rem .75rem;
  border-radius: 6px;
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  cursor: pointer;
  transition: all .15s;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  color: var(--text2);
}
.atm-btn::before { display: none; }
.atm-btn:hover { border-color: var(--amber); color: var(--amber); background: var(--amber-d); }
.atm-btn-csv { border-color: rgba(16,185,129,.3); color: var(--green); background: var(--green-d); }
.atm-btn-csv:hover { border-color: var(--green); filter: brightness(1.1); }
.atm-btn-close { border-color: rgba(239,68,68,.3); color: var(--red); background: var(--red-d); }
.atm-btn-close:hover { border-color: var(--red); }
/* Table */
.atm-table-wrap {
  flex: 1;
  overflow: auto;
  min-height: 0;
}
.atm-table-wrap::-webkit-scrollbar { width: 5px; height: 5px; }
.atm-table-wrap::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 3px; }
.atm-table {
  width: 100%;
  border-collapse: collapse;
  font-family: 'JetBrains Mono', monospace;
  font-size: .67rem;
}
.atm-table thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  padding: .45rem .65rem;
  text-align: left;
  background: var(--bg3);
  border-bottom: 2px solid var(--border2);
  color: var(--text3);
  font-size: .58rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .9px;
  white-space: nowrap;
  cursor: pointer;
  transition: color .15s;
  user-select: none;
}
.atm-table thead th:hover { color: var(--amber); }
.atm-table thead th.sorted { color: var(--amber); }
.atm-table tbody tr {
  border-bottom: 1px solid rgba(255,255,255,.04);
  transition: background .1s;
}
.atm-table tbody tr:hover { background: rgba(212,43,43,.06); }
.atm-table td {
  padding: .38rem .65rem;
  color: var(--text);
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: middle;
}
.atm-table td.num-cell { color: var(--cyan); }
.atm-table td.idx-cell { color: var(--text3); text-align: center; width: 40px; }
.atm-table td.act-cell { text-align: center; width: 52px; }
.atm-edit-btn {
  padding: .2rem .45rem;
  background: var(--amber-d);
  border: 1px solid rgba(212,43,43,.3);
  border-radius: 4px;
  color: var(--amber);
  font-size: .58rem;
  font-weight: 700;
  cursor: pointer;
  font-family: 'JetBrains Mono', monospace;
  transition: all .15s;
  white-space: nowrap;
}
.atm-edit-btn:hover { background: var(--amber-d2); border-color: var(--amber); }
.atm-edit-btn::before { display: none; }
/* Footer pag */
.atm-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .55rem 1.1rem;
  border-top: 1px solid var(--border);
  flex-shrink: 0;
  background: var(--bg2);
}
.atm-pag-info {
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem;
  color: var(--text3);
}
.atm-pag-btns { display: flex; gap: .35rem; }
.atm-pag-btn {
  padding: .28rem .65rem;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: 5px;
  color: var(--text2);
  font-family: 'JetBrains Mono', monospace;
  font-size: .6rem;
  cursor: pointer;
  transition: all .15s;
}
.atm-pag-btn:hover:not(:disabled) { border-color: var(--amber); color: var(--amber); }
.atm-pag-btn:disabled { opacity: .3; cursor: not-allowed; }
.atm-pag-btn::before { display: none; }

/* Layer card — tabla button */
.lca.tbl-btn {
  background: rgba(59,130,246,.08);
  border-color: rgba(59,130,246,.2);
  color: var(--blue);
}
.lca.tbl-btn:hover { background: rgba(59,130,246,.18); border-color: var(--blue); }

/* ══════════════════════════════════════════
   GEO-BALANCEO DE TERRITORIO
══════════════════════════════════════════ */
.gb-stats-card {
  margin-top: .5rem;
  font-family: 'JetBrains Mono', monospace;
}
/* KPI row */
.gb-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(80px, 1fr));
  gap: .4rem;
  margin-bottom: .6rem;
}
.gb-kpi {
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: .5rem .5rem .4rem;
  text-align: center;
}
.gb-kpi-val {
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--amber);
  line-height: 1.1;
}
.gb-kpi-label {
  font-size: .52rem;
  text-transform: uppercase;
  letter-spacing: .9px;
  color: var(--text3);
  margin-top: .2rem;
}
.gb-kpi-sub {
  font-size: .55rem;
  color: var(--text2);
  margin-top: .15rem;
}
/* Balance bar */
.gb-balance-bar-wrap {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: .6rem;
}
.gb-balance-bar-track {
  flex: 1;
  height: 7px;
  background: rgba(255,255,255,.07);
  border-radius: 4px;
  overflow: hidden;
}
.gb-balance-bar-fill {
  height: 100%;
  border-radius: 4px;
  transition: width .5s cubic-bezier(.4,0,.2,1);
}
.gb-balance-bar-label {
  font-size: .58rem;
  color: var(--text3);
  white-space: nowrap;
  font-weight: 600;
}
/* Per-territory table */
.gb-table-wrap {
  max-height: 200px;
  overflow-y: auto;
  border: 1px solid var(--border);
  border-radius: 7px;
  margin-bottom: .55rem;
}
.gb-table-wrap::-webkit-scrollbar { width: 3px; }
.gb-table-wrap::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 2px; }
.gb-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .63rem;
}
.gb-table thead th {
  position: sticky;
  top: 0;
  background: var(--bg3);
  padding: .3rem .45rem;
  text-align: left;
  font-size: .55rem;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: var(--text3);
  border-bottom: 1px solid var(--border2);
}
.gb-table tbody tr:hover { background: rgba(212,43,43,.05); }
.gb-table td {
  padding: .3rem .45rem;
  border-bottom: 1px solid rgba(255,255,255,.04);
  vertical-align: middle;
}
.gb-td-name {
  color: var(--text2);
  max-width: 90px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.gb-mini-bar {
  height: 5px;
  width: 60px;
  background: rgba(255,255,255,.07);
  border-radius: 3px;
  overflow: hidden;
}
/* Action buttons */
.gb-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .35rem;
}
.gb-btn-rebalance, .gb-btn-save, .gb-btn-clear {
  padding: .42rem .3rem;
  border-radius: 7px;
  font-family: 'JetBrains Mono', monospace;
  font-size: .58rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .6px;
  cursor: pointer;
  transition: all .18s;
  text-align: center;
}
.gb-btn-rebalance::before, .gb-btn-save::before, .gb-btn-clear::before { display: none; }
.gb-btn-rebalance {
  grid-column: 1 / -1;
  background: linear-gradient(135deg, #7c3aed, #5b21b6);
  border: none;
  color: #fff;
}
.gb-btn-rebalance:hover { filter: brightness(1.15); transform: translateY(-1px); }
.gb-btn-save {
  background: var(--green-d);
  border: 1px solid rgba(16,185,129,.3);
  color: var(--green);
}
.gb-btn-save:hover { border-color: var(--green); }
.gb-btn-clear {
  background: var(--red-d);
  border: 1px solid rgba(239,68,68,.25);
  color: var(--red);
}
.gb-btn-clear:hover { border-color: var(--red); }

/* Tool card accent */
.gt-geobalance {
  --gt-color-bg: rgba(139,92,246,.08);
  --gt-color-border: rgba(139,92,246,.2);
}

/* ── GEO-BALANCE: Mode pills ───────────────────────── */
.gb-mode-pills {
  display: flex; gap: .3rem; margin-top: .25rem;
}
.gb-mode-pill {
  flex: 1; padding: .32rem .4rem;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text2);
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .5px;
  cursor: pointer; transition: all .15s; text-align: center;
}
.gb-mode-pill::before { display: none; }
.gb-mode-pill.active {
  background: rgba(139,92,246,.15);
  border-color: rgba(139,92,246,.4);
  color: #a78bfa;
}

/* ── GEO-BALANCE: Attr tabs ────────────────────────── */
.gb-attr-tabs {
  display: flex; flex-wrap: wrap; gap: .25rem;
  margin-bottom: .5rem;
  padding-bottom: .45rem;
  border-bottom: 1px solid var(--border);
}
.gb-attr-tab {
  padding: .25rem .55rem;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border);
  border-radius: 5px;
  color: var(--text3);
  font-family: 'JetBrains Mono', monospace;
  font-size: .58rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .5px;
  cursor: pointer; transition: all .15s;
}
.gb-attr-tab::before { display: none; }
.gb-attr-tab.active {
  background: var(--amber-d);
  border-color: rgba(212,43,43,.4);
  color: var(--amber);
}
.gb-attr-tab:hover:not(.active) { border-color: var(--border2); color: var(--text2); }

/* ── GEO-BALANCE: Group tags ───────────────────────── */
.gb-group-tags {
  display: flex; flex-wrap: wrap; gap: .25rem;
  margin-top: .3rem;
}
.gb-tag {
  padding: .18rem .5rem;
  background: rgba(139,92,246,.12);
  border: 1px solid rgba(139,92,246,.25);
  border-radius: 10px;
  color: #a78bfa;
  font-family: 'JetBrains Mono', monospace;
  font-size: .6rem; font-weight: 600;
}

/* ── GEO-BALANCE: Group header in tab ──────────────── */
.gb-group-header {
  display: flex; align-items: center; gap: .5rem;
  padding: .4rem .5rem;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 7px;
  margin-bottom: .45rem;
}
.gb-group-badge {
  padding: .2rem .6rem;
  background: rgba(212,43,43,.15);
  border: 1px solid rgba(212,43,43,.3);
  border-radius: 5px;
  color: var(--amber);
  font-family: 'JetBrains Mono', monospace;
  font-size: .65rem; font-weight: 800;
}

/* Layer card selection button */
.lca.sel-btn {
  background: rgba(59,130,246,.08);
  border-color: rgba(59,130,246,.2);
  color: var(--blue);
}
.lca.sel-btn:hover,
.lca.sel-btn.on {
  background: rgba(59,130,246,.22);
  border-color: var(--blue);
  color: #60a5fa;
}

/* ══════════════════════════════════════════
   LAYER CARD — compact icon bar
══════════════════════════════════════════ */
.lc-iconbar {
  display: flex;
  align-items: center;
  gap: .15rem;
  padding: .25rem .55rem .3rem;
  border-top: 1px solid rgba(255,255,255,.05);
  background: rgba(0,0,0,.15);
}
.lcib {
  width: 26px; height: 24px;
  display: flex; align-items: center; justify-content: center;
  background: none;
  border: 1px solid transparent;
  border-radius: 5px;
  color: var(--text3);
  font-size: .75rem;
  cursor: pointer;
  transition: all .15s;
  flex-shrink: 0;
  padding: 0;
}
.lcib::before { display: none; }
.lcib:hover { background: rgba(255,255,255,.08); color: var(--text); border-color: var(--border); }
.lcib.lcib-on { color: var(--amber); border-color: rgba(212,43,43,.3); background: var(--amber-d); }

/* Colored variants */
.lcib.lcib-tbl { font-size: .8rem; }
.lcib.lcib-tbl:hover { color: var(--blue); border-color: rgba(59,130,246,.3); background: rgba(59,130,246,.1); }
.lcib.lcib-sel:hover { color: var(--cyan); border-color: rgba(6,182,212,.3); background: rgba(6,182,212,.1); }
.lcib.lcib-del:hover { color: var(--red); border-color: rgba(239,68,68,.25); background: var(--red-d); }

.lcib-sep {
  width: 1px; height: 14px;
  background: var(--border);
  margin: 0 .1rem;
  flex-shrink: 0;
}

/* ══════════════════════════════════════════
   ATTRIBUTE EDITOR — right panel inline
══════════════════════════════════════════ */
.attr-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 180px;
  color: var(--text2);
  font-family: 'JetBrains Mono', monospace;
  font-size: .72rem;
  text-align: center;
  gap: .5rem;
}
.aes-icon { font-size: 2rem; }

.attr-editor-wrap {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}
.ae-header {
  display: flex;
  align-items: flex-start;
  gap: .5rem;
  padding: .65rem .9rem .5rem;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  background: rgba(212,43,43,.05);
}
.ae-header-info { flex: 1; min-width: 0; }
.ae-feat-name {
  font-size: .82rem;
  font-weight: 700;
  color: var(--amber);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ae-feat-info {
  font-family: 'JetBrains Mono', monospace;
  font-size: .6rem;
  color: var(--text3);
  margin-top: .1rem;
}
.ae-close-btn {
  background: none;
  border: none;
  color: var(--text3);
  font-size: .8rem;
  cursor: pointer;
  padding: .1rem .3rem;
  border-radius: 4px;
  flex-shrink: 0;
  transition: color .15s;
}
.ae-close-btn:hover { color: var(--red); }
.ae-close-btn::before { display: none; }

/* Scrollable table area */
.ae-table-scroll {
  flex: 1;
  overflow-y: auto;
  min-height: 0;
}
.ae-table-scroll::-webkit-scrollbar { width: 10px; }
.ae-table-scroll::-webkit-scrollbar-track {
  background: rgba(255,255,255,.06);
  border-radius: 5px;
  margin: 4px 0;
}
.ae-table-scroll::-webkit-scrollbar-thumb {
  background: rgba(212,43,43,.6);
  border-radius: 5px;
  border: 2px solid transparent;
  background-clip: padding-box;
  min-height: 40px;
}
.ae-table-scroll::-webkit-scrollbar-thumb:hover {
  background: rgba(212,43,43,.9);
  background-clip: padding-box;
}
.ae-table {
  width: 100%;
  border-collapse: collapse;
  font-family: 'JetBrains Mono', monospace;
  font-size: .67rem;
}
.ae-th {
  position: sticky;
  top: 0;
  z-index: 1;
  padding: .3rem .55rem;
  text-align: left;
  background: var(--bg2);
  border-bottom: 2px solid var(--border2);
  color: var(--text3);
  font-size: .56rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .9px;
}
.ae-table tbody tr {
  border-bottom: 1px solid rgba(255,255,255,.04);
  transition: background .1s;
}
.ae-table tbody tr:hover { background: rgba(212,43,43,.04); }
.ae-table td {
  padding: .28rem .55rem;
  vertical-align: middle;
}
.ae-key-cell {
  color: var(--text2);
  font-size: .64rem;
  max-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.attr-val-input {
  width: 100%;
  background: rgba(255,255,255,.04);
  border: 1px solid transparent;
  border-radius: 4px;
  padding: .25rem .4rem;
  color: var(--text);
  font-family: 'JetBrains Mono', monospace;
  font-size: .64rem;
  transition: all .15s;
}
.attr-val-input:focus {
  outline: none;
  border-color: var(--amber);
  background: rgba(212,43,43,.07);
}
.ae-del-row-btn {
  background: none;
  border: none;
  color: var(--text3);
  font-size: .6rem;
  cursor: pointer;
  width: 18px;
  height: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 3px;
  transition: color .15s;
}
.ae-del-row-btn:hover { color: var(--red); }
.ae-del-row-btn::before { display: none; }

/* Footer */
.ae-footer {
  flex-shrink: 0;
  padding: .5rem .75rem;
  border-top: 1px solid var(--border);
  background: rgba(0,0,0,.15);
}
.ae-add-row {
  display: flex;
  gap: .3rem;
  margin-bottom: .35rem;
}
.ae-input {
  flex: 1;
  min-width: 0;
  background: rgba(255,255,255,.05);
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: .3rem .45rem;
  color: var(--text);
  font-family: 'JetBrains Mono', monospace;
  font-size: .63rem;
  transition: border-color .15s;
}
.ae-input:focus { outline: none; border-color: var(--amber); }
.ae-add-btn {
  padding: .3rem .55rem;
  background: var(--amber-d);
  border: 1px solid rgba(212,43,43,.3);
  border-radius: 5px;
  color: var(--amber);
  font-size: .8rem;
  cursor: pointer;
  flex-shrink: 0;
}
.ae-add-btn::before { display: none; }
.ae-action-row {
  display: flex;
  gap: .3rem;
}
.ae-save-btn {
  flex: 1;
  padding: .4rem;
  background: linear-gradient(135deg, var(--amber), #b01e1e);
  border: none;
  border-radius: 7px;
  color: #000;
  font-family: 'JetBrains Mono', monospace;
  font-weight: 800;
  font-size: .6rem;
  text-transform: uppercase;
  letter-spacing: .8px;
  cursor: pointer;
}
.ae-save-btn::before { display: none; }
.ae-del-btn {
  padding: .4rem .65rem;
  background: var(--red-d);
  border: 1px solid rgba(239,68,68,.25);
  border-radius: 7px;
  color: var(--red);
  font-size: .75rem;
  cursor: pointer;
}
.ae-del-btn::before { display: none; }

/* ══════════════════════════════════════════
   GEOCODE MODAL
══════════════════════════════════════════ */
.gc-step-title {
  font-family: 'JetBrains Mono', monospace;
  font-size: .65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--amber);
  margin-bottom: .75rem;
  padding-bottom: .4rem;
  border-bottom: 1px solid var(--border);
}
.gc-field-row {
  margin-bottom: .45rem;
}
.gc-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: .58rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .9px;
  color: var(--text3);
  display: block;
  margin-bottom: .25rem;
}

/* Layer name rename cursor */
.lc-name[contenteditable="true"] {
  cursor: text;
  background: rgba(212,43,43,.1);
}

/* ══════════════════════════════════════════
   EXCEL SHEET PICKER
══════════════════════════════════════════ */
.sheet-picker-label {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: var(--text2);
  margin-bottom: .3rem;
}
.sheet-picker-sel {
  width: 100%;
  background: var(--bg2);
  border: 1px solid var(--amber);
  border-radius: 7px;
  color: var(--amber);
  font-family: 'JetBrains Mono', monospace;
  font-size: .7rem;
  font-weight: 700;
  padding: .35rem .55rem;
  cursor: pointer;
  outline: none;
  box-shadow: 0 0 0 2px rgba(212,43,43,.15);
  transition: border-color .15s, box-shadow .15s;
}
.sheet-picker-sel:focus {
  border-color: var(--amber);
  box-shadow: 0 0 0 3px rgba(212,43,43,.25);
}
.sheet-picker-sel option {
  background: var(--bg2);
  color: var(--text);
  font-weight: 400;
  padding: .3rem;
}

/* ── Admin panel ─────────────────────────────────── */
.ps-admin-btn {
  padding: .3rem .75rem;
  background: rgba(16,185,129,.12);
  border: 1px solid rgba(16,185,129,.25);
  border-radius: 7px;
  color: var(--green);
  font-family: 'JetBrains Mono', monospace;
  font-size: .65rem;
  font-weight: 700;
  cursor: pointer;
  transition: all .18s;
  letter-spacing: .5px;
}
.ps-admin-btn:hover { background: rgba(16,185,129,.22); border-color: rgba(16,185,129,.5); }
.ps-admin-btn::before { display: none; }

.admin-user-row {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .55rem .75rem;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border);
  border-radius: 9px;
  transition: border-color .15s;
}
.admin-user-row:hover { border-color: var(--border2); }
.admin-user-avatar {
  width: 30px; height: 30px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--amber), #b01e1e);
  display: flex; align-items: center; justify-content: center;
  font-size: .75rem; font-weight: 700; color: #000; flex-shrink: 0;
}
.admin-user-avatar.admin-role { background: linear-gradient(135deg, var(--green), #059669); }
.admin-user-info { flex: 1; min-width: 0; }
.admin-user-name { font-size: .8rem; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.admin-user-email { font-family: 'JetBrains Mono', monospace; font-size: .6rem; color: var(--text3); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.admin-user-role { font-family: 'JetBrains Mono', monospace; font-size: .55rem; font-weight: 700; padding: .1rem .4rem; border-radius: 4px; flex-shrink: 0; }
.admin-user-role.role-admin { background: rgba(16,185,129,.12); color: var(--green); border: 1px solid rgba(16,185,129,.25); }
.admin-user-role.role-user  { background: rgba(212,43,43,.1); color: var(--amber); border: 1px solid rgba(212,43,43,.2); }
.admin-user-del {
  width: 26px; height: 26px;
  background: var(--red-d); border: 1px solid rgba(239,68,68,.2); border-radius: 6px;
  color: var(--red); font-size: .75rem; cursor: pointer; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; transition: all .15s;
}
.admin-user-del:hover { background: rgba(239,68,68,.25); }
.admin-user-del::before { display: none; }

/* ── Proj card rename btn ─────────────────────────── */
.proj-card-rename {
  width: 24px; height: 24px;
  background: rgba(59,130,246,.12);
  border: 1px solid rgba(59,130,246,.2);
  border-radius: 5px; color: var(--blue); font-size: .75rem;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all .15s;
}
.proj-card-rename:hover { background: rgba(59,130,246,.25); }
.proj-card-rename::before { display: none; }

/* ── Password display in admin ─────────────── */
.admin-user-pass {
  font-family: 'JetBrains Mono', monospace;
  font-size: .62rem; color: var(--text3); margin-top: .15rem;
  display: flex; align-items: center; gap: .3rem;
}
.pass-text { color: var(--text2); letter-spacing: .5px; }
.pass-toggle-btn {
  background: none; border: none; cursor: pointer;
  font-size: .7rem; padding: 0 .15rem; line-height: 1;
  color: var(--text3); transition: color .15s;
}
.pass-toggle-btn:hover { color: var(--amber); }
.pass-toggle-btn::before { display: none; }
.admin-user-del {
  font-family: 'JetBrains Mono', monospace;
  font-size: .6rem; font-weight: 700; padding: .2rem .5rem;
  background: var(--red-d); border: 1px solid rgba(239,68,68,.2);
  border-radius: 6px; color: var(--red); cursor: pointer; transition: all .15s;
}
.admin-user-del:hover { background: rgba(239,68,68,.25); }
.admin-user-del::before { display: none; }

.admin-user-toggle {
  font-family: 'JetBrains Mono', monospace;
  font-size: .58rem; font-weight: 700;
  padding: .18rem .45rem;
  background: rgba(59,130,246,.1);
  border: 1px solid rgba(59,130,246,.2);
  border-radius: 5px; color: var(--blue);
  cursor: pointer; transition: all .15s;
}
.admin-user-toggle:hover { background: rgba(59,130,246,.22); }
.admin-user-toggle::before { display: none; }

/* ── Recovery form ───────────────────────────── */
#recoveryForm { display: none; }
#recoveryForm.on { display: block; }

/* ── Layer card drag & drop ─────────────────────────── */
.layer-card { cursor: default; transition: all .18s; }
.layer-card[draggable="true"] { cursor: grab; }
.layer-card.lc-dragging { opacity: .4; transform: scale(.97); }
.layer-card.lc-dragover {
  border-color: var(--amber) !important;
  background: rgba(212,43,43,.08) !important;
  transform: translateY(-2px);
}
.lc-drag-handle {
  font-size: .9rem; color: var(--text3); cursor: grab;
  padding: 0 .2rem; flex-shrink: 0; line-height: 1;
  transition: color .15s;
}
.lc-drag-handle:hover { color: var(--amber); }

/* ── Layer icon bar improvements ────────────────────── */
.lcib { transition: all .15s; border-radius: 5px; }
.lcib svg { display: block; pointer-events: none; }

.lcib-visible { color: var(--green) !important; }
.lcib-hidden  { color: var(--text3) !important; opacity: .5; }
.lcib-visible:hover { background: rgba(16,185,129,.15) !important; opacity: 1; }
.lcib-hidden:hover  { background: rgba(255,255,255,.08) !important; opacity: .8; }

.lcib-order { color: var(--text2); }
.lcib-order:hover { background: rgba(212,43,43,.12) !important; color: var(--amber) !important; }
.lcib-disabled { opacity: .2 !important; pointer-events: none; }

.lcib-zoom:hover { background: rgba(6,182,212,.12) !important; color: var(--cyan) !important; }
.lcib-tbl:hover  { background: rgba(139,92,246,.12) !important; color: #a78bfa !important; }
.lcib-del:hover  { background: rgba(239,68,68,.15) !important; color: var(--red) !important; }

/* ── Auth brand icon ────────────────────────────────── */
.auth-brand-icon img { width: 56px; height: 56px; object-fit: contain; }

/* ── Header logo ────────────────────────────────────── */
.hdr-logo img { width: 22px; height: 22px; object-fit: contain; }
.ps-logo-ic img { width: 22px; height: 22px; object-fit: contain; }

/* ── Light theme — main app adjustments ─────────────── */

body.light header { background: rgba(255,255,255,.96); border-bottom: 1px solid rgba(0,0,0,.1); }
body.light aside  { background: rgba(255,255,255,.97); border-right: 1px solid rgba(0,0,0,.08); }
body.light .layer-card { background: #f8f9fb; border-color: rgba(0,0,0,.08); }
body.light .layer-card.selected { background: rgba(196,32,32,.06); border-color: rgba(196,32,32,.25); }
body.light .modal { background: #fff; border-color: rgba(0,0,0,.1); }
body.light .overlay { background: rgba(0,0,0,.4); }
body.light .hdr-logo,
body.light .ps-logo-ic { background: #f0f2f5; box-shadow: 0 1px 3px rgba(0,0,0,.1); }
body.light .af input { background: #f8f9fb; border-color: #e5e7eb; color: #111827; }
body.light .auth-card { background: #fff; border-color: rgba(0,0,0,.08); }

/* icon-swatch replaced by .icon-sw */

/* ── Compact icon picker swatches ───────────────────── */
.icon-sw {
  display:flex;align-items:center;justify-content:center;
  height:28px;border-radius:5px;font-size:.85rem;
  background:rgba(255,255,255,.04);border:1.5px solid var(--border2);
  cursor:pointer;transition:all .12s;
}
.icon-sw:hover { background:rgba(212,43,43,.1); border-color:var(--amber); }
.icon-sw.on { background:rgba(212,43,43,.15); border-color:var(--amber); box-shadow:0 0 0 2px rgba(212,43,43,.2); }
body.light .icon-sw { background:#f8f9fb; border-color:#e5e7eb; }
body.light .icon-sw:hover { background:rgba(196,32,32,.08); border-color:#C42020; }
body.light .icon-sw.on { background:rgba(196,32,32,.1); border-color:#C42020; }

/* ══════════════════════════════════════════════════════════════
   MICROZONA PANEL — estilos mejorados
   ══════════════════════════════════════════════════════════════ */
/* Cards */
.mz-card {
  background: rgba(255,255,255,.03);
  border: 1px solid var(--border2);
  border-radius: 10px;
  padding: .65rem .75rem;
  margin-bottom: .55rem;
}
body.light .mz-card { background:#f8f9fb; border-color:#e5e7eb; }

.mz-card-hd {
  display:flex; align-items:center; gap:.45rem;
  font-family:'JetBrains Mono',monospace; font-size:.68rem;
  font-weight:700; color:var(--text2); text-transform:uppercase;
  letter-spacing:.04em; margin-bottom:.55rem;
}
.mz-step {
  display:inline-flex; align-items:center; justify-content:center;
  width:16px; height:16px; border-radius:50%;
  background:var(--amber); color:#000; font-size:.6rem; font-weight:900; flex-shrink:0;
}
.mz-field { margin-bottom:.45rem; }
.mz-lbl {
  display:block; font-family:'JetBrains Mono',monospace; font-size:.62rem;
  color:var(--text2); margin-bottom:.25rem; font-weight:600;
}

/* Mode buttons */
.mz-mode-btn {
  flex:1; padding:.3rem .5rem;
  font-family:'JetBrains Mono',monospace; font-size:.62rem; font-weight:600;
  background:rgba(255,255,255,.05); border:1.5px solid var(--border2);
  border-radius:6px; color:var(--text2); cursor:pointer; transition:all .15s;
}
.mz-mode-btn:hover { border-color:var(--amber); color:var(--text); }
.mz-mode-btn.on { background:rgba(245,158,11,.15); border-color:var(--amber); color:var(--amber); }
body.light .mz-mode-btn { background:#fff; border-color:#d1d5db; }
body.light .mz-mode-btn.on { background:rgba(212,43,43,.1); border-color:#C42020; color:#C42020; }

/* Palette grid */
.mz-pal-grid {
  display: grid; grid-template-columns: repeat(4,1fr); gap:.3rem; margin-top:.3rem;
}
.mz-pal {
  height: 22px; border-radius: 5px; cursor: pointer;
  border: 2px solid transparent; transition: all .15s;
}
.mz-pal:hover { transform:scaleY(1.2); border-color:rgba(255,255,255,.5); }
.mz-pal.on { border-color:var(--amber); box-shadow:0 0 0 2px rgba(245,158,11,.3); }

/* Toggle switch */
.mz-toggle { position:relative; display:inline-block; width:34px; height:18px; flex-shrink:0; }
.mz-toggle input { opacity:0; width:0; height:0; }
.mz-toggle span {
  position:absolute; inset:0; cursor:pointer;
  background:rgba(255,255,255,.1); border-radius:18px; transition:.2s;
  border:1px solid var(--border2);
}
.mz-toggle span::before {
  content:''; position:absolute; height:12px; width:12px;
  left:2px; bottom:2px; border-radius:50%;
  background:var(--text2); transition:.2s;
}
.mz-toggle input:checked+span { background:var(--amber); border-color:var(--amber); }
.mz-toggle input:checked+span::before { transform:translateX(16px); background:#000; }
body.light .mz-toggle span { background:#e5e7eb; border-color:#d1d5db; }
body.light .mz-toggle span::before { background:#6b7280; }

/* Tooltip */
.mz-tooltip.leaflet-tooltip {
  background:var(--bg2,#1e293b) !important;
  border:1px solid var(--border2,#334155) !important;
  color:var(--text,#e2e8f0) !important;
  border-radius:10px !important;
  padding:.55rem .7rem !important;
  box-shadow:0 8px 30px rgba(0,0,0,.5) !important;
  pointer-events:none;
}
.mz-tooltip.leaflet-tooltip::before { display:none !important; }
.mz-tt { font-family:'JetBrains Mono',monospace; min-width:175px; }
.mz-tt-hd { font-size:.82rem; font-weight:800; color:#f59e0b; margin-bottom:.3rem; line-height:1.2; }
.mz-tt-id { font-size:.62rem; color:#64748b; margin-bottom:.3rem; }
.mz-tt-row { display:flex; justify-content:space-between; align-items:center;
  font-size:.65rem; padding:.1rem 0; border-bottom:1px solid rgba(255,255,255,.05); }
.mz-tt-row span { color:#94a3b8; }
.mz-tt-row b { color:#e2e8f0; margin-left:.5rem; }
.mz-tt-vals { margin-top:.35rem; font-size:.58rem; color:#64748b;
  background:rgba(255,255,255,.05); border-radius:4px; padding:.25rem .35rem; }

/* Popup */
.mz-popup { font-family:'JetBrains Mono',monospace; min-width:200px; max-width:250px; }
.mz-popup-hd { font-size:.88rem; font-weight:800; color:#f59e0b; margin-bottom:.2rem; }
.mz-popup-id { font-size:.62rem; color:#94a3b8; margin-bottom:.5rem; }
.mz-popup-tbl { width:100%; border-collapse:collapse; font-size:.68rem; margin-bottom:.4rem; }
.mz-popup-tbl td { padding:.22rem .15rem; border-bottom:1px solid rgba(0,0,0,.06); }
.mz-popup-tbl td:first-child { color:#64748b; padding-right:.5rem; white-space:nowrap; }
.mz-popup-vals { font-size:.6rem; color:#94a3b8; background:rgba(0,0,0,.05);
  border-radius:4px; padding:.3rem; margin-top:.2rem; line-height:1.5; }

/* ── Microzona action buttons ─────────────────────── */
.mz-action-btn {
  display:flex;align-items:center;justify-content:center;gap:.35rem;
  padding:.42rem .5rem;border-radius:8px;cursor:pointer;
  font-family:'JetBrains Mono',monospace;font-size:.66rem;font-weight:600;
  background:rgba(255,255,255,.06);border:1.5px solid var(--border2);
  color:var(--text2);transition:all .15s;white-space:nowrap;
}
.mz-action-btn:hover { background:rgba(245,158,11,.12);border-color:var(--amber);color:var(--amber); }
body.light .mz-action-btn { background:#f8f9fb;border-color:#d1d5db;color:#374151; }
body.light .mz-action-btn:hover { background:rgba(212,43,43,.08);border-color:#C42020;color:#C42020; }

.mz-clear-btn {
  display:flex;align-items:center;justify-content:center;
  width:34px;padding:.42rem;border-radius:8px;cursor:pointer;
  background:rgba(239,68,68,.1);border:1.5px solid rgba(239,68,68,.25);
  color:#f87171;transition:all .15s;flex-shrink:0;
}
.mz-clear-btn:hover { background:rgba(239,68,68,.2);border-color:#ef4444;color:#fff; }

/* ── Map legend close button ──────────────────────── */
.mz-legend-close {
  display:flex;align-items:center;justify-content:center;
  width:24px;height:24px;border-radius:6px;cursor:pointer;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  color:#64748b;transition:all .15s;flex-shrink:0;
}
.mz-legend-close:hover { background:rgba(239,68,68,.15);border-color:#ef4444;color:#f87171; }

/* ── Categorize palette scroll ─────────────────────── */
#catPalette::-webkit-scrollbar { width:3px; }
#catPalette::-webkit-scrollbar-thumb { background:var(--border2);border-radius:2px; }

/* Layer order - ensure up/down buttons work */
.lcib-disabled { opacity:.25!important;pointer-events:none!important; }

/* ── Project save button ───────────────────────────── */
.lp-save-btn {
  display:flex;align-items:center;gap:.4rem;
  padding:.35rem .65rem;border-radius:7px;cursor:pointer;
  font-family:'JetBrains Mono',monospace;font-size:.66rem;font-weight:600;
  background:rgba(245,158,11,.1);border:1.5px solid rgba(245,158,11,.25);
  color:var(--amber);transition:all .18s;white-space:nowrap;
}
.lp-save-btn:hover { background:rgba(245,158,11,.2);border-color:var(--amber); }
.lp-save-btn.saving { opacity:.6;pointer-events:none; }
.lp-save-btn.saved { background:rgba(16,185,129,.1);border-color:rgba(16,185,129,.4);color:#10b981; }

.lp-dirty-badge {
  font-family:'JetBrains Mono',monospace;font-size:.58rem;
  color:#f97316;animation:blink-dot 1.8s ease-in-out infinite;
  margin-left:auto;
}
@keyframes blink-dot { 0%,100%{opacity:1} 50%{opacity:.35} }
body.light .lp-save-btn { background:rgba(212,43,43,.06);border-color:rgba(212,43,43,.2);color:#C42020; }
body.light .lp-save-btn:hover { background:rgba(212,43,43,.12); }
body.light .lp-dirty-badge { color:#ea580c; }

/* GLOBAL SCROLLBAR OVERRIDE */
*::-webkit-scrollbar { width: 12px !important; height: 12px !important; }
*::-webkit-scrollbar-track { background: rgba(0,0,0,0.15) !important; border-radius: 4px !important; }
*::-webkit-scrollbar-thumb { background: rgba(220, 38, 38, 0.45) !important; border-radius: 6px !important; border: 2px solid transparent !important; background-clip: content-box !important; }
*::-webkit-scrollbar-thumb:hover { background-color: rgba(220, 38, 38, 0.8) !important; }

/* --- OPTIMIZACIONES V17 (RENDIMIENTO) --- */
.sidebar-panel { background: rgba(11, 14, 20, 0.85); backdrop-filter: blur(16px); border: 1px solid rgba(255,255,255,0.12); border-radius: 12px; }
.abtn:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(245,158,11,0.4); filter: brightness(1.1); }
.geo-tool-card.gt-territory { border-color: rgba(245, 158, 11, 0.3) !important; }
