:root{
  --bg:#ffffff;
  --text:#2b2b2b;

  --serif:"Cormorant Garamond", serif;
  --sans:"Montserrat", sans-serif;

  --max:1200px;
  --side:40px;
  --gap:18px;
  --split-h:clamp(320px, 52vh, 520px);
}

*{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  background:var(--bg);
  color:var(--text);
  margin:0;
  padding:0;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

body.intro-splashing{
  overflow:hidden;
}

a{ text-decoration:none; color:inherit; transition:opacity .25s ease; }
a:hover{ opacity:.65; }
ul{ list-style:none; margin:0; padding:0; }

img,
video{
  -webkit-user-drag:none;
  -webkit-touch-callout:none;
  user-select:none;
}

.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0, 0, 0, 0);
  white-space:nowrap;
  border:0;
}

a:focus-visible,
button:focus-visible{
  outline:2px solid rgba(0,0,0,.55);
  outline-offset:3px;
}

.wrap{
  max-width:var(--max);
  margin:0 auto;
  padding:0;
}

/* =========================
   Header
========================= */
header{
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:28px 20px 16px 20px;
  background:#fff;
  z-index:100;
  position:sticky;
  top:0;
  transition:padding .25s ease;
}

.header-bar{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  margin-bottom:16px;
  transition:margin .25s ease, justify-content .25s ease;
}

.logo-link{
  display:block;
  width:clamp(220px, 30vw, 300px);
  margin:0;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:width .25s ease, height .25s ease;
}

.logo-img{ width:100%; height:auto; display:block; transition:height .25s ease; }

.brand-switch{
  position:absolute;
  right:6px;
  top:0;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:4px;
  font-family:var(--sans);
  font-size:.65rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#4a4a4a;
  line-height:1.2;
}

.brand-tagline{ opacity:.7; }

.brand-link{
  letter-spacing:.28em;
  font-weight:600;
}

body.is-scrolled .brand-switch{
  display:none;
}

body.is-scrolled header{
  padding:10px 20px 10px 20px;
  flex-direction:row;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}

body.is-scrolled .header-bar{
  margin-bottom:0;
  justify-content:flex-start;
  width:auto;
}

body.is-scrolled .desktop-nav{
  width:auto;
}

body.is-scrolled .desktop-nav ul{
  justify-content:flex-start;
}

body.is-scrolled .logo-link{
  width:auto;
  height:auto;
  overflow:visible;
  justify-content:flex-start;
}

body.is-scrolled .logo-img{
  opacity:1;
  visibility:visible;
  height:12px;
  width:auto;
}

.desktop-nav ul{
  display:flex;
  gap:40px;
  justify-content:center;
  flex-wrap:wrap;
  align-items:center;
}

.desktop-nav{ width:100%; }

.desktop-nav a{
  font-family:var(--sans);
  font-size:.8rem;
  letter-spacing:.25em;
  text-transform:uppercase;
  font-weight:500;
  color:#4a4a4a;
  padding:8px 0;
  line-height:1;
  display:inline-flex;
  align-items:center;
}

.nav-trigger{
  border:0;
  background:transparent;
  cursor:pointer;
  font-family:var(--sans);
  font-size:.8rem;
  letter-spacing:.25em;
  text-transform:uppercase;
  font-weight:500;
  color:#4a4a4a;
  padding:8px 0;
  line-height:1;
  display:inline-flex;
  align-items:center;
}

.menu-toggle{
  position:absolute;
  left:6px;
  border:0;
  background:transparent;
  padding:8px;
  display:none;
  flex-direction:column;
  gap:5px;
}

.menu-line{
  display:block;
  width:22px;
  height:1px;
  background:#2b2b2b;
}

.nav-dropdown{ position:relative; }

.nav-submenu{
  position:absolute;
  top:calc(100% + 6px);
  left:50%;
  transform:translate(-50%, 8px);
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 12px 24px rgba(0,0,0,.08);
  padding:12px 16px;
  display:flex;
  flex-direction:column;
  gap:10px;
  min-width:190px;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease, transform .2s ease;
  z-index:10;
}

