/* ============================================================
   sections.css — hero, marquee, sobre, metodo, planos,
   social, faq, contato.
   ============================================================ */

.section {
  position: relative;
  padding-block: var(--section-py);
}

.section--alt {
  /* Slightly translucent so the body-level aurora ghosts through
     while alt sections still read as calmer, darker bands. */
  background: color-mix(in srgb, var(--bg-section) 86%, transparent);
}

.section__head {
  max-width: 760px;
  margin-bottom: var(--sp-10);
}

.section__head--center {
  margin-inline: auto;
  text-align: center;
}

.section__title {
  margin-top: var(--sp-3);
  font-size: var(--fs-3xl);
  text-transform: uppercase;
  letter-spacing: var(--tracking-tight);
  line-height: var(--lh-tight);
  color: var(--text-primary);
}

.section__lead {
  margin-top: var(--sp-5);
  font-size: var(--fs-md);
  line-height: var(--lh-loose);
  color: var(--text-tertiary);
  max-width: 64ch;
}

.section__head--center .section__lead { margin-inline: auto; }

/* Watermark element used on alt sections */
.section__watermark {
  position: absolute;
  pointer-events: none;
  user-select: none;
  z-index: 0;
  opacity: 0.05;
  filter: invert(1) brightness(2);
}
[data-theme="light"] .section__watermark {
  filter: none;
  opacity: 0.06;
}

/* ============================================================
   HERO (mobile-first)
   ============================================================ */
.hero {
  position: relative;
  min-height: 100vh;
  min-height: 100svh;
  padding-top: 90px;          /* mobile: matches compact header */
  padding-bottom: var(--sp-10);
  display: flex;
  align-items: center;
  overflow: hidden;
}
@media (min-width: 768px) {
  .hero { padding-top: 100px; padding-bottom: var(--sp-12); }
}
@media (min-width: 1024px) {
  .hero { padding-top: 120px; }
}

.hero__orbs {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}

.hero__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.45;
  will-change: transform;
}
.hero__orb--1 {
  top: -10%; left: -8%;
  width: clamp(280px, 50vw, 540px);
  height: clamp(280px, 50vw, 540px);
  background: radial-gradient(circle, var(--c-blue) 0%, transparent 70%);
  animation: orb-drift-1 26s var(--ease-in-out) infinite,
             blob-morph 18s var(--ease-in-out) infinite;
}
.hero__orb--2 {
  bottom: -15%; right: -5%;
  width: clamp(320px, 60vw, 680px);
  height: clamp(320px, 60vw, 680px);
  background: radial-gradient(circle, var(--c-gold) 0%, transparent 70%);
  opacity: 0.28;
  animation: orb-drift-2 28s var(--ease-in-out) infinite,
             blob-morph 22s var(--ease-in-out) infinite -6s;
}
.hero__orb--3 {
  top: 30%; right: 25%;
  width: clamp(220px, 35vw, 380px);
  height: clamp(220px, 35vw, 380px);
  background: radial-gradient(circle, var(--c-blue-bright) 0%, transparent 70%);
  opacity: 0.18;
  animation: orb-drift-3 22s var(--ease-in-out) infinite,
             blob-morph 20s var(--ease-in-out) infinite -11s;
}

[data-theme="light"] .hero__orb {
  opacity: 0.18;
}
[data-theme="light"] .hero__orb--2 { opacity: 0.22; }

.hero__inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--sp-8);
  align-items: center;
}

@media (min-width: 960px) {
  .hero__inner {
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
    gap: var(--sp-10);
  }
}

.hero__copy {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
  max-width: 640px;
  min-width: 0;
}
@media (min-width: 768px) { .hero__copy { gap: var(--sp-6); } }

.hero__badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  opacity: 0;
  animation: fade-up 0.9s var(--ease-out) 0.1s forwards;
}

.hero__title {
  font-size: var(--fs-4xl);
  text-transform: uppercase;
  letter-spacing: var(--tracking-tight);
  line-height: 0.95;
  word-wrap: break-word;
  overflow-wrap: break-word;
  hyphens: auto;
  opacity: 0;
  animation: fade-up 0.9s var(--ease-out) 0.2s forwards;
}

.hero__title .accent { display: inline-block; }

.hero__sub {
  font-size: var(--fs-md);
  line-height: var(--lh-loose);
  color: var(--text-tertiary);
  max-width: 56ch;
  opacity: 0;
  animation: fade-up 0.9s var(--ease-out) 0.35s forwards;
}

