:root{--ac:#e8622a;--ad:rgba(232,98,42,.12);--ab:rgba(232,98,42,.3);--gn:#10b981;--yw:#f59e0b;--rd:#ef4444;--bl:#3b82f6;--pu:#8b5cf6;--r:10px;--rl:14px;--tr:.18s cubic-bezier(.4,0,.2,1);}
[data-theme="dark"]{--bg:#0c0c10;--b2:#111116;--b3:#17171e;--b4:#1c1c25;--bo:#1f1f2a;--bo2:#2a2a38;--tx:#ecedf5;--t2:#9899b0;--t3:#5a5b70;--cd:#111116;--ip:#17171e;--sh:0 8px 32px rgba(0,0,0,.45);--ss:0 2px 8px rgba(0,0,0,.3);}
[data-theme="light"]{--bg:#f2f2f7;--b2:#fff;--b3:#f0f0f5;--b4:#e4e4ed;--bo:#e2e2ec;--bo2:#c4c4d4;--tx:#12121c;--t2:#56576e;--t3:#9899b0;--cd:#fff;--ip:#f4f4f8;--sh:0 4px 20px rgba(0,0,0,.08);--ss:0 2px 6px rgba(0,0,0,.06);}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{color-scheme:dark light;}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg);color:var(--tx);min-height:100vh;transition:background var(--tr),color var(--tr);}
button,input,select,textarea{font-family:inherit;}
::-webkit-scrollbar{width:4px;height:4px;}::-webkit-scrollbar-track{background:transparent;}::-webkit-scrollbar-thumb{background:var(--bo2);border-radius:10px;}
input[type="date"]::-webkit-calendar-picker-indicator{opacity:.5;cursor:pointer;}
a{color:var(--ac);text-decoration:none;}a:hover{text-decoration:underline;}

/* LOADING */
#lb{position:fixed;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--ac),var(--yw),var(--ac));background-size:200%;animation:sh 1.2s infinite;z-index:9999;display:none;}
#lb.on{display:block;}@keyframes sh{0%{background-position:200%}100%{background-position:-200%}}

/* SCREENS */
.sc{display:none;min-height:100vh;}.sc.on{display:flex;}

/* CONFIG SCREEN */
#s-cfg{align-items:center;justify-content:center;background:var(--bg);}
.cfg-card{background:var(--b2);border:1px solid var(--bo2);border-radius:18px;width:480px;max-width:96vw;padding:36px;box-shadow:var(--sh);}
.cfg-steps{background:var(--b3);border:1px solid var(--bo);border-radius:var(--r);padding:14px 16px;margin-bottom:20px;font-size:12px;color:var(--t2);line-height:2.2;}
.cfg-steps strong{color:var(--tx);}
.cfg-steps code{font-family:'JetBrains Mono',monospace;background:var(--b4);padding:1px 6px;border-radius:4px;font-size:11px;color:var(--ac);}

/* AUTH SCREEN */
#s-auth {
  display: flex;
  min-height: 100vh;
  width: 100%;
  align-items: center;
  justify-content: center;
  background: var(--bg);
  position: relative;
  overflow: hidden;
}
#s-auth::before {
  content: '';
  position: absolute;
  width: 600px;
  height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(232, 98, 42, .07) 0%, transparent 70%);
  top: -200px;
  right: -200px;
  pointer-events: none;
}
.auth-card {
  background: var(--b2);
  border: 1px solid var(--bo2);
  border-radius: 18px;
  width: 420px;
  max-width: 96vw;
  padding: 36px;
  box-shadow: var(--sh);
  position: relative;
  z-index: 1;
  animation: fadeUp .3s ease;
}
.auth-logo{display:flex;align-items:center;gap:10px;margin-bottom:26px;}
.auth-mark{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#e8622a,#c03510);display:flex;align-items:center;justify-content:center;font-size:17px;box-shadow:0 4px 16px rgba(232,98,42,.4);}
.auth-tabs{display:flex;background:var(--b3);border-radius:var(--r);padding:3px;margin-bottom:22px;}
.atab{flex:1;padding:7px;text-align:center;border-radius:7px;font-size:13px;font-weight:700;cursor:pointer;transition:all var(--tr);color:var(--t2);}
.atab.on{background:var(--b2);color:var(--tx);box-shadow:var(--ss);}
.aerr{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);border-radius:var(--r);padding:10px 13px;font-size:12.5px;color:var(--rd);margin-bottom:14px;display:none;}
.aok{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25);border-radius:var(--r);padding:10px 13px;font-size:12.5px;color:var(--gn);margin-bottom:14px;display:none;}

/* APP */
#s-app{flex-direction:column;}
.app-w{display:flex;height:100vh;overflow:hidden;}

