/* ========================================================
   Nalu Wellness — shared design system
   Direction A v3 (Coastal Hawaiian × Brooke's existing palette)
======================================================== */

:root{
  --shore:      #ede7d8;
  --mist:       #c5d3da;
  --mist-deep:  #4d6168;   /* AA-passing label/eyebrow color (5.28:1 on shore) */
  --mist-grad:  #9eb1bb;   /* original light tone — for decorative gradient backgrounds only */
  --ocean:      #2a4a5b;
  --sunset:     #9c4d2c;   /* AA-passing accent text (4.85:1 on shore) */
  --sunset-glow:#d97757;   /* original warm tone — for glows and large bg accents */
  --sunset-d:   #8e4a2a;   /* even darker for body-size copy */
  --clay-soft:  #e8a991;   /* lifted accent for text on dark bg (4.72:1 on ocean) */
  --plum:       #6b2e3a;
  --foam:       #d6e1d9;
  --sand:       #efe1c8;
  --ink:        #1d2a33;

  --serif:    'Lora', Georgia, serif;
  --sans:     'Outfit', system-ui, sans-serif;
  --col-pad:  clamp(20px, 4vw, 56px);
  --section:  clamp(80px, 11vw, 140px);
  --easing:   cubic-bezier(.2, .6, .2, 1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html, body{
  margin:0;padding:0;
  background:var(--shore);
  color:var(--ocean);
  font-family:var(--sans);
  font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit}
::selection{background:var(--sunset);color:var(--shore)}
*:focus-visible{outline:2px solid var(--ocean);outline-offset:3px;border-radius:2px}

img{max-width:100%;display:block}

/* ============== CUSTOM CURSOR ============== */
@media (hover:hover) and (pointer:fine){
  body{cursor:none}
  .cursor-dot, .cursor-ring{
    position:fixed;top:0;left:0;
    pointer-events:none;z-index:9999;
    border-radius:50%;
    transform:translate(-50%,-50%);
    mix-blend-mode:multiply;
  }
  .cursor-dot{
    width:8px;height:8px;background:var(--plum);
    transition:transform .15s var(--easing), opacity .2s, width .2s, height .2s, background .2s;
  }
  .cursor-ring{
    width:36px;height:36px;
    border:1px solid rgba(42,74,91,.5);
    transition:transform .35s var(--easing), width .25s var(--easing), height .25s var(--easing), border-color .25s, opacity .2s;
  }
  body.hovering-cta .cursor-dot{width:64px;height:64px;background:var(--sunset)}
  body.hovering-cta .cursor-ring{opacity:0}
  body.hovering-link .cursor-dot{width:18px;height:18px;background:var(--sunset)}
}
@media (hover:none){.cursor-dot,.cursor-ring{display:none}}

.scroll-bar{position:fixed;top:0;left:0;height:2px;background:var(--sunset);width:0;z-index:1000;transition:width .12s linear}

/* ============== TYPOGRAPHY ============== */
h1, h2, h3, .display{font-family:var(--serif);font-weight:500;letter-spacing:-.018em;line-height:1;margin:0}
.ital{font-style:italic;font-weight:500}
.eyebrow{font-family:var(--sans);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--ocean);font-weight:500}

/* ============== HEADER ============== */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ocean);color:var(--shore);padding:12px 20px;z-index:1000;text-decoration:none;font-size:14px;letter-spacing:.04em}
.skip-link:focus{left:0;top:0}

header.site{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:24px var(--col-pad);
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px;
  background:rgba(237,231,216,.65);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  transition:background .4s var(--easing), padding .4s var(--easing);
}
body.scrolled header.site{padding:14px var(--col-pad);background:rgba(237,231,216,.92)}
.logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--ocean)}
.logo .mark{width:30px;height:30px}
.logo .word{font-family:var(--serif);font-size:22px;letter-spacing:.04em;line-height:1}
.logo .sub{display:block;font-family:var(--sans);font-size:9px;letter-spacing:.32em;text-transform:uppercase;color:var(--mist-deep);margin-top:4px}
nav.menu ul{display:flex;gap:36px;list-style:none;margin:0;padding:0;font-size:13px;letter-spacing:.06em;justify-self:center}
nav.menu a{text-decoration:none;color:var(--ocean);position:relative;padding:6px 0}
nav.menu a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:currentColor;transform-origin:right;transform:scaleX(0);transition:transform .35s var(--easing)}
nav.menu a:hover::after{transform-origin:left;transform:scaleX(1)}
nav.menu a[aria-current="page"]::after{transform:scaleX(1)}
.header-cta{justify-self:end}

