/* ============================================================
   BR Bespoke Luxury — main.css
   ------------------------------------------------------------
   Section guide:
   1.  Design tokens (colors, fonts, easings)
   2.  Base reset + typography
   3.  Top announcement bar
   4.  Site header (sticky, scroll states, hover anims)
   5.  Main navigation (underline reveal on hover)
   6.  Header CTA button
   7.  Mobile menu (hamburger + overlay)
   8.  Hero
   9.  Reusable: split, cards, image-cards, process, etc.
   10. Page hero, content, footer
   11. Reveal-on-scroll animation
   12. Responsive (≤900px)
   ============================================================ */

/* 1. Design tokens ------------------------------------------ */
:root{
  --navy:#061527;
  --navy-deep:#040f1d;
  --gold:#b89446;
  --gold-soft:#d4b066;
  --ivory:#f8f5ef;
  --ink:#111;
  --muted:#666;
  --white:#fff;
  --shadow-soft:0 18px 50px rgba(0,0,0,.04);
  --shadow-lift:0 24px 60px rgba(0,0,0,.12);
  --shadow-glow:0 10px 30px rgba(184,148,70,.28);
  --ease-luxe:cubic-bezier(.22,.61,.36,1);
  --t-fast:.25s;
  --t-med:.45s;
  --t-slow:.7s;
}

/* 2. Base reset + typography -------------------------------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,"Helvetica Neue",Arial,sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:Georgia,"Cormorant Garamond",serif;font-weight:500;line-height:1.1;margin:0 0 18px;letter-spacing:-.01em}
h1{font-size:clamp(42px,7vw,82px)}
h2{font-size:clamp(30px,4vw,54px)}
h3{font-size:24px}
.eyebrow{letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-size:12px;font-weight:700;margin:0 0 14px}

/* 3a. Testimonial ticker (very top, site-wide) ------------- */
.testimonial-ticker{
  position:relative;
  background:#020812;
  color:#e8e2d4;
  display:flex;
  align-items:center;
  gap:14px;
  padding:11px 5vw;
  border-bottom:1px solid rgba(255,255,255,.05);
  font-size:13px;
  letter-spacing:.02em;
  overflow:hidden;
}
.ticker-track{
  flex:1;
  position:relative;
  min-width:0;
  height:24px;
}
.ticker-slide{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  opacity:0;
  transform:translateX(36px);
  transition:opacity .55s var(--ease-luxe), transform .55s var(--ease-luxe);
  padding:0 8px;
}
.ticker-slide.is-current{opacity:1;transform:translateX(0)}
.ticker-slide.is-leaving{opacity:0;transform:translateX(-36px)}
.ticker-slide .quote{
  color:#fff;
  font-family:Georgia,serif;
  font-style:italic;
  overflow:hidden;
  text-overflow:ellipsis;
}
.ticker-slide .author{
  color:var(--gold);
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  flex:0 0 auto;
}
.ticker-btn{
  background:transparent;
  border:0;
  color:var(--gold);
  cursor:pointer;
  width:28px;
  height:28px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
  transition:color var(--t-fast) var(--ease-luxe), transform var(--t-fast) var(--ease-luxe);
}
.ticker-btn svg{width:14px;height:14px}
.ticker-btn:hover{color:#fff;transform:scale(1.2)}

/* 3. Top announcement bar ---------------------------------- */
.top-bar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:8px 5vw;
  background:var(--navy-deep);
  color:rgba(255,255,255,.78);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.top-bar a{
  color:var(--gold-soft);
  text-decoration:none;
  transition:color var(--t-fast) var(--ease-luxe), letter-spacing var(--t-fast) var(--ease-luxe);
}
.top-bar a:hover{color:#fff;letter-spacing:.26em}

/* 4. Site header ------------------------------------------- */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:22px 5vw;
  background:rgba(6,21,39,.78);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(255,255,255,.04);
  transition:padding var(--t-med) var(--ease-luxe),
             background var(--t-med) var(--ease-luxe),
             box-shadow var(--t-med) var(--ease-luxe);
}
.site-header.scrolled{
  padding:12px 5vw;
  background:rgba(6,21,39,.96);
  box-shadow:0 8px 30px rgba(0,0,0,.25);
}
.brand{
  color:#fff;
  text-decoration:none;
  font-family:Georgia,serif;
  font-size:24px;
  letter-spacing:.02em;
  transition:letter-spacing var(--t-med) var(--ease-luxe),color var(--t-fast) var(--ease-luxe);
}
.brand:hover{letter-spacing:.08em;color:var(--gold-soft)}
.custom-logo{max-height:42px;width:auto}

/* 5. Main navigation --------------------------------------- */
.main-nav ul{
  display:flex;
  gap:34px;
  list-style:none;
  margin:0;
  padding:0;
}
.main-nav a{
  position:relative;
  color:rgba(255,255,255,.85);
  text-decoration:none;
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  padding:6px 0;
  transition:color var(--t-fast) var(--ease-luxe);
}
.main-nav a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:0;
  height:1px;
  width:100%;
  background:var(--gold);
  transform:scaleX(0);
  transform-origin:left center;
  transition:transform var(--t-med) var(--ease-luxe);
}
.main-nav a:hover{color:#fff}
.main-nav a:hover::after{transform:scaleX(1)}
.main-nav a.active{color:var(--gold-soft)}
.main-nav a.active::after{transform:scaleX(1)}

/* 6. Header CTA + base button ------------------------------ */
.header-cta,.btn{
  position:relative;
  display:inline-block;
  padding:13px 26px;
  border:1px solid var(--gold);
  text-decoration:none;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:600;
  overflow:hidden;
  transition:transform var(--t-med) var(--ease-luxe),
             box-shadow var(--t-med) var(--ease-luxe),
             background var(--t-med) var(--ease-luxe),
             color var(--t-med) var(--ease-luxe),
             letter-spacing var(--t-med) var(--ease-luxe);
}
.header-cta,.btn.primary{background:var(--gold);color:#111}
.btn.secondary{color:#fff;background:transparent}
.header-cta:hover,.btn.primary:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-glow);
  background:var(--gold-soft);
  letter-spacing:.26em;
}
.btn.secondary:hover{
  transform:translateY(-2px);
  background:rgba(255,255,255,.05);
  letter-spacing:.26em;
}

/* 7. Mobile menu (hamburger + overlay) --------------------- */
.menu-toggle{
  display:none;
  background:none;
  border:0;
  width:36px;
  height:36px;
  padding:0;
  cursor:pointer;
  position:relative;
  z-index:101;
}
.menu-toggle span{
  display:block;
  position:absolute;
  left:6px;
  width:24px;
  height:1.5px;
  background:#fff;
  transition:transform var(--t-med) var(--ease-luxe),
             opacity var(--t-fast) var(--ease-luxe),
             top var(--t-med) var(--ease-luxe);
}
.menu-toggle span:nth-child(1){top:11px}
.menu-toggle span:nth-child(2){top:17px}
.menu-toggle span:nth-child(3){top:23px}
.menu-toggle.open span{background:var(--gold)}
.menu-toggle.open span:nth-child(1){top:17px;transform:rotate(45deg)}
.menu-toggle.open span:nth-child(2){opacity:0}
.menu-toggle.open span:nth-child(3){top:17px;transform:rotate(-45deg)}

.mobile-overlay{
  position:fixed;
  inset:0;
  background:rgba(4,15,29,.98);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  z-index:100;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  visibility:hidden;
  transition:opacity var(--t-med) var(--ease-luxe), visibility var(--t-med) var(--ease-luxe);
}
.mobile-overlay.open{opacity:1;visibility:visible}
.mobile-overlay nav{text-align:center}
.mobile-overlay ul{list-style:none;margin:0 0 36px;padding:0}
.mobile-overlay li{margin:18px 0;opacity:0;transform:translateY(14px);transition:opacity var(--t-slow) var(--ease-luxe), transform var(--t-slow) var(--ease-luxe)}
.mobile-overlay.open li{opacity:1;transform:translateY(0)}
.mobile-overlay.open li:nth-child(1){transition-delay:.10s}
.mobile-overlay.open li:nth-child(2){transition-delay:.16s}
.mobile-overlay.open li:nth-child(3){transition-delay:.22s}
.mobile-overlay.open li:nth-child(4){transition-delay:.28s}
.mobile-overlay.open li:nth-child(5){transition-delay:.34s}
.mobile-overlay.open li:nth-child(6){transition-delay:.40s}
.mobile-overlay a{
  color:#fff;
  text-decoration:none;
  font-family:Georgia,serif;
  font-size:32px;
  letter-spacing:.04em;
  transition:color var(--t-fast) var(--ease-luxe);
}
.mobile-overlay a:hover{color:var(--gold)}
.mobile-overlay .btn{display:inline-block;opacity:0;transition:opacity var(--t-slow) var(--ease-luxe) .45s, transform var(--t-med) var(--ease-luxe), box-shadow var(--t-med) var(--ease-luxe), background var(--t-med) var(--ease-luxe)}
.mobile-overlay.open .btn{opacity:1}
body.menu-open{overflow:hidden}

/* 8. Hero -------------------------------------------------- */
.hero{
  min-height:88vh;
  position:relative;
  display:flex;
  align-items:center;
  padding:8vw 6vw;
  background:url('https://images.unsplash.com/photo-1594938298603-c8148c4dae35?auto=format&fit=crop&w=1800&q=80') center/cover;
  overflow:hidden;
}
.hero-video,
.hero-youtube{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  pointer-events:none;
  z-index:0;
}
.hero-youtube{
  /* YouTube iframe needs wider scale to avoid letterboxing */
  border:0;
}
.hero-youtube-wrap{
  position:absolute;
  inset:0;
  z-index:0;
  overflow:hidden;
  pointer-events:none;
}
.hero-youtube-wrap iframe{
  position:absolute;
  top:50%;left:50%;
  width:177.78vh;
  min-width:100%;
  height:56.25vw;
  min-height:100%;
  transform:translate(-50%,-50%);
  border:0;
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(6,21,39,.9),rgba(6,21,39,.3));
  z-index:1;
}
.hero-content{max-width:760px;color:#fff;position:relative;z-index:2}
.hero-content p{font-size:20px;max-width:680px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:28px}

/* Brand film section (click-to-play YouTube) */
.brand-film{
  padding:110px 6vw;
  background:var(--ivory);
}
.brand-film-head{
  text-align:center;
  max-width:680px;
  margin:0 auto 50px;
}
.brand-film-head h2{margin:0 0 14px}
.brand-film-head p{margin:0;color:var(--muted);font-size:17px}
.brand-film-player{
  position:relative;
  max-width:1100px;
  margin:0 auto;
  aspect-ratio:16/9;
  overflow:hidden;
  cursor:pointer;
  background:#000;
  box-shadow:0 30px 80px rgba(0,0,0,.25);
  transition:transform var(--t-med) var(--ease-luxe), box-shadow var(--t-med) var(--ease-luxe);
}
.brand-film-player:hover{transform:translateY(-4px);box-shadow:0 40px 100px rgba(0,0,0,.35)}
.brand-film-player img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  opacity:.88;
  transition:transform 1s var(--ease-luxe), opacity var(--t-med) var(--ease-luxe);
}
.brand-film-player:hover img{transform:scale(1.04);opacity:1}
.brand-film-player .play-btn{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:transparent;
  border:0;
  cursor:pointer;
  padding:0;
}
.brand-film-player .play-btn svg{
  width:96px;
  height:96px;
  color:#fff;
  filter:drop-shadow(0 8px 30px rgba(0,0,0,.6));
  transition:transform var(--t-med) var(--ease-luxe), color var(--t-fast) var(--ease-luxe);
}
.brand-film-player:hover .play-btn svg{transform:scale(1.12);color:var(--gold-soft)}
.brand-film-player .film-meta{
  position:absolute;
  bottom:24px;
  left:24px;
  right:24px;
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  z-index:2;
}
.brand-film-player .film-title{
  color:#fff;
  font-family:Georgia,serif;
  font-size:22px;
  line-height:1.2;
  margin:0;
  max-width:60%;
  text-shadow:0 2px 12px rgba(0,0,0,.5);
}
.brand-film-player .film-duration{
  background:rgba(0,0,0,.6);
  color:var(--gold);
  padding:8px 14px;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.brand-film-player .film-duration::before{
  content:"";
  display:inline-block;
  width:6px;
  height:6px;
  background:var(--gold);
  border-radius:50%;
}

/* Video lightbox (shared — used by brand film, lookbook reels later) */
.video-lightbox{
  position:fixed;
  inset:0;
  z-index:220;
  display:none;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.95);
  padding:5vw;
  opacity:0;
  transition:opacity .35s var(--ease-luxe);
}
.video-lightbox.is-open{display:flex;opacity:1}
.video-lightbox-frame{
  position:relative;
  width:100%;
  max-width:1200px;
  aspect-ratio:16/9;
  background:#000;
  box-shadow:0 30px 80px rgba(0,0,0,.5);
}
.video-lightbox-frame iframe,
.video-lightbox-frame video{
  width:100%;height:100%;
  border:0;
  display:block;
}
.video-lightbox-close{
  position:absolute;
  top:-46px;
  right:-4px;
  width:38px;height:38px;
  background:transparent;
  border:0;
  color:#fff;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:transform var(--t-fast) var(--ease-luxe);
}
.video-lightbox-close:hover{transform:rotate(90deg) scale(1.1)}
.video-lightbox-close svg{width:24px;height:24px}

