/* =====================================================
   M · U BAGS — Editorial / Atelier
   ===================================================== */

:root{
  --bone:#f1ebde;
  --paper:#ece5d3;
  --ink:#161210;
  --espresso:#1d1611;
  --char:#2a221c;
  --cognac:#b85c30;
  --ochre:#c98a3c;
  --gold:#d8b072;
  --rust:#8a3a1d;
  --line:rgba(22,18,16,.18);
  --line-light:rgba(241,235,222,.18);
  --serif:"Bodoni Moda", "Times New Roman", serif;
  --sans:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;
  --mono:"JetBrains Mono", ui-monospace, monospace;
  --maxw: 1480px;
  --pad: clamp(20px, 4vw, 64px);
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; }

body{
  background:var(--bone);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
em{ font-style:italic; }

/* ============ TICKER ============ */
.ticker{
  background:var(--ink);
  color:var(--bone);
  overflow:hidden;
  border-bottom:1px solid var(--ink);
}
.ticker__track{
  display:inline-flex;
  gap:32px;
  padding:9px 0;
  white-space:nowrap;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  animation: tickerScroll 42s linear infinite;
}
.ticker__track span{ display:inline-block; }
@keyframes tickerScroll{
  from{ transform:translateX(0); }
  to{ transform:translateX(-50%); }
}

/* ============ NAV ============ */
.nav{
  position:sticky; top:0; z-index:50;
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  gap:24px;
  padding:18px var(--pad);
  background:rgba(241,235,222,.92);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom:1px solid var(--line);
}
.nav__brand{
  display:flex; flex-direction:column; gap:0;
  font-family:var(--serif);
}
.brand__mark{
  font-weight:700;
  font-size:22px;
  letter-spacing:.04em;
  line-height:1;
}
.brand__sub{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-top:4px;
  opacity:.7;
}
.nav__links{
  justify-self:center;
  display:flex; gap:22px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.nav__links a{
  position:relative;
  padding:6px 0;
  transition: color .2s;
}
.nav__links a:hover{ color:var(--cognac); }
.nav__links a:after{
  content:""; position:absolute; left:0; right:100%; bottom:2px;
  height:1px; background:var(--cognac);
  transition: right .25s ease;
}
.nav__links a:hover:after{ right:0; }

.nav__cta{
  justify-self:end;
  display:inline-flex; align-items:center; gap:10px;
  background:var(--ink); color:var(--bone);
  padding:11px 18px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  border-radius:999px;
  transition: background .2s, transform .2s;
}
.nav__cta:hover{ background:var(--cognac); transform:translateY(-1px); }
.arrow{ display:inline-block; transition: transform .25s; }
.nav__cta:hover .arrow, .ghost-btn:hover .arrow{ transform: translateX(4px); }

/* ============ HERO ============ */
.hero{
  position:relative;
  padding: 60px var(--pad) 0;
  overflow:hidden;
}
.hero__grid{
  position:relative;
  display:grid;
  grid-template-columns: 1.1fr 1fr;
  grid-template-rows: auto auto auto;
  gap:40px 60px;
  min-height: calc(100vh - 110px);
  max-width: var(--maxw);
  margin: 0 auto;
}

.hero__meta{
  grid-column: 1 / -1;
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--mono);
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
}
.dot{
  width:7px; height:7px; border-radius:50%;
  background: var(--cognac);
  box-shadow: 0 0 0 4px rgba(184,92,48,.15);
  animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse{
  50%{ transform:scale(1.3); box-shadow:0 0 0 8px rgba(184,92,48,0); }
}

.hero__title{
  grid-column: 1;
  font-family:var(--serif);
  font-weight:500;
  line-height: .92;
  letter-spacing:-0.02em;
  font-size: clamp(60px, 11vw, 196px);
}
.hero__title .line{ display:block; }
.hero__title .line--1{ font-style:normal; }
.hero__title .line--2{
  font-style: italic;
  margin-left: clamp(40px, 12vw, 220px);
  color: var(--cognac);
}
.hero__title .line--3{
  font-family: var(--sans);
  font-size: clamp(14px, 1.2vw, 18px);
  font-weight:500;
  letter-spacing:.18em;
  text-transform: uppercase;
  line-height:1.5;
  margin-top: 28px;
  color: var(--ink);
}

.hero__lede{
  grid-column: 1;
  grid-row: 3;
  align-self:end;
  max-width: 460px;
}
.hero__lede p{
  font-size:17px; line-height:1.55;
  color: var(--char);
  margin-bottom:22px;
  max-width: 38ch;
}

.ghost-btn{
  display:inline-flex; align-items:center; gap:14px;
  border:1px solid var(--ink);
  padding: 14px 22px;
  font-family:var(--mono);
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  border-radius:999px;
  transition: background .25s, color .25s;
}
.ghost-btn:hover{ background:var(--ink); color:var(--bone); }
.ghost-btn--light{ border-color:var(--bone); color:var(--bone); }
.ghost-btn--light:hover{ background:var(--bone); color:var(--ink); }

.hero__hero-img{
  grid-column: 2;
  grid-row: 2 / 4;
  position:relative;
}
.hero__hero-img img{
  width:100%; height: 78vh; min-height:520px;
  object-fit:cover;
  border-radius: 4px;
  filter: saturate(1.05);
  box-shadow: 0 30px 60px -30px rgba(0,0,0,.45);
}
.hero__hero-img figcaption{
  position:absolute; bottom:18px; left:18px;
  background:var(--bone);
  padding:8px 14px;
  font-family:var(--mono);
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  border-radius:999px;
}

.hero__float-1, .hero__float-2{
  position:absolute;
  z-index:3;
  border-radius:4px;
  overflow:hidden;
  box-shadow: 0 20px 40px -25px rgba(0,0,0,.55);
}
.hero__float-1{
  width: clamp(140px, 16vw, 240px);
  aspect-ratio: 3/4;
  top: 22%;
  left: 38%;
  transform: rotate(-4deg);
}
.hero__float-1 img, .hero__float-2 img{ width:100%; height:100%; object-fit:cover; }
.hero__float-2{
  width: clamp(120px, 14vw, 200px);
  aspect-ratio: 4/5;
  bottom: 6%;
  left: 28%;
  transform: rotate(5deg);
}

.hero__price{
  position:absolute;
  top: 18%;
  right: -2%;
  display:flex; flex-direction:column; align-items:flex-end;
  background: var(--ink);
  color: var(--bone);
  padding:14px 20px;
  border-radius: 4px;
  z-index: 4;
  transform: rotate(3deg);
  font-family: var(--mono);
}
.hero__price .px{ font-size:10px; letter-spacing:.2em; opacity:.6; }
.hero__price .num{ font-family:var(--serif); font-size:34px; line-height:1; margin:4px 0 6px; }
.hero__price .lbl{ font-size:10px; letter-spacing:.18em; text-transform:uppercase; }

.hero__corner{
  grid-column: 1;
  grid-row: 1;
  justify-self:end;
  display:flex; flex-direction:column; gap:4px; align-items:flex-end;
  font-family:var(--mono); font-size:11px;
  letter-spacing:.16em; text-transform:uppercase;
  opacity:.7;
}

.hero__marquee{
  margin-top: 60px;
  margin-left: calc(var(--pad) * -1);
  margin-right: calc(var(--pad) * -1);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  overflow:hidden;
  background: transparent;
}
.hero__marquee-track{
  display:inline-flex; align-items:center; gap:36px;
  padding: 22px 0;
  white-space:nowrap;
  font-family:var(--serif);
  font-size: clamp(40px, 6vw, 96px);
  font-weight:500;
  letter-spacing:-0.01em;
  animation: tickerScroll 50s linear infinite;
}
.hero__marquee-track span{ display:inline-block; }
.hero__marquee-track i{ font-style:normal; color:var(--cognac); font-size: .5em; }

/* ============ SHARED HEADINGS ============ */
.sec-head{
  display:grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 60px;
  align-items:end;
  padding: 120px var(--pad) 60px;
  max-width: var(--maxw);
  margin: 0 auto;
}
.sec-head--center{
  grid-template-columns: 1fr;
  text-align:center;
  justify-items:center;
}
.sec-head--center .sec-head__lede{ max-width: 60ch; }
.sec-head__num{
  font-family:var(--mono);
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  align-self:start;
}
.sec-head__num.light{ color:var(--bone); }
.sec-head__title{
  font-family:var(--serif);
  font-weight:500;
  font-size: clamp(48px, 8vw, 130px);
  line-height:.95;
  letter-spacing:-.015em;
  grid-column: 1;
}
.sec-head--center .sec-head__title{ grid-column:auto; }
.sec-head__title em{ color:var(--cognac); }
.sec-head__title.light{ color:var(--bone); }
.sec-head__title.light em{ color: var(--gold); }
.sec-head__lede{
  font-size:17px;
  line-height:1.55;
  color: var(--char);
  max-width: 46ch;
  align-self:end;
}
.sec-head__lede.light{ color: rgba(241,235,222,.78); }

.kicker{
  font-family:var(--mono);
  font-size:10.5px; letter-spacing:.22em; text-transform:uppercase;
  display:block;
}
.kicker.light{ color: rgba(241,235,222,.7); }

/* ============ COLLECTIONS ============ */
.collections{
  padding: 0 var(--pad) 80px;
  max-width: var(--maxw);
  margin: 0 auto;
}
.collections__grid{
  display:grid;
  grid-template-columns: 1.5fr 1fr 1fr 1.5fr;
  grid-template-rows: 64vh 64vh;
  gap: 24px;
}
.coll{
  position:relative;
  background:#222;
  overflow:hidden;
  border-radius:4px;
  display:flex;
  align-items:flex-end;
  isolation:isolate;
}
.coll--lg:nth-of-type(1){ grid-column: 1 / 3; grid-row: 1; }
.coll--sm:nth-of-type(2){ grid-column: 3; grid-row: 1; }
.coll--sm:nth-of-type(3){ grid-column: 4; grid-row: 1; }
.coll--lg:nth-of-type(4){ grid-column: 2 / 5; grid-row: 2; }
.collections__grid > .coll:nth-child(odd){ grid-row: 1; }

.coll__img{ position:absolute; inset:0; z-index:1; }
.coll__img img{
  width:100%; height:100%; object-fit:cover;
  transition: transform 1.4s cubic-bezier(.2,.7,.2,1);
}
.coll:hover .coll__img img{ transform: scale(1.06); }
.coll:after{
  content:""; position:absolute; inset:0; z-index:2;
  background: linear-gradient( to top, rgba(0,0,0,.78) 0%, rgba(0,0,0,.15) 50%, rgba(0,0,0,0) 90% );
}
.coll__body{
  position:relative; z-index:3;
  padding: 30px;
  color: var(--bone);
  max-width: 540px;
}
.coll__body .kicker{ color: var(--gold); margin-bottom:10px; }
.coll__body h3{
  font-family:var(--serif);
  font-weight:500;
  font-size: clamp(32px, 4.4vw, 64px);
  line-height:1;
  letter-spacing:-0.01em;
  margin-bottom: 14px;
}
.coll__body p{
  font-size:15px;
  max-width: 44ch;
  line-height:1.55;
  margin-bottom:14px;
  color: rgba(241,235,222,.85);
}
.coll__meta{
  display:flex; gap:10px; align-items:center;
  font-family:var(--mono); font-size:11px;
  letter-spacing:.18em; text-transform:uppercase;
  color: rgba(241,235,222,.7);
}
.coll__meta i{ font-style:normal; }

/* Restructure collection grid more carefully */
.collections__grid{
  grid-template-areas:
    "a a b c"
    "d d d d";
}
.coll:nth-child(1){ grid-area:a; }
.coll:nth-child(2){ grid-area:b; }
.coll:nth-child(3){ grid-area:c; }
.coll:nth-child(4){ grid-area:d; }

/* ============ TRAVEL ============ */
.travel{
  background: var(--ink);
  color: var(--bone);
  padding: 120px 0;
  position:relative;
  overflow:hidden;
}
.travel__head{
  display:grid;
  grid-template-columns: 1.5fr 1fr;
  gap:60px;
  align-items:end;
  padding: 0 var(--pad) 60px;
  max-width: var(--maxw);
  margin: 0 auto;
}
.travel__title{
  font-family:var(--serif);
  font-weight:500;
  font-size: clamp(54px, 9vw, 150px);
  line-height:.92;
  letter-spacing:-.015em;
}
.travel__title em{ color: var(--gold); }
.travel__head p{
  font-size:17px;
  line-height:1.55;
  color: rgba(241,235,222,.78);
  max-width: 42ch;
}
.travel__hint{
  grid-column: 2;
  font-family:var(--mono);
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold);
  margin-top: 20px;
}
.travel__rail{
  display:flex;
  gap:24px;
  padding: 20px var(--pad) 30px;
  overflow-x:auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: thin;
  scrollbar-color: var(--gold) transparent;
  cursor: grab;
}
.travel__rail::-webkit-scrollbar{ height: 6px; }
.travel__rail::-webkit-scrollbar-thumb{ background: var(--gold); border-radius: 3px; }
.travel__rail::-webkit-scrollbar-track{ background: rgba(241,235,222,.08); }

.trip{
  flex: 0 0 clamp(300px, 36vw, 480px);
  scroll-snap-align: start;
  position:relative;
  display:flex; flex-direction:column;
  gap:18px;
}
.trip__num{
  position:absolute;
  top:-30px; left:0;
  font-family:var(--serif);
  font-size: clamp(70px, 9vw, 130px);
  font-weight:500;
  font-style:italic;
  color: rgba(216,176,114,.18);
  line-height:1;
  z-index: 1;
  pointer-events:none;
}
.trip figure{
  position:relative;
  aspect-ratio: 4/5;
  overflow:hidden;
  border-radius:4px;
  z-index:2;
}
.trip figure img{
  width:100%; height:100%; object-fit:cover;
  transition: transform 1.2s ease;
}
.trip:hover figure img{ transform: scale(1.05); }
.trip__cap{
  display:flex; flex-direction:column; gap:10px;
  padding: 4px 4px 0;
}
.trip__cap .kicker{ color: var(--gold); }
.trip__cap h4{
  font-family:var(--serif);
  font-weight:500;
  font-size: 28px;
  line-height:1.05;
  margin-top:2px;
}
.trip__cap p{
  font-size:14px;
  color: rgba(241,235,222,.72);
  max-width: 38ch;
  line-height:1.55;
}
.trip__price{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.18em;
  margin-top:4px;
  color: var(--bone);
}

/* ============ MATERIALS ============ */
.materials{
  position:relative;
  padding: 140px var(--pad);
  max-width: var(--maxw);
  margin: 0 auto;
}
.materials__intro{
  display:grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 60px;
  align-items:end;
  margin-bottom: 80px;
}
.materials__intro h2{
  font-family:var(--serif);
  font-weight:500;
  font-size: clamp(72px, 12vw, 220px);
  line-height:.86;
  letter-spacing:-.02em;
}
.materials__intro h2 em{ color: var(--cognac); }
.materials__intro p{
  font-size:17px;
  line-height:1.55;
  color: var(--char);
  max-width: 42ch;
}
.materials__intro .sec-head__num{
  position:absolute;
  top: 140px;
  left: var(--pad);
}
.materials__layered{
  position:relative;
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 90px;
  gap: 18px;
}
.mat{
  position:relative;
  overflow:hidden;
  border-radius:4px;
  background:#222;
  isolation:isolate;
}
.mat img{
  width:100%; height:100%; object-fit:cover;
  transition: transform 1.2s ease;
}
.mat:hover img{ transform: scale(1.05); }
.mat:after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(to top, rgba(22,18,16,.85) 0%, rgba(22,18,16,.05) 60%);
  z-index:1;
}
.mat figcaption{
  position:absolute; left:0; right:0; bottom:0;
  padding: 22px;
  color: var(--bone);
  z-index:2;
  display:flex; flex-direction:column; gap:6px;
}
.mat figcaption span{
  font-family:var(--mono);
  font-size:10px; letter-spacing:.22em;
  color: var(--gold);
}
.mat figcaption h4{
  font-family:var(--serif);
  font-weight:500;
  font-size:24px;
  line-height:1.1;
}
.mat figcaption p{
  font-size:14px;
  line-height:1.5;
  color: rgba(241,235,222,.82);
  max-width: 36ch;
}
.mat--a{ grid-column: 1 / 7;  grid-row: 1 / 7; }
.mat--b{ grid-column: 7 / 11; grid-row: 1 / 5; }
.mat--c{ grid-column: 7 / 13; grid-row: 5 / 9; }
.mat--d{ grid-column: 1 / 7;  grid-row: 7 / 10; }
.mat--b{ grid-column: 7 / 13; grid-row: 1 / 5; }