/* SIDEBAR */
.sidebar{width:232px;flex-shrink:0;background:var(--b2);border-right:1px solid var(--bo);display:flex;flex-direction:column;z-index:20;}
.org-sw{padding:14px 12px;border-bottom:1px solid var(--bo);position:relative;}
.org-btn{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:var(--r);cursor:pointer;transition:background var(--tr);width:100%;border:none;background:transparent;}
.org-btn:hover{background:var(--b3);}
.org-av{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;flex-shrink:0;}
.org-nm{font-size:13px;font-weight:700;flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.plan-b{font-size:9px;font-weight:700;padding:1px 6px;border-radius:100px;font-family:'JetBrains Mono',monospace;}
.pf{background:var(--b4);color:var(--t2);}
.ps{background:rgba(59,130,246,.12);color:var(--bl);}
.pp{background:rgba(16,185,129,.12);color:var(--gn);}
.pe{background:rgba(232,98,42,.12);color:var(--ac);}
.org-dd{position:absolute;top:calc(100% - 4px);left:10px;right:10px;background:var(--b2);border:1px solid var(--bo2);border-radius:var(--r);box-shadow:var(--sh);z-index:100;display:none;}
.org-dd.on{display:block;animation:fadeUp .15s ease;}
.odd-i{padding:9px 12px;cursor:pointer;font-size:12.5px;transition:background var(--tr);display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--bo);}
.odd-i:last-child{border-bottom:none;}.odd-i:hover{background:var(--b3);}
.odd-i.on{color:var(--ac);}
.nav{flex:1;padding:10px 8px;overflow-y:auto;}
.ng{font-size:9.5px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:var(--t3);padding:10px 8px 4px;}
.ni{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--r);font-size:13px;font-weight:600;color:var(--t2);cursor:pointer;transition:all var(--tr);margin-bottom:1px;position:relative;user-select:none;}
.ni:hover{background:var(--b3);color:var(--tx);}
.ni.on{background:var(--ad);color:var(--ac);}
.ni.on::before{content:'';position:absolute;left:0;top:18%;bottom:18%;width:3px;background:var(--ac);border-radius:0 3px 3px 0;}
.ni-ic{font-size:14px;width:17px;text-align:center;flex-shrink:0;}
.pill{margin-left:auto;font-size:10px;font-weight:700;padding:2px 6px;border-radius:100px;font-family:'JetBrains Mono',monospace;min-width:18px;text-align:center;}
.pr{background:var(--rd);color:#fff;}.pa{background:var(--ac);color:#fff;}.pm{background:var(--b4);color:var(--t2);}
.sb-bot{padding:10px 8px;border-top:1px solid var(--bo);}
.thbtn{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:var(--r);font-size:12.5px;font-weight:600;color:var(--t2);cursor:pointer;transition:all var(--tr);border:none;background:transparent;width:100%;margin-bottom:4px;}
.thbtn:hover{background:var(--b3);color:var(--tx);}
.sw-t{width:34px;height:18px;border-radius:100px;background:var(--bo2);position:relative;transition:background var(--tr);margin-left:auto;flex-shrink:0;}
.sw-t.on{background:var(--ac);}
.sw-t::after{content:'';position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform var(--tr);box-shadow:0 1px 4px rgba(0,0,0,.25);}
.sw-t.on::after{transform:translateX(16px);}
.sb-user{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--r);}
.sb-av{width:28px;height:28px;border-radius:7px;background:linear-gradient(135deg,var(--ac),#c03510);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:#fff;flex-shrink:0;}
.sb-out{display:flex;align-items:center;gap:6px;padding:7px 10px;border-radius:var(--r);font-size:12.5px;font-weight:600;color:var(--t3);cursor:pointer;transition:all var(--tr);border:none;background:transparent;width:100%;margin-top:2px;}
.sb-out:hover{background:rgba(239,68,68,.08);color:var(--rd);}

/* MAIN */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;}
.topbar{height:54px;background:var(--b2);border-bottom:1px solid var(--bo);display:flex;align-items:center;gap:12px;padding:0 22px;flex-shrink:0;}
.pt{font-size:14.5px;font-weight:800;flex:1;}
.ta{display:flex;align-items:center;gap:7px;}
.srch{display:flex;align-items:center;gap:7px;background:var(--b3);border:1px solid var(--bo);border-radius:var(--r);padding:6px 11px;transition:border-color var(--tr);width:210px;}
.srch:focus-within{border-color:var(--ac);}
.srch input{background:none;border:none;outline:none;color:var(--tx);font-size:12.5px;width:100%;}
.srch input::placeholder{color:var(--t3);}
.dbi{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--t3);font-weight:600;}
.dbd{width:7px;height:7px;border-radius:50%;background:var(--gn);box-shadow:0 0 6px var(--gn);}
.dbd.cn{background:var(--yw);animation:blink 1s infinite;}.dbd.er{background:var(--rd);}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.content{flex:1;overflow-y:auto;padding:20px 22px;background:var(--bg);transition:background var(--tr);}
.view{display:none;animation:fadeUp .22s ease;}.view.on{display:block;}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:var(--r);font-size:12.5px;font-weight:700;cursor:pointer;border:none;transition:all var(--tr);font-family:inherit;white-space:nowrap;}
.btn-p{background:var(--ac);color:#fff;box-shadow:0 2px 10px rgba(232,98,42,.35);}
.btn-p:hover{background:#d4541c;box-shadow:0 4px 16px rgba(232,98,42,.5);transform:translateY(-1px);}
.btn-g{background:transparent;color:var(--t2);border:1px solid var(--bo2);}
.btn-g:hover{background:var(--b3);color:var(--tx);}
.btn-d{background:rgba(239,68,68,.1);color:var(--rd);border:1px solid rgba(239,68,68,.2);}
.btn-d:hover{background:rgba(239,68,68,.2);}
.btn-sm{padding:5px 11px;font-size:11.5px;}.btn-xs{padding:3px 8px;font-size:11px;}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;}
.btn-fw{width:100%;justify-content:center;}

/* FORM */
.fg{display:flex;flex-direction:column;gap:4px;margin-bottom:12px;}
.fl{font-size:10.5px;font-weight:700;color:var(--t2);text-transform:uppercase;letter-spacing:.6px;}
.fi,.fs,.fta{background:var(--ip);border:1px solid var(--bo);border-radius:var(--r);padding:8px 11px;color:var(--tx);font-size:13px;transition:border-color var(--tr);outline:none;width:100%;}
.fi:focus,.fs:focus,.fta:focus{border-color:var(--ac);}
.fi::placeholder{color:var(--t3);}
.fs option{background:var(--b2);}
.fta{resize:vertical;font-family:'JetBrains Mono',monospace;font-size:11.5px;}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:11px;}
.ff{grid-column:1/-1;}

/* TAGS */
.tag{font-size:10px;font-weight:700;padding:2px 7px;border-radius:100px;font-family:'JetBrains Mono',monospace;}
.t-r{background:rgba(239,68,68,.12);color:var(--rd);border:1px solid rgba(239,68,68,.2);}
.t-y{background:rgba(245,158,11,.12);color:var(--yw);border:1px solid rgba(245,158,11,.2);}
.t-g{background:rgba(16,185,129,.12);color:var(--gn);border:1px solid rgba(16,185,129,.2);}
.t-a{background:var(--ad);color:var(--ac);border:1px solid var(--ab);}
.t-b{background:rgba(59,130,246,.12);color:var(--bl);border:1px solid rgba(59,130,246,.2);}

/* SECTION */
.sh{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px;}
.st{font-size:13px;font-weight:800;display:flex;align-items:center;gap:7px;}
.dvd{height:1px;background:var(--bo);margin:14px 0;}

/* STATS */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;}
.scard{background:var(--cd);border:1px solid var(--bo);border-radius:var(--rl);padding:16px 16px 14px;position:relative;overflow:hidden;transition:transform var(--tr),box-shadow var(--tr);}
.scard:hover{transform:translateY(-2px);box-shadow:var(--sh);}
.scard::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;}
.sc-a::after{background:linear-gradient(90deg,transparent,var(--ac),transparent);}
.sc-r::after{background:linear-gradient(90deg,transparent,var(--rd),transparent);}
.sc-y::after{background:linear-gradient(90deg,transparent,var(--yw),transparent);}
.sc-g::after{background:linear-gradient(90deg,transparent,var(--gn),transparent);}
.sc-ic{font-size:18px;margin-bottom:8px;opacity:.65;}
.sc-v{font-size:26px;font-weight:800;font-family:'JetBrains Mono',monospace;line-height:1;}
.sc-l{font-size:11px;color:var(--t2);margin-top:4px;font-weight:500;}

