/* ======================================================================
   RESET BÁSICO / VARIÁVEIS
   ====================================================================== */
*, *::before, *::after { box-sizing: border-box; }

:root{
  --bg:#f6f7fb;
  --sidebar:#0f172a;
  --sidebar-active:#1e293b;
  --card:#ffffff;
  --text:#0f172a;
  --muted:#6b7280;
  --ok:#16a34a;
  --warn:#f59e0b;
  --danger:#ef4444;
  --soft:#e5e7eb;

  --primary:#2e7d32;             /* verde musgo */
  --primary-600:#27662b;         /* hover */
  --primary-ring:rgba(46,125,50,.25);

  --accent:#16a34a;

  /* Paleta sidebar musgo */
  --moss-900:#2f3d2f;
  --moss-800:#334d34;
  --moss-700:#3f5d3b;
  --moss-600:#4a6b45;
  --moss-300:#cfe8d0;
  --moss-100:#eaf6ec;
  --ink-100:#c7d1c7;
  --white:#ffffff;

  /* Sidebar layout */
  --sidebar-w:260px;
  --sidebar-mini:78px;
}

html, body{
  height:100%;
  background:var(--bg);
  color:var(--text);
  font-family:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial;
}

/* ======================================================================
   LAYOUT
   ====================================================================== */
.wrapper{
  display:grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  min-height:100vh;
  transition: grid-template-columns .35s cubic-bezier(.2,.8,.2,1);
}
.sidebar, .sidebar-container{
  transition: padding .35s cubic-bezier(.2,.8,.2,1), width .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s cubic-bezier(.2,.8,.2,1);
}

/* Sem sidebar (login etc.) */
.wrapper.nosidebar{ grid-template-columns:1fr !important; }

/* Conteúdo */
.content{
  height:100vh;              /* ocupa exatamente a altura da viewport */
  padding:26px 28px;
  min-width:0;

  display:flex;
  flex-direction:column;     /* header + ch-page em coluna */
}


.page-title{ font-size:26px; font-weight:800; margin-bottom:14px; }

/* ======================================================================
   SIDEBAR – MUSGO + RECOLHÍVEL
   ====================================================================== */
.sidebar,
.sidebar-container{
  background: linear-gradient(180deg, var(--moss-800), var(--moss-700));
  border-radius:18px;
  margin:12px;
  padding:10px 8px;
  box-shadow:0 10px 24px rgba(0,0,0,.25), inset 0 1px 0 rgba(255,255,255,.06);
  color:#fff;
}

.sidebar .brand{
  display:flex; align-items:center; justify-content:space-between;
  gap:10px; font-weight:800; font-size:18px; padding:8px 10px; margin-bottom:16px;
  color:var(--moss-100);
}

.sidebar .nav,
.sidebar .menu{ display:flex; flex-direction:column; gap:4px; }

.sidebar .nav a,
.sidebar a.nav-link,
.sidebar .menu a{
  position:relative;
  display:flex; align-items:center; gap:10px;
  padding:12px 16px;
  color:var(--moss-100);
  text-decoration:none;
  border-radius:12px;
  transition: color .2s ease, padding .2s ease, gap .2s ease;
}
.sidebar .nav a i,
.sidebar .menu a i{ color:var(--ink-100); font-size:18px; transition:color .2s ease, transform .2s ease, font-size .2s ease; }

/* Sublinhado animado */
.sidebar .nav a::after,
.sidebar .menu a::after{
  content:""; position:absolute; left:16px; right:16px; bottom:8px; height:2px;
  background:var(--moss-300); transform:scaleX(0); transform-origin:left; transition:transform .25s ease;
}
.sidebar .nav a:hover,
.sidebar .menu a:hover{ color:var(--white); }
.sidebar .nav a:hover i,
.sidebar .menu a:hover i{ color:var(--white); transform:translateX(2px); }
.sidebar .nav a:hover::after,
.sidebar .menu a:hover::after{ transform:scaleX(1); }
.sidebar .nav a.active,
.sidebar .menu a.active{ color:var(--white); }
.sidebar .nav a.active i,
.sidebar .menu a.active i{ color:var(--white); }
.sidebar .nav a.active::after,
.sidebar .menu a.active::after{ transform:scaleX(1); height:3px; background:var(--white); }

