/* ═══════════════════════════════════
   VARIABLES & RESET
═══════════════════════════════════ */
:root {
  --aqua:        #00C2D4;
  --aqua-dim:    #007A88;
  --deep:        #020D18;
  --deep-2:      #040F1E;
  --deep-3:      #071525;
  --deep-4:      #0A1C30;
  --steel:       #5A8FAA;
  --steel-light: #90BBD0;
  --white:       #E8F6FF;
  --muted:       #2A5068;
  --pad-x:       clamp(20px, 5vw, 64px);
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background:var(--deep); color:var(--white);
  font-family:'DM Sans', sans-serif;
  overflow-x:hidden;
}
/* hide custom cursor on touch */
@media (hover:hover) and (pointer:fine) {
  body { cursor:none; }
  .cursor, .cursor-ring { display:block; }
}
@media (hover:none), (pointer:coarse) {
  .cursor, .cursor-ring { display:none !important; }
  #ripple-canvas { display:none !important; }
}

/* ═══════════════════════════════════
   CURSOR (desktop only)
═══════════════════════════════════ */
.cursor {
  position: fixed;
  width: 8px;
  height: 8px;
  background: var(--aqua);
  border-radius: 50%;
  pointer-events: none;
  z-index: 99999;
  transform: translate(-50%, -50%);
  transition: width .3s, height .3s;
  box-shadow: 0 0 12px var(--aqua);
  display: none;
}
.cursor-ring {
  position: fixed;
  width: 32px;
  height: 32px;
  border: 1px solid rgba(0,194,212,0.45);
  border-radius: 50%;
  pointer-events: none;
  z-index: 99998;
  transform: translate(-50%, -50%);
  transition: width .3s, height .3s, border-color .3s;
  display: none;
}
#ripple-canvas {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 0.35;
}

/* Click effect is intentionally different from the cursor */
.click-spark {
  position: fixed;
  width: 6px;
  height: 6px;
  background: var(--aqua);
  border-radius: 50%;
  pointer-events: none;
  z-index: 99997;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 10px rgba(0,194,212,.75);
  animation: clickSpark .42s ease-out forwards;
}
@keyframes clickSpark {
  0% { opacity: .95; transform: translate(-50%, -50%) scale(.7); }
  100% { opacity: 0; transform: translate(-50%, -50%) scale(2.4); }
}

/* Grain overlay */
body::after {
  content:''; position:fixed; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
  pointer-events:none; z-index:9000; opacity:.4; mix-blend-mode:overlay;
}

/* ═══════════════════════════════════
   NAVIGATION
═══════════════════════════════════ */
nav {
  position:fixed; top:0; left:0; right:0; z-index:500;
  display:flex; justify-content:space-between; align-items:center;
  padding:18px var(--pad-x);
  background:rgba(2,13,24,0.97);
  border-bottom:1px solid rgba(0,194,212,0.08);
  backdrop-filter:blur(8px);
}
.logo {
  font-family:'Orbitron', sans-serif; font-weight:900;
  font-size:clamp(15px, 3.5vw, 20px); letter-spacing:4px; color:var(--white);
  text-decoration:none;
}
.logo em { color:var(--aqua); font-style:normal; }

/* Desktop nav links */
.nav-center { display:flex; gap:28px; }
.nav-center a {
  text-decoration:none;
  font-family:'Rajdhani', sans-serif; font-weight:600;
  font-size:12px; letter-spacing:2.5px; text-transform:uppercase;
  color:var(--steel); transition:color .25s; position:relative; padding-bottom:4px;
}
.nav-center a::after {
  content:''; position:absolute; bottom:0; left:0;
  width:0; height:1px; background:var(--aqua); transition:width .3s;
}
.nav-center a:hover { color:var(--white); }
.nav-center a:hover::after { width:100%; }

