:root {
    --ink:#17130D;
    --espresso:#241B10;
    --charcoal:#2A2117;
    --gold:#E8A33D;
    --gold-deep:#C77D1E;
    --jungle:#1C5A46;
    --jungle-deep:#123F31;
    --sand:#EFE6D3;
    --bone:#FAF5EA;
    --line:rgba(239,230,211,.14);
    --shadow:0 24px 60px -20px rgba(0,0,0,.6);
    --wrap:1180px;
  }

  * { box-sizing:border-box; margin:0; padding:0; }
  html { scroll-behavior:smooth; }
  body {
    font-family:"Archivo",system-ui,sans-serif;
    background:var(--ink);
    color:var(--bone);
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  h1,h2,h3 { font-family:"Anton",sans-serif; font-weight:400; line-height:.98; letter-spacing:.01em; text-transform:uppercase; }
  a { color:inherit; text-decoration:none; }
  img { max-width:100%; display:block; }
  .wrap { width:min(var(--wrap),92vw); margin-inline:auto; }

  .eyebrow {
    font-size:.72rem; font-weight:700; letter-spacing:.28em; text-transform:uppercase;
    color:var(--gold); display:inline-flex; align-items:center; gap:.6em;
  }
  .eyebrow::before { content:""; width:26px; height:2px; background:var(--gold); display:inline-block; }

  /* Buttons */
  .btn {
    display:inline-flex; align-items:center; gap:.6em; font-weight:700;
    font-size:.95rem; letter-spacing:.02em; padding:.9em 1.5em; border-radius:2px;
    border:2px solid transparent; cursor:pointer; transition:transform .18s ease, background .18s ease, color .18s ease;
    text-transform:uppercase;
  }
  .btn-gold { background:var(--gold); color:var(--ink); }
  .btn-gold:hover { background:var(--bone); transform:translateY(-2px); }
  .btn-ghost { border-color:var(--line); color:var(--bone); }
  .btn-ghost:hover { border-color:var(--gold); color:var(--gold); transform:translateY(-2px); }
  .btn-jungle { background:var(--jungle); color:var(--bone); }
  .btn-jungle:hover { background:var(--jungle-deep); transform:translateY(-2px); }

  :focus-visible { outline:3px solid var(--gold); outline-offset:3px; }

  /* Header */
  header {
    position:sticky; top:0; z-index:50;
    background:rgba(23,19,13,.82); backdrop-filter:blur(10px);
    border-bottom:1px solid var(--line);
  }
  .nav { display:flex; align-items:center; justify-content:space-between; height:74px; }
  .brand { display:flex; align-items:center; gap:.6em; font-family:"Anton",sans-serif; font-size:1.5rem; text-transform:uppercase; letter-spacing:.02em; }
  .brand .mark { width:30px; height:30px; flex:none; }
  .brand b { color:var(--gold); font-weight:400; }
  .nav-links { display:flex; align-items:center; gap:2rem; }
  .nav-links a { font-weight:600; font-size:.9rem; letter-spacing:.03em; color:var(--sand); transition:color .15s; }
  .nav-links a:hover { color:var(--gold); }
  .nav-cta { display:flex; align-items:center; gap:1rem; }
  .menu-btn { display:none; background:none; border:1px solid var(--line); color:var(--bone); width:44px; height:40px; border-radius:2px; font-size:1.2rem; cursor:pointer; }

  /* Hero */
  .hero { position:relative; padding:clamp(3rem,7vw,6rem) 0 clamp(3rem,6vw,5rem); overflow:hidden; }
  .hero::after {
    content:""; position:absolute; inset:0; z-index:-1;
    background:
      radial-gradient(120% 90% at 80% 0%, rgba(28,90,70,.35), transparent 55%),
      radial-gradient(100% 80% at 0% 100%, rgba(199,125,30,.22), transparent 50%);
  }
  .hero-grid { display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(2rem,4vw,3.5rem); align-items:center; }
  .hero-svg { width:100%; height:auto; margin:1.2rem 0 1.4rem; }
  .hero p.lead { font-size:clamp(1.05rem,1.7vw,1.3rem); color:var(--sand); max-width:34ch; }
  .hero-actions { display:flex; flex-wrap:wrap; gap:1rem; margin-top:2rem; }
  .trust { display:flex; flex-wrap:wrap; gap:1.2rem 2rem; margin-top:2.6rem; padding-top:1.6rem; border-top:1px solid var(--line); }
  .trust span { font-size:.78rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--sand); opacity:.85; }
  .trust b { color:var(--gold); font-weight:700; }

  /* Photo placeholders */
  .photo {
    position:relative; border-radius:3px; overflow:hidden;
    background:linear-gradient(150deg,var(--charcoal),var(--espresso));
    border:1px solid var(--line); box-shadow:var(--shadow);
    display:flex; align-items:flex-end; min-height:420px;
  }
  .photo .tag {
    font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; font-weight:700;
    color:var(--sand); opacity:.75; padding:1rem 1.1rem; background:linear-gradient(transparent,rgba(0,0,0,.5));
    width:100%;
  }
  .photo .corner { position:absolute; top:14px; right:14px; width:44px; height:44px; opacity:.9; }

  /* Sections */
  section { padding:clamp(3.5rem,7vw,6rem) 0; }
  .section-head { max-width:52ch; margin-bottom:2.8rem; }
  .section-head h2 { font-size:clamp(2rem,4.4vw,3.4rem); margin:.6rem 0 .5rem; }
  .section-head p { color:var(--sand); opacity:.9; }

  /* Press band */
  .press { background:var(--jungle-deep); border-block:2px solid rgba(232,163,61,.35); padding:2.2rem 0; }
  .press .wrap { display:flex; align-items:center; justify-content:space-between; gap:1.5rem; flex-wrap:wrap; }
  .press .quote { display:flex; align-items:center; gap:1.2rem; }
  .press .live { font-family:"Anton"; font-size:1.1rem; color:var(--gold); border:2px solid var(--gold); padding:.35em .7em; letter-spacing:.05em; flex:none; }
  .press p { font-size:clamp(1rem,1.9vw,1.35rem); font-weight:600; color:var(--bone); }
  .press p b { color:var(--gold); }

  /* Services */
  .cards { display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; }
  .card {
    background:var(--espresso); border:1px solid var(--line); border-radius:4px; padding:1.6rem 1.5rem 1.5rem;
    display:flex; flex-direction:column; gap:.7rem; transition:transform .2s ease, border-color .2s ease;
    position:relative; overflow:hidden;
  }
  .card:hover { transform:translateY(-6px); border-color:rgba(232,163,61,.5); }
  .card .num { font-family:"Anton"; font-size:.95rem; color:var(--gold); letter-spacing:.1em; }
  .card h3 { font-size:1.35rem; }
  .card p { font-size:.92rem; color:var(--sand); opacity:.9; flex:1; }
  .card .price { font-weight:800; color:var(--gold); font-size:.9rem; letter-spacing:.02em; }
  .card a.more { font-weight:700; font-size:.85rem; letter-spacing:.03em; color:var(--bone); text-transform:uppercase; }
  .card a.more:hover { color:var(--gold); }

  /* Schedule */
  .sched-wrap { background:var(--espresso); border:1px solid var(--line); border-radius:4px; overflow:hidden; }
  .sched-row { display:grid; grid-template-columns:120px 160px 1fr 150px; gap:1rem; align-items:center; padding:1.05rem 1.5rem; border-top:1px solid var(--line); }
  .sched-row:first-child { border-top:none; background:var(--charcoal); }
  .sched-row .day { font-family:"Anton"; font-size:1.05rem; color:var(--gold); }
  .sched-row .time { font-weight:700; font-size:.9rem; letter-spacing:.02em; }
  .sched-row .class { font-weight:600; }
  .sched-row .kind { font-size:.72rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; justify-self:start; padding:.3em .7em; border-radius:2px; }
  .k-cycle { background:rgba(232,163,61,.16); color:var(--gold); }
  .k-inperson { background:rgba(28,90,70,.35); color:#7fd8bb; }
  .k-zoom { background:rgba(239,230,211,.12); color:var(--sand); }
  .sched-row.head span { font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; font-weight:700; color:var(--sand); opacity:.7; font-family:"Archivo"; }

  /* Store teaser */
  .store { background:linear-gradient(180deg,var(--ink),var(--espresso)); }
  .price-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; margin-bottom:1.6rem; }
  .price-item { border:1px solid var(--line); border-radius:4px; padding:1.3rem 1.4rem; background:rgba(0,0,0,.15); }
  .price-item .name { font-weight:700; letter-spacing:.02em; }
  .price-item .amt { font-family:"Anton"; font-size:1.8rem; color:var(--gold); margin-top:.3rem; }
  .price-item .amt small { font-family:"Archivo"; font-size:.7rem; font-weight:700; letter-spacing:.14em; color:var(--sand); opacity:.7; text-transform:uppercase; display:block; }
  .waiver { display:flex; align-items:center; gap:.8rem; font-size:.9rem; color:var(--sand); background:rgba(28,90,70,.18); border:1px solid rgba(28,90,70,.5); border-radius:3px; padding:.9rem 1.1rem; margin-bottom:1.6rem; }
  .waiver b { color:var(--gold); }

  /* About */
  .about-grid { display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(2rem,4vw,3.5rem); align-items:center; }
  .creds { display:flex; flex-wrap:wrap; gap:.6rem; margin-top:1.4rem; }
  .creds li { list-style:none; font-size:.78rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--sand); border:1px solid var(--line); border-radius:2px; padding:.5em .8em; }

  /* Retreats */
  .retreat { background:var(--jungle); position:relative; overflow:hidden; }
  .retreat .wrap { display:flex; align-items:center; justify-content:space-between; gap:2rem; flex-wrap:wrap; }
  .retreat h2 { font-size:clamp(1.8rem,4vw,2.8rem); color:var(--bone); max-width:20ch; }
  .retreat p { color:var(--sand); max-width:40ch; margin-top:.6rem; }

  /* Testimonials */
  .quotes { display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
  .quote-card { border:1px solid var(--line); border-radius:4px; padding:1.6rem; background:var(--espresso); }
  .quote-card .stars { color:var(--gold); letter-spacing:.15em; margin-bottom:.7rem; }
  .quote-card p { font-size:1rem; color:var(--bone); }
  .quote-card cite { display:block; margin-top:1rem; font-style:normal; font-weight:700; font-size:.85rem; color:var(--gold); letter-spacing:.03em; }
  .placeholder-note { font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--sand); opacity:.55; margin-top:1rem; }

  /* Final CTA */
  .final { text-align:center; background:radial-gradient(120% 100% at 50% 0%, rgba(199,125,30,.25), transparent 60%); }
  .final h2 { font-size:clamp(2.4rem,6vw,4.6rem); }
  .final p { color:var(--sand); font-size:1.1rem; margin:1rem auto 2rem; max-width:44ch; }
  .final .contact { display:flex; gap:2rem; justify-content:center; flex-wrap:wrap; margin-top:2.4rem; font-weight:700; letter-spacing:.03em; }
  .final .contact a { color:var(--gold); }

  /* Footer */
  footer { border-top:1px solid var(--line); padding:3rem 0 2rem; background:var(--espresso); }
  .foot-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:2rem; margin-bottom:2rem; }
  footer h4 { font-family:"Archivo"; font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-bottom:1rem; }
  footer a, footer p { color:var(--sand); font-size:.92rem; opacity:.9; }
  footer a:hover { color:var(--gold); }
  footer li { list-style:none; margin-bottom:.5rem; }
  .foot-bottom { border-top:1px solid var(--line); padding-top:1.4rem; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.8rem; color:var(--sand); opacity:.7; }

  /* Leopard band */
  .leopard-band { position:relative; padding:clamp(3.5rem,7vw,6rem) 0; background:linear-gradient(160deg,var(--ink),var(--espresso)); overflow:hidden; }
  .leopard-band::after { content:""; position:absolute; inset:0; z-index:0; background:radial-gradient(90% 120% at 100% 50%, rgba(199,125,30,.20), transparent 55%); }
  .leopard-band .wrap { position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,4vw,3.5rem); align-items:center; }
  .leopard-band h2 { font-size:clamp(2.2rem,5vw,3.8rem); margin:.6rem 0 1rem; }
  .leopard-band h2 b { color:var(--gold); font-weight:400; }
  .leopard-band p { color:var(--sand); max-width:38ch; }
  .leopard-panel { position:relative; border:2px solid rgba(232,163,61,.5); border-radius:4px; overflow:hidden; min-height:380px; box-shadow:var(--shadow); background:var(--charcoal); }
  .leopard-panel .print { position:absolute; inset:0; width:100%; height:100%; }
  .leopard-panel .scrim { position:absolute; inset:0; background:linear-gradient(200deg, rgba(23,19,13,.10), rgba(23,19,13,.72)); }
  .leopard-panel .head { position:absolute; top:16px; left:16px; width:48px; height:48px; z-index:2; filter:drop-shadow(0 2px 6px rgba(0,0,0,.5)); }
  .leopard-panel .tag {
    position:absolute; bottom:0; left:0; right:0; z-index:2;
    font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; font-weight:700;
    color:var(--sand); opacity:.9; padding:1rem 1.1rem;
  }

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

  @media (max-width:900px){
    .nav-links { display:none; }
    .menu-btn { display:block; }
    .nav-links.open { display:flex; position:absolute; top:74px; left:0; right:0; flex-direction:column; gap:1.2rem; padding:1.5rem 4vw; background:var(--ink); border-bottom:1px solid var(--line); }
    .hero-grid, .about-grid, .leopard-band .wrap { grid-template-columns:1fr; }
    .hero .photo { min-height:300px; }
    .cards, .price-grid, .quotes { grid-template-columns:1fr; }
    .sched-row { grid-template-columns:90px 1fr; column-gap:1rem; row-gap:.35rem; }
    .sched-row.head { display:none; }
  }
  @media (prefers-reduced-motion:reduce){
    * { scroll-behavior:auto !important; }
    .reveal { opacity:1; transform:none; transition:none; }
    .btn:hover, .card:hover { transform:none; }
  }

