/* ===== SUBPAGE SHARED STYLES ===== */

/* Subpage hero — standard layout for all solution/service pages */
.sub-hero{position:relative;padding:100px 0 80px;background:linear-gradient(180deg,var(--navy) 0%,var(--navy2) 100%);overflow:hidden}
.sub-hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 70%;z-index:0;filter:blur(1.5px);transform:scale(1.02)}
.sub-hero-overlay{position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse 80% 60% at 20% 50%,rgba(37,99,235,.12),transparent),radial-gradient(ellipse 60% 50% at 80% 30%,rgba(244,121,32,.08),transparent),radial-gradient(ellipse 100% 100% at 50% 100%,rgba(11,17,32,.9),transparent),linear-gradient(180deg,rgba(11,17,32,.82) 0%,rgba(16,24,40,.88) 100%)}
.sub-hero .ctn{position:relative;z-index:2;display:grid;grid-template-columns:1.2fr .8fr;gap:60px;align-items:center}
.sub-hero-text{max-width:640px}
.sub-hero-crumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--g400);margin-bottom:20px;font-weight:500}
.sub-hero-crumb a{color:var(--g400);transition:color .2s}
.sub-hero-crumb a:hover{color:var(--orange)}
.sub-hero-crumb i{font-size:9px;color:var(--g600)}
.sub-hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;border-radius:50px;background:rgba(244,121,32,.1);border:1px solid rgba(244,121,32,.25);color:var(--orange);font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:22px;opacity:0;transform:translateY(20px);animation:subHeroFadeUp .7s .2s cubic-bezier(.16,1,.3,1) forwards}
.sub-hero h1{font-size:clamp(34px,5vw,56px);font-weight:800;line-height:1.08;letter-spacing:-.03em;color:var(--white);margin-bottom:20px;opacity:0;transform:translateY(30px);animation:subHeroFadeUp .8s .45s cubic-bezier(.16,1,.3,1) forwards}
.sub-hero h1 span{background:linear-gradient(135deg,var(--orange),var(--orange-g));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.sub-hero-sub{font-size:18px;color:var(--g200);line-height:1.7;margin-bottom:30px;opacity:0;transform:translateY(20px);animation:subHeroFadeUp .8s .7s cubic-bezier(.16,1,.3,1) forwards}
.sub-hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:8px}
.sub-hero-cta .btn-primary{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;border-radius:50px;background:var(--orange);color:var(--white)!important;font-size:15px;font-weight:700;transition:all .3s;border:2px solid var(--orange);opacity:0;transform:translateX(-40px);animation:subHeroSlideLeft .9s .95s cubic-bezier(.16,1,.3,1) forwards}
.sub-hero-cta .btn-primary:hover{background:transparent;transform:translateY(-2px);box-shadow:0 0 24px rgba(244,121,32,.4)}
.sub-hero-cta .btn-outline{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;border-radius:50px;border:2px solid rgba(255,255,255,.2);color:var(--white)!important;font-size:15px;font-weight:700;transition:all .3s;opacity:0;transform:translateX(40px);animation:subHeroSlideRight .9s 1.1s cubic-bezier(.16,1,.3,1) forwards}
.sub-hero-cta .btn-outline:hover{border-color:var(--orange);background:rgba(244,121,32,.05)}

/* Hero entrance keyframes */
@keyframes subHeroFadeUp{to{opacity:1;transform:translateY(0)}}
@keyframes subHeroSlideLeft{to{opacity:1;transform:translateX(0)}}
@keyframes subHeroSlideRight{to{opacity:1;transform:translateX(0)}}
@keyframes subHeroBubbleIn{0%{opacity:0;transform:scale(.7) rotate(-10deg)}100%{opacity:1;transform:scale(1) rotate(0)}}

