/* ============================================
   TELSTRA INTERNATIONAL
   Colors: #FFFFFF  #A3DDFF  #25276A  #0D0D0D  #787878
   ============================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:#fff;color:#0D0D0D;line-height:1.65;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:#f5f8ff}
::-webkit-scrollbar-thumb{background:#25276A;border-radius:3px}

/* ── PRELOADER ── */
#preloader{
  position:fixed;inset:0;z-index:9999;background:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  transition:opacity .5s ease,visibility .5s ease;
}
#preloader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.pl-wrap{display:flex;flex-direction:column;align-items:center;gap:28px}
.pl-logo-img{height:60px;animation:plScale .6s ease both}
.pl-spinner{
  width:40px;height:40px;border:3px solid #A3DDFF;
  border-top-color:#25276A;border-radius:50%;
  animation:spin .8s linear infinite;
}
@keyframes plScale{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── NAV ── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:0 24px;background:rgba(255,255,255,0);
  transition:background .3s,box-shadow .3s;
}
.nav.scrolled{
  background:rgba(255,255,255,0.95);
  backdrop-filter:blur(12px);
  box-shadow:0 1px 0 rgba(37,39,106,0.1),0 4px 20px rgba(37,39,106,0.06);
}
.nav-inner{
  max-width:1200px;margin:0 auto;
  display:flex;align-items:center;gap:24px;height:70px;
}
.nav-logo{display:flex;align-items:center;flex-shrink:0}
.nav-logo img{height:42px;width:auto;object-fit:contain}
.nav-links{display:flex;align-items:center;gap:2px;margin-left:auto}
.nav-links a{
  padding:7px 14px;border-radius:8px;
  font-size:14px;font-weight:500;color:#787878;
  transition:color .2s,background .2s;
}
.nav-links a:hover,.nav-links a.active{color:#25276A;background:rgba(37,39,106,0.06)}
.nav-lang{
  display:flex;align-items:center;gap:3px;
  background:#f5f8ff;border:1px solid rgba(37,39,106,0.12);
  border-radius:8px;padding:4px;
}
.lang-btn{
  padding:5px 12px;border-radius:5px;
  font-size:12px;font-weight:700;color:#787878;transition:.2s;
}
.lang-btn.active{background:#25276A;color:#fff}
.nav-cta{
  padding:10px 22px;border-radius:9px;
  background:#25276A;color:#fff;font-size:14px;font-weight:700;
  transition:background .2s,transform .2s,box-shadow .2s;flex-shrink:0;
}
.nav-cta:hover{background:#1A1C52;box-shadow:0 4px 16px rgba(37,39,106,0.3);transform:translateY(-1px)}
.nav-burger{display:none;flex-direction:column;gap:5px;padding:6px;margin-left:auto}
.nav-burger span{display:block;width:22px;height:2px;background:#25276A;border-radius:2px;transition:.25s}
.nav-mobile{
  display:none;flex-direction:column;
  position:absolute;top:70px;left:0;right:0;
  background:#fff;border-top:1px solid rgba(37,39,106,0.1);
  box-shadow:0 8px 24px rgba(37,39,106,0.1);padding:16px 24px 24px;
}
.nav-mobile.open{display:flex}
.nav-mobile a{padding:13px 0;font-size:15px;font-weight:500;color:#787878;border-bottom:1px solid rgba(37,39,106,0.07);transition:.2s}
.nav-mobile a:hover{color:#25276A;padding-left:6px}
.nav-mobile-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:16px}
@media(max-width:900px){.nav-links,.nav-lang,.nav-cta{display:none}.nav-burger{display:flex}}

/* ── LAYOUT ── */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:96px 0}
.section-alt{background:#F5F8FF}

.tag{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;border-radius:20px;
  background:rgba(163,221,255,0.25);border:1px solid rgba(163,221,255,0.6);
  font-size:11px;font-weight:700;color:#25276A;
  letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;
}
.section-title{
  font-size:clamp(26px,3.5vw,42px);font-weight:800;line-height:1.15;
  letter-spacing:-.02em;color:#25276A;margin-bottom:12px;
}
.section-sub{font-size:17px;color:#787878;line-height:1.75;max-width:560px;margin-bottom:48px}
.section-sub.center{text-align:center;margin-left:auto;margin-right:auto}
.center{text-align:center}

.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 26px;border-radius:10px;font-size:14px;font-weight:700;
  transition:.25s;white-space:nowrap;
}
.btn-primary{background:#25276A;color:#fff}
.btn-primary:hover{background:#1A1C52;box-shadow:0 6px 20px rgba(37,39,106,0.28);transform:translateY(-2px)}
.btn-outline{border:2px solid #25276A;color:#25276A}
.btn-outline:hover{background:#25276A;color:#fff}
.btn-white{background:#fff;color:#25276A}
.btn-white:hover{background:#A3DDFF;box-shadow:0 6px 20px rgba(255,255,255,0.2);transform:translateY(-2px)}
.btn-ghost{border:2px solid rgba(255,255,255,0.35);color:#fff}
.btn-ghost:hover{border-color:rgba(255,255,255,.7);background:rgba(255,255,255,.1)}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* ── HERO ── */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:100px 0 80px;position:relative;overflow:hidden;
  background:#fff;
}
.hero-bg{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 60% 60% at 70% 40%,rgba(163,221,255,.25) 0%,transparent 65%),
    radial-gradient(ellipse 40% 40% at 100% 0%,rgba(37,39,106,.04) 0%,transparent 60%);
}
.hero-dots{
  position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(37,39,106,.07) 1px,transparent 1px);
  background-size:26px 26px;
  -webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 20%,transparent 80%);
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 20%,transparent 80%);
}
.hero-inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;
}
@media(max-width:820px){.hero-inner{grid-template-columns:1fr}.hero-right{display:none}}

.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 16px;border-radius:30px;
  background:rgba(163,221,255,.2);border:1px solid rgba(163,221,255,.6);
  font-size:13px;font-weight:600;color:#25276A;margin-bottom:22px;
}
.hero-badge .dot{width:7px;height:7px;border-radius:50%;background:#25276A;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

.hero-h1{
  font-size:clamp(34px,5vw,62px);font-weight:900;line-height:1.08;
  letter-spacing:-.03em;color:#25276A;margin-bottom:20px;
}
.hero-h1 em{
  font-style:normal;
  background:linear-gradient(135deg,#25276A 0%,#4A6CF7 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-p{font-size:17px;color:#787878;line-height:1.75;max-width:500px;margin-bottom:32px}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:44px}
.hero-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.stat-box{
  background:#F5F8FF;border:1px solid rgba(37,39,106,.1);
  border-radius:12px;padding:18px 16px;transition:.25s;
}
.stat-box:hover{border-color:rgba(37,39,106,.25);background:rgba(163,221,255,.15)}
.stat-num{font-size:28px;font-weight:900;color:#25276A;line-height:1;letter-spacing:-.02em}
.stat-lbl{font-size:12px;color:#787878;margin-top:4px;font-weight:500}

/* Hero right */
.hero-right{position:relative}
.hero-photo{
  border-radius:20px;overflow:hidden;aspect-ratio:4/5;
  box-shadow:0 20px 60px rgba(37,39,106,.18);
}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-card{
  position:absolute;background:#fff;
  border:1px solid rgba(37,39,106,.12);border-radius:12px;
  padding:14px 18px;box-shadow:0 8px 30px rgba(37,39,106,.14);
}
.hero-card-num{font-size:22px;font-weight:900;color:#25276A;line-height:1}
.hero-card-lbl{font-size:11px;color:#787878;margin-top:3px}
.hero-card-1{bottom:-16px;left:-16px;animation:float 4s ease-in-out infinite}
.hero-card-2{top:20px;right:-16px;background:#25276A;animation:float 4s ease-in-out .8s infinite}
.hero-card-2 .hero-card-num{color:#A3DDFF}
.hero-card-2 .hero-card-lbl{color:rgba(255,255,255,.7)}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* ── FEATURES ── */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}
.feat-card{
  background:#fff;border:1.5px solid rgba(37,39,106,.1);
  border-radius:14px;padding:32px 26px;position:relative;
  overflow:hidden;transition:.25s;
}
.feat-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,#A3DDFF,#25276A);
  transform:scaleX(0);transform-origin:left;transition:.3s;
}
.feat-card:hover{border-color:rgba(37,39,106,.25);transform:translateY(-5px);box-shadow:0 12px 36px rgba(37,39,106,.12)}
.feat-card:hover::after{transform:scaleX(1)}
.feat-icon{
  width:52px;height:52px;border-radius:12px;
  background:rgba(163,221,255,.25);border:1px solid rgba(163,221,255,.5);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;margin-bottom:18px;
}
.feat-title{font-size:17px;font-weight:700;color:#25276A;margin-bottom:10px}
.feat-text{font-size:14.5px;color:#787878;line-height:1.65}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
@media(max-width:768px){.about-grid{grid-template-columns:1fr;gap:40px}}
.about-img-wrap{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:4/3;box-shadow:0 20px 50px rgba(37,39,106,.15)}
.about-img-wrap img{width:100%;height:100%;object-fit:cover}
.about-img-badge{
  position:absolute;bottom:20px;left:20px;
  background:rgba(255,255,255,.95);backdrop-filter:blur(8px);
  border:1px solid rgba(37,39,106,.1);border-radius:12px;
  padding:14px 18px;box-shadow:0 8px 24px rgba(37,39,106,.12);
}
.about-img-badge .n{font-size:24px;font-weight:900;color:#25276A}
.about-img-badge .l{font-size:11px;color:#787878;margin-top:2px}
.about-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:28px 0 32px}
.astat{background:#F5F8FF;border:1px solid rgba(37,39,106,.1);border-radius:10px;padding:18px}
.astat-n{font-size:26px;font-weight:900;color:#25276A;line-height:1}
.astat-l{font-size:12px;color:#787878;margin-top:4px}

/* ── PROCESS ── */
.process-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}
.proc-card{
  background:#fff;border:1.5px solid rgba(37,39,106,.1);
  border-radius:14px;padding:28px 22px;transition:.25s;
}
.proc-card:hover{border-color:rgba(37,39,106,.3);transform:translateY(-4px);box-shadow:0 10px 30px rgba(37,39,106,.1)}
.proc-num{font-size:42px;font-weight:900;color:#A3DDFF;line-height:1;margin-bottom:14px}
.proc-title{font-size:16px;font-weight:700;color:#25276A;margin-bottom:8px}
.proc-text{font-size:14px;color:#787878;line-height:1.65}

/* ── TESTIMONIALS ── */
.test-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.test-card{
  background:#fff;border:1.5px solid rgba(37,39,106,.1);
  border-radius:14px;padding:24px;transition:.25s;
}
.test-card:hover{border-color:rgba(37,39,106,.22);transform:translateY(-4px);box-shadow:0 12px 32px rgba(37,39,106,.1)}
.test-stars{color:#F59E0B;font-size:13px;letter-spacing:2px;margin-bottom:12px}
.test-text{font-size:14px;color:#787878;line-height:1.75;margin-bottom:18px;font-style:italic}
.test-text::before{content:'"';color:#25276A;font-size:20px;font-style:normal;line-height:0;vertical-align:-7px;margin-right:2px}
.test-author{display:flex;align-items:center;gap:11px}
.test-av{
  width:42px;height:42px;border-radius:50%;flex-shrink:0;overflow:hidden;
  background:#25276A;display:flex;align-items:center;justify-content:center;
  font-size:15px;font-weight:700;color:#fff;border:2px solid rgba(163,221,255,.4);
}
.test-av img{width:100%;height:100%;object-fit:cover}
.test-name{font-size:13.5px;font-weight:700;color:#25276A}
.test-loc{font-size:12px;color:#787878}

/* ── FAQ ── */
.faq{max-width:800px;margin:0 auto}
.faq-item{border-bottom:1px solid rgba(37,39,106,.1)}
.faq-q{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 0;font-size:15.5px;font-weight:600;
  cursor:pointer;color:#0D0D0D;transition:.2s;gap:16px;
}
.faq-q:hover{color:#25276A}
.faq-ico{
  width:26px;height:26px;border-radius:50%;flex-shrink:0;
  background:#F5F8FF;border:1.5px solid rgba(37,39,106,.12);
  display:flex;align-items:center;justify-content:center;
  font-size:17px;color:#25276A;transition:.3s;
}
.faq-item.open .faq-ico{transform:rotate(45deg);background:#25276A;color:#fff;border-color:#25276A}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .4s cubic-bezier(.4,0,.2,1),padding .3s;
  font-size:14.5px;color:#787878;line-height:1.75;
}
.faq-item.open .faq-a{max-height:300px;padding-bottom:20px}

/* ── TEAM ── */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}
.team-card{
  background:#fff;border:1.5px solid rgba(37,39,106,.1);
  border-radius:14px;overflow:hidden;transition:.25s;text-align:center;
}
.team-card:hover{border-color:#25276A;transform:translateY(-5px);box-shadow:0 14px 36px rgba(37,39,106,.14)}
.team-photo{
  width:100%;aspect-ratio:1;overflow:hidden;
  background:#F5F8FF;
  display:flex;align-items:center;justify-content:center;
}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:top center}
.team-photo-placeholder{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-size:40px;font-weight:800;color:#25276A;background:rgba(163,221,255,.2);
}
.team-info{padding:16px 12px 18px}
.team-name{font-size:14px;font-weight:700;color:#25276A;margin-bottom:4px;line-height:1.3}
.team-role{font-size:12px;color:#787878;margin-bottom:12px}
.team-badge{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 11px;border-radius:20px;
  background:rgba(163,221,255,.2);border:1px solid rgba(163,221,255,.5);
  font-size:11px;font-weight:700;color:#25276A;
}
.team-badge .dot{width:6px;height:6px;border-radius:50%;background:#22C55E;animation:blink 2s infinite}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:52px;align-items:start}
@media(max-width:768px){.contact-grid{grid-template-columns:1fr;gap:36px}}
.cinfo-item{display:flex;gap:14px;align-items:flex-start;padding:16px 0;border-bottom:1px solid rgba(37,39,106,.08)}
.cinfo-item:last-child{border:none}
.cinfo-icon{
  width:42px;height:42px;border-radius:10px;flex-shrink:0;
  background:rgba(163,221,255,.2);border:1px solid rgba(163,221,255,.5);
  display:flex;align-items:center;justify-content:center;font-size:17px;
}
.cinfo-lbl{font-size:11px;font-weight:700;color:#25276A;text-transform:uppercase;letter-spacing:.1em;margin-bottom:3px}
.cinfo-val{font-size:14.5px;color:#0D0D0D;font-weight:500}

.form-box{
  background:#fff;border:1.5px solid rgba(37,39,106,.12);
  border-radius:16px;padding:36px;box-shadow:0 4px 24px rgba(37,39,106,.08);
}
.form-box h3{font-size:21px;font-weight:800;color:#25276A;margin-bottom:6px}
.form-box p{font-size:14px;color:#787878;margin-bottom:28px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:500px){.frow{grid-template-columns:1fr}}
.fg{margin-bottom:16px}
.flbl{display:block;font-size:12px;font-weight:700;color:#787878;text-transform:uppercase;letter-spacing:.05em;margin-bottom:7px}
.finput,.fselect,.ftextarea{
  width:100%;background:#F5F8FF;border:1.5px solid rgba(37,39,106,.12);
  border-radius:9px;padding:12px 14px;font-size:14.5px;color:#0D0D0D;
  font-family:inherit;transition:.2s;outline:none;
}
.finput:focus,.fselect:focus,.ftextarea:focus{
  border-color:#25276A;background:#fff;
  box-shadow:0 0 0 3px rgba(37,39,106,.08);
}
.ftextarea{resize:vertical;min-height:120px}
.fsubmit{
  width:100%;padding:14px;background:#25276A;color:#fff;
  font-size:15px;font-weight:700;border-radius:9px;
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:.25s;
}
.fsubmit:hover{background:#1A1C52;box-shadow:0 6px 20px rgba(37,39,106,.28);transform:translateY(-2px)}
.fsubmit:disabled{opacity:.6;cursor:not-allowed;transform:none}
.fnotice{padding:13px 16px;border-radius:9px;font-size:14px;font-weight:500;margin-top:12px;display:none}
.fnotice.ok{background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.3);color:#16A34A}
.fnotice.err{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.3);color:#DC2626}

/* ── CTA SECTION ── */
.cta-box{
  background:#25276A;border-radius:20px;
  padding:70px 48px;text-align:center;position:relative;overflow:hidden;
}
.cta-box::before{
  content:'';position:absolute;top:-80px;left:50%;transform:translateX(-50%);
  width:500px;height:260px;border-radius:50%;
  background:rgba(163,221,255,.1);pointer-events:none;
}
.cta-box::after{
  content:'';position:absolute;bottom:-60px;right:-60px;
  width:240px;height:240px;border-radius:50%;
  background:rgba(163,221,255,.07);pointer-events:none;
}
.cta-h{font-size:clamp(24px,3.5vw,40px);font-weight:900;letter-spacing:-.02em;color:#fff;margin-bottom:12px}
.cta-p{font-size:17px;color:rgba(255,255,255,.7);max-width:500px;margin:0 auto 32px;line-height:1.7}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}

/* ── BLOG ── */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}
.blog-card{
  background:#fff;border:1.5px solid rgba(37,39,106,.1);
  border-radius:14px;overflow:hidden;transition:.25s;
}
.blog-card:hover{border-color:rgba(37,39,106,.22);transform:translateY(-4px);box-shadow:0 12px 32px rgba(37,39,106,.1)}
.blog-img-wrap{height:190px;background:#F5F8FF;display:flex;align-items:center;justify-content:center;font-size:42px;overflow:hidden}
.blog-img-wrap img{width:100%;height:100%;object-fit:cover}
.blog-body{padding:22px}
.blog-cat{font-size:11px;font-weight:700;color:#25276A;text-transform:uppercase;letter-spacing:.12em;margin-bottom:8px}
.blog-title{font-size:16.5px;font-weight:700;color:#25276A;line-height:1.4;margin-bottom:10px}
.blog-excerpt{font-size:14px;color:#787878;line-height:1.65;margin-bottom:16px}
.blog-meta{display:flex;align-items:center;justify-content:space-between}
.blog-date{font-size:12px;color:#AFAFAF}
.blog-link{font-size:13px;font-weight:700;color:#25276A;display:flex;align-items:center;gap:4px;transition:.2s}
.blog-link:hover{gap:8px}

/* ── PAGE HERO ── */
.page-hero{
  padding:130px 0 70px;text-align:center;
  background:radial-gradient(ellipse 70% 50% at 50% 0%,rgba(163,221,255,.2) 0%,transparent 60%),#fff;
}
.page-hero h1{font-size:clamp(28px,5vw,54px);font-weight:900;letter-spacing:-.03em;color:#25276A;margin-bottom:12px}
.page-hero p{font-size:17px;color:#787878;max-width:580px;margin:0 auto;line-height:1.75}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:#AFAFAF;margin-bottom:16px;justify-content:center}
.breadcrumb a{color:#787878;transition:.2s}
.breadcrumb a:hover{color:#25276A}

/* ── FOOTER ── */
.footer{background:#12143B;color:#fff;padding:60px 0 0}
.footer-grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:48px;margin-bottom:48px}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.footer-grid{grid-template-columns:1fr}}
.footer-brand .footer-logo{height:44px;width:auto;object-fit:contain;margin-bottom:14px;
  filter:brightness(0) invert(1) /* makes dark logo white */;
}
.footer-brand p{font-size:14px;color:rgba(255,255,255,.5);line-height:1.7;max-width:240px}
.footer-col-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:#A3DDFF;margin-bottom:16px}
.footer-links{display:flex;flex-direction:column;gap:9px}
.footer-links a{font-size:14px;color:rgba(255,255,255,.5);transition:.2s}
.footer-links a:hover{color:#fff;padding-left:4px}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  padding:18px 0;display:flex;align-items:center;
  justify-content:space-between;flex-wrap:wrap;gap:10px;
}
.footer-copy{font-size:13px;color:rgba(255,255,255,.35)}
.footer-legal{display:flex;gap:18px}
.footer-legal a{font-size:13px;color:rgba(255,255,255,.35);transition:.2s}
.footer-legal a:hover{color:#fff}

/* ── STATS STRIP ── */
.stats-strip{background:#25276A;padding:0}
.stats-strip-inner{
  display:grid;grid-template-columns:repeat(4,1fr);
}
@media(max-width:600px){.stats-strip-inner{grid-template-columns:repeat(2,1fr)}}
.sstrip{padding:36px 24px;text-align:center;border-right:1px solid rgba(255,255,255,.1)}
.sstrip:last-child{border:none}
.sstrip-num{font-size:36px;font-weight:900;color:#A3DDFF;line-height:1;letter-spacing:-.02em}
.sstrip-lbl{font-size:13px;color:rgba(255,255,255,.6);margin-top:5px}

/* ── DIVIDER ── */
.divider{height:1px;background:rgba(37,39,106,.1);margin:0}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .section{padding:64px 0}
  .cta-box{padding:44px 24px}
  .form-box{padding:24px 18px}
}
@media(max-width:480px){
  .hero-btns{flex-direction:column}
  .btn{justify-content:center}
  .cta-btns{flex-direction:column;align-items:center}
  .about-stats{grid-template-columns:1fr 1fr}
}

/* ============================================
   PREMIUM ANIMATIONS & CURSOR
   ============================================ */

/* ── Custom Cursor ── */
@media(hover:hover){body{cursor:none}}
.cur-dot{
  position:fixed;pointer-events:none;z-index:99999;
  width:8px;height:8px;border-radius:50%;background:#25276A;
  transform:translate(-50%,-50%);
  transition:width .18s,height .18s,background .18s,opacity .3s;
  will-change:left,top;
}
.cur-ring{
  position:fixed;pointer-events:none;z-index:99998;
  width:38px;height:38px;border-radius:50%;
  border:1.5px solid rgba(37,39,106,.45);
  transform:translate(-50%,-50%);
  transition:width .28s cubic-bezier(.16,1,.3,1),height .28s cubic-bezier(.16,1,.3,1),border-color .25s,background .25s,opacity .3s;
  will-change:left,top;
}
body.cur-hover .cur-dot{width:0;height:0;opacity:0}
body.cur-hover .cur-ring{width:54px;height:54px;background:rgba(37,39,106,.07);border-color:rgba(37,39,106,.7)}
body.cur-click .cur-ring{width:26px;height:26px;transition-duration:.08s}

/* ── Scroll Progress Bar ── */
.scroll-bar{
  position:fixed;top:0;left:0;z-index:10000;height:2.5px;width:0%;
  background:linear-gradient(90deg,#A3DDFF 0%,#25276A 60%,#A3DDFF 100%);
  background-size:200% 100%;
  animation:barShimmer 2.5s linear infinite;
  transition:width .1s linear;
}
@keyframes barShimmer{0%{background-position:0% 0}100%{background-position:200% 0}}

/* ── Button Shimmer ── */
.btn-primary{position:relative;overflow:hidden}
.btn-primary::before{
  content:'';position:absolute;top:0;left:-100%;width:55%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);
  transform:skewX(-20deg);transition:left .55s ease;pointer-events:none;
}
.btn-primary:hover::before{left:160%}
.nav-cta{position:relative;overflow:hidden}
.nav-cta::before{
  content:'';position:absolute;top:0;left:-100%;width:55%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);
  transform:skewX(-20deg);transition:left .55s ease;pointer-events:none;
}
.nav-cta:hover::before{left:160%}

/* ── Hero Animated Blobs ── */
.hero-blob{position:absolute;pointer-events:none;border-radius:50%;filter:blur(90px)}
.hero-blob-1{
  width:520px;height:520px;background:rgba(163,221,255,.38);
  top:-120px;right:-60px;
  animation:blob1 9s ease-in-out infinite alternate;
}
.hero-blob-2{
  width:380px;height:380px;background:rgba(37,39,106,.09);
  bottom:-60px;left:-80px;
  animation:blob2 12s ease-in-out infinite alternate;
}
@keyframes blob1{0%{transform:scale(1) translate(0,0)}100%{transform:scale(1.18) translate(30px,-20px)}}
@keyframes blob2{0%{transform:scale(1) translate(0,0)}100%{transform:scale(1.14) translate(-20px,28px)}}

/* ── Nav Link Underline Slide ── */
.nav-links a{position:relative}
.nav-links a::after{
  content:'';position:absolute;bottom:-2px;left:50%;right:50%;
  height:2px;background:#25276A;border-radius:2px;
  transition:left .28s cubic-bezier(.4,0,.2,1),right .28s cubic-bezier(.4,0,.2,1);
}
.nav-links a:hover::after,.nav-links a.active::after{left:14px;right:14px}

/* ── Tag Glow ── */
.tag{transition:box-shadow .3s}
.tag:hover{box-shadow:0 0 0 6px rgba(163,221,255,.22)}

/* ── CTA Box Animated Gradient ── */
.cta-box{
  background:linear-gradient(135deg,#25276A 0%,#32358A 50%,#1A1C52 100%) !important;
  background-size:200% 200% !important;
  animation:ctaGrad 7s ease-in-out infinite alternate !important;
}
@keyframes ctaGrad{0%{background-position:0% 50%}100%{background-position:100% 50%}}

/* ── Footer dark gradient ── */
.footer{
  background:linear-gradient(160deg,#0D0F2E 0%,#12143B 60%,#0A0C24 100%);
}

/* ── Stat Box Shine on Hover ── */
.stat-box{overflow:hidden;position:relative}
.stat-box::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle 80px at var(--sx,50%) var(--sy,50%),rgba(163,221,255,.22),transparent 70%);
  pointer-events:none;opacity:0;transition:opacity .3s;border-radius:inherit;
}
.stat-box:hover::after{opacity:1}

/* ── Card Spotlight ── */
.feat-card::before,.team-card::before,.proc-card::before,.blog-card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(circle 110px at var(--cx,50%) var(--cy,50%),rgba(163,221,255,.14),transparent 75%);
  opacity:0;transition:opacity .3s;z-index:0;
}
.feat-card>*,.team-card>*,.proc-card>*,.blog-card>*{position:relative;z-index:1}
.feat-card:hover::before,.team-card:hover::before,.proc-card:hover::before,.blog-card:hover::before{opacity:1}

/* ── Card 3D setup ── */
.feat-card,.team-card,.proc-card,.test-card,.blog-card{will-change:transform}

/* ── Page Hero Entrance ── */
.page-hero h1,.page-hero p,.page-hero .breadcrumb{
  animation:slideUp .7s cubic-bezier(.16,1,.3,1) both;
}
.page-hero .breadcrumb{animation-delay:.05s}
.page-hero h1{animation-delay:.12s}
.page-hero p{animation-delay:.22s}
@keyframes slideUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* ── Stats Strip Number Glow ── */
.sstrip-num{
  background:linear-gradient(135deg,#A3DDFF 0%,#fff 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ── Process Card connector dots ── */
.proc-num{
  background:linear-gradient(135deg,rgba(163,221,255,.4) 0%,rgba(163,221,255,.1) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  font-size:42px;font-weight:900;line-height:1;margin-bottom:14px;
}

/* ── Reveal upgrade ── */
.reveal{transform:translateY(28px);transition:opacity .75s cubic-bezier(.16,1,.3,1),transform .75s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:none}

/* ── Section title subtle gradient ── */
.section-title,.hero-h1{
  background:linear-gradient(135deg,#25276A 0%,#3D3FA0 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-h1 em{
  background:linear-gradient(135deg,#4A6CF7 0%,#A3DDFF 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ── Smooth image transition ── */
img{transition:opacity .4s ease,transform .4s ease}

/* ── Floating hero cards ── */
.hero-card-1{animation:float 4s ease-in-out infinite}
.hero-card-2{animation:float 4s ease-in-out .8s infinite}