.btn{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--ocean);color:var(--shore);
  text-decoration:none;font-size:13px;font-weight:500;letter-spacing:.06em;
  padding:14px 26px;border-radius:999px;
  transition:transform .35s var(--easing), background .25s, box-shadow .35s;
  border:1px solid var(--ocean);position:relative;cursor:pointer;
}
.btn:hover{background:var(--plum);border-color:var(--plum);transform:translateY(-1px);box-shadow:0 12px 32px -16px rgba(107,46,58,.5)}
.btn .arrow{display:inline-block;transition:transform .35s var(--easing)}
.btn:hover .arrow{transform:translateX(4px)}
.btn.outline{background:transparent;color:var(--ocean)}
.btn.outline:hover{background:var(--ocean);color:var(--shore)}
.btn.warm{background:var(--sunset);border-color:var(--sunset);color:var(--shore)}
.btn.warm:hover{background:var(--plum);border-color:var(--plum)}
.btn.paper{background:var(--shore);color:var(--plum);border-color:var(--shore)}
.btn.paper:hover{background:var(--sunset);border-color:var(--sunset);color:var(--shore)}

/* ============== MOBILE NAV ============== */
.menu-toggle{display:none;background:none;border:1px solid var(--ocean);border-radius:999px;width:44px;height:44px;cursor:pointer;align-items:center;justify-content:center;color:var(--ocean);transition:background .2s,color .2s}
.menu-toggle:hover{background:var(--ocean);color:var(--shore)}
.menu-toggle svg{width:20px;height:20px}
.menu-toggle .close-icon{display:none}
.menu-toggle[aria-expanded="true"] .open-icon{display:none}
.menu-toggle[aria-expanded="true"] .close-icon{display:inline}

.mobile-drawer{position:fixed;inset:0;background:var(--shore);z-index:200;display:none;flex-direction:column;padding:80px 32px 32px;overflow-y:auto}
.mobile-drawer[data-open="true"]{display:flex}
.mobile-drawer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.mobile-drawer li a{display:block;font-family:var(--serif);font-style:italic;font-size:32px;line-height:1.2;color:var(--plum);text-decoration:none;padding:14px 0;border-bottom:1px solid rgba(42,74,91,.18)}
.mobile-drawer li a:hover{color:var(--sunset)}
.mobile-drawer .drawer-cta{margin-top:32px}
.mobile-drawer .drawer-meta{margin-top:auto;padding-top:32px;font-size:13px;color:var(--ocean);border-top:1px solid rgba(42,74,91,.18)}

@media (max-width:780px){
  nav.menu{display:none}
  header.site{grid-template-columns:1fr auto;gap:14px}
  .header-cta{display:none}
  .menu-toggle{display:inline-flex}
  body[data-drawer-open="true"]{overflow:hidden}
}

/* ============== SECTION SHELL ============== */
section.s, .s{padding:var(--section) var(--col-pad);position:relative}
.container{max-width:1280px;margin:0 auto}
.s-head{display:grid;grid-template-columns:auto 1fr;gap:32px 56px;align-items:start;margin-bottom:64px;padding-bottom:32px;border-bottom:1px solid rgba(42,74,91,.18)}
.s-head .marker{display:flex;flex-direction:column;gap:6px;padding-top:8px}
.s-head .marker .num{font-family:var(--serif);font-style:italic;font-weight:500;font-size:48px;line-height:.9;color:var(--sunset)}
.s-head .marker .lbl{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--mist-deep);font-weight:500}
h2.s-h{font-family:var(--serif);font-weight:500;font-size:clamp(34px,5vw,64px);line-height:1.04;letter-spacing:-.022em;color:var(--ocean);max-width:22ch}
h2.s-h .ital{font-style:italic;color:var(--plum);font-weight:500}
h2.s-h .accent{color:var(--sunset)}
.lede{font-size:clamp(17px,1.6vw,19px);line-height:1.55;color:var(--ocean);opacity:.85;max-width:60ch}

@media (max-width:780px){
  .s-head{grid-template-columns:1fr;gap:18px;margin-bottom:48px}
  .s-head .marker{flex-direction:row;align-items:baseline;gap:14px}
  .s-head .marker .num{font-size:34px}
}

