/* Gomes e Caputo Advogados - extensoes ao Tailwind CDN */
/* Comentarios em ASCII puro, uma linha (regra critica da agencia) */

/* ---------- Tokens ---------- */
:root {
  --ink: #1A1A1A;
  --ink-2: #4A4A4A;
  --ink-3: #767676;
  --ink-4: #A8A29C;
  --line: #E5E1DA;
  --line-strong: #D5CFC6;
  --surface: #FAF9F6;
  --sunken: #F3F1EB;
  --graphite: #161616;
  --bronze: #8A6F4D;
  --bronze-soft: #B49B77;
  --whatsapp: #25D366;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---------- Base ---------- */
html {
  scroll-behavior: smooth;
}
html, body {
  overflow-x: hidden;
  overflow-x: clip;
}
body {
  background: var(--surface);
  color: var(--ink-2);
}
::selection {
  background: var(--bronze);
  color: #fff;
}
:focus-visible {
  outline: 2px solid var(--bronze);
  outline-offset: 3px;
}
section[id] {
  scroll-margin-top: 84px;
}
.material-symbols-outlined {
  font-variation-settings: 'FILL' 0, 'wght' 300, 'GRAD' 0, 'opsz' 24;
  font-size: 1.25rem;
  line-height: 1;
}

/* ---------- Film grain (so aparece nas superficies escuras) ---------- */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1000;
  opacity: 0.07;
  mix-blend-mode: screen;
  background-repeat: repeat;
  background-size: 200px 200px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240' viewBox='0 0 240 240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch' seed='3'/%3E%3CfeColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.22 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- Wrap ---------- */
.wrap {
  width: 100%;
  max-width: 72rem;
  margin-inline: auto;
  padding-inline: 1.5rem;
}

/* Wrap mais largo: aplicado so no header e no hero (footer fica em 72rem) */
.wrap--wide {
  max-width: 80rem;
  padding-inline: clamp(2rem, 5vw, 4rem);
}

/* ---------- WhatsApp glyph (branco, via background-image) ---------- */
.wa-ico {
  display: inline-block;
  width: 1.1em;
  height: 1.1em;
  flex: 0 0 auto;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23ffffff' d='M.057 24l1.687-6.163a11.867 11.867 0 0 1-1.587-5.946C.16 5.335 5.495 0 12.05 0a11.817 11.817 0 0 1 8.413 3.488 11.824 11.824 0 0 1 3.48 8.414c-.003 6.557-5.338 11.892-11.893 11.892a11.9 11.9 0 0 1-5.688-1.448L.057 24zm6.597-3.807c1.676.995 3.276 1.591 5.392 1.592 5.448 0 9.886-4.434 9.889-9.885.002-5.462-4.415-9.89-9.881-9.892-5.452 0-9.887 4.434-9.889 9.884a9.86 9.86 0 0 0 1.51 5.26l-.999 3.648 3.748-.984zm11.387-5.464c-.074-.124-.272-.198-.57-.347-.297-.149-1.758-.868-2.031-.967-.272-.099-.47-.149-.669.149-.198.297-.768.967-.941 1.165-.173.198-.347.223-.644.074-.297-.149-1.255-.462-2.39-1.475-.883-.788-1.48-1.761-1.653-2.059-.173-.297-.018-.458.13-.606.134-.133.297-.347.446-.521.151-.172.2-.296.3-.495.099-.198.05-.372-.025-.521-.075-.148-.669-1.611-.916-2.206-.242-.579-.487-.501-.669-.51l-.57-.01a1.1 1.1 0 0 0-.792.372c-.272.297-1.04 1.016-1.04 2.479s1.065 2.876 1.213 3.074c.149.198 2.095 3.2 5.076 4.487.709.306 1.263.489 1.694.626.712.226 1.36.194 1.872.118.571-.085 1.758-.719 2.006-1.413.248-.695.248-1.29.173-1.414z'/%3E%3C/svg%3E");
}
.wa-ico--lg {
  width: 1.7rem;
  height: 1.7rem;
}
/* Variante mask: herda currentColor (usada no CTA do header) */
.wa-ico--current {
  background-image: none;
  background-color: currentColor;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000000' d='M.057 24l1.687-6.163a11.867 11.867 0 0 1-1.587-5.946C.16 5.335 5.495 0 12.05 0a11.817 11.817 0 0 1 8.413 3.488 11.824 11.824 0 0 1 3.48 8.414c-.003 6.557-5.338 11.892-11.893 11.892a11.9 11.9 0 0 1-5.688-1.448L.057 24zm6.597-3.807c1.676.995 3.276 1.591 5.392 1.592 5.448 0 9.886-4.434 9.889-9.885.002-5.462-4.415-9.89-9.881-9.892-5.452 0-9.887 4.434-9.889 9.884a9.86 9.86 0 0 0 1.51 5.26l-.999 3.648 3.748-.984zm11.387-5.464c-.074-.124-.272-.198-.57-.347-.297-.149-1.758-.868-2.031-.967-.272-.099-.47-.149-.669.149-.198.297-.768.967-.941 1.165-.173.198-.347.223-.644.074-.297-.149-1.255-.462-2.39-1.475-.883-.788-1.48-1.761-1.653-2.059-.173-.297-.018-.458.13-.606.134-.133.297-.347.446-.521.151-.172.2-.296.3-.495.099-.198.05-.372-.025-.521-.075-.148-.669-1.611-.916-2.206-.242-.579-.487-.501-.669-.51l-.57-.01a1.1 1.1 0 0 0-.792.372c-.272.297-1.04 1.016-1.04 2.479s1.065 2.876 1.213 3.074c.149.198 2.095 3.2 5.076 4.487.709.306 1.263.489 1.694.626.712.226 1.36.194 1.872.118.571-.085 1.758-.719 2.006-1.413.248-.695.248-1.29.173-1.414z'/%3E%3C/svg%3E");
          mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000000' d='M.057 24l1.687-6.163a11.867 11.867 0 0 1-1.587-5.946C.16 5.335 5.495 0 12.05 0a11.817 11.817 0 0 1 8.413 3.488 11.824 11.824 0 0 1 3.48 8.414c-.003 6.557-5.338 11.892-11.893 11.892a11.9 11.9 0 0 1-5.688-1.448L.057 24zm6.597-3.807c1.676.995 3.276 1.591 5.392 1.592 5.448 0 9.886-4.434 9.889-9.885.002-5.462-4.415-9.89-9.881-9.892-5.452 0-9.887 4.434-9.889 9.884a9.86 9.86 0 0 0 1.51 5.26l-.999 3.648 3.748-.984zm11.387-5.464c-.074-.124-.272-.198-.57-.347-.297-.149-1.758-.868-2.031-.967-.272-.099-.47-.149-.669.149-.198.297-.768.967-.941 1.165-.173.198-.347.223-.644.074-.297-.149-1.255-.462-2.39-1.475-.883-.788-1.48-1.761-1.653-2.059-.173-.297-.018-.458.13-.606.134-.133.297-.347.446-.521.151-.172.2-.296.3-.495.099-.198.05-.372-.025-.521-.075-.148-.669-1.611-.916-2.206-.242-.579-.487-.501-.669-.51l-.57-.01a1.1 1.1 0 0 0-.792.372c-.272.297-1.04 1.016-1.04 2.479s1.065 2.876 1.213 3.074c.149.198 2.095 3.2 5.076 4.487.709.306 1.263.489 1.694.626.712.226 1.36.194 1.872.118.571-.085 1.758-.719 2.006-1.413.248-.695.248-1.29.173-1.414z'/%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: contain;
          mask-size: contain;
  width: 0.95em;
  height: 0.95em;
}

/* ---------- Header ---------- */
#siteHeader {
  position: fixed;
  inset-inline: 0;
  top: 0;
  z-index: 50;
  color: #fff;
  background: transparent;
  transition: transform 0.5s var(--ease), background-color 0.35s ease, color 0.35s ease, box-shadow 0.35s ease;
}
#siteHeader.is-hidden {
  transform: translateY(-100%);
}
#siteHeader.is-solid {
  color: var(--ink);
  background: rgba(250, 249, 246, 0.9);
  -webkit-backdrop-filter: blur(14px) saturate(1.1);
          backdrop-filter: blur(14px) saturate(1.1);
}
#siteHeader.is-solid.is-elevated {
  box-shadow: 0 1px 0 var(--line), 0 14px 34px rgba(20, 20, 20, 0.07);
}
body.menu-open #siteHeader {
  background: transparent !important;
  color: #fff !important;
  box-shadow: none !important;
  -webkit-backdrop-filter: none;
          backdrop-filter: none;
}