/* CARD GRID */
.cg{display:grid;grid-template-columns:repeat(auto-fill,minmax(295px,1fr));gap:11px;margin-bottom:20px;}
.ec{background:var(--cd);border:1px solid var(--bo);border-radius:var(--rl);padding:15px;cursor:pointer;transition:all var(--tr);border-left-width:3px;}
.ec:hover{transform:translateY(-2px);box-shadow:var(--sh);}
.ec-r{border-left-color:var(--rd);}.ec-y{border-left-color:var(--yw);}.ec-g{border-left-color:var(--gn);}.ec-m{border-left-color:var(--bo2);}
.ec-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:9px;}
.clav{width:36px;height:36px;border-radius:9px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;}
.ec-meta{display:flex;gap:10px;font-size:11px;color:var(--t2);margin-bottom:9px;flex-wrap:wrap;}
.prog{height:3px;background:var(--b4);border-radius:100px;overflow:hidden;}
.prog-f{height:100%;border-radius:100px;}
.ec-ft{display:flex;justify-content:space-between;margin-top:5px;}

/* TABLE */
.tw{background:var(--cd);border:1px solid var(--bo);border-radius:var(--rl);overflow:hidden;}
table{width:100%;border-collapse:collapse;}
thead th{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.9px;color:var(--t3);padding:10px 15px;text-align:left;background:var(--b3);border-bottom:1px solid var(--bo);}
tbody tr{border-bottom:1px solid var(--bo);transition:background var(--tr);cursor:pointer;}
tbody tr:last-child{border-bottom:none;}
tbody tr:hover{background:var(--b3);}
tbody td{padding:12px 15px;font-size:12.5px;}
.cb{font-size:9.5px;font-weight:700;padding:2px 7px;border-radius:100px;font-family:'JetBrains Mono',monospace;text-transform:uppercase;}
.cb-anual{background:rgba(59,130,246,.12);color:var(--bl);border:1px solid rgba(59,130,246,.2);}
.cb-semestral{background:rgba(139,92,246,.12);color:var(--pu);border:1px solid rgba(139,92,246,.2);}
.cb-trimestral{background:rgba(245,158,11,.12);color:var(--yw);border:1px solid rgba(245,158,11,.2);}
.cb-mensal{background:rgba(16,185,129,.12);color:var(--gn);border:1px solid rgba(16,185,129,.2);}
.sd{display:inline-flex;align-items:center;gap:5px;font-size:12px;}
.sd::before{content:'';width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.sd-ok::before{background:var(--gn);box-shadow:0 0 5px var(--gn);}
.sd-wn::before{background:var(--yw);box-shadow:0 0 5px var(--yw);animation:blink 1.6s infinite;}
.sd-dd::before{background:var(--rd);box-shadow:0 0 5px var(--rd);}

/* MODAL */
.ov{position:fixed;inset:0;background:rgba(0,0,0,.68);backdrop-filter:blur(5px);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .18s;}
.ov.open{opacity:1;pointer-events:all;}
.modal{background:var(--b2);border:1px solid var(--bo2);border-radius:15px;width:510px;max-width:96vw;max-height:90vh;overflow-y:auto;transform:scale(.96) translateY(10px);transition:transform .22s cubic-bezier(.34,1.5,.64,1);box-shadow:0 32px 80px rgba(0,0,0,.5);}
.ov.open .modal{transform:scale(1) translateY(0);}
.modal.wide{width:600px;}
.mh{padding:20px 20px 0;display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.mt{font-size:15px;font-weight:800;}
.mx{width:27px;height:27px;border-radius:7px;background:var(--b3);border:1px solid var(--bo);color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;transition:all var(--tr);}
.mx:hover{color:var(--tx);}
.mb{padding:0 20px 20px;}
.mf{padding:13px 20px;border-top:1px solid var(--bo);display:flex;justify-content:flex-end;gap:7px;}

/* CLIENT SEARCH DROPDOWN */
.cs-w{position:relative;}
.cs-dd{position:absolute;top:calc(100%+4px);left:0;right:0;background:var(--b2);border:1px solid var(--bo2);border-radius:var(--r);z-index:50;box-shadow:var(--sh);max-height:200px;overflow-y:auto;display:none;}
.cs-dd.on{display:block;}
.cd-i{padding:8px 11px;cursor:pointer;font-size:12.5px;transition:background var(--tr);display:flex;align-items:center;gap:8px;}
.cd-i:hover{background:var(--b3);}
.cd-av{width:25px;height:25px;border-radius:6px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;color:#fff;}
.cd-empty{padding:13px;text-align:center;color:var(--t3);font-size:12px;}

/* NOTIF */
.nb{background:var(--b3);border:1px solid var(--bo);border-radius:var(--r);padding:13px;margin-bottom:12px;}
.nb-t{font-size:10.5px;font-weight:700;color:var(--t2);text-transform:uppercase;letter-spacing:.6px;margin-bottom:9px;}
.ntl{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:9px;}
.ntag{display:flex;align-items:center;gap:4px;background:var(--ad);border:1px solid var(--ab);border-radius:5px;padding:2px 8px;font-size:11px;color:var(--ac);font-family:'JetBrains Mono',monospace;}
.ntx{cursor:pointer;opacity:.6;font-size:12px;}.ntx:hover{opacity:1;}
.na{display:flex;gap:7px;}

/* DETAIL */
.dh{background:var(--cd);border:1px solid var(--bo);border-radius:var(--rl);padding:20px;display:flex;align-items:center;gap:15px;margin-bottom:16px;flex-wrap:wrap;}
.d-av{width:56px;height:56px;border-radius:13px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:#fff;}
.d-nm{font-size:18px;font-weight:800;}.d-sb{font-size:12px;color:var(--t2);margin-top:3px;}
.d-sts{display:flex;gap:20px;margin-left:auto;}
.dsv{text-align:center;}.dsv-v{font-size:18px;font-weight:800;font-family:'JetBrains Mono',monospace;}.dsv-l{font-size:10px;color:var(--t2);margin-top:2px;}
.ir{display:grid;grid-template-columns:repeat(3,1fr);gap:11px;margin-bottom:16px;}
.ib{background:var(--cd);border:1px solid var(--bo);border-radius:var(--r);padding:12px;}
.ib-l{font-size:10px;font-weight:700;color:var(--t2);text-transform:uppercase;letter-spacing:.6px;margin-bottom:4px;}
.ib-v{font-size:12.5px;font-weight:600;}
.sl{display:flex;flex-direction:column;gap:9px;margin-bottom:16px;}
.sr{background:var(--cd);border:1px solid var(--bo);border-radius:var(--rl);padding:13px 16px;display:flex;align-items:center;gap:12px;transition:all var(--tr);}
.sr:hover{border-color:var(--bo2);background:var(--b3);}
.sr-i{flex:1;}.sr-nm{font-size:13px;font-weight:700;}
.sr-mt{font-size:11px;color:var(--t2);margin-top:2px;display:flex;gap:9px;align-items:center;}
.sr-r{display:flex;align-items:center;gap:9px;}

/* LOGS */
.li{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--bo);font-size:12px;}
.li:last-child{border-bottom:none;}.ld{width:7px;height:7px;border-radius:50%;flex-shrink:0;}

/* EMPTY */
.empty{text-align:center;padding:46px 20px;color:var(--t3);}
.e-ic{font-size:32px;margin-bottom:9px;opacity:.45;}.e-tx{font-size:12.5px;}

/* FILTERS */
.fb{display:flex;gap:5px;margin-bottom:14px;flex-wrap:wrap;}
.fbt{padding:5px 12px;border-radius:7px;font-size:11.5px;font-weight:600;cursor:pointer;border:1px solid var(--bo);background:transparent;color:var(--t2);transition:all var(--tr);font-family:inherit;}
.fbt:hover{color:var(--tx);border-color:var(--bo2);}.fbt.on{background:var(--ac);color:#fff;border-color:var(--ac);}

/* SCHEDULE */
.sg{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.scd{background:var(--cd);border:1px solid var(--bo);border-radius:var(--rl);padding:16px;}
.scd-h{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:11px;}
.scd-t{font-size:13px;font-weight:800;}.scd-s{font-size:11px;color:var(--t2);margin-top:1px;}
.stags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:9px;}
.stag{font-size:10.5px;font-family:'JetBrains Mono',monospace;background:var(--b3);border:1px solid var(--bo);border-radius:4px;padding:2px 7px;color:var(--t2);}
.sw{width:37px;height:20px;border-radius:100px;background:var(--bo2);position:relative;cursor:pointer;border:none;transition:background var(--tr);flex-shrink:0;}
.sw.on{background:var(--ac);}
.sw::after{content:'';position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform var(--tr);box-shadow:0 1px 4px rgba(0,0,0,.3);}
.sw.on::after{transform:translateX(17px);}

/* SETTINGS */
.set-g{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.set-c{background:var(--cd);border:1px solid var(--bo);border-radius:var(--rl);padding:16px;}
.set-c.full{grid-column:1/-1;}
.set-t{font-size:13px;font-weight:800;margin-bottom:3px;}
.set-s{font-size:11.5px;color:var(--t2);margin-bottom:13px;}
.smtpbg{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:4px 10px;border-radius:100px;margin-bottom:13px;}
.smtpbg-ok{background:rgba(16,185,129,.12);color:var(--gn);border:1px solid rgba(16,185,129,.2);}
.smtpbg-no{background:var(--b4);color:var(--t2);border:1px solid var(--bo);}

/* TEAM */
.mr{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--bo);}
.mr:last-child{border-bottom:none;}
.m-av{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;flex-shrink:0;}
.rb{font-size:10px;font-weight:700;padding:2px 7px;border-radius:100px;}
.rb-owner{background:rgba(232,98,42,.12);color:var(--ac);}
.rb-admin{background:rgba(59,130,246,.12);color:var(--bl);}
.rb-member{background:var(--b4);color:var(--t2);}

/* BILLING */
.plan-g{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;}
.plan-c{background:var(--cd);border:2px solid var(--bo);border-radius:var(--rl);padding:20px;position:relative;transition:all var(--tr);}
.plan-c:hover{border-color:var(--bo2);transform:translateY(-2px);box-shadow:var(--sh);}
.plan-c.curr{border-color:var(--ac);box-shadow:0 0 0 1px var(--ac);}
.plan-nm{font-size:15px;font-weight:800;margin-bottom:4px;}
.plan-pr{font-size:24px;font-weight:800;font-family:'JetBrains Mono',monospace;color:var(--ac);margin-bottom:2px;}
.plan-pd{font-size:11px;color:var(--t2);margin-bottom:14px;}
.plan-ft{font-size:12px;color:var(--t2);line-height:2;}
.plan-ft strong{color:var(--tx);}
.curr-badge{position:absolute;top:12px;right:12px;font-size:9px;font-weight:700;background:var(--ac);color:#fff;padding:2px 7px;border-radius:100px;}

/* PREVIEW */
.pv-g{background:var(--b3);border:1px solid var(--bo);border-radius:var(--r);padding:13px;margin-bottom:9px;}
.pv-gh{display:flex;align-items:center;gap:8px;margin-bottom:9px;}
.pv-row{display:flex;align-items:center;gap:7px;padding:6px 0;border-top:1px solid var(--bo);}

/* LIMIT WARNING */
.lim-bar{background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.2);border-radius:var(--r);padding:10px 14px;font-size:12.5px;display:flex;align-items:center;gap:10px;margin-bottom:16px;}

/* BACK */
.back{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--t2);cursor:pointer;transition:color var(--tr);margin-bottom:16px;background:none;border:none;font-family:inherit;font-weight:600;}
.back:hover{color:var(--tx);}

/* TOAST */
.toast{position:fixed;bottom:22px;right:22px;padding:10px 16px;border-radius:9px;font-size:12.5px;font-weight:700;z-index:9999;animation:fadeUp .18s ease;font-family:inherit;box-shadow:var(--sh);}
.t-ok{background:var(--gn);color:#fff;}.t-err{background:var(--rd);color:#fff;}.t-info{background:var(--ac);color:#fff;}
.aoa{font-family:'JetBrains Mono',monospace;}

/* ===== GESTÃO DE PLANOS (SUPERADMIN) ===== */
.plans-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 20px;
    margin-top: 20px;
}

.plan-card {
    background: var(--bg);
    border-radius: 16px;
    padding: 20px;
    border: 1px solid var(--br);
    transition: all 0.2s;
}

.plan-card:hover {
    border-color: var(--ac);
    box-shadow: 0 8px 24px rgba(0,0,0,0.1);
}

.plan-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.plan-badge {
    padding: 4px 12px;
    border-radius: 100px;
    font-size: 11px;
    font-weight: 600;
}

.plan-badge.active {
    background: #10b98120;
    color: #10b981;
}

.plan-badge.inactive {
    background: var(--bg);
    color: var(--t2);
    border: 1px solid var(--br);
}

.plan-price {
    font-size: 28px;
    font-weight: 700;
    margin: 16px 0;
    color: var(--ac);
}

.plan-limits {
    background: var(--bg2);
    border-radius: 12px;
    padding: 12px;
    margin: 16px 0;
}

.limit-item {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    border-bottom: 1px solid var(--br);
    font-size: 14px;
}

.limit-item:last-child {
    border-bottom: none;
}

.plan-features {
    margin: 16px 0;
}

.feature-item {
    font-size: 13px;
    color: var(--t2);
    margin: 6px 0;
    display: flex;
    align-items: center;
    gap: 6px;
}

.feature-item:before {
    content: "✓";
    color: var(--ac);
    font-weight: bold;
}

/* Modal */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0,0,0,0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    backdrop-filter: blur(4px);
}

.modal-card {
    background: var(--bg2);
    border-radius: 16px;
    padding: 24px;
    max-width: 600px;
    width: 90%;
    max-height: 90vh;
    overflow-y: auto;
    border: 1px solid var(--br);
    box-shadow: 0 20px 40px rgba(0,0,0,0.3);
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-bottom: 12px;
}

.btn-close {
    background: none;
    border: none;
    font-size: 20px;
    cursor: pointer;
    color: var(--t2);
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
}

.btn-close:hover {
    background: var(--br);
    color: var(--t1);
}

.fl-checkbox {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    padding: 8px 0;
}

.fl-checkbox input[type="checkbox"] {
    width: 18px;
    height: 18px;
    cursor: pointer;
    accent-color: var(--ac);
}

@media (max-width: 768px) {
    .form-row {
        grid-template-columns: 1fr;
    }
    
    .plans-grid {
        grid-template-columns: 1fr;
    }
}

.plan-c.current-plan {
    border: 2px solid var(--ac);
    box-shadow: 0 4px 12px rgba(232, 98, 42, 0.2);
    position: relative;
}

.plan-c.current-plan::after {
    content: "✓ Plano Atual";
    position: absolute;
    top: -10px;
    right: 10px;
    background: var(--ac);
    color: white;
    font-size: 11px;
    font-weight: 600;
    padding: 4px 12px;
    border-radius: 100px;
}

/* ===== POPUP DE UPGRADE ===== */
.plan-card-mini {
    background: var(--bg);
    border: 1px solid var(--br);
    border-radius: 12px;
    padding: 16px;
    cursor: pointer;
    transition: all 0.2s;
}

.plan-card-mini:hover {
    border-color: var(--ac);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

.plan-card-mini .plan-name {
    font-weight: 700;
    font-size: 16px;
    margin-bottom: 4px;
}

.plan-card-mini .plan-price {
    color: var(--ac);
    font-weight: 600;
    font-size: 14px;
    margin-bottom: 8px;
}

.plan-card-mini .plan-features {
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 12px;
    color: var(--t2);
}

/* ===== SUPER-ADMIN PAGE ===== */

 

/* ===== SEM-ACESSO PAGE ===== */
.sa-wrap {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: var(--bg);
}

.sa-container {
    width: 100%;
    max-width: 560px;
    animation: fadeUp .3s ease;
}

.sa-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
}

.sa-logo-mark {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: linear-gradient(135deg, #e8622a, #c03510);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 17px;
    box-shadow: 0 4px 16px rgba(232, 98, 42, .4);
    flex-shrink: 0;
}

.sa-logo-text {
    font-size: 16px;
    font-weight: 800;
    color: var(--tx);
}

.sa-user-bar {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--b2);
    border: 1px solid var(--bo);
    border-radius: var(--rl);
    padding: 10px 14px;
    margin-bottom: 12px;
}

.sa-card {
    background: var(--b2);
    border: 1px solid var(--bo2);
    border-radius: var(--rl);
    padding: 24px;
    box-shadow: var(--sh);
}

.sa-icon-wrap {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: rgba(239, 68, 68, .1);
    border: 1px solid rgba(239, 68, 68, .2);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    margin-bottom: 14px;
}

.sa-title {
    font-size: 20px;
    font-weight: 800;
    color: var(--tx);
    margin-bottom: 6px;
}

.sa-desc {
    font-size: 13px;
    color: var(--t2);
    line-height: 1.6;
    margin-bottom: 16px;
}

.sa-alert {
    background: rgba(239, 68, 68, .08);
    border: 1px solid rgba(239, 68, 68, .2);
    border-radius: var(--r);
    padding: 13px 15px;
    margin-bottom: 20px;
}

.sa-alert-title {
    font-size: 10.5px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .6px;
    color: var(--rd);
    margin-bottom: 5px;
}

.sa-alert-body {
    font-size: 12.5px;
    color: #fca5a5;
    line-height: 1.6;
    margin-bottom: 10px;
}

.sa-dates {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.sa-date-pill {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: rgba(239, 68, 68, .15);
    border-radius: 6px;
    padding: 4px 10px;
    font-size: 11.5px;
    color: #fca5a5;
    font-weight: 600;
    font-family: 'JetBrains Mono', monospace;
}

.sa-options-label {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--t3);
    margin-bottom: 8px;
}

.sa-option {
    display: flex;
    align-items: center;
    gap: 13px;
    padding: 12px 14px;
    background: transparent;
    border: 1px solid var(--bo);
    border-radius: var(--r);
    color: var(--tx);
    cursor: pointer;
    font-size: 13px;
    text-align: left;
    transition: all var(--tr);
    margin-bottom: 7px;
    text-decoration: none;
    width: 100%;
    font-family: inherit;
}

.sa-option:last-child {
    margin-bottom: 0;
}

.sa-option:hover {
    border-color: var(--ac);
    background: var(--ad);
    text-decoration: none;
}

.sa-option.danger:hover {
    border-color: var(--rd);
    background: rgba(239, 68, 68, .06);
}

.sa-opt-icon {
    width: 34px;
    height: 34px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    flex-shrink: 0;
}

.sa-opt-icon.green {
    background: rgba(16, 185, 129, .12);
}

.sa-opt-icon.blue {
    background: rgba(59, 130, 246, .12);
}

.sa-opt-icon.red {
    background: rgba(239, 68, 68, .12);
}

.sa-opt-body {
    flex: 1;
    min-width: 0;
}

.sa-opt-label {
    font-size: 13px;
    font-weight: 700;
    color: var(--tx);
    margin-bottom: 1px;
}

.sa-opt-desc {
    font-size: 11.5px;
    color: var(--t2);
}

.sa-opt-arrow {
    font-size: 17px;
    color: var(--t3);
    flex-shrink: 0;
}

.sa-email-reveal {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--b3);
    border: 1px solid var(--bo);
    border-radius: 7px;
    padding: 7px 10px;
    margin-top: 8px;
    font-size: 12px;
    font-family: 'JetBrains Mono', monospace;
    color: var(--t2);
}

.sa-copy-btn {
    margin-left: auto;
    background: var(--b4);
    border: none;
    border-radius: 5px;
    padding: 3px 9px;
    font-size: 11px;
    color: var(--t2);
    cursor: pointer;
    transition: all var(--tr);
    font-family: inherit;
    font-weight: 600;
    white-space: nowrap;
}

.sa-copy-btn:hover {
    background: var(--ac);
    color: #fff;
}

@media(max-width: 480px) {
    .sa-wrap {
        padding: 12px;
        align-items: flex-start;
        padding-top: 20px;
    }
    
    .sa-card {
        padding: 16px;
    }
    
    .sa-title {
        font-size: 17px;
    }
    
    .sa-dates {
        flex-direction: column;
    }
}

/* Estatísticas do Dashboard */
.stats-grid {
    display: grid;
    gap: 16px;
    margin-bottom: 20px;
}

.stat-card {
    background: var(--bg2);
    border-radius: 12px;
    padding: 18px;
    border: 1px solid var(--br);
    transition: transform 0.2s;
}

.stat-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--sh);
}

