:root{
  --background:oklch(1 0 0); --foreground:oklch(0.145 0 0);
  --card:oklch(1 0 0); --card-foreground:oklch(0.145 0 0);
  --muted:oklch(0.97 0 0); --muted-foreground:oklch(0.556 0 0);
  --border:oklch(0.922 0 0);
  --destructive:oklch(0.577 0.245 27.325);
  --warn:oklch(0.75 0.16 80); --ok:oklch(0.70 0.16 150);
  --radius:0.625rem;
  --brand:oklch(0.61 0.24 300);
  --brand-2:color-mix(in oklab, var(--brand) 85%, white 15%);
  --font-sans:'Geist',system-ui,-apple-system,sans-serif;
  --font-mono:'Geist Mono',ui-monospace,monospace;
}
.dark{
  --background:oklch(0.145 0 0); --foreground:oklch(0.985 0 0);
  --card:oklch(0.2 0 0); --card-foreground:oklch(0.985 0 0);
  --muted:oklch(0.269 0 0); --muted-foreground:oklch(0.708 0 0);
  --border:oklch(0.28 0 0);
  --brand-2:color-mix(in oklab, var(--brand) 80%, black 20%);
}
[data-brand="purple"]{--brand:oklch(0.61 0.24 300)}
[data-brand="blue"]{--brand:oklch(0.65 0.17 240)}
[data-brand="teal"]{--brand:oklch(0.70 0.12 180)}
[data-brand="orange"]{--brand:oklch(0.73 0.19 60)}
[data-brand="pink"]{--brand:oklch(0.71 0.28 360)}

*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-sans);background:var(--background);color:var(--foreground);-webkit-font-smoothing:antialiased}
.page{padding:12px}
@media(min-width:640px){.page{padding:24px}}
.shell{max-width:1400px;margin:0 auto;border-radius:1.5rem;background:var(--card);box-shadow:0 1px 3px rgba(0,0,0,.08);outline:1px solid var(--border);overflow:hidden}
.layout{display:flex;min-height:92vh}

/* sidebar */
.sidebar{background:linear-gradient(to bottom,var(--brand),var(--brand-2));color:#fff;width:208px;border-radius:1.5rem 0 0 1.5rem;display:flex;flex-direction:column;transition:width .3s;flex-shrink:0}
.sidebar.collapsed{width:78px}
.sb-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:20px 16px}
.sb-logo{display:flex;align-items:center;gap:10px;min-width:0}
.sb-logo .mark{width:36px;height:36px;border-radius:.75rem;background:rgba(255,255,255,.2);display:grid;place-items:center;font-weight:700;flex-shrink:0}
.sb-logo .nm{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden}
.sb-toggle{background:rgba(255,255,255,.2);border:none;color:#fff;border-radius:.5rem;padding:6px;cursor:pointer;line-height:0}
.sb-toggle:hover{background:rgba(255,255,255,.3)}
.sidebar.collapsed .nm,.sidebar.collapsed .sb-section,.sidebar.collapsed .navitem .lbl{display:none}
.sb-section{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.6);padding:14px 18px 6px}
.nav{flex:1;overflow-y:auto;padding:0 12px}
.navitem{display:flex;align-items:center;gap:12px;border-radius:.75rem;padding:11px 12px;color:rgba(255,255,255,.9);cursor:pointer;font-size:13px;border:none;background:none;width:100%;text-align:left;transition:background .15s}
.navitem:hover{background:rgba(255,255,255,.12)}
.navitem.active{background:#fff;color:var(--brand);font-weight:600}
.navitem .ic{width:18px;height:18px;flex-shrink:0}
.navitem .cnt{margin-left:auto;font-size:11px;opacity:.7}
.navitem.active .cnt{opacity:.9}

/* main */
.main{flex:1;background:var(--muted);border-radius:0 1.5rem 1.5rem 0;padding:20px;overflow:auto;min-width:0}
@media(min-width:768px){.main{padding:28px}}
.topbar{position:sticky;top:-1px;z-index:30;display:flex;align-items:center;gap:12px;background:color-mix(in oklab,var(--background) 75%,transparent);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);border-radius:.75rem;padding:10px 14px;margin-bottom:22px}
.menu-btn{display:none;background:none;border:none;color:var(--foreground);cursor:pointer;padding:6px;border-radius:9999px}
.menu-btn:hover{background:var(--muted)}
.tb-title{font-size:15px;font-weight:600}
.tb-title small{display:block;font-size:11px;font-weight:400;color:var(--muted-foreground)}
.search{flex:1;max-width:380px;position:relative}
.search input{width:100%;border:1px solid var(--border);background:var(--background);color:var(--foreground);border-radius:9999px;padding:9px 14px 9px 34px;font-size:13px;font-family:inherit}
.search input:focus{outline:none;border-color:var(--brand)}
.search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--muted-foreground);width:15px;height:15px}
.tb-actions{display:flex;align-items:center;gap:6px;margin-left:auto}
.icon-btn{background:none;border:none;color:var(--foreground);cursor:pointer;padding:8px;border-radius:9999px;line-height:0}
.icon-btn:hover{background:var(--muted)}
.swatches{display:flex;gap:5px;align-items:center;padding-left:6px}
.sw{width:18px;height:18px;border-radius:9999px;border:2px solid transparent;cursor:pointer}
.sw.on{border-color:var(--foreground)}