.hero__cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-top: var(--sp-2);
  opacity: 0;
  animation: fade-up 0.9s var(--ease-out) 0.5s forwards;
}

.hero__trust {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-3) var(--sp-5);
  margin-top: var(--sp-4);
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-wide);
  color: var(--text-muted);
  text-transform: uppercase;
  opacity: 0;
  animation: fade-up 0.9s var(--ease-out) 0.65s forwards;
}

.hero__trust-item {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
}

.hero__trust-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--brand-accent);
  display: inline-block;
}

/* HERO IMAGE — mobile-first */
.hero__media {
  position: relative;
  justify-self: center;
  width: 100%;
  max-width: 320px;            /* mobile: more compact */
  /* Matches the real photo ratio (1400x2100 = 2:3) so object-fit:
     cover fills the frame without ever clipping the subject. */
  aspect-ratio: 2 / 3;
  border-radius: var(--r-xl);
  overflow: hidden;
  background: var(--bg-card);
  box-shadow: var(--shadow-elevated);
  opacity: 0;
  animation: fade-left 1s var(--ease-out) 0.3s forwards;
}
@media (min-width: 600px) { .hero__media { max-width: 380px; } }
@media (min-width: 960px) {
  /* Desktop: keep the photo's natural 2:3 proportions and let the
     grid's align-items:center line it up against the copy column —
     centred, not stretched, so the image is never distorted or cut. */
  .hero__media { max-width: 440px; }
}

.hero__media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0, 0, 0, 0.55) 100%);
  pointer-events: none;
}

.hero__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  /* scale(1.08) gives a 4% bleed each side — exactly the room the
     parallax shift (clamped to 4% in scroll.js) needs, so the photo
     edge is never exposed. --parallax-y = scroll, --tilt = cursor.
     No CSS transition: parallax tracks scroll per-frame and the tilt
     is already smoothed by a JS lerp (effects.js). */
  transform:
    perspective(900px)
    rotateX(var(--tilt-x, 0deg))
    rotateY(var(--tilt-y, 0deg))
    translate3d(0, var(--parallax-y, 0), 0)
    scale(1.08);
  will-change: transform;
}

.hero__media-tag {
  position: absolute;
  bottom: var(--sp-5);
  left: var(--sp-5);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-4);
  background: color-mix(in srgb, var(--c-black) 75%, transparent);
  border: 1px solid var(--border-medium);
  border-radius: var(--r-pill);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--c-snow);
  z-index: 2;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.hero__media-tag::before {
  content: '';
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--brand-accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand-accent) 30%, transparent);
}

/* SCROLL INDICATOR */
.hero__scroll {
  position: absolute;
  left: 50%;
  bottom: var(--sp-6);
  transform: translateX(-50%);
  z-index: 3;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-2);
  font-family: var(--font-body);
  font-size: 0.7rem;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--text-muted);
  opacity: 0;
  animation: fade-up 0.9s var(--ease-out) 1.4s forwards;
  text-decoration: none;
}

.hero__scroll svg {
  width: 18px;
  height: 18px;
  color: var(--brand-accent);
  animation: bounce-y 2s var(--ease-in-out) infinite;
}

@media (max-width: 720px) {
  .hero__scroll { display: none; }
}

/* ============================================================
   MARQUEE — horizontal infinite scroll
   ============================================================ */
.marquee {
  position: relative;
  padding-block: var(--sp-7);
  background: var(--bg-deep);
  border-block: 1px solid var(--border-soft);
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, black 8%, black 92%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0%, black 8%, black 92%, transparent 100%);
}

.marquee__track {
  display: flex;
  align-items: center;
  width: max-content;
  gap: var(--sp-9);
  animation: marquee-scroll 45s linear infinite;
}

.marquee:hover .marquee__track {
  animation-play-state: paused;
}

.marquee__item {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-9);
  font-family: var(--font-display);
  font-size: clamp(1.1rem, 0.9rem + 0.6vw, 1.4rem);
  font-weight: 500;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--text-tertiary);
  white-space: nowrap;
  transition: color var(--dur-fast) var(--ease-out);
}
.marquee__item:hover { color: var(--brand-accent); }

.marquee__item::after {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--brand-accent);
  flex-shrink: 0;
  display: inline-block;
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--brand-accent) 18%, transparent);
}

