/* =========================================================
   Isabella Mamedi — identidade visual da campanha
   Paleta, tipografia e sistema de colagem (estrela/fita/tarja)
   ========================================================= */

/* ---------- Fontes (auto-hospedadas) ---------- */
@font-face{font-family:"Hanken";src:url("hanken-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken";src:url("hanken-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken";src:url("hanken-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken";src:url("hanken-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken";src:url("hanken-800.woff2") format("woff2");font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:"Hanken";src:url("hanken-900.woff2") format("woff2");font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:"Garamond";src:url("garamond-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Garamond";src:url("garamond-400-italic.woff2") format("woff2");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"Garamond";src:url("garamond-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}

/* ---------- Tokens ---------- */
:root{
  --cream:#FEFEEE;
  --paper:#FBF7E8;
  --ink:#16181D;
  --ink-soft:#3A3E47;
  --navy:#283151;
  --navy-2:#1F273F;
  --orange:#F04908;
  --green:#52DE80;
  --yellow:#F0CC27;
  --white:#ffffff;

  --sans:"Hanken","Hanken Grotesk",system-ui,"Segoe UI",Roboto,Arial,sans-serif;
  --serif:"Garamond","EB Garamond",Georgia,"Times New Roman",serif;

  --maxw:1200px;
  --gut:clamp(20px,5vw,64px);
  --radius:18px;
  --radius-sm:12px;

  --shadow:0 18px 50px -28px rgba(22,24,29,.45);
  --shadow-card:0 12px 34px -22px rgba(22,24,29,.4);
}

/* ---------- 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;background:var(--cream);color:var(--ink);
  font-family:var(--sans);font-weight:500;line-height:1.55;
  font-size:clamp(16px,1.05vw + 12px,18px);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
:focus-visible{outline:3px solid var(--orange);outline-offset:3px;border-radius:4px}

/* subtle paper grain over the whole page */
body::after{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:clamp(56px,8vw,110px)}
.section--tight{padding-block:clamp(40px,6vw,72px)}
.eyebrow{
  font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(18px,2.2vw,24px);color:var(--orange);margin:0 0 .4em
}
.lead{font-size:clamp(18px,1.4vw,21px);color:var(--ink-soft);max-width:60ch}

/* Headline scale — display in Hanken Black, tight */
h1,h2,h3{font-weight:900;line-height:.98;letter-spacing:-.02em;margin:0}
.h-display{font-size:clamp(40px,6.6vw,78px)}
.h-xl{font-size:clamp(34px,6vw,66px)}
.h-lg{font-size:clamp(26px,3.6vw,40px);line-height:1.02}
.h-md{font-size:clamp(20px,2.4vw,27px);line-height:1.05;letter-spacing:-.01em}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--orange);--fg:var(--cream);
  display:inline-flex;align-items:center;gap:.55em;
  background:var(--bg);color:var(--fg);
  font-weight:800;font-size:1rem;letter-spacing:-.01em;
  padding:.85em 1.4em;border:none;border-radius:999px;cursor:pointer;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
  box-shadow:0 8px 20px -10px rgba(240,73,8,.6);
}
.btn:hover{transform:translateY(-2px) rotate(-.4deg)}
.btn:active{transform:translateY(0)}
.btn--navy{--bg:var(--navy);--fg:var(--cream);box-shadow:0 8px 20px -12px rgba(40,49,81,.7)}
.btn--green{--bg:var(--green);--fg:#0c2a16;box-shadow:0 8px 20px -12px rgba(82,222,128,.7)}
.btn--ghost{--bg:transparent;--fg:var(--ink);border:2px solid var(--ink);box-shadow:none}
.btn--ghost:hover{background:var(--ink);color:var(--cream)}
.btn--lg{font-size:1.08rem;padding:1em 1.7em}
.btn--block{display:flex;width:100%;justify-content:center}
.btn .arrow{transition:transform .15s ease}
.btn:hover .arrow{transform:translateX(3px)}

/* ---------- Nav ---------- */
.nav{
  position:sticky;top:0;z-index:100;
  background:color-mix(in srgb,var(--cream) 88%,transparent);
  backdrop-filter:blur(8px);
  border-bottom:1px solid color-mix(in srgb,var(--ink) 10%,transparent);
}
.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  max-width:var(--maxw);margin-inline:auto;padding:.7rem var(--gut)}
.brand{display:inline-flex;align-items:center;gap:.5rem;font-weight:900;
  letter-spacing:-.03em;font-size:1.22rem;line-height:1}
.brand__mark{width:26px;height:26px;flex:none}
.brand b{color:var(--orange)}
.nav__links{display:flex;align-items:center;gap:1.4rem}
.nav__links a{font-weight:700;font-size:.98rem;color:var(--ink);position:relative}
.nav__links a:not(.btn)::after{content:"";position:absolute;left:0;right:100%;bottom:-4px;height:2px;
  background:var(--orange);transition:right .2s ease}
.nav__links a:not(.btn):hover::after{right:0}
.nav__toggle{display:none;background:none;border:none;cursor:pointer;padding:.4rem}
.nav__toggle svg{display:block}

@media (max-width:860px){
  .nav__links{
    position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;
    gap:0;background:var(--cream);border-bottom:2px solid var(--ink);
    padding:.5rem var(--gut) 1.2rem;
    transform:translateY(-130%);transition:transform .28s cubic-bezier(.4,0,.2,1);
    box-shadow:var(--shadow)
  }
  .nav__links.open{transform:translateY(0)}
  .nav__links a:not(.btn){padding:.85rem 0;border-bottom:1px solid color-mix(in srgb,var(--ink) 12%,transparent)}
  .nav__links a:not(.btn)::after{display:none}
  .nav__links .btn{margin-top:.9rem;justify-content:center}
  .nav__toggle{display:inline-flex}
}

/* ---------- Collage signature pieces ---------- */
.tape{
  position:absolute;width:96px;height:30px;background:rgba(255,255,255,.78);
  box-shadow:0 1px 4px rgba(0,0,0,.12);
  background-image:linear-gradient(90deg,rgba(0,0,0,.05) 0 100%);
}
.tape::before,.tape::after{content:"";position:absolute;top:0;bottom:0;width:7px;
  background:repeating-linear-gradient(180deg,transparent 0 3px,rgba(255,255,255,.5) 3px 6px)}
.tape::before{left:-6px;clip-path:polygon(100% 0,0 25%,100% 50%,0 75%,100% 100%)}
.tape::after{right:-6px;clip-path:polygon(0 0,100% 25%,0 50%,100% 75%,0 100%)}
.strip-navy{background:var(--navy)}

/* Torn divider between sections */
.tear{height:34px;background:var(--navy);position:relative;margin-top:-1px}
.tear--up{clip-path:polygon(0 100%,4% 30%,9% 80%,14% 20%,20% 70%,26% 15%,33% 75%,40% 25%,47% 70%,54% 20%,61% 78%,68% 28%,75% 72%,82% 22%,89% 74%,95% 30%,100% 78%,100% 100%)}
.tear--down{clip-path:polygon(0 0,100% 0,100% 22%,95% 70%,89% 26%,82% 78%,75% 28%,68% 72%,61% 22%,54% 80%,47% 30%,40% 75%,33% 25%,26% 85%,20% 30%,14% 80%,9% 20%,4% 70%,0 22%)}

/* ---------- Hero (full-bleed com fade) ---------- */
.hero{position:relative;min-height:clamp(600px,90vh,860px);display:flex;align-items:center;
  overflow:hidden;isolation:isolate;background:var(--navy)}
.hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 26%;z-index:-2}
.hero__scrim{position:absolute;inset:0;z-index:-1;pointer-events:none;background:
  linear-gradient(90deg, var(--cream) 0%, rgba(254,254,238,.97) 26%, rgba(254,254,238,.55) 41%, rgba(254,254,238,.08) 50%, rgba(254,254,238,0) 64%),
  linear-gradient(to top, rgba(254,254,238,.55) 0%, rgba(254,254,238,0) 26%)}
.hero__inner{width:100%;max-width:var(--maxw);margin-inline:auto;padding:clamp(40px,6vw,72px) var(--gut)}
.hero__copy{position:relative;max-width:clamp(300px,44vw,520px)}
.hero__kicker{display:inline-flex;align-items:center;gap:.5rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;
  background:var(--navy);color:var(--cream);padding:.4rem .8rem;border-radius:999px;margin-bottom:1.1rem;
  box-shadow:0 6px 18px -8px rgba(40,49,81,.5)}
.hero__kicker .dot{width:8px;height:8px;border-radius:50%;background:var(--green)}
.hero h1{font-size:clamp(29px,3.7vw,44px);margin-bottom:.4rem;text-shadow:0 1px 0 rgba(254,254,238,.6)}
.hero h1 .mote{font-family:var(--serif);font-style:italic;font-weight:500;letter-spacing:-.01em;
  color:var(--orange);display:block;font-size:.62em;line-height:1;margin-top:.18em;text-shadow:none}
.hero__sub{font-size:clamp(17px,1.5vw,20px);color:var(--ink-soft);max-width:44ch;margin:1rem 0 1.6rem;font-weight:600}
.hero__cta{display:flex;flex-wrap:wrap;gap:.7rem}
.hero__selo{position:absolute;width:clamp(82px,9vw,116px);right:clamp(16px,4vw,56px);top:clamp(18px,5vw,52px);
  filter:drop-shadow(0 8px 18px rgba(0,0,0,.28));
  display:grid;place-items:center;animation:spin 26s linear infinite;z-index:1}
.hero__selo img{width:100%}
.hero__selo span{position:absolute;color:var(--cream);font-weight:900;font-size:.72rem;line-height:.95;
  text-align:center;text-transform:uppercase;letter-spacing:.02em}
@keyframes spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.hero__selo{animation:none}}

@media (max-width:860px){
  .hero{min-height:clamp(660px,96vh,900px);align-items:stretch}
  .hero__inner{display:flex;padding-top:clamp(18px,3.5vh,36px);padding-bottom:clamp(26px,4.5vh,52px)}
  .hero__img{object-position:50% 16%}
  .hero__copy{display:flex;flex-direction:column;flex:1;max-width:100%}
  .hero__copy > h1{margin-top:auto}
  .hero h1{font-size:clamp(30px,8vw,40px)}
  .hero__sub{font-size:16px;margin:.8rem 0 1.2rem}
  .hero__scrim{background:
    linear-gradient(to top, var(--cream) 0%, rgba(254,254,238,.99) 37%, rgba(254,254,238,.68) 49%, rgba(254,254,238,.1) 59%, rgba(254,254,238,0) 72%)}
  .hero__selo{width:56px;right:10px;top:21%}
}

/* ---------- Statement band ---------- */
.statement{background:var(--navy);color:var(--cream);text-align:left}
.statement .wrap{display:grid;gap:1.4rem}
.statement p.big{font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:clamp(26px,4.4vw,52px);line-height:1.08;letter-spacing:-.01em;max-width:20ch;margin:0}
.statement .sub{max-width:62ch;color:color-mix(in srgb,var(--cream) 82%,transparent);margin:0}
.statement b{color:var(--green)}

/* ---------- Section header ---------- */
.shead{max-width:54ch;margin-bottom:clamp(28px,4vw,48px)}
.shead .num{font-family:var(--serif);font-style:italic;color:var(--orange);font-size:1.1rem;margin-bottom:.3rem;display:block}

/* ---------- Quem é (sobre) ---------- */
.about{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(24px,5vw,64px);align-items:center}
.about__media{position:relative}
.about__media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;object-fit:cover}
.about__media .sun{position:absolute;width:70px;height:70px;border-radius:50%;background:var(--green);right:-14px;bottom:-14px;z-index:-1}
.about__media .tape{top:-14px;right:30px;transform:rotate(-7deg)}
.about__body p{color:var(--ink-soft);max-width:54ch}
.about__body .pull{font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.4vw,28px);
  color:var(--ink);line-height:1.2;border-left:4px solid var(--orange);padding-left:1rem;margin:1.4rem 0}
.about__facts{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.4rem}
.chip{display:inline-flex;gap:.45rem;align-items:center;background:var(--paper);
  border:1.5px solid color-mix(in srgb,var(--ink) 14%,transparent);
  border-radius:999px;padding:.45rem .85rem;font-weight:700;font-size:.92rem}
@media (max-width:820px){.about{grid-template-columns:1fr}.about__media{max-width:440px}}

/* ---------- Bandeiras ---------- */
.flags{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.4vw,26px)}
.flag{position:relative;background:var(--paper);border-radius:var(--radius);overflow:hidden;
  border:1.5px solid color-mix(in srgb,var(--ink) 12%,transparent);box-shadow:var(--shadow-card);
  display:flex;flex-direction:column;transition:transform .18s ease}
