:root{
  --bg:#eef3f8;
  --surface:#ffffff;
  --surface-2:#f8fafc;
  --ink:#111827;
  --muted:#667085;
  --line:#dbe4ee;
  --brand:#2154d6;
  --brand-2:#0f3aa5;
  --brand-soft:#eaf1ff;
  --sidebar:#07111f;
  --sidebar-2:#0b172a;
  --danger:#dc2626;
  --warn:#d97706;
  --ok:#16a34a;
  --shadow:0 18px 40px rgba(15,23,42,.08);
  --shadow-soft:0 8px 22px rgba(15,23,42,.06);
  --radius:20px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Segoe UI",Inter,Arial,sans-serif;background:radial-gradient(circle at top left,#f8fbff 0,#eef3f8 34%,#edf2f7 100%);color:var(--ink)}
a{color:var(--brand);text-decoration:none}strong{font-weight:800}

.sidebar{position:fixed;inset:0 auto 0 0;width:272px;background:linear-gradient(180deg,var(--sidebar),var(--sidebar-2));color:#fff;padding:18px 14px;box-shadow:14px 0 38px rgba(15,23,42,.24);overflow:auto;z-index:10}
.brand{display:flex;gap:12px;align-items:center;padding:12px 10px 20px;border-bottom:1px solid rgba(255,255,255,.10);margin-bottom:14px}
.brand-icon{width:46px;height:46px;border-radius:16px;background:linear-gradient(135deg,#2e63f0,#68a3ff);display:grid;place-items:center;font-weight:900;box-shadow:0 15px 30px rgba(46,99,240,.36)}
.brand-text b{display:block;font-size:18px;letter-spacing:.2px}.brand-text span{font-size:11px;color:#9fb0c8;letter-spacing:.8px}
.nav-title{margin:18px 10px 8px;color:#7d8da8;font-size:11px;text-transform:uppercase;letter-spacing:1.2px;font-weight:900}
.side-nav a{display:flex;align-items:center;gap:10px;color:#d9e4f2;padding:11px 12px;border-radius:14px;margin:3px 0;font-weight:750;font-size:14px;transition:.16s ease}
.side-nav a span{width:25px;min-width:25px;height:25px;border-radius:9px;display:grid;place-items:center;background:rgba(255,255,255,.06);color:#b9c8dc;font-size:12px;font-weight:900}
.side-nav a:hover{background:rgba(255,255,255,.08);color:#fff;transform:translateX(2px)}
.side-nav a.active{background:linear-gradient(135deg,#244fd1,#183b9d);color:#fff;box-shadow:0 10px 25px rgba(36,79,209,.28)}
.side-nav a.active span{background:rgba(255,255,255,.18);color:#fff}.logout-link{margin-top:14px;color:#ffc7c7!important}

.main{margin-left:272px;padding:26px 34px 16px;min-height:100vh}.login-main{margin-left:0;display:grid;place-items:center;padding:18px}.content-shell{max-width:1480px;margin:0 auto}.topbar{max-width:1480px;margin:0 auto 22px;display:flex;justify-content:space-between;align-items:flex-start;gap:18px}.eyebrow{display:inline-flex;background:var(--brand-soft);color:var(--brand-2);border:1px solid #cfddff;border-radius:999px;padding:5px 10px;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.7px}.topbar h1{margin:8px 0 0;font-size:30px;letter-spacing:-.7px}.topbar p{margin:6px 0 0;color:var(--muted)}
.userbox{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.88);border:1px solid var(--line);border-radius:18px;padding:10px 14px;box-shadow:var(--shadow-soft);min-width:190px}.avatar{width:38px;height:38px;border-radius:14px;background:#edf2ff;color:#1e40af;display:grid;place-items:center;font-weight:900}.userbox small{display:block;color:var(--muted);margin-top:2px}

.cards{display:grid;grid-template-columns:repeat(4,minmax(170px,1fr));gap:16px;margin-bottom:18px}.card{background:linear-gradient(180deg,#fff,#fbfdff);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-soft);position:relative;overflow:hidden}.card:before{content:"";position:absolute;right:-28px;top:-28px;width:86px;height:86px;border-radius:50%;background:linear-gradient(135deg,#eef4ff,#f7fbff)}.card span{color:var(--muted);font-size:13px;font-weight:800}.card b{display:block;font-size:28px;margin-top:8px;letter-spacing:-.5px}.card.danger b,.late{color:var(--danger);font-weight:900}.card.warn b{color:var(--warn)}

.grid2{display:grid;grid-template-columns:1.25fr .75fr;gap:18px}.panel{background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:24px;padding:18px;margin-bottom:18px;box-shadow:var(--shadow);overflow:auto}.section-panel{padding:20px}.section-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:16px}.section-head h3,.panel h3{margin:0;font-size:18px;letter-spacing:-.2px}.section-head p{margin:6px 0 0;color:var(--muted);font-size:13px}.page-actions{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap}

.table-wrap{width:100%;overflow:auto;border:1px solid var(--line);border-radius:18px;background:#fff}table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}th{text-align:left;color:#475467;background:#f7f9fc;font-size:12px;text-transform:uppercase;letter-spacing:.6px;font-weight:900}th,td{padding:13px 12px;border-bottom:1px solid var(--line);vertical-align:middle}tr:last-child td{border-bottom:0}tr:hover td{background:#fbfdff}.amount{font-weight:900;color:#0f172a}.muted{color:var(--muted)}
.pill{display:inline-flex;align-items:center;justify-content:center;background:#eef2ff;color:#3730a3;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:900;white-space:nowrap}.pill.ok{background:#dcfce7;color:#166534}.pill.warn{background:#fef3c7;color:#92400e}.pill.danger{background:#fee2e2;color:#991b1b}

.actions{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}.btn,button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;background:var(--brand);color:#fff;padding:11px 15px;border-radius:13px;font-weight:850;cursor:pointer;box-shadow:0 10px 25px rgba(36,84,214,.15);transition:.15s}.btn:hover,button:hover{background:var(--brand-2);transform:translateY(-1px)}.btn.ghost{background:#edf2ff;color:#17318c;box-shadow:none}.btn.small{padding:7px 10px;font-size:12px;border-radius:10px}.btn.danger,button.danger{background:var(--danger);box-shadow:0 10px 25px rgba(220,38,38,.15)}.btn.danger:hover,button.danger:hover{background:#991b1b}.table-actions{white-space:nowrap}.table-actions form{margin:0}.primary-action{align-self:end;min-height:44px}

.formgrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.formgrid .wide,.clean-form .wide{grid-column:1/-1}label{display:flex;flex-direction:column;gap:7px;color:#26354b;font-weight:850;font-size:13px}input,select,textarea{width:100%;border:1px solid #d6deeb;border-radius:13px;padding:11px 12px;background:#fff;color:#172033;outline:none;transition:.15s;font:inherit}input:focus,select:focus,textarea:focus{border-color:#85a4ff;box-shadow:0 0 0 4px rgba(36,84,214,.11)}textarea{min-height:92px;resize:vertical}.checkline{justify-content:center;gap:9px;flex-direction:row;align-items:center;background:#f8fafc;border:1px solid var(--line);border-radius:13px;padding:10px 12px;margin-top:22px}.checkline input{width:auto}.clean-form button{margin-top:auto}

.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:12px 0 16px}.info-grid div{background:#f8fafc;border:1px solid var(--line);border-radius:16px;padding:12px}.info-grid span{display:block;color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase}.info-grid strong{display:block;margin-top:5px}.login-card{width:420px;background:#fff;border:1px solid var(--line);border-radius:28px;padding:30px;box-shadow:0 28px 90px rgba(15,23,42,.20)}.login-card h2{margin-top:0}.alert{padding:13px 15px;border-radius:16px;margin:0 auto 12px;max-width:1480px;background:#e0f2fe;border:1px solid #bae6fd;font-weight:700}.alert.danger{background:#fee2e2;border-color:#fecaca}.alert.success{background:#dcfce7;border-color:#bbf7d0}.comment{border-bottom:1px solid var(--line);padding:10px 0}.comment small{color:var(--muted)}.barrow{display:flex;justify-content:space-between;border-bottom:1px solid var(--line);padding:11px 0}.barrow strong{background:#eef2ff;color:#1e3a8a;border-radius:999px;min-width:32px;text-align:center;padding:4px 8px}footer{max-width:1480px;margin:28px auto 8px;color:var(--muted);font-size:12px}

@media(max-width:1180px){.cards{grid-template-columns:repeat(2,1fr)}.grid2,.formgrid{grid-template-columns:1fr}.checkline{margin-top:0;justify-content:flex-start}.primary-action{align-self:auto}}
@media(max-width:820px){.sidebar{position:static;width:auto}.main{margin-left:0;padding:18px}.topbar{display:block}.cards{grid-template-columns:1fr}.userbox{text-align:left;margin-top:12px}.info-grid{grid-template-columns:1fr}.login-card{width:100%}}
.action-stack{display:flex;gap:7px;align-items:center;flex-wrap:nowrap}.action-stack form{display:inline-flex;margin:0}.btn.ghost,button.ghost{background:#edf2ff;color:#17318c;box-shadow:none}.btn.ghost:hover,button.ghost:hover{background:#dbe7ff;color:#0f2f80}.table-actions .btn,.table-actions button{white-space:nowrap}.table-wrap th:last-child,.table-wrap td:last-child{min-width:245px}

/* Dashboard executivo por área */
.dashboard-filter-panel{border-left:5px solid var(--brand)}
.compact-filter{grid-template-columns:repeat(5,minmax(0,1fr));align-items:end}.compact-filter label{min-width:0}.mini-cards .card b{font-size:24px}.dashboard-charts{grid-template-columns:1fr 1fr}.chart-list{display:flex;flex-direction:column;gap:13px}.chart-row{border:1px solid var(--line);border-radius:16px;padding:12px;background:#fbfdff}.chart-label{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:8px}.chart-label span{font-weight:850;color:#243246}.chart-label strong{background:#eef2ff;color:#1e3a8a;border-radius:999px;min-width:34px;text-align:center;padding:4px 9px}.chart-track{height:13px;border-radius:999px;background:#e8eef6;overflow:hidden}.chart-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--brand),#6ea8ff);min-width:4px}.chart-fill.alt{background:linear-gradient(90deg,#0f766e,#5eead4)}
@media(max-width:1180px){.compact-filter{grid-template-columns:1fr 1fr}.dashboard-charts{grid-template-columns:1fr}}
@media(max-width:820px){.compact-filter{grid-template-columns:1fr}}

/* Dashboard financeiro - maiores gastos do mês */
.expense-chart .chart-label strong {
  min-width: 110px;
  text-align: right;
}
.chart-fill.expense {
  background: linear-gradient(90deg, #f59e0b, #ef4444);
}

/* Dashboard - chamados por mês */
.monthly-ticket-panel { overflow: hidden; }
.month-chart {
  display: grid;
  grid-template-columns: repeat(12, minmax(42px, 1fr));
  gap: 14px;
  align-items: end;
  min-height: 260px;
  padding: 12px 4px 4px;
}
.month-bar-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.month-bar-value {
  min-height: 20px;
  font-weight: 800;
  color: var(--ink);
}
.month-bar-track {
  width: 100%;
  height: 180px;
  border-radius: 16px;
  background: #eef3fb;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  border: 1px solid #dbe5f3;
}
.month-bar-fill {
  width: 100%;
  min-height: 0;
  border-radius: 16px 16px 0 0;
  background: linear-gradient(180deg, #2563eb 0%, #1d4ed8 100%);
  transition: height .25s ease;
}
.month-bar-label {
  font-size: 12px;
  font-weight: 800;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .04em;
}
@media (max-width: 900px) {
  .month-chart { grid-template-columns: repeat(6, minmax(42px, 1fr)); }
}
@media (max-width: 560px) {
  .month-chart { grid-template-columns: repeat(3, minmax(42px, 1fr)); }
}

/* Animações dos gráficos - v2.2 */
@keyframes chartGrowX {
  from { transform: scaleX(0); opacity: .25; }
  to { transform: scaleX(1); opacity: 1; }
}
@keyframes chartGrowY {
  from { transform: scaleY(0); opacity: .25; }
  to { transform: scaleY(1); opacity: 1; }
}
@keyframes softFadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
.chart-row {
  animation: softFadeUp .45s ease both;
}
.chart-fill {
  transform-origin: left center;
  animation: chartGrowX .85s cubic-bezier(.22,1,.36,1) both;
}
.chart-row:nth-child(1) .chart-fill { animation-delay: 40ms; }
.chart-row:nth-child(2) .chart-fill { animation-delay: 90ms; }
.chart-row:nth-child(3) .chart-fill { animation-delay: 140ms; }
.chart-row:nth-child(4) .chart-fill { animation-delay: 190ms; }
.chart-row:nth-child(5) .chart-fill { animation-delay: 240ms; }
.chart-row:nth-child(6) .chart-fill { animation-delay: 290ms; }
.chart-row:nth-child(7) .chart-fill { animation-delay: 340ms; }
.chart-row:nth-child(8) .chart-fill { animation-delay: 390ms; }
.month-bar-fill {
  transform-origin: bottom center;
  animation: chartGrowY .85s cubic-bezier(.22,1,.36,1) both;
}

/* Tabela de barras - chamados mensais */
.bar-table-wrap { overflow-x: auto; }
.bar-table th, .bar-table td { vertical-align: middle; }
.bar-table-value {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  padding: 6px 10px;
  border-radius: 999px;
  background: #eef2ff;
  color: #1e3a8a;
  font-weight: 900;
}
.bar-table-track {
  width: 100%;
  height: 30px;
  border-radius: 999px;
  background: #e8eef6;
  border: 1px solid #dbe5f3;
  overflow: hidden;
}
.bar-table-fill {
  height: 100%;
  min-width: 0;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--brand), #6ea8ff);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding-right: 10px;
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  transform-origin: left center;
  animation: chartGrowX .9s cubic-bezier(.22,1,.36,1) both;
}
.bar-table-fill span { text-shadow: 0 1px 2px rgba(15,23,42,.25); }
@media (max-width: 700px) {
  .bar-table th:nth-child(3), .bar-table td:nth-child(3) { min-width: 260px; }
}

/* Login premium - v2.3 */
.login-main{
  min-height:100vh;
  padding:0;
  display:flex;
  align-items:stretch;
  justify-content:center;
  background:
    radial-gradient(circle at 12% 15%, rgba(37,99,235,.22), transparent 28%),
    radial-gradient(circle at 88% 80%, rgba(15,23,42,.14), transparent 30%),
    linear-gradient(135deg,#eef4fb 0%,#f8fafc 46%,#e7edf5 100%);
}
.login-main .content-shell{
  width:100%;
  max-width:1180px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:42px 24px;
}
.login-main footer{
  position:fixed;
  bottom:18px;
  left:0;
  right:0;
  text-align:center;
  margin:0;
}
.login-shell{
  width:100%;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  min-height:620px;
  border:1px solid rgba(203,213,225,.75);
  border-radius:34px;
  overflow:hidden;
  background:rgba(255,255,255,.78);
  box-shadow:0 34px 110px rgba(15,23,42,.18);
  backdrop-filter:blur(16px);
}
.login-hero{
  position:relative;
  padding:38px;
  color:#fff;
  overflow:hidden;
  background:
    linear-gradient(135deg, rgba(7,17,31,.97), rgba(16,42,87,.96)),
    radial-gradient(circle at top right, rgba(37,99,235,.55), transparent 32%);
}
.login-hero:before{
  content:"";
  position:absolute;
  inset:-80px -120px auto auto;
  width:320px;
  height:320px;
  border-radius:50%;
  background:rgba(37,99,235,.35);
  filter:blur(8px);
}
.login-hero:after{
  content:"";
  position:absolute;
  inset:auto auto -110px -80px;
  width:260px;
  height:260px;
  border-radius:50%;
  background:rgba(96,165,250,.22);
}
.login-brand-row,.login-hero-copy,.login-feature-grid{position:relative;z-index:1}
.login-brand-row{display:flex;align-items:center;gap:14px}
.login-logo{
  width:54px;
  height:54px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,#2563eb,#60a5fa);
  box-shadow:0 18px 40px rgba(37,99,235,.38);
  font-weight:950;
  letter-spacing:.03em;
}
.login-brand-row strong{display:block;font-size:20px}.login-brand-row span{display:block;color:#b7c7dc;font-size:12px;margin-top:3px;letter-spacing:.04em}
.login-hero-copy{max-width:570px;margin-top:95px}.login-kicker{display:inline-flex;padding:7px 12px;border-radius:999px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:#dbeafe}.login-hero-copy h1{font-size:44px;line-height:1.04;margin:18px 0 14px;letter-spacing:-1.2px}.login-hero-copy p{font-size:16px;line-height:1.65;color:#c8d5e6;margin:0}
.login-feature-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:64px}.login-feature-grid div{padding:15px;border:1px solid rgba(255,255,255,.12);border-radius:18px;background:rgba(255,255,255,.07);box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}.login-feature-grid b{display:block;font-size:14px}.login-feature-grid span{display:block;margin-top:6px;color:#b8c7d9;font-size:12px;line-height:1.4}
.premium-login-card{
  width:auto;
  border:0;
  border-radius:0;
  box-shadow:none;
  padding:46px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  background:#fff;
}
.login-card-head{display:flex;gap:14px;align-items:center;margin-bottom:24px}.login-lock{width:46px;height:46px;border-radius:16px;background:#edf2ff;display:grid;place-items:center;font-size:20px}.login-card-head h2{margin:0;font-size:28px;letter-spacing:-.5px}.login-card-head p{margin:4px 0 0;color:var(--muted);font-size:13px}.login-form{display:grid;gap:15px}.login-form label{font-size:13px;color:#1f2a3d}.login-form input{height:48px;background:#f8fafc;border-color:#d9e2ef}.login-form input:focus{background:#fff}.login-button{width:100%;height:50px;margin-top:2px;border-radius:15px;background:linear-gradient(135deg,var(--brand),#123aa3);font-size:15px;box-shadow:0 16px 34px rgba(37,99,235,.22)}.login-help-box{margin-top:22px;border:1px solid #dbe5f3;background:#f8fbff;border-radius:18px;padding:14px 16px;display:grid;gap:4px}.login-help-box span{color:var(--muted);font-size:12px;font-weight:850}.login-help-box strong{color:#172033;font-size:14px}.login-help-box small{color:#667085}
@media(max-width:980px){.login-shell{grid-template-columns:1fr;max-width:560px}.login-hero{display:none}.premium-login-card{border-radius:34px}.login-main .content-shell{padding:28px 16px}.login-main footer{position:static;padding:0 16px 18px}}
@media(max-width:520px){.premium-login-card{padding:28px}.login-card-head h2{font-size:24px}.login-shell{min-height:auto}}

/* v2.4 - Gráficos em colunas estilo Excel, com animação */
.vertical-chart-panel {
  overflow: hidden;
}
.vertical-chart {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(72px, 1fr));
  gap: 18px;
  align-items: end;
  min-height: 330px;
  padding: 18px 10px 8px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background:
    repeating-linear-gradient(to top, transparent 0, transparent 51px, rgba(100,116,139,.14) 52px),
    linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}
.monthly-columns {
  grid-template-columns: repeat(12, minmax(58px, 1fr));
}
.expense-columns {
  grid-template-columns: repeat(auto-fit, minmax(84px, 1fr));
}
.vbar-item {
  height: 280px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  min-width: 0;
}
.vbar-value {
  min-height: 22px;
  padding: 4px 9px;
  border-radius: 999px;
  background: #eef2ff;
  color: #1e3a8a;
  font-size: 13px;
  font-weight: 950;
  white-space: nowrap;
}
.vbar-value.money-value {
  font-size: 11px;
  padding: 4px 7px;
}
.vbar-track {
  width: 46px;
  height: 205px;
  border-radius: 12px 12px 6px 6px;
  background: rgba(226,232,240,.75);
  border: 1px solid #dbe5f3;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
.vbar-fill {
  width: 100%;
  min-height: 0;
  border-radius: 12px 12px 0 0;
  transform-origin: bottom center;
  animation: chartGrowY .9s cubic-bezier(.22,1,.36,1) both;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.28);
}
.vbar-fill.blue { background: linear-gradient(180deg, #3b82f6, #1d4ed8); }
.vbar-fill.orange { background: linear-gradient(180deg, #f59e0b, #ef4444); }
.vbar-fill.teal { background: linear-gradient(180deg, #14b8a6, #0f766e); }
.vbar-label {
  max-width: 100%;
  min-height: 32px;
  text-align: center;
  color: #475467;
  font-size: 11px;
  line-height: 1.2;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .02em;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media(max-width: 980px) {
  .monthly-columns { grid-template-columns: repeat(6, minmax(58px, 1fr)); }
  .vertical-chart { min-height: 360px; }
}
@media(max-width: 560px) {
  .monthly-columns { grid-template-columns: repeat(3, minmax(58px, 1fr)); }
  .vbar-track { width: 38px; }
}

/* v2.6 — Layout ERP Corporativo */
:root{
  --erp-navy:#07111f;
  --erp-blue:#1d4ed8;
  --erp-slate:#334155;
  --erp-border:#d7deea;
  --erp-bg:#eef2f7;
  --erp-panel:#ffffff;
  --erp-soft:#f8fafc;
}
body{background:var(--erp-bg);font-family:Inter,Segoe UI,Arial,sans-serif;color:#111827;}
.sidebar{background:linear-gradient(180deg,#06101f 0%,#0b1729 100%);border-right:1px solid rgba(255,255,255,.06);}
.brand{padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.08)}
.brand-icon{box-shadow:0 12px 28px rgba(29,78,216,.35)}
.side-nav a{border-radius:12px;margin:4px 10px;font-weight:700;letter-spacing:.01em}
.side-nav a.active{background:#1d4ed8;color:#fff;box-shadow:0 14px 30px rgba(29,78,216,.24)}
.side-nav a span{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.05)}
.topbar{background:rgba(255,255,255,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--erp-border);box-shadow:0 8px 24px rgba(15,23,42,.05);}
.page-title .eyebrow{display:inline-flex;background:#e0ecff;border:1px solid #c7dbff;color:#1e40af;border-radius:999px;padding:4px 10px;font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.08em}
.userbox{border:1px solid var(--erp-border);box-shadow:0 10px 25px rgba(15,23,42,.06)}
.content-shell{max-width:1560px}.panel,.card{border:1px solid var(--erp-border);box-shadow:0 10px 32px rgba(15,23,42,.06);border-radius:18px}.panel{background:var(--erp-panel)}
.card{position:relative;overflow:hidden}.card:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,#1d4ed8,#60a5fa)}.card.warn:before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.card.danger:before{background:linear-gradient(90deg,#dc2626,#fb7185)}
.btn,.primary-action{border-radius:10px;font-weight:800;box-shadow:0 6px 18px rgba(29,78,216,.14)}
.btn.ghost{box-shadow:none;background:#f8fafc;border:1px solid var(--erp-border)}
.table-wrap table{border-collapse:separate;border-spacing:0;width:100%;overflow:hidden;border-radius:14px;border:1px solid #e2e8f0}.table-wrap th{background:#f1f5f9;color:#334155;text-transform:uppercase;font-size:12px;letter-spacing:.08em;border-bottom:1px solid #dbe3ef}.table-wrap td{border-bottom:1px solid #edf2f7}.table-wrap tr:hover td{background:#f8fbff}
input,select,textarea{border:1px solid #cbd5e1!important;background:#fff!important;border-radius:11px!important}input:focus,select:focus,textarea:focus{outline:none;border-color:#2563eb!important;box-shadow:0 0 0 4px rgba(37,99,235,.12)}
.erp-toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:18px;padding:14px;border:1px solid var(--erp-border);border-radius:16px;background:#fff;box-shadow:0 10px 28px rgba(15,23,42,.05)}
.erp-panel-strong{border-top:4px solid #1d4ed8}.erp-form-panel{border-top:4px solid #334155}.pill.big{font-size:13px;padding:8px 12px}.compact-table{margin-top:12px}.inline-close-form{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.inline-close-form select,.inline-close-form input{min-width:130px;height:34px;padding:6px 8px}.alert-grid-mini{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.alert-card{border:1px solid #e2e8f0;border-radius:14px;background:#fff;padding:14px;display:flex;flex-direction:column;gap:6px}.alert-card strong{font-size:13px;text-transform:uppercase;letter-spacing:.06em}.alert-card span{color:#475569}.alert-card.warn{border-color:#fde68a;background:#fffbeb}.alert-card.danger{border-color:#fecaca;background:#fef2f2}.erp-alert-panel{border-left:4px solid #f59e0b}
@media(max-width:980px){.alert-grid-mini{grid-template-columns:1fr}.erp-toolbar{align-items:stretch}.erp-toolbar .btn{width:100%;text-align:center}}


/* Sidebar minimizável - v2.7 */
.sidebar-toggle{
  position:absolute;
  top:18px;
  right:14px;
  width:34px;
  height:34px;
  border-radius:12px;
  background:rgba(255,255,255,.08);
  color:#dbeafe;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:none;
  padding:0;
  font-size:16px;
  z-index:2;
}
.sidebar-toggle:hover{
  background:rgba(255,255,255,.16);
  transform:none;
}
.sidebar,
.main,
.brand-text,
.nav-title,
.side-nav a,
.side-nav a span{
  transition:width .22s ease, margin-left .22s ease, padding .22s ease, opacity .18s ease, transform .18s ease, font-size .18s ease;
}
body.sidebar-collapsed .sidebar{
  width:88px;
  padding:18px 10px;
  overflow-x:hidden;
}
body.sidebar-collapsed .main{
  margin-left:88px;
}
body.sidebar-collapsed .brand{
  justify-content:center;
  padding:54px 0 18px;
  margin-bottom:12px;
}
body.sidebar-collapsed .brand-icon{
  width:48px;
  height:48px;
  min-width:48px;
}
body.sidebar-collapsed .brand-text,
body.sidebar-collapsed .nav-title{
  opacity:0;
  height:0;
  margin:0;
  padding:0;
  overflow:hidden;
  pointer-events:none;
}
body.sidebar-collapsed .side-nav a{
  justify-content:center;
  gap:0;
  padding:12px 0;
  font-size:0;
  line-height:0;
  min-height:46px;
}
body.sidebar-collapsed .side-nav a span{
  width:34px;
  min-width:34px;
  height:34px;
  font-size:13px;
  line-height:1;
}
body.sidebar-collapsed .side-nav a:hover{
  transform:none;
}
body.sidebar-collapsed .logout-link{
  margin-top:12px;
}
body.sidebar-collapsed .sidebar-toggle{
  right:27px;
}
@media(max-width:820px){
  .sidebar-toggle{display:none}
  body.sidebar-collapsed .sidebar{width:auto;padding:18px 14px}
  body.sidebar-collapsed .main{margin-left:0}
  body.sidebar-collapsed .brand-text,
  body.sidebar-collapsed .nav-title{opacity:1;height:auto;margin:initial;padding:initial;overflow:visible;pointer-events:auto}
  body.sidebar-collapsed .side-nav a{justify-content:flex-start;gap:10px;padding:11px 12px;font-size:14px;line-height:normal}
  body.sidebar-collapsed .side-nav a span{width:25px;min-width:25px;height:25px;font-size:12px}
}

/* v2.8: remove as barras de rolagem visíveis, mantendo rolagem pelo mouse/touchpad */
html, body, .sidebar, .main, .content-shell, .table-wrap {
  scrollbar-width: none;
  -ms-overflow-style: none;
}
html::-webkit-scrollbar,
body::-webkit-scrollbar,
.sidebar::-webkit-scrollbar,
.main::-webkit-scrollbar,
.content-shell::-webkit-scrollbar,
.table-wrap::-webkit-scrollbar {
  width: 0;
  height: 0;
  display: none;
}

/* Dashboard 100% clicável */
.clickable-cards .card,
.click-card,
.chart-click {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.clickable-cards .card:hover,
.click-card:hover,
.chart-click:hover {
  transform: translateY(-3px);
  border-color: #93c5fd;
  box-shadow: 0 16px 38px rgba(37, 99, 235, .14);
}
.clickable-cards .card small {
  display: block;
  margin-top: 8px;
  color: #64748b;
  font-weight: 800;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.vbar-item.chart-click {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 42px;
  border-radius: 14px;
  padding: 6px 4px;
}
.vbar-item.chart-click:hover .vbar-fill {
  filter: brightness(1.08);
}
.horizontal-click {
  display: block;
}
.alert-grid-mini .alert-card {
  text-decoration: none;
  color: inherit;
}
.barrow.chart-click {
  text-decoration: none;
  color: inherit;
}
.barrow.chart-click:hover {
  background: #f8fbff;
}
.clickable-cards .card{display:block;}

.full-width-chart { width: 100%; }
.dashboard-charts:not(.grid2) { display: block; }


/* Home executiva simplificada - v3.5 */
.executive-hero{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-bottom:16px;overflow:hidden}
.executive-hero h2{font-size:24px;margin:10px 0 4px;letter-spacing:-.4px}.hero-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.executive-cards{grid-template-columns:repeat(3,minmax(190px,1fr));margin-bottom:12px}.executive-shortcuts{margin:6px 0 16px}.executive-alerts{border-left:5px solid var(--warn)}.executive-grid{grid-template-columns:1.1fr .9fr}.inline-filter{display:flex;gap:8px;align-items:center}.inline-filter select{min-width:110px;padding:8px 10px}.compact-monthly{min-height:210px}.compact-monthly .vbar-track{height:150px}
@media(max-width:1180px){.executive-cards{grid-template-columns:repeat(2,1fr)}.executive-grid{grid-template-columns:1fr}.executive-hero{align-items:flex-start;flex-direction:column}.hero-actions{justify-content:flex-start}}
@media(max-width:820px){.executive-cards{grid-template-columns:1fr}.executive-hero{padding:16px}.hero-actions .btn{width:100%}}

/* Inventário com submenu/flyout */
.nav-flyout-wrap{position:relative}
.nav-flyout-trigger{width:100%;border:0;background:transparent;color:#d8e6ff!important;font:inherit;text-align:left;cursor:pointer;display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:12px;box-shadow:none}
.nav-flyout-trigger:hover,.nav-flyout-wrap.open .nav-flyout-trigger{background:rgba(255,255,255,.08);transform:none}
.nav-flyout-trigger span{width:25px;min-width:25px;height:25px;border-radius:9px;display:grid;place-items:center;background:rgba(255,255,255,.06);color:#b9c8dc;font-size:12px;font-weight:900}
.nav-flyout{display:none;position:fixed;min-width:250px;background:#071526;border:1px solid rgba(255,255,255,.15);border-radius:18px;padding:10px;box-shadow:0 24px 60px rgba(0,0,0,.42);z-index:9999}
.nav-flyout:before{content:"";position:absolute;left:-7px;top:22px;width:14px;height:14px;background:#071526;border-left:1px solid rgba(255,255,255,.15);border-bottom:1px solid rgba(255,255,255,.15);transform:rotate(45deg)}
.nav-flyout-wrap.open .nav-flyout{display:block}
.nav-flyout a{display:block;margin:3px 0;padding:11px 13px;border-radius:12px;color:#eaf2ff;text-decoration:none;font-weight:800}
.nav-flyout a:hover{background:rgba(59,130,246,.24);transform:none}
.inventory-type-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:18px}.inventory-type-card{display:block;padding:18px;border:1px solid #d7e1ef;border-radius:18px;background:#fff;text-decoration:none;color:#0f172a;box-shadow:0 10px 30px rgba(15,23,42,.06)}.inventory-type-card:hover{transform:translateY(-1px);border-color:#2d5be3}.inventory-type-card b{display:block;font-size:18px}.inventory-type-card span{color:#64748b;font-size:13px}.inventory-type-card.active{border-color:#2d5be3;box-shadow:0 0 0 3px rgba(45,91,227,.12)}

/* v3.11 - Login estilo lamp-login e popups do dashboard */
.login-main{
  background:
    radial-gradient(circle at 31% 45%, rgba(248,220,137,.24), transparent 0 16%, rgba(248,220,137,.08) 24%, transparent 48%),
    radial-gradient(circle at 70% 40%, rgba(255,255,255,.07), transparent 24%),
    linear-gradient(135deg,#111a1c 0%,#1d2423 45%,#111517 100%)!important;
  overflow:hidden;
}
.login-main:before{
  content:"";position:fixed;inset:0;pointer-events:none;
  background:linear-gradient(90deg,rgba(255,255,255,.03),transparent 18%,transparent 82%,rgba(255,255,255,.03));
}
.login-main .content-shell{max-width:980px!important;padding:34px 24px!important;position:relative;z-index:1}
.login-main footer{color:rgba(255,255,255,.42)!important}
.lamp-login-shell{
  width:min(920px,100%);min-height:520px;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:54px;padding:46px;border-radius:28px;
  background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.06);box-shadow:0 30px 90px rgba(0,0,0,.38), inset 0 1px 0 rgba(255,255,255,.04);
  position:relative;overflow:hidden;
}
.lamp-login-shell:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 25% 50%,rgba(250,223,146,.13),transparent 35%);pointer-events:none}
.lamp-scene{min-height:420px;position:relative;display:flex;align-items:center;justify-content:center}.lamp-glow{position:absolute;width:470px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(255,245,205,.38),rgba(255,231,150,.16) 38%,transparent 72%);filter:blur(14px);left:8%;top:10%;animation:lampPulse 3.5s ease-in-out infinite}
.desk-lamp{position:relative;width:310px;height:400px;transform:translateX(-6px);filter:drop-shadow(0 0 30px rgba(255,239,186,.42))}.lamp-shade{position:absolute;left:34px;top:92px;width:205px;height:102px;background:linear-gradient(180deg,#fffdf0,#f7f5e8);border-radius:120px 120px 14px 14px;clip-path:ellipse(50% 45% at 50% 100%);box-shadow:0 0 56px rgba(255,247,213,.98)}.lamp-neck{position:absolute;left:136px;top:182px;width:16px;height:154px;border-radius:14px;background:linear-gradient(180deg,#fffdf0,#cfc8a6)}.lamp-base-stem{position:absolute;left:98px;top:332px;width:72px;height:16px;background:#e8e2cc;border-radius:999px}.lamp-base{position:absolute;left:62px;top:350px;width:126px;height:20px;background:#e8e2cc;border-radius:999px}.lamp-pull{position:absolute;left:176px;top:196px;width:78px;height:126px}.lamp-pull:before{content:"";position:absolute;left:24px;top:0;width:2px;height:84px;background:rgba(255,232,188,.78)}.lamp-pull span,.lamp-pull i{position:absolute;display:block;border-radius:50%;background:#d8aa75}.lamp-pull span{left:16px;top:82px;width:18px;height:18px}.lamp-pull i{left:46px;top:110px;width:11px;height:11px}
.lamp-login-card{position:relative;z-index:1;width:100%;max-width:340px;justify-self:center;padding:36px 30px;border-radius:26px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.12);box-shadow:0 26px 70px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.08);backdrop-filter:blur(18px)}
.lamp-login-head{text-align:center;margin-bottom:24px}.lamp-chip{display:inline-flex;margin-bottom:10px;padding:6px 10px;border-radius:999px;background:rgba(255,227,156,.16);color:#ffe6a6;border:1px solid rgba(255,227,156,.22);font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.1em}.lamp-login-head h1{margin:0;color:#fff;font-size:24px;letter-spacing:.01em}.lamp-login-head p{margin:7px 0 0;color:rgba(255,255,255,.58);font-size:12px}.lamp-form{display:grid;gap:16px}.lamp-form label{color:rgba(255,255,255,.74);font-size:12px;font-weight:800}.lamp-form input{height:48px;border:1px solid rgba(255,255,255,.10);border-radius:13px;background:rgba(255,255,255,.10);color:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}.lamp-form input::placeholder{color:rgba(255,255,255,.28)}.lamp-form input:focus{border-color:rgba(255,222,146,.56);box-shadow:0 0 0 4px rgba(255,222,146,.10);background:rgba(255,255,255,.13)}.lamp-login-button{height:50px;margin-top:6px;border-radius:15px;color:#2b2112!important;background:linear-gradient(135deg,#fff2b7 0%,#d7a93a 52%,#fff1aa 100%)!important;box-shadow:0 14px 30px rgba(224,176,61,.24), inset 0 1px 0 rgba(255,255,255,.45)!important;font-weight:950}.lamp-login-button:hover{transform:translateY(-1px);filter:brightness(1.04)}.lamp-login-footer{text-align:center;margin-top:18px;color:rgba(255,255,255,.36);font-size:11px}
@keyframes lampPulse{0%,100%{opacity:.74;transform:scale(.98)}50%{opacity:1;transform:scale(1.04)}}
@media(max-width:820px){.lamp-login-shell{grid-template-columns:1fr;padding:28px;gap:18px}.lamp-scene{min-height:280px}.desk-lamp{transform:translateX(-4px) scale(.76)}.lamp-login-card{max-width:420px}.login-main footer{position:static!important}}
@media(max-width:520px){.lamp-login-shell{padding:22px;border-radius:22px}.lamp-scene{display:none}.lamp-login-card{padding:30px 24px}}

.dashboard-popup-trigger.card{border:1px solid var(--erp-border);text-align:left;color:inherit;background:linear-gradient(180deg,#fff,#fbfdff);display:block;width:100%;box-shadow:0 10px 32px rgba(15,23,42,.06);padding:18px;border-radius:18px}.dashboard-popup-trigger.card:hover{background:linear-gradient(180deg,#fff,#f8fbff)}
body.modal-open{overflow:hidden}.dashboard-modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.48);backdrop-filter:blur(3px);z-index:11000;opacity:0;pointer-events:none;transition:.18s ease}.dashboard-modal-backdrop.show{opacity:1;pointer-events:auto}.dashboard-modal{position:fixed;inset:0;z-index:11001;display:none;align-items:center;justify-content:center;padding:24px}.dashboard-modal.show{display:flex}.dashboard-modal-card{width:min(920px,100%);max-height:86vh;overflow:auto;background:#fff;border:1px solid #dbe4ee;border-radius:24px;box-shadow:0 32px 90px rgba(2,6,23,.35);animation:modalPop .18s ease both}.dashboard-modal-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;padding:22px 24px 14px;border-bottom:1px solid #edf2f7}.dashboard-modal-head h3{margin:8px 0 4px;font-size:24px}.dashboard-modal-head p{margin:0;color:#64748b}.modal-close{width:42px;height:42px;border-radius:14px;background:#f1f5f9!important;color:#0f172a!important;box-shadow:none!important;font-size:26px;line-height:1;padding:0}.dashboard-modal-body{padding:20px 24px}.dashboard-modal-actions{padding:0 24px 22px;display:flex;justify-content:flex-end}.modal-kpi-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.modal-kpi{border:1px solid #dbe4ee;border-radius:18px;padding:16px;background:#f8fafc;margin-bottom:14px}.modal-kpi span{display:block;color:#64748b;font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.modal-kpi strong{display:block;font-size:28px;margin-top:6px}.modal-kpi.warn strong{color:var(--warn)}.modal-kpi.danger strong{color:var(--danger)}.modal-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;margin:10px 0 18px}.modal-list div{display:flex;justify-content:space-between;gap:12px;border:1px solid #e2e8f0;background:#fbfdff;border-radius:14px;padding:12px}.modal-list span{color:#334155}.modal-list strong{color:#0f3aa5}.modal-table{max-height:340px;overflow:auto;border:1px solid #dbe4ee;border-radius:16px}.dashboard-modal h4{margin:16px 0 8px}
@keyframes modalPop{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
@media(max-width:680px){.dashboard-modal{padding:12px}.dashboard-modal-head{padding:18px}.dashboard-modal-body{padding:16px 18px}.modal-kpi-grid{grid-template-columns:1fr}.dashboard-modal-actions{padding:0 18px 18px}.dashboard-modal-actions .btn{width:100%}}


/* v3.13 — animação interativa do abajur no login */
.lamp-login-shell{
  --lamp-card-rest-y: 0px;
  --lamp-card-off-y: 18px;
  transition: background .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.lamp-scene,.desk-lamp,.lamp-glow,.lamp-shade,.lamp-login-card,.lamp-login-head h1,.lamp-login-head p,.lamp-login-button{
  transition: opacity .35s ease, transform .35s ease, filter .35s ease, box-shadow .35s ease, background .35s ease, color .35s ease;
}
.lamp-pull{z-index:4}
.lamp-pull:before{display:none}
.lamp-pull-control{
  all:unset;
  position:absolute;
  inset:0;
  display:block;
  cursor:grab;
  user-select:none;
  -webkit-user-select:none;
  -webkit-tap-highlight-color:transparent;
  appearance:none;
  -webkit-appearance:none;
  background:transparent!important;
  border:0!important;
  outline:none!important;
  box-shadow:none!important;
}
.lamp-pull-control:hover,
.lamp-pull-control:focus,
.lamp-pull-control:focus-visible,
.lamp-pull-control:active{
  background:transparent!important;
  border:0!important;
  outline:none!important;
  box-shadow:none!important;
}
.lamp-pull-control::-moz-focus-inner{border:0}
.lamp-pull-control::selection{background:transparent}
.lamp-pull-control span::selection,.lamp-pull-control i::selection{background:transparent}
.lamp-pull-control:active{cursor:grabbing}
.lamp-pull-control:before{content:"";position:absolute;left:18px;top:0;width:2px;height:64px;background:rgba(255,232,188,.82);box-shadow:0 0 10px rgba(255,232,188,.22)}
.lamp-pull-control span,.lamp-pull-control i{position:absolute;display:block;border-radius:50%;background:#d8aa75}
.lamp-pull-control span{left:12px;top:62px;width:15px;height:15px;box-shadow:0 0 16px rgba(216,170,117,.26)}
.lamp-pull-control i{left:35px;top:84px;width:9px;height:9px}
.lamp-login-card{transform:translateY(var(--lamp-card-rest-y))}
.lamp-login-shell.lamp-off .lamp-login-card{
  transform:translateY(var(--lamp-card-off-y));
  background:rgba(255,255,255,.08);
  box-shadow:0 18px 48px rgba(0,0,0,.20), inset 0 1px 0 rgba(255,255,255,.06);
}
.lamp-login-shell.lamp-off .lamp-glow{opacity:.04;filter:blur(8px);animation:none;transform:scale(.92)}
.lamp-login-shell.lamp-off .desk-lamp{filter:drop-shadow(0 0 10px rgba(255,239,186,.08))}
.lamp-login-shell.lamp-off .lamp-shade{background:linear-gradient(180deg,#d8d6ca,#b9b6a9);box-shadow:0 0 10px rgba(255,247,213,.10)}
.lamp-login-shell.lamp-off:before{background:radial-gradient(circle at 25% 50%,rgba(250,223,146,.04),transparent 35%)}
.lamp-login-shell.lamp-off .lamp-login-head h1{color:rgba(255,255,255,.90)}
.lamp-login-shell.lamp-off .lamp-login-head p{color:rgba(255,255,255,.48)}
.lamp-login-shell.lamp-off .lamp-login-button{filter:saturate(.82) brightness(.96);box-shadow:0 10px 22px rgba(224,176,61,.16), inset 0 1px 0 rgba(255,255,255,.35)!important}
.lamp-login-shell.is-pulling .lamp-pull-control{animation:pullCord .46s cubic-bezier(.34,1.56,.64,1) both}
.lamp-login-shell.card-bob-up .lamp-login-card{animation:cardRise .92s cubic-bezier(.22,1,.36,1) both}
.lamp-login-shell.card-bob-down .lamp-login-card{animation:cardDrop .92s cubic-bezier(.22,1,.36,1) both}
@keyframes pullCord{
  0%{transform:translateY(0)}
  40%{transform:translateY(18px)}
  72%{transform:translateY(10px)}
  100%{transform:translateY(0)}
}
@keyframes cardRise{
  0%{transform:translateY(18px)}
  35%{transform:translateY(-16px)}
  65%{transform:translateY(8px)}
  100%{transform:translateY(0)}
}
@keyframes cardDrop{
  0%{transform:translateY(0)}
  35%{transform:translateY(22px)}
  65%{transform:translateY(10px)}
  100%{transform:translateY(18px)}
}
@media (prefers-reduced-motion: reduce){
  .lamp-glow,.lamp-login-shell.is-pulling .lamp-pull-control,.lamp-login-shell.card-bob-up .lamp-login-card,.lamp-login-shell.card-bob-down .lamp-login-card{animation:none!important}
  .lamp-login-card,.lamp-glow,.desk-lamp,.lamp-shade{transition:none!important}
}

/* Correção v3.12 — campos do login visíveis ao digitar */
.lamp-form input,
.lamp-form input[type="email"],
.lamp-form input[type="password"]{
  background: rgba(255,255,255,.12) !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  caret-color: #ffe6a6 !important;
  border-color: rgba(255,255,255,.18) !important;
}
.lamp-form input::placeholder{
  color: rgba(255,255,255,.42) !important;
  -webkit-text-fill-color: rgba(255,255,255,.42) !important;
}
.lamp-form input:focus{
  background: rgba(255,255,255,.16) !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  border-color: rgba(255,222,146,.72) !important;
  box-shadow: 0 0 0 4px rgba(255,222,146,.14) !important;
}
.lamp-form input:-webkit-autofill,
.lamp-form input:-webkit-autofill:hover,
.lamp-form input:-webkit-autofill:focus{
  -webkit-text-fill-color: #ffffff !important;
  caret-color: #ffe6a6 !important;
  box-shadow: 0 0 0 1000px rgba(255,255,255,.14) inset !important;
  transition: background-color 9999s ease-in-out 0s;
}


/* v3.14 — modo dramático da animação do abajur */
.lamp-login-shell{
  --lamp-card-off-y: 32px;
}
.lamp-login-shell.is-pulling .lamp-glow{
  animation: lampFlickerDramatic .58s steps(1,end) both !important;
}
.lamp-login-shell.is-pulling .lamp-shade{
  animation: shadeFlashDramatic .58s steps(1,end) both !important;
}
.lamp-login-shell.is-pulling .lamp-pull-control{
  animation: pullCordDramatic .72s cubic-bezier(.2,1.7,.35,1) both !important;
}
.lamp-login-shell.card-bob-up .lamp-login-card{
  animation: cardRiseDramatic 1.05s cubic-bezier(.18,1.4,.25,1) both !important;
}
.lamp-login-shell.card-bob-down .lamp-login-card{
  animation: cardDropDramatic 1.05s cubic-bezier(.18,1.4,.25,1) both !important;
}
.lamp-login-shell.is-pulling .desk-lamp{
  animation: lampShakeDramatic .72s cubic-bezier(.2,1.2,.35,1) both;
}
@keyframes pullCordDramatic{
  0%{transform:translateY(0) rotate(0deg)}
  32%{transform:translateY(34px) rotate(2deg)}
  52%{transform:translateY(16px) rotate(-2deg)}
  70%{transform:translateY(25px) rotate(1deg)}
  100%{transform:translateY(0) rotate(0deg)}
}
@keyframes cardRiseDramatic{
  0%{transform:translateY(32px) scale(.985)}
  34%{transform:translateY(-28px) scale(1.015)}
  54%{transform:translateY(14px) scale(.996)}
  76%{transform:translateY(-7px) scale(1.004)}
  100%{transform:translateY(0) scale(1)}
}
@keyframes cardDropDramatic{
  0%{transform:translateY(0) scale(1)}
  34%{transform:translateY(44px) scale(.985)}
  55%{transform:translateY(20px) scale(1.006)}
  76%{transform:translateY(36px) scale(.996)}
  100%{transform:translateY(32px) scale(1)}
}
@keyframes lampFlickerDramatic{
  0%{opacity:1;filter:blur(12px);transform:scale(1.04)}
  12%{opacity:.08;filter:blur(8px);transform:scale(.92)}
  22%{opacity:.95;filter:blur(14px);transform:scale(1.08)}
  35%{opacity:.18;filter:blur(8px);transform:scale(.96)}
  48%{opacity:1;filter:blur(15px);transform:scale(1.07)}
  62%{opacity:.10;filter:blur(8px);transform:scale(.92)}
  100%{opacity:inherit;filter:inherit;transform:inherit}
}
@keyframes shadeFlashDramatic{
  0%{box-shadow:0 0 54px rgba(255,247,213,.95)}
  12%{box-shadow:0 0 10px rgba(255,247,213,.12)}
  22%{box-shadow:0 0 64px rgba(255,247,213,1)}
  35%{box-shadow:0 0 13px rgba(255,247,213,.18)}
  48%{box-shadow:0 0 58px rgba(255,247,213,.95)}
  62%{box-shadow:0 0 10px rgba(255,247,213,.12)}
  100%{box-shadow:inherit}
}
@keyframes lampShakeDramatic{
  0%{transform:translateX(0) rotate(0deg)}
  24%{transform:translateX(-2px) rotate(-1.2deg)}
  45%{transform:translateX(3px) rotate(1.4deg)}
  68%{transform:translateX(-1px) rotate(-.6deg)}
  100%{transform:translateX(0) rotate(0deg)}
}
@media(max-width:820px){
  .lamp-login-shell{--lamp-card-off-y:24px}
}
@media (prefers-reduced-motion: reduce){
  .lamp-login-shell.is-pulling .desk-lamp,
  .lamp-login-shell.is-pulling .lamp-glow,
  .lamp-login-shell.is-pulling .lamp-shade,
  .lamp-login-shell.is-pulling .lamp-pull-control,
  .lamp-login-shell.card-bob-up .lamp-login-card,
  .lamp-login-shell.card-bob-down .lamp-login-card{animation:none!important}
}


/* v3.15 — ao puxar a cordinha, o card do login some e reaparece */
.lamp-login-card{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  filter:blur(0);
}
.lamp-login-shell.lamp-off .lamp-login-card{
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateY(58px) scale(.94);
  filter:blur(10px);
}
.lamp-login-shell.card-bob-up .lamp-login-card{
  animation:cardRevealDramatic 1.05s cubic-bezier(.18,1.4,.25,1) both !important;
}
.lamp-login-shell.card-bob-down .lamp-login-card{
  animation:cardHideDramatic .92s cubic-bezier(.18,1.2,.25,1) both !important;
}
@keyframes cardRevealDramatic{
  0%{opacity:0;visibility:visible;transform:translateY(60px) scale(.92);filter:blur(12px)}
  24%{opacity:.18;transform:translateY(18px) scale(.96);filter:blur(8px)}
  48%{opacity:.92;transform:translateY(-24px) scale(1.015);filter:blur(1px)}
  68%{opacity:1;transform:translateY(12px) scale(.996);filter:blur(0)}
  84%{opacity:1;transform:translateY(-6px) scale(1.004);filter:blur(0)}
  100%{opacity:1;visibility:visible;transform:translateY(0) scale(1);filter:blur(0)}
}
@keyframes cardHideDramatic{
  0%{opacity:1;visibility:visible;transform:translateY(0) scale(1);filter:blur(0)}
  26%{opacity:1;transform:translateY(42px) scale(.985);filter:blur(0)}
  52%{opacity:.82;transform:translateY(22px) scale(1.006);filter:blur(1px)}
  72%{opacity:.28;transform:translateY(48px) scale(.97);filter:blur(6px)}
  100%{opacity:0;visibility:hidden;transform:translateY(58px) scale(.94);filter:blur(10px)}
}
@media(max-width:820px){
  .lamp-login-shell.lamp-off .lamp-login-card{transform:translateY(42px) scale(.96)}
  @keyframes cardRevealDramatic{
    0%{opacity:0;visibility:visible;transform:translateY(44px) scale(.94);filter:blur(12px)}
    24%{opacity:.18;transform:translateY(14px) scale(.97);filter:blur(8px)}
    48%{opacity:.92;transform:translateY(-18px) scale(1.01);filter:blur(1px)}
    68%{opacity:1;transform:translateY(10px) scale(.998);filter:blur(0)}
    84%{opacity:1;transform:translateY(-4px) scale(1.002);filter:blur(0)}
    100%{opacity:1;visibility:visible;transform:translateY(0) scale(1);filter:blur(0)}
  }
  @keyframes cardHideDramatic{
    0%{opacity:1;visibility:visible;transform:translateY(0) scale(1);filter:blur(0)}
    26%{opacity:1;transform:translateY(30px) scale(.988);filter:blur(0)}
    52%{opacity:.82;transform:translateY(16px) scale(1.004);filter:blur(1px)}
    72%{opacity:.28;transform:translateY(34px) scale(.975);filter:blur(6px)}
    100%{opacity:0;visibility:hidden;transform:translateY(42px) scale(.96);filter:blur(10px)}
  }
}
@media (prefers-reduced-motion: reduce){
  .lamp-login-shell.lamp-off .lamp-login-card{opacity:0;visibility:hidden;pointer-events:none;transform:translateY(0);filter:none}
  .lamp-login-shell:not(.lamp-off) .lamp-login-card{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0);filter:none}
}


/* v3.16 — abajur centralizado e com acabamento premium */
.lamp-scene{
  min-height: 440px;
  justify-content: center;
  padding: 0 10px 0 4px;
}
.lamp-scene::before{
  content:"";
  position:absolute;
  inset:auto 8% 10% 8%;
  height:42px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,239,186,.10) 0%, rgba(255,239,186,.04) 35%, transparent 72%);
  filter:blur(12px);
  pointer-events:none;
}
.lamp-glow{
  width:520px;
  height:370px;
  left:50%;
  top:50%;
  transform:translate(-50%,-43%);
  background:
    radial-gradient(circle, rgba(255,249,228,.46) 0%, rgba(255,239,186,.24) 28%, rgba(255,226,138,.10) 48%, transparent 72%);
  filter:blur(16px);
}
.desk-lamp{
  width:328px;
  height:420px;
  transform:none !important;
  margin:0 auto;
  filter:
    drop-shadow(0 16px 36px rgba(0,0,0,.22))
    drop-shadow(0 0 30px rgba(255,239,186,.34));
}
.lamp-shade{
  left:34px;
  top:88px;
  width:220px;
  height:110px;
  border-radius:132px 132px 18px 18px;
  background:linear-gradient(180deg,#fffef8 0%, #f8f4e7 34%, #ece4c9 78%, #d9cfb0 100%);
  box-shadow:
    inset 0 10px 12px rgba(255,255,255,.74),
    inset 0 -12px 18px rgba(155,140,100,.18),
    0 0 64px rgba(255,247,213,.98);
}
.lamp-shade::before{
  content:"";
  position:absolute;
  left:16px;
  right:16px;
  top:10px;
  height:24px;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(255,255,255,.88), rgba(255,255,255,0));
  opacity:.9;
}
.lamp-shade::after{
  content:"";
  position:absolute;
  left:24px;
  right:24px;
  bottom:10px;
  height:20px;
  border-radius:50%;
  background:linear-gradient(180deg, rgba(123,103,55,.08), rgba(80,64,28,.18));
  filter:blur(1px);
}
.lamp-neck{
  left:139px;
  top:190px;
  width:18px;
  height:156px;
  border-radius:16px;
  background:linear-gradient(90deg,#bcae7f 0%, #fffef5 18%, #f3ecd8 50%, #c6b588 82%, #9d8d61 100%);
  box-shadow:inset 1px 0 0 rgba(255,255,255,.55), inset -1px 0 0 rgba(88,71,34,.16);
}
.lamp-base-stem{
  left:96px;
  top:340px;
  width:82px;
  height:18px;
  background:linear-gradient(180deg,#f2ecd8 0%, #dfd6bc 56%, #c2b48a 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.62), 0 6px 14px rgba(0,0,0,.10);
}
.lamp-base{
  left:54px;
  top:359px;
  width:148px;
  height:24px;
  background:linear-gradient(180deg,#f6f1de 0%, #ddd3b7 58%, #bcae83 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.62), 0 10px 20px rgba(0,0,0,.12);
}
.lamp-base::after{
  content:"";
  position:absolute;
  left:10px;
  right:10px;
  top:18px;
  height:14px;
  border-radius:50%;
  background:rgba(0,0,0,.16);
  filter:blur(8px);
  z-index:-1;
}
.lamp-pull{
  left:188px;
  top:194px;
  width:82px;
  height:134px;
}
.lamp-pull-control:before{
  left:25px;
  height:92px;
  background:linear-gradient(180deg, rgba(255,247,213,.98), rgba(219,192,125,.62));
  box-shadow:0 0 12px rgba(255,232,188,.24);
}
.lamp-pull-control span,
.lamp-pull-control i{
  background:radial-gradient(circle at 30% 30%, #ffd79f, #d49e5d 62%, #a8753f 100%);
  box-shadow:0 2px 8px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.36);
}
.lamp-pull-control span{left:16px;top:90px;width:20px;height:20px}
.lamp-pull-control i{left:48px;top:120px;width:12px;height:12px}
.lamp-login-shell.lamp-off .lamp-glow{
  transform:translate(-50%,-43%) scale(.94);
}
.lamp-login-shell.lamp-off .desk-lamp{
  filter:drop-shadow(0 10px 20px rgba(0,0,0,.16)) drop-shadow(0 0 12px rgba(255,239,186,.10));
}
@media(max-width:820px){
  .lamp-scene{min-height:300px;padding:0}
  .lamp-glow{width:390px;height:270px;transform:translate(-50%,-42%)}
  .desk-lamp{transform:scale(.80)!important;transform-origin:center center!important;width:328px;height:420px}
}

/* v3.20 — Central de alertas com janela detalhada do patrimônio */
.alert-card.dashboard-popup-trigger{
  width:100%;
  text-align:left;
  border:1px solid #fde68a;
  background:#fff8dd;
  color:#172033;
  box-shadow:none;
  padding:14px;
  border-radius:14px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.alert-card.dashboard-popup-trigger:hover{
  background:#fff4c8;
  transform:translateY(-1px);
}
.alert-card.dashboard-popup-trigger small{
  color:#64748b;
  font-size:11px;
  font-weight:800;
}
.asset-alert-modal-card{
  width:min(1050px,100%);
}
.asset-alert-modal-body{
  display:grid;
  gap:16px;
}
.asset-modal-kpis{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.asset-modal-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
}
.asset-modal-grid.compact{
  grid-template-columns:repeat(4,minmax(0,1fr));
}
.asset-modal-grid div{
  background:#f8fafc;
  border:1px solid #dbe4ee;
  border-radius:14px;
  padding:11px 12px;
}
.asset-modal-grid span{
  display:block;
  color:#64748b;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.asset-modal-grid strong{
  display:block;
  margin-top:5px;
  color:#0f172a;
  word-break:break-word;
}
.asset-modal-section{
  border:1px solid #dbe4ee;
  border-radius:16px;
  background:#fff;
  padding:14px;
}
.asset-modal-section h4{
  margin:0 0 8px;
}
.asset-modal-section p{
  margin:0;
  color:#475569;
  line-height:1.55;
}
@media(max-width:900px){
  .asset-modal-kpis,.asset-modal-grid,.asset-modal-grid.compact{grid-template-columns:1fr}
}