/* ============== PHOTO SLOTS — fall back to gradient ============== */
.photo{
  position:relative;overflow:hidden;border-radius:4px;
  background:
    radial-gradient(circle at 30% 30%, rgba(217,119,87,.4), transparent 50%),
    linear-gradient(160deg, var(--mist) 0%, var(--mist-grad) 100%);
  background-size:cover;background-position:center;
  box-shadow:0 30px 60px -40px rgba(42,74,91,.4);
}
.photo[data-src]{background-image:var(--bg-image, none), radial-gradient(circle at 30% 30%, rgba(217,119,87,.4), transparent 50%), linear-gradient(160deg, var(--mist) 0%, var(--mist-grad) 100%)}
.photo .caption{
  position:absolute;left:24px;bottom:24px;right:24px;
  font-family:var(--serif);font-style:italic;font-size:13px;
  color:var(--shore);
  text-shadow:0 1px 8px rgba(0,0,0,.4);
}
.photo[data-src=""]::before, .photo:not([style*="background-image"])::before{
  content:attr(data-placeholder);
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;text-align:center;
  font-family:var(--serif);font-style:italic;
  color:rgba(255,255,255,.5);font-size:13px;padding:24px;
  pointer-events:none;
}

/* ============== FOOTER ============== */
footer{background:var(--ink);color:rgba(237,231,216,.7);padding:64px var(--col-pad) 36px;font-size:13px}
footer .container{display:grid;grid-template-columns:1fr;gap:36px;padding-bottom:48px;border-bottom:1px solid rgba(237,231,216,.1)}
@media (min-width:780px){footer .container{grid-template-columns:1.5fr 1fr 1fr 1fr 1fr}}
footer h4{font-family:var(--sans);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:rgba(237,231,216,.5);font-weight:500;margin:0 0 16px}
footer ul{list-style:none;margin:0;padding:0}
footer li{margin:8px 0}
footer a{color:rgba(237,231,216,.82);text-decoration:none;transition:color .2s}
footer a:hover{color:var(--sunset)}
footer .brand{display:flex;flex-direction:column;gap:14px}
footer .brand .logoline{font-family:var(--serif);font-size:24px;color:var(--shore)}
footer .brand .tag{font-family:var(--serif);font-style:italic;color:var(--sunset)}
footer .legal{max-width:1280px;margin:36px auto 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(237,231,216,.55)}
footer .legal a{color:rgba(237,231,216,.45);text-decoration:none;transition:color .2s}
footer .legal a:hover{color:var(--sunset)}
.disclaimer-strip{background:var(--shore);padding:28px var(--col-pad);border-top:1px solid rgba(42,74,91,.1)}
.disclaimer-note{font-size:13px;color:rgba(42,74,91,.42);line-height:1.7;font-style:italic;margin:0;max-width:92ch}
.testimonial-disclaimer{font-size:12px;color:rgba(42,74,91,.32);letter-spacing:.04em;margin-top:10px;font-style:italic}
.legal-prose{max-width:760px;margin:0 auto}
.legal-prose h2{font-family:var(--serif);font-size:clamp(24px,2.8vw,32px);color:var(--ocean);margin:48px 0 14px;padding-bottom:12px;border-bottom:1px solid rgba(42,74,91,.15)}
.legal-prose h3{font-family:var(--serif);font-size:20px;color:var(--plum);margin:28px 0 10px}
.legal-prose p,.legal-prose li{font-size:16px;color:rgba(42,74,91,.88);line-height:1.8;margin:0 0 14px}
.legal-prose ul{padding-left:22px;margin:0 0 16px}
.legal-prose ul li{margin:6px 0}
.legal-prose a{color:var(--sunset);text-decoration:none;border-bottom:1px solid rgba(217,119,87,.35)}
.legal-prose a:hover{opacity:.75}
.legal-prose .updated{font-size:13px;color:var(--mist-deep);letter-spacing:.08em;font-style:italic;margin:0 0 48px;display:block}
.legal-notice-box{background:rgba(42,74,91,.05);border-left:3px solid var(--sunset);border-radius:0 4px 4px 0;padding:20px 24px;margin:24px 0}
.legal-notice-box p{margin:0;font-size:15px}

/* ============== REVEAL ============== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s var(--easing), transform 1s var(--easing)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ============== REDUCED MOTION ============== */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  body{cursor:auto !important}
  .cursor-dot,.cursor-ring{display:none}
  .reveal{opacity:1;transform:none}
}

