/* ==========================================================
   REX LUXA — main.css
   Luxa Design Agency visual system
   Type: Cormorant Garamond (display) + Jost (interface)
   Palette: --n Navy · --g Gold · --f Cream · --w White
========================================================== */

:root {
  --g:   #B8973A; --g2: #D4AF5A; --g3: rgba(184,151,58,.1);
  --n:   #0D1B2A; --n2: #152333; --n3: #1e3451;
  --w:   #ffffff; --f:  #F8F5F0; --f2: #F0EBE2; --bdr: #E8E2D8;
  --tx:  #1a1918; --m:  #888;    --lt: #bbb;
  --tx-prose: #4a4a4a; --tx-sub: #5a5a5a;
  --fw-display: 300; --fw-body: 300; --trk-display: 1px;
  --D:   'Cormorant Garamond', Georgia, serif;
  --S:   'Jost', 'Helvetica Neue', Arial, sans-serif;
  --ease:cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--S);color:var(--tx);background:var(--w);
  line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
img,video{max-width:100%;height:auto;display:block;}
a{text-decoration:none;color:inherit;}
button{cursor:pointer;font-family:var(--S);border:none;}
ul{list-style:none;}
h1,h2,h3,h4{font-family:var(--D);font-weight:300;line-height:1.1;}
.screen-reader-text{clip:rect(1px,1px,1px,1px);height:1px;width:1px;overflow:hidden;position:absolute;white-space:nowrap;}
:focus-visible{outline:2px solid var(--g);outline-offset:2px;}

/* ── NAVIGATION ─────────────────────────────────────────── */
#site-nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  height:72px;display:flex;align-items:center;padding:0 60px;gap:40px;
  transition:background .35s var(--ease),box-shadow .35s var(--ease);
}
#site-nav.nav-over-dark{background:transparent;}
#site-nav.nav-solid{background:var(--w);box-shadow:0 1px 0 var(--bdr);}

.site-logo a{display:flex;flex-direction:column;gap:2px;}
.logo-main{font-family:var(--D);font-size:20px;font-weight:400;letter-spacing:3px;line-height:1;transition:color .3s;}
.logo-sub{font-size:7px;font-weight:600;letter-spacing:4px;text-transform:uppercase;transition:color .3s;}
.nav-over-dark .logo-main{color:var(--w);}
.nav-over-dark .logo-sub{color:rgba(255,255,255,.4);}
.nav-solid .logo-main{color:var(--n);}
.nav-solid .logo-sub{color:var(--g);}

.nav-menu{display:flex;gap:0;margin:0 auto;}
.nav-menu li a{
  font-size:9.5px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;
  padding:8px 14px;display:block;position:relative;transition:color .2s;
}
.nav-menu li a::after{
  content:'';position:absolute;bottom:4px;left:14px;right:14px;
  height:1px;background:var(--g);transform:scaleX(0);transform-origin:left;
  transition:transform .3s var(--ease);
}
.nav-menu li a:hover::after,.nav-menu li a.current-menu-item::after{transform:scaleX(1);}
.nav-over-dark .nav-menu li a{color:rgba(255,255,255,.55);}
.nav-over-dark .nav-menu li a:hover,.nav-over-dark .nav-menu li a.current-menu-item{color:var(--w);}
.nav-solid .nav-menu li a{color:var(--m);}
.nav-solid .nav-menu li a:hover,.nav-solid .nav-menu li a.current-menu-item{color:var(--n);}

.nav-cta-btn{
  flex-shrink:0;font-size:9px;font-weight:700;letter-spacing:2.5px;
  text-transform:uppercase;padding:11px 26px;border-radius:1px;
  transition:all .22s var(--ease);white-space:nowrap;display:inline-block;
}
.nav-over-dark .nav-cta-btn{background:transparent;color:var(--w);border:1px solid rgba(255,255,255,.35);}
.nav-over-dark .nav-cta-btn:hover{background:var(--g);border-color:var(--g);color:var(--n);}
.nav-solid .nav-cta-btn{background:var(--n);color:var(--w);}
.nav-solid .nav-cta-btn:hover{background:var(--n2);}

