/* ============================================================
   GOMES & PAZIN — Painel Prazos · App UI system
   Derived from the brand book (verde-sálvia, Plus Jakarta Sans)
   ============================================================ */
:root{
  --ink:#26261f;
  --ink-soft:#55554a;
  --ink-mute:#8a8a7c;
  --sage:#8d8d77;
  --sage-deep:#6c6c57;
  --sage-300:#b7b7a8;
  --sage-100:#e8e8df;
  --sage-50:#f1f1ea;
  --paper:#f4f3ee;
  --paper-2:#eceae3;
  --white:#ffffff;
  --line:#e2e1d8;
  --line-2:#d4d3c8;
  /* functional, muted earth tones that sit with sage */
  --danger:#b4503f;
  --danger-bg:#f6e7e2;
  --warn:#bb8a3a;
  --warn-bg:#f4ecd9;
  --ok:#6f8a5a;
  --ok-bg:#e9efe1;
  --sans:"Plus Jakarta Sans",-apple-system,system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,"SF Mono",Menlo,Consolas,monospace;
  --r:8px;
  --r-sm:6px;
  --shadow:0 1px 2px rgba(38,38,31,.04),0 12px 28px -16px rgba(38,38,31,.18);
  --shadow-sm:0 1px 2px rgba(38,38,31,.05),0 4px 12px -8px rgba(38,38,31,.16);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);
  -webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--sage-100)}

/* ---------- primitives ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:42px;padding:0 20px;border-radius:var(--r-sm);border:1px solid transparent;
  font-size:13.5px;font-weight:600;letter-spacing:.01em;transition:.16s ease}
.btn--primary{background:var(--sage);color:#fff}
.btn--primary:hover{background:var(--sage-deep)}
.btn--ghost{background:transparent;border-color:var(--line-2);color:var(--ink)}
.btn--ghost:hover{background:var(--sage-50);border-color:var(--sage-300)}
.btn--block{width:100%}
.btn--sm{height:34px;padding:0 14px;font-size:12.5px}
.icon{width:17px;height:17px;flex:none;stroke:currentColor;fill:none;stroke-width:1.7;
  stroke-linecap:round;stroke-linejoin:round}

.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:12px;font-weight:600;color:var(--ink-soft);letter-spacing:.01em}
.field .ctrl{display:flex;align-items:center;gap:10px;height:46px;padding:0 14px;
  background:var(--white);border:1px solid var(--line-2);border-radius:var(--r-sm);transition:.16s}
.field .ctrl:focus-within{border-color:var(--sage);box-shadow:0 0 0 3px rgba(141,141,119,.16)}
.field .ctrl input{border:0;outline:0;background:transparent;flex:1;font-family:inherit;
  font-size:14px;color:var(--ink)}
.field .ctrl input::placeholder{color:var(--ink-mute)}
.field .ctrl .icon{color:var(--sage-deep)}
.field .ctrl button.eye{background:none;border:0;color:var(--ink-mute);display:flex;padding:2px}

.brandmark{display:flex;align-items:center;gap:11px}
.brandmark .gp{color:var(--sage)}
.brandmark .nm{font-weight:700;letter-spacing:-.01em;line-height:1}
.brandmark .nm small{display:block;font-weight:600;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--sage-deep);margin-top:4px}

/* ============================================================
   LOGIN
   ============================================================ */
.auth{min-height:100vh;display:grid;grid-template-columns:0.92fr 1.08fr}
.auth__brand{position:relative;overflow:hidden;background:var(--ink);color:#fff;
  padding:48px 56px;display:flex;flex-direction:column}
