/* ============================================================
   SP Engineering & Services – Main Stylesheet
   Dark Industrial Theme · Brand Cyan Accent · Modern UI/UX
   ============================================================ */

/* 1. CSS Variables */
:root {
  --bg:          #07101F;
  --bg-2:        #0D1728;
  --bg-3:        #121F35;
  --bg-card:     #0F1A2E;
  --bg-card-2:   #172035;
  --bg-footer:   #040C1A;
  --border:      rgba(255,255,255,0.07);
  --border-hover:rgba(9,172,233,0.65);
  --primary:     #09ACE9;
  --primary-d:   #0088C2;
  --primary-l:   #29C2F5;
  --primary-glow:rgba(9,172,233,0.18);
  --accent:      #FBBF24;
  --accent-2:    #34D399;
  --accent-blue: #60A5FA;
  --text:        #F1F5F9;
  --text-2:      #94A3B8;
  --text-3:      #64748B;
  --success:     #10B981;
  --error:       #EF4444;
  --ff-body:     'Inter', sans-serif;
  --ff-head:     'Space Grotesk', sans-serif;
  --radius:      12px;
  --radius-lg:   20px;
  --radius-xl:   28px;
  --shadow:      0 4px 24px rgba(0,0,0,0.4);
  --shadow-lg:   0 8px 48px rgba(0,0,0,0.5);
  --shadow-glow: 0 0 48px rgba(9,172,233,0.6);
  --transition:  0.3s cubic-bezier(0.4,0,0.2,1);
}

/* 2. Reset */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--ff-body);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
address{font-style:normal}

/* 3. Page Loader */
.page-loader{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;align-items:center;justify-content:center;transition:opacity .5s ease,visibility .5s ease}
.page-loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-gear{font-size:3rem;color:var(--primary)}

/* 4. Typography */
h1,h2,h3,h4,h5,h6{font-family:var(--ff-head);font-weight:700;line-height:1.2;color:var(--text)}
h1{font-size:clamp(2.2rem,5vw,4rem)}
h2{font-size:clamp(1.8rem,4vw,3rem)}
h3{font-size:clamp(1.2rem,2.5vw,1.6rem)}
p{color:var(--text-2);line-height:1.75}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.75rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--primary);margin-bottom:12px;text-shadow:0 0 18px rgba(9,172,233,.5)}
.eyebrow::before{content:'';display:block;width:24px;height:2px;background:var(--primary);border-radius:2px}
.section-title span{color:var(--primary);text-shadow:0 0 24px rgba(9,172,233,.6)}
.lead{font-size:1.05rem;color:var(--text-2);max-width:640px}

/* 5. Layout */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:96px 0}
.section-header{text-align:center;margin-bottom:64px}
.section-header .lead{margin:16px auto 0}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}