.nav-submenu a{
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#2b2b2b;
}

.nav-dropdown:hover .nav-submenu,
.nav-dropdown:focus-within .nav-submenu{
  opacity:1;
  transform:translate(-50%, 0);
  pointer-events:auto;
}

.mobile-drawer{
  position:fixed;
  inset:0;
  background:#fff;
  display:none;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease;
  z-index:200;
}

body.menu-open{
  overflow:hidden;
}

body.menu-open .mobile-drawer{
  opacity:1;
  pointer-events:auto;
}

.menu-close{
  position:absolute;
  top:20px;
  left:16px;
  border:0;
  background:transparent;
  font-size:28px;
  color:#2b2b2b;
}

.mobile-drawer ul{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:18px;
  align-items:center;
}

.mobile-drawer a,
.mobile-collection-toggle{
  font-family:var(--sans);
  font-size:.85rem;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:#2b2b2b;
}

.mobile-collection-toggle{
  border:0;
  background:transparent;
  cursor:pointer;
}

.mobile-collection-toggle::after{
  content:"›";
  margin-left:10px;
  font-size:1rem;
}

.mobile-submenu{
  display:none;
  flex-direction:column;
  gap:12px;
  margin-top:6px;
}

.mobile-collection.is-open .mobile-submenu{
  display:flex;
}

.mobile-ig{
  margin-top:28px;
  font-family:var(--sans);
  font-size:.75rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:#2b2b2b;
}

/* =========================
   Hero
========================= */
.hero{
  width:100%;
  height:min(100vh, 46vw);
  overflow:hidden;
  display:flex;
  position:relative;
  justify-content:center;
  align-items:center;
  margin-bottom:34px;
}

.hero picture,
.hero-secondary picture,
.collection-hero picture{
  display:block;
  width:100%;
  height:100%;
  flex:1 1 auto;
}

.hero img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center;
}

/* =========================
   Collection title line
========================= */
.section-title{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.15rem;
  line-height:1.9;
  color:rgba(43,43,43,.62);
  text-align:center;
  margin:28px 0 44px 0;
  letter-spacing:.02em;
}

.hero-secondary{
  height:min(100vh, 46vw);
  margin-top:40px;
  margin-bottom:80px;
}

#top img{
  object-position:34% 8%;
}

.hero-secondary img{
  object-position:25% 75%;
}

.hero-overlay-text{
  position:absolute;
  right:3.2vw;
  bottom:6%;
  transform:none;
  margin:0;
  display:inline-block;
  font-family:var(--sans);
  font-size:clamp(.72rem, 1.25vw, .96rem);
  font-weight:400;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#ffffff;
  text-shadow:0 4px 18px rgba(0,0,0,.35);
  z-index:2;
  border-bottom:1px solid rgba(255,255,255,.45);
  padding-bottom:4px;
}

.hero-overlay-text:hover{
  opacity:.88;
}

/* =========================
   Feature row (2 images + intro)
========================= */
.feature-row{
  padding:0 72px 52px 72px;
}

.feature-grid{
  display:grid;
  grid-template-columns:minmax(420px, 620px) minmax(300px, 1fr);
  column-gap:56px;
  align-items:start;
}

.feature-images{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap: 14px;
}

.feature-card img{
  width:100%;
  height:auto;
  display:block;
  background:#f4f4f4;
}

.feature-right{ padding-top:50px; }

.brand-kicker{
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  opacity:.6;
  margin-bottom:14px;
}

.brand-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:1.35rem;
  margin:0 0 14px;
}

.brand-copy{
  font-family:var(--serif);
  font-style:italic;
  line-height:1.9;
  font-size:1rem;
  color:#444;
  margin:0 0 22px;
  max-width:44ch;
}

.brand-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}

.btn{
  display:inline-block;
  padding:10px 14px;
  border:1px solid rgba(0,0,0,.18);
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
}

