* { box-sizing: border-box; }
  html, body { margin: 0; }
  body { font-family: var(--font-sans); background: var(--av-cream-site); color: var(--av-ink); overflow-x: hidden; }

  .nav { max-width: 1240px; margin: 0 auto; padding: 20px 40px 0; display: flex; align-items: center; justify-content: space-between; }
  .nav .right { font-size: 12.5px; color: var(--av-gray); }

  /* Hero: content top-left, Ana photo right, sub/bullets/form below */
  .hero { max-width: 1240px; margin: 0 auto; padding: 18px 40px 24px; display: grid; grid-template-columns: 1.12fr 0.88fr; column-gap: 40px; row-gap: 0; align-items: stretch; grid-template-areas: "content photo" "sub photo" "bullets photo" "form photo"; }
  .left { grid-area: content; display: flex; flex-direction: column; }
  .right { grid-area: photo; }
  .sub { grid-area: sub; }
  .bullets { grid-area: bullets; }
  .formwrap { grid-area: form; }
  .topbar { display: none; }
  .left .eb { margin-bottom: 14px; }
  .left h1 { font-family: var(--font-display); font-weight: 700; font-size: 38px; line-height: 1.06; letter-spacing: -0.01em; margin: 0; color: var(--av-navy); max-width: 580px; }
  .left h1 .g { color: var(--av-gold); }
  .mbr { display: none; }
  .sub { font-family: var(--font-sans); font-weight: 500; font-size: 16px; line-height: 1.45; color: var(--av-ink); margin: 14px 0 0; max-width: 540px; }
  .bullets { list-style: none; padding: 0; margin: 18px 0 0; display: grid; grid-template-columns: 1fr; gap: 12px; }
  .bullets li { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; font-weight: 500; line-height: 1.3; color: var(--av-navy); }
  .bullets .ck { flex: none; width: 22px; height: 22px; border-radius: 50%; background: rgba(198,143,67,.18); display: flex; align-items: center; justify-content: center; margin-top: 1px; }

  .card { margin-top: 24px; max-width: 580px; background: #fff; color: var(--av-ink); border-radius: 20px; box-shadow: var(--sh-card-lg); padding: 26px 28px; }
  .card .ch { font-family: var(--font-display); font-weight: 700; color: var(--av-navy); font-size: 22px; margin: 0 0 3px; }
  .card .cs { color: var(--av-gray); font-size: 13px; margin: 0 0 16px; }
  .form { display: flex; flex-direction: column; gap: 12px; }
  .row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
  .row2 > *, .phone > * { min-width: 0; }
  .phone { display: grid; grid-template-columns: 106px 1fr; gap: 10px; align-items: end; }
  .selectwrap label { display:block; font-size:12.5px; font-weight:600; color:var(--av-navy); margin-bottom:7px; }
  select { width: 100%; appearance: none; -webkit-appearance: none; font-family: var(--font-sans); font-weight: 600; font-size: 14.5px; color: var(--av-navy); background: #fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2362615C' stroke-width='2.5'><path d='M6 9l6 6 6-6'/></svg>") no-repeat right 11px center; border: 1.5px solid var(--av-gold); border-radius: 13px; padding: 12px 32px 12px 13px; cursor: pointer; }
  select:invalid { color: var(--av-gray); font-weight: 500; }
  .consent { display: flex; gap: 9px; align-items: flex-start; font-size: 11px; color: var(--av-gray); line-height: 1.45; }
  /* Gold field borders (CTA tone) */
  .card .form label span:has(> input) { border-color: var(--av-gold) !important; }
  .consent input { margin-top: 1px; accent-color: var(--av-navy); width: 15px; height: 15px; flex: none; }

  /* Right: Ana photo */
  .right { position: relative; display: flex; align-items: flex-start; justify-content: center; }
  .photo { position: relative; transform: translateX(100px); display: flex; justify-content: center; }
  .photo .ring { position: absolute; top: 30px; left: 50%; transform: translateX(-50%); width: 440px; height: 440px; border-radius: 50%; background: radial-gradient(circle, rgba(249,195,73,.20) 0%, rgba(249,195,73,0) 66%); z-index: 0; }
  .photo img { position: relative; z-index: 1; width: 100%; max-width: 460px; display: block; }
  .photo .photo-fade { position: absolute; left: -20px; right: -20px; bottom: 0; height: 180px; background: linear-gradient(to bottom, rgba(248,247,243,0) 0%, var(--av-cream-site) 72%); z-index: 2; pointer-events: none; }
  .photo .reg { position: absolute; left: 50%; transform: translateX(-50%); bottom: 14px; z-index: 3; width: 320px; max-width: 92%; text-align: center; font-size: 12.5px; line-height: 1.45; color: var(--av-gray); }

  .legal { max-width: 1240px; margin: 0 auto; padding: 0 40px 28px; }
  .legal p { font-size: 11.5px; }

  .thanks { margin-top: 24px; max-width: 580px; background: #fff; color: var(--av-ink); border-radius: 20px; box-shadow: var(--sh-card-lg); padding: 36px 32px; text-align: center; }
  .thanks .badge { width: 58px; height: 58px; border-radius: 50%; background: var(--av-cta-gradient); display: flex; align-items: center; justify-content: center; margin: 0 auto 16px; box-shadow: var(--sh-cta); }
  .thanks h2 { font-family: var(--font-display); font-weight: 700; color: var(--av-navy); font-size: 27px; margin: 0 0 8px; }
  .thanks p { color: var(--av-gray); font-size: 15px; line-height: 1.55; margin: 0 auto 6px; max-width: 360px; }

  @media (max-width: 900px) {
    .nav { display: none; }
    .topbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; grid-area: top; margin-bottom: 4px; }
    .topbar .reg-top { width: 128px; flex: none; font-size: 8.5px; line-height: 1.32; color: var(--av-gray); text-align: right; }
    .hero { position: relative; grid-template-columns: 1fr; column-gap: 0; row-gap: 0; padding: 16px 18px 22px; align-items: stretch; grid-template-areas: "top" "content" "sub" "bullets" "form"; }
    .mbr { display: inline; }
    .left { width: 59%; position: relative; z-index: 4; }
    .left h1 { font-size: 24px; line-height: 1.15; max-width: none; }
    .left .eb { margin-bottom: 10px; }
    .sub { font-size: 15px; max-width: none; margin-top: 16px; position: relative; z-index: 4; }
    .bullets { grid-template-columns: 1fr; gap: 10px; margin-top: 16px; position: relative; z-index: 4; }
    .bullets li { font-size: 14px; gap: 9px; }
    .bullets .ck { width: 21px; height: 21px; }
    .card, .thanks { max-width: none; margin-top: 18px; }
    .right { position: absolute; top: 86px; right: 14px; width: 41%; max-width: 146px; height: 228px; overflow: hidden; z-index: 2; pointer-events: none; }
    .photo { position: absolute; inset: 0; transform: none; width: 100%; height: 100%; display: block; }
    .photo .ring { display: none; }
    .photo img { position: absolute; inset: 0; left: auto; transform: none; width: 100%; height: 100%; object-fit: cover; object-position: center top; max-width: none; }
    .photo .photo-fade { left: 0; right: 0; bottom: 0; height: 118px; background: linear-gradient(to bottom, rgba(248,247,243,0) 0%, var(--av-cream-site) 66%); }
    .photo .reg { display: none; }
    .formwrap button { font-size: 14px !important; padding: 14px 18px !important; white-space: nowrap; }
    .legal { padding: 0 18px 28px; }
  }

  @media (max-width: 480px) {
    .hero { padding: 16px 16px 18px; column-gap: 12px; }
    .left { width: 63%; }
    .left h1 { font-size: 24px; line-height: 1.15; }
    .left .eb { margin-bottom: 8px; }
    .sub { font-size: 14px; }
    .bullets li { font-size: 13px; }
    .right { max-width: 134px; right: 14px; height: 210px; }
    .phone { grid-template-columns: 112px 1fr; }
    .card { padding: 20px 18px; }
    .card .ch { font-size: 19px; }
    .formwrap button { font-size: 13px !important; padding: 13px 14px !important; }
  }