/* ══ HERO ══ */
#s-hero{min-height:100vh;background:var(--bg);position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center;padding:108px 5% 72px;}
.hero-dots{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(97,64,230,0.13) 1px,transparent 1px);background-size:28px 28px;mask-image:radial-gradient(ellipse 80% 80% at 68% 44%,black 0%,transparent 100%);pointer-events:none;z-index:0;}
.hero-glow{position:absolute;top:-160px;right:-100px;width:740px;height:740px;border-radius:50%;background:radial-gradient(circle,rgba(97,64,230,0.1) 0%,transparent 68%);pointer-events:none;z-index:0;animation:glowpulse 9s ease-in-out infinite;}
@keyframes glowpulse{0%,100%{opacity:.8;transform:scale(1);}50%{opacity:1;transform:scale(1.06);}}

/* Ghost industry names — RIGHT side, capped so they never reach the side nav as.
   Right edge stops at 80px from viewport edge (side nav sits at right:20px, a is 40px wide) */
.hero-ghost-stack{display:none;}
.hero-ghost-name{
  font-size:clamp(24px,3.8vw,60px);
  font-weight:900;
  letter-spacing:-.04em;
  line-height:1.06;
  -webkit-text-stroke:1px rgba(14,13,11,0.06);
  color:transparent;
  white-space:nowrap;
  text-align:right;
}

/* foreground headline — left side, well within bounds */
.hero-inner{max-width:1280px;margin:0 auto;width:100%;align-items:center;position:relative;z-index:2;display:flex;justify-content:center;}
.hero-bottom-row{display:flex;flex-direction:column;}
.hero-body{margin-bottom:0!important;}
.hero-left{width:100%;}
/* RIGHT SIDE — photo visual composition */
.hero-visual{position:relative;height:500px;margin-left:50px;}
.hv-shape{position:absolute;top:-28px;right:-28px;width:200px;height:200px;border-radius:28px;background:var(--ac);opacity:.07;z-index:0;}
.hv-dots{position:absolute;top:24px;left:-4px;width:84px;height:84px;background-image:radial-gradient(circle,var(--ac) 1.5px,transparent 1.5px);background-size:12px 12px;opacity:.22;z-index:0;}
.hv-main{position:absolute;top:0;right:0;width:88%;height:360px;border-radius:22px;overflow:hidden;box-shadow:0 28px 72px rgba(14,13,11,0.15);z-index:2;}
.hv-main figure{height:100%;}
.hv-main figure .vc_single_image-wrapper{height:100%;}
.hv-main img{width:100%;height:100%!important;object-fit:cover;display:block;transition:transform .75s cubic-bezier(.4,0,.2,1);}
.hv-main:hover img{transform:scale(1.05);}
.hv-float{position:absolute;bottom:0;left:0;width:52%;height:180px;border-radius:18px;overflow:hidden;box-shadow:0 16px 48px rgba(14,13,11,0.13);border:5px solid var(--bg);z-index:3;}
.hv-float img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .75s cubic-bezier(.4,0,.2,1);}
.hv-float:hover img{transform:scale(1.06);}
.hv-badge{position:absolute;bottom:110px;right:4px;background:#fff;border-radius:16px;padding:16px 20px;box-shadow:0 8px 32px rgba(14,13,11,0.12);border:1px solid var(--br);z-index:4;animation:bf 4s ease-in-out infinite;}
@keyframes bf{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}
.hv-badge-num{font-size:20px;font-weight:900;color:var(--t1);letter-spacing:-.04em;line-height:1;}
.hv-badge-lbl{font-size:11px;font-weight:500;color:var(--t3);margin-top:3px;}
.hv-badge-ac{color:var(--ac);font-weight:700;}
@media(max-width:900px){.hero-inner{grid-template-columns:1fr;}.hero-visual{height:280px;margin-top:32px;}}
.hero-kicker{font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--ac);display:flex;align-items:center;gap:12px;margin-bottom:clamp(16px,2vw,28px);}
.hero-kicker::before{content:"";width:28px;height:1.5px;background:var(--ac);}
.hero-h1{font-family:'Outfit',sans-serif!important;font-size:clamp(40px,6.5vw,92px);font-weight:900;line-height:.92;letter-spacing:-.05em;color:var(--t1);}
.hero-h1 em{font-style:normal;font-weight:300;color:var(--ac);}  /* keep violet */
.hero-sub{font-size:clamp(13px,1.4vw,16px);font-weight:400;color:var(--t2);line-height:1.8;max-width:440px;margin-top:clamp(14px,2vw,24px);}
.hero-count-badge{display:inline-flex;align-items:center;gap:12px;background:rgba(97,64,230,0.08);border:1px solid rgba(97,64,230,0.22);border-radius:100px;padding:10px 20px;margin-top:clamp(20px,2.5vw,36px);}
.hero-count-num{font-size:22px;font-weight:900;color:var(--ac);letter-spacing:-.04em;line-height:1;}
.hero-count-lbl{font-size:12px;font-weight:600;color:var(--t3);letter-spacing:.04em;}