.stat-label {
    font-size: 12px;
    color: var(--t2);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 8px;
}

.stat-value {
    font-size: 28px;
    font-weight: 700;
    font-family: 'JetBrains Mono', monospace;
    line-height: 1.2;
}

/* Distribuição de planos */
.plan-distribution {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
    margin-top: 16px;
}

.plan-bar {
    flex: 1;
    min-width: 120px;
}

.plan-bar-label {
    display: flex;
    justify-content: space-between;
    margin-bottom: 4px;
    font-size: 13px;
}

.plan-bar-progress {
    height: 8px;
    background: var(--b4);
    border-radius: 4px;
    overflow: hidden;
}

.plan-bar-fill {
    height: 100%;
    border-radius: 4px;
    transition: width 0.3s;
}

/* Linha do tempo */
.timeline-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 0;
    border-bottom: 1px solid var(--br);
}

.timeline-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

.timeline-content {
    flex: 1;
    font-size: 13px;
}

.timeline-time {
    font-size: 11px;
    color: var(--t2);
    font-family: 'JetBrains Mono', monospace;
}

/* ===== SISTEMA DE TEMPLATES ===== */
.template-bar {
  background: var(--b3);
  border: 1px solid var(--bo);
  border-radius: var(--r);
  padding: 12px 16px;
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.template-select {
  min-width: 250px;
  flex: 1;
}

.template-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.template-manager-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border-bottom: 1px solid var(--br);
  transition: background 0.2s;
}

