:root{ --acento-100:#ccfbf1; --acento-500:#2dd4bf; --acento-600:#0d9488; --acento-700:#0f766e; --acento-900:#134e4a; --acento-050:#f0fdfa; }
/* ============================================================
   Dia Útil — base visual herdada do feriadosbrasil.
   Acento por site via --acento-* (o :root é prefixado pelo gerador).
   Cores semânticas (--feriado/--facultativo/--aberto) são SIGNIFICADO
   e permanecem iguais entre os sites do mesh.
   ============================================================ */
:root{
  --feriado:#e11d48;     --feriado-bg:#fff1f3;
  --facultativo:#d97706; --facultativo-bg:#fff7ed;
  --aberto:#059669;      --aberto-bg:#ecfdf5;
  --tinta:#1a2233; --tinta-2:#56607a; --linha:#e8ecf3; --papel:#fff; --fundo:#f6f8fc;
  --raio:16px; --raio-sm:10px;
  --sombra:0 1px 2px rgba(16,33,67,.04), 0 8px 24px rgba(16,33,67,.06);
  --sombra-hover:0 2px 6px rgba(16,33,67,.06), 0 16px 40px rgba(16,33,67,.10);
  --container:1180px;
  --fonte-display:"Plus Jakarta Sans", system-ui, sans-serif;
  --fonte-corpo:"Inter", system-ui, sans-serif;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0; background:var(--fundo); color:var(--tinta); font-family:var(--fonte-corpo); font-size:16px; line-height:1.6; -webkit-font-smoothing:antialiased;}
a{color:var(--acento-600); text-decoration:none;}
a:hover{text-decoration:underline;}
.container{max-width:var(--container); margin:0 auto; padding:0 20px;}
.container.narrow{max-width:820px;}
h1,h2,h3,h4{font-family:var(--fonte-display); color:var(--acento-900); line-height:1.15; letter-spacing:-.02em; margin:0;}
h1{font-size:clamp(1.9rem,4vw,2.6rem); font-weight:800;}
h2{font-size:clamp(1.3rem,2.4vw,1.7rem); font-weight:700; margin-bottom:14px;}
h3{font-size:1.05rem; font-weight:700; margin-bottom:10px;}
h4{font-size:.78rem; letter-spacing:.05em; text-transform:uppercase; color:var(--tinta-2); margin-bottom:8px;}
.lead{font-size:1.075rem; color:var(--tinta-2);}
.muted{color:var(--tinta-2); font-size:.92rem;}
.eyebrow{display:inline-flex; align-items:center; gap:8px; font-weight:600; font-size:.78rem; letter-spacing:.06em; text-transform:uppercase; color:var(--acento-600); background:var(--acento-100); padding:6px 12px; border-radius:999px;}

.btn{display:inline-flex; align-items:center; gap:8px; background:var(--acento-600); color:#fff; font-weight:600; font-size:.92rem; padding:10px 18px; border-radius:999px; border:0; cursor:pointer; transition:.2s;}
.btn:hover{background:var(--acento-700); text-decoration:none; transform:translateY(-1px);}
.btn-light{background:#fff; color:var(--acento-700); border:1px solid var(--acento-100);}
.btn-light:hover{background:var(--acento-050);}

/* ===== Header ===== */
.site-header{position:sticky; top:0; z-index:50; background:rgba(255,255,255,.85); backdrop-filter:saturate(180%) blur(12px); border-bottom:1px solid var(--linha);}
.hdr-inner{display:flex; align-items:center; gap:28px; height:66px;}
.brand{display:flex; align-items:center; gap:10px; font-family:var(--fonte-display); font-weight:700; font-size:1.15rem; color:var(--acento-900);}
.brand:hover{text-decoration:none;}
.brand-accent{color:var(--acento-600);}
.brand-mark{width:30px; height:30px; border-radius:9px; background:linear-gradient(135deg,var(--acento-600),var(--acento-500)); display:grid; place-items:center; color:#fff; font-family:var(--fonte-corpo); font-weight:700; font-size:.95rem;}
.site-nav{display:flex; gap:20px; margin-left:auto; flex-wrap:wrap;}
.site-nav a{color:var(--tinta-2); font-weight:500; font-size:.92rem;}
.site-nav a:hover,.site-nav a.active{color:var(--acento-700); text-decoration:none;}

/* ===== Layout conteúdo ===== */
.page-wrap{padding:26px 0 10px;}
.card{background:var(--papel); border:1px solid var(--linha); border-radius:var(--raio); box-shadow:var(--sombra); padding:24px; margin-bottom:22px;}
.block{margin-bottom:26px;}
section.block > h2{margin-bottom:14px;}
.prose p{margin:0 0 14px;} .prose p:last-child{margin-bottom:0;} .prose strong{color:var(--acento-900);}

/* ===== Prosa de artigo (evergreen md→HTML) ===== */
.prose.evergreen{background:var(--papel); border:1px solid var(--linha); border-radius:var(--raio); box-shadow:var(--sombra); padding:30px 32px;}
.prose.evergreen h1{font-size:clamp(1.9rem,4vw,2.5rem); margin:0 0 10px;}
.prose h2{margin:28px 0 12px;} .prose h3{margin:20px 0 8px;}
.prose ul,.prose ol{margin:0 0 14px; padding-left:22px;} .prose li{margin:4px 0;}
.prose a{color:var(--acento-600); text-decoration:underline; text-underline-offset:2px;}
.prose table{width:100%; border-collapse:collapse; font-size:.94rem; margin:8px 0 18px;}
.prose th,.prose td{text-align:left; padding:9px 12px; border-bottom:1px solid var(--linha);}
.prose thead th{font-size:.74rem; text-transform:uppercase; letter-spacing:.03em; color:var(--tinta-2); border-bottom:2px solid var(--linha);}
.prose blockquote{margin:0 0 14px; padding:10px 16px; border-left:3px solid var(--acento-100); color:var(--tinta-2); background:var(--acento-050); border-radius:0 var(--raio-sm) var(--raio-sm) 0;}
.disclaimer{margin-top:12px; font-size:.9rem;}

/* ===== Breadcrumb ===== */
.breadcrumb{display:flex; flex-wrap:wrap; align-items:center; gap:8px; font-size:.85rem; color:var(--tinta-2); padding:18px 0 4px;}
.breadcrumb .sep{color:var(--linha);}
.breadcrumb .current{color:var(--tinta);}

/* ===== Hero resposta (página-data) ===== */
.data-hero{padding:14px 0 8px;}
.data-hero h1{margin:8px 0 14px;}

/* === COMPONENTE NOVO: card de dois regimes (salário/comercial) === */
.regime-cards{display:grid; grid-template-columns:repeat(2,1fr); gap:14px; margin:6px 0 4px;}
.regime-cards.single{grid-template-columns:1fr; max-width:460px;}
.regime-card{border:1px solid var(--linha); border-radius:var(--raio); padding:18px 20px; background:var(--papel); box-shadow:var(--sombra);}
.regime-card.salario{background:linear-gradient(160deg,var(--acento-600),var(--acento-700)); border:0; color:#fff;}
.regime-card.salario .rc-label,.regime-card.salario .rc-dow{color:rgba(255,255,255,.82);}
.rc-label{font-size:.74rem; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--tinta-2);}
.rc-date{font-family:var(--fonte-display); font-weight:800; font-size:1.8rem; line-height:1.1; margin:6px 0 2px;}
.rc-dow{font-size:.9rem; color:var(--tinta-2);}
.rc-tag{display:inline-block; margin-top:8px; font-size:.72rem; font-weight:700; padding:3px 9px; border-radius:999px; background:rgba(255,255,255,.18); color:#fff;}
.regime-card:not(.salario) .rc-tag{background:var(--acento-050); color:var(--acento-700);}
.aviso{background:var(--facultativo-bg); border:1px solid #fde7c8; border-radius:var(--raio-sm); padding:12px 16px; color:#7c4a06; font-size:.94rem; margin:14px 0 0;}
.muni-note{background:var(--acento-050); border:1px solid var(--acento-100); border-radius:var(--raio-sm); padding:12px 16px; color:var(--tinta-2); font-size:.92rem; margin:14px 0 0;}
.muni-note strong{color:var(--acento-900);} .muni-note a{color:var(--acento-700); font-weight:600;}

/* === COMPONENTE NOVO: tabela de memória de cálculo === */
.memoria{width:100%; border-collapse:collapse; font-size:.94rem;}
.memoria th,.memoria td{text-align:left; padding:9px 12px;}
.memoria thead th{font-size:.72rem; letter-spacing:.04em; text-transform:uppercase; color:var(--tinta-2); border-bottom:2px solid var(--linha);}
.memoria tbody tr{border-bottom:1px solid var(--linha);}
.memoria tbody tr.nao-util{color:var(--tinta-2);}
.memoria tbody tr.quinto{background:var(--acento-050); font-weight:600;}
.memoria .ord{display:inline-block; min-width:22px; height:22px; line-height:22px; text-align:center; border-radius:6px; background:var(--acento-100); color:var(--acento-700); font-weight:700; font-size:.8rem;}
.memoria .marca-sab{color:var(--aberto); font-weight:600;}
.memoria .marca-nao{color:var(--tinta-2);}

/* === COMPONENTE NOVO: seletor de regime (calculadora — Marco 5) === */
.regime-toggle{display:inline-flex; flex-wrap:wrap; background:var(--fundo); border:1px solid var(--linha); border-radius:999px; padding:4px; gap:4px;}
.regime-toggle button{border:0; background:transparent; padding:7px 16px; border-radius:999px; font-weight:600; font-size:.9rem; color:var(--tinta-2); cursor:pointer;}
.regime-toggle button[aria-pressed="true"]{background:var(--acento-600); color:#fff;}

/* === Calculadoras (formulário + resultado) === */
.calc-form{display:flex; flex-direction:column; gap:18px;}
.calc-grid{display:grid; grid-template-columns:1fr 1fr; gap:14px;}
.calc-field{display:flex; flex-direction:column; gap:6px; font-weight:600; font-size:.9rem; color:var(--acento-900);}
.calc-field input,.calc-field select{font:inherit; font-weight:500; padding:10px 12px; border:1px solid var(--linha); border-radius:var(--raio-sm); background:#fff; color:var(--tinta);}
.calc-field input:focus,.calc-field select:focus{outline:2px solid var(--acento-500); outline-offset:1px; border-color:var(--acento-500);}
.calc-label{font-weight:600; font-size:.9rem; color:var(--acento-900); display:block; margin-bottom:6px;}
.calc-form .btn{align-self:flex-start;}
.calc-result{margin-top:20px; padding-top:18px; border-top:1px solid var(--linha);}
.calc-result[hidden]{display:none;}
.calc-answer{font-size:1.15rem; line-height:1.5; margin:0 0 8px;}
.calc-answer strong{color:var(--acento-700);}
.calc-result .regime-cards{margin:14px 0;}
.calc-result .memoria{margin-top:10px;}
@media (max-width:560px){ .calc-grid{grid-template-columns:1fr;} }

/* === Calendário do mês (diautil) === */
.answer-big{font-family:var(--fonte-display); font-weight:800; font-size:clamp(2.6rem,8vw,3.6rem); line-height:1; color:var(--acento-600);}
.answer-card{display:flex; align-items:baseline; gap:14px; flex-wrap:wrap; background:var(--papel); border:1px solid var(--linha); border-radius:var(--raio); box-shadow:var(--sombra); padding:18px 22px; margin:6px 0 4px;}
.answer-card .ac-unit{font-weight:700; color:var(--tinta-2);}
.answer-card .ac-clt{font-size:.92rem; color:var(--tinta-2);}
.cal-grid{display:grid; grid-template-columns:repeat(7,1fr); gap:6px; margin-top:8px;}
.cal-h{font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.03em; color:var(--tinta-2); text-align:center; padding:4px 0;}
.cal-cell{min-height:54px; border:1px solid var(--linha); border-radius:var(--raio-sm); padding:6px 8px; display:flex; flex-direction:column; gap:2px; background:var(--papel);}
.cal-cell.empty{border:0; background:transparent;}
.cal-cell.util{border-color:var(--acento-100); background:var(--acento-050);}
.cal-cell.fds{background:var(--fundo); color:var(--tinta-2);}
.cal-cell.feriado{background:var(--feriado-bg); border-color:#fbd0da;}
.cal-d{font-family:var(--fonte-display); font-weight:700; color:var(--acento-900);}
.cal-cell.fds .cal-d{color:var(--tinta-2);}
.cal-cell.feriado .cal-d{color:var(--feriado);}
.cal-tag{font-size:.66rem; font-weight:700; color:var(--feriado); text-transform:uppercase; letter-spacing:.02em;}
.cal-cell.util .cal-tag{color:var(--acento-700);}

/* ===== Navegação temporal ===== */
.temporal-nav{display:flex; justify-content:space-between; gap:12px; font-weight:600; font-size:.92rem;}

/* ===== Tabela genérica ===== */
table.dados{width:100%; border-collapse:collapse; font-size:.94rem;}
table.dados th,table.dados td{text-align:left; padding:10px 12px;}
table.dados thead th{font-size:.74rem; letter-spacing:.04em; text-transform:uppercase; color:var(--tinta-2); border-bottom:2px solid var(--linha);}
table.dados tbody tr{border-bottom:1px solid var(--linha);}
table.dados tbody tr:hover{background:var(--acento-050);}

/* ===== Ficha rápida (lista de dados) ===== */
.ficha{list-style:none; margin:0; padding:0;}
.ficha li{display:flex; justify-content:space-between; gap:14px; padding:10px 0; border-top:1px solid var(--linha);}
.ficha li:first-child{border-top:0;}
.ficha li span{color:var(--tinta-2);}

/* ===== FAQ ===== */
.faq details{border:1px solid var(--linha); border-radius:var(--raio-sm); margin-bottom:10px; overflow:hidden; background:#fff;}
.faq details[open]{box-shadow:var(--sombra);}
.faq summary{cursor:pointer; list-style:none; padding:15px 18px; font-weight:600; color:var(--acento-900);}
.faq summary::-webkit-details-marker{display:none;}
.faq .ans{padding:0 18px 16px; color:var(--tinta-2);}

/* ===== Footer ===== */
.site-footer{background:var(--acento-900); color:#cdd6e8; margin-top:50px; padding:38px 0 26px;}
.site-footer a{color:#e4ebf7;}
.foot-inner{display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:28px;}
.foot-brand{font-family:var(--fonte-display); font-weight:700; font-size:1.15rem; color:#fff; display:flex; align-items:center; gap:10px; flex-wrap:wrap;}
.foot-brand p{flex-basis:100%; margin:10px 0 0; font-family:var(--fonte-corpo); font-weight:400; font-size:.9rem; color:#a9b6d1; max-width:44ch;}
.foot-col{display:flex; flex-direction:column; gap:8px; font-size:.92rem;}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12); margin-top:26px; padding-top:16px; font-size:.84rem; color:#93a4c4;}

/* ===== Ad slots (reservados, invisíveis) ===== */
.ad-slot{height:0; overflow:hidden;}
.ad-slot + .card{margin-top:0;}

/* ===== Responsivo ===== */
@media (max-width:720px){
  .regime-cards{grid-template-columns:1fr;}
  .foot-inner{grid-template-columns:1fr 1fr;}
}
@media (max-width:560px){
  .site-nav{display:none;}
  .foot-inner{grid-template-columns:1fr;}
}
