/* =========================================================
   ZEN THERAPY & WELLNESS — Tropical Luxe Design System
   Ocho Rios, Jamaica
   ========================================================= */

/* ---------- Design Tokens ---------- */
:root {
  /* Palette */
  --emerald-900: #0c2c22;
  --emerald-800: #103a2c;
  --emerald-700: #14503b;
  --emerald-600: #1d6b4f;
  --sage-400:    #8ba888;
  --sage-200:    #cdddc9;

  --sand-50:     #faf6ef;
  --sand-100:    #f5efe6;
  --sand-200:    #ece3d4;
  --sand-300:    #ddcfb8;

  --gold-600:    #b88a36;
  --gold-500:    #c9a24b;
  --gold-400:    #d8b86e;

  --ink-900:     #14130f;
  --ink-700:     #2c2a24;
  --ink-500:     #5d584d;
  --ink-300:     #8d8678;

  --white:       #ffffff;

  /* Semantic */
  --bg:          var(--sand-50);
  --bg-alt:      var(--sand-100);
  --bg-dark:     var(--emerald-900);
  --text:        var(--ink-700);
  --text-soft:   var(--ink-500);
  --heading:     var(--emerald-800);
  --accent:      var(--gold-500);
  --accent-deep: var(--gold-600);

  /* Type */
  --font-display: "Cormorant Garamond", Georgia, serif;
  --font-body: "Jost", "Helvetica Neue", Arial, sans-serif;

  /* Spacing / layout */
  --maxw: 1240px;
  --gutter: clamp(1.25rem, 4vw, 4rem);
  --radius: 18px;
  --radius-lg: 28px;
  --shadow-sm: 0 4px 18px rgba(12, 44, 34, 0.08);
  --shadow-md: 0 18px 50px rgba(12, 44, 34, 0.14);
  --shadow-gold: 0 14px 40px rgba(184, 138, 54, 0.28);

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  color: var(--text);
  background: var(--bg);
  line-height: 1.72;
  font-weight: 300;
  overflow-x: hidden;
  font-size: 18px;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }

/* ---------- Typography ---------- */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  color: var(--heading);
  font-weight: 700;
  line-height: 1.03;
  letter-spacing: -0.6px;
}
h1 { font-size: clamp(3.2rem, 8.2vw, 6.4rem); }
h2 { font-size: clamp(2.4rem, 5.6vw, 4.3rem); }
h3 { font-size: clamp(1.65rem, 3.2vw, 2.5rem); letter-spacing: -0.3px; }
h4 { letter-spacing: -0.2px; }
p { color: var(--text-soft); }

.eyebrow {
  font-family: var(--font-body);
  text-transform: uppercase;
  letter-spacing: 3px;
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--accent-deep);
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
}
.eyebrow::before {
  content: "";
  width: 30px; height: 1px;
  background: var(--accent);
  display: inline-block;
}
.script {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--accent-deep);
  font-weight: 500;
}

/* ---------- Layout helpers ---------- */
.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: clamp(4.5rem, 10vw, 8rem); }
.section--dark { background: var(--bg-dark); color: var(--sand-100); }
.section--dark h1, .section--dark h2, .section--dark h3 { color: var(--sand-50); }
.section--dark p { color: var(--sage-200); }
.section--alt { background: var(--bg-alt); }
.center { text-align: center; }
.section-head { max-width: 640px; margin-bottom: 3.5rem; }
.section-head.center { margin-inline: auto; }
.section-head h2 { margin: 0.8rem 0 1rem; }
.lead { font-size: 1.26rem; line-height: 1.65; color: var(--text-soft); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.6rem;
  padding: 1rem 2.1rem;
  border-radius: 100px;
  font-weight: 500;
  font-size: 0.92rem;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  transition: transform .4s var(--ease), box-shadow .4s var(--ease), background .3s, color .3s;
  will-change: transform;
}
.btn--primary { background: var(--accent); color: var(--emerald-900); box-shadow: var(--shadow-gold); }
.btn--primary:hover { transform: translateY(-3px); background: var(--gold-400); box-shadow: 0 20px 48px rgba(184,138,54,.4); }
.btn--dark { background: var(--emerald-700); color: var(--sand-50); }
.btn--dark:hover { transform: translateY(-3px); background: var(--emerald-600); box-shadow: var(--shadow-md); }
.btn--ghost { border: 1px solid currentColor; color: var(--emerald-700); }
.btn--ghost:hover { background: var(--emerald-700); color: var(--sand-50); transform: translateY(-3px); }
.section--dark .btn--ghost { color: var(--sand-100); }
.section--dark .btn--ghost:hover { background: var(--sand-50); color: var(--emerald-900); }
.btn--lg { padding: 1.15rem 2.6rem; font-size: 1rem; }
.btn--block { width: 100%; }

/* ---------- Header / Nav ---------- */
.site-header {
  position: fixed; inset: 0 0 auto 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.1rem var(--gutter);
  transition: background .4s var(--ease), padding .4s var(--ease), box-shadow .4s;
}
.site-header.scrolled {
  background: rgba(250, 246, 239, 0.88);
  backdrop-filter: blur(14px);
  box-shadow: var(--shadow-sm);
  padding-block: 0.7rem;
}
.brand { display: flex; align-items: center; gap: 0.7rem; z-index: 110; }
.brand__mark {
  width: 42px; height: 42px; border-radius: 50%;
  display: grid; place-items: center;
  background: var(--emerald-800); color: var(--gold-400);
  font-family: var(--font-display); font-weight: 700; font-size: 1.25rem;
  border: 1px solid var(--gold-500);
}
.brand__name { font-family: var(--font-display); font-size: 1.35rem; font-weight: 600; color: var(--emerald-800); line-height: 1; }
.brand__name small { display: block; font-family: var(--font-body); font-size: 0.6rem; letter-spacing: 3px; text-transform: uppercase; color: var(--accent-deep); margin-top: 3px; }
.site-header:not(.scrolled) .nav__links a { color: var(--sand-50); }
.site-header:not(.scrolled).on-light .nav__links a { color: var(--emerald-800); }
.site-header:not(.scrolled):not(.on-light) .brand__name { color: var(--sand-50); }
.site-header:not(.scrolled):not(.on-light) .brand__name small { color: var(--gold-400); }

