/* ================================================================
   FLOWVIXAI — Premium AI Automation Agency
   Dark futuristic, electric blue / purple / neon-green palette
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Space+Grotesk:wght@400;500;600;700&display=swap');

/* ===== 1. CSS VARIABLES ===== */
:root {
  --bg:        #030711;
  --bg-2:      #070e22;
  --bg-3:      #0d1533;
  --glass:     rgba(255,255,255,0.03);
  --glass-h:   rgba(255,255,255,0.065);

  --blue:      #00c2ff;
  --blue-dim:  rgba(0,194,255,0.12);
  --blue-glow: rgba(0,194,255,0.35);
  --purple:    #7c3aed;
  --purple-dim:rgba(124,58,237,0.15);
  --green:     #00ff88;
  --green-dim: rgba(0,255,136,0.08);

  --text:   #f1f5f9;
  --text-2: #8b9cb5;
  --text-3: #3f4f68;

  --border:      rgba(255,255,255,0.07);
  --border-blue: rgba(0,194,255,0.22);

  --radius:    16px;
  --radius-lg: 24px;
  --radius-xl: 32px;
  --pill:      9999px;

  --ease: cubic-bezier(0.4,0,0.2,1);
  --t: 0.35s var(--ease);
  --t-slow: 0.65s var(--ease);

  --section-py: 130px;
  --max-w: 1200px;
}

/* ===== 2. RESET ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;min-width:0}
html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden}
body{
  font-family:'Inter',sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  width:100%;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{border:none;background:none;cursor:pointer;font:inherit;color:inherit}
input,textarea,select{font:inherit;color:inherit}

/* ===== 3. TYPOGRAPHY ===== */
h1,h2,h3,h4,h5{font-family:'Space Grotesk',sans-serif;line-height:1.1;font-weight:700}

.gradient-text{
  background:linear-gradient(135deg,#00c2ff 0%,#7c3aed 50%,#00ff88 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.gradient-text-blue{
  background:linear-gradient(135deg,#00c2ff,#005fff);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.gradient-text-animated{
  background:linear-gradient(270deg,#00c2ff,#7c3aed,#00ff88,#00c2ff);
  background-size:400% 400%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:grad 7s ease infinite;
}
@keyframes grad{
  0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}
}

/* ===== 4. LAYOUT ===== */
.container{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.section{padding:var(--section-py) 0}

/* ===== 5. BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 34px;border-radius:var(--pill);
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:1rem;
  transition:var(--t);cursor:pointer;white-space:nowrap;
}
.btn-primary{
  background:linear-gradient(135deg,#00c2ff,#0055ff);
  color:#fff;
  box-shadow:0 0 32px rgba(0,194,255,0.38);
  position:relative;overflow:hidden;
}
.btn-primary::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,0.15),transparent);
  opacity:0;transition:var(--t);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 0 55px rgba(0,194,255,0.55),0 16px 40px rgba(0,0,0,0.4)}
.btn-primary:hover::after{opacity:1}

.btn-ghost{
  background:transparent;color:var(--text);
  border:1px solid var(--border-blue);
}
.btn-ghost:hover{background:var(--blue-dim);border-color:var(--blue);box-shadow:0 0 20px rgba(0,194,255,0.18);transform:translateY(-2px)}

.btn-lg{padding:18px 42px;font-size:1.05rem}

/* ===== 6. BADGE ===== */
.badge{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--blue-dim);border:1px solid var(--border-blue);
  color:var(--blue);padding:6px 18px;border-radius:var(--pill);
  font-size:0.78rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;
}
.badge-dot{
  width:6px;height:6px;background:var(--blue);border-radius:50%;
  animation:bdot 2s ease infinite;
}
@keyframes bdot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.4;transform:scale(0.7)}}

/* ===== 7. SECTION HEADER ===== */
.sec-header{text-align:center;margin-bottom:80px}
.sec-header .badge{margin-bottom:22px}
.sec-header h2{font-size:clamp(2.1rem,5vw,3.4rem);margin-bottom:18px}
.sec-header p{font-size:1.1rem;color:var(--text-2);max-width:580px;margin:0 auto;line-height:1.75}

