@import url('https://fonts.googleapis.com/css2?family=Barlow:wght@400;500;600;700&family=Barlow+Condensed:wght@600;700;800&display=swap');

:root {
  --bg0:#F0F2F7; --bg1:#FFFFFF; --bg2:#F7F8FC; --bg3:#EEF0F6;
  --bdr:rgba(0,0,0,.09); --txt:#1E2233; --mut:#7B8AAB;
  --acc:#D97706; --ok:#16A34A; --warn:#D97706; --err:#DC2626;
  --inf:#2563EB; --wa:#16A34A;
  --sb:224px; --r:10px; --rl:14px;
  --fn:'Barlow',sans-serif; --fd:'Barlow Condensed',sans-serif;
  --shadow:0 1px 4px rgba(0,0,0,.08);
  --shadow-md:0 4px 16px rgba(0,0,0,.10);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--fn);background:var(--bg0);color:var(--txt);min-height:100vh;display:flex}

/* ── SIDEBAR ──────────────────────── */
.sb{width:var(--sb);min-height:100vh;background:var(--bg1);
  border-right:1px solid var(--bdr);
  display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:200;
  overflow-y:auto;transition:transform .22s;box-shadow:var(--shadow-md)}
.sb-logo{padding:17px 16px;border-bottom:1px solid var(--bdr);font-family:var(--fd);
  font-size:1.5rem;letter-spacing:1px;display:flex;align-items:center;gap:10px;
  background:#FFFBF2}
.sb-logo strong{color:var(--acc)}
.sb-nav{flex:1;padding:10px 8px}
.sb-sec{font-size:.61rem;font-weight:700;letter-spacing:1.8px;color:var(--mut);
  padding:14px 10px 4px;text-transform:uppercase}
.sb-nav a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r);
  color:var(--mut);text-decoration:none;font-size:.87rem;font-weight:500;
  margin-bottom:2px;transition:all .14s}
.sb-nav a:hover{background:var(--bg3);color:var(--txt)}
.sb-nav a.on{background:linear-gradient(135deg,rgba(217,119,6,.12),rgba(217,119,6,.05));
  color:var(--acc);border-left:3px solid var(--acc);padding-left:9px;font-weight:600}
.sb-nav a i{width:18px;font-size:.95rem}
.cnt{margin-left:auto;background:var(--err);color:#fff;font-size:.65rem;
  font-weight:800;border-radius:20px;padding:1px 7px}
.sb-foot{padding:12px 14px;border-top:1px solid var(--bdr);
  display:flex;align-items:center;gap:9px;background:var(--bg2)}
.av{width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--acc),#92400e);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:.8rem;color:#fff;flex-shrink:0}
.u-nm{font-size:.8rem;font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--txt)}
.btn-sair{color:var(--mut);font-size:1.1rem;text-decoration:none;padding:4px;border-radius:6px;transition:color .14s}
.btn-sair:hover{color:var(--err)}

/* ── MAIN ─────────────────────────── */
.main{margin-left:var(--sb);flex:1;display:flex;flex-direction:column;min-height:100vh}
.topbar{height:54px;background:var(--bg1);border-bottom:1px solid var(--bdr);
  display:flex;align-items:center;gap:12px;padding:0 20px;
  position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}
.topbar-tit{font-family:var(--fd);font-size:1.2rem;font-weight:700;flex:1;color:var(--txt)}
.btn-menu{background:none;border:none;color:var(--mut);font-size:1.3rem;cursor:pointer;
  padding:6px;border-radius:6px;transition:color .14s}
.btn-menu:hover{color:var(--txt)}
.content{padding:20px;flex:1}

/* ── CARDS ────────────────────────── */
.card{background:var(--bg1);border:1px solid var(--bdr);border-radius:var(--rl);box-shadow:var(--shadow)}
.card-head{padding:13px 18px;border-bottom:1px solid var(--bdr);font-weight:600;
  font-size:.9rem;display:flex;align-items:center;justify-content:space-between;gap:8px;
  background:var(--bg2);border-radius:var(--rl) var(--rl) 0 0;color:var(--txt)}
