/* ============================================================
   VÉRAQ — main.css
   ============================================================ */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  font-family:var(--font-sans); font-weight:400; color:var(--ink);
  background:var(--paper); line-height:1.6; font-size:var(--fs-body);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; background:none; border:none; }
::selection{ background:var(--ink); color:var(--paper); }

/* ---------- primitives ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.wordmark{ font-family:var(--font-display); font-weight:600; letter-spacing:.2em; }
.eyebrow{ font-size:var(--fs-eyebrow); letter-spacing:var(--tracking-wide); text-transform:uppercase; color:var(--ink-soft); font-weight:500; display:inline-block; }
.section{ padding-block:var(--space-section); position:relative; }
.section__head{ max-width:46rem; margin-bottom:clamp(2.4rem,1rem+4vw,4.5rem); }
.section__head--center{ margin-inline:auto; text-align:center; }
.section__title{ font-family:var(--font-display); font-weight:500; font-size:var(--fs-h2); line-height:1.02; letter-spacing:-.01em; margin-top:.6rem; }
.section__lead{ font-size:var(--fs-lead); color:var(--ink-soft); max-width:var(--maxw-text); margin-top:1.3rem; font-weight:300; }

.btn{ --bd:var(--line-2); display:inline-flex; align-items:center; gap:.5em; padding:.92em 1.6em; border-radius:var(--r-pill); font-size:.82rem; letter-spacing:.08em; font-weight:500; border:1px solid var(--bd); transition:transform var(--t-fast) var(--ease), background var(--t-fast), color var(--t-fast), border-color var(--t-fast); white-space:nowrap; }
.btn:hover{ transform:translateY(-2px); }
.btn--solid{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.btn--solid:hover{ background:var(--ink-2); }
.btn--ghost{ background:transparent; }
.btn--ghost:hover{ background:color-mix(in srgb, var(--ink) 7%, transparent); }
.btn--mini{ padding:.62em 1.15em; font-size:.74rem; }

/* ---------- preloader ---------- */
#preloader{ position:fixed; inset:0; z-index:200; background:var(--paper); display:grid; place-items:center; transition:opacity .8s var(--ease), visibility .8s; }
#preloader .wordmark{ font-size:clamp(2rem,1rem+5vw,3.4rem); letter-spacing:.34em; opacity:0; animation:preIn 1.1s var(--ease) forwards; }
#preloader.done{ opacity:0; visibility:hidden; pointer-events:none; }
@keyframes preIn{ from{opacity:0; letter-spacing:.5em} to{opacity:1; letter-spacing:.34em} }

/* ---------- nav ---------- */
.nav{ position:fixed; inset:0 0 auto 0; z-index:100; transition:background var(--t-med), backdrop-filter var(--t-med), border-color var(--t-med); border-bottom:1px solid transparent; }
.nav.is-solid{ background:color-mix(in srgb, var(--paper) 82%, transparent); backdrop-filter:blur(14px) saturate(1.1); border-bottom-color:var(--line); }
.nav__bar{ max-width:var(--maxw); margin-inline:auto; padding:0 var(--gutter); height:var(--header-h); display:flex; align-items:center; justify-content:space-between; gap:1.5rem; }
.nav__logo{ font-size:1.45rem; }
.nav__links{ display:flex; gap:2.1rem; font-size:.82rem; letter-spacing:.04em; }
.nav__links a{ color:var(--ink-2); position:relative; padding:.3em 0; transition:color var(--t-fast); }
.nav__links a::after{ content:""; position:absolute; left:0; bottom:0; width:0; height:1px; background:currentColor; transition:width var(--t-med) var(--ease); }
.nav__links a:hover{ color:var(--ink); }
.nav__links a:hover::after{ width:100%; }
.nav__right{ display:flex; align-items:center; gap:.9rem; }
.nav__burger{ display:none; width:34px; height:34px; flex-direction:column; justify-content:center; gap:6px; }
.nav__burger span{ height:1.5px; width:22px; background:var(--ink); margin-inline:auto; transition:transform var(--t-fast), opacity var(--t-fast); }

