/* E Team Electrical -- High Voltage Brutalist */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:ital,wght@0,400;0,500;0,700;1,400&family=Space+Mono:wght@400;700&display=swap');

:root{
  --bg:#f5f0eb;
  --bg-dark:#1a1a1a;
  --bg-slab:#e8e0d6;
  --card:#fff;
  --text:#1a1a1a;
  --text-light:#5a5a5a;
  --text-inv:#f5f0eb;
  --orange:#ff5e1a;
  --orange-dim:rgba(255,94,26,.08);
  --orange-mid:rgba(255,94,26,.15);
  --yellow:#ffc629;
  --line:#d4cdc4;
  --line-dark:#333;
  --radius:6px;
  --shadow:0 20px 60px rgba(0,0,0,.12);
  --shadow-hard:8px 8px 0 rgba(0,0,0,.08);
  --max:1240px;
  --display:'Bebas Neue', 'Impact', sans-serif;
  --body:'DM Sans', sans-serif;
  --mono:'Space Mono', monospace;
  --grain:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--text);background:var(--bg);line-height:1.6;overflow-x:hidden}
a{color:inherit}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}

.container{max-width:var(--max);margin:0 auto;padding:0 24px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* Scroll reveal animations */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}
.reveal-delay-5{transition-delay:.5s}

