/* ===== EXOTIC AMBIENCE — VIP EDITION ===== */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,600&family=Montserrat:wght@200;300;400;500;600;700;800&family=Cinzel:wght@400;500;600&display=swap');

:root {
  --void:     #050505;
  --smoke:    #0C0C0C;
  --ash:      #141414;
  --ash-2:    #1C1C1C;
  --ash-3:    #242424;
  --ivory:    #F5F3EE;
  --cream:    #E8E0D0;
  --muted:    rgba(245,243,238,0.42);
  --line:     rgba(245,243,238,0.08);
  --gold:     #C9A84C;
  --gold-light:#E2C97E;
  --gold-dark: #9C7A2E;
  --gold-dim:  rgba(201,168,76,0.12);
}

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { font-size:16px; scroll-behavior:smooth; overflow-x:hidden; }
body {
  font-family:'Montserrat',sans-serif;
  background:var(--void);
  color:var(--ivory);
  overflow-x:hidden;
  cursor:none;
}
img { display:block; max-width:100%; }
a { cursor:none; text-decoration:none; color:inherit; }
button { cursor:none; font-family:'Montserrat',sans-serif; }

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar { width:2px; }
::-webkit-scrollbar-track { background:var(--void); }
::-webkit-scrollbar-thumb { background:var(--gold-dark); }

/* ===== PRELOADER ===== */
#preloader {
  position:fixed; inset:0; z-index:99999;
  background:var(--void);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
}
.pl-inner { text-align:center; }
.pl-logo { width:240px; height:240px; margin:0 auto 32px; opacity:0; animation:plLogoIn .8s ease .3s forwards; }
.pl-logo img { width:100%; height:100%; object-fit:contain; }
@keyframes plLogoIn { to { opacity:1; } }
.pl-brand {
  font-family:'Cinzel',serif; font-size:.75rem; letter-spacing:8px; color:var(--ivory);
  display:flex; gap:0; overflow:hidden; margin-bottom:32px;
}
.pl-char { display:inline-block; opacity:0; transform:translateY(20px); animation:plCharIn .5s ease forwards; }
.pl-space { display:inline-block; width:14px; }
.pl-char:nth-child(1){animation-delay:.5s} .pl-char:nth-child(2){animation-delay:.58s}
.pl-char:nth-child(3){animation-delay:.66s} .pl-char:nth-child(4){animation-delay:.74s}
.pl-char:nth-child(5){animation-delay:.82s} .pl-char:nth-child(6){animation-delay:.90s}
.pl-char:nth-child(8){animation-delay:1.0s} .pl-char:nth-child(9){animation-delay:1.08s}
.pl-char:nth-child(10){animation-delay:1.16s} .pl-char:nth-child(11){animation-delay:1.24s}
.pl-char:nth-child(12){animation-delay:1.32s} .pl-char:nth-child(13){animation-delay:1.40s}
.pl-char:nth-child(14){animation-delay:1.48s} .pl-char:nth-child(15){animation-delay:1.56s}
@keyframes plCharIn { to { opacity:1; transform:translateY(0); } }
.pl-line { width:200px; height:1px; background:var(--ash-3); margin:0 auto 16px; position:relative; overflow:hidden; }
.pl-fill { position:absolute; top:0; left:0; height:100%; width:0%; background:linear-gradient(90deg,var(--gold-dark),var(--gold)); transition:width .05s linear; }
.pl-num { font-family:'Cormorant Garamond',serif; font-size:1.1rem; color:var(--muted); letter-spacing:3px; }
.pl-curtain { position:absolute; inset:0; background:var(--void); transform:translateY(0); transition:transform .9s cubic-bezier(.77,0,.175,1); }
.pl-curtain.up { transform:translateY(-100%); }
#preloader.done { pointer-events:none; }

/* ===== CUSTOM CURSOR ===== */
#cursor {
  position:fixed; width:8px; height:8px; border-radius:50%;
  background:var(--gold); pointer-events:none; z-index:99998;
  transform:translate(-50%,-50%);
  transition:width .3s,height .3s,background .3s,opacity .3s;
}
#cursorRing {
  position:fixed; width:40px; height:40px; border-radius:50%;
  border:1px solid rgba(201,168,76,.5);
  pointer-events:none; z-index:99997;
  transform:translate(-50%,-50%);
  transition:width .3s,height .3s,border-color .3s,opacity .3s;
}
#cursorLabel {
  position:fixed; pointer-events:none; z-index:99999;
  font-family:'Cinzel',serif; font-size:.45rem; letter-spacing:3px;
  color:var(--ivory); opacity:0;
  transform:translate(-50%,-50%) translateY(28px);
  transition:opacity .3s,transform .3s;
  white-space:nowrap;
}
body.cursor-active #cursorRing { width:70px; height:70px; border-color:var(--gold); background:rgba(201,168,76,.05); }
body.cursor-active #cursorLabel { opacity:1; transform:translate(-50%,-50%) translateY(36px); }
body.cursor-active #cursor { width:5px; height:5px; }

