/* ============================================================
   FeriadosBrasil — estilo base (evergreen). Tokens herdados do
   wireframe visual docs/template_html/home.html (calendário editorial).
   ============================================================ */
:root{
  --azul-900:#0b2545; --azul-700:#13396b; --azul-600:#1d4ed8; --azul-500:#2f6bff;
  --azul-100:#e7efff; --azul-050:#f3f7ff;
  --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(--azul-600); text-decoration:none;}
a:hover{text-decoration:underline;}
.container{max-width:var(--container); margin:0 auto; padding:0 20px;}
h1,h2,h3,h4{font-family:var(--fonte-display); color:var(--azul-900); line-height:1.15; letter-spacing:-.02em; margin:0;}
h1{font-size:clamp(2rem,4vw,2.8rem); font-weight:800;}
h2{font-size:clamp(1.4rem,2.4vw,1.8rem); 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(--azul-600); background:var(--azul-100); padding:6px 12px; border-radius:999px;}

.btn{display:inline-flex; align-items:center; gap:8px; background:var(--azul-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(--azul-700); text-decoration:none; transform:translateY(-1px);}
.btn-light{background:#fff; color:var(--azul-700);}
.btn-light:hover{background:var(--azul-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.2rem; color:var(--azul-900);}
.brand:hover{text-decoration:none;}
.brand-accent{color:var(--azul-600);}
.brand-mark{width:30px; height:30px; border-radius:9px; background:linear-gradient(135deg,var(--azul-600),var(--azul-500)); display:grid; place-items:center; color:#fff; font-family:var(--fonte-corpo); font-weight:700; font-size:.95rem;}
.site-nav{display:flex; gap:22px; margin-left:auto;}
.site-nav a{color:var(--tinta-2); font-weight:500; font-size:.95rem;}
.site-nav a:hover,.site-nav a.active{color:var(--azul-700); text-decoration:none;}

/* ===== Hero (home) ===== */
.hero{padding:46px 0 26px; position:relative; overflow:hidden;}
.hero::before{content:""; position:absolute; inset:-40% 0 auto 0; height:520px; background:radial-gradient(60% 60% at 18% 0%, rgba(47,107,255,.10), transparent 60%), radial-gradient(50% 50% at 90% 10%, rgba(8,145,178,.07), transparent 60%); z-index:0;}
.hero .container{position:relative; z-index:1;}
.hero h1{margin:14px 0 12px;}
.hero .lead{max-width:60ch;}
.quick-cards{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:26px;}
.qcard{background:var(--papel); border:1px solid var(--linha); border-radius:var(--raio); box-shadow:var(--sombra); padding:16px 18px;}
.qcard.accent{background:linear-gradient(160deg,var(--azul-600),var(--azul-700)); border:0; color:#fff;}
.qcard.accent .qc-label{color:#dbe7ff;}
.qc-label{font-size:.78rem; font-weight:600; letter-spacing:.03em; text-transform:uppercase; color:var(--tinta-2);}
.qc-value{font-family:var(--fonte-display); font-weight:700; font-size:1.25rem; color:var(--azul-900); margin:6px 0 2px;}
.qcard.accent .qc-value{color:#fff;}
.qc-value.yes{color:var(--feriado);}
.qc-value.no{color:var(--tinta-2);}
.qc-sub{font-size:.85rem; color:var(--tinta-2);}
.qcard.accent .btn-light{margin-top:10px;}

/* ===== Layout conteúdo + sidebar ===== */
.layout{display:grid; grid-template-columns:1fr 320px; gap:30px; align-items:start; padding:30px 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:16px;}

/* ===== Tabela de feriados ===== */
table.feriados{width:100%; border-collapse:collapse; font-size:.94rem;}
table.feriados th,table.feriados td{text-align:left; padding:11px 12px;}
table.feriados thead th{font-size:.74rem; letter-spacing:.04em; text-transform:uppercase; color:var(--tinta-2); border-bottom:2px solid var(--linha);}
table.feriados tbody tr{border-bottom:1px solid var(--linha);}
table.feriados tbody tr:hover{background:var(--azul-050);}
table.feriados tbody tr.is-today{background:var(--azul-100);}
.pill{font-size:.74rem; font-weight:700; padding:3px 10px; border-radius:999px; white-space:nowrap;}
.pill.feriado{background:var(--feriado-bg); color:var(--feriado);}
.pill.facultativo{background:var(--facultativo-bg); color:var(--facultativo);}

/* ===== Atalhos (cards) ===== */
.cards-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:14px;}
.shortcut{display:flex; flex-direction:column; gap:4px; background:var(--papel); border:1px solid var(--linha); border-radius:var(--raio); box-shadow:var(--sombra); padding:18px; transition:.18s;}
.shortcut:hover{box-shadow:var(--sombra-hover); transform:translateY(-2px); text-decoration:none;}
.sc-icon{font-size:1.5rem;}
.sc-title{font-family:var(--fonte-display); font-weight:700; color:var(--azul-900);}
.sc-desc{font-size:.88rem; color:var(--tinta-2);}

/* ===== Conceitos ===== */
.concepts{display:grid; grid-template-columns:repeat(3,1fr); gap:20px;}
.concept-col ul{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:8px;}
.concept-col a{color:var(--tinta); font-weight:500;}
.concept-col a:hover{color:var(--azul-700);}

/* ===== Prosa ===== */
.prose p{margin:0 0 14px;}
.prose p:last-child{margin-bottom:0;}
.prose strong{color:var(--azul-900);}

/* ===== 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(--azul-900);}
.faq summary::-webkit-details-marker{display:none;}
.faq .ans{padding:0 18px 16px; color:var(--tinta-2);}

/* ===== Sidebar ===== */
.sidebar .card{padding:18px;}
.side-next .countdown{display:flex; align-items:baseline; gap:8px; margin:4px 0;}
.side-next .big{font-family:var(--fonte-display); font-size:2.4rem; font-weight:800; color:var(--azul-600); line-height:1;}
.side-next .unit{color:var(--tinta-2); font-weight:600;}
.side-list{list-style:none; margin:0; padding:0;}
.side-list li{display:flex; justify-content:space-between; align-items:center; gap:10px; padding:10px 0; border-top:1px solid var(--linha);}
.side-list li:first-child{border-top:0;}
.side-list li span{color:var(--tinta-2); font-size:.85rem;}
.side-stat ul{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:8px;}
.side-stat strong{color:var(--azul-700); font-size:1.05rem;}

/* ===== 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);}

/* ===== Página de feriado ===== */
.holiday-hero{padding:18px 0 24px;}
.holiday-hero h1{margin:12px 0 10px;}
.next-box{display:flex; align-items:center; justify-content:space-between; gap:16px; background:var(--azul-050); border:1px solid var(--azul-100); border-radius:var(--raio); padding:16px 20px; margin-top:18px; max-width:560px;}
.nb-label{display:block; font-size:.75rem; font-weight:600; text-transform:uppercase; letter-spacing:.04em; color:var(--tinta-2);}
.nb-date{display:block; font-family:var(--fonte-display); font-weight:700; color:var(--azul-900); margin-top:2px;}
.nb-count{text-align:center; color:var(--azul-700);}
.nb-count .big{display:block; font-family:var(--fonte-display); font-size:2rem; font-weight:800; line-height:1;}

/* ===== O que abre e fecha ===== */
.services{display:grid; grid-template-columns:repeat(auto-fill,minmax(230px,1fr)); gap:12px;}
.svc{border:1px solid var(--linha); border-radius:var(--raio-sm); padding:14px;}
.svc-head{display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:6px;}
.svc-name{font-weight:700; color:var(--azul-900); font-size:.95rem;}
.svc-detail{font-size:.85rem; color:var(--tinta-2); margin:0;}
.status{font-size:.72rem; font-weight:700; padding:3px 9px; border-radius:999px; white-space:nowrap;}
.status.s-fechado{background:var(--feriado-bg); color:var(--feriado);}
.status.s-aberto{background:var(--aberto-bg); color:var(--aberto);}
.status.s-parcial{background:var(--facultativo-bg); color:var(--facultativo);}
.status.s-varia{background:var(--azul-050); color:var(--tinta-2);}

/* ===== Navegação anterior/próximo ===== */
.holiday-nav{display:flex; justify-content:space-between; gap:12px; margin-top:6px;}
.holiday-nav a{font-weight:600;}

/* ===== Footer ===== */
.site-footer{background:var(--azul-900); color:#c7d4ea; margin-top:50px; padding:38px 0 26px;}
.site-footer a{color:#dbe5f6;}
.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.2rem; 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:#9fb2d0; max-width:42ch;}
.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:#8aa1c4;}

/* ===== Slots de anúncio (reservados, invisíveis) ===== */
.ad-slot{height:0; overflow:hidden;}

/* ===== Erros ===== */
.error-page{text-align:center; padding:80px 20px;}
.error-code{font-family:var(--fonte-display); font-weight:800; font-size:3rem; color:var(--azul-600);}
.error-page h1{margin:8px 0 12px;}
.error-page p{color:var(--tinta-2); margin-bottom:22px;}

/* ===== Conceitos / páginas internas ===== */
.concept-hero{padding:18px 0 22px;}
.concept-hero h1{margin-bottom:10px;}
.uf-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:8px;}
.uf-chip{display:flex; align-items:center; gap:8px; border:1px solid var(--azul-100); background:var(--azul-050); border-radius:var(--raio-sm); padding:9px 12px; font-size:.9rem; color:var(--azul-700);}
.uf-chip:hover{background:var(--azul-600); color:#fff; border-color:var(--azul-600); text-decoration:none;}
.uf-chip span{color:inherit; opacity:.85;}
.uf-chip.disabled{background:var(--fundo); color:var(--tinta-2); border-color:var(--linha); opacity:.55; cursor:not-allowed;}
.uf-chip.disabled:hover{background:var(--fundo); color:var(--tinta-2); text-decoration:none;}
.uf-grid-sm{grid-template-columns:repeat(auto-fill,minmax(52px,1fr)); gap:6px;}
.uf-grid-sm .uf-chip{justify-content:center; padding:8px 6px;}

/* serviços — versão grande (página-mãe) e link */
.services-lg{grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); margin-bottom:26px;}
.svc-link{display:block; background:var(--papel); box-shadow:var(--sombra); transition:.18s;}
.svc-link:hover{box-shadow:var(--sombra-hover); transform:translateY(-2px); text-decoration:none;}
.svc-legal{font-size:.78rem; color:var(--tinta-2); margin:6px 0 0;}

/* é feriado hoje — resposta grande */
.answer-hero{text-align:center; padding:48px 20px 36px;}
.answer-big{font-family:var(--fonte-display); font-weight:800; font-size:clamp(3rem,9vw,5rem); line-height:1;}
.answer-hero.is-yes .answer-big{color:var(--feriado);}
.answer-hero.is-no .answer-big{color:var(--tinta-2);}
.answer-sub{font-size:1.2rem; margin:10px 0 4px;}
.next-card .next-box{margin-top:14px;}

/* countdown (ev-07) */
.container.narrow{max-width:760px;}
.concept-hero.center{text-align:center;}
.countdown-hero{text-align:center; background:var(--papel); border:1px solid var(--linha); border-radius:var(--raio); box-shadow:var(--sombra); padding:40px 20px 30px; margin:8px 0 22px;}
.cd-num{font-family:var(--fonte-display); font-weight:800; line-height:1; color:var(--azul-600);}
.cd-num [data-cd]{font-size:clamp(3rem,11vw,6rem);}
.cd-unit{font-size:1.4rem; color:var(--tinta-2); font-weight:700;}
.cd-sub{font-size:1.15rem; margin:12px 0 4px;}
.inst-nav{margin-top:18px; color:var(--tinta-2); font-size:.92rem;}
.side-cta{margin:10px 0 0; font-size:.9rem; font-weight:600;}

/* comparativo (ev-08) */
.highlights{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin:8px 0 22px;}
.hl{background:var(--papel); border:1px solid var(--linha); border-radius:var(--raio); box-shadow:var(--sombra); padding:16px 18px; text-align:center;}
.hl-label{display:block; font-size:.74rem; font-weight:600; text-transform:uppercase; letter-spacing:.03em; color:var(--tinta-2);}
.hl-value{display:block; font-family:var(--fonte-display); font-weight:800; font-size:2rem; color:var(--azul-600); margin:4px 0;}
.hl-sub{display:block; font-size:.85rem; color:var(--tinta-2);}

/* timeline (ev-09) */
.timeline{list-style:none; margin:0; padding:0;}
.timeline li{display:flex; gap:16px; padding:12px 0; border-top:1px solid var(--linha);}
.timeline li:first-child{border-top:0;}
.tl-year{flex:0 0 auto; width:54px; font-family:var(--fonte-display); font-weight:800; color:var(--azul-600);}
.tl-body{color:var(--tinta);}

/* ===== Responsivo ===== */
@media (max-width:920px){
  .layout{grid-template-columns:1fr;}
  .quick-cards{grid-template-columns:1fr;}
  .concepts{grid-template-columns:1fr 1fr;}
  .foot-inner{grid-template-columns:1fr 1fr;}
}
@media (max-width:600px){
  .site-nav{display:none;}
  .concepts{grid-template-columns:1fr;}
  .foot-inner{grid-template-columns:1fr;}
}
