/* =========================================================
   RÊVE Amsterdam — editorial boutique stylesheet
   ========================================================= */
:root{
  --bg:#F4F2EC;          /* cool bone */
  --bg-deep:#ECE8DF;     /* slightly deeper panel */
  --surface:#FFFFFF;
  --ink:#211E1A;         /* near-black warm */
  --ink-soft:#6B6459;    /* muted body */
  --line:#E2DCD0;        /* hairline */
  --line-strong:#CFC6B6;
  --mauve:#A98A86;       /* brand accent (refined #B89999) */
  --mauve-deep:#8E6C68;
  --cognac:#7C4F3A;      /* leather secondary */
  --ok:#3f6b4e;
  --shadow:0 1px 2px rgba(33,30,26,.04),0 18px 40px -28px rgba(33,30,26,.35);
  --maxw:1280px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:"Hanken Grotesk",system-ui,sans-serif;
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4{font-family:"Fraunces",Georgia,serif;font-weight:400;line-height:1.04;margin:0;letter-spacing:-.01em}
.serif{font-family:"Fraunces",Georgia,serif}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,4vw,52px)}
.eyebrow{
  font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;
  font-weight:600;color:var(--mauve-deep);
}
.muted{color:var(--ink-soft)}
.center{text-align:center}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  border:1px solid var(--ink);background:var(--ink);color:var(--bg);
  padding:.95em 1.9em;border-radius:999px;font-size:.82rem;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;transition:.4s var(--ease);
}
.btn:hover{background:transparent;color:var(--ink)}
.btn--ghost{background:transparent;color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--bg)}
.btn--mauve{background:var(--mauve);border-color:var(--mauve);color:#fff}
.btn--mauve:hover{background:transparent;color:var(--mauve-deep);border-color:var(--mauve-deep)}
.btn--block{width:100%}
.link-underline{
  border-bottom:1px solid currentColor;padding-bottom:2px;
  font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;font-weight:600;
  transition:.3s var(--ease);
}
.link-underline:hover{color:var(--mauve-deep)}

/* ---------- announcement bar ---------- */
.ticker{
  background:var(--ink);color:var(--bg);overflow:hidden;white-space:nowrap;
  font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
}
.ticker__track{display:inline-block;padding:9px 0;animation:ticker 28s linear infinite}
.ticker__track span{margin:0 2.2rem;opacity:.92}
.ticker__track span::before{content:"✶";margin-right:2.2rem;color:var(--mauve)}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- header ---------- */
.site-head{position:sticky;top:0;z-index:60;background:rgba(244,242,236,.86);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.site-head__inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  gap:1rem;padding:18px clamp(18px,4vw,52px)}
.nav{display:flex;gap:2rem;align-items:center}
.nav a{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;
  position:relative;padding:4px 0}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;
  background:var(--ink);transition:width .35s var(--ease)}
.nav a:hover::after,.nav a[aria-current="page"]::after{width:100%}
.brandmark{font-family:"Fraunces",serif;font-size:1.7rem;letter-spacing:.16em;
  text-align:center;font-weight:500;display:block;white-space:nowrap}
.brandmark small{display:block;font-family:"Hanken Grotesk",sans-serif;font-size:.52rem;
  letter-spacing:.46em;text-transform:uppercase;font-weight:600;color:var(--ink-soft);margin-top:3px}
.head-actions{display:flex;gap:1.25rem;justify-content:flex-end;align-items:center}
.icon-btn{background:none;border:none;padding:4px;display:inline-flex;position:relative;color:var(--ink)}
.icon-btn svg{width:21px;height:21px;stroke:currentColor;fill:none;stroke-width:1.5}
.icon-btn .count{position:absolute;top:-6px;right:-8px;background:var(--mauve);color:#fff;
  font-size:.6rem;font-weight:700;min-width:16px;height:16px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;font-family:"Hanken Grotesk",sans-serif;padding:0 3px}
