/* ========================================================================
   LUMORA — premium reading light store
   Warm editorial · cream / ink / amber
   ======================================================================== */

:root{
  --bg:        #F5EEE2;
  --bg-deep:   #EDE3D1;
  --surface:   #FBF6EC;
  --ink:       #1B1815;
  --ink-2:     #3A332C;
  --muted:     #6E6557;
  --hair:      #D7CBB5;
  --line:      #B8A989;
  --amber:     #C8925A;
  --amber-d:   #8E5B2A;
  --amber-s:   #EAD3B0;
  --amber-g:   #F6CB83;
  --success:   #4a6a4a;
  --radius:    14px;
  --radius-lg: 24px;
  --shadow-sm: 0 1px 2px rgba(27,24,21,.06), 0 2px 4px rgba(27,24,21,.04);
  --shadow:    0 10px 30px -12px rgba(27,24,21,.18), 0 2px 8px rgba(27,24,21,.06);
  --shadow-lg: 0 40px 80px -20px rgba(27,24,21,.28), 0 8px 20px rgba(27,24,21,.08);
  --container: min(1680px, 94vw);
  --container-wide: min(1840px, 97vw);
  --container-read: min(1100px, 88vw);
  --ease:      cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter Tight', 'Inter', system-ui, -apple-system, sans-serif;
  font-weight:400;
  font-size:17px;
  line-height:1.55;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}

/* —— typography —— */
.display{
  font-family:'Fraunces', 'Georgia', serif;
  font-weight:400;
  font-variation-settings:"SOFT" 50, "WONK" 0, "opsz" 120;
  letter-spacing:-0.02em;
  line-height:0.98;
}
.display em{font-style:italic;font-weight:400;color:var(--amber-d)}
h1.display{font-size:clamp(3.2rem, 7vw, 6.5rem)}
.display--2{font-size:clamp(2.2rem, 4.4vw, 4rem);line-height:1.02}
.display--3{font-size:clamp(1.5rem, 2.6vw, 2.2rem);line-height:1.15}

.eyebrow{
  font-size:11px;
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--amber-d);
  display:inline-flex;align-items:center;gap:.5rem;
  margin-bottom:1.1rem;
}
.eyebrow .dot-live{
  width:7px;height:7px;border-radius:999px;background:var(--amber);
  box-shadow:0 0 0 0 var(--amber);
  animation:pulse 2.4s var(--ease) infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(200,146,90,.55)}
  70%{box-shadow:0 0 0 8px rgba(200,146,90,0)}
  100%{box-shadow:0 0 0 0 rgba(200,146,90,0)}
}

.muted{color:var(--muted)}

/* —— buttons —— */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:.5rem;
  padding:16px 26px;
  border-radius:999px;
  font-weight:500;
  font-size:15px;
  letter-spacing:.01em;
  transition:transform .2s var(--ease), background .2s var(--ease), color .2s var(--ease), box-shadow .3s var(--ease);
  cursor:pointer;
  white-space:nowrap;
}
.btn--primary{
  background:var(--ink);color:var(--bg);
  box-shadow:0 10px 24px -8px rgba(27,24,21,.4);
}
.btn--primary:hover{
  background:var(--amber-d);
  transform:translateY(-1px);
  box-shadow:0 16px 30px -10px rgba(142,91,42,.55);
}
.btn--ghost{
  background:transparent;color:var(--ink);
  border:1px solid var(--line);
}
.btn--ghost:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.btn--full{width:100%}

/* —— marquee —— */
.marquee{
  background:var(--ink);color:var(--bg);
  overflow:hidden;
  padding:10px 0;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
}
.marquee__track{
  display:flex;gap:2rem;white-space:nowrap;
  animation:slide 40s linear infinite;
  width:max-content;
}
.marquee .dot{color:var(--amber)}
@keyframes slide{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* —— nav —— */
.nav{
  position:sticky;top:0;z-index:50;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;
  gap:2rem;
  padding:18px max(1.5rem, 3vw);
  background:color-mix(in srgb, var(--bg) 82%, transparent);
  backdrop-filter:saturate(160%) blur(18px);
  -webkit-backdrop-filter:saturate(160%) blur(18px);
  border-bottom:1px solid color-mix(in srgb, var(--line) 30%, transparent);
}
.logo{display:inline-flex;align-items:center;gap:.5rem;font-family:Fraunces;font-weight:500;font-size:22px;letter-spacing:-.01em}
.logo svg{color:var(--amber-d)}
.nav__links{display:flex;gap:2.2rem;justify-content:center;font-size:14.5px;font-weight:450}
.nav__links a{position:relative;padding:2px 0;color:var(--ink-2)}
.nav__links a:hover{color:var(--ink)}
.nav__links a:after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;background:var(--amber-d);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.nav__links a:hover:after{transform:scaleX(1)}
.nav__actions{display:flex;gap:.4rem;align-items:center}
.nav__icon, .nav__cart{
  width:40px;height:40px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--ink);
  transition:background .2s var(--ease);
  position:relative;
}
.nav__icon:hover, .nav__cart:hover{background:color-mix(in srgb, var(--hair) 50%, transparent)}
.cart-count{
  position:absolute;top:4px;right:4px;
  background:var(--amber-d);color:var(--bg);
  font-size:10px;font-weight:600;
  min-width:16px;height:16px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  padding:0 4px;
}

