:root{
    --maroon: #800000;
    --maroon-deep: #5a0000;
    --maroon-darker: #3a0000;
    --maroon-soft: #a83232;
    --gold: #d4a64a;
    --gold-soft: #f0d28a;
    --green: #3da35b;
    --green-deep: #2a7a44;

    --bg: #eef1f7;
    --bg-2: #e3e8f1;
    --paper: #ffffff;
    --card: #f6f7fb;
    --ink: #0a1230;
    --ink-soft: #4a516b;
    --ink-muted: #8b91a6;
    --rule: #d9deeb;
    --rule-2: #c4cad9;
    --err: #d0011b;

    --display: "Inter", ui-sans-serif, system-ui, -apple-system, sans-serif;
    --script: "Inter", ui-sans-serif, system-ui, -apple-system, sans-serif;
    --sans: "Inter", ui-sans-serif, system-ui, -apple-system, sans-serif;
  }

  *{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
  html,body{margin:0;padding:0;min-height:100%;background:var(--bg);scroll-behavior:smooth}
  body{
    color:var(--ink);
    font-family:var(--sans);
    font-size:16px;
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
  }
  button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
  img{max-width:100%;display:block}
  a{color:inherit}

  /* —— Hero masthead —— */
  .hero{
    position:relative;
    background:
      radial-gradient(ellipse at 50% 0%, rgba(212,166,74,0.10) 0%, transparent 55%),
      radial-gradient(ellipse at 12% 80%, rgba(255,255,255,0.06) 0%, transparent 45%),
      linear-gradient(180deg, var(--maroon) 0%, var(--maroon-deep) 100%);
    padding:14px 24px;
    color:#fff;
    overflow:hidden;
    border-bottom:1px solid rgba(212,166,74,0.35);
    box-shadow:inset 0 1px 0 rgba(212,166,74,0.45);
  }
  @media (max-width:760px){ .hero{padding:24px 18px 22px} }
  .hero::before{
    /* faint dot ornament, top-left */
    content:"";position:absolute;top:14px;left:18px;width:90px;height:48px;
    background-image:radial-gradient(circle, rgba(240,210,138,0.35) 1.2px, transparent 1.5px);
    background-size:12px 12px;
    pointer-events:none;
    mask-image:linear-gradient(135deg, #000 25%, transparent 75%);
    -webkit-mask-image:linear-gradient(135deg, #000 25%, transparent 75%);
  }
  .hero::after{
    /* mirrored dot ornament, bottom-right */
    content:"";position:absolute;bottom:14px;right:18px;width:90px;height:48px;
    background-image:radial-gradient(circle, rgba(240,210,138,0.35) 1.2px, transparent 1.5px);
    background-size:12px 12px;
    pointer-events:none;
    mask-image:linear-gradient(315deg, #000 25%, transparent 75%);
    -webkit-mask-image:linear-gradient(315deg, #000 25%, transparent 75%);
  }
  .hero-inner{
    position:relative;width:fit-content;max-width:780px;margin:0 auto;
    display:flex;flex-direction:row;align-items:center;text-align:center;gap:32px;
  }

  /* Logo seal — gold-ringed coin */
  .hero .seal{
    min-width:78px;height:78px;border-radius:50%;
    background:#fff;
    display:flex;align-items:center;justify-content:center;
    padding:5px;
    box-shadow:
      0 0 0 1px rgba(255,255,255,0.6),
      0 0 0 4px var(--gold),
      0 0 0 5px rgba(255,255,255,0.18),
      0 14px 28px -12px rgba(0,0,0,.45);
  }
  @media (max-width:760px){ .hero .seal{min-width:64px;height:64px;padding:4px} }
  .hero .seal img{min-width:100%;height:100%;object-fit:contain}
  .hero-inner {gap:24px}
  /* Ornamental rule with center diamond */
  .hero-rule{
    position:relative;width:min(420px, 70%);height:1px;
    background:linear-gradient(90deg, transparent 0%, rgba(212,166,74,0.55) 18%, var(--gold) 50%, rgba(212,166,74,0.55) 82%, transparent 100%);
    display:flex;align-items:center;justify-content:center;
  }
  .hero-rule-mark{
    position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
    color:var(--gold);font-size:10px;line-height:1;
    background:var(--maroon-deep);padding:0 8px;
  }

  /* Brand line */
  .hero h1.brandline{
    font-family:var(--display);font-weight:600;font-style:italic;
    font-size:clamp(20px, 3vw, 32px);
    line-height:1.25;letter-spacing:.005em;
    margin:0;color:#fff;width:100%;
    text-wrap:balance;
    text-align: start;
  }
  .hero h1.brandline .sparkle{
    color:var(--gold-soft);font-size:.65em;font-weight:400;font-style:normal;
    margin:0 .4em;display:inline-block;transform:translateY(-2px);
  }
  .hero .subline{
    font-family:var(--script);font-style:italic;font-weight:500;
    font-size:clamp(19px, 2.3vw, 26px);
    color:var(--gold-soft);
    display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;
    margin:0;
  }
  .flourish{
    display:inline-block;color:var(--gold);opacity:.85;font-style:normal;
    font-size:18px;letter-spacing:.05em;
  }

  /* —— Page shell — 2-column layout —— */
  .page{
    position:relative;
    padding:40px 24px;
    max-width:1280px;margin:0 auto;
  }
  @media (max-width:760px){ .page{padding:30px 18px} }

  .layout{
    display:grid;
    grid-template-columns: minmax(0, 1fr) 420px;
    gap:48px;
    align-items:start;
  }
  @media (max-width:1080px){ .layout{grid-template-columns: minmax(0, 1fr) 380px;gap:36px} }
  @media (max-width:880px){
    .layout{grid-template-columns: 1fr; gap:32px}
    .layout > .form-side{order:-1}
  }

  /* background dots ornaments */
  .page::before, .page::after{
    /* content:"";position:absolute;width:160px;height:160px;
    background-image: radial-gradient(circle, var(--rule-2) 1.5px, transparent 1.8px);
    background-size: 14px 14px;
    opacity:.7;
    pointer-events:none; */
  }
  .page::before{ top:56px; left:18px; }
  .page::after{ bottom:24px; right:18px; }

  /* —— Content column —— */
  .content{display:flex;flex-direction:column;gap:80px;min-width:0}
  @media (max-width:760px){ .content{gap:60px} }

  .section{
    position:relative;
  }
  .section .eyebrow{
    font-family:var(--sans);font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;
    font-weight:600;color:var(--maroon);margin-bottom:14px;
    display:inline-flex;align-items:center;gap:10px;
  }
  .section .eyebrow::before{
    content:"";display:inline-block;width:28px;height:2px;background:var(--maroon);border-radius:99px;
  }
  .section h2{
    font-family:var(--display);font-weight:700;
    font-size:clamp(30px, 4.6vw, 48px);
    line-height:1.05;letter-spacing:-.015em;
    margin:0 0 18px;color:var(--ink);
    text-wrap:balance;
  }
  .section h2 em{font-style:italic;color:var(--maroon);font-weight:600}
  .section .lede{
    color:var(--ink-soft);font-size:17px;line-height:1.55;max-width:60ch;
    margin:0 0 22px;
  }
  .section .lede strong{color:var(--ink);font-weight:600}

  /* —— HERO content —— */
  .hero-content h1{
    font-family:var(--display);font-weight:700;
    font-size:clamp(40px, 4.6vw, 44px);
    line-height:1.02;letter-spacing:-.025em;
    margin:0 0 20px;text-wrap:balance;color:var(--ink);
  }
  .hero-content h1 em{font-style:italic;color:var(--maroon);font-weight:700}
  .hero-content .pillrow{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0 30px}
  .hero-content .pill{
    font-size:12.5px;letter-spacing:.05em;
    color:var(--ink);padding:8px 14px;border:1.5px solid var(--rule);border-radius:999px;background:var(--paper);
    display:inline-flex;align-items:center;gap:8px;font-weight:500;
  }
  .hero-content .pill .x{color:var(--green-deep);font-weight:700}
  .hero-cta{
    display:inline-flex;align-items:center;gap:14px;
    background:var(--maroon);color:#fff;
    padding:16px 26px;border-radius:14px;
    font-weight:600;font-size:16px;letter-spacing:.005em;text-decoration:none;
    box-shadow:0 14px 30px -14px var(--maroon);
    transition:transform .2s ease, background .2s ease, box-shadow .2s ease;
  }
  .hero-cta:hover{transform:translateY(-1px);background:var(--maroon-deep);box-shadow:0 18px 36px -14px var(--maroon-deep)}
  .hero-cta .arrow{
    width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,0.2);
    display:inline-flex;align-items:center;justify-content:center;font-size:16px;
  }
  .hero-cta:hover .arrow{background:var(--gold)}

  .hero-tag{
    font-family:var(--display);font-style:italic;font-weight:500;
    font-size:clamp(22px,2.8vw,24px);color:var(--maroon);
    margin:30px 0 12px;line-height:1.2;
  }

  /* —— "Why people start" 4 cards —— */
  .why-grid{
    display:grid;grid-template-columns:repeat(2, 1fr);gap:14px;
    margin-top:8px;
  }
  @media (max-width:480px){ .why-grid{grid-template-columns:1fr} }
  .why-card{
    background:var(--paper);border:1.5px solid var(--rule);border-radius:18px;
    padding:24px;display:flex;flex-direction:column;gap:10px;min-height:170px;
    transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  }
  .why-card:hover{transform:translateY(-3px);box-shadow:0 18px 36px -22px rgba(128,0,0,.4);border-color:var(--maroon-soft)}
  .why-card .num{
    font-family:var(--display);font-style:italic;font-weight:700;
    font-size:38px;line-height:1;color:var(--maroon);
  }
  .why-card h3{
    font-family:var(--display);font-weight:700;font-size:22px;line-height:1.15;
    margin:0;letter-spacing:-.005em;color:var(--ink);
  }
  .why-card p{margin:0;color:var(--ink-soft);font-size:14.5px;line-height:1.5}

  /* feel-quote band */
  .feel-quote{
    margin-top:24px;padding:24px 28px;
    background:linear-gradient(180deg, rgba(128,0,0,0.04), rgba(61,163,91,0.04));
    border:1px solid var(--rule);border-radius:18px;
    display:flex;justify-content:space-between;gap:18px;align-items:center;flex-wrap:wrap;
  }
  .feel-quote .big{
    font-family:var(--display);font-style:italic;font-size:clamp(22px,2.6vw,28px);
    line-height:1.1;margin:0;color:var(--ink);
  }
  .feel-quote .big em{color:var(--maroon);font-weight:600}
  .feel-quote .stars{color:var(--gold);letter-spacing:3px;font-size:18px}

  /* —— Is this you —— */
  .objections-card{
    background:var(--paper);border:1.5px solid var(--rule);border-radius:20px;
    padding:30px 32px;
  }
  .objections-list{
    list-style:none;padding:0;margin:0;
    display:grid;grid-template-columns:1fr 1fr;gap:10px 24px;
  }
  @media (max-width:560px){ .objections-list{grid-template-columns:1fr} }
  .objections-list li{
    padding:9px 0;color:var(--ink);font-size:15.5px;
    display:flex;align-items:start;gap:12px;line-height:1.45;
    border-top:1px dashed var(--rule);
  }
  .objections-list li:nth-child(1), .objections-list li:nth-child(2){border-top:none}
  @media (max-width:560px){ .objections-list li:nth-child(2){border-top:1px dashed var(--rule)} }
  .objections-list li::before{
    content:"";flex-shrink:0;width:10px;height:10px;border-radius:50%;
    background:var(--maroon);margin-top:6px;
  }
  .objections-after{
    margin-top:22px;padding-top:18px;border-top:1px solid var(--rule);
    font-size:15.5px;color:var(--ink-soft);
  }
  .objections-after strong{color:var(--maroon);font-weight:600}

  /* —— Discovery process steps —— */
  .steps-card{
    background:var(--paper);border:1.5px solid var(--rule);border-radius:20px;
    padding:28px 32px;
  }
  .steps{list-style:none;padding:0;margin:0}
  .steps li{
    display:grid;grid-template-columns:48px 1fr;gap:18px;
    padding:18px 0;border-top:1px solid var(--rule);
  }
  .steps li:first-child{border-top:none;padding-top:0}
  .steps li:last-child{padding-bottom:0}
  .steps .n{
    font-family:var(--display);font-weight:700;font-style:italic;
    color:var(--maroon);font-size:28px;line-height:1;
  }
  .steps .text{font-size:15.5px;color:var(--ink);line-height:1.5}
  .steps .text strong{display:block;color:var(--ink);font-weight:600;font-size:16.5px;margin-bottom:2px}

  .decide{
    margin-top:18px;background:var(--maroon);color:#fff;
    border-radius:18px;padding:24px 26px;position:relative;overflow:hidden;
  }
  .decide::before{
    content:"";position:absolute;top:0;left:0;right:0;height:4px;
    background:repeating-linear-gradient(90deg, var(--gold) 0 14px, #fff 14px 16px, var(--gold-soft) 16px 28px, #fff 28px 30px);
  }
  .decide h4{
    font-family:var(--display);font-style:italic;font-weight:600;font-size:24px;
    margin:8px 0 6px;color:#fff;line-height:1.15;
  }
  .decide p{margin:0;color:rgba(255,255,255,.85);font-size:14.5px}

  /* —— Why us — simple checklist —— */
  ul.why-us{
    list-style:none;margin:0;padding:0;
    display:flex;flex-direction:column;gap:12px;
  }
  ul.why-us li{
    display:flex;align-items:center;gap:12px;
    font-family:var(--display);font-weight:600;font-size:18px;line-height:1.3;
    color:var(--ink);
  }
  ul.why-us .tick{
    flex:none;display:inline-flex;align-items:center;justify-content:center;
    width:24px;height:24px;border-radius:50%;
    background:rgba(61,163,91,0.12);color:var(--green-deep);
    font-size:13px;font-weight:700;
  }

  /* —— Benefits 6 grid —— */
  .benefits{
    display:grid;grid-template-columns:repeat(3, 1fr);gap:0;
    border-top:1px solid var(--rule);border-left:1px solid var(--rule);
    border-radius:14px;overflow:hidden;background:var(--paper);
  }
  @media (max-width:680px){ .benefits{grid-template-columns:repeat(2,1fr)} }
  @media (max-width:420px){ .benefits{grid-template-columns:1fr} }
  .benefit{
    padding:20px 22px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);
    display:flex;flex-direction:column;gap:6px;min-height:110px;
  }
  .benefit .n{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--maroon);font-weight:600}
  .benefit h6{
    font-family:var(--display);font-weight:700;font-size:20px;line-height:1.15;
    margin:0;letter-spacing:-.005em;color:var(--ink);
  }
  .benefits-quote{
    margin-top:24px;padding:24px 28px;
    background:var(--maroon);color:#fff;border-radius:18px;
    font-family:var(--display);font-style:italic;font-weight:500;
    font-size:clamp(20px,2.4vw,26px);line-height:1.2;
    text-align:center;
  }
  .benefits-quote .b{color:var(--gold-soft);font-style:normal;font-weight:700;display:inline-block;margin-top:8px}

  /* —— $25 offer card on content side —— */
  .offer-banner{
    background:linear-gradient(180deg, var(--maroon) 0%, var(--maroon-deep) 100%);
    color:#fff;border-radius:22px;padding:30px 32px;position:relative;overflow:hidden;
  }
  .offer-banner::before{
    content:"";position:absolute;top:0;left:0;right:0;height:5px;
    background:repeating-linear-gradient(90deg, var(--gold) 0 14px, #fff 14px 16px, var(--gold-soft) 16px 28px, #fff 28px 30px);
  }
  .offer-banner::after{
    content:"";position:absolute;inset:-30% -10% auto auto;width:300px;height:300px;border-radius:50%;
    background:radial-gradient(circle, var(--gold) 0%, transparent 60%);
    opacity:.2;pointer-events:none;
  }
  .offer-banner .lbl{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);font-weight:600;display:block;margin:10px 0 8px;position:relative;z-index:1}
  .offer-banner h3{font-family:var(--display);font-style:italic;font-weight:700;font-size:30px;margin:0 0 16px;line-height:1.05;position:relative;z-index:1}
  .offer-banner-grid{
    display:grid;grid-template-columns:1.2fr auto;gap:24px;align-items:center;position:relative;z-index:1;
  }
  @media (max-width:540px){ .offer-banner-grid{grid-template-columns:1fr;gap:16px} }
  .offer-banner ul{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:8px 18px}
  @media (max-width:540px){ .offer-banner ul{grid-template-columns:1fr} }
  .offer-banner ul li{font-size:14px;display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.92)}
  .offer-banner ul li::before{content:"✓";color:var(--gold-soft);font-weight:700;font-size:14px}
  .offer-banner .pricecol{text-align:center}
  .offer-banner .price{
    font-family:var(--display);font-weight:700;font-size:84px;line-height:1.4;letter-spacing:-.03em;
    display:inline-flex;align-items:center;gap:6px;
  }
  .offer-banner .price sup{font-size:28px;color:var(--gold-soft);margin-top:14px}
  .offer-banner .price-sub{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.75);font-weight:500;margin-top:4px}
  .offer-cta{
    display:inline-flex;align-items:center;gap:12px;
    background:var(--gold);color:var(--maroon-darker);
    padding:14px 24px;border-radius:12px;font-weight:700;font-size:15px;
    text-decoration:none;margin-top:18px;
    transition:background .2s ease, transform .2s ease;
    position:relative;z-index:1;
  }
  .offer-cta:hover{background:var(--gold-soft);transform:translateY(-1px)}

  /* —— FAQ —— */
  .faq{display:flex;flex-direction:column;gap:10px}
  details.q{
    background:var(--paper);border:1.5px solid var(--rule);border-radius:14px;
    overflow:hidden;
  }
  details.q[open]{border-color:var(--maroon)}
  details.q > summary{
    list-style:none;cursor:pointer;
    padding:18px 22px;
    display:grid;grid-template-columns:1fr 24px;gap:14px;align-items:center;
    font-family:var(--display);font-weight:700;font-size:18px;color:var(--ink);
    line-height:1.25;
  }
  details.q > summary::-webkit-details-marker{display:none}
  details.q .plus{
    width:24px;height:24px;border-radius:50%;border:1.5px solid var(--rule-2);
    display:inline-flex;align-items:center;justify-content:center;font-size:16px;
    color:var(--maroon);transition:transform .25s ease, background .25s ease, color .25s ease;font-weight:700;
  }
  details.q[open] .plus{transform:rotate(45deg);background:var(--maroon);color:#fff;border-color:var(--maroon)}
  details.q .a{
    padding:0 22px 18px;color:var(--ink-soft);font-size:15px;line-height:1.55;
  }

  /* —— Final closing band —— */
  .closing{
    background:linear-gradient(180deg, var(--maroon) 0%, var(--maroon-darker) 100%);
    color:#fff;border-radius:22px;padding:38px 36px;position:relative;overflow:hidden;text-align:center;
  }
  .closing::before{
    content:"";position:absolute;inset:-40% -10% auto auto;width:380px;height:380px;border-radius:50%;
    background:radial-gradient(circle, var(--gold) 0%, transparent 60%);
    opacity:.18;pointer-events:none;
  }
  .closing h2{
    font-family:var(--display);font-weight:700;font-size:clamp(28px, 4vw, 40px);
    line-height:1.05;letter-spacing:-.015em;
    margin:0 0 16px;text-wrap:balance;color:#fff;position:relative;z-index:1;
  }
  .closing h2 em{font-style:italic;color:var(--gold-soft);font-weight:700}
  .closing .four{
    font-family:var(--display);font-style:italic;font-weight:500;
    font-size:clamp(20px,2.4vw,26px);line-height:1.4;margin:0 0 18px;
    color:rgba(255,255,255,.92);position:relative;z-index:1;
  }
  .closing p{margin:0 0 10px;color:rgba(255,255,255,.85);font-size:16px;position:relative;z-index:1;max-width:50ch;margin-left:auto;margin-right:auto}
  .closing p strong{color:#fff;font-weight:600}
  .closing-cta{
    display:inline-flex;align-items:center;gap:14px;margin-top:16px;
    background:var(--gold);color:var(--maroon-darker);
    padding:16px 26px;border-radius:14px;font-weight:700;font-size:16px;
    text-decoration:none;
    transition:background .2s ease, transform .2s ease;
    position:relative;z-index:1;
  }
  .closing-cta:hover{background:var(--gold-soft);transform:translateY(-1px)}
  .closing-cta .arrow{
    width:30px;height:30px;border-radius:50%;background:rgba(0,0,0,.12);
    display:inline-flex;align-items:center;justify-content:center;font-size:16px;
  }

  /* —— Sticky form sidebar (right column) —— */
  .form-side{
    position:sticky;top:20px;
    align-self:start;
  }
  @media (max-width:880px){
    .form-side{position:static}
  }

  .card{
    background:var(--card);
    border-radius:22px;
    padding:30px 18px 26px;
    box-shadow:
      0 1px 0 rgba(255,255,255,1) inset,
      0 24px 48px -28px rgba(10,18,48,0.18);
    border:1px solid rgba(255,255,255,0.8);
    position:relative;
    overflow:hidden;
  }
  .card::before{
    content:"";position:absolute;top:0;left:0;right:0;height:5px;
    background:repeating-linear-gradient(90deg, var(--maroon) 0 14px, #fff 14px 16px, var(--gold) 16px 28px, #fff 28px 30px);
  }

  .card .ribbon{
    display:inline-block;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;
    font-weight:700;color:#fff;background:var(--maroon);padding:6px 12px;border-radius:99px;
    margin-bottom:14px;margin-top:8px;
  }
  .card h2{
    font-family:var(--display);font-weight:700;
    font-size:clamp(24px, 3.2vw, 32px);
    line-height:1.15;letter-spacing:-.005em;
    color:var(--ink);
    margin:0 0 6px;
    text-wrap:balance;
    text-align:center;
  }
  .card h2 .price{color:var(--maroon);font-style:italic}
  .card .lede{
    color:var(--ink-soft);font-size:14px;
    margin:0 0 22px;line-height:1.5;
    text-align: center;
  }

  /* —— Section heading inside card —— */
  .group-label{
    font-size:11px;letter-spacing:.16em;text-transform:uppercase;
    font-weight:600;color:var(--maroon);margin:6px 0 10px;
    display:flex;align-items:center;gap:10px;
  }
  .group-label::before, .group-label::after{
    content:"";flex:1;height:1px;background:linear-gradient(90deg, transparent, var(--rule-2), transparent);
  }

  /* —— Fields —— */
  .row-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .fields{display:flex;flex-direction:column;gap:10px;margin-bottom:6px}

  .field-wrap{display:flex;flex-direction:column;gap:4px}
  .field{
    position:relative;display:flex;align-items:center;
    background:#fff;border:1.5px solid var(--rule);
    border-radius:12px;
    transition:border-color .2s ease, box-shadow .2s ease;
  }
  .field:focus-within{border-color:var(--maroon);box-shadow:0 0 0 4px rgba(128,0,0,0.08)}
  .field.invalid{border-color:var(--err)}
  .field.invalid:focus-within{box-shadow:0 0 0 4px rgba(208,1,27,0.08)}
  .field .icon{
    width:44px;height:50px;display:flex;align-items:center;justify-content:center;
    color:var(--ink-soft);flex-shrink:0;
  }
  .field input{
    flex:1;border:none;background:transparent;outline:none;
    font-family:var(--sans);font-size:15.5px;color:var(--ink);
    padding:14px 14px 14px 0;height:50px;width:100%;min-width:0;
  }
  .field input::placeholder{color:var(--ink-muted)}

  .err{
    font-size:12.5px;color:var(--err);
    padding-left:6px;display:flex;align-items:center;gap:6px;
    min-height:16px;
  }
  .err::before{content:"⚠";font-size:11px}
  .err:empty{display:none}

  /* —— Radio cards —— */
  .radios{display:flex;flex-direction:column;gap:8px;margin:4px 0}
  .radio-card{
    display:grid;grid-template-columns:38px 1fr 22px;align-items:center;gap:12px;
    background:#fff;border:1.5px solid var(--rule);border-radius:12px;
    padding:10px 14px;text-align:left;cursor:pointer;width:100%;
    transition:all .2s ease;
  }
  .radio-card:hover{border-color:var(--maroon-soft);transform:translateY(-1px)}
  .radio-card.sel{
    border-color:var(--maroon);background:linear-gradient(180deg, rgba(128,0,0,0.04), #fff);
    box-shadow: 0 10px 22px -16px var(--maroon);
  }
  .radio-card .glyph{
    width:34px;height:34px;border-radius:10px;background:#f4f1f1;
    display:flex;align-items:center;justify-content:center;color:var(--maroon);font-size:17px;
    border:1px solid var(--rule);
    transition:all .2s ease;
  }
  .radio-card.sel .glyph{background:var(--maroon);color:#fff;border-color:var(--maroon)}
  .radio-card .text{font-size:14.5px;font-weight:600;color:var(--ink);line-height:1.3}
  .radio-card .text .sub{display:block;font-weight:400;font-size:12px;color:var(--ink-soft);margin-top:1px}
  .radio-card .tick{
    width:20px;height:20px;border-radius:50%;border:1.5px solid var(--rule-2);
    display:flex;align-items:center;justify-content:center;color:transparent;font-size:11px;
    transition:all .2s ease;
  }
  .radio-card.sel .tick{background:var(--green);border-color:var(--green);color:#fff}

  /* —— Submit —— */
  .submit-row{margin-top:18px}
  .btn-submit{
    width:100%;
    background:var(--maroon);color:#fff;
    border:1.5px solid var(--maroon);
    border-radius:14px;
    padding:16px 22px;
    font-family:var(--sans);font-size:15.5px;font-weight:700;letter-spacing:.005em;
    min-height:56px;
    box-shadow: 0 14px 30px -14px var(--maroon);
    display:inline-flex;align-items:center;justify-content:center;gap:12px;
    transition:transform .2s ease, background .2s ease, box-shadow .2s ease;
  }
  .btn-submit:hover:not(:disabled){background:var(--maroon-deep);transform:translateY(-1px);box-shadow:0 18px 36px -14px var(--maroon-deep)}
  .btn-submit:active:not(:disabled){transform:translateY(0)}
  .btn-submit:disabled{
    opacity:.45;cursor:not-allowed;
    background:var(--maroon);border-color:var(--maroon);
    box-shadow:none;
  }
  .btn-submit.is-sending{opacity:.85;cursor:wait}
  .btn-submit.is-sending .btn-label,
  .btn-submit.is-sending .arrow{visibility:hidden}
  .btn-submit .spinner{
    display:none;position:absolute;left:50%;top:50%;
    width:18px;height:18px;margin:-9px 0 0 -9px;
    border:2px solid rgba(255,255,255,0.35);border-top-color:#fff;
    border-radius:50%;animation:btn-spin .7s linear infinite;
  }
  .btn-submit.is-sending .spinner{display:block}
  .btn-submit{position:relative}
  @keyframes btn-spin{to{transform:rotate(360deg)}}
  .btn-submit .arrow{
    width:28px;height:28px;border-radius:50%;background:rgba(255,255,255,0.18);
    display:inline-flex;align-items:center;justify-content:center;font-size:14px;
    transition:background .2s ease;
  }
  .btn-submit:hover:not(:disabled) .arrow{background:var(--gold)}
  .submit-error{
    margin:10px 0 0;text-align:center;font-size:13px;color:var(--err);
    line-height:1.4;
  }

  .legal{
    text-align:center;font-size:11.5px;color:var(--ink-muted);
    margin:12px 0 0;line-height:1.55;
  }

  /* trust strip under form */
  .trust{
    margin-top:14px;padding-top:14px;border-top:1px solid var(--rule);
    display:flex;justify-content:center;gap:10px;flex-wrap:wrap;
    font-size:11px;letter-spacing:.06em;color:var(--ink-muted);font-weight:500;text-transform:uppercase;
  }
  .trust span{display:inline-flex;align-items:center;gap:6px}
  .trust .dot{width:5px;height:5px;border-radius:50%;background:var(--maroon)}
  .trust .dot.g{background:var(--green)}

  /* —— Confirmation —— */
  .confirm{text-align:center;padding:14px 0 6px;animation:fadeUp .4s ease}
  @keyframes fadeUp{from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:none}}
  .confirm .check{
    width:72px;height:72px;border-radius:50%;background:var(--green);
    display:flex;align-items:center;justify-content:center;margin:0 auto 18px;color:#fff;font-size:32px;
    box-shadow:0 20px 40px -16px rgba(61,163,91,0.45);
    border:3px solid #fff;
    animation:pop .5s cubic-bezier(.2,1.4,.3,1);
  }
  @keyframes pop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
  .confirm h3{font-family:var(--display);font-weight:700;font-size:28px;line-height:1.1;margin:0 0 10px;color:var(--ink)}
  .confirm h3 em{color:var(--maroon);font-style:italic;font-weight:600}
  .confirm p{color:var(--ink-soft);max-width:36ch;margin:0 auto 10px;font-size:14.5px}
  .confirm p strong{color:var(--ink);font-weight:600}
  .confirm .meta{display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin-top:18px}
  .confirm .meta .pill{
    font-size:11px;font-weight:500;letter-spacing:.04em;color:var(--ink-soft);
    background:#fff;border:1px solid var(--rule);border-radius:999px;padding:6px 12px;
  }

  /* —— Footer —— */
  footer{
    padding:18px 24px 32px;
    border-top:1px solid var(--rule);
    margin:50px auto 0;max-width:1280px;
    text-align:center;
  }
  footer .links{display:flex;justify-content:center;gap:18px;font-size:14px;color:var(--ink-soft);margin-bottom:10px}
  footer .links a{color:var(--ink-soft);text-decoration:none}
  footer .links a:hover{color:var(--maroon)}
  footer .links .sep{color:var(--rule-2)}
  footer .copy{font-size:13.5px;color:var(--ink-muted)}
  footer .copy a{color:#2b50aa;text-decoration:none}
  footer .copy a:hover{text-decoration:underline}

  /* —— Legal pages (Privacy / Terms) —— */
  .legal-page{
    max-width:760px;margin:0 auto;
    padding:48px 24px 60px;
  }
  @media (max-width:760px){ .legal-page{padding:32px 18px 48px} }
  .legal-page .back-link{font-size:13.5px;color:var(--ink-muted);margin:0 0 24px}
  .legal-page .back-link a{color:var(--maroon);text-decoration:none}
  .legal-page .back-link a:hover{text-decoration:underline}
  .legal-page article > h1{
    font-family:var(--display);font-weight:700;
    font-size:clamp(30px, 4vw, 42px);line-height:1.1;letter-spacing:-.015em;
    margin:0 0 8px;color:var(--ink);
  }
  .legal-page .updated{
    color:var(--ink-muted);font-size:13.5px;margin:0 0 32px;
  }
  .legal-page article h2{
    font-family:var(--display);font-weight:700;
    font-size:19px;line-height:1.25;letter-spacing:-.005em;
    margin:32px 0 10px;color:var(--ink);
  }
  .legal-page article p,
  .legal-page article ul,
  .legal-page article ol{
    color:var(--ink-soft);font-size:15.5px;line-height:1.65;margin:0 0 14px;
  }
  .legal-page article strong{color:var(--ink);font-weight:600}
  .legal-page article ul, .legal-page article ol{padding-left:22px}
  .legal-page article li{margin:0 0 6px}
  .legal-page article a{color:var(--maroon);text-decoration:underline}
  .legal-page article a:hover{text-decoration:none}

  /* Hero seal — make it a clickable home link on legal pages */
  .hero a.seal{display:flex}

  /* —— Scroll-in animations —— */
  .reveal{
    opacity:0;transform:translateY(24px);
    transition:opacity .8s cubic-bezier(.2,.7,.3,1), transform .8s cubic-bezier(.2,.7,.3,1);
    will-change:opacity, transform;
  }
  .reveal.in{opacity:1;transform:none}
  /* staggered children */
  .reveal[data-stagger] > *{
    opacity:0;transform:translateY(16px);
    transition:opacity .7s ease, transform .7s ease;
    transition-delay:0ms;
  }
  .reveal.in[data-stagger] > *{opacity:1;transform:none}
  .reveal.in[data-stagger] > *:nth-child(1){transition-delay:0ms}
  .reveal.in[data-stagger] > *:nth-child(2){transition-delay:80ms}
  .reveal.in[data-stagger] > *:nth-child(3){transition-delay:160ms}
  .reveal.in[data-stagger] > *:nth-child(4){transition-delay:240ms}
  .reveal.in[data-stagger] > *:nth-child(5){transition-delay:320ms}
  .reveal.in[data-stagger] > *:nth-child(6){transition-delay:400ms}
  .reveal.in[data-stagger] > *:nth-child(7){transition-delay:480ms}
  @media (prefers-reduced-motion: reduce){
    .reveal, .reveal[data-stagger] > *{opacity:1;transform:none;transition:none}
  }