/* ---------- hero ---------- */
.hero{ position:relative; padding-top:var(--header-h); }
.hero__inner{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); min-height:calc(100vh - var(--header-h)); display:grid; grid-template-columns:0.92fr 1.08fr; align-items:center; gap:clamp(1rem,2vw,3rem); }
.hero__copy{ padding-block:3rem; max-width:34rem; }
.hero__title{ font-family:var(--font-display); font-weight:500; font-size:var(--fs-display); line-height:.96; letter-spacing:-.015em; margin:1.1rem 0 0; }
.hero__title em{ font-style:italic; font-weight:400; color:var(--accent); }
.hero__lead{ font-size:var(--fs-lead); color:var(--ink-soft); margin-top:1.6rem; font-weight:300; max-width:30rem; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:.8rem; margin-top:2.1rem; }
.hero__picker{ margin-top:2.6rem; }
.hero__picker-head{ display:flex; align-items:baseline; justify-content:space-between; gap:1rem; margin-bottom:.9rem; }
.hero__cname{ font-family:var(--font-display); font-style:italic; font-size:1.05rem; color:var(--ink-2); }
.swatches{ display:flex; gap:.7rem; flex-wrap:wrap; }
.swatch{ width:34px; height:34px; border-radius:50%; background:var(--sw); border:1px solid var(--line-2); position:relative; transition:transform var(--t-fast) var(--ease); }
.swatch::after{ content:""; position:absolute; inset:-5px; border-radius:50%; border:1px solid var(--ink); opacity:0; transform:scale(.8); transition:opacity var(--t-fast), transform var(--t-fast) var(--ease); }
.swatch:hover{ transform:translateY(-2px); }
.swatch.is-active::after{ opacity:1; transform:scale(1); }

.hero__stage{ position:relative; min-height:min(82vh,720px); align-self:stretch; }
.hero__halo{ position:absolute; inset:6% 0 10%; background:radial-gradient(58% 52% at 52% 44%, color-mix(in srgb,var(--paper-3) 80%, #fff) 0%, transparent 70%); filter:blur(8px); }
#hero-canvas{ position:absolute; inset:0; width:100%; height:100%; display:block; opacity:0; transition:opacity 1s var(--ease) .2s; cursor:grab; }
#hero-canvas.is-ready{ opacity:1; }
#hero-canvas:active{ cursor:grabbing; }
#hero-canvas.is-hidden{ display:none; }
.hero__fallback{ position:absolute; inset:0; margin:auto; max-height:80%; width:auto; object-fit:contain; opacity:0; pointer-events:none; }
.hero__fallback.show{ opacity:1; }
.hero__hint{ position:absolute; left:50%; bottom:2%; transform:translateX(-50%); font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; color:var(--ink-faint); }
.hero__scroll{ position:absolute; left:50%; bottom:1.6rem; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:.55rem; font-size:.62rem; letter-spacing:.3em; color:var(--ink-soft); }
.hero__scroll span{ width:1px; height:42px; background:linear-gradient(var(--ink-soft),transparent); animation:scrollLine 2.2s var(--ease) infinite; transform-origin:top; }
@keyframes scrollLine{ 0%{transform:scaleY(0); opacity:0} 35%{transform:scaleY(1); opacity:1} 100%{transform:scaleY(1) translateY(42px); opacity:0} }

/* ---------- marquee ---------- */
.marquee{ overflow:hidden; border-block:1px solid var(--line); padding-block:1.4rem; background:var(--paper-2); }
.marquee__row{ display:flex; align-items:center; gap:1.6rem; width:max-content; animation:marquee 38s linear infinite; font-family:var(--font-display); font-size:clamp(1.1rem,.7rem+1.3vw,1.7rem); color:var(--ink-2); letter-spacing:.04em; white-space:nowrap; }
.marquee__row i{ color:var(--accent); }
@keyframes marquee{ to{ transform:translateX(-50%); } }

/* ---------- collection ---------- */
.grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,.4rem+1.6vw,1.7rem); }
.card{ position:relative; background:var(--paper-2); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; cursor:pointer; transition:transform var(--t-med) var(--ease), box-shadow var(--t-med), border-color var(--t-med); display:flex; flex-direction:column; }
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-m); border-color:var(--line-2); }
.card__media{ position:relative; aspect-ratio:1/1; background:linear-gradient(160deg,#fbf7ef,#e8e0d0); overflow:hidden; }
.card__media img{ width:100%; height:100%; object-fit:contain; padding:7%; transition:transform var(--t-slow) var(--ease); }
.card:hover .card__media img{ transform:scale(1.05); }
.card__role{ position:absolute; top:.9rem; left:.9rem; font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-soft); background:color-mix(in srgb,var(--paper) 70%, transparent); backdrop-filter:blur(6px); padding:.35em .7em; border-radius:var(--r-pill); }
.card__body{ padding:1.3rem 1.4rem 1.5rem; display:flex; flex-direction:column; gap:.5rem; flex:1; }
.card__top{ display:flex; justify-content:space-between; align-items:baseline; gap:.5rem; }
.card__price{ font-size:.8rem; color:var(--ink-2); font-weight:500; }
.card__name{ font-family:var(--font-display); font-weight:500; font-size:var(--fs-h3); line-height:1; }
.card__tag{ font-size:.86rem; color:var(--ink-soft); font-weight:300; flex:1; }
.card__foot{ display:flex; align-items:center; justify-content:space-between; margin-top:.6rem; }
.dots{ display:inline-flex; gap:.34rem; }
.dots i{ width:14px; height:14px; border-radius:50%; background:var(--d); border:1px solid var(--line-2); }
.card__cta{ font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink); display:inline-flex; align-items:center; gap:.4em; }
.card__cta em{ font-style:normal; transition:transform var(--t-fast) var(--ease); }
.card:hover .card__cta em{ transform:translateX(3px) rotate(90deg); }