/* ============================================================
   SOBRE
   ============================================================ */
.sobre__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--sp-8);
  align-items: start;
}

@media (min-width: 960px) {
  .sobre__inner {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
    gap: var(--sp-10);
    align-items: center;
  }
  /* Photo stretches to the height of the text column so the two
     columns line up edge-to-edge — no off-centre "dropped" look. */
  /* Desktop: natural 2:3 proportions, centred against the text
     column by the grid's align-items:center — no stretch, no crop. */
  .sobre__media {
    max-width: 400px;
  }
}

.sobre__media {
  position: relative;
  /* Matches the real photo ratio (900x1350 = 2:3) so the subject
     is shown in full — no clipping from object-fit: cover. */
  aspect-ratio: 2 / 3;
  border-radius: var(--r-xl);
  overflow: hidden;
  background: var(--bg-card);
  box-shadow: var(--shadow-elevated);
  max-width: 420px;
  width: 100%;
  margin-inline: auto;
  isolation: isolate;
}

.sobre__media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(0, 0, 0, 0.45) 100%);
  pointer-events: none;
  z-index: 1;
}

.sobre__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  /* scale(1.08) — matches the 4% parallax travel clamp in scroll.js. */
  transform: translate3d(0, var(--parallax-y, 0), 0) scale(1.08);
  will-change: transform;
}

.sobre__media-frame {
  position: absolute;
  inset: 12px;
  border: 1px solid var(--border-medium);
  border-radius: calc(var(--r-xl) - 6px);
  pointer-events: none;
}

.sobre__pillars {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--sp-4);
  margin-top: var(--sp-7);
}

.pillar {
  position: relative;
  padding: var(--sp-5) var(--sp-6);
  /* Glassmorphism — translucency kept at ~74% so the white title
     and secondary text retain strong contrast over the dark
     section + ambient gradient behind. */
  background: color-mix(in srgb, var(--bg-card) 74%, transparent);
  backdrop-filter: blur(16px) saturate(135%);
  -webkit-backdrop-filter: blur(16px) saturate(135%);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  overflow: hidden;
  transition:
    border-color var(--dur-base) var(--ease-out),
    transform var(--dur-base) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out);
}

/* Hairline glass edge along the top — the classic frosted-pane cue */
.pillar::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    color-mix(in srgb, var(--brand-accent) 35%, transparent),
    transparent
  );
  pointer-events: none;
}

.pillar:hover {
  border-color: var(--border-medium);
  transform: translateY(-3px);
  box-shadow: var(--shadow-card);
}

.pillar__num {
  font-family: var(--font-display);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-widest);
  color: var(--brand-accent);
}

.pillar__title {
  margin-top: var(--sp-2);
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-tight);
  color: var(--text-primary);
}

.pillar__desc {
  margin-top: var(--sp-2);
  font-size: var(--fs-sm);
  line-height: var(--lh-base);
  color: var(--text-tertiary);
}

/* ============================================================
   MÉTODO (mobile-first)
   ============================================================ */
.metodo__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--sp-5);
}

@media (min-width: 600px) {
  .metodo__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1100px) {
  .metodo__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

/* B13 — composable transform via CSS vars */
.metodo__step {
  --tilt-x: 0deg;
  --tilt-y: 0deg;
  --hover-y: 0px;

  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  padding: var(--sp-6) var(--sp-5);
  background: var(--bg-card);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-lg);
  overflow: hidden;
  min-width: 0;
  transform: perspective(900px) rotateX(var(--tilt-x)) rotateY(var(--tilt-y)) translateY(var(--hover-y));
  transform-style: preserve-3d;
  transition:
    border-color var(--dur-base) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out),
    transform var(--dur-base) var(--ease-out);
}

@media (min-width: 720px) {
  .metodo__step { padding: var(--sp-7) var(--sp-6) var(--sp-6); }
}

.metodo__step:hover {
  --hover-y: -6px;
  border-color: var(--border-medium);
  box-shadow: var(--shadow-card);
}

.metodo__step::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--brand-accent), transparent);
  opacity: 0;
  transition: opacity var(--dur-base) var(--ease-out);
}

.metodo__step:hover::before {
  opacity: 1;
}

.metodo__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border: 1px solid var(--brand-accent);
  border-radius: 50%;
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 600;
  letter-spacing: var(--tracking-base);
  color: var(--brand-accent);
  background: color-mix(in srgb, var(--brand-accent) 6%, transparent);
  transform: translateZ(20px);
}