.brand {
  display: flex;
  flex-direction: column;
  line-height: 1;
}
.brand-name {
  font-size: 1.32rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  color: currentColor;
}
.brand-amp {
  font-style: italic;
  font-weight: 400;
  color: var(--bronze-soft);
}
#siteHeader.is-solid .brand-amp {
  color: var(--bronze);
}
.brand-sub {
  margin-top: 0.34rem;
  font-size: 0.54rem;
  font-weight: 500;
  letter-spacing: 0.46em;
  text-transform: uppercase;
  opacity: 0.62;
}

.nav-links a {
  position: relative;
  font-size: 0.8rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: currentColor;
  opacity: 0.75;
  transition: opacity 0.25s ease;
}
.nav-links a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 100%;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.35s var(--ease);
}
.nav-links a:hover {
  opacity: 1;
}
.nav-links a:hover::after {
  transform: scaleX(1);
}

.header-cta {
  padding: 0.62rem 1.3rem;
  border: 1px solid currentColor;
  border-radius: 9999px;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: currentColor;
  transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease, transform 0.3s ease;
}
@media (hover: hover) {
  #siteHeader:not(.is-solid) .header-cta:hover {
    background: #fff;
    border-color: #fff;
    color: var(--ink);
  }
  #siteHeader.is-solid .header-cta:hover {
    background: var(--ink);
    border-color: var(--ink);
    color: #fff;
  }
}
.header-cta:active {
  transform: scale(0.98);
}

/* ---------- Hamburguer ---------- */
#menuToggle {
  position: relative;
  z-index: 60;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
  gap: 6px;
  width: 44px;
  height: 44px;
  padding: 0 4px;
  color: currentColor;
}
@media (min-width: 768px) {
  #menuToggle {
    display: none;
  }
}
.menu-bar {
  display: block;
  height: 1.6px;
  border-radius: 2px;
  background: currentColor;
  transition: transform 0.4s var(--ease), width 0.4s var(--ease);
}
.menu-bar:first-child {
  width: 26px;
}
.menu-bar:last-child {
  width: 18px;
}
body.menu-open .menu-bar {
  width: 24px;
}
body.menu-open .menu-bar:first-child {
  transform: translateY(3.8px) rotate(45deg);
}
body.menu-open .menu-bar:last-child {
  transform: translateY(-3.8px) rotate(-45deg);
}