/* ===== 8. GLASS CARD ===== */
.glass-card{
  background:var(--glass);border:1px solid var(--border);
  border-radius:var(--radius-lg);backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);transition:var(--t);
}
.glass-card:hover{
  background:var(--glass-h);border-color:var(--border-blue);
  box-shadow:0 24px 64px rgba(0,0,0,0.35),0 0 32px rgba(0,194,255,0.07);
  transform:translateY(-6px);
}

/* ===== 9. SCROLL REVEAL ===== */
.reveal,.reveal-l,.reveal-r,.reveal-s{opacity:0;transition:opacity 0.7s var(--ease),transform 0.7s var(--ease)}
.reveal{transform:translateY(32px)}
.reveal-l{transform:translateX(-40px)}
.reveal-r{transform:translateX(40px)}
.reveal-s{transform:scale(0.94)}
.revealed{opacity:1!important;transform:none!important}
.d1{transition-delay:0.1s}.d2{transition-delay:0.2s}.d3{transition-delay:0.3s}
.d4{transition-delay:0.4s}.d5{transition-delay:0.5s}.d6{transition-delay:0.6s}

/* ===== 10. NAVIGATION ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:20px 0;transition:var(--t);
}
.nav.scrolled{
  background:rgba(3,7,17,0.85);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);padding:14px 0;
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  max-width:var(--max-w);margin:0 auto;padding:0 24px;
}
.nav-logo{
  display:flex;align-items:center;gap:10px;
  font-family:'Space Grotesk',sans-serif;font-size:1.45rem;font-weight:700;
}
.logo-icon{
  width:36px;height:36px;background:linear-gradient(135deg,#00c2ff,#7c3aed);
  border-radius:10px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 18px rgba(0,194,255,0.4);
}
.logo-icon svg{width:20px;height:20px;fill:white}
.logo-text span{color:var(--blue)}

.nav-links{display:flex;align-items:center;gap:8px}
.nav-links a{
  padding:8px 18px;border-radius:var(--pill);color:var(--text-2);
  font-weight:500;font-size:0.95rem;transition:var(--t);
}
.nav-links a:hover,.nav-links a.active{color:var(--text);background:var(--glass-h)}

.nav-cta .btn{padding:10px 24px;font-size:0.9rem}

.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px}
.hamburger span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:var(--t)}

.mobile-menu{
  display:none;position:fixed;top:0;left:0;right:0;bottom:0;z-index:999;
  background:rgba(3,7,17,0.97);backdrop-filter:blur(30px);
  flex-direction:column;align-items:center;justify-content:center;gap:8px;
}
.mobile-menu.open{display:flex}
.mobile-menu a{
  font-family:'Space Grotesk',sans-serif;font-size:1.8rem;font-weight:600;
  color:var(--text-2);padding:12px 32px;border-radius:var(--radius);transition:var(--t);
}
.mobile-menu a:hover{color:var(--blue);background:var(--blue-dim)}
.mobile-close{position:absolute;top:24px;right:24px;font-size:2rem;color:var(--text-2);cursor:pointer}

/* ===== 11. ORB BACKGROUND ===== */
.orb-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:0.55}
.orb-1{width:600px;height:600px;background:#1a0066;top:-100px;left:-150px;animation:float1 18s ease-in-out infinite}
.orb-2{width:500px;height:500px;background:#003566;top:10%;right:-100px;animation:float2 22s ease-in-out infinite}
.orb-3{width:400px;height:400px;background:#0a2444;bottom:-50px;left:30%;animation:float3 16s ease-in-out infinite}
.orb-4{width:300px;height:300px;background:#00254d;bottom:20%;right:20%;animation:float1 20s ease-in-out infinite reverse}
@keyframes float1{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(40px,-30px) scale(1.05)}66%{transform:translate(-25px,20px) scale(0.95)}}
@keyframes float2{0%,100%{transform:translate(0,0) scale(1)}40%{transform:translate(-35px,25px) scale(1.08)}70%{transform:translate(20px,-15px) scale(0.97)}}
@keyframes float3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(30px,30px) scale(1.06)}}

/* ===== 12. HERO ===== */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  padding:140px 0 100px;overflow:hidden;
}
#hero-canvas{position:absolute;inset:0;z-index:1;pointer-events:none}
.hero .container{position:relative;z-index:2}
.hero-content{max-width:820px}
.hero-badge{margin-bottom:30px}
.hero h1{
  font-size:clamp(3rem,8vw,7rem);font-weight:800;line-height:1.0;
  margin-bottom:28px;letter-spacing:-0.02em;
}
.hero h1 span{display:block}
.hero-sub{
  font-size:clamp(1rem,2vw,1.2rem);color:var(--text-2);
  max-width:600px;margin-bottom:44px;line-height:1.8;
}
.hero-ctas{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:64px}
.hero-stats{display:flex;flex-wrap:wrap;gap:40px}
.hstat-val{
  font-family:'Space Grotesk',sans-serif;font-size:2rem;font-weight:700;
  background:linear-gradient(135deg,var(--blue),#fff 80%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hstat-lbl{font-size:0.85rem;color:var(--text-2);font-weight:500;margin-top:2px}

/* ===== 13. TRUSTED BY ===== */
.trusted{padding:60px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.trusted-label{
  text-align:center;font-size:0.82rem;font-weight:600;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--text-3);margin-bottom:36px;
}
.marquee-wrap{overflow:hidden;position:relative}
.marquee-wrap::before,.marquee-wrap::after{
  content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;
}
.marquee-wrap::before{left:0;background:linear-gradient(to right,var(--bg),transparent)}
.marquee-wrap::after{right:0;background:linear-gradient(to left,var(--bg),transparent)}
.marquee-track{display:flex;gap:0;width:max-content;animation:marquee 28s linear infinite}
.marquee-track:hover{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.logo-item{
  display:flex;align-items:center;gap:10px;
  padding:0 48px;color:var(--text-3);font-weight:600;font-size:1rem;
  letter-spacing:0.04em;white-space:nowrap;
  transition:var(--t);
}
.logo-item:hover{color:var(--text-2)}
.logo-item svg{width:22px;height:22px;opacity:0.5}

/* ===== 14. WHAT WE DO ===== */
.services-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:24px;
}
.svc-card{
  padding:36px;border-radius:var(--radius-lg);background:var(--glass);
  border:1px solid var(--border);transition:var(--t);position:relative;overflow:hidden;
}
.svc-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,var(--blue-dim),transparent 60%);
  opacity:0;transition:var(--t);border-radius:inherit;
}
.svc-card:hover{background:var(--glass-h);border-color:var(--border-blue);transform:translateY(-8px);box-shadow:0 32px 64px rgba(0,0,0,0.4),0 0 40px rgba(0,194,255,0.08)}
.svc-card:hover::before{opacity:1}
.svc-icon{
  width:56px;height:56px;border-radius:14px;
  background:linear-gradient(135deg,var(--blue-dim),var(--purple-dim));
  border:1px solid var(--border-blue);
  display:flex;align-items:center;justify-content:center;margin-bottom:24px;
  transition:var(--t);
}
.svc-card:hover .svc-icon{box-shadow:0 0 24px var(--blue-glow)}
.svc-icon svg{width:28px;height:28px}
.svc-card h3{font-size:1.25rem;margin-bottom:12px}
.svc-card p{color:var(--text-2);font-size:0.95rem;line-height:1.7}
.svc-arrow{
  display:inline-flex;align-items:center;gap:6px;margin-top:20px;
  color:var(--blue);font-size:0.88rem;font-weight:600;
  transition:var(--t);
}
.svc-arrow:hover{gap:10px}