@media (max-width:900px){
  .brand-film{padding:60px 5vw}
  .brand-film-player .play-btn svg{width:64px;height:64px}
  .brand-film-player .film-title{font-size:16px;max-width:55%}
  .brand-film-player .film-meta{bottom:14px;left:14px;right:14px}
  .video-lightbox{padding:5vw}
  .video-lightbox-close{top:-40px}
}

/* 9. Section spacing + reusable layouts -------------------- */
.split-section,.cards-section,.services-preview,.process,.team-preview,.testimonials,.content-wrap{padding:90px 6vw}
.split-section{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;background:var(--ivory)}
.value-list p{border-left:2px solid var(--gold);padding-left:18px;margin:0 0 20px}

.cards{display:grid;gap:24px;margin-top:38px}
.cards.four{grid-template-columns:repeat(4,1fr)}
.cards.three{grid-template-columns:repeat(3,1fr)}
.cards article{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  padding:34px;
  box-shadow:var(--shadow-soft);
  transition:transform var(--t-med) var(--ease-luxe), box-shadow var(--t-med) var(--ease-luxe);
}
.cards article:hover{transform:translateY(-6px);box-shadow:var(--shadow-lift)}
.cards img{width:100%;height:280px;object-fit:cover;margin-bottom:20px}

/* Card icon — used in "The BR Bespoke Difference" cards */
.card-icon{
  display:block;
  width:48px;
  height:48px;
  color:var(--gold);
  margin-bottom:22px;
  transition:transform var(--t-med) var(--ease-luxe), color var(--t-fast) var(--ease-luxe);
}
.cards article:hover .card-icon{
  transform:scale(1.1) rotate(-4deg);
  color:var(--gold-soft);
}

/* Team carousel ------------------------------------------- */
.team-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:24px;
  margin-bottom:42px;
}
.team-head h2{margin:0}
.carousel-nav{display:flex;gap:12px}
.carousel-btn{
  width:52px;
  height:52px;
  border-radius:50%;
  background:transparent;
  border:1px solid rgba(0,0,0,.15);
  color:var(--ink);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
  transition:background var(--t-med) var(--ease-luxe),
             border-color var(--t-med) var(--ease-luxe),
             color var(--t-med) var(--ease-luxe),
             transform var(--t-med) var(--ease-luxe),
             box-shadow var(--t-med) var(--ease-luxe),
             opacity var(--t-fast) var(--ease-luxe);
}
.carousel-btn svg{width:18px;height:18px}
.carousel-btn:hover{
  background:var(--gold);
  border-color:var(--gold);
  color:#fff;
  transform:translateY(-2px);
  box-shadow:var(--shadow-glow);
}
.carousel-btn:disabled{opacity:.25;cursor:not-allowed;transform:none;box-shadow:none;background:transparent;color:var(--ink);border-color:rgba(0,0,0,.15)}

.team-carousel{
  display:flex;
  gap:24px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  scroll-padding-left:6vw;
  scrollbar-width:none;
  -ms-overflow-style:none;
  margin:0 -6vw;
  padding:8px 6vw 30px;
}
.team-carousel::-webkit-scrollbar{display:none}

.team-card{
  flex:0 0 320px;
  scroll-snap-align:start;
  transition:transform var(--t-med) var(--ease-luxe);
}
.team-photo{
  position:relative;
  width:100%;
  aspect-ratio:4/5;
  overflow:hidden;
  background:var(--ivory);
  margin-bottom:22px;
}
.team-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  opacity:.92;
  transition:transform var(--t-slow) var(--ease-luxe), opacity var(--t-med) var(--ease-luxe);
}
.team-card:hover .team-photo img{transform:scale(1.06);opacity:1}
.team-card .role{
  color:var(--gold);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  margin:0 0 8px;
  font-weight:700;
}
.team-card h3{margin:0 0 12px;font-size:24px}
.team-card > p:last-child{margin:0;color:var(--muted);font-size:15px;line-height:1.55}

.image-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.image-card{min-height:460px;position:relative;overflow:hidden;display:flex;align-items:flex-end;background:var(--navy);color:#fff;text-decoration:none}
.image-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.72;transition:transform var(--t-slow) var(--ease-luxe), opacity var(--t-med) var(--ease-luxe)}
.image-card:hover img{transform:scale(1.05);opacity:.85}
.image-card div{position:relative;padding:28px;background:linear-gradient(transparent,rgba(0,0,0,.75));width:100%}

/* Services carousel (signature business section) ----------- */
.services-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:24px;
  margin-bottom:42px;
}
.services-head h2{margin:0}
.services-carousel{
  display:flex;
  gap:22px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  scroll-padding-left:6vw;
  scrollbar-width:none;
  -ms-overflow-style:none;
  margin:0 -6vw;
  padding:10px 6vw 30px;
}
.services-carousel::-webkit-scrollbar{display:none}
.service-card{
  flex:0 0 380px;
  height:520px;
  scroll-snap-align:start;
  position:relative;
  overflow:hidden;
  display:flex;
  align-items:flex-end;
  background:var(--navy);
  color:#fff;
  text-decoration:none;
  transition:transform var(--t-med) var(--ease-luxe), box-shadow var(--t-med) var(--ease-luxe);
}
.service-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px rgba(0,0,0,.35)}
.service-card img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:.7;
  transition:transform 1s var(--ease-luxe), opacity var(--t-med) var(--ease-luxe);
}
.service-card:hover img{transform:scale(1.08);opacity:.85}
.service-card::before{
  /* Gold corner accent (top-left) */
  content:"";
  position:absolute;
  top:24px;
  left:24px;
  width:0;
  height:1px;
  background:var(--gold);
  transition:width var(--t-slow) var(--ease-luxe);
  z-index:2;
}
.service-card:hover::before{width:56px}
.service-card-body{
  position:relative;
  padding:32px;
  width:100%;
  background:linear-gradient(to top, rgba(0,0,0,.92) 0%, rgba(0,0,0,.55) 60%, transparent 100%);
  z-index:1;
}
.service-card-body h3{
  margin:0 0 10px;
  font-size:28px;
  letter-spacing:-.005em;
  transition:transform var(--t-med) var(--ease-luxe);
}
.service-card:hover .service-card-body h3{transform:translateY(-2px)}
.service-card-body p{
  margin:0 0 16px;
  font-size:14px;
  color:rgba(255,255,255,.86);
  line-height:1.55;
}
.service-card .explore{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--gold);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
}
.service-card .explore svg{
  width:14px;
  height:14px;
  transition:transform var(--t-med) var(--ease-luxe);
}
.service-card:hover .explore{color:var(--gold-soft)}
.service-card:hover .explore svg{transform:translateX(7px)}

/* Location tabs ------------------------------------------- */
.location-tabs{
  padding:100px 6vw;
  background:var(--ivory);
}
.location-head{margin-bottom:34px}
.location-head h2{margin:0}
.location-tablist{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  margin:32px 0 46px;
  border-bottom:1px solid rgba(0,0,0,.08);
}
.location-tab{
  background:transparent;
  border:0;
  padding:16px 22px;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--muted);
  cursor:pointer;
  position:relative;
  transition:color var(--t-fast) var(--ease-luxe);
}
.location-tab:hover{color:var(--ink)}
.location-tab.is-active{color:var(--navy)}
.location-tab::after{
  content:"";
  position:absolute;
  left:22px;
  right:22px;
  bottom:-1px;
  height:2px;
  background:var(--gold);
  transform:scaleX(0);
  transform-origin:center;
  transition:transform var(--t-med) var(--ease-luxe);
}
.location-tab.is-active::after{transform:scaleX(1)}

.location-panels{
  position:relative;
  min-height:540px;
}
.location-panel{
  position:absolute;
  inset:0;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:stretch;
  opacity:0;
  visibility:hidden;
  transition:opacity .55s var(--ease-luxe), visibility 0s linear .55s;
}
.location-panel.is-active{
  opacity:1;
  visibility:visible;
  transition:opacity .55s var(--ease-luxe), visibility 0s linear 0s;
}
.loc-image{
  position:relative;
  overflow:hidden;
  background:#000;
  min-height:480px;
}
.loc-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform 1.2s var(--ease-luxe);
}
.location-panel.is-active .loc-image img{transform:scale(1.03)}
.loc-image:hover img{transform:scale(1.08)}
.loc-info{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:10px 0;
}
.loc-info h3{
  font-size:clamp(28px,3vw,40px);
  margin:6px 0 18px;
}
.loc-meta{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin:0 0 26px;
  color:var(--muted);
  font-size:15px;
}
.loc-meta-row{
  display:flex;
  gap:14px;
  align-items:flex-start;
}
.loc-meta-row svg{
  width:18px;
  height:18px;
  color:var(--gold);
  flex:0 0 auto;
  margin-top:2px;
}
.loc-info .btn{align-self:flex-start;margin-top:8px}