/* ---------- Menu mobile (splash clip-path) ---------- */
#mobileMenu {
  position: fixed;
  inset: 0;
  z-index: 45;
  background: var(--graphite);
  clip-path: circle(0% at calc(100% - 36px) 40px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: clip-path 0.55s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s ease, visibility 0s 0.55s;
}
#mobileMenu.is-open {
  pointer-events: auto;
  opacity: 1;
  visibility: visible;
  clip-path: circle(150% at calc(100% - 36px) 40px);
  transition: clip-path 0.65s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s ease, visibility 0s;
}
body.menu-open {
  overflow: hidden;
}
.mobile-nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.mobile-nav-list li + li {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.mobile-nav-list a {
  display: flex;
  align-items: baseline;
  gap: 1rem;
  padding: 1.05rem 0;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 1.9rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: #fff;
}
.mobile-nav-index {
  font-family: ui-monospace, Menlo, Consolas, monospace;
  font-size: 0.64rem;
  letter-spacing: 0.12em;
  color: var(--bronze-soft);
}
.mobile-menu-meta {
  margin-top: 1.4rem;
  font-size: 0.78rem;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.45);
}

/* ---------- Hero ---------- */
.hero {
  background: radial-gradient(120% 90% at 78% 12%, #1C1C1B 0%, #161616 55%, #121212 100%);
}
.hero-corner {
  position: absolute;
  z-index: 5;
  font: 300 14px/1 ui-monospace, Menlo, Consolas, monospace;
  color: rgba(255, 255, 255, 0.32);
  pointer-events: none;
}
.hero-corner--tl { top: 104px; left: 26px; }
.hero-corner--tr { top: 104px; right: 26px; }
.hero-corner--bl { bottom: 30px; left: 26px; }
.hero-corner--br { bottom: 30px; right: 26px; }
@media (max-width: 767px) {
  .hero-corner--tl, .hero-corner--tr { display: none; }
}
/* Logo monograma como marca dagua gigante, sangrando pelo canto inferior direito */
/* PNG e preto sobre branco: invert torna as linhas claras, screen derruba o fundo branco */
.hero-logo {
  position: absolute;
  right: -3rem;
  bottom: -4rem;
  z-index: 1;
  width: clamp(22rem, 40vw, 42rem);
  height: auto;
  opacity: 0.08;
  filter: invert(1);
  mix-blend-mode: screen;
  pointer-events: none;
  user-select: none;
}
@media (max-width: 767px) {
  .hero-logo {
    width: clamp(15rem, 62vw, 21rem);
    right: -3.5rem;
    bottom: -2.5rem;
    opacity: 0.07;
  }
}
.eyebrow {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--bronze-soft);
}
.eyebrow::before {
  content: "";
  width: 2.25rem;
  height: 1px;
  background: var(--bronze-soft);
  opacity: 0.55;
}
.hero-secondary {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.25);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.75);
  transition: color 0.3s ease, border-color 0.3s ease;
}
.hero-secondary .material-symbols-outlined {
  font-size: 1rem;
  transition: transform 0.35s var(--ease);
}
.hero-secondary:hover {
  color: #fff;
  border-color: #fff;
}
.hero-secondary:hover .material-symbols-outlined {
  transform: translateY(3px);
}
.hero-meta {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 2.1rem;
  z-index: 10;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.6rem 1.1rem;
  font-size: 0.68rem;
  font-weight: 400;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.42);
}
.hero-meta-sep {
  width: 1px;
  height: 12px;
  background: rgba(255, 255, 255, 0.2);
}
@media (max-width: 480px) {
  .hero-meta-sep { display: none; }
}

/* ---------- Botoes ---------- */
.btn-whatsapp {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.65rem;
  padding: 1.05rem 2rem;
  border-radius: 9999px;
  background: var(--whatsapp);
  color: #fff;
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  box-shadow: 0 14px 30px rgba(7, 15, 27, 0.28);
}
.btn-whatsapp .wa-ico {
  width: 1.15rem;
  height: 1.15rem;
  transition: transform 0.35s var(--ease);
}
.btn-whatsapp:active {
  transform: scale(0.98);
}
.hero-whatsapp-cta {
  border-radius: 9999px;
  outline: 2px solid transparent;
  outline-offset: 3px;
  transition: background-color 0.3s ease,
              box-shadow 0.4s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
              outline-color 0.35s ease;
}
@media (hover: hover) and (min-width: 768px) {
  .hero-whatsapp-cta:hover {
    transform: translateY(-2px);
    background-color: #1FBC59;
    box-shadow: 0 20px 44px rgba(7, 15, 27, 0.38);
    outline-color: rgba(37, 211, 102, 0.55);
  }
  .hero-whatsapp-cta:hover .wa-ico {
    transform: translateX(2px) rotate(-6deg);
  }
}
.btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.85rem 1.5rem;
  border: 1px solid var(--ink);
  border-radius: 9999px;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink);
  transition: background-color 0.3s ease, color 0.3s ease, transform 0.3s ease;
}
.btn-outline .material-symbols-outlined {
  font-size: 1.05rem;
}
@media (hover: hover) {
  .btn-outline:hover {
    background: var(--ink);
    color: #fff;
    transform: translateY(-2px);
  }
}
.btn-outline:active {
  transform: scale(0.98);
}