.flag:hover{transform:translateY(-4px)}
.flag__top{padding:1.3rem 1.3rem 0}
.flag__icon{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;color:var(--cream);
  font-size:1.5rem;margin-bottom:.9rem}
.flag h3{font-size:1.34rem;letter-spacing:-.01em;line-height:1.04}
.flag p{color:var(--ink-soft);font-size:.98rem;margin:.5rem 0 1.2rem}
.flag__bar{height:8px;width:100%;margin-top:auto}
.flag--cidade .flag__icon{background:var(--orange)} .flag--cidade .flag__bar{background:var(--orange)}
.flag--passe .flag__icon{background:var(--navy)} .flag--passe .flag__bar{background:var(--navy)}
.flag--juv .flag__icon{background:var(--green);color:#0c2a16} .flag--juv .flag__bar{background:var(--green)}
@media (max-width:820px){.flags{grid-template-columns:1fr}}

/* ---------- Participe (4 ações) ---------- */
.parti{background:var(--paper)}
.parti__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(16px,2.4vw,24px)}
.act{position:relative;background:var(--cream);border-radius:var(--radius);padding:1.5rem;
  border:2px solid var(--ink);box-shadow:6px 6px 0 var(--ink);transition:transform .16s ease,box-shadow .16s ease;
  display:flex;flex-direction:column;gap:.6rem}
