/* ================================================
   ALPHABETA SOLUTIONS LTD — UPDATED STYLESHEET
   Premium Redesign: Indigo × Amber × Space Grotesk
   ================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

/* ── Variables ──────────────────────────────────────────────────────────── */
:root {
  --bg: #FAFAFA;
  --bg-alt: #F1F2F6;
  --surface: #FFFFFF;
  --text: #0D0F1A;
  --text-2: #4B5263;
  --text-3: #9299A8;
  --border: #E2E4ED;
  --nav-bg: rgba(255,255,255,0.96);

  /* Brand — Indigo + Amber */
  --green: #4F46E5;
  --green-dark: #4338CA;
  --green-glow: rgba(79,70,229,0.18);
  --green-light: rgba(79,70,229,0.07);
  --orange: #F59E0B;
  --orange-dark: #D97706;
  --orange-glow: rgba(245,158,11,0.2);
  --navy: #0B1221;
  --navy-2: #131C35;

  /* Shadows */
  --shadow-xs: 0 1px 2px rgba(13,15,26,0.05);
  --shadow-sm: 0 2px 8px rgba(13,15,26,0.07);
  --shadow-md: 0 4px 20px rgba(13,15,26,0.1);
  --shadow-lg: 0 8px 40px rgba(13,15,26,0.13);
  --shadow-xl: 0 20px 60px rgba(13,15,26,0.17);
  --shadow-indigo: 0 8px 32px rgba(79,70,229,0.25);

  --radius: 12px;
  --radius-lg: 20px;
  --radius-xl: 32px;
  --radius-full: 9999px;
  --section-py: 100px;
  --ease: cubic-bezier(0.4,0,0.2,1);
  --t: 0.3s cubic-bezier(0.4,0,0.2,1);
}

[data-theme="dark"] {
  --bg: #070B15;
  --bg-alt: #0C1220;
  --surface: #101828;
  --text: #EDF0F8;
  --text-2: #8B95AE;
  --text-3: #55627A;
  --border: #1C2A42;
  --nav-bg: rgba(7,11,21,0.97);
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.4);
  --shadow-md: 0 4px 20px rgba(0,0,0,0.5);
  --shadow-lg: 0 8px 40px rgba(0,0,0,0.6);
}

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

/* ── Typography ─────────────────────────────────────────────────────────── */
h1,h2,h3,h4,h5,h6{
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;line-height:1.18;color:var(--text);
  letter-spacing:-0.02em;
}

.section-label{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:700;
  letter-spacing:0.18em;text-transform:uppercase;
  color:var(--green);margin-bottom:18px;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.section-label::before{
  content:'';display:block;
  width:24px;height:2px;
  background:var(--green);border-radius:2px;
}
.section-title{
  font-size:clamp(28px,3.8vw,48px);
  line-height:1.12;margin-bottom:18px;
}
.section-title span{color:var(--green);}
.section-desc{
  font-size:17px;color:var(--text-2);
  line-height:1.82;max-width:580px;
}

/* ── Container ──────────────────────────────────────────────────────────── */
.container{max-width:1240px;margin:0 auto;padding:0 28px}

/* ── Buttons ────────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 28px;border-radius:var(--radius-full);
  font-size:14.5px;font-weight:700;
  transition:all var(--t);white-space:nowrap;
  font-family:'Plus Jakarta Sans',sans-serif;
  letter-spacing:0.01em;
}
.btn-primary{
  background:var(--green);color:#fff;
  box-shadow:0 4px 18px var(--green-glow);
}
.btn-primary:hover{
  background:var(--green-dark);
  transform:translateY(-2px);
  box-shadow:0 8px 28px var(--green-glow);
}
.btn-orange{
  background:var(--orange);color:#fff;
  box-shadow:0 4px 18px var(--orange-glow);
}
.btn-orange:hover{
  background:var(--orange-dark);transform:translateY(-2px);
  box-shadow:0 8px 28px var(--orange-glow);
}
.btn-outline{
  border:2px solid var(--border);color:var(--text);
  background:transparent;
}
.btn-outline:hover{
  border-color:var(--green);color:var(--green);
  transform:translateY(-2px);
}
.btn-outline-white{
  border:2px solid rgba(255,255,255,0.3);color:#fff;
  background:transparent;
}
.btn-outline-white:hover{
  border-color:rgba(255,255,255,0.8);
  background:rgba(255,255,255,0.1);
}
.btn-lg{padding:16px 36px;font-size:15.5px}
.btn-sm{padding:9px 20px;font-size:13.5px}

/* ── Navigation ─────────────────────────────────────────────────────────── */
.navbar{
  position:fixed;top:0;left:0;right:0;
  z-index:1000;padding:20px 0;
  transition:all 0.35s var(--ease);
}
/* Default = transparent over dark hero — white text */
.navbar .logo-name{color:#fff;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:17px;letter-spacing:-0.02em}
.navbar .logo-tagline{color:rgba(255,255,255,0.5);font-size:10px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase}
.navbar .nav-link{color:rgba(255,255,255,0.82);font-size:15px;font-weight:600;padding:8px 15px;border-radius:8px;transition:all var(--t);display:flex;align-items:center;gap:4px;letter-spacing:0.01em}
.navbar .nav-link:hover,.navbar .nav-link.active{color:#fff;background:rgba(255,255,255,0.1)}
.navbar .nav-link.active{color:var(--orange)}
.navbar .theme-toggle{border-color:rgba(255,255,255,0.25);color:rgba(255,255,255,0.7)}
.navbar .theme-toggle:hover{border-color:rgba(255,255,255,0.6);color:#fff;background:rgba(255,255,255,0.1)}

/* Scrolled state */
.navbar.scrolled{
  background:var(--nav-bg);
  backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
  padding:11px 0;
  box-shadow:0 1px 0 var(--border),0 4px 24px rgba(13,15,26,0.06);
}
.navbar.scrolled .logo-name{color:var(--text)}
.navbar.scrolled .logo-tagline{color:var(--text-3)}
.navbar.scrolled .nav-link{color:var(--text-2)}
.navbar.scrolled .nav-link:hover,.navbar.scrolled .nav-link.active{color:var(--text);background:var(--bg-alt)}
.navbar.scrolled .nav-link.active{color:var(--green)}
.navbar.scrolled .theme-toggle{border-color:var(--border);color:var(--text-2)}
.navbar.scrolled .theme-toggle:hover{border-color:var(--green);color:var(--green);background:var(--green-light)}

.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}

/* Logo */
.nav-logo{display:flex;align-items:center;gap:11px;flex-shrink:0}
.logo-mark{
  width:44px;height:44px;
  background:linear-gradient(135deg,var(--green) 0%,var(--green-dark) 100%);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;font-size:18px;color:#fff;
  flex-shrink:0;position:relative;overflow:hidden;
  box-shadow:0 4px 16px var(--green-glow);
  letter-spacing:-0.04em;
}
.logo-mark::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,0.18) 0%,transparent 55%)}
.logo-text{display:flex;flex-direction:column;line-height:1.1}

