/* ═══════════════════════════════════════════════════════════════════════════
   Studio Control — App CSS  (Lumin v2)
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Highbase Tracking Dot ── */
.hb-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0;vertical-align:middle;}
.hb-dot-on  {background:#22c55e;box-shadow:0 0 4px #22c55e;animation:hb-blink 1.2s ease-in-out infinite;}
.hb-dot-idle{background:#f97316;box-shadow:0 0 4px #f97316;animation:hb-blink 3s ease-in-out infinite;}
.hb-dot-off {background:#ef4444;opacity:.7;}
@keyframes hb-blink{0%,100%{opacity:1;}50%{opacity:.15;}}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px;}

:root{
  /*
   ESCALA DA UI — altere --zoom abaixo para escalar toda a interface:
   1.00 → ~14px (padrão)  |  1.07 → ~15px  |  1.14 → ~16px ← recomendado
   1.21 → ~17px            |  1.29 → ~18px  |  1.36 → ~19px  |  1.43 → ~20px
   Dica: o Console (/console) também controla via slider "Escala da UI".
  */
  --zoom:1.14;
  --accent:#D7FE03;
  --accent2:#83AF3B;
  --lime:#D7FE03;
  --lime-lt:rgba(215,254,3,.1);
  --accent-soft:rgba(215,254,3,.1);
  --accent-mid:#B8D900;
  --lime-mid:#B8D900;
  --grad-start:#D7FE03;
  --grad-end:#83AF3B;
  --gradient:linear-gradient(135deg,#D7FE03,#83AF3B);
  --green:#2EB679;
  --green-lt:rgba(46,182,121,.1);
  --green-soft:rgba(46,182,121,.1);
  --amber:#F59E0B;
  --amber-lt:rgba(245,158,11,.1);
  --amber-soft:rgba(245,158,11,.1);
  --red:#EF4444;
  --red-lt:rgba(239,68,68,.1);
  --yellow:#FFCE76;
  --yellow-lt:rgba(255,206,118,.1);
  --black:#111827;
  --white:#fff;
  --bg:#F5F5F8;
  --surface:#FFFFFF;
  --surface2:#F8F9FC;
  --sidebar-bg:#0A0A0A;
  --sidebar-border:rgba(255,255,255,.06);
  --border:rgba(0,0,0,.08);
  --border2:rgba(0,0,0,.05);
  --gray-bd:#E5E7EB;
  --gray-lt:#F3F4F6;
  --gray-md:#9CA3AF;
  --gray-dk:#6B7280;
  --text:#111827;
  --text2:#374151;
  --text3:#6B7280;
  --text4:#9CA3AF;
  --shadow:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 16px rgba(0,0,0,.08);
  --shadow-card:0 0 0 1px rgba(0,0,0,.04),0 4px 16px rgba(0,0,0,.06);
  --r:14px;
  --r-sm:10px;
  --r-xs:7px;
  --r-pill:999px;
  --radius:10px;
  --radius-lg:14px;
  --font:'Urbanist',sans-serif;
  --mono:'Urbanist',sans-serif;
  --tr:.18s cubic-bezier(.4,0,.2,1);
  --sidebar-w:240px;
  --topbar-h:58px;
}

/* ── BANNER ──────────────────────────────────────────────────────────────── */
.banner{
  position:fixed;top:0;left:0;right:0;z-index:999;
  height:28px;background:#F0F0F0;color:#666;
  font-family:var(--font);font-size:10px;font-weight:600;
  letter-spacing:.06em;
  display:flex;align-items:center;justify-content:center;
  gap:16px;border-bottom:1px solid #E0E0E0;
}
.banner-link{
  color:#555;text-decoration:none;font-weight:700;
  padding:2px 8px;border-radius:999px;
  transition:background .12s,color .12s;
  font-size:10px;letter-spacing:.04em;
}
.banner-link:hover{background:rgba(0,0,0,.06);color:#111;}
.banner-sep{color:#ccc;font-size:10px;}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  height:calc(100vh / var(--zoom,1));
  display:flex;
  overflow:hidden;
  padding-top:28px;
  zoom:var(--zoom,1);
}

/* ─── SIDEBAR ─────────────────────────────────────────────────────────────── */
.sidebar{
  width:240px;flex-shrink:0;
  background:#0A0A0A;
  border-radius:20px;
  margin:10px 0 10px 10px;
  display:flex;flex-direction:column;
  overflow:hidden;
  position:relative;
  height:calc((100vh - 48px) / var(--zoom,1));
  z-index:100;
}
.sidebar::-webkit-scrollbar{width:0}

/* ── SIDEBAR RESIZE HANDLE ──────────────────────────────────────────────── */
.resize-handle{
  position:fixed;left:var(--sidebar-w);top:0;width:5px;height:calc(100vh / var(--zoom,1));
  cursor:col-resize;z-index:200;
  background:transparent;
  transition:background .15s;
}
.resize-handle:hover,.resize-handle.is-dragging{background:rgba(215,254,3,.15);}
.resize-handle::after{
  content:'';position:absolute;left:1px;top:50%;transform:translateY(-50%);
  width:3px;height:40px;border-radius:4px;
  background:rgba(215,254,3,.5);
  opacity:0;transition:opacity .15s;
}
.resize-handle:hover::after,.resize-handle.is-dragging::after{opacity:1}
@media(max-width:860px){.resize-handle{display:none}}

.sb-logo{
  padding:22px 20px 18px;
  display:flex;align-items:center;gap:10px;
  border-bottom:none !important;
  margin-bottom:6px;
}
.sb-logo-mark{
  width:32px;height:32px;
  background:var(--accent);
  border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.sb-logo-mark svg{width:18px;height:18px;fill:#000;stroke:none;}
.sb-wordmark{font-size:16px;font-weight:800;color:#fff;letter-spacing:-.02em;}
.sb-wordmark span{color:var(--accent);}

.sb-nav{
  flex:1;padding:8px 12px;
  display:flex;flex-direction:column;gap:3px;
  overflow-y:auto;
}
.sb-nav::-webkit-scrollbar{width:0}

/* ── NAV ITEMS ────────────────────────────────────────────────────────────── */
.nav-item{
  display:flex;align-items:center;gap:12px;
  padding:11px 14px;border-radius:12px;
  background:#181818;
  border:1px solid #252525;
  cursor:pointer;transition:all .15s;
}
.nav-num{font-size:11px;font-weight:600;color:#555;min-width:18px;}
.nav-label{font-size:14px;font-weight:600;color:#888;flex:1;}
.nav-item.active{background:var(--accent);border-color:var(--accent);}
.nav-item.active .nav-num{color:rgba(0,0,0,.45);}
.nav-item.active .nav-label{color:#000;}
.nav-item:not(.active):hover{background:#222;}
.nav-item:not(.active):hover .nav-label{color:#ccc;}
.nav-item:not(.active):hover .nav-num{color:#666;}

/* sb-badge */
.sb-badge{
  margin-left:auto;font-size:10px;font-weight:700;
  padding:2px 7px;border-radius:999px;
  background:var(--accent);color:#000;
}

/* Areas submenu */
#areas-submenu{overflow:hidden;display:none}
#areas-submenu.open{display:block}
.nav-sub-item{
  display:flex;align-items:center;gap:8px;
  padding:6px 10px;border-radius:var(--r-xs);
  cursor:pointer;transition:background .1s;
  color:var(--text3);font-size:12px;font-weight:500;
}
.nav-sub-item:hover{background:rgba(255,255,255,.06);color:#ccc;}
.nav-sub-item.active-sub{background:var(--accent-soft);color:var(--accent);}

/* Glow no sidebar */
.sb-glow{
  position:absolute;bottom:70px;left:50%;
  transform:translateX(-50%);
  width:180px;height:180px;
  background:radial-gradient(ellipse at center,rgba(131,175,59,.4) 0%,transparent 70%);
  pointer-events:none;
}

/* Footer */
.sb-footer{
  position:relative;z-index:1;
  padding:12px 16px 14px;
  border-top:1px solid rgba(255,255,255,.06);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  flex-shrink:0;
}
.sb-footer-top{display:flex;align-items:center;gap:10px;width:100%;}
.sb-footer-btns{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;}
.sb-avatar{
  width:34px;height:34px;border-radius:50%;
  background:var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:800;color:#000;flex-shrink:0;
  overflow:hidden;
}
.sb-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.sb-name{font-size:13px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sb-role{font-size:11px;color:#555;margin-top:1px;}
.logout-btn{
  background:none;border:1px solid rgba(255,255,255,.12);cursor:pointer;
  color:#666;padding:5px 8px;border-radius:999px;
  transition:var(--tr);display:flex;align-items:center;gap:4px;
  font-family:var(--font);font-size:11px;font-weight:600;
  white-space:nowrap;margin-left:auto;
}
.logout-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--lime-lt)}
.logout-btn svg{width:12px;height:12px;display:block;flex-shrink:0;}

/* ─── MAIN ────────────────────────────────────────────────────────────────── */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;}

/* ─── TOPBAR ──────────────────────────────────────────────────────────────── */
.topbar{
  height:var(--topbar-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;gap:16px;
  position:sticky;top:0;z-index:90;
  background:var(--bg);
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.tb-left{display:flex;flex-direction:column;gap:2px;}
.tb-greeting{font-size:18px;font-weight:800;letter-spacing:-.03em;color:var(--text);}
.tb-date{font-size:11px;color:var(--text4);margin-top:1px;font-weight:400;}
.tb-right{display:flex;align-items:center;gap:8px;}

/* Plugin pill */
.plugin-pill{
  display:flex;align-items:center;gap:6px;
  padding:6px 14px;border-radius:999px;
  background:var(--green-soft);border:1px solid rgba(46,182,121,.2);
  font-size:11px;font-weight:600;color:var(--green);
}
.plugin-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:blink 2s ease infinite;flex-shrink:0;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* Pills topbar */
.tb-pill{
  display:flex;align-items:center;gap:7px;
  padding:0 16px;height:36px;
  background:transparent;
  border:1px solid rgba(0,0,0,.15);
  border-radius:999px;
  font-family:var(--font);
  font-size:13px;font-weight:600;color:var(--text2);
  cursor:pointer;transition:all .12s;white-space:nowrap;
}
.tb-pill svg{width:14px;height:14px;flex-shrink:0;color:var(--text3);}
.tb-pill:hover{background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.25);}
.tb-pill.icon-only{padding:0;width:36px;justify-content:center;}
.tb-pill-add{background:#000;color:#fff;border-color:#000;border-radius:999px;}
.tb-pill-add:hover{background:#222;border-color:#222;}
.tb-pill-add svg{color:var(--accent);}

/* Hamburger */
.hamburger{
  display:none;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:999px;border:1px solid var(--border);
  background:var(--surface2);cursor:pointer;flex-shrink:0;color:var(--text3);
}
.hamburger svg{width:16px;height:16px;}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:99;}
.sidebar-overlay.show{display:block;}

/* ─── CONTENT AREA ────────────────────────────────────────────────────────── */
.content{
  flex:1;overflow-y:auto;overflow-x:hidden;
  padding:22px 26px;display:flex;flex-direction:column;gap:18px;
}
.content::-webkit-scrollbar{width:4px;}
.content::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.page{padding:22px 26px;overflow-y:auto;flex:1;min-height:0;display:flex;flex-direction:column;gap:18px;}
.page::-webkit-scrollbar{width:4px;}
.page::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}

/* ─── PRIORITY BLOCK ──────────────────────────────────────────────────────── */
.priority-block{
  background:
    radial-gradient(ellipse 55% 70% at 18% 110%,rgba(131,175,59,.55) 0%,transparent 65%),
    #0A0A0A;
  border-radius:24px;
  padding:22px 22px 32px;
  position:relative;
}
.cards-deck{
  display:flex;gap:14px;
  overflow-x:auto;padding-bottom:2px;
  padding-top:16px;
  scrollbar-width:none;
}
.cards-deck::-webkit-scrollbar{display:none;}
.pcard-wrap{
  flex-shrink:0;width:240px;
  position:relative;cursor:grab;
}
.pcard{
  background:#1C1C1C;
  border:1px solid #2a2a2a;
  border-radius:18px;
  padding:20px;
  min-height:160px;
  position:relative;
  transition:border-color .15s,transform .15s;
  user-select:none;
}
.pcard:active{cursor:grabbing;}
.pcard-wrap.dragging .pcard{opacity:.5;transform:scale(.97);}
.pcard-wrap.drag-over .pcard{border-color:var(--lime);}
.pcard-cfg{
  width:26px;height:26px;border-radius:999px;
  background:#282828;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .15s;flex-shrink:0;
}
.pcard-cfg:hover{background:#383838;}
.pcard-cfg svg{width:14px;height:14px;color:#888;}

/* Menu contextual do pcard */
.pcard-menu-dropdown{
  position:absolute;top:44px;right:12px;z-index:50;
  background:#1e1e1e;border:1px solid #333;border-radius:10px;
  padding:4px;min-width:170px;
  box-shadow:0 8px 24px rgba(0,0,0,.4);
  display:none;
}
.pcard-menu-dropdown.open{display:block;}
.pcard-menu-item{
  display:flex;align-items:center;gap:8px;
  padding:8px 10px;border-radius:7px;
  font-family:var(--font);font-size:12px;font-weight:500;
  color:#ccc;cursor:pointer;transition:background .1s;
  border:none;background:none;width:100%;text-align:left;
}
.pcard-menu-item:hover{background:#2a2a2a;color:#fff;}
.pcard-menu-item.danger{color:#EF4444;}
.pcard-menu-item.danger:hover{background:rgba(239,68,68,.1);}
.pcard-menu-item svg{width:13px;height:13px;flex-shrink:0;opacity:.7;}

.pcard-top{display:flex;justify-content:space-between;align-items:center;gap:6px;}
.pcard-priority-lbl{font-size:10px;font-weight:700;color:var(--lime);letter-spacing:.08em;text-transform:uppercase;flex:1;}
.pcard-num{font-size:11px;font-weight:700;color:#444;white-space:nowrap;}
.pcard-name{font-size:15px;font-weight:400;color:#fff;margin-top:16px;line-height:1.3;max-width:210px;}
.pcard-bottom{
  position:absolute;bottom:20px;left:20px;right:20px;
  display:flex;justify-content:space-between;align-items:flex-end;
}
.pcard-field-lbl{font-size:9px;font-weight:700;color:#555;letter-spacing:.08em;text-transform:uppercase;margin-bottom:3px;}
.pcard-field-val{font-size:13px;font-weight:700;color:#aaa;}
.pcard-field-val.lime{color:var(--lime);}
/* Card adicionar */
.pcard-add{
  flex-shrink:0;width:160px;
  background:transparent;border:1.5px dashed #2a2a2a;
  border-radius:18px;min-height:160px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:10px;cursor:pointer;transition:border-color .15s;
}
.pcard-add:hover{border-color:#444;}
.pcard-add svg{width:24px;height:24px;color:#444;}
.pcard-add span{font-size:12px;color:#555;font-weight:500;}

/* ─── CARD BASE ───────────────────────────────────────────────────────────── */
.card{
  background:var(--surface);
  border-radius:var(--r);
  padding:20px;
  border:1px solid var(--border);
  box-shadow:none;
  position:relative;
}
/* SEM faixa verde no topo dos cards KPI */
.card-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 18px 12px;
  border-bottom:1px solid var(--border2);
}
.card-title{font-size:13px;font-weight:600;color:var(--text);letter-spacing:-.01em;}
.card-meta{font-size:11px;color:var(--text4);}
.card-tabs{display:flex;gap:2px;background:var(--surface2);border-radius:999px;padding:2px;border:1px solid var(--border);}
.ctab{font-size:11px;font-weight:600;padding:4px 12px;border-radius:999px;cursor:pointer;color:var(--text3);transition:all .12s;background:none;border:none;font-family:var(--font);}
.ctab.on,.ctab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px rgba(0,0,0,.08);}

/* ─── KPI ROW ─────────────────────────────────────────────────────────────── */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.kpi{
  padding:28px 28px;
  min-height:160px;display:flex;flex-direction:column;justify-content:space-between;
  animation:up .35s ease both;
  cursor:default;position:relative;overflow:hidden;
}
/* SEM ::before (faixa verde removida) */
.kpi:nth-child(1){animation-delay:.04s;}
.kpi:nth-child(2){animation-delay:.08s;}
.kpi:nth-child(3){animation-delay:.12s;}
.kpi:nth-child(4){animation-delay:.16s;}
@keyframes up{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

.kpi-lbl{font-size:10px;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;display:flex;align-items:center;gap:5px;}
.kpi-num{font-size:28px;font-weight:800;letter-spacing:-.05em;line-height:1;margin-bottom:6px;color:var(--text);font-family:var(--font)!important;}
.kpi-num.green,.kpi-num.kpi-green{color:var(--green);}
.kpi-num.orange,.kpi-num.kpi-orange{color:var(--amber);}
.kpi-foot{display:flex;align-items:center;justify-content:space-between;}
.kpi-sub{font-size:11px;color:var(--text4);font-weight:400;}

/* Tags */
.tag,.kpi-tag{font-size:10px;font-weight:700;padding:3px 8px;border-radius:999px;display:inline-flex;align-items:center;gap:3px;}
.tg,.tag-up{background:var(--green-soft);color:var(--green);}
.tr,.tag-down{background:#FEE2E2;color:#DC2626;}
.tw,.tag-amber{background:var(--amber-soft);color:#D97706;}
.tn,.tag-neutral{background:var(--surface2);color:var(--text3);}

/* ─── MID ROW ─────────────────────────────────────────────────────────────── */
.mid-row{display:grid;grid-template-columns:66fr 34fr;gap:14px;align-items:start;}

/* ─── TABLE CARD ──────────────────────────────────────────────────────────── */
.tbl-card{animation:up .35s .2s ease both;max-height:70vh;overflow:hidden;display:flex;flex-direction:column;}
.tbl-card .tbl-wrap{flex:1;overflow-y:auto;}

/* Filter tabs */
.filter-tabs{display:flex;gap:2px;background:var(--surface2);padding:2px;border-radius:999px;border:1px solid var(--border);}
.filter-tab{padding:4px 12px;border-radius:999px;font-size:11px;font-weight:600;color:var(--text3);background:none;border:none;cursor:pointer;font-family:var(--font);transition:all .12s;}
.filter-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px rgba(0,0,0,.08);}
.filter-tab:hover:not(.active){color:var(--text2);}

/* Search */
.search-box{
  display:flex;align-items:center;gap:7px;
  background:var(--surface2);border-radius:999px;padding:7px 12px;
  border:1px solid var(--border);transition:var(--tr);min-width:180px;
}
.search-box:focus-within{background:var(--surface);border-color:var(--lime-mid);}
.search-box svg{width:13px;height:13px;color:var(--text3);flex-shrink:0;}
.search-box input{background:none;border:none;outline:none;font-family:var(--font);font-size:12px;color:var(--text);width:100%;}
.search-box input::placeholder{color:var(--text3);}

/* Table */
.tbl-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;}
thead th{font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text4);padding:10px 18px 8px;text-align:left;border-bottom:1px solid var(--border);}
thead th:first-child{padding-left:18px;}
thead th:last-child{padding-right:18px;text-align:center;}
tbody tr{border-bottom:1px solid var(--border2);cursor:pointer;transition:background .1s;}
tbody tr:last-child{border-bottom:none;}
tbody tr:hover{background:var(--surface2);}
td{padding:22px 18px;vertical-align:middle;font-size:13px;color:var(--text);}
td:first-child{padding-left:18px;}
td:last-child{padding-right:18px;text-align:center;}

.td-num{font-size:11px;font-family:var(--mono);color:var(--text4);}
.td-name{font-size:12px;font-weight:600;color:var(--text);}
.td-client{font-size:11px;color:var(--text4);font-weight:400;margin-top:1px;}
.td-val{font-size:12px;font-weight:600;font-family:var(--mono);color:var(--text);}
.area-chip{font-size:10px;font-weight:600;padding:2px 7px;border-radius:999px;white-space:nowrap;}

/* Status pills */
.pill{font-size:10px;font-weight:600;padding:3px 10px;border-radius:999px;display:inline-flex;align-items:center;gap:3px;white-space:nowrap;letter-spacing:.02em;}
.p-and{background:rgba(215,254,3,.12);color:#5A7000;border:1px solid rgba(215,254,3,.3);}
.p-ent{background:rgba(16,185,129,.08);color:#059669;border:1px solid rgba(16,185,129,.15);}
.p-pau{background:rgba(156,163,175,.1);color:#6B7280;border:1px solid rgba(156,163,175,.2);}
.p-pag{background:rgba(16,185,129,.08);color:#059669;border:1px solid rgba(16,185,129,.15);}
.p-rec{background:rgba(215,254,3,.08);color:#5A7000;border:1px solid rgba(215,254,3,.2);}

/* Payment pills */
.pay-col-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:999px;font-size:10px;font-weight:600;white-space:nowrap;border:1px solid transparent;}
.pay-col-pill::before{content:'';width:5px;height:5px;border-radius:50%;flex-shrink:0;}
.pay-col-pago{background:rgba(16,185,129,.08);color:#059669;border-color:rgba(16,185,129,.15);}.pay-col-pago::before{background:#059669;}
.pay-col-atraso{background:rgba(156,163,175,.1);color:#6B7280;border-color:rgba(156,163,175,.2);}.pay-col-atraso::before{background:#9CA3AF;}
.pay-col-parcial{background:rgba(215,254,3,.08);color:#5A7000;border-color:rgba(215,254,3,.15);}.pay-col-parcial::before{background:var(--accent2);}
.pay-col-receber{background:rgba(156,163,175,.08);color:var(--text3);border-color:rgba(156,163,175,.15);}.pay-col-receber::before{background:var(--text4);}

/* Action buttons */
.act-btn{width:26px;height:26px;border-radius:999px;background:none;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--text4);transition:var(--tr);}
.act-btn:hover{background:var(--surface2);color:var(--text);}
.act-btn svg{width:13px;height:13px;}
.pay-alert{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:#EF4444;color:white;font-size:9px;font-weight:700;margin-left:2px;vertical-align:middle;}

.tbl-footer{padding:12px 18px;border-top:1px solid var(--border2);display:flex;justify-content:flex-end;}
.btn-export{display:inline-flex;align-items:center;gap:6px;padding:8px 20px;background:#000;color:var(--accent);border:none;border-radius:999px;font-family:var(--font);font-size:12px;font-weight:700;cursor:pointer;transition:background .12s;}
.btn-export:hover{background:#222;}
.btn-export svg{width:12px;height:12px;}

.empty-state{padding:48px 24px;text-align:center;}
.empty-text{font-size:13px;font-weight:700;color:var(--text3);margin-bottom:4px;}
.empty-sub{font-size:12px;color:var(--text4);}

/* ─── SUBTASKS ────────────────────────────────────────────────────────────── */
.subtask-toggle{position:relative;}
.subtask-toggle.has-tasks svg{stroke:var(--accent2);}
.subtask-count{font-size:9px;font-weight:700;color:var(--accent2);margin-left:2px;font-family:var(--mono);}
.subtask-row td{padding:0 !important;}
.subtask-panel{border-top:1px solid var(--border);background:var(--surface2);padding:12px 20px 14px 52px;animation:up .2s ease both;}
.subtask-list{display:flex;flex-direction:column;gap:4px;margin-bottom:10px;min-height:0;}
.subtask-empty{font-size:11px;color:var(--text4);padding:4px 0;}
.subtask-item{display:flex;align-items:center;gap:8px;padding:5px 6px;border-radius:999px;transition:background .1s;}
.subtask-item:hover{background:var(--surface);}
.subtask-item.done .subtask-text{text-decoration:line-through;color:var(--text4);}
.subtask-check-wrap{display:flex;align-items:center;cursor:pointer;flex-shrink:0;}
.subtask-check-wrap input[type=checkbox]{display:none;}
.subtask-check-box{width:15px;height:15px;border-radius:4px;border:1.5px solid var(--text4);background:var(--surface);display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0;}
.subtask-check-wrap input:checked+.subtask-check-box{background:linear-gradient(135deg,var(--grad-start),var(--grad-end));border-color:transparent;}
.subtask-check-wrap input:checked+.subtask-check-box::after{content:'';width:8px;height:5px;border-left:1.5px solid #000;border-bottom:1.5px solid #000;transform:rotate(-45deg) translateY(-1px);display:block;}
.subtask-text{font-size:12px;color:var(--text);flex:1;line-height:1.4;}
.subtask-del{background:none;border:none;cursor:pointer;color:var(--text4);padding:2px;border-radius:999px;display:flex;align-items:center;opacity:0;transition:opacity .1s;}
.subtask-item:hover .subtask-del{opacity:1;}
.subtask-input-row{display:flex;gap:8px;align-items:center;}
.subtask-input{flex:1;border:1px solid var(--border);border-radius:999px;padding:6px 12px;font-family:var(--font);font-size:12px;background:var(--surface);color:var(--text);outline:none;}
.subtask-input:focus{border-color:var(--border);}
.subtask-add-btn{padding:6px 14px;border-radius:999px;border:none;cursor:pointer;background:linear-gradient(135deg,var(--grad-start),var(--grad-end));color:#000;font-size:11px;font-weight:700;font-family:var(--font);white-space:nowrap;transition:opacity .15s;}
.subtask-add-btn:hover{opacity:.85;}

/* ─── RIGHT COL ───────────────────────────────────────────────────────────── */
.right-col{display:flex;flex-direction:column;gap:14px;}

/* Gauge / donut card — fundo preto */
.gauge-card,.rev-arc-card{
  background:#0A0A0A !important;
  border:1px solid #1a1a1a !important;
  padding:18px 20px;animation:up .35s .25s ease both;
}
.gauge-card .card-title{color:#fff !important;}
.gauge-inner{display:flex;flex-direction:column;align-items:center;padding:6px 0 0;}
.rev-arc-wrap{display:flex;justify-content:center;padding:4px 0 8px;}
#rev-arc-svg{overflow:visible;}

/* Donut tooltip — glassmorphism com borda branca gradiente */
.donut-tooltip{
  align-self:flex-end;margin-right:6px;margin-bottom:-6px;
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-radius:10px;padding:8px 12px;text-align:right;
  position:relative;
}
.donut-tooltip::before{
  content:'';
  position:absolute;inset:0;
  border-radius:10px;
  padding:1px;
  background:linear-gradient(135deg,rgba(255,255,255,.55),rgba(255,255,255,.08));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
  pointer-events:none;
}
.donut-tooltip-lbl{font-size:11px;color:rgba(255,255,255,.5);}
.donut-tooltip-val{font-size:15px;font-weight:700;color:#fff;margin-top:2px;}

/* Donut container */
.donut-container{position:relative;width:160px;height:160px;display:flex;align-items:center;justify-content:center;}
.donut-center{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.donut-val{font-size:28px;font-weight:800;letter-spacing:-.04em;line-height:1;color:#fff;}
.donut-lbl{font-size:10px;font-weight:700;color:#666;letter-spacing:.08em;text-transform:uppercase;margin-top:4px;}

/* Chart legend */
.chart-wrap{display:flex;flex-direction:column;align-items:center;gap:14px;padding:8px 0;}
.chart-legend{display:flex;justify-content:space-between;width:100%;}
.legend-item{display:flex;flex-direction:column;align-items:center;gap:3px;}
.legend-val{font-size:14px;font-weight:700;font-family:var(--mono);}
.legend-val.green{color:var(--green);}
.legend-val.amber{color:var(--amber);}
.legend-val.muted{color:#555;}
.legend-lbl{font-size:10px;font-weight:600;color:#555;letter-spacing:.06em;text-transform:uppercase;}

/* Gauge legend aliases */
.gauge-legend{display:flex;flex-direction:column;gap:8px;margin-top:12px;width:100%;}
.gauge-legend-row,.g-row{display:flex;align-items:center;justify-content:space-between;}
.gauge-legend-left,.g-left{display:flex;align-items:center;gap:7px;}
.gauge-legend-dot,.g-dot{width:9px;height:9px;border-radius:50%;}
.gauge-legend-label,.g-lbl{font-size:12px;color:rgba(255,255,255,.6);font-weight:400;}
.gauge-legend-val,.g-val{font-size:13px;font-weight:700;font-family:var(--mono);color:#fff;}

.g-detail-btn{
  margin-top:14px;width:100%;padding:9px;
  background:#1a1a1a;border:1px solid #2a2a2a;
  border-radius:999px;font-size:12px;font-weight:600;
  color:#888;cursor:pointer;font-family:var(--font);
  transition:all .12s;text-align:center;
}
.g-detail-btn:hover{background:#222;color:var(--accent);border-color:var(--accent);}

/* Overview blocks */
.overview-card,.status-blocks-card{padding:18px 20px;animation:up .35s .3s ease both;}
.card-head-inner{padding:0 0 12px;border-bottom:1px solid var(--border2);display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.ov-section-lbl{font-size:10px;font-weight:600;color:var(--text4);letter-spacing:.07em;text-transform:uppercase;margin-bottom:8px;margin-top:14px;}
.ov-section-lbl:first-of-type{margin-top:0;}
.ov-blocks{display:flex;gap:6px;}
.ov-block{flex:1;border-radius:var(--r-xs);padding:12px 10px;display:flex;flex-direction:column;align-items:center;gap:3px;text-align:center;}
.ov-block-num{font-size:20px;font-weight:500;letter-spacing:-.03em;font-family:var(--mono);line-height:1;}
.ov-block-lbl{font-size:10px;font-weight:500;margin-top:2px;}
.ob-dark{background:var(--surface2);border:1px solid var(--border);}
.ob-dark .ov-block-num{color:var(--accent);}
.ob-dark .ov-block-lbl{color:var(--text4);}
.ob-accent{background:var(--surface2);border:1px solid var(--border);}
.ob-accent .ov-block-num{color:var(--green);}
.ob-accent .ov-block-lbl{color:var(--text4);}
.ob-light{background:var(--surface2);border:1px solid var(--border);}
.ob-light .ov-block-num{color:var(--text);}
.ob-light .ov-block-lbl{color:var(--text4);}
.ob-green{background:var(--surface2);border:1px solid var(--border);}
.ob-green .ov-block-num{color:var(--green);}
.ob-green .ov-block-lbl{color:var(--text4);}
.ob-orange-lt{background:var(--surface2);border:1px solid var(--border);}
.ob-orange-lt .ov-block-num{color:var(--amber);}
.ob-orange-lt .ov-block-lbl{color:var(--text4);}

/* ─── BOTTOM ROW ──────────────────────────────────────────────────────────── */
.bottom-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}

/* Area bars */
.area-card,.area-bars-card{padding:18px 20px;animation:up .35s .35s ease both;}
.area-list,.area-bars-list{display:flex;flex-direction:column;gap:32px;margin-top:16px;}
.al-row{margin-bottom:18px;}
.al-row:last-child{margin-bottom:0;}
.al-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px;}
.al-name{font-size:12px;font-weight:500;color:var(--text2);display:flex;align-items:center;gap:6px;}
.al-val{font-size:12px;font-weight:700;font-family:var(--mono);color:var(--text);}
.al-track{height:6px;background:var(--surface2);border-radius:3px;overflow:hidden;border:1px solid var(--border2);}
.al-fill{height:100%;border-radius:3px;transition:width .9s cubic-bezier(.4,0,.2,1);background:linear-gradient(90deg,var(--grad-start),var(--grad-end));}
.al-meta{font-size:10px;color:var(--text4);margin-top:3px;font-weight:400;}
.area-total,.area-bars-total{margin-top:14px;padding-top:12px;border-top:1px solid var(--border2);display:flex;justify-content:space-between;}
.at-lbl{font-size:10px;color:var(--text4);font-weight:400;}
.at-val{font-size:15px;font-weight:800;font-family:var(--mono);letter-spacing:-.02em;}
.area-empty{text-align:center;color:var(--text4);font-size:12px;padding:12px 0;}

/* Annual bar chart */
.chart-card,.annual-chart-card{padding:18px 20px;animation:up .35s .4s ease both;}
.chart-area,.annual-bars-wrap{display:flex;align-items:flex-end;gap:5px;height:80px;margin-top:14px;}
.ch-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;}
.ch-bar{width:100%;border-radius:5px 5px 0 0;min-height:3px;transition:height .7s cubic-bezier(.4,0,.2,1);background:var(--gray-bd);}
.ch-bar.active{background:var(--accent2);}
.ch-lbl{font-size:9px;font-weight:600;color:var(--text4);letter-spacing:.02em;}
.ch-lbl.active{color:var(--accent2);font-weight:700;}
.chart-footer,.annual-footer{display:flex;justify-content:space-between;margin-top:12px;padding-top:12px;border-top:1px solid var(--border2);}
.cf-item,.af-item{display:flex;flex-direction:column;gap:2px;}
.cf-lbl,.af-lbl{font-size:10px;color:var(--text4);font-weight:400;}
.cf-val,.af-val{font-size:14px;font-weight:800;letter-spacing:-.02em;font-family:var(--mono);}

/* ─── PAYMENT CARD ────────────────────────────────────────────────────────── */
.pay-dash-card{padding:18px 20px;animation:up .35s .45s ease both;}
.pay-dash-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border2);gap:8px;}
.pay-dash-row:last-child{border-bottom:none;}
.pay-dash-proj{font-size:12px;font-weight:600;color:var(--text);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.pay-dash-amount{font-size:12px;font-weight:700;font-family:var(--mono);color:var(--text);white-space:nowrap;}
.pay-dash-date{font-size:10px;color:var(--text4);white-space:nowrap;}
#pay-dash-list{display:flex;flex-direction:column;}

/* ─── MODALS ──────────────────────────────────────────────────────────────── */
.overlay{display:none;position:fixed;inset:0;z-index:400;background:rgba(0,0,0,.45);align-items:center;justify-content:center;}
.overlay.show,.overlay.open{display:flex;}
.modal{background:#fff;border-radius:14px;width:90%;max-width:560px;box-shadow:0 20px 60px rgba(0,0,0,.25);max-height:90vh;display:flex;flex-direction:column;overflow:hidden;min-width:320px;min-height:180px;}
.modal-body{overflow-y:auto;}
.confirm-modal{max-width:380px;}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1.5px solid var(--gray-lt);flex-shrink:0;}
.modal-title{font-size:15px;font-weight:800;letter-spacing:-.2px;color:var(--text);}
.modal-close{width:28px;height:28px;border-radius:999px;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--gray-dk);transition:var(--tr);}
.modal-close:hover{background:var(--gray-lt);color:var(--text);}
.modal-close svg{width:14px;height:14px;}
.modal-body{padding:16px 20px;overflow-y:auto;flex:1;}
.modal-foot{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1.5px solid var(--gray-lt);flex-shrink:0;}

.confirm-icon-wrap{width:52px;height:52px;border-radius:14px;flex-shrink:0;display:flex;align-items:center;justify-content:center;margin:20px auto 0;}
.confirm-icon-wrap svg{width:26px;height:26px;color:inherit;}
.confirm-body{padding:12px 20px 0;text-align:center;}
.confirm-message{font-size:13px;color:var(--gray-dk);margin-top:6px;line-height:1.5;}
.confirm-actions{justify-content:center;gap:10px;}
.confirm-danger-btn{background:#EF4444;}
.confirm-danger-btn:hover{background:#DC2626;}

/* ─── FORM ────────────────────────────────────────────────────────────────── */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;}
.form-row.full{grid-template-columns:1fr;}
.field{display:flex;flex-direction:column;gap:5px;}
.field label{font-size:11px;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.4px;}
.field input,.field select,.field textarea{padding:9px 12px;border:1.5px solid var(--gray-bd);border-radius:999px;font-family:var(--font);font-size:13px;color:var(--text);background:white;outline:none;transition:border-color var(--tr);}
.field textarea{border-radius:12px;}
.field input:focus,.field select:focus,.field textarea:focus{border-color:#888;}
.field-help{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:var(--gray-lt);border:1px solid var(--gray-bd);color:var(--gray-md);font-size:9px;font-weight:700;cursor:pointer;margin-left:5px;flex-shrink:0;transition:var(--tr);vertical-align:middle;font-style:normal;}
.field-help:hover{background:var(--lime-lt);border-color:var(--lime);color:var(--lime);}

/* Buttons */
.btn-save{background:#000;color:var(--accent);border:none;padding:9px 20px;border-radius:999px;font-family:var(--font);font-size:13px;font-weight:700;cursor:pointer;transition:var(--tr);}
.btn-save:hover{background:#222;}
.btn-cancel{background:none;border:1.5px solid var(--gray-bd);padding:9px 20px;border-radius:999px;font-family:var(--font);font-size:13px;font-weight:600;color:var(--text);cursor:pointer;transition:var(--tr);}
.btn-cancel:hover{border-color:var(--text);}
.btn-add{display:flex;align-items:center;gap:6px;background:#000;color:white;padding:8px 16px;border-radius:999px;font-family:var(--font);font-size:13px;font-weight:700;border:none;cursor:pointer;transition:var(--tr);white-space:nowrap;}
.btn-add:hover{background:#222;}
.btn-add svg{width:13px;height:13px;}
.btn-duplicate{display:flex;align-items:center;gap:6px;background:none;border:1.5px solid var(--gray-bd);padding:9px 14px;border-radius:999px;font-family:var(--font);font-size:13px;font-weight:600;color:var(--text);cursor:pointer;transition:var(--tr);}
.btn-duplicate:hover{border-color:var(--text);color:var(--text);}
.btn-duplicate svg{width:13px;height:13px;}

/* ─── FAB ─────────────────────────────────────────────────────────────────── */
.fab{
  position:fixed;bottom:24px;right:24px;z-index:150;
  display:flex;align-items:center;gap:8px;
  background:#000;color:var(--accent);
  padding:11px 20px;border-radius:999px;
  font-family:var(--font);font-size:13px;font-weight:700;
  border:none;cursor:pointer;
  box-shadow:0 4px 20px rgba(0,0,0,.2);
  transition:var(--tr);white-space:nowrap;
}
.fab:hover{background:#222;box-shadow:0 6px 24px rgba(215,254,3,.2);}
.fab svg{width:15px;height:15px;flex-shrink:0;}

/* ─── TOAST ───────────────────────────────────────────────────────────────── */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--text);color:white;padding:10px 20px;border-radius:999px;font-size:13px;font-weight:600;pointer-events:none;opacity:0;transition:opacity .2s ease;z-index:1000;white-space:nowrap;}
.toast.show{opacity:1;}

/* ─── HELP CARD ───────────────────────────────────────────────────────────── */
.help-card{position:fixed;z-index:500;background:white;border:1.5px solid var(--gray-bd);border-radius:10px;padding:14px 16px;width:240px;box-shadow:0 8px 24px rgba(0,0,0,.12);font-size:12px;line-height:1.6;color:var(--text);opacity:0;pointer-events:none;transform:translateY(4px);transition:opacity .18s ease,transform .18s ease;}
.help-card.show{opacity:1;pointer-events:all;transform:translateY(0);}
.help-card-title{font-size:12px;font-weight:900;color:var(--text);margin-bottom:6px;display:flex;align-items:center;gap:6px;}
.help-card-title svg{color:var(--accent);flex-shrink:0;}
.help-card-body{color:var(--gray-dk);font-size:11px;}
.help-card-tag{display:inline-flex;align-items:center;gap:4px;margin-top:10px;padding:4px 8px;border-radius:999px;background:var(--lime-lt);color:var(--accent2);font-size:10px;font-weight:700;}

/* ─── EXPORT MODAL ────────────────────────────────────────────────────────── */
.export-format-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:16px 0;}
.export-format-card{border:2px solid var(--gray-bd);border-radius:10px;padding:16px;text-align:center;cursor:pointer;transition:var(--tr);background:white;}
.export-format-card:hover{border-color:var(--accent);background:var(--lime-lt);}
.export-format-card.selected{border-color:var(--accent);background:var(--lime-lt);}
.export-format-card svg{width:28px;height:28px;margin:0 auto 8px;display:block;}
.export-format-card .fmt-name{font-size:14px;font-weight:900;color:var(--text);}
.export-format-card .fmt-desc{font-size:11px;color:var(--gray-dk);margin-top:3px;}
.export-dev-notice{background:var(--yellow-lt);border:1.5px solid var(--yellow);border-radius:10px;padding:12px 14px;display:flex;align-items:flex-start;gap:10px;margin-top:4px;}
.export-dev-notice svg{width:16px;height:16px;flex-shrink:0;color:#B45309;margin-top:1px;}
.export-dev-notice p{font-size:12px;color:#92400E;line-height:1.5;}

/* ─── PAYMENT MODAL ───────────────────────────────────────────────────────── */
.pay-summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px;}
.pay-summary-card{background:var(--gray-lt);border-radius:10px;padding:12px;text-align:center;}
.pay-summary-card.orange{background:var(--lime-lt);}
.pay-summary-card.green{background:#ECFDF5;}
.pay-summary-card.red{background:#FEF2F2;}
.pay-summary-num{font-size:18px;font-weight:900;letter-spacing:-.5px;color:var(--text);line-height:1;}
.pay-summary-lbl{font-size:10px;font-weight:700;color:var(--gray-dk);text-transform:uppercase;letter-spacing:.4px;margin-top:4px;}
.pay-installment-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--gray-lt);}
.pay-installment-row:last-child{border-bottom:none;}
.pay-num{width:24px;height:24px;border-radius:50%;background:var(--gray-lt);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--gray-dk);flex-shrink:0;}
.pay-num.entrada{background:var(--lime-lt);color:var(--accent2);}
.pay-info{flex:1;min-width:0;}
.pay-val{font-size:13px;font-weight:900;color:var(--text);}
.pay-meta{font-size:11px;color:var(--gray-dk);margin-top:1px;}
.pay-status-badge{padding:3px 9px;border-radius:999px;font-size:10px;font-weight:700;white-space:nowrap;}
.pay-badge-pago{background:#ECFDF5;color:#065F46;}
.pay-badge-pendente{background:#FFF7ED;color:#C2410C;}
.pay-badge-atrasado{background:#FEF2F2;color:#991B1B;}
.pay-form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px;}
.pay-form-row.three{grid-template-columns:1fr 1fr 1fr;}
.pay-form-row.full{grid-template-columns:1fr;}

/* ─── PAGES ───────────────────────────────────────────────────────────────── */
.page-header{display:flex;align-items:center;gap:12px;margin-bottom:4px;}
.table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;flex-shrink:0;}
.table-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;border-bottom:1px solid var(--border2);flex-wrap:wrap;gap:10px;}
.table-head-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0;}
.table-title{font-size:15px;font-weight:800;letter-spacing:-.2px;color:var(--text);}
.row-idx{font-size:10px;font-weight:700;color:var(--text4);font-family:var(--mono);}
.row-name-main{font-size:13px;font-weight:600;color:var(--text);}
.row-name-sub{font-size:11px;color:var(--text3);margin-top:2px;}
.row-val{font-size:13px;font-weight:700;font-family:var(--mono);color:var(--text);}
.row-date{font-size:11px;color:var(--text3);}
.pill-green{background:#ECFDF5;color:#065F46;}
.pill-purple{background:rgba(215,254,3,.12);color:#5A7000;border:1px solid rgba(215,254,3,.25);}
.pill-orange{background:#FFF7ED;color:#C2410C;}
.pill-red{background:#FEF2F2;color:#991B1B;}
.pill-gray{background:var(--surface2);color:var(--text3);}

#area-filter-banner{display:none;align-items:center;justify-content:space-between;padding:10px 18px;background:var(--lime-lt);border-bottom:1px solid rgba(215,254,3,.2);font-size:12px;color:var(--text);gap:8px;}
#area-filter-banner.show{display:flex;}

/* Resumo */
.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px;box-shadow:var(--shadow);}
.nova-area-card{border:2px dashed var(--border);border-radius:var(--r);padding:18px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;cursor:pointer;transition:border-color .2s,background .2s;min-height:160px;background:transparent;}
.nova-area-card:hover,.nova-area-card.hovered{border-color:var(--accent);background:rgba(215,254,3,0.04);}
.nova-area-icon{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,rgba(215,254,3,.12),rgba(131,175,59,.08));display:flex;align-items:center;justify-content:center;border:1px solid rgba(215,254,3,.2);transition:transform .2s;}
.nova-area-card:hover .nova-area-icon,.nova-area-card.hovered .nova-area-icon{transform:scale(1.08);}
.nova-area-label{font-size:13px;font-weight:700;color:var(--accent2);}
.r-kpi{padding:20px 22px;min-height:120px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;}

/* Advanced filters */
#dashboard-advanced-filters{display:flex;align-items:center;flex-wrap:nowrap;flex:1;min-width:0;padding:0;margin:0;border:none;overflow-x:auto;white-space:nowrap;}
#dashboard-advanced-filters .adv-group{display:flex;gap:6px;align-items:center;white-space:nowrap;flex-wrap:nowrap;}
#dashboard-advanced-filters .adv-btn{border:1px solid var(--border);background:var(--surface);color:var(--text3);border-radius:999px;padding:5px 12px;font:600 11px var(--font);cursor:pointer;transition:var(--tr);}
#dashboard-advanced-filters .adv-btn:hover{border-color:var(--accent);color:#5A7000;background:var(--accent-soft);}
#dashboard-advanced-filters .adv-btn.active{border-color:var(--accent);color:#5A7000;background:var(--accent-soft);}
#dashboard-advanced-filters .adv-btn.clear-btn{border-style:dashed;}
#dashboard-active-filters{display:none !important;}

/* Areas page — barras verde-lima */
.area-perf-bar-fill{background:linear-gradient(90deg,var(--grad-start),var(--grad-end)) !important;}
.area-perf-pct{color:var(--accent2) !important;}
/* Resumo mensal — barra e badge */
.resumo-bar-fill{background:linear-gradient(90deg,var(--grad-start),var(--grad-end)) !important;}
.resumo-atual-badge{background:var(--accent) !important;color:#000 !important;border-radius:999px !important;}
.resumo-mes-atual{color:var(--accent2) !important;}
.resumo-pct{color:var(--accent2) !important;}

/* ─── RESPONSIVE ──────────────────────────────────────────────────────────── */
@media(max-width:1400px){.mid-row{grid-template-columns:1fr 340px;}}
@media(max-width:860px){
  .mid-row{grid-template-columns:1fr;}
  .right-col{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
  .fab{right:24px;}
}
@media(max-width:900px){
  .kpi-row{grid-template-columns:repeat(2,1fr);}
  .bottom-row{grid-template-columns:1fr;}
  .right-col{grid-template-columns:1fr 1fr;}
}
@media(max-width:768px){
  :root{--sidebar-w:0px;}
  .sidebar{position:fixed;left:10px;top:38px;bottom:10px;transform:translateX(-280px);transition:transform .25s cubic-bezier(.4,0,.2,1);z-index:300;width:240px !important;height:auto !important;margin:0 !important;}
  .sidebar.open{transform:translateX(0);}
  .main{margin-left:0 !important;padding-left:0;}
  .topbar{padding:0 14px;gap:8px;}
  .hamburger{display:flex !important;}
  .tb-greeting{font-size:14px;}
  .tb-date{display:none;}
  .kpi-row{grid-template-columns:1fr 1fr;gap:10px;}
  .kpi{padding:12px 14px;}
  .kpi-num{font-size:22px;}
  .mid-row{grid-template-columns:1fr;}
  .right-col{display:flex;flex-direction:column;}
  .bottom-row{grid-template-columns:1fr;}
  html,body{height:auto;min-height:100%;overflow:auto;}
  body{overflow-x:hidden;overflow-y:auto;position:relative;height:auto;display:block;}
  .content{overflow:visible;height:auto;padding:14px;max-width:100%;}
  .page{padding:14px;overflow:visible;}
  .tbl-card{overflow:hidden;max-width:100%;}
  .card-head{flex-wrap:wrap;gap:8px;}
  .search-box{max-width:100%;flex:1 1 100%;}
}

/* ── SETTINGS GEAR BUTTON ─────────────────────────────────────────────── */
.sb-icon-btn{background:none;border:1px solid rgba(255,255,255,.12);cursor:pointer;color:#666;padding:5px;width:28px;height:28px;border-radius:999px;transition:var(--tr);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.sb-icon-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--lime-lt);}
.sb-icon-btn svg{width:13px;height:13px;display:block;}

/* ── FILTER PILL ─────────────────────────────────────────────────────── */
.filter-pill{padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text2);font-family:var(--font);font-size:11px;font-weight:500;cursor:pointer;transition:all .12s;white-space:nowrap;}
.filter-pill:hover{border-color:rgba(0,0,0,.25);background:var(--surface2);}
.filter-pill.active{background:#000;color:var(--accent);border-color:#000;font-weight:700;}

/* ── SUBTASK FIXES ────────────────────────────────────────────────────── */
.subtask-panel{border-top:1px solid var(--border);background:var(--surface2);padding:12px 20px 14px 20px !important;animation:up .2s ease both;text-align:left !important;}
.subtask-list{text-align:left !important;}
.subtask-item{justify-content:flex-start !important;}
.subtask-add-btn{background:#000 !important;color:var(--accent) !important;}
.subtask-add-btn:hover{background:#222 !important;opacity:1 !important;}

/* ── PCARD TOP FIX ────────────────────────────────────────────────────── */
.pcard-top{display:flex;align-items:center;gap:6px;}
.pcard-priority-lbl{flex:1;}
.pcard-num{white-space:nowrap;flex-shrink:0;}
.pcard-cfg{flex-shrink:0;}

/* ── CUSTOM DATE PICKER ──────────────────────────────────────────────────── */
.date-pick-btn{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;border:1.5px solid var(--gray-bd);border-radius:999px;font-family:var(--font);font-size:13px;color:var(--text);background:white;cursor:pointer;transition:border-color .12s;text-align:left;}
.date-pick-btn:hover,.date-pick-btn:focus{border-color:#888;outline:none;}
.date-pick-dropdown{position:absolute;top:calc(100% + 6px);left:0;z-index:600;background:white;border:1px solid var(--border);border-radius:14px;box-shadow:0 8px 24px rgba(0,0,0,.12);padding:14px;min-width:240px;}
.dp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.dp-year{font-size:15px;font-weight:700;color:var(--text);}
.dp-nav{background:none;border:1px solid var(--border);border-radius:999px;width:26px;height:26px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--text);transition:border-color .12s;}
.dp-nav:hover{border-color:#888;}
.dp-months{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;}
.dp-month{padding:7px 4px;border-radius:999px;border:1px solid var(--border);background:white;font-family:var(--font);font-size:11px;font-weight:500;color:var(--text);cursor:pointer;transition:all .12s;text-align:center;}
.dp-month:hover{border-color:#888;background:var(--surface2);}
.dp-month.active{background:#000;color:var(--accent);border-color:#000;font-weight:700;}
.dp-days{margin-top:10px;}
.dp-days-header{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px;}
.dp-day-lbl{text-align:center;font-size:10px;font-weight:600;color:var(--text3);padding:2px 0;}
.dp-days-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;}
.dp-day{padding:5px 2px;border-radius:999px;border:none;background:none;font-family:var(--font);font-size:11px;color:var(--text);cursor:pointer;text-align:center;transition:all .1s;}
.dp-day:hover{background:var(--surface2);}
.dp-day.active{background:#000;color:var(--accent);font-weight:700;}
.dp-day.today{color:var(--accent);font-weight:700;}
.dp-day.empty{cursor:default;}
.dp-mode-toggle{display:flex;gap:6px;margin-bottom:12px;}
.dp-mode-btn{flex:1;padding:5px;border-radius:999px;border:1px solid var(--border);background:white;font-family:var(--font);font-size:11px;font-weight:500;cursor:pointer;transition:all .12s;}
.dp-mode-btn.active{background:#000;color:var(--accent);border-color:#000;}
