/* ═══════════════════════════════════════════════════════
   ProAção — Design System v5  (Tabler 1.4 + Inter)
   ═══════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root {
  --bg:#f1f5f9;--surface:#fff;--surface2:#f8fafc;--border:#e2e8f0;--border2:#cbd5e1;
  --text:#0f172a;--text2:#475569;--text3:#94a3b8;
  --primary:#2563eb;--prim-d:#1d4ed8;--prim-l:#eff6ff;
  --success:#10b981;--succ-l:#ecfdf5;
  --warn:#f59e0b;--warn-l:#fffbeb;
  --danger:#ef4444;--dang-l:#fef2f2;
  --info:#0ea5e9;--info-l:#f0f9ff;
  --orange:#f76707;--orange-l:#fff4e6;
  --purple:#ae3ec9;--purple-l:#f3e8ff;
  --nav-h:60px;--nav-bg:#0f172a;
  --r:8px;--r-lg:12px;--r-xl:18px;
  --sh:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --sh-md:0 4px 16px rgba(0,0,0,.08);--sh-lg:0 12px 32px rgba(0,0,0,.12);
  --tr:.15s ease;
}
*,*::before,*::after{box-sizing:border-box}
html{font-size:15px;scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text);
  line-height:1.6;min-height:100vh;padding-top:var(--nav-h);-webkit-font-smoothing:antialiased}

/* helpers */
.fw-6,.fw-600{font-weight:600}.fw-7,.fw-700{font-weight:700}.fw-8,.fw-800{font-weight:800}
.fs-xs{font-size:.75rem}.fs-sm{font-size:.82rem}.fs-md{font-size:.9rem}
.t-muted{color:var(--text3)}.t-primary{color:var(--primary)}.t-success{color:var(--success)}
.t-danger{color:var(--danger)}.t-warn{color:var(--warn)}.t-orange{color:var(--orange)}.t-purple{color:var(--purple)}
.min-w-0{min-width:0!important}

/* NAVBAR */
.navbar{height:var(--nav-h);background:var(--nav-bg)!important;border-bottom:1px solid rgba(255,255,255,.07);
  position:fixed!important;top:0;left:0;right:0;z-index:1000;padding:0 16px}
.navbar-brand{font-weight:700;font-size:.92rem;color:#fff!important;letter-spacing:-.02em;display:flex;align-items:center;gap:8px}
.navbar-brand img{border-radius:6px}
.navbar-toggler{border:1px solid rgba(255,255,255,.22);padding:5px 9px;border-radius:7px}
.navbar-toggler:focus{box-shadow:none}
.navbar-toggler-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255,255,255,.85)' stroke-linecap='round' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")}
.navbar-nav .nav-link{color:rgba(255,255,255,.72)!important;font-size:.845rem;font-weight:500;
  padding:6px 10px!important;border-radius:7px;transition:all var(--tr);display:flex;align-items:center;gap:6px}