.nav-cta {
  font-family:'Rajdhani', sans-serif; font-weight:700;
  font-size:11px; letter-spacing:2.5px; text-transform:uppercase;
  padding:9px 22px; border:1px solid var(--aqua);
  color:var(--aqua) !important; text-decoration:none;
  position:relative; overflow:hidden; transition:color .3s !important;
}
.nav-cta::before {
  content:''; position:absolute; inset:0;
  background:var(--aqua); transform:translateX(-101%); transition:transform .3s; z-index:-1;
}
.nav-cta:hover::before { transform:translateX(0); }
.nav-cta:hover { color:var(--deep) !important; }

/* Hamburger */
.hamburger {
  display:none; flex-direction:column; gap:5px;
  cursor:pointer; padding:4px; background:none; border:none;
  z-index:600;
}
.hamburger span {
  display:block; width:26px; height:2px;
  background:var(--aqua); transition:all .35s ease;
  transform-origin:center;
}
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Mobile menu overlay */
.mobile-menu {
  display:none; position:fixed; inset:0; z-index:490;
  background:rgba(2,13,24,0.98); backdrop-filter:blur(12px);
  flex-direction:column; align-items:center; justify-content:center;
  gap:32px;
  opacity:0; transform:translateY(-20px);
  transition:opacity .35s, transform .35s;
}
.mobile-menu.open {
  display:flex; opacity:1; transform:translateY(0);
}
.mobile-menu a {
  font-family:'Rajdhani', sans-serif; font-weight:700;
  font-size:28px; letter-spacing:4px; text-transform:uppercase;
  color:var(--steel-light); text-decoration:none;
  transition:color .25s;
  border-bottom:1px solid rgba(0,194,212,0.1);
  padding-bottom:12px; width:200px; text-align:center;
}
.mobile-menu a:hover { color:var(--aqua); }
.mobile-menu .mob-cta {
  margin-top:8px;
  background:var(--aqua); color:var(--deep) !important;
  padding:14px 40px; font-size:14px; border-bottom:none;
}

/* Hide/show based on screen */
@media (max-width:860px) {
  .nav-center, .nav-cta { display:none; }
  .hamburger { display:flex; }
}
@media (min-width:861px) {
  .hamburger, .mobile-menu { display:none !important; }
}

/* ═══════════════════════════════════
   HERO
═══════════════════════════════════ */
.hero {
  min-height:100vh; position:relative;
  display:flex; align-items:center; overflow:hidden;
  padding-top:80px;
}
.hero-depth {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 90% 70% at 65% 40%, rgba(0,100,140,0.12) 0%, transparent 60%),
    radial-gradient(ellipse 60% 60% at 20% 80%, rgba(0,30,60,0.7) 0%, transparent 70%),
    linear-gradient(180deg, #020D18 0%, #031422 40%, #020D18 100%);
}
.hero-waves { position:absolute; inset:0; overflow:hidden; }
.wave-line {
  position:absolute; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--aqua), transparent);
  animation:waveSweep 8s ease-in-out infinite;
}
.wave-line:nth-child(1){top:20%;animation-delay:0s;opacity:.08}
.wave-line:nth-child(2){top:35%;animation-delay:1.5s;opacity:.05}
.wave-line:nth-child(3){top:50%;animation-delay:3s;opacity:.09}
.wave-line:nth-child(4){top:65%;animation-delay:4.5s;opacity:.05}
.wave-line:nth-child(5){top:80%;animation-delay:6s;opacity:.07}
@keyframes waveSweep {
  0%{transform:scaleX(0) translateX(-100%);opacity:0}
  20%{opacity:inherit}
  60%{transform:scaleX(1) translateX(0%);opacity:inherit}
  100%{transform:scaleX(0) translateX(100%);opacity:0}
}
.bubbles { position:absolute; inset:0; overflow:hidden; pointer-events:none; }
.bubble {
  position:absolute; bottom:-20px; border-radius:50%;
  background:radial-gradient(circle at 35% 35%, rgba(0,194,212,0.6), rgba(0,194,212,0.1));
  animation:floatUp linear infinite;
}
@keyframes floatUp {
  0%{transform:translateY(0) scale(1);opacity:0}
  10%{opacity:1} 90%{opacity:.5}
  100%{transform:translateY(-110vh) scale(.5);opacity:0}
}