.process{background:var(--navy);color:#fff}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:35px}
.steps article{transition:transform var(--t-med) var(--ease-luxe)}
.steps article:hover{transform:translateY(-4px)}
.steps span{color:var(--gold);font-size:14px;letter-spacing:.18em;display:block;margin:6px 0 8px}
.step-icon{
  display:block;
  width:44px;
  height:44px;
  color:var(--gold);
  transition:transform var(--t-med) var(--ease-luxe), color var(--t-fast) var(--ease-luxe);
}
.steps article:hover .step-icon{transform:scale(1.12) rotate(-5deg);color:var(--gold-soft)}

.location-band{padding:100px 6vw;background:linear-gradient(90deg,rgba(6,21,39,.87),rgba(6,21,39,.5)),url('https://images.unsplash.com/photo-1560184897-ae75f418493e?auto=format&fit=crop&w=1800&q=80') center/cover;color:#fff}
.location-band div{max-width:720px}

.final-cta{text-align:center;padding:95px 6vw;background:var(--ivory)}

/* ========================================================
   ABOUT / BRAND STORY page
   ========================================================= */

/* About hero — split layout, image left + content right */
.about-hero{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  min-height:88vh;
  background:var(--ivory);
}
.about-hero-image{
  position:relative;
  overflow:hidden;
  background:#000;
}
.about-hero-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform 8s ease-out;
}
.about-hero.is-loaded .about-hero-image img{transform:scale(1.06)}
.about-hero-content{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:8vw 6vw 8vw 5vw;
  max-width:680px;
}
.about-hero-content h1{margin:0 0 22px}
.about-hero-content p{font-size:19px;color:var(--muted);line-height:1.65;margin:0 0 14px}

/* Brand Story timeline */
.brand-story{padding:110px 6vw;background:var(--white)}
.brand-story-head{text-align:center;max-width:680px;margin:0 auto 70px}
.brand-story-head h2{margin:0}
.timeline{
  position:relative;
  max-width:880px;
  margin:0 auto;
  padding:20px 0;
}
.timeline::before{
  content:"";
  position:absolute;
  left:50%;
  top:0;
  bottom:0;
  width:1px;
  background:rgba(184,148,70,.4);
  transform:translateX(-.5px);
}
.timeline-item{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:50px;
  margin-bottom:50px;
  align-items:center;
  position:relative;
}
.timeline-item:last-child{margin-bottom:0}
.timeline-item::before{
  content:"";
  position:absolute;
  left:50%;
  top:30px;
  width:14px;
  height:14px;
  background:var(--gold);
  border-radius:50%;
  transform:translateX(-7px);
  box-shadow:0 0 0 6px var(--white);
  z-index:2;
}
.timeline-year{
  font-family:Georgia,serif;
  font-size:clamp(46px,5vw,72px);
  color:var(--gold);
  font-weight:500;
  line-height:1;
}
.timeline-item:nth-child(odd) .timeline-year{text-align:right;padding-right:50px}
.timeline-item:nth-child(odd) .timeline-card{order:2;padding-left:50px}
.timeline-item:nth-child(even) .timeline-year{order:2;text-align:left;padding-left:50px}
.timeline-item:nth-child(even) .timeline-card{padding-right:50px;text-align:right}
.timeline-card h3{margin:0 0 10px;font-size:24px;color:var(--navy)}
.timeline-card p{margin:0;color:var(--muted);font-size:16px;line-height:1.7}

/* Philosophy — split with manifesto */
.philosophy{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  background:var(--navy);
  color:#fff;
  min-height:600px;
}
.philosophy-content{padding:90px 6vw;display:flex;flex-direction:column;justify-content:center;max-width:680px}
.philosophy-content .eyebrow{color:var(--gold)}
.philosophy-content h2{margin:0 0 28px}
.philosophy-content .lead{
  font-family:Georgia,serif;
  font-style:italic;
  font-size:clamp(22px,2.4vw,30px);
  line-height:1.4;
  color:#fff;
  margin:0 0 26px;
  padding-left:18px;
  border-left:2px solid var(--gold);
}
.philosophy-content p{color:rgba(255,255,255,.78);font-size:16px;line-height:1.75;margin:0 0 14px}
.philosophy-image{position:relative;overflow:hidden;min-height:500px}
.philosophy-image img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.2s var(--ease-luxe)}
.philosophy-image:hover img{transform:scale(1.05)}

/* Craftsmanship — three pillars */
.craftsmanship{padding:110px 6vw;background:var(--ivory)}
.craftsmanship-head{text-align:center;max-width:720px;margin:0 auto 60px}
.craftsmanship-head h2{margin:0 0 14px}
.craftsmanship-head p{margin:0;color:var(--muted);font-size:17px;line-height:1.65}
.pillars{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
}
.pillar{
  background:#fff;
  transition:transform var(--t-med) var(--ease-luxe), box-shadow var(--t-med) var(--ease-luxe);
}
.pillar:hover{transform:translateY(-8px);box-shadow:var(--shadow-lift)}
.pillar-image{
  height:340px;
  overflow:hidden;
  position:relative;
}
.pillar-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform 1s var(--ease-luxe);
}
.pillar:hover .pillar-image img{transform:scale(1.08)}
.pillar-body{padding:34px 30px 38px}
.pillar-body .pillar-number{
  color:var(--gold);
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  margin:0 0 10px;
}
.pillar-body h3{margin:0 0 14px;font-size:26px}
.pillar-body p{margin:0;color:var(--muted);font-size:15px;line-height:1.7}

/* Stats strip — used on About + Team pages */
.stats-strip{
  padding:80px 6vw;
  background:var(--navy);
  color:#fff;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:30px;
  text-align:center;
}
.stat-num{
  font-family:Georgia,serif;
  font-size:clamp(40px,5vw,64px);
  color:var(--gold);
  line-height:1;
  margin-bottom:10px;
}
.stat-label{
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(255,255,255,.7);
}

/* Founder feature (About page) */
.founder-feature{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  padding:110px 6vw;
  background:var(--white);
  align-items:center;
}
.founder-image{
  position:relative;
  overflow:hidden;
  aspect-ratio:4/5;
  background:var(--ivory);
}
.founder-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform 1.2s var(--ease-luxe);
}
.founder-image:hover img{transform:scale(1.04)}
.founder-content{padding:20px 0;max-width:560px}
.founder-content h2{margin:6px 0 8px;font-size:clamp(34px,3.5vw,54px)}
.founder-content .role{
  color:var(--gold);
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  margin:0 0 28px;
  display:block;
}
.founder-content p{color:var(--muted);font-size:16px;line-height:1.75;margin:0 0 18px}
.founder-content .signature{
  font-family:Georgia,serif;
  font-style:italic;
  font-size:20px;
  color:var(--ink);
  margin:24px 0 0;
  padding-left:18px;
  border-left:2px solid var(--gold);
}
.founder-cta{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--navy);
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  text-decoration:none;
  margin-top:30px;
  border-bottom:1px solid var(--gold);
  padding-bottom:6px;
  transition:gap var(--t-med) var(--ease-luxe), color var(--t-fast) var(--ease-luxe);
}
.founder-cta:hover{gap:18px;color:var(--gold)}
.founder-cta svg{width:14px;height:14px;transition:transform var(--t-med) var(--ease-luxe)}
.founder-cta:hover svg{transform:translateX(4px)}

/* Team grid (used on About + Team pages) */
.team-section{padding:110px 6vw;background:var(--white)}
.team-section-head{text-align:center;max-width:680px;margin:0 auto 60px}
.team-section-head h2{margin:0 0 14px}
.team-section-head p{margin:0;color:var(--muted);font-size:17px}
.team-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:50px 30px;
}
.team-grid .team-card{flex:none;width:100%}

/* Page-specific responsive */
@media (max-width:900px){
  .about-hero{grid-template-columns:1fr;min-height:auto}
  .about-hero-image{height:420px}
  .about-hero-content{padding:60px 6vw}
  .brand-story{padding:70px 5vw}
  .timeline::before{left:14px}
  .timeline-item{grid-template-columns:1fr;gap:14px;margin-bottom:36px}
  .timeline-item::before{left:14px;top:18px}
  .timeline-item:nth-child(odd) .timeline-year,
  .timeline-item:nth-child(even) .timeline-year{text-align:left;padding:0 0 0 44px;order:1;font-size:34px}
  .timeline-item:nth-child(odd) .timeline-card,
  .timeline-item:nth-child(even) .timeline-card{padding:0 0 0 44px;text-align:left;order:2}
  .philosophy{grid-template-columns:1fr}
  .philosophy-image{min-height:320px}
  .philosophy-content{padding:60px 6vw}
  .craftsmanship{padding:70px 5vw}
  .pillars{grid-template-columns:1fr;gap:24px}
  .pillar-image{height:240px}
  .stats-strip{grid-template-columns:repeat(2,1fr);gap:30px;padding:60px 6vw}
  .team-section{padding:70px 5vw}
  .team-grid{grid-template-columns:1fr;gap:34px}
  .founder-feature{grid-template-columns:1fr;gap:40px;padding:70px 5vw}
  .founder-image{aspect-ratio:1/1}
}

/* ========================================================
   SERVICES PAGE
   ========================================================= */

/* Services hero — wide cinematic with overlay text */
.services-hero{
  position:relative;
  min-height:72vh;
  display:flex;
  align-items:center;
  padding:8vw 6vw;
  color:#fff;
  background:linear-gradient(rgba(6,21,39,.6),rgba(6,21,39,.6)),url('https://images.unsplash.com/photo-1593030103066-0093718efeb9?auto=format&fit=crop&w=1800&q=85') center/cover;
}
.services-hero-content{max-width:780px;position:relative}
.services-hero h1{margin:0 0 22px;font-size:clamp(44px,6vw,72px)}
.services-hero p{font-size:19px;line-height:1.6;color:rgba(255,255,255,.86);margin:0;max-width:640px}

/* In-page service jump nav */
.services-nav{
  position:sticky;
  top:0;
  z-index:40;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(0,0,0,.06);
  padding:0 6vw;
  overflow-x:auto;
  scrollbar-width:none;
}
.services-nav::-webkit-scrollbar{display:none}
.services-nav ul{
  display:flex;
  list-style:none;
  margin:0;
  padding:0;
  gap:6px;
  min-width:max-content;
}
.services-nav a{
  display:block;
  padding:18px 18px;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--muted);
  text-decoration:none;
  white-space:nowrap;
  border-bottom:2px solid transparent;
  transition:color var(--t-fast) var(--ease-luxe), border-color var(--t-fast) var(--ease-luxe);
}
.services-nav a:hover{color:var(--navy)}
.services-nav a.is-active{color:var(--navy);border-bottom-color:var(--gold)}

/* Service block (alternating L/R) */
.service-block{
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center;
  min-height:640px;
  background:var(--white);
}
.service-block.alt{background:var(--ivory)}
.service-block.right-image .service-image{order:2}
.service-image{
  position:relative;
  overflow:hidden;
  height:100%;
  min-height:520px;
  background:#000;
}
.service-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform 1.4s var(--ease-luxe);
}
.service-image:hover img{transform:scale(1.05)}
.service-image::after{
  /* Service number watermark */
  content:attr(data-number);
  position:absolute;
  bottom:24px;
  right:30px;
  font-family:Georgia,serif;
  font-size:90px;
  color:rgba(255,255,255,.15);
  line-height:1;
  pointer-events:none;
  letter-spacing:-.02em;
}
.service-content{
  padding:80px 6vw 80px 5vw;
  max-width:640px;
}
.service-block.right-image .service-content{padding:80px 5vw 80px 6vw;margin-left:auto}
.service-content .eyebrow{margin-bottom:14px}
.service-content h2{margin:0 0 16px;font-size:clamp(34px,3.6vw,52px)}
.service-lead{
  font-family:Georgia,serif;
  font-style:italic;
  font-size:19px;
  color:var(--ink);
  line-height:1.5;
  margin:0 0 20px;
}
.service-body{color:var(--muted);font-size:16px;line-height:1.75;margin:0 0 28px}
.service-features{
  list-style:none;
  margin:0 0 30px;
  padding:0;
}
.service-features li{
  display:flex;
  gap:12px;
  align-items:flex-start;
  margin:0 0 12px;
  font-size:15px;
  color:var(--ink);
  line-height:1.5;
}
.service-features li::before{
  content:"";
  width:6px;
  height:6px;
  background:var(--gold);
  border-radius:50%;
  margin-top:9px;
  flex:0 0 auto;
}
.service-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:18px;
  padding-top:24px;
  border-top:1px solid rgba(0,0,0,.08);
  margin-bottom:8px;
}
.service-price{
  font-family:Georgia,serif;
  font-size:16px;
}
.service-price strong{
  color:var(--navy);
  font-size:24px;
  display:block;
  margin-top:2px;
  font-weight:500;
}
.service-meta .btn{margin-top:0}