/* kpis */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:18px}
.kpi{border-radius:1rem;background:var(--card);padding:18px;box-shadow:0 1px 3px rgba(0,0,0,.05);outline:1px solid var(--border)}
.kpi .k-top{display:flex;align-items:center;justify-content:space-between}
.kpi .k-lbl{font-size:12px;color:var(--muted-foreground);font-weight:500}
.kpi .k-dot{width:10px;height:10px;border-radius:9999px}
.kpi .k-val{font-size:30px;font-weight:700;margin-top:8px;line-height:1}
.kpi .k-sub{font-size:11px;color:var(--muted-foreground);margin-top:4px}

.grid2{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:1080px){.grid2{grid-template-columns:1fr 300px}}
.card{border-radius:1rem;background:var(--card);padding:20px;box-shadow:0 1px 3px rgba(0,0,0,.05);outline:1px solid var(--border)}
.card h3{font-size:13px;font-weight:600;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;gap:8px}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:14px}
.chip{font-size:12px;padding:6px 12px;border-radius:9999px;border:1px solid var(--border);background:var(--background);color:var(--muted-foreground);cursor:pointer;font-family:inherit}
.chip.on{background:var(--brand);border-color:var(--brand);color:#fff}

/* table */
.tbl-wrap{overflow-x:auto;margin:0 -4px}
table{width:100%;border-collapse:collapse;font-size:13px;min-width:720px}
thead th{text-align:left;padding:9px 10px;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted-foreground);border-bottom:1px solid var(--border);white-space:nowrap;cursor:pointer;user-select:none}
thead th:hover{color:var(--foreground)}
tbody td{padding:10px;border-bottom:1px solid var(--border);vertical-align:middle}
tbody tr:hover{background:var(--muted)}
.mdl{font-weight:600}
.mdl small{display:block;font-weight:400;color:var(--muted-foreground);font-size:11px}
.date-in{border:1px solid transparent;background:none;color:var(--foreground);font-family:var(--font-mono);font-size:12px;padding:4px 6px;border-radius:6px;cursor:pointer}
.date-in:hover{border-color:var(--border);background:var(--background)}
.date-in:focus{outline:none;border-color:var(--brand);background:var(--background)}
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:4px 9px;border-radius:9999px;white-space:nowrap}
.badge::before{content:"";width:7px;height:7px;border-radius:9999px;background:currentColor}
.b-venc{color:var(--destructive);background:color-mix(in oklab,var(--destructive) 14%,transparent)}
.b-crit{color:var(--destructive);background:color-mix(in oklab,var(--destructive) 14%,transparent)}
.b-aten{color:var(--warn);background:color-mix(in oklab,var(--warn) 18%,transparent)}
.b-ok{color:var(--ok);background:color-mix(in oklab,var(--ok) 16%,transparent)}
.b-sem{color:var(--muted-foreground);background:var(--muted)}
.dias{font-family:var(--font-mono);font-size:12px;font-weight:500}

