/* ════════════════════════════════════════════════════
   S&V RAIL® — style.css v5.0
   Nav/Logo  : Cormorant Garamond (ultra-luxury editorial serif)
   Headings  : Cinzel        (Roman-inspired, architectural caps)
   Body      : DM Sans       (geometric, modern, highly legible)
   Gold      : #C8A96E  |  Cream : #F5F0E8  |  Ink : #0A0A0A
════════════════════════════════════════════════════ */

:root{
  --ink:      #0A0A0A;
  --ink-2:    #111;
  --ink-3:    #1C1C1C;
  --charcoal: #282828;
  --cream:    #F5F0E8;
  --cream-2:  #FDFAF5;
  --cream-3:  #EDE8DF;
  --gold:     #C8A96E;
  --gold-2:   #E8D4A8;
  --gold-3:   #A48040;
  --steel:    #7A7870;
  --border:   rgba(0,0,0,.1);
  /* Fonts */
  --fh:  'Cinzel', serif;              /* headings — Roman/architectural */
  --fs:  'Cormorant Garamond', serif;  /* nav, quotes — luxury editorial */
  --fb:  'DM Sans', sans-serif;        /* body — clean geometric */
  --ease:     cubic-bezier(.25,.46,.45,.94);
  --ease-out: cubic-bezier(0,0,.2,1);
}

/* ── RESET ──────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--fb);
  background:var(--cream-2);
  color:var(--ink);
  line-height:1.7;
  overflow-x:hidden;
  cursor:none;
}
img{display:block;width:100%;height:100%;object-fit:cover}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{background:none;border:none;font:inherit}

/* ── CURSOR ─────────────────────────────────────── */
.cursor{
  width:38px;height:38px;
  border:1.5px solid var(--gold);
  border-radius:50%;
  position:fixed;top:0;left:0;
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .35s var(--ease),height .35s var(--ease),border-color .3s;
}
.cursor.hover{width:58px;height:58px;border-color:rgba(200,169,110,.45)}
.cursor-dot{
  width:5px;height:5px;background:var(--gold);
  border-radius:50%;position:fixed;top:0;left:0;
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
}
@media(hover:none){.cursor,.cursor-dot{display:none}body{cursor:auto}}

/* ── PROGRESS BAR ───────────────────────────────── */
.progress-bar{
  position:fixed;top:0;left:0;z-index:2000;
  height:2px;width:0%;
  background:linear-gradient(90deg,var(--gold-3),var(--gold),var(--gold-2));
}

/* ── UTILS ──────────────────────────────────────── */
.container{width:100%;max-width:1280px;margin:0 auto;padding:0 2.5rem}
.section{padding:7.5rem 0}

/* ── AOS ────────────────────────────────────────── */
[data-aos]{
  opacity:0;transform:translateY(28px);
  transition:opacity .8s var(--ease),transform .8s var(--ease);
}
[data-aos].aos-in{opacity:1;transform:translateY(0)}

/* ── LABELS & HEADINGS ──────────────────────────── */
.sec-label{
  display:block;
  font-family:var(--fb);
  font-size:.58rem;font-weight:500;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);margin-bottom:.85rem;
}
.sec-label.light{color:var(--gold)}

.sec-h2{
  font-family:var(--fh);           /* Cinzel — all-caps Roman elegance */
  font-size:clamp(2.2rem,4.5vw,3.8rem);
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  line-height:1.05;
  color:var(--ink);
  margin-bottom:3rem;
}
.sec-h2 em{font-style:normal;color:var(--gold)}
.sec-h2.white{color:#fff}

/* ── BUTTONS ────────────────────────────────────── */
.btn-gold{
  display:inline-flex;align-items:center;gap:.8rem;
  background:var(--gold);color:var(--ink);
  font-family:var(--fh);font-size:.72rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  padding:.9rem 2.25rem;border:2px solid var(--gold);border-radius:1px;
  transition:background .3s,color .3s,gap .3s,transform .2s;
}
.btn-gold svg{width:16px;height:16px;flex-shrink:0;transition:transform .3s}
.btn-gold:hover{background:transparent;color:var(--gold);gap:1.3rem;transform:translateY(-2px)}
.btn-gold:hover svg{transform:translateX(5px)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:.6rem;
  background:transparent;color:rgba(255,255,255,.7);
  font-family:var(--fh);font-size:.72rem;font-weight:500;
  letter-spacing:.15em;text-transform:uppercase;
  padding:.9rem 2rem;border:1.5px solid rgba(255,255,255,.22);border-radius:1px;
  transition:border-color .3s,color .3s;
}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}

