
:root {
  --navy:        #0A2540;
  --navy-deep:   #071829;
  --navy-mid:    #0d2e4e;
  --blue:        #1889E5;
  --blue-light:  #3aa0f5;
  --green:       #2ECC71;
  --green-fresh: #A2D62A;
  --white:       #FFFFFF;
  --slate:       #6B7280;
  --slate-light: #9ab0c5;
  --off-white:   #F4F7FB;
  --border-dark: rgba(255,255,255,0.09);
  --border-light:#e0e8f0;
  --glow-blue:   rgba(24,137,229,0.25);
  --glow-green:  rgba(46,204,113,0.2);
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'DM Sans', sans-serif; background:var(--navy-deep); color:var(--white); overflow-x:hidden; }

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:500;
  height:68px; display:flex; align-items:center; justify-content:space-between;
  padding:0 5%; transition:all 0.4s ease;
}
nav.scrolled {
  background:rgba(7,24,41,0.96); backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid var(--border-dark); box-shadow:0 4px 32px rgba(0,0,0,0.3);
}
.logo { display:flex; align-items:center; gap:11px; text-decoration:none; color:var(--white); flex-shrink:0; }


.logo-img {
  height: 42px;   /* match original logo size */
  width: auto;
  display: block;
}
.logo-mark svg { width:42px; height:42px; }
.logo-name { font-family:'Montserrat',sans-serif; font-size:1.5rem; font-weight:800; letter-spacing:-0.5px; white-space:nowrap; }
.logo-name em { font-style:italic; color:var(--green); }
.nav-right { display:flex; align-items:center; gap:2rem; }
.nav-links { display:flex; gap:2rem; list-style:none; align-items:center; }
.nav-links a { color:rgba(255,255,255,0.8); text-decoration:none; font-size:0.9rem; font-weight:500; white-space:nowrap; transition:color 0.2s; position:relative; padding-bottom:4px; font-family:'Montserrat',sans-serif; letter-spacing:0.01em; }
.nav-links a:hover { color:var(--white); }
.nav-links li.active a { color:var(--white); }
.nav-links li.active a::after { content:''; position:absolute; bottom:0; left:0; right:0; height:2px; background:var(--green); border-radius:2px; }
.btn-nav { background:linear-gradient(135deg, var(--green), #22a852); color:#fff; padding:0.58rem 1.8rem; border-radius:8px; font-family:'Montserrat',sans-serif; font-weight:700; font-size:0.9rem; text-decoration:none; white-space:nowrap; transition:all 0.25s; box-shadow:0 2px 18px var(--glow-green); position:relative; overflow:hidden; cursor:pointer; border:none; }
.btn-nav:hover { background:linear-gradient(135deg, #35e07c, #2ECC71); box-shadow:0 6px 28px var(--glow-green); transform:translateY(-1px); }

/* ── HERO ── */
#hero { position:relative; min-height:68vh; padding-top:68px; display:flex; flex-direction:column; overflow:hidden; }
.hero-bg-img { position:absolute; inset:0; z-index:0; }
.hero-bg-img img { width:100%; height:100%; object-fit:cover; object-position:center 40%; display:block; animation:heroZoom 10s cubic-bezier(0.25,0.46,0.45,0.94) both; }
@keyframes heroZoom { from { transform:scale(1.06); } to { transform:scale(1.0); } }
.hero-overlay { position:absolute; inset:0; z-index:1; background: linear-gradient(to right, rgba(5,15,28,0.97) 0%, rgba(10,37,64,0.92) 35%, rgba(10,37,64,0.65) 55%, rgba(10,37,64,0.20) 80%, rgba(10,37,64,0.05) 100%), linear-gradient(to bottom, rgba(5,15,28,0.55) 0%, transparent 20%, transparent 75%, rgba(5,15,28,0.85) 100%); }
.hero-grid { position:absolute; inset:0; z-index:2; pointer-events:none; background-image: linear-gradient(rgba(24,137,229,0.04) 1px, transparent 1px), linear-gradient(90deg, rgba(24,137,229,0.04) 1px, transparent 1px); background-size:60px 60px; animation:gridShift 22s linear infinite; }
@keyframes gridShift { from { background-position:0 0; } to { background-position:60px 60px; } }
.badge-18 { position:absolute; top:calc(68px + 20px); right:3%; z-index:10; background:rgba(7,22,40,0.88); border:1.5px solid rgba(46,204,113,0.5); border-radius:12px; padding:14px 18px; text-align:right; backdrop-filter:blur(16px); box-shadow:0 8px 32px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.06); animation:fadeSlideDown 0.8s 0.5s ease both; }
.badge-18 .pct { display:block; font-family:'Montserrat',sans-serif; font-size:2.2rem; font-weight:900; color:var(--green); line-height:1; text-shadow:0 0 24px rgba(46,204,113,0.4); }
.badge-18 .lbl { display:block; font-size:0.6rem; font-weight:700; color:rgba(255,255,255,0.85); margin-top:5px; letter-spacing:0.06em; text-transform:uppercase; }
@keyframes fadeSlideDown { from { opacity:0; transform:translateY(-10px); } to { opacity:1; transform:translateY(0); } }
.hero-content { position:relative; z-index:10; padding:2.5rem 6% 1.5rem; max-width:660px; flex:1; display:flex; flex-direction:column; justify-content:center; }
.hero-h1 { font-family:'Montserrat',sans-serif; font-size:clamp(1.8rem, 4.8vw, 5.2rem); font-weight:900; line-height:1.04; letter-spacing:-2px; white-space:nowrap; animation:fadeUp 0.7s 0.1s ease both; }
.hero-h1 .green { color:var(--green); display:block; font-style:italic; text-shadow:0 0 50px rgba(46,204,113,0.2); }
.hero-sub { margin-top:1rem; color:#b8cede; font-size:1.15rem; line-height:1.6; max-width:560px; font-weight:400; animation:fadeUp 0.7s 0.2s ease both; }
.hero-divider { width:560px; max-width:100%; height:2.5px; background:linear-gradient(90deg, var(--green) 0%, rgba(46,204,113,0.3) 70%, transparent 100%); margin:1.1rem 0; animation:fadeUp 0.7s 0.27s ease both; }
.hero-checks { list-style:none; display:flex; flex-direction:column; gap:0.6rem; animation:fadeUp 0.7s 0.32s ease both; }
.hero-checks li { display:flex; align-items:center; gap:12px; font-size:1.05rem; font-weight:500; color:rgba(255,255,255,0.95); }
.chk { width:26px; height:26px; min-width:26px; background:linear-gradient(135deg, var(--green), #22a852); border-radius:50%; display:flex; align-items:center; justify-content:center; color:#041a0b; font-size:0.72rem; font-weight:900; box-shadow:0 0 14px rgba(46,204,113,0.4); flex-shrink:0; }
.hero-cta-row { margin-top:1.8rem; display:flex; flex-direction:column; gap:0.75rem; animation:fadeUp 0.7s 0.42s ease both; }
.btn-cta { display:inline-flex; align-items:center; gap:10px; background:linear-gradient(135deg, var(--green), #22a852); color:#fff; padding:1.05rem 2.4rem; border-radius:10px; font-family:'Montserrat',sans-serif; font-weight:800; font-size:1.05rem; text-decoration:none; width:fit-content; box-shadow:0 4px 28px var(--glow-green), inset 0 1px 0 rgba(255,255,255,0.2); transition:all 0.25s; position:relative; overflow:hidden; cursor:pointer; border:none; }
.btn-cta::after { content:''; position:absolute; inset:0; background:linear-gradient(135deg, rgba(255,255,255,0.15), transparent 60%); pointer-events:none; }
.btn-cta:hover { transform:translateY(-3px); box-shadow:0 12px 40px var(--glow-green); background:linear-gradient(135deg, #35e07c, #2ECC71); }
.btn-cta-arrow { font-size:1.15rem; transition:transform 0.2s; }
.btn-cta:hover .btn-cta-arrow { transform:translateX(5px); }
.cta-note { color:rgba(255,255,255,0.45); font-size:0.85rem; display:flex; align-items:center; gap:8px; }
.cta-note-dot { width:4px; height:4px; border-radius:50%; background:rgba(255,255,255,0.3); }
.hero-stats-outer { position:relative; z-index:20; display:flex; align-items:flex-end; animation:fadeUp 0.8s 0.55s ease both; }
.hero-stats-spacer { width:40%; flex-shrink:0; padding:0 6% 1.8rem; display:flex; flex-direction:column; justify-content:flex-end; }
.hero-stats-box { flex:1; background:var(--off-white); border-top-left-radius:60px; padding:1.6rem 2.4rem 1.5rem; display:grid; grid-template-columns:repeat(4,1fr); gap:0.2rem; box-shadow:0 -4px 40px rgba(0,0,0,0.3); }
.hstat { display:flex; align-items:center; gap:12px; padding:0.4rem 0.8rem; border-right:1px solid #dde5ef; }
.hstat:last-child { border-right:none; }
.hstat-ico { width:38px; height:38px; flex-shrink:0; }
.hstat-val { font-family:'Montserrat',sans-serif; font-size:1.2rem; font-weight:800; color:#0A2540; line-height:1.1; }
.hstat-lbl { font-size:0.71rem; color:#7a95b0; font-weight:500; margin-top:2px; }

/* ── SHARED ── */
.section-eyebrow { display:inline-flex; align-items:center; gap:7px; font-family:'Montserrat',sans-serif; font-size:0.72rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; margin-bottom:1rem; }
.section-eyebrow::before { content:''; width:20px; height:2px; background:var(--green); border-radius:2px; }

/* ── SECTION 2 — STATS ── */
#section2 { background:var(--off-white); padding:72px 6%; color:var(--navy); position:relative; overflow:hidden; }
#section2::before { content:''; position:absolute; inset:0; background:repeating-linear-gradient(-45deg, transparent, transparent 40px, rgba(24,137,229,0.018) 40px, rgba(24,137,229,0.018) 42px); pointer-events:none; }
.s2-inner { position:relative; z-index:1; }
.s2-title { text-align:center; font-family:'Montserrat',sans-serif; font-size:clamp(1.5rem,2.6vw,2.05rem); font-weight:700; color:var(--navy); margin-bottom:0.9rem; line-height:1.25; }
.s2-title strong { font-weight:900; }
.s2-sub { text-align:center; color:var(--slate); font-size:1rem; line-height:1.75; max-width:640px; margin:0 auto 3rem; }
.stat-row { display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; }
.scard { background:var(--white); border:1px solid var(--border-light); border-radius:16px; padding:1.8rem 1.5rem; display:flex; align-items:center; gap:15px; box-shadow:0 2px 16px rgba(10,37,64,0.06); transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1); position:relative; overflow:hidden; cursor:pointer; }
.scard::before { content:''; position:absolute; bottom:0; left:0; right:0; height:3px; background:linear-gradient(90deg, var(--blue), var(--green)); transform:scaleX(0); transform-origin:left; transition:transform 0.3s ease; }
.scard:hover { transform:translateY(-6px); box-shadow:0 12px 36px rgba(10,37,64,0.12); }
.scard:hover::before { transform:scaleX(1); }
.scard-ico { width:44px; height:44px; flex-shrink:0; }
.scard-val { font-family:'Montserrat',sans-serif; font-size:1.65rem; font-weight:900; color:var(--navy); line-height:1.1; }
.scard-lbl { font-size:0.74rem; color:var(--slate); font-weight:500; margin-top:3px; }

/* ── SECTION 3 — SERVICES ── */
#section3 { background:var(--off-white); padding:72px 6%; color:var(--navy); position:relative; overflow:hidden; }
#section3::before { content:''; position:absolute; inset:0; background:repeating-linear-gradient(-45deg, transparent, transparent 40px, rgba(10,37,64,0.018) 40px, rgba(10,37,64,0.018) 42px); pointer-events:none; }
.s3-inner { position:relative; z-index:1; }
.s3-title { text-align:center; font-family:'Montserrat',sans-serif; font-size:clamp(1.5rem,2.6vw,2.05rem); font-weight:500; color:var(--navy); margin-bottom:0.9rem; line-height:1.25; }
.s3-title strong { font-weight:900; }
.s3-sub { text-align:center; color:var(--slate); font-size:1rem; line-height:1.75; max-width:640px; margin:0 auto 3rem; }
.service-row { display:grid; grid-template-columns:repeat(4,1fr); gap:1.4rem; }
.sc { border-radius:18px; overflow:hidden; border:1px solid var(--border-light); box-shadow:0 4px 20px rgba(10,37,64,0.07); position:relative; height:340px; cursor:pointer; text-decoration:none; display:block; }
.sc-img-wrap { position:absolute; inset:0; overflow:hidden; }
.sc-img-wrap img { width:100%; height:100%; object-fit:cover; display:block; transition:transform 0.45s cubic-bezier(0.25,0.46,0.45,0.94); }
.sc:hover .sc-img-wrap img { transform:scale(1.06); }
.sc-body { position:absolute; bottom:0; left:4%; right:4%; width:92%; height:66px; padding:0 1.2rem; border-radius:14px 14px 0 0; overflow:hidden; display:flex; flex-direction:column; justify-content:center; box-sizing:border-box; transition:height 0.32s ease-in-out; }
.sc:hover .sc-body { height:195px; }
.sc:nth-child(1) .sc-body { background:linear-gradient(135deg,rgba(18,137,229,0.96),rgba(10,50,110,0.97)); }
.sc:nth-child(2) .sc-body { background:linear-gradient(135deg,rgba(46,204,113,0.96),rgba(8,90,55,0.97)); }
.sc:nth-child(3) .sc-body { background:linear-gradient(135deg,rgba(46,204,113,0.96),rgba(10,37,64,0.97)); }
.sc:nth-child(4) .sc-body { background:linear-gradient(135deg,rgba(18,137,229,0.96),rgba(10,37,64,0.97)); }
.sc-title { font-family:'Montserrat',sans-serif; font-size:1rem; font-weight:700; color:#fff; flex-shrink:0; transition:transform 0.32s ease-in-out; }
.sc:hover .sc-title { transform:translateY(-4px); }
.sc-desc { font-size:0.82rem; color:rgba(255,255,255,0.9); line-height:1.6; margin-top:0.5rem; opacity:0; max-height:0; overflow:hidden; flex-shrink:0; transition:opacity 0.22s ease 0.06s, max-height 0.32s ease-in-out; }
.sc:hover .sc-desc { opacity:1; max-height:110px; }
.sc-arrow { display:block; margin-top:0.5rem; width:1.3rem; height:1.3rem; flex-shrink:0; opacity:0; transform:translateX(-8px); transition:opacity 0.22s ease 0.1s, transform 0.22s ease 0.1s; }
.sc:hover .sc-arrow { opacity:1; transform:translateX(0); }
@media (hover:none) { .sc-body { height:195px; } .sc-desc { opacity:1; max-height:110px; } .sc-arrow { opacity:1; transform:translateX(0); } }

/* ── HOW IT WORKS ── */
#how-it-works {
  background:var(--navy-deep);
  padding:88px 6%;
  position:relative; overflow:hidden;
}
#how-it-works::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 80% 60% at 50% 100%, rgba(24,137,229,0.07) 0%, transparent 70%);
  pointer-events:none;
}
.hiw-inner { position:relative; z-index:1; }
.hiw-title { text-align:center; font-family:'Montserrat',sans-serif; font-size:clamp(1.5rem,2.6vw,2.05rem); font-weight:700; color:var(--white); margin-bottom:0.9rem; line-height:1.25; }
.hiw-title strong { color:var(--green); }
.hiw-sub { text-align:center; color:var(--slate-light); font-size:1rem; line-height:1.75; max-width:580px; margin:0 auto 4rem; }
.hiw-steps {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:0; position:relative;
}
.hiw-steps::before {
  content:''; position:absolute;
  top:40px; left:calc(12.5%); right:calc(12.5%);
  height:2px;
  background:linear-gradient(90deg, var(--green), var(--blue));
  z-index:0;
}
.hiw-step {
  display:flex; flex-direction:column; align-items:center; text-align:center;
  padding:0 1.5rem; position:relative; z-index:1;
  cursor:pointer;
  transition:transform 0.25s ease;
}
.hiw-step:hover { transform:translateY(-6px); }
.step-num {
  width:80px; height:80px;
  border-radius:50%;
  background:var(--navy-mid);
  border:2px solid rgba(24,137,229,0.3);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:1.6rem;
  position:relative;
  transition:all 0.3s ease;
  box-shadow:0 0 0 6px var(--navy-deep);
}
.hiw-step:hover .step-num {
  border-color:var(--green);
  background:linear-gradient(135deg, rgba(46,204,113,0.2), rgba(24,137,229,0.2));
  box-shadow:0 0 0 6px var(--navy-deep), 0 0 30px rgba(46,204,113,0.3);
}
.step-num svg { width:32px; height:32px; }
.step-badge {
  position:absolute; top:-8px; right:-8px;
  width:24px; height:24px; border-radius:50%;
  background:linear-gradient(135deg, var(--green), #22a852);
  color:#041a0b; font-family:'Montserrat',sans-serif;
  font-size:0.7rem; font-weight:900;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 2px 8px rgba(46,204,113,0.5);
}
.step-title { font-family:'Montserrat',sans-serif; font-size:1rem; font-weight:700; color:var(--white); margin-bottom:0.6rem; }
.step-desc { font-size:0.85rem; color:var(--slate-light); line-height:1.65; }

/* ── INDUSTRIES ── */
#industries {
  background:var(--off-white);
  padding:88px 6%;
  color:var(--navy);
  position:relative; overflow:hidden;
}
#industries::before { content:''; position:absolute; inset:0; background:repeating-linear-gradient(-45deg, transparent, transparent 40px, rgba(10,37,64,0.018) 40px, rgba(10,37,64,0.018) 42px); pointer-events:none; }
.ind-inner { position:relative; z-index:1; }
.ind-title { text-align:center; font-family:'Montserrat',sans-serif; font-size:clamp(1.5rem,2.6vw,2.05rem); font-weight:700; color:var(--navy); margin-bottom:0.9rem; }
.ind-title strong { font-weight:900; }
.ind-sub { text-align:center; color:var(--slate); font-size:1rem; line-height:1.75; max-width:600px; margin:0 auto 3rem; }
.ind-grid {
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:1.1rem;
}
.ind-tile {
  background:var(--white);
  border:1px solid var(--border-light);
  border-radius:16px;
  padding:1.6rem 1.2rem;
  display:flex; flex-direction:column; align-items:flex-start;
  gap:0.9rem;
  box-shadow:0 2px 16px rgba(10,37,64,0.06);
  transition:all 0.3s cubic-bezier(0.34,1.56,0.64,1);
  position:relative; overflow:hidden;
  cursor:pointer;
}
.ind-tile::after {
  content:''; position:absolute; bottom:0; left:0; right:0;
  height:3px; border-radius:0 0 16px 16px;
  transform:scaleX(0); transform-origin:left;
  transition:transform 0.3s ease;
}
.ind-tile:nth-child(1)::after { background:var(--blue); }
.ind-tile:nth-child(2)::after { background:var(--green); }
.ind-tile:nth-child(3)::after { background:#eb6b2c; }
.ind-tile:nth-child(4)::after { background:var(--blue); }
.ind-tile:nth-child(5)::after { background:var(--green); }
.ind-tile:nth-child(6)::after { background:#9b59b6; }
.ind-tile:nth-child(7)::after { background:var(--blue); }
.ind-tile:nth-child(8)::after { background:#e74c3c; }
.ind-tile:nth-child(9)::after { background:var(--green); }
.ind-tile:nth-child(10)::after { background:#eb6b2c; }
.ind-tile:hover { transform:translateY(-7px) scale(1.02); box-shadow:0 16px 40px rgba(10,37,64,0.13); }
.ind-tile:hover::after { transform:scaleX(1); }
.ind-icon {
  width:48px; height:48px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; flex-shrink:0;
}
.ind-tile:nth-child(1) .ind-icon { background:rgba(24,137,229,0.1); }
.ind-tile:nth-child(2) .ind-icon { background:rgba(46,204,113,0.1); }
.ind-tile:nth-child(3) .ind-icon { background:rgba(235,107,44,0.1); }
.ind-tile:nth-child(4) .ind-icon { background:rgba(24,137,229,0.1); }
.ind-tile:nth-child(5) .ind-icon { background:rgba(46,204,113,0.1); }
.ind-tile:nth-child(6) .ind-icon { background:rgba(155,89,182,0.1); }
.ind-tile:nth-child(7) .ind-icon { background:rgba(24,137,229,0.1); }
.ind-tile:nth-child(8) .ind-icon { background:rgba(231,76,60,0.1); }
.ind-tile:nth-child(9) .ind-icon { background:rgba(46,204,113,0.1); }
.ind-tile:nth-child(10) .ind-icon { background:rgba(235,107,44,0.1); }
.ind-name { font-family:'Montserrat',sans-serif; font-size:0.88rem; font-weight:700; color:var(--navy); line-height:1.3; }
.ind-examples { list-style:none; display:flex; flex-direction:column; gap:4px; }
.ind-examples li { font-size:0.75rem; color:var(--slate); display:flex; align-items:flex-start; gap:6px; line-height:1.4; }
.ind-examples li::before { content:'·'; color:var(--blue); font-weight:900; flex-shrink:0; margin-top:1px; }

/* ── CTA BAND ── */
#cta-band { background:linear-gradient(135deg, var(--navy) 0%, #0d2e4e 100%); padding:80px 6%; text-align:center; position:relative; overflow:hidden; }
#cta-band::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 70% 80% at 50% 50%, rgba(24,137,229,0.1) 0%, transparent 65%); pointer-events:none; }
.cta-ring { position:absolute; border-radius:50%; border:1px solid rgba(24,137,229,0.12); top:50%; left:50%; transform:translate(-50%,-50%); animation:ringExpand 4s ease-out infinite; }
.cta-ring:nth-child(2) { animation-delay:1.3s; }
.cta-ring:nth-child(3) { animation-delay:2.6s; }
@keyframes ringExpand { 0% { width:100px; height:100px; opacity:0.6; } 100% { width:700px; height:700px; opacity:0; } }
.cta-inner { position:relative; z-index:1; max-width:620px; margin:0 auto; }
.cta-title { font-family:'Montserrat',sans-serif; font-size:clamp(1.8rem,3vw,2.8rem); font-weight:900; line-height:1.1; margin-bottom:1rem; }
.cta-title span { color:var(--green); }
.cta-sub { color:var(--slate-light); font-size:1rem; line-height:1.7; margin-bottom:2.4rem; }
.cta-buttons { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }
.btn-cta-white { background:var(--white); color:var(--navy); padding:1rem 2.2rem; border-radius:10px; font-family:'Montserrat',sans-serif; font-weight:700; font-size:0.97rem; text-decoration:none; display:inline-flex; align-items:center; gap:8px; transition:all 0.25s; box-shadow:0 4px 20px rgba(0,0,0,0.2); cursor:pointer; border:none; }
.btn-cta-white:hover { transform:translateY(-3px); box-shadow:0 10px 32px rgba(0,0,0,0.3); }
.btn-outline { border:2px solid rgba(255,255,255,0.25); color:var(--white); padding:1rem 2.2rem; border-radius:10px; font-family:'Montserrat',sans-serif; font-weight:600; font-size:0.97rem; text-decoration:none; display:inline-flex; align-items:center; gap:8px; transition:all 0.25s; backdrop-filter:blur(8px); background:rgba(255,255,255,0.05); cursor:pointer; border:2px solid rgba(255,255,255,0.25); }
.btn-outline:hover { border-color:rgba(255,255,255,0.5); background:rgba(255,255,255,0.1); transform:translateY(-2px); }

/* ── FOOTER ── */
footer { background:var(--navy-deep); border-top:1px solid var(--border-dark); padding:24px 6%; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem; }
.footer-right { display:flex; align-items:center; gap:2rem; }
.fc { display:flex; align-items:center; gap:8px; color:var(--slate); font-size:0.85rem; }
.fc a { color:rgba(255,255,255,0.8); text-decoration:none; transition:color 0.2s; }
.fc a:hover { color:var(--green); }
.soc { display:flex; gap:8px; }
.sb { width:34px; height:34px; background:rgba(255,255,255,0.05); border:1px solid var(--border-dark); border-radius:8px; display:flex; align-items:center; justify-content:center; color:var(--slate); font-size:0.75rem; font-weight:700; text-decoration:none; transition:all 0.2s; }
.sb:hover { border-color:rgba(24,137,229,0.5); color:var(--blue); background:rgba(24,137,229,0.1); }

/* ── BOOKING MODAL ── */
.modal-overlay {
  position:fixed; inset:0; z-index:900;
  background:rgba(5,12,24,0.85);
  backdrop-filter:blur(12px);
  display:flex; align-items:center; justify-content:center;
  padding:1.5rem;
  opacity:0; pointer-events:none;
  transition:opacity 0.3s ease;
}
.modal-overlay.open { opacity:1; pointer-events:all; }
.modal {
  background:var(--white);
  border-radius:24px;
  width:100%; max-width:580px;
  max-height:90vh; overflow-y:auto;
  position:relative;
  transform:translateY(30px) scale(0.97);
  transition:transform 0.3s cubic-bezier(0.34,1.56,0.64,1);
  box-shadow:0 40px 80px rgba(0,0,0,0.5);
}
.modal-overlay.open .modal { transform:translateY(0) scale(1); }
.modal-header {
  padding:2rem 2rem 1.2rem;
  border-bottom:1px solid var(--border-light);
  position:relative;
}
.modal-header h2 { font-family:'Montserrat',sans-serif; font-size:1.4rem; font-weight:800; color:var(--navy); margin-bottom:0.3rem; }
.modal-header p { color:var(--slate); font-size:0.9rem; }
.modal-close {
  position:absolute; top:1.4rem; right:1.4rem;
  width:36px; height:36px; border-radius:50%;
  background:var(--off-white); border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem; color:var(--slate);
  transition:all 0.2s;
}
.modal-close:hover { background:#e0e8f0; color:var(--navy); transform:rotate(90deg); }
.modal-body { padding:1.8rem 2rem 2rem; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; }
.form-field { display:flex; flex-direction:column; gap:0.45rem; }
.form-field.full { grid-column:1/-1; }
.form-field label { font-family:'Montserrat',sans-serif; font-size:0.75rem; font-weight:700; color:var(--navy); letter-spacing:0.04em; text-transform:uppercase; }
.form-field input,
.form-field select,
.form-field textarea {
  border:1.5px solid var(--border-light);
  border-radius:10px;
  padding:0.75rem 1rem;
  font-family:'DM Sans',sans-serif;
  font-size:0.95rem;
  color:var(--navy);
  background:var(--off-white);
  transition:border-color 0.2s, box-shadow 0.2s;
  outline:none;
  width:100%;
  appearance:none;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(24,137,229,0.12);
  background:#fff;
}
.form-field textarea { resize:vertical; min-height:90px; }
.form-field select { background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 0.9rem center; padding-right:2.5rem; cursor:pointer; }
.form-notice { background:rgba(24,137,229,0.07); border:1px solid rgba(24,137,229,0.2); border-radius:10px; padding:0.9rem 1.1rem; margin-bottom:1.4rem; display:flex; align-items:flex-start; gap:10px; }
.form-notice svg { flex-shrink:0; margin-top:2px; }
.form-notice p { font-size:0.82rem; color:var(--navy); line-height:1.55; }
.form-notice strong { color:var(--blue); }
.btn-submit {
  width:100%; padding:1.1rem;
  background:linear-gradient(135deg, var(--green), #22a852);
  color:#fff; border:none; border-radius:12px;
  font-family:'Montserrat',sans-serif; font-weight:800; font-size:1.05rem;
  cursor:pointer; margin-top:1.4rem;
  transition:all 0.25s;
  box-shadow:0 4px 20px var(--glow-green);
  display:flex; align-items:center; justify-content:center; gap:10px;
}
.btn-submit:hover { transform:translateY(-2px); box-shadow:0 8px 32px var(--glow-green); background:linear-gradient(135deg, #35e07c, #2ECC71); }
.form-success {
  display:none; flex-direction:column; align-items:center;
  text-align:center; padding:3rem 2rem;
  gap:1rem;
}
.form-success.show { display:flex; }
.form-form.hide { display:none; }
.success-icon { width:72px; height:72px; border-radius:50%; background:linear-gradient(135deg, var(--green), #22a852); display:flex; align-items:center; justify-content:center; box-shadow:0 0 0 12px rgba(46,204,113,0.12); }
.success-icon svg { width:36px; height:36px; }
.form-success h3 { font-family:'Montserrat',sans-serif; font-size:1.4rem; font-weight:800; color:var(--navy); }
.form-success p { color:var(--slate); font-size:0.95rem; line-height:1.6; max-width:360px; }

/* ── REVEAL ── */
.reveal { opacity:0; transform:translateY(30px); transition:opacity 0.7s ease, transform 0.7s cubic-bezier(0.25,0.46,0.45,0.94); }
.reveal.visible { opacity:1; transform:translateY(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; }
@keyframes fadeUp { from { opacity:0; transform:translateY(22px); } to { opacity:1; transform:translateY(0); } }

/* ── RESPONSIVE ── */
@media(max-width:1100px) { .ind-grid { grid-template-columns:repeat(3,1fr); } }
@media(max-width:960px) {
  .nav-links { display:none; }
  .hero-stats-spacer { width:32%; }
  .hero-stats-box { grid-template-columns:repeat(2,1fr); border-top-left-radius:36px; }
  .stat-row { grid-template-columns:repeat(2,1fr); }
  .service-row { grid-template-columns:repeat(2,1fr); }
  .hero-h1 { white-space:normal; }
  .hiw-steps { grid-template-columns:repeat(2,1fr); gap:2rem; }
  .hiw-steps::before { display:none; }
  .ind-grid { grid-template-columns:repeat(2,1fr); }
  .form-grid { grid-template-columns:1fr; }
}
@media(max-width:600px) {
  .hero-stats-outer { flex-direction:column; }
  .hero-stats-spacer { width:100%; padding:0 5% 1rem; }
  .hero-stats-box { border-top-left-radius:0; grid-template-columns:1fr 1fr; }
  .stat-row { grid-template-columns:1fr 1fr; }
  .service-row { grid-template-columns:1fr; }
  .badge-18 { display:none; }
  .ind-grid { grid-template-columns:1fr 1fr; }
}
