:root{
  --paper:#fbfbfa;
  --white:#ffffff;
  --mist:#f3f5f4;
  --wood:#e4e5e3;
  --ink:#181818;
  --muted:#6e6b65;
  --line:rgba(24,24,24,.055);
  --max:1460px;
  --content-max:1380px;
  --serif:"Iowan Old Style","Palatino Linotype","URW Palladio L",Georgia,serif;
  --sans:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:linear-gradient(180deg,#ffffff 0%,#fbfbfa 52%,#f7f8f7 100%);
  color:var(--ink);
  font-family:var(--sans);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{display:block;width:100%;height:100%;object-fit:cover}
button,input{font:inherit}
h1,h2,h3,h4,p,ul{margin:0}

.top-strip{
  padding:9px 16px;
  border-bottom:1px solid var(--line);
  text-align:center;
  font-size:12px;
  color:#77736b;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.site-header{
  position:sticky;
  top:0;
  z-index:80;
  backdrop-filter:blur(18px);
  background:rgba(255,255,255,.9);
}
.nav-shell,.section,.collection-hero,.product-hero,.footer-grid,.timeline,.cart-layout,.article-layout{
  width:min(calc(100% - 52px),var(--content-max));
  margin:0 auto;
}
.nav-shell{
  min-height:78px;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:20px;
}
.nav-left,.nav-right{
  display:flex;
  align-items:center;
  gap:24px;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.11em;
}
.nav-right{justify-content:flex-end}
.brand{
  display:inline-flex;
  align-items:center;
  gap:12px;
  font-family:var(--serif);
  font-size:30px;
  letter-spacing:.04em;
}
.brand img{
  width:34px;
  height:auto;
  object-fit:contain;
}
.menu-toggle{
  display:none;
  padding:0;
  border:0;
  background:none;
  color:var(--ink);
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.11em;
}
.cart-link{display:inline-flex;align-items:center;gap:6px}
.cart-count{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:22px;
  height:22px;
  padding:0 6px;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(255,255,255,.66);
  font-size:12px;
}
.mobile-links{
  display:none;
  width:min(calc(100% - 40px),var(--max));
  margin:0 auto;
  padding:0 0 16px;
  flex-direction:column;
  gap:12px;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.11em;
}
.site-header.open .mobile-links{display:flex}

.eyebrow,.small-label{
  color:var(--muted);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.14em;
}
.small-label{font-size:11px}
h1,h2,h3{
  font-family:var(--serif);
  font-weight:500;
}
h1{
  font-size:clamp(46px,6.2vw,94px);
  line-height:.98;
}
h2{
  font-size:clamp(30px,4vw,56px);
  line-height:1.05;
}
h3{
  font-size:24px;
  line-height:1.18;
}
.lead-copy,.hero-subtitle,.feel-line,.hero-note,.inventory,.card-copy p,.detail-panel p,.article-copy p{
  color:var(--muted);
}

.campaign-hero{
  width:min(calc(100% - 32px),var(--max));
  margin:16px auto 0;
  display:grid;
  grid-template-columns:minmax(0,1.18fr) minmax(320px,.82fr);
  gap:0;
  overflow:hidden;
  background:transparent;
}
.campaign-copy{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  min-height:860px;
  padding:74px 70px 76px;
  background:linear-gradient(180deg,rgba(255,255,255,.08) 0%,rgba(255,255,255,.54) 100%);
}
.hero-copy{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:28px 0 48px;
}
.hero-subtitle{
  max-width:520px;
  margin-top:20px;
  font-size:19px;
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:28px;
}
.hero-note{
  max-width:480px;
  margin-top:28px;
  font-size:14px;
}
.campaign-media{
  min-height:860px;
  background:var(--mist);
}
.campaign-media img{
  height:100%;
}

.button,.mini-button,.filter-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  padding:11px 18px;
  border:1px solid var(--ink);
  border-radius:999px;
  background:transparent;
  color:var(--ink);
  cursor:pointer;
  transition:background .25s ease,color .25s ease,transform .25s ease;
}
.button:hover,.mini-button:hover,.filter-chip:hover{transform:translateY(-1px)}
.button.primary{
  background:var(--ink);
  color:var(--white);
}
.button:disabled{opacity:.4;cursor:not-allowed}
.mini-button{
  min-height:36px;
  padding:8px 13px;
  border-color:var(--line);
  background:rgba(255,255,255,.78);
  font-size:13px;
}
.text-link{
  display:inline-block;
  border-bottom:1px solid rgba(24,24,24,.28);
  padding-bottom:3px;
}

.section{
  padding:112px 0;
}
.section-compact{padding-top:24px}
.section-band{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
  gap:42px;
  padding:18px 0 0;
  border:0;
  border-top:1px solid rgba(24,24,24,.06);
  background:transparent;
}
.band-points{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.band-points p{
  padding-top:14px;
  border-top:1px solid var(--line);
}

.section-head,.collection-hero{
  display:flex;
  justify-content:space-between;
  gap:28px;
  align-items:end;
}
.section-head{margin-bottom:26px}
.collection-hero{
  padding:96px 0 44px;
}
.collection-hero-campaign{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(300px,.7fr);
  align-items:stretch;
  gap:56px;
}
.collection-hero-copy{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}
.collection-hero-media{
  min-height:520px;
  overflow:hidden;
  background:var(--mist);
}
.collection-highlights{
  display:grid;
  gap:10px;
  margin-top:28px;
}
.collection-highlights p{
  padding-top:12px;
  border-top:1px solid var(--line);
  color:var(--muted);
}
.campaign-stack{
  display:grid;
  gap:84px;
}
.campaign-module{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(320px,.8fr);
  gap:48px;
  align-items:end;
  border:0;
  overflow:visible;
  background:transparent;
}
.campaign-module.reverse{
  grid-template-columns:minmax(320px,.8fr) minmax(0,1.05fr);
}
.campaign-module.reverse .campaign-module-media{
  order:2;
}
.campaign-module.reverse .campaign-module-copy{
  order:1;
}
.campaign-module-media{
  min-height:720px;
  background:var(--mist);
}
.campaign-module-copy{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:16px;
  padding:16px 0 32px;
}
.campaign-module-copy p:last-of-type{
  max-width:420px;
  color:var(--muted);
}
.collection-hero > div,
.section-head > div{max-width:760px}
.collection-hero .lead-copy,
.section-head .lead-copy{max-width:500px}

.mood-grid,.product-grid,.process-grid,.footer-grid,.editorial-grid{
  display:grid;
  gap:30px;
}
.mood-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.product-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.sets-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.product-grid-wide{grid-template-columns:repeat(3,minmax(0,1fr))}
.journal-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.editorial-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.ritual-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.product-grid-archive{grid-template-columns:repeat(3,minmax(0,1fr))}
.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}
.series-overview{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}
.series-stack{display:grid;gap:84px;margin-top:30px}

.mood-card,.journal-card,.detail-panel,.timeline-item,.editorial-card,.series-card{
  border:0;
  border-radius:0;
  background:transparent;
}
.product-card{
  background:transparent;
}
.mood-card{
  display:block;
  padding:30px 26px;
}
.mood-card h3{margin:10px 0 8px}
.editorial-card{
  display:grid;
  grid-template-rows:auto 1fr;
  overflow:visible;
}
.editorial-media{
  display:block;
  aspect-ratio:16/14;
  background:#f7f8f7;
}
.editorial-copy{
  display:grid;
  gap:10px;
  padding:22px;
}
.editorial-copy span:last-child{
  color:var(--muted);
}
.ritual-card{
  min-height:260px;
}
.ritual-card p{
  color:var(--muted);
}
.series-card{
  display:grid;
  grid-template-rows:auto 1fr;
  overflow:visible;
}
.series-card-media{
  display:block;
  aspect-ratio:4/3;
  background:#f8f9f8;
}
.series-card-copy{
  display:grid;
  gap:10px;
  padding:22px;
}
.series-card-copy span:last-child{
  color:var(--muted);
}

.card-image{
  display:block;
  aspect-ratio:4/5;
  overflow:hidden;
  background:#f8f9f8;
  position:relative;
}
.journal-image{aspect-ratio:16/12}
.card-copy{
  padding:18px 0 2px;
}
.card-topline,.card-bottomline,.card-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.card-copy h3{
  margin-top:8px;
  font-size:22px;
}
.tone{
  margin-top:8px;
  font-size:14px;
}
.feel-line{
  min-height:72px;
  margin-top:14px;
  font-size:14px;
}
.price{
  color:var(--ink);
  font-weight:600;
}
.large{font-size:30px}
.card-actions{margin-top:16px}
.product-card.is-archived{opacity:.78}
.product-card .card-image img{transition:transform .45s ease, filter .35s ease}
.product-card:hover .card-image img{transform:scale(1.012)}
.product-card .card-copy{border-bottom:1px solid rgba(24,24,24,.06)}
.product-card .card-copy{
  border-bottom:0;
}
.product-card .mini-button{
  border-color:transparent;
  background:transparent;
  padding:0;
  min-height:auto;
}
.inventory.sold{color:#867668}

.product-label{
  position:absolute;
  display:grid;
  grid-template-columns:28px 1fr;
  gap:10px;
  align-items:start;
  background:rgba(255,255,255,.9);
  background:color-mix(in srgb, var(--label-paper) 92%, white 8%);
  color:var(--label-ink);
  border:1px solid var(--label-line);
  box-shadow:0 14px 24px rgba(0,0,0,.08);
  backdrop-filter:blur(10px);
}
.product-label-card{
  left:14px;
  right:14px;
  bottom:14px;
  padding:12px 12px 11px;
}
.product-label-detail{
  left:22px;
  bottom:22px;
  width:min(340px,calc(100% - 44px));
  padding:14px 14px 13px;
}
.product-label-mark{
  display:flex;
  align-items:center;
  justify-content:center;
  padding-top:2px;
}
.product-label-mark img{
  width:22px;
  height:auto;
  object-fit:contain;
  filter:brightness(0);
}
.product-label-body{
  display:grid;
  gap:4px;
}
.product-label-top{
  font-size:10px;
  letter-spacing:.16em;
  text-transform:uppercase;
  opacity:.7;
}
.product-label-name{
  font-family:var(--serif);
  font-size:15px;
  line-height:1.1;
}
.product-label-meta{
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  opacity:.78;
}

.match-panel{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(360px,.9fr);
  gap:26px;
  align-items:end;
  padding:38px 0 0;
  border:0;
  border-top:1px solid rgba(24,24,24,.06);
  border-radius:0;
  background:transparent;
}
.match-form{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:12px;
}
.match-form input{
  min-height:48px;
  padding:0 16px;
  border:1px solid rgba(24,24,24,.1);
  border-radius:999px;
  background:rgba(255,255,255,.85);
}

.series-section{
  padding-top:28px;
  border-top:1px solid rgba(24,24,24,.06);
}
.product-gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
}
.gallery-frame{
  margin:0;
  aspect-ratio:4/5;
  overflow:hidden;
  background:#f8f9f8;
}
.series-section-head{
  display:flex;
  justify-content:space-between;
  gap:24px;
  align-items:end;
  margin-bottom:24px;
}
.series-section-head > div{max-width:560px}
.series-section-head .lead-copy{max-width:420px}
.series-return{
  display:flex;
  justify-content:flex-end;
  margin-top:26px;
}
.series-return-button{
  width:46px;
  height:46px;
  border:1px solid rgba(24,24,24,.1);
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.92);
  color:var(--ink);
  font-size:20px;
  line-height:1;
  transition:transform .25s ease, border-color .25s ease, background .25s ease;
}
.series-return-button:hover{
  transform:translateY(-2px);
  border-color:rgba(24,24,24,.22);
  background:#fff;
}