.nav { display: flex; align-items: center; gap: 2.2rem; }
.nav__links { display: flex; gap: 2rem; }
.nav__links a { font-size: 0.86rem; letter-spacing: 1px; text-transform: uppercase; font-weight: 400; position: relative; transition: color .3s; }
.nav__links a::after { content: ""; position: absolute; left: 0; bottom: -6px; width: 0; height: 1px; background: var(--accent); transition: width .35s var(--ease); }
.nav__links a:hover::after, .nav__links a.active::after { width: 100%; }
.nav__links a.active { color: var(--accent-deep); }

.nav__toggle { display: none; flex-direction: column; gap: 5px; z-index: 110; width: 30px; }
.nav__toggle span { height: 2px; background: currentColor; border-radius: 2px; transition: transform .3s, opacity .3s; }
.site-header:not(.scrolled):not(.on-light) .nav__toggle { color: var(--sand-50); }

@media (max-width: 920px) {
  .nav__links, .nav .btn { display: none; }
  .nav__toggle { display: flex; }
  .nav--open .nav__links {
    display: flex; flex-direction: column; gap: 1.8rem;
    position: fixed; inset: 0; background: var(--emerald-900);
    align-items: center; justify-content: center; z-index: 105;
  }
  .nav--open .nav__links a { color: var(--sand-50) !important; font-size: 1.4rem; font-family: var(--font-display); }
  .nav--open .nav__cta { display: inline-flex; }
}
.nav__cta { display: none; }
@media (min-width: 921px) { .nav .btn { display: inline-flex; } }

/* ---------- Hero ---------- */
.hero {
  position: relative; min-height: 100vh;
  display: flex; align-items: center;
  color: var(--sand-50);
  overflow: hidden;
}
.hero__bg { position: absolute; inset: 0; z-index: -2; }
.hero__bg img { width: 100%; height: 100%; object-fit: cover; }
.hero__bg::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(12,44,34,.55) 0%, rgba(12,44,34,.25) 35%, rgba(12,44,34,.78) 100%),
    radial-gradient(120% 80% at 70% 20%, rgba(0,0,0,0) 40%, rgba(12,44,34,.5) 100%);
}
.hero__inner { padding-top: 7rem; max-width: 760px; }
.hero h1 { color: var(--sand-50); margin: 1.2rem 0 1.4rem; text-shadow: 0 4px 30px rgba(0,0,0,.35); }
.hero h1 em { font-style: italic; color: var(--gold-400); }
.hero__sub { font-size: 1.35rem; line-height: 1.6; color: var(--sand-100); max-width: 580px; margin-bottom: 2.4rem; font-weight: 300; }
.hero__cta { display: flex; gap: 1rem; flex-wrap: wrap; }
.hero__meta {
  display: flex; gap: 2.2rem; margin-top: 3.2rem; flex-wrap: wrap;
  border-top: 1px solid rgba(255,255,255,.18); padding-top: 1.8rem;
}
.hero__meta div span { display: block; }
.hero__meta .num { font-family: var(--font-display); font-size: 2rem; color: var(--gold-400); line-height: 1; }
.hero__meta .lbl { font-size: 0.74rem; letter-spacing: 2px; text-transform: uppercase; color: var(--sand-200); margin-top: 6px; }
.hero__scroll {
  position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%);
  font-size: 0.7rem; letter-spacing: 3px; text-transform: uppercase; color: var(--sand-200);
  display: flex; flex-direction: column; align-items: center; gap: 8px;
}
.hero__scroll::after { content: ""; width: 1px; height: 38px; background: linear-gradient(var(--gold-400), transparent); animation: scrollPulse 2s infinite; }
@keyframes scrollPulse { 0%,100%{opacity:.3;transform:scaleY(.6)} 50%{opacity:1;transform:scaleY(1)} }

/* page hero (interior pages) */
.page-hero { position: relative; padding: 12rem 0 5rem; background: var(--emerald-900); color: var(--sand-50); overflow: hidden; text-align: center; }
.page-hero::before { content:""; position:absolute; inset:0; background-size: cover; background-position: center; opacity: .28; }
.page-hero[data-bg="leaf"]::before { background-image: radial-gradient(circle at 20% 30%, rgba(139,168,136,.5), transparent 40%), radial-gradient(circle at 80% 70%, rgba(184,138,54,.35), transparent 45%); }
.page-hero h1 { color: var(--sand-50); position: relative; }
.page-hero p { color: var(--sage-200); position: relative; max-width: 560px; margin: 1rem auto 0; }
.breadcrumb { position: relative; font-size: .78rem; letter-spacing: 2px; text-transform: uppercase; color: var(--gold-400); margin-bottom: 1rem; }