/* —— HERO —— */
.hero{
  position:relative;
  padding:40px max(1.5rem, 3vw) 100px;
  overflow:hidden;
  isolation:isolate;
}
.hero__grain{
  position:absolute;inset:0;pointer-events:none;z-index:0;opacity:.5;
  background:
    radial-gradient(1200px 600px at 75% 30%, rgba(246,203,131,.35), transparent 60%),
    radial-gradient(900px 500px at 10% 90%, rgba(200,146,90,.12), transparent 60%);
}
.hero__inner{
  max-width:var(--container-wide);margin:0 auto;
  display:grid;grid-template-columns:1.2fr 1fr;
  gap:4rem;align-items:center;
  position:relative;z-index:1;
  min-height:82vh;
}

/* PDP right column */
.hero__pdp{
  max-width:560px;
}
.display--pdp{
  font-size:clamp(2.4rem, 3.4vw, 3.6rem);
  line-height:1;letter-spacing:-.02em;
  margin:.5rem 0 1rem;
}
.pdp-tm{font-size:.4em;vertical-align:super;color:var(--amber-d);font-style:italic;margin-left:2px}
.pdp__tagline{
  font-size:17px;line-height:1.55;color:var(--ink-2);max-width:48ch;margin-bottom:1.2rem;
}
.pdp__tagline em{font-style:italic;color:var(--amber-d)}
.pdp__rating{
  display:inline-flex;align-items:center;gap:.4rem;margin-bottom:1.2rem;font-size:14px;color:var(--ink-2);
}
.pdp__price{display:flex;align-items:baseline;gap:.7rem;margin-bottom:1.3rem}
.pdp__price b{font-family:Fraunces;font-size:36px;color:var(--ink);font-weight:500;letter-spacing:-.02em}
.pdp__price s{color:var(--muted);font-size:18px;opacity:.7}
.pdp__save{
  background:var(--amber-s);color:var(--amber-d);
  padding:4px 10px;border-radius:999px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;
  margin-left:.3rem;
}
.pdp__options{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.3rem}
.pdp__options .buy__option{margin:0}
.pdp__options .buy__option label{padding:14px 16px;gap:.8rem}
.pdp__options .opt__main strong{font-size:16px}
.pdp__options .opt__main span{font-size:12.5px;margin-top:1px}
.pdp__options .opt__price b{font-size:19px}
.pdp__options .opt__price s{font-size:12px}

.hero__pdp .buy__colors{margin:0 0 1.3rem}

.pdp__trust{
  list-style:none;display:flex;gap:1.2rem;flex-wrap:wrap;
  margin-top:1.2rem;padding-top:1.2rem;
  border-top:1px solid var(--hair);
  color:var(--ink-2);font-size:13px;
}
.pdp__trust li{display:inline-flex;align-items:center;gap:.4rem}
.pdp__meta{
  display:flex;justify-content:space-between;gap:1rem;margin-top:.7rem;
  font-size:12px;color:var(--muted);
}
.pdp__meta strong{color:var(--ink);font-weight:600}
.pdp__meta span{display:inline-flex;align-items:center;gap:.4rem}
.hero__copy{max-width:620px}
.h-line{display:block}
.lede{
  font-size:19px;line-height:1.55;color:var(--ink-2);
  margin:2rem 0;max-width:54ch;
}
.hero__rating{display:inline-flex;align-items:center;gap:.55rem;margin-bottom:2rem;font-size:14.5px;color:var(--ink-2)}
.stars{display:inline-flex;gap:1px;color:var(--amber-d);font-size:17px;letter-spacing:1px}
.stars--sm{font-size:13px;letter-spacing:0}
.stars--lg{font-size:26px;letter-spacing:2px}
.hero__cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:2rem}
.trust-row{list-style:none;display:flex;gap:2rem;flex-wrap:wrap;color:var(--ink-2);font-size:14px}
.trust-row li{display:inline-flex;align-items:center;gap:.5rem}