.btn.ghost{
  border-color:rgba(0,0,0,.10);
  opacity:.8;
}

/* =========================
   Slider (2-up looks) — breakout full width
========================= */
.look-slider{
  width:100vw;
  margin-left:calc(50% - 50vw);
  padding:10px 10px 44px 10px;
}

.look-slider .wrap{ max-width:none; }

.look-stage{
  position:relative;
  padding:14px 0 18px 0;
  border-top:none;
}

.slider-kicker{
  text-align:center;
  font-family:var(--sans);
  font-size:.82rem;
  letter-spacing:.30em;
  text-transform:uppercase;
  color:rgba(43,43,43,.55);
  margin:6px 0 14px 0;
}

.look-2up{
  margin-top:12px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  align-items:start;
}

.look-item{ margin:0; }

.look-media{
  position:relative;
  background:#f4f4f4;
  aspect-ratio:2 / 3;
  overflow:hidden;
}

.look-media img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:block;
  object-fit:contain;
  object-position:center;
  opacity:0;
  transition:opacity 600ms ease;
}

.look-media img.is-active{
  opacity:1;
}

.look-cap{
  display:flex;
  flex-direction:column;
  gap:4px;
  padding-top:12px;
  min-height:54px;
}

.look-name{
  font-family:var(--serif);
  font-size:1.05rem;
  color:#222;
}

.look-link{
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  opacity:.65;
  width:fit-content;
  border-bottom:1px solid rgba(0,0,0,.22);
  padding-bottom:3px;
}

.next-arrow{
  position:absolute;
  right:0;
  bottom:0;
  transform:translateY(0);
  background:transparent;
  border:0;
  padding:8px 6px 2px 6px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:10px;
  opacity:.7;
}
.next-arrow:hover{ opacity:1; }

.arrow-line{
  width:96px;
  height:1px;
  background:rgba(0,0,0,.25);
  display:inline-block;
}

.arrow-head{
  font-size:22px;
  line-height:1;
  font-family:var(--sans);
}

/* =========================
   Video split (縮細 video：62% / 38%)
========================= */
.video-split{
  padding:28px 72px 60px 48px;
}

.video-split-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.15fr) minmax(0, .85fr);
  gap:24px;
  align-items:start;
}

.video-left, .image-right{ min-width:0; }

.video-left{ align-self:start; }

.video-box{
  position:relative;
  width:100%;
  max-width:470px;
  margin:0 0 0 auto;
  aspect-ratio:2 / 3;
}

.image-stack{ align-items:center; }

.video-media{
  width:100%;
  height:100%;
  display:block;
  background:#f4f4f4;
  object-fit:cover;
}

.video-caption{
  position:absolute;
  left:12px;
  bottom:12px;
  font-family:var(--serif);
  font-style:italic;
  font-size:.84rem;
  color:rgba(255,255,255,.92);
  text-shadow:0 2px 14px rgba(0,0,0,.55);
}

.image-right{
  display:flex;
  justify-content:center;
  align-items:center;
  align-self:center;
}

.image-stack{
  display:flex;
  flex-direction:column;
  align-items:center;
  width:100%;
}

.image-card{
  width:100%;
  max-width:250px;
}

.image-card img{
  width:100%;
  height:auto;
  display:block;
  background:#f4f4f4;
  object-fit:cover;
}

.image-caption{
  margin:16px 0 0 0;
  max-width:50ch;
  text-align:center;
  font-family:var(--serif);
  font-style:normal;
  font-size:.82rem;
  line-height:1.55;
  letter-spacing:.015em;
  color:rgba(43,43,43,.7);
}

.image-caption-closer{
  display:block;
  font-style:italic;
}

/* =========================
   Intro + About + Footer
========================= */
/* =========================
   Collection pages
========================= */
.collection-page{
  padding-bottom:80px;
}

.collection-hero{
  position:relative;
  overflow:hidden;
  height:min(100vh, 46vw);
  margin-bottom:40px;
}

