:root{
  --navy:   #07111f;
  --navy2:  #0c1c30;
  --navy3:  #112240;
  --blue:   #0ea5e9;
  --blue2:  #0284c7;
  --blue3:  #0369a1;
  --muted:  #64748b;
  --border: #e2e8f0;
  --light:  #f8fafc;
  --white:  #ffffff;
  --fn-h:   'Outfit', sans-serif;
  --fn-b:   'Mulish', sans-serif;
  --fn-nav: 'Inter', sans-serif;
  --r: 16px;
}
html{ scroll-behavior:smooth; }
body{ font-family:var(--fn-b); overflow-x:hidden; color:#1e293b; }
h1,h2,h3,h4,h5,h6{ font-family:var(--fn-h); }

/* ── NAVBAR ── */
#mainNav{
  background:rgba(7,17,31,.97);
  backdrop-filter:blur(18px);
  padding:0;
  transition:box-shadow .3s;
}
#mainNav.scrolled{ box-shadow:0 4px 28px rgba(0,0,0,.5); }
.navbar-brand img{ height:52px; filter:brightness(0) invert(1); }

.navbar-nav .nav-link{
  font-family:var(--fn-nav);
  font-size:.88rem; font-weight:300;
  letter-spacing:.07em;
  color:rgba(255,255,255,.7) !important;
  padding:22px 16px !important;
  position:relative;
  transition:color .2s;
}
.navbar-nav .nav-link::after{
  content:'';
  position:absolute; bottom:14px; left:16px; right:16px;
  height:2px; background:var(--blue);
  transform:scaleX(0); transform-origin:left;
  transition:transform .25s;
}
.navbar-nav .nav-link:hover{ color:#fff !important; }
.navbar-nav .nav-link:hover::after,
.navbar-nav .nav-link.active::after{ transform:scaleX(1); }
.navbar-nav .nav-link.active{ color:#fff !important; }

.nav-contact-btn{
  font-family:var(--fn-nav) !important;
  font-size:.85rem !important; font-weight:400 !important;
  letter-spacing:.07em;
  color:#fff !important;
  background:transparent;
  border:1.5px solid rgba(255,255,255,.25);
  border-radius:8px; padding:9px 22px !important;
  margin:12px 0 12px 10px;
  transition:border-color .2s, background .2s !important;
}
.nav-contact-btn::after{ display:none !important; }
.nav-contact-btn:hover{
  border-color:var(--blue) !important;
  background:var(--blue) !important;
}

.navbar-toggler{ border:1px solid rgba(255,255,255,.2); padding:7px 11px; }
.navbar-toggler-icon{
  background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255,255,255,.85)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* ── HERO ── */
.hero-slide{
  min-height:96vh; display:flex; align-items:center;
  position:relative; overflow:hidden;
}
.hero-slide .bg-pan{
  position:absolute; inset:-8%;
  background-size:cover; background-position:center;
  animation:kenburns 9s ease-out forwards;
  will-change:transform;
}
@keyframes kenburns{ from{ transform:scale(1.12); } to{ transform:scale(1.0); } }
.carousel-item:not(.active) .bg-pan{ animation:none; }
.hero-slide .bg-overlay{
  position:absolute; inset:0;
  background:linear-gradient(110deg,rgba(7,17,31,.82) 0%,rgba(7,17,31,.55) 50%,rgba(7,17,31,.22) 100%);
}
.hero-content{ position:relative; z-index:2; }

.hero-badge{
  display:inline-flex; align-items:center; gap:9px;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18);
  color:#fff; font-family:var(--fn-nav);
  font-size:.74rem; font-weight:300; letter-spacing:.18em; text-transform:uppercase;
  padding:6px 18px; border-radius:50px; margin-bottom:26px;
}
.hero-badge .dot{
  width:8px; height:8px; border-radius:50%; background:var(--blue);
  animation:blink 2s infinite;
}
@keyframes blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(1.6)}}

