
/* ═══════════════════════════════════════════
   DESIGN TOKENS
═══════════════════════════════════════════ */
:root {
  /* BRAND COLORS FROM LOGO */
  --navy:     #574498; /* New brand Purple/Indigo */
  --red:      #da2327; /* New brand Red */
  --red-lt:   #e64a4d; /* Lighter tint of Red */
  --navy-dk:  #2d2054; /* Midnight Purple */

  /* UPDATED SYSTEM COLORS */
  --espresso: var(--navy);    /* Redirecting old espresso to Navy */
  --gold:     var(--red);     /* Redirecting old Gold to Red */
  --gold-lt:  var(--red-lt); 
  --gold-dk:  #b01518;

  /* COOL NEUTRALS (to match the Blue/Red palette) */
  --ivory:    #F8FAFC; 
  --cream:    #F1F5F9;
  --linen:    #E2E8F0;
  --sand:     #B0BCCB; /* Darker sand for borders */
  --taupe:    rgba(45, 32, 84, 0.72); /* Midnight-purple based secondary text */
  --umber:    rgba(45, 32, 84, 0.92);  /* Midnight-purple based strong body text */
  
  /* TYPOGRAPHY remains same for luxury feel */
  --serif:    'Lora', Georgia, serif;
  --caps:     'Cormorant SC', Georgia, serif;
  --sans:     'Outfit', sans-serif;

  /* MOTION */
  --ease:     cubic-bezier(.22,.68,0,1.2);
  --ease-out: cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--ivory);color:var(--espresso);font-family:var(--sans);font-weight:300;overflow-x:hidden;-webkit-font-smoothing:antialiased;cursor:none}
img{display:block;width:100%;height:100%;object-fit:cover}
a{text-decoration:none;color:inherit}
button{font-family:var(--sans)}

/* ═══════════════════════════════════════════
   GRAIN OVERLAY (luxury texture)
═══════════════════════════════════════════ */
body::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:9998;
  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='1'/%3E%3C/svg%3E");
  opacity:.028;
}

/* ═══════════════════════════════════════════
   CUSTOM CURSOR
═══════════════════════════════════════════ */
#cur{position:fixed;top:0;left:0;pointer-events:none;z-index:9997;transition:none}
#cur .outer{
  width:40px;height:40px;border:1px solid var(--gold);border-radius:50%;
  transform:translate(-50%,-50%);
  transition:width .4s var(--ease-out),height .4s var(--ease-out),background .4s,border-color .3s,opacity .3s;
}
#cur .inner{
  width:6px;height:6px;background:var(--gold);border-radius:50%;
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  transition:width .3s,height .3s,opacity .3s;
}
#cur.link .outer{width:64px;height:64px;background:rgba(196,162,101,.1);border-color:var(--gold-dk)}
#cur.link .inner{width:3px;height:3px}
#cur.hidden .outer{opacity:0}

/* ═══════════════════════════════════════════
   PAGE LOADER
═══════════════════════════════════════════ */
#loader{
  position:fixed;inset:0;z-index:9000;background:var(--espresso);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2rem;transition:opacity .8s var(--ease-out),visibility .8s;
}
#loader.gone{opacity:0;visibility:hidden;pointer-events:none}
.loader-logo{
  font-family:var(--serif);font-size:2.4rem;font-weight:400;
  color:var(--ivory);letter-spacing:.12em;opacity:0;
  animation:logoIn 1.2s var(--ease-out) .3s forwards;
}
.loader-logo span{color:var(--gold)}
.loader-sub{
  font-size:.58rem;letter-spacing:.45em;text-transform:uppercase;
  color:rgba(255,255,255,.35);opacity:0;
  animation:logoIn .8s var(--ease-out) 1s forwards;
}
.loader-bar{
  width:160px;height:1px;background:rgba(255,255,255,.1);
  position:relative;overflow:hidden;
}
.loader-bar::after{
  content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:var(--gold);animation:barFill 1.8s var(--ease-out) .2s forwards;
}
@keyframes logoIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes barFill{from{left:-100%}to{left:100%}}

/* ═══════════════════════════════════════════
   NAV
═══════════════════════════════════════════ */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:800;
  height:88px;padding:0 5vw;
  display:flex;align-items:center;justify-content:space-between;
  transition:height .5s var(--ease-out),background .5s,border-color .5s;
  background:rgba(250,250,247,.95);backdrop-filter:blur(20px);
  border-bottom:1px solid var(--linen);
}
#nav.solid{
  height:68px;
}
.nav-brand{display:flex;align-items:center;gap:.8rem;line-height:1;cursor:pointer}
.nav-logo-icon{
  height:68px;
  width:auto;
  object-fit:contain;
  display:block;
  transition:height .5s var(--ease-out);
}
#nav.solid .nav-logo-icon{
  height:52px;
}
.nav-brand-text{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
}
.nav-wordmark{
  font-family:var(--serif);font-size:1.5rem;font-weight:400;
  letter-spacing:.1em;color:var(--espresso);
}
.nav-wordmark em{font-style:normal;color:var(--gold)}
.nav-sub{
  font-size:.48rem;letter-spacing:.45em;text-transform:uppercase;
  color:var(--taupe);margin-top:3px;font-family:var(--caps);
}
.nav-menu{display:flex;gap:0;list-style:none}
.nav-menu li a{
  display:block;padding:.5rem 1.1rem;
  font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--umber);font-weight:400;
  position:relative;transition:color .3s;
  white-space:nowrap;
}
.nav-menu li a::after{
  content:'';position:absolute;bottom:0;left:1.1rem;right:1.1rem;
  height:2px;background:var(--red);transform:scaleX(0);
  transition:transform .35s var(--ease-out);transform-origin:left;
}
.nav-menu li a:hover{color:var(--gold-dk)}
.nav-menu li a:hover::after,.nav-menu li a.active::after{transform:scaleX(1)}
.nav-menu li a.active{color:var(--gold-dk)}