/* ============ CRAFT ============ */
.craft{
  background: var(--espresso);
  color: var(--bone);
  padding: 140px 0;
  position:relative;
  overflow:hidden;
}
.craft .sec-head{
  padding-top:0;
}
.process{
  list-style:none;
  max-width: 1100px;
  margin: 60px auto 0;
  padding: 0 var(--pad);
  position:relative;
}
.process:before{
  content:"";
  position:absolute;
  left: 50%; top:0; bottom:0;
  width: 1px;
  background: var(--line-light);
  transform: translateX(-.5px);
}
.step{
  display:grid;
  grid-template-columns: 1fr 1fr;
  align-items:center;
  gap: 60px;
  margin-bottom: 80px;
  position:relative;
}
.step:last-child{ margin-bottom:0; }
.step__index{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  background: var(--ochre);
  color: var(--ink);
  width: 56px; height:56px;
  border-radius:50%;
  display:grid; place-items:center;
  font-family:var(--serif);
  font-style:italic;
  font-size: 22px;
  font-weight:500;
  z-index:2;
  box-shadow: 0 0 0 8px var(--espresso);
}
.step__media{
  aspect-ratio: 4/3;
  border-radius: 4px;
  overflow:hidden;
}
.step__media img{
  width:100%; height:100%; object-fit:cover;
  filter: saturate(.95) contrast(1.05);
}
.step__body h4{
  font-family:var(--serif);
  font-weight:500;
  font-size: clamp(28px, 3vw, 42px);
  line-height:1.05;
  margin-bottom: 14px;
}
.step__body p{
  font-size: 16px;
  color: rgba(241,235,222,.78);
  line-height: 1.6;
  max-width: 38ch;
}
.step--alt{ grid-template-columns: 1fr 1fr; direction: rtl; }
.step--alt > *{ direction: ltr; }