.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px;}
.nav-burger span{display:block;width:22px;height:1.5px;transition:.3s;}
.nav-over-dark .nav-burger span{background:var(--w);}
.nav-solid .nav-burger span{background:var(--n);}

.mob-drawer{
  position:fixed;top:0;right:0;width:290px;height:100vh;
  background:var(--n);z-index:1000;overflow-y:auto;padding:80px 32px 40px;
  transform:translateX(100%);transition:transform .35s var(--ease);
  box-shadow:-4px 0 30px rgba(0,0,0,.4);
}
.mob-drawer.is-open{transform:none;}
.mob-drawer-close{position:absolute;top:24px;right:24px;background:none;border:none;color:rgba(255,255,255,.4);font-size:20px;cursor:pointer;}
.mob-drawer li{border-bottom:1px solid rgba(255,255,255,.06);}
.mob-drawer li a{display:block;font-size:10px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.5);padding:14px 0;transition:color .2s;}
.mob-drawer li a:hover{color:var(--g2);}

/* ── BUTTONS ────────────────────────────────────────────── */
.btn-solid{font-size:9px;font-weight:700;letter-spacing:3px;text-transform:uppercase;padding:14px 34px;background:var(--n);color:var(--w);border:1px solid var(--n);border-radius:1px;transition:all .22s var(--ease);cursor:pointer;display:inline-flex;align-items:center;gap:10px;}
.btn-solid:hover{background:var(--n2);gap:16px;}
.btn-ghost{font-size:9px;font-weight:700;letter-spacing:3px;text-transform:uppercase;padding:13px 34px;background:transparent;color:var(--n);border:1px solid rgba(0,0,0,.18);border-radius:1px;transition:all .22s var(--ease);cursor:pointer;display:inline-flex;align-items:center;gap:10px;}
.btn-ghost:hover{background:var(--n);color:var(--w);border-color:var(--n);}
.btn-gold{font-size:9px;font-weight:700;letter-spacing:3px;text-transform:uppercase;padding:14px 34px;background:var(--g);color:var(--n);border:1px solid var(--g);border-radius:1px;transition:all .22s var(--ease);cursor:pointer;display:inline-flex;align-items:center;gap:10px;}
.btn-gold:hover{background:var(--g2);gap:16px;}
.btn-dark-ghost{font-size:9px;font-weight:700;letter-spacing:3px;text-transform:uppercase;padding:13px 34px;background:transparent;color:var(--w);border:1px solid rgba(255,255,255,.3);border-radius:1px;transition:all .22s var(--ease);cursor:pointer;display:inline-flex;align-items:center;gap:10px;}
.btn-dark-ghost:hover{border-color:var(--g);color:var(--g2);}
button:disabled{opacity:.6;cursor:not-allowed!important;}

/* ── HERO — Split asymmetric (Luxa Design Agency) ──────── */
.site-hero{position:relative;min-height:100vh;display:grid;grid-template-columns:1fr 1fr;overflow:hidden;}

.hero-left{
  background:var(--f);display:flex;flex-direction:column;justify-content:center;
  padding:140px 70px 80px 60px;position:relative;z-index:2;
}
.hero-left::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 20% 60%,rgba(184,151,58,.07) 0%,transparent 55%);pointer-events:none;}
.hero-kicker{font-size:9px;font-weight:700;letter-spacing:6px;text-transform:uppercase;color:var(--g);margin-bottom:32px;display:flex;align-items:center;gap:16px;}
.hero-kicker::before{content:'';display:block;width:44px;height:1px;background:var(--g);}
.hero-h1{font-family:var(--D);font-size:clamp(48px,5.5vw,80px);font-weight:300;color:var(--n);line-height:.92;letter-spacing:1px;margin-bottom:30px;}
.hero-h1 em{font-style:italic;color:var(--g);display:block;}
.hero-body{font-size:12px;font-weight:300;color:var(--m);line-height:1.9;max-width:420px;margin-bottom:44px;}
.hero-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap;}

.hero-slide{display:none;}
.hero-slide.is-active{display:block;animation:slideIn .6s var(--ease);}
@keyframes slideIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