/* ============== SUB-PAGE HERO ============== */
.subhero{
  position:relative;padding:160px var(--col-pad) clamp(80px, 11vw, 130px);
  background:
    radial-gradient(circle at 78% 28%, rgba(217,119,87,.22), transparent 38%),
    linear-gradient(180deg, var(--mist) 0%, var(--shore) 100%);
  overflow:hidden;
}
.subhero .container{position:relative;z-index:2;max-width:1280px}
.subhero .crumbs{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--mist-deep);font-weight:500;margin-bottom:24px}
.subhero .crumbs a{color:var(--mist-deep);text-decoration:none}
.subhero .crumbs a:hover{color:var(--sunset)}
.subhero .crumbs span{margin:0 12px;color:var(--mist-deep);opacity:.5}
.subhero h1{font-family:var(--serif);font-weight:500;font-size:clamp(42px, 7vw, 84px);line-height:1.02;letter-spacing:-.025em;color:var(--plum);max-width:18ch}
.subhero h1 .ital{font-style:italic;color:var(--ocean)}
.subhero .lede{margin-top:32px;font-size:18px;color:var(--ocean);max-width:48ch}

/* ============== FLOATING CTAs (Book + Thorne) ============== */
.floating-cta{
  position:fixed;right:clamp(16px,2.4vw,28px);bottom:clamp(16px,2.4vw,28px);
  z-index:90;display:flex;flex-direction:column;gap:10px;align-items:flex-end;
  pointer-events:none;opacity:0;transform:translateY(16px);
  transition:opacity .5s var(--easing), transform .5s var(--easing);
}
.floating-cta[data-visible="true"]{opacity:1;transform:translateY(0);pointer-events:auto}
.floating-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 22px;border-radius:999px;
  text-decoration:none;font-family:var(--sans);font-size:13px;
  letter-spacing:.06em;font-weight:500;white-space:nowrap;
  box-shadow:0 12px 32px -10px rgba(28,24,19,.35), 0 2px 6px -2px rgba(28,24,19,.18);
  transition:transform .25s var(--easing), box-shadow .25s var(--easing), background .25s;
  border:1px solid transparent;cursor:pointer;
}
.floating-btn:hover{transform:translateY(-2px);box-shadow:0 16px 40px -12px rgba(28,24,19,.4), 0 4px 8px -2px rgba(28,24,19,.22)}
.floating-btn--book{background:var(--sunset-glow);color:var(--shore);border-color:var(--sunset-glow)}
.floating-btn--book:hover{background:var(--plum);border-color:var(--plum)}
.floating-btn--book .arrow{display:inline-block;transition:transform .3s}
.floating-btn--book:hover .arrow{transform:translateX(3px)}
.floating-btn--thorne{
  background:rgba(255,255,255,.96);color:var(--ocean);
  border-color:var(--rule-soft);font-size:12px;padding:10px 16px;
  backdrop-filter:blur(8px);
}
.floating-btn--thorne:hover{background:#fff;border-color:var(--sunset)}
.floating-btn--thorne strong{color:var(--sunset);font-weight:600;letter-spacing:.08em;font-size:11px}
.floating-btn--thorne .sep{color:var(--rule);margin:0 4px;font-weight:300}
.floating-btn--thorne .label{font-family:var(--serif);font-style:italic;font-weight:500;font-size:14px;letter-spacing:.02em}
@media (max-width:600px){
  .floating-cta{right:14px;bottom:14px;gap:8px}
  .floating-btn{padding:12px 18px;font-size:12px}
  .floating-btn--thorne{padding:8px 14px;font-size:11px}
  .floating-btn--thorne .label{font-size:12px}
}
@media (prefers-reduced-motion: reduce){
  .floating-cta{transition:opacity .01ms !important; transform:none !important}
}

/* ============== CTA STRIP (shared) ============== */
.cta-strip{
  background:var(--plum);color:var(--shore);
  padding:clamp(80px, 11vw, 130px) var(--col-pad);
  text-align:center;position:relative;overflow:hidden;
}
.cta-strip::before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;right:-200px;bottom:-200px;background:radial-gradient(circle, rgba(217,119,87,.4), transparent 70%);z-index:0}
.cta-strip .inner{position:relative;z-index:2;max-width:900px;margin:0 auto}
.cta-strip .tag{font-family:var(--serif);font-style:italic;font-size:16px;color:var(--clay-soft);margin-bottom:24px}
.cta-strip h2{font-family:var(--serif);font-weight:500;font-size:clamp(40px,6.5vw,88px);line-height:1;letter-spacing:-.025em;color:var(--shore)}
.cta-strip h2 .ital{font-style:italic;color:var(--clay-soft)}
.cta-strip p{font-size:16px;color:rgba(237,231,216,.78);margin:24px auto 36px;max-width:38ch}
