/* =====================================================================
   LogProSystem — Design System
   Paleta derivada do logo: navy profundo, azul sinal, laranja rota.
   ===================================================================== */
:root{
  --navy-900:#0A2240;
  --navy-800:#0E2E54;
  --navy-700:#143A66;
  --navy-600:#1B4A80;
  --blue-500:#1E88E5;
  --blue-400:#2BA8FF;
  --blue-100:#E5F1FD;
  --orange:#F26A1B;
  --orange-600:#D9560C;
  --orange-100:#FDEBDD;

  --bg:#EEF2F8;
  --surface:#FFFFFF;
  --surface-2:#F7F9FC;
  --line:#E1E7F0;
  --text:#0F1B2D;
  --muted:#5B6B82;
  --muted-2:#8A98AD;

  --green:#1FA463; --green-bg:#E3F6EC;
  --amber:#C7821A; --amber-bg:#FCF1DC;
  --red:#D43A3A;   --red-bg:#FBE6E6;
  --blue-bg:#E5F1FD;

  --radius:14px;
  --radius-sm:10px;
  --shadow-sm:0 1px 2px rgba(10,34,64,.06),0 1px 3px rgba(10,34,64,.08);
  --shadow:0 4px 16px rgba(10,34,64,.10);
  --shadow-lg:0 16px 48px rgba(10,34,64,.18);

  --sidebar-w:248px;
  --font-display:"Sora","Segoe UI",system-ui,sans-serif;
  --font-body:"Inter","Segoe UI",system-ui,-apple-system,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  font-size:15px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--blue-500);text-decoration:none}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit;font-size:15px}
::selection{background:var(--blue-100)}
.hidden{display:none !important}

/* ---------- Scroll & loading ---------- */
#loader{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  background:var(--navy-900);z-index:9999;color:#fff;flex-direction:column;gap:18px}
.spinner{width:46px;height:46px;border:4px solid rgba(255,255,255,.2);border-top-color:var(--orange);
  border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* =====================================================================
   LOGIN
   ===================================================================== */
.login-wrap{min-height:100%;display:grid;grid-template-columns:1.1fr .9fr}
.login-hero{
  background:radial-gradient(120% 120% at 0% 0%,var(--navy-700),var(--navy-900));
  color:#fff;padding:56px;display:flex;flex-direction:column;justify-content:space-between;
  position:relative;overflow:hidden;
}
.login-hero::after{content:"";position:absolute;right:-120px;bottom:-120px;width:420px;height:420px;
  border:48px solid rgba(43,168,255,.12);border-radius:50%}
.login-hero::before{content:"";position:absolute;left:50%;top:46%;width:520px;height:260px;
  border-bottom:6px solid var(--orange);border-radius:0 0 50% 50%;
  transform:translateX(-50%) rotate(-8deg);opacity:.5}
.login-brand{display:flex;align-items:center;gap:14px;z-index:2}
.login-brand .mark{width:54px;height:54px}
.login-hero h1{font-family:var(--font-display);font-size:40px;line-height:1.08;font-weight:800;
  margin-top:auto;z-index:2;font-style:italic}
.login-hero h1 .b{color:var(--blue-400)}
.login-hero p{color:#bcd2ec;max-width:420px;margin-top:14px;z-index:2}
.login-tags{display:flex;gap:10px;margin-top:26px;flex-wrap:wrap;z-index:2}
.login-tags span{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);
  padding:6px 13px;border-radius:30px;font-size:12.5px;color:#dfeaf7}

.login-panel{display:flex;align-items:center;justify-content:center;padding:40px;background:var(--surface)}
.login-card{width:100%;max-width:380px}
.login-card h2{font-family:var(--font-display);font-size:25px;font-weight:700}
.login-card .sub{color:var(--muted);margin:6px 0 28px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--navy-800);margin-bottom:7px}
.field input,.field select,.field textarea{
  width:100%;padding:11px 13px;border:1.5px solid var(--line);border-radius:var(--radius-sm);
  background:var(--surface);transition:border-color .15s,box-shadow .15s;outline:none}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--blue-500);box-shadow:0 0 0 3px var(--blue-100)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:none;border-radius:var(--radius-sm);padding:11px 18px;font-weight:650;font-size:15px;
  transition:transform .08s,background .15s,box-shadow .15s}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{background:var(--orange-600)}
