/* ================================================================
   THE GOLD BLUSH — "Issue No. One" editorial concept
   Luxe-minimal editorial · warm-neutral · checker + ✦ sparkle
   Yeseva One (masthead) · Spectral (editorial) · Space Grotesk (caps)
   ================================================================ */

:root{
  --cream:#FDF9F5;      /* paper ground (~70%) */
  --greige:#D4C6BD;     /* logo ground / panels / dark checker tile */
  --ivory:#E8DFD8;      /* tonal mid-step, mats, hairlines */
  --champagne:#B79268;  /* the GOLD — thin strokes / ✦ / numerals only */
  --champagne-deep:#8C6A3C;
  --blush:#C98B86;      /* the BLUSH — dusty rose accents */
  --ink:#2A2320;        /* warm near-black type */
  --ink-soft:#6f655d;   /* muted ink */
  --pop-red:#C0473C; --pop-lilac:#B6A6D8; --pop-sky:#9CC2D4; --pop-green:#7FA37A; --pop-peri:#8E94D8;

  --serif:'Yeseva One',Georgia,serif;
  --edit:'Spectral',Georgia,serif;
  --caps:'Space Grotesk',-apple-system,system-ui,sans-serif;

  --maxw:1320px;
  --gut:clamp(20px,5vw,68px);
  --hair:rgba(42,35,32,.16);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:var(--edit);font-size:17px;line-height:1.62;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--blush);color:var(--cream)}

/* ---------- type ---------- */
.disp{font-family:var(--serif);font-weight:400;line-height:.96;letter-spacing:-.01em;color:var(--ink)}
.caps{font-family:var(--caps);text-transform:uppercase;letter-spacing:.22em;font-size:11.5px;font-weight:500;color:var(--ink)}
.caps-sm{font-family:var(--caps);text-transform:uppercase;letter-spacing:.2em;font-size:10px;font-weight:500}
.eyebrow{font-family:var(--caps);text-transform:uppercase;letter-spacing:.26em;font-size:11px;color:var(--champagne-deep);font-weight:500}
.spark{color:var(--champagne);font-style:normal}
.blush-word{color:var(--blush)}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
.rule{height:1px;background:var(--hair);border:0;margin:0}
.rule-champ{height:1px;background:linear-gradient(90deg,transparent,var(--champagne),transparent);border:0}
section{position:relative}

/* ---------- top eyebrow band ---------- */
.band{background:var(--greige);color:var(--ink)}
.band .wrap{display:flex;align-items:center;justify-content:space-between;gap:18px;height:38px}
.band .issue{display:flex;gap:14px;align-items:center;overflow:hidden;white-space:nowrap}
.band .issue span{opacity:.85}
.band .util{display:flex;gap:18px;align-items:center}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(253,249,245,.86);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--hair)}
.nav .wrap{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;height:64px}
.nav .links{display:flex;gap:26px}
.nav .links a{position:relative;padding-block:6px}
.nav .links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--blush);transition:right .35s ease}
.nav .links a:hover::after{right:0}
.nav .brand{display:flex;align-items:center;justify-content:center}
.nav .brand img{height:44px;width:auto;display:block}
.nav .util{justify-self:end;display:flex;gap:20px}
.nav .left{display:flex;gap:26px}
@media(max-width:860px){
  .nav .links,.nav .left{display:none}
  .nav .wrap{grid-template-columns:1fr auto;height:auto;min-height:56px;padding-block:8px}
  .nav .brand{justify-content:flex-start}
  .nav .brand img{height:34px}
  .nav .util{gap:13px;font-size:10px}
}
@media(max-width:430px){.nav .util a:first-child{display:none}.band .issue span:nth-child(n+7){display:none}}

/* ---------- HERO COVER ---------- */
.hero{position:relative;min-height:clamp(540px,82vh,880px);display:flex;align-items:center;overflow:hidden;border-bottom:1px solid var(--hair)}
.hero-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:0}
/* CSS fallback ground (also shown until/instead of webgl) */
.hero-fallback{position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(64% 54% at 50% 42%,rgba(183,146,104,.24),transparent 70%),
    conic-gradient(from 0deg,var(--cream) 0 25%,var(--ivory) 0 50%,var(--cream) 0 75%,var(--ivory) 0);
  background-size:auto,128px 128px;background-position:center,center;opacity:.0;transition:opacity .6s}