/* ---------- Tipografia de secao ---------- */
.kicker {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  font-size: 0.66rem;
  font-weight: 500;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--bronze);
}
.kicker::before {
  content: "";
  width: 2.25rem;
  height: 1px;
  background: var(--bronze);
  opacity: 0.55;
}
.kicker--dark {
  color: var(--bronze-soft);
}
.kicker--dark::before {
  background: var(--bronze-soft);
}
.section-heading {
  margin-top: 1.4rem;
  font-size: clamp(2.2rem, 4vw, 3.1rem);
  line-height: 1.06;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.section-heading em {
  font-weight: 400;
  color: var(--bronze);
}

/* ---------- Frame editorial (ledger grid, desktop apenas) ---------- */
.frame {
  position: relative;
}
.frame-divider {
  background: var(--line);
}
.frame > section + section {
  border-top: 1px solid var(--line);
}
@media (min-width: 768px) {
  .frame {
    width: min(74rem, calc(100% - 4rem));
    margin-inline: auto;
    border-left: 1px solid var(--line);
    border-right: 1px solid var(--line);
  }
  .frame .wrap {
    max-width: none;
    padding-inline: 16px;
  }
  .frame .cta-final {
    border-top: 1px solid var(--line);
  }
  .frame > section {
    position: relative;
  }
  .frame > section::before,
  .frame > section::after {
    content: "+";
    position: absolute;
    top: -0.5px;
    z-index: 2;
    font: 12px/1 ui-monospace, Menlo, Consolas, monospace;
    color: var(--ink-4);
    opacity: 0.7;
    pointer-events: none;
  }
  .frame > section::before { left: -0.5px; transform: translate(-50%, -50%); }
  .frame > section::after { right: -0.5px; transform: translate(50%, -50%); }
  .frame::before,
  .frame::after {
    content: "+";
    position: absolute;
    bottom: 0;
    z-index: 2;
    font: 12px/1 ui-monospace, Menlo, Consolas, monospace;
    color: rgba(255, 255, 255, 0.32);
    pointer-events: none;
  }
  .frame::before { left: 0; transform: translate(-50%, 50%); }
  .frame::after { right: 0; transform: translate(50%, 50%); }

  /* Colored sections escape the frame horizontally to fill 100vw */
  .frame > section.full-bleed-bg {
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
  }
  /* Restore wrap constraint: content stays at frame width, centered */
  .frame > section.full-bleed-bg .wrap {
    max-width: min(74rem, calc(100% - 4rem));
    margin-inline: auto;
    padding-inline: 16px;
  }
  /* Frame border lines drawn OVER the colored background for visual continuity */
  /* left/right: max(2rem, calc(50vw - 37rem)) replicates the frame margin-inline: auto at any vw */
  .frame > section.full-bleed-bg::before,
  .frame > section.full-bleed-bg::after {
    content: "";
    top: 0;
    bottom: 0;
    width: 1px;
    background: var(--line);
    z-index: 1;
    pointer-events: none;
    transform: none;
    opacity: 1;
    font-size: 0;
    color: transparent;
  }
  .frame > section.full-bleed-bg::before {
    left: calc(max(2rem, calc(50vw - 37rem)) - 1px);
  }
  .frame > section.full-bleed-bg::after {
    right: calc(max(2rem, calc(50vw - 37rem)) - 1px);
    left: auto;
  }
  /* On dark (graphite) sections: match the hero-amp stroke color */
  #manifesto.full-bleed-bg::before,
  #manifesto.full-bleed-bg::after,
  #contato.full-bleed-bg::before,
  #contato.full-bleed-bg::after {
    background: rgba(255, 255, 255, 0.07);
  }
}

/* ---------- Credenciais ---------- */
#credenciais .cred-item {
  padding: 2.25rem 0;
  border-top: 1px solid var(--line);
}
#credenciais .cred-item:first-child {
  border-top: 0;
}
@media (min-width: 768px) {
  #credenciais .cred-item {
    border-top: 0;
    border-left: 1px solid var(--line);
    padding: 3rem 2.25rem;
  }
  #credenciais .cred-item:first-child {
    border-left: 0;
    padding-left: 0;
  }
  #credenciais .cred-item:last-child {
    padding-right: 0;
  }
}
.cred-icon {
  font-size: 1.6rem;
  color: var(--bronze);
}
.cred-title {
  margin-top: 1rem;
  font-size: 1.35rem;
  font-weight: 600;
  color: var(--ink);
}
.cred-desc {
  margin-top: 0.45rem;
  font-size: 0.88rem;
  line-height: 1.65;
  color: var(--ink-3);
}

/* ---------- Placeholder editorial de foto ---------- */
.ph {
  position: relative;
  display: grid;
  place-items: center;
  background: var(--sunken);
  border: 1px solid var(--line);
  overflow: hidden;
}
.ph::before {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px dashed var(--line-strong);
  pointer-events: none;
}
.ph-logo {
  width: 68%;
  max-width: 300px;
  mix-blend-mode: multiply;
  opacity: 0.92;
}
.ph-label {
  position: absolute;
  left: 20px;
  bottom: 16px;
  font: 500 0.6rem/1 ui-monospace, Menlo, Consolas, monospace;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-4);
}
.ph-caption {
  margin-top: 0.9rem;
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-4);
}

/* ---------- Sobre ---------- */
.about-points {
  list-style: none;
  margin: 0;
  padding: 0;
}
.about-points li {
  position: relative;
  padding: 0.7rem 0 0.7rem 1.7rem;
  border-top: 1px solid var(--line);
  font-size: 0.92rem;
  line-height: 1.6;
  color: var(--ink-2);
}
.about-points li:last-child {
  border-bottom: 1px solid var(--line);
}
.about-points li::before {
  content: "+";
  position: absolute;
  left: 0;
  top: 0.68rem;
  font-family: ui-monospace, Menlo, Consolas, monospace;
  color: var(--bronze);
}

