/* ============================================================
   INFONIX CLOUD — Ultra Modern Tech UI 2025
   Dark + Glassmorphism + 3D + Vibrant Gradients
   ============================================================ */

/* ---- CSS Variables — Infonix Cloud Palette (matched to infonixcloud.com) ---- */
:root {
  /* === Core Brand Colors === */
  --primary:       #3498db;   /* Light Blue  — same as static site */
  --primary-dark:  #2980b9;   /* Darker Blue */
  --primary-light: #85c1e9;   /* Light Blue tint */
  --secondary:     #f39c12;   /* Warm Orange */
  --accent:        #e74c3c;   /* Red accent */
  --green:         #2ecc71;   /* Success green */
  --pink:          #e91e8c;   /* kept for badge use */

  /* === Dark / Background === */
  --dark:          #333333;   /* Soft dark — not pitch black */
  --dark-2:        #2c3e50;   /* Slightly blue-dark */
  --dark-3:        #3d3d3d;
  --dark-4:        #495057;

  /* === Whites / Grays === */
  --white:         #ffffff;
  --gray-50:       #f8f9fa;   /* Off-white bg — same as static */
  --gray-100:      #e9ecef;
  --gray-200:      #dee2e6;
  --gray-400:      #adb5bd;
  --gray-600:      #6c757d;

  /* === Text === */
  --text:          #333333;   /* Main body text — matches static */
  --text-light:    #6c757d;   /* Muted text */

  /* === Borders === */
  --border:        #e9ecef;
  --border-dark:   rgba(255,255,255,0.08);

  /* === Glass / Overlay === */
  --glass:         rgba(255,255,255,0.06);
  --glass-border:  rgba(255,255,255,0.12);

  /* === Shadows (lighter, cleaner) === */
  --shadow:        0 2px 8px rgba(0,0,0,0.08);
  --shadow-lg:     0 10px 30px rgba(0,0,0,0.10);
  --shadow-xl:     0 20px 60px rgba(0,0,0,0.14);
  --shadow-glow:   0 0 32px rgba(52,152,219,0.25);

  /* === Radius === */
  --radius:        8px;
  --radius-lg:     16px;
  --radius-xl:     24px;

  /* === Transitions === */
  --transition:    all 0.3s ease;

  /* === Typography === */
  --font-main:     'Poppins', sans-serif;
  --font-heading:  'Montserrat', sans-serif;

  /* === Gradients === */
  --gradient:       linear-gradient(135deg, #3498db 0%, #f39c12 100%);
  --gradient-2:     linear-gradient(135deg, #f39c12 0%, #3498db 100%);
  --gradient-3:     linear-gradient(135deg, #f39c12 0%, #e74c3c 100%);
  --gradient-dark:  linear-gradient(135deg, #2c3e50 0%, #333333 100%);
  --gradient-blue:  linear-gradient(135deg, #3498db 0%, #2980b9 100%);
}

/* ---- Reset ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-main);color:var(--text);line-height:1.7;background:#fff;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none;transition:var(--transition)}
ul{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.2;color:var(--dark)}

/* ---- Utilities ---- */
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
.section{padding:6rem 0}
.text-gradient{background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.text-gradient-2{background:var(--gradient-2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.text-primary{color:var(--primary)!important}
.text-muted{color:var(--text-light)}
.text-center{text-align:center}
.text-sm{font-size:.875rem}
.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-10{margin-top:2.5rem}.mt-16{margin-top:4rem}
.mb-4{margin-bottom:1rem}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.75rem;border-radius:50px;font-weight:600;font-size:.95rem;cursor:pointer;border:2px solid transparent;transition:var(--transition);text-decoration:none;white-space:nowrap;position:relative;overflow:hidden}
.btn-primary{background:var(--gradient-blue);color:#fff;border-color:transparent;box-shadow:0 4px 16px rgba(52,152,219,.35)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(52,152,219,.45);color:#fff}
.btn-outline{background:transparent;color:var(--primary);border-color:var(--primary)}
.btn-outline:hover{background:var(--primary);color:#fff;transform:translateY(-2px)}
.btn-outline-white{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-outline-white:hover{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.7)}
.btn-light{background:#fff;color:var(--primary);border-color:#fff;box-shadow:0 4px 16px rgba(0,0,0,.08)}
.btn-light:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.12);color:var(--primary-dark)}
.btn-whatsapp{background:#25d366;color:#fff;border-color:#25d366}
.btn-whatsapp:hover{background:#1ebe5d;color:#fff;transform:translateY(-2px)}
.btn-glass{background:var(--glass);color:#fff;border-color:var(--glass-border);backdrop-filter:blur(10px)}
.btn-glass:hover{background:rgba(255,255,255,.12);color:#fff}
.btn-lg{padding:.9rem 2.25rem;font-size:1rem}
.btn-sm{padding:.45rem 1.1rem;font-size:.85rem}
.btn-full{width:100%;justify-content:center}

/* ---- Section Headers ---- */
.section-header{text-align:center;max-width:720px;margin:0 auto 4rem}
.section-badge{display:inline-flex;align-items:center;gap:.4rem;background:rgba(52,152,219,.08);color:var(--primary);border:1px solid rgba(52,152,219,.2);padding:.35rem 1rem;border-radius:50px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;margin-bottom:.75rem}
.section-title{font-size:clamp(2rem,3.5vw,2.8rem);margin-bottom:1rem;line-height:1.2}
.section-desc{color:var(--text-light);font-size:1.05rem;line-height:1.8}

/* ---- Header ---- */
.site-header{
    position:fixed;top:0;left:0;right:0;
    z-index:1000;
    padding:.75rem 0;
    background:transparent;
    transition:var(--transition);
}

/* Pill container */
.header-pill{
    display:flex;
    align-items:center;
    justify-content:space-between;
    background:#ffffff;
    border:1px solid rgba(0,0,0,.08);
    border-radius:50px;
    padding:.5rem .5rem .5rem 1.25rem;
    box-shadow:0 4px 24px rgba(0,0,0,.08), 0 1px 4px rgba(0,0,0,.04);
    transition:var(--transition);
    gap:1rem;
}
.site-header.scrolled .header-pill{
    box-shadow:0 8px 32px rgba(0,0,0,.12), 0 2px 8px rgba(0,0,0,.06);
}

.header-inner{display:flex;align-items:center;justify-content:space-between}
.logo-link{display:flex;align-items:center;gap:.6rem;text-decoration:none;flex-shrink:0}
.logo-link img{width:36px;height:36px;border-radius:9px}
.logo-text{font-family:var(--font-heading);font-size:1.3rem;font-weight:800}

/* Desktop nav — centered */
.desktop-nav{display:flex;align-items:center;gap:.1rem;flex:1;justify-content:center}
.nav-link{color:var(--dark);padding:.45rem .8rem;border-radius:50px;font-weight:500;font-size:.875rem;transition:var(--transition)}
.nav-link:hover{color:var(--primary);background:rgba(52,152,219,.07)}
.nav-link.active{color:var(--primary);font-weight:600;background:rgba(52,152,219,.07)}

/* Right action buttons */
.header-actions{display:flex;align-items:center;gap:.4rem;flex-shrink:0}
.header-actions .btn-primary{border-radius:50px}

.mobile-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem}
.mobile-toggle span{display:block;width:22px;height:2px;background:var(--dark);border-radius:2px;transition:var(--transition)}
.mobile-nav{display:none;background:transparent;margin-top:.5rem;border-radius:0;overflow:visible}
.mobile-nav .container{background:#fff;border-radius:20px;box-shadow:0 12px 32px rgba(0,0,0,.1);overflow:hidden}
.mobile-nav nav{display:flex;flex-direction:column;padding:.75rem 0;gap:.2rem}
.mobile-nav a{color:var(--dark);padding:.7rem 1.1rem;border-radius:12px;font-weight:500;font-size:.97rem;transition:all .18s ease;display:flex;align-items:center}
.mobile-nav a:hover{color:var(--primary);background:rgba(52,152,219,.07);padding-left:1.4rem}
.mobile-nav a.active{color:var(--primary);background:rgba(52,152,219,.1);font-weight:700;border-left:3px solid var(--primary);padding-left:.9rem}
.mobile-nav .btn{margin-top:.5rem}
.btn-login{background:#fff;color:var(--primary);border:2px solid var(--primary);font-weight:600;font-size:.85rem;padding:.4rem 1rem;border-radius:50px;transition:var(--transition);text-decoration:none;display:inline-flex;align-items:center}
.btn-login:hover{background:var(--primary);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px rgba(52,152,219,.3)}

/* ---- Hero Section ---- */
.hero-section{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:var(--dark);padding-top:90px}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% -10%,rgba(52,152,219,.25),transparent),radial-gradient(ellipse 60% 40% at 80% 80%,rgba(6,182,212,.15),transparent),var(--gradient-dark)}

/* Grid bg — same as footer */
.hero-grid-bg{
    position:absolute;inset:0;
    background-image:
        linear-gradient(rgba(52,152,219,.07) 1px, transparent 1px),
        linear-gradient(90deg, rgba(52,152,219,.07) 1px, transparent 1px);
    background-size:60px 60px;
    pointer-events:none;z-index:0;
}
.hero-content{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;padding:4rem 0}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.5rem;background:rgba(52,152,219,.12);border:1px solid rgba(52,152,219,.3);color:var(--primary-light);padding:.4rem 1rem;border-radius:50px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;margin-bottom:1.5rem}
/* Eyebrow fade-in on load */
.hero-eyebrow-anim{opacity:0;transform:translateY(-8px);animation:heroEyebrowIn .6s ease forwards .1s}
@keyframes heroEyebrowIn{to{opacity:1;transform:translateY(0)}}
/* Typewriter cursor */
.hero-type-cursor{display:inline-block;color:#fff;font-weight:300;animation:cursorBlink .7s step-end infinite;margin-left:1px}
@keyframes cursorBlink{0%,100%{opacity:1}50%{opacity:0}}
/* "Future" — warm gold colour */
#heroLine2{background:linear-gradient(135deg,#f7d060,#f39c12);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
/* Highlighted portion — "With Us" stays cyan-blue */
.hero-type-highlight{background:linear-gradient(135deg,#00d4ff,#0099ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-title{font-size:clamp(2.5rem,5vw,4rem);color:#fff;margin-bottom:1.25rem;line-height:1.1;font-weight:800}
.hero-title .line-2{display:block}
.hero-desc{color:rgba(255,255,255,.65);font-size:1.1rem;margin-bottom:2rem;max-width:520px;line-height:1.8}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.5rem}
.hero-trust{display:flex;align-items:center;gap:1rem}
.hero-trust-avatars{display:flex;align-items:center}
.hero-trust-avatars img{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.3);display:block}
.hero-trust-avatars img:not(:first-child){margin-left:-10px}
.hero-trust-text{font-size:.85rem;color:rgba(255,255,255,.5)}
.hero-trust-text strong{color:#fff;display:block}
/* Avatar lift + tooltip */
.avatar-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .25s ease,z-index 0s}
.avatar-wrap:not(:first-child){margin-left:-10px}
.avatar-wrap img{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.3);display:block;transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease}
.avatar-wrap:hover{z-index:10}
.avatar-wrap:hover img{transform:translateY(-8px) scale(1.18);border-color:rgba(255,255,255,.9);box-shadow:0 8px 20px rgba(0,0,0,.4)}
.avatar-tooltip{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translateX(-50%);background:rgba(255,255,255,.95);color:#1a1a2e;font-size:.7rem;font-weight:700;padding:.3rem .65rem;border-radius:50px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s ease,transform .2s ease;transform:translateX(-50%) translateY(4px);box-shadow:0 4px 12px rgba(0,0,0,.2)}
.avatar-wrap:hover .avatar-tooltip{opacity:1;transform:translateX(-50%) translateY(0)}

/* Hero Visual */
.hero-visual{position:relative}
.hero-3d-card{position:relative;perspective:1000px}
.hero-card-inner{background:rgba(255,255,255,.04);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.5),0 0 0 1px rgba(52,152,219,.2);transform:rotateY(-5deg) rotateX(3deg);transition:transform .5s ease}
.hero-3d-card:hover .hero-card-inner{transform:rotateY(0deg) rotateX(0deg)}
.hero-card-img{height:280px;overflow:hidden;position:relative}
.hero-card-img img{width:100%;height:100%;object-fit:cover}
.hero-card-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(3,7,18,.8),transparent 50%)}
.hero-card-body{padding:1.5rem}
.hero-card-body h4{color:#fff;font-size:1rem;margin-bottom:.25rem}
.hero-card-body p{color:rgba(255,255,255,.45);font-size:.8rem}
.hero-card-tags{display:flex;gap:.4rem;margin-top:.75rem;flex-wrap:wrap}
.hero-card-tag{background:rgba(52,152,219,.2);color:var(--primary-light);padding:.2rem .65rem;border-radius:50px;font-size:.72rem;font-weight:600;border:1px solid rgba(52,152,219,.3)}

/* Floating badges */
.hero-float-badge{position:absolute;background:rgba(15,23,42,.9);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);padding:.85rem 1.1rem;color:#fff;box-shadow:0 8px 32px rgba(0,0,0,.4)}
.hero-float-badge.badge-1{top:-20px;right:-30px;animation:floatBadge 4s ease-in-out infinite}
.hero-float-badge.badge-2{bottom:20px;left:-40px;animation:floatBadge 4s ease-in-out 2s infinite}
.hfb-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:.4rem}
.hfb-icon-1{background:linear-gradient(135deg,#3498db,#06b6d4)}
.hfb-icon-2{background:linear-gradient(135deg,#f59e0b,#ef4444)}
.hfb-icon i{color:#fff;font-size:.9rem}
.hfb-num{font-size:1.5rem;font-weight:800;line-height:1;color:#fff}
.hfb-label{font-size:.72rem;color:rgba(255,255,255,.5);margin-top:.1rem}
@keyframes floatBadge{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

.hero-wave{position:absolute;bottom:0;left:0;right:0}
.hero-wave svg{display:block}

/* ---- Clients Marquee ---- */
.clients-section{padding:3rem 0;background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden}
.clients-label{text-align:center;font-size:.72rem;text-transform:uppercase;letter-spacing:3px;color:var(--text-light);margin-bottom:1.5rem;font-weight:700}
.marquee-wrapper{overflow:hidden;mask-image:linear-gradient(to right,transparent,black 8%,black 92%,transparent)}
.marquee-track{display:flex;gap:1rem;animation:marquee 35s linear infinite;width:max-content}
.marquee-track:hover{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.client-chip{display:inline-flex;align-items:center;padding:.6rem 1.5rem;background:#fff;border:1.5px solid var(--border);border-radius:50px;font-size:.85rem;font-weight:600;color:var(--text);white-space:nowrap;transition:var(--transition);box-shadow:var(--shadow)}
.client-chip:hover{border-color:var(--primary);color:var(--primary);box-shadow:0 4px 20px rgba(52,152,219,.15);transform:translateY(-2px)}

/* ---- Services Grid ---- */
.services-section{background:var(--dark-2);position:relative;overflow:hidden}
.services-section::before{content:'';position:absolute;top:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(52,152,219,.12),transparent 70%);pointer-events:none}
.services-section .section-title,.services-section .section-desc{color:#fff}
.services-section .section-title{color:#fff}
.services-section .section-desc{color:rgba(255,255,255,.55)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.service-card{background:rgba(255,255,255,.03);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.07);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);position:relative;group:true}
.service-card::before{content:'';position:absolute;inset:0;background:var(--gradient);opacity:0;transition:var(--transition);z-index:0}
.service-card:hover{transform:translateY(-8px);border-color:var(--secondary);box-shadow:0 20px 60px rgba(0,0,0,.25),0 0 0 1px var(--secondary);background:linear-gradient(135deg,#f0f8ff,#e8f4fd)}
.service-card:hover::before{opacity:0}
.service-card-img{aspect-ratio:16/9;overflow:hidden;position:relative}
.service-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;filter:brightness(1)}
.service-card:hover .service-card-img img{transform:scale(1.08);filter:brightness(1)}
.service-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(52,152,219,.15),rgba(6,182,212,.1))}
.service-img-placeholder i{font-size:3rem;color:var(--primary-light)}
.service-card-body{padding:1.75rem;position:relative;z-index:1}
.service-icon-wrap{width:52px;height:52px;background:var(--gradient);border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;box-shadow:0 4px 20px rgba(52,152,219,.4);transition:transform .3s ease,box-shadow .3s ease}
.service-card:hover .service-icon-wrap{transform:translateY(-6px) scale(1.08);box-shadow:0 12px 28px rgba(52,152,219,.5)}
.service-icon-wrap i{color:#fff;font-size:1.2rem}
.service-card-body h3{font-size:1.1rem;margin-bottom:.6rem;color:#fff;transition:var(--transition)}
.service-card:hover .service-card-body h3{color:var(--dark)}
.service-card-body p{color:rgba(255,255,255,.5);font-size:.875rem;margin-bottom:1.25rem;line-height:1.7;transition:var(--transition)}
.service-card:hover .service-card-body p{color:var(--text-light)}
.service-card:hover .service-link{color:var(--primary)}
.service-link{color:var(--primary-light);font-weight:600;font-size:.875rem;display:inline-flex;align-items:center;gap:.4rem;transition:var(--transition)}
.service-card:hover .service-link{color:var(--secondary)}
.service-link:hover{gap:.8rem;color:var(--secondary)}

/* ---- Why Us ---- */
.why-us-section{background:#fff}
.why-us-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.why-us-img{position:relative;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-xl)}
.why-us-img img{width:100%;height:auto;min-height:380px;object-fit:cover;display:block}
.why-us-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(3,7,18,.5),transparent 50%)}
.why-badge{position:absolute;bottom:1.5rem;right:1rem;background:#fff;color:var(--primary);padding:.75rem 1.25rem;border-radius:50px;font-weight:700;font-size:.875rem;box-shadow:var(--shadow-xl);display:flex;align-items:center;gap:.5rem;border:1px solid var(--border)}
.why-badge i{color:var(--secondary)}
.features-list{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}
.feature-item{display:flex;gap:1.25rem;align-items:flex-start;padding:1.25rem;border-radius:var(--radius);transition:var(--transition);border:1px solid transparent;cursor:default}
.feature-item:hover{background:var(--gray-50);border-color:var(--border);transform:translateX(4px)}
.feature-icon{width:48px;height:48px;min-width:48px;background:var(--gradient);border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(52,152,219,.3)}
.feature-icon-2{background:linear-gradient(135deg,#f59e0b,#ef4444)}
.feature-icon-3{background:linear-gradient(135deg,#06b6d4,#0891b2)}
.feature-icon-4{background:linear-gradient(135deg,#2ecc71,#059669)}
.feature-icon i{color:#fff;font-size:1rem}
.feature-item h4{font-size:.95rem;margin-bottom:.25rem}
.feature-item p{color:var(--text-light);font-size:.85rem;line-height:1.7}

/* ---- Portfolio Grid ---- */
.portfolio-preview-section{background:var(--gray-50)}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.portfolio-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden;transition:var(--transition)}
.portfolio-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:transparent}
.portfolio-card-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--gray-100)}
.portfolio-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.portfolio-card:hover .portfolio-card-img img{transform:scale(1.08)}
.portfolio-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--gray-100)}
.portfolio-img-placeholder i{font-size:3rem;color:var(--gray-400)}
.portfolio-overlay{position:absolute;inset:0;background:rgba(3,7,18,.8);display:flex;align-items:center;justify-content:center;gap:.75rem;opacity:0;transition:var(--transition)}
.portfolio-card:hover .portfolio-overlay{opacity:1}
.featured-badge{position:absolute;top:.75rem;left:.75rem;background:var(--gradient-3);color:#fff;padding:.25rem .75rem;border-radius:50px;font-size:.72rem;font-weight:700}
.portfolio-card-body{padding:1.5rem}
.portfolio-category{display:inline-block;background:rgba(52,152,219,.08);color:var(--primary);padding:.2rem .75rem;border-radius:50px;font-size:.72rem;font-weight:700;margin-bottom:.6rem;text-transform:uppercase;letter-spacing:.5px}
.portfolio-card-body h3{font-size:1rem;margin-bottom:.5rem}
.tech-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem}
.tech-tag{background:var(--gray-100);color:var(--dark-4);padding:.2rem .65rem;border-radius:6px;font-size:.72rem;font-weight:600;border:1px solid var(--border)}

/* ---- Stats Section ---- */
.stats-section{background:var(--dark);padding:5rem 0;position:relative;overflow:hidden}
.stats-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(52,152,219,.08),transparent)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;position:relative;z-index:1}
.stat-item{text-align:center;padding:2.5rem 1.5rem;border-radius:var(--radius-lg);background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);transition:var(--transition);position:relative;overflow:hidden}
.stat-item::before{content:'';position:absolute;inset:0;background:var(--gradient);opacity:0;transition:var(--transition)}
.stat-item:hover{border-color:rgba(52,152,219,.3);transform:translateY(-4px)}
.stat-item:hover::before{opacity:.05}
.stat-icon{width:64px;height:64px;background:rgba(52,152,219,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;border:1px solid rgba(52,152,219,.25);position:relative;z-index:1}
.stat-icon i{color:var(--secondary);font-size:1.5rem}
.stat-number{font-size:3rem;font-weight:800;color:#fff;font-family:var(--font-heading);display:inline;line-height:1;position:relative;z-index:1}
.stat-suffix{font-size:2.2rem;font-weight:800;color:var(--primary-light);display:inline;position:relative;z-index:1}
.stat-label{color:rgba(255,255,255,.45);font-size:.8rem;margin-top:.5rem;text-transform:uppercase;letter-spacing:1px;position:relative;z-index:1}

/* ---- Blog Grid ---- */
.blog-preview-section{background:#fff}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.blog-card{background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden;transition:var(--transition)}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-xl);border-color:transparent}
.blog-card-img-link{display:block;aspect-ratio:16/9;overflow:hidden;background:var(--gray-100)}
.blog-card-img-link img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.blog-card:hover .blog-card-img-link img{transform:scale(1.08)}
.blog-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--gray-100)}
.blog-img-placeholder i{font-size:3rem;color:var(--gray-400)}
.blog-card-body{padding:1.5rem}
.blog-category{display:inline-block;background:rgba(52,152,219,.08);color:var(--primary);padding:.2rem .75rem;border-radius:50px;font-size:.72rem;font-weight:700;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px}
.blog-card-body h3{font-size:1rem;margin-bottom:.5rem;line-height:1.5}
.blog-card-body h3 a{color:var(--dark)}
.blog-card-body h3 a:hover{color:var(--primary)}
.blog-card-body p{color:var(--text-light);font-size:.875rem;margin-bottom:1rem;line-height:1.7}
.blog-meta{display:flex;gap:1rem;font-size:.78rem;color:var(--text-light)}
.blog-meta i{margin-right:.3rem}

/* ---- TESTIMONIALS — Modern Card Carousel ---- */
.testimonials-section{background:var(--dark-2);position:relative;overflow:hidden;padding:6rem 0}
.testimonials-section::before{content:'';position:absolute;top:-300px;left:-200px;width:700px;height:700px;background:radial-gradient(circle,rgba(52,152,219,.1),transparent 70%);pointer-events:none}
.testimonials-section::after{content:'';position:absolute;bottom:-200px;right:-100px;width:500px;height:500px;background:radial-gradient(circle,rgba(6,182,212,.08),transparent 70%);pointer-events:none}
.testimonials-section .section-title{color:#fff}
.testimonials-section .section-desc{color:rgba(255,255,255,.5)}
.testimonials-section .section-badge{background:rgba(52,152,219,.15);border-color:rgba(52,152,219,.3);color:var(--primary-light)}

.testimonials-wrapper{position:relative;overflow:hidden;border-radius:var(--radius-xl);width:100%}
.testimonials-track{display:flex;transition:transform .6s cubic-bezier(.4,0,.2,1);width:100%}
.testimonial-card{min-width:100%;padding:3rem;background:rgba(255,255,255,.06);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-xl);position:relative;overflow:hidden;box-sizing:border-box}
.testimonial-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient)}
.testimonial-card-inner{max-width:800px;margin:0 auto;text-align:center}
.testimonial-quote-icon{font-size:4rem;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:1rem;opacity:.6}
.testimonial-stars{display:flex;justify-content:center;gap:.3rem;margin-bottom:1.5rem}
.testimonial-stars i{color:var(--accent);font-size:1.1rem}
.testimonial-review{font-size:1.15rem;color:rgba(255,255,255,.85);line-height:1.9;font-style:italic;margin-bottom:2rem;position:relative}
.testimonial-author{display:flex;align-items:center;gap:1rem;justify-content:center}
.testimonial-photo{width:64px;height:64px;border-radius:50%;object-fit:cover;border:3px solid transparent;background:var(--gradient) border-box;box-shadow:0 0 0 3px rgba(52,152,219,.3)}
.testimonial-avatar{width:64px;height:64px;border-radius:50%;background:var(--gradient);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:700;box-shadow:0 0 0 3px rgba(52,152,219,.3)}
.testimonial-author-info strong{display:block;color:#fff;font-size:1rem}
.testimonial-author-info span{color:rgba(255,255,255,.45);font-size:.85rem}
.testimonials-controls{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-top:2rem;position:relative;z-index:1}
.t-prev,.t-next{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);cursor:pointer;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);transition:var(--transition)}
.t-prev:hover,.t-next:hover{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 0 20px rgba(52,152,219,.4)}
.t-dots{display:flex;gap:.5rem}
.t-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.2);border:none;cursor:pointer;transition:var(--transition)}
.t-dot.active{background:var(--primary);width:28px;border-radius:4px;box-shadow:0 0 10px rgba(52,152,219,.5)}

/* ---- FAQ — Modern Accordion ---- */
.faq-section{background:var(--gray-50);position:relative;overflow:hidden}
.faq-section::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(52,152,219,.06),transparent 70%);pointer-events:none}
.faq-layout{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.faq-left .section-header{text-align:left;margin:0 0 2rem}
.faq-left-desc{color:var(--text-light);line-height:1.8;margin-bottom:2rem}
.faq-contact-card{background:#fff;border-radius:var(--radius-lg);padding:1.75rem;border:1px solid var(--border);box-shadow:var(--shadow)}
.faq-contact-card h4{font-size:1rem;margin-bottom:.5rem}
.faq-contact-card p{color:var(--text-light);font-size:.875rem;margin-bottom:1.25rem}
.faq-grid{display:flex;flex-direction:column;gap:.75rem}
.faq-item{background:#fff;border:1.5px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:var(--transition)}
.faq-item.open{border-color:var(--primary);box-shadow:0 4px 24px rgba(52,152,219,.12)}
.faq-question{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;cursor:pointer;background:#fff;transition:var(--transition);gap:1rem}
.faq-item.open .faq-question{background:rgba(52,152,219,.02)}
.faq-question h3{font-size:.9rem;font-weight:600;color:var(--dark);flex:1;line-height:1.5}
.faq-toggle{width:36px;height:36px;min-width:36px;border-radius:50%;background:var(--gray-100);display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.faq-item.open .faq-toggle{background:var(--gradient);box-shadow:0 4px 12px rgba(52,152,219,.3);transform:rotate(45deg)}
.faq-toggle i{font-size:.85rem;color:var(--text-light);transition:var(--transition)}
.faq-item.open .faq-toggle i{color:#fff}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.open .faq-answer{max-height:500px}
.faq-answer p{padding:.25rem 1.5rem 1.5rem;color:var(--text-light);font-size:.875rem;line-height:1.8}
/* Mobile heading — hidden on desktop, shown on mobile */
.faq-mobile-header{display:none;text-align:center;margin-bottom:2rem}

/* ---- Software Delivery Section ---- */
.swd-section{background:#fff;overflow:hidden}
.swd-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.swd-heading{font-size:clamp(1.8rem,3.5vw,2.8rem);line-height:1.2;margin:1rem 0 1.25rem;font-weight:800}
.swd-desc{color:var(--text-light);font-size:1rem;line-height:1.8;margin-bottom:2rem;max-width:480px}
.swd-features{display:flex;flex-direction:column;gap:1.5rem}
.swd-feature-item{display:flex;align-items:flex-start;gap:1rem}
.swd-feature-icon{width:46px;height:46px;min-width:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.swd-feature-item h4{font-size:.95rem;font-weight:700;color:var(--dark);margin-bottom:.25rem}
.swd-feature-item p{font-size:.85rem;color:var(--text-light);line-height:1.7;margin:0}
/* Visual wrapper */
.swd-right{display:flex;justify-content:center;align-items:center}
.swd-visual{position:relative;width:100%;max-width:460px;margin:0 auto;user-select:none}
.swd-img{width:100%;height:auto;display:block;position:relative;z-index:2;transition:transform .15s ease;transform-style:preserve-3d;will-change:transform}
/* Floating Badges */
.swd-badge{position:absolute;display:flex;align-items:center;gap:.75rem;background:#fff;border-radius:14px;padding:.75rem 1rem;box-shadow:0 8px 32px rgba(0,0,0,.10);border:1px solid rgba(0,0,0,.06);min-width:175px;z-index:10}
.swd-badge strong{display:block;font-size:.8rem;font-weight:700;color:var(--dark);line-height:1.2}
.swd-badge span{display:block;font-size:.7rem;color:var(--text-light);margin-top:.1rem}
.swd-badge-icon{width:36px;height:36px;min-width:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:.95rem}
.swd-badge-check{color:#2ecc71;font-size:.9rem;margin-left:auto}
/* Badge positions */
.swd-badge-1{top:8%;left:-8%;animation:swdFloat 3.2s ease-in-out infinite}
.swd-badge-2{top:38%;left:-12%;animation:swdFloat 3.8s ease-in-out infinite .4s}
.swd-badge-3{top:68%;left:-6%;animation:swdFloat 3.5s ease-in-out infinite .8s}
.swd-badge-4{top:15%;right:-6%;animation:swdFloat 3.6s ease-in-out infinite .2s}
.swd-badge-5{top:72%;right:-8%;animation:swdFloat 3.3s ease-in-out infinite .6s}
@keyframes swdFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
/* Desktop: show floating, hide mobile grid */
.swd-badges-desktop{position:absolute;inset:0;pointer-events:none}
.swd-badges-desktop .swd-badge{pointer-events:all}
.swd-badges-mobile{display:none}

/* ---- CTA Section ---- */
.cta-section{background:var(--gray-50);padding:4rem 0;text-align:center;position:relative}
.cta-section .container{position:relative;z-index:1}
.cta-section .cta-content{background:var(--dark);border-radius:var(--radius-xl);padding:4rem 3rem;position:relative;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,.25)}
.cta-section .cta-content::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(52,152,219,.18),transparent);pointer-events:none}
.cta-glow{position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(52,152,219,.2),transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}
.cta-content{position:relative;z-index:1;text-align:center}
.cta-content h2{color:#fff;font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:1rem}
.cta-content p{color:rgba(255,255,255,.65);font-size:1.05rem;margin-bottom:2.5rem;max-width:560px;margin-left:auto;margin-right:auto}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ---- Page Hero ---- */
.page-hero{background:var(--dark);padding:9rem 0 5rem;text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 50% 0%,rgba(52,152,219,.25),transparent 70%)}
.page-hero-grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(52,152,219,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(52,152,219,.05) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black,transparent)}
.page-hero-content{position:relative;z-index:1}
.page-hero-content h1{color:#fff;font-size:clamp(2.2rem,4vw,3.2rem);margin-bottom:1rem}
.page-hero-content p{color:rgba(255,255,255,.6);font-size:1.05rem;margin-bottom:1.5rem}
.breadcrumb{display:inline-flex;align-items:center;gap:.5rem;font-size:.82rem;color:rgba(255,255,255,.4)}
.breadcrumb a{color:rgba(255,255,255,.4)}
.breadcrumb a:hover{color:var(--secondary)}
.breadcrumb i{font-size:.65rem}
.hero-badge{display:inline-block;background:rgba(52,152,219,.15);color:var(--primary-light);border:1px solid rgba(52,152,219,.3);padding:.3rem .9rem;border-radius:50px;font-size:.78rem;font-weight:700;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:1px}
.service-hero-icon{width:80px;height:80px;background:rgba(52,152,219,.15);border-radius:20px;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;border:1px solid rgba(52,152,219,.3)}
.service-hero-icon i{font-size:2rem;color:var(--secondary)}

/* ---- Footer ---- */
.site-footer{background:var(--dark);position:relative;overflow:hidden}

/* Dark grid background — like the image */
.footer-grid-bg{
    position:absolute;inset:0;
    background-image:
        linear-gradient(rgba(52,152,219,.07) 1px, transparent 1px),
        linear-gradient(90deg, rgba(52,152,219,.07) 1px, transparent 1px);
    background-size:48px 48px;
    pointer-events:none;z-index:0;
}
/* Bottom right glow */
.footer-glow{
    position:absolute;
    bottom:-80px;right:-80px;
    width:400px;height:400px;
    background:radial-gradient(circle, rgba(52,152,219,.12), transparent 70%);
    pointer-events:none;z-index:0;
    border-radius:50%;
}

.footer-top{padding:5rem 0 3rem;position:relative;z-index:1}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:3rem}
.footer-brand .logo-link{margin-bottom:1.25rem}
.footer-brand p{font-size:.875rem;color:rgba(255,255,255,.4);margin:1rem 0 1.5rem;line-height:1.8;position:relative;z-index:1}
.footer-links h4,.footer-contact h4{color:rgba(255,255,255,.9);font-size:.875rem;font-weight:700;margin-bottom:1.25rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.06);position:relative;z-index:1}
.footer-links ul{display:flex;flex-direction:column;gap:.6rem}
.footer-links a{color:rgba(255,255,255,.4);font-size:.875rem;transition:var(--transition);display:flex;align-items:center;gap:.4rem}
.footer-links a:hover{color:var(--secondary);padding-left:.4rem}
.footer-contact ul{display:flex;flex-direction:column;gap:.75rem}
.footer-contact li{display:flex;gap:.75rem;align-items:flex-start;font-size:.875rem}
.footer-contact i{color:var(--secondary);margin-top:3px;width:16px}
.footer-contact a{color:rgba(255,255,255,.4)}
.footer-contact a:hover{color:var(--secondary)}
.social-links{display:flex;gap:.6rem}
.social-links a{width:40px;height:40px;background:rgba(255,255,255,.05);border-radius:10px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);transition:var(--transition);border:1px solid rgba(255,255,255,.07)}
.social-links a:hover{background:var(--gradient);color:#fff;border-color:transparent;transform:translateY(-3px);box-shadow:0 4px 16px rgba(52,152,219,.4)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.05);padding:1.5rem 0;position:relative;z-index:1}
.footer-bottom .container{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-bottom p{font-size:.82rem;color:rgba(255,255,255,.3);margin:0}
.footer-bottom-links{display:flex;gap:1rem;align-items:center;font-size:.82rem}
.footer-bottom-links a{color:rgba(255,255,255,.3)}
.footer-bottom-links a:hover{color:var(--secondary)}
.footer-bottom-links span{color:rgba(255,255,255,.1)}

/* ---- Alerts & Forms ---- */
.alert{padding:1rem 1.25rem;border-radius:var(--radius);margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;font-size:.9rem}
.alert-success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}
.alert-danger{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-weight:600;font-size:.875rem;margin-bottom:.4rem;color:var(--text)}
.form-control{width:100%;padding:.8rem 1.1rem;border:1.5px solid var(--border);border-radius:12px;font-family:var(--font-main);font-size:.95rem;color:var(--text);transition:var(--transition);background:#fff}
.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(52,152,219,.08)}
.form-control.is-invalid{border-color:#ef4444}
.form-error{color:#ef4444;font-size:.8rem;margin-top:.25rem;display:block}
.required{color:#ef4444}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}

/* ---- WhatsApp Float & Back to Top ---- */
.whatsapp-float{position:fixed;bottom:5.5rem;right:1.5rem;width:54px;height:54px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.6rem;box-shadow:0 4px 20px rgba(37,211,102,.4);z-index:999;transition:var(--transition)}
.whatsapp-float:hover{transform:scale(1.1);color:#fff;box-shadow:0 8px 32px rgba(37,211,102,.5)}
.back-to-top{position:fixed;bottom:1.5rem;right:1.5rem;width:46px;height:46px;background:var(--gradient);border:none;border-radius:50%;color:#fff;cursor:pointer;display:none;align-items:center;justify-content:center;font-size:1rem;box-shadow:0 4px 20px rgba(52,152,219,.4);z-index:999;transition:var(--transition)}
.back-to-top.visible{display:flex}
.back-to-top:hover{transform:translateY(-3px);box-shadow:0 8px 32px rgba(52,152,219,.5)}

/* ---- Pagination ---- */
.pagination-wrapper{margin-top:2.5rem;display:flex;justify-content:center}
/* Custom pagination */
.custom-pagination{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;justify-content:center}
.page-btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;min-width:42px;height:42px;padding:0 .9rem;border-radius:10px;font-size:.875rem;font-weight:600;border:1.5px solid var(--border);color:var(--text);background:#fff;transition:var(--transition);text-decoration:none;cursor:pointer;white-space:nowrap}
.page-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 4px 16px rgba(33,150,243,.3);transform:translateY(-2px)}
.page-btn.active{background:var(--gradient);color:#fff;border-color:transparent;box-shadow:0 4px 16px rgba(52,152,219,.35);pointer-events:none}
.page-btn.disabled{color:var(--gray-400);background:var(--gray-100);border-color:var(--border);cursor:not-allowed;pointer-events:none;transform:none}

/* ---- Portfolio Filter ---- */
.portfolio-filter{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:3rem;justify-content:center}
.filter-btn{padding:.5rem 1.5rem;border:1.5px solid var(--border);border-radius:50px;background:#fff;color:var(--text);font-weight:600;font-size:.875rem;cursor:pointer;transition:var(--transition)}
.filter-btn:hover,.filter-btn.active{background:var(--gradient);color:#fff;border-color:transparent;box-shadow:0 4px 16px rgba(52,152,219,.3)}
.empty-state{grid-column:1/-1;text-align:center;padding:4rem;color:var(--text-light)}
.empty-state i{font-size:3rem;margin-bottom:1rem;display:block;color:var(--gray-400)}

/* ---- Map ---- */
.map-section{height:420px}
.map-section iframe{width:100%;height:100%;border:0;display:block}

/* ---- Blog Layout ---- */
.blog-layout{display:grid;grid-template-columns:1fr 280px;gap:3rem}
.blog-sidebar .sidebar-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}
.blog-sidebar .sidebar-card h4{font-size:.95rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}
.sidebar-category-list{display:flex;flex-direction:column;gap:.25rem}
.sidebar-category-list a{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;border-radius:8px;color:var(--text);font-size:.875rem;transition:var(--transition)}
.sidebar-category-list a:hover,.sidebar-category-list a.active{background:rgba(52,152,219,.08);color:var(--primary)}
.cat-count{background:var(--gray-100);color:var(--gray-600);padding:.1rem .5rem;border-radius:50px;font-size:.72rem}
.recent-posts-list{display:flex;flex-direction:column;gap:.75rem}
.recent-posts-list a{display:flex;gap:.75rem;align-items:flex-start;color:var(--text);font-size:.875rem}
.recent-posts-list a:hover{color:var(--primary)}
.recent-posts-list span{display:block;font-weight:500;line-height:1.4}
.recent-posts-list small{color:var(--text-light);font-size:.75rem}
.blog-hero-meta{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap;font-size:.875rem;color:rgba(255,255,255,.5);margin-top:.75rem}

/* ---- Careers ---- */
.why-join-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.why-join-card{background:#fff;border-radius:var(--radius-lg);padding:1.75rem;text-align:center;border:1px solid var(--border);transition:var(--transition)}
.why-join-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary)}
.why-join-icon{width:60px;height:60px;border-radius:50%;background:var(--gradient);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;box-shadow:0 4px 16px rgba(52,152,219,.3)}
.why-join-icon i{color:#fff;font-size:1.4rem}
.why-join-card h3{font-size:1rem;margin-bottom:.5rem}
.why-join-card p{color:var(--text-light);font-size:.875rem}
.jobs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.job-card{background:#fff;border-radius:var(--radius-lg);padding:1.75rem;border:1px solid var(--border);transition:var(--transition)}
.job-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary)}
.job-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}
.job-type-badge,.job-mode-badge{display:inline-block;padding:.2rem .75rem;border-radius:50px;font-size:.72rem;font-weight:700}
.job-badge{background:rgba(52,152,219,.1);color:var(--primary)}
.internship-badge{background:rgba(245,158,11,.1);color:#d97706}
.job-mode-badge{background:var(--gray-100);color:var(--gray-600);margin-left:.4rem}
.job-deadline{font-size:.78rem;color:var(--text-light);display:flex;align-items:center;gap:.3rem}
.job-card h3{font-size:1.1rem;margin-bottom:.75rem}
.job-meta{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.75rem}
.job-meta span{font-size:.8rem;color:var(--text-light);display:flex;align-items:center;gap:.3rem}
.job-card p{color:var(--text-light);font-size:.875rem;margin-bottom:1.25rem}
.career-detail-grid{display:grid;grid-template-columns:1fr 320px;gap:3rem}

/* ---- About ---- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.about-img-wrap{position:relative;text-align:center}
.about-logo-img{max-width:300px;margin:0 auto;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl)}
.about-badge{position:absolute;bottom:1rem;right:0;background:var(--gradient);color:#fff;padding:.75rem 1.25rem;border-radius:50px;font-weight:600;font-size:.875rem;box-shadow:0 8px 24px rgba(52,152,219,.4)}
.mission-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.mission-card{background:#fff;border-radius:var(--radius-lg);padding:2rem;text-align:center;border:1px solid var(--border);transition:var(--transition)}
.mission-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.mission-icon{width:64px;height:64px;border-radius:50%;background:var(--gradient);display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;box-shadow:0 4px 16px rgba(52,152,219,.3)}
.mission-icon-2{background:linear-gradient(135deg,#06b6d4,#0891b2)}
.mission-icon-3{background:linear-gradient(135deg,#f59e0b,#ef4444)}
.mission-icon i{color:#fff;font-size:1.4rem}
.mission-card h3{margin-bottom:.75rem}
.mission-card p{color:var(--text-light);font-size:.875rem}

/* ---- Portfolio Single ---- */
.portfolio-single-grid{display:grid;grid-template-columns:1fr 320px;gap:3rem}
.portfolio-main-img img{width:100%;border-radius:var(--radius-lg);margin-bottom:2rem}
.portfolio-gallery h3{margin-bottom:1rem}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:2rem}
.gallery-item{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:4/3;display:block}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-overlay{position:absolute;inset:0;background:rgba(3,7,18,.6);display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--transition)}
.gallery-overlay i{color:#fff;font-size:1.5rem}
.gallery-item:hover .gallery-overlay{opacity:1}
.portfolio-description h3{margin-bottom:1rem}
.prose{color:var(--text-light);line-height:1.9}
.project-info-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}
.project-info-list li{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border);font-size:.875rem}
.info-label{color:var(--text-light);display:flex;align-items:center;gap:.5rem}
.tech-stack-section h5{font-size:.875rem;margin-bottom:.75rem;color:var(--text-light)}
.sidebar-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}
.sidebar-card h4{font-size:.95rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}
.sidebar-service-list li{border-bottom:1px solid var(--border)}
.sidebar-service-list li:last-child{border-bottom:none}
.sidebar-service-list a{display:flex;align-items:center;gap:.75rem;padding:.75rem 0;color:var(--text);font-size:.875rem}
.sidebar-service-list a:hover,.sidebar-service-list li.active a{color:var(--primary)}
.sidebar-service-list i{width:20px;color:var(--primary)}
.sidebar-cta-card{background:var(--gradient);border-radius:var(--radius);padding:1.5rem;margin-top:1.5rem;text-align:center}
.sidebar-cta-card h4{color:#fff;margin-bottom:.5rem}
.sidebar-cta-card p{color:rgba(255,255,255,.75);font-size:.875rem;margin-bottom:1.25rem}
.portfolio-grid-sm{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.related-title{font-size:1.5rem;margin-bottom:1.5rem}

/* ---- Contact ---- */
.contact-grid{display:grid;grid-template-columns:1fr 400px;gap:3rem}
.contact-form-wrap h2{font-size:1.8rem;margin-bottom:1.5rem}
.contact-info-card{background:var(--gradient-dark);border-radius:var(--radius-lg);padding:2rem;margin-bottom:1.5rem;border:1px solid rgba(255,255,255,.06)}
.contact-info-card h3{color:#fff;margin-bottom:1.5rem}
.contact-info-list{display:flex;flex-direction:column;gap:1.25rem}
.contact-info-item{display:flex;gap:1rem;align-items:flex-start}
.contact-info-icon{width:44px;height:44px;min-width:44px;background:rgba(52,152,219,.2);border-radius:10px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(52,152,219,.3)}
.contact-info-icon i{color:var(--secondary);font-size:1rem}
.contact-info-icon-2{background:rgba(6,182,212,.15);border-color:rgba(6,182,212,.3)}
.contact-info-icon-3{background:rgba(245,158,11,.15);border-color:rgba(245,158,11,.3)}
.contact-info-item h4{color:#fff;font-size:.875rem;margin-bottom:.25rem}
.contact-info-item a,.contact-info-item p{color:rgba(255,255,255,.55);font-size:.875rem}
.contact-info-item a:hover{color:var(--secondary)}
.business-hours-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem}
.business-hours-card h4{margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.business-hours-card ul{display:flex;flex-direction:column;gap:.6rem}
.business-hours-card li{display:flex;justify-content:space-between;font-size:.875rem;padding:.4rem 0;border-bottom:1px solid var(--border)}
.business-hours-card li:last-child{border-bottom:none}
.closed{color:#ef4444;font-weight:600}
.social-follow-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}
.social-follow-card h4{margin-bottom:1rem}

/* ---- AOS Animations ---- */
.aos-init{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.aos-init[data-aos="fade-right"]{transform:translateX(-30px)}
.aos-init[data-aos="fade-left"]{transform:translateX(30px)}
.aos-init[data-aos="zoom-in"]{transform:scale(.9)}
.aos-animate{opacity:1!important;transform:none!important}

/* ---- Float Animation ---- */
@keyframes floatAnim{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.animate-float{animation:floatAnim 3s ease-in-out infinite}

/* ---- Responsive ---- */
@media(max-width:1024px){
  .services-grid,.portfolio-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-content{grid-template-columns:1fr;text-align:center}
  .hero-visual{display:none}
  .hero-trust{justify-content:center}
  .hero-actions{justify-content:center}
  .why-us-grid{grid-template-columns:1fr}
  .why-us-img{display:block;margin-bottom:2rem}
  .why-us-img img{min-height:280px}
  .faq-layout{grid-template-columns:1fr}
  .faq-left{display:none}
  .faq-mobile-header{display:block}
  .portfolio-single-grid,.blog-layout,.career-detail-grid,.contact-grid{grid-template-columns:1fr}
  .about-grid,.mission-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .desktop-nav{display:none}
  .mobile-toggle{display:flex}
  .mobile-nav.open{display:block}
  .services-grid,.portfolio-grid,.blog-grid,.portfolio-grid-sm,.jobs-grid,.why-join-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .form-row{grid-template-columns:1fr}
  .section{padding:4rem 0}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
}

/* ---- Industries Grid responsive ---- */
@media(max-width:1024px){
  div[style*="grid-template-columns:repeat(3,1fr)"]{grid-template-columns:repeat(2,1fr)!important}
}
@media(max-width:600px){
  div[style*="grid-template-columns:repeat(3,1fr)"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:repeat(2,1fr)"]{grid-template-columns:1fr!important}
}

/* ---- Images always responsive ---- */
img{max-width:100%;height:auto;display:block}

/* ---- Testimonials + Google Review layout ---- */
.testimonials-section .container > div[style*="grid-template-columns:1fr 340px"] {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 2rem;
    align-items: start;
}
@media(max-width:1024px) {
    .testimonials-section .container > div[style*="grid-template-columns:1fr 340px"] {
        grid-template-columns: 1fr !important;
    }
}

/* Fix testimonials wrapper overflow inside grid */
.testimonials-wrapper {
    overflow: hidden;
    border-radius: var(--radius-xl);
    width: 100%;
}
.testimonials-track {
    display: flex;
    transition: transform .6s cubic-bezier(.4,0,.2,1);
    width: 100%;
}
/* Ensure cards don't shrink and fill the wrapper */
.testimonials-track .testimonial-card {
    min-width: 100%;
    width: 100%;
    flex-shrink: 0;
}
/* Google review card fix on dark bg */
.testimonials-section .google-review-card {
    background: #fff;
    border-radius: var(--radius-xl);
    padding: 2.5rem;
    text-align: center;
    border: 1px solid rgba(255,255,255,.15);
    box-shadow: 0 20px 60px rgba(0,0,0,.3);
    position: relative;
    overflow: hidden;
}

/* ============================================================
   MOBILE RESPONSIVE — Complete Fix
   ============================================================ */

/* ---- Base Mobile ---- */
@media(max-width:768px){
  .section{padding:3.5rem 0}
  .container{padding:0 1rem}

  /* Header */
  .desktop-nav{display:none!important}
  .header-actions{display:none!important}
  .mobile-toggle{display:flex!important}
  .mobile-nav.open{display:block!important}
  .header-pill{border-radius:16px;padding:.5rem .75rem}
  .logo-text{font-size:1.2rem}

  /* Hero */
  .hero-section{min-height:auto;padding:90px 0 3rem}
  .hero-content{grid-template-columns:1fr!important;gap:2rem;padding:2rem 0;text-align:center}
  .hero-visual{display:none!important}
  .hero-title{font-size:2rem!important}
  .hero-desc{font-size:.95rem;max-width:100%}
  .hero-actions{justify-content:center;flex-direction:column;align-items:center;gap:.75rem}
  .hero-actions .btn{width:100%;max-width:300px;justify-content:center}
  .hero-trust{justify-content:center;flex-wrap:wrap;gap:.75rem}
  .hero-eyebrow{font-size:.7rem}
  .hero-wave svg{height:40px}

  /* Section Headers */
  .section-title{font-size:1.6rem!important}
  .section-desc{font-size:.9rem}
  .section-header{margin-bottom:2.5rem}

  /* Services Grid */
  .services-grid{grid-template-columns:1fr!important}
  .service-card-img{aspect-ratio:16/9}

  /* Portfolio */
  .portfolio-grid{grid-template-columns:1fr!important}
  .portfolio-grid-sm{grid-template-columns:1fr!important}
  .portfolio-filter{gap:.5rem}
  .filter-btn{padding:.4rem 1rem;font-size:.8rem}

  /* Stats */
  .stats-grid{grid-template-columns:repeat(2,1fr)!important;gap:1rem}
  .stat-item{padding:1.5rem 1rem}
  .stat-number{font-size:2rem!important}
  .stat-suffix{font-size:1.6rem}

  /* Blog */
  .blog-grid{grid-template-columns:1fr!important}
  .blog-layout{grid-template-columns:1fr!important}

  /* Why Us */
  .why-us-grid{grid-template-columns:1fr!important}
  .why-us-img{display:block!important;margin-bottom:1.5rem}
  .why-us-img img{min-height:240px;height:auto!important}
  .why-badge{right:.75rem;bottom:1rem;font-size:.8rem;padding:.6rem 1rem}
  .feature-item{padding:.75rem}

  /* Testimonials */
  .testimonials-two-col{grid-template-columns:1fr!important;gap:1.25rem!important}
  .testimonial-card{padding:1.5rem 1rem!important}
  .testimonial-review{font-size:.9rem!important}
  .testimonials-wrapper{border-radius:var(--radius-lg);overflow:hidden}
  .testimonials-controls{gap:1rem}

  /* FAQ */
  .faq-layout{grid-template-columns:1fr!important}
  .faq-left{display:none!important}
  .faq-mobile-header{display:block!important}
  .faq-question{padding:1rem 1.25rem}
  .faq-question h3{font-size:.85rem}

  /* Footer */
  .footer-grid{grid-template-columns:1fr!important;gap:2rem}
  .footer-top{padding:3rem 0 2rem}
  .footer-bottom .container{flex-direction:column;text-align:center;gap:.5rem}
  .footer-bottom-links{flex-wrap:wrap;justify-content:center}
  .social-links{flex-wrap:wrap}

  /* CTA */
  .cta-actions{flex-direction:column;align-items:center;gap:.75rem}
  .cta-actions .btn{width:100%;max-width:300px;justify-content:center}
  .cta-content h2{font-size:1.6rem}
  .cta-section .cta-content{padding:2.5rem 1.5rem;border-radius:var(--radius-lg)}

  /* Page Hero */
  .page-hero{padding:7rem 0 3rem}
  .page-hero-content h1{font-size:1.8rem!important}
  .page-hero-content p{font-size:.9rem}
  .breadcrumb{font-size:.78rem;flex-wrap:wrap;justify-content:center;gap:.3rem}

  /* Contact */
  .contact-grid{grid-template-columns:1fr!important}
  .form-row{grid-template-columns:1fr!important}

  /* Portfolio Single */
  .portfolio-single-grid{grid-template-columns:1fr!important}
  .gallery-grid{grid-template-columns:repeat(2,1fr)!important}

  /* Service Single — images in service list page */
  .service-single-grid{grid-template-columns:1fr!important}

  /* Blog Single */
  .blog-single-grid{grid-template-columns:1fr!important}

  /* Career */
  .career-detail-grid{grid-template-columns:1fr!important}
  .jobs-grid{grid-template-columns:1fr!important}
  .why-join-grid{grid-template-columns:repeat(2,1fr)!important}

  /* About */
  .about-grid{grid-template-columns:1fr!important}
  .mission-grid{grid-template-columns:1fr!important}

  /* ---- Inline-style grid overrides (attribute selector pattern) ---- */
  /* These cover the service list, about, portfolio, blog, career pages */
  div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:1fr 340px"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:1fr 320px"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:1fr 300px"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:1fr 420px"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:1fr 280px"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:2fr 1fr"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:repeat(3,1fr)"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:repeat(2,1fr)!important}
  div[style*="grid-template-columns:repeat(2,1fr)"]{grid-template-columns:1fr!important}

  /* Fix direction:rtl for alternating service rows */
  div[style*="direction:rtl"]{direction:ltr!important}

  /* Service images — remove hardcoded height on mobile */
  section[id] div[style*="height:380px"] img,
  section[id] div[style*="height:400px"] img{height:220px!important;object-fit:cover!important}

  /* Founder message card */
  div[style*="padding:3rem 3.5rem"]{padding:1.75rem 1.25rem!important}

  /* Mission/Vision cards fix text overflow */
  div[style*="padding:2.5rem"]{padding:1.5rem!important}

  /* Buttons */
  .btn-lg{padding:.75rem 1.5rem;font-size:.9rem}
  .btn{white-space:normal;text-align:center}

  /* Marquee */
  .clients-section{padding:1.5rem 0}

  /* WhatsApp float */
  .whatsapp-float{width:48px;height:48px;font-size:1.4rem;bottom:4.5rem;right:1rem}
  .back-to-top{width:40px;height:40px;bottom:1rem;right:1rem}

  /* Map */
  .map-section{height:280px}

  /* Inline images used in service/about/portfolio pages */
  img[style*="height:380px"],
  img[style*="height:400px"],
  img[style*="height:420px"],
  img[style*="height:480px"],
  img[style*="max-height:480px"]{height:220px!important;max-height:220px!important;width:100%!important;object-fit:cover!important}

  /* Services list page — sticky quick-nav */
  section[style*="position:sticky"]{top:64px!important}
}

/* ---- Tablet (768px - 1024px) ---- */
@media(min-width:769px) and (max-width:1024px){
  .hero-content{grid-template-columns:1fr!important;text-align:center}
  .hero-visual{display:none!important}
  .hero-actions{justify-content:center}
  .hero-trust{justify-content:center}
  .services-grid{grid-template-columns:repeat(2,1fr)!important}
  .portfolio-grid{grid-template-columns:repeat(2,1fr)!important}
  .blog-grid{grid-template-columns:repeat(2,1fr)!important}
  .stats-grid{grid-template-columns:repeat(2,1fr)!important}
  .footer-grid{grid-template-columns:1fr 1fr!important}
  .why-us-grid{grid-template-columns:1fr!important}
  .why-us-img{display:block!important;margin-bottom:2rem}
  .why-us-img img{min-height:300px;height:auto!important}
  .faq-layout{grid-template-columns:1fr!important}
  .faq-left{display:none!important}
  .faq-mobile-header{display:block!important}
  .testimonials-two-col{grid-template-columns:1fr!important;gap:1.5rem!important}
  div[style*="grid-template-columns:repeat(3,1fr)"]{grid-template-columns:repeat(2,1fr)!important}
  div[style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:repeat(2,1fr)!important}
  div[style*="grid-template-columns:1fr 340px"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:1fr 320px"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:1fr 420px"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:1fr 280px"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:1fr 300px"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
  div[style*="direction:rtl"]{direction:ltr!important}
  .contact-grid{grid-template-columns:1fr!important}
  .portfolio-single-grid{grid-template-columns:1fr!important}
  .career-detail-grid{grid-template-columns:1fr!important}
  .jobs-grid{grid-template-columns:1fr!important}
  .about-grid{grid-template-columns:1fr!important}
  .mission-grid{grid-template-columns:repeat(2,1fr)!important}
}

/* ---- Small phones (max 480px) ---- */
@media(max-width:480px){
  .hero-title{font-size:1.7rem!important}
  .hero-desc{font-size:.875rem}
  .section-title{font-size:1.4rem!important}
  .stats-grid{grid-template-columns:1fr 1fr!important}
  .why-join-grid{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:1fr!important}
  div[style*="grid-template-columns:repeat(2,1fr)"]{grid-template-columns:1fr!important}
  .gallery-grid{grid-template-columns:1fr 1fr!important}
  .footer-bottom-links{flex-direction:column;gap:.4rem;align-items:center}
  .testimonial-card{padding:1.25rem 1rem}
  .cta-content h2{font-size:1.4rem}
  .page-hero-content h1{font-size:1.55rem!important}

  /* Benefit cards single col on very small phones */
  .grid-benefits{grid-template-columns:1fr!important}

  /* Stats 2x2 on small */
  .stats-grid{grid-template-columns:1fr 1fr!important}

  /* Founder card on very small screens */
  div[style*="padding:3rem 3.5rem"]{padding:1.25rem 1rem!important}

  /* Job details — key-value may overflow */
  div[style*="justify-content:space-between"][style*="font-size:.875rem"]{flex-direction:column!important;align-items:flex-start!important;gap:.25rem!important}
}

/* ---- Testimonials Two Column — Left Google, Right Reviews ---- */
.testimonials-two-col {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 2.5rem;
    align-items: start;
}
/* Right column must not overflow the grid cell */
.testimonials-two-col > div:last-child {
    min-width: 0;
    overflow: hidden;
}
.testimonials-two-col .testimonial-card {
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: var(--radius-xl);
    padding: 2rem;
    position: relative;
    overflow: hidden;
    box-sizing: border-box;
}
.testimonials-two-col .testimonial-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: var(--gradient);
}
.testimonials-two-col .testimonial-review {
    font-size: .95rem;
    text-align: left;
    margin-bottom: 0;
}
@media(max-width:1024px) {
    .testimonials-two-col {
        grid-template-columns: 1fr !important;
        gap: 1.5rem !important;
    }
    .testimonials-two-col > div:last-child {
        order: -1;
    }
    .testimonials-two-col > div:first-child {
        order: 1;
    }
}
@media(max-width:768px) {
    .testimonials-two-col {
        grid-template-columns: 1fr !important;
        gap: 1.25rem !important;
    }
    .testimonials-two-col .testimonial-card {
        padding: 1.5rem 1rem;
    }
    .testimonials-two-col > div:last-child {
        order: -1;
    }
    .testimonials-two-col > div:first-child {
        order: 1;
    }
}

/* ============================================================
   HOMEPAGE REDESIGN — Benefits / Blueprint / Industries
   Replaces inline style grids and onmouseover JS handlers
   ============================================================ */

/* ---- Benefits Grid ---- */
.grid-benefits {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}

.benefit-card {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 2rem;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  transition: var(--transition);
  position: relative;
  overflow: hidden;
}

.benefit-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-xl);
}

.benefit-card-icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.25rem;
  box-shadow: 0 4px 16px rgba(0,0,0,.15);
}

.benefit-card-icon i {
  color: #fff;
  font-size: 1.1rem;
}

.benefit-card-bar {
  width: 40px;
  height: 3px;
  border-radius: 2px;
  margin-bottom: 1rem;
}

.benefit-card-title {
  font-size: 1rem;
  margin-bottom: .75rem;
}

.benefit-card-desc {
  color: var(--text-light);
  font-size: .85rem;
  line-height: 1.8;
}

/* ---- Blueprint Grid ---- */
.grid-blueprint {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}

.blueprint-diagram {
  display: flex;
  align-items: center;
  justify-content: center;
}

.blueprint-steps {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.blueprint-step {
  display: flex;
  gap: 1.25rem;
  align-items: flex-start;
  padding: 1.25rem;
  background: #fff;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  transition: var(--transition);
}

.blueprint-step:hover {
  transform: translateX(6px);
  border-color: var(--primary);
}

.blueprint-step-num {
  width: 44px;
  height: 44px;
  min-width: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 800;
  font-size: 1rem;
}

.blueprint-step-body h4 {
  font-size: .95rem;
  margin-bottom: .3rem;
}

.blueprint-step-body p {
  color: var(--text-light);
  font-size: .85rem;
  line-height: 1.7;
}

/* ---- Industries Grid ---- */
.grid-industries {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}

.industry-card {
  background: #fff;
  border-radius: var(--radius-xl);
  padding: 2rem;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  transition: var(--transition);
  position: relative;
  overflow: hidden;
  cursor: default;
}

.industry-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-xl);
  border-color: var(--primary);
}

.industry-card-bg {
  position: absolute;
  top: -40px;
  right: -40px;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  opacity: .06;
  pointer-events: none;
}

.industry-card-icon {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.25rem;
  box-shadow: 0 4px 16px rgba(52,152,219,.25);
}

.industry-card-icon i {
  color: #fff;
  font-size: 1.3rem;
}

.industry-card h3 {
  font-size: 1.05rem;
  margin-bottom: .6rem;
}

.industry-card p {
  color: var(--text-light);
  font-size: .875rem;
  line-height: 1.7;
}

/* ---- Responsive overrides for new grid classes ---- */
@media(max-width:1024px) {
  .grid-benefits { grid-template-columns: repeat(2, 1fr); }
  .grid-blueprint { grid-template-columns: 1fr; gap: 2rem; }
  .grid-industries { grid-template-columns: repeat(2, 1fr); }
  .blueprint-diagram { display: none; }
  /* SWD section */
  .swd-grid{grid-template-columns:1fr;gap:3rem}
  .swd-right{order:-1}
  .swd-visual{max-width:380px}
}

@media(max-width:768px) {
  .grid-benefits { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .grid-blueprint { grid-template-columns: 1fr; }
  .grid-industries { grid-template-columns: 1fr; }
  .benefit-card { padding: 1.5rem; }
  .industry-card { padding: 1.5rem; }
  /* SWD section — keep floating badges, just smaller */
  .swd-grid{grid-template-columns:1fr;gap:1.5rem}
  .swd-visual{max-width:100%;margin:0 auto}
  .swd-img{max-width:220px;width:100%;display:block;margin:0 auto}
  .swd-badges-desktop{display:block}
  .swd-badges-mobile{display:none}
  .swd-badge{min-width:120px;padding:.45rem .6rem;border-radius:10px}
  .swd-badge strong{font-size:.68rem}
  .swd-badge span{font-size:.6rem}
  .swd-badge-icon{width:26px;height:26px;min-width:26px;font-size:.72rem}
  .swd-badge-check{font-size:.75rem}
  .swd-badge-1{top:6%;left:0%}
  .swd-badge-2{top:36%;left:-2%}
  .swd-badge-3{top:66%;left:0%}
  .swd-badge-4{top:12%;right:0%}
  .swd-badge-5{top:55%;right:-2%}
}

@media(max-width:480px) {
  .grid-benefits { grid-template-columns: 1fr; }
  .swd-img{max-width:180px}
  .swd-badge{min-width:105px;padding:.4rem .5rem}
  .swd-badge strong{font-size:.62rem}
  .swd-badge span{font-size:.56rem}
  .swd-badge-icon{width:22px;height:22px;min-width:22px;font-size:.65rem}
}


/* ============================================================
   MARKDOWN BODY — Blog & Product content rendering
   ============================================================ */
.markdown-body {
    font-size: 1rem;
    line-height: 1.9;
    color: var(--text);
    word-break: break-word;
    overflow-wrap: break-word;
    max-width: 100%;
    overflow: hidden;
}

/* Headings */
.markdown-body h1,
.markdown-body h2,
.markdown-body h3,
.markdown-body h4,
.markdown-body h5,
.markdown-body h6 {
    color: var(--dark);
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    line-height: 1.3;
    margin-top: 2rem;
    margin-bottom: .75rem;
}
.markdown-body h1 { font-size: clamp(1.6rem, 3vw, 2.2rem); }
.markdown-body h2 { font-size: clamp(1.3rem, 2.5vw, 1.75rem); border-bottom: 2px solid var(--border); padding-bottom: .4rem; }
.markdown-body h3 { font-size: clamp(1.1rem, 2vw, 1.35rem); }
.markdown-body h4 { font-size: 1.1rem; }
.markdown-body h5 { font-size: 1rem; }
.markdown-body h6 { font-size: .9rem; color: var(--text-light); }

/* Paragraphs */
.markdown-body p {
    margin-bottom: 1.25rem;
}

/* Bold & Italic */
.markdown-body strong { font-weight: 700; color: var(--dark); }
.markdown-body em { font-style: italic; }

/* Links */
.markdown-body a {
    color: var(--primary);
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: var(--transition);
}
.markdown-body a:hover { opacity: .8; }

/* Unordered & Ordered Lists */
.markdown-body ul,
.markdown-body ol {
    padding-left: 1.75rem;
    margin-bottom: 1.25rem;
}
.markdown-body ul { list-style: disc; }
.markdown-body ol { list-style: decimal; }
.markdown-body li {
    margin-bottom: .4rem;
    line-height: 1.8;
}
.markdown-body li > ul,
.markdown-body li > ol {
    margin-top: .4rem;
    margin-bottom: 0;
}

/* Blockquote */
.markdown-body blockquote {
    border-left: 4px solid var(--primary);
    background: rgba(33,150,243,.05);
    margin: 1.5rem 0;
    padding: 1rem 1.5rem;
    border-radius: 0 var(--radius) var(--radius) 0;
    color: var(--text-light);
    font-style: italic;
}
.markdown-body blockquote p { margin-bottom: 0; }

/* Inline Code */
.markdown-body code {
    background: rgba(52,152,219,.1);
    color: #3498db;
    padding: .15em .45em;
    border-radius: 4px;
    font-family: 'Courier New', Courier, monospace;
    font-size: .88em;
}

/* Code Block */
.markdown-body pre {
    background: #1e1e2e;
    color: #cdd6f4;
    padding: 1.5rem;
    border-radius: var(--radius-lg);
    overflow-x: auto;
    margin-bottom: 1.5rem;
    font-size: .875rem;
    line-height: 1.7;
}
.markdown-body pre code {
    background: none;
    color: inherit;
    padding: 0;
    font-size: inherit;
}

/* Horizontal Rule */
.markdown-body hr {
    border: none;
    border-top: 2px solid var(--border);
    margin: 2rem 0;
}

/* Tables (GFM) */
.markdown-body table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 1.5rem;
    font-size: .9rem;
    overflow-x: auto;
    display: block;
}
.markdown-body thead tr {
    background: var(--primary);
    color: #fff;
}
.markdown-body th,
.markdown-body td {
    padding: .75rem 1rem;
    border: 1px solid var(--border);
    text-align: left;
    white-space: nowrap;
}
.markdown-body tbody tr:nth-child(even) {
    background: var(--gray-50);
}

/* Strikethrough (GFM) */
.markdown-body del { text-decoration: line-through; color: var(--text-light); }

/* Images inside markdown */
.markdown-body img {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius-lg);
    margin: 1rem 0;
    box-shadow: var(--shadow);
}

/* Tables and code overflow fix for mobile */
.markdown-body table {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.markdown-body pre {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
}
.markdown-body * {
    max-width: 100%;
}

/* Emoji — renders natively via Unicode, no extra CSS needed */


/* ============================================================
   BLUEPRINT SVG DIAGRAM — Hover Pulse + Draw-line animations
   (same as infonixcloud.com static site)
   ============================================================ */
.blueprint-svg {
    width: 100%;
    max-width: 400px;
    height: auto;
    display: block;
    margin: 0 auto;
    cursor: pointer;
}

.blueprint-node {
    transition: transform 0.3s ease, fill 0.3s ease;
    transform-origin: center;
    transform-box: fill-box;
}

/* On SVG hover — each node pulses with staggered delay */
.blueprint-svg:hover .blueprint-node.node-1 {
    animation: bp-pulse 2s ease-in-out infinite;
    animation-delay: 0s;
}
.blueprint-svg:hover .blueprint-node.node-2 {
    animation: bp-pulse 2s ease-in-out infinite;
    animation-delay: 0.5s;
}
.blueprint-svg:hover .blueprint-node.node-3 {
    animation: bp-pulse 2s ease-in-out infinite;
    animation-delay: 1s;
}
.blueprint-svg:hover .blueprint-node.node-4 {
    animation: bp-pulse 2s ease-in-out infinite;
    animation-delay: 1.5s;
}

@keyframes bp-pulse {
    0%   { transform: scale(1); }
    50%  { transform: scale(1.25); }
    100% { transform: scale(1); }
}

/* Connecting lines draw-in on page load */
.blueprint-line {
    stroke-dasharray: 300;
    stroke-dashoffset: 300;
    animation: bp-draw-line 2s ease forwards;
}

@keyframes bp-draw-line {
    to { stroke-dashoffset: 0; }
}

/* blueprint diagram wrapper — center on mobile */
.blueprint-diagram {
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ============================================================
   LOGO HOVER-ROTATE — Header logo hilne ka effect
   (same as infonixcloud.com static site)
   ============================================================ */
.hover-rotate {
    transition: transform 0.3s ease;
}
.hover-rotate:hover {
    transform: rotate(10deg);
}

/* ============================================================
   NAV DROPDOWN — Our Work (Portfolio + Products)
   ============================================================ */
.nav-dropdown {
    position: relative;
}

.nav-dropdown-toggle {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    color: var(--dark);
    padding: .5rem .9rem;
    border-radius: 8px;
    font-weight: 500;
    font-size: .9rem;
    transition: var(--transition);
    background: transparent;
    border: none;
    cursor: pointer;
    font-family: var(--font-main);
    line-height: 1.7;
    outline: none;
    -webkit-appearance: none;
    appearance: none;
    text-decoration: none;
    white-space: nowrap;
}
.nav-dropdown-toggle:hover,
.nav-dropdown-toggle.active {
    color: var(--primary);
    background: rgba(52,152,219,.08);
}
.nav-dropdown-icon {
    font-size: .65rem;
    transition: transform .25s ease;
}
.nav-dropdown:hover .nav-dropdown-icon,
.nav-dropdown.open .nav-dropdown-icon {
    transform: rotate(180deg);
}

/* Dropdown menu */
.nav-dropdown-menu {
    position: absolute;
    top: calc(100% + .5rem);
    left: 50%;
    transform: translateX(-50%);
    background: #fff;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: 0 8px 32px rgba(0,0,0,.12);
    min-width: 180px;
    padding: .4rem;
    opacity: 0;
    visibility: hidden;
    transform: translateX(-50%) translateY(-6px);
    transition: opacity .2s ease, transform .2s ease, visibility .2s;
    z-index: 200;
}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown.open .nav-dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
}

/* Arrow tip */
.nav-dropdown-menu::before {
    content: '';
    position: absolute;
    top: -5px;
    left: 50%;
    transform: translateX(-50%) rotate(45deg);
    width: 10px;
    height: 10px;
    background: #fff;
    border-left: 1px solid var(--border);
    border-top: 1px solid var(--border);
}

.nav-dropdown-item {
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: .65rem 1rem;
    border-radius: 6px;
    color: var(--dark);
    font-size: .875rem;
    font-weight: 500;
    transition: var(--transition);
    text-decoration: none;
    white-space: nowrap;
}
.nav-dropdown-item i {
    color: var(--primary);
    font-size: .85rem;
    width: 16px;
    text-align: center;
}
.nav-dropdown-item:hover,
.nav-dropdown-item.active {
    background: rgba(52,152,219,.08);
    color: var(--primary);
}

/* Mobile nav group */
.mobile-nav-group {
    display: flex;
    flex-direction: column;
    margin: .4rem 0;
    background: rgba(52,152,219,.04);
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid rgba(52,152,219,.1);
}
.mobile-nav-group-label {
    font-size: .68rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1.8px;
    color: var(--primary);
    padding: .65rem 1.1rem .3rem;
    opacity: .8;
}
.mobile-nav-group a {
    border-radius: 0!important;
    border-left: none!important;
    padding-left: 1.5rem!important;
    font-size: .9rem!important;
}
.mobile-nav-group a:last-child {
    padding-bottom: .65rem!important;
}
.mobile-nav-group a.active {
    border-left: 3px solid var(--primary)!important;
    padding-left: 1.2rem!important;
}

/* ============================================================
   ADDITIONAL RESPONSIVE POLISH — Cards, Images, Layout
   ============================================================ */

/* ---- Service cards — image always fluid ---- */
.service-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ---- Portfolio card — image always fluid ---- */
.portfolio-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ---- Blog card — image always fluid ---- */
.blog-card-img-link img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ---- Product card image ---- */
.product-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ---- Hero section image ---- */
.hero-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ---- About page logo image ---- */
.about-logo-img {
    width: 100%;
    max-width: 300px;
    height: auto;
}

/* ---- Testimonial photo fluid ---- */
.testimonial-photo {
    width: 64px;
    height: 64px;
    min-width: 64px;
    object-fit: cover;
}

/* ---- Google icon in testimonials ---- */
img[style*="width:36px;height:36px"],
img[style*="width:20px;height:20px"],
img[style*="width:40px;height:40px"] {
    flex-shrink: 0;
}

/* ---- Recent blog thumbnails in sidebar ---- */
img[style*="width:56px;height:42px"],
img[style*="width:60px;height:45px"] {
    flex-shrink: 0;
    object-fit: cover;
}

/* ---- Fix container overflow on all pages ---- */
.container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1.5rem;
}

/* ---- Mobile header: ensure logo doesn't overflow ---- */
@media(max-width:480px){
    .logo-text { font-size: 1.15rem; }
    .logo-link img { width: 34px; height: 34px; }
    .header-inner { gap: .5rem; }
}

/* ---- Mobile nav: full width buttons ---- */
@media(max-width:768px){
    .mobile-nav nav .btn {
        width: 100%;
        text-align: center;
        justify-content: center;
        margin-top: .5rem;
    }
    .mobile-nav nav .btn-login {
        width: 100%;
        text-align: center;
        justify-content: center;
    }
    /* Clients marquee label */
    .clients-label { font-size: .68rem; }

    /* Stats section */
    .stats-section { padding: 3.5rem 0; }

    /* Testimonials section */
    .testimonials-section { padding: 4rem 0; }

    /* Google review card */
    .testimonials-section .google-review-card { padding: 1.75rem 1.25rem; }

    /* Contact form card */
    div[style*="padding:2.5rem;border:1px solid var(--border);box-shadow"] {
        padding: 1.5rem!important;
        border-radius: var(--radius-lg)!important;
    }

    /* Footer contact list items */
    .footer-contact li { align-items: flex-start; }

    /* Pagination buttons smaller */
    .page-btn { min-width: 36px; height: 36px; font-size: .8rem; padding: 0 .65rem; }

    /* Portfolio filter scrollable on mobile */
    .portfolio-filter {
        flex-wrap: nowrap;
        overflow-x: auto;
        justify-content: flex-start;
        padding-bottom: .5rem;
        scrollbar-width: none;
        -webkit-overflow-scrolling: touch;
        gap: .5rem;
    }
    .portfolio-filter::-webkit-scrollbar { display: none; }
    .filter-btn { white-space: nowrap; flex-shrink: 0; }

    /* Service quick nav already has overflow-x:auto, ensure same on mobile */
    .services-quick-nav-inner {
        overflow-x: auto;
        scrollbar-width: none;
    }
}

/* ---- Card hover effects off on touch devices ---- */
@media(hover:none){
    .service-card:hover,
    .portfolio-card:hover,
    .blog-card:hover,
    .product-card:hover,
    .benefit-card:hover,
    .industry-card:hover,
    .blueprint-step:hover,
    .feature-item:hover {
        transform: none;
    }
    .portfolio-overlay { opacity: 1; background: rgba(3,7,18,.5); }
}

/* ---- Prevent text overflow in cards ---- */
.service-card-body h3,
.portfolio-card-body h3,
.blog-card-body h3,
.product-card-body h3 {
    overflow-wrap: break-word;
    word-break: break-word;
}

/* ---- Images inside service sections (alternating layout) ---- */
@media(max-width:768px){
    /* Service section image containers */
    section[id] > .container > div > div:first-child > div {
        border-radius: var(--radius-lg)!important;
    }
    section[id] > .container > div > div:first-child > div > img {
        height: 220px!important;
        width: 100%!important;
        object-fit: cover!important;
    }
    section[id] > .container > div > div:first-child > div[style*="height:380px"] {
        height: 220px!important;
    }
    /* Feature grid inside service detail */
    div[style*="grid-template-columns:1fr 1fr;gap:.6rem"],
    div[style*="grid-template-columns:1fr 1fr;gap:.75rem"] {
        grid-template-columns: 1fr!important;
    }
}

/* ---- About page: story section image ---- */
@media(max-width:768px){
    div[style*="padding:3rem"] > img[style*="max-height:420px"] {
        max-height: 260px!important;
        padding: 2rem!important;
    }
}

/* ---- Careers page: perk cards on mobile ---- */
@media(max-width:768px){
    .why-join-grid { grid-template-columns: repeat(2, 1fr)!important; }
}
@media(max-width:480px){
    .why-join-grid { grid-template-columns: 1fr!important; }
}

/* ---- Mobile: CTA section ---- */
@media(max-width:768px){
    .cta-section { padding: 3rem 0; }
    .cta-section .cta-content::before { border-radius: var(--radius-lg); }
}

/* ---- Fix: mobile overflow caused by fixed-width elements ---- */
@media(max-width:768px){
    /* Prevent any element wider than viewport */
    * { max-width: 100%; }
    /* Except those that should scroll */
    .marquee-track,
    .testimonials-track,
    pre,
    .markdown-body table { max-width: none; }
}