/* scroll indicator — bottom LEFT, well clear of the badge */
.hero-scroll-wrap{
  position:absolute;
  bottom:-88px;   /* near the bottom */
  left:5%;
  display:flex;align-items:center;gap:12px;z-index:3;
}
.hero-scroll-line{width:40px;height:1px;background:rgba(14,13,11,0.18);position:relative;overflow:hidden;}
.hero-scroll-line::after{content:"";position:absolute;top:0;left:-100%;height:100%;width:100%;background:var(--ac);animation:scrollL 2.4s cubic-bezier(.4,0,.2,1) infinite;}
@keyframes scrollL{0%{left:-100%;}50%{left:0%;}100%{left:100%;}}
.hero-scroll-txt{font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--t3);}

/* MARQUEE */
.marquee-wrap{background:var(--ac);padding:12px 0;overflow:hidden;white-space:nowrap;position:relative;z-index:10;}
.mq-track{display:inline-flex;animation:mq 32s linear infinite;}
.mq-item{font-size:11px;font-weight:700;letter-spacing:.14em;color:rgba(255,255,255,0.8);text-transform:uppercase;padding:0 26px;display:inline-flex;align-items:center;gap:14px;}
.mq-item::after{content:"✦";font-size:7px;opacity:.5;}
@keyframes mq{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* ══ STATEMENT ══ */
#s-statement{background:var(--bg);padding:clamp(80px,12vw,140px) 5% clamp(60px,8vw,100px);position:relative;overflow:hidden;}
.stmt-quote-deco{position:absolute;bottom:-60px;left:3%;font-size:clamp(200px,28vw,400px);font-weight:900;line-height:1;color:rgba(14,13,11,0.03);letter-spacing:-.05em;pointer-events:none;user-select:none;font-family:"Outfit",sans-serif;}
.stmt-inner{max-width:1200px;margin:0 auto;position:relative;z-index:1;}
.stmt-kicker{font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--ac);display:flex;align-items:center;gap:10px;margin-bottom:clamp(24px,3vw,44px);}
.stmt-kicker::before{content:"";width:20px;height:1.5px;background:var(--ac);}
.stmt-text{font-family:"Outfit",sans-serif;font-size:clamp(32px,5vw,72px);font-weight:900;line-height:1.08;letter-spacing:-.04em;color:var(--t1);}
.word{display:inline;background:linear-gradient(to right,var(--t1) 50%,rgba(14,13,11,0.13) 50%);background-size:200% 100%;background-position:100% 0;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transition:background-position .5s cubic-bezier(.4,0,.2,1);}
.word.filled{background-position:0% 0;}
.word-ac{display:inline;-webkit-text-fill-color:var(--ac);color:var(--ac);}
.stmt-sub{margin-top:clamp(32px,5vw,56px);display:grid;grid-template-columns:140px 1fr;gap:0 40px;border-top:1px solid var(--br);padding-top:clamp(24px,3vw,40px);align-items:start;}
.stmt-sub-lbl{font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--t3);padding-top:3px;line-height:1.6;}
.stmt-sub-body{font-size:clamp(14px,1.8vw,17px);font-weight:400;color:var(--t2);line-height:1.82;}
.stmt-sub-body strong{font-weight:700;color:var(--t1);}