/* ---------- Areas de atuacao ---------- */
.areas-list {
  border-top: 1px solid var(--line);
}
.area-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.1rem;
  padding: 2.2rem 0;
  border-bottom: 1px solid var(--line);
  transition: background-color 0.35s ease;
}
@media (min-width: 768px) {
  .area-row {
    grid-template-columns: minmax(0, 4fr) minmax(0, 5fr) auto;
    align-items: center;
    gap: 3rem;
    padding: 2.6rem 1rem;
  }
}
@media (hover: hover) {
  .area-row:hover {
    background: var(--sunken);
  }
}
.area-id {
  display: flex;
  align-items: baseline;
  gap: 1.1rem;
}
.area-num {
  font-size: 1rem;
  font-style: italic;
  color: var(--bronze);
}
.area-name {
  font-size: clamp(1.7rem, 2.6vw, 2.2rem);
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.area-tag {
  font-size: 0.58rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-4);
  border: 1px solid var(--line-strong);
  border-radius: 9999px;
  padding: 0.34em 0.85em;
  white-space: nowrap;
}
.area-desc {
  max-width: 46ch;
  font-size: 0.95rem;
  line-height: 1.65;
  color: var(--ink-3);
}
.area-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink);
  white-space: nowrap;
  transition: color 0.25s ease;
}
.area-link .material-symbols-outlined {
  font-size: 1rem;
  transition: transform 0.35s var(--ease);
}
.area-link:hover {
  color: var(--bronze);
}
.area-row:hover .area-link .material-symbols-outlined {
  transform: translateX(4px);
}

/* ---------- Metodo ---------- */
.step-num {
  display: block;
  font-size: 3.6rem;
  line-height: 1;
  font-style: italic;
  color: transparent;
  -webkit-text-stroke: 1px var(--ink-4);
}
.step-title {
  margin-top: 1.5rem;
  font-size: 1.45rem;
  font-weight: 600;
  color: var(--ink);
}
.step-desc {
  margin-top: 0.8rem;
  font-size: 0.93rem;
  line-height: 1.7;
  color: var(--ink-3);
}

/* ---------- Manifesto / quote ---------- */
.diff-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.diff-list li {
  position: relative;
  padding: 1rem 0 1rem 1.9rem;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  font-size: 0.98rem;
  font-weight: 300;
  color: rgba(255, 255, 255, 0.82);
}
.diff-list li:last-child {
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}
.diff-list li::before {
  content: "+";
  position: absolute;
  left: 0;
  top: 0.95rem;
  font-family: ui-monospace, Menlo, Consolas, monospace;
  color: var(--bronze-soft);
}
.quote-author {
  margin-top: 2rem;
  font-size: 0.66rem;
  font-weight: 500;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--bronze-soft);
}

/* ---------- Localizacao ---------- */
.loc-block {
  padding: 1.4rem 0;
  border-top: 1px solid var(--line);
  font-style: normal;
}
.loc-label {
  display: block;
  margin-bottom: 0.55rem;
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--ink-4);
}
.loc-value {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--ink);
}
.loc-link {
  border-bottom: 1px solid transparent;
  transition: color 0.25s ease, border-color 0.25s ease;
}
.loc-link:hover {
  color: var(--bronze);
  border-color: var(--bronze);
}
.map-shell {
  position: relative;
  height: 100%;
  min-height: 440px;
  border: 1px solid var(--line);
  background: var(--sunken);
  overflow: hidden;
}
.map-shell iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  filter: grayscale(1) contrast(1.04);
  transition: filter 0.5s ease;
}
.map-shell:hover iframe {
  filter: grayscale(0);
}
@media (max-width: 767px) {
  .map-shell {
    min-height: 0;
    height: auto;
    aspect-ratio: 4 / 3;
  }
}

/* ---------- FAQ ---------- */
.faq-list {
  border-top: 1px solid var(--line);
}
.faq-item {
  border-bottom: 1px solid var(--line);
}
.faq-item summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding: 1.35rem 0;
  cursor: pointer;
  list-style: none;
  font-size: 1.02rem;
  font-weight: 500;
  color: var(--ink);
  transition: color 0.25s ease;
}
.faq-item summary::-webkit-details-marker {
  display: none;
}
.faq-item summary:hover {
  color: var(--bronze);
}
.faq-mark {
  position: relative;
  flex: 0 0 auto;
  width: 14px;
  height: 14px;
}
.faq-mark::before,
.faq-mark::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 14px;
  height: 1.5px;
  background: currentColor;
  transform: translate(-50%, -50%);
  transition: transform 0.35s var(--ease);
}
.faq-mark::after {
  transform: translate(-50%, -50%) rotate(90deg);
}
.faq-item[open] .faq-mark::after {
  transform: translate(-50%, -50%) rotate(0deg);
}
.faq-a {
  overflow: hidden;
}
.faq-a p {
  max-width: 62ch;
  padding: 0 0 1.4rem;
  font-size: 0.95rem;
  line-height: 1.7;
  color: var(--ink-3);
}
.faq-item[open] .faq-a {
  animation: faqOpen 0.45s var(--ease);
}
@keyframes faqOpen {
  from { opacity: 0; transform: translateY(-8px); }
  to { opacity: 1; transform: none; }
}

