/* =====================================================================
   A School — Escola de Idiomas
   Design System "Cartografia do Saber" (explorador-sábio)
   Paleta: navy profundo + ouro + marfim  |  Tipografia: Playfair Display + Mulish
   Autor: Projeto Gabriel  |  Sem dependencias, sem build.
   ===================================================================== */

/* ---------- Tokens ---------- */
:root{
  /* Navy */
  --navy-900:#0B1A3F;
  --navy-800:#102652;
  --navy-700:#1A3A7A;
  --navy-600:#2451A6;
  /* Ouro */
  --gold-700:#1D4ED8;
  --gold-600:#2563EB;
  --gold-500:#3B82F6;
  --gold-400:#60A5FA;
  --gold-300:#93C5FD;
  --gold-200:#C7DDFF;
  /* Marfim / claros */
  --cream:#EAF1FB;
  --cream-2:#F4F8FF;
  --cream-3:#FFFFFF;
  /* Tinta (texto sobre claro) */
  --ink:#0F1E33;
  --ink-soft:#48586B;
  --ink-faint:#6B7A8C;
  /* Texto sobre navy */
  --on-navy:#EAF1FB;
  --on-navy-soft:rgba(234,241,251,.78);
  --on-navy-faint:rgba(234,241,251,.58);
  /* Linhas */
  --line:rgba(20,32,46,.12);
  --line-navy:rgba(96,165,250,.22);
  /* Gradientes */
  --grad-gold:linear-gradient(135deg,#60A5FA 0%,#2563EB 45%,#14B8A6 100%);
  --grad-gold-soft:linear-gradient(135deg,#60A5FA,#14B8A6);
  --grad-navy:linear-gradient(180deg,#102652 0%,#0B1A3F 100%);
  /* Sombras */
  --shadow-sm:0 1px 2px rgba(11,26,63,.06),0 2px 8px rgba(11,26,63,.06);
  --shadow-md:0 12px 30px -12px rgba(11,26,63,.22);
  --shadow-gold:0 14px 34px -14px rgba(37,99,235,.5);
  /* Forma e ritmo */
  --radius:14px;
  --radius-lg:22px;
  --radius-pill:999px;
  --container:1140px;
  --container-narrow:760px;
  --space:clamp(56px,9vw,116px);
  /* Tipografia */
  --font-display:"Playfair Display",Georgia,"Times New Roman",serif;
  --font-body:"Mulish","Segoe UI",system-ui,-apple-system,sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;font-family:var(--font-body);color:var(--ink);background:var(--cream-2);
  font-size:clamp(16px,1.05vw,17.5px);line-height:1.7;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden}
img,svg,picture{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
ul,ol{margin:0;padding:0}
h1,h2,h3,h4{margin:0;font-family:var(--font-display);font-weight:700;line-height:1.12;
  letter-spacing:-.01em;color:var(--ink)}
p{margin:0}
::selection{background:var(--gold-300);color:var(--navy-900)}
:focus-visible{outline:3px solid var(--gold-500);outline-offset:3px;border-radius:6px}

/* ---------- Tipografia (escala) ---------- */
.h1{font-size:clamp(2.3rem,5.4vw,4rem)}
.h2{font-size:clamp(1.9rem,3.6vw,2.85rem)}
.h3{font-size:clamp(1.3rem,2vw,1.6rem)}
.lead{font-size:clamp(1.08rem,1.6vw,1.32rem);line-height:1.6;color:var(--ink-soft)}
.eyebrow{font-family:var(--font-body);font-weight:800;font-size:.78rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold-700);display:inline-flex;align-items:center;gap:.6em;margin-bottom:1rem}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold-500);display:inline-block}
.eyebrow--center{justify-content:center}
.u-gold{color:var(--gold-600);font-style:italic}
.u-underline{background:linear-gradient(transparent 62%,var(--gold-200) 62%)}
.text-center{text-align:center}
.measure{max-width:62ch}
.measure-center{max-width:62ch;margin-inline:auto}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:clamp(20px,5vw,40px)}
.container--narrow{max-width:var(--container-narrow)}
.section{padding-block:var(--space);position:relative}
.section--cream{background:var(--cream-2)}
.section--cream-alt{background:var(--cream)}
.section--white{background:var(--cream-3)}
.section--navy{background:var(--grad-navy);color:var(--on-navy)}
.section--navy h1,.section--navy h2,.section--navy h3{color:var(--on-navy)}
.section--navy .lead{color:var(--on-navy-soft)}
.grid{display:grid;gap:clamp(20px,3vw,34px)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
.section-head{max-width:720px;margin-bottom:clamp(34px,5vw,56px)}
.section-head--center{margin-inline:auto;text-align:center}

/* ---------- Constelação / textura ---------- */
.starfield{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0;opacity:.9}
.starfield::before,.starfield::after{content:"";position:absolute;inset:-10%;
  background-image:
    radial-gradient(1.4px 1.4px at 12% 22%,rgba(96,165,250,.9),transparent),
    radial-gradient(1.4px 1.4px at 78% 14%,rgba(96,165,250,.7),transparent),
    radial-gradient(1.2px 1.2px at 33% 64%,rgba(96,165,250,.6),transparent),
    radial-gradient(1.6px 1.6px at 64% 48%,rgba(255,255,255,.7),transparent),
    radial-gradient(1.2px 1.2px at 88% 72%,rgba(96,165,250,.55),transparent),
    radial-gradient(1.1px 1.1px at 50% 88%,rgba(96,165,250,.5),transparent),
    radial-gradient(1.3px 1.3px at 22% 84%,rgba(255,255,255,.5),transparent);
  background-repeat:no-repeat}
.starfield--dense::after{opacity:.5;transform:scale(1.3) rotate(8deg)}
.section--navy .container{position:relative;z-index:1}

/* divisor compasso */
.divider-compass{display:flex;align-items:center;justify-content:center;gap:14px;margin:0 auto;color:var(--gold-500)}
.divider-compass::before,.divider-compass::after{content:"";height:1px;width:min(120px,22vw);
  background:linear-gradient(90deg,transparent,var(--gold-500))}
.divider-compass::after{background:linear-gradient(90deg,var(--gold-500),transparent)}

/* ---------- Botões ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-family:var(--font-body);font-weight:800;font-size:1rem;letter-spacing:.01em;
  padding:1rem 1.9rem;border-radius:var(--radius-pill);border:1px solid transparent;
  transition:transform .18s ease,box-shadow .25s ease,background .25s ease,color .2s ease;
  text-align:center;line-height:1.15;cursor:pointer;will-change:transform}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn--primary{background:var(--grad-gold);color:var(--navy-900);box-shadow:var(--shadow-gold)}
.btn--primary:hover{box-shadow:0 18px 40px -12px rgba(37,99,235,.7)}
.btn--ghost{background:transparent;color:var(--on-navy);border-color:var(--line-navy)}
.btn--ghost:hover{border-color:var(--gold-400);color:var(--gold-300)}
.btn--ink{background:var(--navy-800);color:var(--cream)}
.btn--ink:hover{background:var(--navy-700)}
.btn--outline{background:transparent;color:var(--navy-800);border-color:rgba(20,32,46,.22)}
.btn--outline:hover{border-color:var(--gold-600);color:var(--gold-700)}
.btn--block{display:flex;width:100%}
.btn--lg{padding:1.15rem 2.3rem;font-size:1.06rem}
.btn .arrow{transition:transform .2s ease}
.btn:hover .arrow{transform:translateX(4px)}
.cta-note{font-size:.86rem;color:var(--ink-faint);margin-top:.75rem}
.section--navy .cta-note{color:var(--on-navy-faint)}

/* ---------- Header / Nav ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.90);
  backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid rgba(11,26,63,.10);transition:background .3s ease,box-shadow .3s ease}
.site-header.is-scrolled{background:rgba(255,255,255,.97);box-shadow:0 8px 28px -18px rgba(11,26,63,.30)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:88px}
.brand{display:flex;align-items:center;gap:.7rem;color:var(--navy-900);font-family:var(--font-display);
  font-weight:700;font-size:1.32rem;letter-spacing:.02em}
.brand .mark{width:34px;height:34px;flex:none;border-radius:50%;display:grid;place-items:center;
  background:var(--grad-gold);color:var(--navy-900);font-weight:800;font-family:var(--font-display);
  box-shadow:0 0 0 1px rgba(96,165,250,.4),0 6px 16px -6px rgba(37,99,235,.8)}
.brand small{display:block;font-family:var(--font-body);font-weight:700;font-size:.58rem;
  letter-spacing:.34em;text-transform:uppercase;color:var(--on-navy-soft);margin-top:2px}
.nav-links{display:flex;align-items:center;gap:1.7rem;list-style:none}
.nav-links a{color:var(--ink-soft);font-weight:700;font-size:.95rem;transition:color .2s ease;position:relative}
.nav-links a:hover{color:var(--gold-600)}
.nav-actions{display:flex;align-items:center;gap:1rem}
.nav-toggle{display:none;background:none;border:0;color:var(--navy-900);padding:8px}
.nav-toggle svg{width:28px;height:28px}
@media(max-width:940px){
  .nav-links,.nav-actions .btn{display:none}
  .nav-toggle{display:inline-flex}
  .nav.is-open .nav-links{display:flex;position:absolute;top:88px;left:0;right:0;flex-direction:column;
    align-items:flex-start;gap:0;background:#fff;padding:10px clamp(20px,5vw,40px) 24px;
    border-bottom:1px solid rgba(11,26,63,.10);box-shadow:0 18px 30px -20px rgba(11,26,63,.30)}
  .nav.is-open .nav-links a{padding:14px 0;width:100%;border-bottom:1px solid rgba(11,26,63,.08)}
  .nav.is-open .nav-actions .btn{display:flex;margin-top:14px}
  .nav.is-open .nav-actions{position:absolute;top:88px;left:0;right:0;padding:0 clamp(20px,5vw,40px) 22px;
    background:#fff}
}

/* ---------- Hero ---------- */
.hero{position:relative;background:var(--grad-navy);color:var(--on-navy);overflow:hidden;
  padding-block:clamp(64px,10vw,120px)}
.hero .container{position:relative;z-index:2}
.hero-glow{position:absolute;z-index:1;width:620px;height:620px;border-radius:50%;
  background:radial-gradient(circle,rgba(59,130,246,.22),transparent 62%);
  top:-160px;right:-120px;filter:blur(8px);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(30px,5vw,64px);align-items:center}
@media(max-width:920px){.hero-grid{grid-template-columns:1fr;text-align:left}}
.hero h1{color:var(--cream);margin-bottom:1.2rem}
.hero h1 .accent{background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;font-style:italic}
.hero .lead{color:var(--on-navy-soft);max-width:54ch;margin-bottom:2rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}
.hero-trust{display:flex;flex-wrap:wrap;gap:1.1rem 1.8rem;margin-top:2.4rem;
  padding-top:1.6rem;border-top:1px solid var(--line-navy)}
.hero-trust div{display:flex;flex-direction:column}
.hero-trust b{font-family:var(--font-display);font-size:1.7rem;color:var(--gold-300);line-height:1}
.hero-trust span{font-size:.82rem;color:var(--on-navy-soft);margin-top:.3rem}

/* medalhão compasso (hero visual) */
.hero-medallion{position:relative;aspect-ratio:1;max-width:380px;margin-inline:auto;width:100%;
  border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 50% 42%,#13366f,#0a1a3c 70%);
  box-shadow:inset 0 0 0 1px rgba(96,165,250,.25),0 30px 70px -30px rgba(0,0,0,.7)}
.hero-medallion::before{content:"";position:absolute;inset:14px;border-radius:50%;
  border:1px dashed rgba(96,165,250,.35)}
.hero-medallion .rose{width:62%;color:var(--gold-400);filter:drop-shadow(0 6px 18px rgba(37,99,235,.55))}
@media(max-width:920px){.hero-medallion{display:none}}

/* ---------- Selos / badges ---------- */
.pill-row{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.4rem}
.pill{display:inline-flex;align-items:center;gap:.5em;font-size:.84rem;font-weight:700;
  padding:.5em 1em;border-radius:var(--radius-pill);background:rgba(96,165,250,.1);
  border:1px solid var(--line-navy);color:var(--on-navy-soft)}
.pill svg{width:15px;height:15px;color:var(--gold-400)}
.badge{display:inline-flex;align-items:center;gap:.5em;font-size:.8rem;font-weight:800;
  letter-spacing:.04em;text-transform:uppercase;color:var(--gold-700);
  background:var(--gold-200);padding:.4em .9em;border-radius:var(--radius-pill)}

/* ---------- Cards ---------- */
.card{background:var(--cream-3);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(22px,3vw,32px);box-shadow:var(--shadow-sm);height:100%;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:rgba(59,130,246,.4)}
.card .icon{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;margin-bottom:1.1rem;
  background:linear-gradient(135deg,var(--navy-700),var(--navy-900));color:var(--gold-300)}
.card .icon svg{width:24px;height:24px}
.card h3{margin-bottom:.6rem;font-size:1.28rem}
.card p{color:var(--ink-soft);font-size:.98rem}
.card--navy{background:linear-gradient(165deg,#13366f,#0a1a3c);border-color:var(--line-navy);color:var(--on-navy)}
.card--navy h3{color:var(--cream)}.card--navy p{color:var(--on-navy-soft)}
.card--gold{background:var(--grad-gold);border:0;color:var(--navy-900)}
.card--gold h3,.card--gold p{color:var(--navy-900)}

/* ---------- Lista de dor / check ---------- */
.icon-list{list-style:none;display:grid;gap:1rem}
.icon-list li{display:flex;gap:.9rem;align-items:flex-start;font-size:1.02rem}
.icon-list .ic{flex:none;width:26px;height:26px;border-radius:50%;display:grid;place-items:center;margin-top:2px}
.icon-list .ic svg{width:15px;height:15px}
.icon-list.is-pain .ic{background:rgba(214,40,40,.12);color:#d11f2b}
.icon-list.is-check .ic{background:rgba(37,99,235,.16);color:var(--gold-700)}
.section--navy .icon-list.is-check .ic{background:rgba(96,165,250,.18);color:var(--gold-300)}
.section--navy .icon-list li{color:var(--on-navy-soft)}

/* ---------- Passos / método ---------- */
.steps{counter-reset:step;display:grid;gap:clamp(18px,2.4vw,26px)}
.step{display:grid;grid-template-columns:auto 1fr;gap:1.2rem;align-items:start}
.step .num{counter-increment:step;width:52px;height:52px;border-radius:50%;flex:none;
  display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:1.4rem;
  background:var(--grad-gold);color:var(--navy-900);box-shadow:var(--shadow-gold)}
.step .num::before{content:counter(step,decimal-leading-zero)}
.step h3{font-size:1.22rem;margin-bottom:.35rem}
.step p{color:var(--ink-soft);font-size:.98rem}
.section--navy .step p{color:var(--on-navy-soft)}

/* ---------- Comparativo ---------- */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2.4vw,26px)}
@media(max-width:620px){.compare{grid-template-columns:1fr}}
.compare .col{border-radius:var(--radius-lg);padding:clamp(22px,3vw,30px);border:1px solid var(--line)}
.compare .col--bad{background:var(--cream-3)}
.compare .col--good{background:linear-gradient(165deg,#13366f,#0a1a3c);color:var(--on-navy);border-color:var(--line-navy)}
.compare .col--good h3{color:var(--cream)}
.compare h3{font-size:1.2rem;margin-bottom:1rem}

/* ---------- Depoimentos ---------- */
.testimonial{background:var(--cream-3);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(24px,3vw,32px);box-shadow:var(--shadow-sm);height:100%;display:flex;flex-direction:column}
.testimonial .stars{color:var(--gold-500);letter-spacing:.15em;margin-bottom:.9rem;font-size:.95rem}
.testimonial blockquote{margin:0 0 1.2rem;font-size:1.06rem;color:var(--ink);line-height:1.6}
.testimonial .who{display:flex;align-items:center;gap:.8rem;margin-top:auto}
.testimonial .avatar{width:44px;height:44px;border-radius:50%;background:var(--grad-gold);
  display:grid;place-items:center;color:var(--navy-900);font-weight:800;flex:none}
.testimonial .who b{display:block;font-size:.96rem}
.testimonial .who span{font-size:.82rem;color:var(--ink-faint)}
.placeholder-note{font-size:.8rem;color:var(--ink-faint);font-style:italic;margin-top:1.2rem}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:.8rem;max-width:820px;margin-inline:auto}
.faq-item{border:1px solid var(--line);border-radius:var(--radius);background:var(--cream-3);overflow:hidden}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:1.15rem 1.3rem;background:none;border:0;text-align:left;font-weight:800;font-size:1.04rem;color:var(--ink)}
.faq-q .chev{flex:none;width:22px;height:22px;color:var(--gold-600);transition:transform .25s ease}
.faq-item.is-open .chev{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-a p{padding:0 1.3rem 1.25rem;color:var(--ink-soft);font-size:.98rem}

/* ---------- Faixa de CTA ---------- */
.cta-band{background:var(--grad-navy);color:var(--on-navy);border-radius:var(--radius-lg);
  padding:clamp(32px,5vw,60px);text-align:center;position:relative;overflow:hidden}
.cta-band h2{color:var(--cream);margin-bottom:1rem}
.cta-band .lead{color:var(--on-navy-soft);max-width:60ch;margin:0 auto 2rem}

/* ---------- Form (agendar) ---------- */
.lead-form{background:var(--cream-3);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:clamp(24px,3.4vw,38px);box-shadow:var(--shadow-md)}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.1rem}
.field label{font-weight:800;font-size:.88rem;color:var(--ink)}
.field input,.field select,.field textarea{font:inherit;padding:.85rem 1rem;border-radius:12px;
  border:1px solid rgba(20,32,46,.2);background:var(--cream-2);color:var(--ink);transition:border-color .2s,box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--gold-500);
  box-shadow:0 0 0 3px rgba(59,130,246,.25)}
.form-ok{display:none;padding:1rem 1.2rem;border-radius:12px;background:rgba(37,99,235,.12);
  color:var(--gold-700);font-weight:700;border:1px solid var(--gold-300)}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-900);color:var(--on-navy-soft);padding-block:clamp(48px,6vw,72px) 28px;
  border-top:1px solid var(--line-navy)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:clamp(24px,4vw,48px)}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.footer-grid h4{color:var(--cream);font-family:var(--font-body);font-weight:800;font-size:.82rem;
  letter-spacing:.14em;text-transform:uppercase;margin-bottom:1.1rem}
