/* ==========================================
   BENMAR ELECTRIC — Fortune 500 Corporate Design
   Fonts: Inter (body), Plus Jakarta Sans (display), JetBrains Mono (mono)
   Colors: Corporate Green, Slate Grays, Black & White
   ========================================== */

:root{
    --accent:#39FF14;
    --accent-hover:#2ecc0f;
    --accent-light:#6FFF4F;
    --accent-subtle:rgba(57,255,20,.06);
    --accent-border:rgba(57,255,20,.15);
    --black:#050505;
    --bg:#0A0A0A;
    --surface:#111111;
    --surface-2:#161616;
    --border:#1C1C1C;
    --border-light:#242424;
    --gray-900:#141414;
    --gray-800:#1E1E1E;
    --gray-700:#2E2E2E;
    --gray-600:#444444;
    --gray-500:#666666;
    --gray-400:#999999;
    --gray-300:#BBBBBB;
    --gray-200:#DDDDDD;
    --gray-100:#EEEEEE;
    --white:#FFFFFF;
    --font:'Inter',system-ui,-apple-system,sans-serif;
    --display:'Plus Jakarta Sans','Inter',system-ui,sans-serif;
    --mono:'JetBrains Mono','Fira Code',monospace;
    --nav-h:96px;
    --container:1240px;
    --ease:cubic-bezier(.16,1,.3,1);
    --ease-out:cubic-bezier(0,0,.2,1);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

html{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--accent) var(--black)}
html::-webkit-scrollbar{width:4px}
html::-webkit-scrollbar-track{background:var(--black)}
html::-webkit-scrollbar-thumb{background:var(--gray-700);border-radius:4px}
html::-webkit-scrollbar-thumb:hover{background:var(--accent)}

body{font-family:var(--font);background:var(--bg);color:var(--gray-400);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

.container{max-width:var(--container);margin:0 auto;padding:0 32px}
.section{padding:140px 0;position:relative}
.accent{color:var(--accent)}

/* ==========================================
   PRELOADER
   ========================================== */
#preloader{position:fixed;inset:0;background:var(--black);z-index:10000;display:flex;align-items:center;justify-content:center;transition:opacity .6s var(--ease),visibility .6s}
#preloader.loaded{opacity:0;visibility:hidden;pointer-events:none}
.preloader-circuit-lines{position:absolute;inset:0;opacity:0}
.preloader-circuit-lines svg{position:absolute;inset:0;width:100%;height:100%}
.preloader-path{stroke-dasharray:2000;stroke-dashoffset:2000;opacity:.4}
.loader{text-align:center;display:flex;flex-direction:column;align-items:center;gap:20px;position:relative;z-index:1}
.loader-logo{width:56px;height:56px;object-fit:contain;filter:brightness(0) invert(1);opacity:0}
.loader-voltage-wrap{position:relative;width:120px;height:68px}
.loader-voltage-meter{width:100%;height:100%}
.loader-voltage-arc{stroke-dasharray:142;stroke-dashoffset:142;filter:drop-shadow(0 0 6px rgba(57,255,20,.5))}
.loader-voltage-pct{position:absolute;bottom:4px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:14px;font-weight:700;color:var(--accent);letter-spacing:.05em}
.loader-text{font-family:var(--mono);font-size:10px;letter-spacing:.3em;color:var(--gray-600);text-transform:uppercase}

/* ==========================================
   NAVIGATION
   ========================================== */
.nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:1000;transition:background .4s,border-color .4s,backdrop-filter .4s}
.nav.scrolled{background:rgba(5,5,5,.92);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border)}
.nav-inner{max-width:var(--container);margin:0 auto;padding:0 32px;height:100%;display:flex;align-items:center;justify-content:space-between;position:relative}
.nav-logo img{height:72px;width:auto;object-fit:contain;transition:opacity .3s}
.nav-logo:hover img{opacity:.8}
.nav-links{display:flex;align-items:center;gap:36px}
.nav-link{font-size:13px;font-weight:500;letter-spacing:.05em;color:var(--gray-500);transition:color .25s;text-transform:uppercase}
.nav-link:hover,.nav-link.active{color:var(--white)}
.nav-cta{background:var(--accent);color:var(--black)!important;padding:10px 24px;border-radius:6px;font-weight:600;transition:background .25s,transform .25s}
.nav-cta:hover{background:var(--accent-hover);transform:translateY(-1px)}

.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;z-index:1001}
.nav-burger span{width:22px;height:1.5px;background:var(--white);transition:.3s var(--ease);border-radius:2px}
.nav-burger.active span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-burger.active span:nth-child(2){opacity:0}
.nav-burger.active span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

.mobile-nav{display:none;position:fixed;inset:0;background:rgba(5,5,5,.98);backdrop-filter:blur(24px);z-index:999;opacity:0;visibility:hidden;transition:.4s var(--ease)}
.mobile-nav.active{opacity:1;visibility:visible}
.mobile-nav-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:32px}
.mobile-nav-link{font-family:var(--display);font-size:28px;font-weight:700;color:var(--gray-300);transition:color .25s}
.mobile-nav-link:hover,.mobile-nav-link.accent{color:var(--accent)}

/* ==========================================
   BUTTONS
   ========================================== */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;border-radius:6px;font-family:var(--font);font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;border:none;transition:.3s var(--ease);position:relative}
.btn-primary{background:var(--accent);color:var(--black)}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 8px 32px rgba(57,255,20,.2)}
.btn-ghost{background:transparent;color:var(--gray-300);border:1px solid var(--border-light)}
.btn-ghost:hover{border-color:var(--accent-border);color:var(--white);background:var(--accent-subtle)}
.btn-sm{padding:10px 22px;font-size:12px}
.btn-full{width:100%;justify-content:center}

.link-arrow{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--accent);letter-spacing:.02em;transition:.25s}
.link-arrow:hover{gap:12px}
.link-arrow svg{transition:transform .25s}
.link-arrow:hover svg{transform:translateX(3px)}

/* ==========================================
   LABELS & HEADINGS
   ========================================== */
.label{font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:12px;margin-bottom:20px}
.label::before{content:'';width:24px;height:1px;background:var(--accent)}

.h2{font-family:var(--display);font-size:clamp(28px,4vw,52px);font-weight:800;line-height:1.15;color:var(--white);margin-bottom:24px;letter-spacing:-.02em}

.section-head{margin-bottom:64px}
.section-head.center{text-align:center}
.section-head.center .label{justify-content:center}
.section-head.center .label::before{display:none}
.section-sub{font-size:16px;color:var(--gray-400);max-width:520px;margin:0 auto;line-height:1.7}

.section-head-row{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:64px;gap:24px;flex-wrap:wrap}

/* ==========================================
   HERO
   ========================================== */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;overflow:hidden}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-img{width:100%;height:100%;object-fit:cover;object-position:center 40%;transform:scale(1.05);animation:heroZoom 25s ease-out forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,5,5,.75) 0%,rgba(5,5,5,.55) 35%,rgba(5,5,5,.8) 70%,var(--bg) 100%)}