/* 6. Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:50px;font-weight:600;font-size:.9rem;letter-spacing:.02em;transition:var(--transition);position:relative;overflow:hidden;white-space:nowrap;border:none;cursor:pointer;font-family:var(--ff-body)}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 24px rgba(9,172,233,0.6),0 0 0 1px rgba(9,172,233,0.2)}
.btn-primary:hover{background:var(--primary-d);transform:translateY(-2px);box-shadow:0 8px 30px rgba(9,172,233,0.88)}
.btn-outline{border:2px solid var(--primary);color:var(--primary);background:transparent}
.btn-outline:hover{background:var(--primary);color:#fff;transform:translateY(-2px)}
.btn-ghost{color:var(--text);background:rgba(255,255,255,.06);border:1px solid var(--border)}
.btn-ghost:hover{background:rgba(255,255,255,.12);transform:translateY(-2px)}
.btn-whatsapp{background:#25D366;color:#fff;box-shadow:0 4px 16px rgba(37,211,102,.3)}
.btn-whatsapp:hover{background:#128C7E;transform:translateY(-2px)}
.btn-lg{padding:16px 40px;font-size:1rem}
.btn-sm{padding:8px 20px;font-size:.82rem}

/* 7. Navbar */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;transition:var(--transition);background:#fff;border-bottom:1px solid rgba(0,0,0,.08);box-shadow:0 2px 16px rgba(0,0,0,.07)}
.navbar.scrolled{background:rgba(255,255,255,.97);backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,.1);box-shadow:0 4px 24px rgba(0,0,0,.12)}
.nav-container{max-width:1200px;margin:0 auto;padding:0 24px;height:108px;display:flex;align-items:center;gap:32px}
.nav-logo{display:flex;align-items:center;gap:12px;flex-shrink:0}
.logo-img{height:84px;width:auto;object-fit:contain;border-radius:0}
.logo-fallback{display:none;align-items:center;gap:10px}
.logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--primary),var(--primary-d));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:#fff;flex-shrink:0}
.logo-text{display:flex;flex-direction:column;line-height:1.2}
.logo-primary{font-family:var(--ff-head);font-weight:800;font-size:1rem;color:#07101F}
.logo-sub{font-size:.7rem;color:var(--primary);font-weight:600;letter-spacing:.05em}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-link{padding:7px 16px;border-radius:50px;font-weight:500;font-size:.88rem;color:#334155;transition:var(--transition);position:relative}
.nav-link::after{content:'';position:absolute;bottom:-2px;left:50%;right:50%;height:2px;background:var(--primary);transition:var(--transition);box-shadow:0 0 8px var(--primary)}
.nav-link:hover,.nav-link.active{color:#07101F}
.nav-link:hover::after,.nav-link.active::after{left:16px;right:16px}
.nav-cta{display:flex;align-items:center;gap:10px}
.hamburger{display:none;flex-direction:column;gap:5px;width:40px;height:40px;align-items:center;justify-content:center;border-radius:8px;border:1px solid rgba(0,0,0,.15);transition:var(--transition)}
.hamburger:hover{border-color:var(--primary);background:rgba(9,172,233,.08)}
.hamburger span{display:block;width:20px;height:2px;background:#334155;border-radius:2px;transition:var(--transition)}
.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-nav{background:#fff;backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,.08);box-shadow:0 4px 16px rgba(0,0,0,.08);display:none;padding:12px 20px 20px}
.mobile-nav.open{display:block;animation:slideDown .3s ease}
.mobile-nav ul{display:flex;flex-direction:column;gap:2px}
.mobile-nav a{display:block;padding:11px 14px;font-weight:500;color:#334155;border-radius:8px;transition:var(--transition)}
.mobile-nav a:hover{color:#07101F;background:rgba(0,0,0,.04)}
.mobile-cta{background:var(--primary)!important;color:#fff!important;text-align:center;margin-top:8px}

/* 8. Hero */
.hero{min-height:100vh;padding:148px 0 80px;background:var(--bg);position:relative;overflow:hidden;display:flex;align-items:center}
.hero-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero-gradient{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 70% 50%,rgba(9,172,233,0.18) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 20% 80%,rgba(96,165,250,.06) 0%,transparent 50%),linear-gradient(180deg,#07101F 0%,#0A1520 100%)}
.hero-grid-lines{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:60px 60px;mask-image:linear-gradient(to bottom,transparent 0%,black 20%,black 80%,transparent 100%)}
.hero-content{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;max-width:1200px;margin:0 auto;padding:0 24px;width:100%}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(9,172,233,0.22);border:1px solid rgba(9,172,233,0.66);border-radius:50px;padding:6px 16px;font-size:.72rem;font-weight:700;letter-spacing:.1em;color:var(--primary);text-transform:uppercase;margin-bottom:20px}
.hero-title{font-size:clamp(2.4rem,5.5vw,4rem);line-height:1.1;font-weight:800;margin-bottom:20px}
.hero-title .line{display:block}
.hero-title .accent{color:var(--primary);position:relative;display:inline-block}
.hero-title .accent::after{content:'';position:absolute;bottom:4px;left:0;right:0;height:3px;background:var(--primary);border-radius:2px;opacity:.35}
.hero-desc{font-size:1rem;color:var(--text-2);margin-bottom:32px;max-width:500px}
.hero-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:44px}
.hero-stats{display:flex;gap:28px;flex-wrap:wrap;padding-top:28px;border-top:1px solid var(--border)}
.hero-stat .num{font-family:var(--ff-head);font-size:1.8rem;font-weight:800;color:var(--text);line-height:1}
.hero-stat .num span{color:var(--primary)}
.hero-stat .lbl{font-size:.72rem;color:var(--text-3);margin-top:4px;text-transform:uppercase;letter-spacing:.08em}

/* 9. Laser Alignment Scene */
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center;width:100%;padding:40px 64px}

/* ── Scene container ── */
.la-scene{position:relative;width:100%;max-width:520px;height:500px;overflow:hidden;border-radius:16px;background:linear-gradient(160deg,rgba(10,18,36,0.97) 0%,rgba(7,14,28,0.99) 100%);border:1px solid rgba(9,172,233,0.15);box-shadow:0 32px 80px rgba(0,0,0,0.7),0 0 0 1px rgba(9,172,233,0.08);will-change:transform}

/* ── Blueprint grid background ── */
.la-grid{position:absolute;inset:0;background:linear-gradient(rgba(96,165,250,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(96,165,250,.035) 1px,transparent 1px);background-size:28px 28px;border-radius:inherit}
.la-grid::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 70% at 50% 50%,rgba(9,172,233,0.07) 0%,transparent 70%)}

/* ── Background gear decorations ── */
.la-gear{position:absolute;pointer-events:none;color:var(--primary)}
.la-gear-1{top:6%;right:6%;font-size:80px;opacity:.04;animation:gearSpin 30s linear infinite}
.la-gear-2{bottom:22%;left:5%;font-size:48px;opacity:.05;animation:gearSpinR 20s linear infinite}

/* ── Machine assembly ── */
.la-machine{position:absolute;bottom:110px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:0;will-change:transform;transition:transform 1.8s cubic-bezier(0.34,1.56,0.64,1)}

/* Motor */
.la-motor{display:flex;flex-direction:column;align-items:center;gap:0}
.la-motor-body{width:100px;height:56px;background:linear-gradient(180deg,#1E3A5F 0%,#152A45 60%,#0F1E33 100%);border:1px solid rgba(9,172,233,0.4);border-radius:8px 8px 4px 4px;position:relative;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 2px 4px rgba(255,255,255,0.06),0 4px 16px rgba(0,0,0,0.5)}
.la-motor-fins{position:absolute;top:0;left:0;right:0;bottom:0;border-radius:inherit;background:repeating-linear-gradient(90deg,transparent 0,transparent 8px,rgba(9,172,233,0.06) 8px,rgba(9,172,233,0.06) 9px)}
.la-motor-label{font-size:.42rem;font-weight:800;letter-spacing:.18em;color:rgba(148,163,184,0.6);text-transform:uppercase;z-index:1}
.la-motor-shaft-end{position:absolute;right:-14px;top:50%;transform:translateY(-50%);width:14px;height:18px;background:linear-gradient(180deg,#2D4A6A,#1A3350);border:1px solid rgba(9,172,233,0.35);border-radius:0 4px 4px 0}

/* Pump */
.la-pump{display:flex;flex-direction:column;align-items:center;gap:0}
.la-pump-body{width:88px;height:56px;background:linear-gradient(180deg,#1C3550 0%,#122540 60%,#0B1A30 100%);border:1px solid rgba(9,172,233,0.3);border-radius:8px 8px 4px 4px;position:relative;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 2px 4px rgba(255,255,255,0.05),0 4px 16px rgba(0,0,0,0.5)}
.la-pump-label{font-size:.42rem;font-weight:800;letter-spacing:.18em;color:rgba(148,163,184,0.5);text-transform:uppercase;z-index:1}
.la-pump-nozzle{position:absolute;top:-16px;right:16px;width:18px;height:16px;background:linear-gradient(180deg,#1E3A5F,#0F2035);border:1px solid rgba(9,172,233,0.25);border-radius:4px 4px 0 0}
.la-pump-shaft-end{position:absolute;left:-14px;top:50%;transform:translateY(-50%);width:14px;height:18px;background:linear-gradient(180deg,#2D4A6A,#1A3350);border:1px solid rgba(9,172,233,0.35);border-radius:4px 0 0 4px}

/* Coupling */
.la-coupling-wrap{display:flex;align-items:center;height:56px}
.la-coupling-half{width:10px;height:28px;border-radius:3px;background:linear-gradient(180deg,#3B82F6,#1D4ED8);box-shadow:0 0 8px rgba(59,130,246,0.5)}
.la-coupling-gap{width:10px;height:32px;display:flex;align-items:center;justify-content:center}
.la-coupling-gap-inner{width:3px;height:100%;background:rgba(255,255,255,0.06);border-radius:2px}

/* Baseplates */
.la-baseplate{height:12px;border-radius:0 0 4px 4px;position:relative;display:flex;align-items:center;justify-content:space-evenly}
.la-baseplate-l{width:100px;background:linear-gradient(180deg,#2A3F5A,#1A2F48);border:1px solid rgba(9,172,233,0.2);border-top:none}
.la-baseplate-r{width:88px;background:linear-gradient(180deg,#243650,#162840);border:1px solid rgba(9,172,233,0.15);border-top:none}

/* Foundation bolts */
.la-bolt{width:7px;height:7px;border-radius:50%;background:#334155;border:1px solid rgba(9,172,233,0.2);position:relative;transition:background .4s ease,box-shadow .4s ease,border-color .4s ease}
.la-bolt.locked{background:#22C55E;border-color:#4ADE80;box-shadow:0 0 8px rgba(34,197,94,0.7)}

/* ── Laser beam ── */
.la-beam-wrap{position:absolute;bottom:110px;left:0;right:0;height:56px;pointer-events:none}
.la-beam{position:absolute;top:50%;left:calc(50% - 157px);width:314px;height:2px;transform-origin:left center;will-change:transform,filter,opacity;border-radius:2px}
.la-beam-glow{position:absolute;top:50%;left:calc(50% - 157px);width:314px;height:8px;transform:translateY(-50%);transform-origin:left center;border-radius:4px;filter:blur(3px);opacity:0.5;will-change:transform,filter,opacity}

/* Beam states — driven by JS class on .la-scene */
.la-scene .la-beam{background:linear-gradient(90deg,rgba(239,68,68,0.9),rgba(248,113,113,0.7));transform:translateY(-50%) rotate(0.8deg);box-shadow:0 0 6px rgba(239,68,68,0.5)}
.la-scene .la-beam-glow{background:linear-gradient(90deg,rgba(239,68,68,0.6),rgba(248,113,113,0.3));transform:translateY(-50%) rotate(0.8deg)}
.la-scene.la-aligning .la-beam{background:linear-gradient(90deg,rgba(251,191,36,0.9),rgba(252,211,77,0.7));transform:translateY(-50%) rotate(0deg);box-shadow:0 0 8px rgba(251,191,36,0.6);transition:background 1.4s ease,transform 1.4s cubic-bezier(0.34,1.56,0.64,1),box-shadow 1.4s ease}
.la-scene.la-aligning .la-beam-glow{background:linear-gradient(90deg,rgba(251,191,36,0.5),rgba(252,211,77,0.25));transform:translateY(-50%) rotate(0deg);transition:background 1.4s ease,transform 1.4s cubic-bezier(0.34,1.56,0.64,1)}
.la-scene.la-aligned .la-beam{background:linear-gradient(90deg,rgba(34,197,94,0.95) 0%,rgba(74,222,128,0.85) 40%,rgba(34,197,94,0.9) 100%);transform:translateY(-50%) rotate(0deg);box-shadow:0 0 16px rgba(34,197,94,0.8),0 0 40px rgba(34,197,94,0.35);transition:background 1s ease,box-shadow 1s ease}
.la-scene.la-aligned .la-beam-glow{background:linear-gradient(90deg,rgba(34,197,94,0.5),rgba(74,222,128,0.25),rgba(34,197,94,0.4));transform:translateY(-50%) rotate(0deg);transition:background 1s ease}
.la-scene.la-aligned .la-beam-glow{opacity:0.8}

/* Emitter disc */
.la-emitter{position:absolute;top:50%;left:calc(50% - 164px);transform:translateY(-50%);width:20px;height:20px;border-radius:50%;background:radial-gradient(circle,rgba(9,172,233,0.9),rgba(9,172,233,0.3));border:2px solid rgba(9,172,233,0.8);display:flex;align-items:center;justify-content:center;will-change:transform;transition:border-color .6s ease,box-shadow .6s ease}
.la-emitter-dot{width:6px;height:6px;border-radius:50%;background:#09ACE9;box-shadow:0 0 6px rgba(9,172,233,1)}
.la-scene.la-aligned .la-emitter{border-color:#4ADE80;box-shadow:0 0 12px rgba(34,197,94,0.8)}
.la-scene.la-aligned .la-emitter-dot{background:#4ADE80;box-shadow:0 0 8px rgba(74,222,128,1)}

/* Receiver disc */
.la-receiver{position:absolute;top:50%;left:calc(50% + 144px);transform:translateY(-50%);width:22px;height:22px;border-radius:50%;background:rgba(15,26,46,0.9);border:2px solid rgba(148,163,184,0.35);display:flex;align-items:center;justify-content:center;will-change:transform;transition:border-color .6s ease,box-shadow .6s ease}
.la-receiver-target{position:absolute;width:8px;height:8px;border-radius:50%;background:rgba(239,68,68,0.6);will-change:transform;transition:transform .8s cubic-bezier(0.34,1.56,0.64,1),background .6s ease,box-shadow .6s ease;transform:translate(3px,-2px)}
.la-scene.la-aligning .la-receiver-target{transform:translate(1px,-1px);transition:transform 1.4s cubic-bezier(0.34,1.56,0.64,1),background .8s ease,box-shadow .8s ease}
.la-scene.la-aligned .la-receiver-target{transform:translate(0,0);background:rgba(34,197,94,0.9);box-shadow:0 0 10px rgba(34,197,94,0.8)}
.la-receiver-ring{position:absolute;inset:-4px;border-radius:50%;border:1px dashed rgba(148,163,184,0.2);animation:receiverRingSpin 8s linear infinite}
.la-scene.la-aligned .la-receiver{border-color:#4ADE80;box-shadow:0 0 14px rgba(34,197,94,0.7)}
.la-scene.la-aligned .la-receiver-ring{border-color:rgba(74,222,128,0.4)}
@keyframes receiverRingSpin{to{transform:rotate(360deg)}}

/* ── Foundation base ── */
.la-foundation{position:absolute;bottom:92px;left:50%;transform:translateX(-50%);width:260px;height:18px;background:linear-gradient(180deg,#1A2F48,#0F1E30);border:1px solid rgba(9,172,233,0.15);border-radius:4px;display:flex;align-items:center;justify-content:center}
.la-found-line{width:90%;height:2px;background:repeating-linear-gradient(90deg,rgba(9,172,233,0.4) 0,rgba(9,172,233,0.4) 14px,transparent 14px,transparent 22px);border-radius:2px}

/* ── Floor strip ── */
.la-scene::after{content:'';position:absolute;bottom:0;left:0;right:0;height:92px;background:linear-gradient(180deg,transparent,rgba(7,12,24,0.95) 60%);border-top:1px solid rgba(9,172,233,0.12)}

/* ── Measurement readout panel ── */
.la-readout{position:absolute;top:18px;right:16px;width:148px;background:rgba(7,14,28,0.92);border:1px solid rgba(9,172,233,0.3);border-radius:10px;padding:10px 12px;backdrop-filter:blur(10px);box-shadow:0 8px 24px rgba(0,0,0,0.5);font-family:var(--ff-body)}
.la-readout-title{font-size:.6rem;font-weight:700;letter-spacing:.1em;color:var(--primary);text-transform:uppercase;margin-bottom:8px;display:flex;align-items:center;gap:5px;border-bottom:1px solid rgba(9,172,233,0.15);padding-bottom:6px}
.la-readout-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}
.la-readout-lbl{font-size:.62rem;color:rgba(148,163,184,0.7);font-weight:500}
.la-readout-val{font-size:.65rem;font-weight:700;color:#F87171;font-family:monospace;transition:color .4s ease}
.la-readout-val.ok{color:#4ADE80}
.la-readout-status{display:flex;align-items:center;gap:6px;margin-top:7px;padding-top:6px;border-top:1px solid rgba(9,172,233,0.12)}
.la-status-dot{font-size:.5rem;color:#F87171;animation:statusBlink 1s ease-in-out infinite}
.la-status-dot.ok{color:#4ADE80;animation:none}
#laStatusText{font-size:.6rem;font-weight:600;color:rgba(148,163,184,0.8)}
@keyframes statusBlink{0%,100%{opacity:1}50%{opacity:0.3}}

/* ── Tool icons panel ── */
.la-tools{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);display:flex;gap:10px}
.la-tool{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;background:rgba(7,14,28,0.88);border:1px solid rgba(9,172,233,0.18);border-radius:8px;min-width:46px;transition:border-color .4s ease,box-shadow .4s ease,transform .3s ease;backdrop-filter:blur(8px)}
.la-tool i{font-size:.85rem;color:rgba(148,163,184,0.5);transition:color .4s ease}
.la-tool span{font-size:.48rem;font-weight:700;letter-spacing:.08em;color:rgba(148,163,184,0.4);text-transform:uppercase;transition:color .4s ease}
.la-tool.active{border-color:rgba(9,172,233,0.8);box-shadow:0 0 14px rgba(9,172,233,0.3),inset 0 0 8px rgba(9,172,233,0.06);transform:translateY(-3px)}
.la-tool.active i{color:var(--primary)}
.la-tool.active span{color:var(--primary-l)}
.la-tool.done{border-color:rgba(34,197,94,0.6);box-shadow:0 0 10px rgba(34,197,94,0.2)}
.la-tool.done i{color:#4ADE80}
.la-tool.done span{color:#4ADE80}

/* ── Success burst ── */
.la-success-burst{position:absolute;inset:0;border-radius:inherit;opacity:0;background:radial-gradient(ellipse 60% 40% at 50% 55%,rgba(34,197,94,0.18) 0%,transparent 70%);pointer-events:none;transition:opacity .8s ease}
.la-scene.la-aligned .la-success-burst{opacity:1}

/* ── Particle shimmer (JS-driven) ── */
.la-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden;border-radius:inherit}
.la-particle{position:absolute;border-radius:50%;pointer-events:none;will-change:transform,opacity}

/* ── Coupling gap oscillation — shows rotational eccentricity ── */
.la-coupling-gap-inner{animation:laCoupOsc .45s ease-in-out infinite}
@keyframes laCoupOsc{0%,100%{height:16px;opacity:.7}50%{height:26px;opacity:1}}
.la-scene.la-aligning .la-coupling-gap-inner{animation-duration:.9s}
.la-scene.la-aligned .la-coupling-gap-inner{animation:none;height:20px;background:rgba(34,197,94,.3)!important;transition:background .5s ease}

/* ── Machine body hum — color-coded to alignment state ── */
.la-motor-body{animation:laMachHum 1.1s ease-in-out infinite}
.la-pump-body{animation:laMachHum 1.1s ease-in-out infinite .35s}
@keyframes laMachHum{0%,100%{box-shadow:inset 0 2px 4px rgba(255,255,255,.06),0 4px 16px rgba(0,0,0,.5)}50%{box-shadow:inset 0 2px 4px rgba(255,255,255,.06),0 4px 16px rgba(0,0,0,.5),0 0 12px rgba(239,68,68,.25)}}
.la-scene.la-aligning .la-motor-body,.la-scene.la-aligning .la-pump-body{animation-name:laMachHumAmb}
@keyframes laMachHumAmb{0%,100%{box-shadow:inset 0 2px 4px rgba(255,255,255,.06),0 4px 16px rgba(0,0,0,.5)}50%{box-shadow:inset 0 2px 4px rgba(255,255,255,.06),0 4px 16px rgba(0,0,0,.5),0 0 14px rgba(251,191,36,.35)}}
.la-scene.la-aligned .la-motor-body,.la-scene.la-aligned .la-pump-body{animation-name:laMachHumGrn;animation-duration:2s}
@keyframes laMachHumGrn{0%,100%{box-shadow:inset 0 2px 4px rgba(255,255,255,.06),0 4px 16px rgba(0,0,0,.5)}50%{box-shadow:inset 0 2px 4px rgba(255,255,255,.06),0 4px 16px rgba(0,0,0,.5),0 0 18px rgba(34,197,94,.4)}}

/* ── Beam scanning (pre-alignment sweep) ── */
.la-scene.la-scanning .la-beam{animation:laBeamScan .5s ease-in-out infinite}
@keyframes laBeamScan{0%,100%{transform:translateY(-50%) rotate(-2deg);opacity:.75}50%{transform:translateY(-50%) rotate(2deg);opacity:1;box-shadow:0 0 24px rgba(239,68,68,.9),0 0 48px rgba(239,68,68,.35)}}
.la-scene.la-scanning .la-beam-glow{animation:laBeamGlowScan .5s ease-in-out infinite}
@keyframes laBeamGlowScan{0%,100%{transform:translateY(-50%) rotate(-2deg);opacity:.2}50%{transform:translateY(-50%) rotate(2deg);opacity:.75}}

/* Speed up alignment transitions */
.la-scene.la-aligning .la-beam{transition:background .7s ease,transform .7s cubic-bezier(.34,1.56,.64,1),box-shadow .7s ease!important}
.la-scene.la-aligning .la-beam-glow{transition:background .7s ease,transform .7s cubic-bezier(.34,1.56,.64,1)!important}
.la-scene.la-aligned .la-beam{transition:background .5s ease,box-shadow .5s ease!important}

/* ── Second receiver ring ── */
.la-rr-1{inset:-6px}
.la-rr-2{inset:-16px;border-width:.5px;animation-direction:reverse;animation-duration:10s}
.la-scene.la-aligned .la-rr-1{border-color:rgba(74,222,128,.75);animation:laRingSnap .4s cubic-bezier(.34,1.56,.64,1) forwards}
.la-scene.la-aligned .la-rr-2{border-color:rgba(74,222,128,.3)}
@keyframes laRingSnap{0%{inset:-16px;opacity:.15}100%{inset:-6px;opacity:1}}

/* ── Bolt flash on tighten ── */
.la-bolt.flash{animation:laBoltFlash .4s ease-out forwards}
@keyframes laBoltFlash{0%{transform:scale(1)}40%{transform:scale(2);box-shadow:0 0 18px rgba(34,197,94,1)}100%{transform:scale(1)}}

/* ── Alignment quality bar ── */
.la-qual-wrap{display:flex;align-items:center;gap:5px;margin-top:6px;padding-top:5px;border-top:1px solid rgba(9,172,233,.1)}
.la-qual-bar{flex:1;height:3px;background:rgba(255,255,255,.07);border-radius:2px;overflow:hidden}
.la-qual-fill{height:100%;width:0%;background:#ef4444;border-radius:2px;transition:background .5s ease}
.la-qual-pct{font-size:.55rem;font-weight:700;font-family:monospace;color:rgba(148,163,184,.6);min-width:26px;text-align:right;transition:color .4s ease}
.la-qual-pct.ok{color:#4ADE80}

/* ── Ring bursts on success ── */
.la-rings{position:absolute;inset:0;pointer-events:none;overflow:visible;border-radius:inherit;z-index:8}
.la-ring-burst{position:absolute;border-radius:50%;border:2px solid rgba(34,197,94,.9);animation:laRingBurst 1s ease-out forwards;width:20px;height:20px;pointer-events:none;margin-left:-10px;margin-top:-10px}
@keyframes laRingBurst{0%{transform:translate(0,0) scale(.5);opacity:1}100%{transform:translate(0,0) scale(9);opacity:0}}

/* ── Floating service chips (shared, reused from old scene) ── */
.svc-chips{position:absolute;inset:0;pointer-events:none;z-index:12}
.svc-chip{position:absolute;display:flex;align-items:center;gap:9px;padding:9px 14px;background:rgba(7,16,31,.92);border:1px solid rgba(9,172,233,0.88);border-radius:50px;backdrop-filter:blur(14px);box-shadow:0 4px 24px rgba(0,0,0,.5),0 0 0 1px rgba(9,172,233,0.18);pointer-events:auto;white-space:nowrap;cursor:default;will-change:transform}
.svc-chip i{font-size:.78rem;color:var(--primary);flex-shrink:0}
.svc-chip span{font-size:.68rem;font-weight:700;color:var(--text);letter-spacing:.03em}
.svc-chip-1{top:13%;left:0;animation:floatChip 3.8s ease-in-out infinite 0s}
.svc-chip-3{top:45%;left:0;animation:floatChip 3.8s ease-in-out infinite 1.3s}
.svc-chip-5{bottom:16%;left:0;animation:floatChip 3.8s ease-in-out infinite 2.6s}
.svc-chip-2{top:13%;right:0;animation:floatChip 3.8s ease-in-out infinite .65s}
.svc-chip-4{top:45%;right:0;animation:floatChip 3.8s ease-in-out infinite 1.95s}
.svc-chip-6{bottom:16%;right:0;animation:floatChip 3.8s ease-in-out infinite 3.25s}
@keyframes floatChip{0%,100%{transform:translateY(0);box-shadow:0 4px 24px rgba(0,0,0,.5),0 0 0 1px rgba(9,172,233,0.18)}50%{transform:translateY(-7px);box-shadow:0 14px 32px rgba(0,0,0,.6),0 0 18px rgba(9,172,233,0.55),0 0 0 1px rgba(9,172,233,0.66)}}

/* ── Shared keyframes ── */
@keyframes gearSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes gearSpinR{from{transform:rotate(360deg)}to{transform:rotate(0deg)}}
@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(9,172,233,0.88)}70%{box-shadow:0 0 0 10px rgba(9,172,233,0)}}

/* 10. Stats Bar */
.stats-bar{background:var(--bg-card);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:40px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px;position:relative}
.stat-item+.stat-item::before{content:'';position:absolute;left:0;top:20%;bottom:20%;width:1px;background:var(--border)}
.stat-num{font-family:var(--ff-head);font-size:2.8rem;font-weight:800;color:var(--primary);line-height:1}
.stat-label{font-size:.75rem;color:var(--text-3);margin-top:6px;text-transform:uppercase;letter-spacing:.1em}

/* 11. Sections */
.section-alt{background:var(--bg-2)}
.section-dark{background:var(--bg-3)}

/* 12. Service Cards */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.service-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;position:relative;overflow:hidden;transition:var(--transition)}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent));transform:scaleX(0);transition:var(--transition)}
.service-card:hover{border-color:var(--border-hover);transform:translateY(-6px);box-shadow:var(--shadow-glow)}
.service-card:hover::before{transform:scaleX(1)}
.service-icon-wrap{width:56px;height:56px;background:var(--primary-glow);border:1px solid rgba(9,172,233,0.66);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--primary);margin-bottom:20px;transition:var(--transition)}
.service-card:hover .service-icon-wrap{background:var(--primary);color:#fff;box-shadow:0 4px 20px rgba(9,172,233,0.88)}
.service-num{position:absolute;top:20px;right:20px;font-family:var(--ff-head);font-size:2.8rem;font-weight:800;color:rgba(255,255,255,.04);line-height:1;user-select:none}
.service-card h3{font-size:1.05rem;margin-bottom:10px}
.service-card p{font-size:.87rem;color:var(--text-2);margin-bottom:16px}
.service-tags{display:flex;flex-wrap:wrap;gap:6px}
.service-tag{font-size:.7rem;font-weight:600;background:rgba(9,172,233,0.18);border:1px solid rgba(9,172,233,0.44);color:var(--primary-l);border-radius:50px;padding:3px 10px}
.service-link{display:inline-flex;align-items:center;gap:6px;color:var(--primary);font-size:.83rem;font-weight:600;margin-top:16px;transition:var(--transition)}
.service-link:hover{gap:10px}
.service-cta-bar{background:rgba(9,172,233,0.13);border:1px solid rgba(9,172,233,0.33);border-radius:var(--radius-lg);padding:28px 32px;display:flex;align-items:center;justify-content:space-between;gap:20px;margin-top:32px;flex-wrap:wrap}
.service-cta-bar strong{font-family:var(--ff-head);font-size:1.1rem}
.service-cta-bar p{font-size:.87rem;margin-top:4px}

/* 13. About */
.about-img-wrap{position:relative;border-radius:var(--radius-xl);overflow:hidden;min-height:440px;background:var(--bg-card)}
.about-img-wrap img{width:100%;height:100%;object-fit:cover}
.about-img-placeholder{width:100%;min-height:440px;background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-card-2) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;border:2px dashed rgba(9,172,233,0.33);border-radius:var(--radius-xl);padding:32px;text-align:center}
.about-img-placeholder i{font-size:3rem;color:var(--primary);opacity:.4}
.about-img-placeholder p{font-size:.83rem;color:var(--text-3)}
.about-badge{position:absolute;bottom:24px;left:24px;background:rgba(7,16,31,.95);border:1px solid var(--border);backdrop-filter:blur(12px);border-radius:14px;padding:12px 18px;display:flex;align-items:center;gap:12px}
.about-badge .badge-icon{width:40px;height:40px;background:var(--primary);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem}
.about-badge strong{display:block;font-size:.85rem;color:var(--text)}
.about-badge span{font-size:.72rem;color:var(--text-2)}
.fact-list{display:flex;flex-direction:column;gap:12px;margin:20px 0}
.fact-item{display:flex;align-items:flex-start;gap:14px;padding:16px;border-radius:var(--radius);background:rgba(9,172,233,0.09);border:1px solid rgba(9,172,233,0.22)}
.fact-check{width:28px;height:28px;flex-shrink:0;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.7rem;margin-top:2px}
.fact-item p{font-size:.88rem;margin:0}
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:20px 0}
.mv-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.mv-card h4{display:flex;align-items:center;gap:8px;font-size:.88rem;margin-bottom:6px;color:var(--primary)}
.mv-card p{font-size:.82rem;margin:0}

/* 14. Industry tags */
.industry-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.industry-tag{display:inline-flex;align-items:center;gap:6px;background:var(--bg-card);border:1px solid var(--border);border-radius:50px;padding:6px 14px;font-size:.78rem;font-weight:500;color:var(--text-2);transition:var(--transition)}
.industry-tag:hover{border-color:var(--primary);color:var(--primary)}
.industry-tag i{color:var(--primary);font-size:.72rem}

/* 15. Why Cards */
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.why-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;display:flex;gap:20px;align-items:flex-start;transition:var(--transition)}
.why-card:hover{border-color:var(--border-hover);transform:translateY(-4px);box-shadow:var(--shadow-glow)}
.why-icon{width:52px;height:52px;flex-shrink:0;background:var(--primary-glow);border:1px solid rgba(9,172,233,0.66);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:var(--primary);transition:var(--transition)}
.why-card:hover .why-icon{background:var(--primary);color:#fff}
.why-card h3{font-size:1rem;margin-bottom:8px}
.why-card p{font-size:.85rem;color:var(--text-2);margin:0}

/* 16. Gallery */
.gallery-grid{columns:3;column-gap:20px}
.gallery-item{position:relative;overflow:hidden;border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border);cursor:pointer;transition:var(--transition);break-inside:avoid;margin-bottom:20px;display:block}
.gallery-item img{width:100%;height:auto;display:block;border-radius:var(--radius-lg)}
.gallery-item:hover{box-shadow:var(--shadow-glow)}
.gallery-item:hover img{transform:scale(1.03);transition:transform .4s cubic-bezier(0.4,0,0.2,1)}
.gallery-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:40px 20px;text-align:center;aspect-ratio:4/3}
.gallery-placeholder i{font-size:2rem;color:var(--primary);opacity:.35}
.gallery-placeholder strong{font-size:.85rem;color:var(--text)}
.gallery-placeholder span{font-size:.74rem;color:var(--text-3)}

/* 17. CTA Section */
.cta-section{background:linear-gradient(135deg,var(--bg-card) 0%,#12203A 100%);border-top:1px solid var(--border);border-bottom:1px solid var(--border);text-align:center;padding:80px 0;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;top:-50%;left:-10%;width:60%;padding-bottom:60%;background:radial-gradient(circle,rgba(9,172,233,0.18) 0%,transparent 70%)}
.cta-section h2{margin-bottom:16px}
.cta-section p{margin-bottom:32px}

/* 10. Stats Bar */
.stats-bar{background:var(--bg-card);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:40px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px;position:relative}
.stat-item+.stat-item::before{content:'';position:absolute;left:0;top:20%;bottom:20%;width:1px;background:var(--border)}
.stat-num{font-family:var(--ff-head);font-size:2.8rem;font-weight:800;color:var(--primary);line-height:1}
.stat-label{font-size:.75rem;color:var(--text-3);margin-top:6px;text-transform:uppercase;letter-spacing:.1em}

/* 11. Sections */
.section-alt{background:var(--bg-2)}
.section-dark{background:var(--bg-3)}

/* 12. Service Cards */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.service-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;position:relative;overflow:hidden;transition:var(--transition)}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent));transform:scaleX(0);transition:var(--transition)}
.service-card:hover{border-color:var(--border-hover);transform:translateY(-6px);box-shadow:var(--shadow-glow)}
.service-card:hover::before{transform:scaleX(1)}
.service-icon-wrap{width:56px;height:56px;background:var(--primary-glow);border:1px solid rgba(9,172,233,0.66);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--primary);margin-bottom:20px;transition:var(--transition)}
.service-card:hover .service-icon-wrap{background:var(--primary);color:#fff;box-shadow:0 4px 20px rgba(9,172,233,0.88)}
.service-num{position:absolute;top:20px;right:20px;font-family:var(--ff-head);font-size:2.8rem;font-weight:800;color:rgba(255,255,255,.04);line-height:1;user-select:none}
.service-card h3{font-size:1.05rem;margin-bottom:10px}
.service-card p{font-size:.87rem;color:var(--text-2);margin-bottom:16px}
.service-tags{display:flex;flex-wrap:wrap;gap:6px}
.service-tag{font-size:.7rem;font-weight:600;background:rgba(9,172,233,0.18);border:1px solid rgba(9,172,233,0.44);color:var(--primary-l);border-radius:50px;padding:3px 10px}
.service-link{display:inline-flex;align-items:center;gap:6px;color:var(--primary);font-size:.83rem;font-weight:600;margin-top:16px;transition:var(--transition)}
.service-link:hover{gap:10px}
.service-cta-bar{background:rgba(9,172,233,0.13);border:1px solid rgba(9,172,233,0.33);border-radius:var(--radius-lg);padding:28px 32px;display:flex;align-items:center;justify-content:space-between;gap:20px;margin-top:32px;flex-wrap:wrap}
.service-cta-bar strong{font-family:var(--ff-head);font-size:1.1rem}
.service-cta-bar p{font-size:.87rem;margin-top:4px}

/* 13. About */
.about-img-wrap{position:relative;border-radius:var(--radius-xl);overflow:hidden;min-height:440px;background:var(--bg-card)}
.about-img-wrap img{width:100%;height:100%;object-fit:cover}
.about-img-placeholder{width:100%;min-height:440px;background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-card-2) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;border:2px dashed rgba(9,172,233,0.33);border-radius:var(--radius-xl);padding:32px;text-align:center}
.about-img-placeholder i{font-size:3rem;color:var(--primary);opacity:.4}
.about-img-placeholder p{font-size:.83rem;color:var(--text-3)}
.about-badge{position:absolute;bottom:24px;left:24px;background:rgba(7,16,31,.95);border:1px solid var(--border);backdrop-filter:blur(12px);border-radius:14px;padding:12px 18px;display:flex;align-items:center;gap:12px}
.about-badge .badge-icon{width:40px;height:40px;background:var(--primary);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem}
.about-badge strong{display:block;font-size:.85rem;color:var(--text)}
.about-badge span{font-size:.72rem;color:var(--text-2)}
.fact-list{display:flex;flex-direction:column;gap:12px;margin:20px 0}
.fact-item{display:flex;align-items:flex-start;gap:14px;padding:16px;border-radius:var(--radius);background:rgba(9,172,233,0.09);border:1px solid rgba(9,172,233,0.22)}
.fact-check{width:28px;height:28px;flex-shrink:0;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.7rem;margin-top:2px}
.fact-item p{font-size:.88rem;margin:0}
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:20px 0}
.mv-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.mv-card h4{display:flex;align-items:center;gap:8px;font-size:.88rem;margin-bottom:6px;color:var(--primary)}
.mv-card p{font-size:.82rem;margin:0}

/* 14. Industry tags */
.industry-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.industry-tag{display:inline-flex;align-items:center;gap:6px;background:var(--bg-card);border:1px solid var(--border);border-radius:50px;padding:6px 14px;font-size:.78rem;font-weight:500;color:var(--text-2);transition:var(--transition)}
.industry-tag:hover{border-color:var(--primary);color:var(--primary)}
.industry-tag i{color:var(--primary);font-size:.72rem}

/* 15. Why Cards */
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.why-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;display:flex;gap:20px;align-items:flex-start;transition:var(--transition)}
.why-card:hover{border-color:var(--border-hover);transform:translateY(-4px);box-shadow:var(--shadow-glow)}
.why-icon{width:52px;height:52px;flex-shrink:0;background:var(--primary-glow);border:1px solid rgba(9,172,233,0.66);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:var(--primary);transition:var(--transition)}
.why-card:hover .why-icon{background:var(--primary);color:#fff}
.why-card h3{font-size:1rem;margin-bottom:8px}
.why-card p{font-size:.85rem;color:var(--text-2);margin:0}

/* 16. Gallery */
.gallery-grid{columns:3;column-gap:20px}
.gallery-item{position:relative;overflow:hidden;border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border);cursor:pointer;transition:var(--transition);break-inside:avoid;margin-bottom:20px;display:block}
.gallery-item img{width:100%;height:auto;display:block;border-radius:var(--radius-lg)}
.gallery-item:hover{box-shadow:var(--shadow-glow)}
.gallery-item:hover img{transform:scale(1.03);transition:transform .4s cubic-bezier(0.4,0,0.2,1)}
.gallery-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:40px 20px;text-align:center;aspect-ratio:4/3}
.gallery-placeholder i{font-size:2rem;color:var(--primary);opacity:.35}
.gallery-placeholder strong{font-size:.85rem;color:var(--text)}
.gallery-placeholder span{font-size:.74rem;color:var(--text-3)}

/* 17. CTA Section */
.cta-section{background:linear-gradient(135deg,var(--bg-card) 0%,#12203A 100%);border-top:1px solid var(--border);border-bottom:1px solid var(--border);text-align:center;padding:80px 0;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;top:-50%;left:-10%;width:60%;padding-bottom:60%;background:radial-gradient(circle,rgba(9,172,233,0.18) 0%,transparent 70%)}
.cta-section h2{margin-bottom:16px}
.cta-section p{margin-bottom:32px}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* 18. Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:48px;align-items:start}
.contact-info-stack{display:flex;flex-direction:column;gap:18px}
.contact-card{display:flex;align-items:flex-start;gap:16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;transition:var(--transition)}
.contact-card:hover{border-color:var(--border-hover);transform:translateX(4px)}
.contact-ico{width:48px;height:48px;flex-shrink:0;background:var(--primary-glow);border:1px solid rgba(9,172,233,0.66);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--primary)}
.contact-card .label{font-size:.7rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:4px}
.contact-card strong{font-size:.93rem;display:block;margin-bottom:4px}
.contact-card p{font-size:.8rem;margin:0}
.contact-card a{color:var(--primary)}

/* 19. Quote Form */
.quote-form-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px}
.quote-form-wrap h3{margin-bottom:6px}
.quote-form-wrap > p{margin-bottom:24px;font-size:.88rem}
.form{display:flex;flex-direction:column;gap:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:.78rem;font-weight:600;color:var(--text-2);letter-spacing:.02em}
.form-group input,.form-group select,.form-group textarea{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;font-family:var(--ff-body);font-size:.88rem;color:var(--text);transition:var(--transition);outline:none;width:100%}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-3)}
.form-group select option{background:var(--bg-3)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(9,172,233,0.22)}
.form-group textarea{resize:vertical;min-height:120px}
.hp-field{display:none!important}
.form-alert{padding:12px 16px;border-radius:var(--radius);font-size:.85rem;font-weight:500;margin-bottom:8px}
.form-alert.ok{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);color:#34D399}
.form-alert.err{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:#FC8181}
.form-success{text-align:center;padding:40px 20px}
.success-icon{width:72px;height:72px;background:rgba(16,185,129,.1);border:2px solid rgba(16,185,129,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:1.8rem;color:#10B981}

/* 20. Footer */
.site-footer{background:var(--bg-footer);border-top:1px solid var(--border)}
.footer-waves{line-height:0;transform:scaleY(-1);margin-bottom:-1px}
.footer-waves svg{display:block}
.footer-body{padding:64px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.6fr;gap:48px;padding-bottom:48px;border-bottom:1px solid var(--border)}
.footer-brand .footer-tagline{font-size:.83rem;color:var(--text-3);margin:16px 0 20px;line-height:1.7;max-width:280px}
.footer-contact-quick{display:flex;flex-direction:column;gap:8px}
.footer-quick-link{display:inline-flex;align-items:center;gap:8px;font-size:.83rem;color:var(--text-2);transition:var(--transition)}
.footer-quick-link:hover{color:var(--primary)}
.footer-quick-link i{color:var(--primary);width:16px}
.footer-heading{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text);margin-bottom:18px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.footer-links{display:flex;flex-direction:column;gap:8px}
.footer-links a{display:flex;align-items:center;gap:8px;font-size:.83rem;color:var(--text-3);transition:var(--transition);padding:2px 0}
.footer-links a i{font-size:.58rem;color:var(--primary)}
.footer-links a:hover{color:var(--primary);padding-left:6px}
.footer-address p{font-size:.82rem;color:var(--text-3);display:flex;align-items:flex-start;gap:8px;margin-bottom:12px;line-height:1.6}
.footer-address i{color:var(--primary);margin-top:3px;flex-shrink:0}
.footer-gstin{margin-top:16px}
.gstin-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(9,172,233,0.18);border:1px solid rgba(9,172,233,0.44);border-radius:50px;padding:5px 12px;font-size:.7rem;font-weight:600;color:var(--primary)}
.footer-bar{display:flex;align-items:center;justify-content:space-between;padding:20px 0;flex-wrap:wrap;gap:8px}
.footer-bar p{font-size:.78rem;color:var(--text-3);margin:0}
.footer-bar a{color:var(--primary)}

/* 21. WhatsApp Float */
.wa-float{position:fixed;bottom:32px;right:32px;z-index:500;width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;box-shadow:0 4px 24px rgba(37,211,102,.4);transition:var(--transition)}
.wa-float:hover{transform:scale(1.1)}
.wa-tooltip{position:absolute;right:68px;background:rgba(0,0,0,.85);color:#fff;font-size:.72rem;font-weight:600;padding:6px 10px;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:var(--transition)}
.wa-float:hover .wa-tooltip{opacity:1}

/* Gallery hover overlay */
.gallery-item{position:relative}
.gallery-overlay{position:absolute;inset:0;background:rgba(7,16,31,.55);display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--transition);border-radius:var(--radius-lg)}
.gallery-overlay i{font-size:1.8rem;color:#fff;filter:drop-shadow(0 0 8px rgba(9,172,233,.8))}
.gallery-item:hover .gallery-overlay{opacity:1}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:9000;background:rgba(4,12,26,.96);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease;padding:20px}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox img{max-width:100%;max-height:90vh;border-radius:var(--radius-lg);box-shadow:0 0 80px rgba(9,172,233,.3);object-fit:contain}
.lightbox-close{position:absolute;top:20px;right:24px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;width:44px;height:44px;border-radius:50%;font-size:1.1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition)}
.lightbox-close:hover{background:var(--primary);border-color:var(--primary)}


/* 22. Back to Top */
.back-to-top{position:fixed;bottom:32px;left:32px;z-index:500;width:44px;height:44px;background:var(--bg-card);border:1px solid var(--border);border-radius:50%;color:var(--text-2);font-size:.88rem;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(10px);transition:var(--transition);pointer-events:none;box-shadow:var(--shadow)}
.back-to-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}
.back-to-top:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px)}

/* 23. Page Hero Banners */
.page-hero{padding:140px 0 80px;background:var(--bg-2);position:relative;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(9,172,233,0.13) 0%,transparent 60%),linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%)}
.page-hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:50px 50px}
.page-hero-content{position:relative;z-index:2}
.page-hero h1{margin-bottom:16px}
.page-hero .lead{margin-bottom:0}
.breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:14px;font-size:.78rem;color:var(--text-3)}
.breadcrumb a{color:var(--text-3);transition:var(--transition)}
.breadcrumb a:hover{color:var(--primary)}
.breadcrumb i{font-size:.58rem}

/* 24. About page */
.timeline{display:flex;flex-direction:column;position:relative}
.timeline::before{content:'';position:absolute;left:24px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--primary),rgba(9,172,233,0.22))}
.timeline-item{display:flex;gap:32px;padding-bottom:36px;position:relative}
.timeline-dot{width:50px;height:50px;flex-shrink:0;background:var(--bg-card);border:2px solid var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:1rem;z-index:1;box-shadow:0 0 14px rgba(9,172,233,.45),inset 0 0 10px rgba(9,172,233,.1)}
.timeline-body{padding-top:8px}
.timeline-body h4{margin-bottom:6px;font-size:1rem}
.timeline-body p{font-size:.86rem;margin:0}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.value-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 22px;text-align:center;transition:var(--transition)}
.value-card:hover{border-color:var(--border-hover);transform:translateY(-4px)}
.value-icon{width:60px;height:60px;margin:0 auto 18px;background:var(--primary-glow);border:1px solid rgba(9,172,233,0.66);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--primary)}
.value-card h3{font-size:.95rem;margin-bottom:8px}
.value-card p{font-size:.83rem;margin:0}
.industries-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.industry-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;display:flex;align-items:center;gap:14px;transition:var(--transition)}
.industry-card:hover{border-color:var(--border-hover);transform:translateX(4px)}
.ind-icon{width:46px;height:46px;flex-shrink:0;background:var(--primary-glow);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--primary)}
.industry-card h4{font-size:.9rem;margin-bottom:4px}
.industry-card p{font-size:.78rem;margin:0}

/* 25. Services detail */
.service-detail{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;padding:60px 0;border-bottom:1px solid var(--border)}
.service-detail:last-child{border-bottom:none}
.service-detail.reverse .service-detail-content{order:-1}
.service-detail-placeholder{width:100%;min-height:340px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;padding:24px;border:2px dashed rgba(9,172,233,0.26);border-radius:var(--radius-xl);background:var(--bg-card)}
.service-detail-placeholder .big-icon{width:90px;height:90px;background:var(--primary-glow);border:1px solid rgba(9,172,233,0.66);border-radius:24px;display:flex;align-items:center;justify-content:center;font-size:2.2rem;color:var(--primary)}
.service-detail-placeholder p{font-size:.83rem;color:var(--text-3)}
.scope-list{display:flex;flex-direction:column;gap:10px;margin:18px 0}
.scope-item{display:flex;align-items:center;gap:12px;font-size:.88rem;color:var(--text-2)}
.scope-item i{color:var(--primary);font-size:.82rem;flex-shrink:0}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
.process-steps::before{content:'';position:absolute;top:26px;left:calc(12.5% + 20px);right:calc(12.5% + 20px);height:2px;background:linear-gradient(90deg,var(--primary),rgba(9,172,233,0.44))}
.process-step{text-align:center}
.step-num{width:52px;height:52px;margin:0 auto 14px;background:var(--bg-card);border:2px solid var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--ff-head);font-weight:800;font-size:1rem;color:var(--primary);position:relative;z-index:1;transition:var(--transition)}
.process-step:hover .step-num{background:var(--primary);color:#fff}
.process-step h4{font-size:.88rem;margin-bottom:6px}
.process-step p{font-size:.8rem;margin:0}

/* 26. Map / Trust */
.map-wrap{height:440px;border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--border);background:var(--bg-card)}
.map-wrap iframe{width:100%;height:100%;display:block;border:0}
.trust-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:28px;margin-top:24px}
.trust-panel h4{margin-bottom:18px;font-size:.95rem}
.kpi-row{display:flex;gap:16px;flex-wrap:wrap}
.kpi{flex:1;text-align:center;background:var(--bg-3);border-radius:var(--radius);padding:14px 10px;min-width:70px}
.kpi strong{display:block;font-family:var(--ff-head);font-size:1.6rem;font-weight:800;color:var(--primary);line-height:1}
.kpi span{font-size:.68rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em}

/* 27. Scroll Reveal */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-32px);transition:opacity .7s ease,transform .7s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(32px);transition:opacity .7s ease,transform .7s ease}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.delay-1{transition-delay:.12s}
.delay-2{transition-delay:.22s}
.delay-3{transition-delay:.32s}
.delay-4{transition-delay:.42s}
.delay-5{transition-delay:.52s}

