:root{
    /* Brand palette — burgundy primary + gold accent */
    --burgundy:#63342B;
    --burgundy-deep:#4a261f;
    --burgundy-soft:#8a4d40;
    --burgundy-tint:#f5ebe8;
    --gold:#af975e;
    --gold-deep:#8d7846;
    --gold-text:#a29160;
    --gold-soft:#d9c79b;
    --gold-tint:#f6f0e2;
    --navy:#23282D;
    --navy-text:#06163A;
    --ink:#333333;
    --ink-2:#4a4a4a;
    --ink-3:#737373;
    --muted:#bbbbbb;
    --line:#ebebeb;
    --line-2:#f0f0f0;
    --gray-bg:#f9f9f9;
    --gray-bg-2:#faf9f5;
    --cream:#faf9f5;
    --cream-2:#f0f0f0;
    --paper:#ffffff;
    --white:#ffffff;
    --green:#2e7d5b;
    --green-tint:#e6f1ea;
    --red:#b14438;
    --red-tint:#fbeae6;
    --shadow-sm:0 1px 2px rgba(31,41,51,.06), 0 1px 3px rgba(31,41,51,.04);
    --shadow-md:0 6px 18px -8px rgba(31,41,51,.18), 0 2px 6px rgba(31,41,51,.06);
    --shadow-lg:0 24px 48px -20px rgba(31,41,51,.25), 0 6px 14px rgba(31,41,51,.06);
    --radius:14px;
    --radius-lg:20px;
  }

  *{box-sizing:border-box}
  html,body{margin:0;padding:0}
  body{
    font-family:'Open Sans', system-ui, sans-serif;
    color:var(--ink);
    background:var(--gray-bg-2);
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
  }
  h1,h2,h3,h4{
    font-family:'EB Garamond', Georgia, serif;
    font-weight:600;
    color:var(--burgundy);
    letter-spacing:-0.005em;
    margin:0;
    text-wrap:balance;
  }
  p{margin:0; text-wrap:pretty}
  a{color:var(--burgundy); text-decoration:none}
  a:hover{text-decoration:underline}
  img{max-width:100%; display:block}

  .wrap{
    max-width:1200px;
    margin:0 auto;
    padding:0 24px;
  }

  /* ───── TOP BAR ───── */
  .topbar{
    background:#fff;
    border-bottom:3px solid var(--gold);
    position:sticky; top:0; z-index:50;
  }
  .topbar-inner{
    display:flex; align-items:center; justify-content:space-between;
    padding:14px 24px; max-width:1200px; margin:0 auto;
    gap:16px;
  }
  .logo{
    display:flex; align-items:center; gap:12px;
    color:var(--ink);
  }
  .logo-mark{
    width:44px; height:44px; border-radius:50%;
    background:var(--burgundy); color:#fff;
    display:grid; place-items:center;
    font-family:'EB Garamond', Georgia, serif; font-weight:600; font-size:20px;
    flex:none;
    border:2px solid var(--gold);
  }
  .logo-text{display:flex; flex-direction:column; line-height:1.15}
  .logo-text strong{font-family:'EB Garamond', Georgia, serif; font-weight:600; font-size:16px; color:var(--burgundy)}
  .logo-text span{font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-text)}

  .top-call{
    display:flex; align-items:center; gap:10px;
    color:#fff; font-weight:600; font-size:15px;
    border:1px solid var(--burgundy);
    padding:9px 16px; border-radius:999px;
    background:var(--burgundy);
    transition:all .15s ease;
  }
  .top-call:hover{background:var(--burgundy-deep); text-decoration:none; border-color:var(--burgundy-deep)}
  .top-call .ph-dot{
    width:8px; height:8px; border-radius:50%; background:var(--gold);
    box-shadow:0 0 0 4px rgba(175,151,94,.25);
  }
  .top-call .ph-num{color:var(--gold-soft)}

  /* ───── HERO ───── */
  .hero{
    background:
      radial-gradient(1100px 460px at 90% -10%, rgba(99,52,43,.08), transparent 60%),
      linear-gradient(180deg, #fff 0%, var(--gray-bg-2) 100%);
    padding:36px 0 48px;
    position:relative;
    overflow:hidden;
  }
  .hero::before{
    content:""; position:absolute; left:0; right:0; bottom:0; height:1px;
    background:linear-gradient(90deg, transparent, var(--line), transparent);
  }
  .hero-grid{
    display:grid;
    grid-template-columns: 1.02fr 1fr;
    gap:48px;
    align-items:start;
  }

  .eyebrow{
    display:inline-flex; align-items:center; gap:10px;
    background:#fff; border:1px solid var(--gold-soft);
    padding:7px 14px 7px 10px; border-radius:999px;
    font-size:12.5px; font-weight:600; letter-spacing:.04em;
    color:var(--burgundy);
    box-shadow:var(--shadow-sm);
  }
  .eyebrow .pin{
    width:18px; height:18px; border-radius:50%;
    background:var(--gold); color:#fff;
    display:grid; place-items:center; font-size:11px;
  }

  h1.hero-title{
    font-size:clamp(30px, 3.6vw, 46px);
    line-height:1.08;
    margin:14px 0 14px;
  }
  h1.hero-title em{
    font-style:normal;
    color:var(--burgundy);
    background:linear-gradient(180deg, transparent 62%, var(--gold-soft) 62%, var(--gold-soft) 92%, transparent 92%);
    padding:0 4px;
  }
  .hero-sub{
    font-size:15px; 
    color:var(--ink-2);
    max-width:520px;
    margin-bottom:20px;
  }

  .hero-bullets{
    list-style:none; padding:0; margin:0 0 22px;
    display:grid; gap:10px;
  }
  .hero-bullets li{
    display:flex; align-items:flex-start; gap:10px;
    font-size:14.5px; color:var(--ink-2);
  }
  .hero-bullets svg{flex:none; margin-top:2px; width:20px; height:20px}

  .hero-cta-row{
    display:flex; align-items:center; gap:14px; flex-wrap:wrap;
    margin-bottom:22px;
  }
  .btn-call-lg{
    display:inline-flex; align-items:center; gap:14px;
    background:var(--burgundy); color:#fff;
    padding:16px 24px; border-radius:14px;
    font-weight:600; font-size:16px;
    box-shadow:var(--shadow-md);
    transition:transform .15s ease, box-shadow .15s ease;
  }
  .btn-call-lg:hover{transform:translateY(-1px); box-shadow:var(--shadow-lg); text-decoration:none}
  .btn-call-lg .icon{
    width:36px; height:36px; border-radius:50%;
    background:var(--gold); display:grid; place-items:center;
  }
  .btn-call-lg .lbl{display:flex; flex-direction:column; line-height:1.15; align-items:flex-start}
  .btn-call-lg .lbl small{font-size:11px; opacity:.7; font-weight:500; letter-spacing:.06em; text-transform:uppercase}
  .btn-call-lg .lbl strong{font-size:18px; font-weight:600}
  .or-tag{font-size:13px; color:var(--ink-3); letter-spacing:.08em; text-transform:uppercase}

  .hero-trust{
    display:flex; align-items:center; gap:20px; flex-wrap:wrap;
    padding-top:16px; border-top:1px dashed var(--line);
  }
  .hero-trust .tcell{display:flex; align-items:center; gap:10px; font-size:13px; color:var(--ink-2)}
  .hero-trust .tcell strong{color:var(--ink); font-weight:600}
  .stars{display:inline-flex; gap:1px; color:var(--gold)}
  .stars svg{width:16px; height:16px}

 /* ── CARD ── */
.form-card { background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); overflow:hidden; display:flex; flex-direction:column; }