/* ===== 15. WHY US ===== */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.why-stats{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.stat-box{
  background:var(--glass);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:32px;text-align:center;transition:var(--t);
}
.stat-box:hover{border-color:var(--border-blue);background:var(--glass-h)}
.stat-box .val{
  font-family:'Space Grotesk',sans-serif;font-size:2.8rem;font-weight:700;
  display:block;margin-bottom:6px;
}
.stat-box .lbl{font-size:0.88rem;color:var(--text-2);font-weight:500}
.why-features{display:flex;flex-direction:column;gap:24px}
.why-feat{display:flex;gap:18px;align-items:flex-start}
.feat-icon{
  width:44px;height:44px;min-width:44px;border-radius:12px;
  background:var(--blue-dim);border:1px solid var(--border-blue);
  display:flex;align-items:center;justify-content:center;margin-top:2px;
}
.feat-icon svg{width:22px;height:22px}
.feat-body h4{font-size:1.05rem;margin-bottom:6px}
.feat-body p{font-size:0.92rem;color:var(--text-2);line-height:1.65}

/* ===== 16. HOW IT WORKS ===== */
.hiw-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;position:relative}
.hiw-grid::before{
  content:'';position:absolute;top:46px;left:calc(33.33% - 0px);right:calc(33.33% - 0px);
  height:1px;background:linear-gradient(to right,var(--border-blue),var(--purple),var(--border-blue));
  z-index:0;
}
.hiw-step{
  text-align:center;padding:40px 32px;position:relative;z-index:1;
}
.step-num{
  width:92px;height:92px;border-radius:50%;
  background:linear-gradient(135deg,var(--bg-2),var(--bg-3));
  border:2px solid var(--border-blue);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 32px;
  font-family:'Space Grotesk',sans-serif;font-size:1.6rem;font-weight:700;
  color:var(--blue);box-shadow:0 0 30px var(--blue-glow);
  position:relative;
}
.step-num::after{
  content:'';position:absolute;inset:-6px;border-radius:50%;
  border:1px solid var(--border-blue);opacity:0.4;
}
.hiw-step h3{font-size:1.2rem;margin-bottom:12px}
.hiw-step p{font-size:0.93rem;color:var(--text-2);line-height:1.7;max-width:240px;margin:0 auto}