/* SVG decoration — hidden on small mobile */
.pipe-water-deco {
  position:absolute; right:40px; top:50%; transform:translateY(-50%);
  width:min(460px, 45vw); height:auto; opacity:0.18;
}
@media(max-width:640px){ .pipe-water-deco{display:none} }

.hero-inner {
  position:relative; z-index:2;
  padding:40px var(--pad-x) 120px;
  max-width:860px; width:100%;
}
.hero-eyebrow {
  display:inline-flex; align-items:center; gap:12px;
  margin-bottom:24px; animation:fadeSlideUp .8s ease both;
}
.hero-eyebrow-line { width:32px; height:1px; background:var(--aqua); flex-shrink:0; }
.hero-eyebrow-text {
  font-family:'Rajdhani', sans-serif; font-size:11px;
  letter-spacing:3px; text-transform:uppercase; color:var(--aqua); font-weight:600;
}
.hero h1 {
  font-family:'Rajdhani', sans-serif; font-weight:700;
  font-size:clamp(48px, 10vw, 124px);
  line-height:.9; letter-spacing:-1px;
  animation:fadeSlideUp .8s ease .1s both;
}
.hero h1 .line-2 {
  color:transparent; display:block;
  -webkit-text-stroke:clamp(1px,0.2vw,1.5px) rgba(0,194,212,0.5);
}
.hero h1 .line-3 { color:var(--aqua); display:block; }
.hero-desc {
  margin-top:24px; font-size:clamp(14px,2.5vw,16px); line-height:1.85;
  color:var(--steel-light); max-width:480px; font-weight:300;
  animation:fadeSlideUp .8s ease .2s both;
}
.hero-btns {
  margin-top:40px; display:flex; flex-wrap:wrap; gap:16px; align-items:center;
  animation:fadeSlideUp .8s ease .3s both;
}

/* Hero stats — horizontal on desktop, 3-col grid on mobile */
.hero-stats {
  position:absolute; bottom:0; left:0; right:0; z-index:2;
  display:grid; grid-template-columns:repeat(3,1fr);
  border-top:1px solid rgba(0,194,212,0.1);
  animation:fadeSlideUp .8s ease .5s both;
}
.hstat {
  padding:20px var(--pad-x);
  border-right:1px solid rgba(0,194,212,0.1);
}
.hstat:last-child { border-right:none; }
.hstat-num {
  font-family:'Orbitron', sans-serif;
  font-size:clamp(22px,4vw,30px); font-weight:700; color:var(--aqua); line-height:1;
}
.hstat-lbl {
  font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin-top:4px;
}

.hero-corner {
  position:absolute; bottom:0; right:0; width:clamp(80px,20vw,220px); height:clamp(80px,20vw,220px);
  border-top:1px solid rgba(0,194,212,0.12); border-left:1px solid rgba(0,194,212,0.12);
}

@keyframes fadeSlideUp {
  from{opacity:0;transform:translateY(24px)}
  to{opacity:1;transform:translateY(0)}
}