/* ══ INDUSTRIES — STACKED STRIPS ══ */
#s-industries{background:var(--bg2);position:relative;}
#s-industries >.vc_column_container >.vc_column-inner{padding:0!important;}
.ind-strip{
  position:relative;
  height:clamp(220px,30vw,400px);
  overflow:hidden;
  cursor:none;
  border-bottom:1px solid var(--br);
}
.ind-strip:last-child{border-bottom:none;}

/* photo layer */
.ind-bg{position:absolute;inset:0;z-index:0;}
.ind-bg img{width:100%;height:100%;object-fit:cover;filter:saturate(.7) brightness(.55);transition:filter .7s cubic-bezier(.4,0,.2,1),transform .9s cubic-bezier(.4,0,.2,1);transform:scale(1.04);}
.ind-strip:hover .ind-bg img{filter:saturate(.85) brightness(.65);transform:scale(1.0);}

/* SCROLL-TRIGGERED BG REVEAL — dark panel wipes upward (scaleY 1→0 from top) */
.ind-reveal-overlay{position:absolute;inset:0;z-index:1;background:var(--bg2);transform-origin:top center;transform:scaleY(1);transition:transform .85s cubic-bezier(.77,0,.18,1);will-change:transform;}
.ind-strip.revealed .ind-reveal-overlay{transform:scaleY(0);}

/* violet tint — z:2 sits above photo, below content */
.ind-tint{position:absolute;inset:0;z-index:2;background:linear-gradient(105deg,rgba(14,13,11,0.72) 0%,rgba(97,64,230,0.25) 55%,rgba(14,13,11,0.38) 100%);pointer-events:none;}

/* MARQUEE — z:3, between tint and foreground content.
   It IS intentionally behind the number/tag/desc which sit at z:4.
   The ghost text IS the background texture — not meant to be fully readable. */
.ind-marquee-wrap{
  position:absolute;
  top:50%;left:0;right:0;
  transform:translateY(-50%);
  z-index:3;
  overflow:hidden;
  white-space:nowrap;
  pointer-events:none;
}
/* SLOWED DOWN: was 18s/9s, now 38s/20s — comfortable, not dizzy */
.ind-marquee-track{
  display:inline-flex;align-items:center;
  animation:indmq 38s linear infinite;
}
/* hover speed change removed — prevents animation restart glitch */
@keyframes indmq{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

.ind-name-item{
  font-size:clamp(80px,13vw,200px);
  font-weight:900;
  letter-spacing:-.05em;
  line-height:.88;
  /* ghost outline — deliberately semi-visible, wallpaper effect */
  -webkit-text-stroke:1.5px rgba(255,255,255,0.18);
  color:transparent;
  padding:0 clamp(32px,4vw,60px);
  white-space:nowrap;
  transition:-webkit-text-stroke .4s;
  display:inline-block;
}
.ind-strip:hover .ind-name-item{-webkit-text-stroke:2px rgba(97,64,230,0.55);}

/* FOREGROUND content — z:4, always on top of the ghost marquee */
.ind-left{
  position:absolute;
  left:5%;
  top:50%;transform:translateY(-50%);
  z-index:4;
  display:flex;flex-direction:column;gap:10px;
  /* cap width so it doesn't bleed into marquee area visually */
  max-width:320px;
}
.ind-num{
  font-size:clamp(52px,7vw,100px);font-weight:900;line-height:.85;letter-spacing:-.07em;
  -webkit-text-stroke:1px rgba(255,255,255,0.14);color:transparent;
  transition:-webkit-text-stroke .4s,color .4s;
}
.ind-strip:hover .ind-num{-webkit-text-stroke:1px rgba(97,64,230,0.55);color:rgba(97,64,230,0.06);}
.ind-meta{display:flex;flex-direction:column;gap:6px;}
.ind-tag{font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--ac);}
.ind-name-label{
  font-size:clamp(13px,1.5vw,17px);font-weight:800;color:#F7F6F3;
  line-height:1.2;letter-spacing:-.02em;
  /* slight text shadow so it lifts above the ghost marquee clearly */
  text-shadow:0 2px 12px rgba(14,13,11,0.8);
}
.ind-desc{font-size:clamp(11px,1.1vw,13px);font-weight:400;color:rgba(247,246,243,0.5);line-height:1.6;text-shadow:0 1px 8px rgba(14,13,11,0.9);}