.metodo__title {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-tight);
  color: var(--text-primary);
  transform: translateZ(20px);
}

.metodo__desc {
  font-size: var(--fs-sm);
  line-height: var(--lh-base);
  color: var(--text-tertiary);
}

/* ============================================================
   PLANOS (mobile-first)
   3 cards: stack on mobile/tablet, side-by-side on desktop
   ============================================================ */
.planos__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--sp-5);
  align-items: stretch;
  max-width: 480px;
  margin-inline: auto;
}

@media (min-width: 960px) {
  .planos__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    max-width: none;
    gap: var(--sp-6);
  }
}

/* B13 — composable transform */
.plano {
  --tilt-x: 0deg;
  --tilt-y: 0deg;
  --hover-y: 0px;

  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
  padding: var(--sp-6);
  background: var(--bg-card);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-lg);
  overflow: hidden;
  min-width: 0;
  transform: perspective(900px) rotateX(var(--tilt-x)) rotateY(var(--tilt-y)) translateY(var(--hover-y));
  transform-style: preserve-3d;
  transition:
    border-color var(--dur-base) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out),
    transform var(--dur-base) var(--ease-out);
}

@media (min-width: 600px) {
  .plano { padding: var(--sp-7); }
}

.plano:hover {
  --hover-y: -6px;
  border-color: var(--border-medium);
  box-shadow: var(--shadow-card);
}

.plano--featured {
  background: linear-gradient(180deg, var(--bg-card) 0%, var(--bg-elevated) 100%);
  border-color: var(--brand-accent);
  box-shadow: var(--shadow-gold);
}

.plano--featured::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at top, color-mix(in srgb, var(--brand-accent) 14%, transparent) 0%, transparent 60%);
  pointer-events: none;
}

.plano__badge {
  position: absolute;
  top: var(--sp-4);
  right: var(--sp-4);
  padding: var(--sp-2) var(--sp-4);
  background: linear-gradient(135deg, var(--brand-accent), var(--brand-accent-deep));
  color: var(--c-black);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  border-radius: var(--r-pill);
  z-index: 2;
}

.plano__head {
  position: relative;
  z-index: 1;
  padding-bottom: var(--sp-5);
  border-bottom: 1px solid var(--border-soft);
}

.plano__name {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-tight);
  color: var(--text-primary);
  transform: translateZ(20px);
}

.plano__tagline {
  margin-top: var(--sp-2);
  font-size: var(--fs-sm);
  color: var(--text-tertiary);
  line-height: var(--lh-base);
}

.plano__features {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  flex: 1;
}

.plano__feature {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  font-size: var(--fs-sm);
  color: var(--text-secondary);
  line-height: var(--lh-base);
}

.plano__feature svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  color: var(--brand-accent);
  margin-top: 2px;
}

.plano__cta {
  position: relative;
  z-index: 1;
  margin-top: var(--sp-3);
  transform: translateZ(20px);
}

/* ============================================================
   SOCIAL / INSTAGRAM CARDS
   ============================================================ */
.social__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--sp-5);
}

@media (min-width: 600px) { .social__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (min-width: 1024px) { .social__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); } }

.post {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: var(--sp-7);
  padding: var(--sp-6) var(--sp-5) var(--sp-5);
  min-height: 240px;
  background: var(--bg-card);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition:
    border-color var(--dur-base) var(--ease-out),
    transform var(--dur-base) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out);
}

.post:hover {
  border-color: var(--border-medium);
  transform: translateY(-4px);
  box-shadow: var(--shadow-card);
}

.post::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 100%;
  background: radial-gradient(ellipse at top right, color-mix(in srgb, var(--brand-accent) 10%, transparent) 0%, transparent 60%);
  opacity: 0;
  transition: opacity var(--dur-base) var(--ease-out);
  pointer-events: none;
}

.post:hover::before {
  opacity: 1;
}

.post__head {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
}

.post__num {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 600;
  color: var(--brand-accent);
  letter-spacing: var(--tracking-base);
}

.post__category {
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--text-tertiary);
}

.post__body {
  position: relative;
  z-index: 1;
}

.post__title {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-tight);
  color: var(--text-primary);
  line-height: var(--lh-snug);
  transition: color var(--dur-fast) var(--ease-out);
}

.post:hover .post__title { color: var(--brand-accent); }