.auth__brand .wm{position:absolute;right:-90px;bottom:-70px;width:520px;height:340px;
  color:#fff;opacity:.05}
.auth__brand .top{display:flex;align-items:center;gap:12px;position:relative;z-index:2}
.auth__brand .top .gp{width:42px;height:27px;color:#fff}
.auth__brand .top .t{font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;color:rgba(255,255,255,.72)}
.auth__brand .mid{margin-top:auto;margin-bottom:auto;position:relative;z-index:2}
.auth__brand .mid .lock{width:128px;height:84px;color:#fff;margin-bottom:30px}
.auth__brand .mid h1{font-size:34px;line-height:1.1;font-weight:700;letter-spacing:-.02em;margin:0;max-width:14ch}
.auth__brand .mid p{font-size:15px;line-height:1.6;color:rgba(255,255,255,.7);margin:18px 0 0;max-width:34ch}
.auth__brand .foot{position:relative;z-index:2;font-size:11.5px;letter-spacing:.04em;
  color:rgba(255,255,255,.5)}

.auth__form{display:flex;align-items:center;justify-content:center;padding:40px;background:var(--paper)}
.card{width:100%;max-width:392px}
.card .head{margin-bottom:30px}
.card .eyebrow{font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;color:var(--sage-deep)}
.card h2{font-size:26px;font-weight:700;letter-spacing:-.02em;margin:10px 0 6px}
.card .sub{font-size:13.5px;color:var(--ink-soft)}
.card .stack{display:flex;flex-direction:column;gap:16px}
.card .row-between{display:flex;align-items:center;justify-content:space-between;margin-top:2px}
.link{font-size:12.5px;font-weight:600;color:var(--sage-deep);white-space:nowrap}
.link:hover{color:var(--ink);text-decoration:underline}
.checkbox{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-soft);user-select:none}
.checkbox input{accent-color:var(--sage);width:15px;height:15px}
.card .divider{display:flex;align-items:center;gap:14px;margin:22px 0;color:var(--ink-mute);font-size:11.5px}
.card .divider::before,.card .divider::after{content:"";flex:1;height:1px;background:var(--line)}
.muted-note{font-size:11.5px;color:var(--ink-mute);text-align:center;margin-top:26px;line-height:1.6}
[hidden]{display:none !important}

/* ============================================================
   APP SHELL
   ============================================================ */
.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{background:var(--white);border-right:1px solid var(--line);display:flex;
  flex-direction:column;padding:22px 16px;position:sticky;top:0;height:100vh}
.sidebar .brand{display:flex;align-items:center;gap:11px;padding:6px 8px 22px}
.sidebar .brand .gp{width:34px;height:22px;color:var(--sage)}
.sidebar .brand .nm{font-weight:700;font-size:15px;line-height:1}
.sidebar .brand .nm small{display:block;font-size:9px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--sage-deep);font-weight:600;margin-top:4px}
.navlabel{font-size:10px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;
  color:var(--ink-mute);padding:14px 10px 8px}
.nav{display:flex;flex-direction:column;gap:2px}
.nav a{display:flex;align-items:center;gap:11px;padding:10px 11px;border-radius:var(--r-sm);
  font-size:13.5px;font-weight:500;color:var(--ink-soft);transition:.14s}
.nav a .icon{color:var(--ink-mute)}
.nav a:hover{background:var(--sage-50);color:var(--ink)}
.nav a.active{background:var(--sage-100);color:var(--ink);font-weight:600}
.nav a.active .icon{color:var(--sage-deep)}
.nav a .count{margin-left:auto;font-size:11px;font-weight:700;background:var(--sage);color:#fff;
  border-radius:20px;padding:2px 8px;font-family:var(--mono)}
.sidebar .user{margin-top:auto;display:flex;align-items:center;gap:11px;padding:12px 10px;
  border-top:1px solid var(--line)}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--sage);color:#fff;display:flex;
  align-items:center;justify-content:center;font-weight:700;font-size:13px;flex:none}
.sidebar .user .u{line-height:1.3;min-width:0}
.sidebar .user .u b{font-size:12.5px;font-weight:600;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar .user .u span{font-size:11px;color:var(--ink-mute)}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{height:66px;background:var(--white);border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:18px;padding:0 28px;position:sticky;top:0;z-index:5}
.topbar h1{font-size:18px;font-weight:700;letter-spacing:-.01em;margin:0}
.topbar .crumb{font-size:11.5px;color:var(--ink-mute);letter-spacing:.04em}
.search{margin-left:auto;display:flex;align-items:center;gap:9px;height:40px;width:300px;
  max-width:38vw;padding:0 13px;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-sm)}
.search .icon{color:var(--ink-mute)}
.search input{border:0;background:transparent;outline:0;font-family:inherit;font-size:13px;flex:1;color:var(--ink)}
.iconbtn{width:40px;height:40px;border-radius:var(--r-sm);border:1px solid var(--line);
  background:var(--white);display:flex;align-items:center;justify-content:center;color:var(--ink-soft);position:relative}
.iconbtn:hover{background:var(--sage-50);border-color:var(--sage-300)}
.iconbtn .dot{position:absolute;top:8px;right:9px;width:7px;height:7px;border-radius:50%;
  background:var(--danger);border:2px solid var(--white)}