.card--feature{ grid-column:1 / -1; flex-direction:row; background:linear-gradient(110deg,var(--paper-2),var(--paper-3)); }
.card--feature .card__media{ aspect-ratio:auto; flex:1.05; min-height:340px; background:linear-gradient(150deg,#fdfaf3,#e6ddcb); }
.card--feature .card__body{ flex:.95; justify-content:center; padding:clamp(1.5rem,1rem+3vw,3.4rem); gap:.7rem; }
.card--feature .card__name{ font-size:clamp(2rem,1.4rem+2vw,3rem); }
.card--feature .card__tag{ font-size:1rem; max-width:34ch; flex:initial; }

/* ---------- spotlight ---------- */
.spotlight{ padding-block:var(--space-section); background:var(--paper); }
.spotlight__grid{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:clamp(2rem,1rem+4vw,5rem); align-items:start; }
.spotlight__sticky{ position:sticky; top:calc(var(--header-h) + 2rem); border-radius:var(--r-lg); overflow:hidden; background:linear-gradient(160deg,#fbf7ef,#e8e0d0); box-shadow:var(--shadow-m); }
.spotlight__sticky img{ width:100%; aspect-ratio:1/1; object-fit:cover; }
.spotlight__copy{ padding-top:.5rem; }
.features{ list-style:none; margin:2.2rem 0; }
.features li{ border-top:1px solid var(--line); padding:1.15rem 0; display:grid; gap:.3rem; }
.features li b{ font-family:var(--font-display); font-weight:600; font-size:1.25rem; }
.features li span{ color:var(--ink-soft); font-size:.92rem; font-weight:300; }
.spec{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; margin-bottom:2rem; }
.spec>div{ background:var(--paper); padding:1.1rem 1.3rem; }
.spec span{ font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-faint); display:block; margin-bottom:.3rem; }
.spec b{ font-weight:500; font-size:1rem; }

/* ---------- tech ---------- */
.tech{ background:var(--paper-2); }
.tech__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(1rem,.4rem+1.4vw,1.5rem); }
.tech__card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--r-lg); padding:1.8rem 1.6rem 1.7rem; display:flex; flex-direction:column; gap:.7rem; min-height:260px; transition:transform var(--t-med) var(--ease), box-shadow var(--t-med); }
.tech__card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-s); }
.tech__no{ font-family:var(--font-display); font-style:italic; font-size:1.1rem; color:var(--accent); }
.tech__card h3{ font-family:var(--font-display); font-weight:600; font-size:1.4rem; }
.tech__card p{ font-size:.88rem; color:var(--ink-soft); font-weight:300; flex:1; }
.tech__metric{ font-family:var(--font-display); font-size:1.8rem; font-weight:600; letter-spacing:.01em; border-top:1px solid var(--line); padding-top:.9rem; }
.tech__metric small{ font-family:var(--font-sans); font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-faint); margin-left:.4em; font-weight:500; }