.footer-grid a{display:block;color:var(--on-navy-soft);padding:.32rem 0;font-size:.95rem;transition:color .2s}
.footer-grid a:hover{color:var(--gold-300)}
.footer-brand p{color:var(--on-navy-soft);font-size:.95rem;margin-top:1rem;max-width:34ch}
.footer-social{display:flex;gap:.7rem;margin-top:1.2rem}
.footer-social a{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;
  border:1px solid var(--line-navy);color:var(--on-navy-soft)}
.footer-social a:hover{color:var(--gold-300);border-color:var(--gold-400)}
.footer-social svg{width:19px;height:19px}
.footer-bottom{margin-top:clamp(32px,5vw,52px);padding-top:22px;border-top:1px solid var(--line-navy);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;font-size:.84rem;color:var(--on-navy-faint)}

/* ---------- Artigo / Blog ---------- */
.post-hero{background:var(--grad-navy);color:var(--on-navy);padding-block:clamp(56px,8vw,96px) clamp(40px,6vw,64px);
  position:relative;overflow:hidden}
.post-hero .container{position:relative;z-index:2;max-width:820px}
.post-meta{display:flex;flex-wrap:wrap;gap:.6rem 1.2rem;align-items:center;font-size:.86rem;
  color:var(--on-navy-soft);margin-top:1.4rem}