/* ===== REVEAL ANIMATIONS ===== */
.reveal-up {
  opacity:0; transform:translateY(60px);
  transition:opacity .95s cubic-bezier(.16,1,.3,1), transform .95s cubic-bezier(.16,1,.3,1);
}
.reveal-up.in { opacity:1; transform:translateY(0); }

.reveal-fade {
  opacity:0;
  transition:opacity 1.1s cubic-bezier(.16,1,.3,1);
}
.reveal-fade.in { opacity:1; }

.reveal-scale {
  opacity:0; transform:scale(.93);
  transition:opacity .95s cubic-bezier(.16,1,.3,1), transform .95s cubic-bezier(.16,1,.3,1);
}
.reveal-scale.in { opacity:1; transform:scale(1); }

.d1 { transition-delay:.1s!important; }
.d2 { transition-delay:.2s!important; }
.d3 { transition-delay:.3s!important; }
.d4 { transition-delay:.4s!important; }
.d5 { transition-delay:.5s!important; }

/* ===== NAVBAR ===== */
#nav {
  position:fixed; inset:0 0 auto 0; z-index:1000;
  padding:28px 72px;
  display:flex; align-items:center; justify-content:space-between;
  transition:all .5s ease;
}
#nav.scrolled {
  background:rgba(5,5,5,.92);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  padding:16px 72px;
  border-bottom:1px solid var(--line);
}
.nav-logo img { height:80px; transition:transform .4s; }
.nav-logo img:hover { transform:scale(1.05); }
.nav-menu { display:flex; gap:44px; list-style:none; }
.nav-menu a {
  font-size:.6rem; font-weight:500; letter-spacing:3px; text-transform:uppercase;
  color:rgba(245,243,238,.6); position:relative; padding-bottom:4px; transition:color .35s;
}
.nav-menu a::after {
  content:''; position:absolute; bottom:0; left:0;
  width:0; height:1px; background:var(--gold); transition:width .4s;
}
.nav-menu a:hover { color:var(--gold); }
.nav-menu a:hover::after { width:100%; }
.nav-cta {
  display:flex; align-items:center; gap:8px;
  padding:11px 28px; border:1px solid var(--gold);
  font-size:.58rem; font-weight:600; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--gold); transition:all .35s ease; position:relative; overflow:hidden;
}
.nav-cta::before {
  content:''; position:absolute; inset:0; background:var(--gold);
  transform:translateX(-101%); transition:transform .4s cubic-bezier(.16,1,.3,1);
}
.nav-cta:hover::before { transform:translateX(0); }
.nav-cta:hover { color:var(--void); }
.nav-cta span,.nav-cta svg { position:relative; z-index:1; }
.nav-burger { display:none; background:none; border:none; padding:4px; flex-direction:column; gap:6px; }
.nav-burger span { display:block; width:26px; height:1px; background:var(--ivory); transition:all .3s; }

/* Mobile overlay */
.mob-overlay {
  display:none; position:fixed; inset:0; z-index:8000;
  background:var(--void); flex-direction:column; align-items:center; justify-content:center;
}
.mob-overlay.open { display:flex; }
.mob-x { position:absolute; top:28px; right:40px; font-size:1.6rem; background:none; border:none; color:var(--gold); }
.mob-brand { font-family:'Cormorant Garamond',serif; font-size:3.2rem; font-weight:600; text-align:center; color:var(--ivory); line-height:1.1; margin-bottom:48px; }
.mob-links { display:flex; flex-direction:column; gap:24px; text-align:center; }
.mob-links a { font-family:'Cinzel',serif; font-size:1rem; letter-spacing:4px; color:var(--muted); text-transform:uppercase; transition:color .3s; }
.mob-links a:hover { color:var(--gold); }
.mob-foot { position:absolute; bottom:36px; font-size:.55rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold-dark); }

/* ===== HERO ===== */
#hero {
  height:100vh; min-height:700px; position:relative;
  display:grid; grid-template-columns:1fr 1fr;
  overflow:hidden; background:var(--void);
}
.hero-bg {
  position:absolute; right:0; top:0; bottom:0; width:55%;
  overflow:hidden;
}
.hero-portrait {
  width:100%; height:100%; object-fit:cover;
  animation:heroReveal 1.6s cubic-bezier(.16,1,.3,1) .4s both;
}
@keyframes heroReveal {
  from { clip-path:inset(0 100% 0 0); transform:scale(1.08); }
  to   { clip-path:inset(0 0% 0 0); transform:scale(1); }
}
.hero-grain {
  position:absolute; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events:none; opacity:.5;
}
.hero-content {
  position:relative; z-index:2;
  display:flex; flex-direction:column; justify-content:center;
  padding:0 80px 80px; max-width:660px;
}
.hero-eyebrow {
  display:flex; align-items:center; gap:10px; margin-bottom:36px;
  opacity:0; animation:fadeIn .8s ease 1.8s forwards;
}
.eyebrow-dot { width:6px; height:6px; background:var(--gold); border-radius:50%; animation:pulse 2s ease infinite; }
@keyframes pulse { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(.7);opacity:.4} }
.hero-eyebrow span { font-size:.58rem; letter-spacing:4px; text-transform:uppercase; color:var(--gold); font-weight:500; }