/* ---------- lifestyle editorial ---------- */
.editorial{ display:flex; flex-direction:column; gap:clamp(3rem,1.5rem+5vw,7rem); margin-top:clamp(2rem,1rem+3vw,4rem); }
.para{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(1.5rem,1rem+3vw,4rem); align-items:center; }
.para--right{ grid-template-columns:.85fr 1.15fr; }
.para--right .para__copy{ order:-1; }
.para__media{ overflow:hidden; border-radius:var(--r-lg); box-shadow:var(--shadow-m); aspect-ratio:5/4; }
.para__media img{ width:100%; height:120%; object-fit:cover; will-change:transform; }
.para__copy{ padding:1rem 0; }
.para__en{ font-family:var(--font-display); font-size:clamp(1.5rem,1rem+2vw,2.6rem); font-weight:500; line-height:1.12; margin:.8rem 0 .7rem; }
.para__zh{ color:var(--ink-soft); font-weight:300; }

/* ---------- colors ---------- */
.palette{ display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:1rem; }
.pal{ display:flex; align-items:center; gap:1rem; text-align:left; background:var(--paper-2); border:1px solid var(--line); border-radius:var(--r-md); padding:1rem 1.1rem; transition:transform var(--t-fast) var(--ease), box-shadow var(--t-fast); }
.pal:hover{ transform:translateY(-3px); box-shadow:var(--shadow-s); }
.pal__sw{ width:46px; height:46px; border-radius:50%; background:var(--p); border:1px solid var(--line-2); flex:none; box-shadow:inset 0 -6px 12px rgba(0,0,0,.08); }
.pal__meta{ display:flex; flex-direction:column; line-height:1.3; }
.pal__meta b{ font-family:var(--font-display); font-weight:600; font-size:1.05rem; }
.pal__meta i{ font-style:normal; font-size:.82rem; color:var(--ink-2); }
.pal__meta em{ font-style:normal; font-size:.68rem; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-faint); margin-top:.15rem; }

/* ---------- gifting ---------- */
.gifting{ background:var(--paper); }
.gifting__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,1rem+4vw,5rem); align-items:center; }
.gifting__sets{ display:flex; flex-wrap:wrap; gap:.6rem; margin:1.8rem 0; }
.gifting__sets span{ border:1px solid var(--line-2); border-radius:var(--r-pill); padding:.5em 1.1em; font-size:.78rem; letter-spacing:.05em; }
.gifting__media{ position:relative; }
.gifting__media img{ width:78%; border-radius:var(--r-lg); box-shadow:var(--shadow-l); }
.gifting__media-2{ position:absolute; right:0; bottom:-12%; width:46%!important; border:4px solid var(--paper); }

/* ---------- story ---------- */
.story{ background:var(--paper-2); text-align:center; }
.story__inner{ max-width:50rem; margin-inline:auto; }
.story__lead{ font-size:var(--fs-lead); color:var(--ink-soft); font-weight:300; margin:1.4rem 0 2.4rem; }
.story__quote{ font-family:var(--font-display); font-weight:500; font-size:clamp(2rem,1.2rem+3.4vw,3.8rem); line-height:1.08; letter-spacing:-.01em; }
.story__en{ margin-top:2rem; font-style:italic; font-family:var(--font-display); font-size:1.15rem; color:var(--ink-2); }

/* ---------- join ---------- */
.join{ text-align:center; }
.join__inner{ max-width:40rem; margin-inline:auto; }
.join__form{ display:flex; gap:.6rem; margin:2rem 0 1rem; }
.join__form input{ flex:1; padding:.95em 1.3em; border:1px solid var(--line-2); border-radius:var(--r-pill); background:var(--paper-2); font:inherit; color:var(--ink); }
.join__form input:focus{ outline:none; border-color:var(--ink); }
.join__note{ font-size:.82rem; color:var(--ink-faint); }

