/* ═══════════════════════════════════════
   KRY OPAL — DESIGN SYSTEM
═══════════════════════════════════════ */
:root {
  --gold: #C9A84C;
  --gold-light: #E8D5A3;
  --gold-dark: #A07830;
  --cobalt: #1B3A7A;
  --cobalt-deep: #152D5E;
  --obsidian: #1A1A1A;
  --ivory: #FAFAF7;
  --white: #FFFFFF;
  --mist: #8A8A8A;
  --rule: rgba(26,26,26,0.1);
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: 'Jost', sans-serif;
  font-weight: 300;
  background: var(--ivory);
  color: var(--obsidian);
  overflow-x: hidden;
  cursor: none;
}

/* ── Cursor ── */
#cursor { width:8px; height:8px; background:var(--gold); border-radius:50%; position:fixed; top:0; left:0; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); transition:transform .1s; }
#cursor-ring { width:36px; height:36px; border:1px solid rgba(201,168,76,.4); border-radius:50%; position:fixed; top:0; left:0; pointer-events:none; z-index:9998; transform:translate(-50%,-50%); transition:transform .5s cubic-bezier(.16,1,.3,1), width .3s, height .3s, border-color .3s; }
.hover-target:hover ~ #cursor-ring, a:hover + #cursor-ring { width:52px; height:52px; }

/* ── Pages ── */
.page { display:none; min-height:100vh; }
.page.active { display:block; }

/* ═══ NAVIGATION ═══ */
nav {
  position: fixed; top:0; left:0; right:0; z-index:500;
  display: flex; align-items:center; justify-content:space-between;
  padding: 28px 64px;
  transition: all .4s ease;
  border-bottom: 1px solid transparent;
}
nav.scrolled {
  background: rgba(250,250,247,.94);
  backdrop-filter: blur(20px);
  padding: 18px 64px;
  border-bottom-color: rgba(201,168,76,.15);
}
/* Always solid on inner pages */
nav.inner-page {
  background: rgba(250,250,247,.98);
  backdrop-filter: blur(20px);
  border-bottom-color: rgba(201,168,76,.15);
}
.nav-logo {
  font-family:'Cormorant Garamond',serif; font-size:20px; font-weight:300;
  letter-spacing:.4em; color:var(--obsidian); text-decoration:none; cursor:none;
}
.nav-links { display:flex; gap:36px; list-style:none; }
.nav-links a {
  font-size:9px; font-weight:400; letter-spacing:.35em; text-transform:uppercase;
  color:var(--obsidian); text-decoration:none; cursor:none;
  position:relative; padding-bottom:3px;
  transition: color .3s;
}
.nav-links a::after { content:''; position:absolute; bottom:0; left:0; right:100%; height:1px; background:var(--gold); transition:right .35s cubic-bezier(.16,1,.3,1); }
.nav-links a:hover { color:var(--gold); }
.nav-links a:hover::after { right:0; }
.nav-links a.active-link { color:var(--gold); }
.nav-links a.active-link::after { right:0; }
.nav-right { display:flex; align-items:center; gap:20px; }
.nav-bag {
  font-size:9px; letter-spacing:.3em; text-transform:uppercase; font-weight:400;
  border:1px solid rgba(26,26,26,.2); padding:9px 20px; background:none;
  color:var(--obsidian); cursor:none; transition:all .3s;
}
.nav-bag:hover { background:var(--obsidian); color:var(--ivory); border-color:var(--obsidian); }
.nav-hamburger { display:none; background:none; border:none; cursor:none; flex-direction:column; gap:5px; }
.nav-hamburger span { display:block; width:24px; height:1px; background:var(--obsidian); transition:all .3s; }

/* ═══ SHARED COMPONENTS ═══ */
.eyebrow {
  font-size:9px; font-weight:500; letter-spacing:.45em; text-transform:uppercase;
  color:var(--gold); display:flex; align-items:center; gap:14px; margin-bottom:14px;
}
.eyebrow::before { content:''; width:28px; height:1px; background:var(--gold); flex-shrink:0; }
.eyebrow.light { color:var(--gold); }
.eyebrow.light::before { background:var(--gold); }

.section-title {
  font-family:'Cormorant Garamond',serif; font-size:clamp(36px,5vw,60px);
  font-weight:300; letter-spacing:.04em; line-height:1.1; margin-bottom:16px;
}
.section-title em { font-style:italic; }