.hero-title { line-height:1.0; margin-bottom:40px; }
.ht-line { display:block; overflow:hidden; }
.ht-word {
  display:inline-block;
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(4rem,8vw,9rem);
  font-weight:600; color:var(--ivory);
  opacity:0; transform:translateY(100%);
  animation:wordSlide 1s cubic-bezier(.16,1,.3,1) forwards;
}
.ht-line:nth-child(1) .ht-word { animation-delay:1.9s; }
.ht-line:nth-child(2) .ht-word { animation-delay:2.1s; color:var(--gold); font-style:italic; }
.ht-word.italic { font-style:italic; }
@keyframes wordSlide { to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn { to { opacity:1; } }

.hero-sub-row {
  display:flex; align-items:center; gap:36px; flex-wrap:wrap;
  opacity:0; animation:fadeIn .8s ease 2.4s forwards;
}
.hero-tagline {
  font-family:'Cormorant Garamond',serif; font-style:italic;
  font-size:1.15rem; color:var(--muted); letter-spacing:1px;
}
.btn-hero {
  display:inline-flex; align-items:center; gap:0;
  overflow:hidden; border:1px solid var(--gold);
  font-size:.58rem; font-weight:600; letter-spacing:3px; text-transform:uppercase;
  color:var(--gold); position:relative;
}
.btn-hero-txt { padding:12px 22px; transition:background .4s,color .4s; }
.btn-hero-arr {
  width:44px; height:42px; background:var(--gold);
  display:flex; align-items:center; justify-content:center;
  transition:background .4s;
}
.btn-hero-arr svg { stroke:var(--void); }
.btn-hero:hover .btn-hero-txt { background:var(--gold); color:var(--void); }
.btn-hero:hover .btn-hero-arr { background:var(--gold-dark); }
.btn-hero-arrow { display:flex; }

.hero-stats {
  position:absolute; bottom:44px; left:72px; right:55%;
  display:flex; align-items:center; gap:0;
  opacity:0; animation:fadeIn .8s ease 2.6s forwards;
}
.hs-item { flex:1; text-align:center; }
.hs-n { font-family:'Cormorant Garamond',serif; font-size:1.8rem; font-weight:700; color:var(--gold); display:block; line-height:1; }
.hs-l { font-size:.48rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--muted); margin-top:5px; display:block; }
.hs-div { width:1px; height:36px; background:var(--line); }

.hero-scroll {
  position:absolute; right:32px; bottom:48px; z-index:3;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  opacity:0; animation:fadeIn .8s ease 2.8s forwards;
}
.hs-track { width:1px; height:60px; background:var(--line); position:relative; overflow:hidden; }
.hs-thumb { position:absolute; top:-100%; width:100%; height:100%; background:var(--gold); animation:scrollThumb 2s ease-in-out infinite; }
@keyframes scrollThumb { 0%{top:-100%} 60%{top:100%} 100%{top:100%} }
.hero-scroll span { font-size:.48rem; letter-spacing:3px; text-transform:uppercase; color:var(--muted); writing-mode:vertical-rl; }

/* ===== TICKER ===== */
.ticker-wrap { background:var(--ash); border-top:1px solid var(--line); border-bottom:1px solid var(--line); overflow:hidden; }
.ticker-row { padding:13px 0; overflow:hidden; }
.ticker-inner { display:flex; width:max-content; gap:40px; align-items:center; }
.ticker-inner { animation:tickerFwd 25s linear infinite; }
.ticker-inner.rev { animation:tickerRev 28s linear infinite; }
.ticker-inner span { font-size:.58rem; font-weight:600; letter-spacing:4px; text-transform:uppercase; color:var(--gold); white-space:nowrap; }
.t-dot { color:var(--gold-dark); font-size:.5rem; }
@keyframes tickerFwd { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes tickerRev { from{transform:translateX(-50%)} to{transform:translateX(0)} }

/* ===== ABOUT ===== */
#about {
  background:var(--smoke); padding:140px 0;
  display:grid; grid-template-columns:1fr 1fr; gap:0;
  min-height:100vh; align-items:stretch;
}
.about-left {
  position:relative; overflow:hidden;
}
.ab-num-wrap {
  position:absolute; top:80px; left:72px; z-index:3;
  display:flex; align-items:flex-end; gap:14px;
}
.ab-big-num {
  font-family:'Cormorant Garamond',serif; font-size:clamp(6rem,11vw,14rem);
  font-weight:700; line-height:1; color:rgba(201,168,76,.08);
  position:absolute; top:-30px; left:40px; pointer-events:none; select:none;
}
.ab-num-label { font-size:.52rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold); position:relative; z-index:1; padding-bottom:6px; }

