/*
Theme Name: Class A Solar
Theme URI: https://www.classasolar.co.za
Author: Think Digital
Author URI: https://www.thinkdigital.co.za
Description: Custom multi-page WordPress theme for Class A Solar - award-winning solar installations in Bloemfontein serving farms, factories and businesses across central South Africa. Built for SEO, speed and conversions.
Version: 1.5.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: class-a-solar
Tags: business, one-column, custom-logo, custom-menu, full-width-template
*/

:root{
--o:#E8791E;--ol:#F49030;--od:#D06818;--og:rgba(232,121,30,0.07);--os:rgba(232,121,30,0.12);--ob:rgba(232,121,30,0.2);--grad:linear-gradient(135deg,#F49030,#E8791E,#D06818);
--bk:#141414;--dk:#1E1E1E;--ch:#333;--tx:#4A4A4A;--tl:#777;--gr:#AAA;--bd:#E5E0D8;--bl:#EFEBE5;--cr:#FBF9F6;--wh:#FFF;
--hd:'Clash Display',sans-serif;--bs:'General Sans',sans-serif;
--pad:clamp(20px,5vw,80px);--mx:1200px;--r:16px;--rs:10px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--bs);background:var(--cr);color:var(--tx);font-size:16px;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}
.con{max-width:var(--mx);margin:0 auto;padding:0 var(--pad)}
.page-section{display:none}.page-section.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.page-section.active{animation:fadeIn .5s ease}
@keyframes heroZoom{0%{transform:scale(1.05)}100%{transform:scale(1.12)}}
@keyframes scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes slideUp{from{transform:translateY(110%)}to{transform:translateY(0)}}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 var(--pad);height:72px;display:flex;align-items:center;justify-content:space-between;background:rgba(251,249,246,0.95);backdrop-filter:blur(24px);border-bottom:1px solid var(--bd);transition:.4s}
.nav-logo img{height:40px}
.nl{display:flex;align-items:center;gap:28px}
.nl a{font-size:13px;font-weight:500;color:var(--tl);transition:.25s;cursor:pointer}.nl a:hover,.nl a.active{color:var(--o)}
.nc{font-size:13px!important;font-weight:600!important;color:white!important;background:var(--grad);padding:10px 24px;border-radius:var(--rs);box-shadow:0 2px 12px rgba(232,121,30,.2);transition:.3s}.nc:hover{transform:translateY(-1px)}
.mt{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}.mt span{display:block;width:22px;height:2px;background:var(--ch)}

/* SECTIONS */
.sec{padding:clamp(72px,10vw,128px) 0}
.sw{background:var(--wh)}.scr{background:var(--cr)}.sdk{background:var(--bk);color:white}
.sdk h2{color:white}.sdk p,.sdk .si{color:rgba(255,255,255,.6)}
.sl{font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--o);margin-bottom:12px}
h2{font-family:var(--hd);font-size:clamp(30px,4vw,50px);font-weight:600;color:var(--bk);line-height:1.1;margin-bottom:16px;letter-spacing:-.8px}
h2 em{font-style:normal;color:var(--o)}
.si{font-size:16px;color:var(--tl);max-width:560px;line-height:1.75;margin-bottom:48px}

/* HERO */
.hero{padding-top:72px;position:relative;background:var(--bk);overflow:hidden;min-height:100vh;display:flex;flex-direction:column}
.hero-bg{position:absolute;inset:0;z-index:1}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 35%;opacity:.45;animation:heroZoom 20s ease-in-out infinite alternate}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,20,20,.4) 0%,rgba(20,20,20,.1) 30%,rgba(20,20,20,.5) 65%,rgba(20,20,20,.95) 100%)}
.hero-inner{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;justify-content:flex-end;padding:0 var(--pad) 60px;max-width:var(--mx);margin:0 auto;width:100%}
.hb{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.hb span{font-size:10.5px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--ol);background:rgba(232,121,30,.1);border:1px solid rgba(232,121,30,.22);padding:6px 13px;border-radius:100px;white-space:nowrap}
.hero h1{font-family:var(--hd);font-size:clamp(38px,6.5vw,76px);font-weight:600;color:white;line-height:1.06;margin-bottom:24px;letter-spacing:-1.5px}
.hero h1 em{font-style:normal;color:var(--ol)}
.h-sub{font-size:clamp(15px,1.8vw,18px);color:rgba(255,255,255,.55);max-width:540px;line-height:1.7;margin-bottom:36px}
.h-btns{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--bs);font-size:14px;font-weight:600;padding:15px 28px;border-radius:var(--rs);border:none;cursor:pointer;transition:.3s}
.bp{background:var(--grad);color:white;box-shadow:0 4px 20px rgba(232,121,30,.25)}.bp:hover{transform:translateY(-2px)}
.bg{background:rgba(255,255,255,.08);color:white;border:1px solid rgba(255,255,255,.2)}.bg:hover{background:rgba(255,255,255,.15)}
.h-stats{display:grid;grid-template-columns:repeat(4,1fr);margin-top:48px;padding-top:32px;border-top:1px solid rgba(255,255,255,.1)}
.hs{text-align:center;padding:0 16px}.hs:not(:last-child){border-right:1px solid rgba(255,255,255,.08)}
.hs .n{font-family:var(--hd);font-size:clamp(26px,3.5vw,42px);font-weight:600;color:white;line-height:1}.hs .n i{font-style:normal;color:var(--ol);font-size:.55em}
.hs .l{font-size:11px;color:rgba(255,255,255,.4);margin-top:4px}