/* ============ EDITORIAL ============ */
.editorial{
  padding: 140px var(--pad);
  max-width: var(--maxw);
  margin: 0 auto;
  position:relative;
}
.editorial__hd{
  display:grid;
  grid-template-columns: 1fr 1fr;
  align-items:end;
  gap:60px;
  margin-bottom: 60px;
}
.editorial__title{
  font-family:var(--serif);
  font-weight:500;
  font-size: clamp(56px, 10vw, 180px);
  line-height: .9;
  letter-spacing:-.02em;
}
.editorial__title em{ color: var(--cognac); font-style:italic; }
.editorial__byline{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color: var(--char);
  align-self: end;
  text-align: right;
}
.editorial__byline strong{ color: var(--ink); font-weight:500; }

.editorial__layout{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 110px;
  gap:24px;
}
.ed{
  position:relative;
  overflow:hidden;
  border-radius:4px;
  background:#222;
}
.ed img{
  width:100%; height:100%; object-fit:cover;
  transition: transform 1.4s ease;
}
.ed:hover img{ transform: scale(1.04); }
.ed figcaption{
  position:absolute; left:14px; bottom:14px;
  background: var(--bone);
  padding: 8px 14px;
  border-radius:999px;
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color: var(--ink);
}
.ed figcaption span{
  color: var(--cognac);
  margin-right:6px;
}
.ed--cover{ grid-column: 1 / 8;  grid-row: 1 / 6; }
.ed--side{ grid-column: 8 / 13; grid-row: 1 / 4; }
.ed--tall{ grid-column: 8 / 13; grid-row: 4 / 8; }
.ed--wide{ grid-column: 1 / 8;  grid-row: 6 / 9; }
.ed__pull{
  grid-column: 8 / 13;
  grid-row: 8 / 9;
  display:flex; flex-direction:column; justify-content:center;
  padding: 12px 4px;
}
.ed__pull p{
  font-family:var(--serif);
  font-style: italic;
  font-size: clamp(20px, 1.6vw, 26px);
  line-height: 1.35;
  margin-bottom: 14px;
  color: var(--ink);
}
.ed__pull span{
  font-family: var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color: var(--char);
}