.post__cta {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--brand-accent);
  margin-top: var(--sp-3);
}
.post__cta svg {
  width: 14px;
  height: 14px;
  transition: transform var(--dur-fast) var(--ease-out);
}
.post:hover .post__cta svg { transform: translateX(4px); }

/* ============================================================
   FAQ
   ============================================================ */
.faq__list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  max-width: 880px;
  margin-inline: auto;
}

.faq__item {
  background: var(--bg-card);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-md);
  transition: border-color var(--dur-base) var(--ease-out);
  overflow: hidden;
}

.faq__item[open] {
  border-color: var(--border-medium);
  background: var(--bg-elevated);
}

.faq__summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  padding: var(--sp-5) var(--sp-6);
  cursor: pointer;
  list-style: none;
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: 500;
  letter-spacing: var(--tracking-base);
  color: var(--text-primary);
  transition: color var(--dur-fast) var(--ease-out);
}

.faq__summary::-webkit-details-marker { display: none; }
.faq__summary::marker { display: none; content: ''; }

.faq__summary:hover { color: var(--brand-accent); }

.faq__icon {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border: 1px solid var(--border-medium);
  border-radius: 50%;
  font-family: var(--font-body);
  font-size: 1.25rem;
  font-weight: 300;
  color: var(--brand-accent);
  transition: transform var(--dur-base) var(--ease-out);
}

.faq__item[open] .faq__icon {
  transform: rotate(45deg);
}

.faq__body {
  padding: 0 var(--sp-6) var(--sp-5);
  font-size: var(--fs-sm);
  line-height: var(--lh-loose);
  color: var(--text-tertiary);
}

/* ============================================================
   CONTATO 2.0 — WhatsApp-first conversion machine
   ============================================================ */
.contato2__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--sp-5);
}

@media (min-width: 768px) {
  .contato2__grid { gap: var(--sp-6); }
}

@media (min-width: 1024px) {
  .contato2__grid {
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
    grid-template-areas:
      "primary steps"
      "side    side";
    gap: var(--sp-6);
  }
  .contato2__primary { grid-area: primary; }
  .contato2__steps   { grid-area: steps; }
  .contato2__side    { grid-area: side; }
}

@media (min-width: 1240px) {
  .contato2__grid {
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr) minmax(0, 1fr);
    grid-template-areas:
      "primary steps side"
      "primary steps side";
    align-items: stretch;
  }
}

/* ---------- PRIMARY CONTACT CARD ---------- */
.contato2__primary {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
  padding: var(--sp-6) var(--sp-5);
  border-radius: var(--r-xl);
  background: var(--bg-card);
  border: 1px solid var(--border-soft);
  color: inherit;
  text-decoration: none;
  overflow: hidden;
  isolation: isolate;
  min-width: 0;
  box-shadow: var(--shadow-card);
  transition:
    transform var(--dur-base) var(--ease-out),
    border-color var(--dur-base) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out);
}

@media (min-width: 600px) {
  .contato2__primary { padding: var(--sp-7); gap: var(--sp-6); }
}
@media (min-width: 1024px) {
  .contato2__primary { padding: var(--sp-8) var(--sp-7); }
}

.contato2__primary:hover {
  transform: translateY(-4px);
  border-color: var(--border-medium);
  box-shadow: var(--shadow-elevated);
}

.contato2__primary:focus-visible {
  outline: 3px solid var(--brand-accent);
  outline-offset: 4px;
}

/* Soft gold light — top-right corner */
.contato2__primary::before {
  content: '';
  position: absolute;
  top: -40%;
  right: -20%;
  width: 80%;
  height: 140%;
  background:
    radial-gradient(circle, color-mix(in srgb, var(--brand-accent) 14%, transparent) 0%, transparent 60%);
  filter: blur(50px);
  pointer-events: none;
  z-index: 0;
}

/* Soft accent glow — bottom-left corner */
.contato2__primary-glow {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at bottom left, color-mix(in srgb, var(--brand-accent) 8%, transparent) 0%, transparent 60%);
  z-index: 0;
  pointer-events: none;
}

.contato2__primary > *:not(.contato2__primary-glow) {
  position: relative;
  z-index: 1;
}

.contato2__primary-head {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
}

.contato2__primary-icon {
  flex-shrink: 0;
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--brand-accent) 12%, transparent);
  border: 1px solid var(--border-medium);
  color: var(--brand-accent);
}