/* hero stage — cinematic photo */
.hero__stage{
  position:relative;min-height:640px;
  display:flex;align-items:center;justify-content:center;
}
.hero__photo{
  position:relative;width:100%;aspect-ratio:4/5;max-height:720px;
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-lg);
  margin:0;
}
.hero__photo img{
  width:100%;height:100%;object-fit:cover;
  animation:kenburns 20s ease-in-out infinite alternate;
}
@keyframes kenburns{
  from{transform:scale(1.02) translate(0,0)}
  to  {transform:scale(1.08) translate(-2%, -1%)}
}
.hero__photo-grain{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(120% 60% at 50% 100%, rgba(15,10,8,.5), transparent 55%),
    radial-gradient(80% 40% at 50% 0%, rgba(15,10,8,.25), transparent 60%);
  mix-blend-mode:multiply;
}
.chip{
  position:absolute;z-index:2;
  background:var(--surface);
  border:1px solid color-mix(in srgb, var(--line) 50%, transparent);
  border-radius:14px;
  padding:10px 14px;
  display:flex;flex-direction:column;
  box-shadow:var(--shadow);
  min-width:90px;
}
.chip strong{font-family:Fraunces;font-size:22px;color:var(--amber-d);line-height:1}
.chip span{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:4px}
.chip--1{top:6%;left:-6%;transform:rotate(-4deg)}
.chip--2{top:42%;right:-6%;transform:rotate(3deg)}
.chip--3{bottom:10%;left:-4%;transform:rotate(-2deg)}

/* —— PRESS STRIP —— */
.press{
  border-top:1px solid var(--hair);
  border-bottom:1px solid var(--hair);
  padding:28px max(1.5rem, 3vw);
  display:grid;grid-template-columns:auto 1fr;align-items:center;gap:2rem;
  background:var(--bg-deep);
}
.press__label{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:600;
}
.press__logos{
  display:flex;align-items:center;justify-content:space-around;gap:3rem;flex-wrap:wrap;
}
.press-logo{white-space:nowrap;color:var(--ink-2);font-size:22px;opacity:.78}
.press-logo--img{
  height:32px;width:auto;object-fit:contain;
  filter:grayscale(1) brightness(.25) contrast(1.2);
  opacity:.72;
  transition:opacity .3s var(--ease), filter .3s var(--ease);
}
.press-logo--img:hover{opacity:1;filter:grayscale(1) brightness(.15)}

/* —— FINISHES —— */
.finishes{padding:120px max(1.5rem, 3vw);background:#F7EFE0}
.finishes__grid{
  max-width:var(--container-wide);margin:0 auto;
  display:grid;grid-template-columns:1fr 1.3fr;gap:5rem;align-items:center;
}
.finishes__copy h2{margin:.5rem 0 1.3rem}
.finishes__copy p{color:var(--muted);font-size:17px;line-height:1.65;max-width:42ch}
.finishes__dots{
  list-style:none;margin-top:2rem;display:flex;flex-direction:column;gap:.8rem;
  font-size:15px;color:var(--ink-2);
}
.finishes__dots li{display:flex;align-items:center;gap:.8rem}
.finishes__dots span{
  width:22px;height:22px;border-radius:999px;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.12), 0 2px 6px rgba(0,0,0,.08);
}
.finishes__photo{
  margin:0;border-radius:var(--radius-lg);overflow:hidden;
  background:#EDE3D0;aspect-ratio:1/1;
  box-shadow:var(--shadow);
}
.finishes__photo img{width:100%;height:100%;object-fit:cover}

/* —— MOMENTS —— */
.moments{padding:40px max(1.5rem, 3vw) 120px;background:var(--bg-deep);border-bottom:1px solid var(--hair)}
.moments__grid{
  max-width:var(--container-wide);margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
}
.moments__grid figure{position:relative;margin:0;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow);transition:transform .35s var(--ease)}
.moments__grid figure:hover{transform:translateY(-4px) scale(1.01)}
.moments__grid img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.moments__grid figure:hover img{transform:scale(1.04)}
.moments__grid figcaption{
  position:absolute;left:0;right:0;bottom:0;
  padding:20px 22px;
  color:#F5EEE2;font-size:13.5px;font-family:Fraunces;font-style:italic;letter-spacing:.01em;
  background:linear-gradient(180deg, transparent, rgba(10,8,6,.78));
}