.post-meta .badge{color:var(--navy-900)}
.breadcrumb{font-size:.82rem;color:var(--on-navy-soft);margin-bottom:1.4rem}
.breadcrumb a:hover{color:var(--gold-300)}
.post-body{max-width:760px;margin-inline:auto;padding-block:clamp(40px,5vw,64px)}
.post-body>*+*{margin-top:1.3rem}
.post-body h2{font-size:clamp(1.5rem,2.6vw,2rem);margin-top:2.6rem;scroll-margin-top:90px}
.post-body h3{font-size:1.25rem;margin-top:1.9rem}
.post-body p,.post-body li{font-size:1.08rem;line-height:1.75;color:#26333f}
.post-body ul,.post-body ol{padding-left:1.3rem;display:grid;gap:.5rem}
.post-body li::marker{color:var(--gold-600)}
.post-body a{color:var(--gold-700);font-weight:700;text-decoration:underline;text-decoration-color:var(--gold-300)}
/* botoes dentro do conteudo NAO herdam o estilo de link de texto: texto escuro, sem sublinhado */
.post-body a.btn,.legal a.btn,.post-cta a.btn{text-decoration:none;font-weight:800}
.post-body a.btn--primary,.legal a.btn--primary,.post-cta a.btn--primary{color:var(--navy-900)}
.post-body a.btn--ghost{color:var(--on-navy)}
.post-body a.btn--outline,.post-body a.btn--ink{color:var(--navy-800)}
.post-body strong{color:var(--ink)}
.post-body blockquote{margin:1.8rem 0;padding:1.1rem 1.4rem;border-left:4px solid var(--gold-500);
  background:var(--cream);border-radius:0 12px 12px 0;font-size:1.1rem;color:var(--ink)}
.answer-box{background:linear-gradient(165deg,#13366f,#0a1a3c);color:var(--on-navy);
  border-radius:var(--radius-lg);padding:clamp(20px,3vw,28px);margin:1.8rem 0;border:1px solid var(--line-navy)}
.answer-box .badge{margin-bottom:.8rem}
.answer-box p{color:var(--cream);font-size:1.08rem;margin:0}
.post-cta{background:var(--cream);border:1px solid var(--gold-300);border-radius:var(--radius-lg);
  padding:clamp(24px,3.4vw,34px);margin:2.4rem 0;text-align:center}
.post-cta h3{margin-bottom:.7rem}
.post-cta p{color:var(--ink-soft);margin-bottom:1.4rem;max-width:52ch;margin-inline:auto}
.toc{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem 1.4rem;margin:1.6rem 0}
.toc b{display:block;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-700);margin-bottom:.6rem}
.toc a{display:block;padding:.3rem 0;color:var(--ink-soft);font-size:.96rem}
.toc a:hover{color:var(--gold-700)}

/* cards de post (blog hub + relacionados) */
.post-card{display:flex;flex-direction:column;background:var(--cream-3);border:1px solid var(--line);
  border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);height:100%;
  transition:transform .25s,box-shadow .25s,border-color .25s}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:rgba(59,130,246,.4)}