/* Botão hamburguer */
.sidebar-toggle{ position:sticky; top:12px; z-index:7; margin-left:auto; background:transparent; border:0; padding:6px; cursor:pointer; transition:all .25s ease; }
.sidebar-toggle i{ font-size:20px; color:var(--moss-100); transition: color .2s ease, transform .25s ease; }
.sidebar-toggle:hover i{ color:var(--white); transform:scale(1.1); }

/* Estado mini (recolhido) */
.sidebar-mini .wrapper{ grid-template-columns: var(--sidebar-mini) 1fr; }
.sidebar-mini .sidebar .brand{ justify-content:center; }
.sidebar-mini .sidebar .nav a,
.sidebar-mini .sidebar .menu a{ font-size:0; gap:0; justify-content:center; padding:10px 12px; }
.sidebar-mini .sidebar .nav a i,
.sidebar-mini .sidebar .menu a i{ font-size:20px; }
.sidebar-mini .sidebar .nav a:hover i{ transform:scale(1.08); }
.sidebar-mini .sidebar .nav-link:hover::after,
.sidebar-mini .sidebar .nav-link.active::after{ left:22px; right:22px; }

/* Ajuste de padding quando mini */
.sidebar-mini .content{ padding-left:18px; transition:padding .25s ease; }

/* ======================================================================
   CARDS / DASHBOARD
   ====================================================================== */
.grid{ display:grid; gap:16px; }
.grid.cards{
  grid-template-columns:repeat(auto-fit, minmax(260px,1fr));
}

.card{
  background:var(--card);
  border:1px solid var(--soft);
  border-radius:16px;
  padding:16px;
  box-shadow:0 1px 2px rgba(0,0,0,.03);
  transition: box-shadow .2s, transform .12s;
  max-width:100%; overflow:hidden;
}
.card:hover{ box-shadow:0 8px 24px rgba(0,0,0,.06); transform:translateY(-1px); }