body.no-webgl .hero-fallback{opacity:.7;animation:drift 26s linear infinite}
@keyframes drift{to{background-position:center,128px 64px}}
.hero .wrap{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;text-align:center;gap:clamp(24px,3.5vw,40px);width:100%;max-width:1040px;padding-block:clamp(44px,7vw,92px)}
.cover-copy{max-width:820px;display:flex;flex-direction:column;align-items:center}
.cover-copy .issue-line{margin-bottom:22px;color:var(--champagne-deep)}
.masthead{font-family:var(--serif);font-size:clamp(2.8rem,7.5vw,6.2rem);line-height:.92;letter-spacing:-.015em;margin:0}
.masthead .l2{display:block}
.cover-deck{font-family:var(--edit);font-size:clamp(17px,1.5vw,21px);line-height:1.5;color:var(--ink);max-width:46ch;margin:22px auto 0}
.cover-meta{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:30px}
.btn{font-family:var(--caps);text-transform:uppercase;letter-spacing:.18em;font-size:12px;font-weight:500;
  background:var(--ink);color:var(--cream);padding:15px 26px;border:0;cursor:pointer;display:inline-flex;align-items:center;gap:10px;transition:background .3s,transform .3s}
.btn:hover{background:var(--champagne-deep);transform:translateY(-1px)}
.btn .arr{transition:transform .3s}.btn:hover .arr{transform:translateX(4px)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}

.cover-plate{position:relative;width:100%;max-width:330px;margin:0 auto}
.cover-plate .mat{position:relative;background:var(--cream);padding:clamp(14px,2vw,26px);box-shadow:0 30px 70px -36px rgba(42,35,32,.5)}
.cover-plate img{width:100%;aspect-ratio:4/5;object-fit:cover}
.cover-plate .plate-cap{display:flex;justify-content:space-between;margin-top:12px}
.cover-plate .bloom{position:absolute;inset:-12% -10% -16% -10%;z-index:-1;border-radius:50%;
  background:radial-gradient(closest-side,rgba(183,146,104,.34),transparent 72%);filter:blur(8px)}

.folio{position:absolute;left:var(--gut);right:var(--gut);bottom:18px;display:flex;justify-content:space-between;z-index:3}
@media(max-width:860px){
  .hero{min-height:auto}
  .hero .wrap{text-align:center;gap:22px;padding-block:30px 46px}
  .cover-plate{max-width:300px}
  .masthead{font-size:clamp(2.7rem,13vw,4.6rem)}
  .folio{display:none}
}
@media(max-width:520px){.band .util{display:none}}

/* ---------- FEATURE 01 — color story ---------- */
.feature{padding-block:clamp(64px,9vw,128px)}
.feat-head{display:flex;align-items:baseline;gap:18px;margin-bottom:42px}
.feat-head .no{font-family:var(--serif);font-size:clamp(2.2rem,5vw,3.6rem);color:var(--champagne)}
.feat-head h2{font-family:var(--serif);font-size:clamp(1.7rem,4vw,2.8rem);margin:0;font-weight:400}
.colorstory{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,5vw,72px);align-items:center}
.cs-stage{position:relative;background:var(--ivory);padding:clamp(20px,3vw,42px)}
.cs-stage img{width:100%;aspect-ratio:1/1;object-fit:cover;transition:opacity .35s ease}
.cs-stage .cs-plac{margin-top:14px}
.cs-side .lead{font-family:var(--edit);font-size:clamp(18px,1.7vw,22px);line-height:1.55;margin:0 0 28px}
.swatch-rail{display:flex;flex-wrap:wrap;gap:14px;margin-top:8px}
.sw{width:46px;height:46px;border-radius:50%;border:1px solid var(--hair);cursor:pointer;position:relative;transition:transform .25s}
.sw:hover{transform:scale(1.08)}
.sw[aria-pressed="true"]{box-shadow:0 0 0 2px var(--cream),0 0 0 3px var(--champagne)}
.sw small{position:absolute;left:50%;top:118%;transform:translateX(-50%);white-space:nowrap;font-family:var(--caps);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);opacity:0;transition:opacity .2s}
.sw:hover small{opacity:1}
@media(max-width:860px){.colorstory{grid-template-columns:1fr;gap:32px}}

