/* ============================================================
   HAPTREND CONNECT — Complete Stylesheet
   Version: 2.0 (Upgraded Hero)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=Nunito:wght@300;400;500;600;700&display=swap');

/* ── CSS VARIABLES ── */
:root {
    --blue-dark:    #0A2540;
    --blue-deep:    #061828;
    --blue-mid:     #1565C0;
    --blue-brand:   #0D47A1;
    --cyan-bright:  #00B0FF;
    --cyan-light:   #18FFFF;
    --cyan-pale:    #B3E5FC;
    --white:        #FFFFFF;
    --off-white:    #F0F8FF;
    --text:         #1A2E44;
    --text-light:   #5A7A96;
    --border:       rgba(0,176,255,0.18);
    --glass-bg:     rgba(255,255,255,0.05);
    --glass-border: rgba(0,176,255,0.25);
    --shadow-cyan:  0 8px 40px rgba(0,176,255,0.25);
    --shadow-blue:  0 8px 40px rgba(13,71,161,0.3);
    --ff-display:   'Rajdhani', sans-serif;
    --ff-body:      'Nunito', sans-serif;
    --radius:       12px;
    --radius-lg:    20px;
    --transition:   all 0.35s cubic-bezier(0.4,0,0.2,1);
}

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body { font-family:var(--ff-body); background:var(--blue-dark); color:var(--white); overflow-x:hidden; line-height:1.6; }
a { text-decoration:none; color:inherit; }
img { max-width:100%; display:block; }
ul { list-style:none; }
button { cursor:pointer; border:none; background:none; font-family:var(--ff-body); }

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:var(--blue-dark); }
::-webkit-scrollbar-thumb { background:var(--cyan-bright); border-radius:3px; }

/* ── UTILITY ── */
.container { max-width:1200px; margin:0 auto; padding:0 5%; }
.section-pad { padding:6rem 0; }
.tag-label {
    display:inline-block;
    font-family:var(--ff-display);
    font-size:0.72rem;
    letter-spacing:3.5px;
    text-transform:uppercase;
    color:var(--cyan-bright);
    border:1px solid rgba(0,176,255,0.4);
    padding:0.35rem 1rem;
    border-radius:100px;
    margin-bottom:1rem;
}
.section-title {
    font-family:var(--ff-display);
    font-size:clamp(2rem,5vw,3.4rem);
    font-weight:700;
    line-height:1.1;
    letter-spacing:1px;
}
.section-title span { color:var(--cyan-bright); }
.divider-cyan {
    width:60px; height:3px;
    background:linear-gradient(90deg,var(--cyan-bright),transparent);
    border-radius:2px;
    margin:1.2rem 0 1.6rem;
}
.section-desc {
    font-size:1.05rem;
    color:rgba(255,255,255,0.65);
    font-weight:300;
    line-height:1.85;
    max-width:520px;
}
.btn-primary {
    display:inline-flex; align-items:center; gap:0.5rem;
    background:linear-gradient(135deg,var(--cyan-bright),var(--blue-mid));
    color:var(--white);
    padding:0.85rem 2rem;
    border-radius:var(--radius);
    font-family:var(--ff-display);
    font-size:0.95rem; font-weight:600; letter-spacing:1px;
    transition:var(--transition);
    box-shadow:var(--shadow-cyan);
}
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 14px 50px rgba(0,176,255,0.45); }
.btn-outline {
    display:inline-flex; align-items:center; gap:0.5rem;
    background:transparent; color:var(--cyan-bright);
    padding:0.85rem 2rem; border-radius:var(--radius);
    font-family:var(--ff-display);
    font-size:0.95rem; font-weight:600; letter-spacing:1px;
    border:2px solid var(--cyan-bright);
    transition:var(--transition);
}
.btn-outline:hover { background:rgba(0,176,255,0.12); transform:translateY(-3px); }

/* ================================================================
   NAVBAR
   ================================================================ */