.template-manager-item:hover {
  background: var(--b3);
}

.template-manager-item:last-child {
  border-bottom: none;
}

.template-info {
  flex: 1;
}

.template-name {
  font-weight: 700;
  font-size: 14px;
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.template-badge {
  font-size: 10px;
  background: var(--ac);
  color: white;
  padding: 2px 8px;
  border-radius: 100px;
}

.template-preview {
  font-size: 12px;
  color: var(--t2);
  font-family: 'JetBrains Mono', monospace;
  background: var(--b4);
  padding: 6px 10px;
  border-radius: 6px;
  margin-top: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 400px;
}

.template-actions {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}

@media (max-width: 768px) {
  .template-bar {
    flex-direction: column;
    align-items: stretch;
  }
  
  .template-select {
    width: 100%;
  }
  
  .template-actions {
    justify-content: flex-end;
  }
}

/* ============================================================
   DASHBOARD MOBILE - CABEÇALHO E MENU
   ============================================================ */

/* Cabeçalho mobile (aparece apenas em ecrãs pequenos) */
.mobile-dash-header {
  display: none;
  background: var(--b2);
  border-bottom: 1px solid var(--bo);
  padding: 8px 16px;
  position: sticky;
  top: 0;
  z-index: 100;
}

.mobile-dash-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.mobile-dash-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
}