.content{padding:26px 28px 40px;overflow:auto}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:22px}
.page-head .ttl{font-size:24px;font-weight:700;letter-spacing:-.02em;margin:0}
.page-head .ttl small{display:block;font-size:13px;font-weight:500;color:var(--ink-soft);
  letter-spacing:0;margin-top:6px}

/* stat cards */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.stat{background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:18px 18px 16px;
  position:relative;overflow:hidden}
.stat .k{font-size:12px;font-weight:600;color:var(--ink-soft);display:flex;align-items:center;gap:8px}
.stat .k .pip{width:9px;height:9px;border-radius:3px;flex:none}
.stat .v{font-size:30px;font-weight:700;letter-spacing:-.02em;margin-top:12px;line-height:1}
.stat .d{font-size:11.5px;color:var(--ink-mute);margin-top:6px}
.pip--danger{background:var(--danger)} .pip--warn{background:var(--warn)}
.pip--ok{background:var(--ok)} .pip--sage{background:var(--sage)}

/* toolbar / filters */
.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{height:34px;padding:0 14px;border-radius:20px;border:1px solid var(--line-2);background:var(--white);
  font-size:12.5px;font-weight:600;color:var(--ink-soft);display:inline-flex;align-items:center;gap:8px;transition:.14s}
.chip:hover{border-color:var(--sage-300);background:var(--sage-50)}
.chip.active{background:var(--ink);border-color:var(--ink);color:#fff}
.chip .n{font-family:var(--mono);font-size:11px;opacity:.8}
.toolbar .spacer{margin-left:auto}

/* table */
.tablewrap{background:var(--white);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-sm)}
.tscroll{overflow-x:auto}
.ptable{width:100%;min-width:880px;border-collapse:collapse;font-size:13px}
.ptable thead th{text-align:left;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  font-weight:700;color:var(--ink-mute);padding:14px 16px;border-bottom:1px solid var(--line);background:var(--paper)}
.ptable tbody td{padding:15px 16px;border-bottom:1px solid var(--line);vertical-align:middle}
.ptable tbody tr:last-child td{border-bottom:0}
.ptable tbody tr:hover{background:var(--sage-50)}
.ptable .proc{font-family:var(--mono);font-size:12px;color:var(--ink);font-weight:500;white-space:nowrap}
.ptable .cli{font-weight:600;color:var(--ink)}
.ptable .sub{font-size:11.5px;color:var(--ink-mute);margin-top:3px}
.ptable .vara{color:var(--ink-soft)}
.ptable .date{font-family:var(--mono);font-size:12px;color:var(--ink-soft);white-space:nowrap}
.who{display:flex;align-items:center;gap:9px}
.who .av{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:10.5px;font-weight:700;color:#fff;flex:none}
.who span{font-size:12.5px;color:var(--ink-soft)}

.due{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:12.5px;
  padding:5px 11px;border-radius:20px;white-space:nowrap}
.due .dd{font-family:var(--mono)}
.due--danger{background:var(--danger-bg);color:var(--danger)}
.due--warn{background:var(--warn-bg);color:#946d28}
.due--ok{background:var(--ok-bg);color:#4f6840}
.tag{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:3px 9px;
  border-radius:5px;background:var(--sage-50);color:var(--sage-deep);border:1px solid var(--sage-100)}
.rowbtn{width:32px;height:32px;border-radius:var(--r-sm);border:1px solid transparent;background:transparent;
  display:flex;align-items:center;justify-content:center;color:var(--ink-mute)}
.rowbtn:hover{background:var(--sage-100);color:var(--sage-deep)}
.t-foot{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;
  border-top:1px solid var(--line);font-size:12.5px;color:var(--ink-mute);background:var(--paper)}
.pager{display:flex;gap:6px}
.pager button{width:32px;height:32px;border-radius:var(--r-sm);border:1px solid var(--line-2);
  background:var(--white);font-size:12.5px;color:var(--ink-soft)}
.pager button.active{background:var(--sage);border-color:var(--sage);color:#fff;font-weight:700}

@media (max-width:1080px){
  .stats{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .auth{grid-template-columns:1fr}
  .auth__brand{display:none}
  .shell{grid-template-columns:1fr}
  .sidebar{display:none}
  .vara-col,.who-col{display:none}
}