/* =========================================================
   Objeções 360 — Landing v2
   Estrutura inspirada em página de vendas (ref. Smart Scripts)
   Identidade: laranja-fogo + azul-marinho + branco
   Fonte: Space Grotesk (display) + Inter (corpo)
   Mobile-first · animações via main.js (GSAP)
   ========================================================= */

:root {
  --navy:      #0a1733;   /* azul marinho escuro */
  --navy-2:    #0e2049;
  --navy-3:    #13285a;
  --orange:    #f23410;   /* laranja forte quase vermelho */
  --orange-2:  #ff5a2c;
  --orange-dk: #c4280a;

  --white:     #ffffff;
  --bg:        #ffffff;
  --bg-soft:   #f5f6fa;
  --ink:       #0a1733;
  --ink-soft:  #515d78;
  --ink-mute:  #8b95ad;
  --line:      #e4e8f0;
  --line-d:    rgba(255,255,255,.12);

  --radius:    16px;
  --radius-lg: 24px;
  --radius-sm: 10px;
  --shadow:    0 20px 50px -28px rgba(10, 23, 51, .35);
  --shadow-lg: 0 50px 110px -45px rgba(10, 23, 51, .55);
  --maxw:      1140px;

  --fdisp: "Space Grotesk", -apple-system, BlinkMacSystemFont, sans-serif;
  --fbody: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--fbody);
  color: var(--ink);
  background: var(--bg);
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
::selection { background: var(--orange); color: #fff; }

h1, h2, h3, .display { font-family: var(--fdisp); }

.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: clamp(20px, 5vw, 44px); }

/* progress bar */
.progress { position: fixed; inset: 0 0 auto 0; height: 3px; z-index: 200; }
.progress i { display: block; height: 100%; width: 100%; transform: scaleX(0); transform-origin: left; background: var(--orange); }

/* utils */
.grad { color: var(--orange); }
.mask-line { display: block; overflow: hidden; padding-bottom: .04em; }
.mask-line .line { display: block; }
.reveal { will-change: transform, opacity; }

/* =========================================================
   NAV
   ========================================================= */