/* ============ FAVORITES ============ */
.favorites{
  background: var(--paper);
  padding: 140px var(--pad);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.favs{
  max-width: var(--maxw);
  margin: 40px auto 0;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 50px 32px;
}
.fav{
  position:relative;
  display:grid;
  grid-template-rows: auto auto;
  gap:18px;
}
.fav__rank{
  position:absolute;
  top: -6px; left: -6px;
  font-family:var(--serif);
  font-style:italic;
  font-weight:500;
  font-size: 28px;
  color: var(--cognac);
  z-index: 2;
  background: var(--paper);
  padding: 0 10px;
}
.fav figure{
  aspect-ratio: 4/5;
  overflow:hidden;
  border-radius: 4px;
  background:#222;
}
.fav figure img{
  width:100%; height:100%; object-fit:cover;
  transition: transform 1s ease;
}
.fav:hover figure img{ transform: scale(1.05); }
.fav h4{
  font-family:var(--serif);
  font-weight:500;
  font-size: 26px;
  line-height:1.1;
  margin-bottom:6px;
}
.fav__cap{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color: var(--char);
  display:block;
  margin-bottom:10px;
}
.fav p{
  font-size: 14.5px;
  line-height:1.5;
  color: var(--char);
  font-style: italic;
  max-width: 38ch;
}

/* ============ GALLERY ============ */
.gallery{
  padding: 140px var(--pad);
  max-width: 1700px;
  margin: 0 auto;
}
.gallery__head{
  display:grid;
  grid-template-columns: 1fr 1fr;
  align-items:end;
  gap: 60px;
  margin-bottom: 50px;
}
.gallery__title{
  font-family:var(--serif);
  font-weight:500;
  font-size: clamp(54px, 9vw, 150px);
  line-height:.92;
  letter-spacing:-.015em;
}
.gallery__title em{ color: var(--cognac); }
.gallery__head p{
  font-size:17px;
  color:var(--char);
  line-height:1.55;
  max-width: 42ch;
  align-self: end;
}
.gallery__grid{
  display:grid;
  grid-template-columns: repeat(8, 1fr);
  grid-auto-rows: 150px;
  gap: 18px;
}
.g{
  position:relative;
  overflow:hidden;
  border-radius:4px;
  background:#222;
  isolation:isolate;
}
.g img{
  width:100%; height:100%; object-fit:cover;
  transition: transform 1.2s ease, filter .4s ease;
  filter: saturate(.97);
}
.g:hover img{ transform: scale(1.07); filter: saturate(1.1) brightness(1.05); }
.g figcaption{
  position:absolute; inset:0;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding: 22px;
  background: linear-gradient(to top, rgba(22,18,16,.78) 0%, rgba(22,18,16,0) 55%);
  color: var(--bone);
  opacity:.92;
  transition: opacity .3s;
}
.g figcaption strong{
  font-family:var(--serif);
  font-weight:500;
  font-size: 22px;
  display:block;
  margin-bottom:4px;
}
.g figcaption span{
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color: rgba(241,235,222,.8);
}

.g--1{ grid-column: 1 / 4; grid-row: 1 / 4; }
.g--2{ grid-column: 4 / 6; grid-row: 1 / 3; }
.g--3{ grid-column: 6 / 8; grid-row: 1 / 4; }
.g--4{ grid-column: 8 / 9; grid-row: 1 / 3; }
.g--5{ grid-column: 4 / 6; grid-row: 3 / 5; }
.g--6{ grid-column: 8 / 9; grid-row: 3 / 5; }
.g--7{ grid-column: 1 / 3; grid-row: 4 / 6; }
.g--8{ grid-column: 3 / 8; grid-row: 4 / 6; }

/* ============ CONTACT ============ */
.contact{
  position:relative;
  display:grid;
  grid-template-columns: 1.05fr 1fr;
  background: var(--ink);
  color: var(--bone);
  min-height: 90vh;
}
.contact__art{
  position:relative;
  overflow:hidden;
}
.contact__art img{
  width:100%; height:100%; object-fit:cover;
  filter: saturate(1.04) brightness(.92);
}
.contact__art:after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(to right, rgba(22,18,16,0) 70%, var(--ink) 100%);
}
.contact__body{
  padding: 100px var(--pad);
  display:flex; flex-direction:column; justify-content:center;
}
.contact__title{
  font-family:var(--serif);
  font-weight:500;
  font-size: clamp(64px, 9vw, 160px);
  line-height:.9;
  letter-spacing:-.015em;
  margin: 18px 0 50px;
}
.contact__title em{ color: var(--gold); }
.contact__cols{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 36px 40px;
  max-width: 720px;
}
.contact__cols > div:nth-child(3){ grid-column: 1 / -1; max-width: 560px; }
.contact__cols .kicker{ margin-bottom: 8px; }
.contact__cols p{
  font-size: 16px;
  line-height:1.5;
  color: rgba(241,235,222,.85);
  margin-bottom: 22px;
}
.contact__cols a{
  color: var(--gold);
  border-bottom: 1px solid var(--gold);
  padding-bottom: 1px;
}

