:root{
  --bg:#eef4ff;--card:#fff;--dark:#101d33;--blue:#2563eb;--blue2:#1d4ed8;--muted:#64748b;--border:#e2e8f0;--danger:#dc2626;--ok:#16a34a;
  --purple:#7c3aed;--cyan:#0891b2;--orange:#f97316;--pink:#db2777;--green:#059669;--slate:#475569;
}
*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:linear-gradient(135deg,#eef4ff 0%,#f8fafc 45%,#ecfeff 100%);color:#172033}.app{display:flex;min-height:100vh}.sidebar{width:250px;background:linear-gradient(180deg,#101d33 0%,#152238 55%,#1e293b 100%);color:white;padding:18px;position:fixed;inset:0 auto 0 0;z-index:10;box-shadow:10px 0 30px rgba(15,23,42,.12)}.brand{font-size:22px;font-weight:bold;margin-bottom:22px;letter-spacing:.3px}.sidebar a{display:block;color:#dbeafe;text-decoration:none;padding:12px;border-radius:12px;margin:5px 0;transition:.18s}.sidebar a:hover{background:#263a5d;transform:translateX(2px)}.main{margin-left:250px;flex:1}.topbar{height:64px;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 22px;position:sticky;top:0;z-index:5}.menu{display:none;border:0;background:#e8eefc;border-radius:10px;padding:10px;font-size:18px}.user a{margin-left:12px;color:var(--blue);font-weight:700}.content{padding:22px}.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.card{background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(255,255,255,.90));border:1px solid rgba(226,232,240,.95);border-radius:18px;padding:18px;box-shadow:0 10px 28px rgba(15,23,42,.07);margin-bottom:16px;position:relative;overflow:hidden}.card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(180deg,var(--blue),var(--cyan));opacity:.95}.grid>.card:nth-child(6n+1):before{background:linear-gradient(180deg,var(--blue),var(--cyan))}.grid>.card:nth-child(6n+2):before{background:linear-gradient(180deg,var(--green),#22c55e)}.grid>.card:nth-child(6n+3):before{background:linear-gradient(180deg,var(--orange),#f59e0b)}.grid>.card:nth-child(6n+4):before{background:linear-gradient(180deg,var(--purple),#a855f7)}.grid>.card:nth-child(6n+5):before{background:linear-gradient(180deg,var(--pink),#f472b6)}.grid>.card:nth-child(6n+6):before{background:linear-gradient(180deg,var(--slate),#94a3b8)}a.card{transition:.18s}a.card:hover{transform:translateY(-2px);box-shadow:0 16px 34px rgba(15,23,42,.11)}.metric{font-size:30px;font-weight:bold;color:var(--blue);line-height:1.1}.grid>.card:nth-child(6n+2) .metric{color:var(--green)}.grid>.card:nth-child(6n+3) .metric{color:var(--orange)}.grid>.card:nth-child(6n+4) .metric{color:var(--purple)}.grid>.card:nth-child(6n+5) .metric{color:var(--pink)}.grid>.card:nth-child(6n+6) .metric{color:var(--slate)}.muted{color:var(--muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:0;border-radius:10px;padding:8px 12px;background:linear-gradient(135deg,var(--blue),var(--blue2));color:white;text-decoration:none;cursor:pointer;font-size:14px;font-weight:700;line-height:1.2;min-height:36px;width:auto;max-width:max-content;box-shadow:0 6px 14px rgba(37,99,235,.18);transition:.16s}.btn:hover{filter:brightness(.97);transform:translateY(-1px)}.btn.secondary{background:linear-gradient(135deg,#64748b,#475569);box-shadow:0 6px 14px rgba(71,85,105,.16)}.btn.danger{background:linear-gradient(135deg,#ef4444,var(--danger));box-shadow:0 6px 14px rgba(220,38,38,.16)}.btn.ok{background:linear-gradient(135deg,#22c55e,var(--ok));box-shadow:0 6px 14px rgba(22,163,74,.16)}.actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.table-wrap{overflow:auto;border-radius:14px;border:1px solid var(--border);background:#fff}.table{width:100%;border-collapse:collapse;background:white}.table th,.table td{padding:12px;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap}.table th{background:#f8fafc;color:#334155}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-group label{font-weight:bold;display:block;margin-bottom:6px}.form-control,select,textarea{width:100%;border:1px solid var(--border);border-radius:12px;padding:11px;background:white}textarea{min-height:90px}.alert{padding:12px;border-radius:12px;margin-bottom:16px}.alert.ok{background:#dcfce7;color:#166534}.alert.err{background:#fee2e2;color:#991b1b}.login{display:flex;min-height:100vh;align-items:center;justify-content:center;padding:20px}.login .card{width:100%;max-width:420px}.checkgrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.pill{display:inline-block;padding:5px 9px;border-radius:999px;background:#e0f2fe;color:#075985;font-size:12px;font-weight:700}.print-header{display:none}
@media(max-width:900px){.grid{grid-template-columns:repeat(2,1fr)}.form-grid{grid-template-columns:1fr}.sidebar{transform:translateX(-100%);transition:.2s}.show-sidebar .sidebar{transform:translateX(0)}.main{margin-left:0}.menu{display:block}.topbar{padding:0 12px}.content{padding:14px}.table th,.table td{padding:10px}.checkgrid{grid-template-columns:1fr}.btn{padding:8px 11px;font-size:13px;min-height:34px}.actions{gap:6px}}
@media(max-width:520px){.grid{grid-template-columns:1fr}.actions .btn{width:auto;max-width:max-content;text-align:center}.user{font-size:12px}.topbar strong{font-size:14px}.content{padding:12px}.card{padding:14px;border-radius:16px}.metric{font-size:26px}}
@media print{.sidebar,.topbar,.no-print,.btn{display:none!important}.main{margin-left:0!important}.content{padding:0!important}.card{box-shadow:none!important;border:0!important;margin:0 0 10px 0!important;padding:8px!important}.card:before{display:none!important}.table th,.table td{border:1px solid #999!important;padding:6px!important;white-space:normal!important}body{background:#fff!important;font-size:12px}.print-header{display:block!important}}

/* v2.8 - Modal de localização e detalhes */
.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-top:12px}
.details-grid>div{background:#f8fafc;border:1px solid #e5e7eb;border-radius:14px;padding:12px}
.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.65);z-index:9999;align-items:center;justify-content:center;padding:16px}
.modal-card{background:#fff;border-radius:18px;box-shadow:0 24px 70px rgba(0,0,0,.25);width:min(940px,96vw);padding:18px}
.map-frame{width:100%;height:420px;border:0;border-radius:14px;background:#e5e7eb}
.card-blue{background:linear-gradient(135deg,#e0f2fe,#ffffff)}
.card-green{background:linear-gradient(135deg,#dcfce7,#ffffff)}
.card-purple{background:linear-gradient(135deg,#ede9fe,#ffffff)}
.btn.success{background:#16a34a;color:#fff}
@media(max-width:700px){.map-frame{height:320px}.modal-card{padding:12px}.details-grid{grid-template-columns:1fr}}


/* v2.9 - Botão modo claro/escuro */
.top-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.theme-toggle{border:1px solid rgba(148,163,184,.35);border-radius:999px;padding:8px 12px;background:#f8fafc;color:#0f172a;cursor:pointer;font-weight:800;box-shadow:0 6px 16px rgba(15,23,42,.08);white-space:nowrap}
.theme-toggle:hover{transform:translateY(-1px)}
.floating-theme{position:fixed;right:14px;top:14px;z-index:50}
body.theme-dark{background:linear-gradient(135deg,#020617 0%,#0f172a 48%,#111827 100%);color:#e5e7eb}
body.theme-dark .sidebar{background:linear-gradient(180deg,#020617 0%,#0b1220 55%,#111827 100%);box-shadow:10px 0 30px rgba(0,0,0,.35)}
body.theme-dark .brand{color:#f8fafc}
body.theme-dark .sidebar a{color:#dbeafe}
body.theme-dark .sidebar a:hover{background:#1e293b}
body.theme-dark .topbar{background:rgba(15,23,42,.92);border-bottom-color:#334155;color:#f8fafc}
body.theme-dark .card{background:linear-gradient(180deg,rgba(30,41,59,.98),rgba(15,23,42,.96));border-color:#334155;color:#e5e7eb;box-shadow:0 12px 30px rgba(0,0,0,.28)}
body.theme-dark .card-blue{background:linear-gradient(135deg,#0f2f4a,#172033)}
body.theme-dark .card-green{background:linear-gradient(135deg,#0f3a28,#172033)}
body.theme-dark .card-purple{background:linear-gradient(135deg,#2c1c55,#172033)}
body.theme-dark .muted{color:#cbd5e1}
body.theme-dark .theme-toggle{background:#1e293b;color:#e5e7eb;border-color:#475569;box-shadow:0 6px 16px rgba(0,0,0,.25)}
body.theme-dark .table-wrap,body.theme-dark .table{background:#0f172a;border-color:#334155;color:#e5e7eb}
body.theme-dark .table th{background:#1e293b;color:#e2e8f0;border-color:#334155}
body.theme-dark .table td{border-color:#334155}
body.theme-dark .form-control,body.theme-dark select,body.theme-dark textarea{background:#0f172a;color:#e5e7eb;border-color:#475569}
body.theme-dark .details-grid>div{background:#0f172a;border-color:#334155;color:#e5e7eb}
body.theme-dark .modal-card{background:#111827;color:#e5e7eb}
body.theme-dark .menu{background:#1e293b;color:#f8fafc}
body.theme-dark .pill{background:#164e63;color:#cffafe}
body.theme-dark a{color:#93c5fd}
body.theme-dark .alert.ok{background:#064e3b;color:#dcfce7}
body.theme-dark .alert.err{background:#7f1d1d;color:#fee2e2}
@media(max-width:520px){.theme-toggle{padding:7px 10px;font-size:12px}.floating-theme{top:10px;right:10px}}
@media print{.theme-toggle,.floating-theme{display:none!important}}


/* v3.0 - Ícones em menu e cards */
.brand{display:flex;align-items:center;gap:10px}
.brand-icon{width:34px;height:34px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#38bdf8,#2563eb);box-shadow:0 10px 24px rgba(37,99,235,.28)}
.sidebar .nav-link{display:flex;align-items:center;gap:10px;font-weight:700}
.nav-icon{width:30px;height:30px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.10);box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);font-size:16px;flex:0 0 30px}
.sidebar .nav-link:hover .nav-icon{background:rgba(96,165,250,.22)}
.page-title{display:flex;align-items:center;gap:10px;min-width:0}
.page-title-icon{width:30px;height:30px;border-radius:11px;display:inline-flex;align-items:center;justify-content:center;background:#eff6ff;color:#1d4ed8;box-shadow:0 6px 14px rgba(37,99,235,.12)}
.dashboard-grid .metric-card{display:flex;align-items:center;gap:15px;min-height:118px;padding-left:18px}
.card-icon{width:52px;height:52px;border-radius:17px;display:inline-flex;align-items:center;justify-content:center;font-size:25px;background:linear-gradient(135deg,#dbeafe,#f8fafc);box-shadow:0 10px 24px rgba(37,99,235,.14);flex:0 0 52px}
.metric-info{min-width:0}.metric-card .muted{font-weight:800;letter-spacing:.2px}.metric-card:hover .card-icon{transform:scale(1.04) rotate(-2deg);transition:.18s}
.dashboard-grid>.metric-card:nth-child(6n+2) .card-icon{background:linear-gradient(135deg,#dcfce7,#f8fafc)}
.dashboard-grid>.metric-card:nth-child(6n+3) .card-icon{background:linear-gradient(135deg,#ffedd5,#f8fafc)}
.dashboard-grid>.metric-card:nth-child(6n+4) .card-icon{background:linear-gradient(135deg,#ede9fe,#f8fafc)}
.dashboard-grid>.metric-card:nth-child(6n+5) .card-icon{background:linear-gradient(135deg,#fce7f3,#f8fafc)}
.dashboard-grid>.metric-card:nth-child(6n+6) .card-icon{background:linear-gradient(135deg,#e2e8f0,#f8fafc)}
.employee-card{min-height:210px;display:flex;flex-direction:column;gap:5px}.employee-card .card-icon{margin-bottom:5px}.employee-card h3{margin:4px 0 2px}.employee-card .btn{margin-top:auto}.title-icon{display:inline-flex;margin-right:8px}.employee-welcome h2{margin-top:0}
body.theme-dark .page-title-icon{background:#1e293b;color:#bfdbfe;box-shadow:0 6px 16px rgba(0,0,0,.25)}
body.theme-dark .card-icon{background:linear-gradient(135deg,#1e3a8a,#0f172a);box-shadow:0 12px 26px rgba(0,0,0,.28)}
body.theme-dark .dashboard-grid>.metric-card:nth-child(6n+2) .card-icon{background:linear-gradient(135deg,#14532d,#0f172a)}
body.theme-dark .dashboard-grid>.metric-card:nth-child(6n+3) .card-icon{background:linear-gradient(135deg,#7c2d12,#0f172a)}
body.theme-dark .dashboard-grid>.metric-card:nth-child(6n+4) .card-icon{background:linear-gradient(135deg,#4c1d95,#0f172a)}
body.theme-dark .dashboard-grid>.metric-card:nth-child(6n+5) .card-icon{background:linear-gradient(135deg,#831843,#0f172a)}
body.theme-dark .dashboard-grid>.metric-card:nth-child(6n+6) .card-icon{background:linear-gradient(135deg,#334155,#0f172a)}
@media(max-width:900px){.dashboard-grid .metric-card{min-height:104px}.card-icon{width:46px;height:46px;border-radius:15px;font-size:22px;flex-basis:46px}.nav-icon{width:28px;height:28px;flex-basis:28px}}
@media(max-width:520px){.dashboard-grid .metric-card{min-height:92px;padding:14px;gap:12px}.card-icon{width:42px;height:42px;border-radius:14px;font-size:20px;flex-basis:42px}.page-title-icon{display:none}.brand-icon{width:30px;height:30px}.employee-card{min-height:180px}}
@media print{.brand-icon,.nav-icon,.page-title-icon,.card-icon{display:none!important}}

/* v3.3 - Frota do funcionário e abastecimentos */
.card-orange{background:linear-gradient(135deg,#ffedd5,#ffffff)}
.photo-thumb{max-width:90px;max-height:70px;border-radius:10px;border:1px solid var(--border);object-fit:cover;background:#f8fafc}
.upload-hint{font-size:12px;color:var(--muted);margin-top:4px}
.location-required{background:#eff6ff;border:1px solid #bfdbfe;color:#1e3a8a;border-radius:14px;padding:12px;margin:10px 0}
body.theme-dark .card-orange{background:linear-gradient(135deg,#7c2d12,#172033)}
body.theme-dark .location-required{background:#172554;border-color:#1d4ed8;color:#dbeafe}

/* v3.5 - Mobile visualização, menu com rolagem e botão sair */
.sidebar{display:flex;flex-direction:column;max-height:100vh;overflow:hidden}
.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding-right:4px;padding-bottom:16px;-webkit-overflow-scrolling:touch}
.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.22);border-radius:999px}
.nav-logout{margin-top:14px!important;background:rgba(239,68,68,.14);color:#fee2e2!important}
.nav-logout:hover{background:rgba(239,68,68,.24)!important}
.view-stack .details-grid,.details-grid.view-stack{grid-template-columns:1fr!important}
.details-grid>div{word-break:break-word;line-height:1.35}
@media(max-width:900px){
  .sidebar{width:min(82vw,310px);height:100vh;overflow:hidden;padding-bottom:10px}
  .sidebar-nav{max-height:calc(100vh - 70px);overflow-y:auto;padding-bottom:28px}
  .details-grid{grid-template-columns:1fr!important;gap:10px}
  .details-grid>div{padding:11px;border-radius:12px}
  .modal-card .details-grid{grid-template-columns:1fr!important}
  .table.mobile-readable,.mobile-readable .table{min-width:0}
}
@media(max-width:520px){
  .details-grid>div strong{display:block;margin-bottom:3px}
  .modal-card{max-height:92vh;overflow:auto}
  .topbar .user a[href="logout.php"]{display:none}
}


/* v3.6 - Correção real das tabelas/visualizações no mobile */
@media(max-width:760px){
  .table-wrap{overflow:visible!important;border:0!important;background:transparent!important}
  .table.mobile-card-table{width:100%!important;border-collapse:separate!important;border-spacing:0!important;background:transparent!important;min-width:0!important}
  .table.mobile-card-table tbody,.table.mobile-card-table tr,.table.mobile-card-table td{display:block!important;width:100%!important;max-width:100%!important}
  .table.mobile-card-table tr:first-child{display:none!important}
  .table.mobile-card-table tr{margin:0 0 12px 0!important;border:1px solid var(--border)!important;border-radius:16px!important;background:#fff!important;box-shadow:0 8px 22px rgba(15,23,42,.06)!important;overflow:hidden!important;padding:6px 0!important}
  .table.mobile-card-table td{white-space:normal!important;border-bottom:1px solid var(--border)!important;padding:10px 12px 10px 44%!important;min-height:42px!important;position:relative!important;word-break:break-word!important;overflow-wrap:anywhere!important;text-align:left!important}
  .table.mobile-card-table td:last-child{border-bottom:0!important}
  .table.mobile-card-table td:before{content:attr(data-label);position:absolute;left:12px;top:10px;width:38%;font-weight:800;color:#334155;white-space:normal;line-height:1.2}
  .table.mobile-card-table td[colspan]{padding:12px!important;text-align:center!important}
  .table.mobile-card-table td[colspan]:before{display:none!important}
  .table.mobile-card-table td.actions,.table.mobile-card-table td.no-print.actions{padding-left:12px!important;display:flex!important;gap:8px!important;flex-wrap:wrap!important;align-items:center!important}
  .table.mobile-card-table td.actions:before,.table.mobile-card-table td.no-print.actions:before{position:static!important;width:100%!important;display:block!important;margin-bottom:4px!important}
  .table.mobile-card-table .btn{max-width:100%;white-space:normal;text-align:center}
  .details-grid{display:grid!important;grid-template-columns:1fr!important;width:100%!important;overflow:visible!important}
  .details-grid>div{width:100%!important;max-width:100%!important;white-space:normal!important;word-break:break-word!important;overflow-wrap:anywhere!important}
  .actions{max-width:100%;overflow:visible}.actions .btn{white-space:normal}
  body.theme-dark .table.mobile-card-table tr{background:#0f172a!important;border-color:#334155!important;box-shadow:0 8px 24px rgba(0,0,0,.22)!important}
  body.theme-dark .table.mobile-card-table td{border-color:#334155!important}
  body.theme-dark .table.mobile-card-table td:before{color:#cbd5e1!important}
}
@media(max-width:430px){
  .table.mobile-card-table td{padding-left:12px!important;padding-top:30px!important}
  .table.mobile-card-table td:before{top:9px;width:auto;right:12px}
}


/* v3.6.1 - Corrige topo do painel do funcionário */
.employee-theme-bar{position:sticky;top:0;z-index:60;display:flex;justify-content:flex-end;align-items:center;padding:10px 14px 0;background:transparent;pointer-events:none}
.employee-theme-bar .theme-toggle{pointer-events:auto}
.employee-theme-bar + .content{padding-top:12px}
@media(max-width:520px){.employee-theme-bar{padding:8px 10px 0}.employee-theme-bar .theme-toggle{font-size:12px;padding:7px 10px}.employee-theme-bar + .content{padding-top:8px}}
@media print{.employee-theme-bar{display:none!important}}

/* v3.7 - Ícones em botões, campos, formulários e logins */
.field-icon{display:inline-flex;align-items:center;justify-content:center;width:25px;height:25px;border-radius:9px;margin-right:7px;background:linear-gradient(135deg,#eff6ff,#dbeafe);color:#1d4ed8;font-size:14px;box-shadow:0 4px 10px rgba(37,99,235,.10);vertical-align:middle;line-height:1}
.form-group label{display:flex;align-items:center;gap:0;line-height:1.25;color:#243044}
.input-icon-wrap{position:relative;width:100%}
.input-icon-wrap .form-control,.input-icon-wrap select,.input-icon-wrap textarea{padding-left:43px!important}
.input-inside-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);font-size:16px;opacity:.78;pointer-events:none;z-index:1}
.input-icon-wrap.textarea-wrap .input-inside-icon{top:17px;transform:none}
.btn .btn-icon,.theme-toggle .btn-icon{display:inline-flex;align-items:center;justify-content:center;line-height:1;font-size:15px;margin-right:2px;filter:drop-shadow(0 1px 0 rgba(0,0,0,.08))}
.btn.iconized,.theme-toggle.iconized{gap:7px}
.login .card h1{display:flex;align-items:center;gap:10px;margin-top:0}
.login .card h1:before{content:'🔐';width:42px;height:42px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#dbeafe,#eff6ff);box-shadow:0 12px 26px rgba(37,99,235,.15);font-size:22px;flex:0 0 42px}
.login .card{border-top:4px solid var(--blue)}
.form-section-title,.card h2,.card h3{display:flex;align-items:center;gap:8px}
.card h2:before,.card h3:before{content:'✨';font-size:16px;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:10px;background:#eff6ff;color:#1d4ed8;box-shadow:0 6px 14px rgba(37,99,235,.10)}
.card h2.no-auto-icon:before,.card h3.no-auto-icon:before,.employee-welcome h2:before{display:none}
.table th{font-weight:900}.table th:first-child:before{content:'📌 ';}
.table th:nth-child(2):before{content:'🏷️ ';}.table th:nth-child(3):before{content:'📋 ';}.table th:nth-child(4):before{content:'📅 ';}.table th:nth-child(5):before{content:'⚙️ ';}
.details-grid>div strong:before{content:'🔹 ';opacity:.85}
body.theme-dark .field-icon{background:linear-gradient(135deg,#1e293b,#0f172a);color:#bfdbfe;box-shadow:0 6px 14px rgba(0,0,0,.24)}
body.theme-dark .login .card h1:before,body.theme-dark .card h2:before,body.theme-dark .card h3:before{background:linear-gradient(135deg,#1e293b,#0f172a);color:#bfdbfe;box-shadow:0 6px 16px rgba(0,0,0,.28)}
body.theme-dark .form-group label{color:#e5e7eb}.input-icon-wrap input[type=file]{padding-left:43px!important}
@media(max-width:520px){.field-icon{width:23px;height:23px;font-size:13px;margin-right:6px}.input-icon-wrap .form-control,.input-icon-wrap select,.input-icon-wrap textarea{padding-left:39px!important}.input-inside-icon{left:12px;font-size:15px}.login .card h1:before{width:38px;height:38px;flex-basis:38px;font-size:20px}.card h2:before,.card h3:before{width:25px;height:25px;font-size:14px}}
@media print{.field-icon,.input-inside-icon,.btn-icon,.login .card h1:before,.card h2:before,.card h3:before{display:none!important}.input-icon-wrap .form-control,.input-icon-wrap select,.input-icon-wrap textarea{padding-left:11px!important}}

/* v3.8 - Ícones em campos de cadastro, edição, visualização e dados */
.view-field{background:linear-gradient(135deg,rgba(248,250,252,.95),rgba(255,255,255,.92));border:1px solid rgba(226,232,240,.95);border-radius:14px;padding:12px;box-shadow:0 6px 16px rgba(15,23,42,.04)}
.view-field strong{display:flex;align-items:center;gap:7px;margin-bottom:4px;color:#243044}
.view-field-icon,.view-inline-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:9px;background:linear-gradient(135deg,#eff6ff,#dbeafe);color:#1d4ed8;font-size:14px;box-shadow:0 4px 10px rgba(37,99,235,.10);line-height:1;flex:0 0 24px;margin-right:2px}
.view-inline-icon{width:20px;height:20px;font-size:12px;border-radius:7px;margin-right:5px;vertical-align:middle}
@media(min-width:701px){.table td.data-cell-icon:not(.actions)::before{content:attr(data-icon);display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;margin-right:6px;border-radius:8px;background:#eff6ff;color:#1d4ed8;font-size:12px;vertical-align:middle}.table td.data-cell-icon{white-space:nowrap}}
@media(max-width:700px){.table.mobile-card-table td.data-cell-icon:before{content:attr(data-icon) '  ' attr(data-label)!important}.table.mobile-card-table td.actions:before{content:'⚙️  Ações'!important}.view-field{padding:11px}.details-grid{grid-template-columns:1fr!important}.form-grid{grid-template-columns:1fr!important}.input-icon-wrap .form-control,.input-icon-wrap select,.input-icon-wrap textarea{font-size:15px}}
body.theme-dark .view-field{background:linear-gradient(135deg,#0f172a,#111827);border-color:#334155;box-shadow:0 8px 18px rgba(0,0,0,.22)}
body.theme-dark .view-field strong{color:#e5e7eb}body.theme-dark .view-field-icon,body.theme-dark .view-inline-icon,body.theme-dark .table td.data-cell-icon:not(.actions)::before{background:linear-gradient(135deg,#1e293b,#0f172a);color:#bfdbfe}
@media print{.view-field{box-shadow:none;background:#fff}.view-field-icon,.view-inline-icon,.table td.data-cell-icon:before{display:none!important}}
.view-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin:12px 0}.view-grid>div{padding:12px;border:1px solid var(--border,#e5e7eb);border-radius:14px;background:rgba(148,163,184,.08)}.pre-box{white-space:pre-wrap;word-break:break-word;padding:14px;border-radius:14px;background:rgba(15,23,42,.06);border:1px solid var(--border,#e5e7eb);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.dark .pre-box,.theme-dark .pre-box,body.dark .pre-box{background:rgba(255,255,255,.06)}@media(max-width:700px){.view-grid{grid-template-columns:1fr}.view-grid>div{font-size:15px}}

/* v4.3.1 - Correção dos logins e ícones duplicados */
.login-card-clean .form-group{margin-bottom:14px}
.login-card-clean .form-group + .form-group{margin-top:6px}
.login-actions{display:flex;justify-content:center;align-items:center;margin-top:22px;margin-bottom:8px;width:100%;gap:10px}
.login-submit{min-width:150px;max-width:210px;text-align:center}
.login-help{text-align:center;margin-top:14px}
.login .btn.secondary[href="login.php"], .login a.btn.secondary[href="login.php"]{display:none!important}
@media(max-width:520px){.login-submit{min-width:145px}.login-actions{margin-top:20px}.login-card-clean .form-group{margin-bottom:13px}}


/* v4.3.2 - Correção global de ícones duplicados e acabamento beta */
.form-group label .field-icon{display:none!important}
.card h2:before,.card h3:before,.login .card h1:before{display:none!important}
.table th:first-child:before,.table th:nth-child(2):before,.table th:nth-child(3):before,.table th:nth-child(4):before,.table th:nth-child(5):before{content:""!important;display:none!important}
.details-grid>div strong:before{content:""!important;display:none!important}
.view-field strong .view-field-icon + .view-field-icon,.card p strong .view-inline-icon + .view-inline-icon{display:none!important}
.beta-banner{display:flex;align-items:flex-start;gap:14px;background:linear-gradient(135deg,#eff6ff,#f8fafc 55%,#ecfeff);border:1px solid rgba(37,99,235,.18);border-radius:18px;padding:18px;box-shadow:0 12px 28px rgba(15,23,42,.07)}
.beta-banner-icon{width:48px;height:48px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2563eb,#0891b2);color:white;font-size:24px;box-shadow:0 12px 26px rgba(37,99,235,.24);flex:0 0 48px}
.beta-banner h2{margin:0 0 6px 0;display:block}.beta-banner p{margin:0;color:#475569;line-height:1.5}
.app-footer{margin:22px 0 4px;padding:14px 18px;border-radius:16px;background:rgba(255,255,255,.70);border:1px solid rgba(226,232,240,.90);display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;color:#64748b;font-size:13px}
body.theme-dark .beta-banner{background:linear-gradient(135deg,#0f172a,#111827 55%,#0b1220);border-color:#334155;color:#e5e7eb;box-shadow:0 14px 30px rgba(0,0,0,.28)}
body.theme-dark .beta-banner p{color:#cbd5e1}body.theme-dark .app-footer{background:rgba(15,23,42,.78);border-color:#334155;color:#cbd5e1}
@media(max-width:560px){.beta-banner{padding:14px;gap:10px}.beta-banner-icon{width:40px;height:40px;flex-basis:40px;font-size:20px}.app-footer{display:block;text-align:center}.app-footer span{display:block;margin:4px 0}}

/* v4.3.3 - Rodapé beta compacto e placeholders */
.footer-beta-enhanced{align-items:center;background:linear-gradient(135deg,rgba(255,255,255,.86),rgba(239,246,255,.82));border:1px solid rgba(37,99,235,.16);box-shadow:0 10px 24px rgba(15,23,42,.06)}
.footer-beta-enhanced strong{color:#1e3a8a}.footer-beta-enhanced .footer-note{color:#64748b;font-size:12px}
body.theme-dark .footer-beta-enhanced{background:linear-gradient(135deg,rgba(15,23,42,.86),rgba(30,41,59,.78));border-color:#334155}
body.theme-dark .footer-beta-enhanced strong{color:#bfdbfe}body.theme-dark .footer-beta-enhanced .footer-note{color:#94a3b8}
.form-control::placeholder, textarea::placeholder{color:#94a3b8;opacity:1}body.theme-dark .form-control::placeholder,body.theme-dark textarea::placeholder{color:#64748b}


/* v4.3.6 - Centralização do rodapé beta e textos profissionais nos logins */
.footer-beta-centered{
  width:min(760px,100%);
  margin:26px auto 6px;
  padding:18px 22px;
  text-align:center;
  justify-content:center;
  align-items:center;
  flex-direction:column;
  gap:6px;
}
.footer-beta-centered span{display:block;width:100%}
.footer-beta-centered strong{font-size:15px}
.footer-beta-centered .footer-note{font-size:12.5px;line-height:1.45}
.login-beta-note{
  text-align:center;
  margin:16px auto 0;
  max-width:330px;
  font-size:12.5px;
  line-height:1.45;
  padding-top:12px;
  border-top:1px solid rgba(148,163,184,.25);
}
.login-card-clean .login-help{display:none!important}
@media(max-width:560px){
  .footer-beta-centered{margin:20px auto 4px;padding:15px 14px;border-radius:15px}
  .footer-beta-centered strong{font-size:14px}
  .footer-beta-centered .footer-note{font-size:12px}
  .login-beta-note{font-size:12px;max-width:280px}
}
body.theme-dark .login-beta-note{border-top-color:#334155}


/* v4.5 - Notificações para funcionários */
.status-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:800;border:1px solid transparent;white-space:nowrap}
.status-ok{background:#dcfce7;color:#166534;border-color:#86efac}.status-pending{background:#fee2e2;color:#991b1b;border-color:#fecaca}.status-warn{background:#fef3c7;color:#92400e;border-color:#fde68a}
.notification-card{border-left:5px solid #94a3b8}.notification-unread{border-left-color:#ef4444;background:linear-gradient(135deg,#fff7ed,#fff)}.notification-read{border-left-color:#22c55e;background:linear-gradient(135deg,#f0fdf4,#fff)}
.card-red{background:linear-gradient(135deg,#fff1f2,#fff)}
body.theme-dark .status-ok{background:#052e16;color:#bbf7d0;border-color:#166534}body.theme-dark .status-pending{background:#450a0a;color:#fecaca;border-color:#991b1b}body.theme-dark .status-warn{background:#451a03;color:#fde68a;border-color:#92400e}
body.theme-dark .notification-unread{background:linear-gradient(135deg,#2a0f12,#0f172a)}body.theme-dark .notification-read{background:linear-gradient(135deg,#052e16,#0f172a)}body.theme-dark .card-red{background:linear-gradient(135deg,#450a0a,#0f172a)}
@media print{.no-print,.sidebar,.topbar,.employee-theme-bar{display:none!important}.main,.content{padding:0!important}.card{box-shadow:none!important;border:1px solid #ddd!important}}


/* v4.9.1 - Login com ver senha/salvar acesso e loading global */
.password-reveal-wrap{position:relative;width:100%}
.password-reveal-wrap input[type="password"],.password-reveal-wrap input[type="text"].password-visible{padding-right:48px!important}
.password-toggle-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:34px;height:34px;border:0;border-radius:10px;background:rgba(37,99,235,.10);color:#1d4ed8;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;box-shadow:none!important;z-index:3}
.password-toggle-btn:hover{background:rgba(37,99,235,.18);transform:translateY(-50%) scale(1.03)}
.login-save-row{display:flex;justify-content:center;margin:14px 0 0;width:100%}
.save-access-option{display:inline-flex!important;align-items:center;justify-content:center;gap:8px;font-weight:800!important;color:#475569;background:rgba(37,99,235,.06);border:1px solid rgba(37,99,235,.12);border-radius:999px;padding:9px 14px;cursor:pointer;user-select:none}
.save-access-option input{width:auto!important;margin:0!important;accent-color:#2563eb}
.save-access-option span{font-size:13px}
.page-loading-overlay{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;background:rgba(238,244,255,.72);backdrop-filter:blur(7px);opacity:0;visibility:hidden;transition:opacity .16s ease,visibility .16s ease}
.page-loading-overlay.active{opacity:1;visibility:visible}
.page-loader-card{min-width:210px;max-width:82vw;border-radius:22px;background:rgba(255,255,255,.95);border:1px solid rgba(226,232,240,.95);box-shadow:0 24px 70px rgba(15,23,42,.18);padding:24px;text-align:center;color:#172033}
.page-loader-logo{width:54px;height:54px;border-radius:18px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2563eb,#0891b2);color:#fff;font-size:26px;box-shadow:0 14px 28px rgba(37,99,235,.25)}
.page-loader-spinner{width:34px;height:34px;margin:12px auto 2px;border-radius:50%;border:4px solid #dbeafe;border-top-color:#2563eb;animation:zivaSpin .72s linear infinite}
.page-loader-text{font-size:13px;font-weight:900;color:#475569;margin-top:10px}
@keyframes zivaSpin{to{transform:rotate(360deg)}}
body.theme-dark .password-toggle-btn{background:rgba(147,197,253,.14);color:#bfdbfe}
body.theme-dark .save-access-option{background:rgba(147,197,253,.10);border-color:#334155;color:#cbd5e1}
body.theme-dark .page-loading-overlay{background:rgba(2,6,23,.72)}
body.theme-dark .page-loader-card{background:rgba(15,23,42,.96);border-color:#334155;color:#e5e7eb;box-shadow:0 24px 70px rgba(0,0,0,.38)}
body.theme-dark .page-loader-text{color:#cbd5e1}
body.theme-dark .page-loader-spinner{border-color:#1e293b;border-top-color:#93c5fd}
@media(max-width:520px){.save-access-option{padding:8px 12px}.save-access-option span{font-size:12.5px}.page-loader-card{padding:20px;min-width:190px}.page-loader-logo{width:48px;height:48px;font-size:23px}}
@media print{.password-toggle-btn,.login-save-row,.page-loading-overlay{display:none!important}}


/* v4.9.2 - Saudação no painel do funcionário e boas-vindas no painel administrativo */
.employee-greeting{
  display:inline-flex;align-items:center;gap:8px;margin:8px 0 4px 0;padding:8px 12px;border-radius:999px;
  background:linear-gradient(135deg,#dbeafe,#ecfeff);color:#1e40af;font-weight:900;letter-spacing:.2px;
  box-shadow:0 8px 18px rgba(37,99,235,.10)
}
.employee-greeting:before{content:"☀️";font-size:16px}
.admin-welcome-card{text-align:center;max-width:520px;margin:auto;padding:26px!important}
.admin-welcome-card:before{display:none!important}
.admin-welcome-icon{width:64px;height:64px;border-radius:22px;margin:0 auto 12px auto;display:flex;align-items:center;justify-content:center;font-size:30px;background:linear-gradient(135deg,#dbeafe,#bfdbfe);box-shadow:0 16px 34px rgba(37,99,235,.18)}
.admin-welcome-card h2{margin:6px 0 8px 0;color:#1d4ed8}
.admin-welcome-card p{line-height:1.45}
body.theme-dark .employee-greeting{background:linear-gradient(135deg,#1e3a8a,#0f172a);color:#dbeafe;box-shadow:0 10px 22px rgba(0,0,0,.28)}
body.theme-dark .admin-welcome-icon{background:linear-gradient(135deg,#1e3a8a,#0f172a);box-shadow:0 16px 34px rgba(0,0,0,.35)}
body.theme-dark .admin-welcome-card h2{color:#bfdbfe}
@media(max-width:520px){.employee-greeting{font-size:14px;padding:7px 10px}.admin-welcome-card{padding:20px!important}.admin-welcome-icon{width:56px;height:56px;border-radius:18px}}

/* v4.9.8.5.1 - Correção do card Mapa de Módulos no final do painel
   O card estava como link inline; isso fazia a linha lateral (:before) ficar com altura errada
   e embolar visualmente com o bloco acima em alguns navegadores mobile/desktop. */
a.card.shortcut-card,
a.card.mapa-modulos-card{
  display:block;
  width:100%;
  box-sizing:border-box;
  clear:both;
}
.mapa-modulos-card{
  margin-top:18px!important;
  margin-bottom:8px!important;
  min-height:86px;
  overflow:hidden;
  isolation:isolate;
}
.mapa-modulos-card:before{
  top:0!important;
  bottom:0!important;
  height:auto!important;
  border-radius:18px 0 0 18px;
}
.mapa-modulos-card > div{
  position:relative;
  z-index:1;
  min-width:0;
}
@media(max-width:520px){
  .mapa-modulos-card{
    margin-top:14px!important;
    min-height:78px;
  }
  .mapa-modulos-card > div{
    align-items:flex-start!important;
    gap:12px!important;
  }
}

/* v4.9.9.3 - Visual do módulo OLT ZTE C3XX */
.olt-zte-page{display:flex;flex-direction:column;gap:16px}
.olt-zte-hero{position:relative;overflow:hidden;border-left:5px solid #2563eb!important;background:linear-gradient(135deg,rgba(37,99,235,.08),rgba(14,165,233,.05))!important}
.olt-zte-hero h2{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.olt-zte-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:14px 0 0}
.olt-zte-metric{border:1px solid var(--border,#e5e7eb);border-radius:16px;padding:14px;background:rgba(248,250,252,.72);box-shadow:0 10px 26px rgba(15,23,42,.05)}
.olt-zte-metric span{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:#64748b}.olt-zte-metric strong{display:block;font-size:24px;line-height:1.15;margin-top:5px;color:#0f172a}.olt-command{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:13px;line-height:1.45;white-space:pre;overflow:auto;background:#0f172a;color:#e5e7eb;border-radius:16px;padding:14px;max-height:520px}.olt-badge{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;background:rgba(37,99,235,.12);font-size:12px;font-weight:900;color:#1d4ed8}.olt-two{display:grid;grid-template-columns:1fr 1fr;gap:14px}.olt-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.olt-code-small{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;background:rgba(148,163,184,.14);padding:3px 7px;border-radius:8px;display:inline-block}.olt-responsive-table{overflow:auto;width:100%}.olt-responsive-table table{min-width:880px}.olt-empty{padding:18px;border:1px dashed rgba(148,163,184,.55);border-radius:16px;text-align:center;color:#64748b;background:rgba(248,250,252,.65)}body.theme-dark .olt-zte-hero{background:linear-gradient(135deg,rgba(30,64,175,.28),rgba(15,23,42,.96))!important;border-left-color:#60a5fa!important}body.theme-dark .olt-zte-metric{background:rgba(15,23,42,.72);border-color:#334155;box-shadow:0 10px 26px rgba(0,0,0,.22)}body.theme-dark .olt-zte-metric span{color:#94a3b8}body.theme-dark .olt-zte-metric strong{color:#e5e7eb}body.theme-dark .olt-badge{background:rgba(96,165,250,.16);color:#bfdbfe}body.theme-dark .olt-code-small{background:rgba(51,65,85,.7);color:#e2e8f0}body.theme-dark .olt-empty{background:rgba(15,23,42,.65);border-color:#334155;color:#cbd5e1}@media(max-width:900px){.olt-zte-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.olt-two{grid-template-columns:1fr}}@media(max-width:560px){.olt-zte-grid{grid-template-columns:1fr}.olt-actions .btn{width:100%;justify-content:center}.olt-zte-hero h2{font-size:20px}.olt-command{font-size:12px}}


/* ZIVA BRAND UPDATE */
:root{
    --ziva-dark:#0b0f14;
    --ziva-card:#111827;
    --ziva-purple:#6d28d9;
    --ziva-purple-soft:#8b5cf6;
    --ziva-silver:#d1d5db;
}
.ziva-brand-gradient,
.brand-icon,
.logo-icon{
    background:linear-gradient(135deg,#111827,#374151 45%,#6d28d9)!important;
}

/* ZIVA v3.1 - ajuste global de escala PC/Mobile e prevenção de rolagem lateral */
*, *::before, *::after { box-sizing: border-box; }
html, body { width: 100%; max-width: 100%; overflow-x: hidden; }
body { margin: 0; }
.app, .main, .content, .page-content, .main-content, .container, .container-fluid { max-width: 100%; min-width: 0; }
.main { min-width: 0; overflow-x: hidden; }
.content { width: 100%; padding: 16px; overflow-x: hidden; }
.card, .panel, .box, .modal-content, .form-grid, .row { max-width: 100%; min-width: 0; }
img, video, canvas, svg, iframe { max-width: 100%; height: auto; }
input, select, textarea, button { max-width: 100%; }
table { width: 100%; border-collapse: collapse; }
.table-wrap, .table-responsive, .olt-table-scroll, .czu-table-wrap { width: 100%; max-width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.actions, .top-actions, .czu-actions, .olt-card-actions { flex-wrap: wrap; }

@media (min-width: 992px){
  .content { padding: 18px; }
  .card { padding: 16px; }
  h1 { font-size: clamp(22px, 2vw, 28px); }
  h2 { font-size: clamp(19px, 1.6vw, 24px); }
  h3 { font-size: clamp(16px, 1.3vw, 20px); }
  .form-grid { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
}

@media (max-width: 768px){
  body { overflow-x: hidden; }
  .content, .page-content, .main-content { padding: 12px; width: 100%; }
  .card, .panel, .box { width: 100%; padding: 14px; margin-bottom: 12px; }
  .row { margin-left: 0; margin-right: 0; }
  [class*="col-"] { width: 100%; max-width: 100%; flex: 0 0 100%; }
  .topbar { gap: 8px; flex-wrap: wrap; }
  .page-title { min-width: 0; max-width: 100%; }
  .btn, button, input[type="submit"], input[type="button"] { white-space: normal; }
}


/* =========================================================
   ZIVA FIX FINAL - PC 100%, ícones visíveis e botão fora da logo
   Aplicado para corrigir necessidade de zoom 90%, emojis/ícones no PC
   e botão abrir/fechar menu sobrepondo a marca do menu.
   ========================================================= */
html, body{
  width:100%!important;
  max-width:100%!important;
  overflow-x:hidden!important;
  text-size-adjust:100%;
  -webkit-text-size-adjust:100%;
}
body{
  font-size:14px!important;
  line-height:1.35!important;
}
*, *::before, *::after{box-sizing:border-box!important;min-width:0;}
img, svg, video, canvas, iframe{max-width:100%!important;height:auto;}
pre, code{white-space:pre-wrap!important;word-break:break-word!important;}
.table-wrap, .table-responsive{width:100%!important;max-width:100%!important;overflow-x:auto!important;}
table{max-width:100%!important;}

/* Ícones/emojis do menu sempre visíveis no PC */
.nav-icon,
.page-title-icon,
.btn-icon,
.field-icon,
.view-inline-icon,
.view-field-icon,
.kpi-ico,
.hero-icon,
.admin-help-fab span:first-child{
  font-family:'Segoe UI Emoji','Apple Color Emoji','Noto Color Emoji','Segoe UI Symbol',Arial,sans-serif!important;
  line-height:1!important;
  text-rendering:auto!important;
  font-variant-emoji:emoji;
}
.sidebar .nav-link .nav-icon,
aside.sidebar .nav-link .nav-icon{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:28px!important;
  height:28px!important;
  min-width:28px!important;
  flex:0 0 28px!important;
  border-radius:9px!important;
  font-size:15px!important;
  opacity:1!important;
  visibility:visible!important;
  color:#f8fafc!important;
  background:rgba(148,163,184,.18)!important;
  overflow:visible!important;
}
.sidebar .nav-link,
aside.sidebar .nav-link{
  display:flex!important;
  align-items:center!important;
  gap:9px!important;
  min-height:38px!important;
  padding:9px 10px!important;
  overflow:visible!important;
}
.sidebar .nav-link span:last-child,
aside.sidebar .nav-link span:last-child{
  font-size:13px!important;
  line-height:1.15!important;
}

@media (min-width:901px){
  /* Compacta o painel para funcionar em 100% no navegador, sem precisar usar zoom 90%. */
  .sidebar,
  aside.sidebar{
    width:232px!important;
    padding:12px!important;
  }
  .main{
    margin-left:232px!important;
    min-width:0!important;
    width:calc(100% - 232px)!important;
    max-width:calc(100% - 232px)!important;
  }
  .topbar{
    height:56px!important;
    min-height:56px!important;
    padding:0 14px!important;
    gap:10px!important;
  }
  .topbar .menu{
    display:none!important;
  }
  .content,
  .page-content,
  .main-content,
  .admin-content,
  .container,
  .container-fluid{
    width:100%!important;
    max-width:100%!important;
    padding:14px!important;
    margin-left:0!important;
    margin-right:0!important;
    overflow-x:hidden!important;
  }
  .card,
  .dash-card,
  .kpi-card,
  .dashboard-card,
  .module-card{
    padding:13px!important;
    margin-bottom:12px!important;
    border-radius:14px!important;
    max-width:100%!important;
    overflow:hidden!important;
  }
  .grid,
  .cards-grid,
  .dashboard-grid,
  .kpi-grid,
  .dashboard-row,
  .row{
    max-width:100%!important;
    width:100%!important;
    gap:12px!important;
  }
  .grid{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))!important;}
  .form-grid{gap:10px!important;}
  .form-control,
  select,
  textarea,
  input{
    font-size:13px!important;
    padding:9px 10px!important;
  }
  .btn{
    font-size:13px!important;
    padding:7px 10px!important;
    min-height:32px!important;
  }
  .table th,
  .table td{
    padding:9px 10px!important;
    font-size:13px!important;
  }
  h1{font-size:22px!important;}
  h2{font-size:19px!important;}
  h3{font-size:16px!important;}
  .metric{font-size:25px!important;}

  /* Botão PC fica fora da logo quando o menu está aberto. */
  .ziva-sidebar-toggle-pc{
    top:13px!important;
    left:244px!important;
    width:38px!important;
    height:38px!important;
    border-radius:11px!important;
    font-size:18px!important;
    z-index:999999!important;
  }
  body.ziva-sidebar-collapsed .ziva-sidebar-toggle-pc{
    left:14px!important;
  }
  body.ziva-sidebar-collapsed .main{
    margin-left:0!important;
    width:100%!important;
    max-width:100%!important;
  }
  body.ziva-sidebar-collapsed .content,
  body.ziva-sidebar-collapsed .page-content,
  body.ziva-sidebar-collapsed .main-content,
  body.ziva-sidebar-collapsed .admin-content{
    padding-left:14px!important;
  }
  .sidebar .brand.ziva-sidebar-brand-clean,
  aside.sidebar .brand.ziva-sidebar-brand-clean{
    min-height:56px!important;
    padding:8px 8px 10px!important;
    margin-bottom:8px!important;
  }
  .sidebar .ziva-menu-wordmark,
  aside.sidebar .ziva-menu-wordmark{
    width:104px!important;
    max-width:104px!important;
  }
}

@media (max-width:900px){
  .main{width:100%!important;max-width:100%!important;margin-left:0!important;}
  .topbar .menu{display:inline-flex!important;align-items:center!important;justify-content:center!important;}
  .content,.page-content,.main-content,.admin-content{width:100%!important;max-width:100%!important;overflow-x:hidden!important;}
}