.navbar-nav .nav-link:hover,.navbar-nav .nav-link.active{color:#fff!important;background:rgba(255,255,255,.1)}
.navbar-nav .nav-link i{font-size:1rem}
.dropdown-menu{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  box-shadow:var(--sh-lg);padding:5px;min-width:210px;animation:dropIn .14s ease}
@keyframes dropIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.dropdown-item{color:var(--text2);font-size:.845rem;padding:8px 12px;border-radius:7px;
  transition:all var(--tr);display:flex;align-items:center;gap:8px}
.dropdown-item:hover,.dropdown-item.active{color:var(--primary);background:var(--prim-l)}
.dropdown-item i{font-size:1rem;width:18px;flex-shrink:0}
.dropdown-divider{border-color:var(--border);margin:4px 0}
.dropdown-header{font-size:.67rem;text-transform:uppercase;letter-spacing:.09em;color:var(--text3);font-weight:700;padding:8px 12px 3px}
.dropdown-submenu{position:relative}
.dropdown-submenu .dropdown-menu{top:0;left:100%;margin-top:-1px;display:none;min-width:180px}
.dropdown-submenu:hover>.dropdown-menu,.dropdown-submenu.show>.dropdown-menu{display:block}
.dropdown-submenu>a::after{content:'';display:inline-block;margin-left:auto;float:right;margin-top:5px;
  border-top:.28em solid transparent;border-bottom:.28em solid transparent;border-left:.28em solid currentColor}
.nav-avatar{width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,.14);
  display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:#fff;flex-shrink:0}

/* LAYOUT */
main.app-main{padding:22px 14px;max-width:1440px;margin:0 auto}
@media(min-width:768px){main.app-main{padding:26px 22px}}
@media(min-width:1200px){main.app-main{padding:30px 32px}}

/* PAGE HEADER */
.ph{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;flex-wrap:wrap;gap:10px}
.ph-title{font-size:1.18rem;font-weight:700;color:var(--text);letter-spacing:-.03em;display:flex;align-items:center;gap:8px}
.ph-title i{color:var(--primary);font-size:1.05rem}
.ph-sub{font-size:.8rem;color:var(--text3);margin-top:2px}
@media(max-width:575px){.ph-title{font-size:1rem}}

/* CARDS */
.card{background:var(--surface);border:1px solid var(--border)!important;border-radius:var(--r-lg)!important;box-shadow:var(--sh);transition:box-shadow var(--tr)}
@media(min-width:768px){.card:hover{box-shadow:var(--sh-md)}}
.card-header{background:var(--surface)!important;border-bottom:1px solid var(--border)!important;
  padding:13px 18px!important;border-radius:var(--r-lg) var(--r-lg) 0 0!important;
  font-weight:600;font-size:.88rem;color:var(--text2);display:flex;align-items:center;gap:8px}
.card-header .card-title{font-weight:600;font-size:.88rem;color:var(--text2);margin:0;display:flex;align-items:center;gap:8px}
.card-header .card-actions{margin-left:auto;display:flex;align-items:center;gap:6px}
.card-body{padding:16px 18px!important}
.card-footer{background:var(--surface2)!important;border-top:1px solid var(--border)!important;
  border-radius:0 0 var(--r-lg) var(--r-lg)!important;font-size:.78rem;color:var(--text3);padding:9px 18px!important}

/* STAT CARDS */
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:18px 20px;box-shadow:var(--sh);transition:transform var(--tr),box-shadow var(--tr);position:relative;overflow:hidden}
@media(min-width:768px){.stat-card:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}}
.stat-card .subheader{font-size:.68rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;display:flex;align-items:center;gap:5px}
.stat-card .h1{font-size:1.85rem;font-weight:800;letter-spacing:-.05em;line-height:1;margin-bottom:6px}
.stat-stamp{position:absolute;bottom:-10px;right:-10px;width:62px;height:62px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;opacity:.07;pointer-events:none}
.stat-stamp i{font-size:2rem}
.stat-ribbon{position:absolute;top:10px;right:-8px;background:var(--danger);color:#fff;
  font-size:.6rem;font-weight:800;padding:2px 10px 2px 8px;border-radius:3px 0 0 3px;letter-spacing:.06em;z-index:2}