/* Responsive for services page */
@media (max-width:900px){
  .services-hero{min-height:60vh;padding:80px 5vw}
  .service-block,
  .service-block.right-image{grid-template-columns:1fr;min-height:auto}
  .service-block.right-image .service-image{order:0}
  .service-image{min-height:300px;height:300px}
  .service-image::after{font-size:60px;bottom:14px;right:18px}
  .service-content,
  .service-block.right-image .service-content{padding:50px 5vw}
  .service-content h2{font-size:32px}
  .services-nav a{padding:14px 12px;font-size:10px;letter-spacing:.16em}
}

/* ========================================================
   LOOKBOOK PAGE
   ========================================================= */

/* Lookbook hero — full-bleed editorial */
.lookbook-hero{
  position:relative;
  min-height:78vh;
  display:flex;
  align-items:flex-end;
  padding:6vw 6vw;
  color:#fff;
  background:linear-gradient(rgba(6,21,39,.35),rgba(6,21,39,.7)),url('https://images.unsplash.com/photo-1507003211169-0a1dd7228f2d?auto=format&fit=crop&w=1800&q=85') center/cover;
}
.lookbook-hero-content{max-width:760px;position:relative}
.lookbook-hero h1{margin:0 0 18px;font-size:clamp(46px,7vw,86px);line-height:.95}
.lookbook-hero p{font-size:18px;line-height:1.6;color:rgba(255,255,255,.85);margin:0;max-width:560px}

/* Section: Collections */
.collections{padding:110px 6vw;background:var(--white)}
.collections-head{text-align:center;margin-bottom:36px;max-width:680px;margin-left:auto;margin-right:auto}
.collections-head h2{margin:0 0 12px}
.collections-head p{margin:0;color:var(--muted);font-size:17px}
.collection-tablist{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:6px;
  margin:0 auto 40px;
  border-bottom:1px solid rgba(0,0,0,.08);
}
.collection-tab{
  background:transparent;
  border:0;
  padding:18px 22px;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--muted);
  cursor:pointer;
  position:relative;
  transition:color var(--t-fast) var(--ease-luxe);
}
.collection-tab:hover{color:var(--ink)}
.collection-tab.is-active{color:var(--navy)}
.collection-tab::after{
  content:"";
  position:absolute;
  left:22px;
  right:22px;
  bottom:-1px;
  height:2px;
  background:var(--gold);
  transform:scaleX(0);
  transition:transform var(--t-med) var(--ease-luxe);
}
.collection-tab.is-active::after{transform:scaleX(1)}

.collection-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:300px;
  gap:14px;
}
.collection-item{
  position:relative;
  overflow:hidden;
  display:block;
  background:#000;
  text-decoration:none;
  color:#fff;
}
.collection-item.span-col-2{grid-column:span 2}
.collection-item.span-row-2{grid-row:span 2}
.collection-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  opacity:.92;
  transition:transform 1.2s var(--ease-luxe), opacity var(--t-med) var(--ease-luxe);
}
.collection-item:hover img{transform:scale(1.06);opacity:1}
.collection-item .overlay{
  position:absolute;
  inset:auto 0 0 0;
  padding:20px 22px 22px;
  background:linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.4) 60%, transparent 100%);
  transform:translateY(14px);
  opacity:.85;
  transition:transform var(--t-med) var(--ease-luxe), opacity var(--t-med) var(--ease-luxe);
}
.collection-item:hover .overlay{transform:translateY(0);opacity:1}
.collection-item .cat{
  margin:0 0 4px;
  color:var(--gold);
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
}
.collection-item h3{
  margin:0;
  font-size:18px;
  letter-spacing:-.005em;
  color:#fff;
}
.collection-item.is-hidden{display:none}

/* Section: Editorial mosaic */
.editorial{padding:110px 6vw;background:var(--ivory)}
.editorial-head{text-align:center;max-width:680px;margin:0 auto 50px}
.editorial-head h2{margin:0 0 12px}
.editorial-head p{margin:0;color:var(--muted);font-size:17px}
.editorial-mosaic{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  grid-auto-rows:200px;
  gap:16px;
}
.editorial-item{position:relative;overflow:hidden;background:#000}
.editorial-item:nth-child(1){grid-column:span 3;grid-row:span 2}
.editorial-item:nth-child(2){grid-column:span 3;grid-row:span 1}
.editorial-item:nth-child(3){grid-column:span 1;grid-row:span 1}
.editorial-item:nth-child(4){grid-column:span 2;grid-row:span 1}
.editorial-item:nth-child(5){grid-column:span 2;grid-row:span 2}
.editorial-item:nth-child(6){grid-column:span 2;grid-row:span 1}
.editorial-item:nth-child(7){grid-column:span 2;grid-row:span 1}
.editorial-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  opacity:.94;
  transition:transform 1.2s var(--ease-luxe), opacity var(--t-fast) var(--ease-luxe);
}
.editorial-item:hover img{transform:scale(1.05);opacity:1}

/* Section: Videos / Reels carousel */
.reels{padding:110px 6vw;background:var(--navy);color:#fff}
.reels-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:24px;
  margin-bottom:42px;
}
.reels-head h2{margin:0;color:#fff}
.reels-head .eyebrow{color:var(--gold)}
.reels-head .carousel-btn{
  background:transparent;
  border:1px solid rgba(255,255,255,.25);
  color:#fff;
}
.reels-head .carousel-btn:hover{background:var(--gold);border-color:var(--gold);color:#fff}
.reels-carousel{
  display:flex;
  gap:18px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  scroll-padding-left:6vw;
  scrollbar-width:none;
  -ms-overflow-style:none;
  margin:0 -6vw;
  padding:6px 6vw 24px;
}
.reels-carousel::-webkit-scrollbar{display:none}
.reel-card{
  flex:0 0 300px;
  aspect-ratio:9/16;
  scroll-snap-align:start;
  position:relative;
  overflow:hidden;
  background:#000;
  text-decoration:none;
  color:#fff;
  cursor:pointer;
  transition:transform var(--t-med) var(--ease-luxe);
}
.reel-card:focus{outline:2px solid var(--gold);outline-offset:3px}
.reel-card:hover{transform:translateY(-4px)}
.reel-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  opacity:.82;
  transition:transform 1s var(--ease-luxe), opacity var(--t-med) var(--ease-luxe);
}
.reel-card:hover img{transform:scale(1.06);opacity:1}
.reel-play{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  pointer-events:none;
}
.reel-play svg{
  width:62px;
  height:62px;
  color:#fff;
  filter:drop-shadow(0 4px 18px rgba(0,0,0,.6));
  transition:transform var(--t-med) var(--ease-luxe);
}
.reel-card:hover .reel-play svg{transform:scale(1.15)}
.reel-meta{
  position:absolute;
  inset:auto 0 0 0;
  padding:18px 20px 22px;
  background:linear-gradient(to top, rgba(0,0,0,.88) 0%, transparent 100%);
}
.reel-meta h3{
  margin:0;
  font-family:Inter,sans-serif;
  font-size:16px;
  font-weight:500;
  color:#fff;
  letter-spacing:0;
}
.reel-meta p{
  margin:4px 0 0;
  font-size:10px;
  color:var(--gold);
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
}

/* Lookbook responsive */
@media (max-width:900px){
  .lookbook-hero{min-height:60vh;padding:60px 5vw}
  .collections,.editorial,.reels{padding:70px 5vw}
  .collection-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:240px}
  .collection-item.span-col-2,.collection-item.span-row-2{grid-column:span 1;grid-row:span 1}
  .editorial-mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}
  .editorial-item:nth-child(n){grid-column:span 1;grid-row:span 1}
  .editorial-item:nth-child(1),.editorial-item:nth-child(5){grid-row:span 2}
  .reel-card{flex:0 0 240px}
  .collection-tab{padding:14px 14px;font-size:11px;letter-spacing:.18em}
  .collection-tab::after{left:14px;right:14px}
}

/* ========================================================
   BOOK APPOINTMENT PAGE
   ========================================================= */

.booking-hero{
  position:relative;
  min-height:60vh;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:8vw 6vw;
  color:#fff;
  background:linear-gradient(rgba(6,21,39,.7),rgba(6,21,39,.7)),url('https://images.unsplash.com/photo-1604578762246-41134e37f9cc?auto=format&fit=crop&w=1800&q=85') center/cover;
}
.booking-hero-content{max-width:780px}
.booking-hero h1{margin:0 0 18px;font-size:clamp(42px,6vw,76px)}
.booking-hero p{font-size:18px;line-height:1.6;color:rgba(255,255,255,.86);margin:0 auto;max-width:580px}

/* Appointment type cards */
.appt-types{padding:100px 6vw;background:var(--white)}
.appt-types-head{text-align:center;max-width:680px;margin:0 auto 50px}
.appt-types-head h2{margin:0 0 14px}
.appt-types-head p{margin:0;color:var(--muted);font-size:17px}
.appt-cards{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.appt-card{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  padding:38px 28px 32px;
  cursor:pointer;
  text-align:left;
  position:relative;
  transition:transform var(--t-med) var(--ease-luxe), box-shadow var(--t-med) var(--ease-luxe), border-color var(--t-med) var(--ease-luxe);
}
.appt-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lift);border-color:rgba(184,148,70,.4)}
.appt-card.is-selected{border-color:var(--gold);box-shadow:var(--shadow-glow)}
.appt-card.is-selected::after{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:3px;
  background:var(--gold);
}
.appt-icon{
  width:46px;
  height:46px;
  color:var(--gold);
  margin-bottom:20px;
  transition:transform var(--t-med) var(--ease-luxe);
}
.appt-card:hover .appt-icon{transform:scale(1.1) rotate(-4deg)}
.appt-card h3{margin:0 0 10px;font-size:22px}
.appt-card p{margin:0 0 16px;color:var(--muted);font-size:14px;line-height:1.6}
.appt-card .duration{
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--navy);
  font-weight:700;
}
.appt-card.is-selected .duration{color:var(--gold)}

/* Booking form */
.booking-form-section{padding:100px 6vw;background:var(--ivory)}
.booking-form-head{text-align:center;max-width:680px;margin:0 auto 50px}
.booking-form-head h2{margin:0 0 14px}
.booking-form-head p{margin:0;color:var(--muted);font-size:17px}
.booking-form{
  max-width:880px;
  margin:0 auto;
  background:#fff;
  padding:50px 50px 40px;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:var(--shadow-soft);
}
.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px 26px;
}
.form-field{position:relative}
.form-field.full{grid-column:1 / -1}
.form-label{
  display:block;
  margin-bottom:8px;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--navy);
  font-weight:700;
}
.form-label .req{color:var(--gold);margin-left:4px}
.form-input,
.form-select,
.form-textarea{
  width:100%;
  padding:14px 16px;
  background:#fff;
  border:1px solid rgba(0,0,0,.14);
  font-family:inherit;
  font-size:15px;
  color:var(--ink);
  transition:border-color var(--t-fast) var(--ease-luxe), box-shadow var(--t-fast) var(--ease-luxe);
  -webkit-appearance:none;
  appearance:none;
  border-radius:0;
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus{
  outline:none;
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(184,148,70,.15);
}
.form-select{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23b89446' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat:no-repeat;
  background-position:right 14px center;
  background-size:16px;
  padding-right:42px;
}
.form-textarea{min-height:140px;resize:vertical;line-height:1.5}
.form-help{
  display:block;
  margin-top:6px;
  font-size:12px;
  color:var(--muted);
}
.form-consent{
  display:flex;
  gap:10px;
  align-items:flex-start;
  font-size:13px;
  color:var(--muted);
  line-height:1.5;
  margin-top:8px;
}
.form-consent input{
  margin-top:3px;
  accent-color:var(--gold);
}
.submit-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:18px;
  padding-top:24px;
  margin-top:30px;
  border-top:1px solid rgba(0,0,0,.08);
}
.submit-row .helper{color:var(--muted);font-size:13px;max-width:380px;margin:0}
.submit-btn{
  padding:18px 38px;
  font-size:13px;
  cursor:pointer;
  font-family:inherit;
  background:var(--gold);
  color:#111;
  border:1px solid var(--gold);
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  transition:transform var(--t-med) var(--ease-luxe), box-shadow var(--t-med) var(--ease-luxe), letter-spacing var(--t-med) var(--ease-luxe), background var(--t-med) var(--ease-luxe);
}
.submit-btn:hover{
  background:var(--gold-soft);
  transform:translateY(-2px);
  box-shadow:var(--shadow-glow);
  letter-spacing:.26em;
}
.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}

