    :root {
      --evergreen: #1f4d3a;
      --evergreen-deep: #163a2c;
      --evergreen-soft: #2d6a4f;
      --moss: #74a892;
      --amber: #c8821e;
      --amber-soft: #e0a94b;
      --cream: #f7f3ea;
      --cream-card: #fffdf8;
      --paper: #fbf8f1;
      --ink: #1b2620;
      --ink-soft: #4a564f;
      --line: #e3dccb;
      --shadow: 0 24px 60px -28px rgba(31, 77, 58, 0.35);
      --shadow-sm: 0 10px 30px -18px rgba(31, 77, 58, 0.4);
    }

    * { margin: 0; padding: 0; box-sizing: border-box; }
    html { scroll-behavior: smooth; }
    body {
      font-family: 'DM Sans', system-ui, sans-serif;
      background: var(--paper);
      color: var(--ink);
      line-height: 1.65;
      overflow-x: hidden;
      -webkit-font-smoothing: antialiased;
    }
    h1, h2, h3, h4 { font-family: 'Fraunces', Georgia, serif; line-height: 1.1; font-weight: 600; }
    a { text-decoration: none; color: inherit; }
    .wrap { max-width: 1180px; margin: 0 auto; padding: 0 28px; }
    .eyebrow {
      font-family: 'DM Sans', sans-serif; font-weight: 700; letter-spacing: 0.18em;
      text-transform: uppercase; font-size: 0.72rem; color: var(--amber);
    }
    .serif-accent { font-style: italic; color: var(--evergreen-soft); }

    /* ── Buttons ── */
    .btn {
      display: inline-flex; align-items: center; gap: 10px; cursor: pointer;
      font-family: 'DM Sans', sans-serif; font-weight: 700; font-size: 1rem;
      border: none; border-radius: 4px; padding: 15px 30px; transition: all 0.22s ease;
    }
    .btn-primary { background: var(--evergreen); color: var(--cream); }
    .btn-primary:hover { background: var(--evergreen-deep); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
    .btn-amber { background: var(--amber); color: #2a1c05; }
    .btn-amber:hover { background: var(--amber-soft); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
    .btn-ghost { background: transparent; color: var(--evergreen); border: 1.5px solid var(--evergreen); }
    .btn-ghost:hover { background: var(--evergreen); color: var(--cream); }

    /* ── Nav ── */
    nav {
      position: fixed; top: 0; left: 0; width: 100%; z-index: 100;
      background: rgba(251, 248, 241, 0.86); backdrop-filter: blur(10px);
      border-bottom: 1px solid transparent; transition: all 0.3s ease;
    }
    nav.scrolled { border-bottom-color: var(--line); box-shadow: 0 4px 20px -16px rgba(0,0,0,0.4); }
    .nav-inner { display: flex; align-items: center; justify-content: space-between; padding: 18px 28px; max-width: 1180px; margin: 0 auto; }
    .brand { display: flex; align-items: center; gap: 11px; font-family: 'Fraunces', serif; font-weight: 700; font-size: 1.5rem; color: var(--evergreen); }
    .brand .mark {
      width: 34px; height: 34px; border-radius: 8px; flex-shrink: 0;
      background: var(--evergreen); position: relative;
      display: grid; place-items: center;
    }
    .brand .mark svg { width: 20px; height: 20px; }
    .brand b { font-weight: 900; }
    .nav-links { display: flex; align-items: center; gap: 34px; }
    .nav-links a.lnk { font-weight: 600; font-size: 0.95rem; color: var(--ink-soft); transition: color 0.2s; }
    .nav-links a.lnk:hover { color: var(--evergreen); }
    .nav-toggle { display: none; background: none; border: none; cursor: pointer; color: var(--evergreen); }
    .nav-toggle svg { width: 28px; height: 28px; }

    /* mobile drawer */
    .drawer { position: fixed; inset: 0; background: var(--evergreen-deep); z-index: 200; display: none; flex-direction: column; align-items: center; justify-content: center; gap: 26px; }
    .drawer.open { display: flex; }
    .drawer a { color: var(--cream); font-size: 1.6rem; font-family: 'Fraunces', serif; }
    .drawer .close { position: absolute; top: 24px; right: 28px; font-size: 2.4rem; color: var(--cream); cursor: pointer; }

    /* ── Hero ── */
    .hero { padding: 168px 0 90px; position: relative; overflow: hidden; }
    .hero::before {
      content: ''; position: absolute; top: -120px; right: -160px; width: 620px; height: 620px;
      background: radial-gradient(circle, rgba(116,168,146,0.28), transparent 65%); z-index: 0;
    }
    .hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 64px; align-items: center; position: relative; z-index: 1; }
    .hero .badge {
      display: inline-flex; align-items: center; gap: 9px; background: var(--cream-card);
      border: 1px solid var(--line); border-radius: 999px; padding: 8px 18px; font-size: 0.82rem;
      font-weight: 600; color: var(--evergreen-soft); margin-bottom: 26px; box-shadow: var(--shadow-sm);
    }
    .hero .badge .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--amber); box-shadow: 0 0 0 4px rgba(200,130,30,0.18); }
    .hero h1 { font-size: clamp(2.7rem, 5.4vw, 4.3rem); font-weight: 600; letter-spacing: -0.01em; margin-bottom: 26px; }
    .hero h1 em { font-style: italic; color: var(--amber); font-weight: 500; }
    .hero p.lead { font-size: 1.08rem; color: var(--ink-soft); max-width: 620px; margin-bottom: 34px; }
    .hero p.lead b { color: var(--evergreen); }
    .hero-cta { display: flex; gap: 16px; flex-wrap: wrap; }

    .hero-visual { position: relative; }
    .hero-card {
      background: var(--cream-card); border: 1px solid var(--line); border-radius: 16px;
      padding: 30px; box-shadow: var(--shadow); position: relative; overflow: hidden;
    }
    .hero-card .topbar { height: 4px; width: 60px; background: var(--amber); border-radius: 4px; margin-bottom: 22px; }
    .hero-card .row { display: flex; align-items: center; justify-content: space-between; padding: 14px 0; border-bottom: 1px dashed var(--line); }
    .hero-card .row:last-child { border-bottom: none; }
    .hero-card .row .k { font-weight: 600; color: var(--ink-soft); font-size: 0.92rem; }
    .hero-card .row .v { font-family: 'Fraunces', serif; font-weight: 700; color: var(--evergreen); font-size: 1.3rem; }
    .hero-card .bar { height: 8px; border-radius: 6px; background: #eee5d2; overflow: hidden; margin-top: 6px; }
    .hero-card .bar > span { display: block; height: 100%; background: linear-gradient(90deg, var(--evergreen-soft), var(--moss)); }

    /* ── Trust strip ── */
    .trust { background: var(--evergreen); color: var(--cream); padding: 44px 0; }
    .trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px; text-align: center; }
    .trust .num { font-family: 'Fraunces', serif; font-size: 2.6rem; font-weight: 700; color: var(--amber-soft); }
    .trust .lbl { font-size: 0.86rem; letter-spacing: 0.05em; opacity: 0.82; margin-top: 4px; }

    /* ── Section scaffolding ── */
    section.block { padding: 100px 0; }
    .sec-head { max-width: 760px; margin: 0 auto 64px; text-align: center; }
    .sec-head h2 { font-size: clamp(2.1rem, 3.8vw, 2.9rem); margin: 14px 0 20px; }
    .sec-head p { color: var(--ink-soft); font-size: 1.02rem; }
    .bg-cream { background: var(--cream); }

    /* ── Process timeline ── */
    .steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; position: relative; }
    .steps::before { content: ''; position: absolute; top: 32px; left: 12%; right: 12%; height: 2px; background: repeating-linear-gradient(90deg, var(--line) 0 10px, transparent 10px 18px); }
    .step { text-align: center; padding: 0 18px; position: relative; }
    .step .circle {
      width: 64px; height: 64px; border-radius: 50%; margin: 0 auto 22px; display: grid; place-items: center;
      background: var(--cream-card); border: 2px solid var(--evergreen); color: var(--evergreen);
      font-family: 'Fraunces', serif; font-size: 1.5rem; font-weight: 700; position: relative; z-index: 1;
    }
    .step:nth-child(even) .circle { border-color: var(--amber); color: var(--amber); }
    .step h3 { font-size: 1.32rem; margin-bottom: 10px; }
    .step p { color: var(--ink-soft); font-size: 0.92rem; }

    /* ── Feature cards ── */
    .feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
    .fcard {
      background: var(--cream-card); border: 1px solid var(--line); border-left: 4px solid var(--evergreen-soft);
      border-radius: 10px; padding: 30px; transition: all 0.25s ease;
    }
    .fcard:hover { transform: translateY(-5px); box-shadow: var(--shadow-sm); border-left-color: var(--amber); }
    .fcard .ico { width: 46px; height: 46px; border-radius: 10px; background: rgba(45,106,79,0.1); display: grid; place-items: center; margin-bottom: 18px; }
    .fcard .ico svg { width: 24px; height: 24px; stroke: var(--evergreen-soft); }
    .fcard h3 { font-size: 1.22rem; margin-bottom: 9px; }
    .fcard p { color: var(--ink-soft); font-size: 0.92rem; margin-bottom: 14px; }
    .fcard .metric { font-weight: 700; font-size: 0.86rem; color: var(--evergreen-soft); display: inline-flex; align-items: center; gap: 7px; }

    /* ── Pricing ── */
    .price-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; align-items: stretch; }
    .pcard {
      background: var(--cream-card); border: 1px solid var(--line); border-radius: 14px;
      padding: 32px 26px; display: flex; flex-direction: column; position: relative; transition: all 0.25s ease;
    }
    .pcard:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
    .pcard.featured { border: 2px solid var(--amber); box-shadow: var(--shadow); }
    .pcard.dark { background: var(--evergreen); color: var(--cream); border-color: var(--evergreen); }
    .pcard.dark h3, .pcard.dark .price { color: var(--cream); }
    .pcard.dark .pdesc, .pcard.dark li { color: rgba(247,243,234,0.82); }
    .tag { position: absolute; top: -13px; left: 50%; transform: translateX(-50%); background: var(--amber); color: #2a1c05; font-size: 0.7rem; font-weight: 800; letter-spacing: 0.08em; padding: 5px 16px; border-radius: 999px; white-space: nowrap; }
    .pcard h3 { font-size: 1.4rem; margin-bottom: 10px; }
    .pcard .price { font-family: 'Fraunces', serif; font-size: 2.5rem; font-weight: 700; color: var(--evergreen); margin-bottom: 8px; }
    .pcard .pdesc { font-size: 0.87rem; color: var(--ink-soft); margin-bottom: 22px; min-height: 64px; }
    .pcard ul { list-style: none; margin-bottom: 26px; flex-grow: 1; }
    .pcard li { font-size: 0.88rem; color: var(--ink-soft); padding: 7px 0 7px 26px; position: relative; }
    .pcard li::before { content: ''; position: absolute; left: 0; top: 13px; width: 13px; height: 7px; border-left: 2px solid var(--amber); border-bottom: 2px solid var(--amber); transform: rotate(-45deg); }
    .pcard.dark li::before { border-color: var(--amber-soft); }
    .pcard .btn { width: 100%; justify-content: center; }

    /* ── Benefits ── */
    .ben-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-bottom: 60px; }
    .bcard { padding: 30px; border-radius: 10px; background: var(--cream-card); border: 1px solid var(--line); }
    .bcard .ico { width: 52px; height: 52px; border-radius: 12px; background: var(--evergreen); display: grid; place-items: center; margin-bottom: 18px; }
    .bcard .ico svg { width: 26px; height: 26px; stroke: var(--amber-soft); }
    .bcard h3 { font-size: 1.2rem; margin-bottom: 10px; }
    .bcard p { color: var(--ink-soft); font-size: 0.93rem; }

    /* ── Considerations split ── */
    .split { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; max-width: 980px; margin: 0 auto; }
    .panel { background: var(--cream-card); border: 1px solid var(--line); border-radius: 14px; padding: 38px; }
    .panel h3 { font-size: 1.5rem; margin-bottom: 22px; display: flex; align-items: center; gap: 12px; }
    .panel.pos h3 { color: var(--evergreen-soft); }
    .panel.con h3 { color: var(--amber); }
    .panel ul { list-style: none; display: flex; flex-direction: column; gap: 16px; }
    .panel li { display: flex; gap: 13px; color: var(--ink-soft); font-size: 0.95rem; }
    .panel li svg { width: 20px; height: 20px; flex-shrink: 0; margin-top: 3px; }
    .panel.pos li svg { stroke: var(--evergreen-soft); }
    .panel.con li svg { stroke: var(--amber); }
    .panel li b { color: var(--ink); }

    /* ── FAQ ── */
    .faq-list { max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; gap: 14px; }
    .faq { background: var(--cream-card); border: 1px solid var(--line); border-radius: 10px; overflow: hidden; transition: border-color 0.2s; }
    .faq.open { border-color: var(--amber); }
    .faq .q { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 22px 26px; cursor: pointer; font-family: 'Fraunces', serif; font-weight: 600; font-size: 1.12rem; }
    .faq .q .chev { width: 22px; height: 22px; flex-shrink: 0; transition: transform 0.3s; stroke: var(--evergreen-soft); }
    .faq.open .q .chev { transform: rotate(180deg); }
    .faq .a { max-height: 0; overflow: hidden; transition: max-height 0.35s ease; }
    .faq .a-inner { padding: 0 26px 24px; color: var(--ink-soft); font-size: 0.96rem; }
    .faq.open .a { max-height: 360px; }

    /* ── CTA ── */
    .cta { background: var(--evergreen); color: var(--cream); text-align: center; padding: 96px 0; position: relative; overflow: hidden; }
    .cta::before { content: ''; position: absolute; bottom: -180px; left: 50%; transform: translateX(-50%); width: 700px; height: 360px; background: radial-gradient(circle, rgba(200,130,30,0.3), transparent 65%); }
    .cta h2 { font-size: clamp(2.2rem, 4vw, 3.2rem); margin-bottom: 18px; position: relative; }
    .cta p { font-size: 1.1rem; opacity: 0.88; margin-bottom: 34px; position: relative; }
    .cta .btn { position: relative; }

    /* ── Footer ── */
    footer { background: var(--evergreen-deep); color: rgba(247,243,234,0.78); padding: 72px 0 36px; }
    .foot-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.4fr; gap: 40px; margin-bottom: 48px; }
    footer h3 { font-size: 1.7rem; color: var(--cream); margin-bottom: 16px; }
    footer h4 { font-family: 'DM Sans', sans-serif; font-size: 0.78rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--amber-soft); margin-bottom: 18px; }
    footer p { font-size: 0.92rem; margin-bottom: 10px; }
    footer ul { list-style: none; display: flex; flex-direction: column; gap: 11px; }
    footer ul a { font-size: 0.92rem; transition: color 0.2s; }
    footer ul a:hover { color: var(--amber-soft); }
    footer iframe { border-radius: 10px; border: 1px solid rgba(255,255,255,0.12); }
    .foot-bottom { border-top: 1px solid rgba(255,255,255,0.12); padding-top: 26px; text-align: center; font-size: 0.85rem; opacity: 0.7; }

    /* ── Modal ── */
    .overlay { position: fixed; inset: 0; background: rgba(22,58,44,0.55); backdrop-filter: blur(4px); z-index: 300; display: none; align-items: flex-start; justify-content: center; padding: 40px 20px; overflow-y: auto; }
    .overlay.show { display: flex; }
    .modal { background: var(--paper); border-radius: 16px; width: 100%; max-width: 640px; box-shadow: var(--shadow); overflow: hidden; animation: pop 0.25s ease; }
    @keyframes pop { from { transform: translateY(16px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
    .modal-head { background: var(--evergreen); color: var(--cream); padding: 30px 34px; position: relative; }
    .modal-head h3 { font-size: 1.7rem; margin-bottom: 6px; }
    .modal-head p { opacity: 0.85; font-size: 0.95rem; }
    .modal-head .x { position: absolute; top: 22px; right: 26px; font-size: 1.8rem; cursor: pointer; color: var(--cream); line-height: 1; }
    .modal-body { padding: 30px 34px; }
    .modal-body h4 { font-family: 'DM Sans', sans-serif; font-weight: 700; color: var(--evergreen); margin: 20px 0 6px; font-size: 1rem; }
    .modal-body h4:first-child { margin-top: 0; }
    .modal-body p { color: var(--ink-soft); font-size: 0.93rem; margin-bottom: 8px; }
    .form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
    .form-grid .full { grid-column: 1 / -1; }
    .modal input, .modal select, .modal textarea {
      width: 100%; padding: 13px 15px; border: 1px solid var(--line); border-radius: 8px;
      font-family: 'DM Sans', sans-serif; font-size: 0.95rem; background: var(--cream-card); color: var(--ink);
    }
    .modal input:focus, .modal select:focus, .modal textarea:focus { outline: none; border-color: var(--amber); box-shadow: 0 0 0 3px rgba(200,130,30,0.15); }
    .modal .btn { width: 100%; justify-content: center; }
    .success-box { display: none; text-align: center; padding: 20px 0; }
    .success-box.show { display: block; }
    .success-box .ring { width: 70px; height: 70px; border-radius: 50%; background: rgba(45,106,79,0.12); display: grid; place-items: center; margin: 0 auto 18px; }
    .success-box .ring svg { width: 36px; height: 36px; stroke: var(--evergreen-soft); }
    .success-box h3 { font-size: 1.6rem; color: var(--evergreen); margin-bottom: 8px; }
    .success-box p { color: var(--ink-soft); }

    /* reveal */
    .reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.7s ease, transform 0.7s ease; }
    .reveal.in { opacity: 1; transform: none; }

    /* ── Responsive ── */
    @media (max-width: 900px) {
      .nav-links { display: none; }
      .nav-toggle { display: block; }
      .hero-grid { grid-template-columns: 1fr; gap: 44px; }
      .hero-visual { order: -1; }
      .trust-grid { grid-template-columns: repeat(2, 1fr); gap: 28px; }
      .steps { grid-template-columns: 1fr 1fr; gap: 40px 18px; }
      .steps::before { display: none; }
      .feature-grid, .ben-grid { grid-template-columns: 1fr; }
      .price-grid { grid-template-columns: 1fr; }
      .split { grid-template-columns: 1fr; }
      .foot-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
      .form-grid { grid-template-columns: 1fr; }
    }
    @media (max-width: 520px) {
      .trust-grid { grid-template-columns: 1fr 1fr; }
      .foot-grid { grid-template-columns: 1fr; }
      section.block { padding: 70px 0; }
    }

    /* ── Sub-pages (legal docs + contact) ── */
    .subpage-head { padding: 150px 0 56px; background: var(--evergreen); color: var(--cream); text-align: center; position: relative; overflow: hidden; }
    .subpage-head::before { content:''; position:absolute; bottom:-160px; left:50%; transform:translateX(-50%); width:600px; height:320px; background: radial-gradient(circle, rgba(200,130,30,0.28), transparent 65%); }
    .subpage-head .eyebrow { color: var(--amber-soft); }
    .subpage-head h1 { font-size: clamp(2.1rem, 4.4vw, 3.2rem); position: relative; margin-top: 12px; }
    .subpage-head p { opacity: 0.85; margin-top: 10px; position: relative; }
    .doc { max-width: 820px; margin: 0 auto; padding: 56px 28px 80px; }
    .doc h4 { font-family: 'DM Sans', sans-serif; font-weight: 700; color: var(--evergreen); margin: 24px 0 6px; font-size: 1.06rem; }
    .doc h4:first-child { margin-top: 0; }
    .doc p { color: var(--ink-soft); margin-bottom: 10px; }
    .doc .back { margin-top: 36px; }
    .contact-wrap { padding: 130px 0 90px; background: var(--cream); }
    .contact-wrap .modal { animation: none; margin: 0 auto; background: var(--cream-card); }
    .contact-wrap .lead-note { text-align:center; max-width:600px; margin: 0 auto 30px; color: var(--ink-soft); }