/* Nav links */
.nav-links{display:flex;align-items:center;gap:2px;flex:1;justify-content:center}
.nav-item{position:relative}
.nav-link svg{width:13px;height:13px;transition:transform var(--t)}
.nav-item:hover .nav-link svg{transform:rotate(180deg)}

/* Dropdown */
.dropdown{
  position:absolute;top:calc(100% + 12px);
  left:50%;transform:translateX(-50%) translateY(10px);
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:8px;min-width:264px;
  box-shadow:var(--shadow-xl);
  opacity:0;visibility:hidden;
  transition:all var(--t);z-index:200;
}
.nav-item:hover .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 14px;border-radius:var(--radius);
  font-size:13.5px;font-weight:600;
  color:var(--text-2);transition:all var(--t);
}
.dropdown-item:hover{background:var(--bg-alt);color:var(--green)}
.dropdown-item-icon{width:36px;height:36px;background:var(--bg-alt);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;transition:background var(--t)}
.dropdown-item:hover .dropdown-item-icon{background:var(--green-light)}
.dropdown-item-title{font-weight:700;color:var(--text);font-size:13.5px}
.dropdown-item-sub{font-size:11.5px;color:var(--text-3);margin-top:1px}

/* Nav right */
.nav-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.theme-toggle{
  width:40px;height:40px;border-radius:var(--radius-full);
  border:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  transition:all var(--t);
}
.theme-toggle .sun-icon{display:none}
.theme-toggle .moon-icon{display:block}
[data-theme="dark"] .theme-toggle .sun-icon{display:block}
[data-theme="dark"] .theme-toggle .moon-icon{display:none}

.nav-cta{
  background:var(--orange) !important;
  color:#fff !important;
  padding:10px 22px;border-radius:var(--radius-full);
  font-size:14px;font-weight:700;
  transition:all var(--t);
  box-shadow:0 4px 16px var(--orange-glow);
  font-family:'Plus Jakarta Sans',sans-serif;
  letter-spacing:0.01em;
}
.nav-cta:hover{background:var(--orange-dark) !important;transform:translateY(-1px);box-shadow:0 6px 24px var(--orange-glow)}

.hamburger{display:none;flex-direction:column;gap:5px;width:34px;padding:4px}
.hamburger span{display:block;height:2px;background:#fff;border-radius:2px;transition:all var(--t)}
.navbar.scrolled .hamburger span{background:var(--text)}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile Menu */
.mobile-menu{
  display:none;position:fixed;
  top:0;left:0;right:0;bottom:0;
  background:var(--surface);z-index:999;
  padding:90px 28px 40px;overflow-y:auto;
  transform:translateX(100%);
  transition:transform 0.4s var(--ease);
}
.mobile-menu.open{transform:translateX(0)}
.mobile-nav-link{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 0;font-size:22px;
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;color:var(--text);
  border-bottom:1px solid var(--border);
  transition:color var(--t);
}
.mobile-nav-link:hover{color:var(--green)}
.mobile-sub{padding:8px 0 8px 16px;display:none}
.mobile-sub.open{display:block}
.mobile-sub-link{display:block;padding:10px 0;font-size:15px;color:var(--text-2);transition:color var(--t)}
.mobile-sub-link:hover{color:var(--green)}

/* ── Page Header ─────────────────────────────────────────────────────────── */
.page-header{
  padding:165px 0 90px;
  background:var(--navy);
  position:relative;overflow:hidden;
}
.page-header-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.025) 1px,transparent 1px);
  background-size:52px 52px;pointer-events:none;
}
.page-header::before{
  content:'';position:absolute;top:-40%;right:-5%;
  width:580px;height:580px;
  background:radial-gradient(circle,rgba(79,70,229,0.18) 0%,transparent 60%);
  pointer-events:none;
}
.page-header::after{
  content:'';position:absolute;bottom:-20%;left:6%;
  width:360px;height:360px;
  background:radial-gradient(circle,rgba(245,158,11,0.1) 0%,transparent 60%);
  pointer-events:none;
}
.page-header-content{position:relative;z-index:2}
.page-header-label{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(79,70,229,0.14);
  border:1px solid rgba(79,70,229,0.3);
  padding:7px 18px;border-radius:var(--radius-full);
  font-size:11px;font-weight:700;
  letter-spacing:0.14em;text-transform:uppercase;
  color:var(--green);margin-bottom:22px;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.page-header h1{
  font-size:clamp(38px,5.5vw,68px);
  font-weight:700;color:#fff;line-height:1.08;
  margin-bottom:20px;letter-spacing:-0.03em;
}
.page-header h1 span{color:var(--orange)}
.page-header p{
  font-size:18px;color:rgba(255,255,255,0.58);
  max-width:540px;line-height:1.78;
}
.breadcrumb{display:flex;align-items:center;gap:8px;margin-top:32px;font-size:13.5px;color:rgba(255,255,255,0.38)}
.breadcrumb a{color:rgba(255,255,255,0.55);transition:color var(--t)}
.breadcrumb a:hover{color:var(--green)}
.breadcrumb-sep{color:rgba(255,255,255,0.2)}
.breadcrumb-current{color:var(--orange);font-weight:600}

/* ── Hero ────────────────────────────────────────────────────────────────── */
.hero{
  min-height:100vh;display:flex;align-items:center;
  background:var(--navy);position:relative;overflow:hidden;
  padding:130px 0 90px;
}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.025) 1px,transparent 1px);
  background-size:64px 64px;
}
.hero-orb{position:absolute;border-radius:50%;pointer-events:none}
.hero-orb-1{top:-120px;right:8%;width:660px;height:660px;background:radial-gradient(circle,rgba(79,70,229,0.18) 0%,transparent 60%);animation:floatOrb 9s ease-in-out infinite}
.hero-orb-2{bottom:-80px;left:2%;width:440px;height:440px;background:radial-gradient(circle,rgba(245,158,11,0.1) 0%,transparent 60%);animation:floatOrb 7s ease-in-out infinite reverse}
.hero-orb-3{top:35%;left:42%;width:280px;height:280px;background:radial-gradient(circle,rgba(79,70,229,0.08) 0%,transparent 60%);animation:floatOrb 11s ease-in-out infinite 2s}
@keyframes floatOrb{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-32px) scale(1.06)}}

.hero-particles{position:absolute;inset:0}
.pt{position:absolute;width:3px;height:3px;background:var(--green);border-radius:50%;opacity:0;animation:ptFloat var(--d,8s) ease-in-out infinite var(--delay,0s)}
@keyframes ptFloat{0%{opacity:0;transform:translateY(0)}20%{opacity:0.5}80%{opacity:0.15}100%{opacity:0;transform:translateY(-70px)}}