.body-text { font-size:15px; font-weight:300; line-height:1.85; color:#5A5A5A; }

.btn {
  display:inline-flex; align-items:center; gap:12px;
  font-size:9px; font-weight:400; letter-spacing:.35em; text-transform:uppercase;
  padding:15px 36px; border:1px solid; cursor:none; text-decoration:none;
  transition:all .35s cubic-bezier(.16,1,.3,1);
}
.btn:hover { transform:translateY(-1px); }
.btn-dark { background:var(--obsidian); color:var(--ivory); border-color:var(--obsidian); }
.btn-dark:hover { background:var(--gold); border-color:var(--gold); }
.btn-outline { background:transparent; color:var(--obsidian); border-color:rgba(26,26,26,.25); }
.btn-outline:hover { border-color:var(--obsidian); background:var(--obsidian); color:var(--ivory); }
.btn-cobalt { background:var(--cobalt); color:var(--ivory); border-color:var(--cobalt); }
.btn-cobalt:hover { background:var(--cobalt-deep); border-color:var(--cobalt-deep); }
.btn-gold-outline { background:transparent; color:var(--gold); border-color:rgba(201,168,76,.5); }
.btn-gold-outline:hover { background:var(--gold); color:var(--obsidian); border-color:var(--gold); }
.btn-white-outline { background:transparent; color:var(--white); border-color:rgba(255,255,255,.3); }
.btn-white-outline:hover { background:var(--white); color:var(--obsidian); border-color:var(--white); }

.arrow-icon { width:14px; height:14px; }

/* ── Scroll reveal ── */
.reveal { opacity:0; transform:translateY(28px); transition:opacity .9s cubic-bezier(.16,1,.3,1), transform .9s cubic-bezier(.16,1,.3,1); }
.reveal.in { opacity:1; transform:translateY(0); }
.reveal-l { opacity:0; transform:translateX(-36px); transition:opacity .9s cubic-bezier(.16,1,.3,1), transform .9s cubic-bezier(.16,1,.3,1); }
.reveal-l.in { opacity:1; transform:translateX(0); }
.reveal-r { opacity:0; transform:translateX(36px); transition:opacity .9s cubic-bezier(.16,1,.3,1), transform .9s cubic-bezier(.16,1,.3,1); }
.reveal-r.in { opacity:1; transform:translateX(0); }
.d1 { transition-delay:.1s; } .d2 { transition-delay:.2s; } .d3 { transition-delay:.3s; } .d4 { transition-delay:.4s; }

/* ── Marquee ── */
.marquee-wrap { overflow:hidden; background:var(--gold); padding:16px 0; white-space:nowrap; }
.marquee-track { display:inline-flex; animation:marquee 28s linear infinite; }
.marquee-item { font-family:'Cormorant Garamond',serif; font-size:13px; font-weight:300; font-style:italic; letter-spacing:.1em; color:var(--obsidian); padding:0 36px; }
.marquee-dot { color:var(--obsidian); opacity:.4; font-size:8px; line-height:2; }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ── Page Hero ── */
.page-hero {
  padding: 160px 80px 100px;
  border-bottom: 1px solid var(--rule);
  background: var(--white);
}
.page-hero-inner { max-width:900px; }

/* ── Nav height clearance — all non-hero page tops ── */
.nav-clearance { padding-top: 90px; }

/* ── Placeholder card ── */
.placeholder-card {
  border:1px dashed rgba(201,168,76,.4);
  background:rgba(201,168,76,.03);
  padding:48px;
  text-align:center;
  position:relative;
}
.placeholder-label {
  position:absolute; top:16px; right:16px;
  font-size:8px; letter-spacing:.3em; text-transform:uppercase;
  color:var(--gold); font-weight:500;
  background:rgba(201,168,76,.1); padding:4px 10px;
}
.placeholder-icon { font-size:48px; color:rgba(201,168,76,.3); margin-bottom:16px; line-height:1; }
.placeholder-text { font-size:12px; letter-spacing:.15em; color:var(--mist); text-transform:uppercase; }

/* ── Footer ── */
footer {
  background:var(--obsidian); color:var(--white);
  padding:80px 80px 40px;
}
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; padding-bottom:56px; border-bottom:1px solid rgba(255,255,255,.07); margin-bottom:36px; }
.footer-brand { font-family:'Cormorant Garamond',serif; font-size:24px; font-weight:300; letter-spacing:.4em; display:block; margin-bottom:8px; }
.footer-sub { font-size:9px; letter-spacing:.35em; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:18px; }
.footer-desc { font-size:12px; font-weight:300; color:rgba(255,255,255,.35); line-height:1.8; max-width:240px; }
.footer-head { font-size:9px; font-weight:500; letter-spacing:.35em; text-transform:uppercase; color:var(--gold); margin-bottom:20px; }
.footer-links { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-links a { font-size:12px; font-weight:300; color:rgba(255,255,255,.4); text-decoration:none; letter-spacing:.05em; transition:color .3s; cursor:none; }
.footer-links a:hover { color:var(--gold); }
.footer-email-input { background:transparent; border:none; border-bottom:1px solid rgba(255,255,255,.2); outline:none; font-family:'Jost',sans-serif; font-size:11px; color:var(--white); letter-spacing:.2em; padding:8px 0; width:100%; placeholder:rgba(255,255,255,.2); }
.footer-email-input::placeholder { color:rgba(255,255,255,.2); font-size:10px; letter-spacing:.25em; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; }
.footer-copy { font-size:9px; font-weight:300; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.2); }
.footer-legal { display:flex; gap:28px; list-style:none; }
.footer-legal a { font-size:9px; font-weight:300; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.2); text-decoration:none; transition:color .3s; cursor:none; }
.footer-legal a:hover { color:rgba(255,255,255,.5); }