/* ===== 17. TESTIMONIALS ===== */
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px}
.testi-card{
  background:var(--glass);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:36px;transition:var(--t);
}
.testi-card:hover{background:var(--glass-h);border-color:var(--border-blue);transform:translateY(-5px)}
.testi-stars{display:flex;gap:4px;margin-bottom:20px}
.testi-stars svg{width:18px;height:18px;fill:#f59e0b}
.testi-card blockquote{
  font-size:1rem;line-height:1.75;color:var(--text-2);margin-bottom:28px;
  font-style:italic;
}
.testi-author{display:flex;align-items:center;gap:14px}
.avatar{
  width:48px;height:48px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.1rem;
  flex-shrink:0;
}
.avatar-1{background:linear-gradient(135deg,#00c2ff,#0055ff)}
.avatar-2{background:linear-gradient(135deg,#7c3aed,#c026d3)}
.avatar-3{background:linear-gradient(135deg,#00ff88,#0066ff)}
.avatar-4{background:linear-gradient(135deg,#f59e0b,#ef4444)}
.testi-name{font-weight:600;font-size:0.95rem}
.testi-role{font-size:0.82rem;color:var(--text-3)}

/* ===== 18. CTA SECTION ===== */
.cta-section{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,rgba(0,100,255,0.12) 0%,rgba(124,58,237,0.12) 50%,rgba(0,255,136,0.06) 100%);
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.cta-content{text-align:center;position:relative;z-index:2}
.cta-content h2{font-size:clamp(2.2rem,5vw,3.8rem);margin-bottom:20px}
.cta-content p{font-size:1.1rem;color:var(--text-2);max-width:540px;margin:0 auto 44px}
.cta-btns{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}

/* ===== 19. FOOTER ===== */
.footer{background:var(--bg-2);border-top:1px solid var(--border);padding:80px 0 40px}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:60px;margin-bottom:60px}
.footer-brand p{color:var(--text-2);font-size:0.93rem;line-height:1.75;margin:16px 0 28px}
.footer-socials{display:flex;gap:12px}
.social-link{
  width:40px;height:40px;border-radius:10px;background:var(--glass);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;transition:var(--t);
}
.social-link:hover{background:var(--blue-dim);border-color:var(--border-blue);box-shadow:0 0 14px rgba(0,194,255,0.2)}
.social-link svg{width:18px;height:18px;fill:var(--text-2)}
.social-link:hover svg{fill:var(--blue)}

.footer-col h4{font-size:0.9rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--text-3);margin-bottom:20px}
.footer-col ul li{margin-bottom:12px}
.footer-col ul li a{color:var(--text-2);font-size:0.93rem;transition:var(--t)}
.footer-col ul li a:hover{color:var(--blue)}

.footer-bottom{
  border-top:1px solid var(--border);padding-top:32px;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
}
.footer-bottom p{color:var(--text-3);font-size:0.85rem}
.footer-bottom-links{display:flex;gap:24px}
.footer-bottom-links a{color:var(--text-3);font-size:0.85rem;transition:var(--t)}
.footer-bottom-links a:hover{color:var(--blue)}

/* ===== 20. PAGE HERO BANNER ===== */
.page-hero{
  position:relative;padding:160px 0 100px;overflow:hidden;
  background:linear-gradient(180deg,var(--bg-2) 0%,var(--bg) 100%);
}
.page-hero .orb-bg .orb{opacity:0.35}
.page-hero .container{position:relative;z-index:2;text-align:center}
.page-hero h1{font-size:clamp(2.5rem,6vw,4.5rem);margin-bottom:20px}
.page-hero p{font-size:1.15rem;color:var(--text-2);max-width:600px;margin:0 auto;line-height:1.75}
.page-hero .badge{margin-bottom:24px}

/* ===== 21. SERVICES PAGE ===== */
.svc-detail-card{
  background:var(--glass);border:1px solid var(--border);border-radius:var(--radius-xl);
  padding:48px;transition:var(--t);display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;
  margin-bottom:28px;
}
.svc-detail-card:hover{border-color:var(--border-blue);box-shadow:0 24px 64px rgba(0,0,0,0.3)}
.svc-detail-card.reverse{direction:rtl}
.svc-detail-card.reverse>*{direction:ltr}
.svc-detail-icon{width:72px;height:72px;border-radius:20px;background:linear-gradient(135deg,var(--blue-dim),var(--purple-dim));border:1px solid var(--border-blue);display:flex;align-items:center;justify-content:center;margin-bottom:28px}
.svc-detail-icon svg{width:36px;height:36px}
.svc-detail-card h3{font-size:1.7rem;margin-bottom:16px}
.svc-detail-card p{color:var(--text-2);line-height:1.75;margin-bottom:24px}
.svc-list{display:flex;flex-direction:column;gap:12px}
.svc-list li{display:flex;align-items:center;gap:12px;color:var(--text-2);font-size:0.93rem}
.svc-list li::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--blue);flex-shrink:0}
.svc-visual{
  border-radius:var(--radius-lg);overflow:hidden;
  background:linear-gradient(135deg,var(--bg-2),var(--bg-3));
  border:1px solid var(--border);min-height:280px;
  display:flex;align-items:center;justify-content:center;
}
.svc-visual-inner{
  display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px;
}

/* Flow animation for service visuals */
.flow-nodes{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}
.flow-row{display:flex;justify-content:center;gap:12px}
.f-node{
  background:var(--glass-h);border:1px solid var(--border-blue);border-radius:10px;
  padding:8px 16px;font-size:0.78rem;font-weight:600;color:var(--blue);
  display:flex;align-items:center;gap:6px;white-space:nowrap;
}
.f-node svg{width:14px;height:14px}
.f-arrow{color:var(--text-3);font-size:1.2rem;text-align:center}

/* ===== 22. ABOUT PAGE ===== */
.mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.mission-visual{position:relative}
.mission-card-main{
  background:var(--glass);border:1px solid var(--border-blue);border-radius:var(--radius-xl);
  padding:48px;
}
.mission-stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px}
.m-stat{text-align:center}
.m-stat .val{font-family:'Space Grotesk',sans-serif;font-size:2rem;font-weight:700;color:var(--blue)}
.m-stat .lbl{font-size:0.8rem;color:var(--text-2)}

.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px}
.value-card{
  background:var(--glass);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:32px;transition:var(--t);text-align:center;
}
.value-card:hover{border-color:var(--border-blue);background:var(--glass-h);transform:translateY(-5px)}
.value-icon{
  width:60px;height:60px;border-radius:16px;background:linear-gradient(135deg,var(--blue-dim),var(--purple-dim));
  border:1px solid var(--border-blue);display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;
}
.value-icon svg{width:28px;height:28px}
.value-card h3{font-size:1.1rem;margin-bottom:10px}
.value-card p{font-size:0.9rem;color:var(--text-2);line-height:1.65}

.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px}
.team-card{
  background:var(--glass);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:32px 24px;text-align:center;transition:var(--t);
}
.team-card:hover{border-color:var(--border-blue);transform:translateY(-5px)}
.team-avatar{
  width:80px;height:80px;border-radius:50%;margin:0 auto 20px;
  display:flex;align-items:center;justify-content:center;
  font-family:'Space Grotesk',sans-serif;font-size:1.8rem;font-weight:700;
}
.team-card h3{font-size:1.05rem;font-weight:700;margin-bottom:4px}
.team-role{font-size:0.85rem;color:var(--blue);font-weight:500;margin-bottom:12px}
.team-card p{font-size:0.88rem;color:var(--text-2);line-height:1.6}

/* ===== 23. CASE STUDIES PAGE ===== */
.cs-featured{
  background:var(--glass);border:1px solid var(--border-blue);border-radius:var(--radius-xl);
  padding:56px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
  margin-bottom:56px;
}
.cs-tag{font-size:0.8rem;font-weight:600;color:var(--green);background:var(--green-dim);
  border:1px solid rgba(0,255,136,0.2);padding:4px 14px;border-radius:var(--pill);display:inline-block;margin-bottom:20px}
.cs-featured h2{font-size:2.2rem;margin-bottom:16px}
.cs-featured p{color:var(--text-2);line-height:1.75;margin-bottom:32px}
.cs-results{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.cs-r{text-align:center;background:var(--glass);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.cs-r .val{font-family:'Space Grotesk',sans-serif;font-size:2rem;font-weight:700;color:var(--green);display:block}
.cs-r .lbl{font-size:0.8rem;color:var(--text-2)}
.cs-visual{
  background:linear-gradient(135deg,var(--bg-2),var(--bg-3));border:1px solid var(--border);
  border-radius:var(--radius-lg);min-height:320px;display:flex;align-items:center;justify-content:center;
}

.case-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:24px}
.case-card{
  background:var(--glass);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:36px;transition:var(--t);
}
.case-card:hover{border-color:var(--border-blue);transform:translateY(-6px);box-shadow:0 24px 56px rgba(0,0,0,0.35)}
.case-card h3{font-size:1.2rem;margin:16px 0 10px}
.case-card .desc{font-size:0.93rem;color:var(--text-2);line-height:1.7;margin-bottom:24px}
.case-metrics{display:flex;gap:20px;flex-wrap:wrap}
.c-m{display:flex;flex-direction:column;gap:2px}
.c-m .v{font-family:'Space Grotesk',sans-serif;font-size:1.4rem;font-weight:700;color:var(--blue)}
.c-m .l{font-size:0.78rem;color:var(--text-2)}

/* ===== 24. CONTACT PAGE ===== */
.contact-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:60px;align-items:start}
.contact-form-wrap{
  background:var(--glass);border:1px solid var(--border);border-radius:var(--radius-xl);padding:48px;
}
.form-group{margin-bottom:24px}
.form-group label{display:block;font-size:0.88rem;font-weight:600;color:var(--text-2);margin-bottom:8px;letter-spacing:0.02em}
.form-group input,.form-group textarea,.form-group select{
  width:100%;background:rgba(255,255,255,0.04);border:1px solid var(--border);
  border-radius:var(--radius);padding:14px 18px;color:var(--text);
  font-size:0.95rem;transition:var(--t);outline:none;
}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{
  border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,194,255,0.12);
  background:rgba(255,255,255,0.06);
}
.form-group textarea{height:140px;resize:vertical}
.form-group select option{background:var(--bg-2);color:var(--text)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}

.contact-info h2{font-size:2.2rem;margin-bottom:16px}
.contact-info>p{color:var(--text-2);line-height:1.75;margin-bottom:40px}
.contact-item{display:flex;gap:18px;align-items:flex-start;margin-bottom:28px}
.contact-item-icon{
  width:48px;height:48px;min-width:48px;border-radius:14px;background:var(--blue-dim);
  border:1px solid var(--border-blue);display:flex;align-items:center;justify-content:center;
}
.contact-item-icon svg{width:22px;height:22px}
.contact-item h4{font-size:0.95rem;font-weight:600;margin-bottom:4px}
.contact-item p{font-size:0.9rem;color:var(--text-2)}
.contact-divider{height:1px;background:var(--border);margin:36px 0}
.faq-item{border-bottom:1px solid var(--border);padding:20px 0}
.faq-q{
  width:100%;display:flex;justify-content:space-between;align-items:center;
  font-weight:600;font-size:0.95rem;cursor:pointer;background:none;border:none;
  color:var(--text);text-align:left;
}
.faq-q svg{width:20px;height:20px;fill:var(--text-2);transition:var(--t);flex-shrink:0}
.faq-item.open .faq-q svg{transform:rotate(45deg);fill:var(--blue)}
.faq-a{font-size:0.9rem;color:var(--text-2);line-height:1.7;max-height:0;overflow:hidden;transition:max-height 0.4s var(--ease)}
.faq-item.open .faq-a{max-height:200px;padding-top:12px}

/* ===== 25. PROCESS / HOW IT WORKS (SERVICES PAGE) ===== */
.process-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:0;position:relative}
.p-step{text-align:center;padding:32px 24px;position:relative}
.p-step::after{
  content:'→';position:absolute;right:-10px;top:50%;transform:translateY(-50%);
  color:var(--border-blue);font-size:1.5rem;
}
.p-step:last-child::after{display:none}
.p-num{
  width:56px;height:56px;border-radius:50%;background:var(--blue-dim);border:2px solid var(--border-blue);
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;
  font-family:'Space Grotesk',sans-serif;font-weight:700;color:var(--blue);font-size:1.1rem;
}
.p-step h4{font-size:0.95rem;margin-bottom:8px}
.p-step p{font-size:0.85rem;color:var(--text-2);line-height:1.6}