.contato2__primary-meta {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.contato2__primary-label {
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--brand-accent);
}

.contato2__primary-status {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--text-tertiary);
}

.contato2__primary-pulse {
  position: relative;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--brand-accent);
  flex-shrink: 0;
}
.contato2__primary-pulse::before {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  border: 2px solid color-mix(in srgb, var(--brand-accent) 70%, transparent);
  animation: contato-pulse 2s var(--ease-out) infinite;
}

@keyframes contato-pulse {
  0%   { transform: scale(0.6); opacity: 1; }
  100% { transform: scale(1.6); opacity: 0; }
}

.contato2__primary-number {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(1.65rem, 1.2rem + 2vw, 2.4rem);
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: var(--text-primary);
  word-break: keep-all;
}

.contato2__primary-cta {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-5);
  background: var(--brand-accent);
  color: var(--c-black);
  border-radius: var(--r-pill);
  font-weight: 700;
  font-size: var(--fs-sm);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  align-self: flex-start;
  transition:
    transform var(--dur-base) var(--ease-spring),
    box-shadow var(--dur-base) var(--ease-out);
}

.contato2__primary:hover .contato2__primary-cta {
  transform: translateX(4px);
  box-shadow: var(--shadow-gold);
}

.contato2__primary-cta svg { transition: transform var(--dur-base) var(--ease-out); }
.contato2__primary:hover .contato2__primary-cta svg { transform: translateX(3px); }

/* ---------- HOW IT WORKS ---------- */
.contato2__steps {
  position: relative;
  padding: var(--sp-6) var(--sp-5);
  background: var(--bg-card);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-xl);
  min-width: 0;
}

@media (min-width: 600px) {
  .contato2__steps { padding: var(--sp-7); }
}
@media (min-width: 1024px) {
  .contato2__steps { padding: var(--sp-8) var(--sp-7); }
}

.contato2__steps-title {
  font-family: var(--font-display);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--brand-accent);
  margin-bottom: var(--sp-5);
}

.contato2__steps-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
  counter-reset: contato-step;
}

.contato2__step {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-4);
}

.contato2__step-num {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: color-mix(in srgb, var(--brand-accent) 12%, transparent);
  border: 1px solid var(--border-medium);
  font-family: var(--font-display);
  font-size: var(--fs-sm);
  font-weight: 700;
  color: var(--brand-accent);
}

.contato2__step strong {
  display: block;
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-base);
  color: var(--text-primary);
  margin-bottom: 4px;
}

.contato2__step p {
  font-size: var(--fs-sm);
  line-height: var(--lh-base);
  color: var(--text-tertiary);
  margin: 0;
}

/* ---------- SECONDARY MINI CARDS ---------- */
.contato2__side {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--sp-3);
  min-width: 0;
}

@media (min-width: 600px) {
  .contato2__side { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (min-width: 1240px) {
  .contato2__side { grid-template-columns: minmax(0, 1fr); }
}

.contato2__mini {
  position: relative;
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-4) var(--sp-5);
  background: var(--bg-card);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-lg);
  text-decoration: none;
  color: inherit;
  min-width: 0;
  transition:
    border-color var(--dur-base) var(--ease-out),
    transform var(--dur-base) var(--ease-out),
    background-color var(--dur-base) var(--ease-out);
}

.contato2__mini:not(.contato2__mini--static):hover {
  border-color: var(--border-medium);
  transform: translateY(-2px);
  background: var(--bg-elevated);
}

.contato2__mini--static {
  cursor: default;
}

.contato2__mini-icon {
  flex-shrink: 0;
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: var(--r-md);
  background: color-mix(in srgb, var(--brand-accent) 10%, transparent);
  color: var(--brand-accent);
}

.contato2__mini-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  flex: 1;
}

.contato2__mini-label {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--text-muted);
}

.contato2__mini-value {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.2;
  word-break: break-word;
}

.contato2__mini-hint {
  font-size: var(--fs-xs);
  color: var(--text-tertiary);
  line-height: var(--lh-base);
}

.contato2__mini-arrow {
  flex-shrink: 0;
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  color: var(--text-muted);
  transition: color var(--dur-fast) var(--ease-out), transform var(--dur-base) var(--ease-out);
}

.contato2__mini:not(.contato2__mini--static):hover .contato2__mini-arrow {
  color: var(--brand-accent);
  transform: translate(2px, -2px);
}
