/* =====================================================================
   ÉTIMOS — folha de estilo única
   Tokens de design no topo. Edite as cores aqui e mudam no site todo.
===================================================================== */

:root {
  /* Cores da marca (extraídas do site aprovado) */
  --indigo:      #191265;
  --indigo-deep: #12103f;
  --royal:       #2567F5;  /* azul-royal (acento da página Palestras) */
  --card-blue:   #2330B8;  /* fundo dos cards azuis (Palestras) */
  --orange:      #F66631;
  --orange-dark: #D04715;
  --green:       #558B6E;
  --green-dark:  #395847;  /* fundo dos cards verdes (Consultoria) */
  --cream:       #FBF6EA;
  --offwhite:    #FDFFFC;
  --white:       #FFFFFF;
  --ink:         #0C0908;

  /* Tipografia */
  --font-display: "Bricolage Grotesque", system-ui, -apple-system, Arial, sans-serif;
  --font-serif:   "Crimson Pro", Georgia, "Times New Roman", serif;
  --font-mono:    "Fragment Mono", ui-monospace, monospace;

  /* Layout */
  --maxw: 1200px;
  --pad: clamp(1.25rem, 5vw, 5rem);
  --radius: 14px;
  --radius-lg: 22px;
}

/* ---------- Reset / base ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-display);
  background: var(--indigo);
  color: var(--offwhite);
  line-height: 1.5;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, picture, svg, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; padding: 0; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
em { font-style: italic; }

/* ---------- Utilidades ---------- */
/* Conteúdo só é escondido quando o JS está ativo e "arma" as animações
   (.reveals-on é adicionado pelo main.js). Sem JS / com erro de JS => tudo visível. */
.reveals-on .reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s cubic-bezier(.16,.84,.44,1); }
.reveals-on .reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1 !important; transform: none !important; transition: none; }
  html { scroll-behavior: auto; }
}

/* ---------- Marca (logo nav/footer) ---------- */
.brand { display: inline-flex; align-items: center; gap: .6rem; color: var(--offwhite); }
.brand__icon { width: 26px; height: 36px; color: var(--offwhite); fill: currentColor; }
.brand__word { width: auto; height: 22px; }

/* ---------- Botões ---------- */
.btn {
  display: inline-flex; align-items: center; gap: .5rem;
  font-weight: 600; font-size: .95rem; letter-spacing: .01em;
  padding: .7rem 1.4rem; border-radius: 999px; transition: background .25s, color .25s, transform .15s;
}
.btn--cta { background: var(--orange); color: var(--white); }
.btn--cta:hover { background: var(--orange-dark); }
.btn--submit {
  background: var(--indigo); color: var(--white); justify-content: center;
  width: 100%; padding: 1.05rem; border-radius: 12px; font-size: 1.05rem; margin-top: .4rem;
}
.btn--submit:hover { background: var(--indigo-deep); }
.btn--submit:disabled { opacity: .6; cursor: progress; }

/* =====================================================================
   NAV
===================================================================== */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  transition: background .3s ease, box-shadow .3s ease;
}
.nav.is-scrolled { background: var(--indigo); box-shadow: 0 2px 30px rgba(0,0,0,.25); }
.nav__inner {
  max-width: var(--maxw); margin: 0 auto; padding: 1rem var(--pad);
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
}
.nav__menu { display: flex; align-items: center; gap: clamp(1rem, 2.5vw, 2.2rem); }
.nav__menu a { font-weight: 500; font-size: .98rem; transition: opacity .2s; }
.nav__menu a:not(.btn):hover { opacity: .7; }

.nav__toggle { display: none; flex-direction: column; gap: 5px; padding: 8px; }
.nav__toggle span { width: 26px; height: 2px; background: var(--offwhite); border-radius: 2px; transition: transform .3s, opacity .3s; }
.nav__toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav__toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Dropdown "Nossos serviços" */
.nav__item--has-menu { position: relative; display: inline-flex; align-items: center;
  padding-bottom: 16px; margin-bottom: -16px; } /* ponte invisível: mantém o hover ao descer pro menu */
.nav__trigger { display: inline-flex; align-items: center; gap: .35rem; font: inherit; font-weight: 500; font-size: .98rem; color: inherit; }
.nav__chev { width: 13px; height: 13px; transition: transform .25s; }
.nav__dropdown {
  position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(10px);
  min-width: 250px; background: var(--indigo); color: var(--offwhite);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 12px; padding: .4rem; box-shadow: 0 22px 50px rgba(8,6,30,.45);
  display: grid; gap: 0;
  opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .2s ease, transform .2s ease;
}
.nav__item--has-menu:hover .nav__dropdown,
.nav__item--has-menu:focus-within .nav__dropdown {
  opacity: 1; visibility: visible; pointer-events: auto; transform: translateX(-50%) translateY(0);
}
.nav__item--has-menu:hover .nav__chev,
.nav__item--has-menu:focus-within .nav__chev { transform: rotate(180deg); }
.nav__dropdown a {
  display: block; padding: .8rem .95rem; border-radius: 8px;
  font-size: .96rem; font-weight: 500; color: var(--offwhite); opacity: .85; transition: background .15s, opacity .15s;
}
.nav__dropdown a + a { border-top: 1px solid rgba(255,255,255,.08); } /* divisórias sutis */
.nav__dropdown a:hover { background: rgba(255,255,255,.08); color: var(--offwhite); opacity: 1; }

/* Backdrop do menu mobile (criado via JS) */
.nav__overlay {
  position: fixed; inset: 0; z-index: 99;
  background: rgba(12, 9, 40, 0.72);
  backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px);
  opacity: 0; pointer-events: none;
  transition: opacity .35s ease;
}
.nav__overlay.is-visible { opacity: 1; pointer-events: auto; }

/* =====================================================================
   HERO
===================================================================== */
.hero { position: relative; min-height: 100svh; background: var(--indigo); color: var(--white); overflow: hidden; }
.hero__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero__overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(25,18,101,.45) 0%, rgba(25,18,101,.05) 30%, rgba(25,18,101,.15) 70%, rgba(25,18,101,.65) 100%),
    linear-gradient(90deg, rgba(12,9,40,.45), transparent 55%);
}
.hero__content { position: relative; z-index: 2; min-height: 100svh; max-width: var(--maxw); margin: 0 auto; padding: 0 var(--pad); }
.hero__title {
  font-weight: 800; line-height: .92; letter-spacing: -.02em;
  font-size: clamp(2.8rem, 9vw, 7.5rem);
  text-shadow: 0 2px 30px rgba(0,0,0,.3);
}
.hero__title--left  { position: absolute; top: 16vh; left: var(--pad); }
.hero__title--right { position: absolute; top: 42vh; right: var(--pad); text-align: right; }
.hero__lead {
  position: absolute; bottom: 9vh; left: var(--pad);
  max-width: 460px; font-weight: 600; font-size: clamp(1rem, 1.4vw, 1.2rem);
  text-shadow: 0 2px 18px rgba(0,0,0,.4);
}

/* =====================================================================
   DIFERENÇAS (índigo)
===================================================================== */
.diferencas {
  background: var(--indigo);
  max-width: var(--maxw); margin: 0 auto; padding: clamp(4rem, 9vw, 8rem) var(--pad);
  display: grid; grid-template-columns: minmax(120px, 220px) 1fr; gap: clamp(2rem, 6vw, 5rem); align-items: center;
}
.diferencas__mark svg { width: 100%; height: auto; color: var(--offwhite); fill: currentColor; }
.diferencas__text h2 { font-weight: 800; font-size: clamp(1.6rem, 3.2vw, 2.4rem); line-height: 1.1; letter-spacing: -.01em; }
.diferencas__text p { margin-top: 1.2rem; font-family: var(--font-serif); font-size: 1.15rem; line-height: 1.6; color: rgba(253,255,252,.88); max-width: 56ch; }

