:root {
      --deep:    #264A2D;
      --bot:     #5E7D3A;
      --sage:    #9CAF6B;
      --olive:   #C2CE9A;
      --gold:    #C9A24B;
      --gold-2:  #E6C97A;
      --cream:   #F7F3EC;
      --beige:   #EAE2D6;
      --char:    #4A4A42;
      --char-2:  #6B6B5E;
      --line:    rgba(74,74,66,0.12);
      --line-2:  rgba(74,74,66,0.06);
      --serif:   "Cormorant Garamond", "Playfair Display", Georgia, serif;
      --sans:    "Inter", system-ui, sans-serif;
      --radius:  18px;
      --radius-lg: 28px;
    }
    * { box-sizing: border-box; }
    html, body {
      margin: 0; padding: 0;
      background: var(--cream);
      color: var(--char);
      font-family: var(--sans);
      font-size: 16px;
      -webkit-font-smoothing: antialiased;
      text-rendering: optimizeLegibility;
      overflow-x: clip;
    }
    img { max-width: 100%; display: block; }
    button { font-family: inherit; cursor: pointer; }
    a { color: inherit; text-decoration: none; }

    .serif { font-family: var(--serif); font-weight: 500; letter-spacing: -0.01em; }
    .cinzel { font-family: "Cinzel", serif; letter-spacing: 0.22em; text-transform: uppercase; font-weight: 500; }

    /* nav */
    .nav-shell {
      position: sticky; top: 0; z-index: 50;
      backdrop-filter: blur(14px) saturate(1.05);
      -webkit-backdrop-filter: blur(14px) saturate(1.05);
      background: rgba(247, 243, 236, 0.78);
      border-bottom: 1px solid transparent;
      transition: border-color .3s ease, background .3s ease;
    }
    .nav-shell.scrolled { border-bottom-color: var(--line-2); background: rgba(247, 243, 236, 0.88); }
    .nav { max-width: 1280px; margin: 0 auto; padding: 18px 32px; display: flex; align-items: center; gap: 40px; }
    .brand-lock { display: flex; align-items: center; gap: 0px; }
    .brand-mark { width: auto; height: 58px; object-fit: contain; } /* logo size — desktop */
    .brand-text { display: flex; flex-direction: column; line-height: 1; }
    .brand-name { font-family: var(--serif); font-size: 19px; color: var(--deep); font-weight: 600; letter-spacing: 0.005em; }
    .brand-tag  { font-family: "Cinzel", serif; font-size: 9px; letter-spacing: 0.28em; color: var(--bot); margin-top: 5px; }
    .nav-links { display: flex; gap: 32px; margin-left: auto; }
    .nav-links a { font-size: 13.5px; color: var(--char); transition: color .2s; position: relative; }
    .nav-links a:hover { color: var(--deep); }
    .nav-links a.active { color: var(--deep); }
    .nav-links a.active::after { content: ""; position: absolute; left: 0; right: 0; bottom: -7px; height: 1px; background: var(--gold); }

    /* buttons */
    .btn {
      display: inline-flex; align-items: center; gap: 10px;
      padding: 13px 24px; border-radius: 100px;
      font-size: 13.5px; font-weight: 500; letter-spacing: 0.01em;
      border: 1px solid transparent;
      transition: transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
      will-change: transform;
    }
    .btn-primary {
      background: linear-gradient(135deg, var(--deep) 0%, var(--bot) 100%);
      color: var(--cream);
      box-shadow: 0 8px 22px -10px rgba(38, 74, 45, 0.55);
    }
    .btn-primary:hover { transform: translateY(-1px); box-shadow: 0 14px 28px -12px rgba(38, 74, 45, 0.6); }
    .btn-gold {
      background: linear-gradient(135deg, var(--gold) 0%, var(--gold-2) 100%);
      color: #3d2e0a;
      box-shadow: 0 8px 22px -10px rgba(201, 162, 75, 0.6);
    }
    .btn-gold:hover { transform: translateY(-1px); box-shadow: 0 14px 28px -12px rgba(201, 162, 75, 0.65); }
    .btn-ghost {
      background: transparent;
      color: var(--deep);
      border-color: rgba(38, 74, 45, 0.22);
    }
    .btn-ghost:hover { background: rgba(38, 74, 45, 0.06); border-color: rgba(38, 74, 45, 0.4); }
    .btn-sm { padding: 10px 18px; font-size: 12.5px; }

    /* layout */
    .container { max-width: 1280px; margin: 0 auto; padding: 0 32px; }
    .section { padding: 80px 0; position: relative; }
    .section-tight { padding: 56px 0; }

    .eyebrow {
      display: inline-flex; align-items: center; gap: 14px;
      font-family: "Cinzel", serif; font-size: 11px; letter-spacing: 0.32em;
      color: var(--bot); text-transform: uppercase; font-weight: 500;
    }
    .eyebrow::before, .eyebrow::after {
      content: ""; width: 28px; height: 1px; background: var(--gold);
    }
    .eyebrow.left::before { display: none; }
    .eyebrow.left { padding-left: 0; }

    h1.display, h2.display, h3.display {
      font-family: var(--serif);
      color: var(--deep);
      font-weight: 500;
      letter-spacing: -0.015em;
      line-height: 1.04;
      margin: 0;
      text-wrap: balance;
    }
    h1.display { font-size: clamp(48px, 6.4vw, 92px); }
    h2.display { font-size: clamp(38px, 4.6vw, 64px); }
    h3.display { font-size: 26px; line-height: 1.18; }
    .lede { font-size: 17px; line-height: 1.65; color: var(--char-2); max-width: 56ch; text-wrap: pretty; }

    /* cards */
    .card {
      background: #FBF8F2;
      border: 1px solid var(--line-2);
      border-radius: var(--radius-lg);
      transition: transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease, border-color .35s ease;
    }
    .card.hoverable:hover { transform: translateY(-4px); box-shadow: 0 26px 50px -32px rgba(38, 74, 45, 0.28); border-color: rgba(94, 125, 58, 0.18); }

    /* reveal */
    .reveal { opacity: 0; transform: translateY(18px); transition: opacity .9s ease, transform .9s ease; }
    .reveal.in { opacity: 1; transform: none; }
    .reveal.d1 { transition-delay: .08s; }
    .reveal.d2 { transition-delay: .16s; }
    .reveal.d3 { transition-delay: .24s; }
    .reveal.d4 { transition-delay: .32s; }
    .reveal.d5 { transition-delay: .4s; }
    .reveal.d6 { transition-delay: .48s; }
    @media (max-width: 1024px) {
      .reveal { opacity: 1; transform: none; }
    }

    /* botanical leaves: drawn as decorations using simple shapes only */
    .leaf-decoration { position: absolute; pointer-events: none; opacity: 0.55; }

    /* tweak surfaces */
    .tone-sage { --deep: #3D5E1F; --bot: #6E8E4A; }
    .tone-gold { --deep: #2F4226; --gold: #B88928; --gold-2: #D9B14C; }

    /* ============ RESPONSIVE GRID UTILITIES ============ */
    .g-hero    { display: grid; grid-template-columns: 1.15fr 1fr; gap: 80px; align-items: center; position: relative; }
    .g-about   { display: grid; grid-template-columns: 0.9fr 1fr;  gap: 80px; align-items: center; }
    .g-contact { display: grid; grid-template-columns: 1fr 1fr;    gap: 60px; align-items: center; position: relative; }
    .g-form    { display: grid; grid-template-columns: 1.05fr 1fr; gap: 56px; align-items: start; }
    .g-3       { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
    .g-3-tight { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
    .g-4       { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
    .g-info    { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
    .g-stats   { display: flex; gap: 36px; align-items: center; flex-wrap: wrap; }
    .g-flow    { display: flex; align-items: end; justify-content: space-between; gap: 40px; flex-wrap: wrap; }

    /* tablet ≤1024 */
    @media (max-width: 1024px) {
      .section { padding: 64px 0; }
      .g-hero    { grid-template-columns: 1fr; gap: 56px; }
      .g-about   { grid-template-columns: 1fr; gap: 56px; }
      .g-contact { grid-template-columns: 1fr; gap: 48px; }
      .g-form    { grid-template-columns: 1fr; gap: 40px; }
      .g-3       { grid-template-columns: repeat(2, 1fr); }
      .g-3-tight { grid-template-columns: repeat(2, 1fr); }
      .g-4       { grid-template-columns: repeat(2, 1fr); }
      .nav { padding: 16px 24px; gap: 20px; }
      .nav-links { display: none; }
      .container { padding: 0 24px; }
      h1.display { font-size: clamp(42px, 7vw, 64px); }
      h2.display { font-size: clamp(34px, 5.6vw, 48px); }
    }

    /* mobile ≤640 */
    @media (max-width: 640px) {
      .section { padding: 48px 0; }
      .g-3, .g-3-tight, .g-4 { grid-template-columns: 1fr; }
      .g-info { grid-template-columns: 1fr; }
      .g-stats { gap: 24px; }
      .container { padding: 0 18px; }
      .nav { padding: 14px 18px; gap: 12px; }
      .brand-tag { font-size: 8px; }
      .brand-name { font-size: 17px; }
      .brand-mark { width: auto; height: 50px; } /* logo size — tablet/mobile */
      h1.display { font-size: clamp(36px, 9vw, 52px); }
      h2.display { font-size: clamp(28px, 7vw, 40px); }
      h3.display { font-size: 22px; }
      .lede { font-size: 15.5px; }
      .btn { padding: 12px 20px; font-size: 13px; }
      .card { border-radius: 22px; }
      .nav-cta-text { display: none; }
      .nav-cta-icon { display: inline-flex !important; }
      .hide-mobile { display: none !important; }
      /* Contact green box: less padding on mobile */
      .contact-box { padding: 48px 24px !important; border-radius: 24px !important; }
      /* Modals scale */
      .booking-grid-dates { grid-template-columns: repeat(2, 1fr) !important; }
      .booking-grid-slots { grid-template-columns: repeat(3, 1fr) !important; }
      .booking-grid-focus { grid-template-columns: 1fr !important; }
      /* Form */
      .form-grid { grid-template-columns: 1fr !important; }
      /* Tip cards aspect ratio */
      .tip-cover { aspect-ratio: 5 / 4 !important; }
      /* Hero portrait shrinks */
      .portrait-frame { border-radius: 160px 160px 24px 24px !important; }
      /* Testimonial */
      .voice-card { padding: 36px 28px 32px !important; }
      .voice-quote { font-size: 21px !important; }
      /* Footer wraps */
      .footer-row { flex-direction: column; align-items: flex-start !important; gap: 20px !important; }
      /* WhatsApp FAB smaller */
      .wa-fab { width: 52px !important; height: 52px !important; right: 18px !important; bottom: 18px !important; }
      /* Hide some decorative leaves on mobile */
      .leaf-decoration { transform: scale(0.65); }
    }
    .nav-cta-icon { display: none; }

    /* mobile drawer */
    .drawer-backdrop {
      position: fixed; inset: 0; z-index: 60;
      background: rgba(38, 74, 45, 0.5);
      backdrop-filter: blur(8px);
      opacity: 0; pointer-events: none;
      transition: opacity .3s ease;
    }
    .drawer-backdrop.open { opacity: 1; pointer-events: auto; }
    .drawer {
      position: fixed; top: 0; right: 0; bottom: 0; z-index: 61;
      width: min(360px, 86%);
      background: var(--cream);
      transform: translateX(100%);
      transition: transform .35s cubic-bezier(.2,.7,.2,1);
      display: flex; flex-direction: column;
      box-shadow: -40px 0 80px -20px rgba(0,0,0,0.2);
    }
    .drawer.open { transform: translateX(0); }
    .drawer-head { padding: 22px 24px; display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--line-2); }
    .drawer-links { display: flex; flex-direction: column; padding: 12px 0; flex: 1; }
    .drawer-links a {
      padding: 18px 28px; font-family: var(--serif); font-size: 22px;
      color: var(--deep); border-bottom: 1px solid var(--line-2);
      display: flex; align-items: center; justify-content: space-between;
    }
    .drawer-links a:last-child { border-bottom: none; }
    .drawer-cta { padding: 24px; border-top: 1px solid var(--line-2); }
    .menu-btn {
      display: none;
      width: 44px; height: 44px; border-radius: 99px;
      border: 1px solid var(--line);
      background: transparent;
      align-items: center; justify-content: center;
      color: var(--deep);
    }
    @media (max-width: 1024px) {
      .menu-btn { display: inline-flex; }
    }

    /* scrollbar polish */
    ::selection { background: rgba(201, 162, 75, 0.35); color: var(--deep); }

    /* ============ PAGE HEADERS ============ */
    .page-header {
      padding: 80px 0 64px;
      position: relative;
      overflow: hidden;
    }
    .page-header .breadcrumb {
      display: flex; width: max-content; align-items: center; gap: 10px;
      font-size: 12px; color: var(--char-2); letter-spacing: 0.04em;
      margin-bottom: 22px;
    }
    .page-header .breadcrumb a { color: var(--char-2); transition: color .2s; }
    .page-header .breadcrumb a:hover { color: var(--deep); }
    .page-header .breadcrumb svg { opacity: 0.4; }

    /* how it works — prep section */
    .hiw-prep-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 48px; align-items: start; }
    @media (max-width: 1024px) {
      .hiw-prep-grid { grid-template-columns: 1fr; gap: 32px; }
    }

    /* faq layout */
    .faq-layout-grid { display: grid; grid-template-columns: 0.6fr 1.4fr; gap: 56px; align-items: start; }
    .faq-sidebar { position: sticky; top: 110px; }
    @media (max-width: 1024px) {
      .faq-layout-grid { grid-template-columns: 1fr; gap: 24px; }
      .faq-sidebar { position: static; }
    }

    /* blog featured card */
    .blog-featured-card { display: grid; grid-template-columns: 1fr 1fr; gap: 0; overflow: hidden; background: #FBF8F2; }
    .blog-featured-body { padding: 56px; display: flex; flex-direction: column; justify-content: center; }
    @media (max-width: 1024px) {
      .blog-featured-card { grid-template-columns: 1fr; }
      .blog-featured-body { padding: 32px; }
    }
    @media (max-width: 640px) {
      .blog-featured-body { padding: 24px; }
    }


    /* services detail section */
    .services-detail-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 56px; }
    .services-detail-card { padding: 44px; min-height: 480px; }
    @media (max-width: 1024px) {
      .services-detail-grid { grid-template-columns: 1fr; gap: 32px; }
      .services-detail-card { min-height: unset; padding: 32px; }
    }
    @media (max-width: 640px) {
      .services-detail-card { padding: 24px; }
    }

    /* map + hours section */
    .map-hours-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 32px; align-items: stretch; }
    .map-card { min-height: 460px; }
    @media (max-width: 1024px) {
      .map-hours-grid { grid-template-columns: 1fr; }
      .map-card { min-height: 320px; }
    }
    @media (max-width: 640px) {
      .map-card { min-height: 260px; }
    }

    /* footer */
    .site-footer { padding: 80px 0 40px; border-top: 1px solid var(--line-2); background: #FBF8F2; }
    .footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 56px; }
    .footer-bottom-links { display: flex; gap: 20px; font-size: 12.5px; color: var(--char-2); flex-wrap: wrap; }
    .footer-bottom-links a { color: var(--char-2); transition: color .2s; }
    .footer-bottom-links a:hover { color: var(--deep); }

    @media (max-width: 1024px) {
      .site-footer { padding: 56px 0 32px; }
      .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px 24px; margin-bottom: 40px; }
      .page-header { padding: 56px 0 48px; }
    }
    @media (max-width: 640px) {
      .site-footer { padding: 44px 0 28px; }
      .footer-grid { grid-template-columns: 1fr 1fr; gap: 28px 16px; margin-bottom: 32px; }
      .footer-bottom-links { gap: 14px; }
    }
    @media (max-width: 400px) {
      .footer-grid { grid-template-columns: 1fr; gap: 28px; }
    }

    /* accordion */
    .acc {
      border-bottom: 1px solid var(--line);
    }
    .acc-q {
      width: 100%; text-align: left; background: transparent; border: none;
      padding: 28px 0; font-family: var(--serif); font-size: 22px; color: var(--deep);
      display: flex; justify-content: space-between; align-items: center; gap: 20px;
      font-weight: 500; cursor: pointer;
    }
    .acc-icon { width: 28px; height: 28px; flex-shrink: 0; border: 1px solid var(--line); border-radius: 50%; display: grid; place-items: center; transition: transform .3s, background .3s; }
    .acc.open .acc-icon { background: var(--deep); color: var(--cream); border-color: var(--deep); transform: rotate(45deg); }
    .acc-a {
      max-height: 0; overflow: hidden;
      transition: max-height .35s ease;
    }
    .acc.open .acc-a { max-height: 400px; }
    .acc-a-inner { padding: 0 0 28px; font-size: 15px; line-height: 1.7; color: var(--char-2); max-width: 64ch; }

    /* timeline / steps */
    .step-line {
      position: absolute; left: 28px; top: 0; bottom: 0; width: 1px;
      background: linear-gradient(180deg, transparent 0%, var(--gold) 8%, var(--gold) 92%, transparent 100%);
    }
    @media (max-width: 640px) {
      .step-line { left: 20px; }
    }

    /* gallery grid */
    .gallery-grid {
      display: grid;
      grid-template-columns: repeat(12, 1fr);
      grid-auto-rows: 120px;
      gap: 14px;
    }
    @media (max-width: 1024px) {
      .gallery-grid { grid-template-columns: repeat(6, 1fr); grid-auto-rows: 100px; gap: 12px; }
    }
    @media (max-width: 640px) {
      .gallery-grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 140px; gap: 10px; }
    }

    /* generic 2-col, 3-col for content pages */
    .g-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; }
    @media (max-width: 1024px) { .g-2 { grid-template-columns: 1fr; gap: 48px; } }

    /* ============ LEGAL PROSE ============ */
    .legal-layout-grid { display: grid; grid-template-columns: 0.55fr 1.45fr; gap: 56px; align-items: start; }
    @media (max-width: 1024px) {
      .legal-layout-grid { grid-template-columns: 1fr; gap: 32px; }
      .legal-toc { position: static !important; }
    }

    .legal-toc {
      position: sticky; top: 110px;
      padding: 22px 24px;
      background: #FBF8F2;
      border: 1px solid var(--line-2);
      border-radius: 18px;
    }
    .legal-toc h4 {
      font-family: "Cinzel", serif;
      font-size: 10.5px;
      letter-spacing: 0.28em;
      color: var(--bot);
      text-transform: uppercase;
      margin: 0 0 14px;
      font-weight: 500;
    }
    .legal-toc ol {
      list-style: none; padding: 0; margin: 0;
      counter-reset: toc;
    }
    .legal-toc li {
      counter-increment: toc;
      padding: 8px 0;
      border-top: 1px solid var(--line-2);
    }
    .legal-toc li:first-child { border-top: none; padding-top: 0; }
    .legal-toc a {
      display: flex; align-items: baseline; gap: 12px;
      font-size: 13.5px;
      color: var(--char);
      transition: color .2s;
      line-height: 1.4;
    }
    .legal-toc a::before {
      content: counter(toc, decimal-leading-zero);
      font-family: var(--serif);
      font-size: 12px;
      color: var(--gold);
      font-weight: 600;
      flex-shrink: 0;
    }
    .legal-toc a:hover { color: var(--deep); }
    .legal-toc a.active { color: var(--deep); font-weight: 500; }

    .legal-prose {
      max-width: 68ch;
    }
    .legal-prose h2 {
      font-family: var(--serif);
      font-size: 32px;
      color: var(--deep);
      font-weight: 500;
      letter-spacing: -0.015em;
      line-height: 1.15;
      margin: 0 0 6px;
      scroll-margin-top: 110px;
    }
    .legal-prose .section-num {
      font-family: "Cinzel", serif;
      font-size: 10.5px;
      letter-spacing: 0.3em;
      color: var(--gold);
      text-transform: uppercase;
      margin-bottom: 14px;
      display: flex; align-items: center; gap: 12px;
    }
    .legal-prose .section-num::after { content: ""; flex: 1; height: 1px; background: rgba(201, 162, 75, 0.3); max-width: 80px; }
    .legal-prose section + section { margin-top: 56px; padding-top: 0; }
    .legal-prose section { padding-bottom: 8px; }
    .legal-prose h3 {
      font-family: var(--serif);
      font-size: 20px;
      color: var(--deep);
      font-weight: 600;
      margin: 28px 0 8px;
    }
    .legal-prose p {
      font-size: 15.5px;
      line-height: 1.75;
      color: var(--char-2);
      margin: 16px 0;
      text-wrap: pretty;
    }
    .legal-prose ul {
      list-style: none; padding: 0; margin: 16px 0;
    }
    .legal-prose ul li {
      position: relative;
      padding: 6px 0 6px 24px;
      font-size: 15.5px;
      line-height: 1.7;
      color: var(--char-2);
    }
    .legal-prose ul li::before {
      content: "";
      position: absolute;
      left: 4px; top: 18px;
      width: 6px; height: 6px;
      background: var(--gold);
      border-radius: 50%;
    }
    .legal-prose strong { color: var(--deep); font-weight: 600; }
    .legal-prose a { color: var(--bot); border-bottom: 1px solid rgba(94, 125, 58, 0.3); transition: border-color .2s; }
    .legal-prose a:hover { border-bottom-color: var(--bot); }

    .legal-callout {
      padding: 22px 26px;
      border-radius: 16px;
      background: rgba(201, 162, 75, 0.08);
      border: 1px solid rgba(201, 162, 75, 0.25);
      margin: 24px 0;
      display: flex; gap: 16px; align-items: flex-start;
    }
    .legal-callout .legal-callout-icon {
      flex-shrink: 0; width: 36px; height: 36px;
      border-radius: 50%; background: var(--gold);
      color: #3d2e0a;
      display: grid; place-items: center;
      font-family: var(--serif); font-weight: 600;
    }
    .legal-callout p { margin: 0; color: var(--char); font-size: 14.5px; }
    .legal-callout strong { color: var(--deep); }

    .legal-meta {
      display: flex; gap: 18px; align-items: center; flex-wrap: wrap;
      padding-bottom: 28px; margin-bottom: 28px;
      border-bottom: 1px solid var(--line-2);
      font-size: 12.5px; color: var(--char-2);
    }
    .legal-meta-chip {
      padding: 5px 12px; border-radius: 99px;
      background: rgba(94, 125, 58, 0.08);
      color: var(--bot);
      letter-spacing: 0.04em;
    }

    @media (max-width: 1024px) {
      .legal-toc { position: static; margin-bottom: 8px; }
    }
