:root{
  --bg:#E9EDF1; --surface:#FFFFFF; --surface-2:#F5F8FA;
  --ink:#15202B; --ink-2:#56646F; --ink-3:#8A97A1;
  --line:#DCE3E9; --line-2:#EAEFF3;
  --brass:#A9791A; --brass-soft:#F1E6CC;
  --pos:#1F7A55; --neg:#BC4327; --neutral:#3D6B86;
  --radius:12px; --radius-sm:8px;
  --shadow-sm:0 1px 2px rgba(20,32,43,.04),0 1px 1px rgba(20,32,43,.03);
  --shadow:0 1px 2px rgba(20,32,43,.04),0 12px 28px -18px rgba(20,32,43,.28);
  --shadow-lg:0 1px 2px rgba(20,32,43,.05),0 24px 48px -24px rgba(20,32,43,.35);
  --mono:"Inter",system-ui,sans-serif;
}
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Space+Grotesk:wght@500;600;700&display=swap');
*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:"Inter",system-ui,sans-serif;background:var(--bg);color:var(--ink);
  font-feature-settings:"tnum" 1,"cv05" 1;-webkit-font-smoothing:antialiased;line-height:1.5;
}
.num{font-variant-numeric:tabular-nums}
h1,h2,h3,.display{font-family:"Space Grotesk",sans-serif;letter-spacing:-.01em;margin:0}
a{color:inherit}
.muted{color:var(--ink-2)} .small{font-size:.82rem}
.eyebrow{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.pos{color:var(--pos)} .neg{color:var(--neg)}

/* ---- Auth (login em dois painéis) ---- */
.auth{min-height:100dvh;display:grid;grid-template-columns:1.05fr 1fr}
.auth-brand{position:relative;display:flex;flex-direction:column;justify-content:space-between;
  padding:42px 44px;color:#EAF0F4;background:
    radial-gradient(120% 90% at 15% 0%, #21344A 0%, transparent 55%),
    linear-gradient(150deg,#15202B 0%,#0E1822 60%,#101D2A 100%);overflow:hidden}
.auth-brand .mark{width:34px;height:34px;border-radius:8px;background:linear-gradient(135deg,#2E4D6B,#3D6B86);
  display:grid;place-items:center;color:#fff;font-family:"Space Grotesk";font-weight:700;font-size:1.1rem}
.auth-brand .b-name{font-family:"Space Grotesk";font-weight:600;font-size:1.05rem;margin-top:14px}
.auth-brand h2{font-family:"Space Grotesk";font-weight:600;font-size:1.7rem;line-height:1.2;max-width:13ch;letter-spacing:-.01em}
.auth-brand p{color:#9DB0C0;font-size:.92rem;max-width:34ch;margin:10px 0 0}
.auth-brand .figure{position:absolute;right:-40px;bottom:-30px;width:60%;opacity:.10;color:#fff}
.auth-foot{font-size:.78rem;color:#7E93A6;letter-spacing:.04em}
.auth-form{display:grid;place-items:center;padding:24px;background:
  radial-gradient(120% 80% at 50% -10%, #F4F7FA 0%, var(--bg) 60%)}
.auth-card{width:100%;max-width:360px}
.auth-card .eyebrow{margin-bottom:6px}
.auth-card h1{font-size:1.5rem;margin-bottom:4px}
.auth-card .lead{color:var(--ink-2);font-size:.9rem;margin:0 0 22px}
@media(max-width:760px){
  .auth{grid-template-columns:1fr}
  .auth-brand{padding:26px 24px;flex-direction:row;align-items:center;gap:14px;justify-content:flex-start}
  .auth-brand h2,.auth-brand p,.auth-brand .figure,.auth-foot{display:none}
  .auth-brand .b-name{margin-top:0}
}

.brand{display:flex;align-items:center;gap:10px;margin-bottom:26px}
.brand .mark{width:30px;height:30px;border-radius:6px;background:linear-gradient(135deg,var(--ink),var(--neutral));
  display:grid;place-items:center;color:#fff;font-family:"Space Grotesk";font-weight:700}
.brand .name{font-family:"Space Grotesk";font-weight:600;font-size:1.02rem}
label{display:block;font-size:.8rem;font-weight:600;color:var(--ink-2);margin:14px 0 6px}
input{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit;background:var(--surface-2)}
input:focus{outline:2px solid var(--neutral);outline-offset:1px;border-color:transparent;background:#fff}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:20px;
  padding:12px 14px;border:0;border-radius:var(--radius-sm);background:var(--ink);color:#fff;font:inherit;font-weight:600;cursor:pointer;transition:background .14s}
.btn:hover{background:#0d1820}
.btn:disabled{opacity:.6;cursor:default}
.err{margin-top:14px;font-size:.85rem;color:var(--neg);min-height:1em}

/* ---- App shell ---- */
.topbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;
  height:60px;padding:0 24px;background:rgba(255,255,255,.82);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)}
.topbar .name{font-family:"Space Grotesk";font-weight:600}
.topbar-right{display:flex;align-items:center;gap:14px}
.topnav{display:flex;gap:2px}
.topnav a{padding:7px 13px;border-radius:8px;font-size:.88rem;font-weight:500;color:var(--ink-2);text-decoration:none;transition:background .12s,color .12s}
.topnav a.active{background:var(--ink);color:#fff}
.topnav a:not(.active):hover{background:var(--surface-2);color:var(--ink)}
.userchip{display:flex;align-items:center;gap:9px;font-size:.86rem;color:var(--ink-2)}
.userchip .av{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;color:#fff;
  font-family:"Space Grotesk";font-weight:600;font-size:.78rem;background:linear-gradient(135deg,var(--neutral),var(--ink))}
.ghost{background:transparent;border:1px solid var(--line);color:var(--ink-2);width:auto;margin:0;padding:7px 12px;font-size:.85rem;border-radius:8px;cursor:pointer;transition:background .12s,border-color .12s}
.ghost:hover{background:var(--surface-2);border-color:#C6D2DC}
.container{max-width:1120px;margin:0 auto;padding:30px 24px 64px}

/* ---- Page header (telas internas) ---- */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:4px 0 22px}
.page-head h1{font-size:1.8rem;margin-top:2px}
.page-actions{display:flex;align-items:flex-end;gap:12px}
.field{display:flex;flex-direction:column;gap:5px}
.field .eyebrow{margin:0}
.select-wrap{position:relative;display:inline-flex}
.select-wrap::after{content:"";position:absolute;right:11px;top:50%;width:8px;height:8px;border-right:1.6px solid var(--ink-3);
  border-bottom:1.6px solid var(--ink-3);transform:translateY(-65%) rotate(45deg);pointer-events:none}
.select-wrap select{appearance:none;-webkit-appearance:none;padding:9px 30px 9px 12px;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);font-weight:500}

/* ---- Hub ---- */
.hub-head{margin:6px 0 18px}
.hub-head h1{font-size:1.8rem;margin-bottom:2px}
.hero-stat{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;
  margin:16px 0 4px;padding:16px 18px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.hero-stat .lbl{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.hero-stat .big{font-family:"Space Grotesk",sans-serif;font-weight:600;font-size:1.6rem;letter-spacing:-.02em;color:var(--ink)}
.hero-stat .when{font-size:.82rem;color:var(--ink-3)}
.hero-stat .chip{margin-left:auto;font-size:.82rem;font-weight:600;padding:5px 11px;border-radius:999px;
  background:var(--surface-2);border:1px solid var(--line)}
.section-label{display:flex;align-items:center;gap:12px;margin:30px 2px 14px;
  font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.section-label::after{content:"";flex:1;height:1px;background:var(--line)}

.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.card{position:relative;display:flex;flex-direction:column;text-decoration:none;color:inherit;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow-sm);transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}
.card .ic{width:40px;height:40px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line-2);
  display:grid;place-items:center;margin-bottom:16px;color:var(--neutral)}
.card .ic svg{width:20px;height:20px;stroke-width:1.6}
.card h3{font-size:1.02rem;margin-bottom:4px;display:flex;align-items:center;gap:8px}
.card p{margin:0;font-size:.84rem;color:var(--ink-2);line-height:1.45}
.card .go{position:absolute;top:20px;right:18px;color:var(--ink-3);opacity:0;transform:translateX(-4px);
  transition:opacity .14s,transform .14s}
a.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:#C6D2DC}
a.card:hover .ic{color:var(--ink);border-color:var(--neutral)}
a.card:hover .go{opacity:1;transform:translateX(0)}
a.card:focus-visible{outline:2px solid var(--neutral);outline-offset:2px}
.card.soon{cursor:default;background:var(--surface-2);box-shadow:none}
.card.soon .ic{background:#fff}
.card.soon h3,.card.soon p{color:var(--ink-3)}

/* ---- Drill-down (linha clicável) ---- */
.catrow{cursor:pointer;transition:background .12s}
.catrow:hover{background:var(--surface-2)}
.catrow.sel{background:var(--brass-soft)}
.catrow.sel td:first-child{font-weight:600}

/* ---- Dashboard ---- */
.grid{display:grid;gap:16px}
.kpis{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}
.kpi .eyebrow{margin-bottom:8px}
.kpi .v{font-family:"Space Grotesk";font-weight:600;font-size:1.55rem;letter-spacing:-.02em}
.kpi .sub{font-size:.8rem;color:var(--ink-2);margin-top:3px}
.row{display:grid;grid-template-columns:1.6fr 1fr;gap:16px}
@media(max-width:820px){.row{grid-template-columns:1fr}}
.panel h2{font-size:1rem;margin-bottom:2px}
.panel .eyebrow{margin-bottom:14px}
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:4px 0 22px}
select{padding:8px 10px;border:1px solid var(--line);border-radius:6px;font:inherit;background:var(--surface-2)}
table{width:100%;border-collapse:collapse;font-size:.88rem}
th,td{text-align:left;padding:8px 6px;border-bottom:1px solid var(--line-2)}
th{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3);font-weight:600}
td.r,th.r{text-align:right;font-variant-numeric:tabular-nums}
.bar{height:6px;border-radius:3px;background:var(--brass-soft)}
.bar>span{display:block;height:100%;border-radius:3px;background:var(--brass)}
.loading{color:var(--ink-3);font-size:.9rem;padding:20px 0}
canvas{max-width:100%}
.badge{display:inline-block;white-space:nowrap;flex:none;font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--surface-2);color:var(--ink-2);border:1px solid var(--line)}
@media (prefers-reduced-motion:reduce){*{transition:none!important}}

/* ===== Componentes de produto (telas internas) ===== */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:6px 0 22px}
.page-head .h-left h1{font-size:1.7rem;margin-top:2px}
.page-head .h-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

/* Pílulas de ano */
.years{display:flex;gap:6px;flex-wrap:wrap}
.yp{font:inherit;font-size:.84rem;font-weight:600;color:var(--ink-2);cursor:pointer;
  padding:7px 12px;border:1px solid var(--line);background:var(--surface);border-radius:999px;
  font-variant-numeric:tabular-nums;transition:all .12s}
.yp:hover{border-color:#C6D2DC;color:var(--ink)}
.yp.on{background:var(--ink);border-color:var(--ink);color:#fff}
.yp:focus-visible{outline:2px solid var(--neutral);outline-offset:2px}

/* KPIs */
.kpi{position:relative;overflow:hidden}
.kpi.hero{color:#EAF0F4;border:0;background:
  radial-gradient(120% 120% at 100% 0%, #21344A 0%, transparent 55%),
  linear-gradient(150deg,#15202B,#0E1822)}
.kpi.hero .eyebrow{color:#8DA2B5}
.kpi.hero .v{color:#fff}
.kpi.hero .sub{color:#9DB0C0}
.kpi .v{display:block}

/* Cabeçalho de painel */
.ph{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:6px}
.ph h2{font-size:1.02rem}
.panel .ph + .eyebrow{margin-bottom:14px}
.legend{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.legend span{display:inline-flex;align-items:center;gap:6px;font-size:.76rem;color:var(--ink-2)}
.legend i{width:9px;height:9px;border-radius:2px;display:inline-block}

/* Mestre-detalhe (Listas) */
.split{display:grid;grid-template-columns:300px 1fr;gap:16px;align-items:start}
@media(max-width:820px){.split{grid-template-columns:1fr}}
.listcol{display:flex;flex-direction:column;gap:8px}
.listrow{display:flex;align-items:center;gap:12px;text-align:left;width:100%;cursor:pointer;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:13px 14px;box-shadow:var(--shadow-sm);transition:border-color .12s,transform .12s,background .12s}
.listrow:hover{border-color:#C6D2DC;transform:translateX(2px)}
.listrow.on{border-color:var(--ink);background:var(--surface)}
.listrow.on .lr-ic{background:var(--ink);color:#fff;border-color:var(--ink)}
.lr-ic{flex:none;width:32px;height:32px;border-radius:8px;background:var(--surface-2);border:1px solid var(--line-2);
  display:grid;place-items:center;color:var(--neutral)}
.lr-ic svg{width:17px;height:17px;stroke-width:1.7}
.lr-body{min-width:0;flex:1}
.lr-body .t{display:block;font-weight:600;font-size:.92rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lr-body .m{display:block;margin-top:1px;font-size:.78rem;color:var(--ink-3);font-variant-numeric:tabular-nums}
.detail-empty{display:grid;place-items:center;min-height:240px;color:var(--ink-3);text-align:center;padding:30px}
.totalrow td{border-top:2px solid var(--line);font-weight:700}