/* 28. Utilities */
.text-center{text-align:center}
.text-primary{color:var(--primary)}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}
.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mb-32{margin-bottom:32px}
.hidden{display:none!important}

/* 29. Responsive */

/* ── Tablet / iPad ── */
@media(max-width:1024px){
  .hero-content{grid-template-columns:1fr;gap:40px;text-align:center}
  .hero-visual{max-width:500px;width:100%;margin:0 auto;padding:40px 48px}
  /* Laser scene — hide right chips to avoid readout overlap */
  .svc-chip-2,.svc-chip-4,.svc-chip-6{display:none}
  .la-scene{height:440px}
  .la-readout{top:14px;right:12px}
  .hero-desc,.hero-actions{margin:auto}
  .hero-actions{justify-content:center}
  .hero-stats{justify-content:center}
  .grid-2{grid-template-columns:1fr}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .service-detail{grid-template-columns:1fr}
  .service-detail.reverse .service-detail-content{order:0}
  .process-steps{grid-template-columns:repeat(2,1fr)}
  .process-steps::before{display:none}
  .contact-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .about-img-wrap{min-height:320px}
}

/* ── Mobile Landscape / Large Phone ── */
@media(max-width:768px){
  :root{--transition:0.22s cubic-bezier(0.4,0,0.2,1)}
  .section{padding:60px 0}
  .section-header{margin-bottom:44px}

  /* Nav */
  .nav-container{height:68px}
  .logo-img{height:50px}
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex;margin-left:auto}

  /* Typography */
  h1{font-size:clamp(1.9rem,8vw,2.6rem)}
  h2{font-size:clamp(1.55rem,7vw,2.1rem)}
  .lead{font-size:.95rem}

  /* Hero */
  .hero{padding:88px 0 56px}
  .hero-content{gap:28px}
  .hero-visual{max-width:420px;padding:28px 20px}
  .hero-desc{font-size:.93rem;margin-bottom:22px}
  .hero-actions{gap:10px;margin-bottom:28px}
  .btn-lg{padding:13px 26px;font-size:.92rem}
  .hero-stats{gap:20px;padding-top:18px}
  .hero-stat .num{font-size:1.55rem}

  /* Laser scene — scale down */
  .la-scene{height:360px}
  .la-machine{bottom:90px}
  .la-beam-wrap{bottom:90px}
  .la-foundation{bottom:78px}
  .la-readout{min-width:130px;padding:8px 10px}

  /* Chips */
  .svc-chip{padding:7px 11px;gap:7px}
  .svc-chip i{font-size:.72rem}
  .svc-chip span{font-size:.62rem}

  /* Services */
  .services-grid{grid-template-columns:1fr 1fr}
  .service-card{padding:22px}
  .service-cta-bar{flex-direction:column;gap:14px}
  .service-cta-bar .btn{align-self:flex-start}

  /* Gallery */
  .gallery-grid{columns:2}

  /* Grids */
  .why-grid,.values-grid{grid-template-columns:1fr}
  .industries-grid{grid-template-columns:1fr 1fr}

  /* Stats */
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-item{padding:16px}
  .stat-num{font-size:2.2rem}
  .stat-item+.stat-item::before{display:none}

  /* Footer */
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .footer-body{padding:44px 0 0}

  /* Forms */
  .form-row{grid-template-columns:1fr}
  .mv-grid{grid-template-columns:1fr}
  .quote-form-wrap{padding:24px}

  /* Fixed floats */
  .wa-float,.back-to-top{bottom:20px}
  .wa-float{right:20px}
  .back-to-top{left:20px}

  /* About */
  .about-img-wrap{min-height:260px}
  .timeline-item{gap:20px}
  .timeline::before{left:20px}
  .timeline-dot{width:42px;height:42px;font-size:.88rem}

  /* Process */
  .process-steps{grid-template-columns:repeat(2,1fr)}
  .process-steps::before{display:none}
}