.card-body{padding:16px 18px}

/* ── STATS ────────────────────────── */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;margin-bottom:20px}
.stat{background:var(--bg1);border:1px solid var(--bdr);border-radius:var(--rl);
  padding:18px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow)}
.stat-ico{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;
  justify-content:center;font-size:1.35rem;flex-shrink:0}
.c-ok  {background:rgba(22,163,74,.12)}
.c-warn{background:rgba(217,119,6,.12)}
.c-err {background:rgba(220,38,38,.12)}
.c-inf {background:rgba(37,99,235,.12)}
.stat-lbl{font-size:.7rem;color:var(--mut);text-transform:uppercase;letter-spacing:.4px}
.stat-val{font-family:var(--fd);font-size:1.9rem;font-weight:700;line-height:1}
.stat-val.sm{font-size:1.1rem;margin-top:2px}
.t-ok  {color:var(--ok)}  .t-warn{color:var(--warn)} .t-err{color:var(--err)}
.t-inf {color:var(--inf)} .t-acc {color:var(--acc)}  .t-txt {color:var(--txt)}

/* ── BADGES ───────────────────────── */
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:700;white-space:nowrap}
.ok     {background:rgba(22,163,74,.12);color:var(--ok)}
.proximo{background:rgba(217,119,6,.13);color:var(--warn)}
.vencido{background:rgba(220,38,38,.12);color:var(--err)}

/* ── TABLES ───────────────────────── */
.tbl{width:100%;border-collapse:separate;border-spacing:0;color:var(--txt)}
.tbl thead th{background:var(--bg3);color:var(--mut);font-size:.68rem;
  text-transform:uppercase;letter-spacing:.8px;padding:9px 13px;border:none;white-space:nowrap}