.nav { position: fixed; inset: 0 0 auto 0; z-index: 100; transition: background .3s, box-shadow .3s; }
.nav.scrolled { background: rgba(10,23,51,.92); backdrop-filter: blur(12px); box-shadow: 0 10px 30px -18px rgba(0,0,0,.6); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 68px; }
.brand { font-family: var(--fdisp); font-weight: 700; font-size: clamp(1.3rem, 4.5vw, 1.7rem); letter-spacing: -.02em; color: #fff; }
.brand b { color: var(--orange-2); }
.nav.light-top .brand { color: #fff; }

/* tag no canto direito do topo */
.nav-tag {
  display: inline-flex; align-items: center; gap: .5em;
  font-family: var(--fbody); font-size: clamp(.74rem, 2.6vw, .86rem); font-weight: 700;
  color: #ffd9cd; background: rgba(242,52,16,.16); border: 1px solid rgba(242,52,16,.4);
  padding: .5em 1em; border-radius: 999px; line-height: 1; white-space: nowrap;
}
.nav-tag::before { content: "✦"; color: var(--orange-2); }

/* =========================================================
   BOTÕES
   ========================================================= */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .55em;
  font-family: var(--fbody); font-weight: 700; font-size: clamp(.98rem, 1.1vw, 1.05rem);
  text-decoration: none; cursor: pointer; border: none; line-height: 1;
  padding: 1.05em 1.9em; border-radius: 999px;
  background: #b4ff3a; color: #07101f;
  box-shadow: 0 16px 34px -12px rgba(180,255,58,.55);
  position: relative; will-change: transform; transition: background .25s, box-shadow .25s;
}
.btn:hover { background: #c6ff5e; box-shadow: 0 22px 46px -12px rgba(180,255,58,.7); }
.btn:active { transform: scale(.98); }
.btn .arrow { transition: transform .3s; }
.btn:hover .arrow { transform: translateX(4px); }
.btn-sm { padding: .72em 1.4em; font-size: .92rem; }

.btn-ghost { background: transparent; color: #fff; border: 1.5px solid rgba(255,255,255,.4); box-shadow: none; }
.btn-ghost:hover { background: rgba(255,255,255,.08); border-color: #fff; box-shadow: none; }
.btn-ghost.dark { color: var(--navy); border-color: var(--navy); }
.btn-ghost.dark:hover { background: rgba(10,23,51,.06); }

.cta-note { display: block; margin-top: 14px; font-size: .88rem; color: var(--ink-mute); }
.cta-note.on-dark { color: rgba(255,255,255,.6); }
.cta-note b { color: inherit; opacity: .85; }

/* =========================================================
   SECTIONS
   ========================================================= */
.section { padding: clamp(64px, 9vw, 120px) 0; position: relative; }
.section.soft { background: var(--bg-soft); }
.section.dark { background: var(--navy); color: #e9eefb; }
.section.dark h2, .section.dark h3 { color: #fff; }
.section.dark .lead { color: #aebbd6; }

.kicker {
  display: inline-flex; align-items: center; gap: .5em;
  font-family: var(--fbody); font-size: .78rem; font-weight: 800;
  letter-spacing: .16em; text-transform: uppercase; color: var(--orange);
  margin-bottom: 16px;
}
.kicker::before { content: ""; width: 26px; height: 2px; background: var(--orange); }
.kicker.center { justify-content: center; }

.head { max-width: 760px; margin-bottom: clamp(38px, 6vw, 60px); }
.head.center { margin-inline: auto; text-align: center; }
h2 { font-size: clamp(1.85rem, 5vw, 3.1rem); line-height: 1.07; letter-spacing: -.03em; font-weight: 700; }
h3 { font-size: 1.25rem; letter-spacing: -.02em; font-weight: 700; }
.lead { font-size: clamp(1.02rem, 1.8vw, 1.18rem); color: var(--ink-soft); margin-top: 18px; line-height: 1.6; }

/* =========================================================
   HERO
   ========================================================= */
.hero {
  position: relative; color: #fff;
  padding: clamp(72px, 8vh, 96px) 0 clamp(40px, 6vh, 70px);
  background:
    radial-gradient(900px 500px at 85% -5%, rgba(242,52,16,.30) 0%, transparent 58%),
    radial-gradient(800px 600px at 0% 100%, rgba(19,40,90,.9) 0%, transparent 60%),
    var(--navy);
  overflow: hidden;
}
.hero::after {
  content: ""; position: absolute; inset: 0; pointer-events: none; opacity: .5;
  background-image: linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: radial-gradient(700px 400px at 70% 10%, #000 0%, transparent 75%);
          mask-image: radial-gradient(700px 400px at 70% 10%, #000 0%, transparent 75%);
}
.hero-deco { position: absolute; inset: 0; pointer-events: none; z-index: 1; }
.hero-deco .ring { position: absolute; width: clamp(260px, 38vw, 480px); height: clamp(260px, 38vw, 480px); border: 1.5px dashed rgba(242,52,16,.3); border-radius: 50%; top: -8%; right: -10%; }
/* base (mobile): foto ACIMA; headline sobe e cobre ~20% da base da imagem */
.hero-grid { position: relative; z-index: 3; display: flex; flex-direction: column; }
.hero-inner { max-width: 880px; position: relative; z-index: 2; }

.hero-photo { order: -1; position: relative; display: flex; justify-content: center; align-items: flex-end; margin-bottom: -98px; }
.hero-photo::before {
  content: ""; position: absolute; inset: auto 0 0 50%; transform: translateX(-50%);
  width: 88%; aspect-ratio: 1; border-radius: 50%;
  background: radial-gradient(circle, rgba(242,52,16,.26) 0%, transparent 62%);
  z-index: 0;
}
/* fumaça azul-marinho no canto inferior esquerdo — dissolve o braço cortado */
.hero-photo::after {
  content: ""; position: absolute; z-index: 2; pointer-events: none;
  left: -4%; bottom: -2%; width: 66%; height: 52%;
  background: radial-gradient(ellipse at 32% 72%, rgba(10,23,51,.96) 0%, rgba(10,23,51,.72) 38%, rgba(10,23,51,0) 72%);
  -webkit-filter: blur(16px); filter: blur(16px);
}
.hero-photo img {
  position: relative; z-index: 1;
  width: auto; max-width: 78%; max-height: 320px;
  -webkit-filter: drop-shadow(0 26px 40px rgba(0,0,0,.45));
          filter: drop-shadow(0 26px 40px rgba(0,0,0,.45));
  -webkit-mask-image: linear-gradient(to bottom, #000 70%, transparent 100%);
          mask-image: linear-gradient(to bottom, #000 70%, transparent 100%);
}

.eyebrow {
  display: inline-flex; align-items: center; gap: .55em;
  font-family: var(--fbody); font-size: .78rem; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: #ffd9cd;
  background: rgba(242,52,16,.16); border: 1px solid rgba(242,52,16,.35);
  padding: .5em 1.05em; border-radius: 999px; margin-bottom: 24px;
}
.eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--orange-2); }

/* base (telas estreitas, ex. iPhone 12 Pro 390px): fonte menor p/ caber 1 linha */
.hero h1 { font-size: clamp(1.85rem, 8vw, 2.2rem); line-height: 1.04; letter-spacing: -.03em; font-weight: 700; margin-bottom: clamp(20px, 3vw, 28px); text-wrap: balance; }
.hero .sub { font-size: clamp(1.05rem, 2.1vw, 1.32rem); color: #b9c5e0; max-width: 620px; margin-bottom: clamp(28px, 4vw, 38px); }
.hero .sub b { color: #fff; font-weight: 600; }

/* preço com desconto no hero */
.hero-price { display: inline-flex; align-items: center; flex-wrap: wrap; gap: 8px 14px; margin-bottom: 20px; }
.hero-price .off {
  font-family: var(--fdisp); font-weight: 700; font-size: .82rem; letter-spacing: .03em;
  background: var(--orange); color: #fff; padding: .42em .8em; border-radius: 8px;
  box-shadow: 0 10px 22px -10px rgba(242,52,16,.8); transform: rotate(-3deg);
}
.hero-price .from { font-size: 1rem; color: #93a1c2; }
.hero-price .from s { color: #93a1c2; text-decoration-thickness: 2px; }
.hero-price .now { font-family: var(--fdisp); font-size: clamp(1.25rem, 4.5vw, 1.6rem); font-weight: 700; color: #fff; }
.hero-price .now b { color: #b4ff3a; }

.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.hero-proof { display: inline-flex; align-items: center; gap: 10px; margin-top: 30px; font-size: .92rem; color: #aebbd6; }
.hero-proof .star { color: var(--orange-2); font-size: 1.1rem; }

/* =========================================================
   STATS strip
   ========================================================= */
.stats {
  display: grid; grid-template-columns: 1fr; gap: 0;
  border-top: 1px solid var(--line-d);
  margin-top: clamp(40px, 6vw, 60px);
}
.stat { padding: 26px 4px; text-align: center; border-bottom: 1px solid var(--line-d); }
.stat .n { font-family: var(--fdisp); font-size: clamp(2.2rem, 7vw, 3.2rem); font-weight: 700; letter-spacing: -.03em; color: var(--orange-2); line-height: 1; }
.stat .l { font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; color: #93a1c2; margin-top: 8px; }

/* =========================================================
   PROCESSO — etapas
   ========================================================= */
.steps { display: grid; grid-template-columns: 1fr; gap: 14px; margin-top: clamp(34px, 5vw, 50px); }
.step {
  position: relative; background: var(--bg); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 22px 22px;
  display: flex; gap: 16px; align-items: center; box-shadow: var(--shadow);
}
.step.active { background: var(--navy); border-color: var(--navy); color: #fff; }
.step.active .step-n { background: var(--orange); color: #fff; }
.step.active .step-t { color: #fff; }
.step.active .step-d { color: #c3cfe8; }
.step-n { flex: none; width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center; font-family: var(--fdisp); font-weight: 700; background: var(--bg-soft); color: var(--orange); }
.step-t { font-family: var(--fdisp); font-weight: 700; font-size: 1.05rem; letter-spacing: -.01em; }
.step-d { font-size: .9rem; color: var(--ink-soft); margin-top: 2px; }

/* =========================================================
   ERROS — cards numerados estilo "frase errada"
   ========================================================= */
.errors { display: grid; grid-template-columns: 1fr; gap: 18px; margin-top: clamp(36px, 6vw, 54px); }
.err {
  background: var(--navy-2); border: 1px solid var(--line-d); border-radius: var(--radius);
  padding: 28px 26px; position: relative; overflow: hidden;
}
.err .tag { display: inline-block; font-size: .74rem; font-weight: 800; letter-spacing: .12em; color: var(--orange-2); margin-bottom: 16px; }
.err .quote {
  font-family: var(--fdisp); font-size: 1.12rem; line-height: 1.4; color: #fff; font-weight: 500;
  padding-left: 18px; border-left: 3px solid var(--orange); margin-bottom: 16px; font-style: italic;
}
.err .why { font-size: .96rem; color: #aebbd6; }
.err .x { position: absolute; top: 20px; right: 22px; font-family: var(--fdisp); font-size: 3.4rem; font-weight: 700; color: rgba(242,52,16,.18); line-height: 1; }

/* =========================================================
   SOLUÇÃO
   ========================================================= */
.sol { max-width: 720px; }
.sol p { font-size: clamp(1.05rem, 2vw, 1.22rem); color: var(--ink-soft); margin-top: 18px; }
.sol p b { color: var(--ink); }
.tags { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 28px; }
.tags span { font-size: .85rem; font-weight: 700; color: var(--orange-dk); background: #ffe9e2; border: 1px solid #ffd2c4; padding: .55em 1.05em; border-radius: 999px; }

/* =========================================================
   O QUE VOCÊ VAI ENCONTRAR — lista de entregáveis
   ========================================================= */
.deliver { display: grid; grid-template-columns: 1fr; gap: 20px; margin-top: clamp(36px, 6vw, 54px); }
.dcard { background: var(--bg); border: 1px solid var(--line); border-radius: var(--radius-lg); padding: 30px 28px; box-shadow: var(--shadow); position: relative; overflow: hidden; }
.dcard .ico { width: 56px; height: 56px; border-radius: 14px; display: grid; place-items: center; background: #ffe9e2; font-size: 1.6rem; margin-bottom: 18px; }
.dcard h3 { margin-bottom: 10px; }
.dcard p { color: var(--ink-soft); font-size: .98rem; }
.dcard .pill { display: inline-block; margin-top: 16px; font-size: .78rem; font-weight: 700; color: var(--orange-dk); background: #ffe9e2; padding: .4em .9em; border-radius: 999px; }

.inside { margin-top: clamp(30px, 5vw, 44px); display: grid; grid-template-columns: 1fr; gap: 12px; }
.inside-row { display: flex; gap: 12px; align-items: flex-start; background: var(--bg); border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 15px 18px; font-size: .98rem; color: var(--ink); font-weight: 500; }
.inside-row .c { flex: none; width: 24px; height: 24px; border-radius: 7px; display: grid; place-items: center; background: var(--orange); color: #fff; font-size: .72rem; font-weight: 800; margin-top: 1px; }

/* =========================================================
   DEPOIMENTOS
   ========================================================= */
.testi { display: grid; grid-template-columns: 1fr; gap: 18px; margin-top: clamp(36px, 6vw, 54px); }
.tcard { background: var(--bg); border: 1px solid var(--line); border-radius: var(--radius); padding: 26px 24px; box-shadow: var(--shadow); }
.tcard .stars { color: var(--orange); letter-spacing: 2px; margin-bottom: 14px; }
.tcard p { font-size: 1rem; color: var(--ink); line-height: 1.6; }
.tcard .who { display: flex; align-items: center; gap: 12px; margin-top: 18px; }
.tcard .av { width: 46px; height: 46px; border-radius: 50%; overflow: hidden; background: linear-gradient(140deg, var(--navy-3), var(--orange)); flex: none; }
.tcard .av img { width: 100%; height: 100%; object-fit: cover; display: block; }
.tcard .who b { font-size: .95rem; display: block; }
.tcard .who small { font-size: .82rem; color: var(--ink-mute); }
.ph-note { font-size: .8rem; color: var(--orange-dk); background: #ffe9e2; border: 1px dashed var(--orange); border-radius: 8px; padding: 8px 12px; margin-top: 20px; display: inline-block; }

/* =========================================================
   INVESTIMENTO
   ========================================================= */
.price-wrap { max-width: 600px; margin-inline: auto; }
.pcard { background: var(--bg); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-lg); border: 1px solid var(--line); }
.pcard-top { background: var(--navy); color: #fff; padding: 30px; text-align: left; position: relative; }
.pcard-top .tag { display: inline-block; font-size: .74rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; background: var(--orange); color: #fff; padding: .42em 1em; border-radius: 999px; margin-bottom: 14px; }
.pcard-top h3 { font-size: 1.5rem; color: #fff; }
.pcard-body { padding: 32px 30px; }
.price { display: flex; flex-direction: column; align-items: flex-start; gap: 4px; text-align: left; margin-bottom: 26px; }
.price .from { font-size: .95rem; color: var(--ink-mute); }
.price .from s { color: var(--ink-mute); }
.price .now { font-family: var(--fdisp); font-size: clamp(2.6rem, 9vw, 3.6rem); font-weight: 700; letter-spacing: -.03em; line-height: 1; margin: 2px 0; color: var(--ink); }
.price .now small { font-size: .85rem; font-weight: 600; color: var(--ink-soft); }
.price .terms { font-size: .92rem; color: var(--ink-soft); }
.inc { list-style: none; display: grid; gap: 12px; margin-bottom: 26px; }
.inc li { position: relative; padding-left: 36px; font-size: 1rem; line-height: 1.5; }
.inc li .c { position: absolute; left: 0; top: 2px; width: 24px; height: 24px; border-radius: 7px; display: grid; place-items: center; background: var(--orange); color: #fff; font-size: .72rem; font-weight: 800; }
.inc li b { font-weight: 700; }
.pcard .btn { width: 100%; }

/* =========================================================
   FAQ
   ========================================================= */
.faq { max-width: 760px; margin-inline: auto; }
.faq-item { border: 1px solid var(--line); border-radius: var(--radius-sm); background: var(--bg); margin-bottom: 12px; overflow: hidden; }
.faq-q { width: 100%; text-align: left; background: none; border: none; cursor: pointer; font-family: var(--fdisp); font-size: 1.05rem; font-weight: 700; color: var(--ink); padding: 20px 22px; display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.faq-q .pm { flex: none; transition: transform .3s; color: var(--orange); font-size: 1.5rem; line-height: 1; }
.faq-item.open .faq-q .pm { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .4s ease; }
.faq-a p { padding: 0 22px 20px; color: var(--ink-soft); font-size: 1rem; }

/* =========================================================
   AUTORIDADE — "Quem está por trás"
   ========================================================= */
.auth { display: grid; gap: clamp(28px, 5vw, 56px); align-items: center; grid-template-columns: 1fr; }
.auth-photo { position: relative; border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 4/5; max-width: 380px; background: linear-gradient(150deg, var(--navy-3), var(--orange)); display: grid; place-items: center; box-shadow: var(--shadow-lg); }
.auth-photo img { width: 100%; height: 100%; object-fit: cover; }
.auth-photo .ph { color: rgba(255,255,255,.85); font-size: .9rem; text-align: center; padding: 20px; place-items: center; }
.auth .bigname { font-family: var(--fdisp); font-size: clamp(2.6rem, 8vw, 4.4rem); line-height: .95; letter-spacing: -.04em; font-weight: 700; color: #fff; margin-bottom: 4px; }
.auth .bigname span { display: block; color: var(--orange-2); }
.auth .role { font-size: .82rem; letter-spacing: .14em; text-transform: uppercase; color: #93a1c2; margin-bottom: 22px; }
.auth p { color: #aebbd6; font-size: 1.04rem; margin-bottom: 16px; }
.auth p b { color: #fff; }
.auth .tags { margin-top: 26px; }
.auth .tags span { background: rgba(242,52,16,.14); border-color: rgba(242,52,16,.35); color: #ffd9cd; }
.cred { list-style: none; display: grid; gap: 11px; margin-top: 24px; }
.cred li { position: relative; padding-left: 33px; font-size: .98rem; color: #aebbd6; line-height: 1.55; }
.cred li b { color: #fff; font-weight: 700; }
.cred li .c { position: absolute; left: 0; top: 3px; width: 22px; height: 22px; border-radius: 6px; display: grid; place-items: center; background: rgba(242,52,16,.2); color: var(--orange-2); font-size: .72rem; font-weight: 800; }

/* =========================================================
   GARANTIA
   ========================================================= */
.guarantee { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 20px; max-width: 660px; margin-inline: auto; }
.guarantee .seal { display: inline-flex; align-items: center; gap: .5em; flex: none; color: #fff; font-family: var(--fdisp); font-weight: 700; font-size: clamp(1.05rem, 4vw, 1.45rem); letter-spacing: .03em; text-transform: uppercase; background: var(--orange); padding: .75em 1.4em; border-radius: 12px; box-shadow: 0 18px 40px -16px rgba(242,52,16,.6); line-height: 1; }
.guarantee p { color: var(--ink-soft); font-size: 1.05rem; }
.guarantee p b { color: var(--ink); }

/* =========================================================
   CTA FINAL
   ========================================================= */
.final { text-align: center; background: radial-gradient(700px 360px at 50% 0%, rgba(242,52,16,.22) 0%, transparent 60%), var(--navy); color: #fff; }
.final h2 { color: #fff; font-size: clamp(2rem, 5.5vw, 3.4rem); }
.final p { color: #aebbd6; max-width: 540px; margin: 18px auto 32px; font-size: 1.1rem; }

/* =========================================================
   FOOTER
   ========================================================= */
.footer { background: #060f24; color: #6f7c9c; padding: 36px 0; font-size: .88rem; }
.footer-inner { display: flex; flex-direction: column; gap: 12px; align-items: center; text-align: center; }
.footer b { color: #c3cfe8; }
.footer a { color: #93a1c2; text-decoration: none; }
.footer a:hover { color: #fff; }

/* =========================================================
   MEDIA QUERIES (min-width)
   ========================================================= */
/* a partir de 412px (S20 Ultra, iPhone 14+): headline no tamanho cheio */
@media (min-width: 412px) {
  .hero h1 { font-size: clamp(2.2rem, 6.4vw, 4.3rem); line-height: 1.02; letter-spacing: -.035em; }
}

@media (min-width: 600px) {
  .stats { grid-template-columns: repeat(3, 1fr); }
  .stat { border-bottom: none; border-right: 1px solid var(--line-d); }
  .stat:last-child { border-right: none; }
  .errors { grid-template-columns: repeat(3, 1fr); }
  .deliver { grid-template-columns: 1fr 1fr; }
  .inside { grid-template-columns: 1fr 1fr; }
  .testi { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 900px) {
  .steps { grid-template-columns: repeat(4, 1fr); }
  .step { flex-direction: column; align-items: flex-start; text-align: left; min-height: 190px; }
  .auth { grid-template-columns: 380px 1fr; }
  .hero-grid { display: block; }
  .hero-photo { display: none; }
}
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
  html { scroll-behavior: auto; }
}