.hero-content{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.hero-badge{
  display:inline-flex;align-items:center;gap:9px;
  background:rgba(79,70,229,0.12);
  border:1px solid rgba(79,70,229,0.3);
  padding:9px 20px;border-radius:var(--radius-full);
  font-size:12.5px;font-weight:700;letter-spacing:0.04em;
  color:var(--green);margin-bottom:32px;
  animation:fadeInDown 0.8s var(--ease) both;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.hero-badge-dot{width:7px;height:7px;background:var(--green);border-radius:50%;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.4;transform:scale(1.7)}}

.hero-title{
  font-size:clamp(38px,5.2vw,72px);
  font-weight:700;color:#fff;line-height:1.06;
  letter-spacing:-0.035em;margin-bottom:26px;
  animation:fadeInUp 0.8s var(--ease) 0.1s both;
}
.hero-title .hl{
  color:var(--orange);position:relative;display:inline-block;
}
.hero-title .hl::after{
  content:'';position:absolute;bottom:4px;left:0;right:0;
  height:3px;background:var(--orange);border-radius:2px;opacity:0.35;
}
.hero-title .dim{color:rgba(255,255,255,0.3);-webkit-text-stroke:1.5px rgba(255,255,255,0.18)}

.hero-desc{
  font-size:17.5px;color:rgba(255,255,255,0.6);
  line-height:1.82;max-width:510px;
  margin-bottom:40px;
  animation:fadeInUp 0.8s var(--ease) 0.2s both;
}
.hero-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:56px;animation:fadeInUp 0.8s var(--ease) 0.3s both}
.hero-stats{display:flex;align-items:center;gap:36px;animation:fadeInUp 0.8s var(--ease) 0.4s both}
.hero-stat-num{font-family:'Space Grotesk',sans-serif;font-size:30px;font-weight:700;color:#fff;line-height:1;margin-bottom:4px}
.hero-stat-num span{color:var(--orange)}
.hero-stat-label{font-size:12px;color:rgba(255,255,255,0.4);letter-spacing:0.05em;font-weight:500}
.hero-stat-div{width:1px;height:38px;background:rgba(255,255,255,0.1)}

.hero-visual{position:relative;animation:fadeInRight 1s var(--ease) 0.2s both}
.hero-svg-frame{
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.07);
  border-radius:28px;padding:32px;
  position:relative;overflow:hidden;
}
.hero-svg-frame::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 30% 30%,rgba(79,70,229,0.1),transparent 50%),
    radial-gradient(circle at 70% 70%,rgba(245,158,11,0.06),transparent 50%);
  pointer-events:none;
}
.hero-float-card{
  position:absolute;
  background:rgba(255,255,255,0.07);
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:var(--radius-lg);padding:16px 20px;
  z-index:10;box-shadow:0 20px 60px rgba(0,0,0,0.35);
}
.hero-float-card-1{bottom:-18px;left:-28px;animation:floatOrb 5s ease-in-out infinite}
.hero-float-card-2{top:-14px;right:-22px;animation:floatOrb 7s ease-in-out infinite 1s}
.hfc-label{font-size:10px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-bottom:4px}
.hfc-value{font-family:'Space Grotesk',sans-serif;font-size:22px;font-weight:700;color:#fff}
.hfc-tag{font-size:12px;font-weight:700;color:var(--orange);display:flex;align-items:center;gap:5px}
.hfc-dot{width:7px;height:7px;background:var(--orange);border-radius:50%;animation:pulse 2s infinite}

/* ── Animations ──────────────────────────────────────────────────────────── */
@keyframes fadeInDown{from{opacity:0;transform:translateY(-22px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInLeft{from{opacity:0;transform:translateX(-32px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeInRight{from{opacity:0;transform:translateX(32px)}to{opacity:1;transform:translateX(0)}}
@keyframes spin{to{transform:rotate(360deg)}}

.reveal{opacity:0;transform:translateY(36px);transition:opacity 0.72s var(--ease),transform 0.72s var(--ease)}
.reveal.revealed{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-36px);transition:opacity 0.72s var(--ease),transform 0.72s var(--ease)}
.reveal-left.revealed{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(36px);transition:opacity 0.72s var(--ease),transform 0.72s var(--ease)}
.reveal-right.revealed{opacity:1;transform:translateX(0)}
.reveal-delay-1{transition-delay:0.1s}
.reveal-delay-2{transition-delay:0.2s}
.reveal-delay-3{transition-delay:0.3s}
.reveal-delay-4{transition-delay:0.4s}
.reveal-delay-5{transition-delay:0.5s}

/* ── Section Layouts ─────────────────────────────────────────────────────── */
.section{padding:var(--section-py) 0}
.section-alt{background:var(--bg-alt)}
.section-dark{background:var(--navy)}
.section-header{text-align:center;max-width:700px;margin:0 auto 68px}
.section-header .section-desc{margin:0 auto;text-align:center}
.section-header.left{text-align:left}
.section-header.left .section-desc{margin:0}
.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:88px;align-items:center}
.split-grid.reverse>*:first-child{order:2}

/* ── Service Cards ───────────────────────────────────────────────────────── */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.service-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:36px 30px;
  transition:all var(--t);
  position:relative;overflow:hidden;
}
.service-card::before{
  content:'';position:absolute;top:0;left:0;right:0;
  height:3px;
  background:linear-gradient(90deg,var(--green),var(--orange));
  opacity:0;transition:opacity var(--t);
}
.service-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-lg);border-color:transparent}
.service-card:hover::before{opacity:1}
.service-icon{
  width:56px;height:56px;
  background:var(--green-light);
  border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  font-size:26px;margin-bottom:24px;transition:all var(--t);
}
.service-card:hover .service-icon{background:var(--green);transform:scale(1.1)}
.service-card h3{font-size:19px;font-weight:700;margin-bottom:12px;transition:color var(--t)}
.service-card:hover h3{color:var(--green)}
.service-card p{font-size:15px;color:var(--text-2);line-height:1.74;margin-bottom:24px}
.service-link{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;font-weight:700;color:var(--green);transition:gap var(--t)}
.service-link:hover{gap:10px}

/* ── Features ────────────────────────────────────────────────────────────── */
.features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:36px}
.feature-item{
  display:flex;gap:14px;padding:20px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);transition:all var(--t);
}
.feature-item:hover{border-color:var(--green);box-shadow:var(--shadow-md)}
.feature-icon{
  width:42px;height:42px;background:var(--green-light);
  border-radius:10px;display:flex;align-items:center;
  justify-content:center;font-size:20px;flex-shrink:0;
  transition:background var(--t);
}
.feature-item:hover .feature-icon{background:var(--green)}
.feature-content h4{font-size:15px;font-weight:700;margin-bottom:4px}
.feature-content p{font-size:13.5px;color:var(--text-2);line-height:1.64}