/* ── NAV SUBMENU DROPDOWN ── */
.nav-item-dropdown {
  position: relative;
}
.dropdown-trigger {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  white-space: nowrap;
}
.nav-arrow {
  font-size: 0.45rem;
  vertical-align: middle;
  display: inline-block;
  transition: transform 0.3s ease;
  opacity: 0.6;
  flex-shrink: 0;
}
.nav-item-dropdown:hover .nav-arrow {
  transform: rotate(180deg);
  color: var(--gold-dk);
}
.nav-submenu {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(10px);
  background: rgba(248, 250, 252, 0.96);
  backdrop-filter: blur(15px);
  -webkit-backdrop-filter: blur(15px);
  border: 1px solid rgba(226, 232, 240, 0.8);
  box-shadow: 0 10px 30px rgba(87, 68, 152, 0.08);
  padding: 0.8rem 0;
  list-style: none;
  border-radius: 8px;
  min-width: 170px;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  z-index: 1000;
}
.nav-item-dropdown:hover .nav-submenu {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}
#nav .nav-menu .nav-submenu li a {
  display: block;
  padding: 0.6rem 1.5rem;
  font-size: 0.58rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--umber);
  font-weight: 400;
  transition: all 0.3s;
  white-space: nowrap;
  text-align: left;
}
#nav .nav-menu .nav-submenu li a::after {
  display: none;
}
#nav .nav-menu .nav-submenu li a:hover {
  color: var(--gold-dk);
  background: rgba(87, 68, 152, 0.02);
}
.nav-actions{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:0.45rem;
  transition: gap 0.5s var(--ease-out);
}
#nav.solid .nav-actions{
  gap:0.25rem;
}
.nav-socials{
  display:flex;
  align-items:center;
  gap:1rem;
}
.nav-soc-link{
  color:var(--espresso);
  opacity:0.65;
  transition:all .3s var(--ease-out);
  display:flex;
  align-items:center;
  justify-content:center;
}
.nav-soc-link:hover{
  opacity:1;
  color:var(--gold);
  transform:translateY(-2px);
}
.nav-consult{
  font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;
  font-weight:500;padding:.7rem 1.8rem;
  border:1px solid var(--espresso);color:var(--espresso);
  transition:all .35s var(--ease-out);position:relative;overflow:hidden;
}
.nav-consult::before{
  content:'';position:absolute;inset:0;background:var(--espresso);
  transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease-out);z-index:0;
}
.nav-consult span{position:relative;z-index:1;transition:color .35s}
.nav-consult:hover span{color:var(--ivory)}
.nav-consult:hover::before{transform:scaleX(1)}
#nav.solid .nav-consult{
  padding:.45rem 1.4rem;
}
.nav-burger{display:none;flex-direction:column;gap:6px;background:none;border:none;padding:4px;cursor:none}
.nav-burger span{display:block;width:26px;height:1px;background:var(--espresso);transition:all .3s}


/* ═══════════════════════════════════════════
   SPA ROUTER
═══════════════════════════════════════════ */
.page{display:none;min-height:100vh;padding-top:88px}
.page.active{display:block}

/* ═══════════════════════════════════════════
   SHARED COMPONENTS
═══════════════════════════════════════════ */
.label{
  display:inline-flex;align-items:center;gap:1rem;
  font-size:.68rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--gold);font-weight:500;font-family:var(--caps);
}
.label::before{content:'';width:36px;height:1px;background:var(--gold)}
.d1{
  font-family:var(--serif);font-size:clamp(2.8rem,4.5vw,5rem);
  font-weight:400;line-height:1.06;letter-spacing:-.02em;
}
.d2{
  font-family:var(--serif);font-size:clamp(2.2rem,3.5vw,3.8rem);
  font-weight:400;line-height:1.1;letter-spacing:-.02em;
}
.d3{
  font-family:var(--serif);font-size:clamp(1.6rem,2.5vw,2.6rem);
  font-weight:400;line-height:1.15;letter-spacing:-.01em;
}
.d1 em,.d2 em,.d3 em{font-style:italic;color:var(--gold)}
.body{font-size:.9rem;line-height:1.95;color:var(--taupe);font-weight:300}
.body strong{color:var(--umber);font-weight:500}
.rule{width:50px;height:1px;background:var(--gold);margin:2rem 0}
.wrap{max-width:1440px;margin:0 auto;padding:0 5vw}
.section{padding:9rem 0}
.section-sm{padding:5rem 0}

/* BUTTONS */
.btn-dark{
  display:inline-flex;align-items:center;gap:1rem;
  background:var(--espresso);color:var(--ivory);
  padding:.95rem 2.4rem;font-size:.62rem;letter-spacing:.22em;
  text-transform:uppercase;font-weight:500;
  position:relative;overflow:hidden;transition:gap .3s;
}
.btn-dark::before{
  content:'';position:absolute;inset:0;background:var(--gold-dk);
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s var(--ease-out);
}
.btn-dark span{position:relative;z-index:1}
.btn-dark:hover::before{transform:scaleX(1)}
.btn-dark:hover{gap:1.5rem}
.btn-dark .arr{position:relative;z-index:1;transition:transform .3s}
.btn-dark:hover .arr{transform:translateX(4px)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:.8rem;
  color:var(--espresso);padding:.9rem 0;
  font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;font-weight:400;
  border-bottom:1px solid var(--sand);transition:all .3s;
}
.btn-ghost:hover{color:var(--gold);border-color:var(--gold);gap:1.2rem}
.btn-ghost .arr{transition:transform .3s}
.btn-ghost:hover .arr{transform:translateX(4px)}

.btn-outline{
  display:inline-flex;align-items:center;gap:.8rem;
  border:1px solid var(--espresso);color:var(--espresso);
  padding:.85rem 2rem;font-size:.62rem;letter-spacing:.22em;
  text-transform:uppercase;font-weight:400;transition:all .3s;
}
.btn-outline:hover{background:var(--espresso);color:var(--ivory)}