/* ═══════════════════════════════════
   BUTTONS
═══════════════════════════════════ */
.btn-aqua {
  background:var(--aqua); color:var(--deep);
  padding:14px clamp(24px,4vw,40px);
  font-family:'Rajdhani', sans-serif; font-weight:700;
  font-size:13px; letter-spacing:3px; text-transform:uppercase;
  text-decoration:none; transition:all .3s; display:inline-block;
  clip-path:polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 0 100%);
}
.btn-aqua:hover { background:#1ADAEC; transform:translateY(-2px); box-shadow:0 12px 36px rgba(0,194,212,.4); }
.btn-ghost {
  color:var(--steel-light); font-family:'Rajdhani', sans-serif; font-weight:600;
  font-size:13px; letter-spacing:3px; text-transform:uppercase;
  text-decoration:none; display:inline-flex; align-items:center; gap:10px;
  transition:color .3s, gap .3s;
}
.btn-ghost:hover { color:var(--aqua); gap:18px; }
.btn-ghost .arr {
  display:inline-block; width:32px; height:1px; background:currentColor; position:relative;
}
.btn-ghost .arr::after {
  content:''; position:absolute; right:0; top:-4px;
  width:7px; height:7px;
  border-top:1px solid currentColor; border-right:1px solid currentColor; transform:rotate(45deg);
}

/* ═══════════════════════════════════
   TICKER
═══════════════════════════════════ */
.ticker {
  background:var(--aqua); padding:11px 0; overflow:hidden; white-space:nowrap; position:relative; z-index:2;
}
.ticker-track { display:inline-flex; animation:ticker 35s linear infinite; }
.ticker-item {
  display:inline-flex; align-items:center; gap:12px; padding:0 24px;
  font-family:'Rajdhani', sans-serif; font-weight:700;
  font-size:12px; letter-spacing:3px; text-transform:uppercase; color:var(--deep);
}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══════════════════════════════════
   SHARED SECTION STYLES
═══════════════════════════════════ */
.section-tag {
  font-family:'Rajdhani', sans-serif; font-size:11px; letter-spacing:4px;
  text-transform:uppercase; color:var(--aqua); margin-bottom:14px;
  display:flex; align-items:center; gap:10px;
}
.section-tag::before { content:''; width:24px; height:1px; background:var(--aqua); flex-shrink:0; }
.section-h {
  font-family:'Rajdhani', sans-serif; font-weight:700;
  font-size:clamp(32px,5vw,60px); letter-spacing:-.5px; line-height:1;
}

/* ═══════════════════════════════════
   ABOUT STRIP
═══════════════════════════════════ */
.about-strip {
  padding:80px var(--pad-x); position:relative;
  display:grid; grid-template-columns:1fr 1.2fr; gap:60px; align-items:center;
}
.about-strip::after {
  content:''; position:absolute; bottom:0; left:var(--pad-x); right:var(--pad-x);
  height:1px; background:linear-gradient(90deg,var(--aqua-dim),transparent);
}
.about-left h2 {
  font-family:'Rajdhani', sans-serif; font-weight:700;
  font-size:clamp(32px,5vw,60px); line-height:1;
}
.about-left h2 span { color:var(--aqua); }
.about-right p { font-size:14px; color:var(--steel-light); line-height:1.9; font-weight:300; margin-bottom:20px; }
.stat-row { display:flex; margin-top:32px; border:1px solid rgba(0,194,212,0.12); }
.stat-box {
  flex:1; padding:20px 16px; border-right:1px solid rgba(0,194,212,0.12); transition:background .3s;
}
.stat-box:last-child{border-right:none}
.stat-box:hover{background:rgba(0,194,212,0.05)}
.stat-box .num {
  font-family:'Orbitron', sans-serif; font-size:clamp(20px,3.5vw,30px);
  font-weight:700; color:var(--aqua); line-height:1;
}
.stat-box .lbl { font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin-top:5px; }

@media(max-width:768px){
  .about-strip { grid-template-columns:1fr; gap:36px; padding:60px var(--pad-x); }
}

/* ═══════════════════════════════════
   SERVICES
═══════════════════════════════════ */
.services {
  padding:80px var(--pad-x); background:var(--deep-2); position:relative;
}
.services::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--aqua),transparent);
}
.services::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--aqua-dim),transparent);
}
.services-header {
  display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:48px; flex-wrap:wrap; gap:16px;
}
.svc-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:3px;
}
.svc-card {
  background:var(--deep-3); padding:40px 32px; position:relative; overflow:hidden;
  transition:transform .4s, background .4s;
}
.svc-card::before {
  content:''; position:absolute; top:0; left:0; width:0; height:3px;
  background:linear-gradient(90deg,var(--aqua),rgba(0,194,212,.3)); transition:width .5s;
}
.svc-card::after {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 80% 60% at 50% 120%,rgba(0,194,212,.06) 0%,transparent 70%);
  opacity:0; transition:opacity .4s;
}
.svc-card:hover::before{width:100%}
.svc-card:hover::after{opacity:1}
.svc-card:hover{background:var(--deep-4);transform:translateY(-4px)}
.svc-icon-wrap {
  width:56px; height:56px; border:1px solid rgba(0,194,212,.2);
  display:flex; align-items:center; justify-content:center; margin-bottom:24px;
  transition:border-color .3s, background .3s;
  clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,0 100%);
}
.svc-card:hover .svc-icon-wrap{border-color:var(--aqua);background:rgba(0,194,212,.08);box-shadow:0 0 18px rgba(0,194,212,.15)}
.svc-icon-wrap svg{color:var(--aqua)}
.svc-num {
  position:absolute; top:20px; right:24px;
  font-family:'Orbitron',sans-serif; font-size:52px; font-weight:700;
  color:rgba(0,194,212,.04); line-height:1; transition:color .3s;
}
.svc-card:hover .svc-num{color:rgba(0,194,212,.1)}
.svc-card h3 {
  font-family:'Rajdhani',sans-serif; font-size:20px; font-weight:700;
  letter-spacing:1px; text-transform:uppercase; margin-bottom:12px;
}
.svc-card p{font-size:14px;color:var(--steel);line-height:1.8;font-weight:300;margin-bottom:24px}
.svc-tags{display:flex;flex-wrap:wrap;gap:7px}
.svc-tag {
  font-family:'Rajdhani',sans-serif; font-size:10px; letter-spacing:1.5px;
  text-transform:uppercase; padding:4px 10px;
  border:1px solid rgba(0,194,212,.18); color:var(--aqua-dim); background:rgba(0,194,212,.04);
}
.svc-learn {
  margin-top:28px; display:flex; align-items:center; gap:10px;
  font-family:'Rajdhani',sans-serif; font-size:11px; letter-spacing:2px;
  text-transform:uppercase; color:var(--aqua); text-decoration:none;
  opacity:0; transform:translateY(8px); transition:opacity .3s,transform .3s,gap .3s;
}
.svc-card:hover .svc-learn{opacity:1;transform:translateY(0)}

