/* ===================== DX ENERGY · SHARED STYLES ===================== */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&display=swap');
:root{
  --orange:#E9642A;--orange-dk:#cf531e;--green:#74C043;
  --ink:#161514;--ink-2:#201e1c;--paper:#fff;--mist:#f4f5f7;
  --line:#e6e8eb;--muted:#6b7280;--maxw:1180px;--r:18px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Poppins",system-ui,sans-serif;color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:"Poppins",system-ui,sans-serif;line-height:1.13;font-weight:700;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,4vw,28px)}
.accent{color:var(--orange)}.grn{color:var(--green)}
.center{text-align:center}.mx{max-width:62ch;margin-left:auto;margin-right:auto}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:"Poppins";font-weight:500;font-size:.97rem;padding:.85em 1.5em;border-radius:999px;cursor:pointer;border:0;transition:.25s}
.btn .arr{display:inline-flex;width:1.5em;height:1.5em;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.18);transition:.25s}
.btn-o{background:var(--orange);color:#fff}
.btn-o:hover{background:var(--orange-dk);transform:translateY(-2px)}
.btn-o:hover .arr{transform:translate(2px,-2px)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5)}
.btn-ghost:hover{background:#fff;color:var(--ink)}
.btn-dark{background:var(--ink);color:#fff}.btn-dark:hover{background:#000;transform:translateY(-2px)}
.link-arr{display:inline-flex;align-items:center;gap:.5em;font-family:"Poppins";font-weight:500;color:var(--orange)}
.link-arr svg{transition:.25s}.link-arr:hover svg{transform:translate(3px,-3px)}

/* header */
header{position:fixed;top:0;left:0;right:0;z-index:50;transition:.3s;padding:18px 0}
header::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(to bottom,rgba(15,14,13,.55),transparent);opacity:1;transition:.3s;pointer-events:none}
header.solid::before{opacity:0}
header.solid{background:rgba(20,19,18,.92);backdrop-filter:blur(10px);padding:11px 0;box-shadow:0 8px 30px rgba(0,0,0,.18)}
.nav{display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:.55rem;font-family:"Poppins";font-weight:600;font-size:1.45rem;color:#fff;line-height:0}
.logo img{height:48px;width:auto;display:block}
.logo.logo-foot img{height:58px}
.menu{display:flex;gap:1.5rem;list-style:none}
.menu a{color:rgba(255,255,255,.86);font-size:.9rem;font-weight:500;position:relative;padding:4px 0;transition:.2s}
.menu a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--orange);transition:.28s}
.menu a:hover,.menu a.active{color:#fff}
.nav-hidden{display:none !important}
.menu a:hover::after,.menu a.active::after{width:100%}
/* dropdown */
.menu .has-sub{position:relative}
.menu .has-sub>a{display:inline-flex;align-items:center}
.dd-caret{font-size:.55rem;margin-left:.3rem;opacity:.85;transition:transform .25s}
.menu .has-sub:hover .dd-caret{transform:rotate(180deg)}
.menu .has-sub::after{content:"";position:absolute;left:0;right:0;top:100%;height:16px}
.menu .submenu{position:absolute;top:calc(100% + 14px);left:-16px;margin:0;padding:8px 0;min-width:232px;list-style:none;background:rgba(22,21,20,.97);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:12px;box-shadow:0 16px 40px rgba(0,0,0,.32);opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .22s,transform .22s,visibility .22s}
.menu .has-sub:hover .submenu{opacity:1;visibility:visible;transform:translateY(0)}
.menu .submenu li{width:100%}
.menu .submenu a{display:block;padding:10px 20px;font-size:.85rem;color:rgba(255,255,255,.82);white-space:nowrap}
.menu .submenu a::after{display:none}
.menu .submenu a:hover{color:#fff;background:rgba(255,255,255,.07)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer}
.burger span{width:24px;height:2px;background:#fff;border-radius:2px}

/* page hero banner */
.phero{position:relative;min-height:62vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden;padding-bottom:64px}
.phero.tall{min-height:100vh;align-items:center;padding-bottom:0}
.phero .bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.16);opacity:0;animation:bgfade 1.2s ease forwards;will-change:transform,opacity}
@keyframes bgfade{to{opacity:1}}
.phero::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(105deg,rgba(15,14,13,.85) 0%,rgba(15,14,13,.5) 50%,rgba(15,14,13,.2) 100%),linear-gradient(to top,rgba(15,14,13,.65),transparent 45%)}
.phero .wrap{position:relative;z-index:2;width:100%}
.eyebrow{font-family:"Poppins";font-weight:500;letter-spacing:.3em;font-size:.72rem;text-transform:uppercase;color:rgba(255,255,255,.62);margin-bottom:.9rem}
.phero h1{font-size:clamp(2.1rem,4.6vw,3.7rem);font-weight:600;max-width:22ch;text-shadow:0 2px 30px rgba(0,0,0,.3)}
.phero h1 .grn{display:block;margin-top:.12em;text-wrap:balance}
.phero h1 .hb{display:inline}
.phero .meta{margin-top:.9rem;color:rgba(255,255,255,.7);font-size:.9rem}
.phero p.lead{max-width:46ch;color:rgba(255,255,255,.85);font-size:1.06rem;margin-top:1.3rem}
.phero .acts{margin-top:1.9rem;display:flex;gap:1.1rem;flex-wrap:wrap;align-items:center}