.btn-gold-outline{
  display:inline-flex;align-items:center;gap:.8rem;
  background:transparent;color:var(--gold);
  font-family:var(--fh);font-size:.72rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  padding:.9rem 2.25rem;border:1.5px solid var(--gold);border-radius:1px;
  transition:background .3s,color .3s,gap .3s;
}
.btn-gold-outline svg{width:16px;height:16px;flex-shrink:0;transition:transform .3s}
.btn-gold-outline:hover{background:var(--gold);color:var(--ink);gap:1.3rem}
.btn-gold-outline:hover svg{transform:translateX(5px)}

.btn-outline{
  display:inline-block;background:transparent;color:var(--ink);
  font-family:var(--fh);font-size:.72rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  padding:.85rem 2.5rem;border:1.5px solid var(--ink);border-radius:1px;
  transition:background .3s,color .3s;
}
.btn-outline:hover{background:var(--ink);color:var(--cream)}

.btn-whatsapp{
  display:inline-flex;align-items:center;gap:.55rem;
  background:#25D366;color:#fff;
  font-family:var(--fh);font-size:.72rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;
  padding:.9rem 2rem;border:2px solid #25D366;border-radius:1px;
  transition:background .3s,transform .2s;
}
.btn-whatsapp svg{width:18px;height:18px}
.btn-whatsapp:hover{background:#1ebf5d;transform:translateY(-2px)}

.btn-mail{
  display:inline-flex;align-items:center;
  color:rgba(255,255,255,.5);
  font-family:var(--fh);font-size:.72rem;font-weight:400;
  letter-spacing:.14em;text-transform:uppercase;
  padding:.9rem 1.75rem;border:1.5px solid rgba(255,255,255,.16);border-radius:1px;
  transition:color .3s,border-color .3s;
}
.btn-mail:hover{color:var(--gold);border-color:var(--gold)}

.text-link{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--fh);font-size:.7rem;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;color:var(--gold);
  transition:gap .3s;
}
.text-link svg{width:15px;height:15px;transition:transform .3s}
.text-link:hover{gap:1rem}
.text-link:hover svg{transform:translateX(4px)}

/* ════════════════════════════════════════════════════
   NAVBAR  — Cormorant Garamond italic for premium feel
   IMPORTANT: .scrolled is ALWAYS applied on non-hero pages
   for hero pages it's added by JS on scroll
════════════════════════════════════════════════════ */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:1.2rem 0;
  transition:background .4s,padding .35s;
}
/* Default dark bg so text is always visible */
.navbar{background:rgba(8,8,8,.0)}
.navbar.scrolled{
  background:rgba(8,8,8,.97) !important;
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  padding:.75rem 0;
  box-shadow:0 1px 0 rgba(200,169,110,.1);
}
/* On pages that don't have a dark hero, force always dark */
.navbar.always-dark{
  background:rgba(8,8,8,.97) !important;
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
}

.nav-wrap{
  max-width:1280px;margin:0 auto;padding:0 2.5rem;
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
}

/* Logo */
.nav-logo img{
  height:30px;width:auto;object-fit:contain;
  filter:invert(1) brightness(2);
  transition:height .35s;
}
.navbar.scrolled .nav-logo img{height:26px}