.hero-content{position:relative;z-index:1;flex:1;display:flex;flex-direction:column;justify-content:center;padding-top:calc(var(--nav-h) + 80px);padding-bottom:180px;max-width:var(--container);padding-left:32px;padding-right:32px;margin:0 auto}

.hero-tag{display:inline-flex;align-items:center;gap:12px;font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-light);margin-bottom:28px}
.tag-pulse{width:8px;height:8px;background:var(--accent);border-radius:50%;animation:tagPulse 3s ease-in-out infinite}
@keyframes tagPulse{0%,100%{opacity:1}50%{opacity:.3}}

.hero-h1{font-family:var(--display);font-size:clamp(40px,7vw,84px);font-weight:800;line-height:1.05;color:var(--white);letter-spacing:-.03em;margin-bottom:28px}
.hero-accent{color:var(--accent-light)}

.hero-sub{font-size:clamp(16px,1.6vw,19px);color:var(--gray-400);max-width:580px;line-height:1.75;margin-bottom:40px}

.hero-btns{display:flex;gap:16px;flex-wrap:wrap}

.hero-bottom{position:absolute;bottom:0;left:0;right:0;z-index:1}
.hero-stats{display:flex;align-items:center;justify-content:center;gap:56px;padding:40px 32px;border-top:1px solid rgba(255,255,255,.06)}
.hero-stat{text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}
.hero-stat-row{display:flex;align-items:baseline;justify-content:center;line-height:1}
.hero-stat-num,.hero-stat-prefix,.hero-stat-suffix{font-family:var(--display);font-size:clamp(32px,4.5vw,52px);font-weight:800}
.hero-stat-num{color:var(--white)}
.hero-stat-prefix,.hero-stat-suffix{color:var(--accent)}
.hero-stat-label{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gray-600)}
.hero-stat-divider{width:1px;height:48px;background:var(--border)}

.hero-scroll{position:absolute;right:32px;bottom:48px;display:flex;flex-direction:column;align-items:center;gap:10px}
.scroll-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);animation:scrollBounce 2.5s ease-in-out infinite}
@keyframes scrollBounce{0%,100%{transform:translateY(0);opacity:1}50%{transform:translateY(10px);opacity:.2}}
.hero-scroll span{font-family:var(--mono);font-size:9px;letter-spacing:.25em;text-transform:uppercase;color:var(--gray-600);writing-mode:vertical-rl}

/* ==========================================
   TICKER
   ========================================== */
.ticker{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden;padding:16px 0}
.ticker-track{display:flex;width:max-content}
.ticker-items{display:flex;align-items:center;gap:40px;animation:ticker 45s linear infinite;padding-right:40px}
.ticker-items span{font-family:var(--display);font-size:13px;font-weight:700;color:var(--gray-400);text-transform:uppercase;letter-spacing:.1em;white-space:nowrap}
.ticker-sep{font-weight:400!important;opacity:.25!important;color:var(--gray-600)!important}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ==========================================
   TRUST BAR (Partners / Certifications inline)
   ========================================== */
.trust-bar{padding:80px 0;border-bottom:1px solid var(--border)}
.trust-bar-inner{display:flex;align-items:center;justify-content:center;gap:64px;flex-wrap:wrap}
.trust-bar-label{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gray-400);white-space:nowrap}
.trust-bar-logos{display:flex;align-items:center;gap:48px;flex-wrap:wrap;justify-content:center}
.trust-bar-logos img{height:44px;width:auto;object-fit:contain;transition:filter .3s}
.trust-bar-logos img:hover{filter:brightness(1.5)}

/* ==========================================
   MISSION
   ========================================== */
.mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:start}
.mission-right p{font-size:16px;color:var(--gray-400);line-height:1.85;margin-bottom:20px}
.mission-right .link-arrow{margin-top:16px}

/* ==========================================
   CAPABILITIES
   ========================================== */
.cap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.cap-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:.4s var(--ease);text-decoration:none}
.cap-card:hover{border-color:var(--accent-border);transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.3)}
.cap-img-wrap{height:220px;overflow:hidden;position:relative}
.cap-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease);filter:grayscale(.2) brightness(.75)}
.cap-card:hover .cap-img-wrap img{transform:scale(1.05);filter:grayscale(0) brightness(.9)}
.cap-body{padding:32px 28px;display:flex;flex-direction:column;flex:1;position:relative}
.cap-num{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.1em;margin-bottom:10px;opacity:.5}
.cap-body h3{font-family:var(--display);font-size:18px;font-weight:700;color:var(--white);margin-bottom:10px;line-height:1.35}
.cap-body p{font-size:14px;color:var(--gray-500);line-height:1.7;flex:1}
.cap-arrow{position:absolute;top:32px;right:28px;opacity:0;transform:translate(-4px,4px);transition:.35s var(--ease)}
.cap-arrow svg{stroke:var(--accent)}
.cap-card:hover .cap-arrow{opacity:1;transform:translate(0,0)}

/* ==========================================
   FEATURED PROJECTS
   ========================================== */
.featured-projects{background:var(--bg)}
.fp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;max-width:1440px;margin:0 auto}
.fp-card{position:relative;overflow:hidden;cursor:pointer;min-height:340px}
.fp-large{grid-column:span 2;grid-row:span 2;min-height:680px}
.fp-img-wrap{position:absolute;inset:0}
.fp-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease);filter:brightness(.65)}
.fp-card:hover .fp-img-wrap img{transform:scale(1.04);filter:brightness(.85)}
.fp-info{position:absolute;bottom:0;left:0;right:0;padding:32px;z-index:1;background:linear-gradient(0deg,rgba(0,0,0,.85) 0%,transparent 100%)}
.fp-tag{font-family:var(--mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--accent-light);margin-bottom:10px;display:block}
.fp-info h3{font-family:var(--display);font-size:18px;font-weight:700;color:var(--white);line-height:1.35}
.fp-large .fp-info h3{font-size:28px}
.fp-info p{font-size:14px;color:var(--gray-400);line-height:1.65;margin-top:10px;max-height:0;overflow:hidden;opacity:0;transition:max-height .5s var(--ease),opacity .3s}
.fp-card:hover .fp-info p{max-height:100px;opacity:1}

/* ==========================================
   PHOTO MOSAIC
   ========================================== */
.photo-mosaic{overflow:hidden;padding:4px 0;background:var(--black)}
.mosaic-row{display:flex;width:max-content;gap:4px;margin-bottom:4px}
.mosaic-scroll-left .mosaic-item{animation:mosaicL 55s linear infinite}
.mosaic-scroll-right .mosaic-item{animation:mosaicR 60s linear infinite}
.mosaic-item{width:300px;height:200px;overflow:hidden;flex-shrink:0}
.mosaic-item img{width:100%;height:100%;object-fit:cover;filter:grayscale(.3) brightness(.75);transition:filter .4s}
.mosaic-item:hover img{filter:grayscale(0) brightness(1)}
@keyframes mosaicL{0%{transform:translateX(0)}100%{transform:translateX(calc(-304px * 6))}}
@keyframes mosaicR{0%{transform:translateX(calc(-304px * 6))}100%{transform:translateX(0)}}