.post-card .thumb{aspect-ratio:16/9;background:var(--grad-navy);position:relative;overflow:hidden}
.post-card .thumb .rose{position:absolute;inset:0;margin:auto;width:44%;color:var(--gold-400);opacity:.7}
.post-card .pc-body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.post-card .cat{font-size:.74rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-700)}
.post-card h3{font-size:1.2rem;line-height:1.25}
.post-card p{font-size:.94rem;color:var(--ink-soft)}
.post-card .more{margin-top:auto;font-weight:800;color:var(--gold-700);font-size:.92rem;display:inline-flex;gap:.4em;align-items:center}

/* documentos legais */
.legal{max-width:780px;margin-inline:auto;padding-block:clamp(40px,5vw,64px)}
.legal h2{margin-top:2.2rem;font-size:1.5rem}
.legal h3{margin-top:1.6rem;font-size:1.18rem}
.legal p,.legal li{color:#2a3744;line-height:1.75}
.legal ul,.legal ol{padding-left:1.3rem;display:grid;gap:.4rem;margin-top:.6rem}
.legal .upd{color:var(--ink-faint);font-size:.9rem}

/* ---------- Animação de revelação ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.is-in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ---------- Utilidades ---------- */
.mt-0{margin-top:0}.mt-1{margin-top:.6rem}.mt-2{margin-top:1.2rem}.mt-3{margin-top:2rem}
.mb-0{margin-bottom:0}.mb-2{margin-bottom:1.2rem}.mb-3{margin-bottom:2rem}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--gold-500);color:var(--navy-900);
  padding:.6rem 1rem;border-radius:0 0 8px 0;font-weight:800;z-index:200}