/* Nav links  — Cormorant Garamond italic for ultimate luxury */
.nav-menu{display:flex;align-items:center;gap:0;list-style:none}
.nav-link{
  font-family:var(--fs);           /* Cormorant Garamond */
  font-size:.95rem;
  font-weight:500;
  font-style:italic;
  letter-spacing:.05em;
  color:rgba(255,255,255,.65);
  padding:.5rem 1.1rem;
  transition:color .25s;
  position:relative;white-space:nowrap;
}
.nav-link::after{
  content:'';
  position:absolute;bottom:0;left:1.1rem;right:1.1rem;
  height:1px;background:var(--gold);
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.nav-link:hover,.nav-link.active{color:#fff}
.nav-link:hover::after,.nav-link.active::after{transform:scaleX(1)}

.drop-arrow{width:10px;height:7px;margin-left:3px;vertical-align:middle;transition:transform .3s}
.has-drop:hover .drop-arrow{transform:rotate(180deg)}

/* Mega dropdown */
.has-drop{position:relative}
.dropdown{
  display:none;
  position:absolute;top:calc(100% + 14px);left:50%;
  transform:translateX(-50%);min-width:700px;
  background:rgba(8,8,8,.98);
  border:1px solid rgba(200,169,110,.15);border-radius:2px;
  padding:2rem;
  grid-template-columns:1fr 1fr 200px;gap:2rem;
  box-shadow:0 24px 64px rgba(0,0,0,.5);
}
.has-drop:hover .dropdown{display:grid}
.drop-head{
  font-family:var(--fh);font-size:.65rem;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);margin-bottom:1rem;
  padding-bottom:.6rem;border-bottom:1px solid rgba(200,169,110,.2);
}
.drop-link{
  display:flex;align-items:flex-start;gap:.75rem;
  padding:.55rem 0;border-bottom:1px solid rgba(255,255,255,.04);
  transition:opacity .2s;
}
.drop-link:last-child{border-bottom:none}
.dl-icon{color:var(--gold);font-size:.6rem;margin-top:4px;flex-shrink:0;opacity:.7}
.drop-link span:not(.dl-icon){flex:1}
.drop-link strong{
  display:block;font-family:var(--fs);font-size:.85rem;
  font-weight:500;color:rgba(255,255,255,.82);
  transition:color .2s;line-height:1.3;
}
.drop-link em{
  display:block;font-family:var(--fb);font-size:.68rem;
  color:rgba(255,255,255,.3);font-style:normal;margin-top:.1rem;
}
.drop-link:hover strong{color:var(--gold)}
.drop-feature{position:relative;border-radius:2px;overflow:hidden;min-height:180px}
.drop-feature img{width:100%;height:100%;object-fit:cover;object-position:center top}
.df-caption{
  position:absolute;bottom:0;left:0;right:0;
  padding:.75rem 1rem;
  background:linear-gradient(to top,rgba(5,5,5,.9),transparent);
}
.df-caption span{
  font-family:var(--fb);font-size:.55rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold);
}
.df-caption p{
  font-family:var(--fs);font-size:.78rem;
  color:rgba(255,255,255,.82);font-style:italic;margin-top:.15rem;
}

