/* ------- Base ------- */
:root{
  --ivoire:#F7F5F1;
  --ivoire-2:#EFEBE3;
  --anthracite:#1E1E22;
  --anthracite-2:#2A2A2F;
  --cuivre:#B07A4E;
  --cuivre-clair:#D4A373;
  --gris:#6B6B70;
  --gris-clair:#B8B8BC;

  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Inter', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', sans-serif;

  --maxw:1240px;
  --pad-x: clamp(20px, 5vw, 56px);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--ivoire);
  color:var(--anthracite);
  font-family:var(--sans);
  font-weight:300;
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .3s ease}
a:focus-visible, button:focus-visible{outline:2px solid var(--cuivre); outline-offset:3px}

h1,h2,h3{
  font-family:var(--serif);
  font-weight:500;
  letter-spacing:.01em;
  margin:0;
  color:var(--anthracite);
}
h1{font-size:clamp(2.6rem, 6vw, 4.6rem); line-height:1.05}
h2{font-size:clamp(2rem, 4vw, 3.1rem); line-height:1.12}
h3{font-size:1.25rem; letter-spacing:.02em}

em{font-style:italic; color:var(--cuivre)}

.container{max-width:var(--maxw); margin:0 auto; padding: 0 var(--pad-x)}
.section{padding: clamp(80px, 11vw, 140px) 0}

.eyebrow{
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--cuivre);
  margin:0 0 18px;
  font-weight:500;
}
.eyebrow.light{color:var(--cuivre-clair)}

.rule{
  width:56px; height:1px; background:var(--cuivre);
  margin: 18px 0 28px;
}
.rule.center{margin: 18px auto 28px}
.rule.cuivre{background:var(--cuivre-clair)}

.section-head{text-align:center; margin-bottom: clamp(50px, 7vw, 80px)}
.section-head h2{max-width:18ch; margin:0 auto}
.section-sub{max-width:52ch; margin:14px auto 0; color:var(--gris)}

/* ------- Reveal animation ------- */
[data-reveal]{opacity:0; transform:translateY(22px); transition:opacity .9s ease, transform .9s cubic-bezier(.2,.7,.2,1)}
[data-reveal].is-visible{opacity:1; transform:none}
@media (prefers-reduced-motion: reduce){
  [data-reveal]{opacity:1; transform:none; transition:none}
  html{scroll-behavior:auto}
}

/* ------- Header / Nav ------- */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:50;
  transition: background .4s ease, box-shadow .4s ease, border-color .4s ease;
  border-bottom:1px solid transparent;
}
.site-header.is-scrolled{
  background:rgba(247,245,241,.94);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom-color: rgba(176,122,78,.18);
}
.nav-inner{
  max-width:var(--maxw); margin:0 auto;
  padding: 18px var(--pad-x);
  display:flex; align-items:center; justify-content:space-between;
}
.brand{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.7rem;
  color:var(--ivoire);
  letter-spacing:.02em;
}
.site-header.is-scrolled .brand{color:var(--anthracite)}
.brand-apos{color:var(--cuivre)}

.nav ul{
  display:flex; gap:38px;
  list-style:none; margin:0; padding:0;
}
.nav a{
  color:var(--ivoire);
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  position:relative;
  padding: 4px 0;
}
.site-header.is-scrolled .nav a{color:var(--anthracite)}
.nav a::after{
  content:''; position:absolute; left:0; right:0; bottom:0;
  height:1px; background:var(--cuivre);
  transform:scaleX(0); transform-origin:left;
  transition:transform .35s ease;
}
.nav a:hover::after{transform:scaleX(1)}

.burger{
  display:none;
  background:transparent; border:0; padding:8px;
  cursor:pointer;
  width:40px; height:40px;
  flex-direction:column; justify-content:center; gap:5px;
}
.burger span{
  display:block; width:22px; height:1.5px;
  background:var(--ivoire);
  transition: transform .3s ease, opacity .3s ease, background .3s ease;
}
.site-header.is-scrolled .burger span{background:var(--anthracite)}