/* accent bar bottom */
.ind-strip::after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--ac);transform:scaleX(0);transform-origin:left;transition:transform .55s cubic-bezier(.4,0,.2,1);z-index:5;}
.ind-strip:hover::after{transform:scaleX(1);}

/* ══ CTA — LIGHT VERSION with scroll-triggered white reveal ══ */
/* The section itself is light bg. A dark overlay sits on top initially,
   then wipes upward (scaleY 1→0 from top) to reveal the light content beneath. */
#s-cta{
  padding:120px 5%;
  background:var(--bg);
  position:relative;overflow:hidden;text-align:center;
}
/* dark curtain overlay — wipes away (scaleY 1→0 from top) to reveal light CTA */
.cta-reveal{
  position:absolute;
  top:-120px;
  bottom:-120px;
  left:-5%;
  right:-5%;
  z-index:1;
  background:var(--dark);
  transform-origin:top center;
  transform:scaleY(1);
  transition:transform 1s cubic-bezier(.77,0,.18,1);
  will-change:transform;
}
#s-cta.cta-revealed .cta-reveal{transform:scaleY(0);}
/* subtle dot grid on light bg */
.cta-dot-bg{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(97,64,230,0.08) 1px,transparent 1px);background-size:28px 28px;pointer-events:none;z-index:0;}
/* decorative violet circle glow */
.cta-circle{position:absolute;bottom:-200px;left:-200px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(97,64,230,0.07) 0%,transparent 65%);pointer-events:none;z-index:0;}
.cta-wm{display:none;}
.cta-in{max-width:820px;margin:0 auto;position:relative;z-index:2;}
.cta-lbl{font-size:11px;font-weight:700;letter-spacing:.2em;color:var(--ac);text-transform:uppercase;margin-bottom:20px;}
.cta-title{font-family:'Outfit',sans-serif!important;font-size:clamp(36px,5vw,64px);font-weight:900;color:var(--t1);line-height:1.0;letter-spacing:-.04em;margin-bottom:22px;}
.cta-title em{font-style:normal;font-weight:300;color:var(--ac);}
.cta-body-txt{font-size:16px;color:var(--t2);line-height:1.8;margin-bottom:44px;max-width:520px;margin-left:auto;margin-right:auto;}
.cta-btns{display:flex;gap:14px;justify-content:center;}
.btn-cm a{padding:16px 36px!important;background:var(--ac)!important;color:#fff!important;font-size:15px!important;font-weight:700!important;border-radius:100px!important;text-decoration:none;cursor:none!important;box-shadow:0 4px 24px rgba(97,64,230,0.35)!important;transition:background .25s,transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .25s!important;display:inline-flex!important;align-items:center;gap:8px;}
.btn-cm a::after{content:"→";transition:transform .22s;}
.btn-cm a:hover{background:#4f30c8;transform:scale(1.05);box-shadow:0 8px 36px rgba(97,64,230,0.5);}
.btn-cm a:hover::after{transform:translateX(4px);}
.btn-cg a{padding:16px 28px!important;background:transparent!important;color:var(--t2)!important;font-size:15px;text-decoration:none;border:1.5px solid var(--br);border-radius:100px;cursor:none;display:inline-flex!important;align-items:center;gap:8px;transition:all .25s!important;}
.btn-cg a:hover{color:var(--ac);border-color:var(--acb);}
.btn-cg a::after{content:"→";}






























/* RESPONSIVE */
@media screen and (max-width: 1440px) {
		
}


@media screen and (min-width: 1241px) and (max-width: 1440px) {
		
}


@media screen and (max-width: 1240px) {
		
}


@media screen and (max-width:  1024px) {
    #s-hero{padding:108px 3% 45px;}
	.hero-visual{margin-left:15px;}
	.eyebrow{font-size:10px;}
	.hero-h1 h1{font-size:clamp(32px, 6vw, 45px);}
	.hero-body{margin-bottom:10px!important;}
	.hero-body p{font-size:13px;line-height:1.5;}
	.hero-body-2{margin-bottom:20px!important;}
	.hero-body-2 p{font-size:12px;line-height:1.5;}
	.hv-main{width:77%;height:300px;margin-bottom:0!important;}
  .hv-main figure,.hv-main figure .vc_single_image-wrapper{height:100%;}
  .hv-main img{height:100%!important;}
	.hv-float{bottom:30%;width:50%;height:150px;}
    .hv-float figure{height:100%;}
    .hv-float figure .vc_single_image-wrapper{height:100%;}
    .hv-float img{height:100%!important;}
	.hv-badge{bottom:150px;right:10px;padding:12px 15px;}
	.hv-badge-v{font-size:18px;}
	.hv-badge-l{font-size:10px;}
    .hero-scroll-wrap{bottom:-78px;}

  .stmt-quote-deco{left:-3%;font-size:15vw;}

  .btn-cm a,.btn-cg a{padding: 10px 20px !important;}
}


@media screen and (max-width:  900px) {
  #s-hero{padding:80px 1% 25px}
	.hero-h1{margin-bottom:15px!important;}
	.hero-h1 h1{font-size:clamp(22px, 5vw, 40px)}
	.hv-shape{top:-15px;right:-15px;width:150px;height:150px;}
	.hv-dots{left:10%;width:64px;height:64px;}
	.hv-main{width: 70%;height:250px;}
	.hv-float{bottom:0%;left:10px;width:40%;height:90px;}
	.hv-badge{bottom:7%;padding:10px;margin-bottom:0!important;}
	.hv-badge-v{font-size:14px;}
	.hv-badge-l{font-size:9px;}
    .hero-count-badge{padding:7px 14px;gap:7px;}
    .hero-count-num{font-size:17px;}
    .hero-count-lbl{font-size:11px;}

	.marquee-wrap{padding:9px 0;margin-bottom:0!important;}
	.mq-item{font-size:10px;padding:0 7px;}

    #s-statement{padding:50px 0;}
    .stmt-quote-deco{bottom:55px;}

  

	#s-cta{padding:30px 1%};
	#s-cta .vc_column-inner .wpb_text_column{margin-bottom:15px!important;}
	.cta-title{font-size:clamp(36px,4vw,64px);}
	.cta-body-txt{font-size:14px;line-height:1.5;}
  .cta-wm{font-size:18vw;bottom:10%;}
}


@media screen and (max-width:  600px) {
	.hero-inner{flex-direction:column-reverse;align-items:center;}
	.hero-visual{height: 380px;margin-left:0;}
	.hv-float{bottom:20%;}
	.hv-badge{bottom:25%;}
	.hero-h1{font-size:clamp(25px, 5vw, 40px);;font-weight:700;line-height:1.2;}
	#s-hero .vc_column_container>.vc_column-inner{padding-left:10px!important;padding-right:10px!important;}
	.btn-hp a,.btn-hg a{font-size:11px!important;padding:7px 15px !important;}

  .stmt-text{font-weight:700;}
	
	#s-cta .vc_column_container>.vc_column-inner{padding-left:0!important;padding-right:0!important;}
  .cta-bg-img{top:-30px;bottom:-30px;}
  .cta-bg-img .vc_column_container{height:100%;}
	.cta-in .wpb_text_column{margin-bottom: 15px!important;}
	.cta-title{font-size:clamp(30px,4vw,54px);font-weight:700;letter-spacing:unset;}
	.cta-body-txt{font-size:12px;}
  .btn-cm a,.btn-cg a{padding:7px 15px !important;font-size:12px!important;}
	
}


@media screen and (max-width:  375px) {
	
}


@media screen and (max-width:  320px) {
		.mgd-rows{display:flex;flex-direction:column;}

    .cta-in{padding:15px;}
    .cta-title{font-size:20px;}
}