#navbar {
    position:fixed; top:0; left:0; right:0;
    z-index:1000;
    padding:1.2rem 5%;
    display:flex; align-items:center; justify-content:space-between;
    transition:var(--transition);
}
#navbar.scrolled {
    background:rgba(6,24,40,0.97);
    backdrop-filter:blur(20px);
    padding:0.75rem 5%;
    border-bottom:1px solid var(--border);
    box-shadow:0 4px 30px rgba(0,0,0,0.5);
}
.nav-logo img { height:52px; width:auto; transition:var(--transition); }
#navbar.scrolled .nav-logo img { height:40px; }
.nav-links { display:flex; align-items:center; gap:2.2rem; }
.nav-links a {
    font-family:var(--ff-display);
    font-size:0.88rem; font-weight:500;
    letter-spacing:1.5px; text-transform:uppercase;
    color:rgba(255,255,255,0.75);
    transition:var(--transition); position:relative;
}
.nav-links a::after {
    content:''; position:absolute; bottom:-4px; left:0;
    width:0; height:2px; background:var(--cyan-bright);
    border-radius:2px; transition:width 0.3s ease;
}
.nav-links a:hover { color:var(--cyan-bright); }
.nav-links a:hover::after { width:100%; }
.nav-cta {
    background:linear-gradient(135deg,var(--cyan-bright),var(--blue-mid));
    color:var(--white) !important;
    padding:0.55rem 1.4rem; border-radius:var(--radius);
    font-weight:600 !important;
}
.nav-cta::after { display:none !important; }
.nav-cta:hover { opacity:0.88; transform:translateY(-2px); }
.nav-hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; z-index:1010; }
.nav-hamburger span { display:block; width:26px; height:2px; background:var(--cyan-bright); border-radius:2px; transition:var(--transition); }

/* Mobile Nav */
.mobile-nav {
    display:none; position:fixed;
    inset:0; z-index:999;
    background:rgba(6,24,40,0.98); backdrop-filter:blur(24px);
    flex-direction:column; align-items:center; justify-content:center; gap:2rem;
}
.mobile-nav.open { display:flex; }
.mobile-nav a {
    font-family:var(--ff-display); font-size:2rem; font-weight:700;
    letter-spacing:3px; text-transform:uppercase;
    color:rgba(255,255,255,0.7); transition:var(--transition);
}
.mobile-nav a:hover { color:var(--cyan-bright); }
.mobile-close {
    position:absolute; top:1.5rem; right:5%;
    font-size:2rem; color:rgba(255,255,255,0.4); cursor:pointer;
    font-family:var(--ff-display); transition:var(--transition);
}
.mobile-close:hover { color:var(--cyan-bright); }

/* ================================================================
   HERO — CINEMATIC UPGRADED
   ================================================================ */
.hero {
    position:relative; min-height:100vh;
    display:flex; align-items:center;
    overflow:hidden; padding-top:80px;
}

/* Background Slideshow */
.hero-slides { position:absolute; inset:0; z-index:0; }
.hero-slide {
    position:absolute; inset:0;
    background-size:cover; background-position:center;
    opacity:0; transform:scale(1.08);
    transition:opacity 1.4s cubic-bezier(0.4,0,0.2,1), transform 8s cubic-bezier(0.4,0,0.2,1);
    will-change:opacity,transform;
}
.hero-slide.active { opacity:1; transform:scale(1.0); }
.hero-slide.prev   { opacity:0; transform:scale(1.06); }

/* Layered Overlays */
.hero-overlay-base {
    position:absolute; inset:0; z-index:1;
    /* background:rgba(6,18,34,0.65); */
}
.hero-overlay-gradient {
    position:absolute; inset:0; z-index:2;
    background:
        linear-gradient(105deg, rgba(6,18,34,0.88) 0%, rgba(6,18,34,0.3) 55%, rgba(0,176,255,0.05) 100%),
        linear-gradient(to top, rgba(6,18,34,0.92) 0%, transparent 45%);
}
.hero-overlay-vignette {
    position:absolute; inset:0; z-index:3;
    background:radial-gradient(ellipse at center, transparent 40%, rgba(4,10,20,0.6) 100%);
}

/* Particle Canvas */
.hero-particles { position:absolute; inset:0; z-index:4; pointer-events:none; }

/* Animated Grid */
.hero-grid-overlay {
    position:absolute; inset:0; z-index:5;
    background-image:
        linear-gradient(rgba(0,176,255,0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0,176,255,0.03) 1px, transparent 1px);
    background-size:70px 70px;
    animation:gridDrift 35s linear infinite;
}
@keyframes gridDrift { from{background-position:0 0} to{background-position:70px 70px} }

/* Slide Counter */
.hero-slide-counter {
    position:absolute; bottom:6rem; right:5%; z-index:20;
    display:flex; align-items:center; gap:0.75rem;
    font-family:var(--ff-display); font-size:0.8rem;
    letter-spacing:2px; color:rgba(255,255,255,0.4);
}
.slide-track { width:60px; height:1px; background:rgba(255,255,255,0.15); border-radius:2px; overflow:hidden; }
.slide-fill { height:100%; background:var(--cyan-bright); border-radius:2px; transition:width 5.5s linear; }
.slide-current { color:var(--cyan-bright); font-weight:700; font-size:1rem; }

/* Slide Dots */
.hero-dots {
    position:absolute; bottom:2.8rem; left:50%; transform:translateX(-50%);
    z-index:20; display:flex; gap:0.6rem; align-items:center;
}
.hero-dot { width:6px; height:6px; border-radius:3px; background:rgba(255,255,255,0.25); cursor:pointer; transition:all 0.4s; }
.hero-dot.active { width:24px; background:var(--cyan-bright); }