.menu-toggle{display:none}

/* ---------- Language toggle (EN / NL) ---------- */
.lang{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line-strong);
  background:var(--surface);border-radius:999px;padding:5px 12px}
.lang button{background:none;border:none;padding:1px 2px;font-family:"Hanken Grotesk",sans-serif;
  font-size:.74rem;font-weight:700;letter-spacing:.08em;color:var(--ink-soft);cursor:pointer;
  transition:.2s var(--ease)}
.lang button:hover{color:var(--ink)}
.lang button.active{color:var(--ink);text-decoration:underline;text-underline-offset:3px}
.lang__sep{color:var(--line-strong);font-size:.74rem}
/* hide Google's own gadget; we use our buttons */
#google_translate_element{position:absolute;width:0;height:0;overflow:hidden;clip:rect(0 0 0 0)}
/* neutralise Google's injected top banner + body shift */
body{top:0!important}
.skiptranslate>iframe{display:none!important;visibility:hidden!important;height:0!important}
.goog-te-banner-frame,.goog-logo-link{display:none!important}
#goog-gt-tt,.goog-tooltip{display:none!important}

/* ---------- hero ---------- */
.hero{position:relative;display:grid;grid-template-columns:1.05fr .95fr;min-height:min(86vh,760px);
  background:var(--bg-deep)}
.hero__copy{display:flex;flex-direction:column;justify-content:center;
  padding:clamp(32px,6vw,90px);gap:1.6rem}
.hero__copy h1{font-size:clamp(2.9rem,6.4vw,5.6rem)}
.hero__copy h1 em{font-style:italic;color:var(--mauve-deep)}
.hero__lead{max-width:42ch;font-size:1.06rem;color:var(--ink-soft)}
.hero__cta{display:flex;gap:1rem;flex-wrap:wrap;margin-top:.3rem}
.hero__media{position:relative;overflow:hidden}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero__tag{position:absolute;left:24px;bottom:24px;background:rgba(244,242,236,.92);
  backdrop-filter:blur(6px);padding:10px 16px;border-radius:999px;font-size:.74rem;
  letter-spacing:.14em;text-transform:uppercase;font-weight:600}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}

/* ---------- marquee value strip ---------- */
.values{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg)}
.values .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;padding:0}
.value{padding:30px clamp(14px,2vw,30px);text-align:center}
.value+ .value{border-left:1px solid var(--line)}
.value h4{font-size:.92rem;font-family:"Hanken Grotesk",sans-serif;font-weight:700;
  letter-spacing:.04em;margin-bottom:6px;text-transform:uppercase}
.value p{font-size:.84rem;color:var(--ink-soft);margin:0}

/* ---------- section heading ---------- */
.section{padding:clamp(56px,9vw,120px) 0}
.section--tight{padding:clamp(40px,6vw,72px) 0}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;
  margin-bottom:clamp(28px,4vw,52px);flex-wrap:wrap}
.sec-head h2{font-size:clamp(2rem,4.4vw,3.4rem)}
.sec-head p{max-width:46ch;color:var(--ink-soft);margin:.4rem 0 0}

/* ---------- product grid ---------- */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,30px)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.card{display:flex;flex-direction:column;position:relative}
.card__media{position:relative;aspect-ratio:4/5;background:var(--surface);overflow:hidden;
  border:1px solid var(--line)}
.card__media img{width:100%;height:100%;object-fit:cover;transition:opacity .6s var(--ease),transform 1.2s var(--ease)}
.card__media img.alt{position:absolute;inset:0;opacity:0}
.card:hover .card__media img.main{opacity:0}
.card:hover .card__media img.alt{opacity:1;transform:scale(1.04)}
.card__badge{position:absolute;top:12px;left:12px;background:var(--ink);color:var(--bg);
  font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;
  padding:5px 11px;border-radius:999px;z-index:2}