/* ── CTA Section ─────────────────────────────────────────────────────────── */
.cta-section{padding:var(--section-py) 0;background:var(--navy);position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;top:-40%;left:-8%;width:520px;height:520px;background:radial-gradient(circle,rgba(79,70,229,0.15) 0%,transparent 60%);pointer-events:none}
.cta-section::after{content:'';position:absolute;bottom:-25%;right:0;width:360px;height:360px;background:radial-gradient(circle,rgba(245,158,11,0.12) 0%,transparent 60%);pointer-events:none}
.cta-inner{position:relative;z-index:2;text-align:center;max-width:720px;margin:0 auto}
.cta-inner h2{font-size:clamp(28px,4vw,50px);font-weight:700;color:#fff;line-height:1.14;margin-bottom:18px;letter-spacing:-0.03em}
.cta-inner p{font-size:18px;color:rgba(255,255,255,0.58);line-height:1.78;margin-bottom:40px}
.cta-actions{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}

/* ── Partner Carousel ────────────────────────────────────────────────────── */
.partners-section{padding:80px 0;overflow:hidden}
.partners-label{
  text-align:center;font-size:11px;font-weight:700;
  letter-spacing:0.16em;text-transform:uppercase;
  color:var(--text-3);margin-bottom:44px;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.carousel-track-wrapper{overflow:hidden;position:relative}
.carousel-track-wrapper::before,.carousel-track-wrapper::after{
  content:'';position:absolute;top:0;bottom:0;
  width:160px;z-index:2;pointer-events:none;
}
.carousel-track-wrapper::before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.carousel-track-wrapper::after{right:0;background:linear-gradient(-90deg,var(--bg),transparent)}
.section-alt .carousel-track-wrapper::before{background:linear-gradient(90deg,var(--bg-alt),transparent)}
.section-alt .carousel-track-wrapper::after{background:linear-gradient(-90deg,var(--bg-alt),transparent)}

.carousel-track{display:flex;animation:scrollTrack 32s linear infinite;width:max-content}
.carousel-track:hover{animation-play-state:paused}
@keyframes scrollTrack{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* Brighter partner logos */
.partner-logo{
  padding:12px 32px;flex-shrink:0;
  display:flex;align-items:center;
  filter:grayscale(20%) opacity(0.72);
  transition:filter 0.4s var(--ease),transform 0.3s var(--ease);
}
.partner-logo:hover{filter:grayscale(0%) opacity(1);transform:scale(1.04)}
.partner-logo-inner{
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  padding:13px 24px;
  display:flex;align-items:center;gap:9px;
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;font-size:14px;
  color:var(--text);white-space:nowrap;
  transition:all 0.4s var(--ease);
  min-width:130px;justify-content:center;
  box-shadow:var(--shadow-xs);
}
.partner-logo:hover .partner-logo-inner{
  border-color:var(--green);color:var(--green);
  box-shadow:0 4px 20px var(--green-glow);
  background:var(--green-light);
}

/* ── Process Steps ───────────────────────────────────────────────────────── */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
.process-grid::before{content:'';position:absolute;top:35px;left:14%;right:14%;height:1px;background:linear-gradient(90deg,transparent,var(--border),var(--border),transparent);z-index:0}
.process-step{text-align:center;position:relative;z-index:1}
.process-num{
  width:70px;height:70px;background:var(--surface);
  border:2px solid var(--border);border-radius:var(--radius-full);
  display:flex;align-items:center;justify-content:center;
  font-family:'Space Grotesk',sans-serif;font-size:21px;font-weight:700;
  color:var(--green);margin:0 auto 22px;transition:all var(--t);
}
.process-step:hover .process-num{
  background:var(--green);color:#fff;border-color:var(--green);
  box-shadow:0 8px 24px var(--green-glow);transform:scale(1.1);
}
.process-step h4{font-size:16.5px;font-weight:700;margin-bottom:10px}
.process-step p{font-size:14px;color:var(--text-2);line-height:1.65}

/* ── Testimonial Slider ──────────────────────────────────────────────────── */
.t-slider-outer{overflow:hidden;position:relative}
.t-slider-inner{
  display:flex;
  transition:transform 0.6s cubic-bezier(0.4,0,0.2,1);
}
.t-slide{min-width:100%;padding:0 4px}
.t-slide-inner{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:22px;
}
.t-controls{
  display:flex;align-items:center;justify-content:center;
  gap:16px;margin-top:40px;
}
.t-btn{
  width:46px;height:46px;border-radius:50%;
  background:var(--surface);border:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;color:var(--text-2);
  cursor:pointer;transition:all var(--t);
}
.t-btn:hover{background:var(--green);border-color:var(--green);color:#fff;transform:scale(1.05)}
.t-dots{display:flex;gap:8px;align-items:center}
.t-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--border);cursor:pointer;
  transition:all var(--t);
}
.t-dot.active{background:var(--green);width:24px;border-radius:4px}

/* Testimonial cards */
.testimonial-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:30px;
  transition:all var(--t);height:100%;
}
.testimonial-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:transparent}
.stars{color:#F59E0B;font-size:14px;margin-bottom:14px;letter-spacing:2px}
.testimonial-text{font-size:15.5px;color:var(--text-2);line-height:1.8;margin-bottom:22px;font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:12px}
.author-avatar{
  width:46px;height:46px;border-radius:var(--radius-full);
  background:var(--green-light);
  display:flex;align-items:center;justify-content:center;
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;font-size:16px;color:var(--green);flex-shrink:0;
}
.author-name{font-weight:700;font-size:15px;margin-bottom:2px}
.author-role{font-size:12.5px;color:var(--text-3)}

/* ── Portfolio ───────────────────────────────────────────────────────────── */
.filter-tabs{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:44px;justify-content:center}
.filter-tab{
  padding:9px 22px;border-radius:var(--radius-full);
  font-size:14px;font-weight:700;color:var(--text-2);
  border:1.5px solid var(--border);background:var(--surface);
  transition:all var(--t);cursor:pointer;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.filter-tab:hover{border-color:var(--green);color:var(--green)}
.filter-tab.active{background:var(--green);border-color:var(--green);color:#fff}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.portfolio-card{
  border-radius:var(--radius-lg);overflow:hidden;
  position:relative;aspect-ratio:4/3;
  transition:all var(--t);cursor:pointer;
}
.portfolio-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-xl)}
.portfolio-bg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:64px}
.portfolio-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(11,18,33,0.97) 0%,transparent 55%);
  opacity:0;transition:opacity 0.4s var(--ease);
  display:flex;align-items:flex-end;padding:26px;
}
.portfolio-card:hover .portfolio-overlay{opacity:1}
.portfolio-cat{font-size:11px;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--orange);margin-bottom:5px}
.portfolio-title{font-size:17px;font-weight:700;color:#fff;margin-bottom:12px}
.portfolio-link{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:700;color:rgba(255,255,255,0.65);transition:color var(--t)}
.portfolio-link:hover{color:var(--orange)}

/* ── Contact ─────────────────────────────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr 1.7fr;gap:72px;align-items:start}
.contact-info h3{font-size:26px;font-weight:700;margin-bottom:14px}
.contact-info>p{color:var(--text-2);line-height:1.78;margin-bottom:36px}
.contact-detail{display:flex;align-items:flex-start;gap:14px;margin-bottom:22px}
.contact-detail-icon{
  width:46px;height:46px;background:var(--green-light);
  border-radius:var(--radius);display:flex;align-items:center;
  justify-content:center;font-size:19px;flex-shrink:0;transition:background var(--t);
}
.contact-detail:hover .contact-detail-icon{background:var(--green)}
.contact-detail-label{font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-3);margin-bottom:3px}
.contact-detail-value{font-size:15px;font-weight:600}

/* ── Forms ───────────────────────────────────────────────────────────────── */
.form-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-xl);padding:48px;
  box-shadow:var(--shadow-lg);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:13.5px;font-weight:700;color:var(--text);margin-bottom:8px}