.filter-bar{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.filter-chip{
  min-height:40px;
  border-color:var(--line);
  font-size:13px;
}
.filter-chip.active{
  background:var(--ink);
  color:var(--white);
}
.results-meta{
  margin:18px 0 0;
  font-size:14px;
  color:var(--muted);
}

.product-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(340px,.88fr);
  gap:60px;
  padding-top:68px;
}
.product-media{
  min-height:840px;
  overflow:hidden;
  background:#f8f9f8;
  position:relative;
}
.product-info{
  padding-top:18px;
}
.breadcrumbs{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-bottom:16px;
  color:var(--muted);
  font-size:13px;
}
.product-summary{
  margin-top:18px;
  max-width:520px;
  font-size:18px;
  color:var(--ink);
}
.product-meta{
  display:flex;
  flex-wrap:wrap;
  gap:18px;
  margin:18px 0 14px;
  color:var(--muted);
  font-size:14px;
}
.pill-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.note-pill{
  display:inline-flex;
  align-items:center;
  min-height:36px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.96);
  color:var(--muted);
  font-size:13px;
}
.qty-row{
  display:flex;
  align-items:center;
  gap:16px;
  margin-top:24px;
}
.qty-label{
  color:var(--muted);
  font-size:14px;
}
.qty-picker{
  display:grid;
  grid-template-columns:42px 56px 42px;
  border:1px solid var(--line);
  border-radius:999px;
  overflow:hidden;
  background:rgba(255,255,255,.82);
}
.qty-picker button,
.qty-picker input{
  height:42px;
  border:0;
  background:transparent;
  text-align:center;
}
.product-detail-grid,.split-section,.cart-layout,.article-layout,.footer-grid{
  display:grid;
  gap:24px;
}
.product-detail-grid,.split-section{grid-template-columns:repeat(2,minmax(0,1fr))}
.detail-panel{
  padding:0;
  box-shadow:none;
}
.detail-panel h2,.detail-panel h3{margin:12px 0}
.note-stack{
  display:grid;
  gap:18px;
}
.detail-list{
  padding-left:18px;
  color:var(--muted);
}
.detail-list li + li{margin-top:8px}
.batch-story{margin-top:18px}