/* Grain overlay on sections */
.grain::before{content:"";position:absolute;inset:0;background-image:var(--grain);background-repeat:repeat;pointer-events:none;z-index:1}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 32px;border:3px solid var(--text);
  font-family:var(--display);font-size:1.1rem;letter-spacing:2px;text-transform:uppercase;
  text-decoration:none;cursor:pointer;position:relative;overflow:hidden;
  transition:all .2s ease;background:transparent;color:var(--text);
}
.btn::after{content:"";position:absolute;inset:0;background:var(--orange);transform:translateX(-101%);transition:transform .25s ease;z-index:-1}
.btn:hover{color:#fff;border-color:var(--orange)}
.btn:hover::after{transform:translateX(0)}
.btn-fill{background:var(--orange);color:#fff;border-color:var(--orange)}
.btn-fill::after{background:var(--bg-dark)}
.btn-fill:hover{border-color:var(--bg-dark)}
.btn-sm{padding:10px 22px;font-size:.95rem}
.btn-inv{border-color:#fff;color:#fff}
.btn-inv::after{background:var(--orange)}
.btn-inv:hover{border-color:var(--orange)}

/* ==================== HEADER ==================== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .3s ease, box-shadow .3s ease;
}
.site-header.scrolled{background:rgba(245,240,235,.96);backdrop-filter:blur(10px);box-shadow:0 2px 20px rgba(0,0,0,.08)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 0;transition:padding .3s ease}
.site-header.scrolled .header-inner{padding:10px 0}

.brand{display:flex;align-items:center;gap:12px}
.brand-mark{
  width:48px;height:48px;background:var(--orange);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:1.6rem;color:#fff;
  clip-path:polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
}
.brand-name{font-family:var(--display);font-size:1.5rem;letter-spacing:3px;text-transform:uppercase}
.brand-sub{font-family:var(--mono);font-size:.62rem;letter-spacing:1.5px;color:var(--text-light);text-transform:uppercase}

.primary-nav .menu{display:flex;gap:0;align-items:center}
.primary-nav .menu a{
  display:block;padding:8px 16px;
  font-family:var(--display);font-size:1rem;letter-spacing:2px;text-transform:uppercase;
  text-decoration:none;color:var(--text-light);position:relative;
  transition:color .15s ease;
}
.primary-nav .menu a:hover{color:var(--orange)}
.primary-nav .menu a::after{
  content:"";position:absolute;bottom:4px;left:16px;right:16px;height:3px;
  background:var(--orange);transform:scaleX(0);transition:transform .2s ease;
}
.primary-nav .menu a:hover::after,.primary-nav .menu .current-menu-item a::after{transform:scaleX(1)}
.primary-nav .menu .current-menu-item a{color:var(--text)}

.nav-toggle{display:none;background:none;border:3px solid var(--text);padding:8px;cursor:pointer;width:44px;height:44px;position:relative}
.nav-toggle span{display:block;width:100%;height:3px;background:var(--text);position:absolute;left:50%;transform:translateX(-50%)}
.nav-toggle span:nth-child(1){top:10px}
.nav-toggle span:nth-child(2){top:18px}
.nav-toggle span:nth-child(3){top:26px}

/* ==================== HERO ==================== */
.hero{
  min-height:100vh;display:flex;align-items:center;
  position:relative;overflow:hidden;
  background:var(--bg-dark);color:var(--text-inv);
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(135deg, rgba(255,94,26,.15) 0%, transparent 50%),
    linear-gradient(315deg, rgba(255,198,41,.08) 0%, transparent 50%);
  z-index:1;
}
.hero-grid{
  position:absolute;inset:0;opacity:.06;
  background-image:
    linear-gradient(rgba(255,255,255,.3) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.3) 1px, transparent 1px);
  background-size:80px 80px;
}
.hero-inner{position:relative;z-index:2;padding:140px 0 80px;width:100%}
.hero-overline{
  font-family:var(--mono);font-size:.78rem;letter-spacing:3px;text-transform:uppercase;
  color:var(--orange);margin-bottom:20px;display:flex;align-items:center;gap:12px;
}
.hero-overline::before{content:"";width:40px;height:3px;background:var(--orange)}
h1.hero-title{
  font-family:var(--display);font-size:clamp(3.5rem,9vw,8rem);
  line-height:.92;letter-spacing:3px;text-transform:uppercase;
  margin-bottom:24px;
}
.hero-title .stroke{
  -webkit-text-stroke:2px var(--text-inv);color:transparent;
}
.hero-lede{font-size:1.15rem;color:rgba(245,240,235,.7);max-width:48ch;margin-bottom:36px;line-height:1.7}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}

.hero-photo{
  position:absolute;right:-5%;top:50%;transform:translateY(-50%);
  width:45%;height:75vh;z-index:1;
}
.hero-photo img{
  width:100%;height:100%;object-fit:cover;
  clip-path:polygon(15% 0, 100% 0, 100% 100%, 0% 100%);
  filter:contrast(1.1) saturate(.9);
}
.hero-photo::after{
  content:"";position:absolute;inset:0;
  clip-path:polygon(15% 0, 100% 0, 100% 100%, 0% 100%);
  background:linear-gradient(180deg, transparent 40%, rgba(26,26,26,.6) 100%);
}

.hero-ticker{
  position:absolute;bottom:0;left:0;right:0;z-index:3;
  background:var(--orange);padding:14px 0;overflow:hidden;
}
.ticker-track{
  display:flex;gap:40px;animation:ticker 25s linear infinite;white-space:nowrap;
  font-family:var(--display);font-size:1rem;letter-spacing:3px;text-transform:uppercase;color:#fff;
}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ==================== SECTIONS ==================== */
.section{padding:80px 0;position:relative}
.section-dark{background:var(--bg-dark);color:var(--text-inv)}
.section-slab{background:var(--bg-slab)}
.section-label{
  font-family:var(--mono);font-size:.72rem;font-weight:700;
  letter-spacing:4px;text-transform:uppercase;color:var(--orange);
  margin-bottom:8px;display:flex;align-items:center;gap:10px;
}
.section-label::before{content:"";width:24px;height:3px;background:var(--orange)}
.section-title{
  font-family:var(--display);font-size:clamp(2.2rem,4vw,3.6rem);
  letter-spacing:2px;text-transform:uppercase;line-height:.95;
}
.section-desc{color:var(--text-light);margin-top:12px;max-width:55ch;font-size:1.02rem;line-height:1.65}
.section-dark .section-desc{color:rgba(245,240,235,.6)}

/* ==================== SERVICES ==================== */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:48px}
.service-card{
  padding:36px 28px;border:1px solid var(--line);
  position:relative;overflow:hidden;
  transition:all .25s ease;
}
.service-card:hover{background:var(--card);box-shadow:var(--shadow);z-index:2;transform:scale(1.02)}
.service-num{
  font-family:var(--display);font-size:4rem;line-height:1;
  color:var(--orange);opacity:.15;position:absolute;top:12px;right:20px;
}
.service-card h3{
  font-family:var(--display);font-size:1.5rem;letter-spacing:2px;text-transform:uppercase;
  margin-bottom:10px;
}
.service-card p{color:var(--text-light);font-size:.92rem;line-height:1.6}
.service-bar{width:40px;height:4px;background:var(--orange);margin-bottom:16px;transition:width .3s ease}
.service-card:hover .service-bar{width:100%}

/* ==================== STATS ==================== */
.stats-strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:3px solid var(--orange);border-bottom:3px solid var(--orange);
}
.stat{padding:40px 28px;text-align:center;border-right:1px solid var(--line-dark)}
.stat:last-child{border:none}
.stat-num{font-family:var(--display);font-size:3.4rem;line-height:1;color:var(--orange)}
.stat-label{font-family:var(--mono);font-size:.7rem;letter-spacing:2px;text-transform:uppercase;margin-top:8px;color:rgba(245,240,235,.5)}