.form-label span{color:var(--orange)}
.form-control{
  width:100%;padding:13px 17px;
  background:var(--bg);border:1.5px solid var(--border);
  border-radius:var(--radius);font-size:15px;color:var(--text);
  transition:all var(--t);outline:none;-webkit-appearance:none;
}
.form-control:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--green-light);background:var(--surface)}
.form-control::placeholder{color:var(--text-3)}
textarea.form-control{min-height:136px;resize:vertical}
select.form-control{cursor:pointer}
.form-submit{
  width:100%;padding:16px;
  background:var(--green);color:#fff;border:none;
  border-radius:var(--radius);font-size:16px;font-weight:700;
  font-family:'Space Grotesk',sans-serif;cursor:pointer;
  transition:all var(--t);display:flex;align-items:center;
  justify-content:center;gap:8px;letter-spacing:-0.01em;
}
.form-submit:hover{background:var(--green-dark);transform:translateY(-2px);box-shadow:0 8px 24px var(--green-glow)}
.form-message{padding:13px 17px;border-radius:var(--radius);font-size:15px;font-weight:600;margin-top:14px;display:none}
.form-message.success{background:rgba(79,70,229,0.08);border:1px solid rgba(79,70,229,0.3);color:var(--green-dark);display:block}
.form-message.error{background:rgba(239,68,68,0.08);border:1px solid rgba(239,68,68,0.2);color:#DC2626;display:block}

/* ── Quote form (single step) ────────────────────────────────────────────── */
.quote-panel{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-xl);padding:48px;
  max-width:820px;margin:0 auto;
}
.quote-panel h3{font-size:24px;font-weight:700;margin-bottom:6px}
.quote-panel .qs-subtitle{color:var(--text-2);margin-bottom:32px;font-size:15px}
.service-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:28px}
.svc-opt{
  padding:16px 10px;border:2px solid var(--border);
  border-radius:var(--radius);text-align:center;
  cursor:pointer;transition:all var(--t);
}
.svc-opt:hover,.svc-opt.selected{border-color:var(--green);background:var(--green-light)}
.svc-opt-icon{font-size:26px;margin-bottom:6px}
.svc-opt-name{font-size:12px;font-weight:700;color:var(--text)}

/* ── About / Values ──────────────────────────────────────────────────────── */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.value-card{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.07);
  border-radius:var(--radius-lg);padding:38px 28px;
  text-align:center;transition:all var(--t);position:relative;overflow:hidden;
}
.value-card::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:50%;height:2px;background:var(--green);opacity:0;transition:opacity var(--t)}
.value-card:hover::after{opacity:1}
.value-card:hover{transform:translateY(-6px)}
.value-icon{font-size:42px;margin-bottom:18px;display:block}
.value-card h4{font-size:19px;color:#fff;margin-bottom:12px}
.value-card p{font-size:14.5px;color:rgba(255,255,255,0.5);line-height:1.75}

/* ── CEO Section ─────────────────────────────────────────────────────────── */
.ceo-spotlight{
  background:var(--navy);
  border-radius:28px;
  padding:52px;
  position:relative;overflow:hidden;
}
.ceo-spotlight::before{
  content:'';position:absolute;top:-60px;right:-60px;
  width:320px;height:320px;
  background:radial-gradient(circle,rgba(79,70,229,0.2),transparent 60%);
  pointer-events:none;
}
.ceo-spotlight::after{
  content:'';position:absolute;bottom:-40px;left:-40px;
  width:200px;height:200px;
  background:radial-gradient(circle,rgba(245,158,11,0.12),transparent 60%);
  pointer-events:none;
}
.ceo-avatar-wrap{
  position:relative;z-index:1;
  width:180px;height:180px;
  margin:0 auto 28px;
}
.ceo-avatar-ring{
  width:180px;height:180px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--green),var(--orange));
  padding:4px;
}
.ceo-avatar-inner{
  width:100%;height:100%;border-radius:50%;
  background:var(--navy-2);
  display:flex;align-items:center;justify-content:center;
  font-size:72px;
}
.ceo-name{
  font-family:'Space Grotesk',sans-serif;
  font-size:26px;font-weight:700;color:#fff;
  text-align:center;margin-bottom:4px;
}
.ceo-title-role{
  font-size:13px;font-weight:600;color:var(--orange);
  text-align:center;letter-spacing:0.06em;text-transform:uppercase;
  margin-bottom:22px;font-family:'Plus Jakarta Sans',sans-serif;
}
.ceo-badges{
  display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:28px;
}
.ceo-badge{
  padding:5px 14px;border-radius:var(--radius-full);
  font-size:12px;font-weight:700;
  background:rgba(79,70,229,0.15);
  border:1px solid rgba(79,70,229,0.3);
  color:var(--green);
  font-family:'Plus Jakarta Sans',sans-serif;
}
.ceo-social{display:flex;gap:10px;justify-content:center}
.ceo-social a{
  width:38px;height:38px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:var(--radius);display:flex;
  align-items:center;justify-content:center;
  font-size:13px;font-weight:700;color:rgba(255,255,255,0.55);
  transition:all var(--t);
}
.ceo-social a:hover{background:var(--green);border-color:var(--green);color:#fff}

.ceo-quote{
  background:rgba(79,70,229,0.08);
  border:1px solid rgba(79,70,229,0.2);
  border-left:4px solid var(--green);
  border-radius:0 var(--radius) var(--radius) 0;
  padding:18px 22px;margin:28px 0;
  font-size:16px;font-style:italic;
  color:var(--text-2);line-height:1.78;
}
.ceo-creds{display:flex;flex-direction:column;gap:14px;margin-top:28px}
.ceo-cred{
  display:flex;align-items:center;gap:12px;
  padding:14px 18px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);transition:all var(--t);
}
.ceo-cred:hover{border-color:var(--green);box-shadow:var(--shadow-sm)}
.ceo-cred-icon{
  width:36px;height:36px;
  background:var(--green-light);
  border-radius:8px;display:flex;align-items:center;
  justify-content:center;font-size:17px;flex-shrink:0;
}
.ceo-cred h5{font-size:14.5px;font-weight:700;margin-bottom:2px}
.ceo-cred p{font-size:12.5px;color:var(--text-3)}

/* Timeline */
.timeline{position:relative;padding-left:44px}
.timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--green),var(--border))}
.timeline-item{position:relative;margin-bottom:46px}
.timeline-item::before{content:'';position:absolute;left:-48px;top:7px;width:10px;height:10px;background:var(--green);border:3px solid var(--bg);border-radius:50%;box-shadow:0 0 0 3px var(--green-glow)}
.timeline-year{font-size:11.5px;font-weight:700;letter-spacing:0.1em;color:var(--green);text-transform:uppercase;margin-bottom:6px;font-family:'Plus Jakarta Sans',sans-serif}
.timeline-item h4{font-size:17.5px;font-weight:700;margin-bottom:8px}
.timeline-item p{font-size:15px;color:var(--text-2);line-height:1.74}