.ab-img-stack { position:relative; height:100%; min-height:700px; }
.ab-img-main { position:absolute; inset:0; }
.ab-img-main img { width:100%; height:100%; object-fit:cover; display:block; }
.ab-img-float {
  position:absolute; bottom:60px; right:-40px; z-index:4;
  width:45%; border:4px solid var(--void); box-shadow:0 30px 80px rgba(0,0,0,.5);
}
.ab-img-float img { width:100%; height:260px; object-fit:cover; display:block; }

.about-right {
  padding:100px 80px 100px 90px;
  display:flex; flex-direction:column; justify-content:center;
  background:var(--ash);
}
.ab-label { font-size:.55rem; letter-spacing:5px; text-transform:uppercase; color:var(--gold-dark); margin-bottom:24px; display:block; }
.ab-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.2rem,3.5vw,3.8rem); font-weight:600; line-height:1.15;
  color:var(--ivory); margin-bottom:0;
}
.at-line { display:block; overflow:hidden; line-height:1.25; }
.ab-title em { font-style:italic; color:var(--gold); }
.ab-gold-bar { width:48px; height:1px; background:linear-gradient(90deg,var(--gold),transparent); margin:28px 0 32px; }
.ab-body { font-size:.88rem; font-weight:300; line-height:2.1; color:var(--muted); margin-bottom:18px; }
.ab-features { display:flex; flex-direction:column; gap:0; margin:28px 0; border-top:1px solid var(--line); }
.ab-feat {
  display:flex; align-items:center; gap:16px; padding:18px 0;
  border-bottom:1px solid var(--line); transition:padding-left .3s ease;
}
.ab-feat:hover { padding-left:8px; }
.af-icon { width:34px; height:34px; min-width:34px; border:1px solid var(--gold-dark); display:flex; align-items:center; justify-content:center; transition:all .3s; }
.ab-feat:hover .af-icon { background:var(--gold); }
.af-icon svg { width:14px; height:14px; stroke:var(--gold); transition:stroke .3s; }
.ab-feat:hover .af-icon svg { stroke:var(--void); }
.ab-feat span { font-size:.72rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--ivory); font-weight:500; }
.btn-gold-outline {
  display:inline-flex; align-items:center; gap:10px; align-self:flex-start;
  padding:13px 30px; border:1px solid var(--gold);
  font-size:.58rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold);
  font-weight:600; margin-top:8px; transition:all .4s;
  position:relative; overflow:hidden;
}
.btn-gold-outline::before { content:''; position:absolute; inset:0; background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .4s cubic-bezier(.16,1,.3,1); }
.btn-gold-outline:hover::before { transform:scaleX(1); }
.btn-gold-outline:hover { color:var(--void); }
.btn-gold-outline span,.btn-gold-outline svg { position:relative; z-index:1; }

/* ===== SERVICES ===== */
#services { background:var(--void); padding:120px 0 0; }
.srv-intro { padding:0 72px; margin-bottom:80px; display:flex; align-items:flex-end; justify-content:space-between; }
.s-label { font-size:.55rem; letter-spacing:5px; text-transform:uppercase; color:var(--gold-dark); display:block; }
.s-big-title { font-family:'Cormorant Garamond',serif; font-size:clamp(3rem,6vw,7rem); font-weight:600; color:var(--ivory); line-height:1; }
.s-big-title em { font-style:italic; color:var(--gold); }
.sbt-line { display:block; overflow:hidden; line-height:1.15; }

.srv-panels { display:flex; flex-direction:column; }
.srv-panel {
  display:grid; grid-template-columns:1fr 1fr;
  min-height:520px;
  border-top:1px solid var(--line);
  position:relative; overflow:hidden;
}
.srv-panel:nth-child(even) { direction:rtl; }
.srv-panel:nth-child(even) .sp-content { direction:ltr; }
.sp-img { position:relative; overflow:hidden; }
.sp-img img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 1.2s cubic-bezier(.16,1,.3,1); }
.srv-panel:hover .sp-img img { transform:scale(1.05); }
.sp-content {
  padding:70px 80px; display:flex; flex-direction:column; justify-content:center;
  background:var(--ash); position:relative;
}
.sp-num { font-family:'Cormorant Garamond',serif; font-size:4rem; font-weight:700; color:rgba(201,168,76,.07); position:absolute; top:24px; right:28px; line-height:1; }
.sp-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,3vw,3.2rem); font-weight:600; color:var(--ivory);
  line-height:1.2; margin-bottom:20px;
}
.sp-desc { font-size:.84rem; font-weight:300; color:var(--muted); line-height:2.1; margin-bottom:32px; }
.sp-link {
  display:inline-flex; align-items:center; gap:10px; align-self:flex-start;
  font-size:.58rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold);
  padding-bottom:3px; border-bottom:1px solid rgba(201,168,76,.3);
  transition:gap .3s, border-color .3s;
}
.sp-link:hover { gap:16px; border-color:var(--gold); }
.sp-link svg { stroke:var(--gold); }