.timeline{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:30px;
  padding:0 0 78px;
}
.timeline-item{
  padding:24px 0 0;
  border-top:1px solid rgba(24,24,24,.08);
}
.timeline-item h3{margin:12px 0}

.process-grid{
  grid-template-columns:repeat(5,minmax(0,1fr));
  padding-bottom:78px;
}

.maison-grid{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(340px,.9fr);
  gap:28px;
  align-items:stretch;
}
.maison-copy{
  padding:32px 0;
}
.maison-copy p:not(.eyebrow){
  max-width:620px;
  margin-top:18px;
  color:var(--muted);
}
.maison-copy .text-link{
  margin-top:22px;
}
.maison-media{
  min-height:560px;
  overflow:hidden;
  background:#f8f9f8;
}

.journal-feature{
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(320px,.8fr);
  gap:52px;
  align-items:end;
  border:0;
  border-radius:0;
  overflow:visible;
  background:transparent;
}
.journal-feature-media{
  min-height:700px;
  background:var(--mist);
}
.journal-feature-copy{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  gap:16px;
  padding:18px 0 28px;
}
.journal-feature-copy p:last-of-type{
  color:var(--muted);
}

.article-layout{
  grid-template-columns:minmax(0,1fr) minmax(320px,.9fr);
  align-items:start;
}
.article-layout img{
  border-radius:8px;
  aspect-ratio:4/5;
}
.article-copy{
  display:grid;
  gap:18px;
}