.act:hover{transform:translate(-2px,-2px);box-shadow:9px 9px 0 var(--ink)}
.act__tag{font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:.74rem;
  align-self:flex-start;padding:.3rem .65rem;border-radius:999px;color:var(--cream)}
.act h3{font-size:1.5rem;line-height:1.02}
.act p{color:var(--ink-soft);font-size:.97rem;margin:0;flex:1}
.act .go{font-weight:800;display:inline-flex;align-items:center;gap:.4rem;margin-top:.4rem}
.act--vaquinha .act__tag{background:var(--orange)} .act--vaquinha{border-color:var(--orange);box-shadow:6px 6px 0 var(--orange)} .act--vaquinha:hover{box-shadow:9px 9px 0 var(--orange)}
.act--pl .act__tag{background:var(--navy)} .act--pl{border-color:var(--navy);box-shadow:6px 6px 0 var(--navy)} .act--pl:hover{box-shadow:9px 9px 0 var(--navy)}
.act--volun .act__tag{background:#1c7e3e} .act--volun{border-color:#1c7e3e;box-shadow:6px 6px 0 #1c7e3e} .act--volun:hover{box-shadow:9px 9px 0 #1c7e3e}
.act--insta .act__tag{background:#b8410d} .act--insta{border-color:#b8410d;box-shadow:6px 6px 0 #b8410d} .act--insta:hover{box-shadow:9px 9px 0 #b8410d}
@media (max-width:760px){.parti__grid{grid-template-columns:1fr}.act{box-shadow:4px 4px 0 var(--ink)}}

/* ---------- Manifesto / GTs (dark) ---------- */
.mani{background:var(--navy);color:var(--cream)}
.mani .eyebrow{color:var(--yellow)}
.mani__intro{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(24px,5vw,56px);align-items:center;margin-bottom:clamp(30px,5vw,56px)}
.mani__intro p{color:color-mix(in srgb,var(--cream) 82%,transparent);max-width:52ch}
.mani__media{position:relative}
.mani__media img{border-radius:var(--radius);width:100%;box-shadow:var(--shadow)}
.mani__media .tape{top:-14px;left:24px;transform:rotate(6deg)}
.gts{display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem}
.gt{background:var(--navy-2);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-sm);
  padding:.95rem 1rem;display:flex;align-items:center;gap:.6rem;font-weight:700;font-size:.96rem}
.gt .pip{width:11px;height:11px;border-radius:3px;flex:none}
@media (max-width:900px){.mani__intro{grid-template-columns:1fr}.gts{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.gts{grid-template-columns:1fr}}

/* ---------- Caixa de sugestões ---------- */
.sugestao{margin-top:1.4rem;background:var(--navy-2);border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius);padding:1.1rem 1.2rem}
.sugestao__text{color:color-mix(in srgb,var(--cream) 86%,transparent);margin-bottom:.7rem;font-size:.98rem}
.sugestao__text strong{color:var(--yellow)}
.sugestao__row{display:flex;gap:.6rem;flex-wrap:wrap}
.sugestao__row input{flex:1 1 260px;font-family:inherit;font-size:1rem;font-weight:600;
  color:var(--cream);background:rgba(255,255,255,.06);
  border:2px solid rgba(255,255,255,.2);border-radius:12px;padding:.75rem .9rem}
.sugestao__row input::placeholder{color:rgba(254,254,238,.5);font-weight:500}
.sugestao__row input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(82,222,128,.2)}
.sugestao__row .btn{flex:0 0 auto}
.sugestao .formstatus{background:rgba(255,255,255,.08);color:var(--cream);border:1px solid rgba(255,255,255,.2)}
.sugestao .formstatus.ok{background:rgba(82,222,128,.16);border-color:rgba(82,222,128,.5)}
.sugestao .formstatus.err{background:rgba(240,73,8,.16);border-color:rgba(240,73,8,.5)}

