/* ── VARIABLES ── */
:root {
  --navy:    #01081B;
  --navy2:   #060D26;
  --navy3:   #0B1535;
  --purple:  #6C28E2;
  --purple2: #4F4FB0;
  --blue:    #4E7BEF;
  --blueL:   #7BA3FF;
  --grad:    linear-gradient(135deg, #6C28E2 0%, #4E7BEF 100%);
  --white:   #FFFFFF;
  --offW:    #EEF2FF;
  --slate:   #7A85AA;
  --muted:   #3D4A6B;
  --border:  rgba(108,40,226,0.22);
  --cream:   #F2EDE4;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:'Inter', 'Segoe UI', sans-serif;
  background:var(--navy);
  color:var(--white);
  overflow-x:hidden;
}
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:var(--navy); }
::-webkit-scrollbar-thumb { background:var(--purple); }

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.1rem 2rem;
  background:rgba(1,8,27,0.88);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  transition:background .3s;
}
.nav-logo { text-decoration:none; }
.nav-logo-text {
  font-family:'Exo 2','Segoe UI',sans-serif; font-weight:800;
  font-size:1.3rem; letter-spacing:.02em; color:var(--white);
}
.nav-logo-text span { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.nav-logo-sub { font-size:.58rem; letter-spacing:.18em; text-transform:uppercase; color:var(--slate); display:block; margin-top:.1rem; }
.nav-links { display:flex; gap:2rem; list-style:none; }
.nav-links a { font-size:.82rem; color:var(--slate); text-decoration:none; letter-spacing:.04em; transition:color .2s; }
.nav-links a:hover { color:var(--blueL); }
.nav-btn {
  font-family:'Exo 2','Segoe UI',sans-serif; font-weight:700; font-size:.78rem;
  letter-spacing:.08em; text-transform:uppercase;
  background:var(--grad); color:var(--white); border:none;
  padding:.65rem 1.5rem; cursor:pointer; text-decoration:none;
  transition:opacity .2s, transform .15s; border-radius:2px;
}
.nav-btn:hover { opacity:.9; transform:scale(1.03); }

/* ── HERO ── */
#hero {
  height:calc(100vh - 72px); min-height:560px; max-height:860px;
  position:relative; display:flex; align-items:stretch; overflow:hidden;
  background:linear-gradient(180deg,#01081B 0%,#060D26 60%,#0B1535 100%);
  padding:0 !important;
}
.hero-grid {
  position:absolute; inset:0;
  background-image: linear-gradient(rgba(108,40,226,.07) 1px,transparent 1px),
                    linear-gradient(90deg,rgba(108,40,226,.07) 1px,transparent 1px);
  background-size:60px 60px;
}
.orb { position:absolute; border-radius:50%; filter:blur(80px); pointer-events:none; }
.orb1 { width:500px; height:500px; background:rgba(108,40,226,.22); top:-100px; right:-80px; animation:orbFloat 8s ease-in-out infinite; }
.orb2 { width:320px; height:320px; background:rgba(78,123,239,.15); bottom:0; left:15%; animation:orbFloat 10s ease-in-out infinite reverse; }
@keyframes orbFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-28px)} }

.hero-inner {
  position:relative; z-index:2;
  max-width:1400px; width:100%; margin:0 auto;
  padding:0 2rem;
  display:grid; grid-template-columns:1fr 1fr; gap:3.5rem;
  align-items:center; height:100%;
}