/* ---------- Reveal animation ---------- */
[data-reveal] { opacity: 0; transform: translateY(34px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
[data-reveal].in { opacity: 1; transform: none; }
[data-reveal-delay="1"] { transition-delay: .12s; }
[data-reveal-delay="2"] { transition-delay: .24s; }
[data-reveal-delay="3"] { transition-delay: .36s; }
@media (prefers-reduced-motion: reduce) { [data-reveal]{opacity:1;transform:none;transition:none} html{scroll-behavior:auto} }

/* ---------- Intro / about split ---------- */
.split { display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; }
.split--reverse .split__media { order: 2; }
.split__media { position: relative; }
.split__media img { width: 100%; border-radius: var(--radius-lg); box-shadow: var(--shadow-md); aspect-ratio: 4/5; object-fit: cover; }
.split__media .tag {
  position: absolute; bottom: -22px; left: -22px;
  background: var(--white); border-radius: var(--radius); padding: 1.1rem 1.4rem;
  box-shadow: var(--shadow-md); display: flex; align-items: center; gap: .9rem;
}
.split__media .tag .stars { color: var(--gold-500); font-size: 1.1rem; letter-spacing: 2px; }
.split__media .tag strong { font-family: var(--font-display); font-size: 1.5rem; color: var(--emerald-800); }
.split__media .tag small { display: block; font-size: .7rem; letter-spacing: 1px; text-transform: uppercase; color: var(--text-soft); }
@media (max-width: 820px) {
  .split { grid-template-columns: 1fr; }
  .split--reverse .split__media { order: 0; }
  .split__media img { aspect-ratio: 4/3; }
}
.feature-list { margin-top: 2rem; display: grid; gap: 1.2rem; }
.feature-list li { display: flex; gap: 1rem; align-items: flex-start; }
.feature-list .ic { flex: 0 0 auto; width: 44px; height: 44px; border-radius: 12px; background: var(--sand-200); color: var(--emerald-700); display: grid; place-items: center; font-size: 1.2rem; }
.feature-list h4 { margin-bottom: 2px; color: var(--emerald-800); font-size: 1.15rem; }
.feature-list p { margin: 0; font-size: .95rem; }

/* ---------- Service cards ---------- */
.cat-tabs { display: flex; gap: .6rem; flex-wrap: wrap; justify-content: center; margin-bottom: 3rem; }
.cat-tab {
  padding: .6rem 1.3rem; border-radius: 100px; font-size: .82rem; letter-spacing: .5px;
  border: 1px solid var(--sand-300); color: var(--text-soft); background: var(--white);
  transition: all .3s var(--ease); text-transform: uppercase;
}
.cat-tab:hover { border-color: var(--gold-500); color: var(--accent-deep); }
.cat-tab.active { background: var(--emerald-800); color: var(--sand-50); border-color: var(--emerald-800); }

.svc-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 1.5rem; }
.svc-card {
  background: var(--white); border-radius: var(--radius); padding: 1.7rem;
  border: 1px solid var(--sand-200); display: flex; flex-direction: column;
  transition: transform .45s var(--ease), box-shadow .45s var(--ease), border-color .3s;
  position: relative; overflow: hidden;
}
.svc-card::before { content:""; position:absolute; left:0; top:0; height:100%; width:3px; background: var(--gold-500); transform: scaleY(0); transform-origin: top; transition: transform .45s var(--ease); }
.svc-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); border-color: transparent; }
.svc-card:hover::before { transform: scaleY(1); }
.svc-card__top { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; }
.svc-card h4 { color: var(--emerald-800); font-size: 1.3rem; line-height: 1.15; }
.svc-card__price { font-family: var(--font-display); font-size: 1.45rem; font-weight: 600; color: var(--accent-deep); white-space: nowrap; }
.svc-card__price small { display:block; font-family: var(--font-body); font-size:.62rem; letter-spacing:1px; color: var(--text-soft); text-transform: uppercase; text-align: right;}
.svc-card__meta { font-size: .78rem; letter-spacing: 1px; text-transform: uppercase; color: var(--sage-400); margin-top: .5rem; display:flex; align-items:center; gap:.5rem; }
.svc-card__desc { font-size: .92rem; margin-top: 1rem; flex: 1; }
.svc-card__member { display:inline-block; margin-top:.5rem; font-size:.8rem; letter-spacing:.3px; color:var(--accent-deep); background:var(--sand-100); border:1px solid var(--sand-300); border-radius:100px; padding:.2rem .7rem; }
.member-banner { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:1rem; background:var(--emerald-900); color:var(--sand-50); border-radius:var(--radius); padding:1.2rem 1.6rem; margin-bottom:2.5rem; }
.member-banner p { color:var(--sage-200); margin:0; }
.member-banner strong { color:var(--gold-400); }

/* Announcement bar (editable in /admin) */
.announce-bar { position:fixed; inset:0 0 auto 0; z-index:200; background:linear-gradient(90deg,var(--gold-500),var(--gold-400)); color:var(--emerald-900); text-align:center; font-size:.82rem; letter-spacing:.3px; padding:.5rem 2.6rem; display:flex; align-items:center; justify-content:center; min-height:38px; }
.announce-bar a { color:var(--emerald-900); font-weight:600; text-decoration:underline; margin-left:.4rem; }
.announce-bar .x { position:absolute; right:.7rem; top:50%; transform:translateY(-50%); border:none; background:none; font-size:1.2rem; line-height:1; color:var(--emerald-900); cursor:pointer; }
body.has-announce .site-header { top:38px; }
@media (max-width:600px){ .announce-bar{ font-size:.72rem; padding:.5rem 2rem .5rem .8rem; } }
.svc-card__btn { margin-top: 1.4rem; }
.svc-card__btn a { display: inline-flex; align-items: center; gap: .5rem; font-size: .82rem; letter-spacing: 1px; text-transform: uppercase; color: var(--emerald-700); font-weight: 500; }
.svc-card__btn a .arr { transition: transform .3s; }
.svc-card:hover .svc-card__btn a .arr { transform: translateX(5px); }
.cat-group { margin-bottom: 3.5rem; }
.cat-group__head { display:flex; align-items:baseline; gap:1rem; margin-bottom: 1.6rem; }
.cat-group__head h3 { color: var(--emerald-800); }
.cat-group__head .line { flex:1; height:1px; background: var(--sand-300); }
.cat-group__head .count { font-size:.78rem; letter-spacing:1px; color: var(--text-soft); text-transform: uppercase; }

/* ---------- Featured services (home) ---------- */
.feat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
@media (max-width: 880px){ .feat-grid{ grid-template-columns:1fr; } }
.feat-card { position: relative; border-radius: var(--radius-lg); overflow: hidden; min-height: 420px; display: flex; align-items: flex-end; color: var(--sand-50); box-shadow: var(--shadow-sm); }
.feat-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform 1s var(--ease); }
.feat-card::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 30%, rgba(12,44,34,.9)); }
.feat-card:hover img { transform: scale(1.07); }
.feat-card__body { position: relative; padding: 2rem; z-index:2; }
.feat-card__body h3 { color: var(--sand-50); margin-bottom: .4rem; }
.feat-card__body p { color: var(--sand-200); font-size: .92rem; margin-bottom: 1rem; }
.feat-card__body .price { font-family: var(--font-display); color: var(--gold-400); font-size: 1.3rem; }