/* REVEAL ANIMATIONS */
.rv{opacity:0;transform:translateY(36px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.rv.show{opacity:1;transform:none}
.rv-l{opacity:0;transform:translateX(-36px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.rv-l.show{opacity:1;transform:none}
.rv-r{opacity:0;transform:translateX(36px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.rv-r.show{opacity:1;transform:none}
.d1s{transition-delay:.1s}.d2s{transition-delay:.2s}.d3s{transition-delay:.3s}.d4s{transition-delay:.4s}.d5s{transition-delay:.5s}

/* MARQUEE */
.mq-strip{background:var(--espresso);padding:.9rem 0;overflow:hidden}
.mq-inner{display:flex;align-items:center;white-space:nowrap;animation:mq 32s linear infinite}
.mq-inner:hover{animation-play-state:paused}
.mqi{font-family:var(--serif);font-style:italic;font-size:.95rem;font-weight:300;color:var(--ivory);padding:0 2rem;flex-shrink:0}
.mq-sep{color:rgba(255,255,255,.18);font-size:.55rem;display:inline-block;padding:0 .3rem;opacity:0.5;line-height:1}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══════════════════════════════════════════
   HOME PAGE
═══════════════════════════════════════════ */
#pg-home{padding-top:0}

/* HERO */
.hero{height:100svh;position:relative;overflow:hidden;background:#000d1a;display:flex;align-items:center;justify-content:center}
.hero-video-bg{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;z-index:1;
  pointer-events:none;
}
.hero-overlay{
  position:absolute;inset:0;
  width:100%;height:100%;
  background:linear-gradient(to bottom, rgba(45, 32, 84, 0.50) 0%, rgba(45, 32, 84, 0.30) 60%, rgba(45, 32, 84, 0.15) 100%);
  z-index:2;pointer-events:none;
}

.hero-l{
  display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;
  padding:0 5vw;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;position:relative;z-index:3;
  max-width:1100px;width:100%;
}
.hero-num-bg{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:var(--serif);font-size:35vw;font-weight:400;
  color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.03);
  line-height:1;pointer-events:none;letter-spacing:-.04em;
  animation:heroNumIn 1.5s var(--ease-out) 2.2s both;
}
@keyframes heroNumIn{from{opacity:0;transform:translate(-50%,-50%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
.hero-label{
  display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:2.5rem;
  animation:fadeUp .8s var(--ease-out) 2s both;
}
.hero-label-line{width:44px;height:1px;background:#ffffff}
.hero-label-txt{font-size:.58rem;letter-spacing:.4em;text-transform:uppercase;color:#ffffff;font-family:var(--caps)}
.hero-h1{
  font-family:var(--serif);
  font-size:clamp(2rem,4.5vw,4.6rem);
  font-weight:400;line-height:1.15;letter-spacing:-.02em;
  color:var(--ivory);margin-bottom:2rem;
  animation:fadeUp .9s var(--ease-out) 2.1s both;
}
.hero-h1 em{font-style:italic;color:var(--gold)}
.hero-desc{
  font-size:.88rem;line-height:1.95;color:rgba(255, 255, 255, 0.7);
  max-width:580px;margin-bottom:3.5rem;
  margin-left:auto;margin-right:auto;
  animation:fadeUp .8s var(--ease-out) 2.25s both;
}
.hero-btns{
  display:flex;gap:2rem;align-items:center;justify-content:center;
  animation:fadeUp .8s var(--ease-out) 2.4s both;
}
.hero-scroll{
  position:absolute;bottom:5vh;right:2.5rem;
  display:flex;flex-direction:column;align-items:center;gap:1rem;
  animation:fadeUp .8s var(--ease-out) 2.6s both;
}
.hero-scroll-bar{width:1px;height:56px;background:rgba(255,255,255,0.2);position:relative;overflow:hidden}
.hero-scroll-bar::after{
  content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;
  background:var(--gold);animation:scrollBar 2.4s ease-in-out 2.8s infinite;
}
@keyframes scrollBar{0%{top:-100%}50%{top:0}100%{top:100%}}
.hero-scroll-txt{font-size:.5rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,0.5);writing-mode:vertical-rl}
.hero-r{position:absolute;bottom:5vh;left:2.5rem;z-index:3}

.hero-location{
  font-size:.5rem;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(255,255,255,.65);display:flex;align-items:center;gap:.8rem;
}
.hero-location::before{content:'';width:18px;height:1px;background:rgba(255,255,255,.3)}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* BRAND STRIP */
.brand-strip{background:var(--cream);padding:5rem 0;border-top:1px solid var(--linen)}
.brand-strip-inner{
  display:grid;grid-template-columns:1fr 2fr;gap:7rem;align-items:center;
}
.brand-quote-text{
  font-family:var(--serif);font-size:clamp(1.5rem,2.5vw,2.2rem);
  font-weight:400;line-height:1.35;color:var(--espresso);
  border-left:2px solid var(--gold);padding-left:2.5rem;
}
.brand-body p{font-size:.88rem;line-height:1.95;color:var(--taupe);margin-bottom:1.1rem}
.brand-body strong{color:var(--espresso);font-weight:500}

/* HOME PHILOSOPHY */
.home-phil{background:var(--ivory);overflow:hidden}
.home-phil-inner{display:grid;grid-template-columns:1fr 1fr;gap:10rem;align-items:center}
.phil-img-wrap{position:relative;height:680px;overflow:hidden}
.phil-img-wrap img{transition:transform 8s linear}
.phil-img-wrap:hover img{transform:scale(1.04)}
.phil-img-accent{
  position:absolute;bottom:-2rem;right:-2rem;
  width:200px;height:200px;
  border:1px solid var(--gold);opacity:.3;
}
.phil-img-accent2{
  position:absolute;top:-1rem;left:-1rem;
  width:120px;height:120px;
  background:var(--gold);opacity:.06;
}
.phil-items{display:flex;flex-direction:column;gap:0}
.phil-item{
  padding:2.5rem 0;
  border-bottom:1px solid var(--linen);
  display:grid;grid-template-columns:64px 1fr;gap:1.5rem;align-items:start;
  position:relative;
}
.phil-item::after{
  content:'';position:absolute;left:0;bottom:-1px;
  width:0;height:1px;background:var(--gold);
  transition:width .6s var(--ease-out);
}
.phil-item:hover::after{width:100%}
.pn{
  font-family:var(--serif);font-size:3.8rem;font-weight:300;
  color:var(--linen);line-height:1;transition:color .4s;
}
.phil-item:hover .pn{color:var(--gold-lt)}
.pt{font-family:var(--serif);font-size:1.15rem;font-weight:500;margin-bottom:.5rem;letter-spacing:.01em}
.pd{font-size:.82rem;line-height:1.88;color:var(--taupe)}

/* HOME SERVICES PREVIEW */
.home-svcs{background:var(--espresso)}
.home-svcs-inner{}
.svcs-header{
  display:grid;grid-template-columns:1fr 1fr;gap:4rem;
  align-items:end;padding-bottom:5rem;
}
.svc-label{color:var(--gold-lt)}.svc-label::before{background:var(--gold-lt)}
.svc-d2{color:var(--ivory)}.svc-d2 em{color:var(--gold-lt)}
.svc-intro{font-size:.88rem;line-height:1.9;color:rgba(255,255,255,.42);align-self:end;max-width:420px}
.svcs-strip{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid rgba(255,255,255,.07);
}
.svc-item{
  padding:3.5rem 2.5rem;
  border-right:1px solid rgba(255,255,255,.07);
  position:relative;overflow:hidden;transition:background .4s;
}
.svc-item:last-child{border-right:none}
.svc-item::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--gold);transform:scaleX(0);transform-origin:left;
  transition:transform .45s var(--ease-out);
}
.svc-item:hover{background:rgba(196,162,101,.06)}
.svc-item:hover::before{transform:scaleX(1)}
.svc-img{height:180px;margin:-3.5rem -2.5rem 2.5rem;overflow:hidden;position:relative}
.svc-img img{transition:transform .7s var(--ease-out)}
.svc-item:hover .svc-img img{transform:scale(1.06)}
.svc-img-fade{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 45%,var(--espresso))}
.svc-n{
  font-size:.68rem;letter-spacing:.35em;color:#ffa1a3;
  margin-bottom:1.2rem;font-family:var(--caps);
}
.svc-t{font-family:var(--serif);font-size:1.25rem;font-weight:400;color:var(--ivory);line-height:1.3;margin-bottom:.9rem}
.svc-d{font-size:.78rem;line-height:1.85;color:rgba(255,255,255,0.45)}
.svc-link{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;
  color:#ffa1a3;margin-top:1.8rem;transition:gap .3s;
}
.svc-link::after{content:'→';transition:transform .3s}
.svc-item:hover .svc-link{gap:1rem}

/* HOME UPVC SIGNATURE */
.upvc-sig{
  background:var(--linen);padding:0;
  display:grid;grid-template-columns:1fr 1fr;min-height:80vh;
}
.upvc-left{
  position:relative;overflow:hidden;
}
.upvc-left img{height:100%;min-height:600px}
.upvc-left-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(196,162,101,.15) 0%,transparent 60%);
}
.upvc-right{
  display:flex;flex-direction:column;justify-content:center;
  padding:7rem 7vw 7rem 5vw;background:var(--cream);
}
.upvc-features{
  display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:3rem;
}
.upvc-feat{
  padding:1.8rem;border:1px solid var(--linen);
  background:white;transition:border-color .3s,box-shadow .3s;
}
.upvc-feat:hover{border-color:var(--gold-lt);box-shadow:0 8px 32px rgba(196,162,101,.1)}
.uf-icon{
  width:32px;height:32px;margin-bottom:1rem;
  color:var(--gold);
}
.uf-t{font-family:var(--serif);font-size:1rem;font-weight:500;margin-bottom:.4rem}
.uf-d{font-size:.75rem;line-height:1.8;color:var(--taupe)}

/* HOME PROJECTS HORIZONTAL */
.home-proj{background:var(--ivory);overflow:hidden}
.proj-header{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:4rem;
}
.proj-scroll-track{
  display:flex;gap:2.5px;overflow-x:auto;padding-bottom:2rem;
  scroll-snap-type:x mandatory;
  scrollbar-width:thin;scrollbar-color:var(--gold) var(--linen);
}
.proj-scroll-track::-webkit-scrollbar{height:2px}
.proj-scroll-track::-webkit-scrollbar-track{background:var(--linen)}
.proj-scroll-track::-webkit-scrollbar-thumb{background:var(--gold)}
.proj-slide{
  flex:0 0 480px;height:600px;position:relative;overflow:hidden;
  scroll-snap-align:start;cursor:none;
}
.proj-slide:first-child{flex:0 0 640px}
.proj-slide img{position:absolute;inset:0;transition:transform .7s var(--ease-out)}
.proj-slide:hover img{transform:scale(1.05)}
.proj-fade{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(24,14,8,.85) 0%,transparent 55%);
}
.proj-info{position:absolute;bottom:0;left:0;right:0;padding:2.5rem}
.proj-tag{font-size:.5rem;letter-spacing:.3em;text-transform:uppercase;color:#ffa1a3;margin-bottom:.5rem;font-family:var(--caps)}
.proj-name{
  font-family:var(--serif);font-size:1.3rem;font-weight:400;
  color:white;line-height:1.3;
}
.proj-slide:first-child .proj-name{font-size:1.8rem}
.proj-loc{font-size:.72rem;color:rgba(255,255,255,.5);margin-top:.4rem}
.proj-detail{
  font-size:.75rem;color:rgba(255,255,255,.45);line-height:1.7;
  margin-top:.6rem;max-height:0;overflow:hidden;
  transition:max-height .4s var(--ease-out);
}
.proj-slide:hover .proj-detail{max-height:80px}
.proj-scroll-hint{
  display:flex;align-items:center;gap:.8rem;
  font-size:.58rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--taupe);margin-top:2rem;
}
.proj-scroll-hint::after{content:'→→';color:var(--gold-lt)}

/* HOME STATS */
.home-stats{
  background:var(--espresso);padding:6rem 0;
  position:relative;overflow:hidden;
}
.home-stats::before{
  content:'RICCHEZZA';
  position:absolute;font-family:var(--serif);font-size:22vw;font-weight:700;
  color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.025);
  top:50%;left:50%;transform:translate(-50%,-50%);
  white-space:nowrap;letter-spacing:-.02em;pointer-events:none;
}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;
}
.stat-cell{
  padding:3.5rem 3rem;border-right:1px solid rgba(255,255,255,.07);
  position:relative;
}
.stat-cell:last-child{border-right:none}
.stat-num{
  font-family:var(--serif);font-size:3.5rem;font-weight:400;
  color:var(--ivory);line-height:1;margin-bottom:.5rem;
  display:flex;align-items:flex-start;gap:.1em;
}
.stat-sup{font-size:1.5rem;padding-top:.4em}
.stat-lbl{font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.38);margin-bottom:.6rem;font-family:var(--caps)}
.stat-desc{font-size:.75rem;line-height:1.75;color:rgba(255,255,255,.3)}

/* HOME INSIGHTS PREVIEW */
.home-insights{background:var(--cream)}
.ins-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:4px;margin-top:4rem}
.ins-card{position:relative;height:480px;overflow:hidden}
.ins-card:first-child{height:540px}
.ins-card img{position:absolute;inset:0;transition:transform .7s var(--ease-out)}
.ins-card:hover img{transform:scale(1.05)}
.ins-fade{position:absolute;inset:0;background:linear-gradient(to top,rgba(87, 68, 152,.88) 0%,rgba(87, 68, 152,.05) 55%,transparent 100%)}
.ins-content{position:absolute;bottom:0;left:0;right:0;padding:2.5rem}
.ins-cat{font-size:.5rem;letter-spacing:.3em;text-transform:uppercase;color:#ffa1a3;margin-bottom:.6rem;font-family:var(--caps)}
.ins-t{font-family:var(--serif);font-size:.95rem;font-weight:400;color:white;line-height:1.4;margin-bottom:.5rem}
.ins-card:first-child .ins-t{font-size:1.4rem}
.ins-ex{font-size:.75rem;color:rgba(255,255,255,.45);line-height:1.75;max-height:0;overflow:hidden;transition:max-height .4s var(--ease-out)}
.ins-card:hover .ins-ex{max-height:100px}
.ins-lnk{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold-lt);margin-top:.9rem;transition:gap .3s;
}
.ins-lnk::after{content:'→'}
.ins-card:hover .ins-lnk{gap:.8rem}