@media(max-width:900px){ .svc-grid{grid-template-columns:1fr 1fr} }
@media(max-width:580px){ .svc-grid{grid-template-columns:1fr} }

/* ═══════════════════════════════════
   PANEL FEATURE
═══════════════════════════════════ */
.panel-feature {
  padding:80px var(--pad-x);
  display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center;
}
.panel-visual { position:relative; height:460px; }
.panel-box-main {
  position:absolute; inset:0; background:var(--deep-3);
  border:1px solid rgba(0,194,212,.12);
  display:flex; flex-direction:column; justify-content:space-between; padding:28px; overflow:hidden;
}
.panel-box-main::before {
  content:''; position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(0,194,212,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,194,212,.03) 1px,transparent 1px);
  background-size:22px 22px;
}
.panel-box-main::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:100px;
  background:linear-gradient(to top,rgba(0,80,120,.3),transparent);
}
.panel-label {
  font-family:'Orbitron',sans-serif; font-size:9px; letter-spacing:3px;
  color:var(--aqua); opacity:.7; position:relative; z-index:1;
}
.panel-rows{display:flex;flex-direction:column;gap:9px;position:relative;z-index:1}
.panel-row {
  height:7px; border-radius:2px;
  background:linear-gradient(90deg,rgba(0,194,212,.5),rgba(0,194,212,.08));
  animation:panelScan 3s ease-in-out infinite;
}
.panel-row:nth-child(2){animation-delay:.4s;width:80%}
.panel-row:nth-child(3){animation-delay:.8s;width:60%}
.panel-row:nth-child(4){animation-delay:1.2s;width:90%}
.panel-row:nth-child(5){animation-delay:1.6s;width:70%}
.panel-row:nth-child(6){animation-delay:2s;width:85%}
.panel-row:nth-child(7){animation-delay:2.4s;width:55%}
@keyframes panelScan{0%,100%{opacity:.4}50%{opacity:1;box-shadow:0 0 8px rgba(0,194,212,.4)}}
.panel-indicators{display:flex;gap:9px;position:relative;z-index:2}
.ind{width:11px;height:11px;border-radius:50%;animation:indBlink 2s ease infinite}
.ind.teal{background:var(--aqua);box-shadow:0 0 8px var(--aqua)}
.ind.blue{background:#3B82F6;box-shadow:0 0 8px #3B82F6;animation-delay:.6s}
.ind.cyan{background:#22D3EE;box-shadow:0 0 8px #22D3EE;animation-delay:1.2s}
@keyframes indBlink{0%,100%{opacity:1}50%{opacity:.25}}
.panel-corner-tl{position:absolute;top:-1px;left:-1px;width:36px;height:36px;border-top:2px solid var(--aqua);border-left:2px solid var(--aqua)}
.panel-corner-br{position:absolute;bottom:-1px;right:-1px;width:36px;height:36px;border-bottom:2px solid var(--aqua);border-right:2px solid var(--aqua)}
.panel-badge {
  position:absolute; top:20px; right:-18px;
  background:var(--aqua); color:var(--deep);
  font-family:'Rajdhani',sans-serif; font-weight:700;
  font-size:10px; letter-spacing:2px; text-transform:uppercase;
  padding:7px 16px; writing-mode:vertical-rl; transform:rotate(180deg);
}
.water-drop{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);width:60px;height:60px;z-index:3}
.drop-circle{position:absolute;border-radius:50%;border:1px solid rgba(0,194,212,.3);animation:dropRipple 3s ease-out infinite}
.drop-circle:nth-child(1){width:20px;height:20px;top:20px;left:20px;animation-delay:0s}
.drop-circle:nth-child(2){width:40px;height:40px;top:10px;left:10px;animation-delay:.5s}
.drop-circle:nth-child(3){width:60px;height:60px;top:0;left:0;animation-delay:1s}
@keyframes dropRipple{0%{opacity:.8;transform:scale(.5)}100%{opacity:0;transform:scale(1.5)}}

.panel-content h2{font-family:'Rajdhani',sans-serif;font-weight:700;font-size:clamp(28px,4vw,54px);line-height:1.05}
.panel-content h2 em{color:var(--aqua);font-style:normal;display:block}
.panel-content p{margin-top:24px;font-size:14px;color:var(--steel-light);line-height:1.9;font-weight:300}
.panel-specs{margin-top:28px;display:grid;grid-template-columns:1fr 1fr;gap:2px}
.spec-item{background:var(--deep-2);padding:16px 18px;border-left:2px solid transparent;transition:border-color .3s,background .3s}
.spec-item:hover{border-left-color:var(--aqua);background:var(--deep-3)}
.spec-item .spec-val{font-family:'Orbitron',sans-serif;font-size:16px;color:var(--aqua);font-weight:700}
.spec-item .spec-key{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-top:3px}

@media(max-width:860px){
  .panel-feature{grid-template-columns:1fr;gap:48px}
  .panel-visual{height:340px}
  .panel-badge{display:none}
}
@media(max-width:480px){ .panel-visual{height:280px} }

/* ═══════════════════════════════════
   PROJECTS
═══════════════════════════════════ */
.projects{padding:80px var(--pad-x);background:var(--deep-2);position:relative}
.projects::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--aqua),transparent)}
.proj-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;flex-wrap:wrap;gap:16px}