/* ---------- Stats band ---------- */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; text-align: center; }
@media (max-width: 760px){ .stats{ grid-template-columns: repeat(2,1fr); gap:2.4rem; } }
.stats .num { font-family: var(--font-display); font-size: clamp(2.6rem,5vw,3.6rem); color: var(--gold-400); line-height: 1; }
.stats .lbl { font-size: .8rem; letter-spacing: 2px; text-transform: uppercase; color: var(--sage-200); margin-top: .6rem; }

/* ---------- Reviews ---------- */
.reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
@media (max-width: 900px){ .reviews-grid{ grid-template-columns:1fr; } }
.review-card { background: var(--white); border-radius: var(--radius); padding: 2rem; box-shadow: var(--shadow-sm); border: 1px solid var(--sand-200); display:flex; flex-direction:column; }
.review-card .stars { color: var(--gold-500); letter-spacing: 2px; margin-bottom: 1rem; }
.review-card p { color: var(--ink-700); font-style: italic; font-family: var(--font-display); font-size: 1.18rem; line-height: 1.5; flex:1; }
.review-card .who { margin-top: 1.4rem; display:flex; align-items:center; gap:.8rem; }
.review-card .who .av { width: 42px; height:42px; border-radius:50%; background: var(--emerald-700); color: var(--sand-50); display:grid; place-items:center; font-family: var(--font-display); font-size:1.1rem; }
.review-card .who strong { color: var(--emerald-800); display:block; font-weight:500; }
.review-card .who small { color: var(--text-soft); }

/* ---------- Gallery ---------- */
.gallery-grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 220px; gap: 14px; }
.gallery-grid figure { overflow: hidden; border-radius: var(--radius); position: relative; }
.gallery-grid img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--ease); }
.gallery-grid figure:hover img { transform: scale(1.08); }
.gallery-grid .tall { grid-row: span 2; }
.gallery-grid .wide { grid-column: span 2; }
@media (max-width: 760px){ .gallery-grid{ grid-template-columns: repeat(2,1fr); grid-auto-rows: 170px; } .gallery-grid .wide{grid-column:span 2;} }

/* ---------- CTA band ---------- */
.cta-band { position: relative; border-radius: var(--radius-lg); overflow: hidden; padding: clamp(3rem,7vw,5.5rem); text-align: center; color: var(--sand-50); }
.cta-band img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; }
.cta-band::after { content:""; position:absolute; inset:0; background: linear-gradient(135deg, rgba(12,44,34,.92), rgba(20,80,59,.78)); z-index:-1; }
.cta-band h2 { color: var(--sand-50); }
.cta-band p { color: var(--sage-200); max-width: 520px; margin: 1rem auto 2rem; }

/* ---------- Info / contact cards ---------- */
.info-grid { display:grid; grid-template-columns: repeat(3,1fr); gap:1.5rem; }
@media (max-width:820px){ .info-grid{ grid-template-columns:1fr; } }
.info-card { background: var(--white); border:1px solid var(--sand-200); border-radius: var(--radius); padding: 2rem; }
.info-card .ic { width:50px;height:50px;border-radius:14px;background:var(--emerald-800);color:var(--gold-400);display:grid;place-items:center;font-size:1.3rem;margin-bottom:1.2rem; }
.info-card h4 { color: var(--emerald-800); margin-bottom:.5rem; }
.info-card p, .info-card a { font-size:.95rem; color: var(--text-soft); }
.info-card a:hover { color: var(--accent-deep); }
.hours-list { display:grid; gap:.5rem; }
.hours-list li { display:flex; justify-content:space-between; font-size:.92rem; padding:.35rem 0; border-bottom:1px dashed var(--sand-200); }
.hours-list li.today { color: var(--emerald-700); font-weight:500; }
.hours-list li span:last-child { color: var(--ink-700); }

/* ---------- Footer ---------- */
.site-footer { background: var(--emerald-900); color: var(--sand-200); padding-top: 4.5rem; }
.footer-grid { display:grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 2.5rem; padding-bottom: 3rem; }
@media (max-width: 820px){ .footer-grid{ grid-template-columns: 1fr 1fr; gap:2rem;} }
@media (max-width: 480px){ .footer-grid{ grid-template-columns: 1fr; } }
.site-footer h5 { font-family: var(--font-body); text-transform: uppercase; letter-spacing:2px; font-size:.78rem; color: var(--gold-400); margin-bottom:1.2rem; font-weight:500; }
.site-footer .brand__name { color: var(--sand-50); }
.site-footer ul { display:grid; gap:.7rem; }
.site-footer a:hover { color: var(--gold-400); }
.site-footer p { color: var(--sage-200); font-size:.92rem; }
.footer-about p { margin-top: 1rem; max-width: 280px; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.1); padding: 1.5rem 0; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.82rem; color: var(--sage-400); }
.social { display:flex; gap:.8rem; margin-top:1.2rem; }
.social a { width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.18);display:grid;place-items:center;transition:all .3s; }
.social a:hover { background: var(--gold-500); border-color: var(--gold-500); color: var(--emerald-900); transform: translateY(-3px); }

/* ---------- Policy note ---------- */
.policy { background: var(--sand-100); border:1px solid var(--sand-300); border-left: 4px solid var(--gold-500); border-radius: var(--radius); padding: 1.6rem 1.8rem; }
.policy h4 { color: var(--emerald-800); margin-bottom:.6rem; font-family: var(--font-body); font-size: .95rem; text-transform: uppercase; letter-spacing:1px; }
.policy ul { display:grid; gap:.5rem; }
.policy li { font-size:.94rem; padding-left:1.4rem; position:relative; color: var(--text-soft); }
.policy li::before { content:"✦"; position:absolute; left:0; color: var(--gold-500); }

/* ============================================================
   BOOKING FLOW
   ============================================================ */
.booking-wrap { display: grid; grid-template-columns: 1fr 360px; gap: 2.5rem; align-items: start; }
@media (max-width: 960px){ .booking-wrap{ grid-template-columns: 1fr; } }