/* ===== PRODUCTS ===== */
#products { background:var(--smoke); padding:120px 72px; }
.prod-head { display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:end; margin-bottom:60px; }
.ph-title { font-family:'Cormorant Garamond',serif; font-size:clamp(2.5rem,5vw,5.5rem); font-weight:600; color:var(--ivory); line-height:1; }
.ph-line { display:block; overflow:hidden; line-height:1.15; }
.ph-title em { font-style:italic; color:var(--gold); }
.ph-sub { font-size:.84rem; font-weight:300; color:var(--muted); line-height:2; align-self:flex-end; }

.prod-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto auto;
  gap:16px;
}
.pg-item { position:relative; overflow:hidden; background:var(--ash); }
.pg-item.large { grid-column:span 2; grid-row:span 1; }
.pg-item.tall { grid-row:span 2; }

.pgi-img { position:relative; overflow:hidden; height:320px; }
.pg-item.large .pgi-img { height:420px; }
.pg-item.tall .pgi-img { height:100%; min-height:500px; }
.pgi-img img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 1s cubic-bezier(.16,1,.3,1); }
.pg-item:hover .pgi-img img { transform:scale(1.06); }

.pgi-overlay {
  position:absolute; inset:0; background:rgba(5,5,5,0);
  display:flex; align-items:center; justify-content:center;
  transition:background .5s;
}
.pg-item:hover .pgi-overlay { background:rgba(5,5,5,.5); }
.pgi-btn {
  font-size:.56rem; letter-spacing:3px; text-transform:uppercase;
  border:1px solid rgba(245,243,238,.7); color:var(--ivory);
  padding:11px 24px; opacity:0; transform:translateY(12px);
  transition:all .4s ease;
}
.pg-item:hover .pgi-btn { opacity:1; transform:translateY(0); }
.pgi-btn:hover { background:var(--gold); border-color:var(--gold); color:var(--void); }

.pgi-info { padding:20px 24px 24px; display:flex; flex-wrap:wrap; align-items:flex-start; gap:8px; }
.pgi-cat { font-size:.52rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold-dark); width:100%; }
.pgi-name { font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-weight:600; color:var(--ivory); width:100%; line-height:1.3; }
.pgi-stars { color:var(--gold); font-size:.75rem; letter-spacing:1px; }
.pgi-tag {
  margin-left:auto; font-size:.48rem; letter-spacing:2px; text-transform:uppercase;
  background:var(--gold-dim); color:var(--gold); border:1px solid rgba(201,168,76,.2);
  padding:4px 10px;
}

/* ===== EDITORIAL ===== */
#editorial {
  display:grid; grid-template-columns:1fr 1fr;
  min-height:100vh; background:var(--void);
  overflow:hidden;
}
.ed-left { position:relative; overflow:hidden; }
.ed-main-img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 1.5s cubic-bezier(.16,1,.3,1); }
#editorial:hover .ed-main-img { transform:scale(1.04); }
.ed-float-img {
  position:absolute; bottom:48px; right:-32px; z-index:2;
  width:52%; border:4px solid var(--void); box-shadow:0 30px 80px rgba(0,0,0,.6);
}
.ed-float-img img { width:100%; height:300px; object-fit:cover; display:block; }

.ed-right {
  background:var(--ash); padding:100px 80px;
  display:flex; flex-direction:column; justify-content:center;
}
.ed-title { font-family:'Cormorant Garamond',serif; font-size:clamp(2.5rem,4vw,5rem); font-weight:600; color:var(--ivory); line-height:1.1; margin:20px 0 0; }
.ed-line { display:block; overflow:hidden; line-height:1.2; }
.ed-title em { font-style:italic; color:var(--gold); }
.ed-gold { width:48px; height:1px; background:linear-gradient(90deg,var(--gold),transparent); margin:28px 0 32px; }
.ed-body { font-size:.88rem; font-weight:300; color:var(--muted); line-height:2.1; margin-bottom:32px; }
.ed-tags { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:40px; }
.ed-tag {
  font-size:.52rem; letter-spacing:2.5px; text-transform:uppercase;
  border:1px solid var(--line); color:var(--muted); padding:7px 16px;
  transition:all .3s;
}
.ed-tag:hover { border-color:var(--gold); color:var(--gold); }
.btn-gold-solid {
  display:inline-flex; align-items:center; gap:10px; align-self:flex-start;
  padding:14px 32px; background:var(--gold); color:var(--void);
  font-size:.58rem; font-weight:700; letter-spacing:2.5px; text-transform:uppercase;
  border:1px solid var(--gold); transition:all .4s;
}
.btn-gold-solid:hover { background:transparent; color:var(--gold); }