/* ==========================================
   CERTIFICATIONS
   ========================================== */
.cert-strip{display:flex;justify-content:center;gap:32px;flex-wrap:wrap;padding:48px 0}
.cert-item{display:flex;flex-direction:column;align-items:center;gap:14px;padding:28px 36px;background:var(--surface);border:1px solid var(--border);border-radius:10px;transition:.35s var(--ease)}
.cert-item:hover{border-color:var(--accent-border);transform:translateY(-2px)}
.cert-item img{height:48px;width:auto;object-fit:contain;filter:brightness(.7) grayscale(.3);transition:filter .3s}
.cert-item:hover img{filter:brightness(1) grayscale(0)}
.cert-item span{font-size:12px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em}

/* ==========================================
   CTA SECTION
   ========================================== */
.cta-section{overflow:hidden}
.cta-bg{position:absolute;inset:0}
.cta-bg img{width:100%;height:100%;object-fit:cover}
.cta-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,5,5,.92) 0%,rgba(5,5,5,.88) 100%)}
.cta-inner{position:relative;z-index:1;text-align:center;padding:100px 32px}
.cta-h2{font-family:var(--display);font-size:clamp(32px,5vw,56px);font-weight:800;color:var(--white);line-height:1.1;margin-bottom:24px;letter-spacing:-.02em}
.cta-sub{font-size:17px;color:var(--gray-400);max-width:540px;margin:0 auto 36px;line-height:1.75}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.cta-simple{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.cta-has-bg{position:relative;background:transparent;border:none}
.cta-has-bg .cta-bg{position:absolute;inset:0}
.cta-has-bg .cta-bg img{width:100%;height:100%;object-fit:cover}
.cta-has-bg .cta-overlay{position:absolute;inset:0;background:rgba(5,5,5,.75)}
.cta-simple .cta-inner{padding:100px 32px}

/* ==========================================
   PAGE HERO (Sub-pages)
   ========================================== */
.page-hero{position:relative;min-height:50vh;display:flex;align-items:flex-end;overflow:hidden;padding-top:var(--nav-h)}
.page-hero-short{min-height:40vh}
.page-hero-bg{position:absolute;inset:0}
.page-hero-bg img{width:100%;height:100%;object-fit:cover}
.page-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,5,5,.65) 0%,rgba(5,5,5,.85) 75%,var(--bg) 100%)}
.page-hero-content{position:relative;z-index:1;padding-bottom:56px;max-width:1440px;margin:0 auto;width:100%;padding-left:clamp(32px,6vw,96px);padding-right:clamp(32px,6vw,96px)}
.page-hero-h1{font-family:var(--display);font-size:clamp(36px,6vw,72px);font-weight:800;line-height:1.05;color:var(--white);letter-spacing:-.02em}

/* ==========================================
   ABOUT PAGE
   ========================================== */
.about-story-grid{display:grid;grid-template-columns:1fr 1fr;gap:100px}
.about-story-right p{font-size:16px;color:var(--gray-400);line-height:1.85;margin-bottom:20px}
.about-img-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:1000px;margin:0 auto}
.about-img-item{overflow:hidden;border-radius:10px;position:relative;height:300px}
.about-img-tall{grid-row:span 2;height:100%}
.about-img-item img{width:100%;height:100%;object-fit:cover;filter:grayscale(.15);transition:.5s var(--ease)}
.about-img-item:hover img{filter:grayscale(0);transform:scale(1.03)}
.about-img-label{position:absolute;bottom:0;left:0;right:0;padding:24px 24px 20px;background:linear-gradient(0deg,rgba(0,0,0,.85) 0%,rgba(0,0,0,.55) 50%,transparent 100%);font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.6)}

/* Stats Band */
.stats-band{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:64px 0}
.stats-band-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:center}
.sb-stat{display:flex;flex-direction:column;align-items:center;gap:12px}
.sb-row{display:flex;align-items:baseline;justify-content:center;line-height:1}
.sb-num,.sb-prefix,.sb-suffix{font-family:var(--display);font-size:clamp(36px,4.5vw,56px);font-weight:800;color:var(--accent)}
.sb-label{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gray-500)}

/* Values */
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.value-card{padding:36px;background:var(--surface);border:1px solid var(--border);border-radius:10px;transition:.35s var(--ease)}
.value-card:hover{border-color:var(--accent-border);transform:translateY(-2px)}
.value-num{font-family:var(--mono);font-size:11px;color:var(--accent);opacity:.4;display:block;margin-bottom:14px}
.value-card h3{font-family:var(--display);font-size:17px;font-weight:700;color:var(--white);margin-bottom:10px}
.value-card p{font-size:14px;color:var(--gray-500);line-height:1.7}

/* Coverage */
.coverage-grid{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center}
.coverage-grid p{font-size:16px;color:var(--gray-400);line-height:1.85;margin-top:20px}
.coverage-locations{display:flex;flex-direction:column;gap:16px}
.cov-loc{display:flex;align-items:center;gap:16px;padding:18px 24px;background:var(--surface);border:1px solid var(--border);border-radius:10px;transition:.35s}
.cov-loc:hover{border-color:var(--accent-border)}
.cov-dot{width:8px;height:8px;border-radius:50%;background:var(--gray-600);flex-shrink:0}
.cov-dot.active{background:var(--accent);box-shadow:0 0 12px rgba(57,255,20,.3);animation:tagPulse 3s ease-in-out infinite}
.cov-loc strong{font-size:14px;color:var(--white);display:block}
.cov-loc span{font-size:12px;color:var(--gray-500)}

/* ==========================================
   PROJECTS PAGE
   ========================================== */
.project-filters{display:flex;gap:10px;margin-bottom:48px;flex-wrap:wrap}
.filter-btn{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:10px 22px;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--gray-500);cursor:pointer;transition:.3s var(--ease)}
.filter-btn:hover{border-color:var(--gray-600);color:var(--white)}
.filter-btn.active{background:var(--accent);border-color:var(--accent);color:var(--black)}

.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.proj-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:.4s var(--ease)}
.proj-card:hover{border-color:var(--accent-border);transform:translateY(-2px)}
.proj-hero-card{grid-column:span 3}
.proj-hero-card .proj-card-img{height:400px}
.proj-card-img{position:relative;height:240px;overflow:hidden}
.proj-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease);filter:brightness(.75)}
.proj-card:hover .proj-card-img img{transform:scale(1.04);filter:brightness(.95)}
.proj-card-overlay{position:absolute;top:16px;left:16px}
.proj-card-tag{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-light);background:rgba(5,5,5,.85);backdrop-filter:blur(8px);padding:7px 14px;border-radius:6px;border:1px solid var(--accent-border)}
.proj-card-body{padding:28px}
.proj-card-body h3{font-family:var(--display);font-size:18px;font-weight:700;color:var(--white);margin-bottom:10px;line-height:1.35}
.proj-hero-card .proj-card-body h3{font-size:24px}
.proj-card-body p{font-size:14px;color:var(--gray-500);line-height:1.7}
.proj-meta{display:flex;gap:16px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}
.proj-meta span{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-600)}