/* Stepper */
.stepper { display:flex; align-items:center; gap:.5rem; margin-bottom: 2.5rem; flex-wrap:wrap; }
.stepper .step { display:flex; align-items:center; gap:.6rem; color: var(--ink-300); font-size:.85rem; letter-spacing:.5px; }
.stepper .step .dot { width:30px;height:30px;border-radius:50%;border:1.5px solid var(--sand-300); display:grid;place-items:center; font-size:.85rem; background:var(--white); transition:all .3s; }
.stepper .step.active { color: var(--emerald-800); font-weight:500; }
.stepper .step.active .dot { background: var(--emerald-800); color: var(--sand-50); border-color: var(--emerald-800); }
.stepper .step.done .dot { background: var(--gold-500); color: var(--emerald-900); border-color: var(--gold-500); }
.stepper .bar { flex:1; height:1.5px; background: var(--sand-300); min-width:20px; }
.stepper .step.done + .bar { background: var(--gold-500); }

.booking-panel { display:none; }
.booking-panel.active { display:block; animation: fadeUp .5s var(--ease); }
@keyframes fadeUp { from{opacity:0;transform:translateY(14px)} to{opacity:1;transform:none} }
.booking-panel h3 { color: var(--emerald-800); margin-bottom:.4rem; }
.booking-panel .hint { color: var(--text-soft); font-size:.95rem; margin-bottom:1.6rem; }