.hero-title{
  font-size:clamp(1.9rem,5.5vw,4.6rem);
  font-weight:900; color:#fff;
  line-height:1.08; letter-spacing:-.025em; margin-bottom:22px;
}
.hero-title span{ color:var(--blue); }
.hero-sub{
  font-size:clamp(.95rem,1.5vw,1.18rem);
  color:rgba(255,255,255,.8); max-width:540px;
  line-height:1.76; margin-bottom:32px; font-weight:400;
}

#heroCarousel .carousel-control-prev,
#heroCarousel .carousel-control-next{
  width:54px; height:54px;
  background:rgba(255,255,255,.09); border:1px solid rgba(255,255,255,.16);
  border-radius:50%; top:50%; transform:translateY(-50%);
  margin:0 22px; opacity:1; transition:background .2s,border-color .2s;
}
#heroCarousel .carousel-control-prev:hover,
#heroCarousel .carousel-control-next:hover{ background:var(--blue); border-color:var(--blue); }
#heroCarousel .carousel-control-prev-icon,
#heroCarousel .carousel-control-next-icon{ width:20px; height:20px; }
.carousel-indicators [data-bs-target]{
  width:10px; height:10px; border-radius:50%;
  background:rgba(255,255,255,.38); border:none; margin:0 5px;
  transition:background .3s,transform .3s;
}
.carousel-indicators .active{ background:var(--blue); transform:scale(1.3); }

/* ── STATS ── */
.stats-strip{ background:var(--navy2); }
.stat-item{
  padding:26px 16px; text-align:center;
  border-right:1px solid rgba(255,255,255,.07);
}
.stat-item:last-child{ border-right:none; }
.stat-n{ font-family:var(--fn-h); font-size:1.9rem; font-weight:800; color:var(--blue); line-height:1; }
.stat-l{ font-size:.84rem; color:rgba(255,255,255,.5); margin-top:5px; font-weight:500; }

/* ── WAVE ── */
.wave svg{ display:block; }

/* ── SECTIONS ── */
.sec-hd{ margin-bottom:54px; }
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--fn-h); font-size:.74rem; font-weight:800;
  letter-spacing:.18em; text-transform:uppercase; color:var(--blue2); margin-bottom:12px;
}
.eyebrow::before{ content:''; width:8px; height:8px; border-radius:50%; background:var(--blue); flex-shrink:0; }
.eyebrow.inv{ color:var(--blue); }
.eyebrow.inv::before{ background:var(--blue); }
.sec-title{
  font-size:clamp(1.85rem,3vw,2.55rem);
  font-weight:800; letter-spacing:-.025em; line-height:1.15; margin-bottom:14px;
}
.sec-sub{ color:var(--muted); font-size:1.02rem; max-width:600px; line-height:1.78; }

