:root{--bg:#f4f6f8;--panel:#fff;--text:#17202a;--muted:#6b7280;--primary:#176b45;--primary-2:#0f5132;--border:#e5e7eb;--warn:#f59e0b;--danger:#dc2626;--dark:#111827;--shadow:0 12px 30px rgba(15,23,42,.08)}*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--text)}.app-shell{display:flex;min-height:100vh}.sidebar{width:290px;background:#0f1f18;color:#fff;padding:22px;display:flex;flex-direction:column;gap:22px;position:sticky;top:0;height:100vh}.brand{display:flex;gap:12px;align-items:center}.brand-mark{width:44px;height:44px;border-radius:14px;background:#21a366;display:grid;place-items:center;font-weight:800}.brand h1{font-size:18px;margin:0}.brand span{font-size:12px;color:#b7c7be}.nav{display:grid;gap:8px}.nav-item{border:0;background:transparent;color:#d7e5dc;text-align:left;padding:12px 14px;border-radius:12px;cursor:pointer;font-weight:600}.nav-item.active,.nav-item:hover{background:rgba(255,255,255,.11)}.sidebar-footer{margin-top:auto;display:grid;gap:8px}.sidebar-footer label,.sidebar-footer small{color:#b7c7be;font-size:12px}.sidebar select{width:100%;padding:10px;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:#152920;color:#fff}.main{flex:1;padding:26px;overflow:auto}.topbar{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:22px}.topbar h2{margin:0;font-size:26px}.topbar p{margin:4px 0 0;color:var(--muted)}button{font-family:inherit}.primary,.secondary{border:0;border-radius:12px;padding:12px 16px;font-weight:700;cursor:pointer}.primary{background:var(--primary);color:#fff}.primary:hover{background:var(--primary-2)}.secondary{background:#fff;color:var(--text);border:1px solid var(--border)}.small{padding:9px 12px;font-size:13px}.topbar-actions{display:flex;gap:10px}.view{display:none}.view.active{display:block}.filters{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:12px;margin-bottom:18px}.filters input,.filters select,input,select,textarea{width:100%;padding:12px;border:1px solid var(--border);border-radius:12px;background:#fff;color:var(--text)}textarea{min-height:105px;resize:vertical}.cards-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-bottom:18px}.metric-card{background:var(--panel);padding:18px;border-radius:18px;box-shadow:var(--shadow);border:1px solid var(--border)}.metric-card span{color:var(--muted);font-size:13px}.metric-card strong{display:block;font-size:30px;margin-top:8px}.metric-card.warning strong{color:var(--warn)}.metric-card.danger strong{color:var(--danger)}.metric-card.dark strong{color:var(--dark)}.panel-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.panel,.form-card{background:var(--panel);border-radius:20px;padding:18px;box-shadow:var(--shadow);border:1px solid var(--border)}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.panel h3,.form-card h3{margin:0 0 12px}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse}th,td{padding:12px;border-bottom:1px solid var(--border);text-align:left;font-size:14px;vertical-align:top}th{font-size:12px;text-transform:uppercase;color:var(--muted);letter-spacing:.04em}.tag{display:inline-flex;padding:5px 8px;border-radius:999px;background:#eef8f2;color:var(--primary);font-size:12px;font-weight:800}.tag.warn{background:#fff7ed;color:#c2410c}.tag.danger{background:#fef2f2;color:#b91c1c}.form-card{max-width:980px}.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}label{font-size:13px;font-weight:700;color:#374151;display:grid;gap:7px;margin-bottom:12px}.form-actions{display:flex;align-items:center;gap:12px;margin:6px 0 14px}.sync-list{display:grid;gap:10px;margin-top:12px}.sync-item{padding:12px;border:1px solid var(--border);border-radius:12px;background:#f9fafb}.toast{position:fixed;right:22px;bottom:22px;background:#111827;color:#fff;padding:14px 16px;border-radius:14px;box-shadow:var(--shadow);display:none;max-width:360px}.toast.show{display:block}@media(max-width:1050px){.app-shell{display:block}.sidebar{position:relative;width:auto;height:auto}.cards-grid{grid-template-columns:repeat(2,1fr)}.panel-grid,.filters,.form-grid{grid-template-columns:1fr}.topbar{align-items:flex-start;flex-direction:column}.topbar-actions{width:100%;flex-wrap:wrap}.primary,.secondary{width:auto}}@media(max-width:560px){.main{padding:14px}.cards-grid{grid-template-columns:1fr}.sidebar{padding:16px}.topbar h2{font-size:22px}}
.hidden{display:none!important}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#eef6ff,#f8fafc);padding:24px}.login-card{width:min(430px,100%);background:#fff;border-radius:24px;padding:28px;box-shadow:0 20px 60px rgba(15,23,42,.16);display:grid;gap:16px}.login-brand{margin-bottom:8px}.login-card label{font-weight:700;color:#0f172a}.login-card input{margin-top:6px}.form-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.small{font-size:.85rem;padding:8px 12px}.table-action{border:0;border-radius:10px;padding:7px 10px;background:#e8f1ff;color:#0b57d0;font-weight:700;cursor:pointer}input[readonly]{background:#f1f5f9;color:#475569}.sidebar-footer strong{display:block;color:#fff;margin:4px 0}.sidebar-footer small{display:block}
.clickable{cursor:pointer;transition:.15s transform,.15s box-shadow}.clickable:hover{transform:translateY(-2px);box-shadow:0 16px 35px rgba(15,23,42,.12)}.link-button{border:0;background:transparent;color:#0b57d0;font-weight:800;cursor:pointer;padding:0;text-align:left}.link-button:hover{text-decoration:underline}.check-inline{display:flex!important;align-items:center;gap:10px;grid-template-columns:auto 1fr!important;font-size:14px}.check-inline input{width:auto;margin:0}.detail-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.detail-item{background:#f8fafc;border:1px solid var(--border);border-radius:14px;padding:12px}.detail-item span{display:block;color:var(--muted);font-size:12px}.detail-item strong{display:block;margin-top:5px}.detail-panels{margin-top:18px}.metric-card.clickable span::after{content:'  • clique para ver';font-size:11px;color:#94a3b8}@media(max-width:900px){.detail-grid{grid-template-columns:1fr 1fr}}@media(max-width:560px){.detail-grid{grid-template-columns:1fr}}


/* V7 - Menu lateral mobile como drawer */
.drawer-overlay,.mobile-menu-btn,.topbar-menu{display:none}
.topbar-title{display:flex;align-items:center;gap:12px}
.topbar-menu{border:1px solid var(--border);background:#fff;color:var(--text);border-radius:12px;width:44px;height:44px;font-size:22px;font-weight:800;cursor:pointer;flex:0 0 auto}
@media(max-width:1050px){
  .app-shell{display:block;min-height:100vh}
  .main{padding-top:20px}
  .sidebar{position:fixed;left:0;top:0;bottom:0;width:min(82vw,330px);height:100vh;z-index:50;transform:translateX(-105%);transition:transform .22s ease;overflow:auto;box-shadow:20px 0 60px rgba(15,23,42,.22)}
  .app-shell.menu-open .sidebar{transform:translateX(0)}
  .drawer-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.42);z-index:40}
  .app-shell.menu-open .drawer-overlay{display:block}
  .topbar-menu{display:inline-grid;place-items:center}
  .mobile-menu-btn{display:none}
  .topbar{position:sticky;top:0;z-index:30;background:rgba(244,246,248,.92);backdrop-filter:blur(10px);padding:12px 0;margin:-14px 0 18px}
  .nav-item{padding:14px 16px;font-size:16px}
  .sidebar-footer{padding-bottom:24px}
}
@media(max-width:560px){
  .main{padding:14px 14px 24px}
  .topbar h2{font-size:24px}
  .topbar p{font-size:14px}
  .topbar-actions .primary,.topbar-actions .secondary{flex:1;min-width:140px}
}

/* V8 - Ajustes mobile: painéis do dashboard do mesmo tamanho e tabelas compactas */
.metric-card{min-height:118px;display:flex;flex-direction:column;justify-content:center}
.panel-grid .panel{display:flex;flex-direction:column;min-height:360px}
.panel-grid .table-wrap{max-height:285px;overflow:auto}
#dashboardDetalhe .table-wrap{max-height:340px;overflow:auto}
@media(max-width:560px){
  .metric-card{min-height:116px}
  .panel-grid .panel{min-height:300px;max-height:300px;overflow:hidden}
  .panel-grid .panel-header{min-height:44px;margin-bottom:8px}
  .panel-grid .panel h3{font-size:16px;line-height:1.2;margin:0}
  .panel-grid .table-wrap{max-height:220px;overflow:auto}
  #dashboardDetalhe{max-height:360px;overflow:hidden}
  #dashboardDetalhe .table-wrap{max-height:270px;overflow:auto}
  th,td{padding:10px 8px;font-size:13px}
}
