/* ============================================================
   MOTA GROUP — MASTER STYLESHEET
   Shared across all pages. Do not fork per-page styles unless
   the component is genuinely page-specific (see bottom sections).
   ============================================================ */

:root{
  --charcoal:#1E1E1E;
  --graphite:#33383F;
  --concrete:#B7B9BC;
  --offwhite:#F4F5F6;
  --deepblue:#0D1B2A;
  --forest:#1F2F28;
  --copper:#B87333;
  --bg:#141414;
  --panel:#1A1A1A;
  --shade-1:#131313;
  --shade-2:#171717;
  --shade-3:#0F0F0F;
  --shade-4:#202020;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'IBM Plex Sans',sans-serif;
  background:var(--bg);
  color:var(--offwhite);
  font-weight:300;
  overflow-x:hidden;
  opacity:1;
  transition:opacity .22s ease;
}
body.page-transitioning{opacity:0;}
a{text-decoration:none;color:inherit;}
img{display:block;max-width:100%;}
ul{list-style:none;}
button{font-family:inherit;}

.reveal{opacity:0;transform:translateY(28px);transition:opacity 1s cubic-bezier(.16,.84,.44,1), transform 1s cubic-bezier(.16,.84,.44,1);}
.reveal.in{opacity:1;transform:translateY(0);}
.reveal-delay-1.in{transition-delay:.12s;}
.reveal-delay-2.in{transition-delay:.24s;}
.reveal-delay-3.in{transition-delay:.36s;}
.reveal-delay-4.in{transition-delay:.48s;}