/* HOME CTA BAND */
.home-cta{
  position:relative;height:560px;overflow:hidden;
  display:flex;align-items:center;justify-content:center;text-align:center;
}
.home-cta img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.home-cta-overlay{position:absolute;inset:0;background:rgba(87, 68, 152,.65)}
.home-cta-content{position:relative;z-index:2;padding:2rem}
.home-cta .label{justify-content:center;color:var(--ivory)}
.home-cta .label::before{background:var(--ivory)}
.home-cta-h{
  font-family:var(--serif);font-size:clamp(2rem,4.5vw,4.2rem);
  font-weight:400;color:white;line-height:1.12;
  max-width:720px;margin:.8rem auto 1.5rem;letter-spacing:-.02em;
}
.home-cta-h em{font-style:italic;color:#ff3333}
.home-cta-sub{font-size:.88rem;color:rgba(255,255,255,.75);max-width:480px;line-height:1.9;margin:0 auto 3rem}
.home-cta-btns{display:flex;gap:1.4rem;justify-content:center}
.btn-ivory{
  display:inline-flex;align-items:center;gap:1rem;
  background:var(--ivory);color:var(--espresso);
  padding:.95rem 2.4rem;font-size:.62rem;letter-spacing:.22em;
  text-transform:uppercase;font-weight:500;transition:all .35s, gap .3s;
}
.btn-ivory:hover{background:var(--gold);color:var(--ivory);gap:1.5rem}
.btn-ivory .arr{transition:transform .3s}
.btn-ivory:hover .arr{transform:translateX(4px)}
.btn-bdr-w{
  display:inline-flex;align-items:center;gap:1rem;
  border:1px solid rgba(255,255,255,.38);color:white;
  padding:.95rem 2.4rem;font-size:.62rem;letter-spacing:.22em;
  text-transform:uppercase;font-weight:500;transition:all .35s, gap .3s;
}
.btn-bdr-w:hover{border-color:var(--gold-lt);color:var(--gold-lt);gap:1.5rem}
.btn-bdr-w .arr{transition:transform .3s}
.btn-bdr-w:hover .arr{transform:translateX(4px)}

/* ═══════════════════════════════════════════
   ABOUT US PAGE
═══════════════════════════════════════════ */
.about-hero{
  min-height:75vh;display:grid;grid-template-columns:1fr 1fr;
}
.about-hero-l{
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:7rem 5vw 7rem;background:var(--cream);
}
.about-hero-r{position:relative;overflow:hidden;min-height:500px}
.about-hero-r img{object-position:center 20%}
.about-hero-r-fade{
  position:absolute;inset:0;
  background:linear-gradient(to right,rgba(244,241,235,.15) 0%,transparent 25%);
}
.about-mission{
  display:grid;grid-template-columns:1fr 1fr;gap:9rem;align-items:start;
  margin-top:0;
}
.about-mission-quote{
  font-family:var(--serif);font-size:clamp(1.4rem,2.5vw,2.2rem);
  font-weight:400;line-height:1.45;color:var(--espresso);
  border-left:2px solid var(--gold);padding-left:2.5rem;position:sticky;top:120px;
}
.about-mission-quote em{font-style:italic;color:var(--gold)}
.about-vals{display:flex;flex-direction:column;gap:0}
.aval{
  padding:2.5rem 0;border-bottom:1px solid var(--linen);
  display:grid;grid-template-columns:50px 1fr;gap:1.5rem;align-items:start;
}
.aval-num{
  font-family:var(--serif);font-size:3rem;font-weight:300;color:var(--linen);
  line-height:1;transition:color .3s;
}
.aval:hover .aval-num{color:var(--gold-lt)}
.aval-t{font-family:var(--serif);font-size:1.1rem;margin-bottom:.4rem}
.aval-d{font-size:.82rem;line-height:1.88;color:var(--taupe)}

/* ── BOARD OF DIRECTORS ── */
.about-directors{
  padding:9rem 0;
  background:var(--cream);
  border-top:1px solid var(--linen);
}
.director-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8rem;
  align-items:center;
}
.director-col-img{
  position:relative;
  height:540px;
  overflow:hidden;
  border: 1px solid var(--sand);
  background: var(--linen);
}
.director-col-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .7s var(--ease-out);
}
.director-col-img:hover img{
  transform:scale(1.04);
}
.director-img-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(0, 45, 82, 0.25) 0%, transparent 50%);
  pointer-events:none;
}

