/* ================================================================
   IPIKK v5 — Sistema de Gestão · Nova Vida 8050
   CSS único, limpo, sem duplicados, sem @extend
   ================================================================ */

/* 1. FONTES ──────────────────────────────────────────────────── */
@font-face{font-family:'Plus Jakarta Sans';font-weight:300;font-display:swap;src:url('../libs/fonts/PlusJakartaSans-Light.woff2') format('woff2')}
@font-face{font-family:'Plus Jakarta Sans';font-weight:400;font-display:swap;src:url('../libs/fonts/PlusJakartaSans-Regular.woff2') format('woff2')}
@font-face{font-family:'Plus Jakarta Sans';font-weight:500;font-display:swap;src:url('../libs/fonts/PlusJakartaSans-Medium.woff2') format('woff2')}
@font-face{font-family:'Plus Jakarta Sans';font-weight:600;font-display:swap;src:url('../libs/fonts/PlusJakartaSans-SemiBold.woff2') format('woff2')}
@font-face{font-family:'Plus Jakarta Sans';font-weight:700;font-display:swap;src:url('../libs/fonts/PlusJakartaSans-Bold.woff2') format('woff2')}
@font-face{font-family:'Plus Jakarta Sans';font-weight:800;font-display:swap;src:url('../libs/fonts/PlusJakartaSans-ExtraBold.woff2') format('woff2')}
@font-face{font-family:'DM Mono';font-weight:400;font-display:swap;src:url('../libs/fonts/DMMono-Regular.woff2') format('woff2')}

/* 2. TOKENS ──────────────────────────────────────────────────── */
:root{
  --navy:#071526; --navy2:#0C1E38; --navy3:#132540;
  --blue:#1A56DB; --blue2:#1648C5; --blue3:#1E6AEE;
  --bluelt:#EBF3FF; --bluemid:#BFDBFE;
  --white:#FFFFFF; --surf:#F4F7FD; --surf2:#EBF0FA;
  --border:#DDE5F4; --bordersoft:#E8EDF8;
  --t1:#071526; --t2:#2D3E58; --t3:#5C738A; --t4:#94A8BE;
  --green:#047857; --greenlt:#ECFDF5;
  --orange:#C2570A; --orangelt:#FFF7ED;
  --red:#C81E1E; --redlt:#FEF2F2;
  --teal:#0771A6; --teallt:#E0F2FE;
  --purple:#6C2BD9; --purplelt:#F5F3FF;
  --amber:#92400E; --amberlt:#FFFBEB;
  --font:'Plus Jakarta Sans',system-ui,sans-serif;
  --mono:'DM Mono',monospace;
  --sbw:64px; --sbwopen:240px;
  --topH:54px;
  --r:8px; --rlg:12px; --rxl:18px;
  --sh1:0 1px 3px rgba(7,21,38,.07);
  --sh2:0 4px 16px rgba(7,21,38,.10);
  --sh3:0 10px 36px rgba(7,21,38,.14);
  --sh4:0 20px 60px rgba(7,21,38,.18);
}

/* 3. RESET ───────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font);background:var(--surf);color:var(--t1);overflow-x:hidden;min-height:100vh}
/* Page exit animation — APENAS opacity para não criar stacking context persistente.
   transform+opacity em simultâneo isola o stacking context e faz o backdrop
   Bootstrap aparecer dentro desse contexto (à frente do modal). */
body.page-leaving .page-content{opacity:0;pointer-events:none;transition:opacity .18s ease}
/* Modals ficam fora de .page-content e não são afectados */
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}