.hero-counter{position:absolute;bottom:48px;left:60px;}
.hero-dots{display:flex;gap:8px;}
.hero-dot{width:28px;height:2px;background:var(--bdr);border:none;border-radius:1px;cursor:pointer;padding:0;transition:all .3s;}
.hero-dot.is-active{background:var(--g);width:44px;}

.hero-right{position:relative;overflow:hidden;background:var(--n);clip-path:polygon(8% 0,100% 0,100% 100%,0% 100%);}
.hero-right-inner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:140px 60px 80px 90px;}
.hero-right-label{font-size:9px;font-weight:700;letter-spacing:5px;text-transform:uppercase;color:var(--g);margin-bottom:24px;}
.hero-stat-big{font-family:var(--D);font-size:clamp(72px,8vw,110px);font-weight:300;color:rgba(255,255,255,.06);line-height:1;margin-bottom:-20px;}
.hero-pillars{display:flex;flex-direction:column;gap:14px;margin-top:32px;}
.hero-pillar{display:flex;align-items:center;gap:14px;padding:14px 18px;border:1px solid rgba(255,255,255,.07);border-radius:1px;transition:border-color .2s,background .2s;cursor:pointer;text-decoration:none;}
.hero-pillar:hover{border-color:rgba(184,151,58,.35);background:rgba(184,151,58,.05);}
.hp-icon{font-size:18px;flex-shrink:0;}
.hp-text{font-size:11px;font-weight:500;color:rgba(255,255,255,.6);letter-spacing:.5px;}
.hp-arrow{margin-left:auto;font-size:14px;color:var(--g);opacity:0;transition:opacity .2s,transform .2s;}
.hero-pillar:hover .hp-arrow{opacity:1;transform:translateX(4px);}

.hero-scroll-hint{position:absolute;bottom:50px;right:60px;z-index:10;display:flex;flex-direction:column;align-items:center;gap:8px;}
.hero-scroll-hint span{font-size:8px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.3);writing-mode:vertical-rl;}
.scroll-line{width:1px;height:44px;background:linear-gradient(to bottom,var(--g),transparent);animation:scrollAnim 2s ease-in-out infinite;}
@keyframes scrollAnim{0%,100%{opacity:.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.3)}}

/* ── SERVICES — 3-col numbered (Luxa) ──────────────────── */
.home-services{background:var(--w);padding:110px 60px;}
.svc-intro{display:grid;grid-template-columns:1fr 2fr;gap:60px;align-items:end;margin-bottom:70px;}
.svc-tag{font-size:9px;font-weight:700;letter-spacing:5px;text-transform:uppercase;color:var(--g);margin-bottom:14px;}
.svc-h{font-family:var(--D);font-size:clamp(30px,4vw,52px);font-weight:600;color:var(--n);line-height:1.1;}
.svc-h em{font-style:italic;color:var(--g);}
.svc-desc{font-size:14px;font-weight:300;color:var(--m);line-height:1.9;max-width:560px;}

.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--bdr);}
.svc-item{background:var(--w);padding:52px 44px 44px;position:relative;overflow:hidden;transition:background .3s var(--ease);}
.svc-item:hover{background:var(--f);}
.svc-item::after{content:'';position:absolute;bottom:0;left:44px;right:44px;height:2px;background:var(--g);transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease);}
.svc-item:hover::after{transform:scaleX(1);}
.svc-num{font-family:var(--D);font-size:80px;font-weight:300;color:var(--bdr);line-height:1;margin-bottom:12px;transition:color .3s;}
.svc-item:hover .svc-num{color:rgba(184,151,58,.12);}
.svc-label{font-size:8.5px;font-weight:700;letter-spacing:4px;text-transform:uppercase;color:var(--g);margin-bottom:18px;}
.svc-title{font-family:var(--D);font-size:clamp(18px,2vw,26px);font-weight:600;color:var(--n);margin-bottom:18px;line-height:1.2;}
.svc-body{font-size:13px;font-weight:300;color:var(--m);line-height:1.85;margin-bottom:30px;}
.svc-link{font-size:9px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--n);display:inline-flex;align-items:center;gap:10px;transition:gap .2s,color .2s;}
.svc-link:hover{gap:16px;color:var(--g);}