/* =====================================================================
   DESCUBRA O POTENCIAL (laranja)
===================================================================== */
.descubra { background: var(--orange); color: var(--white); padding: clamp(4rem, 9vw, 8rem) var(--pad); overflow: hidden; }
.descubra__title {
  position: relative; z-index: 2; /* fica ACIMA da linha índigo (que passa por trás do título) */
  max-width: var(--maxw); margin: 0 auto clamp(2.5rem, 5vw, 4rem);
  font-weight: 800; font-size: clamp(2.6rem, 7vw, 5.5rem); line-height: 1; letter-spacing: -.02em;
}
.descubra__title em { font-family: var(--font-serif); font-weight: 500; font-style: italic; font-size: 1.25em; }

/* Wrapper com a linha índigo "clipe de papel" que entrelaça os cards. Desenhada via JS,
   em trechos com z-index intercalado entre os cards (ver js/main.js → drawWeave). */
.descubra__wrap { position: relative; z-index: 1; max-width: 1280px; margin: 0 auto; } /* bloco da linha+cards numa camada abaixo do título; largura dá margem pro clipe respirar */
.cards { position: relative; display: flex; flex-direction: column; gap: clamp(2.5rem, 6vw, 5.5rem); }
/* cada trecho da linha é um <svg> absoluto cobrindo a área dos cards; o z-index é
   definido inline pelo JS para passar por trás/por cima do card certo. */
.cards > .descubra-line { position: absolute; left: 0; top: 0; width: 100%; height: 100%; overflow: visible; pointer-events: none; color: var(--indigo); }
.card {
  position: relative; /* para o z-index aplicado pelo JS valer */
  width: 82%; margin-inline: auto; /* card centralizado (~mesmo tamanho do original); sobra margem lateral onde o clip respira */
  display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.4rem, 3vw, 2.6rem); align-items: center;
  background: var(--orange-dark); border: 1px solid rgba(255,255,255,.1); /* laranja escuro: contrasta com o fundo da seção, igual ao original */
  border-radius: var(--radius-lg); padding: clamp(1.3rem, 2.2vw, 2rem);
  box-shadow: 0 14px 34px rgba(90,28,4,.22);
}
.card--reverse .card__text { order: 2; } /* inverte: imagem à esquerda, texto à direita */
.card--reverse .card__media { order: 1; }
.card__text h3 { font-weight: 700; font-size: clamp(1.4rem, 2.6vw, 1.9rem); line-height: 1.1; letter-spacing: -.02em; }
.card__text p { margin-top: .9rem; font-family: var(--font-serif); font-size: 1.1rem; line-height: 1.55; color: rgba(255,255,255,.92); }
.card__media img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius); aspect-ratio: 16 / 10; }

/* =====================================================================
   NOSSOS SERVIÇOS (índigo)
===================================================================== */
.servicos { background: var(--indigo); padding: clamp(4rem, 9vw, 8rem) var(--pad); }
.servicos__head { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: minmax(180px, 280px) 1fr; gap: clamp(2rem, 6vw, 5rem); align-items: start; }
.servicos__title { font-weight: 800; font-size: clamp(2rem, 4.5vw, 3rem); }
.servicos__list { display: grid; gap: clamp(1.5rem, 3vw, 2.5rem); }
.servicos__statement { max-width: var(--maxw); margin: clamp(3rem, 7vw, 6rem) auto 0; font-weight: 800; font-size: clamp(2.2rem, 6vw, 4.5rem); line-height: 1.04; letter-spacing: -.02em; color: var(--offwhite); }
.servico { display: grid; grid-template-columns: 48px 1fr; gap: 1.2rem; align-items: start; padding-bottom: clamp(1.5rem,3vw,2.5rem); border-bottom: 1px solid rgba(255,255,255,.12); }
.servicos__list .servico:last-child { border-bottom: 0; }
.servico__icon { width: 34px; height: 46px; color: var(--orange); fill: currentColor; margin-top: 4px; }
.servico__body h3 { font-weight: 800; font-size: clamp(1.3rem, 2.4vw, 1.7rem); }
.servico__body p { margin-top: .5rem; color: rgba(255,255,255,.85); max-width: 52ch; }
.link-arrow { display: inline-flex; align-items: center; gap: .4rem; margin-top: 1rem; font-size: .95rem; font-weight: 500; color: var(--offwhite); transition: gap .2s, opacity .2s; }
.link-arrow span { color: var(--orange); font-size: 1.2em; }
.link-arrow:hover { gap: .7rem; opacity: .85; }

/* =====================================================================
   POR QUE ESCOLHEM (creme)
===================================================================== */
.porque { background: var(--cream); color: var(--indigo); border-radius: var(--radius-lg) var(--radius-lg) 0 0; padding: clamp(4rem, 9vw, 8rem) var(--pad); margin-top: -22px; position: relative; }
.porque__title { max-width: var(--maxw); margin: 0 auto; font-weight: 800; font-size: clamp(2.4rem, 6vw, 4.5rem); line-height: 1.02; letter-spacing: -.02em; padding-bottom: 1.2rem; border-bottom: 2px solid var(--orange); }
.porque__title em { font-family: var(--font-serif); font-weight: 600; font-style: italic; color: var(--orange); font-size: 1.25em; }
.porque__grid { max-width: var(--maxw); margin: clamp(2.5rem,5vw,4rem) auto 0; display: grid; gap: clamp(1.8rem, 4vw, 3rem); }
.razao h3 { font-weight: 700; font-size: clamp(1.3rem, 2.6vw, 1.8rem); }
.razao h3 em { font-family: var(--font-serif); font-style: italic; color: var(--orange); font-weight: 600; font-size: 1.25em; }
.razao p { margin-top: .6rem; font-family: var(--font-serif); font-size: 1.12rem; line-height: 1.55; color: rgba(25,18,101,.8); max-width: 60ch; }

/* =====================================================================
   FAIXA VERDE (divisor)
===================================================================== */
.faixa-verde { background: var(--green); display: grid; place-items: center; padding: clamp(3rem, 6vw, 5rem) var(--pad); }
.faixa-verde__mark { width: clamp(70px, 9vw, 120px); height: auto; color: var(--white); fill: currentColor; }

/* =====================================================================
   CADA ORGANIZAÇÃO (vídeo)
===================================================================== */
.organizacao { position: relative; background: var(--ink); color: var(--white); overflow: hidden; }
.organizacao__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.organizacao__overlay { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(12,9,8,.85) 0%, rgba(12,9,8,.65) 45%, rgba(12,9,8,.25) 100%); }
.organizacao__content {
  position: relative; z-index: 2; max-width: var(--maxw); margin: 0 auto;
  padding: clamp(4rem, 9vw, 7rem) var(--pad);
  display: grid; grid-template-columns: 1.15fr .85fr; gap: clamp(2rem, 5vw, 4rem); align-items: center;
}
.organizacao__left h2 { font-weight: 800; font-size: clamp(1.9rem, 3.4vw, 3rem); line-height: 1.08; letter-spacing: -.02em; }
.organizacao__left h2 em { font-family: var(--font-serif); font-weight: 500; font-style: italic; font-size: 1.25em; }
.organizacao__contato { margin-top: 2.5rem; font-size: 1.1rem; }
.organizacao__contato .label { font-family: var(--font-mono); font-size: .85rem; letter-spacing: .05em; text-transform: uppercase; opacity: .75; margin-bottom: .6rem; }
.organizacao__contato a { font-weight: 600; transition: color .2s; }
.organizacao__contato a:hover { color: var(--orange); }

/* =====================================================================
   FORMULÁRIO (card laranja dentro da seção "Cada organização")
===================================================================== */
.organizacao__form { background: var(--orange); color: var(--white); border-radius: var(--radius-lg); padding: clamp(1.6rem, 3vw, 2.6rem); box-shadow: 0 24px 60px rgba(0,0,0,.35); }
.organizacao__form h2 { font-weight: 800; font-size: clamp(1.8rem, 3vw, 2.4rem); letter-spacing: -.02em; }
.form__lead { margin-top: .8rem; font-family: var(--font-serif); font-size: 1.05rem; line-height: 1.5; }

