: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; }

.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;
}

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

.logo-link{
  display:block;
  width:clamp(220px, 30vw, 300px);
  margin:0;
}

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

.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:90vh;
  overflow:hidden;
  display:flex;
  justify-content:center;
  align-items:center;
  margin-bottom:34px;
}

.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:78vh;
  margin-top:40px;
  margin-bottom:80px;
}

/* =========================
   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{
  height:76vh;
  margin-bottom:40px;
}

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

.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(auto-fit, minmax(220px, 1fr));
  gap:26px;
  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:italic;
  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:italic;
  line-height:2.0;
  font-size:1rem;
  color:rgba(43,43,43,.7);
  max-width:90ch;
  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;
}

/* =========================
   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;
}

/* =========================
   Responsive
========================= */
@media (max-width: 980px){
  :root{ --side:24px; --gap:14px; }
  .hero{ height:70vh; }
  .hero-secondary{ height:64vh; }
  .collection-hero{ height:64vh; }
  .look-layout{ grid-template-columns:1fr; }
  .look-meta{ position:static; text-align:center; }
  .look-desc{ max-width:60ch; margin:0 auto; }

  .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; }
}

@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); }
  .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; }
}

@media (max-width: 560px){
  :root{ --side:18px; }
  .hero{ height:58vh; }
  .hero-secondary{ height:54vh; }
  .collection-hero{ height:54vh; }
  .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; }
}

@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;
}