.collection-hero img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 50%;
}

.collection-hero-title{
  position:absolute;
  top:59%;
  right:6vw;
  transform:translateY(-50%);
  margin:0;
  font-family:var(--sans);
  font-size:clamp(.88rem, 1.95vw, 1.44rem);
  font-weight:400;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:#ffffff;
  text-shadow:0 4px 20px rgba(0,0,0,.4);
  z-index:2;
}

@media (min-width: 1024px){
  .hero,
  .hero-secondary,
  .collection-hero{ height:min(100vh, 42vw); }
  .collection-hero img{ object-position:center 52%; }
}

.collection-title{
  text-align:center;
  font-family:var(--serif);
  font-size:1.7rem;
  margin:40px 0 32px 0;
  letter-spacing:.04em;
}

.collection-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:22px;
  padding:0 40px 80px 40px;
}

.collection-card{
  display:block;
  text-align:center;
}

.collection-card img{
  width:100%;
  height:auto;
  display:block;
  background:#f4f4f4;
}

.collection-card-title{
  margin-top:14px;
  font-family:var(--serif);
  font-size:1.05rem;
}

.look-page{
  max-width:1280px;
  margin:0 auto;
  padding:40px var(--side) 90px;
}

.look-layout{
  display:grid;
  grid-template-columns:minmax(360px, 520px) 1fr;
  gap:40px;
  align-items:start;
}

.look-gallery img{
  width:100%;
  height:auto;
  display:block;
  margin-bottom:24px;
  background:#f4f4f4;
}

.look-meta{
  text-align:left;
  margin-top:6px;
  position:sticky;
  top:120px;
}

.look-title{
  font-family:var(--serif);
  font-size:1.3rem;
  margin:0 0 10px;
}

.look-style-name{
  font-family:var(--serif);
  font-size:1.15rem;
  letter-spacing:.04em;
  margin:0 0 6px;
}

.look-style-code{
  font-family:var(--sans);
  font-size:.68rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(43,43,43,.55);
  margin:0 0 18px;
}

.look-style-desc{
  font-family:var(--serif);
  font-size:.95rem;
  line-height:1.8;
  color:rgba(43,43,43,.78);
}

.look-style-desc p{
  margin:0 0 14px 0;
}

.look-style-section{
  margin:18px 0 8px;
  font-family:var(--sans);
  font-size:.7rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(43,43,43,.7);
  font-weight:600;
  border-top:1px solid rgba(0,0,0,.08);
  padding-top:14px;
}

.look-style-section:first-of-type{
  border-top:0;
  padding-top:0;
  margin-top:0;
}

.look-style-note{
  margin:0 0 12px 0;
  font-family:var(--serif);
  font-size:.88rem;
  color:rgba(43,43,43,.72);
}

.look-style-note strong{
  font-weight:600;
}

.look-desc{
  margin:0;
  max-width:36ch;
  font-family:var(--serif);
  font-style:italic;
  line-height:1.9;
  color:rgba(43,43,43,.7);
}

.look-nav{
  margin-top:36px;
  display:flex;
  justify-content:space-between;
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.2em;
  text-transform:uppercase;
}

.about-page{
  max-width:1100px;
  margin:0 auto;
  padding:40px 24px 90px;
  text-align:center;
}

.about-title{
  font-family:var(--serif);
  font-size:2rem;
  letter-spacing:.06em;
  margin:10px 0 18px;
}

.about-founders{
  font-family:var(--serif);
  font-size:1rem;
  line-height:2.0;
  font-style:normal;
  color:rgba(43,43,43,.7);
  margin-bottom:20px;
}

.about-founders span{
  border-bottom:1px solid rgba(0,0,0,.18);
  padding-bottom:1px;
}

.about-body{
  font-family:var(--serif);
  font-style:normal;
  line-height:2.0;
  font-size:1rem;
  color:rgba(43,43,43,.7);
  max-width:112ch;
  margin:0 auto 18px;
}