/* Hero Inner Layout */
.hero-inner {
    position:relative; z-index:10;
    display:grid; grid-template-columns:1fr 0.85fr;
    gap:3rem; align-items:center;
    max-width:1280px; margin:0 auto;
    padding:3rem 5%; width:100%;
}

/* Pill Tag */
.hero-pill {
    display:inline-flex; align-items:center; gap:0.6rem;
    background:rgba(0,176,255,0.1);
    border:1px solid rgba(0,176,255,0.3);
    border-radius:100px;
    padding:0.4rem 1.1rem 0.4rem 0.7rem;
    margin-bottom:1.6rem;
    font-family:var(--ff-display);
    font-size:0.78rem; letter-spacing:2px; text-transform:uppercase;
    color:rgba(255,255,255,0.85);
    backdrop-filter:blur(8px);
}
.pill-dot {
    width:7px; height:7px; border-radius:50%;
    background:var(--cyan-bright);
    box-shadow:0 0 8px var(--cyan-bright);
    animation:pillPulse 2.2s ease-in-out infinite; flex-shrink:0;
}
@keyframes pillPulse { 0%,100%{box-shadow:0 0 0 0 rgba(0,176,255,0.5)} 50%{box-shadow:0 0 0 7px rgba(0,176,255,0)} }
.pill-badge {
    background:var(--cyan-bright); color:#0A2540;
    font-size:0.65rem; font-weight:700;
    padding:0.1rem 0.5rem; border-radius:100px; margin-left:0.2rem;
}