/* ── Mobile Portrait ── */
@media(max-width:480px){
  .container{padding:0 16px}
  .section{padding:52px 0}
  .section-header{margin-bottom:36px}

  /* Hero */
  .nav-container{height:60px}
  .logo-img{height:44px}
  .hero{padding:76px 0 48px}
  .hero-visual{padding:18px 12px;max-width:100%}
  .hero-stats{gap:14px;flex-wrap:wrap;justify-content:flex-start}
  .hero-stat .num{font-size:1.4rem}
  .hero-stat .lbl{font-size:.65rem}
  .hero-actions{flex-direction:column;align-items:stretch;gap:10px}
  .hero-actions .btn{justify-content:center}

  /* Laser scene mobile */
  .la-scene{height:300px}
  .la-machine{bottom:74px}
  .la-motor-body{width:84px;height:48px}
  .la-pump-body{width:74px;height:48px}
  .la-beam-wrap{bottom:74px}
  .la-foundation{bottom:62px;width:200px}
  .la-readout{top:8px;right:8px;min-width:118px;padding:7px 9px}
  .la-tools{gap:6px}
  .la-tool{padding:6px 8px;min-width:38px}
  .la-tool i{font-size:.75rem}
  .la-tool span{font-size:.42rem}

  /* Chips — simplify on small screens */
  .svc-chip-5,.svc-chip-6{display:none}
  .svc-chip{padding:5px 9px;gap:5px}
  .svc-chip i{font-size:.65rem}
  .svc-chip span{font-size:.58rem}
  .svc-chip-1,.svc-chip-2{top:4%}
  .svc-chip-3,.svc-chip-4{top:43%}

  /* Services */
  .services-grid{grid-template-columns:1fr}
  .industries-grid{grid-template-columns:1fr}
  .service-card{padding:20px}
  .service-cta-bar{text-align:center}
  .service-cta-bar .btn{width:100%;justify-content:center}

  /* Gallery */
  .gallery-grid{columns:1}

  /* Stats */
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-num{font-size:2rem}
  .stat-item{padding:14px 10px}

  /* CTA buttons */
  .cta-actions{flex-direction:column;align-items:center;gap:12px}
  .cta-actions .btn{width:100%;max-width:300px;justify-content:center}

  /* Forms */
  .quote-form-wrap{padding:20px 16px;border-radius:var(--radius-lg)}

  /* Footer */
  .footer-bar{flex-direction:column;text-align:center}

  /* Page banners */
  .page-hero{padding:106px 0 52px}
  .breadcrumb{font-size:.72rem}

  /* Contact */
  .contact-card{padding:16px}

  /* Timeline */
  .timeline::before{left:16px}
  .timeline-dot{width:36px;height:36px;font-size:.8rem}
  .timeline-item{gap:16px}
  .timeline-body h4{font-size:.92rem}

  /* Process steps */
  .process-steps{grid-template-columns:1fr}
}