/* ---------- Timeline ---------- */
.timeline{display:flex;gap:1rem;flex-wrap:wrap;counter-reset:t}
.tl{flex:1 1 150px;background:var(--paper);border-radius:var(--radius-sm);padding:1.1rem;
  border-top:6px solid var(--orange)}
.tl:nth-child(2){border-top-color:var(--green)}
.tl:nth-child(3){border-top-color:var(--navy)}
.tl:nth-child(4){border-top-color:var(--yellow)}
.tl .date{font-weight:900;font-size:1.25rem;letter-spacing:-.02em}
.tl .lbl{color:var(--ink-soft);font-size:.94rem;margin-top:.2rem}

/* ---------- Redes ---------- */
.redes{background:var(--orange);color:var(--cream);text-align:center}
.redes .wrap{display:grid;gap:1.2rem;justify-items:center}
.redes h2{max-width:16ch}
.redes .handle{font-family:var(--serif);font-style:italic;font-size:clamp(22px,3vw,34px)}
.redes .btn{background:var(--cream);color:var(--ink)}
.redes__btns{display:flex;gap:.7rem;flex-wrap:wrap;justify-content:center}

/* ---------- Footer ---------- */
.foot{background:var(--ink);color:color-mix(in srgb,var(--cream) 80%,transparent)}
.foot .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;padding-block:clamp(40px,6vw,64px)}
.foot .brand{color:var(--cream);font-size:1.5rem}
.foot h4{color:var(--cream);font-size:.86rem;text-transform:uppercase;letter-spacing:.08em;margin:0 0 .8rem}
.foot a{display:block;padding:.28rem 0;font-weight:600}
.foot a:hover{color:var(--orange)}
.foot__legal{border-top:1px solid rgba(255,255,255,.12);margin-top:1rem}
.foot__legal .wrap{grid-template-columns:1fr;gap:.4rem;padding-block:1.2rem;font-size:.85rem;
  color:color-mix(in srgb,var(--cream) 60%,transparent)}