.proj-card.hidden{display:none}
.proj-card.anim-up{opacity:1;transform:none}

/* ==========================================
   CAREERS PAGE
   ========================================== */
.careers-intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:start}
.careers-intro-grid p{font-size:16px;color:var(--gray-400);line-height:1.85;margin-bottom:20px}

.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.benefit-card{padding:36px;background:var(--surface);border:1px solid var(--border);border-radius:10px;transition:.35s var(--ease)}
.benefit-card:hover{border-color:var(--accent-border);transform:translateY(-2px)}
.benefit-icon{width:44px;height:44px;margin-bottom:20px}
.benefit-icon svg{width:40px;height:40px;stroke:var(--accent)}
.benefit-card h3{font-family:var(--display);font-size:17px;font-weight:700;color:var(--white);margin-bottom:10px}
.benefit-card p{font-size:14px;color:var(--gray-500);line-height:1.7}

.team-photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.team-photo{overflow:hidden;border-radius:10px;height:280px}
.team-photo-wide{grid-column:span 3;height:280px}
.team-photo-wide img{object-position:center 40%}
.team-photo img{width:100%;height:100%;object-fit:cover;filter:grayscale(.2);transition:.5s var(--ease)}
.team-photo:hover img{filter:grayscale(0);transform:scale(1.03)}

.positions-list{display:flex;flex-direction:column;gap:10px;max-width:840px;margin:0 auto}
.position-card{display:flex;align-items:center;justify-content:space-between;padding:24px 28px;background:var(--surface);border:1px solid var(--border);border-radius:10px;transition:.35s var(--ease);gap:16px}
.position-card:hover{border-color:var(--accent-border)}
.position-info h3{font-size:16px;font-weight:600;color:var(--white);margin-bottom:8px}
.position-tags{display:flex;gap:8px;flex-wrap:wrap}
.position-tags span{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--gray-500);padding:5px 12px;background:var(--gray-900);border-radius:4px}

/* ==========================================
   CONTACT PAGE
   ========================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:start}
.contact-left p{font-size:16px;color:var(--gray-400);line-height:1.85;margin-bottom:36px}
.contact-cards{display:flex;flex-direction:column;gap:16px;margin-bottom:36px}
.contact-card{display:flex;gap:16px;align-items:flex-start;padding:24px;background:var(--surface);border:1px solid var(--border);border-radius:10px;transition:.35s}
.contact-card:hover{border-color:var(--accent-border)}
.contact-card-icon{width:44px;height:44px;min-width:44px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:var(--accent-subtle);border:1px solid var(--accent-border)}
.contact-card-icon svg{width:20px;height:20px;stroke:var(--accent)}
.contact-card h4{font-size:12px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.contact-card p{font-size:14px;color:var(--white);line-height:1.6}
.contact-certs{display:flex;gap:24px;align-items:center}
.contact-certs img{height:40px;width:auto;object-fit:contain;filter:brightness(.5) grayscale(.5)}

.contact-right{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:44px}
.contact-form h3{font-family:var(--display);font-size:22px;font-weight:700;color:var(--white);margin-bottom:28px}
.contact-form{display:flex;flex-direction:column;gap:22px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:8px}
.form-group label{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gray-500)}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:14px 16px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--white);font-family:var(--font);font-size:14px;outline:none;transition:border-color .25s}
.form-group select{-webkit-appearance:none;cursor:pointer}
.form-group textarea{resize:vertical;min-height:110px}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--gray-700)}

/* ==========================================
   FOOTER
   ========================================== */
.footer{background:var(--black);padding:80px 0 40px;border-top:1px solid var(--border)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-logo{height:auto;width:200px;margin-bottom:20px}
.footer-brand p{font-size:14px;color:var(--gray-600);line-height:1.7;max-width:300px}
.footer-col{display:flex;flex-direction:column;gap:10px}
.footer-col h4{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gray-500);margin-bottom:8px}
.footer-col a,.footer-col span{font-size:14px;color:var(--gray-600);transition:color .25s}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{display:flex;justify-content:space-between;padding-top:32px;border-top:1px solid var(--border)}
.footer-bottom span{font-size:12px;color:var(--gray-700)}

/* ==========================================
   ANIMATIONS
   ========================================== */