.card__wish{position:absolute;top:10px;right:10px;z-index:3;background:rgba(255,255,255,.86);
  border:none;border-radius:999px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateY(-6px);transition:.35s var(--ease)}
.card:hover .card__wish{opacity:1;transform:none}
.card__wish svg{width:18px;height:18px;stroke:var(--ink);fill:none;stroke-width:1.6}
.card__wish.active svg{fill:var(--mauve);stroke:var(--mauve)}
.card__quick{position:absolute;left:12px;right:12px;bottom:12px;z-index:2;
  opacity:0;transform:translateY(10px);transition:.4s var(--ease)}
.card:hover .card__quick{opacity:1;transform:none}
.card__info{padding:16px 2px 4px;display:flex;flex-direction:column;gap:3px}
.card__row{display:flex;justify-content:space-between;align-items:baseline;gap:1rem}
.card__name{font-family:"Fraunces",serif;font-size:1.18rem}
.card__price{font-weight:600;font-size:.98rem;white-space:nowrap}
.card__meta{font-size:.78rem;color:var(--ink-soft);letter-spacing:.02em}
.swatch-row{display:flex;gap:6px;margin-top:8px}
.swatch{width:14px;height:14px;border-radius:999px;border:1px solid var(--line-strong)}

/* ---------- editorial split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;gap:0}
.split__media{min-height:420px;overflow:hidden;background:var(--bg-deep)}
.split__media img{width:100%;height:100%;object-fit:cover}
.split__copy{display:flex;flex-direction:column;justify-content:center;gap:1.2rem;
  padding:clamp(34px,6vw,84px)}
.split__copy h2{font-size:clamp(2rem,4vw,3.2rem)}
.split--rev .split__media{order:2}

/* ---------- quote band ---------- */
.band{background:var(--ink);color:var(--bg);text-align:center;
  padding:clamp(56px,10vw,120px) 0}
.band q{font-family:"Fraunces",serif;font-size:clamp(1.7rem,4vw,3rem);font-style:italic;
  line-height:1.18;display:block;max-width:20ch;margin:0 auto;quotes:none}
.band .eyebrow{color:var(--mauve)}

/* ---------- newsletter ---------- */
.news{background:var(--bg-deep);border-top:1px solid var(--line)}
.news .wrap{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center;
  padding:clamp(40px,7vw,90px) clamp(18px,4vw,52px)}
.news h2{font-size:clamp(1.8rem,3.6vw,2.8rem)}
.field{display:flex;gap:10px;flex-wrap:wrap}
.field input{flex:1;min-width:220px;border:1px solid var(--line-strong);background:var(--surface);
  border-radius:999px;padding:.95em 1.4em;font-family:inherit;font-size:.95rem;color:var(--ink)}
.field input:focus{outline:2px solid var(--mauve);outline-offset:1px}

/* ---------- footer ---------- */
.foot{background:var(--bg);border-top:1px solid var(--line);padding:clamp(48px,6vw,80px) 0 32px}
.foot__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2.4rem}
.foot h5{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;
  margin:0 0 1.1rem;color:var(--ink)}
.foot ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.7rem}
.foot a{font-size:.9rem;color:var(--ink-soft);transition:.25s}
.foot a:hover{color:var(--ink)}
.foot__brand .brandmark{text-align:left}
.foot__brand p{font-size:.9rem;color:var(--ink-soft);max-width:34ch;margin:1rem 0 1.4rem}
.foot__bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;
  margin-top:clamp(38px,5vw,60px);padding-top:24px;border-top:1px solid var(--line);flex-wrap:wrap}
.foot__bottom p{font-size:.78rem;color:var(--ink-soft);margin:0}
.foot__pay img{height:24px;opacity:.85}

/* ---------- page hero (sub pages) ---------- */
.page-hero{padding:clamp(48px,7vw,96px) 0 clamp(28px,4vw,52px);border-bottom:1px solid var(--line)}
.page-hero h1{font-size:clamp(2.4rem,5.4vw,4.4rem)}
.page-hero p{max-width:54ch;color:var(--ink-soft);margin:1rem 0 0;font-size:1.05rem}
.crumbs{font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);
  margin-bottom:1.2rem}