.cart-layout{
  grid-template-columns:minmax(0,1fr) minmax(320px,.44fr);
}
.cart-items{
  display:grid;
  gap:16px;
}
.cart-item{
  display:grid;
  grid-template-columns:110px 1fr auto;
  gap:18px;
  align-items:center;
  padding:18px;
  border:1px solid rgba(24,24,24,.045);
  border-radius:8px;
  background:rgba(255,255,255,.96);
}
.cart-item img{
  border-radius:8px;
  aspect-ratio:1/1;
}
.cart-controls{
  display:grid;
  grid-template-columns:36px 28px 36px;
  gap:8px;
  align-items:center;
  justify-items:center;
}
.cart-controls button{
  width:36px;
  height:36px;
  border:1px solid var(--line);
  border-radius:999px;
  background:#fff;
}
.summary-list{
  display:grid;
  gap:10px;
  margin:18px 0 22px;
}
.summary-list p{
  display:grid;
  grid-template-columns:1fr auto;
  gap:12px;
  padding-top:10px;
  border-top:1px solid var(--line);
}
.admin-links{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin:10px 0 18px;
}

.text-flow{
  max-width:880px;
}
.text-flow h2{
  margin:28px 0 10px;
  font-size:30px;
}
.text-flow p + p{margin-top:14px}