/* Desktop: complex grid */
.proj-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-template-rows:240px 200px;
  gap:4px;
}
.proj-cell{position:relative;overflow:hidden;background:var(--deep-3)}
.proj-cell-1{grid-column:span 7}
.proj-cell-2{grid-column:span 5}
.proj-cell-3{grid-column:span 4}
.proj-cell-4{grid-column:span 4}
.proj-cell-5{grid-column:span 4}

.proj-inner{width:100%;height:100%;transition:transform .6s;display:flex;align-items:center;justify-content:center;font-size:clamp(40px,6vw,72px)}
.proj-cell:hover .proj-inner{transform:scale(1.06)}
.proj-cell::before{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(0,194,212,.07) 0%,transparent 50%);opacity:0;transition:opacity .4s}
.proj-cell:hover::before{opacity:1}
.p1{background:linear-gradient(135deg,#021428,#043050)}
.p2{background:linear-gradient(135deg,#021820,#043840)}
.p3{background:linear-gradient(135deg,#041020,#082840)}
.p4{background:linear-gradient(135deg,#021824,#042840)}
.p5{background:linear-gradient(135deg,#031020,#062038)}
.proj-always{position:absolute;bottom:0;left:0;right:0;z-index:2;padding:18px 22px;background:linear-gradient(to top,rgba(2,13,24,.95) 0%,transparent 100%)}
.proj-cat{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--aqua);margin-bottom:4px;font-family:'Rajdhani',sans-serif;font-weight:600}
.proj-name{font-family:'Rajdhani',sans-serif;font-size:clamp(14px,2vw,17px);font-weight:700}

/* Tablet: 2-col grid */
@media(max-width:900px){
  .proj-grid{
    grid-template-columns:1fr 1fr;
    grid-template-rows:repeat(3,200px);
  }
  .proj-cell-1,.proj-cell-2,.proj-cell-3,.proj-cell-4,.proj-cell-5{grid-column:span 1}
}
/* Mobile: 1-col stack */
@media(max-width:520px){
  .proj-grid{grid-template-columns:1fr;grid-template-rows:repeat(5,180px)}
}

/* ═══════════════════════════════════
   PROCESS
═══════════════════════════════════ */
.process{padding:80px var(--pad-x)}
.process-header{text-align:center;margin-bottom:56px}
.process-header .section-tag{justify-content:center}
.process-header .section-tag::before{display:none}

.process-line{
  display:grid;grid-template-columns:repeat(4,1fr);position:relative;
}
.process-line::before{
  content:'';position:absolute;top:30px;left:calc(12.5%);right:calc(12.5%);
  height:1px;background:linear-gradient(90deg,var(--aqua-dim),var(--aqua),var(--aqua-dim));
}
.proc-step{text-align:center;padding:0 16px}
.proc-num{
  width:60px;height:60px;border:1px solid var(--aqua);border-radius:50%;
  display:flex;align-items:center;justify-content:center;margin:0 auto 24px;
  font-family:'Orbitron',sans-serif;font-size:16px;font-weight:700;color:var(--aqua);
  background:var(--deep);position:relative;z-index:1;transition:background .3s,box-shadow .3s;
}
.proc-step:hover .proc-num{background:rgba(0,194,212,.1);box-shadow:0 0 24px rgba(0,194,212,.35)}
.proc-step h4{font-family:'Rajdhani',sans-serif;font-size:16px;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:8px}
.proc-step p{font-size:13px;color:var(--steel);line-height:1.7;font-weight:300}

/* Vertical on mobile */
@media(max-width:680px){
  .process-line{
    grid-template-columns:1fr 1fr;
    grid-template-rows:auto auto;
    gap:40px;
  }
  .process-line::before{display:none}
}
@media(max-width:380px){
  .process-line{grid-template-columns:1fr;gap:32px}
}

/* ═══════════════════════════════════
   CTA
═══════════════════════════════════ */
.cta-wrap{
  padding:80px var(--pad-x);background:var(--deep-2);
  position:relative;overflow:hidden;text-align:center;
}
.cta-wrap::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 70% at 50% 50%,rgba(0,194,212,.07) 0%,transparent 65%)}
.cta-ripple{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);border-radius:50%;
  border:1px solid rgba(0,194,212,.07);animation:ctaRipple 6s ease-out infinite;
}
.cta-ripple:nth-child(1){width:200px;height:200px;animation-delay:0s}
.cta-ripple:nth-child(2){width:400px;height:400px;animation-delay:1s}
.cta-ripple:nth-child(3){width:600px;height:600px;animation-delay:2s}
.cta-ripple:nth-child(4){width:800px;height:800px;animation-delay:3s}
@keyframes ctaRipple{0%{opacity:.5;transform:translate(-50%,-50%) scale(.8)}100%{opacity:0;transform:translate(-50%,-50%) scale(1.2)}}
.cta-wrap .section-tag{justify-content:center}
.cta-wrap .section-tag::before{display:none}
.cta-wrap h2{
  font-family:'Rajdhani',sans-serif;font-weight:700;
  font-size:clamp(36px,7vw,92px);letter-spacing:-1px;line-height:.95;
  position:relative;z-index:1;margin:16px 0 24px;
}
.cta-wrap h2 em{color:var(--aqua);font-style:normal}
.cta-wrap p{
  color:var(--steel);font-size:clamp(14px,2.5vw,16px);
  max-width:480px;margin:0 auto 44px;line-height:1.8;font-weight:300;position:relative;z-index:1;
}
.cta-btns{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;position:relative;z-index:1}

/* ═══════════════════════════════════
   WAVE SEPARATORS
═══════════════════════════════════ */
.wave-sep{display:block;width:100%;overflow:hidden;line-height:0}
.wave-sep svg{display:block;width:100%}

/* ═══════════════════════════════════
   FOOTER
═══════════════════════════════════ */
footer{background:#010810;padding:48px var(--pad-x);border-top:1px solid rgba(0,194,212,.1)}
.footer-top{
  display:flex;justify-content:space-between;align-items:flex-start;
  padding-bottom:40px;border-bottom:1px solid rgba(0,194,212,.06);margin-bottom:28px;
  flex-wrap:wrap;gap:40px;
}
.footer-logo{font-family:'Orbitron',sans-serif;font-size:clamp(16px,3vw,22px);font-weight:900;letter-spacing:5px}
.footer-logo em{color:var(--aqua);font-style:normal}
.footer-tagline{font-size:12px;color:var(--muted);letter-spacing:1px;margin-top:6px}
.footer-cols{display:flex;gap:clamp(24px,5vw,80px);flex-wrap:wrap}
.footer-col h5{font-family:'Rajdhani',sans-serif;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--aqua);margin-bottom:16px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col ul a{font-size:13px;color:var(--muted);text-decoration:none;transition:color .25s;letter-spacing:.5px}
.footer-col ul a:hover{color:var(--white)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer-copy{font-size:11px;color:var(--muted);letter-spacing:1px}
.footer-cert{display:flex;gap:12px;flex-wrap:wrap}
.cert-badge{font-family:'Rajdhani',sans-serif;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--aqua-dim);border:1px solid rgba(0,194,212,.15);padding:4px 10px}

@media(max-width:640px){
  .footer-top{flex-direction:column}
  .footer-bottom{flex-direction:column;align-items:flex-start}
}

/* ═══════════════════════════════════
   MR M&E CLEANUP OVERRIDES
   Safer for a real contractor website
═══════════════════════════════════ */
@media (hover:hover) and (pointer:fine) {
  html, body, a, button, .svc-card, .proj-cell, .proc-step, .work-card, .hamburger {
    cursor: none !important;
  }
  .cursor, .cursor-ring {
    display: block;
  }
}
nav { box-shadow:0 10px 30px rgba(0,0,0,.15); }
.hero h1 { max-width:980px; }
.hero-desc { max-width:640px; font-weight:400; }
.hstat-num, .stat-box .num {
  font-family:'Rajdhani', sans-serif;
  font-size:clamp(18px, 2.4vw, 28px);
  letter-spacing:1px;
  text-transform:uppercase;
}
.stat-box .num { color:var(--aqua); }
.svc-card p, .about-right p, .proc-step p, .cta-wrap p { font-weight:400; }
.svc-learn { display:none; }
.proj-inner { font-size:clamp(42px, 6vw, 78px); }
.footer-col ul a[href="#"] { cursor:default; }

@media(max-width:640px){
  .hero { min-height:92vh; }
  .hero-inner { padding-bottom:150px; }
  .hero-stats { grid-template-columns:1fr; }
  .hstat { padding:14px var(--pad-x); border-right:none; border-bottom:1px solid rgba(0,194,212,0.1); }
  .hstat:last-child { border-bottom:none; }
  .hero h1 { font-size:clamp(42px, 14vw, 64px); }
}