/* ------- Hero ------- */
.hero{
  position:relative; height:100vh; min-height:620px;
  overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  color:var(--ivoire);
  text-align:center;
}
.hero-video{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  object-position:center center;
  z-index:0;
  filter:saturate(.92) contrast(1.02);
}
@media (min-width: 721px){
  .hero{height: 100vh}
  .hero-video{
    object-position: top center;
  }
}
.hero-overlay{
  position:absolute; inset:0; z-index:1;
  background: linear-gradient(180deg, rgba(30,30,34,.35) 0%, rgba(30,30,34,.45) 40%, rgba(30,30,34,.72) 100%);
}
.hero-content{
  position:relative; z-index:2;
  padding: 0 var(--pad-x);
  max-width:820px;
}
.hero-content .eyebrow{color:var(--cuivre-clair)}
.hero-content h1{
  color:var(--ivoire);
  font-weight:400;
}
.hero-content h1 em{color:var(--cuivre-clair); font-weight:500}
.lede{
  font-size:1.05rem;
  letter-spacing:.04em;
  color: rgba(247,245,241,.86);
  margin: 18px auto 34px;
  max-width:46ch;
}

.btn{
  display:inline-block;
  padding: 14px 32px;
  font-family:var(--sans);
  font-size:.76rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  transition: background .35s ease, color .35s ease, border-color .35s ease;
  cursor:pointer;
}
.btn-ghost{
  color:var(--ivoire);
  border:1px solid var(--cuivre-clair);
  background:transparent;
}
.btn-ghost:hover{
  background:var(--cuivre);
  border-color:var(--cuivre);
  color:var(--ivoire);
}

.scroll-hint{
  position:absolute; left:50%; bottom:34px;
  transform:translateX(-50%);
  z-index:2;
  width:1px; height:56px;
  background: rgba(212,163,115,.6);
  overflow:hidden;
}
.scroll-hint span{
  display:block; width:1px; height:24px;
  background:var(--cuivre-clair);
  animation: drip 2.2s ease-in-out infinite;
}
@keyframes drip{
  0%{transform:translateY(-24px)}
  100%{transform:translateY(56px)}
}

/* ------- About ------- */
.about-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 7vw, 90px);
  align-items:center;
}
.about-figure{margin:0; overflow:hidden}
.about-figure img{
  width:100%; height:auto;
  aspect-ratio: 4/5;
  object-fit:cover;
  filter: saturate(.92) contrast(1.04);
  transition: transform 1.2s ease;
}
.about-figure:hover img{transform:scale(1.03)}
.about-text p{color:var(--gris); margin:0 0 14px; max-width:52ch}
.about-text p:last-child{margin-bottom:0}
.about-text strong{color:var(--anthracite); font-weight:500}

/* ------- Brands ------- */
.section-brands{background: var(--ivoire-2)}
.brand-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(16px, 2vw, 28px);
}
.brand-card{
  margin:0;
  position:relative;
  overflow:hidden;
  background:#fff;
  aspect-ratio: 4/5;
}
.brand-card img{
  width:100%; height:100%;
  object-fit:cover;
  filter: saturate(.88) contrast(1.02);
  transition: transform 1s ease, filter .7s ease;
}
.brand-card figcaption{
  position:absolute; left:0; right:0; bottom:0;
  padding: 16px 20px;
  font-family:var(--serif);
  font-size:1.3rem;
  font-weight:500;
  color:var(--ivoire);
  background: linear-gradient(180deg, transparent 0%, rgba(30,30,34,.75) 100%);
  letter-spacing:.02em;
  transition: color .35s ease;
}
.brand-card:hover img{transform:scale(1.05); filter:saturate(1) contrast(1.05)}
.brand-card:hover figcaption{color:var(--cuivre-clair)}

/* ------- Services ------- */
.services-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(24px, 3vw, 48px);
}
.service{
  text-align:center;
  padding: 36px 24px;
  border-top:1px solid rgba(176,122,78,.25);
}
.service-icon{
  width:52px; height:52px;
  color:var(--cuivre);
  margin-bottom:22px;
}
.service h3{margin-bottom:10px}
.service p{color:var(--gris); font-size:.95rem; margin:0}

/* ------- Universe (mosaic) ------- */
.section-universe{background:var(--ivoire-2)}
.mosaic{
  display:grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 180px;
  gap: 14px;
}
.mosaic-item{
  margin:0; overflow:hidden; position:relative;
  grid-column: span 2;
  grid-row: span 2;
}
.mosaic-item img, .mosaic-item video{
  width:100%; height:100%;
  object-fit:cover;
  filter: saturate(.92) contrast(1.04);
  transition: transform 1.2s ease, filter .7s ease;
}
.mosaic-item:hover img, .mosaic-item:hover video{
  transform:scale(1.04);
  filter:saturate(1) contrast(1.05);
}
.mosaic-tall{grid-row: span 3}
.mosaic-video{grid-row: span 3}