/* ── Very small phones (iPhone SE etc.) ── */
@media(max-width:360px){
  h1{font-size:1.75rem}
  h2{font-size:1.4rem}
  .crane-scene{height:200px}
  .crane-tower{height:126px}
  .crane-jib{width:80px}
  .svc-chip-3,.svc-chip-4{display:none}
  .hero-badge{font-size:.62rem;padding:5px 12px}
  .hero-stat .num{font-size:1.3rem}
  .btn-lg{padding:11px 20px;font-size:.85rem}
}

/* ── Reduced motion accessibility ── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
  .reveal,.reveal-left,.reveal-right{
    opacity:1!important;
    transform:none!important;
    transition:none!important;
  }
  .crane-trolley,.crane-rope,.crane-cargo,.truck,.truck-cargo{animation:none!important}
  .crane-cargo{opacity:1!important;transform:translateX(-50%)!important}
  .svc-chip{animation:none!important}
  .gear-bg{animation:none!important}
  .spark{display:none!important}
  .scene-card{animation:none!important}
}

/* ============================================================
   TESTIMONIALS CAROUSEL
   ============================================================ */
.testimonials-section{background:var(--bg-2)}
.testimonials-carousel{position:relative;overflow:hidden;border-radius:var(--radius-xl);padding:0}
.testimonials-track{display:flex;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.testimonial-card{min-width:100%;padding:40px 48px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);box-sizing:border-box}
.testi-stars{color:#FBBF24;font-size:1rem;letter-spacing:2px;margin-bottom:20px}
.testi-quote{font-size:1.05rem;line-height:1.8;color:var(--text-2);font-style:italic;margin:0 0 28px;position:relative}
.testi-quote::before{content:'\201C';font-size:4rem;color:var(--primary);opacity:.25;position:absolute;top:-20px;left:-12px;font-family:Georgia,serif;line-height:1}
.testi-author{display:flex;align-items:center;gap:16px}
.testi-avatar{width:48px;height:48px;background:var(--primary-glow);border:2px solid var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--primary);flex-shrink:0}
.testi-author strong{display:block;font-size:.95rem;color:var(--text);font-family:var(--ff-head)}
.testi-author span{font-size:.8rem;color:var(--text-3)}
.testi-controls{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:28px}
.testi-btn{width:42px;height:42px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border);color:var(--text-2);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);font-size:.85rem}
.testi-btn:hover{background:var(--primary);border-color:var(--primary);color:#fff}
.testi-dots{display:flex;gap:8px;align-items:center}
.testi-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:var(--transition);cursor:pointer;border:none}
.testi-dot.active{background:var(--primary);width:24px;border-radius:4px}
@media(max-width:768px){
  .testimonial-card{padding:28px 24px}
  .testi-quote{font-size:.92rem}
  .testi-quote::before{font-size:3rem}
}