/* ==================== GALLERY ==================== */
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:32px}
.tile{
  position:relative;overflow:hidden;min-height:260px;
  background:var(--bg-dark);cursor:pointer;
}
.tile:hover .tile-media-img{transform:scale(1.06);filter:contrast(1.08) saturate(1.1)}
.tile-media-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;image-orientation:from-image;
  transition:transform .5s cubic-bezier(.16,1,.3,1), filter .3s ease;
}
.tile-media-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.tile::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 40%, rgba(0,0,0,.6) 100%);
  opacity:0;transition:opacity .3s ease;pointer-events:none;
}
.tile:hover::after{opacity:1}
.tile-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:2;pointer-events:none}
.tile-play span{
  width:60px;height:60px;background:var(--orange);
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;color:#fff;clip-path:polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
  transition:transform .2s ease;
}
.tile:hover .tile-play span{transform:scale(1.1)}
.tile-play.playing span{opacity:.2}
.tile-play.playing:hover span{opacity:.9}

.filter-bar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:24px}
.chip{
  padding:8px 16px;border:2px solid var(--line);
  font-family:var(--display);font-size:.85rem;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--text-light);cursor:pointer;transition:all .15s ease;text-decoration:none;
  background:transparent;
}
.chip:hover,.chip.active{border-color:var(--orange);color:var(--orange);background:var(--orange-dim)}

/* Preview pager */
.preview-pager{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:24px}
.pager-btn{
  padding:12px 28px;border:3px solid var(--text);background:transparent;
  font-family:var(--display);font-size:1rem;letter-spacing:2px;text-transform:uppercase;
  color:var(--text);cursor:pointer;position:relative;overflow:hidden;transition:all .2s ease;
}
.pager-btn::after{content:"";position:absolute;inset:0;background:var(--orange);transform:translateX(-101%);transition:transform .25s ease;z-index:-1}
.pager-btn:hover:not(:disabled){color:#fff;border-color:var(--orange)}
.pager-btn:hover:not(:disabled)::after{transform:translateX(0)}
.pager-btn:disabled{opacity:.3;cursor:default;border-color:var(--line)}
.pager-counter{font-family:var(--mono);font-size:.85rem;letter-spacing:1px;color:var(--text-light);min-width:60px;text-align:center}

/* Slideshow header */
.slideshow-header{position:relative;overflow:hidden;min-height:400px;background:var(--bg-dark);display:flex;align-items:flex-end}
.slideshow-bg{position:absolute;inset:0}
.slideshow-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;image-orientation:from-image;opacity:0;transition:opacity 1s ease}
.slideshow-img.active{opacity:1}
.slideshow-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg, rgba(26,26,26,.3) 0%, rgba(26,26,26,.85) 100%)}
.slideshow-header .inner{position:relative;z-index:2;padding:60px 0;color:var(--text-inv)}
.slideshow-controls{display:flex;align-items:center;gap:10px;margin-top:16px}
.slideshow-btn{
  background:transparent;border:2px solid rgba(255,255,255,.3);
  color:#fff;width:38px;height:38px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:1.1rem;transition:all .15s ease;
}
.slideshow-btn:hover{border-color:var(--orange);color:var(--orange)}
.slideshow-counter{font-family:var(--mono);font-size:.8rem;color:rgba(255,255,255,.5);min-width:60px;text-align:center}

/* ==================== CONTACT ==================== */
.contact-split{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:48px;min-height:500px}
.contact-info-panel{
  background:var(--bg-dark);color:var(--text-inv);padding:48px 40px;
  display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;
}
.contact-info-panel::before{
  content:"CONTACT";position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%) rotate(-90deg);
  font-family:var(--display);font-size:12rem;letter-spacing:10px;
  color:rgba(255,255,255,.02);white-space:nowrap;pointer-events:none;
}
.contact-detail{margin-bottom:28px}
.contact-label{font-family:var(--mono);font-size:.68rem;letter-spacing:3px;text-transform:uppercase;color:var(--orange);margin-bottom:4px}
.contact-value{font-size:1.15rem;font-weight:700}
.contact-value a{text-decoration:none;transition:color .15s}
.contact-value a:hover{color:var(--orange)}

.contact-form-panel{padding:48px 40px;background:var(--card);border:1px solid var(--line)}
.form-label{
  display:block;margin:16px 0 6px;
  font-family:var(--display);font-size:.9rem;letter-spacing:2px;text-transform:uppercase;
}
.form-input,.form-select,.form-textarea{
  width:100%;padding:14px 16px;border:2px solid var(--line);
  background:var(--bg);font-family:var(--body);font-size:.95rem;color:var(--text);
  transition:border-color .15s ease;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--orange)}