.about-gallery{
  margin-top:34px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:18px;
}

.about-gallery img{
  width:100%;
  height:auto;
  display:block;
  background:#f4f4f4;
}

.about-body strong{
  font-style:normal;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.contact-details{
  font-family:var(--serif);
  font-style:italic;
  line-height:2.0;
  color:rgba(43,43,43,.7);
}

.contact-details a{
  color:inherit;
  border-bottom:1px solid rgba(0,0,0,.25);
  padding-bottom:2px;
}

.subscribe-modal{
  position:fixed;
  inset:0;
  display:none;
  z-index:900;
}

.subscribe-modal[aria-hidden="false"]{
  display:block;
}

.subscribe-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.38);
}

.subscribe-modal-card{
  position:relative;
  width:min(520px, calc(100vw - 32px));
  margin:clamp(24px, 9vh, 90px) auto 0;
  background:#fff;
  border:1px solid rgba(0,0,0,.1);
  padding:32px 28px 26px;
  box-shadow:0 22px 64px rgba(0,0,0,.24);
}

.subscribe-close{
  position:absolute;
  top:10px;
  right:10px;
  border:0;
  background:transparent;
  font-size:24px;
  line-height:1;
  color:#3a3a3a;
  cursor:pointer;
}

.subscribe-kicker{
  margin:0 0 10px;
  font-family:var(--sans);
  font-size:.68rem;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:rgba(43,43,43,.55);
}

.subscribe-title{
  margin:0 0 10px;
  font-family:var(--serif);
  font-size:1.85rem;
  font-weight:400;
  letter-spacing:.02em;
}

.subscribe-copy{
  margin:0 0 18px;
  font-family:var(--serif);
  font-size:1rem;
  line-height:1.7;
  color:rgba(43,43,43,.72);
}

.subscribe-form{
  display:grid;
  gap:12px;
}

.subscribe-field{
  display:grid;
  gap:6px;
  text-align:left;
}

.subscribe-field span{
  font-family:var(--sans);
  font-size:.66rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:rgba(43,43,43,.65);
}

.subscribe-field input,
.subscribe-field select{
  width:100%;
  border:1px solid rgba(0,0,0,.18);
  padding:11px 12px;
  font:inherit;
  font-family:var(--sans);
  font-size:.88rem;
  background:#fff;
}

.subscribe-honey{
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  overflow:hidden;
}

.subscribe-submit,
.subscribe-later{
  border:1px solid rgba(0,0,0,.2);
  background:#fff;
  padding:12px 14px;
  font-family:var(--sans);
  font-size:.7rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  cursor:pointer;
}

.subscribe-submit{
  background:#2b2b2b;
  color:#fff;
  border-color:#2b2b2b;
}

.subscribe-submit.is-busy{
  opacity:.72;
}

.subscribe-status{
  min-height:1.2em;
  margin:2px 0 0;
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.04em;
}