/* ===== 26. PRICING TEASER ===== */
.pricing-card{
  background:var(--glass);border:1px solid var(--border);border-radius:var(--radius-xl);
  padding:48px;text-align:center;transition:var(--t);
}
.pricing-card.featured{border-color:var(--border-blue);background:linear-gradient(135deg,rgba(0,194,255,0.07),rgba(124,58,237,0.07))}
.pricing-card h3{font-size:1.4rem;margin-bottom:8px}
.pricing-card .price{font-family:'Space Grotesk',sans-serif;font-size:3rem;font-weight:700;margin:16px 0 4px}
.pricing-card .price-note{font-size:0.85rem;color:var(--text-2);margin-bottom:28px}
.pricing-card .plan-list{text-align:left;display:flex;flex-direction:column;gap:12px;margin-bottom:32px}
.pricing-card .plan-list li{display:flex;align-items:center;gap:12px;font-size:0.93rem;color:var(--text-2)}
.check-icon{width:20px;height:20px;min-width:20px;border-radius:50%;background:var(--blue-dim);border:1px solid var(--border-blue);display:flex;align-items:center;justify-content:center}
.check-icon svg{width:11px;height:11px;stroke:var(--blue);fill:none;stroke-width:2.5}

/* ===== 27. RESULTS BANNER ===== */
.results-banner{
  background:linear-gradient(135deg,rgba(0,194,255,0.1),rgba(124,58,237,0.1));
  border:1px solid var(--border-blue);border-radius:var(--radius-xl);
  padding:56px;display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  text-align:center;
}
.rb-stat{padding:20px;border-right:1px solid var(--border)}
.rb-stat:last-child{border-right:none}
.rb-stat .v{font-family:'Space Grotesk',sans-serif;font-size:2.6rem;font-weight:700;display:block;margin-bottom:6px}
.rb-stat .l{font-size:0.88rem;color:var(--text-2)}