.form-textarea{resize:vertical;min-height:100px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-req{color:var(--orange)}
.hp{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}

.notice{padding:16px 20px;margin:16px 0;font-weight:700;border-left:4px solid}
.notice-ok{border-color:var(--orange);background:var(--orange-dim);color:var(--orange)}
.notice-err{border-color:#e03131;background:rgba(224,49,49,.06);color:#e03131}

/* ==================== REVIEWS ==================== */
.review-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:32px}
.review-card{
  background:var(--card);border:1px solid var(--line);padding:28px;
  position:relative;transition:box-shadow .2s ease;
}
.review-card:hover{box-shadow:var(--shadow)}
.review-card::before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--orange)}
.review-meta{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.review-name{font-family:var(--display);font-size:1.2rem;letter-spacing:1px;text-transform:uppercase}
.review-trade{font-family:var(--mono);font-size:.7rem;letter-spacing:1px;text-transform:uppercase;color:var(--text-light);margin-top:2px}
.review-stars{color:var(--orange);font-size:1.1rem;letter-spacing:2px}
.review-text{color:var(--text-light);line-height:1.65;font-size:.94rem}
.review-date{font-family:var(--mono);font-size:.72rem;color:var(--text-light);margin-top:12px;letter-spacing:1px}

.rating-input{display:flex;flex-direction:row-reverse;justify-content:flex-end;gap:4px}
.rating-input input{display:none}
.rating-input label{font-size:1.6rem;cursor:pointer;opacity:.25;transition:opacity .12s;color:var(--orange)}
.rating-input input:checked ~ label,.rating-input label:hover,.rating-input label:hover ~ label{opacity:1}

/* ==================== CTA ==================== */
.cta-band{
  background:var(--orange);padding:40px 0;position:relative;overflow:hidden;
}
.cta-band::before{content:"";position:absolute;inset:0;background-image:var(--grain);background-repeat:repeat;pointer-events:none;opacity:.3}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;position:relative;z-index:1}
.cta-text{font-family:var(--display);font-size:clamp(1.5rem,3vw,2.4rem);letter-spacing:2px;text-transform:uppercase;color:#fff}

/* ==================== FOOTER ==================== */
.site-footer{background:var(--bg-dark);color:var(--text-inv);padding:40px 0;border-top:4px solid var(--orange)}
.footer-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.footer-brand{font-family:var(--display);font-size:1.2rem;letter-spacing:3px;text-transform:uppercase}
.footer-nav .menu{display:flex;gap:20px}
.footer-nav a{
  font-family:var(--mono);font-size:.75rem;letter-spacing:1.5px;text-transform:uppercase;
  color:rgba(245,240,235,.4);text-decoration:none;transition:color .15s;
}
.footer-nav a:hover{color:var(--orange)}
.footer-legal{
  width:100%;text-align:center;margin-top:24px;padding-top:24px;
  border-top:1px solid var(--line-dark);
  font-family:var(--mono);font-size:.72rem;color:rgba(245,240,235,.3);letter-spacing:1px;
}

/* ==================== LIGHTBOX ==================== */
.lightbox-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:9999;align-items:center;justify-content:center;cursor:zoom-out}
.lightbox-overlay.active{display:flex}
.lightbox-overlay img,.lightbox-overlay video{max-width:92vw;max-height:90vh;image-orientation:from-image}
.lb-btn{position:fixed;color:#fff;font-size:2rem;cursor:pointer;z-index:10000;background:transparent;border:2px solid rgba(255,255,255,.2);width:48px;height:48px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.lb-btn:hover{border-color:var(--orange);color:var(--orange)}
.lb-close{top:16px;right:20px}
.lb-prev{top:50%;left:16px;transform:translateY(-50%)}
.lb-next{top:50%;right:16px;transform:translateY(-50%)}

/* ==================== RESPONSIVE ==================== */
@media(max-width:960px){
  .hero-photo{display:none}
  .services-grid{grid-template-columns:1fr 1fr}
  .stats-strip{grid-template-columns:1fr 1fr}
  .stat{border-right:none;border-bottom:1px solid var(--line-dark)}
  .contact-split{grid-template-columns:1fr}
  .tiles{grid-template-columns:1fr 1fr}
  .review-grid{grid-template-columns:1fr}
  .cta-inner{flex-direction:column;text-align:center}
}
@media(max-width:640px){
  .primary-nav{
    display:none;position:fixed;top:0;left:0;right:0;bottom:0;
    background:rgba(26,26,26,.98);z-index:99;
    flex-direction:column;align-items:center;justify-content:center;
  }
  .primary-nav.open{display:flex}
  .primary-nav .menu{flex-direction:column;gap:8px;text-align:center}
  .primary-nav .menu a{font-size:1.8rem;color:var(--text-inv);padding:12px}
  .primary-nav .menu a::after{display:none}
  .nav-toggle{display:block;z-index:100}
  .services-grid,.tiles{grid-template-columns:1fr}
  .stats-strip{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  h1.hero-title{font-size:clamp(2.8rem,12vw,5rem)}
  .hero-inner{padding:120px 0 100px}
  .contact-info-panel,.contact-form-panel{padding:32px 24px}
}