/* ============================================================
   CERTIFICATIONS SECTION (About Page)
   ============================================================ */
.cert-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.cert-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;display:flex;gap:20px;align-items:flex-start;transition:var(--transition)}
.cert-card:hover{border-color:var(--border-hover);transform:translateY(-4px);box-shadow:var(--shadow)}
.cert-icon{width:56px;height:56px;border-radius:14px;background:var(--primary-glow);border:1px solid rgba(9,172,233,.3);display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--primary);flex-shrink:0}
.cert-body h4{font-family:var(--ff-head);font-size:1.05rem;color:var(--text);margin-bottom:4px}
.cert-number{font-family:monospace;font-size:.85rem;color:var(--primary);background:var(--primary-glow);border:1px solid rgba(9,172,233,.2);padding:4px 10px;border-radius:6px;display:inline-block;margin:6px 0 8px;letter-spacing:.05em}
.cert-body p{font-size:.88rem;color:var(--text-2);line-height:1.6;margin:0 0 12px}
.cert-badge{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;padding:5px 12px;border-radius:50px;background:rgba(9,172,233,.12);color:var(--primary);border:1px solid rgba(9,172,233,.25)}
.cert-badge-active{background:rgba(16,185,129,.12);color:#10B981;border-color:rgba(16,185,129,.3)}
/* GSTIN highlight bar */
.gstin-highlight-bar{margin-top:40px;background:linear-gradient(135deg,rgba(9,172,233,.1),rgba(9,172,233,.04));border:1px solid rgba(9,172,233,.25);border-radius:var(--radius-lg);padding:28px 36px;display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.gstin-highlight-icon{width:52px;height:52px;background:var(--primary);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:#fff;flex-shrink:0}
.gstin-highlight-text{flex:1;min-width:200px}
.gstin-label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--primary);margin-bottom:4px}
.gstin-value{font-family:monospace;font-size:1.4rem;font-weight:700;color:var(--text);letter-spacing:.08em}
.gstin-highlight-state{display:flex;flex-direction:column;gap:6px;font-size:.82rem;color:var(--text-2)}
.gstin-highlight-state span{display:flex;align-items:center;gap:8px}
@media(max-width:768px){
  .cert-grid{grid-template-columns:1fr}
  .cert-card{padding:24px}
  .gstin-highlight-bar{padding:20px 24px;gap:16px}
  .gstin-value{font-size:1.1rem}
}

/* ============================================================
   CONTACT PAGE — MINI TESTIMONIAL
   ============================================================ */
.contact-testi{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-top:20px}
.contact-testi .testi-stars{font-size:.85rem;letter-spacing:1px;color:#FBBF24}

/* ============================================================
   SELECT FIELD (Project Location dropdown)
   ============================================================ */
.sp-form select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2309ACE9' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}

/* ============================================================
   BANK DETAIL TABLE (About Page – Certifications)
   ============================================================ */
.bank-detail-table{width:100%;border-collapse:collapse;margin:10px 0 4px;font-size:.85rem}
.bank-detail-table td{padding:6px 10px 6px 0;vertical-align:top;line-height:1.5}
.bank-detail-table td:first-child{color:var(--text-3);white-space:nowrap;width:130px;font-size:.78rem;padding-top:7px}
.bank-detail-table td:last-child strong{color:var(--text);font-family:monospace;font-size:.88rem;letter-spacing:.03em}
.bank-detail-table tr+tr td{border-top:1px solid var(--border)}

/* ============================================================
   BANK DETAILS BAR (Contact Page – full-width section)
   ============================================================ */
.bank-details-bar{display:flex;align-items:center;gap:32px;background:var(--bg-card);border:1px solid rgba(167,139,250,.25);border-radius:var(--radius-xl);padding:36px 40px;flex-wrap:wrap}
.bank-details-icon{width:64px;height:64px;background:rgba(167,139,250,.12);border:1px solid rgba(167,139,250,.3);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;color:#A78BFA;flex-shrink:0}
.bank-details-fields{display:flex;flex:1;gap:0;flex-wrap:wrap;min-width:0}
.bank-field{flex:1;min-width:160px;padding:0 24px;border-left:1px solid var(--border)}
.bank-field:first-child{padding-left:0;border-left:none}
.bank-field-label{display:block;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);margin-bottom:6px}
.bank-field-value{display:block;font-size:.95rem;font-weight:600;color:var(--text)}
.bank-field-value.mono{font-family:monospace;font-size:1rem;letter-spacing:.04em;color:var(--primary)}
.bank-details-badge{flex-shrink:0}
@media(max-width:900px){
  .bank-details-bar{padding:24px 20px;gap:20px}
  .bank-details-fields{gap:12px}
  .bank-field{min-width:calc(50% - 12px);padding:0;border-left:none;border-top:1px solid var(--border);padding-top:12px}
  .bank-field:first-child,.bank-field:nth-child(2){border-top:none;padding-top:0}
}
@media(max-width:540px){
  .bank-field{min-width:100%}
  .bank-field:nth-child(2){border-top:none;padding-top:0}
  .bank-field+.bank-field{border-top:1px solid var(--border);padding-top:12px}
  .bank-details-badge{width:100%}
}

/* ============================================================
   Careers Page
   ============================================================ */

/* Perk cards */
.careers-perk-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px 28px;text-align:center;transition:var(--transition)}
.careers-perk-card:hover{border-color:var(--border-hover);transform:translateY(-4px)}
.careers-perk-icon{width:60px;height:60px;background:var(--primary-glow);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:1.4rem;color:var(--primary)}
.careers-perk-card h3{font-family:var(--ff-head);font-size:1.1rem;margin-bottom:10px}

/* Job listings */
.careers-listings{display:flex;flex-direction:column;gap:16px;max-width:860px;margin:0 auto}
.careers-job-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--transition)}
.careers-job-card:hover{border-color:rgba(9,172,233,.35)}
.careers-job-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:24px 28px;cursor:pointer;user-select:none}
.careers-job-header:hover .careers-expand-btn{border-color:var(--primary);color:var(--primary)}
.careers-job-meta{flex:1;min-width:0}
.careers-job-meta h3{font-family:var(--ff-head);font-size:1.1rem;margin-bottom:10px}
.careers-job-tags{display:flex;flex-wrap:wrap;gap:8px}
.careers-tag{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:50px;padding:3px 12px;font-size:.75rem;color:var(--text-2)}
.careers-tag-new{background:rgba(16,185,129,.1);border-color:rgba(16,185,129,.35);color:#34D399}
.careers-tag-new i{font-size:.45rem;color:#34D399}
.careers-expand-btn{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.05);color:var(--text-2);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.careers-expand-btn i{transition:transform .3s ease}
.careers-job-body{padding:0 28px 28px;border-top:1px solid var(--border)}
.careers-job-desc{color:var(--text-2);line-height:1.75;white-space:pre-line;margin:20px 0}
.careers-job-apply{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px}

/* No jobs / general CTA */
.careers-no-jobs{text-align:center;padding:80px 24px;max-width:560px;margin:0 auto}
.careers-no-jobs i{font-size:3rem;color:var(--text-3);margin-bottom:20px}
.careers-no-jobs h3{font-family:var(--ff-head);margin-bottom:12px}
.careers-general-cta{margin-top:48px}
.careers-cta-inner{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:36px 40px;display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.careers-cta-inner>i{font-size:2.5rem;color:var(--primary);flex-shrink:0}
.careers-cta-inner>div{flex:1}
.careers-cta-inner h3{font-family:var(--ff-head);font-size:1.15rem;margin-bottom:6px}

@media(max-width:640px){
  .careers-job-header{padding:18px 20px}
  .careers-job-body{padding:0 20px 20px}
  .careers-cta-inner{padding:24px 20px;flex-direction:column;text-align:center}
}

/* ============================================================
   Gallery Page
   ============================================================ */

/* Filter bar */
.gallery-filter-bar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:40px;justify-content:center}
.gallery-filter-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 18px;border-radius:50px;font-size:.82rem;font-weight:600;background:rgba(255,255,255,.05);border:1px solid var(--border);color:var(--text-2);cursor:pointer;transition:var(--transition);font-family:var(--ff-body)}
.gallery-filter-btn:hover,.gallery-filter-btn.active{background:var(--primary-glow);border-color:rgba(9,172,233,.5);color:var(--primary)}
.gallery-filter-count{background:rgba(255,255,255,.08);border-radius:50px;padding:1px 7px;font-size:.7rem;color:var(--text-3)}
.gallery-filter-btn.active .gallery-filter-count{background:rgba(9,172,233,.2);color:var(--primary)}

/* Gallery grid */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.gallery-item-inner{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);cursor:pointer}
.gallery-item-inner:hover{border-color:rgba(9,172,233,.4);transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.gallery-img-wrap{position:relative;aspect-ratio:4/3;overflow:hidden}
.gallery-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.gallery-item-inner:hover .gallery-img-wrap img{transform:scale(1.06)}
.gallery-img-overlay{position:absolute;inset:0;background:rgba(0,0,0,0);display:flex;align-items:center;justify-content:center;transition:background var(--transition);pointer-events:none}
.gallery-item-inner:hover .gallery-img-overlay{background:rgba(0,0,0,.45)}
.gallery-zoom-icon{opacity:0;width:52px;height:52px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.1rem;transform:scale(0.7);transition:var(--transition)}
.gallery-item-inner:hover .gallery-zoom-icon{opacity:1;transform:scale(1)}
.gallery-item-meta{padding:16px 18px}
.gallery-cat-badge{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:700;color:var(--primary);background:var(--primary-glow);border:1px solid rgba(9,172,233,.25);border-radius:50px;padding:3px 10px;margin-bottom:8px}
.gallery-item-desc{font-size:.85rem;color:var(--text-2);line-height:1.55;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}

/* Empty / no results */
.gallery-empty,.gallery-no-results{text-align:center;padding:80px 24px;color:var(--text-3);display:flex;flex-direction:column;align-items:center;gap:16px}
.gallery-empty i,.gallery-no-results i{font-size:3rem}
.gallery-empty h3{font-family:var(--ff-head);color:var(--text-2)}

/* Filter btn empty state */
.gallery-filter-btn-empty{opacity:.45}
.gallery-filter-btn-empty:hover{opacity:1}

/* Lightbox */
.gallery-lightbox{position:fixed;inset:0;z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px}
.gallery-lightbox-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.92);backdrop-filter:blur(8px)}
.gallery-lightbox-content{position:relative;z-index:1;max-width:960px;width:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;max-height:95vh}
.gallery-lb-close{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;background:rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.15);color:var(--text);font-size:.9rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);z-index:10}
.gallery-lb-close:hover{background:var(--error);border-color:var(--error)}