::selection{background:var(--copper);color:#fff;}

/* ===== SCROLLBAR (subtle, premium) ===== */
::-webkit-scrollbar{width:9px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:#2c2c2c;border-radius:0;}
::-webkit-scrollbar-thumb:hover{background:var(--copper);}

/* ===== PAGE LOADER ===== */
#page-loader{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .6s ease, visibility .6s ease;}
#page-loader.done{opacity:0;visibility:hidden;pointer-events:none;}
.loader-mark{width:34px;height:34px;border:1px solid rgba(184,115,51,.3);border-top-color:var(--copper);border-radius:50%;animation:loaderSpin .9s linear infinite;}
@keyframes loaderSpin{to{transform:rotate(360deg);}}

/* ===== NAV ===== */
nav{position:fixed;top:0;left:0;right:0;z-index:400;display:flex;align-items:center;justify-content:space-between;padding:24px 48px;background:linear-gradient(180deg, rgba(10,10,10,.6) 0%, rgba(10,10,10,0) 100%);transition:background .4s ease, padding .4s ease;}
nav.scrolled,
body.subpage nav{background:rgba(10,10,10,.92);backdrop-filter:blur(14px);padding:16px 48px;border-bottom:1px solid rgba(255,255,255,.06);}
.nav-logo{display:flex;align-items:center;gap:10px;}
.nav-logo img{height:30px;width:auto;transition:height .4s ease;}
nav.scrolled .nav-logo img,
body.subpage .nav-logo img{height:25px;}
.nav-links{display:flex;gap:38px;list-style:none;align-items:center;}
.nav-links > li{position:relative;}
.nav-links a{font-size:11.5px;letter-spacing:.14em;color:rgba(244,245,246,.85);text-transform:uppercase;position:relative;padding-bottom:4px;font-weight:500;display:inline-flex;align-items:center;gap:6px;}
.nav-links > li > a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--copper);transition:width .35s ease;}
.nav-links a:hover{color:#fff;}
.nav-links > li > a:hover::after{width:100%;}
.nav-links > li.current > a{color:#fff;}
.nav-links > li.current > a::after{width:100%;}
.nav-caret{width:8px;height:8px;stroke:currentColor;transition:transform .3s ease;}
.nav-links > li:hover .nav-caret{transform:rotate(180deg);}
.nav-cta{border:1px solid rgba(255,255,255,.3);color:#fff;padding:10px 22px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;transition:all .3s ease;}
.nav-cta:hover{background:#fff;color:var(--charcoal);border-color:#fff;}
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:300;background:none;border:none;padding:6px;}
.nav-burger span{width:22px;height:1px;background:#fff;display:block;transition:transform .3s ease, opacity .3s ease;}

/* Dropdown */
.nav-dropdown{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(6px);min-width:220px;background:rgba(14,14,14,.98);border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(16px);padding:10px;opacity:0;visibility:hidden;transition:opacity .28s ease, transform .28s ease, visibility .28s ease;box-shadow:0 24px 48px rgba(0,0,0,.5);}
.nav-links > li:hover .nav-dropdown,
.nav-links > li:focus-within .nav-dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.nav-dropdown a{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;font-size:11px;letter-spacing:.1em;color:rgba(244,245,246,.80);border-left:2px solid transparent;transition:all .25s ease;}
.nav-dropdown a::after{display:none;}
.nav-dropdown a:hover{color:#fff;background:rgba(184,115,51,.08);border-left-color:var(--copper);padding-left:18px;}
.nav-dropdown a span.dd-tag{font-size:9px;color:rgba(255,255,255,.32);letter-spacing:.06em;text-transform:none;}

/* Mobile nav panel */
.mobile-panel{position:fixed;inset:0;background:rgba(10,10,10,.98);backdrop-filter:blur(20px);z-index:390;display:flex;flex-direction:column;justify-content:center;padding:40px;opacity:0;visibility:hidden;transition:opacity .4s ease, visibility .4s ease;}
.mobile-panel.open{opacity:1;visibility:visible;}
.mobile-panel ul{display:flex;flex-direction:column;gap:6px;}
.mobile-panel a{font-size:26px;font-weight:600;text-transform:uppercase;letter-spacing:-.01em;color:#fff;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.06);display:block;}
.mobile-panel .mobile-sub{display:flex;flex-direction:column;max-height:0;overflow:hidden;transition:max-height .4s ease;}
.mobile-panel li.open .mobile-sub{max-height:260px;}
.mobile-panel .mobile-sub a{font-size:14px;font-weight:400;text-transform:none;padding:10px 0 10px 16px;border-bottom:none;color:rgba(255,255,255,.6);}
.mobile-toggle-caret{float:right;transition:transform .3s ease;}
.mobile-panel li.open .mobile-toggle-caret{transform:rotate(180deg);}

/* ===== SECTION SHARED ===== */
.label{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--copper);margin-bottom:18px;font-weight:600;}
section{padding:120px 48px;}
.btn{display:inline-flex;align-items:center;gap:12px;padding:16px 30px;border:1px solid var(--copper);color:#fff;font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;transition:all .3s ease;white-space:nowrap;position:relative;overflow:hidden;cursor:pointer;background:transparent;}
.btn span{position:relative;z-index:2;display:inline-flex;align-items:center;gap:12px;}
.btn::before{content:'';position:absolute;inset:0;background:var(--copper);transform:scaleX(0);transform-origin:left;transition:transform .35s cubic-bezier(.16,.84,.44,1);z-index:1;}
.btn:hover::before{transform:scaleX(1);}
.btn svg{width:13px;height:13px;stroke:currentColor;transition:transform .3s ease;}
.btn:hover svg{transform:translateX(3px);}
.btn-block{width:100%;justify-content:center;}

/* Breadcrumb (subpages) */
.crumb{padding:150px 48px 0;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4);display:flex;gap:10px;align-items:center;}
.crumb a{color:rgba(255,255,255,.4);transition:color .25s ease;}
.crumb a:hover{color:var(--copper);}
.crumb svg{width:10px;height:10px;stroke:currentColor;opacity:.5;}
.crumb .current{color:rgba(255,255,255,.75);}

/* ===== HERO (home) ===== */
.hero{position:relative;height:100vh;min-height:740px;width:100%;overflow:hidden;background:#0a0a0a;display:flex;align-items:center;}
.hero-bg{position:absolute;inset:0;background-image:
    linear-gradient(90deg, rgba(8,8,8,0.22) 0%, rgba(8,8,8,0.05) 45%, rgba(8,8,8,0.22) 100%),
    linear-gradient(0deg, rgba(8,8,8,0.4) 0%, rgba(8,8,8,0.03) 35%, rgba(8,8,8,0.09) 100%),
    url('../images/hero-electrical-truck.jpg');
  background-size:cover;background-position:center 38%;
  transform:scale(1.08);animation:heroZoom 22s ease-out forwards;
  filter:contrast(1.03) saturate(0.79) brightness(0.85);
}
@keyframes heroZoom{to{transform:scale(1);}}
.hero-content{position:relative;z-index:3;padding:0 48px;max-width:780px;}
.hero-eyebrow{font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--copper);margin-bottom:22px;font-weight:600;}
.hero-title{font-size:clamp(38px,5.6vw,68px);line-height:1.04;font-weight:700;color:#fff;letter-spacing:-.02em;text-transform:uppercase;margin-bottom:26px;}
.hero-sub{font-size:15px;line-height:1.75;color:rgba(244,245,246,.72);font-weight:300;max-width:380px;margin-bottom:36px;}
.hero-actions{display:flex;gap:28px;align-items:center;flex-wrap:wrap;}
.hero-link{display:inline-flex;align-items:center;gap:10px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#fff;font-weight:600;border-bottom:1px solid rgba(255,255,255,.3);padding-bottom:8px;transition:border-color .3s ease;}
.hero-link:hover{border-color:var(--copper);}
.hero-link svg{width:13px;height:13px;stroke:var(--copper);transition:transform .3s ease;}
.hero-link:hover svg{transform:translateX(4px);}
.hero-scroll{position:absolute;bottom:36px;right:48px;z-index:3;display:flex;flex-direction:column;align-items:center;gap:10px;color:rgba(244,245,246,.58);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;}
.hero-scroll-line{width:1px;height:40px;background:rgba(255,255,255,.2);position:relative;overflow:hidden;}
.hero-scroll-line::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--copper);animation:scrollLine 2.4s ease-in-out infinite;}
@keyframes scrollLine{0%{top:-100%;}50%{top:0;}100%{top:100%;}}

/* Generic inner-page hero (About / Companies / Contact / Project) */
.page-hero{position:relative;min-height:64vh;width:100%;overflow:hidden;background:#0a0a0a;display:flex;align-items:flex-end;padding-bottom:80px;}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.06);animation:heroZoom 20s ease-out forwards;}
.page-hero-bg::after{content:'';position:absolute;inset:0;background:
    linear-gradient(0deg, rgba(8,8,8,0.6) 0%, rgba(8,8,8,0.15) 60%, rgba(8,8,8,0.28) 100%),
    linear-gradient(90deg, rgba(8,8,8,0.34) 0%, rgba(8,8,8,0.03) 45%);
}
.page-hero-bg img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(0.73) brightness(0.73);position:absolute;inset:0;}
.page-hero-content{position:relative;z-index:2;padding:0 48px;max-width:820px;}
.page-hero-kicker{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--copper);margin-bottom:20px;font-weight:600;display:flex;align-items:center;gap:12px;}
.page-hero-kicker::before{content:'';width:28px;height:1px;background:var(--copper);}
.page-hero-lines{display:flex;flex-direction:column;}
.page-hero-lines span{display:block;overflow:hidden;}
.page-hero-lines span b{display:block;transform:translateY(110%);transition:transform .9s cubic-bezier(.16,.84,.44,1);font-weight:700;}
.page-hero-lines.in span b{transform:translateY(0);}
.page-hero-lines span:nth-child(2) b{transition-delay:.08s;}
.page-hero-lines span:nth-child(3) b{transition-delay:.16s;}
.page-hero-sub{font-size:15px;line-height:1.8;color:rgba(244,245,246,.70);max-width:480px;margin-top:24px;font-weight:300;}

/* ===== STAT STRIP (reusable) ===== */
.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06);}
.stat-cell{padding:56px 40px;border-left:1px solid rgba(255,255,255,.06);}
.stat-cell:first-child{border-left:none;}
.stat-num{font-size:clamp(32px,3.4vw,46px);font-weight:700;color:#fff;letter-spacing:-.02em;display:flex;align-items:baseline;gap:4px;}
.stat-num .suffix{font-size:.5em;color:var(--copper);font-weight:600;}
.stat-lbl{font-size:11px;color:rgba(244,245,246,.58);letter-spacing:.08em;text-transform:uppercase;margin-top:10px;line-height:1.5;}

/* ===== COMPANIES — homepage teaser (hover only, click navigates) ===== */
.companies{display:grid;grid-template-columns:380px 1fr;gap:0;align-items:stretch;border-top:1px solid rgba(255,255,255,.06);}
.companies-intro{padding:120px 48px;display:flex;flex-direction:column;justify-content:center;}
.companies-intro h2{font-size:clamp(28px,2.8vw,38px);font-weight:600;line-height:1.18;letter-spacing:-.01em;color:#fff;margin-bottom:22px;}
.companies-intro p{font-size:14.5px;line-height:1.8;color:rgba(244,245,246,.62);font-weight:300;max-width:300px;margin-bottom:30px;}
.co-rail{display:flex;position:relative;}
.co-panel{
  position:relative;width:25%;overflow:hidden;cursor:pointer;
  transition:width .55s cubic-bezier(.16,.84,.44,1);
  border-left:1px solid rgba(255,255,255,.06);
  display:block;
}
.co-panel.active{width:34%;}
.co-panel img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:contrast(1.08) saturate(0.85) brightness(0.77);transition:filter .5s ease, transform 1.2s cubic-bezier(.16,.84,.44,1);transform:scale(1.06);}
.co-panel.active img,
.co-panel:hover img{filter:contrast(1.03) saturate(1.0) brightness(0.85);transform:scale(1.14);}
.co-panel::after{content:'';position:absolute;inset:0;background:linear-gradient(0deg, rgba(8,8,8,0.57) 0%, rgba(8,8,8,0.06) 55%);z-index:1;transition:background .4s ease;}
.co-panel:hover::after{background:linear-gradient(0deg, rgba(8,8,8,0.55) 0%, rgba(184,115,51,.14) 100%);}
.co-content{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;padding:24px 22px;}
.co-index{font-size:11px;color:var(--copper);letter-spacing:.12em;margin-bottom:auto;font-weight:600;}
.co-name{font-size:17px;font-weight:600;color:#fff;letter-spacing:-.01em;text-transform:uppercase;margin-bottom:6px;}
.co-tag{font-size:12px;color:rgba(244,245,246,.62);line-height:1.5;font-weight:300;}
.co-arrow{width:34px;height:34px;border:1px solid rgba(255,255,255,.25);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:16px;opacity:0;transform:translateX(-8px);transition:opacity .35s ease, transform .35s ease, border-color .3s ease, background .3s ease;}
.co-panel:hover .co-arrow,
.co-panel.active .co-arrow{opacity:1;transform:translateX(0);}
.co-panel:hover .co-arrow{background:var(--copper);border-color:var(--copper);}
.co-arrow svg{width:13px;height:13px;stroke:#fff;}

/* ===== TRUST ===== */
.trust{border-top:1px solid rgba(255,255,255,.06);}
.trust-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:0;align-items:stretch;}
.trust-img{position:relative;overflow:hidden;min-height:520px;}
.trust-img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;filter:contrast(1.03) saturate(0.79) brightness(0.77);}
.trust-content{padding:120px 48px;display:flex;flex-direction:column;justify-content:center;}
.trust-content h2{font-size:clamp(26px,2.8vw,38px);font-weight:600;line-height:1.2;letter-spacing:-.01em;color:#fff;margin-bottom:48px;max-width:440px;}
.trust-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;}
.ts-icon{width:30px;height:30px;border:1px solid var(--copper);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:18px;}
.ts-icon svg{width:14px;height:14px;stroke:var(--copper);}
.ts-num{font-size:28px;font-weight:600;color:#fff;letter-spacing:-.01em;}
.ts-label{font-size:10.5px;color:rgba(244,245,246,.58);letter-spacing:.08em;text-transform:uppercase;margin-top:8px;line-height:1.5;}

/* ===== CTA BAND (reusable, every page ends on one) ===== */
.cta{position:relative;overflow:hidden;min-height:340px;display:flex;align-items:center;border-top:1px solid rgba(255,255,255,.06);}
.cta-bg{position:absolute;inset:0;background-image:url('../images/cta-bg.jpg');background-size:cover;background-position:center;filter:contrast(1.03) saturate(0.75) brightness(0.52);}
.cta-overlay{position:absolute;inset:0;background:linear-gradient(90deg, rgba(8,8,8,0.43) 0%, rgba(8,8,8,0.22) 100%);}
.cta-inner{position:relative;z-index:2;width:100%;display:flex;justify-content:space-between;align-items:center;padding:0 48px;gap:40px;flex-wrap:wrap;}
.cta-inner h2{font-size:clamp(26px,3.2vw,42px);font-weight:600;letter-spacing:-.01em;line-height:1.2;color:#fff;max-width:520px;text-transform:none;}

/* ===== FOOTER ===== */
footer{background:#0e0e0e;padding:70px 48px 28px;border-top:1px solid rgba(255,255,255,.06);}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;max-width:1400px;margin:0 auto 54px;padding-bottom:54px;border-bottom:1px solid rgba(255,255,255,.06);}
.footer-brand{display:flex;align-items:center;gap:10px;margin-bottom:18px;}
.footer-brand img{height:26px;}
.footer-top p{font-size:13px;color:rgba(255,255,255,.38);line-height:1.8;max-width:260px;font-weight:300;}
.footer-social{display:flex;gap:10px;margin-top:22px;}
.footer-social a{width:34px;height:34px;border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;transition:all .25s ease;}
.footer-social a:hover{border-color:var(--copper);background:rgba(184,115,51,.1);}
.footer-social svg{width:14px;height:14px;stroke:rgba(255,255,255,.6);}
.footer-col h6{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--copper);margin-bottom:18px;font-weight:600;}
.footer-col a{display:block;font-size:13.5px;color:rgba(255,255,255,.68);margin-bottom:12px;font-weight:300;transition:color .3s ease;}
.footer-col a:hover{color:var(--copper);}
.footer-col p.static{font-size:13.5px;color:rgba(255,255,255,.68);margin-bottom:12px;font-weight:300;line-height:1.7;}
.footer-bottom{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;font-size:11px;color:rgba(255,255,255,.28);letter-spacing:.03em;flex-wrap:wrap;gap:12px;}

/* ================================================================
   ABOUT PAGE
   ================================================================ */
.about-intro{display:grid;grid-template-columns:1fr 1fr;gap:80px;border-top:1px solid rgba(255,255,255,.06);align-items:start;}
.about-intro .label-block h2{font-size:clamp(26px,2.6vw,36px);font-weight:600;line-height:1.25;letter-spacing:-.01em;color:#fff;}
.about-intro .copy p{font-size:15px;line-height:1.9;color:rgba(244,245,246,.68);font-weight:300;margin-bottom:22px;}
.about-intro .copy p:last-child{margin-bottom:0;}


/* Editorial storytelling — varied rhythm, typography-led, no imagery */
.story-wide{padding:130px 48px;text-align:center;border-top:1px solid rgba(255,255,255,.06);}
.story-wide h3{font-size:clamp(30px,3.4vw,46px);font-weight:600;line-height:1.3;letter-spacing:-.01em;color:#fff;max-width:820px;margin:0 auto 28px;}
.story-wide p{font-size:15px;line-height:1.9;color:rgba(244,245,246,.7);font-weight:300;max-width:600px;margin:0 auto;}

.story-split{display:grid;grid-template-columns:280px 1fr;gap:60px;padding:110px 48px;border-top:1px solid rgba(255,255,255,.06);max-width:1200px;margin:0 auto;}
.story-split h3{font-size:clamp(24px,2.4vw,32px);font-weight:600;color:#fff;letter-spacing:-.01em;line-height:1.3;}
.story-split-copy p{font-size:15px;line-height:1.9;color:rgba(244,245,246,.7);font-weight:300;max-width:560px;}

.story-narrow{padding:90px 48px 130px;text-align:center;border-top:1px solid rgba(255,255,255,.06);}
.story-narrow h3{font-size:clamp(22px,2.2vw,28px);font-weight:600;color:#fff;letter-spacing:-.01em;margin:0 auto 18px;max-width:520px;}
.story-narrow p{font-size:14px;line-height:1.85;color:rgba(244,245,246,.65);font-weight:300;max-width:480px;margin:0 auto;}

/* Values */
.values-section{border-top:1px solid rgba(255,255,255,.06);}
.values-head{max-width:600px;margin:0 auto 70px;text-align:center;}
.values-head h2{font-size:clamp(26px,2.8vw,38px);font-weight:600;color:#fff;letter-spacing:-.01em;line-height:1.2;}
.values-head p{margin-top:22px;font-size:14.5px;line-height:1.85;color:rgba(244,245,246,.68);font-weight:300;max-width:620px;margin-left:auto;margin-right:auto;}
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);}
.value-card{background:var(--bg);padding:48px 34px;transition:background .35s ease;}
.value-card:hover{background:#191919;}
.value-icon{width:52px;height:52px;border:1px solid var(--copper);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:26px;transition:background .3s ease;}
.value-card:hover .value-icon{background:var(--copper);}
.value-icon svg{width:22px;height:22px;stroke:var(--copper);transition:stroke .3s ease;}
.value-card:hover .value-icon svg{stroke:#fff;}
.value-card h4{font-size:16px;font-weight:600;color:#fff;letter-spacing:-.005em;margin-bottom:12px;text-transform:uppercase;font-size:13px;letter-spacing:.08em;}
.value-card p{font-size:13.5px;line-height:1.8;color:rgba(244,245,246,.62);font-weight:300;}

/* Timeline (editorial) */
.timeline-section{border-top:1px solid rgba(255,255,255,.06);}
.timeline{max-width:920px;margin:0 auto;position:relative;padding-left:40px;}
.timeline::before{content:'';position:absolute;left:0;top:6px;bottom:6px;width:1px;background:linear-gradient(0deg, rgba(184,115,51,0) 0%, var(--copper) 8%, var(--copper) 92%, rgba(184,115,51,0) 100%);}
.tl-item{position:relative;padding-bottom:64px;}
.tl-item:last-child{padding-bottom:0;}
.tl-dot{position:absolute;left:-45px;top:2px;width:11px;height:11px;border-radius:50%;background:var(--bg);border:2px solid var(--copper);}
.tl-year{font-size:13px;color:var(--copper);letter-spacing:.1em;font-weight:600;margin-bottom:10px;}
.tl-item h4{font-size:19px;font-weight:600;color:#fff;margin-bottom:10px;letter-spacing:-.005em;}
.tl-item p{font-size:14px;line-height:1.85;color:rgba(244,245,246,.66);font-weight:300;max-width:560px;}

/* Group structure diagram */
.structure-section{border-top:1px solid rgba(255,255,255,.06);background:var(--shade-3);}
.structure-head{text-align:center;max-width:640px;margin:0 auto 80px;}
.structure-head h2{font-size:clamp(26px,2.8vw,38px);font-weight:600;color:#fff;letter-spacing:-.01em;}
.diagram{max-width:880px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:0;}
.diagram-node{border:1px solid rgba(255,255,255,.14);padding:20px 36px;font-size:13px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:#fff;text-align:center;background:var(--panel);}
.diagram-node.top{border-color:var(--copper);color:var(--copper);font-size:15px;padding:22px 44px;}
.diagram-connector{width:1px;height:36px;background:rgba(255,255,255,.16);}
.diagram-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;width:100%;margin:0 0 0;}
.diagram-row .diagram-node{font-size:12px;padding:18px 12px;}
.diagram-branch{display:grid;grid-template-columns:repeat(4,1fr);width:100%;height:36px;position:relative;}
.diagram-branch::before{content:'';position:absolute;top:0;left:12.5%;right:12.5%;height:1px;background:rgba(255,255,255,.16);}
.diagram-branch span{display:block;width:1px;height:36px;background:rgba(255,255,255,.16);margin:0 auto;}

/* About page CTA already reuses .cta */


/* ===== GROUP FLOW (how the companies work together) ===== */
.flow-section{padding:120px 48px;border-top:1px solid rgba(255,255,255,.06);background:var(--shade-1);}
.flow-head{text-align:center;max-width:620px;margin:0 auto 64px;}
.flow-head h2{font-size:clamp(26px,2.8vw,38px);font-weight:600;color:#fff;letter-spacing:-.01em;line-height:1.25;}
.flow-row{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:0;max-width:1040px;margin:0 auto;}
.flow-node{border:1px solid rgba(255,255,255,.14);padding:22px 30px;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:#fff;background:var(--panel);white-space:nowrap;transition:border-color .3s ease,background .3s ease;}
.flow-node:hover{border-color:var(--copper);background:rgba(184,115,51,.08);}
.flow-arrow{width:44px;height:1px;background:rgba(255,255,255,.2);position:relative;margin:0 4px;flex-shrink:0;}
.flow-arrow::after{content:'';position:absolute;right:0;top:-3px;width:7px;height:7px;border-right:1px solid var(--copper);border-bottom:1px solid var(--copper);transform:rotate(-45deg);}

/* ===== COMPANY BLOCKS (rich, fully-clickable, no explicit CTA) ===== */
.co-block-list{border-top:1px solid rgba(255,255,255,.06);}
.co-block{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid rgba(255,255,255,.06);position:relative;color:inherit;}
.co-block:first-child{border-top:none;}
.co-block.reverse{direction:rtl;}
.co-block.reverse > *{direction:ltr;}
.co-block-img{position:relative;overflow:hidden;min-height:600px;}
.co-block-img img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;filter:contrast(1.04) saturate(.85) brightness(.78);transition:transform 1.3s cubic-bezier(.16,.84,.44,1), filter .5s ease;}
.co-block:hover .co-block-img img{transform:scale(1.06);filter:contrast(1.02) saturate(.95) brightness(.92);}
.co-block-text{padding:90px 64px;display:flex;flex-direction:column;justify-content:center;background:var(--bg);transition:background .3s ease;}
.co-block:hover .co-block-text{background:#181818;}
.co-block-idx{font-size:12px;color:var(--copper);letter-spacing:.14em;font-weight:600;margin-bottom:20px;}
.co-block-text h3{font-size:clamp(26px,2.6vw,36px);font-weight:700;text-transform:uppercase;color:#fff;letter-spacing:-.01em;margin-bottom:8px;}
.co-block-text .co-block-tag{font-size:13px;color:rgba(244,245,246,.62);margin-bottom:24px;}
.co-block-text p.overview{font-size:14.5px;line-height:1.9;color:rgba(244,245,246,.7);font-weight:300;max-width:460px;margin-bottom:30px;}
.co-block-meta{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:8px;max-width:460px;}
.co-block-meta h5{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--copper);margin-bottom:12px;font-weight:600;}
.co-block-meta ul{display:flex;flex-direction:column;gap:7px;}
.co-block-meta li{font-size:13px;color:rgba(244,245,246,.72);font-weight:300;line-height:1.4;}
.co-block-footer{display:flex;align-items:center;justify-content:space-between;margin-top:36px;max-width:460px;}
.co-block-strengths{display:flex;gap:10px;flex-wrap:wrap;}
.co-block-strengths span{font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:rgba(244,245,246,.6);border:1px solid rgba(255,255,255,.14);padding:6px 12px;}
.co-block-arrow{width:44px;height:44px;border:1px solid rgba(255,255,255,.25);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateX(-8px);transition:all .35s ease;flex-shrink:0;}
.co-block:hover .co-block-arrow{opacity:1;transform:translateX(0);background:var(--copper);border-color:var(--copper);}
.co-block-arrow svg{width:16px;height:16px;stroke:#fff;}

/* ================================================================
   COMPANY DETAIL PAGES (electrical / projects / facilities / manufacturing)
   ================================================================ */
.co-overview{display:grid;grid-template-columns:1fr 1fr;gap:80px;border-top:1px solid rgba(255,255,255,.06);}
.co-overview h2{font-size:clamp(26px,2.6vw,36px);font-weight:600;line-height:1.25;letter-spacing:-.01em;color:#fff;}
.co-overview .copy p{font-size:15px;line-height:1.9;color:rgba(244,245,246,.68);font-weight:300;margin-bottom:20px;}

.services-section{border-top:1px solid rgba(255,255,255,.06);}
.services-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:60px;gap:24px;flex-wrap:wrap;}
.services-head h2{font-size:clamp(26px,2.8vw,38px);font-weight:600;color:#fff;letter-spacing:-.01em;max-width:520px;}
.services-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);}
.service-row{background:var(--bg);padding:38px 32px;transition:background .3s ease;position:relative;}
.service-row:hover{background:#191919;}
.service-row .n{font-size:11px;color:var(--copper);letter-spacing:.12em;font-weight:600;margin-bottom:16px;display:block;}
.service-row h4{font-size:16px;font-weight:600;color:#fff;letter-spacing:-.005em;margin-bottom:10px;}
.service-row p{font-size:13px;line-height:1.75;color:rgba(244,245,246,.62);font-weight:300;}

.capability-section{border-top:1px solid rgba(255,255,255,.06);background:var(--shade-2);}
.capability-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);}
.capability-card{background:var(--shade-2);padding:44px 34px;}
.capability-card .cap-num{font-size:34px;font-weight:700;color:var(--copper);letter-spacing:-.02em;margin-bottom:16px;}
.capability-card h4{font-size:14.5px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px;}
.capability-card p{font-size:13px;line-height:1.75;color:rgba(244,245,246,.62);font-weight:300;}

/* Featured projects strip (per-company) */
.featured-section{border-top:1px solid rgba(255,255,255,.06);}
.featured-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);}
.feat-card{position:relative;min-height:380px;overflow:hidden;background:#141414;display:block;}
.feat-card .feat-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:contrast(1.03) saturate(0.73) brightness(0.59);transform:scale(1.08);transition:transform 1.3s cubic-bezier(.16,.84,.44,1), filter .4s ease;}
.feat-card:hover .feat-bg{transform:scale(1.16);filter:contrast(1.03) saturate(0.92) brightness(0.73);}
.feat-card::after{content:'';position:absolute;inset:0;background:linear-gradient(0deg, rgba(8,8,8,0.57) 0%, rgba(8,8,8,0.06) 55%);}
.feat-meta{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;padding:30px;}
.feat-meta .tag{font-size:10.5px;color:var(--copper);letter-spacing:.1em;text-transform:uppercase;font-weight:600;margin-bottom:10px;}
.feat-meta h4{font-size:16px;font-weight:600;color:#fff;letter-spacing:-.005em;margin-bottom:8px;}
.feat-meta span{font-size:12px;color:rgba(244,245,246,.62);}
.feat-meta .view{margin-top:16px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#fff;display:flex;align-items:center;gap:8px;opacity:0;transform:translateY(6px);transition:opacity .3s ease, transform .3s ease;}
.feat-card:hover .feat-meta .view{opacity:1;transform:translateY(0);}
.feat-meta .view svg{width:12px;height:12px;stroke:var(--copper);}

/* Related company nav (bottom of each company page) */
.related-companies{border-top:1px solid rgba(255,255,255,.06);}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);}
.related-item{background:var(--bg);padding:34px 28px;transition:background .3s ease;display:block;}
.related-item:hover{background:#191919;}
.related-item .lbl{font-size:10px;color:var(--copper);letter-spacing:.12em;text-transform:uppercase;font-weight:600;margin-bottom:10px;}
.related-item h5{font-size:15px;color:#fff;font-weight:600;display:flex;align-items:center;justify-content:space-between;}
.related-item h5 svg{width:13px;height:13px;stroke:var(--copper);transition:transform .3s ease;}
.related-item:hover h5 svg{transform:translateX(4px);}

/* ================================================================
   PROJECT DETAIL TEMPLATE
   ================================================================ */
.proj-hero-meta{display:flex;gap:40px;flex-wrap:wrap;margin-top:32px;}
.proj-hero-meta div{display:flex;flex-direction:column;gap:6px;}
.proj-hero-meta .k{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.4);}
.proj-hero-meta .v{font-size:14px;color:#fff;font-weight:500;}

.proj-overview{display:grid;grid-template-columns:1fr 1fr;gap:80px;border-top:1px solid rgba(255,255,255,.06);}
.proj-overview h2{font-size:clamp(24px,2.4vw,32px);font-weight:600;color:#fff;letter-spacing:-.01em;margin-bottom:20px;}
.proj-overview p{font-size:14.5px;line-height:1.9;color:rgba(244,245,246,.66);font-weight:300;margin-bottom:18px;}
.scope-list{display:flex;flex-direction:column;gap:14px;}
.scope-list li{display:flex;gap:14px;font-size:14px;color:rgba(244,245,246,.76);font-weight:300;align-items:flex-start;}
.scope-list li svg{width:15px;height:15px;stroke:var(--copper);flex-shrink:0;margin-top:3px;}

.proj-gallery{border-top:1px solid rgba(255,255,255,.06);}
.gallery-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;grid-template-rows:repeat(2,280px);gap:2px;}
.gallery-grid .g1{grid-row:1 / 3;}
.gallery-tile{position:relative;overflow:hidden;background:#181818;}
.gallery-tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:contrast(1.03) saturate(0.79) brightness(0.79);transition:transform 1.1s cubic-bezier(.16,.84,.44,1);}
.gallery-tile:hover img{transform:scale(1.08);}

.proj-outcomes{border-top:1px solid rgba(255,255,255,.06);}
.outcomes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);}
.outcome-card{background:var(--bg);padding:42px 32px;}
.outcome-card .num{font-size:36px;font-weight:700;color:var(--copper);letter-spacing:-.02em;margin-bottom:14px;}
.outcome-card p{font-size:13px;color:rgba(244,245,246,.66);line-height:1.7;font-weight:300;}

.related-projects{border-top:1px solid rgba(255,255,255,.06);}

/* ================================================================
   CONTACT PAGE
   ================================================================ */
.contact-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:0;border-top:1px solid rgba(255,255,255,.06);}
.contact-form-col{padding:110px 64px;}
.contact-form-col h2{font-size:clamp(26px,2.6vw,36px);font-weight:600;color:#fff;letter-spacing:-.01em;margin-bottom:16px;}
.contact-form-col > p{font-size:14.5px;color:rgba(244,245,246,.66);line-height:1.8;max-width:440px;margin-bottom:48px;font-weight:300;}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;}
.field{margin-bottom:26px;position:relative;}
.field.full{grid-column:1 / -1;}
.field label{display:block;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:10px;font-weight:600;}
.field input,
.field select,
.field textarea{
  width:100%;background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.18);
  color:#fff;font-family:inherit;font-size:14.5px;font-weight:300;padding:10px 2px;
  transition:border-color .3s ease;
}
.field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23B87333' stroke-width='1.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 2px center;background-size:16px;}
.field select option{background:#1a1a1a;color:#fff;}
.field textarea{resize:vertical;min-height:120px;}
.field input:focus,
.field select:focus,
.field textarea:focus{outline:none;border-color:var(--copper);}
.field .err-msg{display:none;font-size:11px;color:#e07a5f;margin-top:8px;letter-spacing:.02em;}
.field.invalid input,
.field.invalid select,
.field.invalid textarea{border-color:#e07a5f;}
.field.invalid .err-msg{display:block;}
.radio-row{display:flex;gap:26px;flex-wrap:wrap;margin-top:6px;}
.radio-opt{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.7);cursor:pointer;}
.radio-opt input{width:auto;accent-color:var(--copper);}


#contact-form.hidden{display:none;}
.success-panel{display:none;text-align:left;padding:60px 0;}
.success-panel.show{display:block;animation:fadeUp .6s ease both;}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:translateY(0);}}
.success-icon{width:64px;height:64px;border:1px solid var(--copper);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:28px;}
.success-icon svg{width:26px;height:26px;stroke:var(--copper);}
.success-panel h3{font-size:24px;font-weight:600;color:#fff;margin-bottom:14px;letter-spacing:-.01em;}
.success-panel p{font-size:14.5px;color:rgba(244,245,246,.68);line-height:1.8;max-width:420px;margin-bottom:28px;}

.contact-info-col{background:var(--shade-4);padding:110px 56px;border-left:1px solid rgba(255,255,255,.06);}
.info-block{margin-bottom:44px;}
.info-block:last-child{margin-bottom:0;}
.info-block h6{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--copper);margin-bottom:14px;font-weight:600;}
.info-block p{font-size:14.5px;color:rgba(244,245,246,.78);line-height:1.75;font-weight:300;}
.info-block a{color:rgba(244,245,246,.88);border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:2px;transition:border-color .25s ease, color .25s ease;}
.info-block a:hover{color:var(--copper);border-color:var(--copper);}
.hours-row{display:flex;justify-content:space-between;font-size:13px;color:rgba(244,245,246,.68);padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05);}
.hours-row span:last-child{color:rgba(244,245,246,.88);}
.map-embed{margin-top:44px;border:1px solid rgba(255,255,255,.08);position:relative;min-height:220px;overflow:hidden;background:#161616;}
.map-embed iframe{width:100%;height:220px;border:0;filter:grayscale(.4) contrast(1.1) brightness(.85);}
.map-badge{position:absolute;top:12px;left:12px;background:rgba(10,10,10,.85);padding:6px 12px;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--copper);border:1px solid rgba(184,115,51,.3);}

/* ===== RESPONSIVE ===== */
@media (max-width:980px){
  nav{padding:18px 22px;}
  .nav-links{display:none;}
  .nav-burger{display:flex;}
  .hero-content{padding:0 22px;max-width:100%;}
  section{padding:70px 22px;}
  .page-hero-content{padding:0 22px;}
  .crumb{padding:120px 22px 0;}

  .companies{grid-template-columns:1fr;}
  .companies-intro{padding:60px 22px;}
  .co-rail{flex-direction:column;}
  .co-panel{width:100% !important;height:220px;border-left:none;border-top:1px solid rgba(255,255,255,.06);}
  .co-panel.active{height:320px;}

  .trust-grid{grid-template-columns:1fr;}
  .trust-content{padding:60px 22px;}
  .trust-img{min-height:320px;}
  .trust-stats{grid-template-columns:1fr 1fr;gap:28px;}

  .cta-inner{flex-direction:column;align-items:flex-start;padding:60px 22px;text-align:left;}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px;}

  .stat-strip{grid-template-columns:1fr 1fr;}
  .stat-cell:nth-child(3){border-left:none;}

  .about-intro{grid-template-columns:1fr;gap:40px;padding:60px 22px;}
  .story-wide{padding:70px 22px;}
  .story-split{grid-template-columns:1fr;gap:24px;padding:70px 22px;}
  .story-narrow{padding:60px 22px 80px;}
  .values-grid{grid-template-columns:1fr 1fr;}
  .diagram-row,.diagram-branch{grid-template-columns:1fr 1fr;gap:16px;row-gap:16px;}
  .diagram-branch{display:none;}

  .co-overview{grid-template-columns:1fr;gap:40px;padding:60px 22px;}
  .services-list{grid-template-columns:1fr;}
  .capability-grid{grid-template-columns:1fr;}
  .featured-grid{grid-template-columns:1fr;}
  .related-grid{grid-template-columns:1fr;}

  .flow-row{flex-direction:column;}
  .flow-arrow{width:1px;height:32px;margin:4px 0;}
  .flow-arrow::after{right:-3px;top:auto;bottom:0;transform:rotate(45deg);}
  .co-block,.co-block.reverse{grid-template-columns:1fr;direction:ltr;}
  .co-block-img{min-height:320px;}
  .co-block-text{padding:56px 22px;}
  .co-block-meta{grid-template-columns:1fr;}

  .proj-overview{grid-template-columns:1fr;gap:40px;padding:60px 22px;}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,220px);}
  .gallery-grid .g1{grid-row:auto;grid-column:1/3;}
  .outcomes-grid{grid-template-columns:1fr;}

  .contact-layout{grid-template-columns:1fr;}
  .contact-form-col{padding:60px 22px;}
  .contact-info-col{padding:60px 22px;border-left:none;border-top:1px solid rgba(255,255,255,.06);}
  .form-grid{grid-template-columns:1fr;}
}
@media (max-width:560px){
  .footer-top{grid-template-columns:1fr;}
  .values-grid{grid-template-columns:1fr;}
}