.anim-in{opacity:0;transform:translateY(24px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.anim-in.visible{opacity:1;transform:translateY(0)}
.anim-in[data-delay="1"]{transition-delay:.12s}
.anim-in[data-delay="2"]{transition-delay:.24s}
.anim-in[data-delay="3"]{transition-delay:.36s}
.anim-in[data-delay="4"]{transition-delay:.4s}
.anim-in[data-delay="5"]{transition-delay:.5s}
.anim-in[data-delay="6"]{transition-delay:.6s}
.anim-in[data-delay="7"]{transition-delay:.7s}

.anim-up{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.anim-up.visible{opacity:1;transform:translateY(0)}
.anim-up[data-delay="1"]{transition-delay:.12s}
.anim-up[data-delay="2"]{transition-delay:.24s}
.anim-up[data-delay="3"]{transition-delay:.36s}
.anim-up[data-delay="4"]{transition-delay:.48s}
.anim-up[data-delay="5"]{transition-delay:.6s}

/* ==========================================
   RESPONSIVE
   ========================================== */
@media(max-width:1024px){
    .section{padding:100px 0}
    .mission-grid,.about-story-grid,.careers-intro-grid,.coverage-grid,.contact-grid{grid-template-columns:1fr;gap:48px}
    .cap-grid{grid-template-columns:repeat(2,1fr)}
    .fp-grid{grid-template-columns:repeat(2,1fr)}
    .fp-large{grid-column:span 2;min-height:420px}
    .proj-grid{grid-template-columns:repeat(2,1fr)}
    .proj-hero-card{grid-column:span 2}
    .stats-band-grid{grid-template-columns:repeat(2,1fr);gap:24px}
    .values-grid{grid-template-columns:1fr 1fr}
    .benefits-grid{grid-template-columns:repeat(2,1fr)}
    .footer-top{grid-template-columns:1fr 1fr}
    .hero-stats{gap:32px;flex-wrap:wrap;justify-content:center}
    .trust-bar-inner{gap:32px}
}

@media(max-width:768px){
    :root{--nav-h:64px}
    .container{padding:0 20px}
    .section{padding:72px 0}

    /* Nav */
    .nav-links{display:none}
    .nav-burger{display:flex}
    .nav-logo img{height:52px}
    .nav-inner{padding:0 20px}

    /* Mobile nav overlay */
    .mobile-nav{display:block}
    .mobile-nav-inner{gap:24px;padding:0 32px}
    .mobile-nav-link{font-size:32px;font-weight:800;opacity:0;transform:translateY(20px);transition:opacity .4s var(--ease),transform .4s var(--ease),color .25s}
    .mobile-nav.active .mobile-nav-link{opacity:1;transform:translateY(0)}
    .mobile-nav.active .mobile-nav-link:nth-child(1){transition-delay:.05s}
    .mobile-nav.active .mobile-nav-link:nth-child(2){transition-delay:.1s}
    .mobile-nav.active .mobile-nav-link:nth-child(3){transition-delay:.15s}
    .mobile-nav.active .mobile-nav-link:nth-child(4){transition-delay:.2s}
    .mobile-nav.active .mobile-nav-link:nth-child(5){transition-delay:.25s}

    /* Hero */
    .hero-content{padding-top:calc(var(--nav-h) + 48px);padding-bottom:200px;padding-left:20px;padding-right:20px}
    .hero-h1{font-size:clamp(32px,10vw,48px)}
    .hero-sub{font-size:16px;margin-bottom:32px}
    .hero-tag{font-size:11px;letter-spacing:.15em;margin-bottom:20px}
    .hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:20px 16px;justify-items:center;padding:28px 20px}
    .hero-stat-divider{display:none}
    .hero-stat-num,.hero-stat-prefix,.hero-stat-suffix{font-size:clamp(28px,8vw,40px)}
    .hero-stat-label{font-size:9px;letter-spacing:.14em}
    .hero-scroll{display:none}

    /* Ticker */
    .ticker{padding:12px 0}
    .ticker-items span{font-size:12px}

    /* Trust bar */
    .trust-bar{padding:48px 0}
    .trust-bar-inner{flex-direction:column;gap:20px}
    .trust-bar-logos{gap:24px}
    .trust-bar-logos img{height:32px}

    /* Horizontal scroll text */
    .hscroll-text{padding:36px 0}

    /* Section headings */
    .section-head{margin-bottom:40px}
    .section-head-row{flex-direction:column;align-items:flex-start;gap:16px;margin-bottom:40px}
    .h2{margin-bottom:16px}
    .label{margin-bottom:16px}

    /* Capabilities */
    .cap-grid{grid-template-columns:1fr}
    .cap-img-wrap{height:200px}
    .cap-body{padding:24px 20px}
    .cap-body h3{font-size:17px}
    .cap-body p{font-size:13px}

    /* Featured projects */
    .fp-grid{grid-template-columns:1fr}
    .fp-large{grid-column:span 1;grid-row:span 1;min-height:300px}
    .fp-card{min-height:240px}
    .fp-info{padding:24px 20px}
    .fp-large .fp-info h3{font-size:22px}
    .fp-info h3{font-size:16px}
    .fp-info p{max-height:100px;opacity:1}

    /* Photo mosaic */
    .mosaic-item{width:220px;height:150px}

    /* Project grid */
    .proj-grid{grid-template-columns:1fr}
    .proj-hero-card{grid-column:span 1}
    .proj-hero-card .proj-card-img{height:240px}
    .proj-card-img{height:200px}
    .proj-card-body{padding:20px}
    .proj-card-body h3{font-size:16px}
    .proj-hero-card .proj-card-body h3{font-size:20px}

    /* Project filters — horizontal scroll on mobile */
    .project-filters{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:8px;gap:8px;scrollbar-width:none}
    .project-filters::-webkit-scrollbar{display:none}
    .filter-btn{white-space:nowrap;flex-shrink:0;padding:10px 18px}

    /* Stats band */
    .stats-band{padding:48px 0}
    .stats-band-grid{grid-template-columns:1fr 1fr;gap:28px 16px}
    .sb-num,.sb-prefix,.sb-suffix{font-size:clamp(32px,8vw,44px)}

    /* Values grid */
    .values-grid{grid-template-columns:1fr}
    .value-card{padding:28px 24px}

    /* Benefits */
    .benefits-grid{grid-template-columns:1fr}
    .benefit-card{padding:28px 24px}

    /* Team photos */
    .team-photo-grid{grid-template-columns:1fr}
    .team-photo{height:220px}
    .team-photo-wide{grid-column:span 1;height:220px}

    /* Positions */
    .positions-list{gap:12px}

    /* About images */
    .about-img-grid{grid-template-columns:1fr}
    .about-img-tall{grid-row:span 1;height:280px}
    .about-img-item{height:240px}

    /* Coverage */
    .coverage-map-wrap iframe{min-height:300px}

    /* Contact */
    .contact-right{padding:28px 20px;border-radius:10px}
    .contact-form h3{font-size:20px;margin-bottom:20px}
    .form-row{grid-template-columns:1fr}
    .form-group input,.form-group select,.form-group textarea{padding:14px;font-size:16px}

    /* CTA */
    .cta-inner{padding:72px 20px}
    .cta-h2{font-size:clamp(26px,7vw,40px)}
    .cta-sub{font-size:15px;margin-bottom:28px}

    /* Page hero (sub-pages) */
    .page-hero{min-height:40vh}
    .page-hero-short{min-height:32vh}
    .page-hero-content{padding-bottom:40px;padding-left:20px;padding-right:20px}
    .page-hero-h1{font-size:clamp(32px,10vw,52px)}

    /* Footer */
    .footer{padding:56px 0 32px}
    .footer-top{grid-template-columns:1fr;gap:32px;margin-bottom:32px}
    .footer-logo{width:160px;margin-bottom:12px}
    .footer-col{gap:8px}
    .footer-col h4{margin-bottom:4px}
    .footer-bottom{flex-direction:column;gap:8px;text-align:center}

    /* Cert strip */
    .cert-strip{gap:12px}
    .cert-item{padding:20px 24px}

    /* Circuit dividers less height on mobile */
    .circuit-divider{height:48px}

    /* Mission */
    .mission-right p{font-size:15px}
}

@media(max-width:480px){
    .container{padding:0 16px}
    .hero-content{padding-left:16px;padding-right:16px}
    .hero-h1{font-size:clamp(28px,9vw,40px)}
    .hero-btns,.cta-btns{flex-direction:column}
    .btn{width:100%;justify-content:center;padding:16px 24px;font-size:14px}
    .btn-sm{padding:12px 20px;font-size:13px}
    .stats-band-grid{grid-template-columns:1fr}
    .position-card{flex-direction:column;align-items:flex-start;gap:16px}
    .position-card .btn{width:100%}
    .fp-large{min-height:260px}
    .fp-card{min-height:220px}
    .mosaic-item{width:180px;height:120px}
    .contact-right{padding:24px 16px}
    .nav-inner{padding:0 16px}
    .page-hero-content{padding-left:16px;padding-right:16px}
    .mobile-nav-link{font-size:28px}
    .hero-stats{padding:24px 16px;gap:16px 12px}
    .hero-stat-num,.hero-stat-prefix,.hero-stat-suffix{font-size:clamp(24px,7vw,36px)}
}

/* ==========================================
   MOBILE TOUCH & UX ENHANCEMENTS
   ========================================== */
/* iOS safe areas for notched devices */
@supports(padding: env(safe-area-inset-bottom)){
    .footer-bottom{padding-bottom:env(safe-area-inset-bottom)}
    .mobile-nav-inner{padding-bottom:env(safe-area-inset-bottom)}
    .hero-bottom{padding-bottom:env(safe-area-inset-bottom)}
}

/* Better tap highlight on iOS */
@media(pointer:coarse){
    a,button,.btn,.cap-card,.fp-card,.proj-card,.filter-btn,.nav-burger{-webkit-tap-highlight-color:rgba(57,255,20,.1)}
    /* Minimum 44px touch targets */
    .nav-burger{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
    .filter-btn{min-height:44px}
    .btn{min-height:48px}
    .btn-sm{min-height:44px}
    .mobile-nav-link{min-height:48px;display:flex;align-items:center}
    .footer-col a{min-height:40px;display:inline-flex;align-items:center}
    /* Prevent text size adjustment on orientation change */
    html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
    /* Disable hover effects that feel wrong on touch */
    .cap-card:hover{transform:none}
    .value-card:hover{transform:none}
    .benefit-card:hover{transform:none}
    .proj-card:hover{transform:none}
    .cert-item:hover{transform:none}
    .fp-card:hover .fp-info p{max-height:100px;opacity:1}
    .cap-card:active{transform:scale(.98);transition-duration:.1s}
    .proj-card:active{transform:scale(.98);transition-duration:.1s}
    .fp-card:active{transform:scale(.99);transition-duration:.1s}
    .btn:active{transform:scale(.97);transition-duration:.1s}
    /* Form inputs at 16px prevent iOS zoom */
    .form-group input,.form-group select,.form-group textarea{font-size:16px}
}

/* ==========================================
   SCROLL PROGRESS BAR
   ========================================== */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-light));z-index:10001;transition:width .05s linear;box-shadow:0 0 12px rgba(57,255,20,.4)}