/* —— COMMUNITY —— */
.community{padding:120px max(1.5rem, 3vw)}
.community__grid{
  max-width:var(--container-wide);margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;
}
.inbox{
  background:#fff;border:1px solid var(--hair);border-radius:var(--radius);
  padding:24px 22px;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;gap:.7rem;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.inbox:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.inbox__head{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.7rem;margin-bottom:.2rem}
.inbox__avatar{
  width:40px;height:40px;border-radius:999px;color:#fff;
  display:grid;place-items:center;
  font-family:Fraunces;font-weight:500;font-size:18px;letter-spacing:0;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.15);
}
.inbox__who strong{display:block;font-size:14px;font-weight:500;color:var(--ink);letter-spacing:-.005em}
.inbox__who span{display:block;font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}
.inbox__time{font-size:11.5px;color:var(--muted);letter-spacing:.02em}
.inbox h4{font-family:Fraunces;font-weight:500;font-size:19px;letter-spacing:-.01em;line-height:1.25;margin:.2rem 0 .1rem}
.inbox h4 em{color:var(--amber-d);font-style:italic}
.inbox p{color:var(--ink-2);font-size:14.5px;line-height:1.55}
.inbox__foot{
  margin-top:auto;padding-top:.8rem;border-top:1px solid var(--hair);
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:11.5px;color:var(--amber-d);letter-spacing:.02em;font-weight:500;
}