.mobile-dash-avatar {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: var(--ac-g);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  font-weight: 800;
  color: #fff;
  flex-shrink: 0;
}

.mobile-dash-name {
  font-weight: 700;
  font-size: 15px;
  line-height: 1.3;
}

.mobile-dash-org {
  font-size: 12px;
  color: var(--t2);
}

.mobile-dash-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.mobile-dash-action {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  background: var(--b3);
  border: 1px solid var(--bo);
  color: var(--t2);
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--tr);
}

.mobile-dash-action:hover,
.mobile-dash-action:active {
  background: var(--ac);
  color: #fff;
  border-color: var(--ac);
}

.mobile-dash-menu-btn {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  background: var(--b3);
  border: 1px solid var(--bo);
  color: var(--t2);
  font-size: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--tr);
}

.mobile-dash-menu-btn:hover,
.mobile-dash-menu-btn:active {
  background: var(--ac);
  color: #fff;
  border-color: var(--ac);
}

/* Menu mobile (desliza da esquerda) */
.mobile-dash-menu {
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: 85%;
  max-width: 320px;
  background: var(--b2);
  border-right: 1px solid var(--bo);
  z-index: 1000;
  transform: translateX(-100%);
  transition: transform 0.3s ease;
  overflow-y: auto;
  box-shadow: var(--sh);
}

.mobile-dash-menu.open {
  transform: translateX(0);
}

.mobile-dash-menu-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 20px 16px;
  border-bottom: 1px solid var(--bo);
  background: var(--b3);
}