.tbl thead th:first-child{border-radius:8px 0 0 8px}
.tbl thead th:last-child {border-radius:0 8px 8px 0}
.tbl tbody td{padding:10px 13px;border-bottom:1px solid var(--bdr);font-size:.85rem;vertical-align:middle}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl tbody tr:hover{background:#FAFBFE}
.ovx{overflow-x:auto}

/* ── FORMS ────────────────────────── */
.lbl{font-size:.7rem;font-weight:700;color:var(--mut);text-transform:uppercase;
  letter-spacing:.5px;display:block;margin-bottom:5px}
.inp,.sel,.ta{background:var(--bg1);border:1.5px solid var(--bdr);color:var(--txt);
  border-radius:8px;padding:9px 13px;font-size:.88rem;width:100%;
  font-family:var(--fn);transition:border-color .14s}
.inp:focus,.sel:focus,.ta:focus{border-color:var(--acc);outline:none;
  box-shadow:0 0 0 3px rgba(217,119,6,.10)}
.inp::placeholder,.ta::placeholder{color:var(--mut);opacity:.7}
.sel option{background:var(--bg1);color:var(--txt)}
.ta{resize:vertical;min-height:75px}
.inp-ico{position:relative}
.inp-ico i{position:absolute;left:11px;top:50%;transform:translateY(-50%);
  color:var(--mut);font-size:.9rem}
.inp-ico .inp{padding-left:34px}
.frow{display:grid;gap:12px}
.cols2{grid-template-columns:1fr 1fr}
.cols3{grid-template-columns:1fr 1fr 1fr}
.cols4{grid-template-columns:1fr 1fr 1fr 1fr}

/* ── BUTTONS ──────────────────────── */
.btn{display:inline-flex;align-items:center;gap:6px;border:none;border-radius:8px;
  padding:9px 18px;font-size:.87rem;font-weight:600;cursor:pointer;
  text-decoration:none;font-family:var(--fn);transition:all .14s}
.btn-primary{background:linear-gradient(135deg,#D97706,#B45309);color:#fff}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(217,119,6,.35);color:#fff}
.btn-ghost{background:var(--bg2);color:var(--txt);border:1.5px solid var(--bdr)}
.btn-ghost:hover{background:var(--bg3);color:var(--txt)}
.btn-danger{background:rgba(220,38,38,.08);color:var(--err);border:1.5px solid rgba(220,38,38,.22)}
.btn-danger:hover{background:rgba(220,38,38,.15);color:var(--err)}
.btn-wa{background:linear-gradient(135deg,#22C55E,#16A34A);color:#fff}
.btn-wa:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(34,197,94,.3);color:#fff}
.btn-sm{padding:5px 13px;font-size:.78rem}
.btn-xs{padding:3px 9px;font-size:.72rem;border-radius:6px}
.w100{width:100%;justify-content:center}

/* ── MODAL ────────────────────────── */
.modal{display:none;position:fixed;inset:0;z-index:500;align-items:flex-start;
  justify-content:center;padding:40px 16px;overflow-y:auto}
.modal.open{display:flex}
.overlay{position:fixed;inset:0;background:rgba(30,34,51,.45);z-index:499}
.modal-box{background:var(--bg1);border:1px solid var(--bdr);border-radius:var(--rl);
  width:100%;position:relative;z-index:501;box-shadow:0 20px 60px rgba(0,0,0,.15)}
.modal-box.sm{max-width:440px} .modal-box.md{max-width:640px} .modal-box.lg{max-width:820px}
.modal-hd{padding:15px 20px;border-bottom:1px solid var(--bdr);background:var(--bg2);
  border-radius:var(--rl) var(--rl) 0 0;
  display:flex;align-items:center;justify-content:space-between}
.modal-hd h5{font-family:var(--fd);font-size:1.05rem;font-weight:700;color:var(--txt)}
.modal-bd{padding:20px}
.modal-ft{padding:13px 20px;border-top:1px solid var(--bdr);background:var(--bg2);
  border-radius:0 0 var(--rl) var(--rl);
  display:flex;gap:8px;justify-content:flex-end}
.btn-x{background:none;border:none;color:var(--mut);font-size:1.3rem;cursor:pointer;
  line-height:1;padding:2px}
.btn-x:hover{color:var(--err)}

/* ── FLASH ────────────────────────── */
.flash{border-radius:var(--r);padding:10px 16px;font-size:.86rem;margin:12px 20px 0;line-height:1.5;border:1px solid transparent}
.flash-ok  {background:#F0FDF4;color:#15803D;border-color:#BBF7D0}
.flash-err {background:#FEF2F2;color:#B91C1C;border-color:#FECACA}
.flash-warn{background:#FFFBEB;color:#B45309;border-color:#FDE68A}

/* ── VEHICLE CARDS ────────────────── */
.vcard{display:block;background:var(--bg1);border:1.5px solid var(--bdr);
  border-radius:var(--rl);padding:16px;text-decoration:none;color:var(--txt);
  transition:all .18s;box-shadow:var(--shadow)}
.vcard:hover{border-color:var(--acc);transform:translateY(-3px);color:var(--txt);
  box-shadow:0 8px 24px rgba(0,0,0,.12)}
.placa{font-family:var(--fd);font-size:1.1rem;font-weight:800;letter-spacing:2px;
  color:var(--acc);background:rgba(217,119,6,.10);display:inline-block;
  padding:2px 10px;border-radius:6px;border:1px solid rgba(217,119,6,.20)}
.medidor-box{background:var(--bg3);border-radius:8px;padding:14px;text-align:center;
  border:1px solid var(--bdr)}
.medidor-val{font-family:var(--fd);font-size:1.7rem;font-weight:700;color:var(--acc);line-height:1}
.medidor-lbl{font-size:.63rem;color:var(--mut);text-transform:uppercase;margin-top:3px;letter-spacing:.6px}

/* ── ALERTA CARDS ─────────────────── */
.alerta-card{background:var(--bg1);border:1.5px solid var(--bdr);border-radius:var(--rl);
  padding:16px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow)}
.alerta-card.vencido{border-left:4px solid var(--err);background:#FFFAFA}
.alerta-card.proximo{border-left:4px solid var(--warn);background:#FFFDF5}
.alerta-ico{font-size:2.2rem;flex-shrink:0}
.alerta-info{flex:1;min-width:0}
.alerta-placa{font-family:var(--fd);font-size:1.1rem;font-weight:800;color:var(--acc)}
.alerta-tipo{font-size:.88rem;font-weight:600;margin-top:2px;color:var(--txt)}
.alerta-detalhe{font-size:.79rem;color:var(--mut);margin-top:4px}
.alerta-acoes{display:flex;flex-direction:column;gap:6px;flex-shrink:0;align-items:flex-end}
.sec-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;padding:6px 0}
.vencido-label{color:var(--err)} .proximo-label{color:var(--warn)}

/* ── LOGIN ────────────────────────── */
.login-pg{min-height:100vh;background:linear-gradient(135deg,#FEF3C7 0%,#F0F2F7 60%);
  display:flex;align-items:center;justify-content:center;padding:20px;width:100%}
.login-box{background:var(--bg1);border:1px solid var(--bdr);border-radius:18px;
  padding:40px;width:100%;max-width:390px;box-shadow:0 20px 60px rgba(0,0,0,.12)}
.login-logo{font-family:var(--fd);font-size:2.2rem;font-weight:800;text-align:center;margin-bottom:4px;color:var(--txt)}
.login-logo strong{color:var(--acc)}
.login-sub{text-align:center;color:var(--mut);font-size:.84rem;margin-bottom:26px}

/* ── UTILS ────────────────────────── */
.flex{display:flex} .ai-c{align-items:center} .jc-b{justify-content:space-between}
.fw-7{font-weight:700} .fw-8{font-weight:800} .fs-disp{font-family:var(--fd)}
.mb-1{margin-bottom:6px}  .mb-2{margin-bottom:10px} .mb-3{margin-bottom:16px} .mb-4{margin-bottom:22px}
.mt-2{margin-top:10px}    .mt-3{margin-top:16px}
.me-2{margin-right:10px}
.gap-8{gap:8px} .gap-12{gap:12px}
.t-mut{color:var(--mut)} .t-acc{color:var(--acc)} .t-ok{color:var(--ok)}
.t-err{color:var(--err)} .t-warn{color:var(--warn)} .t-inf{color:var(--inf)}
.t-sm{font-size:.82rem} .t-xs{font-size:.72rem}
.t-c{text-align:center} .t-r{text-align:right}
.d-none{display:none!important}

code{background:rgba(217,119,6,.10);padding:2px 8px;border-radius:5px;
  font-size:.83rem;font-family:monospace;color:var(--acc);border:1px solid rgba(217,119,6,.20)}

::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--bg0)}
::-webkit-scrollbar-thumb{background:#D1D5E0;border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:#B0B8CC}

@media(max-width:768px){
  .sb{transform:translateX(-100%)}
  .sb.open{transform:none;box-shadow:4px 0 24px rgba(0,0,0,.15)}
  .main{margin-left:0}
  .content{padding:12px}
  .cols2,.cols3,.cols4{grid-template-columns:1fr}
  .alerta-acoes{flex-direction:row;flex-shrink:unset;flex-wrap:wrap}
  .stats{grid-template-columns:repeat(2,1fr)}
}

.btn-tg{background:linear-gradient(135deg,#2CA5E0,#1A8AC0);color:#fff}
.btn-tg:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(44,165,224,.35);color:#fff}