.subscribe-status[data-state="success"]{ color:#186a3b; }
.subscribe-status[data-state="error"]{ color:#9c1b1b; }

.subscribe-note{
  margin:2px 0 0;
  font-family:var(--sans);
  font-size:.63rem;
  line-height:1.65;
  color:rgba(43,43,43,.6);
}

body.subscribe-open{
  overflow:hidden;
}

/* =========================
   Contact page
========================= */
.contact-page{
  padding:36px 40px 70px;
}

.contact-shell{
  display:grid;
  grid-template-columns:1fr 1fr;
  border:1px solid rgba(0,0,0,.08);
}

.contact-media{
  position:relative;
  min-height:520px;
}

.contact-media img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center;
}

.contact-panel{
  background:#ffffff;
  color:#2b2b2b;
  padding:56px 60px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.contact-title{
  font-family:var(--serif);
  font-weight:500;
  font-size:1.8rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin:0 0 12px;
}

.contact-subtitle{
  font-family:var(--sans);
  font-size:.85rem;
  letter-spacing:.06em;
  color:rgba(43,43,43,.65);
  margin:0 0 28px;
}

.contact-form{
  display:flex;
  flex-direction:column;
  gap:22px;
}

.contact-field{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.contact-field span{
  font-family:var(--sans);
  font-size:.7rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:rgba(43,43,43,.7);
}

.contact-field input,
.contact-field textarea{
  width:100%;
  border:0;
  border-bottom:1px solid rgba(0,0,0,.2);
  background:transparent;
  color:#2b2b2b;
  padding:10px 0;
  font-family:var(--sans);
  font-size:.9rem;
}

.contact-field textarea{
  resize:vertical;
  min-height:120px;
}

.contact-field input:focus,
.contact-field textarea:focus{
  outline:none;
  border-bottom-color:rgba(0,0,0,.6);
}

.contact-field-light input{
  background:#ffffff;
  color:#1a1a1a;
  border:1px solid rgba(0,0,0,.35);
  padding:10px 12px;
}

.contact-field-light input:focus{
  border-color:rgba(0,0,0,.7);
}

.contact-field-box textarea{
  background:#ffffff;
  color:#1a1a1a;
  border:1px solid rgba(0,0,0,.35);
  padding:12px 12px;
  min-height:140px;
}

.contact-field-box textarea:focus{
  border-color:rgba(0,0,0,.7);
}

.contact-honey{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0, 0, 0, 0);
  white-space:nowrap;
  border:0;
}

.contact-status{
  min-height:18px;
  font-family:var(--sans);
  font-size:.75rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin:6px 0 0;
  color:rgba(43,43,43,.7);
}

.contact-status[data-state="success"]{
  color:#1b6b3a;
}

.contact-status[data-state="error"]{
  color:#a32222;
}

.contact-submit.is-busy{
  opacity:.6;
  cursor:progress;
}

.contact-submit{
  margin-top:8px;
  border:1px solid rgba(0,0,0,.45);
  background:transparent;
  color:#2b2b2b;
  padding:12px 16px;
  font-family:var(--sans);
  font-size:.75rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  cursor:pointer;
}

.contact-submit:hover{
  opacity:.7;
}

.appointment-page{
  max-width:1440px;
  margin:0 auto;
  padding:34px var(--side) 90px;
}

.appointment-page-title{
  margin:0 0 18px;
  font-family:var(--serif);
  font-size:2.2rem;
  letter-spacing:.05em;
  font-weight:400;
  text-align:center;
  color:#2a2a2a;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:16px;
}

.appointment-page-title::before,
.appointment-page-title::after{
  content:"";
  width:58px;
  height:1px;
  background:rgba(42,42,42,.32);
}

.appointment-hero{
  position:relative;
}

.appointment-hero img{
  width:100%;
  height:min(82vh, 960px);
  display:block;
  object-fit:cover;
  object-position:center;
  background:#f4f4f4;
}

.appointment-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(255,255,255,.78) 14%, rgba(255,255,255,.52) 52%, rgba(255,255,255,.4) 100%);
}

