  :root{
    --gold:#D4A857;
    --gold-dark:#b8923f;
    --cream:#F5F1EA;
    --ink:#0F0F0F;
    --ink-2:#1c1c1c;
    --text:#2a2a2a;
    --muted:#6b6b6b;
    --line:#e7e0d4;
    --white:#ffffff;
    --shadow:0 10px 30px rgba(15,15,15,.08);
    --shadow-lg:0 20px 50px rgba(15,15,15,.12);
    --radius:14px;
    --maxw:1180px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    font-family:'Inter',system-ui,sans-serif;
    color:var(--text);
    background:var(--white);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:clip;
  }
  h1,h2,h3{font-family:'Playfair Display',Georgia,serif;color:var(--ink);line-height:1.15;font-weight:700;font-variant-numeric:lining-nums;font-feature-settings:"lnum" 1}
  a{color:inherit;text-decoration:none}
  img{max-width:100%;display:block}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
  .eyebrow{
    display:inline-block;font-size:.78rem;font-weight:600;letter-spacing:.12em;
    text-transform:uppercase;color:var(--gold-dark);margin-bottom:14px;
  }
  .btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    font-weight:600;font-size:.95rem;padding:13px 26px;border-radius:10px;
    border:1.5px solid transparent;cursor:pointer;transition:.18s ease;
  }
  .btn-gold{background:var(--gold);color:var(--ink)}
  .btn-gold:hover{background:var(--gold-dark);transform:translateY(-1px)}
  .btn-ghost{background:transparent;border-color:rgba(255,255,255,.35);color:var(--white)}
  .btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
  .btn-dark{background:var(--ink);color:var(--white)}
  .btn-dark:hover{background:var(--ink-2);transform:translateY(-1px)}
  :focus-visible{outline:2px solid var(--gold-dark);outline-offset:3px}

  /* ---------- NAV ---------- */
  header.nav{
    position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);
    backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
  }
  .nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
  .brand{display:flex;align-items:center;gap:10px;font-family:'Playfair Display',serif;
    font-weight:700;font-size:clamp(.92rem,1.7vw,1.15rem);color:var(--ink)}
  .brand .mark{width:38px;height:38px;border-radius:8px;background:var(--ink);
    color:var(--gold);display:grid;place-items:center;font-size:.9rem;font-weight:700;overflow:hidden}
  .brand .mark img{width:100%;height:100%;object-fit:cover;border-radius:inherit}
  .nav-links{display:flex;gap:30px;align-items:center}
  .nav-links a{font-size:.92rem;font-weight:500;color:var(--text);transition:.15s}
  .nav-links a:hover{color:var(--gold-dark)}
  .nav-cta{display:flex;align-items:center;gap:16px}
  .nav-phone{font-weight:600;font-size:.92rem;color:var(--ink)}
  .nav-cta .btn{padding:9px 18px;font-size:.85rem}
  .nav-ig{display:inline-flex;align-items:center;color:var(--ink);transition:color .15s}
  .nav-ig:hover{color:var(--gold-dark)}
  .burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
  .burger span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;transition:.2s}

  /* ---------- HERO ---------- */
  .hero{position:relative;background:var(--ink);color:var(--white);overflow:hidden}
  .hero::before{content:"";position:absolute;inset:0;background:transparent;}
  .hero-inner{position:relative;padding:90px 0 80px;max-width:760px;margin:0 auto;text-align:center}
  .hero h1{color:var(--white);font-size:clamp(2.4rem,5.5vw,4rem);font-weight:800;margin-bottom:22px}
  .hero h1 .accent{color:var(--gold);white-space:nowrap}
  .hero p{font-size:1.12rem;color:rgba(255,255,255,.78);max-width:680px;margin:0 auto 34px}
  .hero .eyebrow{color:var(--gold)}
  .hero-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-bottom:56px}
  .stats{display:flex;justify-content:center;gap:54px;flex-wrap:wrap}
  .stat .num{font-family:'Playfair Display',serif;font-size:2.4rem;font-weight:700;color:var(--gold);font-variant-numeric:lining-nums;font-feature-settings:"lnum" 1}
  .stat .num .sym{font-size:.8em;vertical-align:0.05em;margin-left:0;color:var(--gold)}
  .stat .label{font-size:.9rem;color:rgba(255,255,255,.7)}

  /* ---------- TESTIMONIALS ---------- */
  .reviews{background:var(--cream);padding:64px 0}
  .review-track{
    display:flex;gap:22px;overflow-x:auto;
    scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
    padding:6px 0 10px;scrollbar-width:none;
  }
  .review-track::-webkit-scrollbar{display:none}
  .review-card{
    flex:0 0 320px;scroll-snap-align:start;
    background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
    box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;transition:.2s;
  }
  .review-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
  .review-photo{aspect-ratio:1/1;background:var(--cream);overflow:hidden}
  .review-photo img{width:100%;height:100%;object-fit:cover;object-position:top center}
  .review-body{padding:22px 24px 26px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px}
  .review-name{font-family:'Playfair Display',serif;font-weight:700;color:var(--ink);font-size:1.15rem}
  .review-stars{color:var(--gold);font-size:1rem;letter-spacing:2px}
  .review-text{font-size:.92rem;color:var(--muted);line-height:1.6}
  /* Carousel arrows (desktop nav) */
  .review-nav{display:flex;justify-content:center;gap:14px;margin-top:22px}
  .review-arrow{
    width:46px;height:46px;border-radius:50%;border:1px solid var(--line);
    background:var(--white);color:var(--ink);font-size:1.4rem;line-height:1;
    cursor:pointer;box-shadow:var(--shadow);transition:.18s ease;display:grid;place-items:center;
  }
  .review-arrow:hover{background:var(--ink);color:var(--gold);transform:translateY(-1px)}
  .review-arrow:disabled{opacity:.35;cursor:default;box-shadow:none;transform:none;background:var(--white);color:var(--ink)}
  @media (max-width:680px){
    .review-card{flex:0 0 84%}
    .review-nav{display:none}
  }

  /* ---------- SECTIONS ---------- */
  section{scroll-margin-top:80px}
  .pad{padding:88px 0}
  .section-head{max-width:680px;margin-bottom:48px}
  .section-head h2{font-size:clamp(2.2rem,4.5vw,3.2rem);margin-bottom:14px}
  .section-head p{font-size:1.05rem;color:var(--muted)}
  .center{text-align:center;margin-left:auto;margin-right:auto}

  /* About */
  .about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
  .about p{margin-bottom:16px}
  .about ul{list-style:none;margin-top:24px;display:grid;grid-template-columns:1fr 1fr;gap:12px 24px}
  .about li{position:relative;padding-left:28px;font-size:.95rem;font-weight:500;color:var(--ink)}
  .about li::before{content:"✓";position:absolute;left:0;top:0;color:var(--gold-dark);font-weight:700}
  .about-media{background:var(--ink);border-radius:var(--radius);aspect-ratio:4/3;
    display:grid;place-items:center;color:var(--gold);box-shadow:var(--shadow-lg)}
  .about-media .mark{font-family:'Playfair Display',serif;font-size:2rem;text-align:center;padding:20px}
  .about-media img{width:100%;height:100%;object-fit:contain;border-radius:var(--radius);display:block}

  /* Services */
  .services{background:var(--cream)}
  .card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
  .card-grid.two{grid-template-columns:repeat(2,1fr);max-width:780px;margin:0 auto;align-items:stretch}
  .card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
    padding:34px 30px;position:relative;box-shadow:var(--shadow);transition:.2s;display:flex;flex-direction:column}
  .card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
  .card.featured{border-color:var(--gold);border-width:2px}
  .badge{position:absolute;top:-12px;left:30px;background:var(--gold);color:var(--ink);
    font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
    padding:5px 12px;border-radius:20px}
  .card h3{font-size:1.4rem;margin-bottom:12px}
  .card .desc{color:var(--muted);font-size:.95rem;margin-bottom:20px}
  .card ul{list-style:none;margin-bottom:26px;display:grid;gap:10px}
  .card ul li{padding-left:24px;position:relative;font-size:.92rem}
  .card ul li::before{content:"›";position:absolute;left:6px;color:var(--gold-dark);font-weight:700}
  .card .btn{margin-top:auto;width:100%}

  /* Pricing */
  .price-amt{font-family:'Playfair Display',serif;font-size:2.6rem;font-weight:700;color:var(--ink);
    margin:8px 0 22px;display:flex;align-items:baseline;gap:6px;font-variant-numeric:lining-nums;font-feature-settings:"lnum" 1}
  .price-amt span{font-size:.95rem;font-weight:500;color:var(--muted);font-family:'Inter',sans-serif}
  .pricing-note{text-align:center;margin-top:36px;color:var(--muted);font-size:.95rem}
  .pricing-note a{color:var(--gold-dark);font-weight:600}

  /* Contact */
  .contact{background:var(--ink);color:var(--white)}
  .contact .eyebrow{color:var(--gold)}
  .contact-title{color:var(--white);font-size:clamp(1.9rem,3.6vw,2.7rem);margin:14px 0 14px}
  .contact-intro{color:rgba(255,255,255,.72);font-size:1.05rem;max-width:460px;margin-bottom:34px}
  .contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:50px;align-items:start}
  .info-row{display:flex;gap:16px;margin-bottom:24px;align-items:flex-start}
  .info-row .ico{width:44px;height:44px;border-radius:10px;background:rgba(212,168,87,.15);
    color:var(--gold);display:grid;place-items:center;flex:none;font-size:1.1rem}
  .info-row .lbl{font-size:.8rem;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.08em}
  .info-row .val{font-weight:600;font-size:1.02rem;color:var(--white)}
  .info-row .val a{color:var(--white)}
  .info-row .val a:hover{color:var(--gold)}
  .hours{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);
    border-radius:var(--radius);padding:24px;margin-top:30px}
  .hours h3{color:var(--white);font-size:1.1rem;margin-bottom:14px}
  .hours .row{display:flex;justify-content:space-between;font-size:.92rem;
    color:rgba(255,255,255,.8);padding:6px 0}
  .form{background:var(--white);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow-lg)}
  .form .field{margin-bottom:18px}
  .form label{display:block;font-size:.85rem;font-weight:600;color:var(--ink);margin-bottom:7px}
  .form input,.form textarea{width:100%;border:1.5px solid var(--line);border-radius:10px;
    padding:12px 14px;font-family:inherit;font-size:.95rem;color:var(--text);background:var(--cream);transition:.15s}
  .form input:focus,.form textarea:focus{outline:none;border-color:var(--gold);background:var(--white)}
  .form textarea{resize:vertical;min-height:110px}
  .form .btn{width:100%;margin-top:6px}
  .form .disclaimer{font-size:.8rem;color:var(--muted);text-align:center;margin-top:14px}
  .form-status{font-size:.9rem;text-align:center;margin-top:12px;font-weight:600;display:none}
  .form-status.show{display:block}
  .form-status.ok{color:#1c7c46}
  .form-status.err{color:#b3261e}

  /* Footer */
  footer{background:#0a0a0a;color:rgba(255,255,255,.7);padding:60px 0 26px}
  .foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;margin-bottom:40px}
  .foot-brand .brand{color:var(--white);margin-bottom:16px}
  .foot-brand p{font-size:.92rem;max-width:300px}
  footer h4{color:var(--white);font-size:.95rem;font-weight:600;margin-bottom:16px;
    font-family:'Inter',sans-serif}
  footer ul{list-style:none;display:grid;gap:10px}
  footer ul a,footer ul li{font-size:.9rem;color:rgba(255,255,255,.65);transition:.15s}
  footer ul a:hover{color:var(--gold)}
  .foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;
    display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:.85rem}
  .foot-bottom a{margin-left:20px;color:rgba(255,255,255,.6)}
  .foot-bottom .credit a{margin-left:0;color:var(--gold);font-weight:600}
  .foot-bottom a:hover{color:var(--gold)}

  /* ---------- RESPONSIVE ---------- */
  @media (max-width:980px){
    .nav-phone,.nav-ig{display:none}
    .nav-links{gap:20px}
    .nav-links a{font-size:.86rem}
    .feature-grid{grid-template-columns:repeat(2,1fr)}
    .about-grid,.contact-grid{grid-template-columns:1fr;gap:40px}
    .card-grid{grid-template-columns:1fr;max-width:460px;margin:0 auto}
    .card-grid.two{grid-template-columns:1fr;max-width:460px}
    .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
  }
  @media (max-width:680px){
    .nav-links{display:none}
    .nav-links.open{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;
      background:var(--white);border-bottom:1px solid var(--line);padding:18px 24px;gap:18px}
    .nav-cta{gap:8px}
    .nav-cta .btn{display:none}
    .burger{display:block}
    .pad{padding:56px 0}
    .feature-grid{grid-template-columns:1fr}
    .about ul{grid-template-columns:1fr}
    .stats{gap:36px}
    .hero-inner{padding:64px 0 56px}
    .foot-grid{grid-template-columns:1fr}
  }
  /* ---------- MOBILE CAROUSELS (Services / Pricing / Car Hire) ---------- */
  @media (max-width:680px){
    .card-grid,.card-grid.two{
      display:flex;
      max-width:none;
      margin:0;
      gap:14px;
      overflow-x:auto;
      scroll-snap-type:x mandatory;
      -webkit-overflow-scrolling:touch;
      padding-top:20px;
      padding-bottom:6px;
      scrollbar-width:none;
    }
    .card-grid::-webkit-scrollbar,.card-grid.two::-webkit-scrollbar{display:none}
    .card-grid>.card,.card-grid.two>.card{
      flex:0 0 92%;
      scroll-snap-align:center;
      max-width:none;
    }
  }

  @media (prefers-reduced-motion:reduce){
    *{transition:none!important;scroll-behavior:auto!important}
  }

  /* ============================================================
     V2 SUB-PAGES (shared) — added for the multi-page SEO build.
     Components: sub-page header, breadcrumb, prose/article body,
     blog grid + post cards, blog-post layout, lesson CTA band.
     Everything below is built on the tokens + card system above,
     so the new pages match index.html exactly. Mobile-safe.
     ============================================================ */

  /* Sub-page header — compact dark band, same language as the hero */
  .subhero{background:var(--ink);color:var(--white);text-align:center}
  .subhero-inner{padding:64px 0 56px;max-width:760px;margin:0 auto}
  .subhero .eyebrow{color:var(--gold)}
  .subhero h1{color:var(--white);font-size:clamp(2rem,4.5vw,3rem);margin-bottom:14px}
  .subhero p{color:rgba(255,255,255,.78);font-size:1.08rem;max-width:600px;margin:0 auto}

  /* Breadcrumb */
  .crumb{font-size:.85rem;color:var(--muted);margin-bottom:14px}
  .crumb a{color:var(--gold-dark);font-weight:600}
  .crumb .sep{margin:0 8px;color:var(--line)}

  /* Prose / article body — a readable column for legal + blog copy */
  .prose{max-width:720px;margin:0 auto}
  .prose h2{font-size:clamp(1.5rem,3vw,2rem);margin:38px 0 14px}
  .prose h2:first-child{margin-top:0}
  .prose h3{font-size:1.25rem;margin:28px 0 10px}
  .prose p{margin-bottom:16px;color:var(--text)}
  .prose ul,.prose ol{margin:0 0 18px 22px;display:grid;gap:8px}
  .prose li{color:var(--text)}
  .prose a{color:var(--gold-dark);font-weight:600;text-decoration:underline;text-underline-offset:2px}
  .prose .lead{font-size:1.15rem;color:var(--muted);margin-bottom:28px}
  .prose strong{color:var(--ink)}
  .legal-meta{font-size:.9rem;color:var(--muted);margin-bottom:32px;padding-bottom:20px;border-bottom:1px solid var(--line)}

  /* Blog landing grid */
  .blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
  .post-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
    overflow:hidden;box-shadow:var(--shadow);transition:.2s;display:flex;flex-direction:column}
  .post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
  .post-card .thumb{aspect-ratio:16/10;background:var(--cream);overflow:hidden}
  .post-card .thumb img{width:100%;height:100%;object-fit:cover;transition:.3s}
  .post-card:hover .thumb img{transform:scale(1.04)}
  .post-card .body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
  .post-card .tag{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
    color:var(--gold-dark);margin-bottom:10px}
  .post-card h3{font-size:1.22rem;line-height:1.25;margin-bottom:10px}
  .post-card p{font-size:.92rem;color:var(--muted);margin-bottom:18px;flex:1}
  .post-card .more{font-size:.9rem;font-weight:600;color:var(--ink);margin-top:auto}
  .post-card .more::after{content:" \2192";color:var(--gold-dark)}

  /* Blog-post header image */
  .post-hero-img{aspect-ratio:16/7;border-radius:var(--radius);overflow:hidden;
    margin-bottom:34px;box-shadow:var(--shadow)}
  .post-hero-img img{width:100%;height:100%;object-fit:cover}

  /* Lesson-page CTA band */
  .cta-band{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);
    padding:36px;text-align:center;margin-top:8px}
  .cta-band h3{font-size:1.5rem;margin-bottom:10px}
  .cta-band p{color:var(--muted);margin-bottom:22px;max-width:480px;margin-left:auto;margin-right:auto}

  /* Sub-page responsive */
  @media (max-width:980px){
    .blog-grid{grid-template-columns:repeat(2,1fr)}
  }
  @media (max-width:680px){
    .subhero-inner{padding:48px 0 44px}
    .blog-grid{grid-template-columns:1fr}
  }