/* ============ FOOTER ============ */
.foot{
  background: var(--ink);
  color: var(--bone);
  padding: 60px var(--pad) 0;
  position:relative;
  overflow:hidden;
  border-top:1px solid var(--line-light);
}
.foot__top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap: 40px;
  flex-wrap:wrap;
  padding-bottom:40px;
  border-bottom:1px solid var(--line-light);
  max-width: var(--maxw);
  margin: 0 auto;
}
.foot__mark{
  display:flex; flex-direction:column;
  font-family:var(--serif);
}
.foot__brand{
  font-size: 28px;
  font-weight:500;
}
.foot__loc{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color: rgba(241,235,222,.6);
  margin-top: 4px;
}
.foot__nav{
  display:flex;
  gap: 22px;
  flex-wrap:wrap;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.foot__nav a{
  opacity:.78;
  transition: opacity .2s, color .2s;
}
.foot__nav a:hover{ opacity:1; color: var(--gold); }
.foot__priv{ color: var(--gold); opacity:1!important; }

.foot__bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  flex-wrap:wrap;
  padding: 24px 0 30px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color: rgba(241,235,222,.6);
  max-width: var(--maxw);
  margin: 0 auto;
}
.foot__giant{
  font-family:var(--serif);
  font-style:italic;
  font-weight:500;
  font-size: clamp(140px, 24vw, 380px);
  line-height: .85;
  letter-spacing:-.04em;
  white-space:nowrap;
  text-align:center;
  background: linear-gradient(180deg, rgba(216,176,114,.12), rgba(216,176,114,0));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin-top: 20px;
  margin-bottom: -3vw;
  pointer-events:none;
}