/* Service select grid */
.choose-grid { display:grid; grid-template-columns: repeat(auto-fill,minmax(260px,1fr)); gap:1rem; }
.choose-card { text-align:left; border:1.5px solid var(--sand-200); border-radius:14px; padding:1.2rem; background:var(--white); transition:all .25s var(--ease); position:relative; }
.choose-card:hover { border-color: var(--gold-500); transform: translateY(-3px); box-shadow: var(--shadow-sm); }
.choose-card.selected { border-color: var(--emerald-700); box-shadow: 0 0 0 2px var(--emerald-700); }
.choose-card.selected::after { content:"✓"; position:absolute; top:10px; right:12px; width:22px;height:22px;border-radius:50%;background:var(--emerald-700);color:#fff;display:grid;place-items:center;font-size:.75rem; }
.choose-card h5 { font-family:var(--font-body); font-weight:500; color: var(--emerald-800); font-size:1rem; margin-bottom:.4rem; line-height:1.25; }
.choose-card .meta { font-size:.78rem; color:var(--sage-400); text-transform:uppercase; letter-spacing:.5px; }
.choose-card .pr { font-family:var(--font-display); font-size:1.2rem; color:var(--accent-deep); margin-top:.5rem; font-weight:600; }
.choose-filter { display:flex; gap:.4rem; flex-wrap:wrap; margin-bottom:1.4rem; }

/* Date & time */
.field { margin-bottom:1.3rem; }
.field label { display:block; font-size:.82rem; letter-spacing:.5px; text-transform:uppercase; color:var(--emerald-800); margin-bottom:.5rem; font-weight:500; }
.field input, .field textarea, .field select {
  width:100%; padding:.95rem 1.1rem; border:1.5px solid var(--sand-300); border-radius:12px;
  font-family:var(--font-body); font-size:1rem; color:var(--ink-700); background:var(--white); transition:border-color .25s;
}
.field input:focus, .field textarea:focus, .field select:focus { outline:none; border-color: var(--gold-500); }
.field textarea { resize:vertical; min-height:90px; }
.field .err { color:#b5462f; font-size:.82rem; margin-top:.4rem; display:none; }
.field.invalid input, .field.invalid select { border-color:#cf6a52; }
.field.invalid .err { display:block; }
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
@media (max-width:520px){ .two-col{ grid-template-columns:1fr; } }

.slots { display:grid; grid-template-columns: repeat(auto-fill,minmax(92px,1fr)); gap:.6rem; }
.slot { padding:.7rem .4rem; border:1.5px solid var(--sand-300); border-radius:10px; background:var(--white); font-size:.9rem; color:var(--ink-700); transition:all .2s; text-align:center; }
.slot:hover { border-color: var(--gold-500); }
.slot.selected { background: var(--emerald-800); color:#fff; border-color:var(--emerald-800); }
.slots-empty { color:var(--text-soft); font-size:.92rem; padding:1rem 0; }

/* Payment method toggles */
.pay-methods { display:grid; gap:.8rem; margin:1.2rem 0; }
.pay-method { display:flex; align-items:center; gap:1rem; border:1.5px solid var(--sand-300); border-radius:12px; padding:1rem 1.2rem; cursor:pointer; transition:all .25s; }
.pay-method:hover { border-color: var(--gold-500); }
.pay-method.selected { border-color: var(--emerald-700); box-shadow:0 0 0 2px var(--emerald-700); }
.pay-method input { accent-color: var(--emerald-700); width:18px;height:18px; }
.pay-method .pm-ic { font-size:1.4rem; }
.pay-method .pm-label strong { display:block; color:var(--emerald-800); font-weight:500; }
.pay-method .pm-label small { color:var(--text-soft); font-size:.82rem; }
#payArea { margin-top:1rem; }
.demo-badge { display:inline-block; background:var(--gold-500); color:var(--emerald-900); font-size:.7rem; letter-spacing:1px; text-transform:uppercase; padding:.25rem .7rem; border-radius:100px; font-weight:600; }

/* Summary sidebar */
.summary { background:var(--white); border:1px solid var(--sand-200); border-radius:var(--radius); padding:1.7rem; position:sticky; top:90px; box-shadow:var(--shadow-sm); }
.summary h4 { font-family:var(--font-body); text-transform:uppercase; letter-spacing:1px; font-size:.8rem; color:var(--gold-600); margin-bottom:1.2rem; }
.summary .row { display:flex; justify-content:space-between; gap:1rem; padding:.55rem 0; font-size:.92rem; color:var(--text-soft); border-bottom:1px dashed var(--sand-200); }
.summary .row span:last-child { color:var(--ink-700); text-align:right; font-weight:400; }
.summary .row.empty span:last-child { color:var(--ink-300); font-style:italic; }
.summary .total { display:flex; justify-content:space-between; align-items:baseline; margin-top:1rem; padding-top:1rem; }
.summary .total .lbl { font-size:.8rem; text-transform:uppercase; letter-spacing:1px; color:var(--text-soft); }
.summary .total .amt { font-family:var(--font-display); font-size:1.6rem; color:var(--emerald-800); font-weight:600; }
.summary .deposit { background:var(--sand-100); border-radius:12px; padding:.9rem 1rem; margin-top:1rem; }
.summary .deposit .row { border:none; padding:.25rem 0; }
.summary .deposit .due { color:var(--accent-deep); font-weight:600; }
.summary .fine { font-size:.78rem; color:var(--text-soft); margin-top:1rem; line-height:1.5; }

.booking-nav { display:flex; justify-content:space-between; gap:1rem; margin-top:2rem; }
.booking-nav .btn--text { background:none; color:var(--text-soft); padding:1rem 0; }
.booking-nav .btn--text:hover { color:var(--emerald-800); }

/* Confirmation */
.confirm { text-align:center; max-width:560px; margin:0 auto; padding:2rem 0; }
.confirm .check { width:84px;height:84px;border-radius:50%;background:var(--emerald-700);color:var(--gold-400);display:grid;place-items:center;font-size:2.4rem;margin:0 auto 1.5rem; animation:pop .5s var(--ease); }
@keyframes pop { 0%{transform:scale(.6);opacity:0} 100%{transform:scale(1);opacity:1} }
.confirm .ref { display:inline-block; background:var(--sand-100); border:1px dashed var(--sand-300); border-radius:10px; padding:.6rem 1.2rem; font-family:var(--font-display); font-size:1.3rem; color:var(--emerald-800); margin:1rem 0; letter-spacing:2px; }
.confirm-card { background:var(--white); border:1px solid var(--sand-200); border-radius:var(--radius); padding:1.6rem; text-align:left; margin:1.5rem 0; }
.confirm-card .row { display:flex; justify-content:space-between; padding:.5rem 0; border-bottom:1px dashed var(--sand-200); font-size:.95rem; }
.confirm-card .row span:first-child { color:var(--text-soft); }

/* ============================================================
   BRAND LOGO (vector lotus)  +  STORY  +  EMBED  +  STICKY BAR
   ============================================================ */
.brand__logo { width: 40px; height: 40px; flex: none; display: block; }
.brand__logo .lotus { fill: var(--gold-500); transition: fill .3s; }
.site-header:not(.scrolled):not(.on-light) .brand__name { color: var(--sand-50); }
.brand__name { font-family: var(--font-display); font-size: 1.4rem; font-weight: 600; color: var(--emerald-800); line-height: 1; letter-spacing: .5px; }
.brand__name small { display: block; font-family: var(--font-body); font-size: 0.58rem; letter-spacing: 3px; text-transform: uppercase; color: var(--accent-deep); margin-top: 4px; font-weight: 400; }

/* Founder / story split */
.founder { display:grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(2rem,5vw,4.5rem); align-items:center; }
@media (max-width:840px){ .founder{ grid-template-columns:1fr; } }
.founder__photo { position:relative; }
.founder__photo img { width:100%; border-radius: var(--radius-lg); box-shadow: var(--shadow-md); aspect-ratio: 4/5; object-fit: cover; object-position: top center; }
.founder__photo .sig { position:absolute; bottom:-20px; right:-10px; background:var(--emerald-900); color:var(--gold-400); font-family:var(--font-display); font-size:1.5rem; padding:.7rem 1.4rem; border-radius:14px; box-shadow:var(--shadow-md); }
.founder__photo .sig small { display:block; font-family:var(--font-body); font-size:.6rem; letter-spacing:2px; text-transform:uppercase; color:var(--sand-200); }
.founder blockquote { font-family:var(--font-display); font-size:clamp(1.4rem,2.6vw,1.9rem); line-height:1.4; color:var(--emerald-800); font-style:italic; margin:1.2rem 0; }

/* Story band (parallax-ish image with text) */
.story-band { position:relative; border-radius:var(--radius-lg); overflow:hidden; min-height:460px; display:flex; align-items:center; color:var(--sand-50); }
.story-band img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; }
.story-band::after { content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(12,44,34,.92) 0%, rgba(12,44,34,.7) 45%, rgba(12,44,34,.15) 100%); z-index:-1; }
.story-band__body { padding:clamp(2rem,5vw,4rem); max-width:560px; }
.story-band__body h2 { color:var(--sand-50); }
.story-band__body p { color:var(--sage-200); }
.story-band__body .eyebrow { color:var(--gold-400); }

/* Heritage cards */
.herb-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; }
@media (max-width:820px){ .herb-grid{ grid-template-columns:repeat(2,1fr); } }
.herb { background:var(--white); border:1px solid var(--sand-200); border-radius:var(--radius); padding:1.6rem; text-align:center; transition:transform .35s var(--ease), box-shadow .35s; }
.herb:hover { transform:translateY(-5px); box-shadow:var(--shadow-md); }
.herb .ic { font-size:1.9rem; }
.herb h4 { color:var(--emerald-800); margin:.6rem 0 .3rem; font-size:1.15rem; }
.herb p { font-size:.88rem; }

/* Setmore embed */
.embed-wrap { background:var(--white); border:1px solid var(--sand-200); border-radius:var(--radius-lg); padding:.6rem; box-shadow:var(--shadow-sm); overflow:hidden; }
.embed-wrap iframe { width:100%; min-height:760px; border:0; border-radius:calc(var(--radius-lg) - 6px); display:block; }
.embed-fallback { text-align:center; padding:2rem; }

/* Map block */
.map-wrap { border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); border:1px solid var(--sand-200); }
.map-wrap iframe { width:100%; height:340px; border:0; display:block; }