.about-team{background:var(--espresso)}
.team-heading{color:var(--ivory)}.team-heading em{color:var(--gold-lt)}
.team-sub{color:rgba(255,255,255,.42);font-size:.88rem;line-height:1.9;max-width:520px}
.team-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:4rem;
}
.team-card{position:relative;height:480px;overflow:hidden}
.team-card img{transition:transform .7s var(--ease-out)}
.team-card:hover img{transform:scale(1.05)}
.team-card-bg{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(24,14,8,.88) 0%,transparent 50%);
}
.team-info{position:absolute;bottom:0;left:0;right:0;padding:2.5rem}
.team-name{font-family:var(--serif);font-size:1.2rem;font-weight:400;color:white;margin-bottom:.25rem}
.team-role{font-size:.58rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold-lt);font-family:var(--caps)}

/* ═══════════════════════════════════════════
   SERVICES PAGE
═══════════════════════════════════════════ */
.svcs-page-hero{
  background:var(--espresso);min-height:60vh;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding-top:8rem;padding-bottom:6rem;position:relative;overflow:hidden;
}
.svcs-hero-img{position:absolute;inset:0;opacity:.25}
.svcs-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,var(--espresso) 20%,transparent 70%)}
.svcs-page-label{color:var(--gold-lt)}.svcs-page-label::before{background:var(--gold-lt)}
.svcs-page-d1{color:var(--ivory)}.svcs-page-d1 em{color:var(--gold-lt)}
.svcs-detail{display:flex;flex-direction:column;gap:0}
.svc-row{
  display:grid;grid-template-columns:1fr 1fr;
  min-height:60vh;border-bottom:1px solid var(--linen);
}
.svc-row:nth-child(even) .svc-row-img{order:-1}
.svc-row:nth-child(even){background:var(--cream)}
.svc-row-content{
  display:flex;flex-direction:column;justify-content:center;
  padding:6rem 5vw;
}
.svc-row-img{position:relative;overflow:hidden;min-height:500px}
.svc-row-img img{transition:transform 6s linear}
.svc-row:hover .svc-row-img img{transform:scale(1.04)}
.svc-row-img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(196,162,101,.08) 0%,transparent 50%);
}
.svc-scope{margin-top:2.5rem}
.svc-scope-title{font-size:.55rem;letter-spacing:.35em;text-transform:uppercase;color:var(--gold);margin-bottom:1rem;font-family:var(--caps)}
.svc-scope-list{display:flex;flex-direction:column;gap:.6rem}
.svc-scope-item{
  display:flex;align-items:flex-start;gap:1rem;
  font-size:.82rem;line-height:1.7;color:var(--taupe);
}
.svc-scope-item::before{
  content:'';width:4px;height:4px;border-radius:50%;
  background:var(--gold);flex-shrink:0;margin-top:.55rem;
}