/* ============ PRIVACY PAGE ============ */
.priv-wrap{
  max-width: 880px;
  margin: 0 auto;
  padding: 80px var(--pad) 120px;
}
.priv-hero{
  border-bottom:1px solid var(--line);
  padding-bottom: 30px;
  margin-bottom: 50px;
}
.priv-hero .sec-head__num{ margin-bottom: 16px; }
.priv-hero h1{
  font-family:var(--serif);
  font-weight:500;
  font-size: clamp(48px, 7vw, 96px);
  line-height: .95;
  letter-spacing:-.015em;
}
.priv-hero h1 em{ color: var(--cognac); }
.priv-hero .meta{
  font-family:var(--mono);
  font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color: var(--char);
  margin-top:18px;
}
.priv-content h2{
  font-family:var(--serif);
  font-weight:500;
  font-size: 28px;
  line-height: 1.15;
  margin: 38px 0 14px;
  color: var(--ink);
}
.priv-content h3{
  font-family:var(--mono);
  font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  margin: 24px 0 8px;
  color: var(--cognac);
}
.priv-content p, .priv-content li{
  font-size: 16px;
  line-height: 1.7;
  color: var(--char);
  margin-bottom: 14px;
}
.priv-content ul{ padding-left: 22px; margin-bottom: 16px; }
.priv-content li{ margin-bottom: 6px; }
.priv-content strong{ color: var(--ink); font-weight:600; }
.priv-back{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--mono);
  font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  margin-top: 40px;
  border-bottom: 1px solid var(--ink);
  padding-bottom: 4px;
}