/* ---------- The Collection grid ---------- */
.collection-intro{font-family:var(--edit);font-size:clamp(17px,1.6vw,21px);line-height:1.5;color:var(--ink-soft);max-width:52ch;margin:-26px 0 0}
.collection-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px}
.collection-grid .pcard{min-width:0}
@media(max-width:860px){.collection-grid{grid-template-columns:1fr 1fr;gap:14px}}
/* scroll cue (replaces the lone hero plate) */
.scrollcue{color:var(--ink-soft);display:inline-flex;align-items:center;gap:8px;margin-top:6px}
.scrollcue span{display:inline-block;animation:bob 1.8s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* ---------- FEATURE 02 — styled three ways ---------- */
.styled{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;background:var(--greige)}
.styled .photo{min-height:420px;background-size:cover;background-position:center}
.styled .col{padding:clamp(32px,5vw,72px)}
.styled .col h2{font-family:var(--serif);font-weight:400;font-size:clamp(1.8rem,4vw,3rem);margin:0 0 8px}
.dropcap::first-letter{font-family:var(--serif);float:left;font-size:3.4em;line-height:.72;padding:6px 12px 0 0;color:var(--champagne)}
.styled ol{list-style:none;counter-reset:s;padding:0;margin:30px 0 0}
.styled ol li{counter-increment:s;padding:18px 0;border-top:1px solid rgba(42,35,32,.22);display:grid;grid-template-columns:auto 1fr;gap:18px}
.styled ol li::before{content:counter(s,decimal-leading-zero);font-family:var(--serif);color:var(--champagne);font-size:1.5rem;line-height:1}
.styled ol li b{font-family:var(--caps);text-transform:uppercase;letter-spacing:.16em;font-size:12px;display:block;margin-bottom:4px}
@media(max-width:860px){.styled{grid-template-columns:1fr}.styled .photo{min-height:300px}}

/* ---------- pull-quote ---------- */
.pquote{padding-block:clamp(80px,12vw,170px);text-align:center}
.pquote p{font-family:var(--edit);font-style:italic;font-weight:400;font-size:clamp(2rem,6vw,4.4rem);line-height:1.06;color:var(--blush);margin:0 auto;max-width:18ch}
.pquote .src{margin-top:26px}

/* ---------- THE BACK PAGES — checker category tiles ---------- */
.backpages{padding-block:clamp(56px,8vw,116px)}
.tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:40px}
.tile{display:block;min-width:0}
.tile-img{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--cream);border:1px solid var(--hair)}
.tile-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.tile:hover .tile-img img{transform:scale(1.04)}
.tile-cap{display:flex;justify-content:space-between;align-items:baseline;margin-top:13px;gap:10px}
.tile .t-name{font-family:var(--serif);font-size:1.4rem;color:var(--ink);line-height:1}
.tile .t-no{color:var(--champagne-deep);white-space:nowrap}
@media(max-width:860px){.tiles{grid-template-columns:1fr 1fr;gap:14px}.tile .t-name{font-size:1.06rem}.tile-cap{margin-top:10px}}

/* ---------- social proof folio band ---------- */
.proof{background:var(--ink);color:var(--cream)}
.proof .wrap{display:flex;flex-wrap:wrap;gap:26px;justify-content:center;align-items:center;height:auto;padding-block:24px;text-align:center}
.proof .caps{color:var(--cream)}
.proof .spark{color:var(--champagne)}

/* ---------- footer ---------- */
.foot{background:var(--cream);border-top:1px solid var(--hair);padding-block:clamp(48px,7vw,90px)}
.foot .grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px}
.foot .fdisp{font-family:var(--serif);font-size:clamp(2rem,5vw,3.4rem);line-height:.95}
.foot h4{font-family:var(--caps);text-transform:uppercase;letter-spacing:.2em;font-size:11px;color:var(--ink-soft);margin:0 0 16px}
.foot ul{list-style:none;padding:0;margin:0;display:grid;gap:10px;font-size:15px}
.foot .news input{font-family:var(--edit);background:transparent;border:0;border-bottom:1px solid var(--ink);padding:10px 0;width:100%;color:var(--ink);font-size:15px}
.foot .news input::placeholder{color:var(--ink-soft)}
.foot .botline{display:flex;justify-content:space-between;margin-top:48px;padding-top:20px;border-top:1px solid var(--hair)}
@media(max-width:860px){.foot .grid{grid-template-columns:1fr 1fr}.foot .fdisp{grid-column:1/-1}}