/* Hero Title */
.hero-title {
    font-family:var(--ff-display);
    font-size:clamp(3rem,6.5vw,5.6rem);
    font-weight:700; line-height:1.02; letter-spacing:1px;
    color:#fff; margin-bottom:1.4rem;
    display:flex; flex-direction:column; gap:0.08em;
}
.title-line { display:block; overflow:hidden; }
.title-word { display:inline-block; }
.hl-cyan { color:var(--cyan-bright); text-shadow:0 0 40px rgba(0,176,255,0.5); }
.hl-gradient {
    background:linear-gradient(135deg,#18FFFF,#00B0FF,#1565C0);
    -webkit-background-clip:text; -webkit-text-fill-color:transparent;
    background-clip:text; filter:drop-shadow(0 0 20px rgba(0,176,255,0.35));
}
.title-sub-line { font-size:0.65em; opacity:0.85; letter-spacing:2px; margin-top:0.15em; }

/* Subtitles */
.hero-subtitle {
    font-family:var(--ff-display); font-size:1rem;
    letter-spacing:2.5px; text-transform:uppercase;
    color:var(--cyan-bright); margin-bottom:0.7rem; opacity:0.9;
}
.hero-subdesc {
    font-size:1.05rem; color:rgba(255,255,255,0.55);
    font-weight:300; line-height:1.75;
    margin-bottom:2.4rem; max-width:480px;
}

/* CTA Buttons */
.hero-btns { display:flex; gap:1.2rem; flex-wrap:wrap; margin-bottom:3rem; }
.hero-btn-primary {
    display:inline-flex; align-items:center; gap:0.6rem;
    background:linear-gradient(135deg,#00B0FF,#1565C0);
    color:#fff; padding:1rem 2.2rem; border-radius:var(--radius);
    font-family:var(--ff-display); font-size:1rem;
    font-weight:700; letter-spacing:1.5px; text-transform:uppercase;
    box-shadow:0 8px 35px rgba(0,176,255,0.4);
    transition:var(--transition); position:relative; overflow:hidden;
}
.hero-btn-primary::before {
    content:''; position:absolute; inset:0;
    background:linear-gradient(135deg,rgba(255,255,255,0.15),transparent);
    opacity:0; transition:opacity 0.3s;
}
.hero-btn-primary:hover { transform:translateY(-3px); box-shadow:0 16px 50px rgba(0,176,255,0.55); }
.hero-btn-primary:hover::before { opacity:1; }
.hero-btn-primary svg { transition:transform 0.3s; }
.hero-btn-primary:hover svg { transform:translateX(4px); }

.hero-btn-play {
    display:inline-flex; align-items:center; gap:0.9rem;
    color:rgba(255,255,255,0.8);
    font-family:var(--ff-display); font-size:0.95rem;
    font-weight:600; letter-spacing:1.5px; text-transform:uppercase;
    transition:var(--transition);
}
.play-circle {
    width:3rem; height:3rem; border-radius:50%;
    border:2px solid rgba(0,176,255,0.5);
    display:flex; align-items:center; justify-content:center;
    color:var(--cyan-bright); transition:all 0.3s;
    background:rgba(0,176,255,0.08); position:relative;
}
.play-circle::after {
    content:''; position:absolute; inset:-4px; border-radius:50%;
    border:1px solid rgba(0,176,255,0.2);
    animation:playRing 2.5s ease-in-out infinite;
}
@keyframes playRing { 0%,100%{transform:scale(1);opacity:0.6} 50%{transform:scale(1.18);opacity:0} }
.hero-btn-play:hover { color:#fff; }
.hero-btn-play:hover .play-circle { border-color:var(--cyan-bright); background:rgba(0,176,255,0.18); }

/* Stats Row */
.hero-stats-row {
    display:flex; align-items:center;
    padding-top:2rem; border-top:1px solid rgba(0,176,255,0.15);
    flex-wrap:wrap; gap:0;
}
.hero-stat { text-align:center; padding:0 2rem 0 0; }
.hero-stat strong {
    display:block; font-family:var(--ff-display);
    font-size:2.2rem; font-weight:700;
    color:var(--cyan-bright); line-height:1;
    text-shadow:0 0 20px rgba(0,176,255,0.4);
}
.hero-stat strong span { font-size:1.4rem; color:rgba(0,176,255,0.7); }
.hero-stat small {
    display:block; font-size:0.68rem; letter-spacing:2px;
    text-transform:uppercase; color:rgba(255,255,255,0.4); margin-top:0.25rem;
}
.stat-sep { width:1px; height:40px; background:rgba(0,176,255,0.18); margin:0 2rem 0 0; flex-shrink:0; }

/* Right Panel */
.hero-right-panel {
    position:relative; display:flex;
    align-items:center; justify-content:center; min-height:520px;
}
.hero-logo-card {
    position:relative; width:380px; height:380px;
    display:flex; align-items:center; justify-content:center;
}
.logo-card-glow {
    position:absolute; width:300px; height:300px; border-radius:50%;
    background:radial-gradient(circle,rgba(0,176,255,0.22) 0%,rgba(0,176,255,0.06) 50%,transparent 70%);
    animation:glowPulse 4s ease-in-out infinite;
}
@keyframes glowPulse { 0%,100%{transform:scale(1);opacity:0.8} 50%{transform:scale(1.22);opacity:1} }
.logo-ring-wrap {
    position:relative; width:100%; height:100%;
    display:flex; align-items:center; justify-content:center;
}
.lring {
    position:absolute; border-radius:50%;
    border:1px solid rgba(0,176,255,0.2);
    animation:ringFwd linear infinite;
}
.lring-1 { width:360px; height:360px; animation-duration:22s; }
.lring-2 { width:270px; height:270px; animation-duration:15s; animation-direction:reverse; border-style:dashed; border-color:rgba(0,176,255,0.12); }
.lring-3 { width:178px; height:178px; animation-duration:9s; border-color:rgba(0,176,255,0.08); }
@keyframes ringFwd { from{transform:rotate(0deg)} to{transform:rotate(360deg)} }
.lring-dot {
    position:absolute; width:10px; height:10px; border-radius:50%;
    background:var(--cyan-bright);
    box-shadow:0 0 12px var(--cyan-bright),0 0 25px rgba(0,176,255,0.4);
}
.d1 { animation:orbit1 22s linear infinite; }
.d2 { animation:orbit2 15s linear infinite; }
.d3 { animation:orbit3 9s  linear infinite; }
@keyframes orbit1 { from{transform:rotate(0deg)    translateX(180px) rotate(0deg)}     to{transform:rotate(360deg)  translateX(180px) rotate(-360deg)} }
@keyframes orbit2 { from{transform:rotate(120deg)  translateX(135px) rotate(-120deg)}  to{transform:rotate(480deg)  translateX(135px) rotate(-480deg)} }
@keyframes orbit3 { from{transform:rotate(240deg)  translateX(89px)  rotate(-240deg)}  to{transform:rotate(600deg)  translateX(89px)  rotate(-600deg)} }
.logo-hero-img {
    position:relative; z-index:5; width:210px;
    filter:drop-shadow(0 0 30px rgba(0,176,255,0.6)) drop-shadow(0 0 60px rgba(0,176,255,0.2));
    animation:logoFloat 5s ease-in-out infinite;
}
@keyframes logoFloat { 0%,100%{transform:translateY(0) scale(1)} 50%{transform:translateY(-14px) scale(1.02)} }

/* Floating Cards */
.fc {
    position:absolute; z-index:10;
    background:rgba(8,24,48,0.88);
    backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
    border:1px solid rgba(0,176,255,0.28);
    border-radius:14px; padding:0.9rem 1.3rem;
    display:flex; align-items:center; gap:0.8rem;
    box-shadow:0 10px 40px rgba(0,0,0,0.4), inset 0 1px 0 rgba(0,176,255,0.1);
    white-space:nowrap;
}
.fc-icon { font-size:1.6rem; flex-shrink:0; }
.fc-body strong { display:block; font-family:var(--ff-display); font-size:0.9rem; font-weight:700; color:#fff; }
.fc-body span   { display:block; font-size:0.72rem; color:var(--cyan-bright); letter-spacing:0.5px; }
.fc-bar { width:100%; height:3px; background:rgba(255,255,255,0.08); border-radius:2px; margin-top:0.5rem; overflow:hidden; }
.fc-bar-fill {
    height:100%; width:0%; background:linear-gradient(90deg,var(--cyan-bright),#1565C0);
    border-radius:2px; animation:barLoad 2.5s 1s ease-out forwards;
}
@keyframes barLoad { to{width:72%} }
.fc-stars { color:#FFD700; font-size:0.75rem; letter-spacing:2px; margin-left:auto; text-shadow:0 0 8px rgba(255,215,0,0.4); }
.fc-top    { top:5%;   left:-10%;  animation:fcf1 5s ease-in-out infinite; }
.fc-bottom { bottom:7%;right:-8%;  animation:fcf2 6s ease-in-out infinite; }
.fc-mid    { top:42%;  right:-12%; animation:fcf3 7s ease-in-out infinite; }
@keyframes fcf1 { 0%,100%{transform:translateY(0) rotate(-2deg)} 50%{transform:translateY(-10px) rotate(-2deg)} }
@keyframes fcf2 { 0%,100%{transform:translateY(0) rotate(2deg)}  50%{transform:translateY(-12px) rotate(2deg)} }
@keyframes fcf3 { 0%,100%{transform:translateY(0) rotate(1deg)}  50%{transform:translateY(-8px)  rotate(1deg)} }

/* Scroll Indicator */
.hero-scroll-ind {
    position:absolute; bottom:2.5rem; left:5%; z-index:20;
    display:flex; align-items:center; gap:0.8rem;
    color:rgba(255,255,255,0.3);
    font-family:var(--ff-display); font-size:0.72rem;
    letter-spacing:2.5px; text-transform:uppercase;
}
.scroll-mouse {
    width:22px; height:34px; border:1.5px solid rgba(255,255,255,0.18);
    border-radius:12px; display:flex; align-items:flex-start;
    justify-content:center; padding-top:5px;
}
.scroll-wheel {
    width:3px; height:7px; background:var(--cyan-bright);
    border-radius:2px; animation:wheelScroll 1.8s ease-in-out infinite;
}
@keyframes wheelScroll { 0%{opacity:1;transform:translateY(0)} 100%{opacity:0;transform:translateY(10px)} }

/* ================================================================
   STATS BAND
   ================================================================ */
.stats-band {
    background:linear-gradient(135deg,var(--blue-brand),#0D47A1,#005B9F);
    position:relative; overflow:hidden; padding:4rem 0;
}
.stats-band::before {
    content:''; position:absolute; inset:0;
    background-image:linear-gradient(rgba(0,176,255,0.07) 1px,transparent 1px),
                     linear-gradient(90deg,rgba(0,176,255,0.07) 1px,transparent 1px);
    background-size:40px 40px;
}
.stats-inner { position:relative; }
.stats-grid {
    display:grid; grid-template-columns:repeat(4,1fr);
    gap:1px; background:rgba(255,255,255,0.08);
    border-radius:var(--radius); overflow:hidden;
}
.stat-box {
    background:rgba(10,37,64,0.5); backdrop-filter:blur(10px);
    padding:2.5rem 1.5rem; text-align:center;
    transition:var(--transition);
}
.stat-box:hover { background:rgba(0,176,255,0.15); }
.stat-num {
    font-family:var(--ff-display); font-size:3rem; font-weight:700;
    color:var(--cyan-bright); line-height:1; display:block;
}
.stat-lbl {
    font-size:0.75rem; letter-spacing:2px; text-transform:uppercase;
    color:rgba(255,255,255,0.5); margin-top:0.6rem; display:block;
}

/* ================================================================
   SERVICES
   ================================================================ */
.services-section { background:var(--off-white); }
.services-section .section-title { color:var(--text); }
.services-section .section-desc  { color:var(--text-light); }
.services-header {
    display:grid; grid-template-columns:1fr 1fr;
    gap:3rem; align-items:end; margin-bottom:4rem;
}
.services-grid {
    display:grid; grid-template-columns:repeat(3,1fr);
    gap:1.5rem;
}
.service-card {
    background:var(--white); border-radius:var(--radius-lg);
    padding:2.5rem 2rem; border:1px solid rgba(0,176,255,0.1);
    transition:var(--transition); position:relative; overflow:hidden; cursor:default;
}
.service-card::before {
    content:''; position:absolute; inset:0;
    background:linear-gradient(135deg,rgba(0,176,255,0.05) 0%,transparent 60%);
    opacity:0; transition:var(--transition);
}
.service-card:hover { transform:translateY(-6px); box-shadow:0 20px 60px rgba(0,176,255,0.15); border-color:rgba(0,176,255,0.35); }
.service-card:hover::before { opacity:1; }
.service-card-top {
    width:3.2rem; height:3.2rem;
    background:linear-gradient(135deg,var(--cyan-bright),var(--blue-mid));
    border-radius:var(--radius); display:flex; align-items:center; justify-content:center;
    font-size:1.4rem; margin-bottom:1.5rem;
    box-shadow:0 6px 20px rgba(0,176,255,0.3);
}
.service-card h3 { font-family:var(--ff-display); font-size:1.2rem; font-weight:700; color:var(--text); margin-bottom:0.7rem; }
.service-card p   { font-size:0.88rem; color:var(--text-light); line-height:1.7; }
.service-card-link {
    display:inline-flex; align-items:center; gap:0.4rem;
    font-family:var(--ff-display); font-size:0.8rem; font-weight:600;
    color:var(--blue-brand); letter-spacing:1px; text-transform:uppercase;
    margin-top:1.2rem; transition:gap 0.3s, color 0.3s;
}
.service-card:hover .service-card-link { gap:0.7rem; color:var(--cyan-bright); }

/* ================================================================
   ABOUT
   ================================================================ */
.about-section { background:var(--blue-dark); }
.about-inner { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.about-visual { position:relative; }
.about-img-box { border-radius:var(--radius-lg); overflow:hidden; position:relative; }
.about-img-box img { width:100%; height:460px; object-fit:cover; display:block; }
.about-img-overlay {
    position:absolute; inset:0;
    background:linear-gradient(to bottom-right,rgba(0,176,255,0.12),rgba(10,37,64,0.35));
}
.about-glow {
    position:absolute; width:300px; height:300px;
    background:radial-gradient(circle,rgba(0,176,255,0.18),transparent 70%);
    top:-60px; left:-60px; border-radius:50%; z-index:-1;
}
.about-badge-float {
    position:absolute; bottom:-2rem; right:-2rem;
    background:linear-gradient(135deg,var(--cyan-bright),var(--blue-mid));
    border-radius:var(--radius-lg); padding:1.5rem 2rem;
    text-align:center; box-shadow:var(--shadow-cyan);
}
.about-badge-float strong { font-family:var(--ff-display); font-size:2.5rem; font-weight:700; display:block; line-height:1; }
.about-badge-float span   { font-size:0.7rem; letter-spacing:2px; text-transform:uppercase; opacity:0.85; }
.about-features { margin-top:2rem; display:flex; flex-direction:column; gap:1rem; }
.about-feature  { display:flex; align-items:flex-start; gap:1rem; }
.feature-dot {
    width:10px; height:10px; border-radius:50%;
    background:var(--cyan-bright); flex-shrink:0; margin-top:0.4rem;
    box-shadow:0 0 10px var(--cyan-bright);
}
.feature-text strong { font-family:var(--ff-display); font-size:0.95rem; color:var(--white); display:block; }
.feature-text span   { font-size:0.85rem; color:rgba(255,255,255,0.45); }

/* ================================================================
   GALLERY
   ================================================================ */
.gallery-section { background:var(--blue-deep); }
.gallery-header { text-align:center; margin-bottom:3.5rem; }
.gallery-header .divider-cyan { margin:1.2rem auto; }
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1rem; }
.gallery-item {
    border-radius:var(--radius); overflow:hidden; position:relative;
    aspect-ratio:4/3; border:1px solid var(--border);
}
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform 0.6s ease; display:block; }
.gallery-item:hover img { transform:scale(1.08); }
.gallery-item-overlay {
    position:absolute; inset:0;
    background:linear-gradient(to top,rgba(10,37,64,0.9) 0%,rgba(10,37,64,0.1) 60%);
    opacity:0; transition:var(--transition);
    display:flex; align-items:flex-end; padding:1.5rem;
}
.gallery-item:hover .gallery-item-overlay { opacity:1; }
.gallery-label { font-family:var(--ff-display); font-size:1rem; font-weight:600; color:var(--white); letter-spacing:1px; }
.gallery-label span { color:var(--cyan-bright); display:block; font-size:0.75rem; letter-spacing:2px; text-transform:uppercase; }

/* ================================================================
   PROCESS
   ================================================================ */
.process-section { background:var(--off-white); }
.process-section .section-title { color:var(--text); }
.process-header { text-align:center; margin-bottom:4rem; }
.process-header .divider-cyan { margin:1.2rem auto; }
.process-track {
    display:grid; grid-template-columns:repeat(4,1fr);
    position:relative; max-width:1000px; margin:0 auto;
}
.process-track::before {
    content:''; position:absolute;
    top:2.5rem; left:calc(12.5% + 10px); right:calc(12.5% + 10px);
    height:2px; background:linear-gradient(90deg,var(--cyan-bright),var(--blue-mid));
    z-index:0;
}
.process-step { position:relative; text-align:center; padding:0 1.5rem; }
.step-circle {
    width:5rem; height:5rem; border-radius:50%;
    background:linear-gradient(135deg,var(--cyan-bright),var(--blue-mid));
    display:flex; align-items:center; justify-content:center;
    margin:0 auto 1.5rem;
    font-family:var(--ff-display); font-size:1.4rem; font-weight:700; color:var(--white);
    box-shadow:0 6px 25px rgba(0,176,255,0.4); position:relative; z-index:1;
    transition:var(--transition);
}
.process-step:hover .step-circle { transform:scale(1.1); box-shadow:0 10px 35px rgba(0,176,255,0.55); }
.step-title { font-family:var(--ff-display); font-size:1.05rem; font-weight:700; color:var(--text); margin-bottom:0.5rem; }
.step-desc  { font-size:0.85rem; color:var(--text-light); line-height:1.6; }

/* ================================================================
   TESTIMONIALS
   ================================================================ */
.testimonials-section { background:var(--blue-dark); }
.testimonials-header { text-align:center; margin-bottom:4rem; }
.testimonials-header .divider-cyan { margin:1.2rem auto; }
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.testimonial-card {
    background:rgba(255,255,255,0.04); border:1px solid var(--glass-border);
    border-radius:var(--radius-lg); padding:2.5rem;
    backdrop-filter:blur(10px); transition:var(--transition);
    position:relative; overflow:hidden;
}
.testimonial-card::before {
    content:'"'; position:absolute; top:-1rem; right:1.5rem;
    font-family:var(--ff-display); font-size:8rem;
    color:var(--cyan-bright); opacity:0.07; line-height:1;
}
.testimonial-card:hover { border-color:rgba(0,176,255,0.5); background:rgba(0,176,255,0.06); transform:translateY(-4px); }
.stars { color:var(--cyan-bright); font-size:0.85rem; letter-spacing:2px; margin-bottom:1rem; }
.t-text { font-size:0.9rem; color:rgba(255,255,255,0.72); line-height:1.8; font-weight:300; font-style:italic; margin-bottom:1.5rem; }
.t-author { display:flex; align-items:center; gap:1rem; }
.t-avatar {
    width:3rem; height:3rem; border-radius:50%;
    background:linear-gradient(135deg,var(--cyan-bright),var(--blue-mid));
    display:flex; align-items:center; justify-content:center;
    font-family:var(--ff-display); font-size:0.85rem; font-weight:700; flex-shrink:0;
}
.t-name { font-family:var(--ff-display); font-size:0.95rem; font-weight:600; color:var(--white); }
.t-role { font-size:0.75rem; color:var(--cyan-bright); letter-spacing:1px; text-transform:uppercase; }

/* ================================================================
   CONTACT
   ================================================================ */
.contact-section { background:linear-gradient(135deg,#040E1C,var(--blue-dark)); }
.contact-inner { display:grid; grid-template-columns:1fr 1.3fr; gap:5rem; align-items:start; }
.contact-detail-item { display:flex; align-items:flex-start; gap:1.2rem; margin-bottom:2rem; }
.contact-icon-box {
    width:3rem; height:3rem; border-radius:var(--radius);
    background:rgba(0,176,255,0.1); border:1px solid var(--border);
    display:flex; align-items:center; justify-content:center;
    font-size:1.1rem; flex-shrink:0;
}
.contact-detail-lbl { font-size:0.7rem; letter-spacing:2px; text-transform:uppercase; color:var(--cyan-bright); margin-bottom:0.2rem; }
.contact-detail-val { font-size:0.95rem; color:rgba(255,255,255,0.8); }
.form-card {
    background:rgba(255,255,255,0.04); border:1px solid var(--glass-border);
    border-radius:var(--radius-lg); padding:3rem; backdrop-filter:blur(12px);
}
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group { margin-bottom:1.2rem; }
.form-group label {
    display:block; font-size:0.72rem; letter-spacing:2px; text-transform:uppercase;
    color:rgba(255,255,255,0.45); margin-bottom:0.5rem; font-family:var(--ff-display);
}
.form-group input,
.form-group select,
.form-group textarea {
    width:100%; padding:0.85rem 1rem;
    background:rgba(255,255,255,0.05);
    border:1px solid rgba(0,176,255,0.2);
    border-radius:var(--radius);
    font-family:var(--ff-body); font-size:0.92rem;
    color:var(--white); outline:none; transition:border-color 0.3s;
    -webkit-appearance:none;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color:rgba(255,255,255,0.22); }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color:var(--cyan-bright); background:rgba(0,176,255,0.06); }
.form-group select option { background:var(--blue-dark); color:var(--white); }
.form-group textarea { resize:vertical; min-height:120px; }
.form-submit { width:100%; padding:1rem; font-size:1rem; letter-spacing:2px; border-radius:var(--radius); justify-content:center; }
.form-success {
    background:rgba(0,176,255,0.1); border:1px solid var(--cyan-bright);
    border-radius:var(--radius); padding:1rem 1.5rem;
    color:var(--cyan-bright); font-size:0.9rem; margin-bottom:1.5rem;
}
.form-error {
    background:rgba(220,50,50,0.08); border:1px solid rgba(220,50,50,0.4);
    border-radius:var(--radius); padding:1rem 1.5rem;
    color:#ff6b6b; font-size:0.9rem; margin-bottom:1.5rem;
}

/* ================================================================
   FOOTER
   ================================================================ */
footer { background:#040C16; padding:4rem 0 2rem; border-top:1px solid var(--border); }
.footer-top {
    display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr;
    gap:3rem; padding-bottom:3rem;
    border-bottom:1px solid var(--border); margin-bottom:2rem;
}
.footer-logo img { height:50px; margin-bottom:1.2rem; }
.footer-tagline { font-size:0.88rem; color:rgba(255,255,255,0.35); line-height:1.7; max-width:280px; }
.footer-col-title {
    font-family:var(--ff-display); font-size:0.72rem;
    letter-spacing:3px; text-transform:uppercase;
    color:var(--cyan-bright); margin-bottom:1.4rem;
}
.footer-links li { margin-bottom:0.65rem; }
.footer-links a { font-size:0.88rem; color:rgba(255,255,255,0.4); transition:var(--transition); }
.footer-links a:hover { color:var(--cyan-bright); padding-left:4px; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; }
.footer-copy { font-size:0.8rem; color:rgba(255,255,255,0.22); }
.social-row { display:flex; gap:0.8rem; }
.social-btn {
    width:2.4rem; height:2.4rem; border-radius:50%;
    border:1px solid rgba(0,176,255,0.25);
    display:flex; align-items:center; justify-content:center;
    color:rgba(255,255,255,0.35); font-size:0.75rem;
    font-family:var(--ff-display); font-weight:700;
    transition:var(--transition);
}
.social-btn:hover { border-color:var(--cyan-bright); color:var(--cyan-bright); background:rgba(0,176,255,0.1); transform:translateY(-3px); }

/* Back To Top */
#backToTop {
    position:fixed; bottom:2rem; right:2rem;
    width:3rem; height:3rem; border-radius:50%;
    background:linear-gradient(135deg,var(--cyan-bright),var(--blue-mid));
    color:#fff; font-size:1.2rem;
    display:flex; align-items:center; justify-content:center;
    box-shadow:0 6px 20px rgba(0,176,255,0.4);
    opacity:0; pointer-events:none;
    transition:opacity 0.3s, transform 0.3s;
    z-index:999; border:none; cursor:pointer;
}
#backToTop:hover { transform:translateY(-3px) scale(1.08); }

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media (max-width:1100px) {
    .hero-inner { grid-template-columns:1fr; padding-top:2rem; }
    .hero-right-panel { display:none; }
    .hero-title { font-size:clamp(2.8rem,9vw,4.5rem); }
    .hero-subdesc { max-width:100%; }
    .about-inner { grid-template-columns:1fr; gap:3rem; }
    .services-header { grid-template-columns:1fr; }
    .contact-inner { grid-template-columns:1fr; gap:3rem; }
    .stats-grid { grid-template-columns:repeat(2,1fr); }
    .footer-top { grid-template-columns:1fr 1fr; }
}
@media (max-width:768px) {
    .nav-links { display:none; }
    .nav-hamburger { display:flex; }
    .services-grid { grid-template-columns:1fr; }
    .gallery-grid { grid-template-columns:repeat(2,1fr); }
    .testimonials-grid { grid-template-columns:1fr; }
    .process-track { grid-template-columns:repeat(2,1fr); }
    .process-track::before { display:none; }
    .footer-top { grid-template-columns:1fr; }
    .form-row { grid-template-columns:1fr; }
    .form-card { padding:2rem; }
    .hero-slide-counter { display:none; }
}
@media (max-width:480px) {
    .gallery-grid { grid-template-columns:1fr; }
    .stats-grid { grid-template-columns:1fr 1fr; }
    .hero-btns { flex-direction:column; align-items:flex-start; }
    .hero-stats-row { flex-wrap:wrap; row-gap:1rem; }
    .stat-sep { display:none; }
    .hero-stat { padding:0; min-width:80px; }
}