/* ── SERVICE CARDS ── */
.svc-card{
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--r); padding:32px 24px 28px;
  height:100%; position:relative; overflow:hidden;
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.svc-card::before{
  content:''; position:absolute; top:0;left:0;right:0; height:3px;
  background:linear-gradient(90deg,var(--blue3),var(--blue));
  transform:scaleX(0); transform-origin:left; transition:transform .3s;
}
.svc-card:hover{ transform:translateY(-6px); box-shadow:0 16px 48px rgba(14,165,233,.13); border-color:#bae6fd; }
.svc-card:hover::before{ transform:scaleX(1); }
.svc-ico{
  width:54px; height:54px; border-radius:14px;
  background:linear-gradient(135deg,#f0f9ff,#e0f2fe);
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; color:var(--blue2); margin-bottom:18px;
}
.svc-card h5{ font-family:var(--fn-h); font-weight:700; font-size:1.05rem; margin-bottom:10px; }
.svc-card p{ font-size:.88rem; color:var(--muted); line-height:1.65; margin:0; }
.svc-badge{
  display:inline-block; margin-top:14px;
  font-family:var(--fn-h); font-size:.67rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase; padding:4px 12px; border-radius:50px;
}
.b-blue  { background:#f0f9ff; color:var(--blue3); }
.b-sky   { background:#e0f2fe; color:#0369a1; }
.b-indigo{ background:#eef2ff; color:#4338ca; }
.b-green { background:#f0fdf4; color:#166534; border:1px solid #bbf7d0; }

/* ── INFRA ── */
.infra-wrap{
  background:linear-gradient(160deg,var(--navy) 0%,var(--navy2) 50%,#0c2440 100%);
}
.infra-card{
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.09);
  border-radius:var(--r); padding:32px 24px; height:100%;
  transition:background .25s,transform .25s,box-shadow .25s;
}
.infra-card:hover{ background:rgba(255,255,255,.09); transform:translateY(-5px); box-shadow:0 14px 44px rgba(0,0,0,.35); }
.infra-card.feat{ background:rgba(14,165,233,.1); border-color:rgba(14,165,233,.3); }
.infra-ico{
  width:54px; height:54px; border-radius:13px;
  background:rgba(14,165,233,.15);
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; color:var(--blue); margin-bottom:18px;
}
.infra-card h5{ font-family:var(--fn-h); font-weight:700; color:#fff; font-size:1.05rem; margin-bottom:10px; }
.infra-card p{ font-size:.88rem; color:rgba(255,255,255,.58); line-height:1.65; margin:0; }
.infra-card ul{ margin:14px 0 0; padding:0; list-style:none; }
.infra-card ul li{
  font-size:.82rem; color:rgba(255,255,255,.52);
  padding:3px 0; display:flex; align-items:center; gap:8px;
}
.infra-card ul li::before{ content:'✓'; color:var(--blue); font-weight:800; flex-shrink:0; }

/* ── PORTFOLIO ── */
.pf-card{
  border-radius:var(--r); overflow:hidden; position:relative;
  box-shadow:0 4px 20px rgba(0,0,0,.1);
  transition:transform .3s,box-shadow .3s;
}
.pf-card:hover{ transform:translateY(-5px); box-shadow:0 16px 48px rgba(0,0,0,.18); }
.pf-card img{ width:100%; aspect-ratio:4/3; object-fit:cover; display:block; transition:transform .55s; }
.pf-card:hover img{ transform:scale(1.05); }
.pf-overlay{
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(7,17,31,.9) 0%,rgba(7,17,31,.2) 55%,transparent 100%);
  display:flex; flex-direction:column; justify-content:flex-end; padding:24px;
}
.pf-cat{
  display:inline-block; align-self:flex-start;
  font-family:var(--fn-h); font-size:.65rem; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase;
  background:var(--blue); color:#fff;
  padding:4px 12px; border-radius:50px; margin-bottom:9px;
}
.pf-overlay h5{ font-family:var(--fn-h); font-weight:700; color:#fff; font-size:1.05rem; margin:0 0 12px; }
.pf-overlay a{
  display:inline-flex; align-items:center; gap:7px; align-self:flex-start;
  background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.28);
  color:#fff; font-family:var(--fn-h); font-size:.82rem; font-weight:600;
  padding:7px 16px; border-radius:9px; backdrop-filter:blur(8px);
  transition:background .2s;
}
.pf-overlay a:hover{ background:rgba(14,165,233,.5); border-color:var(--blue); }
/* ── PORTFOLIO SLIDER ── */
.pf-track-wrap{
  overflow:hidden;               /* clips the partial 3rd card */
  /* fade-out right edge to hint there's more */
  -webkit-mask-image: linear-gradient(to right, black 85%, transparent 100%);
  mask-image: linear-gradient(to right, black 85%, transparent 100%);
}
.pf-track{
  display:flex;
  gap:24px;
  transition:transform .45s cubic-bezier(.25,.8,.25,1);
  will-change:transform;
  cursor:grab;
}
.pf-track.dragging{ cursor:grabbing; transition:none; }
.pf-slide{
  /* 2 cards + ~35% of 3rd visible = each card ~44% of wrapper */
  flex: 0 0 calc(44% - 12px);
  min-width: 0;
}
@media(max-width:991px){ .pf-slide{ flex: 0 0 calc(70% - 12px); } }
@media(max-width:600px) { .pf-slide{ flex: 0 0 calc(90% - 12px); } }

/* Arrow buttons */
.pf-arrows{ display:flex; gap:10px; }
.pf-arr{
  width:48px; height:48px; border-radius:50%;
  border:1.5px solid var(--border);
  background:var(--white);
  color:var(--navy2);
  font-size:1.1rem;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:background .2s, border-color .2s, color .2s;
}
.pf-arr:hover{ background:var(--blue2); border-color:var(--blue2); color:#fff; }
.pf-arr:disabled{ opacity:.35; cursor:default; }
.pf-arr:disabled:hover{ background:var(--white); border-color:var(--border); color:var(--navy2); }

/* ── SUPPORT ── */
.support-wrap{
  background:linear-gradient(135deg,var(--light) 0%,#f0f9ff 100%);
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
}
/* Steps */
.support-steps{ display:flex; gap:0; flex-wrap:wrap; margin-top:36px; }
.support-step{
  display:flex; align-items:flex-start; gap:16px;
  flex:1; min-width:180px; padding:0 24px 0 0; position:relative;
}
.support-step:not(:last-child)::after{
  content:''; position:absolute; right:0; top:24px;
  width:1px; height:32px; background:var(--border);
}
.step-num{
  width:44px; height:44px; border-radius:50%; flex-shrink:0;
  background:var(--blue2); color:#fff;
  font-family:var(--fn-h); font-weight:800; font-size:1rem;
  display:flex; align-items:center; justify-content:center;
}
.step-text h6{ font-family:var(--fn-h); font-weight:700; font-size:.95rem; margin-bottom:3px; }
.step-text p{ font-size:.82rem; color:var(--muted); margin:0; line-height:1.55; }

/* Download bar */
.rdsk-bar{
  display:flex; align-items:center; flex-wrap:wrap; gap:16px;
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--r); padding:22px 28px;
  box-shadow:0 4px 24px rgba(14,165,233,.07);
  margin-top:36px;
}
.rdsk-bar-label{
  display:flex; align-items:center; gap:10px;
  font-family:var(--fn-h); font-weight:700; font-size:.95rem; color:#1e293b;
  flex:1; min-width:160px;
}
.rdsk-bar-label i{ font-size:1.25rem; color:var(--blue2); }
.rdsk-bar-label small{ display:block; font-family:var(--fn-b); font-size:.78rem; font-weight:400; color:var(--muted); }
.rdsk-btns{ display:flex; gap:10px; flex-wrap:wrap; }
.rdsk-btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:11px 20px; border-radius:10px; text-decoration:none;
  font-family:var(--fn-h); transition:transform .2s,box-shadow .2s;
}
.rdsk-btn:hover{ transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,0,0,.15); }
.rdsk-btn i{ font-size:1.5rem; }
.rdsk-btn small{ display:block; font-size:.64rem; font-weight:300; opacity:.75; letter-spacing:.04em; text-transform:uppercase; }
.rdsk-btn strong{ display:block; font-size:.9rem; font-weight:700; line-height:1.1; }
.rdsk-btn.win{ background:#0078d4; color:#fff; }
.rdsk-btn.mac{ background:#1d1d1f; color:#fff; }
.rdsk-link{
  font-family:var(--fn-h); font-size:.8rem; font-weight:500;
  color:var(--blue2); text-decoration:none;
  display:flex; align-items:center; gap:5px; white-space:nowrap;
  margin-left:auto;
}
.rdsk-link:hover{ color:var(--blue3); }
@media(max-width:767px){
  .rdsk-bar{ flex-direction:column; align-items:flex-start; padding:18px; }
  .rdsk-btns{ width:100%; }
  .rdsk-btn{ flex:1; justify-content:center; }
  .rdsk-link{ margin-left:0; }
  .support-step:not(:last-child)::after{ display:none; }
  .support-steps{ gap:20px; }
}

/* ── CONTACT ── */
.contact-wrap{ background:linear-gradient(160deg,var(--navy) 0%,var(--navy2) 100%); }
.contact-card{
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r); padding:40px 24px;
  height:100%; min-height:220px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; transition:background .25s,transform .25s;
}
.contact-card:hover{ background:rgba(255,255,255,.12); transform:translateY(-4px); }
.contact-ico{ font-size:2.2rem; margin-bottom:16px; display:block; color:var(--blue); }
.contact-ico.wa{ color:#25d366; }
.contact-card h6{ font-family:var(--fn-h); font-weight:700; color:#fff; font-size:1.05rem; margin-bottom:10px; }
.contact-card a,
.contact-card p{ color:rgba(255,255,255,.62); font-size:.92rem; text-decoration:none; margin:0; line-height:1.75; }
.contact-card a:hover{ color:#fff; }

/* ── BUTTONS ── */
.btn-az{
  background:var(--blue2); color:#fff;
  font-family:var(--fn-h); font-weight:700; font-size:.9rem;
  padding:13px 28px; border-radius:11px; border:none;
  transition:background .2s,transform .2s;
}
.btn-az:hover{ background:var(--blue3); transform:translateY(-2px); color:#fff; }
.btn-sky{
  background:var(--blue); color:#fff;
  font-family:var(--fn-h); font-weight:700; font-size:.9rem;
  padding:13px 28px; border-radius:11px; border:none;
  transition:background .2s,transform .2s;
}
.btn-sky:hover{ background:var(--blue2); transform:translateY(-2px); color:#fff; }
.btn-ghost{
  background:transparent; color:#fff;
  font-family:var(--fn-h); font-weight:600; font-size:.9rem;
  padding:12px 26px; border-radius:11px;
  border:2px solid rgba(255,255,255,.3);
  transition:border-color .2s,background .2s;
}
.btn-ghost:hover{ border-color:#fff; background:rgba(255,255,255,.1); color:#fff; }

/* ── FOOTER ── */
footer{ background:#040d18; padding:52px 0 0; color:#5e7a90; }
.ft-logo{ height:36px; filter:brightness(0) invert(1); opacity:.8; margin-bottom:16px; }
footer p{ font-size:.86rem; line-height:1.8; }
.ft-fb{
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.09);
  color:#fff; font-family:var(--fn-h); font-size:.8rem; font-weight:600;
  padding:8px 16px; border-radius:9px; transition:background .2s; text-decoration:none;
}
.ft-fb:hover{ background:rgba(24,119,242,.22); border-color:#1877f2; color:#fff; }
footer h6{ font-family:var(--fn-h); font-size:.72rem; font-weight:800; letter-spacing:.16em; text-transform:uppercase; color:#fff; margin-bottom:16px; }
footer ul{ list-style:none; padding:0; margin:0; }
footer ul li{ padding:3px 0; }
footer a{ color:#5e7a90; font-size:.85rem; text-decoration:none; transition:color .2s; }
footer a:hover{ color:#fff; }
.ft-bottom{ border-top:1px solid rgba(255,255,255,.05); padding:18px 0; margin-top:44px; font-size:.78rem; color:#253545; }

/* ── RESPONSIVE ── */
.hero-row{
  min-height:92vh;
  padding-top:100px;  /* clear fixed navbar */
  padding-bottom:48px;
}
@media(max-width:991px){
  .navbar-nav .nav-link{ padding:11px 20px !important; }
  .navbar-nav .nav-link::after{ display:none; }
  .nav-contact-btn{ margin:6px 20px 14px; }
  .hero-row{ min-height:88vh; padding-top:90px; }
}
@media(max-width:767px){
  .hero-slide{ min-height:unset; }
  .hero-row{ min-height:100svh; padding-top:80px; padding-bottom:40px; }
  .hero-badge{ font-size:.68rem; padding:5px 14px; }
  .btn-ghost{ padding:10px 18px; font-size:.85rem; }
  .btn-sky{ padding:12px 22px; font-size:.88rem; }
  .stats-strip .col-6:nth-child(odd){ border-right:1px solid rgba(255,255,255,.07); }
  .stats-strip .col-6{ border-bottom:1px solid rgba(255,255,255,.07); }
  .stats-strip .col-6:nth-last-child(-n+2){ border-bottom:none; }
  #heroCarousel .carousel-control-prev,
  #heroCarousel .carousel-control-next{ display:none; }
  .d-flex.flex-wrap.gap-3{ gap:.75rem !important; }
}