/* Left */
.hero-tag {
  display:inline-flex; align-items:center; gap:.6rem;
  font-size:.68rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--blueL); margin-bottom:1rem; margin-top:1.5rem;
  opacity:0; animation:fadeUp .7s .2s forwards;
}
.hero-tag::before { content:''; width:20px; height:2px; background:var(--grad); }
.hero-h1 {
  font-family:'Exo 2','Segoe UI',sans-serif; font-weight:900;
  font-size:clamp(2rem,3.8vw,3.4rem); line-height:1.05;
  text-transform:uppercase; letter-spacing:-.01em;
  opacity:0; animation:fadeUp .8s .35s forwards;
}
.hero-h1 .g {
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; display:inline;
}
.hero-desc {
  font-size:.9rem; font-weight:300; color:var(--slate); line-height:1.7;
  max-width:420px; margin-top:1.2rem;
  opacity:0; animation:fadeUp .8s .5s forwards;
}
.hero-btns {
  display:flex; gap:.85rem; margin-top:1.6rem;
  opacity:0; animation:fadeUp .8s .65s forwards;
}
.btn-grad {
  font-family:'Exo 2','Segoe UI',sans-serif; font-weight:700; font-size:.8rem;
  letter-spacing:.08em; text-transform:uppercase;
  background:var(--grad); color:var(--white); border:none;
  padding:.9rem 2rem; cursor:pointer; text-decoration:none;
  display:inline-flex; align-items:center; gap:.5rem;
  transition:opacity .2s, transform .15s; border-radius:2px;
}
.btn-grad:hover { opacity:.9; transform:translateY(-2px); }
.btn-outline {
  font-family:'Exo 2','Segoe UI',sans-serif; font-weight:600; font-size:.8rem;
  letter-spacing:.08em; text-transform:uppercase;
  background:transparent; color:var(--blueL);
  border:1px solid rgba(78,123,239,.4);
  padding:.9rem 2rem; cursor:pointer; text-decoration:none;
  transition:border-color .2s, background .2s; border-radius:2px;
}
.btn-outline:hover { border-color:var(--blue); background:rgba(78,123,239,.08); }
.hero-stats {
  display:grid; grid-template-columns:repeat(3,1fr); gap:1px;
  margin-top:1.8rem; background:var(--border);
  opacity:0; animation:fadeUp .8s .8s forwards;
}
.hero-stat { background:rgba(6,13,38,.9); padding:.85rem .8rem; text-align:center; border-top:1px solid var(--border); }
.hero-stat-num {
  font-family:'Exo 2','Segoe UI',sans-serif; font-weight:800; font-size:1.45rem;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.hero-stat-label { font-size:.68rem; color:var(--slate); margin-top:.2rem; }

/* Right — slider */
.hero-img-wrap {
  position:relative; align-self:stretch;
  opacity:0; animation:fadeIn 1.2s .4s forwards;
  border-radius:4px; overflow:hidden;
  box-shadow:0 0 60px rgba(108,40,226,.35), 0 20px 60px rgba(0,0,0,.5);
  display:flex; flex-direction:column;
}
.hero-slider { position:relative; width:100%; flex:1; min-height:320px; overflow:hidden; }
.hero-slide {
  position:absolute; inset:0;
  opacity:0; transition:opacity 1s ease-in-out;
}
.hero-slide.active { opacity:1; }
.hero-slide img {
  width:100%; height:100%; object-fit:cover; object-position:center;
  transition:transform 8s ease-in-out;
  transform:scale(1.06);
}
.hero-slide.active img { transform:scale(1); }
.hero-slide-label {
  position:absolute; bottom:0; left:0; right:0; padding:.8rem 1rem;
  background:linear-gradient(transparent,rgba(1,8,27,.9));
  display:flex; align-items:center; gap:.6rem; z-index:2;
}
.slide-dot { width:7px; height:7px; border-radius:50%; background:var(--blue); animation:pulse 2s infinite; flex-shrink:0; }
.slide-label-text { font-family:'Exo 2',sans-serif; font-size:.68rem; letter-spacing:.1em; color:var(--offW); }
.slider-dots {
  position:absolute; bottom:2.8rem; left:50%; transform:translateX(-50%);
  display:flex; gap:.5rem; z-index:3;
}
.slider-dot-btn {
  width:6px; height:6px; border-radius:50%;
  background:rgba(255,255,255,.3); border:none; cursor:pointer; padding:0;
  transition:background .3s, transform .3s;
}
.slider-dot-btn.active { background:var(--blue); transform:scale(1.4); }
.hero-img-glow { position:absolute; inset:-2px; background:var(--grad); opacity:.25; filter:blur(20px); z-index:-1; border-radius:6px; }

/* ── MARQUEE ── */
.marquee-wrap { background:var(--grad); overflow:hidden; padding:.72rem 0; }
.marquee-track { display:flex; white-space:nowrap; animation:marquee 20s linear infinite; }
.marquee-item { font-family:'Exo 2',sans-serif; font-weight:700; font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.85); padding:0 2.2rem; }
.marquee-sep { color:rgba(255,255,255,.35); padding:0; }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ── SECTION COMMON ── */
.container { max-width:1400px; margin:0 auto; padding:0 2rem; }
section { padding:5rem 0; }
.section-eyebrow {
  font-family:'Exo 2',sans-serif; font-weight:700; font-size:.7rem;
  letter-spacing:.22em; text-transform:uppercase;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  display:flex; align-items:center; gap:.7rem; margin-bottom:1rem;
}
.section-eyebrow::before { content:''; width:22px; height:2px; background:var(--grad); flex-shrink:0; }
.section-h2 {
  font-family:'Exo 2',sans-serif; font-weight:900;
  font-size:clamp(2.2rem,4.5vw,4rem); line-height:.95;
  text-transform:uppercase; letter-spacing:-.01em; color:var(--white);
}
.section-h2 .g { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }

/* ── ABOUT ── */
#about { background:var(--navy2); }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:6rem; align-items:center; }
.about-text p { font-size:.98rem; color:var(--slate); line-height:1.8; margin-top:1.5rem; }
.about-pills { display:flex; flex-wrap:wrap; gap:.6rem; margin-top:2rem; }
.pill {
  font-family:'Exo 2',sans-serif; font-weight:600; font-size:.7rem; letter-spacing:.1em; text-transform:uppercase;
  border:1px solid var(--border); color:var(--blueL); padding:.35rem .9rem; border-radius:30px;
  background:rgba(108,40,226,.08);
}
.about-img { position:relative; }
.about-img img { width:100%; border-radius:4px; filter:brightness(.9); display:block; }
.about-img-overlay { position:absolute; inset:0; border-radius:4px; background:linear-gradient(180deg,transparent 40%,rgba(1,8,27,.8) 100%); }
.about-img-badge {
  position:absolute; bottom:1.5rem; left:1.5rem; right:1.5rem;
  background:rgba(6,13,38,.92); backdrop-filter:blur(8px); border:1px solid var(--border);
  padding:1rem 1.2rem; display:flex; align-items:center; gap:1rem;
}
.badge-dot { width:8px; height:8px; border-radius:50%; background:var(--blue); flex-shrink:0; animation:pulse 2s infinite; }
.badge-text { font-size:.82rem; color:var(--offW); line-height:1.4; }
.badge-text strong { color:var(--blueL); display:block; font-weight:600; }

/* ── SERVICES ── */
#services { background:var(--navy); }
.services-head { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:end; margin-bottom:3rem; }
.services-desc { font-size:.95rem; color:var(--slate); line-height:1.8; align-self:end; }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border); }
.svc-card {
  background:var(--navy2); padding:2.8rem 2.2rem; position:relative; overflow:hidden; transition:background .3s;
}
.svc-card::before {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:var(--grad); transform:scaleX(0); transform-origin:left;
  transition:transform .45s cubic-bezier(.16,1,.3,1);
}
.svc-card:hover::before { transform:scaleX(1); }
.svc-card:hover { background:var(--navy3); }
.svc-num { font-family:'Exo 2',sans-serif; font-weight:700; font-size:.65rem; letter-spacing:.2em; color:var(--muted); margin-bottom:1.8rem; }
.svc-icon-wrap {
  width:54px; height:54px; border-radius:4px;
  background:rgba(108,40,226,.15); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center; margin-bottom:1.6rem; transition:background .3s;
}
.svc-icon-wrap svg { width:26px; height:26px; opacity:.85; }
.svc-card:hover .svc-icon-wrap { background:var(--grad); }
.svc-h3 { font-family:'Exo 2',sans-serif; font-weight:800; font-size:1.45rem; text-transform:uppercase; line-height:1.1; color:var(--white); margin-bottom:.9rem; }
.svc-desc { font-size:.88rem; color:var(--slate); line-height:1.75; }
.svc-tags { display:flex; flex-wrap:wrap; gap:.45rem; margin-top:1.6rem; }
.svc-tag {
  font-size:.65rem; font-family:'Exo 2',sans-serif; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  border:1px solid rgba(108,40,226,.3); color:rgba(123,163,255,.7); padding:.25rem .65rem; border-radius:30px;
  transition:border-color .2s, color .2s;
}
.svc-card:hover .svc-tag { border-color:rgba(108,40,226,.6); color:var(--blueL); }