/* ---------- Footer ---------- */
.site-footer {
  background: #121212;
  color: rgba(255, 255, 255, 0.6);
}
.brand--footer .brand-name {
  color: #fff;
  font-size: 1.5rem;
}
.brand--footer .brand-sub {
  color: rgba(255, 255, 255, 0.55);
}
.footer-heading {
  margin-bottom: 1.2rem;
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-4);
}
.footer-nav {
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer-nav li + li {
  margin-top: 0.6rem;
}
.footer-nav a {
  font-size: 0.92rem;
  font-weight: 300;
  color: rgba(255, 255, 255, 0.65);
  transition: color 0.25s ease;
}
.footer-nav a:hover {
  color: #fff;
}
.footer-contact {
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer-contact li {
  font-size: 0.92rem;
  font-weight: 300;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.65);
}
.footer-contact li + li {
  margin-top: 0.65rem;
}
.footer-contact a {
  transition: color 0.25s ease;
}
.footer-contact a:hover {
  color: #fff;
}
.footer-legal {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  padding: 1.8rem 0 2rem;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  font-size: 0.78rem;
  color: rgba(255, 255, 255, 0.4);
}
@media (min-width: 768px) {
  .footer-legal {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}
.footer-credit a {
  color: var(--bronze-soft);
  text-decoration: underline;
  text-decoration-color: rgba(180, 155, 119, 0.4);
  text-underline-offset: 3px;
  transition: color 0.25s ease;
}
.footer-credit a:hover {
  color: #fff;
}

/* ---------- Social masks ---------- */
.social-link {
  display: inline-flex;
}
.social-mask {
  display: inline-block;
  width: 22px;
  height: 22px;
  background-color: rgba(255, 255, 255, 0.45);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: contain;
          mask-size: contain;
  transition: background-color 0.25s ease;
}
.social-mask--whatsapp {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000000' d='M.057 24l1.687-6.163a11.867 11.867 0 0 1-1.587-5.946C.16 5.335 5.495 0 12.05 0a11.817 11.817 0 0 1 8.413 3.488 11.824 11.824 0 0 1 3.48 8.414c-.003 6.557-5.338 11.892-11.893 11.892a11.9 11.9 0 0 1-5.688-1.448L.057 24zm6.597-3.807c1.676.995 3.276 1.591 5.392 1.592 5.448 0 9.886-4.434 9.889-9.885.002-5.462-4.415-9.89-9.881-9.892-5.452 0-9.887 4.434-9.889 9.884a9.86 9.86 0 0 0 1.51 5.26l-.999 3.648 3.748-.984zm11.387-5.464c-.074-.124-.272-.198-.57-.347-.297-.149-1.758-.868-2.031-.967-.272-.099-.47-.149-.669.149-.198.297-.768.967-.941 1.165-.173.198-.347.223-.644.074-.297-.149-1.255-.462-2.39-1.475-.883-.788-1.48-1.761-1.653-2.059-.173-.297-.018-.458.13-.606.134-.133.297-.347.446-.521.151-.172.2-.296.3-.495.099-.198.05-.372-.025-.521-.075-.148-.669-1.611-.916-2.206-.242-.579-.487-.501-.669-.51l-.57-.01a1.1 1.1 0 0 0-.792.372c-.272.297-1.04 1.016-1.04 2.479s1.065 2.876 1.213 3.074c.149.198 2.095 3.2 5.076 4.487.709.306 1.263.489 1.694.626.712.226 1.36.194 1.872.118.571-.085 1.758-.719 2.006-1.413.248-.695.248-1.29.173-1.414z'/%3E%3C/svg%3E");
          mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000000' d='M.057 24l1.687-6.163a11.867 11.867 0 0 1-1.587-5.946C.16 5.335 5.495 0 12.05 0a11.817 11.817 0 0 1 8.413 3.488 11.824 11.824 0 0 1 3.48 8.414c-.003 6.557-5.338 11.892-11.893 11.892a11.9 11.9 0 0 1-5.688-1.448L.057 24zm6.597-3.807c1.676.995 3.276 1.591 5.392 1.592 5.448 0 9.886-4.434 9.889-9.885.002-5.462-4.415-9.89-9.881-9.892-5.452 0-9.887 4.434-9.889 9.884a9.86 9.86 0 0 0 1.51 5.26l-.999 3.648 3.748-.984zm11.387-5.464c-.074-.124-.272-.198-.57-.347-.297-.149-1.758-.868-2.031-.967-.272-.099-.47-.149-.669.149-.198.297-.768.967-.941 1.165-.173.198-.347.223-.644.074-.297-.149-1.255-.462-2.39-1.475-.883-.788-1.48-1.761-1.653-2.059-.173-.297-.018-.458.13-.606.134-.133.297-.347.446-.521.151-.172.2-.296.3-.495.099-.198.05-.372-.025-.521-.075-.148-.669-1.611-.916-2.206-.242-.579-.487-.501-.669-.51l-.57-.01a1.1 1.1 0 0 0-.792.372c-.272.297-1.04 1.016-1.04 2.479s1.065 2.876 1.213 3.074c.149.198 2.095 3.2 5.076 4.487.709.306 1.263.489 1.694.626.712.226 1.36.194 1.872.118.571-.085 1.758-.719 2.006-1.413.248-.695.248-1.29.173-1.414z'/%3E%3C/svg%3E");
}
.social-mask--instagram {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Crect x='2.6' y='2.6' width='18.8' height='18.8' rx='5' fill='none' stroke='%23000000' stroke-width='1.8'/%3E%3Ccircle cx='12' cy='12' r='4.4' fill='none' stroke='%23000000' stroke-width='1.8'/%3E%3Ccircle cx='17.2' cy='6.8' r='1.35' fill='%23000000'/%3E%3C/svg%3E");
          mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Crect x='2.6' y='2.6' width='18.8' height='18.8' rx='5' fill='none' stroke='%23000000' stroke-width='1.8'/%3E%3Ccircle cx='12' cy='12' r='4.4' fill='none' stroke='%23000000' stroke-width='1.8'/%3E%3Ccircle cx='17.2' cy='6.8' r='1.35' fill='%23000000'/%3E%3C/svg%3E");
}
.social-mask--linkedin {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000000' d='M20.447 20.452h-3.554v-5.569c0-1.328-.027-3.037-1.852-3.037-1.853 0-2.136 1.445-2.136 2.939v5.667H9.351V9h3.414v1.561h.046c.477-.9 1.637-1.85 3.37-1.85 3.601 0 4.267 2.37 4.267 5.455v6.286zM5.337 7.433c-1.144 0-2.063-.926-2.063-2.065 0-1.138.92-2.063 2.063-2.063 1.14 0 2.064.925 2.064 2.063 0 1.139-.925 2.065-2.064 2.065zm1.782 13.019H3.555V9h3.564v11.452zM22.225 0H1.771C.792 0 0 .774 0 1.729v20.542C0 23.227.792 24 1.771 24h20.451C23.2 24 24 23.227 24 22.271V1.729C24 .774 23.2 0 22.225 0z'/%3E%3C/svg%3E");
          mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000000' d='M20.447 20.452h-3.554v-5.569c0-1.328-.027-3.037-1.852-3.037-1.853 0-2.136 1.445-2.136 2.939v5.667H9.351V9h3.414v1.561h.046c.477-.9 1.637-1.85 3.37-1.85 3.601 0 4.267 2.37 4.267 5.455v6.286zM5.337 7.433c-1.144 0-2.063-.926-2.063-2.065 0-1.138.92-2.063 2.063-2.063 1.14 0 2.064.925 2.064 2.063 0 1.139-.925 2.065-2.064 2.065zm1.782 13.019H3.555V9h3.564v11.452zM22.225 0H1.771C.792 0 0 .774 0 1.729v20.542C0 23.227.792 24 1.771 24h20.451C23.2 24 24 23.227 24 22.271V1.729C24 .774 23.2 0 22.225 0z'/%3E%3C/svg%3E");
}
.social-link--whatsapp:hover .social-mask { background-color: #25D366; }
.social-link--instagram:hover .social-mask { background-color: #E1306C; }
.social-link--linkedin:hover .social-mask { background-color: #0A66C2; }

/* ---------- Sticky bar mobile ---------- */
#mobileStickyBar {
  position: fixed;
  inset-inline: 0;
  bottom: 0;
  z-index: 40;
  background: #fff;
  border-top: 1px solid var(--line);
  padding: 0.8rem 1rem calc(0.8rem + env(safe-area-inset-bottom));
}
.sticky-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  width: 100%;
  padding: 0.95rem 1rem;
  border-radius: 9999px;
  background: var(--ink);
  color: #fff;
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.sticky-cta:active {
  transform: scale(0.985);
}

/* ---------- WhatsApp FAB ---------- */
/* Mobile: bottom = altura da sticky bar (75px) + right (20px) */
#whatsappFab {
  position: fixed;
  right: 20px;
  bottom: 95px;
  z-index: 46;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--whatsapp);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.3);
  transform: translateY(120%) scale(0.6);
  opacity: 0;
  transition: transform 0.4s var(--ease), opacity 0.4s ease, box-shadow 0.3s ease;
}
#whatsappFab.is-visible {
  transform: translateY(0) scale(1);
  opacity: 1;
}
body.menu-open #whatsappFab.is-visible {
  transform: translateY(120%) scale(0.6);
  opacity: 0;
}
@media (min-width: 768px) {
  #whatsappFab {
    right: 36px;
    bottom: 36px;
    width: 68px;
    height: 68px;
  }
  #whatsappFab .wa-ico {
    width: 2rem;
    height: 2rem;
  }
}
@media (min-width: 768px) and (hover: hover) {
  #whatsappFab.is-visible:hover {
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.45);
    transform: scale(1.06);
  }
}
@media (max-width: 767px) {
  #mobileStickyBar {
    transform: translateY(120%);
    transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
  }
  #mobileStickyBar.is-visible {
    transform: translateY(0);
  }
  body.menu-open #mobileStickyBar.is-visible {
    transform: translateY(120%);
  }
}