@media (max-width:760px){.foot .wrap{grid-template-columns:1fr 1fr}.foot .brandcol{grid-column:1/-1}}

/* ---------- Forms ---------- */
.formwrap{max-width:680px}
.formcard{background:var(--paper);border:2px solid var(--ink);border-radius:var(--radius);
  box-shadow:8px 8px 0 var(--ink);padding:clamp(1.3rem,3vw,2.2rem)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-weight:800;margin-bottom:.4rem;font-size:.96rem}
.field label .req{color:var(--orange)}
.field .hint{font-weight:500;color:var(--ink-soft);font-size:.84rem;margin-top:.3rem}
.field input,.field select{
  width:100%;font-family:inherit;font-size:1rem;font-weight:600;color:var(--ink);
  background:var(--cream);border:2px solid color-mix(in srgb,var(--ink) 30%,transparent);
  border-radius:12px;padding:.8rem .9rem;transition:border-color .15s ease,box-shadow .15s ease}
.field input:focus,.field select:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(240,73,8,.18)}
.field input::placeholder{color:color-mix(in srgb,var(--ink) 40%,transparent);font-weight:500}
.field--row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media (max-width:560px){.field--row{grid-template-columns:1fr}}
.checks{display:grid;gap:.7rem;margin:1.2rem 0}
.check{display:flex;gap:.7rem;align-items:flex-start;font-size:.92rem;color:var(--ink-soft);line-height:1.4}
.check input{width:20px;height:20px;flex:none;margin-top:2px;accent-color:var(--orange)}
.check a{color:var(--orange);font-weight:700;text-decoration:underline}
.themechips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}
.themechips label{display:inline-flex;align-items:center;gap:.4rem;background:var(--cream);
  border:2px solid color-mix(in srgb,var(--ink) 22%,transparent);border-radius:999px;
  padding:.45rem .8rem;font-weight:700;font-size:.9rem;cursor:pointer;transition:.15s}