.skip-link:focus{left:0}

/* ============================================================
   Correções de formatação + reforço MOBILE-FIRST
   ============================================================ */

/* Tabelas dentro de artigos: roláveis no celular, sem quebrar o layout */
.post-body .table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:1.4rem 0;
  border:1px solid var(--line);border-radius:12px}
.post-body .table-wrap table{margin:0;min-width:520px}
.post-body table{width:100%;border-collapse:collapse;font-size:.96rem;background:var(--cream-3)}
.post-body thead th{background:var(--cream);color:var(--ink);font-weight:800}
.post-body th,.post-body td{vertical-align:top}

/* icon-list robusto: só vira flex quando REALMENTE tem ícone (.ic).
   Assim, listas com texto rico (negrito/itálico) não são espremidas em colunas. */
.icon-list li{display:block}
.icon-list li:has(.ic){display:flex;gap:.9rem;align-items:flex-start}

/* Evita estouro horizontal e palavras longas vazando no mobile */
img,svg,table{max-width:100%}
.post-body{overflow-wrap:break-word}

@media(max-width:560px){
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{width:100%}
  .post-cta .btn,.cta-band .btn{width:100%}
  .post-body table{font-size:.9rem}
  .post-body .table-wrap table{min-width:460px}
  .hero-trust{gap:1rem 1.3rem}
  .post-meta{gap:.5rem .9rem}
  .section-head,.section-head--center{margin-bottom:clamp(26px,7vw,40px)}
}


/* ---------- Logo "I Can — A School" (marca) ---------- */
.brand-logo{height:68px;width:auto;flex:none;margin:0;padding:0;display:block}
@media(max-width:560px){.brand-logo{height:54px}}
.hero-logo{max-width:240px;width:60%;margin:0 auto 1.4rem;display:block;
  filter:drop-shadow(0 16px 38px rgba(11,26,63,.30))}
.logo-badge{background:#fff;border-radius:18px;padding:14px 18px;display:inline-block;
  box-shadow:0 18px 50px -20px rgba(11,26,63,.55)}

.site-footer .brand-logo{background:none;border-radius:0;box-shadow:none;padding:0;margin:0;height:62px;filter:brightness(0) invert(1)}