/* ---------- Clearance da sticky bar (ultima secao escura + footer) ---------- */
@media (max-width: 767px) {
  .cta-final {
    padding-bottom: 120px;
  }
  .site-footer {
    padding-bottom: 110px;
  }
}

/* ---------- Estados iniciais data-anim ---------- */
[data-anim] {
  opacity: 0;
  will-change: transform, opacity;
}
[data-anim="hero-eyebrow"],
[data-anim="hero-title"],
[data-anim="hero-sub"],
[data-anim="hero-cta"],
[data-anim="hero-meta"] { transform: translateY(28px); }
[data-anim="cred-item"] { transform: translateY(20px); }
[data-anim="about-image"] { transform: translateX(-40px); }
[data-anim="about-text"] { transform: translateX(40px); }
[data-anim="section-title"] { transform: translateY(24px); }
[data-anim="service-row"] { transform: translateY(30px); }
[data-anim="step-item"] { transform: translateY(26px); }
[data-anim="diff-list"] { transform: translateX(-40px); }
[data-anim="diff-quote"] { transform: scale(0.96); }
[data-anim="loc-info"] { transform: translateX(-30px); }
[data-anim="loc-map"] { transform: translateY(30px); }
[data-anim="faq-item"] { transform: translateY(16px); }
[data-anim="final-cta"] { transform: translateY(30px); }

/* Override obrigatorio: text-trace controla a propria opacidade */
[data-anim="text-trace"] {
  opacity: 1;
  will-change: auto;
  transform: none;
}

/* Fallback global sem GSAP ou com reduced motion */
html.reveal-immediate [data-anim] {
  opacity: 1 !important;
  transform: none !important;
}

/* ---------- Text Trace ---------- */
.trace-word {
  display: inline-block;
  white-space: nowrap;
}
.trace-char {
  display: inline-block;
  white-space: pre;
  opacity: 0;
}
.trace-char.is-animating {
  animation: traceFadeIn var(--trace-duration, 600ms) var(--trace-delay, 0ms) forwards ease-out;
}
[data-trace-end="outline"] .trace-char.is-animating {
  animation: traceSolidToOutline var(--trace-duration, 600ms) var(--trace-delay, 0ms) forwards ease-out;
}
@keyframes traceFadeIn {
  0% { opacity: 0; }
  100% { opacity: 1; }
}
@keyframes traceSolidToOutline {
  0% { opacity: 0; color: var(--trace-color, currentColor); -webkit-text-stroke: 0 transparent; }
  50% { opacity: 1; color: var(--trace-color, currentColor); -webkit-text-stroke: 0 transparent; }
  100% { opacity: 1; color: transparent; -webkit-text-stroke: 0.04em var(--trace-color, currentColor); }
}
@media (prefers-reduced-motion: reduce) {
  .trace-char {
    opacity: 1;
    animation: none;
  }
  [data-trace-end="outline"] .trace-char {
    color: transparent;
    -webkit-text-stroke: 0.04em var(--trace-color, currentColor);
  }
}