.themechips input{position:absolute;opacity:0;width:0;height:0}
.themechips label:has(input:checked){background:var(--navy);color:var(--cream);border-color:var(--navy)}
.formnote{font-size:.86rem;color:var(--ink-soft);margin-top:1rem}
.formstatus{margin-top:1rem;padding:.9rem 1rem;border-radius:12px;font-weight:700;display:none}
.formstatus.show{display:block}
.formstatus.err{background:#fde7df;color:#9a2c08;border:1.5px solid #f0a98e}
.formstatus.ok{background:#e3f9ec;color:#0c5a2c;border:1.5px solid #8fe0ab}

/* ---------- Page hero (internal pages) ---------- */
.phero{background:var(--navy);color:var(--cream);padding-block:clamp(40px,6vw,72px)}
.phero .back{display:inline-flex;gap:.4rem;align-items:center;font-weight:700;color:var(--yellow);margin-bottom:1rem}
.phero h1{margin-bottom:.6rem}
.phero p{color:color-mix(in srgb,var(--cream) 82%,transparent);max-width:62ch}
.phero .mote{font-family:var(--serif);font-style:italic;color:var(--green)}

/* ---------- Info callout ---------- */
.callout{background:var(--cream);border:2px dashed color-mix(in srgb,var(--navy) 40%,transparent);
  border-radius:var(--radius);padding:1.2rem 1.3rem;margin-bottom:1.6rem}
.callout strong{color:var(--navy)}
.callout ul{margin:.6rem 0 0;padding-left:1.1rem}
.callout li{margin-bottom:.3rem;color:var(--ink-soft)}

/* ---------- Prose (privacidade/manifesto) ---------- */
.prose{max-width:72ch}
.prose h2{font-size:clamp(22px,3vw,30px);margin:2rem 0 .6rem}
.prose h3{font-size:1.2rem;margin:1.4rem 0 .4rem}
.prose p,.prose li{color:var(--ink-soft)}
.prose ul{padding-left:1.2rem}
.prose li{margin-bottom:.4rem}
.prose a{color:var(--orange);font-weight:700;text-decoration:underline}

/* utility */
.center{text-align:center}
.mt-2{margin-top:1.4rem}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