.crumbs a:hover{color:var(--ink)}

/* ---------- shop layout ---------- */
.shop{display:grid;grid-template-columns:230px 1fr;gap:clamp(24px,3vw,52px);
  padding-top:clamp(34px,4vw,56px)}
.filters{position:sticky;top:120px;align-self:start}
.filters h4{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;
  margin:0 0 .9rem;padding-bottom:.7rem;border-bottom:1px solid var(--line)}
.filters+ .filters,.filter-group+.filter-group{margin-top:2rem}
.fbtn{display:block;width:100%;text-align:left;background:none;border:none;padding:.45em 0;
  font-size:.92rem;color:var(--ink-soft);transition:.2s}
.fbtn:hover,.fbtn[aria-pressed="true"]{color:var(--ink);font-weight:600}
.shop__bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.4rem;
  flex-wrap:wrap;gap:1rem}
.shop__bar select{border:1px solid var(--line-strong);background:var(--surface);border-radius:999px;
  padding:.6em 1.2em;font-family:inherit;font-size:.86rem;color:var(--ink)}
.filter-toggle{display:none}

/* ---------- product detail ---------- */
.pdp{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(28px,4vw,64px);
  padding-top:clamp(28px,4vw,48px)}
.gallery{display:flex;flex-direction:column;gap:14px}
.gallery__main{aspect-ratio:4/5;border:1px solid var(--line);background:var(--surface);overflow:hidden}
.gallery__main img{width:100%;height:100%;object-fit:cover}
.gallery__thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.gallery__thumbs button{border:1px solid var(--line);background:var(--surface);padding:0;
  aspect-ratio:1;overflow:hidden;transition:.25s}
.gallery__thumbs button.active{border-color:var(--ink)}
.gallery__thumbs img{width:100%;height:100%;object-fit:cover}
.pdp__info{align-self:start;position:sticky;top:120px}
.pdp__info h1{font-size:clamp(2.2rem,4vw,3.2rem);margin:.5rem 0 .3rem}
.pdp__price{font-size:1.4rem;font-weight:600;margin:.4rem 0 1.2rem}
.pdp__short{color:var(--ink-soft);font-size:1.05rem;margin-bottom:1.4rem}
.pdp__opts{margin:1.4rem 0}
.opt-label{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
  margin-bottom:.6rem;display:block}
.color-row{display:flex;gap:10px;flex-wrap:wrap}
.color-chip{display:flex;align-items:center;gap:8px;border:1px solid var(--line-strong);
  background:var(--surface);border-radius:999px;padding:8px 14px 8px 8px;font-size:.82rem;transition:.25s}
.color-chip.active,.color-chip:hover{border-color:var(--ink)}
.color-chip .dot{width:16px;height:16px;border-radius:999px;border:1px solid rgba(0,0,0,.1)}
.qty{display:inline-flex;align-items:center;border:1px solid var(--line-strong);border-radius:999px;overflow:hidden}
.qty button{background:none;border:none;width:42px;height:44px;font-size:1.1rem;color:var(--ink)}
.qty input{width:40px;text-align:center;border:none;background:none;font-family:inherit;font-size:1rem;color:var(--ink)}
.pdp__buy{display:flex;gap:12px;margin:1.4rem 0 1rem;align-items:stretch;flex-wrap:wrap}
.pdp__buy .btn{flex:1;min-width:180px}
.wish-btn{border:1px solid var(--line-strong);background:var(--surface);border-radius:999px;
  width:52px;display:flex;align-items:center;justify-content:center}