/* ---------- WhatsApp chat widget (desktop) ---------- */
.wa-widget{position:fixed;right:36px;bottom:120px;z-index:59;width:264px;transform-origin:bottom right;opacity:0;transform:scale(0.9) translateY(4px);pointer-events:none;transition:opacity .35s var(--ease),transform .4s var(--ease)}
.wa-widget.is-open{opacity:1;transform:scale(1) translateY(0);pointer-events:auto}
.wa-panel{position:relative;background:#fff;border:1.5px solid var(--ink);border-radius:16px;padding:14px;box-shadow:0 14px 34px rgba(0,0,0,0.16)}
.wa-panel::after{content:"";position:absolute;width:14px;height:14px;background:#fff;border-right:1.5px solid var(--ink);border-bottom:1.5px solid var(--ink);border-bottom-right-radius:3px;bottom:-8px;right:30px;transform:rotate(45deg)}
.wa-scroll{max-height:min(58vh,400px);overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:#d2d2d2 transparent}
.wa-scroll::-webkit-scrollbar{width:5px}
.wa-scroll::-webkit-scrollbar-thumb{background:#d2d2d2;border-radius:5px}
.wa-thread{display:flex;flex-direction:column}
.wa-bubble{max-width:88%;padding:8px 11px;font-size:0.82rem;line-height:1.45;border-radius:13px;margin-bottom:12px;overflow-wrap:break-word;animation:waMsgIn .35s var(--ease) both}
.wa-bubble--in{background:#F0F0F0;color:var(--ink);border-top-left-radius:4px;align-self:flex-start}
.wa-bubble--out{background:var(--ink);color:#fff;border-top-right-radius:4px;align-self:flex-end}
.wa-bubble--typing{padding:11px 13px}
.wa-dots{display:inline-flex;gap:4px;align-items:center}
.wa-dots span{width:6px;height:6px;border-radius:50%;background:#a8a8a8;animation:waType 1.2s infinite ease-in-out}
.wa-dots span:nth-child(2){animation-delay:.18s}
.wa-dots span:nth-child(3){animation-delay:.36s}
@keyframes waType{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}
@keyframes waMsgIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.wa-quick{display:flex;flex-direction:column;gap:6px;margin-top:5px}
.wa-chip{width:100%;text-align:left;background:#fff;border:1px solid var(--line-strong);border-radius:10px;padding:8px 11px;font:inherit;font-size:0.78rem;line-height:1.35;color:var(--ink-2);cursor:pointer;transition:border-color .2s ease,color .2s ease,background .2s ease}
.wa-chip:hover{border-color:var(--ink);color:var(--ink);background:#FAFAFA}
.wa-quick-end{font-size:0.76rem;line-height:1.45;color:var(--ink-3);margin:6px 2px 0}
.wa-cta{display:block;text-align:center;margin-top:11px;padding-top:11px;border-top:1px solid var(--line);font-size:0.78rem;font-weight:600;letter-spacing:0.02em;color:var(--ink);text-decoration:none}
.wa-cta:hover{text-decoration:underline}
.wa-close{position:absolute;top:-10px;right:-10px;width:24px;height:24px;border-radius:50%;border:1.5px solid var(--ink);background:#fff;color:var(--ink);cursor:pointer;padding:0;box-shadow:0 2px 6px rgba(0,0,0,0.14);transition:background .2s ease,color .2s ease}
.wa-close:hover{background:var(--ink);color:#fff}
.wa-teaser{position:fixed;right:36px;bottom:120px;z-index:58;opacity:0;transform:translateY(6px) scale(0.96);transform-origin:bottom right;pointer-events:none;transition:opacity .35s var(--ease),transform .4s var(--ease)}
.wa-teaser.is-shown{opacity:1;transform:none;pointer-events:auto}
.wa-teaser-bubble{position:relative;display:block;max-width:200px;background:#fff;border:1.5px solid var(--ink);border-radius:14px;padding:10px 13px;font:inherit;font-size:0.84rem;line-height:1.35;color:var(--ink);text-align:left;cursor:pointer;box-shadow:0 12px 28px rgba(0,0,0,0.16);transition:background .2s ease}
.wa-teaser-bubble:hover{background:#FAFAFA}
.wa-teaser-bubble::after{content:"";position:absolute;width:12px;height:12px;background:#fff;border-right:1.5px solid var(--ink);border-bottom:1.5px solid var(--ink);border-bottom-right-radius:3px;bottom:-7px;right:26px;transform:rotate(45deg)}
.wa-teaser-x{position:absolute;top:-9px;right:-9px;width:22px;height:22px;border-radius:50%;border:1.5px solid var(--ink);background:#fff;color:var(--ink);cursor:pointer;padding:0;box-shadow:0 2px 6px rgba(0,0,0,0.14);transition:background .2s ease,color .2s ease}
.wa-teaser-x:hover{background:var(--ink);color:#fff}
.wa-close::before,.wa-close::after,.wa-teaser-x::before,.wa-teaser-x::after{content:"";position:absolute;left:50%;top:50%;width:10px;height:1.5px;background:currentColor;border-radius:2px}
.wa-close::before,.wa-teaser-x::before{transform:translate(-50%,-50%) rotate(45deg)}
.wa-close::after,.wa-teaser-x::after{transform:translate(-50%,-50%) rotate(-45deg)}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
  *, *::before, *::after {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
  }
}