/* hero hero (home) */
.socials{display:flex;gap:.7rem}
.socials a{width:38px;height:38px;border:1.4px solid rgba(255,255,255,.35);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.25s}
.socials a:hover{background:var(--orange);border-color:var(--orange);transform:translateY(-3px)}
.socials svg{width:15px;height:15px;fill:#fff}

/* sections */
.sec{padding:clamp(54px,8vw,92px) 0}.sec.sm{padding:clamp(42px,6vw,64px) 0}
.dark{background:var(--ink);color:#fff}
.mist{background:var(--mist)}
.sec-head{margin-bottom:46px;max-width:62ch}
.kicker{font-family:"Poppins";font-weight:600;color:var(--orange);text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;margin-bottom:.7rem;display:inline-block}
h2.title{font-size:clamp(1.8rem,3.3vw,2.6rem)}
.sub{color:var(--muted);margin-top:.9rem;font-size:1.03rem}
.dark .sub{color:rgba(255,255,255,.72)}
p.body{color:var(--muted);margin-bottom:1rem}

/* reveal */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.16,.7,.2,1),transform .8s cubic-bezier(.16,.7,.2,1),filter .8s ease;will-change:opacity,transform}
.reveal.from-left{transform:translateX(-44px)}
.reveal.from-right{transform:translateX(44px)}
.reveal.zoom-in{transform:scale(.9)}
.reveal.blur-in{filter:blur(12px)}
.reveal.in{opacity:1;transform:none;filter:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}.d5{transition-delay:.4s}.d6{transition-delay:.48s}.d7{transition-delay:.56s}.d8{transition-delay:.64s}
/* hover polish */
.imgcard{transition:transform .5s cubic-bezier(.2,.7,.2,1),box-shadow .5s ease}
.imgcard:hover{transform:translateY(-6px);box-shadow:0 28px 54px rgba(20,19,18,.2)}
.post{transition:transform .4s cubic-bezier(.2,.7,.2,1)}
.post:hover{transform:translateY(-4px)}
.post h3{transition:color .25s}
.post:hover h3{color:var(--orange)}
.post .cat{display:inline-flex;align-items:center;gap:.3em;transition:gap .25s}
.post:hover .cat{gap:.7em}
.recent .t{transition:color .2s}
.recent:hover .t{color:var(--orange)}
.recent img{transition:transform .35s ease}
.recent:hover img{transform:scale(1.06)}
.case-card img{transition:transform .55s cubic-bezier(.2,.7,.2,1)}
.case-card:hover img{transform:scale(1.07)}
.chip{transition:.2s}
.chip:hover{border-color:var(--orange);color:var(--orange)}
.stat b{transition:transform .3s ease}
.stat:hover b{transform:scale(1.07)}
.btn-o:active,.btn-dark:active,.btn-ghost:active{transform:translateY(0)}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;filter:none!important;transition:none!important}
  .phero .bg{animation:none!important;opacity:1!important}
  .phero.tall .eyebrow,.phero.tall h1,.phero.tall .lead,.phero.tall .acts{animation:none!important;opacity:1!important;transform:none!important}
}

/* generic grids */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}