.form-success{
  display:none;
  max-width:880px;
  margin:0 auto;
  background:#fff;
  padding:60px 50px;
  text-align:center;
  border:1px solid var(--gold);
  border-left-width:3px;
}
.form-success.is-visible{display:block}
.form-success .check{
  width:64px;
  height:64px;
  margin:0 auto 24px;
  color:var(--gold);
}
.form-success h3{margin:0 0 14px;font-size:30px}
.form-success p{margin:0;color:var(--muted);font-size:16px;line-height:1.6}

/* What to Expect */
.what-to-expect{padding:100px 6vw;background:var(--navy);color:#fff}
.what-to-expect-head{text-align:center;max-width:680px;margin:0 auto 50px}
.what-to-expect-head h2{margin:0 0 14px;color:#fff}
.what-to-expect-head p{margin:0;color:rgba(255,255,255,.7);font-size:17px}
.expect-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:30px;
}
.expect-item{
  padding:0 10px;
  transition:transform var(--t-med) var(--ease-luxe);
}
.expect-item:hover{transform:translateY(-4px)}
.expect-num{
  font-family:Georgia,serif;
  font-size:14px;
  color:var(--gold);
  letter-spacing:.22em;
  display:block;
  margin-bottom:14px;
}
.expect-item h3{margin:0 0 12px;font-size:22px;color:#fff}
.expect-item p{margin:0;color:rgba(255,255,255,.75);font-size:15px;line-height:1.7}

/* Studio Images */
.studio-images{padding:100px 6vw;background:var(--ivory)}
.studio-images-head{text-align:center;max-width:680px;margin:0 auto 50px}
.studio-images-head h2{margin:0 0 14px}
.studio-images-head p{margin:0;color:var(--muted);font-size:17px}
.studio-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:260px;
  gap:16px;
}
.studio-grid > div{position:relative;overflow:hidden;background:#000}
.studio-grid > div:nth-child(1){grid-column:span 2;grid-row:span 2}
.studio-grid img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  opacity:.94;
  transition:transform 1s var(--ease-luxe), opacity var(--t-fast) var(--ease-luxe);
}
.studio-grid > div:hover img{transform:scale(1.06);opacity:1}

/* Bottom reassurance */
.booking-reassure{
  padding:60px 6vw;
  background:#fff;
  text-align:center;
}
.booking-reassure h3{margin:0 0 12px;font-size:24px}
.booking-reassure p{margin:0;color:var(--muted);font-size:15px;line-height:1.7}
.booking-reassure .contact-links{
  display:inline-flex;
  gap:30px;
  flex-wrap:wrap;
  justify-content:center;
  margin-top:18px;
}
.booking-reassure .contact-links a{
  color:var(--navy);
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  text-decoration:none;
  font-weight:700;
  border-bottom:1px solid var(--gold);
  padding-bottom:6px;
  transition:color var(--t-fast) var(--ease-luxe);
}
.booking-reassure .contact-links a:hover{color:var(--gold)}

/* Responsive */
@media (max-width:900px){
  .booking-hero{min-height:50vh;padding:60px 5vw}
  .appt-types,.booking-form-section,.what-to-expect,.studio-images{padding:60px 5vw}
  .appt-cards{grid-template-columns:1fr 1fr;gap:14px}
  .appt-card{padding:28px 22px}
  .booking-form{padding:30px 24px}
  .form-grid{grid-template-columns:1fr;gap:18px}
  .expect-grid{grid-template-columns:1fr 1fr;gap:24px}
  .studio-grid{grid-template-columns:1fr 1fr;grid-auto-rows:200px}
  .studio-grid > div:nth-child(1){grid-column:span 2;grid-row:span 2}
  .submit-row{flex-direction:column;align-items:stretch}
  .submit-btn{width:100%}
}

/* ========================================================
   SINGLE LOCATION PAGE (Page 6 — dynamic per location)
   ========================================================= */

.loc-hero{
  position:relative;
  min-height:78vh;
  display:flex;
  align-items:flex-end;
  padding:6vw 6vw 5vw;
  color:#fff;
}
.loc-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(rgba(6,21,39,.45) 0%, rgba(6,21,39,.55) 50%, rgba(6,21,39,.9) 100%);
}
.loc-hero-content{position:relative;max-width:760px;width:100%}
.loc-hero h1{margin:0 0 18px;font-size:clamp(46px,7vw,84px);line-height:1}
.loc-hero .loc-address{
  display:inline-flex;
  align-items:center;
  gap:12px;
  color:rgba(255,255,255,.92);
  font-size:15px;
  letter-spacing:.04em;
  margin:0 0 20px;
}
.loc-hero .loc-address svg{width:18px;height:18px;color:var(--gold);flex:0 0 auto}
.loc-hero p{font-size:18px;line-height:1.6;color:rgba(255,255,255,.85);margin:0 0 30px;max-width:580px}
.loc-hero-ctas{display:flex;gap:14px;flex-wrap:wrap}

/* About this location */
.loc-about{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  padding:110px 6vw;
  background:var(--white);
  align-items:center;
}
.loc-about-image{position:relative;overflow:hidden;aspect-ratio:5/4;background:var(--ivory)}
.loc-about-image img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.2s var(--ease-luxe)}
.loc-about-image:hover img{transform:scale(1.04)}
.loc-about-content{max-width:560px}
.loc-about-content .eyebrow{margin-bottom:10px}
.loc-about-content h2{margin:0 0 22px;font-size:clamp(32px,3.5vw,48px)}
.loc-about-content p{color:var(--muted);font-size:16px;line-height:1.75;margin:0 0 16px}
.loc-about-content .feature-list{
  list-style:none;
  margin:24px 0 0;
  padding:0;
}
.loc-about-content .feature-list li{
  display:flex;
  gap:12px;
  align-items:flex-start;
  margin:0 0 10px;
  font-size:14px;
  color:var(--ink);
}
.loc-about-content .feature-list li::before{
  content:"";
  width:6px;
  height:6px;
  background:var(--gold);
  border-radius:50%;
  margin-top:8px;
  flex:0 0 auto;
}

/* Services at this location */
.loc-services{padding:110px 6vw;background:var(--ivory)}
.loc-services-head{text-align:center;max-width:680px;margin:0 auto 50px}
.loc-services-head h2{margin:0 0 12px}
.loc-services-head p{margin:0;color:var(--muted);font-size:17px}
.loc-services-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.loc-service-card{
  position:relative;
  overflow:hidden;
  aspect-ratio:3/4;
  background:#000;
  color:#fff;
  text-decoration:none;
  display:flex;
  align-items:flex-end;
}
.loc-service-card img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  opacity:.7;
  transition:transform 1s var(--ease-luxe), opacity var(--t-med) var(--ease-luxe);
}
.loc-service-card:hover img{transform:scale(1.06);opacity:.88}
.loc-service-card-body{
  position:relative;
  padding:22px;
  width:100%;
  background:linear-gradient(to top, rgba(0,0,0,.88), transparent 75%);
}
.loc-service-card h3{margin:0;font-size:20px;color:#fff;letter-spacing:-.005em}
.loc-service-card .explore-mini{
  margin-top:8px;
  display:inline-block;
  color:var(--gold);
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  transition:gap var(--t-med) var(--ease-luxe);
}

/* Local lifestyle imagery — reuses editorial-mosaic structure */
.loc-lifestyle{padding:110px 6vw;background:var(--white)}
.loc-lifestyle-head{text-align:center;max-width:680px;margin:0 auto 50px}
.loc-lifestyle-head h2{margin:0 0 12px}
.loc-lifestyle-head p{margin:0;color:var(--muted);font-size:17px}

/* Testimonials on location page (compact, navy) */
.loc-testimonials{padding:100px 6vw;background:var(--navy);color:#fff}
.loc-testimonials-head{text-align:center;max-width:680px;margin:0 auto 50px}
.loc-testimonials-head h2{color:#fff;margin:0 0 12px}
.loc-testimonials-head p{margin:0;color:rgba(255,255,255,.7);font-size:17px}
.loc-testimonials-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
}
.loc-testimonial{
  padding:36px 30px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.02);
  transition:transform var(--t-med) var(--ease-luxe), border-color var(--t-med) var(--ease-luxe);
}
.loc-testimonial:hover{transform:translateY(-6px);border-color:rgba(184,148,70,.4)}
.loc-testimonial .quote-mark{
  color:var(--gold);
  font-family:Georgia,serif;
  font-size:48px;
  line-height:.4;
  margin-bottom:18px;
}
.loc-testimonial p{
  margin:0 0 22px;
  color:rgba(255,255,255,.9);
  font-family:Georgia,serif;
  font-style:italic;
  font-size:17px;
  line-height:1.6;
}
.loc-testimonial cite{
  display:block;
  color:var(--gold);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  font-style:normal;
}

/* Team at this location */
.loc-team{padding:110px 6vw;background:var(--ivory)}
.loc-team-head{text-align:center;max-width:680px;margin:0 auto 50px}
.loc-team-head h2{margin:0 0 12px}
.loc-team-head p{margin:0;color:var(--muted);font-size:17px}
.loc-team-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:40px 28px;
}

/* Map + contact split */
.loc-map-section{
  display:grid;
  grid-template-columns:1fr 1fr;
  background:var(--navy);
  color:#fff;
  min-height:520px;
}
.loc-map-info{
  padding:80px 6vw;
  display:flex;
  flex-direction:column;
  justify-content:center;
  max-width:680px;
}
.loc-map-info .eyebrow{color:var(--gold)}
.loc-map-info h2{color:#fff;margin:0 0 28px}
.loc-info-row{
  display:flex;
  gap:14px;
  margin:0 0 20px;
  align-items:flex-start;
}
.loc-info-row svg{
  width:20px;
  height:20px;
  color:var(--gold);
  flex:0 0 auto;
  margin-top:3px;
}
.loc-info-row .info-content{flex:1}
.loc-info-row .info-label{
  display:block;
  color:var(--gold);
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  margin-bottom:4px;
}
.loc-info-row .info-value{
  color:rgba(255,255,255,.92);
  font-size:15px;
  line-height:1.55;
}
.loc-info-row .info-value a{color:#fff;text-decoration:none;border-bottom:1px solid rgba(184,148,70,.5);transition:border-color var(--t-fast)}
.loc-info-row .info-value a:hover{border-bottom-color:var(--gold)}
.loc-map-cta{margin-top:24px;align-self:flex-start}
.loc-map-embed{position:relative;min-height:520px;overflow:hidden}
.loc-map-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.15) contrast(1.05)}

/* Final CTA variant on location page */
.loc-final-cta{
  padding:110px 6vw;
  background:var(--white);
  text-align:center;
}
.loc-final-cta h2{margin:0 0 16px}
.loc-final-cta p{margin:0 auto 28px;color:var(--muted);font-size:17px;max-width:560px}