/* ── PORTFOLIO — Filter + 3-col grid ───────────────────── */
.home-portfolio{background:var(--f);padding:90px 60px 100px;}
.port-head{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:24px;margin-bottom:44px;}
.port-filters{display:flex;border-bottom:1px solid var(--bdr);align-self:flex-end;}
.pf-btn{font-size:9.5px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:10px 22px 9px;background:none;border:none;border-bottom:2px solid transparent;color:var(--lt);margin-bottom:-1px;transition:all .22s;cursor:pointer;}
.pf-btn:hover{color:var(--n);}
.pf-btn.is-active{color:var(--n);border-bottom-color:var(--g);}
.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}
.port-item{position:relative;overflow:hidden;aspect-ratio:4/3;background:var(--n2);cursor:pointer;}
.port-item.is-hidden{display:none;}
.port-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:52px;background:linear-gradient(145deg,var(--n2),var(--n3));transition:transform .6s var(--ease);}
.port-thumb{position:absolute;inset:0;overflow:hidden;}
.port-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);}
.port-item:hover .port-placeholder,.port-item:hover .port-thumb img{transform:scale(1.07);}
.port-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,27,42,.94) 0%,rgba(13,27,42,.1) 55%,transparent 100%);opacity:0;transition:opacity .35s var(--ease);display:flex;flex-direction:column;justify-content:flex-end;padding:26px 24px;}
.port-item:hover .port-overlay{opacity:1;}
.port-cat{font-size:8px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--g);margin-bottom:6px;}
.port-name{font-family:var(--D);font-size:19px;font-weight:600;color:var(--w);line-height:1.2;}
.port-more-wrap{text-align:center;margin-top:44px;}
.port-more-btn{font-size:9px;font-weight:700;letter-spacing:3px;text-transform:uppercase;padding:13px 44px;border:1px solid var(--n);color:var(--n);background:transparent;border-radius:1px;cursor:pointer;transition:all .22s;}
.port-more-btn:hover{background:var(--n);color:var(--w);}

/* ── STATS BAND — Dark, Cormorant numbers ───────────────── */
.home-stats{background:var(--n);padding:80px 60px;}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid rgba(255,255,255,.07);border-left:1px solid rgba(255,255,255,.07);max-width:1200px;margin:0 auto;}
.stat-box{padding:52px 36px;text-align:center;border-right:1px solid rgba(255,255,255,.07);border-bottom:1px solid rgba(255,255,255,.07);}
.stat-n{font-family:var(--D);font-size:clamp(54px,6vw,78px);font-weight:300;color:var(--w);line-height:1;margin-bottom:10px;}
.stat-n b{color:var(--g2);font-weight:300;}
.stat-l{font-size:8.5px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.3);}

/* ── TESTIMONIALS ───────────────────────────────────────── */
.home-testis{background:var(--w);padding:110px 60px;}
.testi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;margin-top:54px;}
.testi-card{background:var(--f);padding:52px 48px;position:relative;overflow:hidden;}
.testi-card::before{content:'\201C';font-family:var(--D);font-size:140px;color:rgba(184,151,58,.08);position:absolute;top:-16px;left:34px;line-height:1;pointer-events:none;}
.testi-stars{font-size:13px;color:var(--g);letter-spacing:4px;margin-bottom:18px;}
.testi-body{font-family:var(--D);font-size:19px;font-style:italic;font-weight:300;color:var(--n);line-height:1.65;margin-bottom:32px;position:relative;z-index:1;}
.testi-author{display:flex;align-items:center;gap:16px;border-top:1px solid var(--bdr);padding-top:22px;}
.testi-av{width:48px;height:48px;border-radius:50%;background:var(--n);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--D);font-size:20px;color:var(--g2);overflow:hidden;}
.testi-av img{width:100%;height:100%;object-fit:cover;}
.testi-name{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--n);margin-bottom:4px;}
.testi-role{font-size:11px;font-weight:300;color:var(--m);}