/* ── HEAD ── */
.form-head { background:linear-gradient(180deg,var(--burgundy) 0%,var(--burgundy-deep) 100%); color:#fff; padding:18px 24px 16px; position:relative; flex-shrink:0; }
.form-head::after { content:""; position:absolute; left:0; right:0; bottom:0; height:3px; background:linear-gradient(90deg,var(--gold-soft),var(--gold),var(--gold-deep)); }
.form-head .badge-free { display:inline-flex; align-items:center; gap:6px; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.18); padding:4px 10px; border-radius:999px; font-size:11px; font-weight:600; letter-spacing:.08em; text-transform:uppercase; margin-bottom:8px; }
.form-head h2 { color:#fff; font-size:20px; line-height:1.15; margin-bottom:2px; }
.form-head p  { font-size:12.5px; color:rgba(255,255,255,.7); }

/* ── BODY ── */
.form-body { padding:14px 16px 18px; flex:1; }

/* ── FORM ── */
#leadForm { display:flex; flex-direction:column; gap:6px; }

/* ── FIELD ROW — always 2 columns, even on mobile ── */
.field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;   /* fixed 2 cols on ALL screen sizes */
  gap: 6px;
}

/* ── FIELD ── */
.field { display:flex; flex-direction:column; }
.field input,
.field textarea {
  font-family:inherit; font-size:13px;
  padding:8px 11px;
  border:1.5px solid var(--line); border-radius:9px;
  background:#fff; color:var(--ink); width:100%;
  transition:border-color .15s,box-shadow .15s;
  outline:none;
}
.field input::placeholder,
.field textarea::placeholder { color:var(--ink-3); font-size:12.5px; }
.field input:focus,
.field textarea:focus { border-color:var(--gold); box-shadow:0 0 0 3px var(--gold-tint); }
.field input.is-error,
.field textarea.is-error { border-color:var(--red)!important; box-shadow:0 0 0 3px rgba(177,68,56,.12)!important; }
.field textarea { resize:vertical; min-height:58px; }

