
/* Dashboard calendar (tarefas ativas por vencimento) */
.dash-cal{ width:100%; }
.dash-cal-week{ display:grid; grid-template-columns:repeat(7,1fr); gap:8px; margin-bottom:8px; }
.dash-cal-wd{ font-size:11px; font-weight:700; color:#6b7280; text-align:center; }
.dash-cal-grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:8px; }
.dash-cal-day{ background:#fff; border:1px solid #e5e7eb; border-radius:12px; padding:8px; min-height:72px; position:relative; cursor:pointer; transition:transform .08s ease, box-shadow .08s ease; }
.dash-cal-day:hover{ transform:translateY(-1px); box-shadow:0 10px 25px rgba(0,0,0,.08); }
.dash-cal-day.is-out{ opacity:.45; cursor:default; }
.dash-cal-day.is-out:hover{ transform:none; box-shadow:none; }
.dash-cal-n{ font-size:12px; font-weight:800; color:#111827; }
.dash-cal-dots{ position:absolute; left:8px; bottom:8px; display:flex; gap:4px; }
.dash-dot{ width:8px; height:8px; border-radius:999px; display:inline-block; }
.dash-dot.green{ background:#10b981; }
.dash-dot.yellow{ background:#f59e0b; }
.dash-dot.red{ background:#ef4444; }
.dash-dot.gray{ background:#cbd5e1; }
.dash-cal-tasks{ margin-top:10px; background:#fff; border:1px solid #e5e7eb; border-radius:12px; padding:10px; max-height:220px; overflow:auto; }
.dash-cal-tasks h4{ margin:0 0 6px 0; font-size:13px; font-weight:800; color:#003151; }
.dash-cal-task{ padding:8px 10px; border-radius:10px; border:1px solid #eef2f7; margin-bottom:8px; }
.dash-cal-task:last-child{ margin-bottom:0; }
.dash-cal-task .t-title{ font-weight:800; font-size:12px; color:#111827; }
.dash-cal-task .t-meta{ font-size:11px; color:#6b7280; }
:root{
  --wrs-blue:#003151;
  --wrs-orange:#ff6b00;
  --wrs-bg:#f4f6f8;
  --wrs-text:#0f172a;
  --wrs-radius:18px;
  --wrs-radius-sm:12px;
  --wrs-shadow:0 10px 26px rgba(2,6,23,.07);
  --wrs-shadow-sm:0 6px 16px rgba(2,6,23,.08);
}

/* Piscar botão Atualizar (após 1h sem refresh ou quando houver atualização disponível) */
.wrs-blink{
  animation: wrsBlink 1s infinite;
}
@keyframes wrsBlink{
  0%,100%{ box-shadow: 0 0 0 rgba(255,107,0,.0); }
  50%{ box-shadow: 0 0 0 6px rgba(255,107,0,.35); }
}
*{box-sizing:border-box}
body{
  background:var(--wrs-bg);
  color:var(--wrs-text);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}

/* Layout */
.wrs-app{min-height:100vh;display:flex}
.wrs-sidebar{
  width:260px;
  background:var(--wrs-blue);
  color:#fff;
  position:fixed;
  left:0;top:0;bottom:0;
  overflow-y:auto;
  overflow-x:hidden;
  box-shadow:0 10px 30px rgba(0,0,0,.15);
  z-index:1030;
}
.wrs-sidebar .brand{
  padding:18px 18px 12px 18px;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.wrs-sidebar .brand .title{font-weight:800;letter-spacing:.3px;font-size:18px;line-height:1}
.wrs-sidebar .brand .subtitle{opacity:.85;font-size:12px;margin-top:6px}

.taskprime-brand{display:inline-flex;align-items:baseline;gap:.24em;line-height:1;white-space:nowrap;max-width:100%}
.taskprime-brand .task{display:inline-block;color:#ff6b00;font-weight:900;letter-spacing:.2px;line-height:1}
.taskprime-brand .prime{display:inline-block;font-size:.62em;font-style:italic;font-weight:700;letter-spacing:.04em;line-height:1;color:currentColor;opacity:.96;transform:translateY(-.02em)}
.taskprime-brand-light{color:#fff}
.taskprime-brand-dark{color:#003151}
.taskprime-brand-login{font-size:32px}
.taskprime-brand-sidebar{font-size:18px}
.taskprime-brand-super{font-size:28px}

.wrs-nav{padding:10px}
 .wrs-nav a i{font-size:1.1rem;width:22px;text-align:center}

.wrs-nav a{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;
  border-radius:12px;
  color:rgba(255,255,255,.92);
  text-decoration:none;
  font-weight:600;
}
.wrs-nav a:hover{background:var(--wrs-orange);color:#fff}
.wrs-nav a.active{background:rgba(255,255,255,.16);color:#fff}

/* Submenus (Fiscal / Contabilidade / DP / Configurações) */
.wrs-nav .nav-parent{
  width:100%;
  background:transparent;
  border:0;
  color:#fff;
  font-weight:700;
  padding:14px 18px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:flex-start;gap:10px;
  cursor:pointer;
}
.wrs-nav .nav-parent:hover{background:var(--wrs-orange);}
.wrs-nav .nav-parent .chev{margin-left:auto;opacity:.9}
.wrs-nav .nav-parent .caret{opacity:.9}
.wrs-nav .submenu a{
  display:block;
  padding:10px 18px 10px 34px;
  color:#fff;
  font-weight:600;
  border-radius:10px;
}
.wrs-nav .submenu a:hover{background:rgba(255,255,255,0.10)}

.wrs-main{
  margin-left:260px;
  width:calc(100% - 260px);
  min-height:100vh;
}

/* ── Sidebar toggle — fixed pill at top-right edge of sidebar ────────────── */
.wrs-sb-toggle {
  position: fixed;
  left: 248px; /* 260px sidebar - 12px overlap */
  top: 18px;
  transform: none;
  z-index: 1040;
  background: #FF6B00;
  border: 2px solid #fff;
  cursor: pointer;
  padding: 0 8px;
  width: auto;
  height: 32px;
  border-radius: 0 8px 8px 0;
  font-size: 15px;
  color: #fff;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background .18s, left .2s;
  box-shadow: 2px 2px 8px rgba(0,0,0,.25);
}
.wrs-sb-toggle:hover { background: #e05c00; }
.wrs-app.is-collapsed .wrs-sb-toggle { left: 72px; border-radius: 0 8px 8px 0; }

/* Brand row needs no special positioning anymore */
.wrs-sidebar .brand { position: relative; }
.wrs-sidebar .brand .brand-row { display:flex; align-items:center; justify-content:flex-start; gap:10px; }


.wrs-sidebar .brand .brand-row{display:flex;align-items:center;justify-content:flex-start;gap:10px;gap:10px}
.wrs-sidebar.is-collapsed{width:84px}
.wrs-sidebar.is-collapsed .brand{padding:18px 22px 12px 10px}
.wrs-sidebar.is-collapsed .brand .subtitle{display:none}
.wrs-sidebar.is-collapsed .brand .title{font-size:15px}
.wrs-sidebar.is-collapsed .taskprime-brand-sidebar{display:inline-flex;flex-direction:column;align-items:flex-start;gap:2px;white-space:normal}
.wrs-sidebar.is-collapsed .taskprime-brand-sidebar .task{font-size:1em}
.wrs-sidebar.is-collapsed .taskprime-brand-sidebar .prime{font-size:.72em;transform:none;margin-left:0}
.wrs-sidebar.is-collapsed .wrs-nav a,
.wrs-sidebar.is-collapsed .wrs-nav .nav-parent{justify-content:center}
.wrs-sidebar.is-collapsed .wrs-nav .nav-label{display:none}
.wrs-sidebar.is-collapsed  .wrs-nav a i{font-size:1.1rem;width:22px;text-align:center}

.wrs-nav a{gap:10px}
.wrs-sidebar.is-collapsed .wrs-nav .nav-parent{gap:0}
.wrs-nav .nav-parent{gap:10px}
.wrs-sidebar.is-collapsed .wrs-nav a i,
.wrs-sidebar.is-collapsed .wrs-nav .nav-parent i{font-size:1.15rem}
.wrs-sidebar.is-collapsed .wrs-nav .chev{display:none}
.wrs-sidebar.is-collapsed .nav-children{padding-left:0}
.wrs-sidebar.is-collapsed .nav-children a{justify-content:center}
.wrs-sidebar.is-collapsed .nav-children a i{margin-right:0}

.wrs-main{transition:margin-left .2s ease,width .2s ease}
.wrs-sidebar{transition:width .2s ease}
.wrs-app.is-collapsed .wrs-main{margin-left:84px;width:calc(100% - 84px)}
.wrs-topbar{
  position:sticky;top:0;z-index:1020;
  background:#fff;
  border-bottom:1px solid rgba(15,23,42,.08);
  padding:12px 18px;
}

/* Topbar layout (sem depender de utilitários do Bootstrap) */

/* Escritório logado no topo */
.topbar-office{margin-left:92px;line-height:1.1}
.topbar-office-name{font-weight:800;color:#003151;max-width:560px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-office-cnpj{font-size:.82rem;color:#6c757d;font-weight:700;margin-top:3px}
@media (max-width: 992px){.topbar-office{margin-left:56px}.topbar-office-name{max-width:280px}}
@media (max-width: 768px){.topbar-office{margin-left:44px}.topbar-office-name{max-width:220px;font-size:.95rem}}


.wrs-topbar{display:flex;align-items:center;justify-content:flex-start;gap:10px;gap:12px;}
.wrs-topbar .topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px;}
.notif-bell{position:relative;}
.notif-badge{
  position:absolute;top:-6px;right:-6px;
  min-width:18px;height:18px;padding:0 6px;
  border-radius:999px;
  display:flex;align-items:center;justify-content:center;
  background:#dc2626;color:#fff;
  font-size:12px;font-weight:800;line-height:1;
}
.wrs-topbar .user{
  display:flex;align-items:center;gap:10px;
}
.wrs-avatar{
  width:34px;height:34px;border-radius:999px;overflow:hidden;
  background:rgba(0,0,0,.08);
  display:flex;align-items:center;justify-content:center;
  color:var(--wrs-blue);font-weight:800;
}
.wrs-avatar img{width:100%;height:100%;object-fit:cover}

.wrs-content{padding:18px}

/* Cards (estilo moderno, clean) */
.card{border:0;border-radius:var(--wrs-radius);box-shadow:var(--wrs-shadow)}
.card-header{background:#fff;border-bottom:1px solid rgba(15,23,42,.08);border-top-left-radius:var(--wrs-radius);border-top-right-radius:var(--wrs-radius)}

/* Buttons (inspirado em sistemas SaaS tipo Nibo, mantendo cores WRS) */
.btn{
  border-radius:var(--wrs-radius-sm);
  font-weight:800;
  padding:.58rem .9rem;
  transition:transform .08s ease, box-shadow .18s ease, background-color .18s ease, border-color .18s ease, color .18s ease;
}
.btn:active{transform:translateY(1px)}
.btn:focus{box-shadow:0 0 0 .2rem rgba(0,49,81,.18)}

.btn-wrs{
  background:linear-gradient(180deg, rgba(0,49,81,1) 0%, rgba(0,38,64,1) 100%);
  border-color:rgba(0,49,81,.95);
  color:#fff;
  box-shadow:var(--wrs-shadow-sm);
}
.btn-wrs:hover{background:var(--wrs-orange);border-color:var(--wrs-orange);color:#fff;box-shadow:0 10px 22px rgba(255,107,0,.25)}
.btn-outline-wrs{
  border:1px solid var(--wrs-blue);
  color:var(--wrs-blue);
  background:#fff;
}
.btn-outline-wrs:hover{background:var(--wrs-orange);border-color:var(--wrs-orange);color:#fff}

/* Botões de ícone (mesmo padrão do Tarefas) */
.btn-wrs-icon{
  width:38px;height:38px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:12px;
  border:2px solid var(--wrs-orange);
  background:#fff;
  color:var(--wrs-blue);
  box-shadow:var(--wrs-shadow-sm);
  transition:transform .08s ease, box-shadow .18s ease, background-color .18s ease, border-color .18s ease, color .18s ease;
}
.btn-wrs-icon:hover{background:var(--wrs-blue);border-color:var(--wrs-blue);color:var(--wrs-orange);transform:translateY(-1px);box-shadow:0 10px 18px rgba(0,0,0,.10)}
.btn-wrs-icon:active{transform:translateY(0)}
.btn-wrs-icon.disabled, .btn-wrs-icon[disabled]{opacity:.45;pointer-events:none;box-shadow:none;transform:none}
.btn-wrs-icon i{font-size:18px;line-height:1}

/* Finance tabs (Receita / Despesa / Dash) */
.finance-tabs{gap:14px}
.finance-tabs .btn{border-radius:14px}

/* Floating plus */

/* Tables */
.table{color:var(--wrs-text)}
.table thead th{border-bottom:1px solid rgba(15,23,42,.12);color:var(--wrs-blue);font-weight:800}
.table td, .table th{vertical-align:middle}
.table tbody tr:hover{background:rgba(255,107,0,.06)}

/* Badges */
.badge{border-radius:999px;font-weight:800}

/* Forms */
.form-control, .form-select{
  border-radius:var(--wrs-radius-sm);
  border:1px solid rgba(15,23,42,.14);
}
.form-control:focus, .form-select:focus{
  border-color:rgba(0,49,81,.55);
  box-shadow:0 0 0 .2rem rgba(255,107,0,.14);
}
label.form-label{font-weight:700;color:var(--wrs-blue)}

.badge-wrs{background:rgba(0,49,81,.12);color:var(--wrs-blue);font-weight:800;border-radius:999px}

/* Dossier cards */
.client-card{cursor:pointer;transition:transform .12s ease, box-shadow .12s ease}
.client-card:hover{transform:translateY(-2px);box-shadow:0 16px 35px rgba(2,6,23,.10)}

/* Responsive */
@media (max-width: 992px){
  .wrs-sidebar{width:260px;transform:translateX(-100%);transition:transform .2s ease}
  .wrs-sidebar.show{transform:translateX(0)}
  .wrs-sidebar.is-collapsed{width:260px}
  .wrs-sidebar.is-collapsed .brand{padding:18px 18px 12px 18px}
  .wrs-sidebar.is-collapsed .brand .title{font-size:18px}
  .wrs-sidebar.is-collapsed .brand .subtitle{display:block}
  .wrs-sidebar.is-collapsed .taskprime-brand-sidebar{display:inline-flex;flex-direction:row;align-items:baseline;gap:.24em;white-space:nowrap}
  .wrs-sidebar.is-collapsed .taskprime-brand-sidebar .prime{font-size:.62em;transform:translateY(-.02em)}
  .wrs-sidebar.is-collapsed .wrs-nav a,
  .wrs-sidebar.is-collapsed .wrs-nav .nav-parent,
  .wrs-sidebar.is-collapsed .nav-children a{justify-content:flex-start}
  .wrs-sidebar.is-collapsed .wrs-nav .nav-label{display:inline}
  .wrs-sidebar.is-collapsed .wrs-nav .chev{display:inline-block}
  .wrs-sidebar.is-collapsed .nav-children{padding-left:0}
  .wrs-sidebar.is-collapsed .nav-children a i{margin-right:0}
  .wrs-main{margin-left:0;width:100%}
  .wrs-app.is-collapsed .wrs-main{margin-left:0;width:100%}
}


/* ===== Documentos (Contabilidade) - visual tipo "pasta" ===== */
.wrs-docbar{
  display:flex;
  gap:16px;
  align-items:flex-start;
  justify-content:flex-start;gap:10px;
}
.wrs-doc-title{
  font-weight:900;
  color:var(--wrs-blue);
  font-size:1.05rem;
}
.wrs-doc-sub{
  color:#6b7785;
  font-size:.9rem;
  margin-top:2px;
}
.wrs-docfilters{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:flex-end;
  justify-content:flex-start;gap:10px;
  padding:12px;
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  border-radius:14px;
}
.wrs-docfilter{min-width:220px; flex:1 1 220px;}
.wrs-doccrumb{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:12px;
  background:rgba(0,49,81,.04);
  border:1px solid rgba(0,49,81,.10);
  flex:0 0 auto;
}
.wrs-folder{display:flex;align-items:center;gap:8px;font-weight:800;color:var(--wrs-blue);}
.wrs-folder-icon{font-size:1.05rem;}
.wrs-folder-sep{color:#9aa6b2;font-weight:900;}

.wrs-doccard{
  background:#fff;
  border:1px solid rgba(0,0,0,.06);
  border-radius:16px;
  padding:16px;
  box-shadow:0 10px 30px rgba(0,0,0,.04);
  height:100%;
}
.wrs-doccard-head{
  display:flex;
  gap:12px;
  align-items:flex-start;
}
.wrs-docbadge{
  padding:8px 10px;
  border-radius:12px;
  font-weight:900;
  font-size:.85rem;
  white-space:nowrap;
}
.wrs-docbadge-blue{background:rgba(0,49,81,.10); color:var(--wrs-blue); border:2px solid var(--wrs-orange);}
.wrs-docbadge-orange{background:rgba(255,107,0,.12); color:var(--wrs-blue); border:1px solid rgba(255,107,0,.22);}
.wrs-docmeta{flex:1;}
.wrs-docname{font-weight:900; color:var(--wrs-blue); line-height:1.2;}
.wrs-docsmall{font-size:.86rem; color:#6b7785; margin-top:4px;}
.wrs-doccard-actions{
  margin-top:12px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

/* file input premium */
.wrs-file{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.08);
  background:#fff;
}
.wrs-file-input{display:none;}
.wrs-file-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  border-radius:10px;
  border:1px solid rgba(0,0,0,.12);
  background:rgba(0,49,81,.06);
  color:var(--wrs-blue);
  font-weight:900;
  cursor:pointer;
  user-select:none;
}
.wrs-file-btn:hover{background:var(--wrs-orange); color:#fff; border-color:var(--wrs-orange);}
.wrs-file-name{
  font-size:.9rem;
  color:#6b7785;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  flex:1;
}

/* melhora tabs (Controle / Documentos) */
.nav-pills .nav-link.active{
  background:var(--wrs-blue) !important;
}
.nav-pills .nav-link{
  border-radius:999px !important;
  font-weight:900;
}

/* =====================================================
   PADRONIZAÇÃO VISUAL (Bootstrap overrides)
   Objetivo: botões e campos sempre no padrão WRS
   Regra de hover:
     - Primário azul -> hover laranja
     - Laranja -> hover azul
   ===================================================== */

/* Botões (base) */
.btn{
  border-radius:12px !important;
  font-weight:800 !important;
}
.btn:focus{ box-shadow:0 0 0 .2rem rgba(0,49,81,.12) !important; }

/* Primário */
.btn-primary{
  background:var(--wrs-blue) !important;
  border-color:var(--wrs-blue) !important;
  color:#fff !important;
}
.btn-primary:hover,
.btn-primary:active,
.btn-primary:focus{
  background:var(--wrs-orange) !important;
  border-color:var(--wrs-orange) !important;
  color:#fff !important;
}

/* Outline primário */
.btn-outline-primary{
  border-color:var(--wrs-blue) !important;
  color:var(--wrs-blue) !important;
  background:transparent !important;
}
.btn-outline-primary:hover,
.btn-outline-primary:active,
.btn-outline-primary:focus{
  background:var(--wrs-orange) !important;
  border-color:var(--wrs-orange) !important;
  color:#fff !important;
}

/* Laranja (warning) segue regra inversa */
.btn-warning{
  background:var(--wrs-orange) !important;
  border-color:var(--wrs-orange) !important;
  color:#fff !important;
}
.btn-warning:hover,
.btn-warning:active,
.btn-warning:focus{
  background:var(--wrs-blue) !important;
  border-color:var(--wrs-blue) !important;
  color:#fff !important;
}

/* Neutros */
.btn-secondary{
  background:rgba(15,23,42,.12) !important;
  border-color:rgba(15,23,42,.10) !important;
  color:var(--wrs-blue) !important;
}
.btn-secondary:hover{
  background:rgba(15,23,42,.18) !important;
  border-color:rgba(15,23,42,.14) !important;
  color:var(--wrs-blue) !important;
}

/* Botões pequenos mantêm o mesmo padrão */
.btn-sm{ border-radius:10px !important; font-weight:800 !important; }

/* Inputs / selects: garantir altura e alinhamento */
.form-control, .form-select{
  min-height:44px;
  padding:.55rem .85rem;
}
.input-group .form-control, .input-group .form-select{ min-height:44px; }
.input-group-text{
  border-radius:12px;
  border:1px solid rgba(15,23,42,.14);
  background:rgba(0,49,81,.04);
  color:var(--wrs-blue);
  font-weight:900;
}

/* Links/ícones clicáveis (ex.: olhinho) no padrão WRS */
.link-wrs{ color:var(--wrs-blue); font-weight:900; text-decoration:none; }
.link-wrs:hover{ color:#fff; background:var(--wrs-orange); padding:2px 6px; border-radius:8px; }



/* ====== WRS UI kit ====== */
.wrs-card, .card{
  border:1px solid rgba(15,23,42,.08);
  border-radius:16px;
  box-shadow:0 10px 24px rgba(2,6,23,.06);
}
.card .card-header{
  background:linear-gradient(180deg, rgba(0,49,81,.06), rgba(255,255,255,0));
  border-bottom:1px solid rgba(15,23,42,.08);
  border-top-left-radius:16px;
  border-top-right-radius:16px;
}
.table thead th{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.06em;
  color:rgba(15,23,42,.65);
}
.table td{vertical-align:middle}
.table-hover tbody tr:hover{background:rgba(255,107,0,.06)}

/* Inputs */
.form-control, .form-select{
  border-radius:14px !important;
  border-color:rgba(15,23,42,.16) !important;
}
.form-control:focus, .form-select:focus{
  box-shadow:0 0 0 .2rem rgba(255,107,0,.18) !important;
  border-color:rgba(255,107,0,.85) !important;
}

/* Buttons */
.btn{
  border-radius:14px !important;
  font-weight:800;
  letter-spacing:.2px;
}
.btn-wrs{
  background:var(--wrs-blue) !important;
  color:#fff !important;
  border:1px solid rgba(0,49,81,.9) !important;
}
.btn-wrs:hover{
  background:var(--wrs-orange) !important;
  border-color:var(--wrs-orange) !important;
  color:#fff !important;
}
.btn-outline-primary{
  border-color:var(--wrs-blue) !important;
  color:var(--wrs-blue) !important;
}
.btn-outline-primary:hover{
  background:var(--wrs-orange) !important;
  border-color:var(--wrs-orange) !important;
  color:#fff !important;
}
.btn-outline-secondary{
  border-color:rgba(15,23,42,.18) !important;
  color:rgba(15,23,42,.82) !important;
}
.btn-outline-secondary:hover{
  background:var(--wrs-orange) !important;
  border-color:var(--wrs-orange) !important;
  color:#fff !important;
}

/* Badges */
.badge{border-radius:999px;padding:.45rem .6rem}

/* Sidebar refinements */
 .wrs-nav a i{font-size:1.1rem;width:22px;text-align:center}

.wrs-nav a{transition:all .18s ease}
.wrs-nav a.active{
  background:rgba(255,255,255,.14);
  outline:1px solid rgba(255,255,255,.18);
}

/* Page spacing */
.container-fluid{padding-left:18px;padding-right:18px}


/* Nibo-like refinements (keep WRS colors) */
.btn{
  border-radius:12px!important;
  padding:.55rem .9rem;
  font-weight:600;
  letter-spacing:.2px;
  box-shadow:0 6px 14px rgba(2,6,23,.08);
  transition:transform .08s ease, box-shadow .18s ease, background-color .18s ease, border-color .18s ease;
}
.btn:active{transform:translateY(1px)}
.btn:hover{box-shadow:0 10px 22px rgba(2,6,23,.12)}
.btn-primary{
  background:var(--wrs-blue)!important;
  border-color:var(--wrs-blue)!important;
}
.btn-primary:hover{background:var(--wrs-orange)!important;border-color:var(--wrs-orange)!important}
.btn-outline-primary{
  color:var(--wrs-blue)!important;
  border-color:rgba(0,49,81,.35)!important;
  background:#fff!important;
}
.btn-outline-primary:hover{background:var(--wrs-blue)!important;border-color:var(--wrs-blue)!important;color:#fff!important}
.btn-outline-secondary{
  border-color:rgba(15,23,42,.12)!important;
  color:rgba(15,23,42,.85)!important;
  background:#fff!important;
}
.btn-outline-secondary:hover{background:rgba(0,49,81,.08)!important;border-color:rgba(0,49,81,.18)!important}

.form-control,.form-select{
  border-radius:12px!important;
  border:1px solid rgba(15,23,42,.12)!important;
  padding:.55rem .75rem!important;
  background:#fff!important;
}
.form-control:focus,.form-select:focus{
  border-color:rgba(255,107,0,.55)!important;
  box-shadow:0 0 0 .22rem rgba(255,107,0,.18)!important;
}
.input-group-text{
  border-radius:12px!important;
  border:1px solid rgba(15,23,42,.12)!important;
  background:rgba(0,49,81,.04)!important;
}

.card{
  border:1px solid rgba(15,23,42,.08)!important;
  border-radius:18px!important;
  box-shadow:0 10px 26px rgba(2,6,23,.06);
  overflow:hidden;
}
.card-header{
  background:linear-gradient(180deg, rgba(0,49,81,.06), rgba(0,49,81,.02))!important;
  border-bottom:1px solid rgba(15,23,42,.08)!important;
}
.table{
  border-color:rgba(15,23,42,.08)!important;
}
.table thead th{
  background:rgba(0,49,81,.06)!important;
  color:rgba(15,23,42,.9)!important;
  font-weight:700;
  border-bottom:1px solid rgba(15,23,42,.10)!important;
}
.table tbody tr:hover{
  background:rgba(255,107,0,.06)!important;
}
.badge{
  border-radius:999px!important;
  padding:.45em .7em!important;
  font-weight:700!important;
}

.modal-content{
  border-radius:18px!important;
  border:1px solid rgba(15,23,42,.10)!important;
  box-shadow:0 22px 60px rgba(2,6,23,.25);
}
.nav-pills .nav-link{
  border-radius:999px!important;
  font-weight:700;
  padding:.5rem .9rem;
}
.nav-pills .nav-link.active{
  background:var(--wrs-blue)!important;
}
.nav-pills .nav-link:hover{
  background:rgba(255,107,0,.10);
}

.alert{
  border-radius:16px!important;
  border:1px solid rgba(15,23,42,.08)!important;
}



/* === WRS Charts (Finance Dash) === */
.wrs-pie{border-radius:16px; filter: drop-shadow(0 10px 22px rgba(0,0,0,.12)); transition: transform .18s ease, filter .18s ease;}
.wrs-pie:hover{transform: translateY(-2px) scale(1.02); filter: drop-shadow(0 16px 34px rgba(0,0,0,.16));}
.wrs-pie path{transition: opacity .18s ease, transform .18s ease;}
.wrs-pie:hover path{opacity:.98;}
.wrs-progress{
  height: 12px;
  background: rgba(0,49,81,.10);
  border-radius: 999px;
  overflow:hidden;
  box-shadow: inset 0 1px 2px rgba(0,0,0,.10);
}
.wrs-progress > span{
  display:block;
  height:100%;
  width:0;
  border-radius:999px;
  background: linear-gradient(90deg, rgba(0,49,81,1), rgba(255,107,0,1));
  transition: width .45s cubic-bezier(.2,.8,.2,1);
}


/* Sticky headers (tabelas) */
.table thead th{
  position: sticky;
  top: 0;
  z-index: 5;
  background: #f7f8fa;
}
.table thead th:first-child{left:0;}


/* Tabelas com rolagem e cabeçalho fixo (sem alterar layout geral) */
.table-responsive{max-height:70vh; overflow:auto;}
.table-responsive thead th{position:sticky; top:0; z-index:2; background:#f4f4f4;}


/* Dashboard: 5 cards na mesma linha */
@media (min-width: 992px){
  .dash-col-5{flex:0 0 20%;max-width:20%;}
}

/* Dashboard: divisória entre gráficos (Abertas x Concluídas) */
.dashboard-task-charts{display:flex;gap:40px;align-items:stretch;}
.dashboard-task-charts .chart-box{flex:1;padding:10px 20px;}
.dashboard-task-charts .chart-divider{
  width:2px;
  background:linear-gradient(to bottom, transparent, #cfcfcf, transparent);
  box-shadow:0 0 12px rgba(0,0,0,.15);
  border-radius:999px;
}
@media (max-width: 991.98px){
  .dashboard-task-charts{flex-direction:column;gap:24px;}
  .dashboard-task-charts .chart-divider{display:none;}
  .dashboard-task-charts .chart-box{padding:0;}
}

/* Menu lateral (evitar sobreposição de cliques) */
.nav-parent{width:100%;text-align:left;background:transparent;border:0;padding:10px 12px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:flex-start;gap:10px;}
.nav-children{padding-left:0;margin:0;}
.nav-children a{display:block;padding:8px 12px 8px 28px;color:#cfe1ee;text-decoration:none;}
.nav-children a:hover{background:#FF6B00;color:#fff;}



/* Dashboard - tarefas estilo "loading/progress" */
.task-progress-list{display:flex;flex-direction:column;gap:8px}
.task-user-row{
  display:flex;align-items:center;justify-content:flex-start;gap:10px;
  gap:16px;padding:10px 0;border-bottom:1px solid rgba(0,0,0,.06);
}
.task-user-row:last-child{border-bottom:0}
.task-user-left{display:flex;align-items:center;gap:10px;min-width:220px}
.user-mini{width:24px;height:24px;border-radius:50%;object-fit:cover}
.user-initials{
  width:24px;height:24px;border-radius:50%;
  background:#003151;color:#fff;font-size:11px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
}
.task-user-bar{flex:1;min-width:260px}
.task-progress{height:12px;border-radius:999px;overflow:hidden;background:#eef1f4}
.task-progress .progress-bar{transition:width .2s ease}
.task-open{background:#198754}
.task-done{background:#ff6b00}
.task-user-meta{display:flex;gap:8px;justify-content:flex-end;margin-top:6px}
.badge-open{background:rgba(25,135,84,.12);color:#0f5132;border:1px solid rgba(25,135,84,.18)}
.badge-done{background:rgba(255,107,0,.12);color:#7a3b00;border:1px solid rgba(255,107,0,.18)}

/* Dashboard charts */
.chart-canvas-wrap{height:260px}
.totals-box{border:1px solid rgba(0,0,0,.06);border-radius:14px;padding:14px;background:#fff}
.pct-badge{background:#003151;color:#fff;border-radius:999px;padding:6px 10px;font-weight:800}

/* Dashboard - Regime legend fixa */
.regime-legend{margin-top:12px; display:flex; flex-direction:column; gap:8px;}
.regime-legend-row{display:flex; justify-content:flex-start;gap:10px; align-items:center; padding:8px 10px; border:1px solid #e9ecef; border-radius:12px; background:#f8fafc;}
.regime-legend-name{font-weight:800; color:#003151; display:flex; align-items:center; gap:10px;}
.regime-legend-swatch{width:12px; height:12px; border-radius:6px; display:inline-block; box-shadow:0 2px 8px rgba(0,0,0,.12); flex:0 0 auto;}
.regime-legend-val{font-weight:700; color:#334155;}
@media (max-width: 575.98px){
  .regime-legend-row{flex-direction:column; align-items:flex-start; gap:2px;}
}


/* Export PNG (Dashboard) */
.export-mode { padding: 12px; border-radius: 16px; }
.export-mode .no-export { display:none !important; }
.export-mode .card { box-shadow: none !important; }
.export-mode .card-header { border-bottom: 1px solid #e9ecef; }
.export-mode .chart-canvas-wrap { height: auto; }

.export-mode.export-stack .row.g-3.align-items-center{
  flex-direction: column;
}
.export-mode.export-stack .col-md-7,
.export-mode.export-stack .col-md-5{
  width: 100%;
  max-width: 100%;
}
.export-mode.export-stack .totals-box{ margin-top: 10px; }


/* --- Dashboard exports / tooltips --- */
.chart-canvas-wrap-sm{height:170px;}
.wrs-toast{
  position:fixed;
  right:18px;
  bottom:18px;
  padding:12px 14px;
  border-radius:12px;
  background:#003151;
  color:#fff;
  font-weight:700;
  box-shadow:0 10px 24px rgba(0,0,0,.18);
  opacity:0;
  transform:translateY(8px);
  transition:opacity .18s ease, transform .18s ease;
  z-index:99999;
}
.wrs-toast.show{opacity:1; transform:translateY(0);}
.wrs-toast-success{background:#2E5E4E;}
.wrs-toast-danger{background:#dc3545;}


/* Dashboard charts */
.chart-fiscal-wrap{height:340px}
.chart-dpH-wrap{height:240px}
.chart-legend{display:flex; gap:16px; flex-wrap:wrap; align-items:center}
.chart-legend .legend-item{display:flex; align-items:center; gap:8px; font-size:13px; color:rgba(0,0,0,.70)}
.chart-legend .legend-swatch{width:12px; height:12px; border-radius:3px; display:inline-block}



/* --- Dashboard premium charts (WRS) --- */
.chart-canvas-wrap{height:360px}
.chart-fiscal-wrap{height:420px}
.chart-dpH-wrap{height:300px}
#cardRegime .chart-canvas-wrap{height:380px}

.chart-canvas-wrap canvas{
  width:100% !important;
  height:100% !important;
  display:block;
}

.card#cardFiscal, .card#cardDP, .card#cardRegime{
  box-shadow:0 12px 28px rgba(0,49,81,.10);
}

.chart-legend{
  justify-content:flex-start;
}
.chart-legend .legend-item{
  background:#f8fafc;
  border:1px solid rgba(0,0,0,.06);
  padding:8px 10px;
  border-radius:12px;
  gap:10px;
}
.chart-legend .legend-swatch{
  width:14px;
  height:14px;
  border-radius:6px;
}
.chart-legend .legend-val{
  margin-left:auto;
  font-weight:800;
  color:#003151;
}

/* Dashboard: avatares empilhados (departamentos / usuários) */
.avatar-stack{display:flex; align-items:center; flex-wrap:nowrap;}
.avatar-xs{width:28px; height:28px; border-radius:999px; object-fit:cover; border:2px solid #fff; background:#eef3f8; box-shadow:0 2px 6px rgba(0,0,0,.08); margin-left:-10px;}
.avatar-stack .avatar-xs:first-child{margin-left:0;}

/* Dashboard (Chart.js) */
.chart-wrap{position:relative;width:100%;height:320px}
.chart-wrap.tall{height:360px}
.chart-wrap canvas{width:100%!important;height:100%!important}

/* Dashboard - espaçamento e cards de gráficos */
.card-hero{margin-top:14px}
.card-hero .card-head{display:flex;align-items:flex-start;justify-content:flex-start;gap:10px;gap:12px;padding:14px 16px;border-bottom:1px solid #eef2f7;background:#fff;border-top-left-radius:14px;border-top-right-radius:14px}
.card-hero .card-head h3{margin:0;font-size:1.05rem;font-weight:800;color:#003151}
.card-hero .card-head .muted{margin-top:2px}
.card-hero .card-body{padding:16px}
.dash-legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.dash-legend .leg-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid rgba(0,0,0,.06);border-radius:999px;background:#f8fafc}
.dash-legend .leg-swatch{width:12px;height:12px;border-radius:999px}
.dash-legend .leg-avatar{width:22px;height:22px;border-radius:999px;object-fit:cover;border:2px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.10);background:#eef3f8}


/* Ajuste global: evitar espaço em branco excessivo entre abas e conteúdo */
.nav-tabs{ margin-bottom: 10px; }
.tab-content{ padding-top: 0; margin-top: 0; }
.tab-pane{ padding-top: 0; margin-top: 0; }

/* =========================================================
   Ajustes de espaçamento - Abas E-mail e WhatsApp
   ========================================================= */

/* 1. Reduz o espaçamento interno (padding) dos cards */
#tab-email .card-body,
#tab-whatsapp .card-body {
    padding: 16px !important; /* Se ainda achar grande, pode testar com 12px */
}

/* 2. Reduz o espaço entre os campos do formulário */
#tab-email .mb-3,
#tab-email .mb-4,
#tab-whatsapp .mb-3,
#tab-whatsapp .mb-4 {
    margin-bottom: 12px !important; 
}

/* 3. Reduz o espaço em cima dos títulos como "Gerador rápido" */
#tab-email .mt-4,
#tab-whatsapp .mt-4 {
    margin-top: 16px !important; 
}

/* 4. Aproxima os botõezinhos (placeholders) que ficam soltos */
#tab-email .gap-2,
#tab-whatsapp .gap-2 {
    gap: 6px !important;
}
/* Fiscal / FOPAG action column — compact single row */
.fiscal-actions-row {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-wrap: nowrap;
  min-width: 0;
}
.fiscal-actions-row .form-check {
  margin-bottom: 0;
  white-space: nowrap;
}
.fiscal-actions-row .form-check-label {
  font-size: .78rem;
}
.fiscal-actions-row .btn { padding: 3px 7px; font-size: .78rem; }
.fiscal-actions-row .js-obs {
  min-width: 80px;
  max-width: 130px;
  font-size: .78rem;
  padding: 3px 6px;
  height: auto;
}


/* === WRS PRO UI v1 === */

/* Títulos e barras de ação (padrão) */
.wrs-page-head{display:flex;gap:12px;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap}
.wrs-page-title{margin:0;font-weight:900;color:var(--wrs-blue);letter-spacing:.2px}
.wrs-page-sub{color:#6b7785;font-size:.92rem}
.wrs-toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

/* Botões com ícone + texto (altura consistente) */
.btn{min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.btn i{line-height:1}

/* Campos: placeholder, readonly e disabled mais “premium” */
.form-control::placeholder{color:#94a3b8}
.form-control[readonly], .form-select[disabled], .form-control[disabled]{background:#f8fafc;opacity:1}

/* Modais */
.modal-content{border:0;border-radius:18px;box-shadow:0 22px 60px rgba(2,6,23,.18)}
.modal-header{border-bottom:1px solid rgba(15,23,42,.08)}
.modal-footer{border-top:1px solid rgba(15,23,42,.08)}

/* Tabelas: linhas mais suaves */
.table{border-color:rgba(15,23,42,.08)}
.table thead th{background:linear-gradient(180deg, rgba(0,49,81,.05), rgba(255,255,255,0));}
.table-striped>tbody>tr:nth-of-type(odd)>*{--bs-table-bg-type:rgba(0,49,81,.02)}

/* Chips / pílulas */
.wrs-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-weight:900;font-size:12px;border:1px solid rgba(15,23,42,.10);background:#fff;color:var(--wrs-blue)}
.wrs-chip.orange{background:rgba(255,107,0,.10);border-color:rgba(255,107,0,.25)}
.wrs-chip.blue{background:rgba(0,49,81,.08);border-color:rgba(0,49,81,.18)}

/* Estados de foco “bonitos” também para checkbox/radio */
.form-check-input:focus{box-shadow:0 0 0 .2rem rgba(255,107,0,.18)}
.form-check-input:checked{background-color:var(--wrs-blue);border-color:var(--wrs-blue)}
.form-check-input:checked:focus{box-shadow:0 0 0 .2rem rgba(0,49,81,.18)}


/* Ajuste visual dos ícones dos submenus */
.nav-children a,
.wrs-nav .nav-children a{
  display:flex;
  align-items:center;
  gap:10px;
}
.nav-children a i,
.wrs-nav .nav-children a i{
  width:22px;
  min-width:22px;
  text-align:center;
  margin-right:0;
  flex:0 0 22px;
}