/* ── BRANDS STRIP ───────────────────────────────────────── */
.home-brands{background:var(--f2);padding:44px 60px;border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr);}
.brands-inner{display:flex;align-items:center;justify-content:space-around;flex-wrap:wrap;gap:28px;max-width:1200px;margin:0 auto;}
.brand-item{font-family:var(--D);font-size:14px;font-weight:400;letter-spacing:2px;color:var(--lt);transition:color .2s;}
.brand-item:hover{color:var(--n);}

/* ── NEWSLETTER STRIP — Dark ────────────────────────────── */
.nl-strip{background:var(--n2);padding:70px 60px;display:flex;align-items:center;justify-content:space-between;gap:48px;flex-wrap:wrap;border-top:3px solid var(--g);}
.nl-strip-left .nl-tag{font-size:9px;font-weight:700;letter-spacing:5px;text-transform:uppercase;color:var(--g);margin-bottom:12px;}
.nl-strip-left h3{font-family:var(--D);font-size:clamp(22px,3vw,36px);font-weight:300;color:var(--w);line-height:1.2;}
.nl-strip-left h3 em{font-style:italic;color:var(--g2);}
.nl-inline-form{display:flex;flex:1;max-width:460px;}
.nl-inline-form input{flex:1;padding:14px 20px;border:1px solid rgba(255,255,255,.12);border-right:none;background:rgba(255,255,255,.06);color:var(--w);font-family:var(--S);font-size:12px;outline:none;transition:border-color .2s;}
.nl-inline-form input::placeholder{color:rgba(255,255,255,.28);}
.nl-inline-form input:focus{border-color:var(--g);}
.nl-inline-form button{padding:14px 26px;background:var(--g);color:var(--n);border:none;font-family:var(--S);font-size:9px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;white-space:nowrap;cursor:pointer;transition:background .2s;}
.nl-inline-form button:hover{background:var(--g2);}

/* ── FOOTER — Dark 4-column ─────────────────────────────── */
.site-footer{background:var(--n);padding:80px 60px 0;}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:60px;padding-bottom:60px;border-bottom:1px solid rgba(255,255,255,.07);}
.f-brand{font-family:var(--D);font-size:22px;font-weight:300;color:var(--w);letter-spacing:3px;margin-bottom:10px;}
.f-tagline{font-size:9.5px;font-weight:400;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:28px;}
.f-socials{display:flex;gap:8px;flex-wrap:wrap;}
.f-soc{width:36px;height:36px;border:1px solid rgba(255,255,255,.12);border-radius:1px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:rgba(255,255,255,.35);transition:all .22s;text-decoration:none;}
.f-soc:hover{border-color:var(--g);color:var(--g2);background:rgba(184,151,58,.08);}
.f-col-title{font-size:9px;font-weight:700;letter-spacing:4px;text-transform:uppercase;color:var(--g);margin-bottom:22px;}
.f-nav li{margin-bottom:10px;}
.f-nav li a{font-size:12px;font-weight:300;color:rgba(255,255,255,.38);transition:color .2s;}
.f-nav li a:hover{color:var(--g2);}
.f-ci{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;}
.f-ci-icon{font-size:13px;color:var(--g);flex-shrink:0;margin-top:2px;}
.f-ci-text{font-size:12px;font-weight:300;color:rgba(255,255,255,.38);line-height:1.6;}
.f-cta{display:inline-block;margin-top:18px;font-size:9px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--g);border-bottom:1px solid rgba(184,151,58,.3);padding-bottom:2px;transition:letter-spacing .2s,color .2s;}
.f-cta:hover{letter-spacing:3.5px;color:var(--g2);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:22px 0;gap:20px;flex-wrap:wrap;}
.f-copy{font-size:8.5px;font-weight:400;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.16);}