/* ── ERROR MSG ── */
.err-msg { font-size:10.5px; color:var(--red); line-height:14px; margin-top:2px; padding-left:2px; display:none; align-items:center; gap:3px; }
.err-msg.show { display:flex; }
.err-msg::before { content:""; flex-shrink:0; width:10px; height:10px; background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23b14438' stroke-width='2.5' stroke-linecap='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='M12 8v4M12 16h.01'/%3E%3C/svg%3E") center/contain no-repeat; }

/* ── YES/NO BLOCK ── */
.yn-block {
  border:1.5px solid var(--line);
  border-radius:9px;
  overflow:hidden;
}

.yn-question {
  display: grid;
  grid-template-columns: 1fr auto;  /* label stretches, buttons fixed width */
  grid-template-rows: auto auto;    /* row 2 for error msg */
  align-items: center;
  column-gap: 10px;
  padding: 8px 11px;
  border-bottom: 1px solid var(--line-2);
}
.yn-question:last-child { border-bottom:0; }

.yn-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.4;
  grid-column: 1;
  grid-row: 1;
  min-width: 0;          /* allows text to wrap inside the column */
}
.yn-label .req { color:var(--red); margin-left:2px; }

.yn {
  display: flex;
  gap: 5px;
  flex-shrink: 0;
  grid-column: 2;
  grid-row: 1;
}

/* error spans full width below both columns */
.yn-question .err-msg {
  grid-column: 1 / -1;
  grid-row: 2;
  display: none;
  margin-top: 3px;
  padding-bottom: 1px;
  padding-left: 0;
}
.yn-question .err-msg.show { display:flex; }
.yn-question.is-error { background:rgba(177,68,56,.04); }