/* MARQUEE */
.marq{background:var(--wh);border-bottom:1px solid var(--bd);padding:14px 0;overflow:hidden}
.mtr{display:flex;gap:48px;animation:scroll 35s linear infinite;width:max-content}
.mi{font-size:12px;font-weight:600;color:var(--tl);letter-spacing:.5px;text-transform:uppercase;white-space:nowrap;display:flex;align-items:center;gap:10px}
.md{width:6px;height:6px;background:var(--o);border-radius:50%}

/* GRADIENT ACCENT */
.grad-accent{background-image:linear-gradient(135deg,#E8791E 0%,#d16f1a 100%);background-size:cover;background-position:center;border-radius:var(--r);padding:60px 48px;color:white;position:relative;overflow:hidden;margin:48px 0}
.grad-accent h2{color:white}.grad-accent p{color:rgba(255,255,255,.85)}

/* GRID LAYOUTS */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}

/* CARDS */
.card{background:var(--wh);border:1px solid var(--bd);border-radius:var(--r);padding:36px;transition:.35s;position:relative;overflow:hidden}
.card:hover{border-color:var(--ob);transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.05)}
.card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:transform .4s}
.card:hover::after{transform:scaleX(1)}

/* FOUNDER CARDS */
.founder-card{text-align:center;background:var(--wh);border:1px solid var(--bd);border-radius:var(--r);padding:32px;transition:.3s}
.founder-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px rgba(0,0,0,.06)}
.founder-img{width:160px;height:160px;border-radius:50%;object-fit:cover;margin:0 auto 16px;border:4px solid var(--og)}
.founder-name{font-family:var(--hd);font-size:20px;font-weight:600;color:var(--bk)}
.founder-role{font-size:13px;color:var(--tl);margin-top:4px}

/* PROJECT CARDS */
.proj-card{background:var(--wh);border:1px solid var(--bd);border-radius:var(--r);overflow:hidden;cursor:pointer;transition:.3s}
.proj-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.06)}
.proj-card img{width:100%;height:240px;object-fit:cover;transition:transform .6s}
.proj-card:hover img{transform:scale(1.04)}
.proj-card-body{padding:24px}
.proj-card-body h3{font-family:var(--hd);font-size:18px;font-weight:600;color:var(--bk);margin-bottom:6px}
.proj-card-body p{font-size:13px;color:var(--tl);line-height:1.5}
.proj-tag{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--o);margin-bottom:8px}

/* PROJECT OVERLAY */
.proj-overlay{display:none;position:fixed;inset:0;z-index:2000;background:var(--cr);overflow-y:auto}
.proj-overlay.open{display:block;animation:fadeIn .4s ease}
.proj-close{position:fixed;top:20px;right:24px;z-index:2001;width:48px;height:48px;background:var(--bk);color:white;border:none;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.3s}
.proj-close:hover{background:var(--o)}
.proj-hero{width:100%;height:50vh;object-fit:cover}
.proj-content{max-width:800px;margin:0 auto;padding:48px var(--pad)}
.proj-content h1{font-family:var(--hd);font-size:clamp(28px,4vw,42px);font-weight:600;color:var(--bk);letter-spacing:-.8px;margin-bottom:20px}
.proj-content h2{font-size:clamp(20px,3vw,28px);margin-top:40px;margin-bottom:12px;border:none;padding:0}
.proj-content p{font-size:15px;line-height:1.8;color:var(--tx);margin-bottom:16px}
.proj-content .proj-gallery{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:32px 0}
.proj-content .proj-gallery img{width:100%;height:300px;object-fit:cover;border-radius:var(--rs)}
.proj-quote{background:var(--og);border-left:4px solid var(--o);padding:24px 32px;border-radius:0 var(--rs) var(--rs) 0;margin:32px 0;font-style:italic;font-size:15px;color:var(--ch);line-height:1.7}