/* ── INNER PAGES ─────────────────────────────────────────── */
.site-main{flex:1;}
.inner-hero{background:var(--n);padding:148px 60px 90px;position:relative;overflow:hidden;}
.inner-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--g),transparent);}
.inner-hero-ghost{position:absolute;right:60px;bottom:-20px;font-family:var(--D);font-size:clamp(80px,14vw,200px);font-weight:700;color:rgba(255,255,255,.03);line-height:1;pointer-events:none;user-select:none;}
.ih-tag{font-size:9px;font-weight:700;letter-spacing:5px;text-transform:uppercase;color:var(--g);margin-bottom:16px;display:flex;align-items:center;gap:14px;}
.ih-tag::before{content:'';display:block;width:30px;height:1px;background:var(--g);}
.ih-h1{font-family:var(--D);font-size:clamp(34px,5.5vw,70px);font-weight:300;color:var(--w);line-height:1.05;letter-spacing:2px;margin-bottom:20px;}
.ih-h1 em{color:var(--g2);font-style:italic;}
.ih-sub{font-size:12px;font-weight:300;color:rgba(255,255,255,.42);max-width:600px;line-height:1.8;}

/* Page body */
.page-body{max-width:1200px;margin:0 auto;padding:80px 60px 100px;}
.blk{margin-bottom:64px;}
.blk-tag{font-size:9px;font-weight:700;letter-spacing:5px;text-transform:uppercase;color:var(--g);margin-bottom:12px;display:flex;align-items:center;gap:10px;}
.blk-tag::before{content:'';display:block;width:18px;height:1px;background:var(--g);}
.blk-h{font-family:var(--D);font-size:clamp(20px,2.5vw,30px);font-weight:600;color:var(--n);margin-bottom:20px;line-height:1.2;}
.blk-p{font-size:14px;font-weight:300;color:var(--tx-prose);line-height:1.95;max-width:820px;}
.blk-p+.blk-p{margin-top:16px;}
.pullq{border-left:3px solid var(--g);padding:18px 30px;margin:28px 0;background:rgba(184,151,58,.04);max-width:800px;}
.pullq p{font-family:var(--D);font-size:21px;font-style:italic;font-weight:300;color:var(--n);line-height:1.55;}
.pullq cite{display:block;font-family:var(--S);font-size:11px;font-style:normal;color:var(--m);margin-top:10px;letter-spacing:1px;}

/* Content grids */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:2px;margin-top:28px;}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:28px;}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-top:28px;}

.card{background:var(--f);padding:32px 28px;border-top:3px solid var(--g);transition:background .2s;}
.card:hover{background:var(--f2);}
.card-ttl{font-size:9.5px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--n);margin-bottom:16px;}
.card ul li{font-size:13px;font-weight:300;color:var(--tx-sub);padding:5px 0;border-bottom:1px solid var(--bdr);line-height:1.6;}
.card ul li:last-child{border-bottom:none;}
.card ul li::before{content:'—';color:var(--g);margin-right:9px;font-weight:600;}

.act-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:28px;}
.act{background:var(--f);padding:22px 20px;display:flex;align-items:flex-start;gap:14px;transition:background .2s;}
.act:hover{background:var(--f2);}
.act-ico{font-size:22px;flex-shrink:0;}
.act-txt{font-size:12px;font-weight:500;color:var(--n);line-height:1.5;}

.focus-g{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;margin-top:28px;}
.focus{background:var(--f);padding:20px;display:flex;align-items:flex-start;gap:16px;border-left:3px solid var(--g);}
.focus-n{font-family:var(--D);font-size:32px;font-weight:300;color:var(--g);line-height:1;flex-shrink:0;width:30px;}
.focus-t{font-size:13px;font-weight:400;color:var(--tx-prose);line-height:1.6;padding-top:5px;}

.timeline{padding-left:36px;position:relative;margin-top:28px;}
.timeline::before{content:'';position:absolute;left:7px;top:0;bottom:0;width:1px;background:linear-gradient(to bottom,var(--g),rgba(184,151,58,.08));}
.tl{position:relative;margin-bottom:15px;display:flex;gap:18px;align-items:baseline;}
.tl::before{content:'';position:absolute;left:-31px;top:7px;width:9px;height:9px;border-radius:50%;background:var(--g);border:2px solid var(--f);}
.tl-y{font-size:9.5px;font-weight:700;letter-spacing:2px;color:var(--g);text-transform:uppercase;white-space:nowrap;min-width:46px;}
.tl-d{font-size:13px;font-weight:300;color:var(--tx-sub);line-height:1.6;}