.stat-ribbon::after{content:'';position:absolute;right:0;bottom:-4px;border-left:8px solid #b91c1c;border-bottom:4px solid transparent}
.status-live{display:inline-block;width:7px;height:7px;border-radius:50%;background:#22c55e;
  box-shadow:0 0 0 0 rgba(34,197,94,.5);animation:pulse-live 2s infinite;flex-shrink:0}
@keyframes pulse-live{0%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}70%{box-shadow:0 0 0 6px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
.stat-icon{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}
.si-blue{background:var(--prim-l);color:var(--primary)}.si-green{background:var(--succ-l);color:var(--success)}
.si-warn{background:var(--warn-l);color:var(--warn)}.si-danger{background:var(--dang-l);color:var(--danger)}
.si-info{background:var(--info-l);color:var(--info)}.si-orange{background:var(--orange-l);color:var(--orange)}
.si-purple{background:var(--purple-l);color:var(--purple)}
.subheader{font-size:.68rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em}

/* STEPS */
.steps-bar{display:flex;gap:0}
.step-item{flex:1;text-align:center;position:relative}
.step-item+.step-item::before{content:'';position:absolute;left:-50%;right:50%;top:13px;height:2px;background:var(--border)}
.step-item.done+.step-item::before{background:var(--primary)}
.step-circle{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  margin:0 auto 5px;font-size:.65rem;font-weight:700;position:relative;z-index:1}
.step-label{font-size:.62rem;font-weight:600;color:var(--text3);letter-spacing:.03em}
.step-item.done .step-circle{background:var(--primary);color:#fff}
.step-item.done .step-label{color:var(--primary)}
.step-item.active .step-circle{background:var(--warn);color:#fff;box-shadow:0 0 0 3px rgba(245,158,11,.2)}
.step-item.active .step-label{color:var(--warn)}
.step-item.pending .step-circle{background:var(--surface2);color:var(--text3);border:2px solid var(--border)}

/* AVATAR STACK */
.av-stack{display:flex}
.av-stack .avatar{margin-left:-6px;border:2px solid #fff}
.av-stack .avatar:first-child{margin-left:0}
.avatar{width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;
  font-size:.78rem;font-weight:700;flex-shrink:0;background:var(--prim-l);color:var(--primary)}
.avatar-xs{width:22px;height:22px;font-size:.58rem}
.avatar-sm{width:26px;height:26px;font-size:.65rem}
.avatar-md{width:36px;height:36px;font-size:.82rem}
.avatar-lg{width:44px;height:44px;font-size:.95rem}

/* DATAGRID */
.datagrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}
.datagrid-item{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:10px 12px}
.datagrid-title{font-size:.67rem;font-weight:700;color:var(--text3);text-transform:uppercase;
  letter-spacing:.06em;margin-bottom:4px;display:flex;align-items:center;gap:4px}
.datagrid-content{font-size:.88rem;font-weight:600;color:var(--text);display:flex;align-items:center;gap:5px}

/* ACTIVITY */
.activity-item{display:flex;gap:.85rem;padding:.65rem 0;position:relative}
.activity-item+.activity-item::before{content:'';position:absolute;left:15px;top:0;bottom:0;width:1px;background:var(--border);z-index:0}
.activity-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;z-index:1;border:2px solid #fff;box-shadow:0 0 0 1px var(--border)}
.activity-dot i{font-size:.9rem}
.activity-content{flex:1;min-width:0;padding-top:3px}
.activity-title{font-size:.82rem;font-weight:600;color:var(--text);line-height:1.3}
.activity-sub{font-size:.72rem;color:var(--text3);margin-top:2px}
.activity-time{font-size:.68rem;color:var(--text3);white-space:nowrap}

/* BORDER-LEFT */
.bl-primary{border-left:4px solid var(--primary)!important}.bl-success{border-left:4px solid var(--success)!important}
.bl-warn{border-left:4px solid var(--warn)!important}.bl-danger{border-left:4px solid var(--danger)!important}
.bl-gray{border-left:4px solid var(--border2)!important}

/* BUTTONS */
.btn{font-weight:600;font-size:.845rem;border-radius:var(--r)!important;padding:8px 16px;min-height:36px;
  transition:all var(--tr);display:inline-flex;align-items:center;gap:6px;letter-spacing:-.01em;
  cursor:pointer;border:none!important}
.btn-sm{padding:5px 12px;min-height:30px;font-size:.78rem}
.btn-lg{padding:12px 22px;min-height:46px;font-size:.9rem}
.btn-primary{background:var(--primary)!important;color:#fff!important;box-shadow:0 2px 8px rgba(37,99,235,.28)}
.btn-primary:hover{background:var(--prim-d)!important;color:#fff!important;transform:translateY(-1px);box-shadow:0 4px 14px rgba(37,99,235,.38)}
.btn-success{background:var(--success)!important;color:#fff!important}
.btn-danger{background:var(--danger)!important;color:#fff!important}
.btn-warning{background:var(--warn)!important;color:#fff!important}
.btn-secondary{background:#64748b!important;color:#fff!important}
.btn-outline-primary{background:transparent!important;border:1.5px solid var(--primary)!important;color:var(--primary)!important}
.btn-outline-secondary{background:transparent!important;border:1.5px solid var(--border2)!important;color:var(--text2)!important}
.btn-outline-danger{background:transparent!important;border:1.5px solid var(--danger)!important;color:var(--danger)!important}
.btn-outline-success{background:transparent!important;border:1.5px solid var(--success)!important;color:var(--success)!important}
.btn-ghost-primary{background:transparent!important;border:none!important;color:var(--primary)!important}
.btn-ghost-secondary{background:transparent!important;border:none!important;color:var(--text2)!important}
.btn-ghost-danger{background:transparent!important;border:none!important;color:var(--danger)!important}
.btn-outline-primary:hover{background:var(--prim-l)!important}
.btn-outline-secondary:hover{background:var(--surface2)!important}
.btn-outline-danger:hover{background:var(--dang-l)!important}
.btn-ghost-primary:hover{background:var(--prim-l)!important}
.btn-ghost-danger:hover{background:var(--dang-l)!important}
@media(max-width:767px){.btn{min-height:44px}.btn-sm{min-height:40px}}

/* FORMS */
.form-control,.form-select{background:var(--surface)!important;border:1.5px solid var(--border)!important;
  border-radius:var(--r)!important;font-family:'Inter',sans-serif;font-size:.875rem!important;
  color:var(--text)!important;padding:8px 12px!important;min-height:38px;
  transition:border-color var(--tr),box-shadow var(--tr)}
.form-control:focus,.form-select:focus{border-color:var(--primary)!important;box-shadow:0 0 0 3px rgba(37,99,235,.12)!important;outline:none!important}
.form-control.is-invalid{border-color:var(--danger)!important}
.form-control-sm,.form-select-sm{padding:5px 10px!important;min-height:32px!important;font-size:.8rem!important}
.form-label{font-weight:600;font-size:.78rem;color:var(--text2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:5px;display:flex;align-items:center;gap:4px}
.form-text{font-size:.73rem;color:var(--text3);margin-top:4px}
textarea.form-control{resize:vertical;min-height:80px}
.form-check-input:checked{background-color:var(--primary);border-color:var(--primary)}
.form-check-input:focus{box-shadow:0 0 0 3px rgba(37,99,235,.12);border-color:var(--primary)}
.form-switch .form-check-input{width:2.5em}
.input-group-text{background:var(--surface2)!important;border:1.5px solid var(--border)!important;border-radius:var(--r)!important;color:var(--text3);font-size:.85rem}
@media(max-width:767px){.form-control,.form-select{min-height:46px;font-size:.95rem!important}}

/* TABLES */
.table{font-size:.855rem}
.table thead th{background:var(--surface2)!important;color:var(--text3);font-weight:700;font-size:.68rem;
  text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border)!important;padding:10px 14px!important;white-space:nowrap}
.table tbody td{border-bottom:1px solid var(--border)!important;padding:11px 14px!important;vertical-align:middle;color:var(--text2)}
.table tbody tr:last-child td{border-bottom:none!important}
.table-hover tbody tr:hover td{background:var(--surface2)!important}
@media(max-width:640px){
  .tbl-cards thead{display:none}
  .tbl-cards tbody tr{display:block;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);margin-bottom:8px;padding:12px 14px}
  .tbl-cards tbody td{display:flex;justify-content:space-between;align-items:center;border:none!important;padding:4px 0!important;font-size:.84rem}
  .tbl-cards tbody td::before{content:attr(data-label);font-weight:700;font-size:.67rem;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;flex-shrink:0;margin-right:10px}
}

/* BADGES */
.badge{font-size:.68rem!important;font-weight:700!important;padding:3px 9px!important;border-radius:20px!important;
  letter-spacing:.02em;display:inline-flex;align-items:center;gap:4px}
.badge.bg-success{background:var(--success)!important}.badge.bg-danger{background:var(--danger)!important}
.badge.bg-warning{background:var(--warn)!important;color:#fff!important}.badge.bg-info{background:var(--info)!important}
.badge.bg-secondary{background:#64748b!important}.badge.bg-primary{background:var(--primary)!important}
.badge.bg-success-subtle{background:var(--succ-l)!important;color:#065f46!important}
.badge.bg-primary-subtle{background:var(--prim-l)!important;color:var(--primary)!important}
.badge.bg-warning-subtle{background:var(--warn-l)!important;color:#92400e!important}
.badge.bg-danger-subtle{background:var(--dang-l)!important;color:#991b1b!important}
.badge.bg-info-subtle{background:var(--info-l)!important;color:#0c4a6e!important}
.badge.bg-secondary-subtle{background:#f1f5f9!important;color:#475569!important}
.badge.bg-orange-subtle{background:var(--orange-l)!important;color:#9a3412!important}
.badge.bg-purple-subtle{background:var(--purple-l)!important;color:#6d28d9!important}

/* MODALS */
.modal-content{border:none!important;border-radius:var(--r-xl)!important;box-shadow:var(--sh-lg)!important}
.modal-header{border-bottom:1px solid var(--border)!important;padding:16px 20px!important;border-radius:var(--r-xl) var(--r-xl) 0 0!important}
.modal-title{font-weight:700;color:var(--text);font-size:.92rem}
.modal-body{padding:18px 20px!important}
.modal-footer{border-top:1px solid var(--border)!important;padding:12px 20px!important}
@media(max-width:576px){
  .modal-dialog{margin:0;align-items:flex-end;min-height:100%}
  .modal-dialog.modal-dialog-centered{align-items:flex-end}
  .modal-content{border-radius:var(--r-xl) var(--r-xl) 0 0!important}
}

/* ALERTS */
.alert{border:none!important;border-radius:var(--r)!important;font-size:.855rem;padding:11px 15px!important;display:flex;align-items:flex-start;gap:8px}
.alert-success{background:var(--succ-l)!important;color:#065f46!important}
.alert-danger{background:var(--dang-l)!important;color:#991b1b!important}
.alert-warning{background:var(--warn-l)!important;color:#92400e!important}
.alert-info{background:var(--info-l)!important;color:#0c4a6e!important}
.alert-light{background:var(--surface2)!important;color:var(--text2)!important;border:1px solid var(--border)!important}

/* PROGRESS */
.progress{background:var(--border)!important;border-radius:99px!important;overflow:hidden}
.progress-bar{background:var(--primary)!important;border-radius:99px!important;transition:width .4s ease!important}
.progress-bar.bg-success{background:var(--success)!important}.progress-bar.bg-warning{background:var(--warn)!important}
.progress-bar.bg-danger{background:var(--danger)!important}.progress-bar.bg-info{background:var(--info)!important}
.progress-xs{height:4px!important}.progress-sm{height:6px!important}

/* SECTION HEAD */
.sec-head{display:flex;align-items:center;gap:8px;margin:0 0 14px}
.sec-head-bar{width:4px;height:20px;border-radius:2px;flex-shrink:0}
.sec-head-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--text2)}
.sec-head-badge{background:var(--surface2);color:var(--text3);border-radius:20px;padding:2px 9px;font-size:.67rem;font-weight:700;margin-left:4px}

/* KPI CARDS (fornecedor) */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:24px}
.kpi{background:var(--surface);border-radius:14px;padding:18px 16px;border:1px solid var(--border);
  box-shadow:var(--sh);transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}
.kpi:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.kpi::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:14px 14px 0 0}
.kpi.kc-blue::before{background:linear-gradient(90deg,#1e40af,#60a5fa)}
.kpi.kc-green::before{background:linear-gradient(90deg,#065f46,#34d399)}
.kpi.kc-amber::before{background:linear-gradient(90deg,#92400e,#fbbf24)}
.kpi.kc-violet::before{background:linear-gradient(90deg,#4c1d95,#a78bfa)}
.kpi.kc-rose::before{background:linear-gradient(90deg,#9f1239,#fb7185)}
.kpi.kc-teal::before{background:linear-gradient(90deg,#134e4a,#2dd4bf)}
.kpi-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}
.kpi-ico{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0}
.kpi-trend{font-size:.7rem;font-weight:700;display:flex;align-items:center;gap:3px}
.kpi-val{font-size:1.85rem;font-weight:800;letter-spacing:-.06em;line-height:1;margin-bottom:3px}
.kpi-lbl{font-size:.67rem;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:.07em}
@media(max-width:576px){.kpi-val{font-size:1.55rem}.kpi-grid{grid-template-columns:1fr 1fr;gap:8px}.kpi{padding:13px 12px}}

/* STATS PANEL */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;margin-bottom:24px}
.stats-panel{background:var(--surface);border-radius:14px;border:1px solid var(--border);box-shadow:var(--sh);overflow:hidden}
.stats-panel-head{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}
.stats-panel-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.stats-panel-title{font-weight:700;font-size:.88rem;color:var(--text)}
.stats-panel-body{padding:6px 0}
.stat-row{display:flex;align-items:center;gap:10px;padding:10px 16px}
.stat-ico{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}
.stat-content{flex:1;min-width:0}
.stat-lbl{font-size:.68rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em}
.stat-num{font-size:1.35rem;font-weight:800;letter-spacing:-.05em;line-height:1.2;color:var(--text)}
.stat-divider{height:1px;background:var(--border);margin:0 16px}

/* ROTA CARD */
.rota-card{background:var(--surface);border-radius:14px;border:1px solid var(--border);box-shadow:var(--sh);overflow:hidden;margin-bottom:14px}
.rota-card-head{background:linear-gradient(135deg,#f0f6ff,#fff);padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.rota-icon-wrap{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,#1e40af,#3b82f6);
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.15rem;flex-shrink:0;box-shadow:0 4px 12px rgba(37,99,235,.3)}
.rota-card-body{padding:14px 18px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.rota-donut-wrap{position:relative;width:120px;height:120px;flex-shrink:0}
.rota-donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}
.rota-donut-pct{font-size:1.3rem;font-weight:800;letter-spacing:-.05em;color:#1e40af;line-height:1}
.rota-donut-sub{font-size:.62rem;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.rota-legend{display:flex;flex-direction:column;gap:9px;flex:1;min-width:130px}
.rota-leg-item{display:flex;align-items:center;gap:9px}
.rota-leg-dot{width:11px;height:11px;border-radius:50%;flex-shrink:0}
.rota-leg-text{flex:1}
.rota-leg-label{font-size:.68rem;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.rota-leg-val{font-size:1.15rem;font-weight:800;letter-spacing:-.04em;color:var(--text);line-height:1.2}
.rota-btn{display:inline-flex;align-items:center;gap:7px;background:linear-gradient(135deg,#1e40af,#2563eb);
  color:#fff;border-radius:9px;padding:9px 18px;text-decoration:none;font-size:.8rem;font-weight:700;
  transition:all .2s;box-shadow:0 4px 12px rgba(37,99,235,.3);border:none;cursor:pointer;margin-top:10px}
.rota-btn:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(37,99,235,.4);color:#fff}

/* AÇÃO CARDS */
.acao-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px;margin-bottom:22px}
.acao-hoje{background:var(--surface);border-radius:14px;border:1px solid var(--border);box-shadow:var(--sh);
  padding:16px 18px;display:flex;flex-direction:column;gap:10px;transition:transform .2s,box-shadow .2s}
.acao-hoje:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.acao-hoje.tipo-evento{border-top:4px solid var(--warn)}
.acao-hoje.tipo-acao{border-top:4px solid #7c3aed}
.acao-type-badge{display:inline-flex;align-items:center;gap:5px;border-radius:20px;padding:3px 10px;font-size:.67rem;font-weight:700}
.atb-acao{background:#f5f3ff;color:#4c1d95}
.atb-evento{background:var(--warn-l);color:#92400e}

/* FOTOS */
.foto-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:8px}
.foto-card{position:relative;border-radius:10px;overflow:hidden}
.foto-card img{width:100%;height:108px;object-fit:cover;display:block}
.foto-cap{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.6));color:#fff;font-size:10px;padding:14px 5px 5px;line-height:1.3}
.foto-del{position:absolute;top:4px;right:4px;background:rgba(239,68,68,.85);border:none;border-radius:50%;
  width:24px;height:24px;color:#fff;font-size:11px;display:flex;align-items:center;justify-content:center;cursor:pointer}

/* BOTTOM NAV */
.bnav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);
  padding:5px 0 max(5px,env(safe-area-inset-bottom));z-index:999;box-shadow:0 -4px 18px rgba(0,0,0,.07)}
.bnav-item{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1;text-decoration:none;
  color:var(--text3);font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  padding:5px 3px;border-radius:7px;transition:color var(--tr)}
.bnav-item i{font-size:1.25rem}
.bnav-item.active{color:var(--primary)}
.bnav-item.active i{transform:scale(1.08)}
@media(max-width:767px){.bnav{display:flex}.has-bnav main{padding-bottom:78px}}

/* ANIMAÇÕES */
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.fu{animation:fadeUp .22s ease both}
.fu1{animation-delay:.04s}.fu2{animation-delay:.08s}.fu3{animation-delay:.12s}.fu4{animation-delay:.16s}
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
.skeleton{background:linear-gradient(90deg,var(--border) 25%,var(--surface2) 50%,var(--border) 75%);background-size:800px 100%;animation:shimmer 1.4s infinite;border-radius:6px}

/* MISC */
.status-sel{font-size:.8rem!important;padding:5px 10px!important;min-height:auto!important;cursor:pointer}
img[loading="lazy"]{opacity:0;transition:opacity .3s}
img[loading="lazy"].loaded{opacity:1}
@media(min-width:768px){::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:99px}}

/* FORNECEDOR PREMIUM */
body.perfil-fornecedor{background:#f0f4ff}
body.perfil-fornecedor .navbar{background:linear-gradient(135deg,#0f172a,#1e3a5f)!important;border-bottom:1px solid rgba(59,130,246,.2)}
@media(min-width:768px){
  body.perfil-fornecedor .forn-header{background:linear-gradient(135deg,#1e3a5f 0%,#1e40af 60%,#2563eb 100%);border-radius:var(--r-xl);padding:30px 34px;margin-bottom:26px;color:#fff;box-shadow:0 8px 32px rgba(30,64,175,.3);position:relative;overflow:hidden}
  body.perfil-fornecedor .forn-header::after{content:'';position:absolute;top:-40px;right:-40px;width:200px;height:200px;background:rgba(255,255,255,.06);border-radius:50%}
  body.perfil-fornecedor .forn-header::before{content:'';position:absolute;bottom:-60px;right:80px;width:280px;height:280px;background:rgba(255,255,255,.04);border-radius:50%}
  body.perfil-fornecedor .card{border-color:rgba(37,99,235,.12)!important;box-shadow:0 2px 8px rgba(37,99,235,.06)}
  body.perfil-fornecedor .card:hover{box-shadow:0 8px 24px rgba(37,99,235,.12);border-color:rgba(37,99,235,.2)!important}
  body.perfil-fornecedor .card-header{background:linear-gradient(to right,#f8faff,#fff)!important;border-bottom-color:rgba(37,99,235,.1)!important}
  body.perfil-fornecedor .kpi{border-color:rgba(37,99,235,.12)!important}
  body.perfil-fornecedor .table thead th{background:linear-gradient(to right,#f0f6ff,#f8faff)!important;color:#1e40af;border-bottom-color:rgba(37,99,235,.15)!important}
  body.perfil-fornecedor .table-hover tbody tr:hover td{background:#f0f6ff!important}
}
@media(max-width:767px){
  body.perfil-fornecedor .forn-header{background:linear-gradient(135deg,#1e40af,#2563eb);border-radius:var(--r-lg);padding:18px 16px;margin-bottom:18px;color:#fff;box-shadow:0 4px 16px rgba(30,64,175,.3)}
  body.perfil-fornecedor .bnav{background:linear-gradient(to top,#0f172a,#1e293b);border-top:1px solid rgba(59,130,246,.2)}
  body.perfil-fornecedor .bnav-item{color:rgba(255,255,255,.45)}
  body.perfil-fornecedor .bnav-item.active{color:#60a5fa}
}
body.perfil-fornecedor .btn-primary{background:linear-gradient(135deg,#1e40af,#2563eb)!important;box-shadow:0 4px 14px rgba(30,64,175,.35)!important}
body.perfil-fornecedor .btn-primary:hover{background:linear-gradient(135deg,#1e3a8a,#1d4ed8)!important}

/* LOGIN */
.login-bg{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e3a5f 50%,#0f172a);display:flex;align-items:center;justify-content:center;padding:20px;position:relative;overflow:hidden}
.login-bg::before{content:'';position:absolute;inset:-50%;background:radial-gradient(ellipse at 30% 40%,rgba(37,99,235,.18),transparent 60%),radial-gradient(ellipse at 70% 70%,rgba(16,185,129,.12),transparent 50%);animation:breathe 8s ease-in-out infinite}
@keyframes breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.04)}}
.login-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:22px;padding:38px 34px;width:100%;max-width:390px;backdrop-filter:blur(20px);box-shadow:0 24px 64px rgba(0,0,0,.4);animation:fadeUp .4s ease;position:relative;z-index:1}
.login-inp{width:100%;background:rgba(255,255,255,.07);border:1.5px solid rgba(255,255,255,.12);border-radius:10px;padding:12px 14px;font-family:'Inter',sans-serif;font-size:.9rem;color:#fff;outline:none;transition:all .15s}
.login-inp:focus{background:rgba(255,255,255,.11);border-color:#3b82f6;box-shadow:0 0 0 3px rgba(59,130,246,.2)}
.login-inp::placeholder{color:rgba(255,255,255,.3)}
.login-btn{width:100%;padding:13px;background:#2563eb;border:none;border-radius:10px;font-family:'Inter',sans-serif;font-size:.9rem;font-weight:700;color:#fff;cursor:pointer;transition:all .15s;box-shadow:0 4px 16px rgba(37,99,235,.4);margin-top:22px}
.login-btn:hover{background:#1d4ed8;transform:translateY(-1px)}