/* AWARDS */
.aw{background:var(--wh);border:1px solid var(--bd);border-radius:var(--r);padding:28px;text-align:center;transition:.3s}
.aw:hover{transform:translateY(-4px);box-shadow:0 8px 30px rgba(0,0,0,.06)}
.aw-yr{font-family:var(--hd);font-size:38px;font-weight:600;color:var(--o);line-height:1;margin-bottom:10px}
.aw-t{font-size:14px;font-weight:600;color:var(--bk);margin-bottom:4px}
.aw-o{font-size:11px;color:var(--tl)}

/* TECH */
.tch{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);padding:32px;text-align:center;transition:.35s}
.tch:hover{border-color:var(--ob);background:rgba(232,121,30,.05);transform:translateY(-4px)}
.tch-n{font-family:var(--hd);font-size:24px;font-weight:600;color:white;margin-bottom:4px}
.tch-tp{font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--ol);margin-bottom:12px}
.tch-d{font-size:13px;color:rgba(255,255,255,.5);line-height:1.6}

/* TIMELINE */
.tline{position:relative;padding-left:40px;margin-top:48px}
.tline::before{content:'';position:absolute;left:14px;top:0;bottom:0;width:2px;background:var(--bd)}
.tl{position:relative;margin-bottom:36px;padding-left:28px}
.tl-dot{position:absolute;left:-33px;top:4px;width:16px;height:16px;background:var(--cr);border:3px solid var(--o);border-radius:50%;transition:.3s;z-index:2}
.tl:hover .tl-dot{background:var(--o);transform:scale(1.3)}
.tl-yr{font-family:var(--hd);font-size:26px;font-weight:600;color:var(--o)}
.tl-t{font-size:15px;font-weight:600;color:var(--bk);margin-bottom:4px}
.tl-d{font-size:13px;color:var(--tl);line-height:1.6}

/* FAQ */
.fq{border-bottom:1px solid var(--bd)}
.fq-q{display:flex;justify-content:space-between;align-items:center;padding:20px 0;cursor:pointer;font-size:15px;font-weight:600;color:var(--ch);transition:.25s}
.fq-q:hover{color:var(--o)}
.fq-q svg{width:20px;height:20px;stroke:var(--gr);fill:none;stroke-width:2;transition:.3s;flex-shrink:0}
.fq.open .fq-q svg{transform:rotate(45deg);stroke:var(--o)}
.fq-a{max-height:0;overflow:hidden;transition:max-height .5s cubic-bezier(.16,1,.3,1);font-size:14px;color:var(--tl);line-height:1.7}
.fq.open .fq-a{max-height:300px;padding-bottom:20px}

/* CONTACT */
.cc{background:var(--og);border:1px solid var(--ob);border-radius:var(--r);padding:20px;margin-bottom:14px;display:flex;gap:14px;align-items:center;transition:.25s}
.cc:hover{transform:translateX(6px)}
.cci{width:44px;height:44px;background:var(--os);border-radius:var(--rs);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cci svg{width:20px;height:20px;stroke:var(--o);fill:none;stroke-width:1.5}
.cct strong{display:block;font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--tl);margin-bottom:1px}
.cct span{font-size:15px;font-weight:600;color:var(--bk)}
.frm{background:var(--wh);border:1px solid var(--bd);border-radius:var(--r);padding:40px}
.fg{margin-bottom:18px}.fg label{display:block;font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--tl);margin-bottom:5px}
.fg input,.fg select,.fg textarea{width:100%;font-family:var(--bs);font-size:14px;color:var(--bk);background:var(--cr);border:1.5px solid var(--bd);border-radius:var(--rs);padding:12px 14px;outline:none;transition:.3s}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--o)}
.fg textarea{min-height:90px;resize:vertical}
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fsb{width:100%;font-family:var(--bs);font-size:14px;font-weight:600;color:white;background:var(--grad);border:none;border-radius:var(--rs);padding:15px;cursor:pointer;transition:.3s;margin-top:4px}