/* ── PORTFOLIO ── */
#work { background:var(--navy2); }
.work-head { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:2.2rem; }
.port-grid-top { display:grid; grid-template-columns:1.5fr 1fr 1fr; gap:4px; margin-bottom:4px; }
.port-grid-bot { display:grid; grid-template-columns:repeat(4,1fr); gap:4px; }
.port-item { position:relative; overflow:hidden; background:var(--navy3); }
.port-item img {
  width:100%; height:100%; object-fit:cover; display:block;
  min-height:220px; max-height:340px;
  transition:transform .6s cubic-bezier(.16,1,.3,1), filter .4s;
  filter:brightness(.88) saturate(1.05);
}
.port-grid-bot .port-item img { min-height:180px; max-height:220px; }
.port-item:hover img { transform:scale(1.05); filter:brightness(1) saturate(1.15); }
.port-overlay {
  position:absolute; inset:0;
  background:linear-gradient(transparent 50%,rgba(1,8,27,.88) 100%);
  opacity:0; transition:opacity .3s;
  display:flex; align-items:flex-end; padding:1rem 1.2rem;
}
.port-item:hover .port-overlay { opacity:1; }
.port-overlay span {
  font-family:'Exo 2',sans-serif; font-weight:700; font-size:.72rem;
  letter-spacing:.1em; text-transform:uppercase;
  background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}

/* ── PROCESS ── */
#process { background:var(--navy); }
.process-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border); margin-top:3rem; }
.process-step { background:var(--navy2); padding:3rem 2.4rem; position:relative; }
.process-step::before {
  content:attr(data-num); position:absolute; top:2.5rem; right:2rem;
  font-family:'Exo 2',sans-serif; font-weight:900; font-size:5.5rem; line-height:1;
  color:rgba(108,40,226,.06); pointer-events:none;
}
.step-icon {
  width:44px; height:44px; border-radius:50%; background:var(--grad);
  display:flex; align-items:center; justify-content:center; margin-bottom:1.5rem;
}
.step-icon svg { width:20px; height:20px; }
.step-h3 { font-family:'Exo 2',sans-serif; font-weight:800; font-size:1.25rem; text-transform:uppercase; color:var(--white); margin-bottom:.7rem; }
.step-desc { font-size:.88rem; color:var(--slate); line-height:1.75; }

/* ── CONTACT ── */
#contact { background:linear-gradient(135deg,#0E0535 0%,#1A0A50 40%,#0B1535 100%); }
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:stretch; }
.contact-details { margin-top:2.5rem; display:flex; flex-direction:column; gap:1.6rem; }
.contact-item { display:flex; align-items:flex-start; gap:1rem; }
.contact-icon {
  width:38px; height:38px; border-radius:50%; flex-shrink:0;
  background:rgba(108,40,226,.25); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
}
.contact-icon svg { width:17px; height:17px; }
.contact-label { font-size:.68rem; letter-spacing:.12em; text-transform:uppercase; color:var(--slate); margin-bottom:.3rem; }
.contact-value { font-size:.95rem; color:var(--offW); line-height:1.5; }
.contact-link { text-decoration:none; color:var(--blueL); transition:color .2s; }
.contact-link:hover { color:var(--white); }
.contact-cta { margin-top:2.5rem; display:inline-flex; align-items:center; gap:.5rem; border:none; cursor:pointer; }
.contact-map {
  position:relative; border-radius:4px; overflow:hidden; min-height:420px;
  border:1px solid var(--border); box-shadow:0 0 60px rgba(108,40,226,.2);
}
.contact-map iframe { position:absolute; inset:0; width:100%; height:100%; filter:invert(90%) hue-rotate(180deg) saturate(.8) brightness(.85); }
.map-badge {
  position:absolute; bottom:1rem; left:1rem; right:1rem;
  background:rgba(6,13,38,.92); backdrop-filter:blur(8px);
  border:1px solid var(--border); padding:.7rem 1rem;
  display:flex; align-items:center; gap:.6rem;
  font-family:'Exo 2',sans-serif; font-size:.72rem; letter-spacing:.08em; color:var(--offW); border-radius:2px;
}