.site-footer{
  margin-top:44px;
  padding:64px 0 80px;
  border-top:1px solid rgba(24,24,24,.06);
}
.footer-grid{
  grid-template-columns:1.2fr .8fr .8fr .9fr;
}
.footer-grid h3{
  margin:12px 0 10px;
  font-size:28px;
}
.footer-grid h4{
  margin-bottom:12px;
  font-family:var(--sans);
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--muted);
}
.footer-links{
  display:grid;
  gap:10px;
}

.password-page{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:30px;
}
.password-box{
  width:min(420px,100%);
  padding:34px;
  border:1px solid rgba(24,24,24,.08);
  border-radius:8px;
  background:rgba(255,255,255,.92);
}
.password-box h1{
  margin:12px 0;
  font-size:56px;
}
.password-box form{
  display:grid;
  gap:12px;
  margin-top:20px;
}
.password-box input{
  min-height:48px;
  padding:0 14px;
  border:1px solid var(--line);
  border-radius:999px;
  background:#fff;
}
.toast{
  min-height:22px;
  color:#8f6456;
  font-size:14px;
}
.site-toast{
  position:fixed;
  right:20px;
  bottom:20px;
  z-index:100;
  padding:12px 16px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:0 16px 28px rgba(0,0,0,.08);
  opacity:0;
  transform:translateY(10px);
  transition:opacity .24s ease,transform .24s ease;
}
.site-toast.visible{
  opacity:1;
  transform:translateY(0);
}

@media (max-width:1120px){
  .mood-grid,.product-grid,.product-grid-wide,.sets-grid,.timeline,.process-grid,.footer-grid,.editorial-grid,.journal-grid,.ritual-grid,.product-grid-archive,.stats-grid,.series-overview,.product-gallery-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .campaign-hero{
    grid-template-columns:1fr;
  }
  .campaign-module,
  .campaign-module.reverse,
  .journal-feature,
  .match-panel{
    grid-template-columns:1fr;
  }
  .campaign-copy,
  .campaign-media,
  .campaign-module-media,
  .journal-feature-media{
    min-height:620px;
  }
}

@media (max-width:900px){
  .menu-toggle{display:inline-flex}
  .nav-left a,.nav-right a:not(.cart-link){display:none}
  .campaign-hero,.product-hero,.product-detail-grid,.split-section,.cart-layout,.article-layout,.section-band,.collection-hero,.footer-grid,.maison-grid,.journal-feature,.campaign-module,.campaign-module.reverse,.match-panel{
    grid-template-columns:1fr;
  }
  .collection-hero,.section-head{display:block}
  .series-section-head{display:block}
  .collection-hero > * + *,
  .section-head > * + *,
  .series-section-head > * + *{margin-top:14px}
  .campaign-media,.product-media,.maison-media,.collection-hero-media,.campaign-module-media,.journal-feature-media{min-height:420px}
  .match-form{grid-template-columns:1fr}
}

@media (max-width:700px){
  .nav-shell,.section,.collection-hero,.product-hero,.footer-grid,.timeline,.cart-layout,.article-layout{
    width:min(calc(100% - 28px),var(--content-max));
  }
  .mood-grid,.product-grid,.product-grid-wide,.sets-grid,.timeline,.process-grid,.footer-grid,.editorial-grid,.journal-grid,.ritual-grid,.product-grid-archive,.stats-grid,.series-overview,.product-gallery-grid{
    grid-template-columns:1fr;
  }
  .campaign-hero{
    width:min(calc(100% - 20px),var(--max));
  }
  .campaign-copy{
    min-height:unset;
    padding:36px 22px 42px;
  }
  .campaign-media,.campaign-module-media,.journal-feature-media{min-height:340px}
  .campaign-module-copy,
  .journal-feature-copy{padding:28px 22px 32px}
  .section{padding:68px 0}
  .cart-item{grid-template-columns:88px 1fr}
  .cart-controls{grid-column:2}
  .qty-row{flex-direction:column;align-items:flex-start}
  .brand{font-size:24px}
  .brand img{width:28px}
  h1{font-size:clamp(42px,14vw,74px)}
  .hero-actions{display:grid}
  .product-label-card{
    left:10px;
    right:10px;
    bottom:10px;
    padding:10px;
  }
  .product-label-detail{
    left:14px;
    right:14px;
    width:auto;
    bottom:14px;
    padding:12px;
  }
}