/* Nav CTA */
.nav-btn{
  display:inline-flex;align-items:center;
  font-family:var(--fh);font-size:.7rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink);background:var(--gold);
  padding:.52rem 1.5rem;border-radius:1px;margin-left:1rem;
  transition:background .25s,transform .2s;white-space:nowrap;
}
.nav-btn:hover{background:var(--gold-2);transform:translateY(-1px)}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;padding:4px;cursor:pointer}
.hamburger span{display:block;width:22px;height:1.5px;background:#fff;transition:transform .3s,opacity .3s}

/* ════════════════════════════════════════════════════
   HERO
════════════════════════════════════════════════════ */
.hero{
  position:relative;height:100vh;min-height:680px;
  display:flex;flex-direction:column;justify-content:center;overflow:hidden;
}
.hero-bg{position:absolute;inset:0;background:var(--ink)}
.hero-bg img{
  opacity:.46;object-position:center 35%;
  transform:scale(1.06);animation:hZoom 10s var(--ease) forwards;
}
@keyframes hZoom{to{transform:scale(1)}}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(130deg,rgba(4,4,4,.93) 0%,rgba(4,4,4,.6) 45%,rgba(4,4,4,.22) 100%);
}
.hero-lines{
  position:absolute;inset:0;
  display:flex;justify-content:space-between;padding:0 5rem;
  pointer-events:none;overflow:hidden;
}
.hero-lines span{
  width:1px;
  background:linear-gradient(to bottom,transparent,rgba(200,169,110,.1),transparent);
  transform-origin:top;transform:scaleY(0);opacity:0;
  animation:lDown 2s var(--ease) forwards;
}
.hero-lines span:nth-child(1){animation-delay:.1s}
.hero-lines span:nth-child(2){animation-delay:.25s}
.hero-lines span:nth-child(3){animation-delay:.4s}
.hero-lines span:nth-child(4){animation-delay:.55s}
.hero-lines span:nth-child(5){animation-delay:.7s}
@keyframes lDown{to{transform:scaleY(1);opacity:1}}

.hero-content{
  position:relative;z-index:2;
  max-width:1280px;margin:0 auto;
  padding:0 2.5rem;padding-top:5.5rem;
}
.hero-eyebrow{
  font-family:var(--fs);font-size:.78rem;font-weight:400;font-style:italic;
  letter-spacing:.2em;color:var(--gold);margin-bottom:1.1rem;
}
.hero-h1{
  font-family:var(--fh);           /* Cinzel — supreme architectural presence */
  font-size:clamp(3.8rem,8.5vw,7.5rem);
  font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;line-height:.95;
  margin-bottom:1.6rem;overflow:hidden;
}
.hl{display:block;color:#fff;transform:translateY(110%);animation:lUp .95s var(--ease) forwards}
.hl:nth-child(2){animation-delay:.12s}
.hl.gold{color:var(--gold) !important}
@keyframes lUp{to{transform:translateY(0)}}

.hero-sub{
  font-family:var(--fb);font-size:.95rem;font-weight:300;
  color:rgba(255,255,255,.52);max-width:520px;line-height:1.85;margin-bottom:2.2rem;
}
.br-d{display:inline}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}

/* Certifications band */
.hero-certs{
  position:absolute;bottom:0;left:0;right:0;z-index:2;
  display:flex;align-items:center;justify-content:center;
  background:rgba(8,8,8,.92);backdrop-filter:blur(14px);
  border-top:1px solid rgba(200,169,110,.14);padding:1.4rem 2rem;
}
.cert-item{display:flex;align-items:center;gap:.9rem;padding:0 2.75rem}
.cert-item svg{width:26px;height:26px;color:var(--gold);flex-shrink:0}
.cert-item strong{
  display:block;font-family:var(--fh);font-size:.82rem;font-weight:600;
  letter-spacing:.1em;color:#fff;line-height:1;
}
.cert-item span{
  font-family:var(--fb);font-size:.55rem;font-weight:400;
  letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.3);
  margin-top:.25rem;display:block;
}
.cert-sep{width:1px;height:40px;background:rgba(255,255,255,.1)}

/* Scroll wheel */
.scroll-hint{position:absolute;right:2.5rem;bottom:5.5rem;z-index:2}
.scroll-wheel{width:22px;height:38px;border:1.5px solid rgba(200,169,110,.4);border-radius:20px;position:relative}
.scroll-wheel::after{
  content:'';width:3px;height:8px;background:var(--gold);border-radius:2px;
  position:absolute;top:6px;left:50%;transform:translateX(-50%);
  animation:sWheel 1.8s ease-in-out infinite;
}
@keyframes sWheel{0%{opacity:1;top:6px}55%{opacity:0;top:22px}100%{opacity:0;top:6px}}
.hide-sm{display:inline}