.wish-btn svg{width:20px;height:20px;stroke:var(--ink);fill:none;stroke-width:1.6}
.wish-btn.active svg{fill:var(--mauve);stroke:var(--mauve)}
.accordion{border-top:1px solid var(--line);margin-top:1.6rem}
.acc{border-bottom:1px solid var(--line)}
.acc__head{width:100%;background:none;border:none;display:flex;justify-content:space-between;
  align-items:center;padding:1.1em 0;font-size:.92rem;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;color:var(--ink)}
.acc__head .plus{transition:.3s;font-size:1.2rem;font-weight:400}
.acc.open .plus{transform:rotate(45deg)}
.acc__body{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.acc__body-inner{padding:0 0 1.3em;color:var(--ink-soft);font-size:.95rem}
.acc__body-inner ul{margin:.4rem 0 0;padding-left:1.1rem}
.acc__body-inner li{margin:.3rem 0}
.meta-list{list-style:none;margin:1.4rem 0 0;padding:1.2rem 0 0;border-top:1px solid var(--line);
  display:flex;flex-wrap:wrap;gap:.4rem 2rem;font-size:.84rem;color:var(--ink-soft)}
.meta-list b{color:var(--ink);font-weight:600}

/* ---------- prose pages ---------- */
.prose{max-width:760px;margin:0 auto;padding:clamp(40px,5vw,72px) 0}
.prose h2{font-size:clamp(1.5rem,3vw,2.1rem);margin:2.2rem 0 .8rem}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:1.15rem;font-family:"Hanken Grotesk",sans-serif;font-weight:700;margin:1.6rem 0 .4rem}
.prose p,.prose li{color:var(--ink-soft);font-size:1rem}
.prose ul{padding-left:1.2rem}
.prose li{margin:.4rem 0}
.prose a{color:var(--mauve-deep);border-bottom:1px solid var(--mauve)}
.toc{background:var(--bg-deep);border:1px solid var(--line);border-radius:14px;padding:24px 28px;margin-bottom:2.4rem}
.toc h4{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;margin:0 0 .8rem}
.toc ul{list-style:none;padding:0;margin:0;columns:2;gap:1rem}
.toc a{font-size:.92rem;color:var(--ink-soft);border:none}
.toc a:hover{color:var(--ink)}

/* faq */
.faq-list{max-width:820px;margin:0 auto}
.faq-list .acc__head{font-family:"Fraunces",serif;text-transform:none;font-size:1.12rem;
  letter-spacing:0;font-weight:500;padding:1.3em 0}

/* contact */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,60px);
  padding:clamp(36px,5vw,64px) 0}
.contact__card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:30px}
.contact__card h3{font-family:"Hanken Grotesk",sans-serif;font-size:1rem;font-weight:700;
  letter-spacing:.04em;text-transform:uppercase;margin:0 0 .4rem}
.contact__card p{margin:.2rem 0;color:var(--ink-soft);font-size:.95rem}
.form-grid{display:grid;gap:14px}
.form-grid label{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;
  display:block;margin-bottom:6px}
.form-grid input,.form-grid textarea{width:100%;border:1px solid var(--line-strong);background:var(--surface);
  border-radius:12px;padding:.85em 1em;font-family:inherit;font-size:.95rem;color:var(--ink)}
.form-grid textarea{min-height:140px;resize:vertical}
.form-grid input:focus,.form-grid textarea:focus{outline:2px solid var(--mauve);outline-offset:1px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* ---------- cart drawer ---------- */
.overlay{position:fixed;inset:0;background:rgba(33,30,26,.4);backdrop-filter:blur(2px);
  opacity:0;pointer-events:none;transition:.4s;z-index:90}
.overlay.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(420px,92vw);background:var(--bg);
  z-index:100;transform:translateX(100%);transition:transform .45s var(--ease);
  display:flex;flex-direction:column;box-shadow:-20px 0 60px -30px rgba(0,0,0,.4)}
.drawer.open{transform:none}
.drawer__head{display:flex;justify-content:space-between;align-items:center;padding:22px 24px;
  border-bottom:1px solid var(--line)}