.card .label{ display:flex; align-items:center; gap:10px; color:var(--muted); font-size:14px; margin-bottom:10px; }
.card .label i{ font-size:22px; padding:8px; border-radius:10px; display:inline-flex; align-items:center; justify-content:center; }
.card .label .abertos{ background:#fee2e2; color:#dc2626; }
.card .label .atend{ background:#dbeafe; color:#2563eb; }
.card .label .pendentes{ background:#fef3c7; color:#d97706; }
.card .label .espera{ background:#f3e8ff; color:#7e22ce; }
.card .label .resolvidos{ background:#dcfce7; color:#16a34a; }
.card .label .fechados{ background:#e5e7eb; color:#374151; }
.card .label .empresas{ background:#cffafe; color:#0891b2; }
.card .label .sla{ background:#ffedd5; color:#ea580c; }
.big{ font-size:30px; font-weight:900; }
/* KPI cards do dashboard */
.kpi-card .label{
  margin-bottom:0;
}

.kpi-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:8px;
}

.kpi-num{
  font-size:26px;
  font-weight:800;
  color:#0f172a;
}

/* reduzir um pouco em telas menores */
@media (max-width:1280px){
  .kpi-num{
    font-size:22px;
  }
}

/* Badges */
.badge{
  font-size:12px; padding:6px 10px; border-radius:12px;
  border:1px solid var(--soft); background:#f8fafc;
  white-space:nowrap; display:inline-flex; align-items:center;
}
.badge.ok{ color:var(--ok); border-color:#56906AFF; background:#f0fdf4; }
.badge.warn{ color:var(--warn); border-color:#fde68a; background:#fffbeb; }
.badge.danger{ color:var(--danger); border-color:#fecaca; background:#fef2f2; }

/* Badges de status */
.badge.status{ font-size:12px; font-weight:600; padding:6px 12px; border-radius:999px; display:inline-block; }
.badge.ativa{ background:#fff; color:#127637FF; border:1px solid #127637FF; }
.badge.inativa{ background:#fee2e2; color:#dc2626; border:1px solid #fecaca; }
.badge.suspensa{ background:#dbeafe; color:#2563eb; border:1px solid #bfdbfe; }

/* Badge tonal */
.badge.tone{
  --tone:#64748b;
  --tone-dark: color-mix(in srgb, var(--tone) 70%, #000);
  border:1px solid var(--tone-dark);
  color:var(--tone-dark);
  background: color-mix(in srgb, var(--tone) 12%, #fff);
}

/* ======================================================================
   TABELAS
   ====================================================================== */
.table{ width:100%; border-collapse:separate; border-spacing:0 8px; min-width:760px; }
.table th{ text-align:left; color:var(--muted); font-size:12px; font-weight:600; padding:0 12px 8px; white-space:nowrap; }
.table td{ background:var(--card); border:1px solid var(--soft); border-left:4px solid transparent; padding:12px; }
.table tr td:first-child{ border-radius:12px 0 0 12px; padding-left:5px; padding-right:5px; }
.table tr td:last-child{ border-radius:0 12px 12px 0; padding-left:5px; padding-right:5px; }

.table-wrapper{
  overflow-y:auto;
  overflow-x:auto;
  padding:2px;
  border-radius:12px;
}


.table-wrapper .table{
  width: 100%;
  min-width: 960px;  
}

/* Dashboard – cards com tabelas com scroll interno */
.dash-bottom{
  align-items:stretch;
}

.dash-bottom .card{
  display:flex;
  flex-direction:column;
  min-height:0;
}

/* wrapper de tabela dentro dos cards do dashboard */
.dash-bottom .card .table-wrapper{
  flex:1;
  min-height:0;
  overflow-y:auto;
}

/* altura máxima específica (ajusta se quiser mais/menos) */
.table-wrapper.sla-scroll{
  max-height:260px;
}

.table-wrapper.dash-recentes{
  max-height:260px;
}

.card[style*="padding:0"]{ overflow-x:auto; }

.table a.ch-link{ text-decoration:none; color:inherit; }
.table a.ch-link:hover{ filter:brightness(.92); }
.ch-id{ display:block; font-size:11px; color:#94a3b8; letter-spacing:.2px; margin-bottom:2px; font-weight:700; }
.ch-title{ display:block; font-size:15px; line-height:1.28; font-weight:500; color:#0f172a; margin-top:1px; }

/* Última coluna sticky (ações) */
#tabelaChamados th:last-child,
#tabelaChamados td.actions{
  position:sticky; right:0; z-index:5; background:#fff;
  min-width:72px; width:72px; text-align:right;
  box-shadow:-8px 0 10px -8px rgba(0,0,0,.08);
}

/* ======================================================================
   DROPDOWN (3 pontinhos + genéricos)
   ====================================================================== */
td.actions{ position:relative; width:48px; }
.btn.icon.kebab{ border:0; background:transparent; padding:6px; cursor:pointer; color:#6b7280; }

.dropdown{
  position:absolute; right:0; top:36px; min-width:160px; z-index:2000;
  background:#fff; border:1px solid var(--soft); border-radius:10px;
  box-shadow:0 10px 30px rgba(0,0,0,.12); display:none; overflow:hidden;
}
.dropdown.show{ display:block; }
.dropdown .opt,
.anexos-wrap .dropdown .dropdown-item{
  display:flex; align-items:center; gap:8px; width:100%;
  text-align:left; padding:10px 12px; border:0; background:#fff; cursor:pointer; text-decoration:none; color:#111827;
}
/* Dropdown portaleado (menu dos 3 pontinhos “flutuando” no body) */
.dropdown.is-portal{
  max-width: min(260px, 90vw);                 /* não passa da largura da tela */
  max-height: min(320px, calc(100vh - 32px));  /* nem da altura */
  overflow-y: auto;
}

/* Em telas menores, centraliza melhor e evita ficar cortado nas bordas */
@media (max-width: 900px){
  .dropdown.is-portal{
    left: 8px !important;
    right: 8px !important;
  }
}
@media (max-height: 700px){
  .table-wrapper{
    max-height: 320px;
    overflow-y: auto;
  }
}

.dropdown .opt:hover,
.anexos-wrap .dropdown .dropdown-item:hover{ background:#f8fafc; }
.dropdown .danger{ color:var(--danger); }
td.actions .dropdown.drop-up{ top:auto; bottom:36px; }
td.actions .dropdown.scroll-y{ max-height:240px; overflow-y:auto; }

/* ======================================================================
   BOTÕES
   ====================================================================== */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 14px; border-radius:10px; border:1px solid var(--soft);
  background:#fff; cursor:pointer; font-weight:600;
}
.btn.primary{ background:var(--primary); color:#fff; border-color:transparent; }
.btn.primary:hover{ background:var(--primary-600); filter:none; }
.btn.primary:focus{ outline:none; box-shadow:0 0 0 3px var(--primary-ring); }
.btn.ghost{ background:#fff; }
.icon{ background:transparent; border:0; cursor:pointer; color:#6b7280; }

/* ======================================================================
   FORMULÁRIOS
   ====================================================================== */
.form2{ grid-template-columns:1fr 1fr; gap:18px; }
.form2 .full{ grid-column:1/-1; }
.form-group{ display:flex; flex-direction:column; gap:8px; }
.form-group label{ font-size:14px; font-weight:600; color:#334155; }
.form-group input,
.form-group textarea,
.form-group select{
  border:1px solid #d1d5db; border-radius:10px; padding:12px 14px; background:#fff; font-size:14px;
  transition:border .2s, box-shadow .2s, background .2s;
}
.form-group textarea{ min-height:96px; resize:vertical; }
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus{
  outline:none; border-color:#2563eb; box-shadow:0 0 0 3px #bfdbfe; background:#fff;
}

/* Filtros */
.filters-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px 14px; align-items:end; }
.filters-grid .form-group label{ display:block; font-size:.9rem; margin-bottom:6px; }
.filters-grid .form-group select,
.filters-grid .form-group input[type="text"]{ width:100%; height:40px; padding:0 12px; border:1px solid #e5e7eb; border-radius:8px; background:#fff; outline:none; }
.filters-grid .span-3{ grid-column:1/-1; }

/* ======================================================================
   MODAL (CORRIGIDO)
   ====================================================================== */
.modal{
  position:fixed;
  inset:0;
  z-index:1000;

  display:none;               /* estado padrão oculto */
  align-items:center;         /* centraliza vertical */
  justify-content:center;     /* centraliza horizontal */
}

.modal.show{
  display:flex;               /* quando abrir, vira flex container */
}

.modal__backdrop{ position:absolute; inset:0; background:rgba(15,23,42,.45); z-index:1000; }
.modal__dialog{
  position:relative;
  margin:0 16px;
  max-width:960px;
  width:calc(100% - 32px);

  max-height:90vh;
  overflow:hidden;           

  background:#fff;
  border:1px solid #e5e7eb;
  border-radius:14px;
  box-shadow:0 20px 60px rgba(0,0,0,.25);

  z-index:1001;
  display:flex;
  flex-direction:column;    
}

.modal__header,
.modal__footer{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 22px; background:#fff;
}
.modal__header{ border-bottom:1px solid #f1f5f9; }
.modal__footer{ border-top:1px solid #f1f5f9; }
.modal__title{ font-weight:700; font-size:20px; display:flex; align-items:center; gap:10px; color:#1e293b; }
.modal__body{
  padding:20px 22px;

  flex:1 1 auto;
  min-height:0;
  overflow-y:auto;
}


/* ======================================================================
   LOGIN
   ====================================================================== */
.wrapper.nosidebar .content{
  display:flex; justify-content:center; align-items:flex-start;
  min-height:calc(100vh - 52px); padding:64px 16px;
  background: radial-gradient(1200px 400px at 50% -100px, #e8efff, transparent) var(--bg);
}
.login-card{
  width:100%; max-width:560px; background:#fff; border:1px solid var(--soft);
  border-radius:16px; padding:28px 26px; box-shadow:0 20px 50px rgba(0,0,0,.08); text-align:left;
}
.login-logo{
  width:72px; height:72px; display:flex; align-items:center; justify-content:center;
  margin:0 auto 14px; background:var(--accent); color:#fff; border-radius:18px;
  box-shadow:0 10px 24px rgba(37,99,235,.35); font-size:32px;
}
.login-title{ font-size:28px; font-weight:800; text-align:center; margin:8px 0 4px; }
.login-subtitle{ text-align:center; color:var(--muted); margin:0 0 18px; }
.login-form{ display:grid; gap:14px; }
.input-icon{ position:relative; }
.input-icon > i{
  position:absolute; left:14px; top:50%; transform:translateY(-50%);
  pointer-events:none; z-index:1; font-size:18px; color:#9ca3af;
}
.input-icon input{
  width:100%; padding:12px 54px 12px 54px;
  border:1px solid #d1d5db; border-radius:10px; background:#fff; font-size:14px;
  transition:border .2s, box-shadow .2s;
}
.input-icon input:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(37,99,235,.2); }
.eye-btn{ position:absolute; right:10px; top:50%; transform:translateY(-50%); border:0; background:transparent; cursor:pointer; padding:6px; color:#64748b; }
.eye-btn:hover{ color:#334155; }
.login-submit{ width:100%; padding:12px 14px; font-size:16px; display:flex; align-items:center; justify-content:center; gap:8px; border-radius:10px; }
input::-ms-reveal, input::-ms-clear{ display:none; }
input[type="password"]::-webkit-credentials-auto-fill-button{ display:none; visibility:hidden; }

/* Botão “Salvar nova senha” (perfil) */
.btn-senha-wrapper{ display:flex; justify-content:center; width:100%; margin-top:10px; }
.btn-senha{ display:inline-flex; align-items:center; gap:8px; width:max-content; min-width:0; padding:11px 18px; text-align:center; }

/* ======================================================================
   ABAS / CONFIGURAÇÕES
   ====================================================================== */
.tabs{ display:flex; gap:8px; padding:10px; background:#f8fafc; border-bottom:1px solid var(--soft); }
.tab{ border:1px solid var(--soft); background:#fff; padding:10px 14px; border-radius:10px; cursor:pointer; font-weight:600; color:#334155; }
.tab.active{ background:#e8f0ff; border-color:#c7d2fe; color:#1d4ed8; }
.tabpane{ display:none; padding:12px; }
.tabpane.show{ display:block; }
.cfg-page-header{ display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.cfg-subtitle{ color:#6b7280; }
.cfg-card{ padding:0; overflow:hidden; }
.cfg-section-head{ display:flex; align-items:center; justify-content:space-between; margin:16px 8px 8px; }
.cfg-section-title{ font-weight:700; margin-bottom:4px; }
.cfg-section-sub{ color:#6b7280; }
.cfg-dotline{ display:inline-flex; align-items:center; gap:8px; }
.cfg-dot{ width:10px; height:10px; border-radius:999px; background:var(--dot); display:inline-block; }
.badge-code{ background:#f8fafc; border-color:#e5e7eb; }
.color-picker{ display:flex; align-items:center; gap:8px; }
.color-picker input[type="color"]{ width:40px; height:32px; padding:0; border:none; cursor:pointer; }
.color-picker .color-preview{ width:40px; height:32px; border-radius:6px; }

/* ======================================================================
   RELATÓRIOS
   ====================================================================== */
.filters-bar{
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap;
  gap:12px; padding:12px;
}
.filters-bar .inputs{ display:flex; align-items:flex-end; gap:12px; flex-wrap:wrap; }
.filters-bar label{ display:flex; flex-direction:column; gap:4px; font-size:.9rem; color:#475569; font-weight:500; min-width:200px; }
.filters-bar select, .filters-bar input[type="date"]{
  height:38px; padding:0 12px; border:1px solid #d0d7de; border-radius:8px; background:#f8fafc; color:#111827; font-size:.95rem; transition:all .2s ease; max-width:100%;
}
.filters-bar .exports{ display:flex; gap:8px; flex-wrap:wrap; }
.table-responsive{ width:100%; overflow-x:auto; -webkit-overflow-scrolling:touch; }
.report-chart{ width:100%; height:160px; max-width:100%; }

.reports-grid{ display:grid; gap:12px; padding:12px; }
.report-item{
  display:flex; gap:12px; align-items:center; text-decoration:none; background:#fff;
  border:1px solid #e5e7eb; border-radius:14px; padding:14px 16px;
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.report-item:hover{ transform:translateY(-1px); border-color:#d1d5db; box-shadow:0 6px 18px rgba(2,6,23,.06); }
.report-item.disabled{ opacity:.6; pointer-events:none; background:#f8fafc; }
.ri-icon{ width:42px; height:42px; display:flex; align-items:center; justify-content:center; border-radius:10px; background:#eef2ff; color:#1e40af; flex:0 0 42px; font-size:20px; }
.ri-content{ min-width:0; }
.ri-title{ font-weight:600; color:#0f172a; line-height:1.2; }
.ri-desc{ color:#64748b; font-size:.925rem; margin-top:2px; overflow:hidden; text-overflow:ellipsis; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; }
.ri-arrow{ margin-left:auto; color:#94a3b8; font-size:18px; }

/* ======================================================================
   CHAMADOS – EXTRAS
   ====================================================================== */
.hide{ display:none !important; }
.card-empty{ padding:16px; color:#6b7280; }
.ctr-small{ font-size:.85rem; color:#64748b; }
.nowrap{ white-space:nowrap; }
.col-actions{ width:60px; }

.ctr-progress{ --pct:0%; --tone:#22c55e; height:10px; background:#f1f5f9; border-radius:999px; overflow:hidden; position:relative; }
.ctr-progress__bar{ display:block; height:100%; width:var(--pct); background:var(--tone); transition:width .25s ease; }

/* Destaque temporário */
#tabelaChamados tbody tr.row-focus td{ background:#e7fbe7 !important; transition:background .6s ease; }
/* Timer rodando */
#tabelaChamados tbody tr.timer-active{ background:#fff7d6; transition:background .2s ease; }
#tabelaChamados tbody tr.timer-active .badge{ filter:saturate(1.05); }

/* Comentários */
.comentarios-section{ margin-top:30px; }
.comentario-form textarea{
  width:100%; min-height:80px; padding:10px; border-radius:8px; border:1px solid #ccc; resize:vertical; font-size:14px;
}
.comentario-form button{
  margin-top:8px; padding:6px 14px; border:none; background:#2563eb; color:#fff; border-radius:6px; cursor:pointer;
}
.comentario-item{ background:#f8f9fa; border-radius:8px; padding:10px; margin-top:10px; }
.comentario-header{ font-size:13px; color:#555; margin-bottom:4px; }
.comentario-header strong{ color:#111; }
.comentario-conteudo{ font-size:14px; color:#333; white-space:pre-line; }

/* ======================================================================
   RESPONSIVO
   ====================================================================== */
@media (max-width:1200px){
  .grid.cards{ grid-template-columns:repeat(3, minmax(220px,1fr)); }
}
@media (max-width:900px){
  .wrapper{ grid-template-columns:1fr; }
  .sidebar{ position:sticky; top:0; z-index:5; }
  .grid.cards{ grid-template-columns:repeat(2, minmax(180px,1fr)); }
  .modal__dialog{ margin:30px 14px; max-width:100%; }
  .filters-grid{ grid-template-columns:1fr; }
}
@media (max-width:600px){
  .grid.cards{ grid-template-columns:1fr; }
  .form2{ grid-template-columns:1fr; }
  .btn-senha{ width:max-content; }
}

/* Compacto notebook/altura baixa */
@media (max-width:1440px), (max-height:820px){
  html{ font-size:13.5px; }
  .wrapper{ grid-template-columns: var(--sidebar-w) 1fr; }
  .content{ padding:16px 18px; }
  .page-title{ font-size:21px; margin-bottom:6px; }
  .cfg-subtitle{ font-size:12.5px; }
  .card{ padding:12px; border-radius:14px; }
  .grid{ gap:10px; }
  .filters-grid{ gap:8px 10px; }
  .filters-grid .form-group label{ font-size:12.5px; margin-bottom:3px; }
  .filters-grid .form-group select,
  .filters-grid .form-group input[type="text"],
  .filters-grid .form-group input[type="date"]{ height:34px; padding:0 10px; font-size:12.5px; }
  .form2{ gap:12px; }
  .form-group label{ font-size:12.5px; }
  .form-group input, .form-group select, .form-group textarea{ padding:9px 11px; font-size:12.5px; }
  .btn{ padding:8px 11px; }
  .table{ border-spacing:0 6px; }
  .table th{ font-size:10.5px; padding:0 8px 6px; }
  .table td{ padding:8px 10px; }
  td.actions{ width:42px; }
  .btn.icon.kebab{ padding:4px; }
  .badge, .badge.status{ font-size:10.5px; padding:4px 8px; border-radius:10px; }
  .ch-id{ font-size:9.5px; margin-bottom:1px; }
  .ch-title{ font-size:13.5px; line-height:1.22; }
  .modal__title{ font-size:17px; }
  .modal__header, .modal__footer{ padding:12px 16px; }
  .modal__body{ padding:14px 16px; }
  @media (max-width:1200px){ .filters-grid{ grid-template-columns:repeat(2,1fr); } }
}
@media (max-width:1280px), (max-height:760px){
  html{ font-size:12.5px; }
  .content{ padding:14px 16px; }
  .page-title{ font-size:19px; }
  .filters-grid{ gap:6px 8px; }
  .filters-grid .form-group select,
  .filters-grid .form-group input[type="text"],
  .filters-grid .form-group input[type="date"]{ height:32px; padding:0 8px; font-size:12px; }
  .table th{ font-size:10px; padding-bottom:4px; }
  .table td{ padding:7px 9px; }
  .badge, .badge.status{ font-size:10px; padding:3px 7px; }
  .ch-title{ font-size:13px; }
}

/* ======================================================================
   UTIL
   ====================================================================== */
.no-anim *{ transition:none !important; }
/* ==== FIX borda do modal “quadrada” ao fundo ==== */
.modal__dialog{
  /* já está com border-radius e overflow:visible */
  background:#fff;           /* o branco fica só aqui */
  border-radius:14px;
}

.modal__header,
.modal__body,
.modal__footer{
  background:transparent;    /* filhos transparentes, não “vazam” nos cantos */
}

/* mantém as linhas do header/footer */
.modal__header{ border-bottom:1px solid #f1f5f9; }
.modal__footer{ border-top:1px solid #f1f5f9; }
/* ===== Botão do menu no topo da sidebar recolhida ===== */

/* Sidebar como referência */
.sidebar {
  position: relative;
}

/* brand oculta texto quando mini */
.sidebar-mini .sidebar .brand {
  font-size: 0;
  padding: 0;
  justify-content: center;
  align-items: center;
}

/* botão no topo, centralizado horizontalmente */
.sidebar-mini .sidebar-toggle {
  position: absolute;
  top: 14px;                 /* distância do topo */
  left: 50%;
  transform: translateX(-50%);
  margin: 0;
  z-index: 2;
}

/* estilo do ícone */
.sidebar-mini .sidebar-toggle i {
  font-size: 22px;
  color: var(--moss-100);
  transition: color .2s ease, transform .25s ease;
}
.sidebar-mini .sidebar-toggle:hover i {
  color: var(--white);
  transform: scale(1.1);
}
/* ===== Sidebar recolhida: reserva espaço pro hambúrguer ===== */

/* tamanho/posição do botão no topo */
.sidebar-mini .sidebar-toggle{
  position: absolute;
  top: 12px;                 /* ajusta a distância do topo */
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
}

/* cria um "safe area" no topo da lista do menu */
.sidebar-mini .sidebar .menu,
.sidebar-mini .sidebar nav ul{
  padding-top: 56px;         /* altura ≈ botão (40px) + respiro */
}

/* opcional: evita qualquer altura colapsada da brand */
.sidebar-mini .sidebar .brand{
  font-size: 0;              /* esconde texto */
  height: 40px;              /* reserva espaço da cápsula superior */
  margin-bottom: 8px;
}
/* regra geral: link de chamado sem sublinhado */
a.ch-link {
  text-decoration: none;
  color: inherit;
}

/* título do chamado (texto em negrito) */
a.ch-link .ch-title {
  text-decoration: none;
}

/* quando passar o mouse: só o título sublinha */
a.ch-link:hover .ch-title {
  text-decoration: underline;
}
/* ======================================================================
   CHAMADOS – TELA CHEIA COM SCROLL INTERNO NA TABELA
   ====================================================================== */

/* Container da aba de chamados:
   pega quase a altura da tela inteira abaixo do header */
.ch-page{
  display:flex;
  flex-direction:column;
  gap:12px;

  /* ocupa o espaço restante dentro de .content */
  flex:1;
  min-height:0;   /* IMPORTANTÍSSIMO pro flex não estourar a tela */
}


/* Card da tabela cresce para ocupar o resto do espaço */
.ch-table-card{
  flex:1;
  min-height:0;
  display:flex;
  flex-direction:column;
}

.ch-table-card .table-wrapper{
  flex:1;
  min-height:0;
  overflow-y:auto;
  overflow-x:auto;
  /* sem max-height aqui, quem manda é o flex */
}
/* ===========================
   FIX – Centralização da tela de login
   =========================== */

.wrapper.nosidebar .content{
  display: flex !important;
  flex-direction: column;
  justify-content: center !important;
  align-items: center !important;

  min-height: 100vh !important;
  padding: 32px 16px !important;

  background: radial-gradient(1200px 400px at 50% -100px, #e8efff, transparent) var(--bg);
}

.login-card{
  width: 100%;
  max-width: 420px;          /* menor para deixar mais elegante */
  background: #fff;
  border: 1px solid var(--soft);
  border-radius: 16px;
  padding: 32px 28px;
  box-shadow: 0 20px 50px rgba(0,0,0,.10);
}
/* ===================== CONFIG > E-MAIL (REGRAS POR ROLE) ===================== */
.email-role-grid{
  display:grid;
  grid-template-columns: 320px 1fr;
  gap:16px;
  align-items:start;
}
@media (max-width: 980px){
  .email-role-grid{ grid-template-columns: 1fr; }
}

.email-role-card{
  border:1px solid var(--soft);
  border-radius:16px;
  background: var(--card);
  padding:14px;
}

.email-role-card__title{
  font-weight:800;
  font-size:14px;
}
.email-role-card__sub{
  margin-top:4px;
  color: var(--muted);
  font-size:13px;
}

.email-role-picker{
  margin-top:12px;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.email-role-btn{
  width:100%;
  border:1px solid var(--soft);
  background:#fff;
  padding:12px 12px;
  border-radius:14px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  transition:.15s ease;
}
.email-role-btn:hover{ transform: translateY(-1px); }
.email-role-btn.active{
  border-color: var(--primary);
  box-shadow: 0 0 0 4px var(--primary-ring);
}
.email-role-pill{
  display:none;
  font-size:12px;
  padding:4px 8px;
  border-radius:999px;
  background: rgba(46,125,50,.12);
  color: var(--primary);
  font-weight:700;
}
.email-role-btn.active .email-role-pill{ display:inline-flex; }

.email-role-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  flex-wrap:wrap;
}
.email-role-head__actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.email-rule-box{
  margin-top:12px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:12px;
}
@media (max-width: 980px){
  .email-rule-box{ grid-template-columns: 1fr; }
}

.email-chk{
  display:flex;
  gap:10px;
  align-items:flex-start;
  border:1px solid var(--soft);
  border-radius:14px;
  padding:12px;
  cursor:pointer;
  background:#fff;
}
.email-chk input{ margin-top:4px; transform: scale(1.05); }

.email-role-footer{
  margin-top:12px;
  display:flex;
  justify-content:flex-end;
  align-items:center;
  gap:10px;
}

.email-msg{
  margin-top:12px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--soft);
}
.email-msg.ok{
  border-color: rgba(22,163,74,.35);
  background: rgba(22,163,74,.08);
}
.email-msg.err{
  border-color: rgba(239,68,68,.35);
  background: rgba(239,68,68,.08);
}
/* ===================== SMTP SENDER CARD ===================== */
.email-sender-card{
  border:1px solid var(--soft);
  border-radius:16px;
  padding:16px;
  background:#fff;
}

.email-sender-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:12px;
}

.email-sender-title{ font-weight:800; font-size:16px; }
.email-sender-sub{ color:var(--muted); margin-top:2px; }

.email-switch{
  display:flex;
  align-items:center;
  gap:10px;
  cursor:pointer;
  user-select:none;
  font-weight:700;
}

.email-sender-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:12px;
}

@media (max-width: 900px){
  .email-sender-grid{ grid-template-columns: 1fr; }
}

.email-row{
  grid-column: 1 / -1;
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  align-items:center;
}

.chk-inline{
  display:flex;
  gap:10px;
  align-items:flex-start;
  cursor:pointer;
}

.email-sender-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  align-items:center;
  margin-top:12px;
  flex-wrap:wrap;
}
/* ===== FIX SCROLL (Configurações) ===== */

/* garante rolagem da página */
html, body{
  height: 100%;
  overflow-y: auto;
}

/* evita travar scroll por altura fixa */
.wrapper{
  min-height: 100vh;
  height: auto;
}

/* se o seu conteúdo principal usa alguma classe tipo .content / .main,
   deixe SEM overflow hidden */
.content, main, .main, .page, .page-content{
  height: auto;
  overflow: visible;
}

/* opcional: se você quiser que o card das configurações role por dentro */
.cfg-card{
  max-height: calc(100vh - 160px); /* ajuste fino se quiser */
  overflow: auto;
}