/* ════════════════════════════════════════════════════
   MARQUEE
════════════════════════════════════════════════════ */
.marquee-band{
  background:var(--ink-3);overflow:hidden;
  border-top:1px solid rgba(200,169,110,.12);
  border-bottom:1px solid rgba(200,169,110,.12);padding:.95rem 0;
}
.marquee-inner{display:flex;align-items:center;white-space:nowrap;animation:marq 30s linear infinite}
@keyframes marq{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.marquee-inner span{
  font-family:var(--fs);font-size:.98rem;font-style:italic;
  color:rgba(255,255,255,.38);padding:0 1.75rem;transition:color .25s;
}
.marquee-inner span:hover{color:var(--gold)}
.marquee-inner em{color:var(--gold);font-style:normal;font-size:.55rem;opacity:.65}

/* ════════════════════════════════════════════════════
   INTRO SECTION
════════════════════════════════════════════════════ */
.intro-section{background:var(--cream-2);padding:6rem 0;border-bottom:1px solid var(--cream-3)}
.intro-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:6rem;align-items:start}
.intro-left .sec-h2{margin-bottom:0}
.intro-right p{
  font-family:var(--fb);font-size:.88rem;color:var(--steel);line-height:1.9;margin-bottom:1.25rem;
}

/* ════════════════════════════════════════════════════
   RAILING SECTION
════════════════════════════════════════════════════ */
.railing-section{background:var(--cream-2)}
.railing-header{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:end;margin-bottom:3.5rem}
.railing-header .sec-h2{margin-bottom:0}
.railing-intro{font-family:var(--fb);font-size:.88rem;color:var(--steel);line-height:1.9}