/* Hero visual (right side) */
.sub-hero-visual{display:flex;align-items:center;justify-content:center;position:relative;opacity:0;animation:subHeroBubbleIn .9s .4s cubic-bezier(.16,1,.3,1) forwards}
.sub-hero-visual .icon-bubble{width:280px;height:280px;border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(244,121,32,.2),rgba(37,99,235,.15) 60%,transparent 80%);display:flex;align-items:center;justify-content:center;position:relative;animation:subHeroBubbleFloat 6s 1.3s ease-in-out infinite}
@keyframes subHeroBubbleFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.sub-hero-visual .icon-bubble::before{content:'';position:absolute;inset:-20px;border:1px dashed rgba(255,255,255,.08);border-radius:50%;animation:rotateSlow 20s linear infinite}
.sub-hero-visual .icon-bubble::after{content:'';position:absolute;inset:-50px;border:1px dashed rgba(244,121,32,.15);border-radius:50%;animation:rotateSlow 30s linear infinite reverse}
.sub-hero-visual .icon-bubble i{font-size:110px;color:var(--orange);filter:drop-shadow(0 0 30px rgba(244,121,32,.3))}
@keyframes rotateSlow{to{transform:rotate(360deg)}}

/* Features grid — moving grid (squares) bg */
.sub-features{padding:80px 0;background:var(--navy);position:relative;overflow:hidden}
.sub-features::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:60px 60px;animation:gridDrift 25s linear infinite;pointer-events:none;z-index:0}
.sub-features::after{content:'';position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(244,121,32,.06),transparent 70%);top:-150px;right:-150px;pointer-events:none;z-index:0;filter:blur(40px);animation:glowPulse 8s ease-in-out infinite alternate}
.sub-features .ctn{position:relative;z-index:2}
.sub-features-head{text-align:center;max-width:720px;margin:0 auto 56px}
.sub-features-head h2{font-size:clamp(28px,3.5vw,42px);font-weight:800;color:var(--white);margin-bottom:16px;letter-spacing:-.02em}
.sub-features-head p{font-size:17px;color:var(--g400);line-height:1.7}
.sub-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.sub-feature{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:18px;padding:32px 28px;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}
.sub-feature::before{content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(244,121,32,.1),transparent);transition:left .7s cubic-bezier(.4,0,.2,1);pointer-events:none}
.sub-feature:hover::before{left:150%}
.sub-feature:hover{transform:translateY(-8px);border-color:rgba(244,121,32,.4);background:rgba(244,121,32,.04);box-shadow:0 16px 40px rgba(244,121,32,.12),0 0 0 1px rgba(244,121,32,.1)}
.sub-feature>*{position:relative;z-index:1}
.sub-feature-ico{width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,rgba(244,121,32,.15),rgba(255,154,68,.08));display:flex;align-items:center;justify-content:center;color:var(--orange);font-size:22px;margin-bottom:20px;transition:all .4s cubic-bezier(.4,0,.2,1)}
.sub-feature:hover .sub-feature-ico{transform:translateY(-4px) scale(1.08) rotate(-5deg);background:linear-gradient(135deg,var(--orange),var(--orange-g));color:var(--white);box-shadow:0 8px 24px rgba(244,121,32,.4)}
/* Stagger reveals — 2nd and 3rd cards delayed */
.sub-features-grid .sub-feature:nth-child(2){transition-delay:.12s}
.sub-features-grid .sub-feature:nth-child(3){transition-delay:.24s}
.sub-feature h3{font-size:20px;font-weight:700;color:var(--white);margin-bottom:12px}
.sub-feature p{font-size:15px;color:var(--g400);line-height:1.7}