/* Prev / Next navigation arrows */
.gallery-lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:rgba(0,0,0,.65);border:1px solid rgba(255,255,255,.18);color:var(--text);font-size:1rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition);z-index:10}
.gallery-lb-nav:hover{background:var(--primary);border-color:var(--primary)}
.gallery-lb-prev{left:14px}
.gallery-lb-next{right:14px}

/* Main image area */
.gallery-lb-img-wrap{flex:1;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#000;min-height:200px;max-height:58vh}
.gallery-lb-img-wrap img{max-width:100%;max-height:58vh;object-fit:contain;display:block;transition:opacity .2s ease}

/* Info bar */
.gallery-lb-info{padding:14px 56px 14px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px;border-top:1px solid var(--border);flex-wrap:wrap}
.gallery-lb-info-left{display:flex;flex-direction:column;gap:5px}
.gallery-lb-info p{color:var(--text-2);font-size:.88rem;margin:0}
.gallery-lb-counter{font-size:.78rem;color:var(--text-3);font-weight:600;white-space:nowrap}

/* Related strip */
.gallery-lb-related{padding:14px 20px 18px;border-top:1px solid var(--border)}
.gallery-lb-related-label{font-size:.72rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}
.gallery-lb-related-strip{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.gallery-lb-related-strip::-webkit-scrollbar{height:4px}
.gallery-lb-related-strip::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.gallery-lb-rel-thumb{flex-shrink:0;width:68px;height:52px;border-radius:6px;overflow:hidden;border:2px solid transparent;cursor:pointer;transition:var(--transition);background:none;padding:0}
.gallery-lb-rel-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.gallery-lb-rel-thumb:hover{border-color:var(--primary)}
.gallery-lb-rel-thumb.active{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow)}

@media(max-width:640px){
  .gallery-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px}
  .gallery-filter-bar{gap:8px}
  .gallery-filter-btn{font-size:.75rem;padding:6px 14px}
  .gallery-lightbox{padding:8px}
  .gallery-lb-img-wrap{max-height:45vh}
  .gallery-lb-nav{width:36px;height:36px;font-size:.85rem}
  .gallery-lb-prev{left:6px}
  .gallery-lb-next{right:6px}
}

/* ============================================================
   Careers – Live indicator + CV button updates
   ============================================================ */

/* Pulsing live dot */
.careers-live-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#22C55E;box-shadow:0 0 0 0 rgba(34,197,94,.6);animation:careers-pulse 1.8s ease-in-out infinite;flex-shrink:0}
@keyframes careers-pulse{
  0%  {box-shadow:0 0 0 0 rgba(34,197,94,.7)}
  60% {box-shadow:0 0 0 7px rgba(34,197,94,0)}
  100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}
}
.careers-tag-new{background:rgba(34,197,94,.1);border-color:rgba(34,197,94,.35);color:#4ADE80;display:inline-flex;align-items:center;gap:6px}

/* Header actions row (CV button + expand toggle) */
.careers-job-header-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.careers-cv-btn{white-space:nowrap}

@media(max-width:540px){
  .careers-job-header{flex-wrap:wrap;gap:12px}
  .careers-job-header-actions{width:100%;justify-content:flex-end}
  .careers-cv-btn{font-size:.78rem;padding:7px 14px}
}