/* ── Service Detail ──────────────────────────────────────────────────────── */
.service-detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;margin-top:60px}
.sd-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--t)}
.sd-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-xl)}
.sd-head{padding:28px 28px 22px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:16px}
.sd-icon{width:56px;height:56px;border-radius:var(--radius);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:26px}
.sd-card h3{font-size:19.5px;font-weight:700;margin-bottom:4px}
.sd-card .sd-sub{font-size:13px;color:var(--text-2)}
.sd-body{padding:22px 28px 30px}
.sd-features{display:flex;flex-direction:column;gap:10px;margin-bottom:22px}
.sd-feature{display:flex;align-items:center;gap:10px;font-size:14.5px;color:var(--text-2)}
.sd-feature::before{content:'✓';width:22px;height:22px;background:var(--green-light);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:var(--green);flex-shrink:0;line-height:22px;text-align:center}

/* ── Visitors / Analytics (forced dark) ──────────────────────────────────── */
.vis-page{background:#070B15;color:#EDF0F8;min-height:100vh}
.vis-header{background:#0C1220;border-bottom:1px solid #1C2A42;padding:80px 0 40px}
.vis-header h1{color:#fff;font-size:28px;margin-bottom:8px;font-family:'Space Grotesk',sans-serif}
.vis-header p{color:rgba(255,255,255,0.45);font-size:15px}
.vis-header-meta{display:flex;align-items:center;gap:16px;margin-top:18px}
.live-badge{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(79,70,229,0.15);
  border:1px solid rgba(79,70,229,0.35);
  padding:6px 14px;border-radius:var(--radius-full);
  font-size:12.5px;font-weight:700;color:#818CF8;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.vis-main{padding:36px 0 80px}

/* Dark stat boxes */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:24px}
.stat-box{
  background:#101828;border:1px solid #1C2A42;
  border-radius:var(--radius-lg);padding:22px;
  transition:all var(--t);
}
.stat-box:hover{border-color:#4F46E5;box-shadow:0 0 0 1px rgba(79,70,229,0.2)}
.stat-box-label{font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:#55627A;margin-bottom:10px;font-family:'Plus Jakarta Sans',sans-serif}
.stat-box-value{font-family:'Space Grotesk',sans-serif;font-size:32px;font-weight:700;color:#818CF8;line-height:1;margin-bottom:5px}
.stat-box-sub{font-size:12.5px;color:#55627A}

.charts-row{display:grid;grid-template-columns:2fr 1fr;gap:20px;margin-bottom:20px}
.chart-box{background:#101828;border:1px solid #1C2A42;border-radius:var(--radius-lg);padding:24px}
.chart-box h3{font-size:15px;font-weight:700;margin-bottom:20px;color:#EDF0F8;font-family:'Space Grotesk',sans-serif}
.tables-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.table-box{background:#101828;border:1px solid #1C2A42;border-radius:var(--radius-lg);padding:22px}
.table-box h3{font-size:14px;font-weight:700;margin-bottom:14px;color:#EDF0F8;display:flex;align-items:center;justify-content:space-between;font-family:'Space Grotesk',sans-serif}
.table-box table{width:100%;border-collapse:collapse;font-size:13px}
.table-box th{font-size:10.5px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:#55627A;padding:0 0 9px;text-align:left;border-bottom:1px solid #1C2A42}
.table-box td{padding:9px 0;color:#8B95AE;border-bottom:1px solid #1C2A42}
.table-box tr:last-child td{border:none}

/* Badges */
.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:var(--radius-full);font-size:11px;font-weight:700}
.badge-g{background:rgba(79,70,229,0.15);color:#818CF8}
.badge-o{background:rgba(245,158,11,0.12);color:#F59E0B}
.badge-b{background:rgba(59,130,246,0.12);color:#60A5FA}
.badge-p{background:rgba(168,85,247,0.12);color:#C084FC}

/* Vis login overlay */
.vis-login-overlay{position:fixed;inset:0;background:#070B15;z-index:9999;display:flex;align-items:center;justify-content:center}
.vis-login-box{background:#101828;border:1px solid #1C2A42;border-radius:var(--radius-xl);padding:48px 44px;max-width:400px;width:90%;box-shadow:0 32px 80px rgba(0,0,0,0.6);text-align:center}
.vis-login-box h2{font-size:24px;margin-bottom:8px;color:#EDF0F8;font-family:'Space Grotesk',sans-serif}
.vis-login-box p{color:#55627A;margin-bottom:28px;font-size:15px}
.vis-err{color:#F87171;font-size:13px;margin-top:10px;display:none}

/* ── Footer ──────────────────────────────────────────────────────────────── */
footer{background:var(--navy);color:rgba(255,255,255,0.68)}
.footer-stats-bar{background:rgba(79,70,229,0.07);border-bottom:1px solid rgba(255,255,255,0.05);padding:44px 0}
.footer-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:center}
.footer-stat-num{font-family:'Space Grotesk',sans-serif;font-size:40px;font-weight:700;color:var(--orange);line-height:1;margin-bottom:7px;display:block}
.footer-stat-label{font-size:13px;color:rgba(255,255,255,0.38);letter-spacing:0.04em}
.footer-main{padding:80px 0 40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.6fr;gap:52px;margin-bottom:60px}
.footer-logo{display:flex;align-items:center;gap:11px;margin-bottom:20px}
.footer-logo-mark{width:42px;height:42px;background:linear-gradient(135deg,var(--green),var(--green-dark));border-radius:11px;display:flex;align-items:center;justify-content:center;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:18px;color:#fff;box-shadow:0 4px 14px var(--green-glow);letter-spacing:-0.04em}
.footer-brand-name{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:15.5px;color:#fff;line-height:1.1}
.footer-brand-sub{font-size:10px;color:rgba(255,255,255,0.3);letter-spacing:0.1em;text-transform:uppercase}
.footer-desc{font-size:14.5px;line-height:1.8;color:rgba(255,255,255,0.38);margin-bottom:26px;max-width:300px}
.footer-social{display:flex;gap:9px}
.footer-social-link{width:38px;height:38px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.08);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:rgba(255,255,255,0.42);transition:all var(--t)}
.footer-social-link:hover{background:var(--green);border-color:var(--green);color:#fff;transform:translateY(-2px)}
.footer-col-title{font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:700;color:#fff;margin-bottom:24px;position:relative;padding-bottom:12px}
.footer-col-title::after{content:'';position:absolute;bottom:0;left:0;width:26px;height:2.5px;background:var(--green);border-radius:2px}
.footer-links{display:flex;flex-direction:column;gap:10px}
.footer-link{font-size:14px;color:rgba(255,255,255,0.38);transition:all var(--t);display:flex;align-items:center}
.footer-link::before{content:'›';color:var(--orange);opacity:0;font-size:17px;transition:all var(--t);width:0;overflow:hidden}
.footer-link:hover{color:rgba(255,255,255,0.8);padding-left:6px}
.footer-link:hover::before{opacity:1;width:12px}
.footer-contact-item{display:flex;align-items:flex-start;gap:11px;margin-bottom:16px}
.footer-contact-icon{width:34px;height:34px;background:rgba(79,70,229,0.12);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;color:var(--green)}
.footer-contact-text{font-size:13.5px;color:rgba(255,255,255,0.38);line-height:1.5}
.footer-contact-text strong{display:block;color:rgba(255,255,255,0.6);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;margin-bottom:2px}
.newsletter-form{display:flex;gap:8px;margin-top:14px}
.newsletter-input{flex:1;padding:11px 14px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:var(--radius);font-size:13.5px;color:#fff;outline:none;transition:all var(--t)}
.newsletter-input::placeholder{color:rgba(255,255,255,0.25)}
.newsletter-input:focus{border-color:var(--green);background:rgba(255,255,255,0.08)}
.newsletter-btn{padding:11px 17px;background:var(--green);border:none;border-radius:var(--radius);color:#fff;font-size:13.5px;font-weight:700;cursor:pointer;transition:all var(--t);white-space:nowrap}
.newsletter-btn:hover{background:var(--green-dark)}
.footer-newsletter h4{font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:700;color:#fff;margin-bottom:5px}
.footer-newsletter p{font-size:13px;color:rgba(255,255,255,0.35);line-height:1.6}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.07);padding:28px 0;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-copy{font-size:13px;color:rgba(255,255,255,0.28)}
.footer-copy span{color:var(--orange)}
.footer-bottom-links{display:flex;gap:22px}
.footer-bottom-link{font-size:13px;color:rgba(255,255,255,0.28);transition:color var(--t)}
.footer-bottom-link:hover{color:var(--green)}

/* ── Scroll to top ───────────────────────────────────────────────────────── */
.scroll-top{position:fixed;bottom:30px;right:30px;width:46px;height:46px;background:var(--green);color:#fff;border:none;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;visibility:hidden;transition:all var(--t);z-index:500;box-shadow:0 4px 16px var(--green-glow);font-size:18px}
.scroll-top.visible{opacity:1;visibility:visible}
.scroll-top:hover{transform:translateY(-3px);box-shadow:0 8px 28px var(--green-glow)}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media(max-width:1100px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .t-slide-inner{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  :root{--section-py:70px}
  .hero-content{grid-template-columns:1fr;gap:48px;text-align:center}
  .hero-actions,.hero-stats{justify-content:center}
  .hero-desc{margin:0 auto 40px}
  .hero-visual{display:none}
  .split-grid{grid-template-columns:1fr;gap:44px}
  .split-grid.reverse>*:first-child{order:0}
  .contact-grid{grid-template-columns:1fr}
  .nav-links{display:none}
  .nav-right .nav-cta{display:none}
  .hamburger{display:flex}
  .mobile-menu{display:block}
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .process-grid::before{display:none}
  .footer-stats-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .service-detail-grid{grid-template-columns:1fr}
  .service-selector{grid-template-columns:repeat(2,1fr)}
  .values-grid{grid-template-columns:1fr}
  .charts-row{grid-template-columns:1fr}
  .tables-row{grid-template-columns:1fr}
  .stats-row{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  :root{--section-py:56px}
  .container{padding:0 18px}
  .services-grid,.portfolio-grid,.features-grid,.footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .form-row{grid-template-columns:1fr}
  .form-card,.quote-panel{padding:26px 20px}
  .service-selector,.process-grid{grid-template-columns:1fr}
  .hero-actions{flex-direction:column;align-items:center}
  .cta-actions{flex-direction:column;align-items:center}
  .stats-row{grid-template-columns:1fr 1fr}
  .footer-stats-grid{grid-template-columns:1fr 1fr}
  .ceo-spotlight{padding:32px 24px}
  .t-slide-inner{grid-template-columns:1fr}
}

/* ====================================================
   MOBILE RESPONSIVENESS PATCH — Full Device Coverage
   ==================================================== */

/* ── Global overflow prevention ─────────────────────── */
html { overflow-x: hidden; scroll-behavior: smooth; }
body { overflow-x: hidden; max-width: 100vw; }
* { min-width: 0; }

/* ── Quote page two-col layout (replaces inline style) ─ */
.quote-form-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 48px;
  align-items: start;
  max-width: 1000px;
  margin: 0 auto;
}
@media (max-width: 860px) {
  .quote-form-layout { grid-template-columns: 1fr; }
  .quote-form-layout .quote-sidebar { display: none; }
  .quote-panel { max-width: 100%; }
}

/* ── Home testimonials horizontal scroll carousel ──── */
.home-t-section { padding: var(--section-py) 0; overflow: hidden; }
.home-t-header  { padding: 0 28px; max-width: 1240px; margin: 0 auto 52px; }
.home-t-outer   { position: relative; overflow: hidden; }
.home-t-outer::before,
.home-t-outer::after {
  content: '';
  position: absolute; top: 0; bottom: 0; width: 120px;
  z-index: 2; pointer-events: none;
}
.home-t-outer::before { left: 0;  background: linear-gradient(90deg, var(--bg), transparent); }
.home-t-outer::after  { right: 0; background: linear-gradient(-90deg, var(--bg), transparent); }
.section-alt .home-t-outer::before { background: linear-gradient(90deg, var(--bg-alt), transparent); }
.section-alt .home-t-outer::after  { background: linear-gradient(-90deg, var(--bg-alt), transparent); }

.home-t-track {
  display: flex;
  gap: 22px;
  width: max-content;
  animation: scrollHomeT 55s linear infinite;
  padding: 8px 0 20px;
}
.home-t-track:hover { animation-play-state: paused; }

@keyframes scrollHomeT {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.home-t-card {
  min-width: 340px; max-width: 340px;
  flex-shrink: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 28px 26px;
  transition: all var(--t);
  box-shadow: var(--shadow-xs);
}
.home-t-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-lg);
  border-color: transparent;
}
@media (max-width: 640px) {
  .home-t-card { min-width: 290px; max-width: 290px; padding: 22px 20px; }
}

/* ── Page header — smaller on mobile ────────────────── */
@media (max-width: 768px) {
  .page-header { padding: 130px 0 60px; }
  .page-header h1 { font-size: clamp(32px, 8vw, 52px); }
}
@media (max-width: 480px) {
  .page-header { padding: 110px 0 48px; }
}

/* ── Hero section mobile ─────────────────────────────── */
@media (max-width: 640px) {
  .hero { padding: 110px 0 64px; min-height: auto; }
  .hero-title { font-size: clamp(32px, 9vw, 52px); letter-spacing: -0.025em; }
  .hero-desc  { font-size: 16px; }
  .hero-badge { font-size: 11px; padding: 7px 14px; }
}

/* Hero stats — prevent cutoff on small screens */
.hero-stats {
  flex-wrap: wrap;
  gap: 20px 28px;
}
@media (max-width: 420px) {
  .hero-stats { gap: 16px; justify-content: center; }
  .hero-stat-num { font-size: 22px; }
  .hero-stat-label { font-size: 11px; }
  .hero-stat-div  { display: none; }
}

/* ── Buttons — no overflow ───────────────────────────── */
.btn { white-space: normal; text-align: center; }
@media (max-width: 480px) {
  .btn-lg { padding: 14px 24px; font-size: 14.5px; }
  .hero-actions .btn { width: 100%; justify-content: center; }
}

/* ── Section headers on mobile ──────────────────────── */
@media (max-width: 480px) {
  .section-title { font-size: clamp(24px, 7vw, 36px); }
  .section-desc  { font-size: 15.5px; }
}

/* ── Services grid ───────────────────────────────────── */
@media (max-width: 480px) {
  .services-grid { grid-template-columns: 1fr; gap: 16px; }
  .service-card  { padding: 26px 22px; }
}

/* ── Features grid ───────────────────────────────────── */
@media (max-width: 480px) {
  .features-grid { grid-template-columns: 1fr; gap: 14px; }
}

/* ── Process grid ────────────────────────────────────── */
@media (max-width: 480px) {
  .process-grid { grid-template-columns: 1fr; gap: 28px; }
}

/* ── Portfolio grid ──────────────────────────────────── */
@media (max-width: 540px) {
  .portfolio-grid { grid-template-columns: 1fr; gap: 16px; }
  .filter-tabs    { gap: 6px; }
  .filter-tab     { padding: 7px 14px; font-size: 13px; }
}

/* ── Testimonial slider (portfolio page) ─────────────── */
@media (max-width: 680px) {
  .t-slide-inner { grid-template-columns: 1fr; gap: 16px; }
  .t-controls    { margin-top: 28px; }
}

/* ── Split grid ──────────────────────────────────────── */
@media (max-width: 640px) {
  .split-grid { gap: 32px; }
}

/* ── Contact grid ────────────────────────────────────── */
@media (max-width: 640px) {
  .contact-grid  { gap: 32px; }
  .form-card     { padding: 24px 18px; border-radius: var(--radius-lg); }
  .form-row      { grid-template-columns: 1fr; gap: 0; }
}

/* ── Service detail grid ─────────────────────────────── */
@media (max-width: 640px) {
  .service-detail-grid { grid-template-columns: 1fr; gap: 16px; }
  .sd-head { padding: 20px 20px 16px; }
  .sd-body { padding: 16px 20px 22px; }
}

/* ── Values grid ─────────────────────────────────────── */
@media (max-width: 640px) {
  .values-grid { grid-template-columns: 1fr; gap: 14px; }
  .value-card  { padding: 28px 22px; }
}

/* ── CEO section ─────────────────────────────────────── */
@media (max-width: 640px) {
  .ceo-spotlight { padding: 28px 20px; }
  .ceo-avatar-ring, .ceo-avatar-wrap { width: 140px; height: 140px; }
  .ceo-avatar-inner { font-size: 56px; }
  .ceo-name   { font-size: 22px; }
  .ceo-badges { gap: 6px; }
  .ceo-badge  { font-size: 11px; padding: 4px 10px; }
}

/* ── Footer stats — prevent cut off ─────────────────── */
.footer-stats-grid { align-items: center; }
.footer-stat-num   { font-size: clamp(26px, 6vw, 40px); }

@media (max-width: 480px) {
  .footer-stats-grid { grid-template-columns: 1fr 1fr; gap: 20px; }
  .footer-stat-num   { font-size: 28px; }
  .footer-grid       { grid-template-columns: 1fr; gap: 28px; }
  .footer-main       { padding: 48px 0 28px; }
  .footer-bottom     { flex-direction: column; text-align: center; gap: 12px; }
  .footer-bottom-links { flex-wrap: wrap; justify-content: center; gap: 12px; }
}

/* ── Navbar mobile ───────────────────────────────────── */
@media (max-width: 480px) {
  .navbar { padding: 16px 0; }
  .navbar.scrolled { padding: 10px 0; }
  .logo-mark  { width: 38px; height: 38px; font-size: 16px; }
  .logo-name  { font-size: 15px; }
  .logo-tagline { font-size: 9px; }
  .container  { padding: 0 16px; }
}

/* ── Mobile menu ─────────────────────────────────────── */
@media (max-width: 480px) {
  .mobile-menu { padding: 80px 20px 36px; }
  .mobile-nav-link { font-size: 20px; padding: 15px 0; }
}

/* ── CTA section ─────────────────────────────────────── */
@media (max-width: 640px) {
  .cta-inner h2 { font-size: clamp(24px, 7vw, 36px); }
  .cta-inner p  { font-size: 16px; }
  .cta-actions  { flex-direction: column; align-items: stretch; }
  .cta-actions .btn { justify-content: center; }
}

/* ── Service selector grid (quote) ──────────────────── */
@media (max-width: 480px) {
  .service-selector { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .svc-opt          { padding: 14px 8px; }
  .svc-opt-icon     { font-size: 22px; }
  .svc-opt-name     { font-size: 11px; }
}

/* ── Quote panel mobile ──────────────────────────────── */
@media (max-width: 640px) {
  .quote-panel { padding: 24px 18px; border-radius: var(--radius-lg); }
  .quote-panel h3 { font-size: 20px; }
}

/* ── Timeline ────────────────────────────────────────── */
@media (max-width: 480px) {
  .timeline         { padding-left: 28px; }
  .timeline-item::before { left: -32px; }
}

/* ── Partner carousel — no overflow ─────────────────── */
.carousel-track-wrapper { max-width: 100vw; }

/* ── Stats on dark sections ──────────────────────────── */
.dark-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
  padding: 48px 0;
}
@media (max-width: 640px) {
  .dark-stats { grid-template-columns: repeat(2, 1fr); gap: 20px; padding: 32px 0; }
}

/* ── Stats row (visitors page) ───────────────────────── */
@media (max-width: 480px) {
  .stats-row { grid-template-columns: 1fr 1fr; gap: 12px; }
  .stat-box  { padding: 16px 14px; }
  .stat-box-value { font-size: 26px; }
}

/* ── Scroll-to-top button ────────────────────────────── */
@media (max-width: 480px) {
  .scroll-top { bottom: 20px; right: 16px; width: 40px; height: 40px; font-size: 16px; }
}

/* ── Ensure images never overflow ───────────────────── */
img, svg, video, canvas, iframe { max-width: 100%; }

/* ── Table responsiveness ────────────────────────────── */
.table-box  { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.chart-box  { overflow: hidden; }
.chart-panel { overflow: hidden; }

/* ── Stats panel grid (Why Choose Us section) ───────── */
.stats-panel-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  position: relative;
  z-index: 1;
}
.stats-panel-item {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  padding: 22px 18px;
  text-align: center;
}
.stats-panel-num {
  font-family: 'Space Grotesk', sans-serif;
  font-size: clamp(26px, 5vw, 36px);
  font-weight: 700;
  line-height: 1;
  margin-bottom: 6px;
}
.stats-panel-label {
  font-size: 13px;
  color: rgba(255,255,255,0.45);
}
@media (max-width: 480px) {
  .stats-panel-grid { gap: 12px; }
  .stats-panel-item { padding: 16px 12px; }
  .stats-panel-num  { font-size: 24px; }
  .stats-panel-label { font-size: 12px; }
}

/* ── Inline-grid responsive overrides ──────────────── */

/* Portfolio stats row */
.portfolio-stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
  margin-top: 64px;
}
@media (max-width: 768px) {
  .portfolio-stats-row { grid-template-columns: repeat(2, 1fr); gap: 14px; }
}
@media (max-width: 400px) {
  .portfolio-stats-row { grid-template-columns: 1fr 1fr; gap: 10px; }
}

/* Services CCTV capabilities 2-col grid */
.cctv-caps-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 400px) {
  .cctv-caps-grid { grid-template-columns: 1fr; }
}