/* Sticky mobile book bar */
.book-bar { position:fixed; left:0; right:0; bottom:0; z-index:90; display:none; align-items:center; justify-content:space-between; gap:1rem; padding:.7rem 1rem; background:var(--emerald-900); color:var(--sand-50); box-shadow:0 -8px 30px rgba(0,0,0,.25); }
.book-bar small { display:block; font-size:.7rem; letter-spacing:1px; text-transform:uppercase; color:var(--gold-400); }
.book-bar b { font-family:var(--font-display); font-size:1.05rem; }
@media (max-width:760px){ .book-bar{ display:flex; } body{ padding-bottom:70px; } }

/* tourist note */
.visit-note { display:inline-flex; align-items:center; gap:.6rem; background:var(--sand-100); border:1px solid var(--sand-300); border-radius:100px; padding:.5rem 1.1rem; font-size:.82rem; color:var(--emerald-800); margin-top:1.4rem; }
.story-band__body .visit-note { background:rgba(255,255,255,.12); border-color:rgba(255,255,255,.25); color:var(--sand-50); }

/* ============================================================
   MOTION  ·  TRUST  ·  GIFT CARD  ·  SIGNUP FORM
   ============================================================ */
/* Hero video */
.hero__bg video { width:100%; height:100%; object-fit:cover; }
.hero__bg img.kenburns { animation: kenburns 22s ease-in-out infinite alternate; }
@keyframes kenburns { from { transform: scale(1) translateY(0); } to { transform: scale(1.12) translateY(-2%); } }
@media (prefers-reduced-motion: reduce){ .hero__bg img.kenburns{ animation:none; } }

/* Parallax (JS sets --py) */
.parallax { will-change: transform; }

/* Trust strip */
.trust-strip { border-top:1px solid var(--sand-200); border-bottom:1px solid var(--sand-200); background:var(--white); }
.trust-strip .container { display:flex; flex-wrap:wrap; justify-content:center; gap:1.4rem 2.6rem; padding-block:1.4rem; }
.trust-item { display:flex; align-items:center; gap:.6rem; font-size:.85rem; letter-spacing:.5px; color:var(--emerald-800); }
.trust-item .ti { width:30px;height:30px;border-radius:8px;background:var(--sand-100);display:grid;place-items:center;color:var(--accent-deep);font-size:1rem; }
.trust-item strong { font-weight:500; }