/* ==========================================
   CUSTOM CURSOR
   ========================================== */
.cursor-dot,.cursor-ring,.cursor-glow{pointer-events:none;position:fixed;top:0;left:0;z-index:99999;will-change:transform}
.cursor-dot{width:6px;height:6px;margin:-3px 0 0 -3px;background:var(--accent);border-radius:50%;transition:opacity .2s}
.cursor-dot.hovering{opacity:0}
.cursor-ring{width:40px;height:40px;margin:-20px 0 0 -20px;border:1.5px solid rgba(57,255,20,.4);border-radius:50%;transition:opacity .2s,border-color .2s,background .2s}
.cursor-ring.hovering{border-color:rgba(57,255,20,.6);background:rgba(57,255,20,.05)}
.cursor-glow{width:120px;height:120px;margin:-60px 0 0 -60px;border-radius:50%;background:radial-gradient(circle,rgba(57,255,20,.06) 0%,transparent 70%);transition:opacity .3s}

@media(pointer:coarse){
    .cursor-dot,.cursor-ring,.cursor-glow{display:none!important}
}

/* Hide default cursor on desktop when custom cursor is active */
@media(pointer:fine){
    body{cursor:none}
    a,button,.btn,.cap-card,.fp-card,.proj-card,.filter-btn,.nav-burger,input,select,textarea{cursor:none}
}

/* ==========================================
   TEXT SPLIT REVEAL
   ========================================== */
.split-word-wrap{display:inline-block;overflow:hidden;vertical-align:top}
.split-word{display:inline-block;transform:translateY(110%);transition:transform .7s cubic-bezier(.16,1,.3,1)}
.split-text.split-visible .split-word{transform:translateY(0)}

.split-char-wrap{display:inline-block;overflow:hidden}
.split-char{display:inline-block;transform:translateY(110%);transition:transform .5s cubic-bezier(.16,1,.3,1)}
.split-text.split-visible .split-char{transform:translateY(0)}

/* ==========================================
   IMAGE CLIP-REVEAL
   ========================================== */
.img-reveal{clip-path:inset(0 100% 0 0);transition:clip-path .9s cubic-bezier(.16,1,.3,1)}
.img-reveal.img-revealed{clip-path:inset(0 0% 0 0)}
.img-reveal img{transform:scale(1.15);transition:transform 1.2s cubic-bezier(.16,1,.3,1) .1s,filter .4s ease!important}
.img-reveal.img-revealed img{transform:scale(1);opacity:1!important}

/* ==========================================
   CIRCUIT DIVIDERS
   ========================================== */
.circuit-divider{position:relative;height:80px;overflow:visible;margin:0 auto;max-width:var(--container);padding:0 32px}
.circuit-divider svg{width:100%;height:100%;overflow:visible}
.circuit-path{fill:none;stroke:var(--accent);stroke-width:1.5;opacity:.3;transition:stroke-dashoffset 2s cubic-bezier(.16,1,.3,1)}
.circuit-path.circuit-animate{stroke-dashoffset:0!important}
.circuit-node{fill:var(--accent);opacity:0;transition:opacity .4s ease,r .4s ease;r:0}
.circuit-node.circuit-node-visible{opacity:.6;r:4}

/* ==========================================
   CARD SHINE EFFECT
   ========================================== */
.card-shine{position:absolute;inset:0;border-radius:inherit;pointer-events:none;opacity:0;transition:opacity .4s;z-index:1}

/* ==========================================
   SECTION VISIBILITY GLOW
   ========================================== */
.section::before{content:'';position:absolute;top:-1px;left:50%;transform:translateX(-50%);width:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);transition:width 1.2s cubic-bezier(.16,1,.3,1);opacity:.3}
.section.section-visible::before{width:60%}

/* ==========================================
   RESPONSIVE
   ========================================== */
/* ==========================================
   NOISE / GRAIN OVERLAY
   ========================================== */
.noise-overlay{position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.035;mix-blend-mode:overlay}
.noise-overlay canvas{width:100%;height:100%}

/* ==========================================
   ANIMATED GRADIENT MESH (Hero)
   ========================================== */
.hero-gradient-mesh{position:absolute;inset:0;z-index:0;overflow:hidden;opacity:.4}
.hero-gradient-mesh .mesh-blob{position:absolute;border-radius:50%;filter:blur(120px);will-change:transform;animation:meshFloat 20s ease-in-out infinite alternate}
.mesh-blob-1{width:600px;height:600px;background:rgba(57,255,20,.12);top:-20%;left:-10%;animation-delay:0s!important}
.mesh-blob-2{width:500px;height:500px;background:rgba(57,255,20,.08);bottom:-15%;right:-5%;animation-delay:-7s!important;animation-duration:25s!important}
.mesh-blob-3{width:400px;height:400px;background:rgba(57,255,20,.06);top:40%;left:50%;animation-delay:-12s!important;animation-duration:22s!important}
@keyframes meshFloat{
    0%{transform:translate(0,0) scale(1)}
    25%{transform:translate(60px,-40px) scale(1.1)}
    50%{transform:translate(-30px,50px) scale(.95)}
    75%{transform:translate(40px,20px) scale(1.05)}
    100%{transform:translate(-20px,-30px) scale(1)}
}

/* ==========================================
   BUTTON RIPPLE EFFECT
   ========================================== */
.btn{overflow:hidden}
.btn-ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,.25);transform:scale(0);animation:rippleOut .6s ease-out forwards;pointer-events:none}
@keyframes rippleOut{to{transform:scale(4);opacity:0}}

/* ==========================================
   NAV LINK SLIDING UNDERLINE
   ========================================== */