/* ═══════════════════════════════════════════
   SOLUTIONS PAGE
═══════════════════════════════════════════ */
.sol-hero{
  background:var(--espresso);min-height:70vh;
  display:grid;grid-template-columns:1fr 1fr;
}
.sol-hero-l{
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:7rem 5vw 6rem;
}
.sol-hero-label{color:var(--gold-lt)}.sol-hero-label::before{background:var(--gold-lt)}
.sol-hero-d1{color:var(--ivory)}.sol-hero-d1 em{color:var(--gold-lt)}
.sol-hero-body{color:rgba(255,255,255,.45);font-size:.88rem;line-height:1.9;max-width:480px;margin-top:1.5rem}
.sol-hero-r{position:relative;overflow:hidden}
.sol-hero-r img{object-position:center 30%}
.sol-hero-r-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to right,rgba(24,14,8,.5) 0%,transparent 40%);
}
.sol-bento{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-template-rows:340px 280px 280px 300px;
  gap:3px;
  background:var(--espresso);
}
.sol-tile{position:relative;overflow:hidden}
.sol-tile:nth-child(1){grid-column:span 8;grid-row:span 2}
.sol-tile:nth-child(2){grid-column:span 4}
.sol-tile:nth-child(3){grid-column:span 4}
.sol-tile:nth-child(4){grid-column:span 4}
.sol-tile:nth-child(5){grid-column:span 4}
.sol-tile:nth-child(6){grid-column:span 4}
.sol-tile:nth-child(7){grid-column:span 6}
.sol-tile:nth-child(8){grid-column:span 6}
.sol-tile img{position:absolute;inset:0;transition:transform .7s var(--ease-out)}
.sol-tile:hover img{transform:scale(1.06)}
.sol-tile-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,15,30,0.95) 0%,rgba(0,15,30,0.65) 50%,rgba(0,15,30,0.3) 100%);
  transition:opacity 0.3s ease;
}
.sol-tile-content{position:absolute;bottom:0;left:0;right:0;padding:2rem}
.sol-tile-tag{font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:#ffa1a3;margin-bottom:.4rem;font-family:var(--caps);font-weight:600}
.sol-tile-name{font-family:var(--serif);font-size:1.05rem;font-weight:400;color:white;line-height:1.3}
.sol-tile:nth-child(1) .sol-tile-name{font-size:1.6rem}
.sol-tile-desc{font-size:.75rem;color:rgba(255,255,255,.8);line-height:1.75;max-height:0;overflow:hidden;transition:max-height .4s var(--ease-out);margin-top:.4rem}
.sol-tile:hover .sol-tile-desc{max-height:90px}
.sol-why{background:var(--cream);padding:9rem 0}
.sol-why-inner{display:grid;grid-template-columns:1fr 1fr;gap:9rem;align-items:center}
.sol-why-img{position:relative;height:600px;overflow:hidden}
.sol-why-badge{
  position:absolute;bottom:3rem;right:-1.5rem;
  width:150px;height:150px;background:var(--gold);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:1rem;z-index:2;
}
.sol-why-badge-n{font-family:var(--serif);font-size:2.2rem;font-weight:400;color:white;line-height:1}
.sol-why-badge-t{font-size:.45rem;letter-spacing:.2em;text-transform:uppercase;color:white;line-height:1.6;margin-top:.3rem}
.sol-feats{display:flex;flex-direction:column;gap:1.2rem;margin-top:2.5rem}
.sf{
  display:flex;align-items:flex-start;gap:1.5rem;
  padding:1.5rem;border:1px solid var(--linen);
  background:white;transition:border-color .3s,transform .3s;
}
.sf:hover{border-color:var(--gold-lt);transform:translateX(6px)}
.sf-dot{width:6px;height:6px;background:var(--gold);border-radius:50%;flex-shrink:0;margin-top:.55rem}
.sf-text{font-size:.84rem;line-height:1.82;color:var(--taupe)}
.sf-text strong{color:var(--espresso);font-weight:500}

/* ═══════════════════════════════════════════
   PROJECTS PAGE
═══════════════════════════════════════════ */
.projects-hero{
  min-height:65vh;display:grid;grid-template-columns:1fr 1fr;
}
.projects-hero-l{
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:7rem 5vw 6rem;background:var(--ivory);
}
.projects-hero-r{position:relative;overflow:hidden;min-height:480px}
.projects-hero-r img{object-position:center 40%}
.proj-grid-full{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2px;
}
.pcard{position:relative;height:420px;overflow:hidden}
.pcard.tall{height:560px}
.pcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease-out)}
.pcard:hover img{transform:scale(1.05)}
.pcard-fade{position:absolute;inset:0;background:linear-gradient(to top,rgba(87, 68, 152,.82) 0%,transparent 55%)}
.pcard-info{position:absolute;bottom:0;left:0;right:0;padding:2.5rem}
.pcard-tag{font-size:.5rem;letter-spacing:.3em;text-transform:uppercase;color:#ffa1a3;margin-bottom:.4rem;font-family:var(--caps)}
.pcard-name{font-family:var(--serif);font-size:1.1rem;font-weight:400;color:white;line-height:1.3}
.pcard.tall .pcard-name{font-size:1.5rem}
.pcard-meta{font-size:.7rem;color:rgba(255,255,255,.45);margin-top:.35rem}
.proj-filter{
  display:flex;gap:0;border-bottom:1px solid var(--linen);margin-bottom:4rem;
}
.pf-btn{
  padding:.9rem 1.6rem;font-size:.6rem;letter-spacing:.22em;
  text-transform:uppercase;background:none;border:none;
  color:var(--taupe);cursor:none;border-bottom:2px solid transparent;
  transition:all .3s;margin-bottom:-1px;
}
.pf-btn.on{color:var(--espresso);border-bottom-color:var(--gold)}
.pf-btn:hover{color:var(--espresso)}

/* ═══════════════════════════════════════════
   PRODUCTS PAGE
═══════════════════════════════════════════ */
.products-intro{
  display:grid;grid-template-columns:1fr 1.2fr;gap:8rem;align-items:center;
}
.products-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:2rem;
}
.prod-card{
  border:1px solid var(--linen);background:white;
  transition:border-color .4s,box-shadow .4s,transform .4s;
  overflow:hidden;
}
.prod-card:hover{border-color:var(--gold-lt);box-shadow:0 16px 48px rgba(196,162,101,.14);transform:translateY(-4px)}
.prod-img{height:240px;overflow:hidden;position:relative}
.prod-img img{transition:transform .7s var(--ease-out)}
.prod-card:hover .prod-img img{transform:scale(1.07)}
.prod-body{padding:2rem}
.prod-cat{font-size:.5rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem;font-family:var(--caps)}
.prod-name{font-family:var(--serif);font-size:1.1rem;font-weight:500;margin-bottom:.5rem;line-height:1.3}
.prod-desc{font-size:.78rem;line-height:1.82;color:var(--taupe);margin-bottom:1.2rem}
.prod-feat-list{display:flex;flex-direction:column;gap:.4rem;padding-top:1.2rem;border-top:1px solid var(--linen)}
.pfl-item{font-size:.72rem;color:var(--taupe);display:flex;align-items:center;gap:.6rem}
.pfl-item::before{content:'';width:3px;height:3px;background:var(--gold);border-radius:50%;flex-shrink:0}

/* ═══════════════════════════════════════════
   INSIGHTS PAGE
═══════════════════════════════════════════ */
.blog-hero{
  background:var(--espresso);min-height:50vh;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding-top:8rem;padding-bottom:6rem;position:relative;overflow:hidden;
}
.blog-hero img{position:absolute;inset:0;opacity:.2}
.blog-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,var(--espresso) 30%,transparent 80%)}
.blog-hero .label{color:var(--gold-lt)}.blog-hero .label::before{background:var(--gold-lt)}
.blog-hero .d1{color:var(--ivory)}.blog-hero .d1 em{color:var(--gold-lt)}
.blog-grid{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:2.5rem;margin-top:4rem;
}
.blog-card{border-bottom:1px solid var(--linen);padding-bottom:2.5rem;transition:border-color .3s}
.blog-card:hover{border-bottom-color:var(--gold)}
.blog-card-img{height:220px;overflow:hidden;margin-bottom:1.8rem;position:relative}
.blog-card-img img{transition:transform .7s var(--ease-out)}
.blog-card:hover .blog-card-img img{transform:scale(1.05)}
.blog-cat{font-size:.5rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:.7rem;font-family:var(--caps)}
.blog-t{font-family:var(--serif);font-size:1.05rem;font-weight:500;line-height:1.4;margin-bottom:.6rem}
.blog-ex{font-size:.78rem;line-height:1.85;color:var(--taupe);margin-bottom:1.2rem}
.blog-meta{font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--sand)}