.tag-wrap{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px;}
.tag{font-size:9.5px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:8px 20px;background:var(--n);color:var(--g2);border-radius:1px;}

.ifooter{background:var(--n);border-top:1px solid rgba(255,255,255,.06);text-align:center;padding:44px 20px;}
.if-name{font-family:var(--D);font-size:20px;font-weight:300;color:var(--g2);letter-spacing:4px;margin-bottom:8px;}
.if-tag{font-size:8px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.18);}

/* ── BLOG ───────────────────────────────────────────────── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.blog-card{background:var(--w);border:1px solid var(--bdr);overflow:hidden;transition:box-shadow .25s;}
.blog-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.1);}
.blog-card-thumb{overflow:hidden;}
.blog-card-thumb img{width:100%;height:220px;object-fit:cover;transition:transform .4s;}
.blog-card:hover .blog-card-thumb img{transform:scale(1.04);}
.blog-card-body{padding:22px 20px 26px;}
.blog-card-meta{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--g);margin-bottom:10px;}
.blog-card-title{font-family:var(--D);font-size:20px;font-weight:600;color:var(--n);margin-bottom:10px;line-height:1.25;}
.blog-card-title a:hover{color:var(--g);}
.blog-card-excerpt{font-size:12px;font-weight:300;color:var(--m);line-height:1.75;margin-bottom:14px;}
.blog-card-more{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--g);transition:letter-spacing .2s;}
.blog-card-more:hover{letter-spacing:3px;}

/* ── NEWSLETTER PAGE ────────────────────────────────────── */
.nl-perks{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-top:32px;}
.nl-perk{background:var(--n);padding:32px 26px;text-align:center;}
.nl-pico{font-size:28px;margin-bottom:12px;}
.nl-pttl{font-size:9.5px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--g2);margin-bottom:8px;}
.nl-pd{font-size:12px;font-weight:300;color:rgba(255,255,255,.38);line-height:1.6;}
.nl-issues{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:2px;}
.nl-issue{background:var(--f);padding:28px 24px;border-top:3px solid var(--g);transition:background .2s;}
.nl-issue:hover{background:var(--f2);}
.iss-meta{font-size:8.5px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--g);margin-bottom:10px;display:flex;justify-content:space-between;align-items:center;}
.iss-lbl{background:var(--n);color:var(--g2);padding:3px 10px;border-radius:1px;font-size:8px;}
.iss-ttl{font-family:var(--D);font-size:19px;font-weight:600;color:var(--n);margin-bottom:10px;line-height:1.25;}
.iss-exc{font-size:12px;font-weight:300;color:var(--m);line-height:1.75;margin-bottom:14px;}
.iss-rd{font-size:9px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--g);transition:letter-spacing .2s,color .2s;cursor:pointer;}
.iss-rd:hover{letter-spacing:3.5px;color:var(--n);}
.nl-full-form{background:var(--n2);padding:60px;display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;border-top:3px solid var(--g);}
.nlff-h{font-family:var(--D);font-size:clamp(24px,3vw,38px);font-weight:300;color:var(--w);margin-bottom:10px;}
.nlff-s{font-size:12px;font-weight:300;color:rgba(255,255,255,.38);line-height:1.7;}
.nl-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;}
.nl-chip{font-size:8.5px;font-weight:700;letter-spacing:2px;text-transform:uppercase;padding:5px 14px;border:1px solid rgba(184,151,58,.28);color:var(--g);border-radius:1px;}

/* ── 404 ────────────────────────────────────────────────── */
.error-404{min-height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 40px;}
.error-404-num{font-family:var(--D);font-size:clamp(120px,20vw,220px);font-weight:300;color:var(--bdr);line-height:1;}
.error-404-h{font-family:var(--D);font-size:clamp(28px,4vw,48px);font-weight:300;color:var(--n);margin:-20px 0 20px;}