/* ============ Inner pages ============ */
.page-hero { position:relative; padding:clamp(3rem,6vw,5rem) 0 clamp(2rem,4vw,3rem); overflow:hidden; border-bottom:1px solid var(--line); }
.page-hero::after { content:""; position:absolute; inset:0; z-index:-1; background:radial-gradient(90% 120% at 20% 0%, rgba(199,125,30,.18), transparent 55%); }
.page-hero h1 { font-family:"Anton",sans-serif; font-weight:400; text-transform:uppercase; line-height:.98; font-size:clamp(2.6rem,7vw,5rem); }
.page-hero h1 b { color:var(--gold); font-weight:400; }
.page-hero p { color:var(--sand); max-width:54ch; margin-top:1rem; font-size:1.1rem; }

/* Store */
.store-layout { display:grid; grid-template-columns:1fr 360px; gap:2.5rem; align-items:start; }
.product-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1.2rem; }
.product { background:var(--espresso); border:1px solid var(--line); border-radius:4px; overflow:hidden; display:flex; flex-direction:column; }
.product .pimg { min-height:150px; background:linear-gradient(150deg,var(--charcoal),var(--espresso)); position:relative; display:flex; align-items:flex-end; border-bottom:1px solid var(--line); }
.product .pimg .tag { font-size:.64rem; letter-spacing:.12em; text-transform:uppercase; font-weight:700; color:var(--sand); opacity:.55; padding:.7rem .9rem; }
.product .pbody { padding:1.3rem; display:flex; flex-direction:column; gap:.5rem; flex:1; }
.product h3 { font-size:1.3rem; }
.product .desc { font-size:.88rem; color:var(--sand); opacity:.9; flex:1; }
.product .prow { display:flex; align-items:center; justify-content:space-between; margin-top:.7rem; gap:1rem; }
.product .price { font-family:"Anton"; color:var(--gold); font-size:1.5rem; line-height:1; }
.product .price small { font-family:"Archivo"; font-size:.6rem; font-weight:700; letter-spacing:.12em; color:var(--sand); opacity:.7; text-transform:uppercase; display:block; margin-top:.2rem; }