/* ================= PDP ================= */
.pdp-crumb{padding-block:18px;border-bottom:1px solid var(--hair)}
.pdp-crumb .wrap{display:flex;justify-content:space-between}
.pdp{padding-block:clamp(34px,5vw,68px)}
.pdp-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(30px,5vw,72px);align-items:start}
.gallery{display:grid;grid-template-columns:74px 1fr;gap:16px}
.thumbs{display:flex;flex-direction:column;gap:12px}
.thumbs button{padding:0;border:1px solid var(--hair);background:var(--cream);cursor:pointer;aspect-ratio:1;overflow:hidden}
.thumbs button[aria-pressed="true"]{border-color:var(--champagne)}
.thumbs img{width:100%;height:100%;object-fit:cover}
.plate{position:relative;background:var(--cream);padding:clamp(14px,2vw,26px);box-shadow:0 30px 70px -40px rgba(42,35,32,.45)}
.plate .bloom{position:absolute;inset:-8%;z-index:0;border-radius:50%;background:radial-gradient(closest-side,rgba(183,146,104,.28),transparent 70%);filter:blur(10px)}
.plate img{position:relative;z-index:1;width:100%;aspect-ratio:4/5;object-fit:cover}
.info{position:sticky;top:84px}
.info .placard{display:flex;gap:12px;align-items:center;color:var(--champagne-deep);margin-bottom:14px}
.info h1{font-family:var(--serif);font-weight:400;font-size:clamp(2rem,4.5vw,3.4rem);line-height:1;margin:0 0 12px}
.info .deck{font-family:var(--edit);color:var(--ink-soft);margin:0 0 22px;max-width:42ch}
.info .price{font-family:var(--caps);letter-spacing:.06em;font-size:20px;display:flex;align-items:center;gap:14px;margin-bottom:6px}
.stars{color:var(--champagne);letter-spacing:.1em}
.info .clabel{margin:26px 0 12px}
.pdp-sw{display:flex;flex-wrap:wrap;gap:13px;margin-bottom:30px}
.cta-row{display:flex;gap:12px;align-items:stretch;margin-bottom:8px}
.cta-row .btn{flex:1;justify-content:center;padding-block:18px}
.heart{width:54px;border:1px solid var(--ink);background:transparent;cursor:pointer;font-size:18px;color:var(--ink);transition:.3s}
.heart[aria-pressed="true"]{color:var(--blush);border-color:var(--blush)}
.accord{margin-top:30px;border-top:1px solid var(--hair)}
.accord details{border-bottom:1px solid var(--hair)}
.accord summary{list-style:none;cursor:pointer;padding:18px 0;display:flex;justify-content:space-between;font-family:var(--caps);text-transform:uppercase;letter-spacing:.14em;font-size:12px}
.accord summary::-webkit-details-marker{display:none}
.accord summary .pm{color:var(--champagne);transition:transform .3s}
.accord details[open] summary .pm{transform:rotate(45deg)}
.accord .body{padding:0 0 20px;color:var(--ink-soft);font-size:15.5px;max-width:54ch}
@media(max-width:860px){.pdp-grid{grid-template-columns:1fr;gap:30px}.info{position:static}.gallery{grid-template-columns:60px 1fr}}

/* cross-sell */
.pair{padding-block:clamp(48px,7vw,100px);border-top:1px solid var(--hair)}
.pair-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:34px}
.pcard .pc-img{background:var(--ivory);aspect-ratio:1;overflow:hidden}
.pcard img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.pcard:hover img{transform:scale(1.05)}
.pcard .pc-name{font-family:var(--serif);font-size:1.25rem;margin-top:12px}
.pcard .pc-meta{display:flex;justify-content:space-between;margin-top:4px}
@media(max-width:680px){.pair-grid{grid-template-columns:1fr}}

/* ---------- promo / email-capture modal ---------- */
.modal{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:20px;background:rgba(42,35,32,.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:opacity .45s ease,visibility .45s ease}
.modal.open{opacity:1;visibility:visible}
.modal-card{position:relative;width:100%;max-width:452px;background:var(--cream);border:1px solid var(--hair);box-shadow:0 40px 90px -40px rgba(42,35,32,.6);transform:translateY(14px) scale(.985);transition:transform .5s cubic-bezier(.2,.7,.2,1);overflow:hidden}
.modal.open .modal-card{transform:none}
.modal-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--champagne),var(--blush),var(--champagne))}
.modal-inner{padding:clamp(32px,5vw,46px) clamp(26px,5vw,44px);text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}
.modal-inner .promo-logo{height:34px;width:auto;margin-bottom:2px}
.modal-inner .eyebrow{margin:0}
.modal-inner h2{font-family:var(--serif);font-weight:400;font-size:clamp(2rem,6vw,2.9rem);line-height:1.02;margin:0;color:var(--ink)}
.modal-inner p{font-family:var(--edit);font-size:15.5px;line-height:1.5;color:var(--ink-soft);margin:0;max-width:34ch}
.modal-form{display:flex;flex-direction:column;gap:12px;width:100%;margin-top:6px}
.modal-form input{font-family:var(--edit);font-size:16px;text-align:center;background:transparent;border:1px solid var(--ink);padding:14px 16px;color:var(--ink)}
.modal-form input::placeholder{color:var(--ink-soft)}
.modal-form .btn{justify-content:center;padding-block:15px}
.modal-decline{background:none;border:0;color:var(--ink-soft);text-decoration:underline;text-underline-offset:3px;cursor:pointer;margin-top:2px;font-size:11px}
.modal-decline:hover{color:var(--ink)}
.modal-x{position:absolute;top:12px;right:14px;background:none;border:0;font-size:26px;line-height:1;color:var(--ink-soft);cursor:pointer;width:38px;height:38px;z-index:2;transition:color .2s}
.modal-x:hover{color:var(--champagne-deep)}
@media(prefers-reduced-motion:reduce){.modal-card{transform:none}}

/* ---------- reveal motion ---------- */
.rv{opacity:0;transform:translateY(16px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .rv{opacity:1;transform:none}
}
