/* === homepage page styles === */
.hero-carousel{position:relative;height:100vh;min-height:680px;overflow:hidden;background:var(--black)}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease-in-out;pointer-events:none}.hero-slide--active{opacity:1;pointer-events:auto}
.hero-slide__img{position:absolute;inset:0}.hero-slide__img img{width:100%;height:100%;object-fit:cover}
.hero-slide--active .hero-slide__img img{animation:slowZoom 12s ease-out forwards}
@keyframes slowZoom{from{transform:scale(1)}to{transform:scale(1.06)}}
.hero-slide__overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(0,0,0,.3) 0%,rgba(0,0,0,.05) 35%,rgba(0,0,0,.55) 100%)}
.hero-slide__content{position:absolute;inset:0;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:0 40px}
.hero-slide__eyebrow{font-size:13px;font-weight:500;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:18px;opacity:0;transform:translateY(20px)}
.hero-slide--active .hero-slide__eyebrow{animation:fadeUp .8s var(--ease) .3s forwards}
.hero-slide__title{font-size:clamp(32px,5vw,62px);font-weight:800;line-height:1.08;color:#fff;margin-bottom:20px;letter-spacing:-1px;max-width:780px;opacity:0;transform:translateY(30px)}
.hero-slide--active .hero-slide__title{animation:fadeUp .9s var(--ease) .5s forwards}
.hero-slide__desc{font-size:clamp(14px,1.5vw,17px);font-weight:300;line-height:1.8;color:rgba(255,255,255,.6);max-width:560px;margin-bottom:36px;opacity:0;transform:translateY(20px)}
.hero-slide--active .hero-slide__desc{animation:fadeUp .9s var(--ease) .7s forwards}
.hero-slide__actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;opacity:0;transform:translateY(20px)}
.hero-slide--active .hero-slide__actions{animation:fadeUp .9s var(--ease) .9s forwards}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
.hero-nav{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:20;display:flex;gap:8px}
.hero-dot{width:32px;height:3px;background:rgba(255,255,255,.3);border:none;cursor:pointer;border-radius:2px;transition:all .4s;padding:0}.hero-dot--active{background:#fff;width:48px}
.hero-arrow{position:absolute;top:50%;z-index:20;width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.1);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.15);display:grid;place-items:center;cursor:pointer;transition:all .3s;color:#fff}.hero-arrow:hover{background:rgba(255,255,255,.2)}
.hero-arrow--prev{left:40px;transform:translateY(-50%)}.hero-arrow--next{right:40px;transform:translateY(-50%)}
.hero-arrow svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2}
.sol-nav{position:relative;background:var(--white);border-bottom:1px solid var(--gray-100)}
.sol-nav__inner{max-width:var(--content-max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr)}
.sol-nav__item{position:relative;padding:44px 28px;text-align:center;cursor:pointer;transition:background .4s var(--ease)}
.sol-nav__item::after{content:'';position:absolute;top:24%;right:0;width:1px;height:52%;background:var(--gray-100)}.sol-nav__item:last-child::after{display:none}
.sol-nav__item:hover{background:var(--gray-50)}
.sol-nav__icon{width:48px;height:48px;border-radius:12px;background:var(--accent-light);display:grid;place-items:center;margin:0 auto 14px;transition:all .45s var(--ease)}
.sol-nav__item:hover .sol-nav__icon{background:var(--accent);box-shadow:0 6px 20px rgba(0,102,255,.18)}
.sol-nav__icon svg{width:22px;height:22px;stroke:var(--accent);fill:none;stroke-width:1.8;transition:stroke .35s}
.sol-nav__item:hover .sol-nav__icon svg{stroke:#fff}
.sol-nav__title{font-size:15px;font-weight:600;color:var(--gray-900);margin-bottom:4px;transition:color .35s}
.sol-nav__item:hover .sol-nav__title{color:var(--accent)}
.sol-nav__sub{font-size:12px;font-weight:400;color:var(--gray-400);letter-spacing:.3px}
.sol-nav__desc{font-size:13px;font-weight:300;color:var(--gray-500);line-height:1.5;margin-top:10px;opacity:0;transition:opacity .45s var(--ease)}
.sol-nav__item:hover .sol-nav__desc{opacity:1}
.showcase__hero{position:relative;height:100vh;min-height:680px;display:flex;align-items:flex-end;overflow:hidden}
.showcase__hero-img{position:absolute;inset:0}.showcase__hero-img img{width:100%;height:100%;object-fit:cover;transition:transform 8s linear}
.showcase__hero:hover .showcase__hero-img img{transform:scale(1.03)}
.showcase__hero-gradient{position:absolute;inset:0;z-index:2;background:linear-gradient(0deg,rgba(0,0,0,.7) 0%,rgba(0,0,0,0) 50%,rgba(0,0,0,.15) 100%)}
.showcase__hero-content{position:relative;z-index:10;padding:0 var(--content-pad) 80px;max-width:calc(var(--content-max) + var(--content-pad)*2);margin:0 auto;width:100%}
.showcase__hero-eyebrow{font-size:12px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.showcase__hero-title{font-size:clamp(28px,4vw,50px);font-weight:800;line-height:1.12;color:#fff;margin-bottom:16px;letter-spacing:-.5px}
.showcase__hero-sub{font-size:16px;font-weight:300;line-height:1.8;color:rgba(255,255,255,.6);max-width:520px}
.showcase__detail{background:var(--white);padding:100px var(--content-pad)}.showcase__detail--alt{background:var(--gray-50)}
.showcase__detail-inner{max-width:var(--content-max);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.showcase__detail-tag{font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.showcase__detail-heading{font-size:clamp(24px,2.6vw,36px);font-weight:700;line-height:1.2;color:var(--gray-900);margin-bottom:24px;letter-spacing:-.5px}
.showcase__detail-text{font-size:15px;font-weight:300;line-height:1.9;color:var(--gray-600);margin-bottom:36px}
.showcase__detail-cta{font-size:14px;font-weight:600;color:var(--accent);display:inline-flex;align-items:center;gap:8px;transition:gap .3s var(--ease)}.showcase__detail-cta:hover{gap:14px}
.showcase__detail-cta svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}
.showcase__features{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.showcase__feature{position:relative;padding:24px 22px;border-radius:14px;background:var(--white);border:1px solid var(--gray-100);transition:all .4s var(--ease)}
.showcase__detail--alt .showcase__feature{background:var(--white)}
.showcase__feature:hover{border-color:rgba(0,102,255,.15);box-shadow:0 8px 32px rgba(0,102,255,.06)}
.showcase__feature-top{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.showcase__feature-icon{width:38px;height:38px;border-radius:10px;background:var(--accent-light);display:grid;place-items:center;flex-shrink:0;transition:all .4s var(--ease)}
.showcase__feature:hover .showcase__feature-icon{background:var(--accent);box-shadow:0 4px 14px rgba(0,102,255,.2)}
.showcase__feature-icon svg{width:17px;height:17px;stroke:var(--accent);fill:none;stroke-width:2;transition:stroke .3s}
.showcase__feature:hover .showcase__feature-icon svg{stroke:#fff}
.showcase__feature-title{font-size:14px;font-weight:600;color:var(--gray-900);transition:color .3s;line-height:1.3}
.showcase__feature:hover .showcase__feature-title{color:var(--accent)}
.showcase__feature-desc{font-size:13px;font-weight:300;color:var(--gray-500);line-height:1.6;padding-left:50px}
.media-gallery{padding:100px 0;background:var(--gray-50);overflow:hidden}
.media-gallery__header{max-width:calc(var(--content-max) + var(--content-pad)*2);margin:0 auto 56px;padding:0 var(--content-pad);display:flex;justify-content:space-between;align-items:flex-end}
.media-gallery__tag{font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.media-gallery__title{font-size:clamp(26px,3vw,40px);font-weight:700;color:var(--gray-900);letter-spacing:-.3px}
.media-gallery__arrows{display:flex;gap:8px}
.mg-arrow{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--gray-200);background:#fff;display:grid;place-items:center;cursor:pointer;transition:all .3s}
.mg-arrow:hover{border-color:var(--accent);background:var(--accent)}.mg-arrow:hover svg{stroke:#fff}
.mg-arrow svg{width:18px;height:18px;stroke:var(--gray-700);fill:none;stroke-width:2}
.mg-carousel{position:relative;width:100%;overflow:hidden}
.mg-track{display:flex;transition:transform .7s cubic-bezier(.25,.1,.25,1);will-change:transform}
.mg-slide{flex:0 0 auto;padding:0 8px;transition:all .7s cubic-bezier(.25,.1,.25,1);opacity:.4;transform:scale(.9);filter:brightness(.65) saturate(.7)}
.mg-slide--focus{opacity:1;transform:scale(1);filter:brightness(1) saturate(1)}
.mg-slide__inner{position:relative;width:100%;height:100%;border-radius:12px;overflow:hidden;cursor:pointer}
.mg-slide img,.mg-slide video{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease)}
.mg-slide--focus .mg-slide__inner:hover img,.mg-slide--focus .mg-slide__inner:hover video{transform:scale(1.04)}
.mg-slide__overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(0deg,rgba(0,0,0,.6) 0%,rgba(0,0,0,0) 50%);opacity:0;transition:opacity .5s}
.mg-slide--focus .mg-slide__overlay{opacity:1}
.mg-slide__info{position:absolute;bottom:0;left:0;right:0;padding:24px;z-index:2;opacity:0;transform:translateY(12px);transition:all .6s var(--ease)}
.mg-slide--focus .mg-slide__info{opacity:1;transform:translateY(0);transition-delay:.12s}
.mg-slide__title{font-size:15px;font-weight:600;color:#fff;margin-bottom:3px}
.mg-slide__sub{font-size:12px;font-weight:300;color:rgba(255,255,255,.6)}
.mg-slide__play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3;width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,.2);backdrop-filter:blur(10px);border:1.5px solid rgba(255,255,255,.3);display:grid;place-items:center;opacity:0;transition:all .4s;pointer-events:none}
.mg-slide__play svg{width:20px;height:20px;fill:#fff;margin-left:2px}
.media-gallery__dots{display:flex;gap:6px;justify-content:center;margin-top:36px}
.mg-dot{width:6px;height:6px;border-radius:50%;background:var(--gray-300);border:none;padding:0;cursor:pointer;transition:all .3s}
.mg-dot--active{background:var(--accent);width:24px;border-radius:3px}
.industries{padding:120px var(--content-pad);background:var(--white)}
.industries__header{max-width:var(--content-max);margin:0 auto 64px;display:flex;justify-content:space-between;align-items:flex-end}
.industries__tag{font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.industries__title{font-size:clamp(26px,3.2vw,42px);font-weight:700;color:var(--gray-900);letter-spacing:-.3px}
.industries__header-right{font-size:15px;font-weight:300;color:var(--gray-500);max-width:380px;text-align:right;line-height:1.7}
.industries__grid{max-width:var(--content-max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.ind-card{position:relative;height:400px;border-radius:12px;overflow:hidden;cursor:pointer}
.ind-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}.ind-card:hover img{transform:scale(1.06)}
.ind-card__overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(0deg,rgba(0,0,0,.7) 0%,rgba(0,0,0,0) 55%);transition:background .4s}
.ind-card:hover .ind-card__overlay{background:linear-gradient(0deg,rgba(0,102,255,.75) 0%,rgba(0,0,0,.1) 60%)}
.ind-card__content{position:absolute;bottom:0;left:0;right:0;padding:28px;z-index:2}
.ind-card__title{font-size:17px;font-weight:700;color:#fff;margin-bottom:4px}
.ind-card__sub{font-size:12px;font-weight:300;color:rgba(255,255,255,.5);opacity:0;transform:translateY(8px);transition:all .4s var(--ease)}
.ind-card:hover .ind-card__sub{opacity:1;transform:translateY(0)}
.cta-banner{position:relative;height:60vh;min-height:420px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.cta-banner__bg{position:absolute;inset:0}.cta-banner__bg img{width:100%;height:100%;object-fit:cover}
.cta-banner__bg::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,.55)}
.cta-banner__content{position:relative;z-index:10;max-width:640px;padding:0 40px}
.cta-banner__title{font-size:clamp(26px,3.8vw,46px);font-weight:700;color:#fff;margin-bottom:18px;line-height:1.2;letter-spacing:-.5px}
.cta-banner__desc{font-size:16px;font-weight:300;color:rgba(255,255,255,.6);line-height:1.7;margin-bottom:36px}
.cta-banner__actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
/* === Stats Counter === */
.stats{padding:80px var(--content-pad);position:relative}
.stats--dark{background:var(--gray-900);color:#fff}
.stats--light{background:var(--gray-50)}
.stats__inner{max-width:var(--content-max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:40px;text-align:center}
.stat__number{font-size:clamp(36px,4vw,56px);font-weight:800;line-height:1;margin-bottom:12px;letter-spacing:-1px;color:var(--accent)}
.stats--dark .stat__number{color:#fff}
.stat__label{font-size:14px;font-weight:600;color:var(--gray-900);letter-spacing:.5px}
.stats--dark .stat__label{color:rgba(255,255,255,.6)}
.stat__desc{font-size:13px;font-weight:300;color:var(--gray-500);margin-top:6px}
.stats--dark .stat__desc{color:rgba(255,255,255,.35)}

/* === Section Header (generic) === */
.sec__tag{font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.sec__title{font-size:clamp(26px,3vw,40px);font-weight:700;color:var(--gray-900);letter-spacing:-.3px}

@media(max-width:1024px){
.hero-arrow{display:none}.hero-slide__title{max-width:600px}
.showcase__detail-inner{grid-template-columns:1fr;gap:48px}
.showcase__features{gap:12px}.showcase__feature{padding:20px 18px}.showcase__feature-desc{padding-left:0;margin-top:6px}
.sol-nav__inner{grid-template-columns:repeat(2,1fr)}.sol-nav__item{padding:36px 24px}.sol-nav__item:nth-child(2)::after{display:none}.sol-nav__desc{display:none}
.industries__grid{grid-template-columns:repeat(2,1fr)}.industries__header{flex-direction:column;align-items:flex-start;gap:16px}.industries__header-right{text-align:left}
.stats__inner{grid-template-columns:repeat(2,1fr);gap:32px}
}
@media(max-width:768px){
.hero-carousel{min-height:600px}.hero-slide__title{font-size:clamp(28px,6vw,40px)}.hero-slide__content{padding:0 28px}
.showcase__hero{height:65vh;min-height:500px}.showcase__detail{padding:72px var(--content-pad)}.showcase__detail-inner{gap:40px}
.industries{padding:72px var(--content-pad)}.ind-card{height:340px}
.media-gallery{padding:72px 0}.media-gallery__header{margin-bottom:40px}
.cta-banner{min-height:360px}.cta-banner__content{padding:0 28px}
}
@media(max-width:640px){
.hero-carousel{min-height:560px}.hero-slide__content{padding:0 20px}.hero-slide__title{font-size:clamp(26px,8vw,34px);max-width:100%}.hero-slide__desc{font-size:14px;margin-bottom:28px}
.hero-slide__actions{gap:10px}.hero-nav{bottom:28px}
.sol-nav__inner{grid-template-columns:repeat(2,1fr)}.sol-nav__item{padding:24px 14px}.sol-nav__item::after{display:none}.sol-nav__title{font-size:14px}.sol-nav__sub{font-size:10px}
.showcase__hero{height:55vh;min-height:400px}.showcase__hero-content{padding:0 var(--content-pad) 40px}.showcase__hero-title{font-size:clamp(24px,7vw,32px)}.showcase__hero-sub{font-size:14px;line-height:1.7}
.showcase__detail{padding:48px var(--content-pad)}.showcase__detail-heading{font-size:clamp(22px,5.5vw,28px)}
.showcase__features{grid-template-columns:1fr;gap:10px}.showcase__feature-desc{padding-left:0;margin-top:6px}
.media-gallery{padding:56px 0 64px}.media-gallery__header{flex-direction:column;align-items:flex-start;gap:16px;padding:0 var(--content-pad)}.media-gallery__title{font-size:clamp(22px,5vw,30px)}
.industries{padding:48px var(--content-pad)}.industries__grid{grid-template-columns:1fr}.ind-card{height:260px}
.cta-banner{height:auto;padding:64px 0;min-height:auto}.cta-banner__content{padding:0 20px}.cta-banner__title{font-size:clamp(22px,6vw,32px)}.cta-banner__actions{flex-direction:column;align-items:center}
}
@media(max-width:400px){
.hero-slide__title{font-size:24px}.hero-slide__desc{font-size:13px}
.sol-nav__item{padding:20px 10px}.sol-nav__title{font-size:13px}
.showcase__feature{padding:18px 14px}
}