.nav-link:not(.nav-cta){position:relative}
.nav-link:not(.nav-cta)::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--accent);transition:width .35s var(--ease)}
.nav-link:not(.nav-cta):hover::after,.nav-link:not(.nav-cta).active::after{width:100%}

/* ==========================================
   FLOATING PARTICLES (Hero)
   ========================================== */
.hero-particles{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.hero-particle{position:absolute;border-radius:50%;background:var(--accent);opacity:0;animation:particleDrift linear infinite}
@keyframes particleDrift{
    0%{transform:translateY(100vh) translateX(0) scale(0);opacity:0}
    10%{opacity:.4}
    90%{opacity:.4}
    100%{transform:translateY(-20vh) translateX(var(--drift-x,30px)) scale(1);opacity:0}
}

/* ==========================================
   GRADIENT BORDER GLOW ON CARDS
   ========================================== */
.cap-card::before,.value-card::before,.benefit-card::before,.cert-item::before,.proj-card::before,.contact-card::before{
    content:'';position:absolute;inset:-1px;border-radius:inherit;padding:1px;
    background:linear-gradient(135deg,transparent 40%,rgba(57,255,20,.3) 50%,transparent 60%);
    background-size:300% 300%;background-position:0% 0%;
    -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
    -webkit-mask-composite:xor;mask-composite:exclude;
    opacity:0;transition:opacity .4s ease;pointer-events:none;z-index:2
}
.cap-card:hover::before,.value-card:hover::before,.benefit-card:hover::before,.cert-item:hover::before,.proj-card:hover::before,.contact-card:hover::before{
    opacity:1;animation:borderGlow 2s linear infinite
}
@keyframes borderGlow{
    0%{background-position:0% 0%}
    100%{background-position:300% 300%}
}
.cap-card,.value-card,.benefit-card,.cert-item,.proj-card,.contact-card{position:relative}

/* ==========================================
   PAGE TRANSITION OVERLAY
   ========================================== */
.page-transition{position:fixed;inset:0;z-index:99999;pointer-events:none}
.page-transition .pt-curtain{position:absolute;inset:0;background:var(--black);transform:translateY(100%);will-change:transform}
.page-transition .pt-accent{position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;will-change:opacity,transform}
.page-transition .pt-logo{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.8);opacity:0;will-change:opacity,transform;width:60px;height:auto;filter:brightness(0) invert(1)}

/* ==========================================
   PARALLAX FLOATING SHAPES
   ========================================== */
.floating-shapes{position:fixed;inset:0;pointer-events:none;z-index:-1;overflow:hidden}
.float-shape{position:absolute;border:1px solid rgba(57,255,20,.08);opacity:0;transition:opacity 1s ease}
.float-shape.visible{opacity:1}
.float-shape-1{width:200px;height:200px;border-radius:50%;top:15%;right:8%}
.float-shape-2{width:120px;height:120px;top:55%;left:3%;transform:rotate(45deg)}
.float-shape-3{width:80px;height:80px;border-radius:50%;bottom:20%;right:15%}
.float-shape-4{width:160px;height:1px;background:linear-gradient(90deg,transparent,rgba(57,255,20,.1),transparent);top:35%;left:10%;border:none}

/* ==========================================
   ENHANCED FORM FOCUS
   ========================================== */
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
    border-color:var(--accent);
    box-shadow:0 0 0 3px rgba(57,255,20,.08),0 0 20px rgba(57,255,20,.06);
}
.form-group{position:relative}
.form-group label{transition:color .25s}
.form-group:focus-within label{color:var(--accent)}

/* ==========================================
   HORIZONTAL SCROLL TEXT
   ========================================== */
.hscroll-text{overflow:hidden;padding:60px 0;white-space:nowrap}
.hscroll-text-inner{font-family:var(--display);font-size:clamp(60px,10vw,140px);font-weight:800;color:transparent;-webkit-text-stroke:1px var(--border-light);letter-spacing:-.02em;will-change:transform;display:inline-block}
.hscroll-text-inner .hscroll-filled{-webkit-text-stroke:0;color:var(--white);opacity:.06}

/* ==========================================
   STAGGER SCALE-IN (for logos, certs)
   ========================================== */
.scale-in{opacity:0;transform:scale(.85);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.scale-in.visible{opacity:1;transform:scale(1)}

/* ==========================================
   GLOW PULSE ON ACCENT ELEMENTS
   ========================================== */
.accent-glow{position:relative}
.accent-glow::after{content:'';position:absolute;inset:-2px;border-radius:inherit;background:var(--accent);opacity:0;filter:blur(16px);z-index:-1;transition:opacity .4s}
.accent-glow:hover::after{opacity:.15;animation:glowPulse 2s ease-in-out infinite}
@keyframes glowPulse{0%,100%{opacity:.15}50%{opacity:.25}}

/* ==========================================
   SMOOTH IMAGE ZOOM ON SCROLL
   ========================================== */
.scroll-zoom{overflow:hidden}
.scroll-zoom img{transition:transform .1s linear;will-change:transform}

/* ==========================================
   NAV "POWERED ON" INDICATOR
   ========================================== */
.nav-status{display:flex;align-items:center;gap:6px;position:absolute;left:220px;top:50%;transform:translateY(-50%)}
.nav-status-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px rgba(57,255,20,.4);animation:tagPulse 3s ease-in-out infinite}
.nav-status-text{font-family:var(--mono);font-size:9px;letter-spacing:.15em;color:var(--accent);text-transform:uppercase;opacity:.7;transition:opacity .4s}
.nav.scrolled .nav-status-text{opacity:0}

/* ==========================================
   NEON TEXT GLOW
   ========================================== */
.label,.hero-tag,.fp-tag,.proj-card-tag{
    text-shadow:0 0 7px rgba(57,255,20,.3),0 0 20px rgba(57,255,20,.15),0 0 40px rgba(57,255,20,.08)
}
@keyframes neonPulse{
    0%,100%{text-shadow:0 0 7px rgba(57,255,20,.3),0 0 20px rgba(57,255,20,.15),0 0 40px rgba(57,255,20,.08)}
    50%{text-shadow:0 0 10px rgba(57,255,20,.5),0 0 30px rgba(57,255,20,.25),0 0 60px rgba(57,255,20,.12)}
}
.hero-tag{animation:neonPulse 4s ease-in-out infinite}

/* ==========================================
   POWER GRID BACKGROUND
   ========================================== */
.power-grid-bg{
    background-image:
        linear-gradient(rgba(57,255,20,.03) 1px,transparent 1px),
        linear-gradient(90deg,rgba(57,255,20,.03) 1px,transparent 1px);
    background-size:50px 50px
}

/* ==========================================
   SECTION WIPE (clip-path scrubbed via GSAP)
   ========================================== */
.section-wipe{clip-path:inset(100% 0 0 0)}

/* ==========================================
   CIRCUIT CURRENT DOTS
   ========================================== */
.circuit-current-dot{
    fill:var(--accent);
    filter:drop-shadow(0 0 6px rgba(57,255,20,.8));
    opacity:0
}