/* ===== 28. RESPONSIVE ===== */
@media(max-width:1024px){
  .why-grid{grid-template-columns:1fr;gap:48px}
  .mission-grid{grid-template-columns:1fr;gap:48px}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .cs-featured{grid-template-columns:1fr;gap:40px}
  .footer-top{grid-template-columns:1fr 1fr;gap:40px}
  .svc-detail-card{grid-template-columns:1fr;gap:32px}
  .svc-detail-card.reverse{direction:ltr}
}

/* ── 768 px ── */
@media(max-width:768px){
  :root{--section-py:80px}
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  /* Hero */
  .hero{padding:100px 0 64px;overflow:hidden}
  .hero h1{font-size:clamp(2.2rem,8vw,3.6rem)}
  .hero-sub{font-size:1rem}
  /* Grids — all forced to single column */
  .hiw-grid{grid-template-columns:1fr;gap:0}
  .hiw-grid::before{display:none}
  .services-grid{grid-template-columns:1fr}
  .testi-grid{grid-template-columns:1fr}
  .case-grid{grid-template-columns:1fr}
  /* Why */
  .why-stats{grid-template-columns:1fr 1fr}
  /* Results */
  .results-banner{grid-template-columns:1fr 1fr}
  .rb-stat:nth-child(2){border-right:none}
  .rb-stat:nth-child(3){border-right:1px solid var(--border)}
  /* Footer */
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  /* Forms */
  .cs-results{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .mission-stat-row{grid-template-columns:repeat(3,1fr)}
  /* Buttons — allow text to wrap so they never overflow */
  .btn{white-space:normal}
  /* Service page flow diagram nodes */
  .flow-row{flex-wrap:wrap;justify-content:center}
  /* Service visual height */
  .svc-visual{min-height:180px}
  /* Paddings */
  .contact-form-wrap{padding:32px 24px}
  .cs-featured{padding:36px 24px}
  .svc-detail-card{padding:36px 24px}
  /* Page hero */
  .page-hero{padding:120px 0 60px}
  /* Marquee */
  .logo-item{padding:0 28px;font-size:0.9rem}
}

/* ── 480 px ── */
@media(max-width:480px){
  :root{--section-py:64px}
  /* ---- HERO: core overflow fix ---- */
  .hero{padding:96px 0 60px}
  .hero h1{font-size:clamp(2rem,9vw,2.8rem)}
  .hero-sub{font-size:0.93rem;margin-bottom:28px;max-width:100%}
  .hero-badge{margin-bottom:18px}
  /* CTA buttons: stretch full width + reduced padding = no overflow */
  .hero-ctas{flex-direction:column;align-items:stretch;gap:12px}
  .hero-ctas .btn{
    width:100%;justify-content:center;
    padding:13px 18px;font-size:0.9rem;
  }
  /* Hero stats: controlled 2-col grid */
  .hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .hstat-val{font-size:1.55rem}
  .hstat-lbl{font-size:0.78rem}
  /* CTA section */
  .cta-btns{flex-direction:column;align-items:stretch;gap:12px}
  .cta-btns .btn{width:100%;max-width:100%;justify-content:center;padding:13px 18px}
  /* Section header */
  .sec-header{margin-bottom:44px}
  .sec-header h2{font-size:clamp(1.75rem,7vw,2.3rem)}
  /* Cards */
  .svc-card{padding:26px 20px}
  .testi-card{padding:26px 20px}
  .case-card{padding:26px 20px}
  .stat-box{padding:20px 14px}
  .stat-box .val{font-size:2rem}
  /* Page hero */
  .page-hero{padding:106px 0 52px}
  .page-hero h1{font-size:clamp(1.8rem,7vw,2.5rem)}
  .page-hero p{font-size:1rem}
  /* HIW */
  .step-num{width:72px;height:72px;font-size:1.25rem}
  .hiw-step{padding:28px 14px}
  /* Why stats */
  .why-stats{grid-template-columns:1fr 1fr}
  .feat-icon{width:38px;height:38px;min-width:38px}
  .why-feat{gap:14px}
  /* Grids */
  .values-grid{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .process-steps{grid-template-columns:1fr 1fr}
  .p-step{padding:20px 12px}
  .p-step::after{display:none}
  /* Results banner */
  .results-banner{padding:28px 16px;grid-template-columns:1fr 1fr;gap:16px}
  .rb-stat{border-right:none!important;padding:10px 6px}
  .rb-stat .v{font-size:1.8rem}
  /* CS */
  .cs-featured{padding:26px 20px}
  .cs-featured h2{font-size:1.55rem}
  .cs-results{grid-template-columns:1fr}
  /* About */
  .mission-card-main{padding:28px 20px}
  .m-stat .val{font-size:1.5rem}
  /* Contact */
  .contact-form-wrap{padding:26px 20px}
  .contact-info h2{font-size:1.7rem}
  /* SVC detail */
  .svc-detail-card{padding:26px 20px}
  /* Footer */
  .footer{padding:52px 0 28px}
  .footer-top{gap:28px}
  .footer-bottom-links{gap:14px}
  /* Badge */
  .badge{font-size:0.7rem;padding:5px 12px}
  /* Marquee */
  .logo-item{padding:0 20px;font-size:0.85rem}
  /* Trusted */
  .trusted{padding:40px 0}
}

/* ── 375 px ── */
@media(max-width:375px){
  .hero h1{font-size:1.85rem}
  .hero-ctas .btn{padding:12px 14px;font-size:0.82rem}
  .sec-header h2{font-size:1.6rem}
  .page-hero h1{font-size:1.65rem}
  .stat-box .val{font-size:1.8rem}
  /* Single col for smallest screens */
  .values-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr}
  .why-stats{grid-template-columns:1fr 1fr}
  .results-banner{grid-template-columns:1fr 1fr}
  /* HIW step text */
  .hiw-step p{font-size:0.88rem}
}