/* ============ RESPONSIVE ============ */
@media (max-width: 1100px){
  .hero__grid{
    grid-template-columns: 1fr;
    gap:40px;
    min-height: auto;
  }
  .hero__hero-img{ grid-column:1; grid-row: auto; }
  .hero__hero-img img{ height: 60vh; min-height: 380px; }
  .hero__corner{ justify-self:start; }
  .hero__price{ right:5%; top: 60%; transform: rotate(2deg); }
  .hero__float-1{ top:30%; left: 60%; }
  .hero__float-2{ bottom:5%; left: 70%; }

  .collections__grid{
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "a a"
      "b c"
      "d d";
    grid-template-rows: 60vh 50vh 60vh;
  }
  .materials__layered{
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 240px;
  }
  .mat--a{ grid-column: 1 / 3; grid-row: 1 / 3; }
  .mat--b{ grid-column: 1 / 2; grid-row: 3 / 4; }
  .mat--c{ grid-column: 2 / 3; grid-row: 3 / 4; }
  .mat--d{ grid-column: 1 / 3; grid-row: 4 / 5; }

  .editorial__layout{
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 200px;
  }
  .ed--cover{ grid-column: 1 / 3; grid-row: 1 / 3; }
  .ed--side{ grid-column: 1; grid-row: 3; }
  .ed--tall{ grid-column: 2; grid-row: 3; }
  .ed--wide{ grid-column: 1 / 3; grid-row: 4; }
  .ed__pull{ grid-column: 1 / 3; grid-row: 5; }

  .favs{ grid-template-columns: 1fr 1fr; }

  .gallery__grid{
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: 200px;
  }
  .g--1{ grid-column: 1 / 3; grid-row: 1 / 3; }
  .g--2{ grid-column: 3 / 5; grid-row: 1; }
  .g--3{ grid-column: 3 / 4; grid-row: 2; }
  .g--4{ grid-column: 4 / 5; grid-row: 2; }
  .g--5{ grid-column: 1 / 3; grid-row: 3; }
  .g--6{ grid-column: 3 / 5; grid-row: 3; }
  .g--7{ grid-column: 1 / 3; grid-row: 4; }
  .g--8{ grid-column: 3 / 5; grid-row: 4; }

  .contact{ grid-template-columns: 1fr; }
  .contact__art{ height: 50vh; }
  .contact__art:after{ background: linear-gradient(to bottom, rgba(22,18,16,0) 60%, var(--ink) 100%); }
}