/* Cart */
.cart { position:sticky; top:96px; background:var(--espresso); border:1px solid var(--line); border-radius:4px; padding:1.5rem; }
.cart h3 { font-size:1.4rem; margin-bottom:1rem; }
.cart-empty { color:var(--sand); opacity:.7; font-size:.9rem; padding:.5rem 0 1rem; }
.cart-items { display:flex; flex-direction:column; gap:.9rem; }
.cart-item { display:flex; flex-wrap:wrap; gap:.4rem .8rem; align-items:center; justify-content:space-between; padding-bottom:.9rem; border-bottom:1px solid var(--line); }
.cart-item .ci-name { font-weight:600; font-size:.92rem; flex:1 1 100%; }
.cart-item .ci-price { color:var(--gold); font-weight:700; font-size:.9rem; }
.qty { display:inline-flex; align-items:center; border:1px solid var(--line); border-radius:2px; }
.qty button { background:none; border:none; color:var(--bone); width:28px; height:28px; cursor:pointer; font-size:1rem; line-height:1; }
.qty button:hover { color:var(--gold); }
.qty span { min-width:26px; text-align:center; font-weight:700; font-size:.9rem; }
.ci-remove { background:none; border:none; color:var(--sand); opacity:.55; cursor:pointer; font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; }
.ci-remove:hover { color:var(--gold); opacity:1; }
.cart-total { display:flex; justify-content:space-between; align-items:baseline; margin:1rem 0; padding-top:1rem; border-top:1px solid var(--line); }
.cart-total .lbl { font-weight:700; letter-spacing:.08em; text-transform:uppercase; font-size:.8rem; color:var(--sand); }
.cart-total .amt { font-family:"Anton"; color:var(--gold); font-size:1.8rem; }
.waiver-check { display:flex; gap:.6rem; align-items:flex-start; font-size:.82rem; color:var(--sand); margin-bottom:1rem; line-height:1.45; }
.waiver-check input { margin-top:.2rem; accent-color:var(--gold); width:16px; height:16px; flex:none; }
.waiver-check a { color:var(--gold); text-decoration:underline; }
.btn[disabled] { opacity:.4; cursor:not-allowed; transform:none; }
.btn.block { width:100%; justify-content:center; }
.note { font-size:.74rem; color:var(--sand); opacity:.6; margin-top:.8rem; text-align:center; line-height:1.5; }

/* Generic content */
.split { display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,4vw,3.5rem); align-items:center; }
.prose p { color:var(--sand); margin-bottom:1rem; }
.prose p:last-child { margin-bottom:0; }
.feature-list { display:flex; flex-direction:column; gap:1.4rem; margin-top:1.6rem; }
.feature { display:grid; grid-template-columns:auto 1fr; gap:1.1rem; align-items:start; }
.feature .fnum { font-family:"Anton"; color:var(--gold); font-size:1.5rem; line-height:1; }
.feature h3 { font-size:1.25rem; margin-bottom:.3rem; }
.feature p { color:var(--sand); font-size:.92rem; }

@media (max-width:900px){
  .store-layout { grid-template-columns:1fr; }
  .product-grid { grid-template-columns:1fr; }
  .cart { position:static; }
  .split { grid-template-columns:1fr; }
}

/* ============ Real images in photo panels ============ */
.photo img.pfill { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.photo .corner { z-index:2; }
.leopard-panel img.print { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; filter:contrast(1.04) saturate(1.15) sepia(.16); }
.leopard-panel .scrim { z-index:1; }
.leopard-panel .head { z-index:2; }