/* 4. KEYFRAMES ───────────────────────────────────────────────── */
@keyframes pageEnter{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeUp   {from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeDown {from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeLeft {from{opacity:0;transform:translateX(-14px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeIn   {from{opacity:0}to{opacity:1}}
@keyframes scaleIn  {from{opacity:0;transform:scale(.93)}to{opacity:1;transform:scale(1)}}
@keyframes slideInLeft{from{transform:translateX(-100%)}to{transform:translateX(0)}}
@keyframes slideUp  {from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes popIn    {0%{transform:scale(0) rotate(-8deg);opacity:0}70%{transform:scale(1.06) rotate(1deg)}100%{transform:scale(1) rotate(0);opacity:1}}
@keyframes shimmer  {0%{background-position:-600px 0}100%{background-position:600px 0}}
@keyframes spin     {to{transform:rotate(360deg)}}
@keyframes barFill  {from{width:0!important}}
@keyframes countUp  {from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulseRing{0%,100%{box-shadow:0 0 0 0 rgba(26,86,219,.28)}70%{box-shadow:0 0 0 8px rgba(26,86,219,0)}}
@keyframes badgePulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
@keyframes gradShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes accentSlide{from{transform:scaleY(0)}to{transform:scaleY(1)}}
@keyframes toastSlide{from{transform:translateY(20px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}

/* 5. SIDEBAR ─────────────────────────────────────────────────── */
.sidebar{
  position:fixed;top:0;left:0;bottom:0;
  width:var(--sbw);
  background:linear-gradient(175deg, var(--navy) 0%, var(--navy2) 100%);
  z-index:300;display:flex;flex-direction:column;overflow:hidden;
  transition:width .26s cubic-bezier(.4,0,.2,1),box-shadow .26s;
  box-shadow:2px 0 12px rgba(0,0,0,.15);
}
/* Accent line top */
.sidebar::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--blue),#60A5FA,var(--blue));
  background-size:200%;animation:gradShift 4s ease infinite;z-index:2;
}
/* hover = overlay (no content push) */
.sidebar:hover{width:var(--sbwopen);z-index:302;box-shadow:4px 0 32px rgba(0,0,0,.25)}
.sidebar.pinned{width:var(--sbwopen)}

/* Logo */
.sb-logo{
  height:60px;display:flex;align-items:center;padding:0 14px;gap:11px;
  border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0;overflow:hidden;
  transition:all .26s;
}
.sb-logo-mark{
  width:34px;height:34px;border-radius:9px;flex-shrink:0;overflow:hidden;
  background:#fff;display:flex;align-items:center;justify-content:center;
  transition:box-shadow .2s;
}
.sb-logo-mark:hover{box-shadow:0 0 0 4px rgba(26,86,219,.35)}
.sb-logo-mark img{width:28px;height:28px;object-fit:contain;display:block}
.sb-logo-text{overflow:hidden;min-width:0;opacity:0;transition:opacity .2s .04s;white-space:nowrap}
.sidebar:hover .sb-logo-text,.sidebar.pinned .sb-logo-text{opacity:1}
.sb-logo-name{font-size:13px;font-weight:800;color:#fff;letter-spacing:.2px}
.sb-logo-sub{font-size:9px;color:rgba(255,255,255,.3);letter-spacing:.5px;margin-top:1px}

/* Pin button */
.sb-pin{
  margin-left:auto;flex-shrink:0;width:22px;height:22px;border-radius:5px;
  background:transparent;border:none;color:rgba(255,255,255,.3);cursor:pointer;
  display:none;align-items:center;justify-content:center;transition:all .14s;
  font-size:11px;
}
.sidebar:hover .sb-pin,.sidebar.pinned .sb-pin{display:flex}
.sb-pin:hover{background:rgba(255,255,255,.1);color:#fff}
.sidebar.pinned .sb-pin{color:var(--blue);background:rgba(26,86,219,.2)}

/* Nav body */
.sb-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:6px 8px 4px;scrollbar-width:none}
.sb-nav::-webkit-scrollbar{display:none}

/* Section label */
.sb-section-label{
  font-size:9px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;
  color:rgba(255,255,255,.16);padding:9px 10px 3px;white-space:nowrap;overflow:hidden;
  opacity:0;transition:opacity .2s;
}
.sidebar:hover .sb-section-label,.sidebar.pinned .sb-section-label{opacity:1}

/* Nav item */
.nav-item{
  display:flex;align-items:center;height:38px;border-radius:var(--r);
  padding:0 10px;gap:10px;color:rgba(255,255,255,.42);
  font-size:12.5px;font-weight:500;cursor:pointer;
  position:relative;overflow:hidden;transition:background .14s,color .14s,transform .14s;
  white-space:nowrap;margin-bottom:1px;text-decoration:none;
}
.nav-item .ni-icon{
  width:18px;height:18px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.nav-item .ni-icon img{
  width:16px;height:16px;display:block;flex-shrink:0;
  filter:brightness(0) invert(1);opacity:.45;transition:opacity .14s;
}
.nav-item .ni-lbl{
  flex:1;overflow:hidden;text-overflow:ellipsis;
  opacity:0;transition:opacity .18s .03s;
}
.sidebar:hover .ni-lbl,.sidebar.pinned .ni-lbl{opacity:1}
.nav-item .ni-badge{
  font-size:9px;font-weight:700;min-width:14px;padding:1px 5px;
  border-radius:20px;background:var(--red);color:#fff;
  opacity:0;transition:opacity .18s .03s;flex-shrink:0;
  animation:badgePulse 2.5s ease infinite;
}
.sidebar:hover .ni-badge,.sidebar.pinned .ni-badge{opacity:1}
.nav-item:hover{
  background:rgba(255,255,255,.07);color:rgba(255,255,255,.85);
  transform:translateX(2px);
}
.nav-item:hover .ni-icon img{opacity:.85}
.nav-item.active{
  background:rgba(26,86,219,.16);color:#fff;
}
.nav-item.active::after{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--blue);border-radius:0 2px 2px 0;
  animation:accentSlide .2s ease;
}
.nav-item.active .ni-icon img{opacity:1}

/* Tooltip (rail mode) */
.nav-item[data-tip]::before{
  content:attr(data-tip);
  position:absolute;left:calc(var(--sbw) + 10px);top:50%;transform:translateY(-50%);
  background:var(--navy2);color:#fff;font-size:11.5px;font-weight:600;
  padding:5px 10px;border-radius:6px;white-space:nowrap;
  pointer-events:none;opacity:0;transition:opacity .1s;
  box-shadow:var(--sh2);z-index:400;
}
.sidebar:not(:hover):not(.pinned) .nav-item[data-tip]:hover::before{opacity:1}

.sb-divider{height:1px;background:rgba(255,255,255,.06);margin:5px 10px}

/* User bottom */
.sb-bottom{padding:8px;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0}
.sb-user{
  display:flex;align-items:center;gap:9px;padding:7px 10px;
  border-radius:var(--r);cursor:pointer;transition:background .14s;
  text-decoration:none;overflow:hidden;
}
.sb-user:hover{background:rgba(255,255,255,.07)}
.sb-avatar-wrap{
  width:30px;height:30px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--blue),var(--teal));
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:#fff;overflow:hidden;
  border:1.5px solid rgba(255,255,255,.12);transition:transform .15s;
}
.sb-user:hover .sb-avatar-wrap{transform:scale(1.06)}
.sb-avatar-wrap img{width:100%;height:100%;object-fit:cover;display:block}
.sb-user-info{overflow:hidden;min-width:0;opacity:0;transition:opacity .18s}
.sidebar:hover .sb-user-info,.sidebar.pinned .sb-user-info{opacity:1}
.sb-user-name{font-size:12px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-user-role{font-size:10px;color:rgba(255,255,255,.28);white-space:nowrap}

/* Mobile overlay */
.sb-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:299;backdrop-filter:blur(2px)}
.sb-overlay.active{display:block;animation:fadeIn .2s ease}

/* 6. MAIN + TOPBAR ───────────────────────────────────────────── */
.main-content{
  margin-left:var(--sbw);min-height:100vh;
  display:flex;flex-direction:column;
  transition:margin-left .26s cubic-bezier(.4,0,.2,1);
  background:var(--surf);
}
.sidebar.pinned ~ .main-content{margin-left:var(--sbwopen)}

.topbar{
  height:var(--topH);background:var(--white);
  border-bottom:1.5px solid var(--border);
  display:flex;align-items:center;padding:0 20px;gap:12px;
  position:sticky;top:0;z-index:200;
  box-shadow:var(--sh1);flex-shrink:0;
  /* animation:fadeDown removida — fadeDown usa transform:translateY que criaria
     um stacking context isolado com z-index:200, podendo interferir com modais.
     O topbar usa position:sticky + z-index:200, pelo que não precisa de animação. */
}

/* Breadcrumb */
.tb-bread{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--t3);flex:1;min-width:0;overflow:hidden}
.tb-bread .bc-sep{color:var(--border);font-size:15px;flex-shrink:0}
.tb-bread .bc-cur{display:flex;align-items:center;gap:6px;font-weight:700;color:var(--t1);overflow:hidden;white-space:nowrap}
.tb-bread .bc-inst{display:flex;align-items:center;gap:5px;font-size:11.5px;color:var(--t3);white-space:nowrap;flex-shrink:0}
.tb-bread .bc-inst img{width:14px;height:14px;border-radius:3px;opacity:.55}
.bc-icon{
  width:26px;height:26px;border-radius:6px;background:var(--bluelt);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.bc-icon img{width:13px;height:13px;display:block;filter:invert(25%) sepia(80%) saturate(1500%) hue-rotate(200deg)}

/* Topbar right */
.tb-right{display:flex;align-items:center;gap:7px;flex-shrink:0}
.tb-btn{
  width:34px;height:34px;border-radius:var(--r);
  border:1.5px solid var(--border);background:var(--white);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .15s;
}
.tb-btn img{width:15px;height:15px;display:block;opacity:.5;flex-shrink:0}
.tb-btn:hover{background:var(--bluelt);border-color:var(--blue)}
.tb-btn:hover img{opacity:1;filter:invert(25%) sepia(80%) saturate(1500%) hue-rotate(200deg)}
.tb-ham{display:none}
.tb-avatar-btn{
  width:34px;height:34px;border-radius:50%;overflow:hidden;cursor:pointer;
  background:linear-gradient(135deg,var(--blue),var(--teal));
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:#fff;
  border:2px solid var(--blue);transition:transform .15s,box-shadow .15s;
  text-decoration:none;
}
.tb-avatar-btn:hover{transform:scale(1.07);box-shadow:0 0 0 3px rgba(26,86,219,.2)}
.tb-avatar-btn img{width:100%;height:100%;object-fit:cover;display:block}

/* 7. PAGE CONTENT + HEADER ──────────────────────────────────── */
.page-content{
  flex:1;padding:20px 24px 36px;
  /* NOTA: animation removida propositadamente — a animação pageEnter usava
     opacity+transform e criava um stacking context isolado que colocava o
     backdrop Bootstrap DENTRO do contexto do page-content (à frente do modal).
     A animação foi movida para .page-content-inner abaixo. */
}
/* Wrapper interno para a animação de entrada — NÃO cria stacking context
   persistente porque a animação termina e transform fica em none. */
.page-content-anim{
  animation:pageEnter .42s cubic-bezier(.16,1,.3,1) both;
}

.page-header{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;margin-bottom:20px;flex-wrap:wrap;
  animation:fadeUp .35s ease both;
}
.ph-left{display:flex;align-items:center;gap:11px}
.ph-icon{
  width:34px;height:34px;border-radius:9px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.ph-icon img{width:18px;height:18px;display:block;flex-shrink:0}
.ph-icon.blue  {background:var(--bluelt)}
.ph-icon.blue   img{filter:invert(25%) sepia(80%) saturate(1500%) hue-rotate(200deg)}
.ph-icon.orange{background:var(--orangelt)}
.ph-icon.orange img{filter:invert(40%) sepia(80%) saturate(1200%) hue-rotate(10deg)}
.ph-icon.green {background:var(--greenlt)}
.ph-icon.green  img{filter:invert(30%) sepia(80%) saturate(900%) hue-rotate(100deg)}
.ph-icon.red   {background:var(--redlt)}
.ph-icon.red    img{filter:invert(20%) sepia(90%) saturate(2000%) hue-rotate(340deg)}
.ph-icon.teal  {background:var(--teallt)}
.ph-icon.teal   img{filter:invert(35%) sepia(80%) saturate(900%) hue-rotate(180deg)}
.ph-icon.purple{background:var(--purplelt)}
.ph-icon.purple img{filter:invert(25%) sepia(80%) saturate(1500%) hue-rotate(260deg)}
.ph-icon.amber {background:var(--amberlt)}
.ph-icon.amber  img{filter:invert(30%) sepia(80%) saturate(1200%) hue-rotate(20deg)}
.ph-title{font-size:15px;font-weight:700;color:var(--t1);line-height:1.2}
.ph-sub{font-size:11px;color:var(--t3);margin-top:1px}
.ph-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}

/* 8. METRIC GRID ─────────────────────────────────────────────── */
.metric-grid{display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:20px}

.metric-card{
  background:var(--white);border:1.5px solid var(--border);
  border-radius:var(--rlg);padding:16px 18px;
  position:relative;overflow:hidden;
  transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s,border-color .2s;
  animation:fadeUp .38s cubic-bezier(.16,1,.3,1) both;
}
.metric-card:hover{transform:translateY(-3px);box-shadow:var(--sh3);border-color:transparent}
.metric-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  border-radius:var(--rlg) var(--rlg) 0 0;
}
.mc-blue::before  {background:linear-gradient(90deg,var(--blue),#60A5FA)}
.mc-orange::before{background:linear-gradient(90deg,var(--orange),#FB923C)}
.mc-green::before {background:linear-gradient(90deg,var(--green),#34D399)}
.mc-teal::before  {background:linear-gradient(90deg,var(--teal),#22D3EE)}
.mc-red::before   {background:linear-gradient(90deg,var(--red),#F87171)}
.mc-purple::before{background:linear-gradient(90deg,var(--purple),#A78BFA)}

.metric-card:nth-child(1){animation-delay:.04s}
.metric-card:nth-child(2){animation-delay:.08s}
.metric-card:nth-child(3){animation-delay:.12s}
.metric-card:nth-child(4){animation-delay:.16s}

.mc-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:13px}
.mc-icon,.metric-icon{
  width:38px;height:38px;border-radius:9px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.mc-icon img,.metric-icon img{width:19px;height:19px;display:block;flex-shrink:0;max-width:19px;max-height:19px}
.mc-blue   .mc-icon,.mc-blue   .metric-icon{background:var(--bluelt)}
.mc-blue   .mc-icon img,.mc-blue   .metric-icon img{filter:invert(25%) sepia(80%) saturate(1500%) hue-rotate(200deg)}
.mc-orange .mc-icon,.mc-orange .metric-icon{background:var(--orangelt)}
.mc-orange .mc-icon img,.mc-orange .metric-icon img{filter:invert(40%) sepia(80%) saturate(1200%) hue-rotate(10deg)}
.mc-green  .mc-icon,.mc-green  .metric-icon{background:var(--greenlt)}
.mc-green  .mc-icon img,.mc-green  .metric-icon img{filter:invert(30%) sepia(80%) saturate(900%) hue-rotate(100deg)}
.mc-teal   .mc-icon,.mc-teal   .metric-icon{background:var(--teallt)}
.mc-teal   .mc-icon img,.mc-teal   .metric-icon img{filter:invert(35%) sepia(80%) saturate(900%) hue-rotate(180deg)}
.mc-red    .mc-icon,.mc-red    .metric-icon{background:var(--redlt)}
.mc-red    .mc-icon img,.mc-red    .metric-icon img{filter:invert(20%) sepia(90%) saturate(2000%) hue-rotate(340deg)}
.mc-purple .mc-icon,.mc-purple .metric-icon{background:var(--purplelt)}
.mc-purple .mc-icon img,.mc-purple .metric-icon img{filter:invert(25%) sepia(80%) saturate(1500%) hue-rotate(260deg)}

.mc-trend,.metric-trend{font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px;display:flex;align-items:center;gap:3px}
.mc-trend.up,.metric-trend-up{background:var(--greenlt);color:var(--green)}
.mc-trend.down,.metric-trend-down{background:var(--redlt);color:var(--red)}
.mc-trend.neu{background:var(--surf2);color:var(--t3)}
.mc-lbl,.metric-lbl{font-size:10.5px;color:var(--t3);font-weight:600;letter-spacing:.3px;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mc-val,.metric-val{font-size:22px;font-weight:800;color:var(--t1);line-height:1;animation:countUp .5s ease both;font-variant-numeric:tabular-nums;font-family:var(--mono)}
.mc-sub,.metric-sub{font-size:11px;color:var(--t3);margin-top:5px;display:flex;align-items:center;gap:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mc-sub img,.metric-sub img{width:12px;height:12px;opacity:.5;flex-shrink:0;display:block}

/* 9. CARDS ───────────────────────────────────────────────────── */
.card,.card-ipikk{
  background:var(--white);border:1.5px solid var(--border);
  border-radius:var(--rlg);overflow:hidden;
  animation:fadeUp .38s cubic-bezier(.16,1,.3,1) both;
  transition:box-shadow .18s,border-color .18s,transform .18s;
}
.card:hover,.card-ipikk:hover{box-shadow:var(--sh1)}
.card-click,.card[onclick]{cursor:pointer}
.card-click:hover,.card[onclick]:hover{transform:translateY(-2px);box-shadow:var(--sh2)}

.card-head{
  padding:12px 16px 11px;
  border-bottom:1px solid var(--bordersoft);
  display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.card-head-left{display:flex;align-items:center;gap:8px;min-width:0;overflow:hidden}
.card-head-icon{
  width:26px;height:26px;border-radius:6px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:var(--bluelt);
}
.card-head-icon img{width:14px;height:14px;display:block;flex-shrink:0;filter:invert(25%) sepia(80%) saturate(1500%) hue-rotate(200deg)}
.card-head-icon.orange{background:var(--orangelt)}
.card-head-icon.orange img{filter:invert(40%) sepia(80%) saturate(1200%) hue-rotate(10deg)}
.card-head-icon.green{background:var(--greenlt)}
.card-head-icon.green img{filter:invert(30%) sepia(80%) saturate(900%) hue-rotate(100deg)}
.card-head-icon.red{background:var(--redlt)}
.card-head-icon.red img{filter:invert(20%) sepia(90%) saturate(2000%) hue-rotate(340deg)}
.card-head-title{font-size:12.5px;font-weight:700;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-head-sub{font-size:10.5px;color:var(--t3);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-body{padding:16px}
.card-body-flush{padding:0}

/* Card accent (borda esquerda colorida, como nas preventivas) */
.card-accent{border-left:4px solid var(--blue)!important}
.card-accent.accent-orange{border-left-color:var(--orange)!important}
.card-accent.accent-green{border-left-color:var(--green)!important}
.card-accent.accent-red{border-left-color:var(--red)!important}
.card-accent.accent-teal{border-left-color:var(--teal)!important}
.card-accent.accent-purple{border-left-color:var(--purple)!important}

/* Card row (linha de lista) */
.card-row{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--bordersoft);transition:background .12s;cursor:pointer}
.card-row:last-child{border-bottom:none}
.card-row:hover{background:var(--bluelt)}
.card-row-icon{width:32px;height:32px;border-radius:8px;background:var(--bluelt);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.card-row-icon img{width:15px;height:15px;display:block;filter:invert(25%) sepia(80%) saturate(1500%) hue-rotate(200deg)}
.card-row-body{flex:1;min-width:0}
.card-row-title{font-size:13px;font-weight:600;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-row-sub{font-size:11px;color:var(--t3);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Card 2col */
.card-2col{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--bordersoft)}
.card-2col>div{padding:10px 16px}
.card-2col>div+div{border-left:1px solid var(--bordersoft)}
.card-2col .col-label{font-size:9px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--t4);margin-bottom:3px;display:flex;align-items:center;gap:3px}
.card-2col .col-label img{width:10px;height:10px;opacity:.45}
.card-2col .col-value{font-size:13px;font-weight:700;color:var(--t1)}
.card-2col .col-sub{font-size:11px;color:var(--t3);margin-top:1px}

/* Item card */
.item-card{
  background:var(--white);border:1.5px solid var(--border);border-radius:var(--rlg);
  padding:14px 16px;display:flex;align-items:center;gap:13px;
  cursor:pointer;transition:all .18s;text-decoration:none;color:inherit;overflow:hidden;
}
.item-card:hover{transform:translateY(-2px);box-shadow:var(--sh2);border-color:var(--blue);color:inherit;text-decoration:none}
.item-card-icon{width:40px;height:40px;border-radius:10px;flex-shrink:0;background:var(--bluelt);display:flex;align-items:center;justify-content:center}
.item-card-icon img{width:20px;height:20px;display:block;filter:invert(25%) sepia(80%) saturate(1500%) hue-rotate(200deg)}
.item-card-title{font-size:13px;font-weight:700;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.item-card-sub{font-size:11.5px;color:var(--t3);margin-top:2px}

/* Empty state */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:44px 20px;text-align:center;color:var(--t3)}
.empty-state .es-icon{width:48px;height:48px;opacity:.16;margin-bottom:14px;display:block}
.empty-state .es-title{font-size:13.5px;font-weight:700;color:var(--t2);margin-bottom:5px}
.empty-state .es-sub{font-size:11.5px;line-height:1.6}

/* Skeleton */
.skel{background:linear-gradient(90deg,var(--surf2) 25%,var(--border) 50%,var(--surf2) 75%);background-size:600px 100%;animation:shimmer 1.5s infinite;border-radius:var(--r)}

/* 10. TABLES ─────────────────────────────────────────────────── */
.table-wrap,.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}
.tbl,.table-ipikk{width:100%;border-collapse:collapse}
.tbl thead th,.table-ipikk thead th{
  background:var(--surf);color:var(--t3);
  font-size:10px;font-weight:700;letter-spacing:.9px;text-transform:uppercase;
  padding:9px 14px;border-bottom:1.5px solid var(--border);white-space:nowrap;
}
.tbl thead th img,.table-ipikk thead th img{width:11px;height:11px;opacity:.5;vertical-align:-1px;margin-right:3px;display:inline-block}
.tbl tbody tr,.table-ipikk tbody tr{border-bottom:1px solid var(--bordersoft);transition:background .12s;cursor:pointer}
.tbl tbody tr:last-child,.table-ipikk tbody tr:last-child{border-bottom:none}
.tbl tbody tr:hover,.table-ipikk tbody tr:hover{background:var(--bluelt)}
.tbl td,.table-ipikk td{padding:10px 14px;font-size:12.5px;color:var(--t2);vertical-align:middle;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tbl-main{font-weight:600;color:var(--t1)}
.tbl-sub{font-size:11px;color:var(--t3);margin-top:1px}
.equip-thumb{width:36px;height:36px;border-radius:7px;object-fit:cover;border:1.5px solid var(--border);display:block;flex-shrink:0}
.equip-thumb-ph{width:36px;height:36px;border-radius:7px;background:var(--surf2);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.equip-thumb-ph img{width:16px;height:16px;opacity:.3}

/* 11. BADGES ─────────────────────────────────────────────────── */
.badge,.badge-ipikk{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap;
  animation:popIn .2s ease both;
}
.badge img,.badge-ipikk img{width:11px;height:11px;flex-shrink:0;display:block}
.badge-ok,.badge-ipikk.badge-ok{background:var(--greenlt);color:var(--green)}
.badge-warn,.badge-ipikk.badge-warn{background:var(--orangelt);color:var(--orange)}
.badge-err,.badge-ipikk.badge-err{background:var(--redlt);color:var(--red)}
.badge-info,.badge-ipikk.badge-info{background:var(--bluelt);color:var(--blue)}
.badge-teal,.badge-ipikk.badge-teal{background:var(--teallt);color:var(--teal)}
.badge-purple,.badge-ipikk.badge-purple{background:var(--purplelt);color:var(--purple)}
.badge-neutral,.badge-ipikk.badge-neutral{background:var(--surf2);color:var(--t3)}

/* 12. BUTTONS ────────────────────────────────────────────────── */
.btn,.btn-ipikk{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 15px;border-radius:var(--r);
  font-size:12.5px;font-weight:600;font-family:var(--font);
  cursor:pointer;border:none;white-space:nowrap;line-height:1;
  transition:all .16s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;
}
.btn img,.btn-ipikk img{width:14px;height:14px;display:block;flex-shrink:0}
.btn:hover,.btn-ipikk:hover{transform:translateY(-2px);box-shadow:var(--sh2)}
.btn:active,.btn-ipikk:active{transform:scale(.97)}
.btn-primary,.btn-ipikk.btn-primary{background:var(--blue);color:#fff}
.btn-primary img,.btn-ipikk.btn-primary img{filter:brightness(0) invert(1)}
.btn-primary:hover,.btn-ipikk.btn-primary:hover{background:var(--blue2);color:#fff}
.btn-success,.btn-ipikk.btn-success{background:var(--green);color:#fff}
.btn-success img,.btn-ipikk.btn-success img{filter:brightness(0) invert(1)}
.btn-success:hover,.btn-ipikk.btn-success:hover{background:#036644;color:#fff}
.btn-danger,.btn-ipikk.btn-danger{background:var(--red);color:#fff}
.btn-danger img,.btn-ipikk.btn-danger img{filter:brightness(0) invert(1)}
.btn-warning,.btn-ipikk.btn-warning{background:var(--orange);color:#fff}
.btn-warning img,.btn-ipikk.btn-warning img{filter:brightness(0) invert(1)}
.btn-outline,.btn-ipikk.btn-outline{background:transparent;color:var(--blue);border:1.5px solid var(--blue)}
.btn-outline img,.btn-ipikk.btn-outline img{filter:invert(25%) sepia(80%) saturate(1500%) hue-rotate(200deg)}
.btn-outline:hover,.btn-ipikk.btn-outline:hover{background:var(--bluelt);color:var(--blue)}
.btn-ghost,.btn-ipikk.btn-ghost{background:var(--surf);color:var(--t2);border:1.5px solid var(--border)}
.btn-ghost img,.btn-ipikk.btn-ghost img{opacity:.55}
.btn-ghost:hover,.btn-ipikk.btn-ghost:hover{background:var(--bluelt);color:var(--blue);border-color:var(--blue)}
.btn-ghost:hover img,.btn-ipikk.btn-ghost:hover img{opacity:1;filter:invert(25%) sepia(80%) saturate(1500%) hue-rotate(200deg)}
.btn-sm,.btn-ipikk.btn-sm{padding:5px 11px;font-size:11.5px;border-radius:6px;gap:5px}
.btn-sm img,.btn-ipikk.btn-sm img{width:13px;height:13px}
.btn-lg{padding:10px 22px;font-size:13.5px}
/* Alias legado */
.btn-ipikk-success{display:inline-flex;align-items:center;gap:6px;padding:7px 15px;border-radius:var(--r);font-size:12.5px;font-weight:600;font-family:var(--font);background:var(--green);color:#fff;border:none;cursor:pointer;transition:all .16s;white-space:nowrap}
.btn-ipikk-success img{width:14px;height:14px;filter:brightness(0) invert(1);display:block;flex-shrink:0}
.btn-ipikk-success:hover{background:#036644;transform:translateY(-2px);box-shadow:var(--sh2);color:#fff}

/* Spinner in button */
.btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:none}
.btn.loading .btn-spinner{display:block}
.btn.loading img,.btn.loading span.btn-lbl{display:none}

/* 13. FORMS ──────────────────────────────────────────────────── */
.form-control,.form-select{
  border:1.5px solid var(--border);border-radius:var(--r);
  padding:8px 12px;font-size:13px;font-family:var(--font);
  color:var(--t1);background:var(--white);width:100%;
  transition:border-color .16s,box-shadow .16s;
}
.form-control:focus,.form-select:focus{
  outline:none;border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(26,86,219,.1);
}
.form-control::placeholder{color:var(--t4)}
.form-control-sm,.form-select-sm{padding:7px 11px;font-size:12.5px}
.form-label{
  font-size:10.5px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;
  color:var(--t3);margin-bottom:5px;display:flex;align-items:center;gap:5px;
  transition:transform .15s;
}
.form-label img{width:12px;height:12px;opacity:.55;flex-shrink:0;display:block}
.form-control:focus + .form-label,.form-control:focus ~ .form-label{color:var(--blue)}
.form-text{font-size:11px;color:var(--t4);margin-top:3px}
.is-invalid{border-color:var(--red)!important}
.is-invalid:focus{box-shadow:0 0 0 3px rgba(200,30,30,.1)!important}
.is-valid{border-color:var(--green)!important}
.invalid-feedback{font-size:11px;color:var(--red);margin-top:3px}
.input-wrap{position:relative}
.input-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:15px;height:15px;opacity:.4;pointer-events:none;display:block}
.input-wrap .form-control{padding-left:36px}

/* 14. ALERTS ─────────────────────────────────────────────────── */
.alert-bar,.info-bar,.warn-bar,.ok-bar{
  display:flex;align-items:flex-start;gap:9px;
  padding:10px 13px;border-radius:var(--r);font-size:12px;
  margin-bottom:12px;line-height:1.5;
  animation:fadeLeft .28s ease;
}
.alert-bar img,.info-bar img,.warn-bar img,.ok-bar img{width:14px;height:14px;flex-shrink:0;margin-top:1px;display:block}
.info-bar,.alert-info{background:var(--bluelt);color:#1E40AF;border-left:3px solid var(--blue)}
.info-bar img{filter:invert(25%) sepia(80%) saturate(1500%) hue-rotate(200deg)}
.warn-bar,.alert-warn{background:var(--orangelt);color:#7C2D12;border-left:3px solid var(--orange)}
.ok-bar,.alert-ok{background:var(--greenlt);color:#064E3B;border-left:3px solid var(--green)}
.alert-err{background:var(--redlt);color:#7F1D1D;border-left:3px solid var(--red)}

/* 15. MODAL ──────────────────────────────────────────────────── */
/*
   ARQUITECTURA DE Z-INDEX:
   ─────────────────────────
   sidebar          z:300  (position:fixed)
   topbar           z:200  (position:sticky) — sem transform para não criar stacking context
   .modal-backdrop  z:1040 (filho de <body>) — escurece a PÁGINA atrás do modal
   .modal           z:1055 (filho de <body>, movido por JS) — visível e clicável

   Os modais são movidos para <body> via JS (footer.php) para garantirem que
   estão FORA de qualquer stacking context criado por .page-content ou .main-content.
*/
.modal-backdrop{z-index:1040!important}
.modal{z-index:1055!important}

.modal-content{
  border:none;border-radius:var(--rxl);box-shadow:var(--sh4);
  animation:scaleIn .24s cubic-bezier(.16,1,.3,1);overflow:hidden;
  background:#fff!important;
}
.modal-header{background:var(--navy);color:#fff;padding:14px 20px;border:none}
.modal-header.light{background:var(--surf);color:var(--t1);border-bottom:1px solid var(--border)}
.modal-title{font-size:14px;font-weight:700;display:flex;align-items:center;gap:7px}
.modal-title img{width:15px;height:15px;filter:brightness(0) invert(1);flex-shrink:0;display:block}
.modal-header.light .modal-title img{filter:none;opacity:.6}
.modal-body{padding:18px 20px}
.modal-footer{padding:12px 20px;border-top:1px solid var(--border);gap:8px}
.btn-close{opacity:.45;transition:opacity .15s,transform .15s}
.btn-close:hover{opacity:1;transform:rotate(90deg)}
.btn-close-white{filter:brightness(0) invert(1)}

/* 16. TOAST ──────────────────────────────────────────────────── */
#toast{
  position:fixed;bottom:22px;right:22px;
  background:var(--navy);color:#fff;
  padding:12px 18px;border-radius:var(--rlg);
  font-size:13px;font-weight:600;
  display:flex;align-items:center;gap:9px;
  opacity:0;pointer-events:none;transition:opacity .2s;
  z-index:9999;box-shadow:var(--sh4);max-width:360px;
}
#toast.show{opacity:1;pointer-events:auto;animation:toastSlide .28s ease}

/* 17. PROGRESS BARS ──────────────────────────────────────────── */
.bar-row{display:flex;align-items:center;gap:9px;margin-bottom:9px}
.bar-lbl{font-size:12px;color:var(--t2);width:120px;flex-shrink:0;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bar-track{flex:1;height:6px;background:var(--bordersoft);border-radius:6px;overflow:hidden}
.bar-fill{height:100%;border-radius:6px;animation:barFill .7s cubic-bezier(.4,0,.2,1) both;background:linear-gradient(90deg,var(--blue),var(--blue3))}
.bar-fill.green{background:linear-gradient(90deg,var(--green),#34D399)}
.bar-fill.orange{background:linear-gradient(90deg,var(--orange),#FB923C)}
.bar-fill.red{background:linear-gradient(90deg,var(--red),#F87171)}
.bar-val{font-size:11px;font-weight:700;color:var(--t1);width:26px;text-align:right;flex-shrink:0}
/* Card progress bar (preventivas) */
.card-progress{padding:0 16px 12px}
.card-progress-track{height:5px;border-radius:3px;background:var(--surf2);overflow:hidden}
.card-progress-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--green),#34D399);transition:width .6s cubic-bezier(.4,0,.2,1)}
.card-progress-fill.warn{background:linear-gradient(90deg,var(--orange),#FB923C)}
.card-progress-fill.alert{background:linear-gradient(90deg,var(--red),#F87171)}
.card-progress-meta{display:flex;justify-content:space-between;margin-top:3px}
.card-progress-meta span{font-size:9.5px;color:var(--t4);font-weight:600}

/* 18. FOTO UPLOAD + IMAGEM SEARCH ───────────────────────────── */
.foto-upload-zone{border:2px dashed var(--border);border-radius:var(--rlg);background:var(--surf);padding:14px;transition:border-color .16s,background .16s}
.foto-upload-zone:hover{border-color:var(--blue);background:var(--bluelt)}
.foto-preview-wrap{width:110px;aspect-ratio:4/3;border-radius:var(--r);overflow:hidden;border:1.5px solid var(--border);background:var(--surf2);flex-shrink:0}
.foto-preview-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;color:var(--t4);font-size:11px}
.foto-preview-placeholder img{width:20px;height:20px;opacity:.22}
.img-motor-btn{padding:0 11px;height:100%;border:none;background:transparent;font-size:12px;font-weight:600;color:var(--t3);cursor:pointer;transition:all .13s;white-space:nowrap;font-family:var(--font)}
.img-motor-btn:hover{background:var(--bluelt);color:var(--blue)}
.img-motor-btn.active{background:var(--blue);color:#fff}
.img-motor-btn+.img-motor-btn{border-left:1px solid var(--border)}
.img-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:9px;max-height:420px;overflow-y:auto;padding-right:2px}
.img-grid::-webkit-scrollbar{width:4px}
.img-grid::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.img-tile{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/3;cursor:pointer;border:2.5px solid transparent;background:var(--bordersoft);transition:border-color .13s,transform .13s}
.img-tile img{width:100%;height:100%;object-fit:cover;display:block}
.img-tile:hover{border-color:var(--blue);transform:scale(1.02)}
.img-tile.sel{border-color:var(--green)}
.img-tile .chk{position:absolute;top:5px;right:5px;width:18px;height:18px;border-radius:50%;background:var(--green);color:#fff;font-size:10px;font-weight:700;display:none;align-items:center;justify-content:center}
.img-tile.sel .chk{display:flex}
.img-tile .src-tag{position:absolute;bottom:3px;left:3px;background:rgba(0,0,0,.5);color:#fff;font-size:9px;padding:1px 5px;border-radius:3px;font-weight:600}
.img-tile-skel{aspect-ratio:4/3;border-radius:var(--r);background:linear-gradient(90deg,var(--surf2) 25%,var(--border) 50%,var(--surf2) 75%);background-size:600px 100%;animation:shimmer 1.5s infinite}

/* 19. LOGIN ──────────────────────────────────────────────────── */
.login-page{min-height:100vh;background:var(--white);display:flex}
.login-left{
  flex:1;background:var(--navy);position:relative;overflow:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;
}
.login-left::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(26,86,219,.18) 0%,transparent 60%),radial-gradient(ellipse at 80% 80%,rgba(7,113,166,.1) 0%,transparent 50%)}
.login-left::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--blue),#60A5FA,var(--blue));background-size:200%;animation:gradShift 4s ease infinite}
.login-brand{position:relative;z-index:2;text-align:center;width:100%;max-width:340px}
.login-logo-inst{
  width:80px;height:80px;border-radius:16px;
  background:rgba(255,255,255,.93);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 18px;
  box-shadow:0 4px 24px rgba(0,0,0,.28),0 0 0 5px rgba(255,255,255,.12);
}
.login-logo-inst img{width:62px;height:62px;object-fit:contain;display:block}
.login-logo-box{
  width:52px;height:52px;border-radius:12px;background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;
  animation:pulseRing 3s ease infinite;
}
.login-logo-box img{width:32px;height:32px;filter:brightness(0) invert(1);opacity:.7;display:block}
.login-inst-label{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.45);font-size:9px;font-weight:700;letter-spacing:2px;padding:4px 12px;border-radius:20px;margin-bottom:16px}
.login-inst-label img{width:11px;height:11px;filter:brightness(0) invert(1);opacity:.45}
.login-title{font-size:24px;font-weight:800;color:#fff;line-height:1.2;margin-bottom:7px}
.login-desc{font-size:12.5px;color:rgba(255,255,255,.36);line-height:1.7;margin-bottom:30px}
.login-features{display:flex;flex-direction:column;gap:10px}
.login-feat{display:flex;align-items:center;gap:11px;text-align:left;animation:fadeUp .4s ease both}
.login-feat:nth-child(1){animation-delay:.18s}
.login-feat:nth-child(2){animation-delay:.26s}
.login-feat:nth-child(3){animation-delay:.34s}
.login-feat:nth-child(4){animation-delay:.42s}
.feat-dot{width:28px;height:28px;border-radius:7px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.feat-dot img{width:14px;height:14px;filter:brightness(0) invert(1);opacity:.7}
.feat-dot.blue{background:rgba(26,86,219,.22)}
.feat-dot.green{background:rgba(4,120,87,.22)}
.feat-dot.orange{background:rgba(194,87,10,.22)}
.feat-dot.teal{background:rgba(7,113,166,.22)}
.feat-text{font-size:12.5px;color:rgba(255,255,255,.47)}
.login-right{width:440px;min-width:440px;background:var(--white);display:flex;align-items:center;justify-content:center;padding:44px 40px;position:relative}
.login-right::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:linear-gradient(180deg,var(--blue) 0%,var(--teal) 100%)}
.login-form-wrap{width:100%;max-width:320px;animation:fadeUp .4s ease}
.login-form-icon{width:46px;height:46px;border-radius:12px;background:var(--bluelt);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.login-form-icon img{width:22px;height:22px;filter:invert(25%) sepia(80%) saturate(1500%) hue-rotate(200deg);display:block}
.login-form-title{font-size:20px;font-weight:800;color:var(--t1);margin-bottom:4px}
.login-form-sub{font-size:12px;color:var(--t3);margin-bottom:22px}
.login-btn{width:100%;padding:11px;border-radius:var(--r);background:var(--blue);color:#fff;border:none;font-family:var(--font);font-size:13.5px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;transition:all .18s;margin-top:5px}
.login-btn img{width:15px;height:15px;filter:brightness(0) invert(1);display:block}
.login-btn:hover{background:var(--blue2);transform:translateY(-1px);box-shadow:0 7px 24px rgba(26,86,219,.3)}
.login-btn:active{transform:scale(.98)}
.login-forgot{text-align:center;margin-top:12px}
.login-forgot a{font-size:12px;color:var(--t3);text-decoration:none;transition:color .14s}
.login-forgot a:hover{color:var(--blue)}
.login-footer{margin-top:24px;font-size:11px;color:var(--t4);text-align:center;display:flex;align-items:center;justify-content:center;gap:5px}
.login-footer img{width:13px;height:13px;opacity:.3;border-radius:3px}
.erro-box{background:var(--redlt);border:1.5px solid #FCA5A5;border-radius:var(--r);padding:9px 13px;font-size:12px;color:var(--red);display:flex;align-items:flex-start;gap:7px;margin-bottom:14px}
.erro-box img{width:14px;height:14px;flex-shrink:0;margin-top:1px;filter:invert(20%) sepia(90%) saturate(2000%) hue-rotate(340deg)}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}
.shake{animation:shake .28s ease}

/* 20. UTILITIES ──────────────────────────────────────────────── */
.anim-up,.anim-fade-up{animation:fadeUp .38s cubic-bezier(.16,1,.3,1) both}
.anim-in{animation:fadeIn .3s ease both}
.anim-scale{animation:scaleIn .28s ease both}
.d1{animation-delay:.04s}.d2{animation-delay:.08s}.d3{animation-delay:.12s}
.d4{animation-delay:.16s}.d5{animation-delay:.20s}.d6{animation-delay:.24s}
.hover-lift{transition:transform .18s,box-shadow .18s}
.hover-lift:hover{transform:translateY(-2px);box-shadow:var(--sh2)}
.spin{animation:spin 1s linear infinite}
.sep{height:1px;background:var(--bordersoft);margin:14px 0}
.mono{font-family:var(--mono)}

/* Module card (dashboard) */
.module-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--rlg);padding:16px;display:flex;align-items:flex-start;gap:12px;cursor:pointer;transition:all .18s;text-decoration:none;color:inherit;overflow:hidden}
.module-card:hover{transform:translateY(-3px);box-shadow:var(--sh3);border-color:transparent;text-decoration:none;color:inherit}
.module-card-title{font-size:13px;font-weight:700;color:var(--t1);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.module-card-sub{font-size:11.5px;color:var(--t3);line-height:1.5;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}

/* Stat row */
.stat-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--bordersoft);font-size:12.5px}
.stat-row:last-child{border-bottom:none}
.stat-row-label{color:var(--t3);display:flex;align-items:center;gap:5px}
.stat-row-label img{width:13px;height:13px;opacity:.5}
.stat-row-value{font-weight:700;color:var(--t1)}

/* Image search motor info */
#imgMotorInfo{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px;padding:7px 12px;background:var(--surf);border:1.5px solid var(--border);border-radius:8px;font-size:11.5px;flex-wrap:wrap}

/* 21. RESPONSIVE ─────────────────────────────────────────────── */
@media(min-width:1400px){
  .page-content{max-width:1560px}
}
@media(max-width:1100px){
  .metric-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  .sidebar,.sidebar.pinned{width:var(--sbw)!important}
  .sidebar:hover{width:var(--sbw)!important;z-index:300;box-shadow:2px 0 12px rgba(0,0,0,.15)}
  .main-content,.sidebar.pinned ~ .main-content{margin-left:var(--sbw)!important}
  .sb-pin{display:none!important}
}
@media(max-width:768px){
  .sidebar{transform:translateX(-100%);width:var(--sbwopen)!important;transition:transform .26s cubic-bezier(.4,0,.2,1)}
  .sidebar:hover{width:var(--sbwopen)!important;transform:translateX(-100%)}
  .sidebar.mobile-open,.sidebar.mobile-open:hover{transform:translateX(0)!important}
  .main-content,.sidebar.pinned ~ .main-content{margin-left:0!important}
  .tb-ham{display:flex}
  .page-content{padding:14px 14px 26px}
  .topbar{padding:0 14px}
  .metric-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .login-left{display:none}
  .login-right{width:100%;min-width:unset}
}
@media(max-width:520px){
  .page-content{padding:10px 10px 22px}
  .topbar{height:48px;padding:0 10px}
  .page-header{margin-bottom:12px}
  .ph-sub{display:none}
  .metric-grid{gap:8px}
  .metric-card{padding:12px}
  .mc-val,.metric-val{font-size:20px}
}
@media(max-width:380px){
  .metric-grid{grid-template-columns:1fr}
  .login-right{padding:30px 18px}
}