.mobile-dash-menu-close {
  margin-left: auto;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: var(--b4);
  border: 1px solid var(--bo);
  color: var(--t2);
  font-size: 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mobile-dash-menu .nav {
  padding: 16px;
}

.mobile-dash-menu .ni {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
}

.mobile-dash-menu .ni .pill {
  margin-left: auto;
}

.mobile-dash-menu-footer {
  padding: 20px 16px;
  border-top: 1px solid var(--bo);
  margin-top: 20px;
}

.mobile-dash-menu-footer .sb-out {
  width: 100%;
  justify-content: center;
}

/* Media query para mobile */
@media (max-width: 1024px) {
  .mobile-dash-header {
    display: block;
  }
  
  .sidebar {
    display: none !important;
  }
  
  .app-w {
    flex-direction: column;
  }
  
  .main {
    width: 100%;
  }
  
  .topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: auto;
    padding: 8px 16px;
    gap: 12px;
  }
  
  /* PTITLE OCULTO */
  .pt {
    display: none !important;
  }
  
  .ta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    gap: 12px;
  }
  
  /* Indicador Supabase - alinhado à esquerda */
  .dbi {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 11px;
    color: var(--t3);
    font-weight: 600;
    white-space: nowrap;
    margin: 0;
    flex-shrink: 0;
  }
  
  /* Caixa de pesquisa - alinhada à direita */
  .srch {
    display: flex;
    align-items: center;
    gap: 7px;
    background: var(--b3);
    border: 1px solid var(--bo);
    border-radius: var(--r);
    padding: 6px 11px;
    transition: border-color var(--tr);
    flex: 0 1 auto;
    min-width: 100px;
    max-width: 200px;
    margin: 0;
  }
  
  .srch input {
    background: none;
    border: none;
    outline: none;
    color: var(--tx);
    font-size: 12.5px;
    width: 100%;
  }
  
  .srch input::placeholder {
    color: var(--t3);
  }
  
  /* Botões visíveis até 768px */
  .ta .btn {
    display: flex;
    flex: 0 0 auto;
    justify-content: center;
    white-space: nowrap;
    padding: 6px 12px;
    margin: 0;
  }
  
  /* Stats */
  .stats {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
  
  .scard {
    padding: 12px;
  }
  
  .sc-v {
    font-size: 20px;
  }
  
  /* Tables com scroll */
  .tw {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  
  table {
    min-width: 700px;
  }
  
  /* Cards */
  .cg {
    grid-template-columns: 1fr;
  }
  
  /* Detail view */
  .dh {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }
  
  .d-sts {
    margin-left: 0;
    width: 100%;
    justify-content: space-around;
  }
  
  .ir {
    grid-template-columns: 1fr;
  }
  
  .sr {
    flex-direction: column;
    align-items: flex-start;
  }
  
  .sr-r {
    width: 100%;
    justify-content: space-between;
    margin-top: 8px;
  }
  
  /* Settings */
  .set-g {
    grid-template-columns: 1fr;
  }
  
  .fr {
    grid-template-columns: 1fr;
  }
  
  /* Billing */
  .plan-g {
    grid-template-columns: 1fr;
  }
  
  /* Templates */
  .template-bar {
    flex-direction: column;
    align-items: stretch;
  }
  
  .template-select {
    width: 100%;
  }
  
  /* Modals */
  .modal {
    width: 95vw;
    max-width: 95vw;
  }
  
  .modal.wide {
    width: 95vw;
  }
}

@media (max-width: 768px) {
  .topbar {
    padding: 8px 12px;
    gap: 8px;
  }
  
  .ta {
    gap: 8px;
  }
  
  .dbi {
    font-size: 10px;
  }
  
  .srch {
    min-width: 160px;
    padding: 5px 8px;
  }
  
  .srch input {
    font-size: 12px;
  }
  
  /* A partir de 768px, os botões ainda estão visíveis */
  .ta .btn {
    display: flex;
    padding: 5px 10px;
    font-size: 11.5px;
  }
}

@media (max-width: 1024px) {
  .topbar {
    padding: 22px 22px;
  }
  
  .ta {
    gap: 6px;
  }
  
  .dbi {
    font-size: 10px;
    flex-shrink: 0;
  }
  
  .srch {
    flex: 1;
    min-width: 140px;
    padding: 5px 8px;
  }
  
  /* BOTÕES OCULTOS A PARTIR DE 1024px */
  .ta .btn {
    display: none !important;
  }
  
  .stats {
    grid-template-columns: 1fr;
    gap: 6px;
  }
  
  .scard {
    padding: 10px;
  }
  
  .sc-ic {
    font-size: 16px;
  }
  
  .sc-v {
    font-size: 20px;
  }
  
  .mobile-dash-actions {
    gap: 4px;
  }
  
  .mobile-dash-action,
  .mobile-dash-menu-btn {
    width: 36px;
    height: 36px;
    font-size: 16px;
  }
  
  /* Ajustes para o cabeçalho mobile */
  .mobile-dash-header {
    padding: 16px 12px;
  }
  
  .mobile-dash-logo {
    gap: 8px;
  }
  
  .mobile-dash-avatar {
    width: 36px;
    height: 36px;
    font-size: 14px;
  }
  
  .mobile-dash-name {
    font-size: 14px;
  }
  
  .mobile-dash-org {
    font-size: 11px;
  }
}

@media (max-width: 360px) {
  .topbar {
    padding: 4px 8px;
  }
  
  .dbi {
    font-size: 9px;
  }
  
  .srch {
    min-width: 120px;
    padding: 4px 6px;
  }
  
  .srch input {
    font-size: 11px;
  }
  
  .mobile-dash-avatar {
    width: 32px;
    height: 32px;
    font-size: 12px;
  }
  
  .mobile-dash-name {
    font-size: 13px;
  }
  
  .mobile-dash-org {
    font-size: 10px;
  }
  
  .mobile-dash-action,
  .mobile-dash-menu-btn {
    width: 32px;
    height: 32px;
    font-size: 14px;
  }
}

/* ===== MENU MOBILE ATIVO ===== */
.mobile-dash-menu .ni.on {
  background: var(--ad);
  color: var(--ac);
}

.mobile-dash-menu .ni.on::before {
  content: '';
  position: absolute;
  left: 0;
  top: 18%;
  bottom: 18%;
  width: 3px;
  background: var(--ac);
  border-radius: 0 3px 3px 0;
}


/* Topbar com transição suave - VERSÃO CORRIGIDA */
.topbar {
  transition: transform 0.3s ease, opacity 0.3s ease;
  position: sticky;
  top: 0;
  z-index: 90;
  background: var(--b2);
  border-bottom: 1px solid var(--bo); /* Garantir que tem borda */
  will-change: transform; /* Otimização para animações */
}

.topbar.hidden {
  transform: translateY(-100%);
  opacity: 0;
  pointer-events: none;
}

/* Garantir que o conteúdo abaixo não fica com espaço vazio */
.main {
  position: relative;
}
/* ═══════════════════════════════════════════════════════
   FINANCIAL DASHBOARD — stats-5, fin-block, top-clients, chart
═══════════════════════════════════════════════════════ */

/* 5 stat cards */
.stats-5 { grid-template-columns: repeat(5, 1fr); }
.sc-p::after { background: linear-gradient(90deg, transparent, #8b5cf6, transparent); }

/* Financial summary block */
.fin-block {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}
.fin-card {
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--cd);
  border: 1px solid var(--bo);
  border-radius: var(--rl);
  padding: 16px 18px;
  border-left: 3px solid transparent;
  transition: transform var(--tr), box-shadow var(--tr);
}
.fin-card:hover { transform: translateY(-2px); box-shadow: var(--sh); }
.fin-rec { border-left-color: var(--gn); }
.fin-exp { border-left-color: var(--rd); }
.fin-bal { border-left-color: var(--ac); }
.fin-bal.negative { border-left-color: var(--rd); }
.fin-ic {
  font-size: 22px;
  font-weight: 900;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.fin-rec .fin-ic  { background: #10b98120; color: var(--gn); }
.fin-exp .fin-ic  { background: #ef444420; color: var(--rd); }
.fin-bal .fin-ic  { background: #e8622a20; color: var(--ac); }
.fin-bal.negative .fin-ic { background: #ef444420; color: var(--rd); }
.fin-v {
  font-size: 17px;
  font-weight: 800;
  font-family: 'JetBrains Mono', monospace;
  line-height: 1.1;
}
.fin-l { font-size: 11px; color: var(--t2); margin-top: 3px; }

/* Bottom row: top clients + monthly chart */
.fin-bottom {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 24px;
}
.fin-panel {
  background: var(--cd);
  border: 1px solid var(--bo);
  border-radius: var(--rl);
  padding: 16px 18px;
}

/* Top clients list */
.top-cl-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 0;
  border-bottom: 1px solid var(--bo);
  cursor: pointer;
  transition: opacity .15s;
}
.top-cl-row:last-child { border-bottom: none; }
.top-cl-row:hover { opacity: .8; }
.top-cl-bar-wrap {
  flex: 1;
  height: 5px;
  background: var(--bg2);
  border-radius: 99px;
  overflow: hidden;
}
.top-cl-bar { height: 100%; border-radius: 99px; transition: width .5s ease; }

/* Monthly bar chart */
.month-chart {
  display: flex;
  align-items: flex-end;
  gap: 6px;
  height: 90px;
  padding-top: 8px;
}
.month-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
  gap: 3px;
  height: 100%;
  justify-content: flex-end;
}
.month-bars {
  display: flex;
  gap: 2px;
  align-items: flex-end;
  width: 100%;
  flex: 1;
}
.month-bar {
  flex: 1;
  border-radius: 3px 3px 0 0;
  min-height: 2px;
  transition: height .5s ease;
}
.month-lbl {
  font-size: 9px;
  color: var(--t3);
  font-family: 'JetBrains Mono', monospace;
  white-space: nowrap;
}
.month-tooltip {
  position: absolute;
  background: var(--bg1);
  border: 1px solid var(--bo);
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 11px;
  pointer-events: none;
  z-index: 99;
  white-space: nowrap;
  box-shadow: var(--sh);
}

/* Responsive */
@media (max-width: 900px) {
  .stats-5 { grid-template-columns: repeat(3, 1fr); }
  .fin-block { grid-template-columns: repeat(2, 1fr); }
  .fin-bottom { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .stats-5 { grid-template-columns: repeat(2, 1fr); }
  .fin-block { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════
   ANÁLISE FINANCEIRA — view completa
═══════════════════════════════════════════════════════ */

.fin-page { padding: 0 0 32px; }

/* Filtros */
.fin-filters {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 20px;
  background: var(--cd);
  border: 1px solid var(--bo);
  border-radius: var(--rl);
  padding: 14px 16px;
}
.fin-filter-group { display: flex; flex-direction: column; gap: 4px; }
.fin-filter-lbl { font-size: 10px; font-weight: 700; color: var(--t3); text-transform: uppercase; letter-spacing: 1px; }
.fin-sel { padding: 6px 10px; font-size: 12px; min-width: 140px; }

/* KPI row */
.fin-kpi-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin-bottom: 16px;
}
.fin-kpi {
  background: var(--cd);
  border: 1px solid var(--bo);
  border-radius: var(--rl);
  padding: 14px 16px;
  border-top: 2px solid transparent;
  transition: transform var(--tr), box-shadow var(--tr);
}
.fin-kpi:hover { transform: translateY(-2px); box-shadow: var(--sh); }
.fin-kpi-ic { font-size: 16px; margin-bottom: 6px; opacity: .7; }
.fin-kpi-val {
  font-size: 15px;
  font-weight: 800;
  font-family: 'JetBrains Mono', monospace;
  line-height: 1.1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.fin-kpi-lbl { font-size: 10px; color: var(--t2); margin-top: 4px; line-height: 1.3; }

/* Main grid */
.fin-main-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 16px;
}
.fin-panel {
  background: var(--cd);
  border: 1px solid var(--bo);
  border-radius: var(--rl);
  padding: 18px;
}
.fin-panel-title {
  font-size: 12px;
  font-weight: 700;
  color: var(--t2);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 16px;
}

/* Bar chart */
.fin-chart-wrap {
  display: flex;
  align-items: flex-end;
  gap: 8px;
  height: 160px;
  padding-bottom: 0;
  position: relative;
}
.fin-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
  height: 100%;
  gap: 0;
  justify-content: flex-end;
  position: relative;
  cursor: pointer;
}
.fin-col:hover .fin-bars { opacity: .85; }
.fin-bars {
  display: flex;
  gap: 2px;
  align-items: flex-end;
  width: 100%;
  flex: 1;
  transition: opacity .15s;
}
.fin-bar {
  flex: 1;
  border-radius: 3px 3px 0 0;
  min-height: 2px;
  transition: height .5s ease;
  position: relative;
}
.fin-bar-sal {
  width: 2px;
  border-radius: 2px;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  transition: height .5s ease;
}
.fin-col-lbl {
  font-size: 9px;
  color: var(--t3);
  font-family: 'JetBrains Mono', monospace;
  margin-top: 5px;
  white-space: nowrap;
}
.fin-chart-legend {
  display: flex;
  align-items: center;
  font-size: 11px;
  color: var(--t2);
  margin-top: 12px;
}
.fin-leg-dot {
  width: 8px;
  height: 8px;
  border-radius: 2px;
  display: inline-block;
  margin-right: 4px;
}

/* Top list */
.fin-top-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--bo);
  cursor: pointer;
  transition: opacity .15s;
}
.fin-top-row:last-child { border-bottom: none; }
.fin-top-row:hover { opacity: .75; }
.fin-top-bar-wrap {
  flex: 1;
  height: 4px;
  background: var(--bg2);
  border-radius: 99px;
  overflow: hidden;
}
.fin-top-bar { height: 100%; border-radius: 99px; }

/* Tooltip */
.fin-tip {
  position: fixed;
  background: var(--b2);
  border: 1px solid var(--bo);
  border-radius: 10px;
  padding: 10px 14px;
  font-size: 11px;
  pointer-events: none;
  z-index: 999;
  white-space: nowrap;
  box-shadow: 0 8px 24px rgba(0,0,0,.25);
  line-height: 1.7;
}

/* Responsive */
@media (max-width: 1100px) {
  .fin-kpi-row { grid-template-columns: repeat(3, 1fr); }
  .fin-main-grid { grid-template-columns: 1fr; }
  .fin-top-panel { order: -1; }
}
@media (max-width: 700px) {
  .fin-kpi-row { grid-template-columns: repeat(2, 1fr); }
  .fin-filters { flex-direction: column; }
  .fin-sel { min-width: unset; width: 100%; }
}