/* donut */
.donut-wrap{display:grid;place-items:center;padding:8px 0 4px}
.donut{width:160px;height:160px;border-radius:9999px;display:grid;place-items:center}
.donut .hole{width:108px;height:108px;border-radius:9999px;background:var(--card);display:grid;place-items:center;text-align:center}
.donut .hole .n{font-size:26px;font-weight:700}
.donut .hole .t{font-size:10px;color:var(--muted-foreground)}
.legend{display:flex;flex-direction:column;gap:9px;margin-top:14px}
.legend .li{display:flex;align-items:center;gap:9px;font-size:12px}
.legend .li .d{width:10px;height:10px;border-radius:3px}
.legend .li .v{margin-left:auto;font-weight:600;font-family:var(--font-mono)}
.foot{font-size:11px;color:var(--muted-foreground);margin-top:14px;text-align:center}
.empty{text-align:center;color:var(--muted-foreground);padding:30px;font-size:13px}

/* modal / pop-up de detalhe */
.modal-overlay{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;padding:16px;background:rgba(0,0,0,.55);backdrop-filter:blur(3px)}
.modal-overlay.show{display:flex;animation:fadein .15s ease}
@keyframes fadein{from{opacity:0}to{opacity:1}}
.modal{width:100%;max-width:460px;max-height:90vh;overflow:auto;background:var(--card);color:var(--foreground);border-radius:1.25rem;outline:1px solid var(--border);box-shadow:0 24px 60px rgba(0,0,0,.35);animation:pop .18s ease}
@keyframes pop{from{transform:translateY(10px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal-head{position:relative;padding:22px 22px 18px;color:#fff;background:linear-gradient(135deg,var(--brand),var(--brand-2));border-radius:1.25rem 1.25rem 0 0}
.modal-head .m-unit{font-size:11px;letter-spacing:.08em;text-transform:uppercase;opacity:.85}
.modal-head .m-model{font-size:19px;font-weight:700;margin-top:3px;line-height:1.2}
.modal-head .m-tipo{font-size:12px;opacity:.9;margin-top:2px}
.modal-head .badge{background:rgba(255,255,255,.22);color:#fff;margin-top:12px}
.modal-head .badge::before{background:#fff}
.modal-x{position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:9999px;border:none;background:rgba(255,255,255,.22);color:#fff;font-size:15px;cursor:pointer;line-height:1}
.modal-x:hover{background:rgba(255,255,255,.35)}
.modal-body{padding:8px 22px 22px;display:grid;grid-template-columns:1fr 1fr;gap:2px}
.m-field{padding:12px 2px;border-bottom:1px solid var(--border)}
.m-field.full{grid-column:1 / -1}
.m-lbl{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted-foreground);margin-bottom:5px}
.m-val{font-size:14px;font-weight:500;word-break:break-word}
.m-date{font-family:var(--font-mono);font-size:13px;border:1px solid var(--border);background:var(--background);color:var(--foreground);border-radius:8px;padding:6px 8px;cursor:pointer}
.m-date:focus{outline:none;border-color:var(--brand)}
@media(max-width:1023px){
  .sidebar{position:fixed;inset:0 auto 0 0;z-index:50;transform:translateX(-100%);transition:transform .3s;border-radius:0}
  .sidebar.open{transform:translateX(0)}
  .main{border-radius:1.5rem}
  .menu-btn{display:block}
  .backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:40;display:none}
  .backdrop.show{display:block}
}