.btn-navy{background:var(--navy-800);color:#fff}
.btn-navy:hover{background:var(--navy-700)}
.btn-ghost{background:var(--surface-2);color:var(--navy-800);border:1.5px solid var(--line)}
.btn-ghost:hover{background:var(--blue-100);border-color:var(--blue-400)}
.btn-block{width:100%}
.btn-sm{padding:7px 12px;font-size:13.5px;border-radius:9px}
.btn-icon{background:transparent;border:none;padding:7px;border-radius:8px;color:var(--muted);display:inline-flex}
.btn-icon:hover{background:var(--surface-2);color:var(--navy-800)}
.btn-danger{background:var(--red-bg);color:var(--red)}
.btn-danger:hover{background:#f6cccc}
.login-error{background:var(--red-bg);color:var(--red);padding:10px 13px;border-radius:9px;
  font-size:13.5px;margin-bottom:14px;display:none}
.login-hint{margin-top:18px;font-size:12.5px;color:var(--muted-2);text-align:center}

/* =====================================================================
   APP SHELL
   ===================================================================== */
.app{display:none;min-height:100%}
.app.show{display:grid;grid-template-columns:var(--sidebar-w) 1fr}

.sidebar{
  background:linear-gradient(180deg,var(--navy-800),var(--navy-900));
  color:#cfdcec;padding:20px 16px;display:flex;flex-direction:column;gap:6px;
  position:sticky;top:0;height:100vh;overflow-y:auto}
.sidebar .brand{display:flex;align-items:center;gap:11px;padding:6px 8px 18px}
.sidebar .brand .mark{width:40px;height:40px;flex:0 0 auto}
.sidebar .brand .txt{font-family:var(--font-display);font-weight:800;font-style:italic;color:#fff;
  font-size:18px;line-height:1}
.sidebar .brand .txt small{display:block;font-style:normal;font-weight:500;font-size:9.5px;
  letter-spacing:.12em;color:var(--blue-400);margin-top:3px}
.nav-group{font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:#6f87a6;
  padding:14px 12px 6px;font-weight:600}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;
  color:#bccbe0;font-weight:550;font-size:14px;transition:background .15s,color .15s;border:none;background:none;
  width:100%;text-align:left}
.nav-item svg{width:19px;height:19px;flex:0 0 auto}
.nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-item.active{background:var(--orange);color:#fff;box-shadow:0 6px 16px rgba(242,106,27,.35)}
.sidebar .spacer{flex:1}
.sidebar .ver{font-size:11px;color:#6f87a6;padding:8px 12px;border-top:1px solid rgba(255,255,255,.08);
  margin-top:8px}

.main{min-width:0;display:flex;flex-direction:column}
.topbar{position:sticky;top:0;z-index:30;background:rgba(255,255,255,.85);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);padding:13px 26px;display:flex;align-items:center;gap:16px}
.topbar .menu-btn{display:none}
.topbar h1{font-family:var(--font-display);font-size:21px;font-weight:700}
.topbar .sub{color:var(--muted);font-size:13px}
.topbar .right{margin-left:auto;display:flex;align-items:center;gap:14px}
.userchip{display:flex;align-items:center;gap:10px}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--navy-800);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-family:var(--font-display)}
.userchip .meta{line-height:1.15}
.userchip .meta b{font-size:13.5px}
.userchip .meta span{font-size:11.5px;color:var(--muted);text-transform:capitalize}

.content{padding:26px;max-width:1280px;width:100%}

/* ---------- Cards / surfaces ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.card-pad{padding:20px}
.section-head{display:flex;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.section-head h2{font-family:var(--font-display);font-size:19px;font-weight:700}
.section-head .actions{margin-left:auto;display:flex;gap:10px;flex-wrap:wrap}

/* ---------- KPI cards ---------- */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-bottom:22px}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 20px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.kpi .ico{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.kpi .ico svg{width:22px;height:22px}
.kpi .val{font-family:var(--font-display);font-size:30px;font-weight:800;line-height:1}
.kpi .lbl{color:var(--muted);font-size:13px;margin-top:5px}
.kpi.k-navy .ico{background:var(--navy-800);color:#fff}
.kpi.k-blue .ico{background:var(--blue-bg);color:var(--blue-500)}
.kpi.k-orange .ico{background:var(--orange-100);color:var(--orange)}
.kpi.k-green .ico{background:var(--green-bg);color:var(--green)}
.kpi.k-red .ico{background:var(--red-bg);color:var(--red)}

.grid-2{display:grid;grid-template-columns:1.4fr 1fr;gap:18px}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:14px}
thead th{text-align:left;font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);
  font-weight:650;padding:11px 14px;border-bottom:1px solid var(--line);white-space:nowrap}
tbody td{padding:13px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--surface-2)}
.t-actions{display:flex;gap:4px;justify-content:flex-end}
.muted{color:var(--muted)}
.strong{font-weight:650}