/* ═══════════════════════════════════════════
   CAREERS PAGE
═══════════════════════════════════════════ */
.careers-intro{
  display:grid;grid-template-columns:1fr 1fr;min-height:70vh;
}
.careers-l{
  display:flex;flex-direction:column;justify-content:center;
  padding:7rem 5vw 6rem;background:var(--espresso);
}
.careers-l .label{color:var(--gold-lt)}.careers-l .label::before{background:var(--gold-lt)}
.careers-l .d1{color:var(--ivory)}.careers-l .d1 em{color:var(--gold-lt)}
.careers-l .body{color:rgba(255,255,255,.45)}
.careers-r{position:relative;overflow:hidden;min-height:500px}
.careers-r img{object-position:center 30%}
.openings{display:flex;flex-direction:column;gap:0;margin-top:3rem}
.job{
  padding:2.5rem 0;border-bottom:1px solid var(--linen);
  display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center;
  cursor:none;transition:background .3s;
}
.job:hover{background:var(--cream);padding-left:1rem;margin:0 -1rem;padding-right:1rem}
.job-dept{font-size:.55rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem;font-family:var(--caps)}
.job-title{font-family:var(--serif);font-size:1.15rem;font-weight:500;margin-bottom:.35rem}
.job-loc{font-size:.75rem;color:var(--taupe)}
.job-type{
  font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;
  border:1px solid var(--sand);color:var(--stone);
  padding:.45rem .9rem;white-space:nowrap;
}
.culture-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:2px;
  margin-top:4rem;
}
.culture-card{position:relative;height:320px;overflow:hidden}
.culture-card img{transition:transform .7s var(--ease-out)}
.culture-card:hover img{transform:scale(1.06)}
.culture-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(24,14,8,.8) 0%,transparent 55%)}
.culture-info{position:absolute;bottom:0;left:0;right:0;padding:2rem}
.culture-title{font-family:var(--serif);font-size:1.1rem;font-weight:400;color:white;margin-bottom:.3rem}
.culture-desc{font-size:.75rem;color:rgba(255,255,255,.5);line-height:1.7}

/* ═══════════════════════════════════════════
   CONTACT PAGE
═══════════════════════════════════════════ */
.contact-hero{
  background:var(--cream);min-height:52vh;
  display:grid;grid-template-columns:1fr 1fr;
}
.contact-hero-l{
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:7rem 5vw 5rem;
}
.contact-hero-r{position:relative;overflow:hidden;min-height:420px}
.contact-hero-r img{object-position:center 55%}
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:9rem;align-items:start}
.contact-info-block{display:flex;flex-direction:column;gap:2rem}
.ci{display:flex;gap:1.5rem}
.ci-lbl{
  font-size:.55rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);width:72px;flex-shrink:0;padding-top:.15rem;
  font-family:var(--caps);font-weight:500;
}
.ci-val{font-size:.86rem;line-height:1.8;color:var(--taupe)}
.contact-map{
  margin-top:2.5rem;height:200px;background:var(--linen);
  position:relative;overflow:hidden;border:1px solid var(--sand);
}
.map-grid-bg{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(196,162,101,.07) 1px,transparent 1px),
    linear-gradient(90deg,rgba(196,162,101,.07) 1px,transparent 1px);
  background-size:28px 28px;
}
.map-pin{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);
  width:14px;height:14px;background:var(--gold);border-radius:50%;
}
.map-pin::after{
  content:'';position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:28px;height:28px;border:1px solid var(--gold);border-radius:50%;
  animation:ping 2s ease-out infinite;
}
@keyframes ping{0%{opacity:.8;transform:translate(-50%,-50%) scale(1)}100%{opacity:0;transform:translate(-50%,-50%) scale(2.5)}}
.map-label-txt{
  position:absolute;bottom:1.2rem;left:50%;transform:translateX(-50%);
  font-size:.55rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--taupe);white-space:nowrap;
}
/* FORM */
.cf{display:flex;flex-direction:column;gap:1.8rem}
.fg{display:flex;flex-direction:column;gap:.6rem}
.fgrow{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.fg label{font-size:.55rem;letter-spacing:.3em;text-transform:uppercase;color:var(--stone);font-family:var(--caps);font-weight:400}
.fg input,.fg select,.fg textarea{
  border:none;border-bottom:1px solid var(--sand);
  background:transparent;font-family:var(--sans);font-size:.88rem;
  font-weight:300;color:var(--espresso);padding:.85rem 0;outline:none;
  transition:border-color .3s;-webkit-appearance:none;
}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-bottom-color:var(--gold)}
.fg input::placeholder,.fg textarea::placeholder{color:var(--sand)}
.fg select{color:var(--taupe)}
.fg select option{background:var(--ivory);color:var(--espresso)}
.fg textarea{resize:none;min-height:110px}
.form-privacy{font-size:.7rem;color:var(--taupe);line-height:1.8;margin-top:.5rem}

/* ═══════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════ */
#footer{background:var(--navy-dk);padding:6rem 5vw 3rem;border-top:1px solid rgba(255,255,255,.04)}
.footer-top{
  display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;
  gap:5rem;padding-bottom:4rem;border-bottom:1px solid rgba(255,255,255,.06);
}
.f-logo-wrap{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
}
.f-brand-wrap{
  display:flex;
  align-items:center;
  gap:1rem;
  margin-bottom:1.5rem;
}
.f-logo-icon{
  height:96px;
  width:auto;
  object-fit:contain;
  display:block;
}
.f-logo-wordmark{
  font-family:var(--serif);font-size:1.6rem;font-weight:400;
  letter-spacing:.1em;color:white;display:block;margin-bottom:.6rem;
}
.f-logo-wordmark em{font-style:normal;color:var(--gold)}
.f-logo-sub{font-size:.5rem;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,.28);font-family:var(--caps);display:block;margin-bottom:1.8rem}
.f-desc{font-size:.78rem;line-height:1.95;color:rgba(255,255,255,.7);max-width:280px;margin-bottom:2rem}

.f-col h5{
  font-size:.55rem;letter-spacing:.38em;text-transform:uppercase;
  color:var(--gold);margin-bottom:2rem;font-family:var(--caps);
}
.f-col ul{list-style:none;display:flex;flex-direction:column;gap:.85rem}
.f-col a{font-size:.78rem;color:rgba(255,255,255,.65);transition:color .3s;font-weight:300}
.f-col a:hover{color:rgba(255,255,255,.8)}
.footer-bottom{
  display:flex;justify-content:center;align-items:center;
  padding-top:2.5rem;text-align:center;
}
.f-copy{font-size:.65rem;color:rgba(255,255,255,.6)}