/* Responsive */
@media (max-width:900px){
  .loc-hero{min-height:60vh;padding:60px 5vw 50px}
  .loc-about{grid-template-columns:1fr;gap:36px;padding:60px 5vw}
  .loc-services,.loc-lifestyle,.loc-testimonials,.loc-team,.loc-final-cta{padding:60px 5vw}
  .loc-services-grid{grid-template-columns:1fr 1fr;gap:14px}
  .loc-testimonials-grid{grid-template-columns:1fr;gap:18px}
  .loc-team-grid{grid-template-columns:1fr;gap:32px}
  .loc-map-section{grid-template-columns:1fr;min-height:auto}
  .loc-map-info{padding:50px 5vw}
  .loc-map-embed{min-height:340px;height:340px}
}

/* ========================================================
   LOCATIONS INDEX (parent /locations/ page — lists all studios)
   ========================================================= */

.locs-index-hero{
  position:relative;
  min-height:54vh;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:8vw 6vw;
  color:#fff;
  background:linear-gradient(rgba(6,21,39,.65),rgba(6,21,39,.85)),url('https://images.unsplash.com/photo-1604578762246-41134e37f9cc?auto=format&fit=crop&w=1800&q=85') center/cover;
}
.locs-index-hero-content{max-width:780px}
.locs-index-hero h1{margin:0 0 18px;font-size:clamp(42px,6vw,72px)}
.locs-index-hero p{font-size:18px;line-height:1.6;color:rgba(255,255,255,.86);margin:0 auto;max-width:600px}

.locs-grid-section{padding:100px 6vw;background:var(--ivory)}
.locs-grid-head{text-align:center;max-width:680px;margin:0 auto 60px}
.locs-grid-head h2{margin:0 0 12px}
.locs-grid-head p{margin:0;color:var(--muted);font-size:17px}
.locs-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:30px;
}
.loc-card{
  position:relative;
  overflow:hidden;
  background:var(--navy);
  color:#fff;
  text-decoration:none;
  min-height:480px;
  display:flex;
  align-items:flex-end;
  transition:transform var(--t-med) var(--ease-luxe), box-shadow var(--t-med) var(--ease-luxe);
}
.loc-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px rgba(0,0,0,.25)}
.loc-card img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:.7;
  transition:transform 1.2s var(--ease-luxe), opacity var(--t-med) var(--ease-luxe);
}
.loc-card:hover img{transform:scale(1.06);opacity:.85}
.loc-card-body{
  position:relative;
  padding:36px 34px 34px;
  width:100%;
  background:linear-gradient(to top, rgba(0,0,0,.92) 0%, rgba(0,0,0,.6) 50%, transparent 100%);
  z-index:1;
}
.loc-card-eyebrow{
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:700;
  margin:0 0 8px;
}
.loc-card h3{
  margin:0 0 14px;
  font-size:32px;
  color:#fff;
  letter-spacing:-.01em;
}
.loc-card-meta{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:24px;
  font-size:14px;
  color:rgba(255,255,255,.85);
  line-height:1.5;
}
.loc-card-meta .meta-row{display:flex;gap:10px;align-items:flex-start}
.loc-card-meta .meta-row svg{width:14px;height:14px;color:var(--gold);flex:0 0 auto;margin-top:4px}
.loc-card-visit{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--gold);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  border-bottom:1px solid var(--gold);
  padding-bottom:6px;
  transition:gap var(--t-med) var(--ease-luxe), color var(--t-fast) var(--ease-luxe);
}
.loc-card:hover .loc-card-visit{gap:18px;color:#fff}
.loc-card-visit svg{width:14px;height:14px;transition:transform var(--t-med) var(--ease-luxe)}
.loc-card:hover .loc-card-visit svg{transform:translateX(4px)}

/* Private travel band */
.private-travel{
  display:grid;
  grid-template-columns:1fr 1fr;
  background:var(--navy);
  color:#fff;
  align-items:center;
  min-height:480px;
}
.private-travel-content{padding:80px 6vw;max-width:640px}
.private-travel-content .eyebrow{color:var(--gold)}
.private-travel-content h2{color:#fff;margin:0 0 22px}
.private-travel-content p{color:rgba(255,255,255,.78);font-size:16px;line-height:1.75;margin:0 0 16px}
.private-travel-content .btn{margin-top:14px}
.private-travel-image{position:relative;overflow:hidden;min-height:400px}
.private-travel-image img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.2s var(--ease-luxe)}
.private-travel-image:hover img{transform:scale(1.05)}

@media (max-width:900px){
  .locs-index-hero{min-height:44vh;padding:60px 5vw}
  .locs-grid-section{padding:60px 5vw}
  .locs-grid{grid-template-columns:1fr;gap:20px}
  .loc-card{min-height:380px}
  .loc-card-body{padding:28px 24px 26px}
  .loc-card h3{font-size:26px}
  .private-travel{grid-template-columns:1fr;min-height:auto}
  .private-travel-image{min-height:280px}
  .private-travel-content{padding:50px 5vw}
}

/* ========================================================
   TEAM PAGE (Page 7)
   ========================================================= */

.team-hero{
  position:relative;
  min-height:70vh;
  display:flex;
  align-items:flex-end;
  padding:6vw 6vw 5vw;
  color:#fff;
  background:linear-gradient(rgba(6,21,39,.35) 0%, rgba(6,21,39,.55) 50%, rgba(6,21,39,.9) 100%),url('https://images.unsplash.com/photo-1556905055-8f358a7a47b2?auto=format&fit=crop&w=1800&q=85') center/cover;
}
.team-hero-content{max-width:780px;position:relative}
.team-hero h1{margin:0 0 22px;font-size:clamp(46px,7vw,84px);line-height:1}
.team-hero p{font-size:18px;line-height:1.6;color:rgba(255,255,255,.86);margin:0;max-width:620px}

/* Team group section (Style Consultants / Master Tailors) */
.team-group{padding:110px 6vw}
.team-group.alt{background:var(--ivory)}
.team-group.dark{background:var(--navy);color:#fff}
.team-group-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:30px;
  margin-bottom:56px;
  max-width:1200px;
}
.team-group-head-text{max-width:580px}
.team-group-head-text .eyebrow{margin-bottom:10px}
.team-group-head-text h2{margin:0 0 14px}
.team-group.dark .team-group-head-text h2{color:#fff}
.team-group-head-text p{margin:0;font-size:17px;color:var(--muted);line-height:1.6}
.team-group.dark .team-group-head-text p{color:rgba(255,255,255,.7)}

.team-group-count{
  font-family:Georgia,serif;
  font-size:clamp(60px,6vw,90px);
  color:var(--gold);
  line-height:.9;
  letter-spacing:-.02em;
}

/* Expanded team card (with bio + specialty tags) */
.team-group-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:36px 26px;
}
.team-bio-card{
  display:flex;
  flex-direction:column;
}
.team-bio-card .photo{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
  background:var(--ivory);
  margin-bottom:22px;
}
.team-bio-card .photo img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  opacity:.92;
  transition:transform var(--t-slow) var(--ease-luxe), opacity var(--t-med) var(--ease-luxe);
}
.team-bio-card:hover .photo img{transform:scale(1.06);opacity:1}
.team-group.dark .team-bio-card .photo{background:#040f1d}
.team-bio-card .role{
  display:block;
  color:var(--gold);
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  margin:0 0 8px;
}
.team-bio-card h3{
  margin:0 0 12px;
  font-size:22px;
  letter-spacing:-.005em;
}
.team-group.dark .team-bio-card h3{color:#fff}
.team-bio-card .bio{
  margin:0 0 16px;
  color:var(--muted);
  font-size:14px;
  line-height:1.65;
}
.team-group.dark .team-bio-card .bio{color:rgba(255,255,255,.72)}
.specialty-tags{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:auto;
  padding-top:8px;
}
.specialty-tag{
  display:inline-block;
  padding:4px 11px;
  font-size:9.5px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--muted);
  border:1px solid rgba(0,0,0,.12);
  border-radius:999px;
  transition:color var(--t-fast) var(--ease-luxe), border-color var(--t-fast) var(--ease-luxe);
}
.team-group.dark .specialty-tag{
  color:rgba(255,255,255,.55);
  border-color:rgba(255,255,255,.15);
}
.team-bio-card:hover .specialty-tag{
  color:var(--gold);
  border-color:var(--gold);
}

/* Company Culture — editorial split */
.culture-section{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  align-items:stretch;
  background:var(--white);
}
.culture-image{position:relative;overflow:hidden;min-height:520px;background:#000}
.culture-image img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.4s var(--ease-luxe)}
.culture-image:hover img{transform:scale(1.05)}
.culture-content{
  padding:90px 6vw;
  max-width:680px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.culture-content .eyebrow{margin-bottom:10px}
.culture-content h2{margin:0 0 24px;font-size:clamp(32px,3.4vw,48px)}
.culture-content > p{color:var(--muted);font-size:16px;line-height:1.75;margin:0 0 16px}
.culture-content .pull{
  font-family:Georgia,serif;
  font-style:italic;
  font-size:clamp(20px,2.2vw,26px);
  color:var(--ink);
  line-height:1.5;
  margin:24px 0;
  padding:18px 0 18px 22px;
  border-left:2px solid var(--gold);
}
.culture-stats{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px 36px;
  margin-top:32px;
  padding-top:32px;
  border-top:1px solid rgba(0,0,0,.08);
}
.culture-stat .num{
  font-family:Georgia,serif;
  font-size:38px;
  color:var(--gold);
  line-height:1;
  display:block;
}
.culture-stat .label{
  display:block;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:700;
  margin-top:6px;
}

/* Join Our Team CTA */
.join-team{
  padding:90px 6vw;
  background:var(--ivory);
  text-align:center;
}
.join-team .eyebrow{margin-bottom:14px}
.join-team h2{margin:0 0 16px}
.join-team p{margin:0 auto 28px;color:var(--muted);font-size:17px;line-height:1.6;max-width:620px}
.join-team .btn-group{display:inline-flex;gap:14px;flex-wrap:wrap;justify-content:center}

/* Responsive */
@media (max-width:900px){
  .team-hero{min-height:54vh;padding:60px 5vw 50px}
  .team-group{padding:60px 5vw}
  .team-group-head{margin-bottom:36px}
  .team-group-grid{grid-template-columns:repeat(2,1fr);gap:30px 16px}
  .team-bio-card h3{font-size:19px}
  .team-bio-card .bio{font-size:13px}
  .culture-section{grid-template-columns:1fr}
  .culture-image{min-height:300px}
  .culture-content{padding:50px 5vw}
  .culture-stats{grid-template-columns:1fr 1fr;gap:20px}
  .join-team{padding:60px 5vw}
}

/* ========================================================
   CONTACT SECTION (embedded in /locations/ page)
   ========================================================= */

.contact-section{
  padding:110px 6vw;
  background:var(--white);
  scroll-margin-top:80px;
}
.contact-section-head{text-align:center;max-width:680px;margin:0 auto 50px}
.contact-section-head h2{margin:0 0 12px}
.contact-section-head p{margin:0;color:var(--muted);font-size:17px}
.contact-grid{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:60px;
  max-width:1100px;
  margin:0 auto;
  align-items:start;
}

/* Contact form (reuses booking-form styles where possible) */
.contact-form{
  background:var(--ivory);
  padding:40px 38px;
  border:1px solid rgba(0,0,0,.06);
}
.contact-form .form-grid{grid-template-columns:1fr 1fr;gap:20px}
.contact-form .submit-row{margin-top:24px;padding-top:20px}

/* Right column: general contact info */
.contact-info h3{margin:0 0 22px;font-size:28px}
.contact-info-block{margin:0 0 28px;padding:0 0 28px;border-bottom:1px solid rgba(0,0,0,.08)}
.contact-info-block:last-child{border-bottom:0}
.contact-info-block .label{
  display:block;
  margin:0 0 10px;
  color:var(--gold);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
}
.contact-info-block .value{margin:0;font-size:15px;line-height:1.7;color:var(--ink)}
.contact-info-block .value a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--gold);transition:color var(--t-fast) var(--ease-luxe)}
.contact-info-block .value a:hover{color:var(--gold)}