/* ---------- Badges / chips ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:30px;
  font-size:12px;font-weight:650;white-space:nowrap}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.b-pendente{background:var(--surface-2);color:var(--muted)}
.b-em_andamento{background:var(--blue-bg);color:var(--blue-500)}
.b-entrega_feita{background:var(--green-bg);color:var(--green)}
.b-coleta_feita{background:var(--green-bg);color:var(--green)}
.b-realizada{background:var(--green-bg);color:var(--green)}
.b-nao_realizada{background:var(--red-bg);color:var(--red)}
.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:8px;font-size:12.5px;font-weight:600}
.chip-entrega{background:var(--blue-bg);color:var(--blue-500)}
.chip-coleta{background:var(--orange-100);color:var(--orange-600)}
.pill{padding:2px 8px;border-radius:6px;background:var(--surface-2);font-size:12px;color:var(--muted);font-weight:600}

/* ---------- Forms grid ---------- */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.form-grid .col-full{grid-column:1/-1}

/* ---------- Modal ---------- */
.modal-back{position:fixed;inset:0;background:rgba(10,34,64,.5);backdrop-filter:blur(3px);
  display:none;align-items:flex-start;justify-content:center;z-index:200;padding:34px 16px;overflow-y:auto}
.modal-back.show{display:flex}
.modal{background:var(--surface);border-radius:18px;box-shadow:var(--shadow-lg);width:100%;max-width:680px;
  animation:pop .18s ease}
.modal.lg{max-width:880px}
@keyframes pop{from{transform:translateY(12px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal-head{display:flex;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line)}
.modal-head h3{font-family:var(--font-display);font-size:18px;font-weight:700}
.modal-head .btn-icon{margin-left:auto}
.modal-body{padding:22px;max-height:70vh;overflow-y:auto}
.modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:16px 22px;border-top:1px solid var(--line)}

/* ---------- Item rows (route builder) ---------- */
.item-row{display:grid;grid-template-columns:1fr 130px 90px 38px;gap:10px;align-items:end;margin-bottom:10px}
.route-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}

/* ---------- Empty / toast ---------- */
.empty{text-align:center;padding:48px 20px;color:var(--muted)}
.empty svg{width:46px;height:46px;color:var(--muted-2);margin-bottom:12px}
#toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(80px);
  background:var(--navy-900);color:#fff;padding:13px 20px;border-radius:12px;box-shadow:var(--shadow-lg);
  z-index:999;opacity:0;transition:.25s;font-size:14px;display:flex;align-items:center;gap:10px;max-width:90vw}
#toast.show{transform:translateX(-50%) translateY(0);opacity:1}
#toast.err{background:var(--red)}
#toast.ok{background:var(--green)}

/* ---------- Update banner ---------- */
#update-banner{position:fixed;bottom:0;left:0;right:0;background:var(--navy-800);color:#fff;
  padding:13px 20px;display:none;align-items:center;gap:14px;z-index:500;box-shadow:0 -4px 20px rgba(0,0,0,.2)}
#update-banner.show{display:flex}
#update-banner .ico{width:34px;height:34px;background:var(--orange);border-radius:9px;display:flex;
  align-items:center;justify-content:center;flex:0 0 auto}
#update-banner b{display:block}
#update-banner small{color:#aecbe9}

/* ---------- Timeline ---------- */
.timeline{position:relative;padding-left:22px}
.timeline::before{content:"";position:absolute;left:6px;top:4px;bottom:4px;width:2px;background:var(--line)}
.tl-item{position:relative;padding:0 0 16px}
.tl-item::before{content:"";position:absolute;left:-22px;top:3px;width:13px;height:13px;border-radius:50%;
  background:#fff;border:3px solid var(--blue-500)}
.tl-item:last-child{padding-bottom:0}
.tl-item .t{font-size:12px;color:var(--muted)}

.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}
.detail-grid .lbl{font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600}
.detail-grid .v{font-weight:600;margin-top:2px}

/* ---------- Filters bar ---------- */
.filters{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px;align-items:end}
.filters .field{margin:0;min-width:150px}
.filters .field label{font-size:12px}

/* ---------- Toolbar search ---------- */
.search-box{position:relative}
.search-box input{padding-left:36px}
.search-box svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:17px;height:17px;color:var(--muted-2)}

/* =====================================================================
   RESPONSIVO
   ===================================================================== */
.scrim{position:fixed;inset:0;background:rgba(10,34,64,.45);z-index:40;display:none}
@media(max-width:980px){
  .grid-2{grid-template-columns:1fr}
}
@media(max-width:860px){
  .app.show{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;z-index:50;width:var(--sidebar-w);transform:translateX(-100%);
    transition:transform .25s ease}
  .sidebar.open{transform:none;box-shadow:var(--shadow-lg)}
  .scrim.show{display:block}
  .topbar .menu-btn{display:inline-flex}
  .login-wrap{grid-template-columns:1fr}
  .login-hero{display:none}
}
@media(max-width:560px){
  .content{padding:16px}
  .topbar{padding:12px 16px}
  .form-grid{grid-template-columns:1fr}
  .detail-grid{grid-template-columns:1fr}
  .item-row{grid-template-columns:1fr 1fr;gap:8px}
  .item-row .rm{grid-column:2;justify-self:end}
  .userchip .meta{display:none}
}