/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */
@media(max-width:1200px){
  .hero{
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
  }
  .hero-l{
    padding-top:120px;
    padding-bottom:60px;
  }
  .hero-r{
    position:absolute;
    bottom:4vh;
    left:1.5rem;
    z-index:3;
  }
  .hero-overlay{
    background:rgba(45, 32, 84, 0.45);
  }

  .about-hero,.about-mission,.sol-hero,.sol-why-inner,
  .upvc-sig,.svcs-page-hero,.projects-hero,
  .careers-intro,.contact-hero,
  .contact-grid,.home-phil-inner,.brand-strip-inner{
    grid-template-columns:1fr;gap:0
  }
  .about-hero-r,.projects-hero-r,.careers-r,.contact-hero-r{height:380px}
  .about-mission-quote{position:static;padding:5rem 5vw;background:var(--cream)}
  .about-vals{padding:5rem 5vw}
  .team-grid{grid-template-columns:1fr 1fr}
  .svcs-strip{grid-template-columns:1fr 1fr}
  .svc-item:nth-child(2){border-right:none}
  .sol-bento{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .sol-tile,
  .sol-tile:nth-child(1),
  .sol-tile:nth-child(2),
  .sol-tile:nth-child(3),
  .sol-tile:nth-child(4),
  .sol-tile:nth-child(5),
  .sol-tile:nth-child(6),
  .sol-tile:nth-child(7),
  .sol-tile:nth-child(8){grid-column:span 1;grid-row:span 1;height:280px}
  .ins-grid{grid-template-columns:1fr 1fr}
  .ins-card:first-child{grid-column:span 2;height:420px}
  .stats-grid{grid-template-columns:1fr 1fr}
  .stat-cell:nth-child(2){border-right:none}
  .proj-grid-full{grid-template-columns:1fr 1fr}
  .products-intro{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr;gap:3rem}
  .brand-strip-inner{padding:5rem 5vw}
  .home-phil-inner{gap:0}
  .phil-img-wrap{height:400px}
  .phil-items{padding:5rem 5vw}
  .svcs-header{grid-template-columns:1fr}
  .svc-row{grid-template-columns:1fr}
  .svc-row:nth-child(even) .svc-row-img{order:0}
  .svc-row-img{min-height:320px}
  .sol-why-inner{padding:5rem 5vw}
  .contact-grid{gap:4rem;padding:5rem 5vw}
  .upvc-right{padding:5rem 5vw}
}
@media(max-width:1366px){
  #nav{padding:0 2.5vw}
  .nav-wordmark{font-size:1.3rem}
  .nav-sub{font-size:.44rem;letter-spacing:.38em}
  .nav-menu li a{padding:.5rem .55rem;font-size:.56rem;letter-spacing:.18em}
  .nav-consult{padding:.55rem 1.3rem;font-size:.56rem}
  #nav.solid .nav-consult{padding:.4rem 1.1rem}
  .nav-actions{gap:.25rem}
  .nav-socials{gap:.8rem}
}
@media(max-width:1024px){
  .nav-menu,.nav-actions{display:none}
  .nav-burger{display:flex}
  .director-row{
    grid-template-columns:1fr;
    gap:4rem;
  }
  .director-col-img{
    height:420px;
  }
}
@media(max-width:768px){
  .home-cta-btns{flex-direction:column;align-items:center}
  .blog-grid,.products-grid,.culture-grid{grid-template-columns:1fr}
  .proj-grid-full{grid-template-columns:1fr}
  .fgrow{grid-template-columns:1fr}
  .svcs-strip{grid-template-columns:1fr}
  .sol-bento{display:flex;flex-direction:column}
  .team-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1fr}
  .ins-grid{grid-template-columns:1fr}
  .ins-card:first-child{grid-column:span 1}
  .about-stats-row{grid-template-columns:1fr 1fr}
  .upvc-features{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════
   ALTERNATIVE MODERN HEADER (v2)
   Toggle by adding class "modern-v2" to <nav id="nav">
═══════════════════════════════════════════ */
#nav.modern-v2{
  top: 1.5rem;
  left: 3.5vw;
  right: 3.5vw;
  width: calc(100% - 7vw);
  height: 84px;
  padding: 0 2.5rem;
  border-radius: 50px;
  background: rgba(248, 250, 252, 0.82);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(226, 232, 240, 0.7);
  box-shadow: 0 8px 30px rgba(87, 68, 152, 0.05);
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: all 0.4s var(--ease-out);
}

#nav.modern-v2.solid{
  top: 0.75rem;
  height: 72px;
  background: rgba(248, 250, 252, 0.92);
  box-shadow: 0 12px 40px rgba(87, 68, 152, 0.08);
}

#nav.modern-v2 .nav-logo-icon{
  height: 60px;
  transition: height 0.4s var(--ease-out);
}

#nav.modern-v2.solid .nav-logo-icon{
  height: 48px;
}

#nav.modern-v2 .nav-menu{
  display: flex;
  align-items: center;
  gap: 0.2rem;
}

#nav.modern-v2 .nav-menu li a{
  padding: 0.4rem 0.8rem;
  font-size: 0.54rem;
  letter-spacing: 0.22em;
}

#nav.modern-v2 .nav-menu li a::after{
  left: 0.8rem;
  right: 0.8rem;
  bottom: -4px;
}

#nav.modern-v2 .nav-actions{
  flex-direction: row;
  align-items: center;
  gap: 1.8rem;
  width: auto;
}

#nav.modern-v2 .nav-socials{
  gap: 0.9rem;
}

#nav.modern-v2 .nav-soc-link svg{
  width: 14px;
  height: 14px;
}

#nav.modern-v2 .nav-consult{
  font-size: 0.54rem;
  letter-spacing: 0.2em;
  padding: 0.6rem 1.4rem;
  border-radius: 30px;
  background: var(--espresso);
  border: 1px solid var(--espresso);
  color: var(--ivory);
}

#nav.modern-v2 .nav-consult::before{
  background: var(--ivory);
}

#nav.modern-v2 .nav-consult span{
  color: var(--ivory);
}

#nav.modern-v2 .nav-consult:hover span{
  color: var(--espresso);
}

/* Responsive Overrides for Modern v2 */
@media (max-width: 1366px) {
  #nav.modern-v2{
    padding: 0 1.75rem;
    left: 2.5vw;
    right: 2.5vw;
    width: calc(100% - 5vw);
  }
  #nav.modern-v2 .nav-menu li a{
    padding: 0.4rem 0.6rem;
    font-size: 0.52rem;
    letter-spacing: 0.18em;
  }
  #nav.modern-v2 .nav-actions{
    gap: 1.2rem;
  }
}

@media (max-width: 1280px) {
  #nav.modern-v2 .nav-socials {
    display: none;
  }
  #nav.modern-v2 .nav-sub {
    display: none;
  }
  #nav.modern-v2 .nav-menu li a {
    padding: 0.4rem 0.45rem;
    font-size: 0.5rem;
    letter-spacing: 0.14em;
  }
  #nav.modern-v2 .nav-actions {
    gap: 1rem;
  }
}

@media (max-width: 1024px) {
  #nav.modern-v2{
    top: 1rem;
    left: 4vw;
    right: 4vw;
    width: calc(100% - 8vw);
    height: 60px;
    padding: 0 1.5rem;
    border-radius: 30px;
  }
  #nav.modern-v2.solid{
    top: 0.75rem;
    height: 60px;
  }
  #nav.modern-v2 .nav-brand{
    padding: 0;
    border-right: none;
  }
  #nav.modern-v2 .nav-menu,
  #nav.modern-v2 .nav-actions {
    display: none;
  }
  #nav.modern-v2 .nav-burger {
    display: flex;
  }
}

@media (max-width: 768px) {
  #nav.modern-v2{
    left: 3vw;
    right: 3vw;
    width: calc(100% - 6vw);
    padding: 0 1.25rem;
  }
  #nav.modern-v2 .nav-sub {
    display: none;
  }
  #nav.modern-v2 .nav-wordmark {
    font-size: 1.15rem;
  }
  .hero-r {
    display: none !important;
  }
  .hero-scroll {
    display: none !important;
  }
}