.appointment-overlay{
  position:absolute;
  inset:0;
  z-index:1;
  padding:24px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.appointment-content{
  width:min(980px, calc(100% - 48px));
  text-align:center;
}

.appointment-title{
  margin:0 0 14px;
  font-family:var(--serif);
  font-size:2.18rem;
  letter-spacing:.04em;
  font-weight:400;
  color:#1f1f1f;
  text-align:center;
}

.appointment-details{
  display:flex;
  justify-content:center;
  gap:34px;
  flex-wrap:wrap;
  margin-bottom:24px;
}

.appointment-details p{
  margin:0;
  font-family:var(--serif);
  font-size:1.2rem;
  color:rgba(28,28,28,.92);
}

.appointment-details strong{
  font-style:normal;
  letter-spacing:.1em;
  text-transform:uppercase;
  font-size:.72rem;
  font-family:var(--sans);
  color:rgba(28,28,28,.82);
  margin-right:8px;
}

.appointment-note{
  margin:0 0 20px;
  font-family:var(--sans);
  font-size:.8rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:rgba(28,28,28,.8);
}

.appointment-entries{
  width:min(900px, 100%);
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:18px;
  margin:40px auto 0;
}

.appointment-entry{
  border:1px solid rgba(0,0,0,.26);
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(1.5px);
  padding:20px 18px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:7px;
  cursor:pointer;
  text-align:center;
}

.appointment-entry:hover{
  opacity:.82;
}

.appointment-entry-heading{
  margin:0;
  font-family:var(--sans);
  font-size:.86rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:#1f1f1f;
}

.appointment-entry-copy{
  margin:0;
  font-family:var(--serif);
  font-size:1.02rem;
  line-height:1.6;
  color:rgba(28,28,28,.88);
  text-align:center;
}

/* =========================
   Footer
========================= */
.site-footer{
  border-top:1px solid rgba(0,0,0,.08);
  padding:42px 40px 50px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:26px;
}

.footer-logo{
  width:140px;
  display:block;
}

.footer-logo img{
  width:100%;
  display:block;
}

.footer-nav{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:24px;
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#4a4a4a;
}

.footer-copy{
  font-family:var(--sans);
  font-size:.7rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:rgba(74,74,74,.7);
  margin:0;
}

.staff-link{
  position:fixed;
  bottom:12px;
  left:14px;
  opacity:.1;
  font-family:var(--sans);
  font-size:.55rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#4a4a4a;
  z-index:50;
}
.staff-link:hover{ opacity:.45; }

/* =========================
   Responsive
========================= */
@media (max-width: 980px){
  :root{ --side:24px; --gap:14px; }
  .hero{ height:70vh; }
  .hero-secondary{ height:64vh; }
  .hero-overlay-text{
    right:4vw;
    bottom:6%;
    font-size:clamp(.68rem, 2.4vw, .9rem);
    letter-spacing:.12em;
  }
  .collection-hero{ height:58vh; }
  .collection-hero-title{
    top:56%;
    right:4vw;
    font-size:clamp(.85rem, 3.9vw, 1.22rem);
    letter-spacing:.14em;
  }
  .collection-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .look-layout{ grid-template-columns:1fr; }
  .look-meta{ position:static; text-align:center; }
  .look-desc{ max-width:60ch; margin:0 auto; }
  .appointment-page-title{ font-size:1.9rem; margin-bottom:14px; }
  .appointment-page-title::before,
  .appointment-page-title::after{ width:44px; }
  .appointment-hero img{ height:64vh; }
  .appointment-overlay{ padding:20px; }
  .appointment-title{ font-size:1.84rem; }
  .appointment-details{ gap:18px; }
  .appointment-details p{ font-size:1.08rem; }
  .appointment-note{ margin:0 0 16px; font-size:.72rem; }
  .appointment-entries{ width:min(760px, 100%); gap:14px; }
  .contact-page{ padding:20px 24px 60px; }
  .contact-shell{ grid-template-columns:1fr; }
  .contact-media{ min-height:280px; }
  .contact-panel{ padding:42px 32px; }

  .feature-grid{
    grid-template-columns:1fr;
    row-gap:26px;
    column-gap:0;
  }
  .feature-right{ padding-top:24px; }

  .video-split{ padding:28px var(--side) 60px var(--side); }
  .video-split-grid{ grid-template-columns:1fr; }
  .video-box{ max-width:520px; margin:0 auto; }
  .image-card{ display:none; }

  .subscribe-modal-card{
    width:min(500px, calc(100vw - 26px));
    margin:24px auto 0;
    padding:28px 22px 22px;
  }
  .subscribe-title{ font-size:1.55rem; }
}

@media (max-width: 768px){
  .header-bar{ margin-bottom:0; }
  .menu-toggle{ display:flex; }
  .desktop-nav{ display:none; }
  .mobile-drawer{ display:flex; }
  .logo-link{ width:clamp(160px, 46vw, 220px); }
  .brand-switch{ display:none; }
  .appointment-page{ padding:24px 20px 70px; }
  .appointment-page-title{ font-size:1.52rem; margin-bottom:12px; }
  .appointment-page-title::before,
  .appointment-page-title::after{ width:28px; }
  .appointment-hero img{ height:72vh; }
  .appointment-overlay{ padding:16px; }
  .appointment-title{ font-size:1.45rem; }
  .appointment-details{ gap:8px; margin-bottom:0; }
  .appointment-details p{ width:100%; font-size:1rem; }
  .appointment-note{ font-size:.68rem; margin:10px 0 14px; line-height:1.8; }
  .appointment-entries{
    width:100%;
    grid-template-columns:1fr;
    gap:10px;
  }
  .appointment-entry{ padding:14px 12px; }
  .appointment-entry-heading{ font-size:.78rem; }
  .appointment-entry-copy{ font-size:.9rem; }
  .collection-grid{ padding:0 24px 70px 24px; }
  .look-page{ padding:32px 20px 80px; }

  .movement-look{
    grid-template-columns:1fr;
    gap:20px;
  }

  .movement-images{ grid-template-columns:repeat(2, minmax(0, 1fr)); }

  .look-2up{
    display:flex;
    gap:16px;
    overflow-x:auto;
    padding-bottom:8px;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
  }

  .look-item{
    min-width:86vw;
    scroll-snap-align:start;
  }

  .next-arrow{ display:none; }
  .about-gallery{ grid-template-columns:1fr; }

  body.is-scrolled header{
    padding:28px 20px 16px 20px;
    flex-direction:column;
    align-items:center;
    justify-content:flex-start;
    gap:0;
  }

  body.is-scrolled .header-bar{
    justify-content:center;
    width:100%;
    margin-bottom:0;
  }

  body.is-scrolled .menu-toggle{
    left:6px;
    right:auto;
  }

  body.is-scrolled .logo-link{
    width:clamp(160px, 46vw, 220px);
    margin-left:0;
  }

  body.is-scrolled .logo-img{
    width:100%;
    height:auto;
  }
}

@media (max-width: 560px){
  :root{ --side:18px; }
  .hero{ height:58vh; }
  .hero-secondary{ height:54vh; }
  .hero-overlay-text{
    bottom:10px;
    right:14px;
    transform:none;
    letter-spacing:.1em;
  }
  .collection-grid{ grid-template-columns:1fr; }
  .collection-hero{ height:52vh; }
  .collection-hero-title{
    top:14px;
    right:50%;
    transform:translateX(50%);
    letter-spacing:.1em;
  }
  .feature-row{ padding:0 var(--side) 34px var(--side); }
  .feature-images{ grid-template-columns:1fr; }
  .collection-grid{ padding:0 18px 60px 18px; }
  .look-nav{ flex-direction:column; gap:16px; text-align:center; }

  .subscribe-modal-card{
    width:calc(100vw - 18px);
    margin:18px auto 0;
    padding:24px 16px 18px;
  }
  .subscribe-title{ font-size:1.3rem; }
  .subscribe-copy{ font-size:.95rem; }
  .subscribe-submit,
  .subscribe-later{ letter-spacing:.16em; }
}

@media (max-width: 520px){
  .mobile-drawer a,
  .mobile-collection-toggle{
    font-size:.8rem;
    letter-spacing:.22em;
  }
}

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  a{ transition:none; }
  .look-2up{ transition:none; }
  .intro-splash{ transition:none; }
}

.intro-splash{
  position:fixed;
  inset:0;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:999;
  opacity:1;
  visibility:visible;
  transition:opacity .36s ease, visibility .36s ease;
}

.intro-splash.is-hidden{
  opacity:0;
  visibility:hidden;
}

.intro-splash-logo{
  width:clamp(160px, 24vw, 260px);
  height:auto;
  display:block;
}