/* ── MODAL ── */
.modal-overlay {
  display:none; position:fixed; inset:0; z-index:500;
  background:rgba(1,8,27,.85); backdrop-filter:blur(8px);
  align-items:center; justify-content:center;
}
.modal-overlay.open { display:flex; }
.modal {
  background:var(--navy3); border:1px solid var(--border); border-radius:4px;
  padding:2.8rem; width:100%; max-width:520px; position:relative;
  box-shadow:0 0 80px rgba(108,40,226,.3); animation:fadeUp .35s ease;
}
.modal-close { position:absolute; top:1.2rem; right:1.2rem; background:none; border:none; color:var(--slate); cursor:pointer; font-size:1.4rem; line-height:1; transition:color .2s; }
.modal-close:hover { color:var(--white); }
.modal h3 { font-family:'Exo 2',sans-serif; font-weight:800; font-size:1.5rem; text-transform:uppercase; color:var(--white); margin-bottom:.4rem; }
.modal-sub { font-size:.85rem; color:var(--slate); margin-bottom:2rem; }
.form-group { margin-bottom:1.2rem; }
.form-group label { display:block; font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--slate); margin-bottom:.45rem; font-family:'Exo 2',sans-serif; font-weight:600; }
.form-group input, .form-group textarea {
  width:100%; background:rgba(255,255,255,.05); border:1px solid var(--border);
  color:var(--white); padding:.75rem 1rem; font-size:.9rem; border-radius:2px; outline:none; transition:border-color .2s;
}
.form-group input:focus, .form-group textarea:focus { border-color:var(--purple); }
.form-group textarea { height:110px; resize:vertical; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.modal-submit { width:100%; margin-top:.5rem; justify-content:center; font-size:.82rem; padding:1rem; }
.modal-success { display:none; text-align:center; padding:1rem 0; }
.modal-success p { color:var(--offW); font-size:.95rem; }

/* ── FOOTER ── */
footer { background:var(--navy); border-top:1px solid var(--border); padding:3.5rem 0 2rem; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:4rem; padding-bottom:3rem; border-bottom:1px solid rgba(255,255,255,.05); }
.footer-logo-text { font-family:'Exo 2',sans-serif; font-weight:800; font-size:1.4rem; color:var(--white); letter-spacing:.02em; }
.footer-logo-text span { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.footer-logo-sub { font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-top:.2rem; }
.footer-brand-desc { font-size:.85rem; color:var(--slate); line-height:1.75; margin-top:1.2rem; max-width:280px; }
.footer-col-title { font-family:'Exo 2',sans-serif; font-weight:700; font-size:.65rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-bottom:1.2rem; }
.footer-col ul { list-style:none; }
.footer-col li { margin-bottom:.65rem; }
.footer-col a { font-size:.85rem; color:var(--slate); text-decoration:none; transition:color .2s; }
.footer-col a:hover { color:var(--blueL); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding-top:2rem; font-size:.72rem; color:var(--muted); }
.footer-live { display:flex; align-items:center; gap:.5rem; color:var(--blueL); }
.live-dot { width:6px; height:6px; border-radius:50%; background:var(--blue); animation:pulse 2s infinite; }

/* ── ANIMATIONS ── */
@keyframes fadeUp { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:none} }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
@keyframes pulse { 0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(78,123,239,.4)} 50%{opacity:.7;box-shadow:0 0 0 6px rgba(78,123,239,0)} }

.reveal { opacity:0; transform:translateY(24px); transition:opacity .7s, transform .7s cubic-bezier(.16,1,.3,1); }
.reveal.vis { opacity:1; transform:none; }
.r1{transition-delay:.1s} .r2{transition-delay:.2s} .r3{transition-delay:.3s}


.nav-logo { display:flex; flex-direction:column; text-decoration:none; }
.nav-logo-text { font-family:'Exo 2','Segoe UI',sans-serif; font-weight:800; font-size:1.3rem; letter-spacing:.02em; color:var(--white); }
.nav-logo-text span { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.nav-logo-sub { font-size:.58rem; letter-spacing:.18em; text-transform:uppercase; color:var(--slate); margin-top:.1rem; }
.footer-logo-text { font-family:'Exo 2','Segoe UI',sans-serif; font-weight:800; font-size:1.4rem; color:var(--white); letter-spacing:.02em; }
.footer-logo-text span { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.footer-logo-sub { font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-top:.2rem; }

/* ── RESPONSIVE ── */
@media(max-width:920px){
  .hero-inner { grid-template-columns:1fr; padding:5rem 1.5rem 3rem; height:auto; }
  .hero-img-wrap { display:none; }
  #about .about-grid { grid-template-columns:1fr; padding:5rem 2rem; gap:3rem; }
  .services-head { grid-template-columns:1fr; }
  .services-grid { grid-template-columns:1fr; }
  .port-grid-top { grid-template-columns:1fr 1fr; }
  .port-grid-bot { grid-template-columns:1fr 1fr; }
  .process-grid { grid-template-columns:1fr; }
  .contact-grid { grid-template-columns:1fr; gap:3rem; }
  .contact-map { min-height:300px; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:2.5rem; }
  nav { padding:1.1rem 1.5rem; }
  .nav-links { display:none; }
  section { padding:4rem 0; }
  .container { padding:0 1.5rem; }
  .form-grid { grid-template-columns:1fr; }
}