/* CTA */
.cta-s{position:relative;padding:100px var(--pad);text-align:center;overflow:hidden;background:#f6580a}
.cta-s h2{color:white;max-width:700px;margin:0 auto 12px}.cta-s p{color:rgba(255,255,255,.8);font-size:17px;margin-bottom:32px}
.bdk{font-family:var(--bs);font-size:15px;font-weight:600;color:var(--o);background:var(--bk);padding:18px 36px;border-radius:var(--rs);border:none;cursor:pointer;transition:.3s;display:inline-flex;align-items:center;gap:8px}
.bdk:hover{transform:translateY(-2px)}

/* CLIENTS */
.cls{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.cl{font-size:13px;font-weight:500;color:var(--tl);background:var(--wh);border:1px solid var(--bd);padding:10px 20px;border-radius:100px;transition:.25s;cursor:default}
.cl:hover{border-color:var(--ob);color:var(--o)}

/* FLOATING CTA + WA */
.fcta{position:fixed;bottom:24px;right:24px;z-index:999;display:flex;flex-direction:column;gap:10px;opacity:0;transform:translateY(20px);transition:.4s;pointer-events:none}
.fcta.v{opacity:1;transform:translateY(0);pointer-events:auto}
.fcta a{display:flex;align-items:center;gap:8px;font-family:var(--bs);font-size:13px;font-weight:600;color:white;padding:14px 24px;border-radius:100px;box-shadow:0 4px 24px rgba(0,0,0,.2);transition:.3s}
.fcta a:hover{transform:translateY(-2px)}
.fcta .quote-btn{background:var(--grad)}
.fcta .wa-btn{background:#25D366}

/* FOOTER */
.foot{background:var(--bk);padding:48px var(--pad)}
.foot-top{max-width:var(--mx);margin:0 auto;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:32px;padding-bottom:32px;margin-bottom:32px;border-bottom:1px solid rgba(255,255,255,.08)}
.foot-logo img{height:60px;margin-bottom:10px;display:block}
.foot-tag{font-size:13px;color:rgba(255,255,255,.35);max-width:300px}
.flnk{display:flex;gap:40px}
.fcol h4{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.25);margin-bottom:12px}
.fcol a{display:block;font-size:13px;color:rgba(255,255,255,.45);padding:3px 0;transition:.25s;cursor:pointer}.fcol a:hover{color:var(--ol)}
.foot-bot{max-width:var(--mx);margin:0 auto;display:flex;justify-content:space-between;font-size:11px;color:rgba(255,255,255,.2);flex-wrap:wrap;gap:8px}

@media(max-width:1024px){.g2,.g3,.g4{grid-template-columns:1fr}.h-stats{grid-template-columns:repeat(2,1fr)}.hs:not(:last-child){border-right:none}.foot-top{flex-direction:column}}
@media(max-width:768px){.nl{display:none}.mt{display:flex}.nl.open{display:flex!important;flex-direction:column;position:absolute;top:72px;left:0;right:0;background:rgba(251,249,246,.98);backdrop-filter:blur(20px);padding:24px;gap:16px;border-bottom:1px solid var(--bd)}.h-stats{grid-template-columns:1fr 1fr}.fr2{grid-template-columns:1fr}.flnk{flex-direction:column;gap:24px}.proj-content .proj-gallery{grid-template-columns:1fr}}

/* ===================== WordPress theme additions ===================== */
.nav-logo img{width:auto}
.foot-logo img{width:auto}

/* SEO: page lead heading styled like h2 so every page has exactly one H1 */
.lead-h1{font-family:var(--hd);font-size:clamp(30px,4vw,50px);font-weight:600;color:var(--bk);line-height:1.1;margin-bottom:16px;letter-spacing:-.8px}
.lead-h1 em{font-style:normal;color:var(--o)}
.sdk .lead-h1{color:#fff}

/* Accessibility / quality floor */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--o);outline-offset:2px;border-radius:4px}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--bk);color:#fff;padding:10px 16px;z-index:3000;border-radius:0 0 8px 0}
.skip-link:focus{left:0;top:0}
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .hero-bg img{animation:none;transform:none}
  .mtr{animation:none}
}

/* WordPress core safety */
.wp-caption,.gallery{max-width:100%}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}

/* Project overlay title (kept as h2 so each page has a single H1) */
#pj-title{font-family:var(--hd);font-size:clamp(28px,4vw,42px);font-weight:600;color:var(--bk);letter-spacing:-.8px;line-height:1.1;margin-bottom:20px}
.proj-card:focus-visible{outline:3px solid var(--o);outline-offset:3px}

/* Hero accolades: all three in one row on mobile, text wraps inside each pill */
@media(max-width:768px){
.hb{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:18px}
.hb span{white-space:normal;text-align:center;font-size:9px;letter-spacing:.2px;padding:7px 6px;line-height:1.22;display:flex;align-items:center;justify-content:center;min-height:34px}
}

/* Desktop: slightly larger nav logo and menu text */
@media(min-width:769px){.nav-logo img{height:46px}.nl a{font-size:15px}.nc{font-size:15px!important}}