/* ------- Visit ------- */
.section-visit{
  background:var(--anthracite);
  color:var(--ivoire);
  padding: clamp(90px, 12vw, 150px) 0;
}
.section-visit h2{color:var(--ivoire)}
.visit-grid{
  display:grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(40px, 6vw, 90px);
  align-items:start;
}
.visit-address{
  font-style:normal;
  font-size:1.1rem;
  line-height:1.75;
  margin: 22px 0 32px;
  color: rgba(247,245,241,.88);
}
.visit-address a{
  color:var(--cuivre-clair);
  border-bottom:1px solid rgba(212,163,115,.4);
  padding-bottom:2px;
}
.visit-address a:hover{color:var(--ivoire); border-color:var(--ivoire)}

.hours{
  width:100%;
  border-collapse:collapse;
  max-width: 440px;
  font-size:.95rem;
}
.hours th, .hours td{
  padding: 10px 0;
  text-align:left;
  font-weight:400;
  border-bottom:1px solid rgba(212,163,115,.15);
  color: rgba(247,245,241,.82);
}
.hours th{
  width: 38%;
  font-family:var(--serif);
  font-size:1.05rem;
  font-style:italic;
  color:var(--ivoire);
}
.hours tr.closed th, .hours tr.closed td{color:var(--gris-clair)}

.visit-cta{display:flex; flex-direction:column; gap:14px; margin-top:34px}
.cta-block{
  display:flex; align-items:center; gap:18px;
  padding: 20px 24px;
  border:1px solid rgba(212,163,115,.3);
  background: rgba(255,255,255,.02);
  color:var(--ivoire);
  transition: background .35s ease, border-color .35s ease, transform .35s ease;
}
.cta-block svg{width:26px; height:26px; color:var(--cuivre-clair); flex-shrink:0}
.cta-block strong{
  display:block;
  font-family:var(--serif);
  font-size:1.3rem;
  font-weight:500;
  letter-spacing:.02em;
}
.cta-block small{
  display:block;
  font-size:.78rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--gris-clair);
  margin-top:2px;
}
.cta-block:hover{
  background: rgba(176,122,78,.12);
  border-color: var(--cuivre);
  transform: translateX(3px);
}
.cta-inline{
  margin-top:12px;
  font-size:.86rem;
  letter-spacing:.12em;
  color:var(--cuivre-clair);
  align-self:flex-start;
}
.cta-inline:hover{color:var(--ivoire)}

/* ------- Footer ------- */
.site-footer{
  background:var(--anthracite-2);
  color: rgba(247,245,241,.6);
  padding: 40px 0;
  border-top: 1px solid rgba(176,122,78,.2);
}
.footer-inner{
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:14px;
}
.footer-brand{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.3rem;
  color:var(--ivoire);
  margin:0;
}
.footer-meta{
  font-size:.78rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  margin:0;
}

/* ------- Responsive ------- */
@media (max-width: 960px){
  .about-grid{grid-template-columns:1fr}
  .brand-grid{grid-template-columns: repeat(2, 1fr)}
  .services-grid{grid-template-columns: repeat(2, 1fr)}
  .visit-grid{grid-template-columns:1fr}
  .mosaic{
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 160px;
  }
  .mosaic-item{grid-column: span 1; grid-row: span 2}
  .mosaic-tall, .mosaic-video{grid-row: span 2}
}

@media (max-width: 720px){
  .burger{display:flex}
  .nav{
    position:fixed; top:0; right:0;
    width: 78%;
    max-width: 340px;
    height: 100vh;
    background: var(--ivoire);
    padding: 90px 32px 32px;
    transform: translateX(100%);
    transition: transform .45s cubic-bezier(.2,.7,.2,1);
    box-shadow: -10px 0 40px rgba(0,0,0,.1);
  }
  .nav.is-open{transform:translateX(0)}
  .nav ul{flex-direction:column; gap:22px}
  .nav a{
    color:var(--anthracite) !important;
    font-size:1rem;
    letter-spacing:.2em;
  }
  .burger.is-open span:nth-child(1){transform: translateY(6.5px) rotate(45deg)}
  .burger.is-open span:nth-child(2){opacity:0}
  .burger.is-open span:nth-child(3){transform: translateY(-6.5px) rotate(-45deg)}

  .brand-grid{grid-template-columns: 1fr}
  .services-grid{grid-template-columns: 1fr}
  .hero{min-height:560px; height: 92vh}
  .lede{font-size:1rem}
  .footer-inner{flex-direction:column; text-align:center}
}