/* Benefits block — stats-inspired bg: moving image + scrolling lines (no rotating gradient) */
.sub-benefits{padding:80px 0;background:linear-gradient(135deg,var(--navy3) 0%,var(--navy2) 100%);position:relative;overflow:hidden}
.sub-benefits::before{content:'';position:absolute;inset:0;background:url('/sections/stats/assets/desktop/stats-bg.jpg') center/cover no-repeat;opacity:.08;animation:subBenefitsBgMove 20s ease-in-out infinite alternate;pointer-events:none;z-index:0}
.sub-benefits::after{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(90deg,rgba(255,255,255,.05) 0,rgba(255,255,255,.05) 1px,transparent 1px,transparent 120px);animation:subBenefitsLineScroll 20s linear infinite;pointer-events:none;z-index:0}
@keyframes subBenefitsBgMove{0%{transform:scale(1.15) translate(0,0)}50%{transform:scale(1.25) translate(-3%,2%)}100%{transform:scale(1.15) translate(2%,-2%)}}
@keyframes subBenefitsLineScroll{to{transform:translateX(120px)}}
.sub-benefits .ctn{max-width:1000px;position:relative;z-index:1}
.sub-benefits-wrap{background:rgba(11,17,32,.45);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:2px solid rgba(244,121,32,.3);border-radius:24px;padding:48px 44px;box-shadow:0 16px 40px rgba(0,0,0,.25);position:relative;overflow:hidden;transition:all .5s cubic-bezier(.4,0,.2,1);animation:benefitsPulse 4s ease-in-out infinite}
/* Shine sweep — bright band that crosses the card when it enters view */
.sub-benefits-wrap::before{content:'';position:absolute;top:0;left:-80%;width:70%;height:100%;background:linear-gradient(90deg,transparent,rgba(244,121,32,.25) 40%,rgba(255,154,68,.3) 50%,rgba(244,121,32,.25) 60%,transparent);pointer-events:none;transition:left 1.6s cubic-bezier(.16,1,.3,1);z-index:0;filter:blur(1px)}
.sub-benefits-wrap.sr.vis::before{left:180%}
.sub-benefits-wrap>*{position:relative;z-index:1}
/* Continuous strong border glow pulse */
@keyframes benefitsPulse{0%,100%{border-color:rgba(244,121,32,.3);box-shadow:0 16px 40px rgba(0,0,0,.25),0 0 0 rgba(244,121,32,0),inset 0 0 0 rgba(244,121,32,0)}50%{border-color:rgba(244,121,32,.7);box-shadow:0 16px 40px rgba(0,0,0,.25),0 0 40px rgba(244,121,32,.25),inset 0 0 30px rgba(244,121,32,.05)}}
/* Hover — clear lift and stronger glow */
.sub-benefits-wrap:hover{transform:translateY(-6px) scale(1.01);border-color:rgba(244,121,32,.85);box-shadow:0 24px 56px rgba(0,0,0,.4),0 0 60px rgba(244,121,32,.3),inset 0 0 40px rgba(244,121,32,.08)}
.sub-benefits-wrap h2{font-size:clamp(26px,3.2vw,38px);font-weight:800;color:var(--white);margin-bottom:12px;letter-spacing:-.02em}
.sub-benefits-wrap .intro{font-size:16px;color:var(--g200);line-height:1.7;margin-bottom:32px;font-style:italic;border-left:3px solid var(--orange);padding-left:16px}
.sub-benefits-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:14px 28px;padding:0;margin:0}
.sub-benefits-list li{display:flex;align-items:flex-start;gap:12px;font-size:15px;color:var(--g200);line-height:1.5}
.sub-benefits-list li .ico{flex-shrink:0;width:32px;height:32px;border-radius:8px;background:rgba(244,121,32,.12);display:flex;align-items:center;justify-content:center;color:var(--orange);font-size:13px;margin-top:2px}