/* image cards (solutions) */
.imgcard{position:relative;border-radius:var(--r);overflow:hidden;min-height:340px;display:flex;flex-direction:column;justify-content:flex-end;color:#fff;isolation:isolate;box-shadow:0 14px 34px rgba(20,19,18,.1)}
.imgcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:.6s}
.imgcard::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(to top,rgba(15,14,13,.92),rgba(15,14,13,.3) 60%,rgba(15,14,13,.1))}
.imgcard:hover img{transform:scale(1.07)}
.imgcard .body{padding:26px}
.imgcard h3{font-size:1.25rem;margin-bottom:.5rem}
.imgcard p{font-size:.9rem;color:rgba(255,255,255,.8);margin-bottom:1rem}
.go{width:40px;height:40px;border-radius:50%;background:var(--orange);display:flex;align-items:center;justify-content:center;transition:.25s}
.imgcard:hover .go{transform:translate(3px,-3px);background:#fff}
.imgcard:hover .go svg{stroke:var(--ink)}
.go svg{stroke:#fff}
/* full-image solution tiles (home) */
.tile-photo{display:block;border-radius:var(--r);overflow:hidden;transition:transform .5s cubic-bezier(.2,.7,.2,1),box-shadow .5s ease}
.tile-photo img{width:100%;height:auto;display:block;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.tile-photo:hover{transform:translateY(-5px);box-shadow:0 24px 50px rgba(20,19,18,.18)}
.tile-photo:hover img{transform:scale(1.04)}
/* For Business hover-reveal cards */
.biz-card{position:relative;border-radius:var(--r);overflow:hidden;min-height:360px;display:flex;background:var(--mist);border:1px solid var(--line);color:var(--ink);isolation:isolate;transition:transform .5s cubic-bezier(.2,.7,.2,1),box-shadow .5s ease,border-color .3s}
.biz-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;opacity:0;transform:scale(1.07);transition:opacity .55s ease,transform .9s cubic-bezier(.2,.7,.2,1)}
.biz-card::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(to top,rgba(15,14,13,.92),rgba(15,14,13,.45) 55%,rgba(15,14,13,.22));opacity:0;transition:opacity .55s ease}
.biz-card:hover{transform:translateY(-6px);box-shadow:0 28px 54px rgba(20,19,18,.2);border-color:transparent;color:#fff}
.biz-card:hover img{opacity:1;transform:scale(1)}
.biz-card:hover::after{opacity:1}
.biz-card .body{padding:30px;display:flex;flex-direction:column;width:100%}
.biz-card .num{font-family:"Poppins";font-weight:600;color:var(--orange);font-size:1.05rem;letter-spacing:.06em;margin-bottom:.7rem}
.biz-card h3{font-size:1.3rem;margin-bottom:.6rem;transition:color .3s}
.biz-card p{font-size:.92rem;color:var(--muted);margin-bottom:auto;transition:color .3s}
.biz-card:hover p{color:rgba(255,255,255,.86)}
.biz-card .go{margin-top:26px;width:42px;height:42px;border-radius:50%;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;transition:.3s}
.biz-card .go svg{stroke:var(--ink);transition:.3s}
.biz-card:hover .go{background:var(--orange);border-color:var(--orange);transform:translate(3px,-3px)}
.biz-card:hover .go svg{stroke:#fff}

/* value/feature cards (light panels) */
.panel{background:var(--mist);border:1px solid var(--line);border-radius:16px;padding:28px;transition:.25s}
.panel:hover{transform:translateY(-5px);box-shadow:0 18px 40px rgba(20,19,18,.08);border-color:#dfe2e6}
.panel .num{font-family:"Poppins";color:var(--orange);font-weight:600;font-size:.95rem;margin-bottom:.5rem}
.panel h3{font-size:1.18rem;margin-bottom:.5rem}
.panel p{color:var(--muted);font-size:.93rem;margin:0}
/* innovation hover-reveal cards */
.inno-card{position:relative;background:var(--mist);border:1px solid var(--line);border-radius:16px;overflow:hidden;min-height:248px;padding:28px;isolation:isolate;transition:transform .42s cubic-bezier(.2,.7,.2,1),box-shadow .42s ease,border-color .42s ease}
.inno-card .ic-bg{position:absolute;inset:0;z-index:0;opacity:0;transition:opacity .55s ease}
.inno-card .ic-bg img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.07);transition:transform .8s ease}
.inno-card .ic-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(12,12,12,.84),rgba(12,12,12,.5))}
.inno-card .ic-num{position:relative;z-index:1;font-family:"Poppins";color:var(--orange);font-weight:600;font-size:.95rem;margin-bottom:.5rem;transition:color .4s ease}
.inno-card h3{position:relative;z-index:1;font-size:1.18rem;margin-bottom:.5rem;color:var(--ink);transition:color .4s ease}
.inno-card p{position:relative;z-index:1;color:var(--muted);font-size:.93rem;margin:0;transition:color .4s ease}
.inno-card:hover{transform:translateY(-6px);box-shadow:0 28px 54px rgba(20,19,18,.22);border-color:transparent}
.inno-card:hover .ic-bg{opacity:1}
.inno-card:hover .ic-bg img{transform:scale(1)}
.inno-card:hover h3{color:#fff}
.inno-card:hover p{color:rgba(255,255,255,.85)}
.inno-card:hover .ic-num{color:#ff8f52}

/* icon feature row */
.icf{display:flex;gap:1rem;align-items:flex-start}
.icf .ic{flex:0 0 auto;width:48px;height:48px;border-radius:12px;background:rgba(233,100,42,.12);display:flex;align-items:center;justify-content:center}
.icf .ic svg{width:24px;height:24px;stroke:var(--orange);fill:none;stroke-width:1.9}
.icf h4{font-size:1.05rem;margin-bottom:.25rem}
.icf p{color:var(--muted);font-size:.9rem;margin:0}
.dark .icf .ic{background:rgba(233,100,42,.2)}
.dark .icf p{color:rgba(255,255,255,.7)}

/* checklist */
.why{list-style:none;display:grid;gap:.85rem}
.why li{display:flex;gap:.7rem;align-items:flex-start;font-weight:500}
.why .chk{flex:0 0 auto;width:24px;height:24px;border-radius:50%;background:rgba(116,192,67,.16);display:flex;align-items:center;justify-content:center}
.why .chk svg{width:13px;height:13px;stroke:var(--green);fill:none;stroke-width:3}
.dark .why .chk{background:rgba(116,192,67,.22)}

/* accordion */
.acc{border-top:1px solid rgba(255,255,255,.14)}
.acc details{border-bottom:1px solid rgba(255,255,255,.14)}
.acc summary{list-style:none;cursor:pointer;padding:20px 0;font-family:"Poppins";font-weight:500;font-size:1.12rem;display:flex;justify-content:space-between;align-items:center;color:#fff}
.acc summary::-webkit-details-marker{display:none}
.acc summary .pm{width:26px;height:26px;border-radius:50%;border:1.5px solid rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;transition:.25s;flex:0 0 auto}
.acc summary .pm::before{content:"+";font-size:1.1rem}
.acc details[open] summary .pm{background:var(--orange);border-color:var(--orange);transform:rotate(45deg)}
.acc .ac-body{padding:0 0 22px;color:rgba(255,255,255,.74);font-size:.95rem}
.acc .ac-body ul{margin:.4rem 0 0 1.1rem}
.acc .ac-body li{margin-bottom:.3rem}
.acc .hl{color:var(--orange);font-weight:600}

/* process steps */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.step{text-align:left}
.step .n{font-family:"Poppins";font-weight:700;font-size:1.5rem;color:var(--orange);width:48px;height:48px;border-radius:50%;border:1.5px solid rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.step h4{font-size:1rem;margin-bottom:.3rem}
.step p{font-size:.85rem;color:rgba(255,255,255,.66);margin:0}
.process4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.process4 .pic{width:56px;height:56px;margin:0 auto 12px;border-radius:14px;background:rgba(233,100,42,.18);display:flex;align-items:center;justify-content:center}
.process4 .pic svg{width:28px;height:28px;stroke:var(--orange);fill:none;stroke-width:1.8}
.process4 h4{font-size:1.02rem}

/* stat bar */
.statbar{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:16px;overflow:hidden}
.statbar .s{padding:22px 24px;border-right:1px solid var(--line)}
.statbar .s:last-child{border-right:0}
.statbar .lbl{color:var(--orange);font-family:"Poppins";font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.3rem}
.statbar .val{font-family:"Poppins";font-weight:600;font-size:1.5rem}
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.stat b{font-family:"Poppins";font-size:2.2rem;color:var(--orange);display:block;line-height:1}
.stat span{font-size:.84rem;color:var(--muted)}
.dark .stat span{color:rgba(255,255,255,.6)}

/* badge */
.badge-img{position:relative}
.badge-img img{border-radius:var(--r);width:100%;height:clamp(300px,46vw,480px);object-fit:cover;box-shadow:0 24px 50px rgba(20,19,18,.18)}
.badge{position:absolute;left:-22px;bottom:30px;background:var(--orange);color:#fff;border-radius:16px;padding:18px 22px;box-shadow:0 16px 36px rgba(233,100,42,.36)}
.badge b{font-family:"Poppins";font-size:2rem;display:block;line-height:1;font-variant-numeric:tabular-nums}
.badge span{font-size:.8rem;opacity:.9}

/* home: For Home dark banner with glass tiles */
.forhome-inner{position:relative;border-radius:var(--r);overflow:hidden;min-height:430px;display:flex;align-items:center;color:#fff}
.forhome-inner>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.forhome-inner::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(100deg,rgba(15,14,13,.9) 0 40%,rgba(15,14,13,.45))}
.forhome-inner .pad{padding:clamp(32px,5vw,54px) clamp(28px,5vw,52px);width:100%}
.forhome-inner h2{font-size:clamp(1.8rem,3vw,2.5rem);margin-bottom:.7rem}
.forhome-inner>.pad>p{max-width:50ch;color:rgba(255,255,255,.82);margin-bottom:2.2rem}
.fh-feats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:760px}
.fh-feat{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:20px;backdrop-filter:blur(4px);transition:.25s}
.fh-feat:hover{background:rgba(233,100,42,.16);border-color:rgba(233,100,42,.4);transform:translateY(-4px)}
.fh-feat .ic{width:40px;height:40px;border-radius:10px;background:var(--orange);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.fh-feat .ic svg{width:20px;height:20px;stroke:#fff;fill:none}
.fh-feat h4{font-size:1.02rem;margin-bottom:.3rem}
.fh-feat p{font-size:.84rem;color:rgba(255,255,255,.72);margin:0}

/* home: innovation band */
.innov{position:relative;color:#fff;overflow:hidden}
.innov>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.innov::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,rgba(15,14,13,.92) 0 50%,rgba(15,14,13,.55))}
.innov .wrap{padding:clamp(54px,8vw,84px) clamp(18px,4vw,28px)}
.innov h2{font-size:clamp(1.8rem,3vw,2.6rem);margin-bottom:.8rem}
.innov p{max-width:48ch;color:rgba(255,255,255,.82);margin-bottom:1.6rem}

/* home hero stagger + scroll cue */
.phero.tall .eyebrow,.phero.tall h1,.phero.tall .lead,.phero.tall .acts{opacity:0;transform:translateY(24px);animation:up .9s forwards cubic-bezier(.2,.7,.2,1)}
.phero.tall h1{animation-delay:.15s}.phero.tall .lead{animation-delay:.3s}.phero.tall .acts{animation-delay:.45s}
@keyframes up{to{opacity:1;transform:none}}
.scroll-cue{position:absolute;left:50%;bottom:28px;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.5rem;color:rgba(255,255,255,.6);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-family:"Poppins"}
.scroll-cue .dot{width:24px;height:38px;border:1.5px solid rgba(255,255,255,.45);border-radius:14px;position:relative}
.scroll-cue .dot::after{content:"";position:absolute;left:50%;top:7px;transform:translateX(-50%);width:4px;height:7px;border-radius:3px;background:#fff;animation:sc 1.6s infinite}
@keyframes sc{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,12px)}}

/* solution band */
.solband{position:relative;border-radius:var(--r);overflow:hidden;min-height:330px;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;padding:50px}
.solband img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.solband::after{content:"";position:absolute;inset:0;z-index:-1;background:rgba(15,14,13,.6)}
.solband h2{font-size:clamp(1.6rem,3vw,2.3rem);margin-bottom:1rem}
.solband p{max-width:62ch;color:rgba(255,255,255,.85)}
.solvideo{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:16/9;background:#0f0e0d;box-shadow:0 24px 50px rgba(20,19,18,.18)}
.solvideo video{display:block;width:100%;height:100%;object-fit:cover}
/* EV home product card (rebuilt in HTML for crisp text + animated %) */
.ev-card{background:#f4f4f3;border-radius:26px;padding:30px 30px 26px;box-shadow:0 26px 54px rgba(20,19,18,.13);max-width:520px;margin:0 auto;display:flex;align-items:center;gap:14px}
.ev-card__battery{flex:0 0 auto;width:32%;max-width:146px;height:auto;filter:drop-shadow(0 16px 22px rgba(0,0,0,.26))}
.ev-card__right{flex:1 1 auto;display:flex;flex-direction:column;align-items:center;text-align:center;min-width:0}
.ev-card__date{font-weight:600;font-size:.8rem;color:var(--ink-2)}
.ev-card__pct{display:flex;align-items:baseline;justify-content:center;gap:6px;margin-top:2px;line-height:1}
.ev-card__pct b{font-family:"Poppins";font-weight:700;font-size:clamp(2.3rem,5.4vw,3.1rem);color:var(--orange);line-height:1;font-variant-numeric:tabular-nums}
.ev-card__pct .ch{font-weight:700;font-size:clamp(1rem,2.4vw,1.25rem);color:var(--ink-2);letter-spacing:.01em}
.ev-card__than{font-weight:700;font-size:clamp(.92rem,2.2vw,1.02rem);color:var(--ink-2);line-height:1.22;margin-top:6px}
.ev-card__charger{margin-top:18px;background:#eeeeef;border-radius:18px;padding:14px 26px;box-shadow:0 12px 30px rgba(233,100,42,.30),0 0 0 1px rgba(233,100,42,.10)}
.ev-card__charger img{display:block;width:140px;max-width:100%;height:auto}
.ev-card__caption{margin-top:18px;color:var(--orange);font-family:"Poppins";font-weight:600;font-size:1.18rem;line-height:1.28}
@media(max-width:560px){.ev-card{flex-direction:column}.ev-card__battery{width:auto;max-width:130px}}

/* quote */
.quote{font-family:"Poppins";font-weight:400;font-size:1.4rem;line-height:1.5;position:relative;padding-left:20px;background:var(--mist);border-radius:16px;padding:34px 30px}
.quote.on-dark{background:rgba(255,255,255,.05)}
.quote::before{content:"“";position:absolute;left:14px;top:-6px;font-size:4rem;color:var(--orange);font-family:Georgia,serif;line-height:1}
.q-author{margin-top:1.2rem}
.q-author b{font-family:"Poppins";font-size:1.02rem}
.q-author span{display:block;color:var(--orange);font-size:.88rem}

/* partner logos */
.plogos{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-top:clamp(36px,5vw,58px)}
.plogo{height:84px;border:1px solid var(--line);border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--paper);transition:.25s;padding:14px 20px}
.plogo img{max-height:42px;max-width:100%;width:auto;object-fit:contain;display:block}
@media(max-width:980px){.plogos{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.plogos{grid-template-columns:repeat(2,1fr);gap:14px}}
.plogo:hover{border-color:var(--orange);transform:translateY(-3px);box-shadow:0 10px 22px rgba(20,19,18,.07)}

/* CTA */
.cta{position:relative;color:#fff;overflow:hidden}
.cta .bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:-2;transform:scale(1.16);will-change:transform}
.cta::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(90deg,rgba(15,14,13,.85),rgba(15,14,13,.4))}
.cta .wrap{padding:clamp(60px,9vw,100px) clamp(18px,4vw,28px)}
.cta h2{font-size:clamp(2.2rem,4.5vw,3.6rem);margin-bottom:1.4rem}

/* footer */
footer{background:#0f0e0d;color:rgba(255,255,255,.7);padding:64px 0 28px}
.foot-top{display:grid;grid-template-columns:1.3fr 1fr 1fr 1.1fr;gap:40px;padding-bottom:42px;border-bottom:1px solid rgba(255,255,255,.1)}
footer .logo{margin-bottom:1rem}
.foot-top p{font-size:.92rem;max-width:34ch}
.foot-col h4{font-family:"Poppins";color:#fff;font-size:1rem;margin-bottom:1rem}
.foot-col ul{list-style:none;display:grid;gap:.6rem}
.foot-col a{font-size:.9rem;color:rgba(255,255,255,.66);transition:.2s}
.foot-col a:hover{color:var(--orange);padding-left:3px}
.foot-contact div{display:flex;gap:.6rem;align-items:flex-start;margin-bottom:.85rem;font-size:.9rem}
.foot-contact svg{width:16px;height:16px;stroke:var(--orange);fill:none;flex:0 0 auto;margin-top:3px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;font-size:.82rem;color:rgba(255,255,255,.5);flex-wrap:wrap;gap:12px}
.foot-bottom .socials a{width:34px;height:34px;border-color:rgba(255,255,255,.2)}
.foot-bottom .socials svg{width:13px;height:13px}

/* ---------- article + sidebar (news/case single) ---------- */
.article-layout{display:grid;grid-template-columns:1fr 320px;gap:54px}
.article p{color:#3f4045;margin-bottom:1.1rem}
.article h2{font-size:1.7rem;margin:2rem 0 .9rem}
.article h3{font-size:1.3rem;margin:1.6rem 0 .7rem}
.article ul{margin:0 0 1.1rem 1.2rem;color:#3f4045}
.article ul li{margin-bottom:.4rem}
.article img.inline{border-radius:14px;margin:1.6rem 0;width:100%;height:clamp(200px,40vw,320px);object-fit:cover}
.article figure{margin:1.8rem 0}
.article figure img{display:block;width:100%;height:auto;border-radius:var(--r)}
.article figure.portrait img{width:auto;max-width:100%;max-height:540px;margin:0 auto}
.article figcaption,.article .cap-center{margin-top:.7rem;font-size:.85rem;color:var(--muted);text-align:center;line-height:1.5}
.article .img2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:1.8rem 0 0}
.article .img2 figure{margin:0}
.article .img2 img{aspect-ratio:3/4;object-fit:cover;object-position:center}
.article .img2.land img{aspect-ratio:3/2}
.article .source{font-size:.85rem;color:var(--muted);margin-top:1.6rem}
.article .source a{color:var(--orange);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s}
.article .source a:hover{border-bottom-color:currentColor}
.aside .box{margin-bottom:34px}
.aside h4{font-family:"Poppins";font-size:1.1rem;margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid var(--line)}
.aside ul{list-style:none;display:grid;gap:.7rem}
.aside ul a{color:var(--muted);font-size:.92rem;transition:.2s}
.aside ul a:hover{color:var(--orange)}
.recent{display:flex;gap:12px;margin-bottom:14px;align-items:center}
.recent img{width:64px;height:54px;border-radius:8px;object-fit:cover;flex:0 0 auto}
.recent .t{font-family:"Poppins";font-weight:500;font-size:.9rem;line-height:1.3}
.recent .dt{font-size:.74rem;color:var(--muted)}
.tagrow{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:26px;padding-top:20px;border-top:1px solid var(--line)}
.chip{font-size:.78rem;background:var(--mist);border:1px solid var(--line);border-radius:999px;padding:5px 12px;color:var(--muted)}
.prevnext{display:flex;justify-content:space-between;gap:20px;margin-top:30px;padding-top:24px;border-top:1px solid var(--line)}
.prevnext .pn small{color:var(--muted);font-size:.78rem}
.prevnext .pn b{font-family:"Poppins";font-weight:500;display:block;font-size:.95rem}

/* news list cards */
.news-list .post{margin:0;padding:42px 0;border-top:1px solid var(--line)}
.news-list .post.first-on-page{border-top:0;padding-top:0}
.post{margin-bottom:46px}
.post img{border-radius:14px;width:100%;height:clamp(210px,38vw,320px);object-fit:cover;margin-bottom:18px}
.post .poster-band{width:100%;height:400px;background:#0b0b0c;border-radius:14px;overflow:hidden;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.post .poster-band img{width:auto;height:100%;max-width:100%;object-fit:contain;margin:0;border-radius:0}
.post .cat{color:var(--orange);font-size:.8rem;font-family:"Poppins";font-weight:500}
.post h3{font-size:1.45rem;margin:.3rem 0 .5rem}
.post p{color:var(--muted);font-size:.95rem}

/* case grid */
.filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:14px}
.filters button{font-family:"Poppins";font-weight:500;font-size:.88rem;border:1px solid var(--line);background:#fff;color:#444;border-radius:999px;padding:.5em 1.1em;cursor:pointer;transition:.2s}
.filters button.on,.filters button:hover{background:var(--orange);border-color:var(--orange);color:#fff}
.subfilters{display:flex;flex-wrap:wrap;gap:24px;justify-content:center;margin-bottom:40px;color:var(--muted);font-size:.9rem}
.subfilters span{cursor:pointer}.subfilters span:hover{color:var(--orange)}
.case-card{border-radius:14px;overflow:hidden;background:#fff;border:1px solid var(--line);transition:.25s}
.case-card:hover{transform:translateY(-5px);box-shadow:0 18px 40px rgba(20,19,18,.1)}
.case-card img{width:100%;height:180px;object-fit:cover}
.case-card .cc{padding:20px}
.case-card h3{font-size:1.1rem;line-height:1.25;margin-bottom:.6rem}
.case-card .m{font-size:.82rem;color:var(--muted);margin-bottom:.2rem}
.case-card .cat{color:var(--orange);font-size:.8rem;font-family:"Poppins";font-weight:500;margin-top:.6rem;display:inline-block}
.pager{display:flex;gap:10px;justify-content:center;margin-top:42px}
.pager a{width:42px;height:42px;border-radius:10px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:"Poppins";font-weight:500;transition:.2s}
.pager a.on,.pager a:hover{background:var(--orange);border-color:var(--orange);color:#fff}
.pager a[aria-disabled="true"]{opacity:.4;pointer-events:none}

/* downloads */
.dlgroup{margin-bottom:42px}
.dlgroup h3{font-size:1.15rem;margin-bottom:16px}
.dlrow{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.dlrow svg{width:20px;height:20px;stroke:var(--orange);fill:none;flex:0 0 auto}
.dlrow a{color:var(--orange);font-weight:500}
.dlrow a:hover{text-decoration:underline}
.dlrow .sz{color:var(--muted);font-size:.82rem;margin-left:auto;white-space:nowrap}

/* contact form */
.cform{display:grid;gap:14px}
.cform input,.cform select,.cform textarea{width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:10px;background:var(--mist);font-family:inherit;font-size:.95rem;color:var(--ink)}
.cform textarea{min-height:120px;resize:vertical}
.cform input:focus,.cform select:focus,.cform textarea:focus{outline:none;border-color:var(--orange);background:#fff}
.cinfo h3{font-size:1.3rem;margin:1.4rem 0 1rem}
.cinfo .row{display:flex;gap:.7rem;align-items:flex-start;margin-bottom:1rem}
.cinfo .row svg{width:18px;height:18px;stroke:var(--orange);fill:none;flex:0 0 auto;margin-top:4px}
.map-ph{height:400px;border-radius:var(--r);background:linear-gradient(135deg,#e8eef0,#dfe7ea);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted);font-family:"Poppins";position:relative;overflow:hidden}
.map-ph::after{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(116,192,67,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(116,192,67,.08) 1px,transparent 1px);background-size:40px 40px}
.map-ph .pin{position:relative;z-index:2;text-align:center}
.map-ph .pin svg{width:34px;height:34px;stroke:var(--orange);fill:var(--orange);margin-bottom:6px}
.map-embed{position:relative;height:clamp(320px,40vw,440px);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:0 14px 34px rgba(20,19,18,.06);background:var(--mist)}
.map-embed iframe{width:100%;height:100%;border:0;display:block;filter:grayscale(.08)}
.map-embed .map-link{position:absolute;right:14px;bottom:14px;z-index:2;background:#fff;border:1px solid var(--line);border-radius:999px;padding:.5em 1em;font-family:"Poppins";font-weight:500;font-size:.82rem;color:var(--ink);box-shadow:0 6px 18px rgba(20,19,18,.12);transition:.2s}
.map-embed .map-link:hover{color:var(--orange);transform:translateY(-2px)}

/* lighting portfolio */
.portfolio{display:grid;grid-template-columns:120px 1fr;gap:24px;align-items:start;margin-bottom:30px}
.portfolio .series-lbl{font-family:"Poppins";font-weight:600;color:var(--orange);padding-top:8px}
.lights{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.light{text-align:center}
.light .box{height:96px;border-radius:12px;background:var(--mist);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin-bottom:8px}
.light .box svg{width:54px;height:46px;color:#9aa0a6}
.light b{font-family:"Poppins";font-weight:500;font-size:.9rem;display:block}
.light span{font-size:.76rem;color:var(--muted)}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery img{border-radius:12px;height:clamp(150px,24vw,200px);width:100%;object-fit:cover;transition:.3s}
.gallery a{overflow:hidden;border-radius:12px}
.gallery img:hover{transform:scale(1.06)}

/* radial spec */
.spec{display:grid;grid-template-columns:1fr auto 1fr;gap:30px;align-items:center;max-width:860px;margin:0 auto}
.spec .col{display:grid;gap:26px}
.spec .feat h4{font-size:1rem;color:var(--orange)}
.spec .feat p{font-size:.85rem;color:var(--muted);margin:0}
.spec .col.r{text-align:right}
.spec .disc{width:264px;height:240px;border-radius:50%;background:radial-gradient(64% 56% at 50% 50%,#fbe0cf 0%,#f8d2b8 50%,rgba(248,210,184,0) 100%);display:flex;align-items:center;justify-content:center;position:relative;overflow:visible}
.spec .disc img{display:block;width:auto;height:auto;filter:drop-shadow(0 18px 26px rgba(20,19,18,.22))}
.spec .disc.batt img{height:300px;margin-top:-6px}
.spec .disc.charger img{width:244px}

/* relationship diagram */
.reldiag{display:grid;grid-template-columns:1fr auto 1fr;gap:30px;align-items:center;max-width:820px;margin:0 auto}
.relnode{background:var(--mist);border:1px solid var(--line);border-radius:14px;padding:18px;text-align:center}
.relnode b{font-family:"Poppins";display:block;color:var(--orange)}
.relnode span{font-size:.82rem;color:var(--muted)}
.relcore{width:140px;height:140px;border-radius:50%;background:linear-gradient(135deg,var(--orange),#f59563);color:#fff;display:flex;align-items:center;justify-content:center;text-align:center;font-family:"Poppins";font-weight:600;padding:14px;box-shadow:0 16px 40px rgba(233,100,42,.3)}

/* footprint map placeholder */
.footprint{height:420px;border-radius:var(--r);background:linear-gradient(135deg,#eef2f4,#e3eaee);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--muted);font-family:"Poppins";position:relative;overflow:hidden}
.offices{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.office-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s ease}
.office-card:hover{transform:translateY(-5px);box-shadow:0 18px 40px rgba(20,19,18,.1)}
.office-card h4{font-size:1.05rem;margin-bottom:.35rem}
.office-card .loc{font-size:.82rem;color:var(--muted);margin-bottom:1rem}
.office-card a{display:flex;align-items:center;gap:.55rem;font-size:.9rem;color:#3f4045;margin-top:.55rem;word-break:break-word}
.office-card a:hover{color:var(--orange)}
.office-card svg{width:16px;height:16px;stroke:var(--orange);fill:none;flex:0 0 auto}
/* business footprint: contact list + map */
.footprint-grid{display:grid;grid-template-columns:0.82fr 1.18fr;gap:44px;align-items:center}
.fp-offices{display:flex;flex-direction:column;gap:20px}
.fp-office h4{font-size:1.12rem;margin-bottom:6px;color:var(--ink)}
.fp-office ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}
.fp-office li{position:relative;padding-left:18px;color:var(--ink-2);font-size:.96rem;word-break:break-word}
.fp-office li::before{content:"";position:absolute;left:3px;top:.62em;width:5px;height:5px;border-radius:50%;background:var(--muted)}
.fp-office li a{color:var(--orange);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s ease}
.fp-office li a[href^="tel"]{color:var(--ink-2)}
.fp-office li a:hover{border-bottom-color:currentColor}
.fp-map{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:0 14px 34px rgba(20,19,18,.06)}
.fp-map img{width:100%;height:auto;display:block}
@media(max-width:860px){.footprint-grid{grid-template-columns:1fr;gap:30px}}
.scn-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.scn-card{border-radius:14px;overflow:hidden;border:1px solid var(--line);background:#fff;transition:transform .45s cubic-bezier(.2,.7,.2,1),box-shadow .45s ease}
.scn-card:hover{transform:translateY(-5px);box-shadow:0 20px 44px rgba(20,19,18,.12)}
.scn-card .scn-h{display:flex;align-items:center;gap:.7rem;padding:18px 22px}
.scn-card .scn-h h4{font-size:1.06rem;line-height:1.25}
.scn-card img{width:100%;height:clamp(180px,30vw,240px);object-fit:cover;display:block;transition:transform .55s cubic-bezier(.2,.7,.2,1)}
.scn-card:hover img{transform:scale(1.05)}
.ic-check{width:30px;height:30px;border-radius:50%;border:1.6px solid var(--orange);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.ic-check svg{width:15px;height:15px;stroke:var(--orange);fill:none;stroke-width:2.5}
.comp-card{background:var(--mist);border:1px solid var(--line);border-radius:16px;padding:26px;transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s ease}
.comp-card:hover{transform:translateY(-5px);box-shadow:0 18px 40px rgba(20,19,18,.08)}
.comp-card .ic{width:46px;height:46px;border-radius:12px;background:rgba(233,100,42,.12);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.comp-card .ic svg{width:24px;height:24px;stroke:var(--orange);fill:none;stroke-width:2}
.comp-card h3{font-size:1.14rem;margin-bottom:.45rem}
.comp-card>p{font-size:.9rem;color:var(--muted);margin-bottom:.7rem}
.comp-card ul{list-style:none;display:grid;gap:.42rem}
.comp-card li{position:relative;padding-left:1.1rem;font-size:.88rem;color:#3f4045}
.comp-card li::before{content:"";position:absolute;left:0;top:.55em;width:6px;height:6px;border-radius:50%;background:var(--orange)}
.gmodel{background:var(--mist);border:1px solid var(--line);border-radius:18px;padding:22px 22px 16px;transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s ease}
.gmodel:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(20,19,18,.08)}
.gmodel img{width:100%;height:auto;display:block}
.gmodel-cap{text-align:center;margin-top:8px}
.gmodel-cap b{display:block;font-family:"Poppins";font-weight:700;font-size:1.04rem;color:var(--ink)}
.gmodel-cap span{color:var(--muted);font-size:.9rem}
.footprint::after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle,rgba(116,192,67,.14) 1.5px,transparent 1.5px);background-size:26px 26px}
.footprint.has-map{background:#fff}
.footprint.has-map::after{display:none}
.footprint.has-map img{width:100%;height:100%;object-fit:contain;padding:18px;box-sizing:border-box;display:block}

/* ---------- interactive business-footprint map ---------- */
.fp-intro .sub{margin-top:1rem}
.fp-hint{display:flex;align-items:flex-start;gap:.55rem;margin-top:1.4rem;color:var(--ink-2);font-size:.92rem;font-weight:500}
.fp-hint svg{width:18px;height:18px;stroke:var(--orange);fill:none;flex:0 0 auto;margin-top:2px}
.fp-map{position:relative}
.fp-map img{width:100%;height:auto;display:block}
.fp-mark{position:absolute;transform:translate(-50%,-50%);width:30px;height:30px;padding:0;border:0;background:transparent;cursor:pointer;z-index:3}
.fp-mark .dot{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:13px;height:13px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 3px #fff,0 2px 6px rgba(20,19,18,.3);transition:transform .2s}
.fp-mark .dot::before{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--orange);opacity:.7;animation:fp-pulse 2s ease-out infinite}
.fp-mark:hover .dot,.fp-mark:focus-visible .dot{transform:translate(-50%,-50%) scale(1.18)}
.fp-mark.on .dot{background:var(--green)}
.fp-mark.on .dot::before{border-color:var(--green);animation:none;opacity:0}
.fp-mark:focus-visible{outline:none}
@keyframes fp-pulse{0%{transform:scale(1);opacity:.7}70%{transform:scale(2.1);opacity:0}100%{opacity:0}}
@media(prefers-reduced-motion:reduce){.fp-mark .dot::before{animation:none;opacity:0}}
.fp-pop{position:absolute;z-index:5;width:max-content;max-width:240px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 44px rgba(20,19,18,.18);padding:16px 18px;opacity:0;visibility:hidden;transform-origin:center;transition:opacity .18s ease,visibility .18s ease}
.fp-pop.show{opacity:1;visibility:visible}
.fp-pop__close{position:absolute;top:8px;right:10px;border:0;background:transparent;font-size:1.15rem;line-height:1;color:var(--muted);cursor:pointer;padding:2px}
.fp-pop__close:hover{color:var(--orange)}
.fp-pop h4{font-size:1rem;margin:0 18px .7rem 0;color:var(--ink)}
.fp-pop__row{display:flex;align-items:center;gap:.5rem;font-size:.88rem;color:var(--ink-2);padding:3px 0;word-break:break-word}
.fp-pop__row svg{width:15px;height:15px;stroke:var(--orange);fill:none;flex:0 0 auto}
.fp-pop a.fp-pop__row{color:var(--ink-2)}
.fp-pop a.fp-pop__row:hover{color:var(--orange)}
.fp-pop__row.mail{color:var(--orange)}

/* ===================== RESPONSIVE (layered, fluid) ===================== */

/* large desktop: keep content from stretching too wide on big monitors */
@media(min-width:1500px){
  :root{--maxw:1280px}
}

/* small laptop / large tablet landscape — soften multi-column grids gradually */
@media(max-width:1100px){
  .grid-2{gap:40px}
  .steps{grid-template-columns:repeat(3,1fr);row-gap:30px}
  .menu{gap:1.1rem}
  .menu a{font-size:.86rem}
}

/* tablet landscape — nav collapses to burger from here down */
@media(max-width:980px){
  .grid-2,.article-layout,.spec,.reldiag{grid-template-columns:1fr;gap:34px}
  .grid-3,.grid-4,.process4,.statbar,.lights,.gallery{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .statbar{border-radius:16px}.statbar .s{border-right:0;border-bottom:1px solid var(--line)}
  .statbar .s:last-child{border-bottom:0}
  .spec .col.r{text-align:left}
  .portfolio{grid-template-columns:1fr}
  .article-layout .aside{margin-top:8px}
  .menu{display:none}.burger{display:flex}
  .menu.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:rgba(20,19,18,.98);padding:18px clamp(18px,4vw,28px);gap:1rem;max-height:78vh;overflow:auto}
  .menu.open a{font-size:.95rem}
  .menu.open .has-sub::after{display:none}
  .menu.open .dd-caret{display:none}
  .menu.open .submenu{position:static;opacity:1;visibility:visible;transform:none;background:transparent;border:none;box-shadow:none;backdrop-filter:none;padding:8px 0 0 14px;min-width:0;border-left:2px solid rgba(255,255,255,.12);margin-top:.6rem;display:flex;flex-direction:column;gap:.6rem}
  .menu.open .submenu a{padding:0;font-size:.86rem}
  .foot-top{grid-template-columns:1fr 1fr}
  .phero{min-height:54vh;padding-bottom:48px}
  .badge{left:14px;bottom:14px}
}

/* tablet portrait — collapse the remaining 2-column card rows */
@media(max-width:768px){
  .grid-3,.grid-4,.process4,.scn-grid,.offices,.fh-feats{grid-template-columns:1fr}
  .lights,.gallery{grid-template-columns:repeat(2,1fr)}
  .imgcard,.biz-card{min-height:300px}
  .forhome-inner{min-height:auto}
  .article .img2,.article .img2.land{grid-template-columns:1fr}
  .prevnext{flex-direction:column;gap:18px}
  .sec-head{margin-bottom:34px}
  .quote{font-size:1.2rem;padding:26px 24px}
  .spec .disc{width:220px;height:200px}
  .spec .disc.batt img{height:240px}
}

/* phone */
@media(max-width:560px){
  .grid-2{gap:28px}
  .steps,.lights,.gallery,.stat-row,.statbar{grid-template-columns:1fr}
  .statbar .s{padding:18px 20px}
  .foot-top{grid-template-columns:1fr;gap:28px}
  .foot-bottom{flex-direction:column;align-items:flex-start;text-align:left}
  .phero{min-height:48vh;padding-bottom:40px}
  .phero h1{max-width:none}
  .phero h1 .hb{display:none}
  .badge{position:static;margin-top:16px;display:inline-block}
  .badge-img{display:flex;flex-direction:column;align-items:flex-start}
  .solband{padding:36px 22px}
  .quote::before{display:none}.quote{padding-left:24px}
  .acc summary{font-size:1rem}
  .article h2{font-size:1.42rem}.article h3{font-size:1.18rem}
}

/* small phone */
@media(max-width:420px){
  .gallery,.lights{grid-template-columns:repeat(2,1fr)}
  .logo{font-size:1.25rem}.logo img{height:40px}
  .logo.logo-foot img{height:48px}
  .btn{font-size:.9rem;padding:.78em 1.3em}
  .phero .acts{gap:.7rem}
  .phero .acts .btn{flex:1 1 auto;justify-content:center}
  .stat b{font-size:1.9rem}
  .pager a{width:38px;height:38px}
}