/* ===== STATEMENT ===== */
#statement {
  background:var(--ash); padding:160px 72px;
  position:relative; overflow:hidden;
  display:flex; align-items:center;
}
.stmt-inner { position:relative; z-index:2; }
.stmt-line {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(3rem,7vw,8rem);
  font-weight:600; line-height:1.1; color:var(--ivory);
  display:block; overflow:hidden;
}
.stmt-line em { font-style:italic; color:var(--gold); }
.stmt-bg-text {
  position:absolute; right:-40px; top:50%; transform:translateY(-50%);
  font-family:'Cinzel',serif; font-size:clamp(8rem,18vw,22rem);
  font-weight:600; color:rgba(201,168,76,.04); pointer-events:none; white-space:nowrap;
  letter-spacing:20px; line-height:1;
}

/* ===== GALLERY ===== */
#gallery { background:var(--void); padding:120px 72px; }
.gal-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:60px; }
.gal-title { font-family:'Cormorant Garamond',serif; font-size:clamp(2.5rem,5vw,5rem); font-weight:600; color:var(--ivory); text-align:right; line-height:1; }
.gtl { display:block; overflow:hidden; line-height:1.15; }
.gal-title em { font-style:italic; color:var(--gold); }

.gal-grid {
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-template-rows:380px 280px;
  gap:12px;
}
.gg-item { position:relative; overflow:hidden; }
.gg-1 { grid-column:1/6; grid-row:1/2; }
.gg-2 { grid-column:6/9; grid-row:1/2; }
.gg-3 { grid-column:9/13; grid-row:1/2; }
.gg-4 { grid-column:1/5; grid-row:2/3; }
.gg-5 { grid-column:5/9; grid-row:2/3; }
.gg-6 { grid-column:9/13; grid-row:2/3; }

.gg-item img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 1.2s cubic-bezier(.16,1,.3,1); }
.gg-item:hover img { transform:scale(1.08); }
.gg-label {
  position:absolute; bottom:0; left:0; right:0; padding:16px 18px;
  background:linear-gradient(to top,rgba(5,5,5,.8),transparent);
  font-size:.52rem; letter-spacing:3px; text-transform:uppercase;
  color:var(--gold-light); opacity:0; transform:translateY(4px); transition:all .4s;
}
.gg-item:hover .gg-label { opacity:1; transform:translateY(0); }

/* ===== TESTIMONIALS ===== */
#testimonials { background:var(--ash); padding:120px 72px; }
.test-wrap { }
.test-head { margin-bottom:70px; display:flex; align-items:flex-end; justify-content:space-between; }
.test-title { font-family:'Cormorant Garamond',serif; font-size:clamp(2.5rem,5vw,5rem); font-weight:600; color:var(--ivory); line-height:1; text-align:right; }
.ttl { display:block; overflow:hidden; line-height:1.15; }
.test-title em { font-style:italic; color:var(--gold); }
.test-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); }
.tc { padding:50px 44px; background:var(--ash); position:relative; transition:background .4s; }
.tc:hover { background:var(--ash-2); }
.tc-quote { font-family:'Cormorant Garamond',serif; font-size:6rem; font-weight:700; color:rgba(201,168,76,.1); position:absolute; top:10px; left:36px; line-height:1; }
.tc-body { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:1.08rem; color:rgba(245,243,238,.7); line-height:2; padding-top:24px; margin-bottom:32px; }
.tc-author { display:flex; align-items:center; gap:14px; margin-bottom:20px; }
.tc-author img { width:46px; height:46px; border-radius:50%; object-fit:cover; border:1.5px solid rgba(201,168,76,.25); }
.tc-name { font-size:.78rem; font-weight:600; color:var(--ivory); display:block; margin-bottom:3px; }
.tc-role { font-size:.52rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold-dark); }
.tc-stars { color:var(--gold); font-size:.85rem; letter-spacing:2px; }