/* Related solutions — solutions-inspired bg: horizontal shimmer sweep + breathing mesh */
.sub-related{padding:80px 0;background:var(--navy);position:relative;overflow:hidden}
.sub-related::before{content:'';position:absolute;inset:0 auto 0 -60%;width:60%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.04),rgba(255,255,255,.08),rgba(255,255,255,.04),transparent);animation:subRelatedSweep 8s ease-in-out infinite;pointer-events:none;z-index:0}
.sub-related::after{content:'';position:absolute;inset:-20%;background:radial-gradient(ellipse 600px 400px at 20% 30%,rgba(37,99,235,.12),transparent),radial-gradient(ellipse 500px 500px at 80% 60%,rgba(37,99,235,.10),transparent),radial-gradient(ellipse 400px 300px at 50% 80%,rgba(59,130,246,.08),transparent);animation:subRelatedMesh 12s ease-in-out infinite;pointer-events:none;z-index:0}
@keyframes subRelatedSweep{0%,100%{left:-60%}50%{left:100%}}
@keyframes subRelatedMesh{0%,100%{transform:translate(0,0) rotate(0deg)}33%{transform:translate(30px,-20px) rotate(1deg)}66%{transform:translate(-20px,15px) rotate(-1deg)}}
.sub-related .ctn{position:relative;z-index:1}
.sub-related-head{text-align:center;max-width:640px;margin:0 auto 48px}
.sub-related-head h2{font-size:clamp(26px,3vw,36px);font-weight:800;color:var(--white);margin-bottom:12px;letter-spacing:-.02em}
.sub-related-head p{font-size:16px;color:var(--g400)}
.sub-related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.sub-related-card{display:flex;align-items:center;gap:14px;padding:20px 22px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:14px;transition:all .4s cubic-bezier(.4,0,.2,1);color:var(--white)!important;position:relative;overflow:hidden}
.sub-related-card::before{content:'';position:absolute;top:0;left:-100%;width:40%;height:100%;background:linear-gradient(90deg,transparent,rgba(244,121,32,.1),transparent);transition:left .6s cubic-bezier(.4,0,.2,1);pointer-events:none}
.sub-related-card:hover::before{left:150%}
.sub-related-card:hover{transform:translateX(6px) translateY(-2px);border-color:rgba(244,121,32,.4);background:rgba(244,121,32,.05);box-shadow:0 8px 24px rgba(244,121,32,.1)}
.sub-related-card>*{position:relative;z-index:1}
.sub-related-card .rc-ico{flex-shrink:0;width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,rgba(244,121,32,.15),rgba(37,99,235,.1));display:flex;align-items:center;justify-content:center;color:var(--orange);font-size:16px;transition:all .4s cubic-bezier(.4,0,.2,1)}
.sub-related-card:hover .rc-ico{background:linear-gradient(135deg,var(--orange),var(--orange-g));color:var(--white);transform:rotate(-8deg) scale(1.05)}
/* Stagger reveals */
.sub-related-grid .sub-related-card:nth-child(2){transition-delay:.1s}
.sub-related-grid .sub-related-card:nth-child(3){transition-delay:.2s}
.sub-related-card .rc-txt{display:flex;flex-direction:column;gap:4px;min-width:0}
.sub-related-card .rc-txt strong{font-size:15px;font-weight:700;color:var(--white);line-height:1.2}
.sub-related-card .rc-txt span{font-size:12px;color:var(--g400);line-height:1.3}

/* Responsive */
@media(min-width:768px) and (max-width:1024px){
  .sub-hero .ctn{grid-template-columns:1fr;text-align:center}
  .sub-hero-text{max-width:100%;margin:0 auto}
  .sub-hero-cta{justify-content:center}
  .sub-hero-visual .icon-bubble{width:220px;height:220px}
  .sub-hero-visual .icon-bubble i{font-size:80px}
  .sub-features-grid{grid-template-columns:1fr 1fr}
  .sub-related-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .sub-hero{padding:60px 0 50px}
  .sub-hero .ctn{grid-template-columns:1fr;gap:30px;text-align:center}
  .sub-hero-text{max-width:100%;margin:0 auto}
  .sub-hero-cta{justify-content:center}
  .sub-hero-crumb{justify-content:center}
  .sub-hero-badge{margin:0 auto 18px}
  .sub-hero-visual{order:-1}
  .sub-hero-visual .icon-bubble{width:180px;height:180px}
  .sub-hero-visual .icon-bubble i{font-size:70px}
  .sub-features{padding:60px 0}
  .sub-features-grid{grid-template-columns:1fr;gap:16px}
  .sub-feature{padding:24px 20px}
  .sub-benefits{padding:60px 0}
  .sub-benefits-wrap{padding:32px 22px}
  .sub-benefits-list{grid-template-columns:1fr}
  .sub-related{padding:60px 0}
  .sub-related-grid{grid-template-columns:1fr}
}