/* Finish cards */
.finish-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5px;background:var(--cream-3);border:1.5px solid var(--cream-3);margin-bottom:2.5rem}
.finish-card{background:var(--cream-2);padding:2rem 1.5rem;transition:background .3s;position:relative;overflow:hidden}
.finish-card::before{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.finish-card:hover{background:var(--cream)}
.finish-card:hover::before{transform:scaleX(1)}
.finish-card.highlight{background:var(--cream)}
.fc-swatch{width:100%;height:48px;border-radius:2px;margin-bottom:1.25rem}
.fc-swatch.satin{background:linear-gradient(135deg,#c0c0c0,#d8d8d8,#a8a8a8,#d0d0d0)}
.fc-swatch.mirror{background:linear-gradient(135deg,#e8e8e8,#f5f5f5,#d0d0d0,#f0f0f0)}
.fc-swatch.powder{background:linear-gradient(135deg,#2c4a2c,#4a7a4a,#1a3a6a,#c8a96e,#8b1a1a)}
.fc-swatch.pvd{background:linear-gradient(135deg,var(--gold-3),var(--gold),var(--gold-2),var(--gold))}
.fc-info h4{font-family:var(--fh);font-size:.88rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);margin-bottom:.5rem}
.fc-info p{font-family:var(--fb);font-size:.78rem;color:var(--steel);line-height:1.75}
.fc-badge{display:inline-block;font-family:var(--fb);font-size:.58rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-3);border:1px solid rgba(200,169,110,.4);border-radius:1px;padding:.2rem .65rem;margin-top:.75rem}

/* Railing tiles */
.railing-tiles{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:260px 260px;gap:3px;margin-bottom:3rem}
.rt{position:relative;overflow:hidden;background:var(--ink-3);cursor:pointer}
.rt img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.rt:hover img{transform:scale(1.08)}
.rt-info{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:1.5rem;background:linear-gradient(to top,rgba(4,4,4,.88) 0%,rgba(4,4,4,.3) 55%,transparent 100%)}
.rt-info span{font-family:var(--fb);font-size:.55rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:.3rem}
.rt-info h3{font-family:var(--fh);font-size:1rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#fff;transform:translateY(5px);transition:transform .4s}
.rt:hover .rt-info h3{transform:translateY(0)}
.section-cta{text-align:center;margin-top:.5rem}

/* ════════════════════════════════════════════════════
   PARTITION SECTION — SPLIT SCREEN
════════════════════════════════════════════════════ */
.partition-section{display:grid;grid-template-columns:1fr 1fr;min-height:100vh}
.partition-left{position:sticky;top:0;height:100vh;overflow:hidden}
.pl-img-wrap{position:relative;width:100%;height:100%}
.pl-img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .8s var(--ease)}
.partition-left:hover .pl-img{transform:scale(1.03)}
.pl-tag{position:absolute;bottom:2.5rem;left:2.5rem;background:rgba(8,8,8,.85);border:1px solid rgba(200,169,110,.25);padding:.75rem 1.25rem;backdrop-filter:blur(8px)}
.pl-tag span{display:block;font-family:var(--fs);font-size:.88rem;font-style:italic;color:#fff;margin-bottom:.15rem}
.pl-tag em{font-family:var(--fb);font-size:.6rem;font-style:normal;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.partition-right{background:var(--ink);display:flex;align-items:center}
.pr-inner{padding:5rem 4.5rem;max-width:620px}
.pr-desc{font-family:var(--fb);font-size:.88rem;color:rgba(255,255,255,.48);line-height:1.9;margin-bottom:2.5rem}
.pr-list{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2.5rem}
.prl-item{display:flex;gap:1.25rem;align-items:flex-start;padding-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.06)}
.prl-item:last-child{border-bottom:none;padding-bottom:0}
.prl-num{font-family:var(--fs);font-size:.9rem;font-style:italic;color:var(--gold);opacity:.6;flex-shrink:0;min-width:28px;margin-top:2px}
.prl-item strong{display:block;font-family:var(--fs);font-size:.95rem;font-weight:600;font-style:italic;color:rgba(255,255,255,.85);margin-bottom:.3rem}
.prl-item p{font-family:var(--fb);font-size:.78rem;color:rgba(255,255,255,.38);line-height:1.7}
.pr-types{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:2.5rem}
.pr-types span{font-family:var(--fb);font-size:.62rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.42);border:1px solid rgba(200,169,110,.18);border-radius:1px;padding:.3rem .85rem;transition:color .2s,border-color .2s}
.pr-types span:hover{color:var(--gold);border-color:var(--gold)}

/* ════════════════════════════════════════════════════
   PILLARS
════════════════════════════════════════════════════ */
.pillars-section{background:var(--cream-2)}
.pillars-header{display:grid;grid-template-columns:1fr 1.4fr;gap:4rem;align-items:end;margin-bottom:4rem}
.pillars-header .sec-h2{margin-bottom:0}
.pillars-intro{font-family:var(--fb);font-size:.88rem;color:var(--steel);line-height:1.9}
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5px;background:var(--cream-3);border:1.5px solid var(--cream-3)}
.pillar{background:var(--cream-2);padding:2.75rem 2rem;position:relative;overflow:hidden;transition:background .3s}
.pillar::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.pillar:hover{background:var(--cream)}
.pillar:hover::after{transform:scaleX(1)}
.pillar-icon{width:44px;height:44px;color:var(--gold);margin-bottom:1.25rem}
.pillar-icon svg{width:100%;height:100%}
.pillar h3{font-family:var(--fh);font-size:.9rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);margin-bottom:.6rem}
.pillar p{font-family:var(--fb);font-size:.8rem;color:var(--steel);line-height:1.8}

/* ════════════════════════════════════════════════════
   GALLERY
════════════════════════════════════════════════════ */
.gallery-section{background:var(--cream)}
.gallery-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:3rem}
.gallery-header .sec-h2{margin-bottom:0}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:280px 280px;gap:3px}
.gbox{position:relative;overflow:hidden;background:var(--ink-3);cursor:zoom-in}
.gbox.tall{grid-row:span 2}
.gbox.wide{grid-column:span 2}
.gbox img{width:100%;height:100%;object-fit:cover;transition:transform .75s var(--ease)}
.gbox:hover img{transform:scale(1.07)}
.gbox-cap{position:absolute;left:0;right:0;bottom:0;padding:2rem 1.4rem .9rem;background:linear-gradient(to top,rgba(4,4,4,.88),transparent);transform:translateY(100%);transition:transform .38s var(--ease)}
.gbox:hover .gbox-cap{transform:translateY(0)}
.gbox-cap span{font-family:var(--fs);font-size:.78rem;font-style:italic;color:rgba(255,255,255,.78)}

/* ════════════════════════════════════════════════════
   PROCESS
════════════════════════════════════════════════════ */
.process-section{background:var(--ink);padding:7rem 0}
.process-header{text-align:center;margin-bottom:4.5rem}
.process-steps{display:flex;align-items:flex-start;justify-content:center}
.ps{flex:1;padding:0 2.5rem;text-align:center;border-left:1px solid rgba(200,169,110,.12)}
.ps:first-child{border-left:none}
.ps-num{font-family:var(--fs);font-size:2.2rem;font-weight:400;font-style:italic;color:var(--gold);opacity:.4;line-height:1;margin-bottom:.75rem}
.ps h4{font-family:var(--fh);font-size:.88rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin-bottom:.6rem}
.ps p{font-family:var(--fb);font-size:.8rem;color:rgba(255,255,255,.38);line-height:1.8}

/* ════════════════════════════════════════════════════
   CTA
════════════════════════════════════════════════════ */
.cta-section{position:relative;padding:9rem 0;overflow:hidden;background:var(--ink)}
.cta-bg{position:absolute;inset:0;background:var(--ink)}
.cta-bg img{opacity:.12;object-position:center 40%}
.cta-veil{position:absolute;inset:0;background:linear-gradient(140deg,rgba(4,4,4,.98),rgba(4,4,4,.88))}
.cta-body{position:relative;z-index:2;text-align:center}
.cta-tag{display:inline-block;font-family:var(--fs);font-size:.72rem;font-style:italic;letter-spacing:.18em;color:var(--gold);margin-bottom:.9rem}
.cta-h2{font-family:var(--fh);font-size:clamp(2.2rem,5vw,4rem);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#fff;line-height:1.0;margin-bottom:1.1rem}
.cta-h2 em{font-style:normal;color:var(--gold)}
.cta-desc{font-family:var(--fb);font-size:.88rem;color:rgba(255,255,255,.36);max-width:560px;margin:0 auto 2.5rem;line-height:1.85}
.cta-btns{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:1rem;margin-bottom:2.2rem}
.cta-addr{font-family:var(--fb);font-size:.68rem;letter-spacing:.06em;color:rgba(255,255,255,.2)}

/* ════════════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════════════ */
.footer{background:#070707;padding-top:5.5rem}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:2.5rem;padding-bottom:4rem;border-bottom:1px solid rgba(255,255,255,.05)}
.fg-logo{height:28px;width:auto;object-fit:contain;filter:invert(1) brightness(1.5);margin-bottom:1.3rem}
.fg-brand>p{font-family:var(--fb);font-size:.8rem;color:rgba(255,255,255,.28);line-height:1.85;max-width:260px;margin-bottom:1.5rem}
.fg-social{display:flex;gap:.65rem}
.fg-social a{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid rgba(255,255,255,.1);border-radius:50%;color:rgba(255,255,255,.35);transition:border-color .2s,color .2s,background .2s}
.fg-social a svg{width:14px;height:14px}
.fg-social a:hover{border-color:var(--gold);color:var(--gold);background:rgba(200,169,110,.06)}
.fg-col h4{font-family:var(--fh);font-size:.65rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:1.1rem}
.fg-col a{display:block;font-family:var(--fb);font-size:.78rem;color:rgba(255,255,255,.3);margin-bottom:.5rem;transition:color .2s}
.fg-col a:hover{color:rgba(255,255,255,.78)}
.footer-bar{padding:1.25rem 0}
.footer-bar-inner{display:flex;justify-content:space-between;align-items:center}
.footer-bar-inner span{font-family:var(--fb);font-size:.68rem;color:rgba(255,255,255,.15)}

/* ── LIGHTBOX ───────────────────────────────────── */
.lightbox{display:none;position:fixed;inset:0;z-index:9990;background:rgba(0,0,0,.95);align-items:center;justify-content:center;cursor:zoom-out}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:90vh;width:auto;height:auto;object-fit:contain}
.lb-close{position:absolute;top:1.5rem;right:2rem;font-size:2.5rem;color:rgba(255,255,255,.38);line-height:1;transition:color .2s}
.lb-close:hover{color:#fff}

/* ════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════ */
@media(max-width:1200px){
  .partition-section{grid-template-columns:1fr;min-height:auto}
  .partition-left{position:relative;height:60vh}
  .partition-right{display:block}
  .pr-inner{padding:4rem 2.5rem;max-width:100%}
  .footer-grid{grid-template-columns:1fr 1fr 1fr;row-gap:2.5rem}
}
@media(max-width:1024px){
  .intro-grid,.railing-header,.pillars-header{grid-template-columns:1fr}
  .finish-grid{grid-template-columns:1fr 1fr}
  .railing-tiles{grid-template-columns:1fr 1fr;grid-template-rows:240px 240px 240px}
  .pillars-grid{grid-template-columns:repeat(2,1fr)}
  .dropdown{min-width:500px;grid-template-columns:1fr 1fr}
  .drop-feature{display:none}
  .process-steps{flex-direction:column;gap:2rem;align-items:stretch}
  .ps{border-left:none;border-top:1px solid rgba(200,169,110,.12);padding:2rem 0 0}
  .ps:first-child{border-top:none;padding-top:0}
}
@media(max-width:768px){
  .section{padding:5rem 0}
  .container{padding:0 1.5rem}
  .hamburger{display:flex}
  .nav-menu{position:fixed;top:0;right:-100%;width:82vw;max-width:320px;height:100vh;background:rgba(7,7,7,.99);flex-direction:column;align-items:flex-start;gap:0;padding:5.5rem 2rem 2rem;transition:right .4s var(--ease);overflow-y:auto}
  .nav-menu.open{right:0}
  .nav-menu li{width:100%;border-bottom:1px solid rgba(255,255,255,.05)}
  .nav-link{display:block;padding:.85rem 0;font-size:.95rem}
  .dropdown{display:none !important;position:static;grid-template-columns:1fr;min-width:0;border:none;padding:.5rem 0 .5rem 1rem;background:rgba(255,255,255,.03);box-shadow:none}
  .has-drop.open .dropdown{display:flex !important;flex-direction:column}
  .nav-btn{margin:1rem 0 0;display:block;text-align:center}
  .hero-h1{font-size:clamp(3rem,12vw,4.5rem)}
  .hero-sub{font-size:.86rem}
  .br-d{display:none}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .hero-certs{flex-wrap:wrap;padding:.75rem 1rem}
  .cert-item{padding:.6rem 1.25rem}
  .cert-sep{display:none}
  .scroll-hint{display:none}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:190px 190px 190px}
  .gbox.tall{grid-row:span 2}
  .gbox.wide{grid-column:span 2}
  .pillars-grid{grid-template-columns:1fr}
  .finish-grid{grid-template-columns:1fr}
  .railing-tiles{grid-template-columns:1fr;grid-template-rows:repeat(6,240px)}
  .gallery-header{flex-direction:column;align-items:flex-start;gap:1.25rem}
  .footer-grid{grid-template-columns:1fr}
  .footer-bar-inner{flex-direction:column;gap:.5rem;text-align:center}
  .cta-btns{flex-direction:column;align-items:center}
}
@media(max-width:480px){
  .hero-h1{font-size:clamp(2.5rem,13vw,3.5rem)}
  .gallery-grid{grid-template-columns:1fr;grid-template-rows:repeat(6,220px)}
  .gbox.tall,.gbox.wide{grid-row:span 1;grid-column:span 1}
}