.social-links{display:flex;gap:14px;margin-top:6px}
.social-links a{
  width:42px;height:42px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(0,0,0,.14);
  color:var(--ink);
  text-decoration:none;
  transition:background var(--t-med) var(--ease-luxe), color var(--t-med) var(--ease-luxe), border-color var(--t-med) var(--ease-luxe), transform var(--t-fast) var(--ease-luxe);
}
.social-links a:hover{background:var(--gold);color:#fff;border-color:var(--gold);transform:translateY(-2px)}
.social-links svg{width:18px;height:18px}

@media (max-width:900px){
  .contact-section{padding:60px 5vw}
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .contact-form{padding:28px 22px}
  .contact-form .form-grid{grid-template-columns:1fr}
}

/* ========================================================
   JOURNAL / BLOG PAGE (Page 8)
   ========================================================= */

.journal-hero{
  position:relative;
  min-height:54vh;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:8vw 6vw;
  color:#fff;
  background:linear-gradient(rgba(6,21,39,.6),rgba(6,21,39,.85)),url('https://images.unsplash.com/photo-1593030103066-0093718efeb9?auto=format&fit=crop&w=1800&q=85') center/cover;
}
.journal-hero-content{max-width:760px}
.journal-hero h1{margin:0 0 18px;font-size:clamp(44px,6vw,72px)}
.journal-hero p{font-size:18px;line-height:1.6;color:rgba(255,255,255,.86);margin:0 auto;max-width:560px}

/* Category filter */
.journal-cats{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:6px;
  padding:30px 6vw 0;
  background:var(--white);
  border-bottom:1px solid rgba(0,0,0,.08);
}
.journal-cat{
  background:transparent;
  border:0;
  padding:18px 22px;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--muted);
  cursor:pointer;
  position:relative;
  text-decoration:none;
  transition:color var(--t-fast) var(--ease-luxe);
}
.journal-cat:hover{color:var(--ink)}
.journal-cat.is-active{color:var(--navy)}
.journal-cat::after{
  content:"";
  position:absolute;
  left:22px;right:22px;bottom:-1px;
  height:2px;
  background:var(--gold);
  transform:scaleX(0);
  transition:transform var(--t-med) var(--ease-luxe);
}
.journal-cat.is-active::after{transform:scaleX(1)}

/* Featured (latest) post */
.journal-featured{
  padding:80px 6vw 50px;
  background:var(--white);
}
.featured-post{
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:50px;
  align-items:center;
  max-width:1200px;
  margin:0 auto;
}
.featured-post .image{position:relative;overflow:hidden;aspect-ratio:5/4;background:#000}
.featured-post .image img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.2s var(--ease-luxe)}
.featured-post:hover .image img{transform:scale(1.04)}
.featured-post .content{max-width:520px}
.featured-post .cat-line{
  display:flex;
  align-items:center;
  gap:14px;
  margin:0 0 16px;
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--gold);
}
.featured-post .cat-line .dot{color:rgba(0,0,0,.2)}
.featured-post .cat-line .date{color:var(--muted)}
.featured-post h2{margin:0 0 18px;font-size:clamp(28px,3vw,44px);letter-spacing:-.01em}
.featured-post h2 a{color:var(--ink);text-decoration:none;transition:color var(--t-fast) var(--ease-luxe)}
.featured-post h2 a:hover{color:var(--gold)}
.featured-post .excerpt{margin:0 0 22px;color:var(--muted);font-size:16px;line-height:1.7}
.featured-post .read-cta{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--navy);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  text-decoration:none;
  border-bottom:1px solid var(--gold);
  padding-bottom:6px;
  transition:gap var(--t-med) var(--ease-luxe), color var(--t-fast) var(--ease-luxe);
}
.featured-post .read-cta:hover{gap:18px;color:var(--gold)}

/* Post grid */
.journal-grid-section{padding:60px 6vw 110px;background:var(--white)}
.journal-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:36px 30px;
  max-width:1200px;
  margin:0 auto;
}
.journal-card{
  display:flex;
  flex-direction:column;
  text-decoration:none;
  color:inherit;
}
.journal-card .image{
  aspect-ratio:4/3;
  overflow:hidden;
  background:#000;
  margin-bottom:20px;
}
.journal-card .image img{width:100%;height:100%;object-fit:cover;display:block;opacity:.94;transition:transform 1s var(--ease-luxe), opacity var(--t-fast) var(--ease-luxe)}
.journal-card:hover .image img{transform:scale(1.05);opacity:1}
.journal-card .cat-line{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--gold);
  margin:0 0 10px;
}
.journal-card .cat-line .dot{color:rgba(0,0,0,.2)}
.journal-card .cat-line .date{color:var(--muted)}
.journal-card h3{
  margin:0 0 10px;
  font-size:20px;
  letter-spacing:-.005em;
  color:var(--ink);
  line-height:1.3;
  transition:color var(--t-fast) var(--ease-luxe);
}
.journal-card:hover h3{color:var(--gold)}
.journal-card p{margin:0;color:var(--muted);font-size:14px;line-height:1.65}

/* Newsletter band on journal page */
.journal-newsletter{
  padding:80px 6vw;
  background:var(--navy);
  color:#fff;
  text-align:center;
}
.journal-newsletter h2{color:#fff;margin:0 0 12px}
.journal-newsletter p{margin:0 auto 24px;color:rgba(255,255,255,.78);font-size:16px;max-width:520px}
.journal-newsletter form{
  display:flex;
  gap:0;
  max-width:520px;
  margin:0 auto;
}
.journal-newsletter input[type="email"]{
  flex:1;
  padding:16px 18px;
  background:#fff;
  border:1px solid #fff;
  font-family:inherit;
  font-size:15px;
  color:var(--ink);
}
.journal-newsletter input[type="email"]:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(184,148,70,.25)}
.journal-newsletter button{
  padding:16px 28px;
  background:var(--gold);
  border:1px solid var(--gold);
  color:#111;
  font-family:inherit;
  font-size:12px;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  cursor:pointer;
  transition:background var(--t-med) var(--ease-luxe), letter-spacing var(--t-med) var(--ease-luxe);
}
.journal-newsletter button:hover{background:var(--gold-soft);letter-spacing:.26em}

@media (max-width:900px){
  .journal-hero{min-height:44vh;padding:60px 5vw}
  .journal-featured{padding:50px 5vw 30px}
  .featured-post{grid-template-columns:1fr;gap:24px}
  .journal-grid-section{padding:30px 5vw 60px}
  .journal-grid{grid-template-columns:1fr;gap:30px}
  .journal-newsletter{padding:50px 5vw}
  .journal-newsletter form{flex-direction:column;gap:10px}
  .journal-newsletter button{width:100%}
  .journal-cat{padding:14px 14px;font-size:11px;letter-spacing:.18em}
  .journal-cat::after{left:14px;right:14px}
}

/* FAQ section (SEO + AI Search optimized) ----------------- */
.faq-section{padding:100px 6vw;background:var(--white)}
.faq-head{text-align:center;max-width:760px;margin:0 auto 50px}
.faq-head h2{margin:0 0 14px}
.faq-intro{margin:0;color:var(--muted);font-size:17px;line-height:1.6}
.faq-list{max-width:880px;margin:0 auto}
.faq-item{
  position:relative;
  border-bottom:1px solid rgba(0,0,0,.08);
  transition:background var(--t-fast) var(--ease-luxe);
}
.faq-item:hover{background:var(--ivory)}
.faq-item.is-open{background:var(--ivory)}
.faq-item::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:0;
  background:var(--gold);
  transition:width var(--t-med) var(--ease-luxe);
}
.faq-item.is-open::before{width:3px}
.faq-question{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  background:transparent;
  border:0;
  padding:26px 30px;
  text-align:left;
  cursor:pointer;
  font-family:Georgia,serif;
  font-size:19px;
  font-weight:500;
  color:var(--ink);
  letter-spacing:-.005em;
  line-height:1.4;
  transition:color var(--t-fast) var(--ease-luxe), padding-left var(--t-med) var(--ease-luxe);
}
.faq-question:hover{color:var(--navy)}
.faq-item.is-open .faq-question{padding-left:38px;color:var(--navy)}
.faq-chevron{
  width:22px;
  height:22px;
  flex:0 0 auto;
  color:var(--gold);
  transition:transform var(--t-med) var(--ease-luxe), color var(--t-fast) var(--ease-luxe);
}
.faq-item.is-open .faq-chevron{transform:rotate(180deg);color:var(--gold-soft)}
.faq-answer{
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows .45s var(--ease-luxe);
}
.faq-answer > div{
  overflow:hidden;
  padding:0 30px;
}
.faq-item.is-open .faq-answer{grid-template-rows:1fr}
.faq-item.is-open .faq-answer > div{padding-bottom:26px}
.faq-answer p{
  margin:0 0 14px;
  color:#3a3a3a;
  font-size:16px;
  line-height:1.7;
}
.faq-answer p:last-child{margin-bottom:0}
.faq-answer strong{color:var(--ink);font-weight:600}