/* ══════════════════════════════════════
   PAGE 1 — HOMEPAGE
══════════════════════════════════════ */
.hero {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden; background:var(--ivory); text-align:center;
}
.hero-bg { position:absolute; inset:0; background: radial-gradient(ellipse 60% 50% at 20% 60%, rgba(201,168,76,.06) 0%, transparent 60%), radial-gradient(ellipse 40% 50% at 80% 30%, rgba(27,58,122,.05) 0%, transparent 60%); }
.hero-content { position:relative; z-index:2; max-width:800px; padding:0 40px; }
.hero-eyebrow { font-size:9px; font-weight:400; letter-spacing:.35em; text-transform:uppercase; color:var(--gold); margin-bottom:28px; opacity:0; animation:fadeUp 1s cubic-bezier(.16,1,.3,1) .3s forwards; max-width:320px; margin-left:auto; margin-right:auto; }
.hero-brand { font-family:'Cormorant Garamond',serif; font-size:clamp(76px,13vw,140px); font-weight:300; letter-spacing:.2em; color:var(--obsidian); line-height:.9; margin-bottom:24px; opacity:0; animation:fadeUp 1.2s cubic-bezier(.16,1,.3,1) .5s forwards; }
.hero-rule { width:80px; height:1px; background:linear-gradient(to right,transparent,var(--gold),transparent); margin:0 auto 24px; opacity:0; animation:fadeIn 1s ease .9s forwards; }
.hero-tagline { font-family:'Cormorant Garamond',serif; font-size:clamp(18px,2.5vw,26px); font-weight:300; font-style:italic; color:rgba(26,26,26,.6); margin-bottom:48px; line-height:1.5; opacity:0; animation:fadeUp 1s cubic-bezier(.16,1,.3,1) 1s forwards; }
.hero-ctas { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; opacity:0; animation:fadeUp 1s cubic-bezier(.16,1,.3,1) 1.2s forwards; }
.scroll-hint { position:absolute; bottom:40px; left:50%; transform:translateX(-50%); z-index:2; display:flex; flex-direction:column; align-items:center; gap:8px; opacity:0; animation:fadeIn 1s ease 1.8s forwards; cursor:none; }
.scroll-line { width:1px; height:48px; background:linear-gradient(to bottom,rgba(201,168,76,.8),transparent); animation:pulse 2s ease infinite; }
.scroll-text { font-size:8px; letter-spacing:.4em; text-transform:uppercase; color:var(--gold); }
@keyframes fadeUp { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
@keyframes pulse { 0%,100%{opacity:.4} 50%{opacity:1} }

/* Trust bar */
.trust-bar { display:grid; grid-template-columns:repeat(4,1fr); background:var(--white); border-top:1px solid rgba(201,168,76,.12); border-bottom:1px solid rgba(201,168,76,.12); }
.trust-item { padding:40px 24px; display:flex; flex-direction:column; align-items:center; gap:14px; text-align:center; border-right:1px solid var(--rule); }
.trust-item:last-child { border-right:none; }
.trust-icon-box { width:44px; height:44px; border:1px solid rgba(201,168,76,.3); display:flex; align-items:center; justify-content:center; }
.trust-icon-box svg { width:20px; height:20px; stroke:var(--gold); fill:none; stroke-width:1.5; }
.trust-label { font-size:9px; font-weight:400; letter-spacing:.3em; text-transform:uppercase; }

/* Product feature */
.product-feature { max-width:1320px; margin:0 auto; padding:120px 80px; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.product-img-frame { position:relative; aspect-ratio:4/5; background:#EEEEE8; overflow:hidden; }
.product-img-frame img { width:100%; height:100%; object-fit:cover; transition:transform .8s cubic-bezier(.16,1,.3,1); }
.product-img-frame:hover img { transform:scale(1.04); }
.product-badge-tag { position:absolute; top:24px; left:24px; font-size:9px; letter-spacing:.3em; text-transform:uppercase; background:rgba(250,250,247,.92); padding:8px 16px; backdrop-filter:blur(8px); }
.ingredient-grid-mini { display:grid; grid-template-columns:1fr 1fr; border:1px solid rgba(201,168,76,.2); margin:28px 0; }
.ing-cell { padding:18px; border-right:1px solid rgba(201,168,76,.2); border-bottom:1px solid rgba(201,168,76,.2); }
.ing-cell:nth-child(even) { border-right:none; }
.ing-cell:nth-last-child(-n+2) { border-bottom:none; }
.ing-name { font-size:9px; font-weight:500; letter-spacing:.25em; text-transform:uppercase; color:var(--gold-dark); margin-bottom:4px; }
.ing-desc { font-size:12px; color:#6A6A6A; line-height:1.6; }
.product-meta { display:flex; gap:32px; padding-top:24px; border-top:1px solid var(--rule); margin-top:8px; }
.meta-item-label { font-size:9px; letter-spacing:.3em; text-transform:uppercase; color:var(--mist); margin-bottom:4px; }
.meta-item-val { font-family:'Cormorant Garamond',serif; font-size:18px; font-weight:300; }

/* Clean story teaser */
.clean-teaser { background:var(--obsidian); padding:120px 80px; position:relative; overflow:hidden; }
.clean-teaser::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 0% 50%,rgba(27,58,122,.18) 0%,transparent 60%), radial-gradient(ellipse 40% 60% at 100% 0%,rgba(201,168,76,.08) 0%,transparent 50%); }
.clean-teaser-inner { max-width:1320px; margin:0 auto; position:relative; z-index:1; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.exclude-list { list-style:none; margin:28px 0; }
.exclude-item { display:flex; align-items:center; gap:14px; padding:12px 0; border-bottom:1px solid rgba(255,255,255,.06); font-size:13px; font-weight:300; color:rgba(255,255,255,.55); }
.ex-mark { width:20px; height:20px; border:1px solid rgba(201,168,76,.35); display:flex; align-items:center; justify-content:center; font-size:10px; color:var(--gold); flex-shrink:0; }
.clean-quote { margin-top:24px; padding:20px 24px; border:1px solid rgba(201,168,76,.2); background:rgba(201,168,76,.04); }
.clean-quote p { font-family:'Cormorant Garamond',serif; font-size:17px; font-style:italic; color:rgba(255,255,255,.5); line-height:1.6; }
.clean-quote em { color:var(--gold); }

/* Email capture */
.email-capture { padding:120px 80px; text-align:center; background:var(--white); }
.email-form { display:flex; max-width:440px; margin:36px auto 0; border:1px solid rgba(26,26,26,.2); }
.email-inp { flex:1; background:transparent; border:none; outline:none; font-family:'Jost',sans-serif; font-size:12px; font-weight:300; color:var(--obsidian); padding:14px 18px; letter-spacing:.05em; }
.email-inp::placeholder { color:var(--mist); font-size:10px; letter-spacing:.2em; }
.email-sub { background:var(--obsidian); color:var(--ivory); border:none; font-family:'Jost',sans-serif; font-size:9px; font-weight:400; letter-spacing:.3em; text-transform:uppercase; padding:14px 24px; cursor:none; transition:background .3s; flex-shrink:0; }
.email-sub:hover { background:var(--gold); }
.email-note { font-size:11px; color:var(--mist); margin-top:10px; letter-spacing:.08em; }

/* ══════════════════════════════════════
   PAGE 2 — SHOP
══════════════════════════════════════ */
.shop-filter-bar { display:flex; gap:0; padding:0 80px; border-bottom:1px solid var(--rule); background:var(--white); overflow-x:auto; }
.filter-tab { font-size:9px; font-weight:400; letter-spacing:.3em; text-transform:uppercase; padding:18px 28px; border-bottom:2px solid transparent; color:var(--mist); cursor:none; transition:all .3s; white-space:nowrap; background:none; border-left:none; border-right:none; border-top:none; }
.filter-tab:hover, .filter-tab.active { color:var(--obsidian); border-bottom-color:var(--gold); }
.products-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--rule); padding:0; margin:0; }
.product-card { background:var(--ivory); position:relative; overflow:hidden; cursor:none; }
.product-card:hover .product-card-img { transform:scale(1.04); }
.product-card-img-wrap { aspect-ratio:3/4; overflow:hidden; background:#EEEEE8; }
.product-card-img { width:100%; height:100%; object-fit:cover; transition:transform .7s cubic-bezier(.16,1,.3,1); }
.product-card-info { padding:24px 28px 32px; }
.product-card-tag { font-size:8px; letter-spacing:.35em; text-transform:uppercase; color:var(--gold); margin-bottom:8px; }
.product-card-name { font-family:'Cormorant Garamond',serif; font-size:22px; font-weight:300; letter-spacing:.04em; margin-bottom:6px; }
.product-card-desc { font-size:12px; color:var(--mist); line-height:1.6; margin-bottom:16px; }
.product-card-footer { display:flex; align-items:center; justify-content:space-between; }
.product-price { font-family:'Cormorant Garamond',serif; font-size:20px; font-weight:300; }
.add-to-bag { font-size:8px; letter-spacing:.25em; text-transform:uppercase; background:var(--obsidian); color:var(--ivory); border:none; padding:10px 18px; cursor:none; transition:background .3s; }
.add-to-bag:hover { background:var(--cobalt); }
.product-card-badge { position:absolute; top:16px; left:16px; font-size:8px; letter-spacing:.25em; text-transform:uppercase; background:var(--obsidian); color:var(--ivory); padding:5px 12px; }
.product-card-badge.gold { background:var(--gold); color:var(--obsidian); }
.coming-soon-card { background:var(--white); border:1px dashed rgba(201,168,76,.35); display:flex; flex-direction:column; align-items:center; justify-content:center; padding:80px 40px; text-align:center; gap:16px; min-height:480px; }
.cs-label { font-size:9px; letter-spacing:.35em; text-transform:uppercase; color:var(--gold); }
.cs-name { font-family:'Cormorant Garamond',serif; font-size:28px; font-weight:300; color:rgba(26,26,26,.4); }
.cs-sub { font-size:11px; color:var(--mist); }

/* ══════════════════════════════════════
   PAGE 3 — PRODUCT DETAIL
══════════════════════════════════════ */
.pdp-wrap { max-width:1320px; margin:0 auto; padding:140px 80px 100px; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start; }
.pdp-gallery { display:flex; flex-direction:column; gap:2px; }
.pdp-main-img { aspect-ratio:4/5; background:#EEEEE8; overflow:hidden; position:relative; }
.pdp-main-img img { width:100%; height:100%; object-fit:cover; }
.pdp-thumbs { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; }
.pdp-thumb { aspect-ratio:1; background:#EEEEE8; overflow:hidden; cursor:none; opacity:.5; transition:opacity .3s; }
.pdp-thumb:hover { opacity:1; }
.pdp-thumb img { width:100%; height:100%; object-fit:cover; }
.pdp-info { padding-top:8px; }
.pdp-tag { font-size:9px; letter-spacing:.35em; text-transform:uppercase; color:var(--gold); margin-bottom:12px; }
.pdp-name { font-family:'Cormorant Garamond',serif; font-size:clamp(40px,4vw,56px); font-weight:300; line-height:1.05; margin-bottom:16px; }
.pdp-subtitle { font-family:'Cormorant Garamond',serif; font-size:18px; font-weight:300; font-style:italic; color:var(--mist); margin-bottom:24px; }
.pdp-price { font-family:'Cormorant Garamond',serif; font-size:32px; font-weight:300; margin-bottom:28px; }
.pdp-price span { font-size:13px; font-weight:300; color:var(--mist); font-family:'Jost',sans-serif; margin-left:8px; }
.pdp-desc { font-size:15px; font-weight:300; color:#5A5A5A; line-height:1.85; margin-bottom:32px; padding-bottom:32px; border-bottom:1px solid var(--rule); }
.pdp-options { margin-bottom:28px; }
.pdp-option-label { font-size:9px; letter-spacing:.35em; text-transform:uppercase; margin-bottom:12px; color:var(--obsidian); }
.size-selector { display:flex; gap:8px; }
.size-btn { border:1px solid var(--rule); padding:10px 20px; font-size:11px; letter-spacing:.1em; cursor:none; transition:all .3s; background:transparent; }
.size-btn.selected { border-color:var(--obsidian); background:var(--obsidian); color:var(--ivory); }
.pdp-actions { display:flex; flex-direction:column; gap:10px; margin-bottom:32px; }
.pdp-accordion { border-top:1px solid var(--rule); }
.accordion-item { border-bottom:1px solid var(--rule); }
.accordion-trigger { width:100%; display:flex; justify-content:space-between; align-items:center; padding:18px 0; background:none; border:none; cursor:none; text-align:left; }
.accordion-trigger-text { font-size:11px; letter-spacing:.2em; text-transform:uppercase; font-weight:400; }
.accordion-icon { font-size:18px; color:var(--gold); transition:transform .3s; line-height:1; }
.accordion-content { overflow:hidden; max-height:0; transition:max-height .4s cubic-bezier(.16,1,.3,1); }
.accordion-content.open { max-height:400px; }
.accordion-inner { padding:0 0 20px; font-size:13px; font-weight:300; color:#6A6A6A; line-height:1.8; }
.inci-list { font-size:11px; color:var(--mist); letter-spacing:.05em; line-height:2; font-family:'Jost',sans-serif; }

/* ══════════════════════════════════════
   PAGE 4 — THE CLEAN STORY
══════════════════════════════════════ */
.clean-hero { background:var(--obsidian); padding:160px 80px 100px; position:relative; overflow:hidden; }
.clean-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 50% 80% at 10% 50%,rgba(27,58,122,.2) 0%,transparent 60%); }
.clean-hero-inner { max-width:900px; position:relative; z-index:1; }
.in-out-grid { display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--rule); margin:64px 80px; }
.in-col, .out-col { background:var(--white); padding:48px; }
.col-header { font-size:9px; letter-spacing:.4em; text-transform:uppercase; margin-bottom:28px; padding-bottom:16px; border-bottom:2px solid; }
.col-header.green { color:#2D6A4F; border-color:#2D6A4F; }
.col-header.red { color:#9B2335; border-color:#9B2335; }
.ingredient-row { display:flex; gap:16px; padding:14px 0; border-bottom:1px solid var(--rule); align-items:flex-start; }
.ingredient-row:last-child { border-bottom:none; }
.ing-check { width:18px; height:18px; border:1px solid rgba(45,106,79,.4); display:flex; align-items:center; justify-content:center; font-size:10px; color:#2D6A4F; flex-shrink:0; margin-top:2px; }
.ing-x { width:18px; height:18px; border:1px solid rgba(155,35,53,.3); display:flex; align-items:center; justify-content:center; font-size:10px; color:#9B2335; flex-shrink:0; margin-top:2px; }
.ing-info { flex:1; }
.ing-title { font-size:12px; font-weight:400; letter-spacing:.05em; margin-bottom:2px; }
.ing-function { font-size:11px; color:var(--mist); line-height:1.5; }
.standard-banner { background:var(--cobalt); padding:80px; text-align:center; }
.standard-banner h2 { font-family:'Cormorant Garamond',serif; font-size:clamp(32px,4vw,52px); font-weight:300; color:var(--white); margin-bottom:12px; }
.standard-banner p { font-size:14px; font-weight:300; color:rgba(255,255,255,.55); max-width:560px; margin:0 auto 32px; line-height:1.8; }

/* ══════════════════════════════════════
   PAGE 5 — OUR RITUAL
══════════════════════════════════════ */
.ritual-hero { background:var(--ivory); padding:160px 80px 100px; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; max-width:1320px; margin:0 auto; }
.ritual-hero-text .section-title { font-size:clamp(42px,5vw,64px); }

/* ── Grid overlap fix ── */
.products-grid, .journal-grid, .in-out-grid, .verify-features, .values-grid { overflow:hidden; }
.ingredient-grid-mini, .footer-grid { overflow:visible; }
.ritual-img { aspect-ratio:3/4; background:#E8E4DC; overflow:hidden; }
.ritual-img img { width:100%; height:100%; object-fit:cover; }
.story-text-section { max-width:680px; margin:0 auto; padding:100px 80px; }
.story-p { font-family:'Cormorant Garamond',serif; font-size:20px; font-weight:300; line-height:1.85; color:var(--obsidian); margin-bottom:28px; }
.story-p em { color:var(--gold-dark); font-style:italic; }
.story-pull { font-family:'Cormorant Garamond',serif; font-size:28px; font-weight:300; font-style:italic; text-align:center; color:var(--obsidian); border-left:2px solid var(--gold); padding:20px 40px; margin:48px 0; line-height:1.5; }
.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--rule); margin:0 80px 80px; }
.value-card { background:var(--white); padding:40px; }
.value-num { font-family:'Cormorant Garamond',serif; font-size:40px; font-weight:300; color:var(--gold-light); line-height:1; margin-bottom:16px; }
.value-title { font-family:'Cormorant Garamond',serif; font-size:22px; font-weight:300; margin-bottom:10px; }
.value-text { font-size:13px; font-weight:300; color:#6A6A6A; line-height:1.7; }

/* ══════════════════════════════════════
   PAGE 6 — VERIFICATION
══════════════════════════════════════ */
.verify-hero { min-height:80vh; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:160px 80px 100px; background:var(--obsidian); position:relative; overflow:hidden; }
.verify-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(27,58,122,.25) 0%,transparent 70%); }
.verify-content { position:relative; z-index:1; max-width:700px; }
.verify-badge { width:100px; height:100px; border:1px solid rgba(201,168,76,.4); border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto 40px; position:relative; }
.verify-badge::before { content:''; position:absolute; inset:6px; border:1px solid rgba(201,168,76,.2); border-radius:50%; }
.verify-badge svg { width:40px; height:40px; stroke:var(--gold); fill:none; stroke-width:1; }
.verify-ring { position:absolute; inset:-20px; border:1px solid rgba(201,168,76,.1); border-radius:50%; animation:spin 12s linear infinite; }
@keyframes spin { to{transform:rotate(360deg)} }
.verify-coming { display:inline-block; font-size:8px; letter-spacing:.4em; text-transform:uppercase; background:rgba(201,168,76,.15); color:var(--gold); border:1px solid rgba(201,168,76,.3); padding:8px 24px; margin-bottom:28px; }
.verify-features { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:rgba(255,255,255,.05); margin:64px 80px; }
.verify-feature { background:rgba(250,250,247,.03); padding:40px; text-align:center; }
.verify-feature-icon { font-size:28px; margin-bottom:16px; }
.verify-feature-title { font-family:'Cormorant Garamond',serif; font-size:20px; font-weight:300; color:var(--white); margin-bottom:8px; }
.verify-feature-text { font-size:12px; font-weight:300; color:rgba(255,255,255,.4); line-height:1.7; }
.notify-form { display:flex; max-width:400px; margin:32px auto 0; border:1px solid rgba(255,255,255,.2); }
.notify-inp { flex:1; background:transparent; border:none; outline:none; font-family:'Jost',sans-serif; font-size:11px; color:var(--white); letter-spacing:.15em; padding:14px 18px; }
.notify-inp::placeholder { color:rgba(255,255,255,.2); font-size:10px; letter-spacing:.2em; }
.notify-sub { background:var(--gold); color:var(--obsidian); border:none; font-family:'Jost',sans-serif; font-size:9px; font-weight:500; letter-spacing:.25em; text-transform:uppercase; padding:14px 20px; cursor:none; flex-shrink:0; }

/* ══════════════════════════════════════
   PAGE 7 — JOURNAL
══════════════════════════════════════ */
.journal-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--rule); margin:0; }
.journal-card { background:var(--white); overflow:hidden; cursor:none; }
.journal-card:hover .journal-img { transform:scale(1.04); }
.journal-card-img-wrap { aspect-ratio:3/2; overflow:hidden; background:#EEEEE8; }
.journal-img { width:100%; height:100%; object-fit:cover; transition:transform .7s cubic-bezier(.16,1,.3,1); }
.journal-card-body { padding:28px; }
.journal-cat { font-size:8px; letter-spacing:.35em; text-transform:uppercase; color:var(--gold); margin-bottom:10px; }
.journal-title { font-family:'Cormorant Garamond',serif; font-size:22px; font-weight:300; line-height:1.3; margin-bottom:10px; letter-spacing:.02em; }
.journal-excerpt { font-size:12px; color:var(--mist); line-height:1.7; margin-bottom:16px; }
.journal-read { font-size:9px; letter-spacing:.3em; text-transform:uppercase; color:var(--obsidian); display:flex; align-items:center; gap:8px; }
.journal-read svg { width:14px; height:14px; stroke:var(--gold); fill:none; stroke-width:1.5; }
.journal-hero-card { grid-column:1 / -1; display:grid; grid-template-columns:1fr 1fr; }
.journal-hero-card .journal-card-img-wrap { aspect-ratio:auto; min-height:400px; }
.journal-hero-card .journal-card-body { display:flex; flex-direction:column; justify-content:center; padding:56px; }
.journal-hero-card .journal-title { font-size:36px; margin-bottom:16px; }

/* ══════════════════════════════════════
   PAGE 8 — CONTACT
══════════════════════════════════════ */
.contact-wrap { display:grid; grid-template-columns:1fr 1fr; max-width:1320px; margin:0 auto; padding:140px 80px 100px; gap:80px; }
.contact-form { display:flex; flex-direction:column; gap:20px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-field { display:flex; flex-direction:column; gap:8px; }
.form-label { font-size:9px; letter-spacing:.35em; text-transform:uppercase; color:var(--obsidian); font-weight:400; }
.form-input, .form-select, .form-textarea { background:var(--white); border:1px solid var(--rule); padding:14px 18px; font-family:'Jost',sans-serif; font-size:13px; font-weight:300; color:var(--obsidian); outline:none; transition:border-color .3s; }
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color:var(--gold); }
.form-textarea { resize:vertical; min-height:140px; }
.form-select { appearance:none; cursor:none; }
.contact-info { display:flex; flex-direction:column; gap:32px; padding-top:8px; }
.contact-block-label { font-size:9px; letter-spacing:.35em; text-transform:uppercase; color:var(--gold); margin-bottom:8px; font-weight:500; }
.contact-block-val { font-family:'Cormorant Garamond',serif; font-size:20px; font-weight:300; }
.contact-block-sub { font-size:12px; color:var(--mist); margin-top:4px; line-height:1.6; }
.contact-divider { height:1px; background:var(--rule); margin:8px 0; }
.social-row { display:flex; gap:0; }
.social-link { font-size:9px; letter-spacing:.25em; text-transform:uppercase; color:var(--obsidian); text-decoration:none; padding:12px 20px; border:1px solid var(--rule); cursor:none; transition:all .3s; }
.social-link:not(:last-child) { border-right:none; }
.social-link:hover { background:var(--obsidian); color:var(--ivory); border-color:var(--obsidian); }

/* ═══ TOAST ═══ */
#toast { position:fixed; bottom:40px; right:40px; background:var(--obsidian); color:var(--white); padding:14px 22px; z-index:1000; font-size:12px; letter-spacing:.1em; opacity:0; transform:translateY(12px); transition:all .4s cubic-bezier(.16,1,.3,1); pointer-events:none; border-left:2px solid var(--gold); }
#toast.show { opacity:1; transform:translateY(0); }

/* ═══ RESPONSIVE ═══ */
@media(max-width:1024px) {
  nav { padding:20px 32px; }
  nav.scrolled, nav.inner-page { padding:16px 32px; }
  .nav-links { gap:20px; }
  .product-feature, .clean-teaser-inner, .contact-wrap { gap:48px; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:36px; }
}
@media(max-width:768px) {
  body { cursor:auto; }
  #cursor, #cursor-ring { display:none; }
  nav { padding:18px 24px; }
  nav.scrolled, nav.inner-page { padding:14px 24px; }
  .nav-links { display:none !important; }
  .nav-hamburger { display:flex; }
  .hero-brand { font-size:clamp(56px,15vw,100px); }
  .trust-bar { grid-template-columns:repeat(2,1fr); }
  .trust-item { border-right:none !important; border-bottom:1px solid var(--rule); }
  .trust-item:nth-last-child(-n+2) { border-bottom:none; }
  .product-feature, .clean-teaser-inner, .ritual-hero, .pdp-wrap, .contact-wrap { grid-template-columns:1fr !important; gap:40px; padding:100px 24px 60px; }
  .clean-teaser { padding:80px 24px; }
  .in-out-grid { grid-template-columns:1fr !important; margin:40px 24px; }
  .products-grid { grid-template-columns:1fr !important; }
  .journal-grid { grid-template-columns:1fr !important; }
  .journal-hero-card { grid-template-columns:1fr !important; }
  .values-grid { grid-template-columns:1fr !important; margin:0 24px 48px; }
  .verify-features { grid-template-columns:1fr !important; margin:40px 24px; }
  .page-hero, .clean-hero, .verify-hero, .story-text-section { padding:120px 24px 60px; }
  .shop-filter-bar { padding:0 24px; }
  .standard-banner { padding:60px 24px; }
  .footer-grid { grid-template-columns:1fr !important; gap:32px; }
  footer { padding:60px 24px 32px; }
  .footer-bottom { flex-direction:column; gap:12px; text-align:center; }
  .form-row { grid-template-columns:1fr !important; }
  .email-capture { padding:80px 24px; }
  .email-form { flex-direction:column; }
  .email-sub { width:100%; padding:14px; text-align:center; }
  .pdp-thumbs { grid-template-columns:repeat(4,1fr); }
  .product-meta { flex-wrap:wrap; gap:20px; }
}