/* ===== CTA ===== */
#cta { position:relative; padding:180px 72px; text-align:left; overflow:hidden; }
.cta-bg { position:absolute; inset:0; }
.cta-bg img { width:100%; height:100%; object-fit:cover; display:block; }
.cta-overlay { position:absolute; inset:0; background:linear-gradient(120deg,rgba(5,5,5,.92) 45%,rgba(5,5,5,.6) 100%); }
.cta-content { position:relative; z-index:2; max-width:760px; }
.cta-title { font-family:'Cormorant Garamond',serif; font-size:clamp(3rem,6vw,7.5rem); font-weight:600; color:var(--ivory); line-height:1; margin:20px 0 0; }
.ctl { display:block; overflow:hidden; line-height:1.15; }
.cta-title em { font-style:italic; color:var(--gold); }
.cta-sub { font-size:.88rem; font-weight:300; color:var(--muted); line-height:2.1; margin:32px 0 44px; max-width:540px; }
.cta-btns { display:flex; gap:16px; flex-wrap:wrap; }
.btn-cta-gold {
  display:inline-flex; align-items:center; gap:10px;
  padding:15px 36px; background:var(--gold); color:var(--void);
  font-size:.62rem; font-weight:700; letter-spacing:2.5px; text-transform:uppercase;
  border:1.5px solid var(--gold); transition:all .4s;
}
.btn-cta-gold:hover { background:var(--gold-light); border-color:var(--gold-light); transform:translateY(-2px); }
.btn-cta-outline {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 36px; background:transparent; color:var(--ivory);
  font-size:.62rem; font-weight:500; letter-spacing:2.5px; text-transform:uppercase;
  border:1.5px solid rgba(245,243,238,.25); transition:all .4s;
}
.btn-cta-outline:hover { border-color:var(--gold); color:var(--gold); }

/* ===== CONTACT ===== */
#contact { background:var(--smoke); padding:140px 0; }
.contact-wrap { max-width:1240px; margin:0 auto; padding:0 72px; display:grid; grid-template-columns:1fr 1fr; gap:100px; align-items:start; }
.ct-title { font-family:'Cormorant Garamond',serif; font-size:clamp(2.5rem,4.5vw,5.5rem); font-weight:600; color:var(--ivory); line-height:1; margin:24px 0 0; }
.ctl-line { display:block; overflow:hidden; line-height:1.2; }
.ct-title em { font-style:italic; color:var(--gold); }
.ct-gold { width:48px; height:1px; background:linear-gradient(90deg,var(--gold),transparent); margin:28px 0 24px; }
.ct-sub { font-size:.86rem; font-weight:300; color:var(--muted); line-height:2.1; margin-bottom:40px; }
.ct-info { display:flex; flex-direction:column; gap:0; border-top:1px solid var(--line); }
.cti-item { display:flex; align-items:center; gap:18px; padding:22px 0; border-bottom:1px solid var(--line); transition:padding-left .3s; }
.cti-item:hover { padding-left:8px; }
.cti-ico { width:40px; height:40px; min-width:40px; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; transition:all .3s; }
.cti-item:hover .cti-ico { background:var(--gold); border-color:var(--gold); }
.cti-ico svg { width:15px; height:15px; stroke:var(--gold); transition:stroke .3s; }
.cti-item:hover .cti-ico svg { stroke:var(--void); }
.cti-label { font-size:.5rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold-dark); display:block; margin-bottom:3px; }
.cti-val { font-size:.84rem; color:rgba(245,243,238,.7); }

.ct-right { background:var(--ash); padding:56px 48px; border:1px solid var(--line); }
.cf-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.cf-field { margin-bottom:20px; }
.cf-field label { display:block; font-size:.5rem; letter-spacing:3px; text-transform:uppercase; color:var(--gold-dark); margin-bottom:10px; }
.cf-field input,.cf-field textarea,.cf-field select {
  width:100%; background:var(--void); border:1px solid var(--line);
  color:var(--ivory); font-family:'Montserrat',sans-serif; font-size:.84rem;
  font-weight:300; padding:13px 16px; outline:none; transition:border-color .3s;
  -webkit-appearance:none; appearance:none;
}
.cf-field input:focus,.cf-field textarea:focus,.cf-field select:focus { border-color:var(--gold-dark); }
.cf-field input::placeholder,.cf-field textarea::placeholder { color:rgba(245,243,238,.2); }
.cf-field textarea { height:110px; resize:none; }
.cf-field select option { background:var(--ash); color:var(--ivory); }
.cf-submit {
  width:100%; padding:0; background:transparent; border:1px solid var(--gold);
  display:flex; align-items:center; overflow:hidden; transition:border-color .4s; margin-top:4px;
}
.cf-btn-txt { flex:1; padding:16px; font-size:.62rem; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--gold); text-align:left; background:transparent; transition:background .4s,color .4s; }
.cf-btn-arr { width:54px; height:54px; background:var(--gold); display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:background .4s; }
.cf-btn-arr svg { stroke:var(--void); }
.cf-submit:hover .cf-btn-txt { background:var(--gold); color:var(--void); }
.cf-submit:hover .cf-btn-arr { background:var(--gold-dark); }