.form { margin-top: 1.8rem; }
.form__field { margin-bottom: 1.3rem; }
.form__field label { display: block; font-weight: 600; font-size: .9rem; margin-bottom: .5rem; }
.form input, .form textarea {
  width: 100%; padding: .95rem 1.1rem; border-radius: 12px; border: 2px solid transparent;
  background: #fde3d8; color: var(--ink); font-family: var(--font-display); font-size: 1rem; resize: vertical;
  transition: border-color .2s, background .2s;
}
.form input::placeholder, .form textarea::placeholder { color: #b07a63; }
.form input:focus, .form textarea:focus { outline: none; border-color: var(--indigo); background: #fff; }
.hp { position: absolute; left: -9999px; opacity: 0; }
.form__consent { font-size: .85rem; line-height: 1.45; opacity: .92; margin: .2rem 0 1rem; }
.form__consent a { text-decoration: underline; }
.form__status { margin-top: 1rem; font-weight: 600; min-height: 1.2em; }
.form__status.is-ok { color: #1c5e2a; }
.form__status.is-error { color: #5a1010; }

/* =====================================================================
   FOOTER
===================================================================== */
.footer { background: var(--indigo); color: var(--offwhite); padding: clamp(3.5rem, 7vw, 6rem) var(--pad) 2rem; }
.footer__inner { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 2.1fr 1fr 1.2fr 1fr; gap: clamp(1.6rem, 4vw, 3.2rem); }
.brand--footer { margin-bottom: 1.3rem; }
.brand--footer .brand__icon { width: 32px; height: 44px; }
.brand--footer .brand__word { height: 26px; }
.footer__brand p { color: rgba(253,255,252,.75); font-family: var(--font-serif); font-size: 1.05rem; line-height: 1.55; max-width: 42ch; }
.footer__social { display: flex; gap: .8rem; margin-top: 1.5rem; }
.footer__social a { width: 40px; height: 40px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.25); border-radius: 50%; transition: background .2s, border-color .2s; }
.footer__social a:hover { background: var(--orange); border-color: var(--orange); }
.footer__social svg { width: 18px; height: 18px; fill: var(--offwhite); }
.footer__col h4 { font-weight: 700; font-size: 1.05rem; margin-bottom: 1.1rem; }
.footer__col a { display: block; padding: .35rem 0; color: rgba(253,255,252,.8); transition: color .2s; }
.footer__col a:hover { color: var(--orange); }
.footer__base { max-width: var(--maxw); margin: clamp(2.5rem,5vw,4rem) auto 0; padding-top: 1.5rem; border-top: 1px solid rgba(255,255,255,.12); font-size: .85rem; color: rgba(253,255,252,.55); }

/* =====================================================================
   WHATSAPP flutuante
===================================================================== */
.whatsapp {
  position: fixed; right: clamp(1rem, 3vw, 2rem); bottom: clamp(1rem, 3vw, 2rem); z-index: 90;
  width: 58px; height: 58px; border-radius: 50%; background: #25D366; display: grid; place-items: center;
  box-shadow: 0 6px 24px rgba(0,0,0,.3); transition: transform .2s;
}
.whatsapp:hover { transform: scale(1.08); }
.whatsapp svg { width: 32px; height: 32px; fill: #fff; }

/* =====================================================================
   PÁGINA PALESTRAS & TALKS
===================================================================== */
/* Tema por página de serviço: cada uma colore painel/cards/acento de um jeito,
   igual ao original. Os valores caem pro royal (Palestras) quando não há tema. */
.svc-orange { --svc-panel: var(--orange); --svc-card: var(--orange-dark); --svc-accent: var(--orange); }
.svc-green  { --svc-panel: var(--green);  --svc-card: var(--green-dark);  --svc-accent: var(--green);  }

.btn--royal { background: var(--svc-accent, var(--royal)); color: var(--white); }
.btn--royal:hover { filter: brightness(.92); }

/* HERO da página (índigo, centralizado) */
.subhero { background: var(--indigo); color: var(--white); padding: clamp(7rem, 14vw, 11rem) var(--pad) clamp(4rem, 8vw, 7rem); text-align: center; }
.subhero__inner { max-width: 900px; margin: 0 auto; display: grid; justify-items: center; gap: 1.1rem; }
.subhero__icon { width: clamp(40px, 5vw, 54px); height: auto; color: var(--svc-accent, var(--royal)); }
.subhero__title { font-weight: 500; font-size: clamp(2.4rem, 6vw, 4.4rem); line-height: 1.02; letter-spacing: -.01em; }
.subhero__accent { font-weight: 800; font-size: clamp(2.2rem, 6vw, 4.4rem); line-height: 1; letter-spacing: -.02em; color: var(--svc-accent, var(--royal)); }
p.subhero__accent { font-size: clamp(1.5rem, 3.5vw, 2.8rem); }
.subhero .btn--royal { margin-top: 1.4rem; }

/* Painel azul-royal com os 3 diferenciais */
.pal-cards-section { background: var(--indigo); padding: 0 var(--pad) clamp(4rem, 9vw, 8rem); }
.pal-panel { max-width: 1200px; margin: 0 auto; background: var(--svc-panel, var(--royal)); border-radius: clamp(28px, 4vw, 60px); padding: clamp(1.6rem, 4vw, 3.4rem); }
.cards--blue { gap: clamp(1.6rem, 3vw, 2.6rem); }
/* card de serviço (cor vem do tema da página: azul/laranja/verde) */
.card--blue { background: var(--svc-card, var(--card-blue)); box-shadow: 0 14px 34px rgba(10,18,80,.28); }

/* EDUCAR + ESTATÍSTICAS (creme) */
.educar { background: var(--cream); color: var(--indigo); padding: clamp(4rem, 9vw, 8rem) var(--pad); }
.educar__intro { max-width: var(--maxw); margin: 0 auto; }
.educar__intro h2 { font-weight: 800; font-size: clamp(2rem, 5vw, 3.4rem); line-height: 1.05; letter-spacing: -.02em; }
.educar__intro p { margin-top: 1.2rem; max-width: 760px; font-family: var(--font-serif); font-size: clamp(1.1rem, 1.5vw, 1.3rem); line-height: 1.6; }
.stats { max-width: var(--maxw); margin: clamp(2.5rem, 5vw, 4rem) auto 0; display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.6rem, 4vw, 3rem); }
.stat { background: var(--white); border: 1px solid rgba(25,18,101,.1); border-radius: var(--radius-lg); padding: clamp(1.6rem, 3vw, 2.4rem); }
.stat__num { font-weight: 800; font-size: clamp(2rem, 4.5vw, 3.2rem); line-height: 1; letter-spacing: -.02em; color: var(--orange); }
.stat__txt { margin-top: 1rem; font-weight: 600; font-size: 1.1rem; line-height: 1.4; }
.stat__sub { margin-top: .9rem; font-family: var(--font-serif); font-size: 1.05rem; line-height: 1.55; color: rgba(25,18,101,.82); }

/* CARROSSEL FAQ (índigo) */
.faq { background: var(--indigo); color: var(--white); padding: clamp(4rem, 9vw, 7rem) 0; overflow: hidden; }
.faq__head { max-width: var(--maxw); margin: 0 auto clamp(1.8rem, 4vw, 3rem); padding: 0 var(--pad); display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.faq__title { font-weight: 800; font-size: clamp(1.8rem, 4.5vw, 3rem); letter-spacing: -.02em; }
.faq__nav { display: flex; gap: .6rem; }
.faq__btn { width: 48px; height: 48px; border-radius: 50%; border: 1.5px solid rgba(255,255,255,.35); color: var(--white); display: grid; place-items: center; transition: background .2s, border-color .2s, opacity .2s; }
.faq__btn:hover { background: var(--svc-accent, var(--royal)); border-color: var(--svc-accent, var(--royal)); }
.faq__btn svg { width: 22px; height: 22px; }
.faq__btn[disabled] { opacity: .35; cursor: default; }
.faq__btn[disabled]:hover { background: none; border-color: rgba(255,255,255,.35); }
.faq__track {
  display: flex; gap: clamp(1rem, 2vw, 1.6rem);
  max-width: var(--maxw); margin: 0 auto; padding: .4rem var(--pad);
  overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth;
  scrollbar-width: none;
}
.faq__track::-webkit-scrollbar { display: none; }
/* card sólido na cor do tema (azul/laranja/verde), igual ao original */
.faq__card {
  flex: 0 0 clamp(260px, 80vw, 340px); scroll-snap-align: start;
  background: var(--svc-card, var(--card-blue)); border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-lg); padding: clamp(1.4rem, 2.5vw, 2rem);
  display: flex; flex-direction: column; gap: .6rem;
}
.faq__card p.faq__tag { font-family: var(--font-mono); font-size: .78rem; letter-spacing: .06em; text-transform: uppercase; color: rgba(255,253,245,.7); }
.faq__card h3 { font-weight: 700; font-size: clamp(1.2rem, 2vw, 1.5rem); line-height: 1.15; letter-spacing: -.01em; }
.faq__card p { font-family: var(--font-serif); font-size: 1.05rem; line-height: 1.55; color: rgba(255,255,255,.9); }

/* CITAÇÃO (faixa verde) */
.quote { background: var(--green); color: var(--white); display: grid; justify-items: center; gap: 1.6rem; text-align: center; padding: clamp(4rem, 8vw, 7rem) var(--pad); }
.quote__mark { width: clamp(56px, 7vw, 90px); height: auto; color: var(--white); fill: currentColor; }
.quote__text p { font-family: var(--font-serif); font-style: italic; font-weight: 500; font-size: clamp(1.6rem, 3.6vw, 2.8rem); line-height: 1.25; max-width: 900px; }

/* =====================================================================
   PÁGINA SOBRE
===================================================================== */
/* Hero variante (usa .subhero da página Palestras, com elementos extras) */
.subhero__mark { width: clamp(46px, 5vw, 64px); height: auto; color: var(--royal); fill: currentColor; margin-bottom: .4rem; }
.subhero__eyebrow { font-family: var(--font-mono); font-size: .82rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.65); }
.subhero__title .subhero__accent { display: inline; font-family: var(--font-serif); font-style: italic; font-weight: 600; color: var(--royal); font-size: 1.25em; }
.subhero__lead { max-width: 640px; margin-top: .6rem; font-family: var(--font-serif); font-size: clamp(1.15rem, 1.8vw, 1.45rem); line-height: 1.55; color: rgba(255,255,255,.9); }

/* Título + foto do time (índigo) */
.sobre-top { background: var(--indigo); color: var(--white); padding: clamp(7rem, 13vw, 10rem) var(--pad) 0; }
.sobre-top__head { max-width: var(--maxw); margin: 0 auto; display: grid; justify-items: center; gap: .8rem; text-align: center; }
.sobre-top__head .subhero__mark { margin: 0; }
.sobre-top__title { font-weight: 800; font-size: clamp(2.2rem, 5.5vw, 3.8rem); letter-spacing: -.02em; }
.sobre-photo { max-width: 920px; margin: clamp(2.5rem, 5vw, 4rem) auto 0; }
.sobre-photo img { width: 100%; height: auto; aspect-ratio: 500 / 250; object-fit: cover; border-radius: var(--radius-lg); box-shadow: 0 22px 50px rgba(8,6,30,.35); }

/* Nossa visão (fundo #fffdf5, texto índigo — cores exatas do original) */
.visao { background: #fffdf5; color: var(--indigo); padding: clamp(4rem, 9vw, 8rem) var(--pad); }
.visao__label { max-width: 740px; margin: 0 auto 1.2rem; font-family: var(--font-serif); font-style: italic; font-weight: 700; font-size: clamp(1.4rem, 2vw, 1.75rem); color: var(--indigo); }
.visao__body { max-width: 740px; margin: 0 auto; }
.visao__body p { font-family: var(--font-display); font-weight: 400; font-size: clamp(1.15rem, 1.7vw, 1.5rem); line-height: 1.5; }
.visao__body p + p { margin-top: 1.2rem; }
.visao__highlight { max-width: 740px; margin: clamp(1.4rem, 3vw, 2rem) auto 0; font-family: var(--font-display); font-weight: 700; font-size: clamp(1.15rem, 1.7vw, 1.5rem); line-height: 1.3; }

/* Amizade / origem (índigo) */
.amizade { background: var(--indigo); color: var(--white); padding: clamp(4rem, 9vw, 8rem) var(--pad); display: grid; justify-items: center; text-align: center; gap: 1.4rem; }
.amizade__mark { width: clamp(54px, 7vw, 86px); height: auto; color: var(--offwhite); fill: currentColor; }
.amizade__title { font-weight: 800; font-size: clamp(1.9rem, 4.5vw, 3.2rem); line-height: 1.08; letter-spacing: -.02em; max-width: 900px; }
.amizade__body { max-width: 680px; }
.amizade__body p { font-family: var(--font-serif); font-size: clamp(1.1rem, 1.5vw, 1.28rem); line-height: 1.6; color: rgba(255,255,255,.9); }
.amizade__body p + p { margin-top: 1rem; }

/* Sócios (fundo índigo, texto off-white — cores exatas do original) */
.team { background: var(--indigo); color: var(--offwhite); padding: clamp(3.5rem, 8vw, 8rem) var(--pad); display: grid; gap: clamp(2.5rem, 6vw, 5rem); }
.team__member { max-width: var(--maxw); width: 100%; margin: 0 auto; display: flex; flex-direction: row-reverse; align-items: center; gap: clamp(1.8rem, 4vw, 3.5rem); }
.team__member--reverse { flex-direction: row; }
.team__photo { flex: 0 0 clamp(220px, 32%, 340px); }
.team__photo img { width: 100%; height: auto; aspect-ratio: 1 / 1; object-fit: cover; border-radius: var(--radius-lg); box-shadow: 0 18px 44px rgba(8,6,30,.45); }
.team__info { flex: 1; }
.team__name { font-weight: 800; font-size: clamp(1.6rem, 3vw, 2.2rem); letter-spacing: -.02em; color: var(--offwhite); }
.team__bio { margin-top: 1rem; font-family: var(--font-serif); font-size: clamp(1.1rem, 1.5vw, 1.25rem); line-height: 1.6; color: rgba(253,255,252,.9); }

/* =====================================================================
   PÁGINAS DE CONTEÚDO (Glossário · Calendário · Linha do tempo · Blog)
   Sistema de acento de cor reutilizável: a classe .c-* define --accent,
   e os componentes leem var(--accent). Mantém tudo na paleta da marca.
===================================================================== */
.c-orange     { --accent: var(--orange); }
.c-orangedark { --accent: var(--orange-dark); }
.c-green      { --accent: var(--green); }
.c-royal      { --accent: var(--royal); }
.c-indigo     { --accent: var(--indigo); }

/* Aviso "rascunho" discreto no topo das seções de conteúdo */
.draft-note {
  max-width: var(--maxw); margin: 0 auto clamp(1.6rem, 3vw, 2.4rem);
  display: flex; align-items: flex-start; gap: .7rem;
  background: rgba(37,103,245,.08); border: 1px dashed rgba(37,103,245,.4);
  border-radius: 12px; padding: .9rem 1.1rem; font-size: .92rem; line-height: 1.45; color: var(--indigo);
}
.draft-note svg { width: 20px; height: 20px; flex: 0 0 20px; fill: var(--royal); margin-top: 1px; }

/* ---------- GLOSSÁRIO (fundo creme) ---------- */
.gloss { background: var(--cream); color: var(--indigo); padding: clamp(3.5rem, 8vw, 7rem) var(--pad) clamp(4rem, 9vw, 8rem); }
.gloss__tools { max-width: var(--maxw); margin: 0 auto clamp(1.8rem, 4vw, 2.6rem); display: grid; gap: 1.1rem; }
.gloss__search-wrap { position: relative; }
.gloss__search-wrap svg { position: absolute; left: 1.1rem; top: 50%; transform: translateY(-50%); width: 20px; height: 20px; stroke: rgba(25,18,101,.5); pointer-events: none; }
.gloss__search {
  width: 100%; padding: 1rem 1.2rem 1rem 3rem; border-radius: 999px;
  border: 2px solid rgba(25,18,101,.18); background: var(--white); color: var(--indigo);
  font-family: var(--font-display); font-size: 1.05rem; transition: border-color .2s, box-shadow .2s;
}
.gloss__search::placeholder { color: rgba(25,18,101,.45); }
.gloss__search:focus { outline: none; border-color: var(--royal); box-shadow: 0 0 0 4px rgba(37,103,245,.12); }
.gloss__chips { display: flex; flex-wrap: wrap; gap: .55rem; }
.chip {
  font-weight: 600; font-size: .9rem; padding: .5rem 1rem; border-radius: 999px;
  border: 1.5px solid rgba(25,18,101,.2); color: var(--indigo); background: transparent;
  transition: background .18s, color .18s, border-color .18s;
}
.chip:hover { border-color: var(--royal); color: var(--royal); }
.chip.is-active { background: var(--indigo); border-color: var(--indigo); color: var(--white); }
.gloss__count { max-width: var(--maxw); margin: 0 auto 1.2rem; font-family: var(--font-mono); font-size: .85rem; opacity: .6; }
.gloss__grid {
  max-width: var(--maxw); margin: 0 auto;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: clamp(1rem, 2.2vw, 1.6rem);
}
.term {
  background: var(--white); border: 1px solid rgba(25,18,101,.08); border-left: 5px solid var(--accent, var(--royal));
  border-radius: 14px; padding: clamp(1.3rem, 2.2vw, 1.7rem);
  box-shadow: 0 10px 26px rgba(25,18,101,.07); display: flex; flex-direction: column; gap: .55rem;
}
.term__cat { align-self: flex-start; font-family: var(--font-mono); font-size: .7rem; letter-spacing: .06em; text-transform: uppercase; color: var(--white); background: var(--accent, var(--royal)); padding: .28rem .6rem; border-radius: 999px; }
.term h3 { font-weight: 800; font-size: clamp(1.2rem, 2vw, 1.45rem); line-height: 1.12; letter-spacing: -.01em; }
.term p { font-family: var(--font-serif); font-size: 1.05rem; line-height: 1.55; color: rgba(25,18,101,.82); }
.term[hidden] { display: none; }
.gloss__empty { max-width: var(--maxw); margin: 2rem auto 0; text-align: center; font-family: var(--font-serif); font-size: 1.2rem; opacity: .7; }
.gloss__empty[hidden] { display: none; }

/* ---------- CALENDÁRIO (busca + filtro por cor, cards de papel) ----------
   As cores das tags e dos chips são as MESMAS da planilha original do Marcelo
   (16 categorias). Cada card carrega uma "lombada" listrada com as cores das
   categorias àquela data — a paleta da tabela vira identidade visual. */
.cal { background: var(--cream); color: var(--indigo); padding: clamp(3.5rem, 8vw, 7rem) var(--pad) clamp(4rem, 9vw, 8rem); }

.cal__tools { max-width: var(--maxw); margin: 0 auto clamp(1.4rem, 3vw, 2rem); display: grid; gap: 1.1rem; }
.cal__search-wrap { position: relative; }
.cal__search-wrap svg { position: absolute; left: 1.1rem; top: 50%; transform: translateY(-50%); width: 20px; height: 20px; stroke: rgba(25,18,101,.5); pointer-events: none; }
.cal__search {
  width: 100%; padding: 1rem 1.2rem 1rem 3rem; border-radius: 14px;
  border: 2px solid rgba(25,18,101,.18); background: var(--white); color: var(--indigo);
  font-family: var(--font-display); font-size: 1.02rem;
}
.cal__search::placeholder { color: rgba(25,18,101,.45); }
.cal__search:focus { outline: none; border-color: var(--royal); box-shadow: 0 0 0 4px rgba(37,103,245,.12); }

.cal__chips { display: flex; flex-wrap: wrap; gap: .5rem; }
.cal__chips .chip { display: inline-flex; align-items: center; gap: .45rem; }
.chip__dot { width: 12px; height: 12px; border-radius: 50%; flex: 0 0 12px; box-shadow: inset 0 0 0 1px rgba(12,9,8,.18); }

.cal__count { max-width: var(--maxw); margin: 0 auto 1.2rem; font-family: var(--font-mono); font-size: .85rem; opacity: .6; }

.cal__grid { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: clamp(1.1rem, 2.4vw, 1.6rem); }

.datecard {
  position: relative; overflow: hidden;
  background: var(--white); border: 1px solid rgba(25,18,101,.08); border-radius: 18px;
  padding: clamp(1.3rem, 2.4vw, 1.7rem) clamp(1.3rem, 2.4vw, 1.7rem) clamp(1.3rem, 2.4vw, 1.7rem) calc(clamp(1.3rem, 2.4vw, 1.7rem) + 10px);
  display: flex; flex-direction: column; gap: .55rem; min-height: 230px;
  box-shadow: 0 10px 30px rgba(8,6,30,.07);
  transition: transform .2s ease, box-shadow .2s ease;
}
.datecard:hover { transform: translateY(-3px); box-shadow: 0 18px 42px rgba(8,6,30,.13); }
.datecard[hidden] { display: none; }
.datecard__spine { position: absolute; left: 0; top: 0; bottom: 0; width: 10px; }

.datecard__head { display: flex; align-items: flex-start; justify-content: space-between; gap: .6rem; }
.datecard__date { display: flex; flex-direction: column; line-height: 1; }
.datecard__day { font-weight: 800; font-size: clamp(2.6rem, 5vw, 3.4rem); line-height: .9; letter-spacing: -.03em; color: var(--indigo); }
.datecard__day-label { font-weight: 800; font-size: clamp(1.15rem, 2.2vw, 1.5rem); line-height: 1; letter-spacing: -.01em; color: var(--indigo); }
.datecard__month { font-family: var(--font-mono); font-size: .78rem; letter-spacing: .1em; text-transform: uppercase; color: var(--royal); margin-top: .35rem; }
.datecard__scope { font-family: var(--font-mono); font-size: .66rem; letter-spacing: .05em; text-transform: uppercase; color: rgba(25,18,101,.6); border: 1.5px solid rgba(25,18,101,.18); padding: .26rem .55rem; border-radius: 999px; white-space: nowrap; }
.datecard__name { font-weight: 800; font-size: clamp(1.18rem, 2vw, 1.4rem); line-height: 1.14; letter-spacing: -.01em; color: var(--indigo); margin-top: .1rem; }
.datecard__desc { font-family: var(--font-serif); font-size: 1.01rem; line-height: 1.5; color: rgba(25,18,101,.82); }
.datecard__tags { list-style: none; display: flex; flex-wrap: wrap; gap: .4rem; margin-top: auto; padding-top: .4rem; }
.cattag { font-family: var(--font-mono); font-size: .68rem; letter-spacing: .02em; color: #2a2440; background: var(--tag, #eee); padding: .26rem .55rem; border-radius: 999px; box-shadow: inset 0 0 0 1px rgba(12,9,8,.08); }

.cal__empty { max-width: var(--maxw); margin: 2rem auto 0; text-align: center; font-family: var(--font-serif); font-size: 1.2rem; opacity: .7; }
.cal__empty[hidden] { display: none; }

/* ---------- CALENDÁRIO · "Meu plano" (seleção + .ics + impressão) ----------
   Botão por card + barra fixa no canto inferior esquerdo (longe dos FABs). */
.datecard__add {
  margin-top: .7rem; align-self: flex-start;
  display: inline-flex; align-items: center; gap: .4rem;
  font-family: var(--font-mono); font-size: .68rem; letter-spacing: .04em; text-transform: uppercase;
  color: var(--royal); background: rgba(37,103,245,.08);
  border: 1.5px solid rgba(37,103,245,.3); border-radius: 999px; padding: .45rem .8rem;
  transition: background .15s, color .15s, border-color .15s;
}
.datecard__add:hover { background: rgba(37,103,245,.16); }
.datecard.is-inplan { box-shadow: 0 10px 30px rgba(37,103,245,.18); outline: 2px solid rgba(37,103,245,.35); outline-offset: -2px; }
.datecard.is-inplan .datecard__add { background: var(--royal); color: #fff; border-color: var(--royal); }

/* width deixa ~7rem de folga à direita para não colidir com os FABs (WhatsApp/VLibras) */
.planbar { position: fixed; left: clamp(1rem, 4vw, 2rem); bottom: 1.4rem; z-index: 85; width: min(340px, calc(100vw - 7rem)); font-family: var(--font-display); }
.planbar[hidden] { display: none; }
.planbar__pill { width: 100%; display: flex; align-items: center; gap: .6rem; background: var(--indigo); color: #fff; border-radius: 14px; padding: .85rem 1rem; box-shadow: 0 16px 40px rgba(8,6,30,.35); transition: background .2s; }
.planbar__pill:hover { background: var(--indigo-deep); }
.planbar__ico { width: 22px; height: 22px; flex: 0 0 22px; }
.planbar__count { font-weight: 800; font-size: 1.05rem; }
.planbar__chev { width: 18px; height: 18px; margin-left: auto; transition: transform .25s; }
.planbar__pill[aria-expanded="true"] .planbar__chev { transform: rotate(180deg); }
.planbar__drawer { background: var(--white); color: var(--indigo); border-radius: 14px; margin-bottom: .6rem; padding: 1rem; box-shadow: 0 22px 50px rgba(8,6,30,.3); border: 1px solid rgba(25,18,101,.1); max-height: min(58vh, 460px); overflow-y: auto; }
.planbar__drawer[hidden] { display: none; }
.planbar__title { font-family: var(--font-mono); font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; color: rgba(25,18,101,.55); margin-bottom: .6rem; }
.planbar__list { display: grid; gap: .35rem; margin-bottom: .7rem; }
.planbar__item { display: flex; align-items: baseline; gap: .5rem; font-size: .92rem; line-height: 1.3; }
.planbar__item-date { font-family: var(--font-mono); font-size: .76rem; color: var(--royal); flex: 0 0 auto; min-width: 3.4em; }
.planbar__item-name { flex: 1; color: rgba(25,18,101,.9); }
.planbar__remove { flex: 0 0 auto; color: rgba(25,18,101,.4); font-size: 1rem; line-height: 1; padding: 0 .2rem; }
.planbar__remove:hover { color: var(--orange-dark); }
.planbar__note { font-size: .8rem; line-height: 1.4; color: rgba(25,18,101,.7); background: rgba(246,102,49,.1); border-radius: 8px; padding: .5rem .6rem; margin-bottom: .7rem; }
.planbar__note[hidden] { display: none; }
.planbar__actions { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: .6rem; }
.planbar__btn { display: inline-flex; align-items: center; justify-content: center; gap: .4rem; flex: 1 1 8rem; background: var(--royal); color: #fff; border-radius: 10px; padding: .6rem .7rem; font-weight: 600; font-size: .88rem; transition: background .15s; }
.planbar__btn svg { width: 17px; height: 17px; }
.planbar__btn:hover { background: #1b53d6; }
.planbar__btn--ghost { flex: 0 0 auto; background: transparent; color: rgba(25,18,101,.65); border: 1.5px solid rgba(25,18,101,.18); }
.planbar__btn--ghost:hover { background: rgba(25,18,101,.06); color: var(--indigo); }
.planbar__cta { display: block; text-align: center; font-family: var(--font-mono); font-size: .76rem; letter-spacing: .02em; color: var(--orange-dark); padding: .3rem; }
.planbar__cta:hover { text-decoration: underline; }

/* Documento de impressão do plano: escondido na tela, visível só ao imprimir */
.planprint { display: none; }
@media print {
  body.is-printing-plan * { visibility: hidden !important; }
  body.is-printing-plan .planprint, body.is-printing-plan .planprint * { visibility: visible !important; }
  body.is-printing-plan .planprint { display: block !important; position: absolute; left: 0; top: 0; width: 100%; padding: 1.5rem 2rem; color: #000; font-family: var(--font-serif); }
  .planprint h1 { font-family: var(--font-display); font-size: 1.7rem; margin-bottom: .2rem; }
  .planprint .pp-sub { font-size: .95rem; color: #555; margin-bottom: 1.3rem; }
  .planprint ul { list-style: none; padding: 0; margin: 0; }
  .planprint li { padding: .5rem 0; border-bottom: 1px solid #ddd; display: flex; gap: 1rem; page-break-inside: avoid; }
  .planprint .pp-date { font-weight: 700; min-width: 5.5em; flex: 0 0 auto; }
  .planprint .pp-foot { margin-top: 1.4rem; font-size: .82rem; color: #666; }
}

/* =====================================================================
   TERMÔMETRO DE INCLUSÃO (autodiagnóstico)
   Painel índigo-profundo tipo "instrumento": difere das listas creme
   (glossário/calendário) porque é uma ferramenta interativa, não conteúdo
   para folhear. A cor do resultado (--tier) muda conforme a pontuação.
===================================================================== */
.termo { position: relative; overflow: hidden; background: var(--indigo-deep); color: var(--offwhite); padding: clamp(3rem, 7vw, 6rem) var(--pad) clamp(4rem, 9vw, 7rem); }
/* Brilho atmosférico atrás do painel */
.termo__aura { position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(60% 50% at 50% 0%, rgba(37,103,245,.30), transparent 70%),
    radial-gradient(40% 40% at 85% 90%, rgba(246,102,49,.16), transparent 70%),
    radial-gradient(45% 45% at 12% 80%, rgba(85,139,110,.18), transparent 70%); }
.termo__wrap { position: relative; max-width: 760px; margin: 0 auto; }
.termo__wrap .draft-note { color: rgba(255,255,255,.82); background: rgba(37,103,245,.14); border-color: rgba(255,255,255,.22); }
.termo__wrap .draft-note svg { fill: var(--royal); }

.termo__panel {
  position: relative; background: rgba(10,8,40,.55);
  border: 1px solid rgba(255,255,255,.12); border-radius: var(--radius-lg);
  box-shadow: 0 30px 80px rgba(4,3,20,.5), inset 0 1px 0 rgba(255,255,255,.06);
  padding: clamp(1.6rem, 4vw, 3rem); backdrop-filter: blur(6px);
  min-height: 440px; display: flex; flex-direction: column; justify-content: center;
}
.termo__stage { animation: termoIn .5s cubic-bezier(.16,.84,.44,1) both; }
.termo__stage[hidden] { display: none; }
@keyframes termoIn { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .termo__stage { animation: none; } }

/* ---- Intro ---- */
.termo__intro { text-align: center; display: grid; justify-items: center; gap: 1.1rem; }
.termo__mark { width: clamp(40px, 5vw, 56px); height: auto; color: var(--royal); fill: currentColor; }
.termo__intro-title { font-weight: 800; font-size: clamp(1.9rem, 4.5vw, 3rem); line-height: 1.04; letter-spacing: -.02em; }
.termo__intro-lead { max-width: 480px; font-family: var(--font-serif); font-size: clamp(1.1rem, 2vw, 1.35rem); line-height: 1.5; color: rgba(255,255,255,.82); }
.termo__meta { display: flex; flex-wrap: wrap; justify-content: center; gap: .5rem; margin: .2rem 0 .4rem; }
.termo__meta li { font-family: var(--font-mono); font-size: .76rem; letter-spacing: .04em; text-transform: uppercase; color: rgba(255,255,255,.7); border: 1px solid rgba(255,255,255,.18); border-radius: 999px; padding: .38rem .8rem; }
.termo__meta strong { color: var(--offwhite); font-weight: 700; }
.termo__start { background: var(--orange); color: var(--white); font-size: 1.05rem; padding: .95rem 1.8rem; }
.termo__start:hover { background: var(--orange-dark); transform: translateY(-2px); }
.termo__disclaimer { max-width: 460px; font-size: .82rem; line-height: 1.45; color: rgba(255,255,255,.5); }

/* ---- Quiz ---- */
.termo__top { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: .9rem; }
.termo__dimtag { font-family: var(--font-mono); font-size: .74rem; letter-spacing: .08em; text-transform: uppercase; color: var(--royal); font-weight: 500; }
.termo__counter { font-family: var(--font-mono); font-size: .8rem; color: rgba(255,255,255,.55); }
.termo__progress { height: 6px; border-radius: 999px; background: rgba(255,255,255,.12); overflow: hidden; margin-bottom: clamp(1.6rem, 4vw, 2.4rem); }
.termo__progress-fill { display: block; height: 100%; width: 0; border-radius: 999px; background: linear-gradient(90deg, var(--royal), var(--orange)); transition: width .45s cubic-bezier(.16,.84,.44,1); }
.termo__qbox { animation: termoSlide .35s cubic-bezier(.16,.84,.44,1) both; }
@keyframes termoSlide { from { opacity: 0; transform: translateX(18px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .termo__qbox { animation: none; } }
.termo__q { font-weight: 700; font-size: clamp(1.35rem, 3vw, 2rem); line-height: 1.18; letter-spacing: -.01em; margin-bottom: clamp(1.3rem, 3vw, 1.8rem); min-height: 2.2em; }
.termo__opts { display: grid; gap: .7rem; }
.termo__opt {
  display: flex; align-items: center; gap: .9rem; text-align: left; width: 100%;
  background: rgba(255,255,255,.05); border: 1.5px solid rgba(255,255,255,.16); border-radius: 14px;
  padding: 1rem 1.15rem; color: var(--offwhite); font-family: var(--font-serif); font-size: 1.08rem; line-height: 1.35;
  transition: background .18s, border-color .18s, transform .12s;
}
.termo__opt:hover { background: rgba(37,103,245,.16); border-color: var(--royal); transform: translateX(3px); }
.termo__opt:focus-visible { outline: 2px solid var(--royal); outline-offset: 2px; }
.termo__opt.is-picked { background: var(--royal); border-color: var(--royal); color: var(--white); }
.termo__opt-key { flex: 0 0 1.7rem; height: 1.7rem; display: grid; place-items: center; font-family: var(--font-mono); font-size: .82rem; color: rgba(255,255,255,.7); border: 1px solid rgba(255,255,255,.25); border-radius: 7px; }
.termo__opt.is-picked .termo__opt-key { background: rgba(255,255,255,.22); color: var(--white); border-color: transparent; }
.termo__back { align-self: flex-start; margin-top: 1.3rem; font-family: var(--font-mono); font-size: .82rem; color: rgba(255,255,255,.6); padding: .3rem 0; transition: color .18s; }
.termo__back:hover { color: var(--offwhite); }
.termo__back[hidden] { display: none; }

/* ---- Resultado ---- */
.termo__result { text-align: center; display: grid; justify-items: center; gap: .5rem; --tier: var(--royal); }
.termo__result-eyebrow { font-family: var(--font-mono); font-size: .78rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.55); }
.termo__gauge { position: relative; width: min(320px, 78vw); margin: .2rem auto 0; }
.termo__gauge svg { width: 100%; height: auto; overflow: visible; }
.termo__gauge-track { fill: none; stroke: rgba(255,255,255,.12); stroke-width: 18; stroke-linecap: round; }
.termo__gauge-val { fill: none; stroke: var(--tier); stroke-width: 18; stroke-linecap: round; transition: stroke-dashoffset 1.1s cubic-bezier(.16,.84,.44,1), stroke .6s; filter: drop-shadow(0 0 10px color-mix(in srgb, var(--tier) 55%, transparent)); }
.termo__score { position: absolute; left: 0; right: 0; bottom: 6%; display: flex; align-items: baseline; justify-content: center; gap: .1rem; }
.termo__score-num { font-weight: 800; font-size: clamp(3rem, 11vw, 4.6rem); line-height: 1; letter-spacing: -.03em; color: var(--offwhite); }
.termo__score-unit { font-family: var(--font-mono); font-size: 1.1rem; color: rgba(255,255,255,.5); }
.termo__gauge-min, .termo__gauge-max { position: absolute; bottom: 2%; font-family: var(--font-mono); font-size: .72rem; color: rgba(255,255,255,.4); }
.termo__gauge-min { left: 2%; } .termo__gauge-max { right: 2%; }
.termo__tier { font-weight: 800; font-size: clamp(1.5rem, 3.5vw, 2.1rem); letter-spacing: -.01em; color: var(--tier); margin-top: .3rem; }
.termo__reading { max-width: 540px; font-family: var(--font-serif); font-size: clamp(1.08rem, 2vw, 1.28rem); line-height: 1.55; color: rgba(255,255,255,.85); margin-bottom: .6rem; }

.termo__dims { width: 100%; display: grid; gap: 1rem; margin: .8rem 0 1.4rem; text-align: left; }
.termo__dim { display: grid; gap: .45rem; }
.termo__dim-head { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; }
.termo__dim-label { font-weight: 600; font-size: 1rem; }
.termo__dim-foco { font-family: var(--font-mono); font-size: .64rem; letter-spacing: .06em; text-transform: uppercase; color: var(--orange); border: 1px solid var(--orange); border-radius: 999px; padding: .12rem .5rem; margin-left: .5rem; }
.termo__dim-val { font-family: var(--font-mono); font-size: .85rem; color: rgba(255,255,255,.6); }
.termo__dim-track { height: 9px; border-radius: 999px; background: rgba(255,255,255,.1); overflow: hidden; }
.termo__dim-fill { display: block; height: 100%; width: 0; border-radius: 999px; background: var(--dim, var(--royal)); transition: width .9s cubic-bezier(.16,.84,.44,1); }

.termo__cta { display: grid; justify-items: center; gap: .9rem; margin-top: .4rem; }
.termo__cta-btn { background: var(--orange); color: var(--white); font-size: 1.02rem; padding: .95rem 1.7rem; text-align: center; }
.termo__cta-btn:hover { background: var(--orange-dark); transform: translateY(-2px); }
.termo__restart { font-family: var(--font-mono); font-size: .82rem; color: rgba(255,255,255,.6); transition: color .18s; }
.termo__restart:hover { color: var(--offwhite); }

.termo__noscript { margin-top: 1.4rem; text-align: center; font-family: var(--font-serif); font-size: 1.1rem; color: rgba(255,255,255,.8); }
.termo__noscript a { color: var(--orange); text-decoration: underline; }

@media (max-width: 520px) {
  .termo__panel { padding: 1.4rem 1.1rem; }
  .termo__opt { font-size: 1rem; padding: .85rem .9rem; }
}

/* ---------- LINHA DO TEMPO (fundo creme) ---------- */
.timeline { background: var(--cream); color: var(--indigo); padding: clamp(3.5rem, 8vw, 7rem) var(--pad) clamp(4rem, 9vw, 8rem); }
.tl { max-width: 940px; margin: 0 auto; position: relative; }
.tl::before { content: ""; position: absolute; left: 22px; top: 6px; bottom: 6px; width: 3px; background: linear-gradient(var(--orange), var(--royal), var(--green)); border-radius: 3px; }
.tl__item { position: relative; padding: 0 0 clamp(2rem, 4vw, 3rem) clamp(3.6rem, 6vw, 5rem); }
.tl__item:last-child { padding-bottom: 0; }
/* Marcador de era: linha horizontal + label em mono */
.tl__era {
  position: relative; padding: clamp(.2rem,1vw,.5rem) 0 clamp(1.4rem,3vw,2.2rem) clamp(3.6rem,6vw,5rem);
  font-family: var(--font-mono); font-size: .73rem; letter-spacing: .13em; text-transform: uppercase;
  color: rgba(25,18,101,.5); font-weight: 500;
}
.tl__era::before {
  content: ""; position: absolute; left: 0; top: 1em;
  width: clamp(2.6rem,4vw,3.6rem); height: 1px; background: rgba(25,18,101,.2);
}
.tl__dot { position: absolute; left: 13px; top: 4px; width: 21px; height: 21px; border-radius: 50%; background: var(--accent, var(--royal)); border: 4px solid var(--cream); box-shadow: 0 0 0 2px var(--accent, var(--royal)); }
.tl__year { font-family: var(--font-mono); font-weight: 500; font-size: 1.05rem; color: var(--accent, var(--royal)); letter-spacing: .02em; }
.tl__card { margin-top: .5rem; background: var(--white); border: 1px solid rgba(25,18,101,.08); border-radius: 14px; padding: clamp(1.2rem, 2.2vw, 1.6rem); box-shadow: 0 10px 26px rgba(25,18,101,.07); }
.tl__card h3 { font-weight: 800; font-size: clamp(1.2rem, 2.2vw, 1.55rem); line-height: 1.12; letter-spacing: -.01em; }
.tl__card p { margin-top: .5rem; font-family: var(--font-serif); font-size: 1.06rem; line-height: 1.55; color: rgba(25,18,101,.82); }

/* ---------- BLOG (fundo índigo) ---------- */
.blog { background: var(--indigo); color: var(--white); padding: clamp(3.5rem, 8vw, 7rem) var(--pad) clamp(4rem, 9vw, 8rem); }
.blog__featured {
  max-width: var(--maxw); margin: 0 auto clamp(2rem, 4vw, 3rem);
  background: var(--royal); border-radius: 22px; padding: clamp(1.8rem, 4vw, 3.2rem);
  display: grid; grid-template-columns: 1.3fr 1fr; gap: clamp(1.5rem, 4vw, 3rem); align-items: center;
  box-shadow: 0 22px 50px rgba(8,6,30,.35);
}
.blog__featured-tag { font-family: var(--font-mono); font-size: .78rem; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.85); }
.blog__featured h2 { font-weight: 800; font-size: clamp(1.8rem, 3.6vw, 2.9rem); line-height: 1.08; letter-spacing: -.02em; margin: .7rem 0 .9rem; }
.blog__featured p { font-family: var(--font-serif); font-size: clamp(1.1rem, 1.5vw, 1.28rem); line-height: 1.6; color: rgba(255,255,255,.92); }
.blog__featured-meta { margin-top: 1.2rem; display: flex; align-items: center; gap: .8rem; font-size: .9rem; color: rgba(255,255,255,.8); }
.blog__featured-pull { display: flex; align-items: center; justify-content: center; padding: clamp(1.5rem,3vw,2rem); }
.blog__pullquote {
  font-family: var(--font-serif); font-style: italic; font-weight: 600;
  font-size: clamp(1.35rem,2.8vw,2rem); line-height: 1.3; color: rgba(255,255,255,.95);
  text-align: right; border-right: 3px solid rgba(255,255,255,.45); padding-right: 1.5rem;
  max-width: 300px;
}
.blog__grid { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: clamp(1.1rem, 2.4vw, 1.7rem); }
.post {
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.12); border-top: 4px solid var(--accent, var(--royal));
  border-radius: 16px; padding: clamp(1.4rem, 2.4vw, 1.9rem); display: flex; flex-direction: column; gap: .7rem;
  transition: transform .2s, background .2s; min-height: 250px;
}
.post:hover { transform: translateY(-4px); background: rgba(255,255,255,.08); }
.post__cat { align-self: flex-start; font-family: var(--font-mono); font-size: .7rem; letter-spacing: .06em; text-transform: uppercase; color: var(--white); background: var(--accent, var(--royal)); padding: .26rem .6rem; border-radius: 999px; }
.post__title { font-weight: 800; font-size: clamp(1.25rem, 2.2vw, 1.6rem); line-height: 1.14; letter-spacing: -.01em; }
.post__excerpt { font-family: var(--font-serif); font-size: 1.06rem; line-height: 1.55; color: rgba(255,255,255,.88); }
.post__meta { margin-top: auto; font-family: var(--font-mono); font-size: .8rem; letter-spacing: .04em; color: rgba(255,255,255,.6); }

/* =====================================================================
   RESPONSIVO
===================================================================== */
@media (max-width: 860px) {
  /* Nav vira menu hambúrguer */
  .nav__toggle { display: flex; }
  .nav__menu {
    position: fixed; inset: 0 0 0 auto; width: min(82vw, 300px); height: 100dvh;
    background: var(--indigo-deep); flex-direction: column; align-items: stretch; justify-content: flex-start;
    gap: 0; padding: 4.5rem 0 2rem; transform: translateX(100%);
    transition: transform .38s cubic-bezier(.23,1,.32,1);
    box-shadow: -8px 0 50px rgba(0,0,0,.55); overflow-y: auto; z-index: 100;
  }
  .nav__menu.is-open { transform: translateX(0); }
  .nav__menu a { font-size: 1.15rem; }
  .nav__menu > a:not(.btn) {
    padding: .9rem 1.6rem; display: block; font-weight: 500;
    border-bottom: 1px solid rgba(255,255,255,.07);
    transition: color .18s;
  }
  .nav__menu > a:not(.btn):hover { color: var(--orange); opacity: 1; }
  .nav__menu > a.btn--cta { display: inline-flex; margin: 1.4rem 1.6rem 0; width: calc(100% - 3.2rem); justify-content: center; }

  /* Dropdown vira acordeão */
  .nav__item--has-menu { display: block; width: 100%; padding: 0; margin: 0; border-bottom: 1px solid rgba(255,255,255,.07); }
  .nav__trigger { font-size: 1.15rem; font-weight: 500; pointer-events: auto; display: flex; width: 100%; padding: .9rem 1.6rem; justify-content: space-between; align-items: center; transition: color .18s; }
  .nav__trigger:hover { color: var(--orange); }
  .nav__chev { display: block; width: 15px; height: 15px; transition: transform .28s ease; flex-shrink: 0; }
  .nav__item--has-menu.is-open .nav__chev { transform: rotate(180deg); }
  .nav__dropdown {
    position: static; transform: none; opacity: 1; visibility: visible; pointer-events: auto;
    display: block; background: rgba(0,0,0,.18); box-shadow: none; border: 0; border-radius: 0;
    min-width: 0; padding: 0; margin: 0; gap: 0;
    max-height: 0; overflow: hidden; transition: max-height .32s ease;
  }
  .nav__item--has-menu.is-open .nav__dropdown { max-height: 360px; }
  /* Cancela o transform e visibilidade do hover-desktop que tem especificidade maior */
  .nav__item--has-menu:hover .nav__dropdown,
  .nav__item--has-menu:focus-within .nav__dropdown { transform: none; opacity: 1; visibility: visible; }
  .nav__dropdown a { color: rgba(253,255,252,.82); font-size: 1.05rem; font-weight: 400; opacity: 1; padding: .7rem 1.6rem .7rem 2.1rem; border-radius: 0; display: block; border-top: 1px solid rgba(255,255,255,.06); }
  .nav__dropdown a + a { border-top: 1px solid rgba(255,255,255,.06); }
  .nav__dropdown a:hover { background: rgba(255,255,255,.07); color: var(--white); opacity: 1; }

  /* Hero empilha em vez de sobrepor */
  .hero__content { display: flex; flex-direction: column; justify-content: center; gap: 1.2rem; padding-top: 6rem; padding-bottom: 4rem; }
  .hero__title--left, .hero__title--right { position: static; text-align: left; }

  /* Cards empilham e ocupam largura toda; some a linha do ziguezague */
  .descubra-line { display: none; }
  .card { width: 100%; margin: 0; grid-template-columns: 1fr; }
  .card--reverse .card__text { order: 0; }
  .card--reverse .card__media { order: 0; }
  .card__media { order: -1; }

  /* "Cada organização" + form empilham */
  .organizacao__content { grid-template-columns: 1fr; }

  /* Palestras: estatísticas e cards azuis empilham */
  .stats { grid-template-columns: 1fr; }
  .card--blue { grid-template-columns: 1fr; }

  /* Sobre: sócios empilham (foto em cima do texto) */
  .team__member, .team__member--reverse { flex-direction: column; align-items: flex-start; gap: 1.4rem; }
  .team__photo { flex-basis: auto; width: 100%; max-width: 300px; }

  /* Nossos serviços: título em cima, lista embaixo */
  .servicos__head { grid-template-columns: 1fr; gap: 1.5rem; }

  /* Diferenças empilha */
  .diferencas { grid-template-columns: 1fr; }
  .diferencas__mark svg { width: 110px; }

  /* Footer empilha */
  .footer__inner { grid-template-columns: 1fr; }

  /* Conteúdo: featured do blog empilha */
  .blog__featured { grid-template-columns: 1fr; }
  .blog__featured-pull { order: -1; }
}

@media (max-width: 480px) {
  .nav__menu { width: min(92vw, 280px); }
}

/* =====================================================================
   VLibras (widget de acessibilidade em Libras do governo)
   Padrão do plugin: botão ancorado no meio da borda direita (encosta no
   texto) e painel aberto grande. Ajustes:
   1) botão fechado vai para o canto inferior direito, acima do WhatsApp;
   2) painel aberto é reduzido, ancorado no canto superior direito.
   `!important` porque o plugin posiciona via estilo inline.
===================================================================== */
[vw] { top: auto !important; bottom: 66px !important; right: 31px !important; }
[vw-plugin-wrapper] { transform: scale(.78) !important; transform-origin: top right !important; }