/* ---------- footer ---------- */
.footer{ background:var(--ink); color:var(--paper); padding-top:clamp(3rem,2rem+3vw,5rem); }
.footer__grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:2rem; padding-bottom:3rem; }
.footer__logo{ font-size:1.8rem; display:inline-block; margin-bottom:1rem; }
.footer__brand p{ color:color-mix(in srgb,var(--paper) 64%, transparent); font-size:.88rem; font-weight:300; max-width:28ch; }
.footer__col h4{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:color-mix(in srgb,var(--paper) 54%, transparent); margin-bottom:1rem; font-weight:500; }
.footer__col a{ display:block; padding:.32em 0; color:color-mix(in srgb,var(--paper) 80%, transparent); font-size:.9rem; transition:color var(--t-fast); }
.footer__col a:hover{ color:var(--paper); }
.footer__base{ display:flex; justify-content:space-between; gap:1rem; padding-block:1.6rem; border-top:1px solid color-mix(in srgb,var(--paper) 16%, transparent); font-size:.78rem; color:color-mix(in srgb,var(--paper) 56%, transparent); flex-wrap:wrap; }
.footer__tag{ font-family:var(--font-display); font-style:italic; letter-spacing:.04em; }

/* ---------- modal ---------- */
.modal{ position:fixed; inset:0; z-index:150; display:none; }
body.modal-open{ overflow:hidden; }
body.modal-open .modal{ display:block; }
.modal__scrim{ position:absolute; inset:0; background:rgba(20,18,15,.5); backdrop-filter:blur(8px); animation:fade .4s var(--ease); }
.modal__panel{ position:absolute; inset:auto 0 0 0; margin-inline:auto; top:50%; left:50%; transform:translate(-50%,-50%); width:min(960px,92vw); max-height:90vh; overflow:auto; background:var(--paper); border-radius:var(--r-lg); display:grid; grid-template-columns:1.05fr .95fr; box-shadow:var(--shadow-l); animation:modalIn .5s var(--ease); }
@keyframes fade{ from{opacity:0} }
@keyframes modalIn{ from{opacity:0; transform:translate(-50%,-46%)} }
.modal__x{ position:absolute; top:1rem; right:1rem; z-index:2; width:38px; height:38px; border-radius:50%; background:color-mix(in srgb,var(--paper) 70%, transparent); backdrop-filter:blur(6px); border:1px solid var(--line); font-size:1rem; }
.modal__gallery{ background:linear-gradient(160deg,#fbf7ef,#e6ddcb); padding:1.6rem; display:flex; flex-direction:column; gap:1rem; }
.modal__hero{ flex:1; display:grid; place-items:center; min-height:300px; }
.modal__hero img{ max-height:46vh; width:auto; object-fit:contain; opacity:0; transform:scale(.98); transition:opacity .4s var(--ease), transform .4s var(--ease); }
.modal__hero img.in{ opacity:1; transform:none; }
.modal__thumbs{ display:flex; gap:.6rem; flex-wrap:wrap; }
.thumb{ width:60px; height:60px; border-radius:var(--r-sm); overflow:hidden; border:1px solid var(--line-2); background:var(--paper); transition:border-color var(--t-fast); }
.thumb img{ width:100%; height:100%; object-fit:cover; }
.thumb.is-active{ border-color:var(--ink); }
.modal__info{ padding:clamp(1.6rem,1rem+2vw,2.8rem); display:flex; flex-direction:column; }
.modal__info h3{ font-family:var(--font-display); font-weight:500; font-size:clamp(1.8rem,1.2rem+2vw,2.6rem); line-height:1; margin:.5rem 0; }
.modal__zh{ color:var(--ink-soft); font-weight:300; }
.modal__price{ font-family:var(--font-display); font-size:1.7rem; font-weight:600; margin:1.1rem 0; }
.modal__price span{ font-family:var(--font-sans); font-size:.8rem; color:var(--ink-faint); font-weight:400; letter-spacing:.04em; }
.modal__colors{ display:flex; flex-wrap:wrap; gap:.5rem; margin-bottom:1.3rem; }
.chip{ display:inline-flex; align-items:center; gap:.45em; border:1px solid var(--line-2); border-radius:var(--r-pill); padding:.4em .8em; font-size:.78rem; }
.chip i{ width:13px; height:13px; border-radius:50%; background:var(--d); border:1px solid var(--line-2); }
.modal__specs{ list-style:none; border-top:1px solid var(--line); margin-bottom:1.6rem; }
.modal__specs li{ display:flex; justify-content:space-between; gap:1rem; padding:.7rem 0; border-bottom:1px solid var(--line); font-size:.9rem; }
.modal__specs span{ color:var(--ink-faint); }
.modal__specs b{ font-weight:500; text-align:right; }
.modal__actions{ display:flex; gap:.7rem; margin-top:auto; flex-wrap:wrap; }
.modal__actions .btn{ flex:1; justify-content:center; }
.modal__note{ font-size:.72rem; color:var(--ink-faint); margin-top:1rem; }

/* ---------- toast ---------- */
.toast{ position:fixed; left:50%; bottom:2rem; transform:translate(-50%,140%); z-index:200; background:var(--ink); color:var(--paper); padding:.85em 1.5em; border-radius:var(--r-pill); font-size:.85rem; box-shadow:var(--shadow-l); transition:transform .5s var(--ease); }
.toast.show{ transform:translate(-50%,0); }

/* ---------- nav cart ---------- */
.nav__cart{ position:relative; display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px; border-radius:50%; color:var(--ink); transition:background var(--t-fast); }
.nav__cart:hover{ background:color-mix(in srgb,var(--ink) 8%, transparent); }
.nav__cart-count{ position:absolute; top:0; right:0; min-width:17px; height:17px; padding:0 4px; border-radius:9px; background:var(--ink); color:var(--paper); font-size:.6rem; font-weight:600; display:grid; place-items:center; line-height:1; transition:transform var(--t-fast) var(--ease); }
.nav__cart-count[data-empty]{ transform:scale(0); }

/* ---------- cart drawer ---------- */
.drawer{ position:fixed; inset:0; z-index:160; visibility:hidden; }
body.drawer-open{ overflow:hidden; }
body.drawer-open .drawer{ visibility:visible; }
.drawer__scrim{ position:absolute; inset:0; background:rgba(20,18,15,.45); backdrop-filter:blur(6px); opacity:0; transition:opacity var(--t-med); }
body.drawer-open .drawer__scrim{ opacity:1; }
.drawer__panel{ position:absolute; top:0; right:0; height:100%; width:min(430px,93vw); background:var(--paper); box-shadow:var(--shadow-l); display:flex; flex-direction:column; transform:translateX(100%); transition:transform var(--t-med) var(--ease); }
body.drawer-open .drawer__panel{ transform:none; }
.drawer__head{ display:flex; align-items:center; justify-content:space-between; padding:1.4rem 1.5rem; border-bottom:1px solid var(--line); }
.drawer__head h3{ font-family:var(--font-display); font-weight:600; font-size:1.35rem; }
.drawer__x{ width:34px; height:34px; border-radius:50%; border:1px solid var(--line); font-size:.9rem; }
.drawer__items{ flex:1; overflow:auto; padding:1.2rem 1.5rem; display:flex; flex-direction:column; gap:1.3rem; }
.drawer__empty{ margin:auto; text-align:center; color:var(--ink-faint); display:flex; flex-direction:column; gap:1.1rem; padding:3rem 1rem; }
.drawer__empty .btn{ align-self:center; }
.bagitem{ display:grid; grid-template-columns:66px 1fr auto; gap:1rem; align-items:start; }
.bagitem__img{ width:66px; height:66px; border-radius:var(--r-sm); background:linear-gradient(160deg,#fbf7ef,#e8e0d0); overflow:hidden; }
.bagitem__img img{ width:100%; height:100%; object-fit:contain; padding:7%; }
.bagitem__name{ font-family:var(--font-display); font-weight:600; font-size:1.1rem; line-height:1.1; }
.bagitem__meta{ font-size:.74rem; color:var(--ink-soft); display:inline-flex; align-items:center; gap:.4em; margin-top:.25rem; }
.bagitem__meta i{ width:11px; height:11px; border-radius:50%; background:var(--d); border:1px solid var(--line-2); }
.bagitem__qty{ display:inline-flex; align-items:center; gap:.6rem; margin-top:.5rem; }
.bagitem__qty button{ width:23px; height:23px; border-radius:50%; border:1px solid var(--line-2); font-size:.82rem; line-height:1; transition:background var(--t-fast); }
.bagitem__qty button:hover{ background:color-mix(in srgb,var(--ink) 7%, transparent); }
.bagitem__qty span{ min-width:1.2em; text-align:center; font-size:.85rem; }
.bagitem__right{ text-align:right; }
.bagitem__price{ font-weight:500; font-size:.92rem; white-space:nowrap; }
.bagitem__rm{ font-size:.66rem; color:var(--ink-faint); text-decoration:underline; margin-top:.6rem; }
.drawer__foot{ border-top:1px solid var(--line); padding:1.3rem 1.5rem; display:flex; flex-direction:column; gap:1rem; }
.drawer__sub{ display:flex; justify-content:space-between; align-items:baseline; font-family:var(--font-display); }
.drawer__sub span{ font-family:var(--font-sans); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-faint); }
.drawer__sub b{ font-size:1.5rem; font-weight:600; }
.drawer__foot .btn{ justify-content:center; }
.drawer__note{ font-size:.68rem; color:var(--ink-faint); text-align:center; line-height:1.5; }

/* selectable color chips in modal */
.chip.sel{ cursor:pointer; transition:border-color var(--t-fast), background var(--t-fast); }
.chip.sel:hover{ border-color:var(--ink-soft); }
.chip.sel.is-active{ border-color:var(--ink); background:color-mix(in srgb,var(--ink) 5%, transparent); }

/* ---------- reveal default (pre-JS) ---------- */
[data-reveal]{ will-change:transform,opacity; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1080px){
  .hero__inner{ grid-template-columns:1fr; min-height:auto; gap:0; }
  .hero__copy{ padding-top:5rem; padding-bottom:1rem; order:1; }
  .hero__stage{ order:2; min-height:56vh; }
  .hero__scroll{ display:none; }
  .grid{ grid-template-columns:repeat(2,1fr); }
  .card--feature{ flex-direction:column; }
  .card--feature .card__media{ min-height:300px; }
  .tech__grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:900px){
  .nav__links{ display:none; }
  .nav__burger{ display:flex; }
  .spotlight__grid{ grid-template-columns:1fr; gap:2rem; }
  .spotlight__sticky{ position:relative; top:0; }
  .para,.para--right{ grid-template-columns:1fr; }
  .para--right .para__copy{ order:0; }
  .gifting__grid{ grid-template-columns:1fr; }
  .gifting__media{ max-width:80%; }
  .footer__grid{ grid-template-columns:1fr 1fr; gap:1.6rem 1rem; }
  .modal__panel{ grid-template-columns:1fr; }
  .modal__hero img{ max-height:38vh; }

  /* mobile fullscreen menu */
  body.menu-open{ overflow:hidden; }
  .nav__links{ position:fixed; inset:var(--header-h) 0 0 0; background:var(--paper); flex-direction:column; justify-content:center; align-items:center; gap:1.4rem; font-size:1.4rem; font-family:var(--font-display); transform:translateY(-12px); opacity:0; pointer-events:none; transition:opacity var(--t-med), transform var(--t-med); }
  body.menu-open .nav__links{ display:flex; opacity:1; transform:none; pointer-events:auto; }
  body.menu-open .nav__burger span:nth-child(1){ transform:translateY(3.7px) rotate(45deg); }
  body.menu-open .nav__burger span:nth-child(2){ transform:translateY(-3.7px) rotate(-45deg); }
}
@media (max-width:640px){
  .grid{ grid-template-columns:1fr; }
  .tech__grid{ grid-template-columns:1fr; }
  .palette{ grid-template-columns:1fr 1fr; }
  .join__form{ flex-direction:column; }
  .footer__grid{ grid-template-columns:1fr; }
  .hero__title{ font-size:clamp(2.8rem,2rem+9vw,4rem); }
}

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001s!important; animation-iteration-count:1!important; transition-duration:.01s!important; }
  .marquee__row{ animation:none; }
}
