/* ============================================================
   GERMANA MEDEIROS — Campanha 2026 (pré-campanha)
   Design system fiel ao Brand Book v1.0
   ============================================================ */

:root{
  /* Paleta oficial */
  --orange:#E67E22;
  --orange-d:#cf6a12;
  --navy:#1F3A5F;
  --navy-d:#16293f;
  --terra:#DB5C38;
  --cream:#F7F3EC;
  --sand:#E8DCCB;
  --ink:#2A2A2A;
  --white:#ffffff;

  --muted:#6b6256;
  --line:rgba(31,58,95,.12);

  --maxw:1180px;
  --gutter:clamp(20px,5vw,40px);
  --radius:18px;
  --radius-lg:28px;
  --shadow-sm:0 6px 20px rgba(31,58,95,.08);
  --shadow:0 18px 50px rgba(31,58,95,.13);
  --shadow-lg:0 30px 80px rgba(31,58,95,.20);

  --ease:cubic-bezier(.22,.61,.36,1);
  --font:"Outfit",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --script:"Kaushan Script",cursive;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--cream);
  line-height:1.6;font-size:clamp(15px,.5vw + 14px,17px);
  overflow-x:clip;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4{line-height:1.12;margin:0;font-weight:700;letter-spacing:-.01em}
p{margin:0 0 1em}
::selection{background:var(--orange);color:#fff}

.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{position:relative;padding:clamp(64px,9vw,120px) 0}

/* ---------- Wordmark ---------- */
.brand{display:inline-flex;align-items:baseline;gap:.32em;line-height:1;color:var(--navy)}
.brand__pre{font-size:.84rem;font-weight:600;letter-spacing:.02em;opacity:.85}
.brand__name{font-family:var(--script);font-size:1.65rem;color:var(--navy);transform:translateY(.04em)}
.brand__last{font-size:.84rem;font-weight:600;letter-spacing:.34em;text-transform:uppercase}
.brand--footer{color:#fff}
.brand--footer .brand__name{color:#fff}

/* ============================================================
   TSE BAR
   ============================================================ */
.tsebar{background:var(--navy);color:#eaf0f7;font-size:.78rem}
.tsebar__in{display:flex;align-items:center;gap:.6em;justify-content:center;padding:.5em 0;text-align:center}
.tsebar p{margin:0}
.tsebar strong{color:#fff}
.tsebar__dot{width:7px;height:7px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 0 rgba(230,126,34,.7);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(230,126,34,.6)}70%{box-shadow:0 0 0 8px rgba(230,126,34,0)}100%{box-shadow:0 0 0 0 rgba(230,126,34,0)}}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{position:sticky;top:0;z-index:60;background:rgba(247,243,236,.82);backdrop-filter:blur(12px);
  border-bottom:1px solid transparent;transition:.35s var(--ease)}
.site-header.is-stuck{background:rgba(247,243,236,.92);box-shadow:0 6px 24px rgba(31,58,95,.08);border-bottom-color:var(--line)}
.header__in{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:74px;transition:height .35s var(--ease)}
.site-header.is-stuck .header__in{height:62px}
.nav{display:flex;align-items:center;gap:clamp(.6rem,1.6vw,1.6rem)}
.nav__link{font-size:.92rem;font-weight:500;color:var(--navy);padding:.4em 0;position:relative;opacity:.82;transition:.25s}
.nav__link::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--orange);transition:right .3s var(--ease);border-radius:2px}
.nav__link:hover,.nav__link.is-active{opacity:1}
.nav__link.is-active::after,.nav__link:hover::after{right:0}
.nav__cta{font-size:.92rem;font-weight:600;color:#fff;background:var(--orange);padding:.6em 1.15em;border-radius:999px;transition:.25s var(--ease);box-shadow:0 8px 18px rgba(230,126,34,.28)}
.nav__cta:hover{background:var(--orange-d);transform:translateY(-2px)}

.burger{display:none;width:44px;height:44px;border:0;background:transparent;flex-direction:column;justify-content:center;gap:5px;padding:0}
.burger span{display:block;height:2.5px;width:24px;background:var(--navy);border-radius:2px;transition:.3s var(--ease);margin-inline:auto}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ============================================================
   BUTTONS / LINKS
   ============================================================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-weight:600;font-size:.98rem;
  padding:.85em 1.5em;border-radius:999px;border:2px solid transparent;transition:.28s var(--ease);will-change:transform}
.btn--primary{background:var(--orange);color:#fff;box-shadow:0 12px 26px rgba(230,126,34,.32)}
.btn--primary:hover{background:var(--orange-d);transform:translateY(-3px);box-shadow:0 18px 34px rgba(230,126,34,.4)}
.btn--ghost{background:transparent;border-color:var(--navy);color:var(--navy)}
.btn--ghost:hover{background:var(--navy);color:#fff;transform:translateY(-3px)}
.btn--block{width:100%}

.link-arrow{display:inline-flex;align-items:center;gap:.45em;font-weight:600;color:var(--terra);font-size:.95rem}
.link-arrow::after{content:"→";transition:transform .25s var(--ease)}
.link-arrow:hover::after{transform:translateX(5px)}

/* ============================================================
   SECTION HEADERS / shared
   ============================================================ */
.eyebrow{display:inline-flex;align-items:center;gap:.55em;font-weight:600;font-size:.8rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--terra);margin:0 0 .9em}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--orange);border-radius:2px}
.eyebrow--light{color:#f3c9a3}
.eyebrow--light::before{background:var(--orange)}
.sec-head{max-width:760px;margin-bottom:clamp(2.2rem,5vw,3.4rem)}
.sec-head--center{margin-inline:auto;text-align:center}
.sec-head--center .eyebrow{justify-content:center}
.sec-title{font-size:clamp(1.7rem,3.6vw,2.7rem);color:var(--navy);font-weight:700}
.sec-title--light{color:#fff}
.sec-title .amp{color:var(--orange)}
.sec-lead{font-size:clamp(1.02rem,1.4vw,1.18rem);color:var(--muted);margin-top:1em}
.sec-lead--light{color:rgba(255,255,255,.82)}
.eyebrow .tick{display:none}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;padding:clamp(40px,7vw,86px) 0 clamp(60px,8vw,110px);overflow:hidden;
  background:radial-gradient(120% 100% at 80% 0%,#fff 0%,var(--cream) 45%,var(--sand) 130%)}
.hero__bg{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
/* 21st.dev-style aurora — warm brand wash, masked top-right behind portrait */
.aurora{position:absolute;inset:-25%;will-change:background-position;filter:blur(62px) saturate(1.08);opacity:.4;
  background:
    repeating-linear-gradient(102deg,#fff 0%,#fff 6%,transparent 9%,transparent 12%,#fff 15%),
    repeating-linear-gradient(102deg,var(--orange) 8%,var(--terra) 14%,var(--sand) 20%,var(--navy) 26%,var(--orange) 32%);
  background-size:280% 220%,220% 180%;
  -webkit-mask-image:radial-gradient(120% 95% at 78% 8%,#000 6%,transparent 66%);
          mask-image:radial-gradient(120% 95% at 78% 8%,#000 6%,transparent 66%);
  animation:auroraShift 24s linear infinite}
@keyframes auroraShift{0%{background-position:0% 50%,100% 50%}50%{background-position:100% 50%,0% 50%}100%{background-position:0% 50%,100% 50%}}
.hero__glow{position:absolute;width:46vw;max-width:560px;aspect-ratio:1;right:-8%;top:-8%;border-radius:50%;
  background:radial-gradient(circle,rgba(230,126,34,.15),transparent 60%);filter:blur(8px)}
.blob{position:absolute;filter:blur(2px);opacity:.9}
.blob--orange{width:min(46vw,560px);right:-9%;top:-12%;fill:var(--orange);opacity:.16;animation:float1 16s ease-in-out infinite}
.blob--navy{width:min(34vw,420px);left:-12%;bottom:-18%;fill:var(--navy);opacity:.10;animation:float2 20s ease-in-out infinite}
@keyframes float1{0%,100%{transform:translate(0,0) rotate(0)}50%{transform:translate(-18px,22px) rotate(8deg)}}
@keyframes float2{0%,100%{transform:translate(0,0) rotate(0)}50%{transform:translate(20px,-16px) rotate(-6deg)}}
.dots{position:absolute;width:180px;height:180px;
  background-image:radial-gradient(var(--orange) 2px,transparent 2.4px);background-size:18px 18px;opacity:.28}
.dots--hero{left:46%;bottom:8%}

.hero__grid{position:relative;z-index:2;display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.hero__eyebrow{display:inline-flex;align-items:center;gap:.6em;font-weight:600;font-size:.8rem;letter-spacing:.04em;
  color:var(--navy);background:rgba(255,255,255,.7);border:1px solid var(--line);padding:.5em .9em;border-radius:999px;margin:0 0 1.4em}
.hero__eyebrow .tick{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--orange)}
.hero__title{font-size:clamp(2.1rem,5vw,3.85rem);color:var(--navy);font-weight:800;letter-spacing:-.02em;margin-bottom:.55em}
.hero__title .hl{position:relative;color:var(--orange);white-space:nowrap}
.hero__title .hl::after{content:"";position:absolute;left:-2%;right:-2%;bottom:.06em;height:.28em;background:rgba(230,126,34,.18);z-index:-1;border-radius:4px}
.hero__sub{font-size:clamp(1.02rem,1.4vw,1.2rem);color:#4b4337;max-width:36em;margin-bottom:1.8em}
.hero__sub strong{color:var(--navy)}
.hero__actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-bottom:1.8em}
.hero__pills{display:flex;flex-wrap:wrap;gap:.6rem;list-style:none;padding:0;margin:0}
.pill{font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--navy);
  background:rgba(255,255,255,.65);border:1px solid var(--line);padding:.5em .95em;border-radius:999px}

/* Portrait treatment — organic, branded */
.portrait{position:relative;width:min(100%,420px);margin-inline:auto;aspect-ratio:3/4;
  border-radius:48% 48% 46% 46%/40% 40% 60% 60%;overflow:hidden;box-shadow:var(--shadow-lg);
  background:var(--navy)}
.portrait img{width:100%;height:100%;object-fit:cover;object-position:50% 22%;
  filter:saturate(1.04) contrast(1.03)}
.portrait--hero{animation:portraitIn 1s var(--ease) both}
@keyframes portraitIn{from{opacity:0;transform:translateY(28px) scale(.97)}to{opacity:1;transform:none}}
.portrait__ring{position:absolute;inset:-3px;border-radius:inherit;
  background:linear-gradient(135deg,var(--orange),var(--terra) 50%,var(--navy));z-index:-1}
.hero__media{position:relative}
.hero__media::before{content:"";position:absolute;width:140px;height:140px;right:-16px;top:-8px;z-index:-1;
  background-image:linear-gradient(var(--navy) 1px,transparent 1px),linear-gradient(90deg,var(--navy) 1px,transparent 1px);
  background-size:20px 20px;opacity:.12;
  -webkit-mask-image:radial-gradient(circle,#000,transparent 70%);mask-image:radial-gradient(circle,#000,transparent 70%)}
.portrait__tag{position:absolute;left:0;bottom:34px;z-index:3;background:#fff;border-radius:14px;padding:.7em 1.05em;
  box-shadow:var(--shadow);display:flex;flex-direction:column;line-height:1.15;animation:tagIn 1.1s .5s var(--ease) both}
@keyframes tagIn{from{opacity:0;transform:translateX(-16px)}to{opacity:1;transform:none}}
.portrait__tag-k{font-weight:800;color:var(--orange);font-size:1.15rem}
.portrait__tag-v{font-size:.8rem;color:var(--muted)}

.scrollcue{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);width:26px;height:42px;
  border:2px solid rgba(31,58,95,.35);border-radius:14px;z-index:3}
.scrollcue span{position:absolute;left:50%;top:8px;width:4px;height:8px;background:var(--orange);border-radius:2px;
  transform:translateX(-50%);animation:cue 1.6s infinite}
@keyframes cue{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,12px)}}

/* ============================================================
   DUAS FRENTES
   ============================================================ */
.frentes{background:var(--cream)}
.frentes__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.2rem,2.5vw,2rem)}
.frente{position:relative;padding:clamp(1.8rem,3vw,2.6rem);border-radius:var(--radius-lg);background:#fff;
  border:1px solid var(--line);box-shadow:var(--shadow-sm);overflow:hidden;transition:.4s var(--ease)}
.frente::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--orange)}
.frente--alt::before{background:var(--navy)}
.frente:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.frente__label{display:inline-block;font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  color:var(--terra);margin-bottom:.9em}
.frente--alt .frente__label{color:var(--navy)}
.frente__title{font-size:clamp(1.4rem,2.4vw,1.9rem);color:var(--navy);margin-bottom:.5em}
.frente p{color:var(--muted);margin-bottom:1.2em}

/* ============================================================
   A GERMANA
   ============================================================ */
.germana{background:linear-gradient(180deg,var(--cream),#fff);overflow:hidden}
.germana__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.germana__media{position:relative}
.portrait--about{width:min(100%,400px);border-radius:46% 46% 48% 48%/38% 38% 62% 62%;box-shadow:var(--shadow)}
.portrait--about img{object-position:50% 18%}
.stat-card{position:absolute;right:-6px;bottom:-26px;max-width:240px;background:var(--navy);color:#fff;
  border-radius:18px;padding:1.1em 1.2em;box-shadow:var(--shadow-lg)}
.stat-card__num{font-size:2.4rem;font-weight:800;color:var(--orange);line-height:1;margin:0 0 .2em}
.stat-card__txt{font-size:.82rem;color:rgba(255,255,255,.88);margin:0 0 .5em;line-height:1.4}
.stat-card__src{font-size:.68rem;color:rgba(255,255,255,.55);margin:0}
.germana__copy p{color:#4b4337}
.germana__copy .sec-title{margin-bottom:.7em}
.pullquote{font-family:var(--script);font-size:clamp(1.5rem,2.6vw,2.1rem);color:var(--terra);line-height:1.3;
  margin:1.4em 0;padding-left:1em;border-left:4px solid var(--orange)}
.traj{list-style:none;padding:0;margin:1.5em 0 0;display:grid;gap:.7em}
.traj li{position:relative;padding-left:1.7em;color:var(--muted);font-size:.96rem}
.traj li::before{content:"";position:absolute;left:0;top:.5em;width:9px;height:9px;border-radius:50%;
  background:var(--orange);box-shadow:0 0 0 4px rgba(230,126,34,.15)}
.traj li span{color:var(--navy);font-weight:600}

/* wave divider */
.wave{position:absolute;left:0;right:0;height:60px;background-repeat:no-repeat;background-size:cover;z-index:1}
.wave--top{top:-1px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 60' preserveAspectRatio='none'%3E%3Cpath fill='%23F7F3EC' d='M0,0 C360,60 1080,60 1440,0 L1440,0 L0,0 Z'/%3E%3C/svg%3E")}

/* ============================================================
   BANDEIRAS  (fundo navy)
   ============================================================ */
.bandeiras{background:var(--navy);position:relative;overflow:hidden}
.bandeiras::before{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:52px 52px;
  -webkit-mask-image:radial-gradient(ellipse 75% 65% at 50% 35%,#000,transparent 78%);
          mask-image:radial-gradient(ellipse 75% 65% at 50% 35%,#000,transparent 78%)}
.bandeiras__grid{position:relative;display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.1rem,2vw,1.8rem)}
.flag{position:relative;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius-lg);padding:clamp(1.6rem,2.6vw,2.3rem);color:#fff;transition:.4s var(--ease);overflow:hidden}
.flag::after{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;background:var(--orange);transform:scaleX(0);
  transform-origin:left;transition:transform .45s var(--ease)}
.flag:hover{transform:translateY(-8px);background:rgba(255,255,255,.09)}
.flag:hover::after{transform:scaleX(1)}
.flag--feature{background:linear-gradient(160deg,var(--orange),var(--terra));border-color:transparent}
.flag--feature:hover{background:linear-gradient(160deg,var(--orange-d),var(--terra))}
.flag__icon{width:52px;height:52px;border-radius:14px;background:rgba(255,255,255,.12);display:grid;place-items:center;margin-bottom:1.1em}
.flag--feature .flag__icon{background:rgba(255,255,255,.22)}
.flag__icon svg{width:26px;height:26px;fill:none;stroke:#fff;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.flag__star{font-size:.74rem;font-weight:700;letter-spacing:.06em;color:#f3c9a3;text-transform:uppercase}
.flag--feature .flag__star{color:rgba(255,255,255,.9)}
.flag__title{font-size:1.32rem;margin:.4em 0 .55em}
.flag p{color:rgba(255,255,255,.8);font-size:.96rem;margin-bottom:1.2em}
.flag .link-arrow{color:#fff}
.flag--feature .link-arrow{color:#fff}

/* ============================================================
   PLANO DE GOVERNO
   ============================================================ */
.plano{background:linear-gradient(180deg,#fff,var(--cream))}
.chips{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:clamp(2rem,4vw,3rem)}
.chip{font-size:.88rem;font-weight:600;color:var(--navy);background:#fff;border:1.5px solid var(--line);
  padding:.55em 1.1em;border-radius:999px;transition:.25s var(--ease)}
.chip:hover{border-color:var(--orange);color:var(--orange)}
.chip.is-active{background:var(--navy);color:#fff;border-color:var(--navy)}
.eixo{margin-bottom:clamp(2.4rem,5vw,3.6rem)}
.eixo.is-dim{display:none}
.eixo__head{display:flex;flex-wrap:wrap;align-items:baseline;gap:.4em 1em;padding-bottom:1.1em;margin-bottom:1.4em;
  border-bottom:2px solid var(--line)}
.eixo__n{font-size:.78rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--orange)}
.eixo__title{font-size:clamp(1.4rem,2.6vw,2rem);color:var(--navy)}
.eixo__desc{flex-basis:100%;color:var(--muted);font-size:.98rem;margin:0}
.props{display:grid;gap:.9rem}
.prop{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm);transition:.3s var(--ease)}
.prop[open]{box-shadow:var(--shadow)}
.prop--flag{border-color:rgba(230,126,34,.4)}
.prop summary{list-style:none;display:flex;align-items:center;gap:.8em;padding:1.05em 1.3em;font-weight:600;
  color:var(--navy);font-size:1.05rem;cursor:pointer;transition:background .2s}
.prop summary::-webkit-details-marker{display:none}
.prop summary:hover{background:rgba(247,243,236,.7)}
.prop__badge{color:var(--orange);font-size:1.1rem}
.prop__name{flex:1}
.prop__chev{width:11px;height:11px;border-right:2.5px solid var(--terra);border-bottom:2.5px solid var(--terra);
  transform:rotate(45deg);transition:transform .3s var(--ease);flex-shrink:0;margin-right:.2em}
.prop[open] .prop__chev{transform:rotate(-135deg)}
.prop__body{padding:0 1.3em 1.4em;animation:propOpen .4s var(--ease)}
@keyframes propOpen{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.prop__resumo{font-size:1.02rem;color:var(--ink);font-weight:500;padding:.4em 0 1em;border-top:1px solid var(--line)}
.prop__fields{margin:0;display:grid;gap:.2em}
.prop__fields dt{font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--terra);margin-top:.9em}
.prop__fields dd{margin:0;color:var(--muted);font-size:.96rem}
.prop__src{margin:1.1em 0 0;font-size:.78rem;color:var(--navy);font-weight:600;opacity:.7}

/* ============================================================
   DADOS — A CONTA É PÚBLICA  (fundo terra/orange)
   ============================================================ */
.dados{background:linear-gradient(160deg,var(--terra),var(--orange));position:relative;overflow:hidden}
.dados::before{content:"";position:absolute;right:-6%;top:-30%;width:480px;height:480px;border-radius:50%;
  background:rgba(255,255,255,.07)}
.dados__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.1rem,2vw,1.8rem)}
.data{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-lg);
  padding:clamp(1.6rem,2.6vw,2.2rem);color:#fff;backdrop-filter:blur(4px);transition:.4s var(--ease)}
.data:hover{transform:translateY(-6px);background:rgba(255,255,255,.18)}
.data__num{font-size:clamp(2.6rem,5vw,3.6rem);font-weight:800;line-height:1;margin:0 0 .35em;display:flex;align-items:baseline;gap:.08em}
.data__pre{font-size:.5em;font-weight:700;opacity:.9}
.data__unit{font-size:.42em;font-weight:700;opacity:.9;margin-left:.1em}
.data__txt{color:rgba(255,255,255,.92);font-size:.98rem;margin-bottom:1em}
.data__src{font-size:.76rem;font-weight:600;color:rgba(255,255,255,.7);border-top:1px solid rgba(255,255,255,.25);padding-top:.7em;margin:0}
.dados__gate{text-align:center;color:rgba(255,255,255,.85);font-size:.86rem;margin:clamp(1.8rem,3vw,2.4rem) 0 0;font-style:italic}

/* ============================================================
   TRANSPARÊNCIA
   ============================================================ */
.transp{background:var(--cream)}
.transp__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.transp__copy p{color:#4b4337}
.transp__copy .sec-title{margin-bottom:.6em}
.transp__regua{margin-top:1em;color:var(--navy)!important}
.transp__cards{display:grid;gap:1rem}
.commit{display:flex;gap:1.1em;background:#fff;border:1px solid var(--line);border-radius:18px;padding:1.4em 1.5em;
  box-shadow:var(--shadow-sm);transition:.3s var(--ease)}
.commit:hover{transform:translateX(6px);box-shadow:var(--shadow)}
.commit__n{font-size:1.6rem;font-weight:800;color:var(--orange);line-height:1;flex-shrink:0}
.commit h4{color:var(--navy);font-size:1.08rem;margin-bottom:.3em}
.commit p{color:var(--muted);font-size:.92rem;margin:0}

/* ============================================================
   NOTÍCIAS
   ============================================================ */
.noticias{background:#fff}
.noticias__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2.4vw,1.8rem)}
.post{border-radius:var(--radius-lg);overflow:hidden;background:var(--cream);border:1px solid var(--line);
  box-shadow:var(--shadow-sm);transition:.4s var(--ease);display:flex;flex-direction:column}
.post:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.post__media{position:relative;aspect-ratio:16/10;display:flex;align-items:flex-end;padding:1em}
.post__media--a{background:linear-gradient(135deg,var(--navy),#33597f)}
.post__media--b{background:linear-gradient(135deg,var(--terra),var(--orange))}
.post__media--c{background:linear-gradient(135deg,#3a6b4f,#5a9b73)}
.post__media::after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.16) 1.5px,transparent 2px);background-size:16px 16px;opacity:.5}
.post__cat{position:relative;z-index:1;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:#fff;background:rgba(0,0,0,.22);padding:.4em .8em;border-radius:999px}
.post__body{padding:1.4em 1.5em 1.7em;flex:1}
.post__date{font-size:.78rem;color:var(--terra);font-weight:600;margin-bottom:.5em}
.post__title{font-size:1.18rem;color:var(--navy);margin-bottom:.55em;line-height:1.25}
.post__body p{color:var(--muted);font-size:.92rem;margin:0}

/* ============================================================
   AGENDA
   ============================================================ */
.agenda{background:linear-gradient(180deg,#fff,var(--cream))}
.agenda__list{list-style:none;padding:0;margin:0;display:grid;gap:1rem;max-width:820px}
.ev{display:flex;align-items:center;gap:1.4em;background:#fff;border:1px solid var(--line);border-radius:18px;
  padding:1.1em 1.4em;box-shadow:var(--shadow-sm);transition:.3s var(--ease)}
.ev:hover{transform:translateX(8px);box-shadow:var(--shadow);border-color:rgba(230,126,34,.4)}
.ev__date{flex-shrink:0;width:64px;height:64px;border-radius:14px;background:var(--navy);color:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1}
.ev__d{font-size:1.5rem;font-weight:800}
.ev__m{font-size:.68rem;font-weight:700;letter-spacing:.1em;color:var(--orange)}
.ev__city{font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--terra)}
.ev__info h3{font-size:1.1rem;color:var(--navy);margin:.15em 0}
.ev__info p{font-size:.86rem;color:var(--muted);margin:0}

/* ============================================================
   PARTICIPE
   ============================================================ */
.participe{background:var(--navy);position:relative;overflow:hidden}
.participe::before{content:"";position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:52px 52px;
  -webkit-mask-image:radial-gradient(ellipse 85% 75% at 30% 30%,#000,transparent 80%);
          mask-image:radial-gradient(ellipse 85% 75% at 30% 30%,#000,transparent 80%)}
.blob--cta{position:absolute;width:min(50vw,560px);right:-12%;top:-20%;aspect-ratio:1;border-radius:46% 54% 60% 40%/50% 40% 60% 50%;
  background:radial-gradient(circle at 30% 30%,rgba(230,126,34,.5),rgba(219,92,56,.25) 60%,transparent 75%);filter:blur(10px)}
.participe__grid{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.participe__ways{list-style:none;padding:0;margin:1.6em 0 0;display:grid;gap:.9em}
.participe__ways li{color:rgba(255,255,255,.82);font-size:.98rem;padding-left:1.6em;position:relative}
.participe__ways li::before{content:"✓";position:absolute;left:0;color:var(--orange);font-weight:800}
.participe__ways strong{color:#fff}
.form{background:#fff;border-radius:var(--radius-lg);padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--shadow-lg)}
.form__title{font-size:1.3rem;color:var(--navy);margin-bottom:1.2em}
.field{margin-bottom:1em}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1em}
.field label{display:block;font-size:.82rem;font-weight:600;color:var(--navy);margin-bottom:.4em}
.field input,.field select{width:100%;padding:.8em 1em;border:1.5px solid var(--line);border-radius:12px;
  font-family:inherit;font-size:.95rem;color:var(--ink);background:var(--cream);transition:.2s}
.field input:focus,.field select:focus{outline:none;border-color:var(--orange);background:#fff;box-shadow:0 0 0 4px rgba(230,126,34,.12)}
.check{display:flex;gap:.7em;align-items:flex-start;font-size:.8rem;color:var(--muted);margin:.4em 0 1.3em;cursor:pointer}
.check input{margin-top:.2em;width:18px;height:18px;accent-color:var(--orange);flex-shrink:0}
.form__ok{margin:1em 0 0;text-align:center;color:#2f7a4f;font-weight:600;background:#eaf7ef;border-radius:12px;padding:.8em}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--navy-d);color:rgba(255,255,255,.75)}
.footer__grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.3fr;gap:2.4rem clamp(1.5rem,3vw,3rem);align-items:start;padding:clamp(3rem,6vw,5rem) 0 2.6rem}
.footer__desc{font-size:.9rem;margin:1.2em 0;max-width:30ch}
.footer__phrase{font-family:var(--script);font-size:1.25rem;color:#f3c9a3;line-height:1.3}
.footer__col h4{color:#fff;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.1em}
.footer__col a{display:block;font-size:.92rem;padding:.32em 0;opacity:.78;transition:.2s}
.footer__col a:hover{opacity:1;color:var(--orange);transform:translateX(3px)}
.footer__contact p{font-size:.9rem;margin:0 0 .5em}
.footer__contact a{opacity:.9}
.footer__contact a:hover{color:var(--orange)}
.social{display:flex;gap:1.15em;margin-top:1.1em}
.social__a{display:inline-grid;place-items:center;background:none;border:0;padding:0;transition:transform .25s var(--ease)}
.social__a:hover{transform:translateY(-3px)}
.social__a svg{width:22px;height:22px;fill:none;stroke:rgba(255,255,255,.72);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;transition:stroke .25s var(--ease)}
.social__a:hover svg{stroke:var(--orange)}
.social__a svg path[d^="M14 7h2"]{fill:rgba(255,255,255,.72);stroke:none;transition:fill .25s var(--ease)}
.social__a:hover svg path[d^="M14 7h2"]{fill:var(--orange)}
.footer__legal{border-top:1px solid rgba(255,255,255,.1);padding:1.5em 0}
.footer__legal p{font-size:.78rem;margin:0;opacity:.6}
.footer__legal strong{color:rgba(255,255,255,.85)}
.footer__credit{margin-top:.4em!important;font-size:.72rem!important;opacity:.45!important}

/* ============================================================
   FAB
   ============================================================ */
.fab{position:fixed;right:18px;bottom:18px;z-index:55;display:inline-flex;align-items:center;gap:.5em;
  background:var(--orange);color:#fff;font-weight:600;font-size:.9rem;padding:.75em 1.2em;border-radius:999px;
  box-shadow:0 14px 30px rgba(230,126,34,.4);transform:translateY(120px);transition:.4s var(--ease)}
.fab.is-shown{transform:translateY(0)}
.fab:hover{background:var(--orange-d);transform:translateY(-3px)}
.fab svg{width:18px;height:18px;fill:#fff}
@media (max-width:560px){.fab span{display:none}.fab{padding:.85em;border-radius:50%}}

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .blob,.portrait--hero,.portrait__tag,.tsebar__dot,.scrollcue span{animation:none}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .hero__grid,.germana__grid,.transp__grid,.participe__grid{grid-template-columns:1fr}
  .germana__media{order:2;max-width:420px;margin-inline:auto}
  .germana__copy{order:1}
  .stat-card{position:static;max-width:none;margin-top:1.4rem}
  .bandeiras__grid,.dados__grid,.noticias__grid{grid-template-columns:1fr 1fr}
  .footer__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .nav{position:fixed;inset:0 0 0 auto;width:min(82vw,330px);background:var(--cream);flex-direction:column;
    align-items:flex-start;justify-content:flex-start;gap:.3rem;padding:90px 1.6rem 2rem;
    box-shadow:-20px 0 60px rgba(31,58,95,.2);transform:translateX(100%);transition:transform .4s var(--ease);z-index:50}
  .nav.is-open{transform:translateX(0)}
  .nav__link{font-size:1.05rem;width:100%;padding:.7em 0;border-bottom:1px solid var(--line)}
  .nav__link::after{display:none}
  .nav__cta{margin-top:1rem;width:100%;text-align:center}
  .burger{display:flex;z-index:60}
  .frentes__grid,.bandeiras__grid,.dados__grid,.noticias__grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .hero__title{font-size:clamp(2rem,8vw,2.6rem)}
}
@media (max-width:760px){
  body.nav-open{overflow:hidden}
  .nav-scrim{position:fixed;inset:0;background:rgba(22,41,63,.45);opacity:0;visibility:hidden;transition:.3s;z-index:45}
  .nav-scrim.is-open{opacity:1;visibility:visible}
}

/* ============================================================
   21ST.DEV-INSPIRED EFFECTS — grain, spotlight, marquee
   ============================================================ */

/* Film grain / noise overlay — kills the flat "AI" look */
body::before{content:"";position:fixed;inset:0;z-index:300;pointer-events:none;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* Spotlight cards — cursor-follow radial glow (ported from 21st.dev Spotlight Card) */
.spot{position:relative}
.spot::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;opacity:0;z-index:4;
  transition:opacity .4s var(--ease);
  background:radial-gradient(440px circle at var(--mx,50%) var(--my,50%),var(--spot,rgba(230,126,34,.22)),transparent 56%)}
.spot:hover::after,.spot:focus-within::after{opacity:1}
/* dark cards: lighten with a warm spotlight */
.flag.spot{--spot:rgba(243,201,163,.55)}
.flag.spot::after{mix-blend-mode:screen}
.flag--feature.spot{--spot:rgba(255,255,255,.5)}
/* light cards: warm multiply vignette follows cursor */
.post.spot,.ev.spot,.commit.spot{--spot:rgba(230,126,34,.18)}
.post.spot::after,.ev.spot::after,.commit.spot::after{mix-blend-mode:multiply}

/* Editorial marquee ticker */
.marquee{background:var(--orange);color:#fff;overflow:hidden;padding:.95em 0;position:relative;
  border-block:1px solid rgba(0,0,0,.06)}
.marquee__track{display:inline-flex;align-items:center;gap:1.5rem;white-space:nowrap;
  font-weight:700;font-size:.92rem;letter-spacing:.12em;text-transform:uppercase;
  animation:marquee 34s linear infinite;will-change:transform}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__track .star{color:var(--navy);font-size:.8em;transform:translateY(-1px)}
@keyframes marquee{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){
  .aurora,.marquee__track{animation:none}
}

/* TSE notice moved to footer */
.tsebar--footer{background:transparent;color:rgba(255,255,255,.6);border-top:1px solid rgba(255,255,255,.08)}

/* ============================================================
   NOTÍCIAS — blog layout (shadcn/21st.dev style)
   ============================================================ */
.blog__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,3vw,2.4rem)}
.bpost{display:flex;flex-direction:column;gap:1rem;cursor:pointer;transition:opacity .3s var(--ease),transform .45s var(--ease)}
.bpost:hover{opacity:.82}
.bpost:hover .bpost__media{transform:translateY(-4px)}
.bpost--feature{grid-column:1 / -1}
.bpost__media{position:relative;overflow:hidden;border-radius:16px;aspect-ratio:16/10;box-shadow:var(--shadow-sm);transition:transform .45s var(--ease)}
.bpost--feature .bpost__media{aspect-ratio:24/7}
.bpost__media.post__media--a{background:linear-gradient(135deg,var(--navy),#33597f)}
.bpost__media.post__media--b{background:linear-gradient(135deg,var(--terra),var(--orange))}
.bpost__media.post__media--c{background:linear-gradient(135deg,#3a6b4f,#5a9b73)}
.bpost__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:0}
.bpost__media::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(31,58,95,.12) 0%,transparent 32%,transparent 62%,rgba(22,41,63,.34) 100%)}
.bpost__meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.badge{display:inline-flex;align-items:center;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#fff;background:var(--navy);padding:.4em .85em;border-radius:8px}
.byline{display:inline-flex;align-items:center;gap:.5em;font-size:.86rem;color:var(--ink)}
.byline .muted{color:var(--muted)}
.byline .avatar{width:24px;height:24px;border-radius:50%;overflow:hidden;flex-shrink:0;border:1px solid var(--line)}
.byline .avatar img{width:100%;height:100%;object-fit:cover;object-position:50% 16%}
.bpost__text{display:flex;flex-direction:column;gap:.5rem}
.bpost__title{color:var(--navy);font-size:1.4rem;line-height:1.2;letter-spacing:-.01em}
.bpost--feature .bpost__title{font-size:clamp(1.7rem,2.8vw,2.3rem);max-width:20ch}
.bpost__text p{color:var(--muted);margin:0;max-width:62ch}
@media (max-width:760px){
  .blog__grid{grid-template-columns:1fr}
  .bpost--feature .bpost__media{aspect-ratio:16/10}
}

/* ============================================================
   AGENDA — mapa interativo (MapLibre GL, 21st.dev style)
   ============================================================ */
.agenda__map-wrap{position:relative}
.agenda__map{display:none;height:clamp(380px,52vh,560px);border-radius:20px;overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow)}
.agenda__fallback{list-style:none;margin:0;padding:0;display:grid;gap:.8rem;max-width:820px}
.agenda__fallback li{background:#fff;border:1px solid var(--line);border-radius:14px;padding:1em 1.2em;color:var(--muted);box-shadow:var(--shadow-sm)}
.agenda__fallback strong{color:var(--navy)}
/* teardrop pin */
.mappin{width:38px;height:38px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);
  background:var(--navy);border:3px solid #fff;box-shadow:0 6px 16px rgba(31,58,95,.4);cursor:pointer;
  display:grid;place-items:center;transition:background .25s var(--ease),transform .25s var(--ease)}
.mappin:hover{background:var(--orange);transform:rotate(-45deg) scale(1.08)}
.mappin__d{transform:rotate(45deg);color:#fff;font-weight:800;font-size:.82rem;line-height:1}
/* popup */
.maplibregl-popup-content{border-radius:14px;padding:14px 32px 14px 16px;box-shadow:var(--shadow);border:1px solid var(--line);font-family:var(--font)}
.maplibregl-popup-close-button{width:24px;height:24px;font-size:16px;color:var(--muted);border-radius:6px;margin:3px 4px 0 0}
.maplibregl-popup-close-button:hover{background:var(--cream);color:var(--navy)}
.mappop{display:flex;flex-direction:column;gap:.25em;max-width:230px}
.mappop__city{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--terra)}
.mappop strong{color:var(--navy);font-size:1rem;line-height:1.25}
.mappop__info{font-size:.82rem;color:var(--muted)}
.maplibregl-ctrl-group{border-radius:10px;overflow:hidden;box-shadow:var(--shadow-sm)}

/* blog card linking (homepage teasers) */
.bpost{position:relative;cursor:pointer}
.bpost__cover{position:absolute;inset:0;z-index:4;border-radius:16px}
.bpost__title a{color:inherit}
.bpost__title a:hover{color:var(--terra)}
.noticias-all{margin-top:1em}