/* ==========================================
   LIGHTNING FLASH OVERLAY
   ========================================== */
.lightning-flash{
    position:fixed;inset:0;z-index:99998;
    pointer-events:none;opacity:0;
    background:linear-gradient(135deg,rgba(57,255,20,.08),rgba(255,255,255,.06));
    mix-blend-mode:screen
}

/* ==========================================
   VOLTAGE METER STAT COUNTERS
   ========================================== */
.stat-voltage-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center}
.stat-voltage-svg{position:absolute;width:100px;height:100px;top:50%;left:50%;transform:translate(-50%,-50%);opacity:.25}
.stat-voltage-bg{fill:none;stroke:var(--border);stroke-width:2}
.stat-voltage-fill{fill:none;stroke:var(--accent);stroke-width:2;stroke-linecap:round;transition:stroke-dashoffset 2s cubic-bezier(.16,1,.3,1)}
.stat-voltage-tick{stroke:var(--gray-700);stroke-width:.5}

/* ==========================================
   CLICK SPARK PARTICLES
   ========================================== */
.click-spark{
    position:fixed;width:2px;height:2px;
    border-radius:50%;pointer-events:none;z-index:99997;
    background:var(--accent)
}

/* ==========================================
   THREE.JS PARTICLE CANVAS
   ========================================== */
.hero-three-canvas{
    position:absolute;inset:0;z-index:0;
    pointer-events:none;opacity:.15
}
.hero-three-canvas canvas{width:100%!important;height:100%!important}

/* ==========================================
   FILTER PILL SLIDER
   ========================================== */
.project-filters{position:relative}
.filter-pill{
    position:absolute;height:100%;
    background:var(--accent);border-radius:6px;
    transition:left .35s var(--ease),width .35s var(--ease);
    z-index:0;pointer-events:none;top:0
}
.filter-btn{position:relative;z-index:1}

/* ==========================================
   COVERAGE MAP
   ========================================== */
.coverage-address{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border)}
.coverage-address h4{font-family:var(--mono);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem}
.coverage-address p{color:var(--text-secondary);font-size:.95rem;line-height:1.7;margin-bottom:.5rem}
.coverage-map-wrap{position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--border)}
.coverage-map-wrap iframe{display:block;filter:invert(90%) hue-rotate(180deg) saturate(.3) brightness(.6) contrast(1.2)}
.coverage-route{stroke-dasharray:8 4}
.coverage-pin.pin-visible{opacity:1}

/* ==========================================
   FORM VALIDATION
   ========================================== */
.form-group.valid input,.form-group.valid select,.form-group.valid textarea{border-color:var(--accent)}
.form-group.valid label::after{
    content:' ✓';color:var(--accent);font-size:12px
}
.form-submit-success .submit-spinner{
    width:18px;height:18px;border:2px solid rgba(5,5,5,.2);
    border-top-color:var(--black);border-radius:50%;
    animation:submitSpin .6s linear infinite;display:inline-block
}
@keyframes submitSpin{to{transform:rotate(360deg)}}

/* ==========================================
   CTA VIBRATION (electrical hum)
   ========================================== */
@keyframes electricHum{
    0%,100%{transform:translate(0,0)}
    25%{transform:translate(.3px,-.2px)}
    50%{transform:translate(-.3px,.2px)}
    75%{transform:translate(.2px,.3px)}
}
.electric-hum{animation:electricHum .15s linear infinite}

/* ==========================================
   FEATURED CARD BORDER TRACE
   ========================================== */
@property --border-angle{syntax:'<angle>';initial-value:0deg;inherits:false}
.fp-card{position:relative}
.fp-card::after{
    content:'';position:absolute;inset:0;z-index:2;pointer-events:none;
    border:1px solid rgba(57,255,20,.35);
    opacity:0;transition:opacity .3s
}
.fp-card:hover::after{opacity:1}

/* ==========================================
   URGENTLY HIRING PULSE
   ========================================== */
.position-urgent{position:relative}
.position-urgent::before{
    content:'Urgently Hiring';position:absolute;top:8px;right:80px;
    font-family:var(--mono);font-size:9px;letter-spacing:.1em;
    text-transform:uppercase;color:var(--accent);
    padding:4px 8px;border:1px solid var(--accent-border);
    border-radius:4px;animation:urgentPulse 2s ease-in-out infinite
}
@keyframes urgentPulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ==========================================
   KEN BURNS TEAM PHOTO
   ========================================== */
.team-photo-wide img{animation:kenBurns 20s ease-in-out infinite alternate}
@keyframes kenBurns{
    0%{transform:scale(1) translate(0,0)}
    100%{transform:scale(1.08) translate(-2%,-1%)}
}

/* ==========================================
   CONTACT CARD HOVER ENHANCE
   ========================================== */
.contact-card-icon{transition:transform .4s var(--ease),background .4s}
.contact-card:hover .contact-card-icon{transform:rotate(8deg) scale(1.1);background:rgba(57,255,20,.12)}

/* ==========================================
   CAP-NUM WATERMARK
   ========================================== */
.cap-num-watermark{
    position:absolute;top:20px;right:20px;
    font-family:var(--display);font-size:80px;font-weight:800;
    color:var(--white);opacity:.03;line-height:1;pointer-events:none
}

/* ==========================================
   WEBGL NOISE CANVAS
   ========================================== */
.noise-webgl{position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.035;mix-blend-mode:overlay}
.noise-webgl canvas{width:100%;height:100%}

/* ==========================================
   PREFERS REDUCED MOTION
   ========================================== */
@media(prefers-reduced-motion:reduce){
    *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
    .anim-in,.anim-up{opacity:1;transform:none}
    .split-word,.split-char{transform:none!important}
    .img-reveal{clip-path:none!important}
    .img-reveal img{transform:none!important;opacity:1!important}
    .circuit-path{stroke-dashoffset:0!important}
    .circuit-node{opacity:.6!important;r:4!important}
    .section::before{width:60%!important}
    .hero-gradient-mesh,.hero-particles,.floating-shapes,.noise-overlay,.noise-webgl{display:none!important}
    .page-transition,.lightning-flash{display:none!important}
    .btn-ripple,.click-spark{display:none!important}
    .scale-in{opacity:1!important;transform:none!important}
    .hscroll-text-inner{transform:none!important}
    .hero-three-canvas{display:none!important}
    .electric-hum{animation:none!important}
    .section-wipe{clip-path:none!important}
    .coverage-pin{opacity:1!important}
    .preloader-circuit-lines{display:none!important}
    .fp-card::after{display:none!important}
    .team-photo-wide img{animation:none!important}
}

/* ==========================================
   RESPONSIVE — POWERED ON HIDE ON MOBILE
   ========================================== */
@media(max-width:1024px){
    .nav-status{display:none}
}
@media(pointer:coarse){
    .click-spark{display:none!important}
}

/* ==========================================
   MOBILE NAV — SMOOTH OPEN/CLOSE
   ========================================== */
.mobile-nav{transition:opacity .35s var(--ease),visibility .35s}
.mobile-nav.active{transition:opacity .35s var(--ease)}