/* Gift card */
.giftcard { position:relative; border-radius:var(--radius-lg); overflow:hidden; display:grid; grid-template-columns:1.1fr .9fr; gap:0; box-shadow:var(--shadow-md); }
@media (max-width:780px){ .giftcard{ grid-template-columns:1fr; } }
.giftcard__body { background:var(--emerald-900); color:var(--sand-50); padding:clamp(2rem,5vw,3.5rem); }
.giftcard__body h2 { color:var(--sand-50); }
.giftcard__body p { color:var(--sage-200); margin:1rem 0 1.6rem; }
.giftcard__visual { position:relative; min-height:260px; background:linear-gradient(135deg,#1d6b4f,#0c2c22); display:grid; place-items:center; padding:2rem; }
.gc-card { width:100%; max-width:330px; aspect-ratio:1.6/1; border-radius:18px; background:linear-gradient(135deg,#13110c,#241c0e); border:1px solid var(--gold-500); box-shadow:0 18px 50px rgba(0,0,0,.4); padding:1.5rem; color:var(--gold-400); display:flex; flex-direction:column; justify-content:space-between; transform:rotate(-4deg); transition:transform .5s var(--ease); }
.giftcard:hover .gc-card { transform:rotate(0deg) translateY(-4px); }
.gc-card .gc-top { display:flex; justify-content:space-between; align-items:center; font-family:var(--font-display); font-size:1.3rem; }
.gc-card .gc-amt { font-family:var(--font-display); font-size:2.2rem; color:var(--sand-50); }
.gc-card small { letter-spacing:3px; text-transform:uppercase; font-size:.6rem; color:var(--sage-200); }

/* Signup / marketing form */
.signup { background:var(--emerald-900); border-radius:var(--radius-lg); padding:clamp(2.2rem,5vw,3.6rem); color:var(--sand-50); text-align:center; }
.signup h2 { color:var(--sand-50); }
.signup p { color:var(--sage-200); max-width:520px; margin:1rem auto 1.8rem; }
.zen-form { max-width:560px; margin:0 auto; text-align:left; }
.zen-form .row2 { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
@media (max-width:540px){ .zen-form .row2{ grid-template-columns:1fr; } }
.zen-form input[type=text], .zen-form input[type=email], .zen-form input[type=tel] {
  width:100%; padding:.95rem 1.1rem; border-radius:12px; border:1px solid rgba(255,255,255,.2);
  background:rgba(255,255,255,.06); color:var(--sand-50); font:inherit; font-size:1rem; margin-bottom:1rem;
}
.zen-form input::placeholder { color:rgba(255,255,255,.5); }
.zen-form input:focus { outline:none; border-color:var(--gold-500); }
.zen-form .consent { display:flex; gap:.7rem; align-items:flex-start; font-size:.82rem; color:var(--sage-200); margin-bottom:.7rem; text-align:left; }
.zen-form .consent input { accent-color:var(--gold-500); margin-top:3px; }
.zen-form .btn { width:100%; margin-top:.6rem; }
.form-note { font-size:.74rem; color:var(--sage-400); margin-top:1rem; }
.form-success { display:none; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.2); border-radius:12px; padding:1rem 1.2rem; color:var(--sand-50); margin-top:1rem; }

/* ===== Reveal safety: content visible even if JS fails ===== */
[data-reveal]{ opacity:1; transform:none; }
html.js [data-reveal]{ opacity:0; transform:translateY(30px); transition:opacity .9s cubic-bezier(.22,1,.36,1),transform .9s cubic-bezier(.22,1,.36,1); }
html.js [data-reveal].in{ opacity:1; transform:none; }

/* ===== Header + logo + hero polish (v3) ===== */
.site-header, .site-header.scrolled, .site-header.on-light{
  background: linear-gradient(180deg, rgba(8,20,15,.98), rgba(8,20,15,.86)) !important;
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 2px 28px rgba(0,0,0,.42) !important;
}
.site-header .nav__links a{ color: var(--sand-50) !important; }
.site-header .nav__links a:hover, .site-header .nav__links a.active{ color: var(--gold-400) !important; }
.site-header .nav__toggle{ color: var(--sand-50) !important; }
.site-header .brand__name{ color: var(--sand-50) !important; font-size: 1.82rem !important; letter-spacing:.6px; }
.site-header .brand__name small{ color: var(--gold-400) !important; letter-spacing:3.5px; }
.brand__logo{
  width:62px !important; height:62px !important; display:grid !important; place-items:center !important;
  background: radial-gradient(circle at 50% 34%, #1d2f27, #0a120f) !important;
  border: 2px solid var(--gold-400) !important; border-radius:50% !important;
  box-shadow: 0 6px 18px rgba(0,0,0,.45), inset 0 0 16px rgba(201,162,75,.32) !important;
}
.brand__logo svg{ width:40px !important; height:40px !important; }
.brand__logo .lotus{ fill: var(--gold-400) !important; }
.hero__bg::after{
  background:
    linear-gradient(180deg, rgba(8,26,20,.72) 0%, rgba(8,26,20,.42) 45%, rgba(8,26,20,.88) 100%),
    linear-gradient(90deg, rgba(8,26,20,.82) 0%, rgba(8,26,20,.34) 55%, rgba(8,26,20,0) 100%) !important;
}
.hero h1{ text-shadow: 0 2px 5px rgba(0,0,0,.5), 0 10px 44px rgba(0,0,0,.55) !important; }
.hero__sub{ color: var(--sand-50) !important; font-weight:400 !important; text-shadow: 0 1px 3px rgba(0,0,0,.6), 0 2px 20px rgba(0,0,0,.45) !important; }
.hero .eyebrow{ text-shadow: 0 1px 4px rgba(0,0,0,.6); }
@media (max-width:600px){
  .brand__logo{ width:50px !important; height:50px !important; }
  .brand__logo svg{ width:32px !important; height:32px !important; }
  .site-header .brand__name{ font-size:1.45rem !important; }
}

/* ===== Rewards cards (referral / membership / loyalty) ===== */
.rewards-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; align-items:stretch; }
@media (max-width:880px){ .rewards-grid{ grid-template-columns:1fr; max-width:440px; margin-inline:auto; } }
.reward-card{ position:relative; background:var(--white); border:1px solid var(--sand-200); border-radius:var(--radius-lg); padding:2.6rem 1.8rem; text-align:center; display:flex; flex-direction:column; align-items:center; box-shadow:var(--shadow-sm); transition:transform .45s var(--ease), box-shadow .45s var(--ease); }
.reward-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); }
.reward-card__ic{ width:66px; height:66px; border-radius:50%; display:grid; place-items:center; font-size:1.8rem; background:linear-gradient(145deg,var(--sand-100),var(--sand-200)); color:var(--accent-deep); border:1px solid var(--sand-300); margin-bottom:1.1rem; }
.reward-card__tag{ display:inline-block; font-size:.68rem; letter-spacing:2px; text-transform:uppercase; color:var(--accent-deep); background:var(--sand-100); border-radius:100px; padding:.32rem .95rem; margin-bottom:1rem; font-weight:500; }
.reward-card h3{ font-size:1.42rem; color:var(--emerald-800); margin-bottom:1rem; line-height:1.15; }
.reward-card .big{ font-family:var(--font-display); color:var(--accent-deep); font-size:3rem; line-height:1; font-weight:600; }
.reward-card .big span{ display:block; font-family:var(--font-body); font-size:.72rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-soft); margin-top:.6rem; font-weight:400; }
.reward-card p{ font-size:.94rem; color:var(--text-soft); margin-top:1rem; }
.reward-card .btn{ margin-top:1.6rem; }
.reward-card--featured{ background:linear-gradient(165deg,var(--emerald-800),var(--emerald-900)); border:none; box-shadow:var(--shadow-md); transform:translateY(-12px); }
@media (max-width:880px){ .reward-card--featured{ transform:none; } }
.reward-card--featured .reward-card__ic{ background:rgba(216,184,110,.14); border-color:var(--gold-500); color:var(--gold-400); }
.reward-card--featured .reward-card__tag{ background:rgba(255,255,255,.1); color:var(--gold-400); }
.reward-card--featured h3{ color:var(--sand-50); }
.reward-card--featured .big{ color:var(--gold-400); }
.reward-card--featured .big span{ color:var(--sage-200); }
.reward-card--featured p{ color:var(--sage-200); }
.reward-card__ribbon{ position:absolute; top:1.1rem; right:1.1rem; background:var(--gold-500); color:var(--emerald-900); font-size:.62rem; letter-spacing:1.5px; text-transform:uppercase; font-weight:600; padding:.32rem .85rem; border-radius:100px; }
.rewards-note{ text-align:center; font-size:.82rem; color:var(--text-soft); margin-top:2.2rem; max-width:640px; margin-inline:auto; line-height:1.6; }

/* ===== Rewards terms panel (transparent, sets expectations) ===== */
.rewards-terms{ background:var(--white); border:1px solid var(--sand-200); border-radius:var(--radius-lg); padding:2rem 2.2rem; margin-top:2.4rem; box-shadow:var(--shadow-sm); }
.rewards-terms h4{ color:var(--emerald-800); font-family:var(--font-body); text-transform:uppercase; letter-spacing:1.5px; font-size:.82rem; margin-bottom:1.3rem; }
.rewards-terms ul{ display:grid; grid-template-columns:1fr 1fr; gap:.9rem 2.2rem; }
@media (max-width:760px){ .rewards-terms ul{ grid-template-columns:1fr; } }
.rewards-terms li{ font-size:.92rem; color:var(--text-soft); padding-left:1.5rem; position:relative; line-height:1.55; }
.rewards-terms li::before{ content:"\2726"; position:absolute; left:0; color:var(--gold-500); }
.rewards-terms strong{ color:var(--emerald-800); font-weight:500; }