/* —— BUY CARD PRODUCT HERO —— */
.buy__hero{
  margin:-32px -32px 20px;padding:40px 32px;
  background:linear-gradient(180deg,#F7F0E2 0%,#FBF6EC 100%);
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
  border-bottom:1px solid var(--hair);
  text-align:center;
}
.buy__hero img{width:80%;max-width:280px;margin:0 auto;display:block;
  filter:drop-shadow(0 10px 24px rgba(27,24,21,.14));
}

/* sticky atc thumb with real image */
.sticky-atc__thumb{background:var(--bg);padding:4px}
.sticky-atc__thumb img{width:100%;height:100%;object-fit:contain}

/* —— STORY —— */
.story{padding:120px max(1.5rem, 3vw)}
.story__grid{
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start;
}
.story__body{color:var(--ink-2);font-size:18px;line-height:1.7;max-width:52ch}
.story__body p + p{margin-top:1.3rem}
.story__sig{
  margin-top:2rem !important;font-style:italic;color:var(--muted);font-size:15px;
  font-family:Fraunces;
}

/* —— FEATURES —— */
.features{
  padding:120px max(1.5rem, 3vw);
  background:var(--bg-deep);
  border-top:1px solid var(--hair);
  border-bottom:1px solid var(--hair);
}
.section-head{max-width:var(--container);margin:0 auto 4rem}
.section-head--center{text-align:center}
.section-head--center .eyebrow{justify-content:center}
.section-head--center h2{max-width:20ch;margin:0 auto}
.features__grid{
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--hair);
  border:1px solid var(--hair);border-radius:var(--radius-lg);overflow:hidden;
}
.feat{
  background:var(--surface);
  padding:44px 36px;
  transition:background .3s var(--ease);
  position:relative;
}
.feat:hover{background:#fff}
.feat__icon{
  width:56px;height:56px;border-radius:14px;
  display:inline-flex;align-items:center;justify-content:center;
  background:color-mix(in srgb, var(--amber-s) 65%, transparent);
  color:var(--amber-d);
  margin-bottom:1.5rem;
}
.feat h3{font-family:Fraunces;font-weight:500;font-size:22px;margin-bottom:.6rem;letter-spacing:-.01em}
.feat p{color:var(--muted);font-size:15.5px;line-height:1.55}
.feat p em{color:var(--ink-2);font-style:italic}

/* —— MODES —— */
.modes{padding:120px max(1.5rem, 3vw)}
.modes__head{max-width:var(--container);margin:0 auto 3rem;text-align:center}
.modes__head .eyebrow{justify-content:center}
.modes__head h2{max-width:20ch;margin:0 auto}
.modes__player{
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:1.2fr 1fr;gap:3rem;align-items:stretch;
}
.modes__scene{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  min-height:600px;
  background:#120E0B;
}
.modes__photo{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:filter 1s var(--ease);
  filter:
    brightness(calc(0.35 + (var(--beam, 0.6) * 0.85)))
    saturate(var(--sat, 1.15))
    hue-rotate(var(--hue, 0deg));
}
.modes__tint{
  position:absolute;inset:0;pointer-events:none;
  background:var(--tint, radial-gradient(55% 45% at 50% 45%, rgba(255,190,110,.35), transparent 70%));
  mix-blend-mode:screen;
  transition:background 1s var(--ease), opacity .6s var(--ease);
  opacity:calc(0.6 + var(--beam, 0.6) * 0.4);
}
.modes__scene[data-mode="warm"]   { --hue:   0deg; --sat:1.2;  --tint: radial-gradient(55% 45% at 50% 45%, rgba(255,180,95,.45), transparent 70%); }
.modes__scene[data-mode="natural"]{ --hue:  -8deg; --sat:0.85; --tint: radial-gradient(55% 45% at 50% 45%, rgba(255,240,205,.35), transparent 70%); }
.modes__scene[data-mode="cool"]   { --hue: 175deg; --sat:0.75; --tint: radial-gradient(55% 45% at 50% 45%, rgba(180,210,255,.45), transparent 70%); }

.modes__controls{display:flex;flex-direction:column;gap:.8rem}
.mode-btn{
  display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:center;
  padding:18px 20px;border-radius:var(--radius);
  background:var(--surface);border:1px solid transparent;
  text-align:left;
  transition:all .25s var(--ease);
}
.mode-btn:hover{border-color:var(--hair)}
.mode-btn.is-active{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.mode-btn.is-active em{color:var(--amber-g)}
.mode-btn strong{font-family:Fraunces;font-size:20px;font-weight:500;display:block;letter-spacing:-.01em}
.mode-btn em{font-size:13px;font-style:normal;color:var(--muted);display:block;margin-top:2px}
.swatch{
  width:28px;height:28px;border-radius:999px;display:inline-block;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.08);
  flex-shrink:0;
}
.swatch--warm{background:radial-gradient(circle,#FFD58F,#E09B4A)}
.swatch--natural{background:radial-gradient(circle,#FFF3D4,#C9B58A)}
.swatch--cool{background:radial-gradient(circle,#EAF2FF,#7A95B8)}

.mode-dim{margin-top:1rem;padding:18px 20px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--hair)}
.mode-dim__label{display:flex;justify-content:space-between;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:.6rem}
input[type="range"]{
  -webkit-appearance:none;appearance:none;width:100%;height:4px;border-radius:2px;
  background:linear-gradient(90deg, var(--amber-d) 0%, var(--amber-d) var(--val, 60%), var(--hair) var(--val, 60%), var(--hair) 100%);
  outline:none;
}
input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:22px;height:22px;border-radius:999px;
  background:var(--ink);border:3px solid var(--amber-g);
  cursor:pointer;box-shadow:var(--shadow-sm);
}
input[type="range"]::-moz-range-thumb{width:18px;height:18px;border-radius:999px;background:var(--ink);border:3px solid var(--amber-g)}

/* —— HOW —— */
.how{padding:120px max(1.5rem, 3vw);background:var(--bg-deep);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.how__steps{
  max-width:var(--container);margin:0 auto;
  list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
}
.how__steps li{
  position:relative;padding:44px 36px;
  background:var(--surface);border:1px solid var(--hair);border-radius:var(--radius-lg);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  overflow:hidden;
}
.how__steps li:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.how__steps li::before{
  content:"";position:absolute;top:0;right:0;width:120px;height:120px;
  background:radial-gradient(circle at 70% 30%, rgba(246,203,131,.35), transparent 70%);
  pointer-events:none;
}
.how__num{
  font-family:Fraunces;font-style:italic;font-size:64px;color:var(--amber-d);
  letter-spacing:-.02em;margin-bottom:1rem;display:block;line-height:1;
  font-weight:300;opacity:.9;
}
.how__steps h3{font-family:Fraunces;font-weight:500;font-size:30px;margin-bottom:1rem;letter-spacing:-.02em}
.how__steps p{color:var(--muted);line-height:1.6;font-size:16px;max-width:36ch}

/* —— COMPARE —— */
.compare{padding:120px max(1.5rem, 3vw)}
.compare__table{
  max-width:var(--container);margin:0 auto;
  border:1px solid var(--hair);border-radius:var(--radius-lg);overflow:hidden;
  background:var(--surface);
}
.compare__row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;align-items:center;min-height:64px;border-top:1px solid var(--hair)}
.compare__row:first-child{border-top:0}
.compare__row > *{padding:18px 20px}
.compare__row--head{background:var(--bg-deep);font-family:Fraunces;font-size:18px;font-weight:500;letter-spacing:-.01em}
.compare__row--head .compare__us{color:var(--amber-d)}
.compare__row [role="rowheader"]{font-weight:500;font-size:15.5px}
.compare__row:not(.compare__row--head) .compare__us{background:color-mix(in srgb, var(--amber-s) 40%, transparent);color:var(--amber-d);font-weight:600}
.compare__row:not(.compare__row--head) > div:not([role="rowheader"]):not(.compare__us){color:var(--muted);text-align:center}
.compare__row:not(.compare__row--head) .compare__us{text-align:center}

/* —— EDITORIAL —— */
.edit{
  padding:120px max(1.5rem, 3vw);
  background:var(--bg-deep);
  border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);
}
.edit{display:grid;grid-template-columns:1.2fr 1fr;gap:5rem;max-width:var(--container);margin:0 auto;align-items:center}
.edit__image{position:relative;margin:0;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow-lg)}
.edit__image img{width:100%;height:100%;object-fit:cover;
  animation:kenburns 22s ease-in-out infinite alternate;
}
.edit__caption{
  position:absolute;left:0;right:0;bottom:0;
  padding:20px 24px;display:block;
  color:#F5EEE2;font-size:13px;font-family:Fraunces;font-style:italic;letter-spacing:.02em;
  background:linear-gradient(180deg, transparent, rgba(10,8,6,.7));
}

.edit__quote{position:relative}
.quote-mark{
  font-family:Fraunces;font-size:140px;line-height:.8;color:var(--amber-d);opacity:.35;
  margin-bottom:-.4em;
}
.edit__quote blockquote{
  font-family:Fraunces;font-weight:300;font-size:clamp(1.6rem, 2.6vw, 2.4rem);line-height:1.2;letter-spacing:-.015em;
  color:var(--ink);margin-bottom:2rem;
}
.edit__quote blockquote em{font-style:italic;color:var(--amber-d)}
.edit__quote figcaption{display:flex;flex-direction:column;gap:3px;color:var(--muted);font-size:14px}
.edit__quote figcaption strong{color:var(--ink);font-size:15px}
.edit__quote figcaption .stars{margin-top:.4rem}

/* —— REVIEWS —— */
.reviews{padding:120px max(1.5rem, 3vw)}
.reviews__head{
  max-width:var(--container);margin:0 auto 4rem;
  display:grid;grid-template-columns:auto 1fr;gap:5rem;align-items:center;
}
.reviews__score{
  background:var(--surface);border:1px solid var(--hair);
  border-radius:var(--radius-lg);padding:40px;min-width:320px;
}
.score-num{font-family:Fraunces;font-size:84px;line-height:1;letter-spacing:-.03em;font-weight:300}
.score-bars{list-style:none;margin-top:1.5rem}
.score-bars li{display:grid;grid-template-columns:16px 1fr 48px;gap:.8rem;align-items:center;font-size:13px;color:var(--muted);margin:.35rem 0}
.score-bars i{display:block;height:6px;border-radius:999px;background:var(--hair);position:relative;overflow:hidden}
.score-bars b{display:block;height:100%;background:var(--amber-d);border-radius:999px}
.score-bars em{font-style:normal;text-align:right;font-variant-numeric:tabular-nums}
.reviews__grid{
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
}
.rev{
  background:var(--surface);border:1px solid var(--hair);border-radius:var(--radius);
  padding:28px;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}
.rev:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.rev__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.verified{font-size:11px;color:var(--amber-d);font-weight:600;letter-spacing:.08em}
.rev h4{font-family:Fraunces;font-weight:500;font-size:19px;margin-bottom:.6rem;letter-spacing:-.01em;line-height:1.25}
.rev p{color:var(--muted);font-size:15px;line-height:1.55;margin-bottom:1.2rem}
.rev footer{font-size:13px;color:var(--muted)}
.rev footer strong{color:var(--ink);font-weight:500}

/* —— SPECS —— */
.specs{padding:120px max(1.5rem, 3vw);background:var(--bg-deep);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.specs__grid{
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:repeat(2,1fr);gap:0;
  border-top:1px solid var(--line);
}
.specs__grid > div{
  display:grid;grid-template-columns:1fr 2fr;gap:2rem;
  padding:20px 0;border-bottom:1px solid var(--hair);
  align-items:baseline;
}
.specs__grid dt{font-family:Fraunces;font-size:15px;color:var(--muted);letter-spacing:.02em}
.specs__grid dd{font-size:16px;color:var(--ink);font-weight:450}
@media (min-width:800px){
  .specs__grid > div:nth-child(odd){padding-right:3rem;border-right:1px solid var(--hair)}
  .specs__grid > div:nth-child(even){padding-left:3rem}
}

/* —— FAQ —— */
.faq{padding:120px max(1.5rem, 3vw)}
.faq__head{max-width:var(--container);margin:0 auto 3rem;text-align:center}
.faq__head .eyebrow{justify-content:center}
.faq__list{max-width:840px;margin:0 auto;border-top:1px solid var(--hair)}
.faq details{border-bottom:1px solid var(--hair);padding:24px 0}
.faq summary{
  list-style:none;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;
  font-family:Fraunces;font-size:22px;font-weight:500;letter-spacing:-.01em;
  gap:2rem;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-family:Fraunces;font-size:30px;color:var(--amber-d);
  transition:transform .3s var(--ease);
}
.faq details[open] summary::after{content:"–"}
.faq p{color:var(--muted);margin-top:1rem;font-size:16px;line-height:1.65;max-width:70ch}

/* —— BUY —— */
.buy{padding:120px max(1.5rem, 3vw)}
.buy__grid{
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start;
}
.buy__left h2{margin-bottom:1.5rem}
.buy__trust{list-style:none;display:flex;flex-direction:column;gap:.8rem;margin-top:2rem;font-size:15.5px;color:var(--ink-2)}

.buy__card{
  background:var(--surface);border:1px solid var(--hair);border-radius:var(--radius-lg);
  padding:32px;box-shadow:var(--shadow);position:relative;
}
.buy__tag{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--amber-d);color:var(--bg);padding:6px 14px;border-radius:999px;
  font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
}
.buy__option{
  border:1.5px solid var(--hair);border-radius:var(--radius);
  margin-bottom:.8rem;transition:all .25s var(--ease);position:relative;
  background:var(--surface);
}
.buy__option.is-active{border-color:var(--ink);background:color-mix(in srgb, var(--amber-s) 22%, transparent)}
.buy__option label{display:grid;grid-template-columns:auto 1fr auto;gap:1rem;align-items:center;padding:18px 20px;cursor:pointer}
.buy__option input[type="radio"]{
  appearance:none;width:18px;height:18px;border:1.5px solid var(--line);border-radius:999px;position:relative;
}
.buy__option input[type="radio"]:checked{border-color:var(--ink);background:radial-gradient(circle,var(--amber-d) 42%, transparent 44%)}
.opt__main strong{font-family:Fraunces;font-size:18px;font-weight:500;display:block;letter-spacing:-.01em}
.opt__main span{color:var(--muted);font-size:13.5px;display:block;margin-top:2px}
.opt__price{text-align:right}
.opt__price b{font-family:Fraunces;font-size:22px;font-weight:500;color:var(--ink);display:block;letter-spacing:-.01em}
.opt__price s{color:var(--muted);font-size:13px;opacity:.7}
.pill{display:inline-block;background:var(--amber-d);color:var(--bg);font-size:10px;padding:3px 10px;border-radius:999px;letter-spacing:.1em;text-transform:uppercase;margin-left:.5rem;vertical-align:middle;font-weight:600;line-height:1.4}
.pill--float{position:absolute;top:-10px;right:16px;z-index:2}

.buy__colors{
  display:flex;align-items:center;gap:.6rem;margin:1.5rem 0;flex-wrap:wrap;
}
.buy__colors .label{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-right:.4rem}
.color{
  width:34px;height:34px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1.5px solid transparent;padding:3px;
}
.color span{width:100%;height:100%;border-radius:999px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.12)}
.color.is-active{border-color:var(--ink)}
.buy__colors em{margin-left:.6rem;font-style:italic;font-family:Fraunces;color:var(--muted);font-size:14px}

.buy__meta{margin-top:1.3rem;display:flex;flex-direction:column;gap:.6rem;font-size:13px;color:var(--muted)}
.buy__meta strong{color:var(--ink);font-weight:600}
.buy__meta span{display:inline-flex;align-items:center;gap:.5rem}

/* —— GUARANTEE —— */
.guarantee{padding:40px max(1.5rem, 3vw) 120px}
.guarantee__card{
  max-width:var(--container);margin:0 auto;
  display:flex;gap:2rem;align-items:center;
  padding:44px;background:var(--ink);color:var(--bg);
  border-radius:var(--radius-lg);
}
.guarantee__card svg{color:var(--amber-g);flex-shrink:0}
.guarantee__card .eyebrow{color:var(--amber-g)}
.guarantee__card h3{color:var(--bg);max-width:60ch}

/* —— FOOTER —— */
.footer{background:var(--ink);color:var(--bg);padding:80px max(1.5rem, 3vw) 32px}
.footer__top{max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:1.2fr 2fr;gap:4rem;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer__brand p{color:rgba(245,238,226,.65);font-size:15px;max-width:36ch;margin:1rem 0 2rem}
.footer__brand .logo{color:var(--bg)}
.footer__brand .logo svg{color:var(--amber-g)}
.logo--lg{font-size:28px}
.footer__form label{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:rgba(245,238,226,.55);display:block;margin-bottom:.6rem}
.footer__form .field{display:flex;border-bottom:1px solid rgba(245,238,226,.25);padding:8px 0}
.footer__form input{flex:1;background:transparent;border:0;color:var(--bg);font-size:15px;outline:none}
.footer__form input::placeholder{color:rgba(245,238,226,.4)}
.footer__form button{color:var(--amber-g);font-size:14px;letter-spacing:.12em;text-transform:uppercase;font-weight:600}
.footer__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.footer__cols h5{font-family:Fraunces;font-size:17px;font-weight:500;margin-bottom:1rem;letter-spacing:-.01em}
.footer__cols a{display:block;color:rgba(245,238,226,.6);font-size:14px;padding:5px 0;transition:color .2s var(--ease)}
.footer__cols a:hover{color:var(--amber-g)}
.footer__bottom{max-width:var(--container);margin:0 auto;padding-top:24px;display:flex;justify-content:space-between;font-size:12px;color:rgba(245,238,226,.45);letter-spacing:.04em}

/* —— STICKY ATC —— */
.sticky-atc{
  position:fixed;bottom:0;left:0;right:0;z-index:40;
  background:color-mix(in srgb, var(--ink) 92%, transparent);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  color:var(--bg);
  border-top:1px solid rgba(255,255,255,.08);
  transform:translateY(100%);
  transition:transform .3s var(--ease);
}
.sticky-atc.is-visible{transform:translateY(0)}
.sticky-atc__inner{
  max-width:var(--container);margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:14px max(2rem, 5vw);
}
.sticky-atc__prod{display:flex;gap:1rem;align-items:center}
.sticky-atc__thumb{width:44px;height:44px;border-radius:8px;background:#2A2421;display:grid;place-items:center}
.sticky-atc__thumb svg{width:28px;height:28px}
.sticky-atc__prod strong{font-family:Fraunces;font-size:17px;font-weight:500;display:block}
.sticky-atc__prod span{font-size:12px;color:rgba(245,238,226,.55)}
.sticky-atc__right{display:flex;gap:1.2rem;align-items:center}
.sticky-atc__price b{font-family:Fraunces;font-size:22px;color:var(--amber-g);font-weight:500;letter-spacing:-.01em}
.sticky-atc__price s{color:rgba(245,238,226,.45);font-size:14px;margin-left:.4rem}
.sticky-atc .btn--primary{background:var(--amber-g);color:var(--ink)}
.sticky-atc .btn--primary:hover{background:var(--bg);color:var(--ink)}

/* —— RESPONSIVE —— */
@media (max-width:1000px){
  .nav__links{display:none}
  .hero__inner{grid-template-columns:1fr;gap:2rem;min-height:auto;padding:2rem 0}
  .hero__stage{min-height:460px;order:-1}
  .story__grid{grid-template-columns:1fr;gap:2rem}
  .features__grid{grid-template-columns:1fr 1fr}
  .modes__player{grid-template-columns:1fr}
  .modes__scene{min-height:360px}
  .how__steps{grid-template-columns:1fr;gap:2rem}
  .compare__row{grid-template-columns:2fr 1fr 1fr 1fr 1fr;font-size:13px}
  .compare__row > *{padding:14px 10px}
  .edit{grid-template-columns:1fr;gap:3rem}
  .reviews__head{grid-template-columns:1fr;gap:2rem}
  .reviews__grid{grid-template-columns:1fr}
  .specs__grid{grid-template-columns:1fr}
  .buy__grid{grid-template-columns:1fr;gap:3rem}
  .footer__top{grid-template-columns:1fr;gap:2rem}
  .guarantee__card{flex-direction:column;text-align:center;padding:32px}
  .press{grid-template-columns:1fr}
  .press__logos{justify-content:center;gap:2rem}
  .finishes__grid{grid-template-columns:1fr;gap:2rem}
  .moments__grid{grid-template-columns:1fr}
  .community__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .features__grid{grid-template-columns:1fr}
  .compare__row{grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;font-size:12px}
  .footer__cols{grid-template-columns:1fr 1fr}
  .community__grid{grid-template-columns:1fr}
  .pdp__meta{flex-direction:column;gap:.3rem;align-items:flex-start}
  .pdp__trust{gap:.8rem}
  .buy__card{padding:24px}
  .buy__hero{margin:-24px -24px 16px;padding:32px 24px}
  .display--pdp{font-size:clamp(2rem, 8vw, 2.6rem)}
  /* sticky ATC compact on mobile */
  .sticky-atc__inner{padding:10px 16px;gap:.6rem}
  .sticky-atc__thumb{width:38px;height:38px}
  .sticky-atc__prod{gap:.5rem;min-width:0}
  .sticky-atc__prod strong{font-size:14px;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .sticky-atc__prod span{display:none}
  .sticky-atc__right{gap:.6rem}
  .sticky-atc__price b{font-size:18px}
  .sticky-atc__price s{display:none}
  .sticky-atc .btn{padding:10px 16px;font-size:13.5px}
  /* hero spacing */
  .hero{padding-top:20px;padding-bottom:60px}
  .hero__inner{gap:2rem}
  .hero__pdp{max-width:100%}
}