/* ===== FOOTER ===== */
#footer { background:var(--void); padding:80px 72px 40px; border-top:1px solid var(--line); }
.foot-top { display:grid; grid-template-columns:1.4fr 2fr 1fr; gap:60px; margin-bottom:60px; align-items:start; }
.ft-brand img { height:100px; margin-bottom:20px; }
.ft-brand p { font-size:.75rem; font-weight:300; color:var(--muted); line-height:2; }
.ft-nav { display:grid; grid-template-columns:repeat(3,1fr); gap:32px; }
.ftn-col h5 { font-size:.5rem; letter-spacing:3.5px; text-transform:uppercase; color:var(--gold-dark); margin-bottom:20px; }
.ftn-col a { display:block; font-size:.76rem; font-weight:300; color:var(--muted); margin-bottom:12px; transition:color .3s; }
.ftn-col a:hover { color:var(--gold); }
.ft-social h5 { font-size:.5rem; letter-spacing:3.5px; text-transform:uppercase; color:var(--gold-dark); margin-bottom:20px; }
.ft-soc-links { display:flex; gap:10px; }
.fsl { width:38px; height:38px; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; transition:all .3s; }
.fsl:hover { background:var(--gold-dim); border-color:var(--gold); }
.fsl svg { width:14px; height:14px; stroke:var(--gold); fill:none; stroke-width:1.5; }
.foot-bottom { display:flex; justify-content:space-between; align-items:center; padding-top:32px; border-top:1px solid var(--line); }
.fb-copy { font-size:.58rem; letter-spacing:1px; color:rgba(245,243,238,.25); }
.fb-tag { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:.95rem; color:rgba(201,168,76,.35); }

/* ===== RESPONSIVE ===== */
@media(max-width:1100px){
  #nav { padding:22px 36px; }
  #nav.scrolled { padding:14px 36px; }
  .nav-menu { gap:28px; }
  #hero { grid-template-columns:1fr; }
  .hero-bg { width:100%; opacity:.35; }
  .hero-content { padding:0 36px 100px; max-width:100%; }
  .hero-stats { left:36px; right:36px; }
  #about { grid-template-columns:1fr; }
  .about-left { min-height:480px; }
  .ab-img-float { right:20px; }
  .about-right { padding:70px 36px; }
  .srv-panel { grid-template-columns:1fr; }
  .srv-panel:nth-child(even) { direction:ltr; }
  .sp-img { min-height:320px; }
  .sp-content { padding:50px 36px; }
  #products { padding:100px 36px; }
  .prod-grid { grid-template-columns:1fr 1fr; }
  .pg-item.large { grid-column:span 2; }
  .pg-item.tall { grid-row:span 1; }
  #editorial { grid-template-columns:1fr; }
  .ed-left { min-height:460px; }
  .ed-float-img { right:20px; }
  .ed-right { padding:70px 36px; }
  #statement { padding:100px 36px; }
  #gallery { padding:100px 36px; }
  .gal-grid { grid-template-columns:1fr 1fr 1fr; grid-template-rows:280px 200px; }
  .gg-1 { grid-column:1/3; } .gg-2 { grid-column:3/4; }
  .gg-3 { grid-column:1/2; } .gg-4 { grid-column:2/3; } .gg-5 { grid-column:3/4; }
  .gg-6 { display:none; }
  #testimonials { padding:100px 36px; }
  .test-cards { grid-template-columns:1fr 1fr; }
  #cta { padding:120px 36px; }
  .contact-wrap { grid-template-columns:1fr; gap:60px; padding:0 36px; }
  #footer { padding:60px 36px 32px; }
  .foot-top { grid-template-columns:1fr 1fr; }
  .ft-brand { grid-column:1/-1; }
}
@media(max-width:768px){
  #nav { padding:18px 20px; }
  #nav.scrolled { padding:12px 20px; }
  .nav-menu,.nav-cta { display:none; }
  .nav-burger { display:flex; }
  #hero { min-height:100svh; }
  .hero-content { padding:0 20px 100px; }
  .hero-stats { left:20px; right:20px; bottom:24px; }
  .ht-word { font-size:clamp(3rem,14vw,5rem); }
  #products { padding:80px 20px; }
  .prod-grid { grid-template-columns:1fr; }
  .pg-item.large { grid-column:span 1; }
  .pgi-img { height:260px; }
  .pg-item.large .pgi-img { height:300px; }
  .prod-head { grid-template-columns:1fr; }
  .gal-grid { grid-template-columns:1fr 1fr; grid-template-rows:220px 180px 160px; }
  .gg-1 { grid-column:1/2; } .gg-2 { grid-column:2/3; }
  .gg-3 { grid-column:1/2; } .gg-4 { grid-column:2/3; }
  .gg-5 { grid-column:1/3; } .gg-6 { display:none; }
  .test-cards { grid-template-columns:1fr; }
  .srv-intro { padding:0 20px; flex-direction:column; align-items:flex-start; gap:12px; }
  #cta { padding:100px 20px; }
  body { cursor:auto; }
  #cursor,#cursorRing,#cursorLabel { display:none; }
  .cf-row { grid-template-columns:1fr; }
  #footer { padding:50px 20px 28px; }
  .foot-top { grid-template-columns:1fr; }
  .ft-nav { grid-template-columns:1fr 1fr; }
  .foot-bottom { flex-direction:column; gap:10px; text-align:center; }
  #gallery { padding:80px 20px; }
  #testimonials { padding:80px 20px; }
}