.drawer__head h3{font-size:1.3rem}
.drawer__close{background:none;border:none;font-size:1.4rem;color:var(--ink);line-height:1}
.drawer__body{flex:1;overflow:auto;padding:8px 24px}
.cart-item{display:grid;grid-template-columns:74px 1fr auto;gap:14px;padding:18px 0;border-bottom:1px solid var(--line)}
.cart-item img{width:74px;height:92px;object-fit:cover;border:1px solid var(--line)}
.cart-item h4{font-family:"Fraunces",serif;font-size:1.02rem;font-weight:500}
.cart-item .ci-meta{font-size:.8rem;color:var(--ink-soft);margin:2px 0 8px}
.cart-item .qty{transform:scale(.86);transform-origin:left}
.cart-item .ci-remove{background:none;border:none;color:var(--ink-soft);font-size:.76rem;
  text-decoration:underline;padding:0;margin-top:6px;cursor:pointer}
.cart-item .ci-price{font-weight:600}
.drawer__foot{padding:20px 24px;border-top:1px solid var(--line);background:var(--bg-deep)}
.drawer__total{display:flex;justify-content:space-between;font-weight:600;font-size:1.05rem;margin-bottom:4px}
.drawer__note{font-size:.78rem;color:var(--ink-soft);margin:0 0 14px}
.cart-empty{text-align:center;padding:60px 10px;color:var(--ink-soft)}

/* toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--ink);color:var(--bg);padding:13px 22px;border-radius:999px;font-size:.85rem;
  letter-spacing:.04em;opacity:0;pointer-events:none;transition:.4s var(--ease);z-index:120}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---------- responsive ---------- */
@media(max-width:1024px){
  .grid{grid-template-columns:repeat(3,1fr)}
  .foot__grid{grid-template-columns:1fr 1fr}
  .pdp,.split,.news .wrap,.contact{grid-template-columns:1fr}
  .pdp__info,.filters{position:static}
  .split--rev .split__media{order:0}
}
@media(max-width:820px){
  .nav,.head-actions .desk-only{display:none}
  .menu-toggle{display:inline-flex}
  .site-head__inner{grid-template-columns:auto 1fr auto}
  .head-actions{gap:.7rem}
  .lang{padding:4px 9px;gap:4px}
  .lang button{font-size:.7rem;letter-spacing:.05em}
  .brandmark{text-align:left;font-size:1.4rem}
  .hero{grid-template-columns:1fr}
  .hero__media{min-height:50vh;order:-1}
  .values .wrap{grid-template-columns:1fr 1fr}
  .value:nth-child(3){border-left:none}
  .value:nth-child(odd){border-left:none}
  .value{border-top:1px solid var(--line)}
  .grid{grid-template-columns:repeat(2,1fr)}
  .shop{grid-template-columns:1fr}
  .filters{display:none}
  .filters.open{display:block;position:fixed;inset:auto 0 0 0;top:0;background:var(--bg);
    z-index:95;padding:80px 24px 24px;overflow:auto}
  .filter-toggle{display:inline-flex}
  .toc ul{columns:1}
  .two-col{grid-template-columns:1fr}
}
@media(max-width:520px){
  .grid,.grid--3{grid-template-columns:1fr 1fr;gap:14px}
  .foot__grid{grid-template-columns:1fr}
  .hero__cta{flex-direction:column}
  .hero__cta .btn{width:100%}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
}

/* mobile slide menu */
.mobile-menu{position:fixed;inset:0;background:var(--bg);z-index:110;transform:translateX(-100%);
  transition:transform .4s var(--ease);display:flex;flex-direction:column;padding:24px}
.mobile-menu.open{transform:none}
.mobile-menu__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}
.mobile-menu a{font-family:"Fraunces",serif;font-size:1.8rem;padding:.5rem 0;border-bottom:1px solid var(--line)}
.mobile-menu .close{background:none;border:none;font-size:1.6rem;color:var(--ink)}