@media (max-width: 760px){
  .nav{
    grid-template-columns: 1fr auto;
  }
  .nav__links{ display:none; }
  .sec-head{ grid-template-columns: 1fr; gap: 26px; padding: 80px var(--pad) 30px; }
  .materials__intro{ grid-template-columns:1fr; gap:24px; }
  .travel__head{ grid-template-columns:1fr; gap:20px; }
  .travel__hint{ grid-column:1; }
  .editorial__hd{ grid-template-columns: 1fr; gap:24px; }
  .editorial__byline{ text-align:left; }
  .gallery__head{ grid-template-columns: 1fr; gap:20px; }
  .favs{ grid-template-columns: 1fr; gap: 40px; }
  .step{ grid-template-columns: 1fr; gap: 24px; padding-top: 40px; margin-bottom: 60px; }
  .step__index{ position: static; transform:none; margin: 0 auto; }
  .step--alt{ direction: ltr; }
  .process:before{ display:none; }
  .contact__cols{ grid-template-columns: 1fr; }
  .foot__bottom{ flex-direction:column; align-items:flex-start; }

  .hero__title .line--2{ margin-left: 30px; }
  .hero__price{ right: 4%; top: auto; bottom: 8%; transform: rotate(2deg); padding: 10px 14px; }
  .hero__price .num{ font-size: 24px; }
  .hero__float-1{ width: 110px; left: 55%; top: 38%; }
  .hero__float-2{ width: 100px; left: 70%; bottom: 4%; }

  .gallery__grid{
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 200px;
  }
  .g--1, .g--2, .g--3, .g--4, .g--5, .g--6, .g--7, .g--8{
    grid-column: auto; grid-row: auto;
  }
  .g--1, .g--8{ grid-column: 1 / 3; }
}