.yn label {
  display:flex; align-items:center; justify-content:center; gap:4px;
  padding:4px 11px;
  border:1.5px solid var(--line); border-radius:7px;
  font-size:12.5px; font-weight:500; color:var(--ink-2);
  cursor:pointer; background:#fff;
  transition:all .15s; user-select:none; white-space:nowrap;
}
.yn label:hover { border-color:var(--gold-soft); background:var(--cream); }
.yn input { position:absolute; opacity:0; pointer-events:none; }
.yn label:has(input:checked) { border-color:var(--gold); background:var(--gold-tint); color:var(--gold-deep); font-weight:600; }
.yn label .dot { width:9px; height:9px; border-radius:50%; border:1.5px solid var(--line); flex:none; position:relative; transition:all .15s; }
.yn label:has(input:checked) .dot { border-color:var(--gold-deep); background:var(--gold-deep); }
.yn label:has(input:checked) .dot::after { content:""; position:absolute; inset:2px; border-radius:50%; background:#fff; }

/* ── CONSENT ── */
.consent { display:flex; align-items:flex-start; gap:8px; cursor:pointer; user-select:none; }
.consent input { position:absolute; opacity:0; pointer-events:none; }
.consent-box { flex:none; width:16px; height:16px; border-radius:4px; border:1.5px solid var(--line); background:#fff; display:grid; place-items:center; color:transparent; transition:all .15s; margin-top:1px; }
.consent:hover .consent-box { border-color:var(--gold); }
.consent:has(input:checked) .consent-box { background:var(--burgundy); border-color:var(--burgundy); color:#fff; }
.consent-text { font-size:10px; color:var(--ink-3); line-height:1.55; max-height:48px; overflow-y:auto; display:block; padding-right:4px; scrollbar-width:thin; scrollbar-color:var(--line) transparent; }
.consent-text::-webkit-scrollbar { width:3px; }
.consent-text::-webkit-scrollbar-thumb { background:var(--line); border-radius:99px; }
.consent-text a { color:var(--burgundy); text-decoration:underline; }
#consent-err { padding-left:24px; }

/* ── SUBMIT ── */
.submit-btn { width:100%; background:var(--gold); color:#fff; border:0; padding:11px 20px; border-radius:9px; font-family:inherit; font-size:14px; font-weight:600; cursor:pointer; display:flex; align-items:center; justify-content:center; gap:10px; box-shadow:0 4px 14px -4px rgba(175,151,94,.55); transition:transform .15s,background .15s,box-shadow .15s; }
.submit-btn:not(:disabled):hover { background:var(--gold-deep); transform:translateY(-1px); box-shadow:0 8px 22px -6px rgba(175,151,94,.7); }
.submit-btn:disabled { opacity:.4; cursor:not-allowed; transform:none; box-shadow:none; }
@keyframes btn-pop { 0%{transform:scale(1)} 50%{transform:scale(1.03)} 100%{transform:scale(1)} }
.submit-btn.just-enabled { animation:btn-pop .3s ease; }

/* ── RESULT SCREEN ── */
.form-card.submitted #leadForm { display:none; }
.result-screen      { display:none; }
.result-screen.on   { display:block; animation:fadeUp .35s ease; }
.result-card        { display:none; text-align:center; padding:24px 20px; }
.result-card.active { display:block; }

.result-card.qualified   { background:#f0fdf4; border:2px solid #22c55e; border-radius:12px; margin:16px 0; }
.result-card.disqualified{ background:#fef2f2; border:2px solid #ef4444; border-radius:12px; margin:16px 0; }

.result-icon { width:64px; height:64px; border-radius:50%; display:grid; place-items:center; margin:0 auto 12px; color:#fff; }
.result-icon.ok  { background:linear-gradient(180deg,#2fcd68,#22b85a); box-shadow:0 10px 24px -10px rgba(34,184,90,.45); }
.result-icon.bad { background:linear-gradient(180deg,#f2554f,#ea403c); box-shadow:0 10px 24px -10px rgba(234,64,60,.45); }

.result-card h3 { font-size:19px; line-height:1.25; margin-bottom:8px; letter-spacing:-.02em; }
.result-card.qualified    h3 { color:#176c39; }
.result-card.disqualified h3 { color:#8c201d; }
.result-card p { font-size:13px; line-height:1.7; color:var(--ink-2); max-width:360px; margin:0 auto; }

.result-meta { display:flex; justify-content:center; gap:6px; flex-wrap:wrap; margin-top:12px; }
.result-meta span { display:inline-flex; align-items:center; gap:5px; background:rgba(34,184,90,.08); color:#176c39; border:1px solid rgba(34,184,90,.16); border-radius:999px; padding:5px 10px; font-size:11px; font-weight:600; }

/* ── CALL BUTTONS ── */
.result-call { display:inline-flex; align-items:center; justify-content:center; gap:10px; margin-top:16px; min-width:240px; color:#fff; text-decoration:none; border-radius:999px; padding:11px 22px; font-size:14px; transition:transform .15s,box-shadow .15s; }
.result-call:hover { transform:translateY(-1px); }
.result-call span   { text-transform:uppercase; letter-spacing:.08em; font-size:11px; }
.result-call strong { font-size:15px; font-weight:700; }
.result-call.green { background:linear-gradient(180deg,#2fcd68,#1fa854); box-shadow:0 10px 22px -12px rgba(31,168,84,.65); }
.result-call.green:hover { box-shadow:0 14px 26px -14px rgba(31,168,84,.8); }
.result-call.red   { background:linear-gradient(180deg,#d74742,#c53631); box-shadow:0 10px 22px -12px rgba(197,54,49,.7); }
.result-call.red:hover { box-shadow:0 14px 26px -14px rgba(197,54,49,.8); }

@keyframes fadeUp { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }

/* ── MOBILE — only field-row stays 2 cols, everything else tightens ── */
@media (max-width: 480px) {
  .form-body { padding:12px 14px 16px; }
  /* field-row intentionally NOT changed — stays 2 cols on mobile too */
  .field input,
  .field textarea { font-size:12px; padding:8px 10px; }
  .field input::placeholder,
  .field textarea::placeholder { font-size:11.5px; }
  .yn-label { font-size:11.5px; }
  .yn label { padding:4px 9px; font-size:12px; }
  .result-call { min-width:100%; }
}

  /* ───── TRUST STRIP ───── */
  .trust-strip{
    background:#fff;
    border-top:1px solid var(--line-2);
    border-bottom:1px solid var(--line-2);
    padding:28px 0;
  }
  .trust-grid{
    display:grid;
    grid-template-columns:repeat(4, 1fr);
    gap:24px;
  }
  .tcard{
    display:flex; align-items:center; gap:14px;
    padding:0 4px;
  }
  .tcard .ic{
    width:48px; height:48px; border-radius:12px;
    background:var(--gold-tint); color:var(--gold-deep);
    display:grid; place-items:center; flex:none;
  }
  .tcard .ic svg{width:24px; height:24px}
  .tcard .lbl{display:flex; flex-direction:column; line-height:1.25}
  .tcard .lbl strong{font-family:'EB Garamond', Georgia, serif; font-size:18px; font-weight:600; color:var(--ink)}
  .tcard .lbl span{font-size:12.5px; color:var(--ink-3)}

  /* ───── ABOUT NIKKI ───── */
  .about{padding:80px 0; background:var(--paper)}
  .about-grid{
    display:grid; grid-template-columns:0.85fr 1.15fr; gap:56px;
    align-items:center;
  }
  .about-photo{
    position:relative; border-radius:var(--radius-lg);
    /*aspect-ratio: 4/5;*/
    overflow:hidden;
    background:linear-gradient(135deg, var(--gold-tint), var(--cream-2));
    box-shadow:var(--shadow-lg);
  }
  .about-photo .ph-img{
    width:100%; height:100%;
    background:
      linear-gradient(135deg, rgba(175,151,94,.25), rgba(175,151,94,.05)),
      radial-gradient(circle at 50% 38%, var(--gold-soft) 0%, transparent 40%),
      var(--cream-2);
    display:grid; place-items:center;
    color:var(--gold-deep);
    font-family:'EB Garamond', Georgia, serif; font-size:80px; font-weight:600;
    position:relative;
  }
  .about-photo .ph-img::after{
    content:"Photo of Nikki L. Prasad";
    position:absolute; bottom:18px; left:0; right:0;
    font-family:'Open Sans', sans-serif; font-size:11px; font-weight:500;
    color:var(--ink-3); letter-spacing:.08em; text-transform:uppercase;
    text-align:center;
  }
  .about-photo .badge-float{
    position:absolute; bottom:20px; right:20px;
    background:#fff; padding:14px 18px; border-radius:14px;
    box-shadow:var(--shadow-md);
    display:flex; align-items:center; gap:10px;
    font-size:13px; font-weight:600; color:var(--ink);
  }
  .about-photo .badge-float .num{
    font-family:'EB Garamond', Georgia, serif; font-size:28px; color:var(--gold-deep);
    line-height:1;
  }

  .about h2{font-size:clamp(28px, 3vw, 38px); line-height:1.15; margin-bottom:18px}
  .about-eyebrow{
    font-size:12px; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
    color:var(--gold-deep); margin-bottom:12px; display:block;
  }
  .about p{color:var(--ink-2); font-size:16.5px; margin-bottom:14px}
  .creds{
    margin-top:24px;
    display:grid; grid-template-columns:1fr 1fr; gap:14px 22px;
    padding-top:24px; border-top:1px solid var(--line-2);
  }
  .creds .item{
    display:flex; align-items:flex-start; gap:10px;
    font-size:14px; color:var(--ink-2);
  }
  .creds .item svg{flex:none; margin-top:2px; color:var(--gold-deep)}
  .creds .item strong{color:var(--ink); font-weight:600; display:block}

  /* ───── PROCESS ───── */
  .process{
    padding:80px 0;
    background:linear-gradient(180deg, var(--cream) 0%, var(--paper) 100%);
    border-top:1px solid var(--line-2);
  }
  .section-head{text-align:center; max-width:680px; margin:0 auto 48px}
  .section-head h2{font-size:clamp(28px, 3vw, 40px); margin-bottom:14px}
  .section-head p{color:var(--ink-2); font-size:17px}
  .section-eyebrow{
    font-size:12px; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
    color:var(--gold-deep); margin-bottom:14px; display:block;
  }

  .steps{
    display:grid; grid-template-columns:repeat(4, 1fr); gap:20px;
    position:relative;
  }
  .steps::before{
    content:""; position:absolute; top:32px; left:7%; right:7%;
    height:1px; border-top:1.5px dashed var(--gold-soft); z-index:0;
  }
  .step{
    background:#fff;
    border:1px solid var(--line-2);
    border-radius:var(--radius);
    padding:24px 22px;
    position:relative; z-index:1;
    transition:transform .2s ease, box-shadow .2s ease;
  }
  .step:hover{transform:translateY(-3px); box-shadow:var(--shadow-md)}
  .step .num{
    width:48px; height:48px; border-radius:50%;
    background:var(--burgundy); color:#fff;
    font-family:'EB Garamond', Georgia, serif; font-weight:600; font-size:20px;
    display:grid; place-items:center;
    margin-bottom:18px;
    border:4px solid var(--paper);
    box-shadow:0 0 0 1px var(--line);
  }
  .step h3{font-size:18px; margin-bottom:8px}
  .step p{font-size:14px; color:var(--ink-2)}

  /* ───── HELP STAGES ───── */
  .stages{padding:80px 0; background:var(--paper)}
  .stage-grid{
    display:grid; grid-template-columns:repeat(4, 1fr); gap:18px;
  }
  .stage{
    background:#fff; border:1px solid var(--line-2);
    border-radius:var(--radius);
    padding:28px 22px; text-align:center;
    transition:all .2s ease;
  }
  .stage:hover{border-color:var(--gold-soft); transform:translateY(-3px); box-shadow:var(--shadow-md)}
  .stage .stg-ic{
    width:60px; height:60px; border-radius:14px;
    background:var(--gold-tint); color:var(--gold-deep);
    display:grid; place-items:center;
    margin:0 auto 16px;
  }
  .stage h3{font-size:17px; margin-bottom:6px}
  .stage p{font-size:13.5px; color:var(--ink-3)}

  /* ───── TESTIMONIALS ───── */
  .testimonials{
    padding:80px 0;
    background:linear-gradient(180deg, var(--paper) 0%, var(--cream) 100%);
    border-top:1px solid var(--line-2);
  }
  .testi-grid{
    display:grid; grid-template-columns:repeat(3, 1fr); gap:24px;
  }
  .testi{
    background:#fff;
    border:1px solid var(--line-2);
    border-radius:var(--radius);
    padding:28px;
    display:flex; flex-direction:column;
    box-shadow:var(--shadow-sm);
  }
  .testi .stars{margin-bottom:14px}
  .testi blockquote{
    margin:0 0 22px; padding:0;
    font-family:'EB Garamond', Georgia, serif; font-size:18px; line-height:1.45;
    color:var(--ink); flex:1;
  }
  .testi blockquote::before{
    content:"“"; font-size:48px; color:var(--gold);
    line-height:0; vertical-align:-22px; margin-right:2px;
  }
  .testi-person{display:flex; align-items:center; gap:12px; padding-top:16px; border-top:1px solid var(--line-2)}
  .testi-avatar{
    width:42px; height:42px; border-radius:50%;
    background:var(--gold-tint); color:var(--gold-deep);
    display:grid; place-items:center;
    font-family:'EB Garamond', Georgia, serif; font-weight:600; font-size:16px;
    flex:none;
  }
  .testi-person .name{font-size:14px; font-weight:600; color:var(--ink)}
  .testi-person .meta{font-size:12.5px; color:var(--ink-3)}

  /* ───── FAQ ───── */
  .faq{padding:80px 0; background:var(--paper)}
  .faq-grid{
    display:grid; grid-template-columns:0.85fr 1.15fr; gap:56px;
    align-items:start;
  }
  .faq h2{font-size:clamp(28px, 3vw, 38px); margin-bottom:14px}
  .faq-side p{color:var(--ink-2); font-size:16px; margin-bottom:24px}
  .faq-side .call-card{
    background:linear-gradient(135deg, var(--burgundy) 0%, var(--burgundy-deep) 100%);
    color:#fff; padding:24px;
    border-radius:var(--radius); position:relative; overflow:hidden;
  }
  .faq-side .call-card::after{
    content:""; position:absolute; right:-30px; bottom:-30px;
    width:140px; height:140px; border-radius:50%;
    background:radial-gradient(circle, var(--gold) 0%, transparent 70%);
    opacity:.35;
  }
  .faq-side .call-card strong{display:block; font-family:'EB Garamond', Georgia, serif; font-size:20px; margin-bottom:6px}
  .faq-side .call-card p{font-size:14px; color:rgba(255,255,255,.72); margin-bottom:14px}
  .faq-side .call-card a{
    display:inline-flex; align-items:center; gap:10px;
    color:#fff; font-weight:600; font-size:18px;
    background:var(--gold); padding:10px 18px; border-radius:10px;
    position:relative; z-index:1;
  }
  .faq-side .call-card a:hover{background:var(--gold-deep); text-decoration:none}

  details.qa{
    background:#fff;
    border:1px solid var(--line-2);
    border-radius:12px;
    padding:0;
    margin-bottom:10px;
    transition:border-color .15s ease;
  }
  details.qa[open]{border-color:var(--gold-soft)}
  details.qa summary{
    list-style:none;
    cursor:pointer;
    padding:18px 22px;
    display:flex; align-items:center; justify-content:space-between; gap:14px;
    font-family:'EB Garamond', Georgia, serif; font-size:17px; font-weight:600; color:var(--ink);
  }
  details.qa summary::-webkit-details-marker{display:none}
  details.qa summary .chev{
    flex:none; width:28px; height:28px; border-radius:50%;
    background:var(--cream); color:var(--ink-2);
    display:grid; place-items:center;
    transition:transform .2s ease, background .2s ease, color .2s ease;
  }
  details.qa[open] summary .chev{transform:rotate(180deg); background:var(--gold); color:#fff}
  details.qa .answer{
    padding:0 22px 20px;
    font-size:15px; color:var(--ink-2); line-height:1.6;
  }

  /* ───── FINAL CTA ───── */
  .final-cta{
    background:
      linear-gradient(135deg, rgba(99,52,43,.97), rgba(74,38,31,.97)),
      radial-gradient(circle at 20% 50%, var(--gold-deep) 0%, transparent 60%);
    color:#fff;
    padding:72px 0;
    text-align:center;
    border-top:1px solid var(--line);
    position:relative; overflow:hidden;
  }
  .final-cta::before{
    content:""; position:absolute; inset:0;
    background:
      radial-gradient(800px 300px at 50% 0%, rgba(175,151,94,.25), transparent 70%);
  }
  .final-cta-inner{position:relative; z-index:1; max-width:700px; margin:0 auto; padding:0 24px}
  .final-cta h2{color:#fff; font-size:clamp(28px, 3.5vw, 42px); margin-bottom:14px}
  .final-cta p{color:rgba(255,255,255,.75); font-size:17px; margin-bottom:30px}
  .final-cta-row{display:flex; gap:14px; justify-content:center; flex-wrap:wrap}
  .btn-primary{
    background:var(--gold); color:#fff;
    padding:16px 28px; border-radius:12px;
    font-weight:600; font-size:16px;
    display:inline-flex; align-items:center; gap:10px;
    transition:all .15s ease;
  }
  .btn-primary:hover{background:var(--gold-deep); text-decoration:none; transform:translateY(-1px)}
  .btn-ghost{
    background:transparent; color:#fff;
    border:1.5px solid rgba(255,255,255,.3);
    padding:14px 26px; border-radius:12px;
    font-weight:600; font-size:16px;
    display:inline-flex; align-items:center; gap:10px;
    transition:all .15s ease;
  }
  .btn-ghost:hover{background:rgba(255,255,255,.08); border-color:#fff; text-decoration:none}

  /* ───── FOOTER ───── */
  footer{
    background:var(--burgundy-deep); color:rgba(255,255,255,.65);
    padding:48px 0 0; font-size:13.5px;
  }
  .foot-grid{
    display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:48px;
    margin-bottom:36px;
  }
  .foot-grid .logo{color:#fff}
  .foot-grid .logo-text strong{color:#fff}
  .foot-grid .logo-text span{color:rgba(255,255,255,.45)}
  .foot-grid h4{color:#fff; font-family:'Open Sans', sans-serif; font-size:13px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; margin-bottom:14px}
  .foot-grid p{margin-bottom:8px; line-height:1.6}
  .foot-grid a{color:rgba(255,255,255,.65); display:block; margin-bottom:6px}
  .foot-grid a:hover{color:#fff; text-decoration:none}
  .foot-disclaim{
    border-top:1px solid rgba(255,255,255,.08);
    padding:24px 0;
    font-size:11.5px; line-height:1.65;
    color:rgba(255,255,255,.45);
  }
  .foot-disclaim p{margin-bottom:10px}
  .foot-bottom{
    border-top:1px solid rgba(255,255,255,.08);
    padding:18px 0; font-size:12px;
    display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px;
  }


  @media (max-width: 767px) {
  .firm_about,
  .first_practice_area {
    display: none;
  }
}

  /* ───── THANK YOU STATE ───── */
  .thanks{
    display:none;
    text-align:center;
    padding:32px 24px;
  }
  .thanks.on{display:block}
  .thanks .check{
    width:72px; height:72px; border-radius:50%;
    background:var(--green-tint); color:var(--green);
    display:grid; place-items:center;
    margin:0 auto 16px;
  }
  .thanks h3{font-size:24px; margin-bottom:10px}
  .thanks p{color:var(--ink-2); font-size:15px; margin-bottom:18px}
  .thanks .tcall{
    display:inline-flex; align-items:center; gap:10px;
    background:var(--burgundy); color:#fff;
    padding:12px 20px; border-radius:10px;
    font-weight:600;
  }
  /* .form-card.submitted .form-body > :not(.thanks){display:none} */

  /* ───── STICKY MOBILE CTA ───── */
  .mobile-cta{
    display:none;
    position:fixed; left:0; right:0; bottom:0; z-index:60;
    background:#fff;
    border-top:1px solid var(--line);
    padding:10px 14px;
    box-shadow:0 -4px 16px rgba(0,0,0,.08);
    gap:10px;
  }
  .mobile-cta a{
    flex:1;
    display:flex; align-items:center; justify-content:center; gap:8px;
    padding:13px 12px; border-radius:10px;
    font-weight:600; font-size:14.5px;
  }
  .mobile-cta .mb-call{background:var(--burgundy); color:#fff}
  .mobile-cta .mb-form{background:var(--gold); color:#fff}

  /* ───── RESPONSIVE ───── */
  @media (max-width: 980px){
    .hero-grid{grid-template-columns:1fr; gap:36px}
    .trust-grid{grid-template-columns:repeat(2, 1fr); gap:18px}
    .about-grid{grid-template-columns:1fr; gap:36px}
    .about-photo{max-width:380px; margin:0 auto}
    .steps{grid-template-columns:repeat(2, 1fr)}
    .steps::before{display:none}
    .stage-grid{grid-template-columns:repeat(2, 1fr)}
    .testi-grid{grid-template-columns:1fr; gap:18px}
    .faq-grid{grid-template-columns:1fr; gap:32px}
    .foot-grid{grid-template-columns:1fr 1fr; gap:32px}
  }

  @media (max-width: 640px){
    .topbar-inner{padding:12px 16px}
    /*.top-call .ph-num{display:none}*/
    .top-call{padding:8px 12px}
    .wrap{padding:0 18px}
    .hero{padding:32px 0 40px}
    h1.hero-title{font-size:32px}
    .hero-sub{font-size:16px}
    .hero-cta-row{gap:12px}
    .or-tag{display:none}
    .btn-call-lg{width:100%; justify-content:flex-start}
    .form-head{padding:20px 22px 18px}
    .form-body{padding:20px 22px 22px}
    .form-head h2{font-size:20px}
    /* .field-row{grid-template-columns:1fr} */
    .trust-grid{grid-template-columns:1fr 1fr; gap:14px}
    .tcard{gap:10px}
    .tcard .ic{width:42px; height:42px}
    .about, .process, .stages, .testimonials, .faq, .final-cta{padding:56px 0}
    .stage-grid{grid-template-columns:1fr 1fr}
    .creds{grid-template-columns:1fr}
    .foot-grid{grid-template-columns:1fr; gap:28px}
    .mobile-cta{display:flex}
    body{padding-bottom:70px}
    .topbar{position:relative}
  }
  /* Only for last question on mobile */
@media (max-width: 768px) {

    #row-q_age_group {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
    }

    #row-q_age_group .yn {
        width: 100%;
        margin-top: 8px;
        justify-content: flex-start;
    }
}