/* 10. Page hero + content + footer ------------------------- */
.page-hero{padding:110px 6vw;background:var(--navy);color:#fff;text-align:center}
.content-wrap{max-width:980px;margin:auto}
.content-wrap img{max-width:100%;height:auto}

.site-footer{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr;
  gap:40px;
  padding:55px 6vw 40px;
  background:#050b12;
  color:#fff;
}
.site-footer a{color:#fff;text-decoration:none;transition:color var(--t-fast) var(--ease-luxe)}
.site-footer a:hover{color:var(--gold-soft)}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer li{margin:6px 0}
.site-footer .footer-col-head{
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--gold);
  margin:0 0 12px;
}
.footer-social{display:flex;gap:10px;margin-top:18px}
.footer-social a{
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.75);
  transition:background var(--t-med) var(--ease-luxe), color var(--t-med) var(--ease-luxe), border-color var(--t-med) var(--ease-luxe), transform var(--t-fast) var(--ease-luxe);
}
.footer-social a:hover{background:var(--gold);border-color:var(--gold);color:#111;transform:translateY(-2px)}
.footer-social svg{width:15px;height:15px}

/* Legal bar (below footer) */
.legal-bar{
  padding:18px 6vw;
  background:#020812;
  color:rgba(255,255,255,.55);
  font-size:11px;
  letter-spacing:.08em;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:14px;
  border-top:1px solid rgba(255,255,255,.05);
}
.legal-bar .est{
  color:var(--gold);
  font-family:Georgia,serif;
  font-style:italic;
  font-size:13px;
  letter-spacing:.04em;
}
.legal-bar nav{display:flex;flex-wrap:wrap;gap:24px}
.legal-bar a{
  color:rgba(255,255,255,.6);
  text-decoration:none;
  transition:color var(--t-fast) var(--ease-luxe);
}
.legal-bar a:hover{color:var(--gold)}

/* Staff (team member) login link in top-bar */
.top-bar-right{display:flex;align-items:center;gap:20px}
.staff-login{
  display:inline-flex;
  align-items:center;
  gap:7px;
  color:rgba(255,255,255,.6);
  text-decoration:none;
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  padding:4px 0;
  border-bottom:1px solid transparent;
  transition:color var(--t-fast) var(--ease-luxe), border-color var(--t-fast) var(--ease-luxe);
}
.staff-login:hover{color:var(--gold);border-bottom-color:var(--gold)}
.staff-login svg{width:11px;height:11px}

/* ========================================================
   COOKIE CONSENT BANNER (GDPR + Google Consent Mode v2)
   ========================================================= */
.cookie-banner{
  position:fixed;
  left:20px;
  right:20px;
  bottom:20px;
  z-index:180;
  max-width:920px;
  margin:0 auto;
  background:rgba(4,15,29,.98);
  color:#fff;
  border:1px solid rgba(184,148,70,.3);
  box-shadow:0 30px 80px rgba(0,0,0,.5);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  padding:24px 28px;
  display:none;
  align-items:center;
  gap:24px;
  flex-wrap:wrap;
  opacity:0;
  transform:translateY(20px);
  transition:opacity .4s var(--ease-luxe), transform .4s var(--ease-luxe);
}
.cookie-banner.is-open{display:flex;opacity:1;transform:translateY(0)}
.cookie-text{
  flex:1;
  min-width:240px;
  margin:0;
  font-size:14px;
  line-height:1.6;
  color:rgba(255,255,255,.86);
}
.cookie-text a{color:var(--gold);text-decoration:none;border-bottom:1px solid rgba(184,148,70,.4);transition:color var(--t-fast)}
.cookie-text a:hover{color:#fff;border-bottom-color:#fff}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.cookie-btn{
  padding:11px 20px;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:700;
  border:1px solid rgba(255,255,255,.25);
  background:transparent;
  color:#fff;
  cursor:pointer;
  font-family:inherit;
  transition:background var(--t-med) var(--ease-luxe), color var(--t-med) var(--ease-luxe), border-color var(--t-med) var(--ease-luxe), letter-spacing var(--t-med) var(--ease-luxe);
}
.cookie-btn:hover{border-color:#fff;background:rgba(255,255,255,.06)}
.cookie-btn.accept{
  background:var(--gold);
  color:#111;
  border-color:var(--gold);
}
.cookie-btn.accept:hover{background:var(--gold-soft);letter-spacing:.22em}
.cookie-btn.text{
  background:transparent;
  border:0;
  padding:11px 8px;
  color:rgba(255,255,255,.7);
}
.cookie-btn.text:hover{color:var(--gold);background:transparent}

/* Cookie preferences modal */
.cookie-prefs{
  position:fixed;
  inset:0;
  z-index:190;
  display:none;
  align-items:center;
  justify-content:center;
  padding:5vw;
  background:rgba(6,21,39,.7);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  opacity:0;
  transition:opacity .35s var(--ease-luxe);
}
.cookie-prefs.is-open{display:flex;opacity:1}
.cookie-prefs-card{
  position:relative;
  max-width:560px;
  width:100%;
  background:#fff;
  color:var(--ink);
  padding:42px 38px 32px;
  max-height:90vh;
  overflow-y:auto;
}
.cookie-prefs-card h2{margin:0 0 12px;font-size:28px}
.cookie-prefs-card > p{margin:0 0 24px;color:var(--muted);font-size:14px;line-height:1.6}
.cookie-prefs-close{
  position:absolute;
  top:14px;right:14px;
  width:34px;height:34px;
  background:rgba(0,0,0,.05);
  border:0;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--ink);
  transition:background var(--t-fast);
}
.cookie-prefs-close:hover{background:rgba(0,0,0,.1)}
.cookie-prefs-close svg{width:16px;height:16px}
.cookie-category{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  padding:18px 0;
  border-bottom:1px solid rgba(0,0,0,.08);
  cursor:pointer;
}
.cookie-category:last-of-type{border-bottom:0}
.cookie-category .info{flex:1}
.cookie-category strong{
  display:block;
  margin-bottom:4px;
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--navy);
}
.cookie-category p{
  margin:0;
  color:var(--muted);
  font-size:13px;
  line-height:1.55;
}
.cookie-toggle{
  position:relative;
  width:44px;
  height:24px;
  background:rgba(0,0,0,.15);
  border-radius:24px;
  transition:background var(--t-med) var(--ease-luxe);
  flex:0 0 auto;
  margin-top:2px;
}
.cookie-toggle::after{
  content:"";
  position:absolute;
  top:3px;left:3px;
  width:18px;height:18px;
  background:#fff;
  border-radius:50%;
  transition:transform var(--t-med) var(--ease-luxe);
  box-shadow:0 1px 3px rgba(0,0,0,.2);
}
.cookie-category input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.cookie-category input:checked ~ .cookie-toggle{background:var(--gold)}
.cookie-category input:checked ~ .cookie-toggle::after{transform:translateX(20px)}
.cookie-category input:disabled ~ .cookie-toggle{background:var(--gold);opacity:.6;cursor:not-allowed}
.cookie-prefs-actions{
  display:flex;
  gap:10px;
  margin-top:24px;
  padding-top:20px;
  border-top:1px solid rgba(0,0,0,.08);
  flex-wrap:wrap;
}
.cookie-prefs-actions .cookie-btn{
  background:#fff;
  color:var(--ink);
  border-color:rgba(0,0,0,.2);
  flex:1;
  min-width:140px;
}
.cookie-prefs-actions .cookie-btn:hover{border-color:var(--ink)}
.cookie-prefs-actions .cookie-btn.accept{
  background:var(--gold);
  color:#111;
  border-color:var(--gold);
}

/* "Cookie settings" link in legal bar (for revisiting choice) */
.legal-bar .cookie-settings{
  background:none;
  border:0;
  color:rgba(255,255,255,.6);
  cursor:pointer;
  font-family:inherit;
  font-size:11px;
  letter-spacing:.08em;
  padding:0;
  transition:color var(--t-fast);
}
.legal-bar .cookie-settings:hover{color:var(--gold)}

@media (max-width:700px){
  .cookie-banner{left:12px;right:12px;bottom:12px;padding:18px 18px;gap:14px}
  .cookie-actions{width:100%;justify-content:flex-end}
  .cookie-btn{padding:10px 14px;font-size:10px;letter-spacing:.14em}
  .cookie-prefs-card{padding:30px 24px 24px}
  .cookie-prefs-card h2{font-size:22px}
}

/* ========================================================
   NEWSLETTER POPUP (modal — email signup for deals/discounts)
   ========================================================= */
.newsletter-popup{
  position:fixed;
  inset:0;
  z-index:200;
  display:none;
  align-items:center;
  justify-content:center;
  padding:5vw;
  background:rgba(6,21,39,.7);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  opacity:0;
  transition:opacity .35s var(--ease-luxe);
}
.newsletter-popup.is-open{display:flex;opacity:1}
.newsletter-popup-card{
  position:relative;
  max-width:920px;
  width:100%;
  background:#fff;
  display:grid;
  grid-template-columns:1fr 1fr;
  transform:translateY(20px);
  transition:transform .45s var(--ease-luxe);
  max-height:90vh;
  overflow:hidden;
}
.newsletter-popup.is-open .newsletter-popup-card{transform:translateY(0)}
.newsletter-popup-image{
  position:relative;
  min-height:480px;
  overflow:hidden;
  background:#000;
}
.newsletter-popup-image img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
}
.newsletter-popup-image::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, transparent 0%, rgba(6,21,39,.3) 100%);
}
.newsletter-popup-content{
  padding:54px 48px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.newsletter-popup-content .eyebrow{margin-bottom:14px}
.newsletter-popup-content h2{
  margin:0 0 14px;
  font-size:34px;
  line-height:1.1;
}
.newsletter-popup-content > p{
  margin:0 0 22px;
  color:var(--muted);
  font-size:15px;
  line-height:1.6;
}
.newsletter-popup-content .offer{
  font-family:Georgia,serif;
  font-style:italic;
  color:var(--ink);
  font-size:17px;
  border-left:2px solid var(--gold);
  padding:6px 0 6px 16px;
  margin:0 0 24px;
}
.newsletter-popup-form{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.newsletter-popup-form input{
  padding:15px 16px;
  background:var(--ivory);
  border:1px solid rgba(0,0,0,.12);
  font-family:inherit;
  font-size:14px;
  color:var(--ink);
}
.newsletter-popup-form input:focus{
  outline:none;
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(184,148,70,.15);
}
.newsletter-popup-form button{
  padding:15px;
  background:var(--gold);
  border:1px solid var(--gold);
  color:#111;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:700;
  cursor:pointer;
  transition:background var(--t-med) var(--ease-luxe), letter-spacing var(--t-med) var(--ease-luxe);
}
.newsletter-popup-form button:hover{background:var(--gold-soft);letter-spacing:.26em}
.newsletter-popup-decline{
  margin-top:14px;
  background:none;
  border:0;
  color:var(--muted);
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  cursor:pointer;
  text-align:left;
  padding:0;
  font-family:inherit;
}
.newsletter-popup-decline:hover{color:var(--ink)}
.newsletter-popup-close{
  position:absolute;
  top:14px;
  right:14px;
  width:36px;height:36px;
  background:rgba(0,0,0,.05);
  border:0;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--ink);
  transition:background var(--t-fast) var(--ease-luxe), transform var(--t-fast) var(--ease-luxe);
  z-index:2;
}
.newsletter-popup-close:hover{background:rgba(0,0,0,.1);transform:rotate(90deg)}
.newsletter-popup-close svg{width:18px;height:18px}
.newsletter-popup-tiny{
  margin-top:14px;
  font-size:11px;
  color:var(--muted);
  line-height:1.5;
}

@media (max-width:700px){
  .newsletter-popup-card{grid-template-columns:1fr;max-width:460px;max-height:96vh;overflow-y:auto}
  .newsletter-popup-image{min-height:180px}
  .newsletter-popup-content{padding:32px 26px}
  .newsletter-popup-content h2{font-size:26px}
}

@media (max-width:900px){
  .site-footer{grid-template-columns:1fr;gap:30px;padding:40px 5vw 30px}
  .legal-bar{flex-direction:column;align-items:flex-start;text-align:left;padding:18px 5vw}
  .legal-bar nav{gap:18px}
  .top-bar-right{gap:14px}
  .staff-login span{display:none}
}

/* 11. Reveal-on-scroll utility ----------------------------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity var(--t-slow) var(--ease-luxe), transform var(--t-slow) var(--ease-luxe)}
.reveal.in{opacity:1;transform:none}

/* 12. Responsive ------------------------------------------- */
@media (max-width:900px){
  .main-nav,.header-cta{display:none}
  .menu-toggle{display:block}
  .top-bar{font-size:10px;letter-spacing:.18em;padding:7px 5vw}
  .split-section,.cards.four,.cards.three,.image-cards,.steps,.site-footer{grid-template-columns:1fr}
  .hero{min-height:75vh}
  .cards article{padding:26px}
  .image-card{min-height:360px}
  .mobile-overlay a{font-size:26px}
  .team-card{flex:0 0 260px}
  .team-card h3{font-size:21px}
  .carousel-btn{width:46px;height:46px}
  .testimonial-ticker{font-size:11px;padding:9px 4vw;gap:8px}
  .ticker-slide{gap:10px}
  .ticker-slide .author{font-size:9px;letter-spacing:.18em}
  .step-icon{width:36px;height:36px}
  .service-card{flex:0 0 280px;height:440px}
  .service-card-body{padding:24px}
  .service-card-body h3{font-size:22px}
  .location-panels{min-height:auto}
  .location-panel{position:relative;grid-template-columns:1fr;gap:24px}
  .location-panel:not(.is-active){display:none}
  .loc-image{min-height:280px}
  .location-tab{padding:14px 16px;font-size:11px;letter-spacing:.18em}
  .location-tab::after{left:16px;right:16px}
  .faq-section{padding:70px 5vw}
  .faq-question{font-size:17px;padding:20px 22px;gap:14px}
  .faq-item.is-open .faq-question{padding-left:30px}
  .faq-answer > div{padding:0 22px}
  .faq-answer p{font-size:15px}
  .faq-head{margin-bottom:36px}
  .faq-intro{font-size:15px}
}