/* ── RESPONSIVE ─────────────────────────────────────────── */
@media(max-width:1100px){
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .footer-top{grid-template-columns:1fr 1fr;gap:40px;}
  .svc-intro{grid-template-columns:1fr;}
}
@media(max-width:900px){
  #site-nav{padding:0 28px;}
  .nav-menu,.nav-cta-btn{display:none;}
  .nav-burger{display:flex;}
  .site-hero{grid-template-columns:1fr;}
  .hero-right,.hero-scroll-hint{display:none;}
  .hero-left{min-height:100vh;padding:120px 28px 80px;}
  .home-services,.home-portfolio,.home-testis,.home-stats,.home-brands,.nl-strip,
  .site-footer,.inner-hero,.page-body{padding-left:28px;padding-right:28px;}
  .svc-grid,.port-grid,.nl-issues,.g3,.g4,.blog-grid{grid-template-columns:1fr 1fr;}
  .nl-full-form,.testi-grid{grid-template-columns:1fr;}
  .nl-perks{grid-template-columns:1fr 1fr;}
  .footer-top{grid-template-columns:1fr;}
  .hero-counter{left:28px;}
}
@media(max-width:600px){
  .svc-grid,.port-grid,.nl-issues,.act-grid,.g2,.g3,.g4,.nl-perks,.focus-g,.testi-grid,.blog-grid{grid-template-columns:1fr;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .nl-strip{flex-direction:column;}
  .nl-inline-form{flex-direction:column;width:100%;}
  .nl-inline-form input{border-right:1px solid rgba(255,255,255,.12);border-bottom:none;width:100%;}
  .nl-full-form{padding:36px 24px;gap:32px;}
  .hero-counter{display:none;}
}
@media print{
  #site-nav,.hero-right,.home-stats,.nl-strip,.site-footer{display:none!important;}
}

/* ── HERO BACKGROUND IMAGE SYSTEM ──────────────────────────
   Slide left panel: bg image + cream overlay (layered)
   Right panel: bg image + dark overlay (layered)
   All managed via Customizer — no external deps.
─────────────────────────────────────────────────────────── */

/* Left panel: position context for bg layers */
.hero-left { isolation: isolate; }

/* Per-slide bg image layer — sits below text, above default cream bg */
.hero-slide { position: relative; }
.hero-slide-bg {
  position: absolute; inset: 0; z-index: 0;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}
/* Cream tint overlay — keeps text legible over any image */
.hero-slide-overlay {
  position: absolute; inset: 0; z-index: 1;
  background: var(--f);
  /* opacity set inline from Customizer */
}
/* Actual content sits above bg + overlay */
.hero-slide-content {
  position: relative; z-index: 2;
}
/* When no bg image: hero-slide-bg and hero-slide-overlay are absent,
   hero-slide-content fills naturally — no layout shift */

/* Right panel background image */
.hero-right {
  position: relative;
  /* background-image set inline via wp_head CSS output */
}
/* Dark overlay div — covers bg image with controlled opacity */
.hero-right-overlay {
  position: absolute; inset: 0; z-index: 0;
  background: var(--n);
  /* opacity set via Customizer CSS output, default = 0.82 (full dark) */
}
/* Push content above the overlay */
.hero-right-inner { position: relative; z-index: 1; }

/* ── Customizer admin: image control preview thumbnails ─── */
@media screen and (min-width: 1px) {
  .customize-control-image .attachment-thumb { max-width: 100%; border-radius: 2px; }
}

/* ── TYPOGRAPHY VARIABLE DEFAULTS ───────────────────────────
   Set here as fallbacks; overridden at priority-25 by
   customizer.php wp_head output when settings differ.
─────────────────────────────────────────────────────────── */
/* Typography vars defined in main :root above */
/* Apply display weight + tracking to all heading elements */
h1, h2, h3, h4, h5, h6,
.hero-h1, .ih-h1, .svc-h, .blk-h,
.testi-body, .pullq p,
.f-brand, .logo-main, .stat-n {
  font-weight:     var(--fw-display);
  letter-spacing:  var(--trk-display);
}
/* Apply body weight to prose elements */
.blk-p, .svc-desc, .svc-body,
.hero-body, .ih-sub, .testi-role,
.iss-exc, .nl-pd, .f-ci-text {
  font-weight: var(--fw-body);
}
