  :root{
    --teal:#1D5553;--teal-d:#091e1a;--teal-2:#0f3631;--green:#10a048;--green-soft:#7df3a6;--emer:#14A14B;
    --grad:linear-gradient(118deg,#1D5553,#157953 50%,#10a048);
    --paper:#fff;--mist:#f4f7f5;--mist-2:#edf3f0;--line:#e2ece7;--ink:#0c1a16;--slate:#586b63;
    --maxw:1200px;--ease:cubic-bezier(.16,1,.3,1);--font-display:'Geist','Inter',-apple-system,'Segoe UI',sans-serif;--font-body:'Inter',-apple-system,'Segoe UI',sans-serif;--font-hero:var(--font-display);
    --shadow:0 30px 70px -34px rgba(9,30,26,.45);--shadow-sm:0 16px 38px -22px rgba(9,30,26,.4);
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth}
  body{font-family:var(--font-body);background:#fff;color:var(--slate);line-height:1.6;font-size:16.5px;overflow-x:hidden}
  ::selection{background:var(--green);color:#04240f}
  a{text-decoration:none;color:inherit}
  img{display:block;max-width:100%}
  h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);line-height:1.04;letter-spacing:-.03em;font-weight:700}
  .wrap{max-width:var(--maxw);margin:0 auto;padding:0 30px}
  .eyebrow{display:inline-flex;align-items:center;gap:11px;font-family:var(--font-body);font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--emer)}
  .eyebrow::before{content:"";width:26px;height:1.5px;background:var(--green);border-radius:2px}
  .eyebrow.light{color:var(--green-soft)}
  .img-slot{position:relative;background:repeating-linear-gradient(45deg,rgba(29,85,83,.05) 0 11px,rgba(29,85,83,.08) 11px 22px),var(--mist);border:1.5px dashed #c5d6cd;display:grid;place-items:center;color:var(--teal);overflow:hidden;border-radius:14px}
  .img-slot span{font-family:var(--font-body);font-size:11.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;opacity:.62;text-align:center;padding:12px}

  .topbar{background:#091e1a;color:#bfe0d3;font-size:12.5px}
  .topbar .row{display:flex;justify-content:space-between;align-items:center;min-height:42px;padding:6px 0;gap:16px}
  .topbar .row>div{display:flex;gap:20px;align-items:center}
  .topbar .dot{width:7px;height:7px;border-radius:50%;background:var(--green);display:inline-block;margin-right:7px;box-shadow:0 0 8px var(--green);animation:pulse 2.4s infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(19,193,86,.5)}70%{box-shadow:0 0 0 7px rgba(19,193,86,0)}100%{box-shadow:0 0 0 0 rgba(19,193,86,0)}}
  .soc{display:inline-flex;gap:8px;align-items:center}
  .soc a{width:30px;height:30px;display:grid;place-items:center;border-radius:9px;background:rgba(125,243,166,.1);border:1px solid rgba(125,243,166,.24);transition:.25s var(--ease)}
  .soc a:hover{background:var(--grad);border-color:transparent;transform:translateY(-2px);box-shadow:0 8px 18px -7px rgba(16,160,72,.7)}
  .soc a:hover svg path{fill:#06140f}
  .soc svg{width:15px;height:15px}
  @media(max-width:680px){.topbar .row{flex-wrap:nowrap;justify-content:space-between;align-items:center;min-height:42px;padding:6px 0;gap:10px;font-size:12px}.topbar .hours,.topbar .email{display:none}.topbar .row>div{display:flex;align-items:center;gap:10px}.topbar .soc{gap:8px}.topbar .soc a{width:28px;height:28px}}

  header.site{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
  header.site .row{display:flex;align-items:center;justify-content:space-between;height:108px;gap:24px}
  header.site .brand{display:flex;align-items:center}
  header.site .logo,.mnav-head .logo{height:auto;max-height:70px;max-width:340px;width:auto;object-fit:contain;display:block}
  header.site img,header.site .logo,header.site .custom-logo,.brand img,.mnav-head img,.mnav-head .logo{max-height:70px!important;height:auto!important;width:auto!important;max-width:320px!important;object-fit:contain!important}
  .mnav-head .logo{max-height:58px;max-width:240px}
  nav.links{display:flex;align-items:center;gap:2px}
  .links-list{display:flex;align-items:center;gap:2px;list-style:none;margin:0;padding:0}
  nav.links>a:not(.navbtn),.links-list a{position:relative;display:inline-block;font-family:var(--font-display);font-size:14.5px;font-weight:600;letter-spacing:-.012em;color:var(--ink);padding:9px 9px;line-height:1;transition:color .2s var(--ease)}
  nav.links>a:not(.navbtn)::after,.links-list a::after{content:"";position:absolute;left:50%;bottom:7px;width:0;height:2px;background:var(--grad);border-radius:2px;transform:translateX(-50%);transition:width .26s var(--ease)}
  nav.links>a:not(.navbtn):hover,.links-list a:hover,.links-list .current-menu-item>a,.links-list .current_page_item>a{color:var(--teal)}
  nav.links>a:not(.navbtn):hover::after,.links-list a:hover::after,.links-list .current-menu-item>a::after,.links-list .current_page_item>a::after{width:calc(100% - 18px)}
  .navbtn{margin-left:18px;background:var(--grad)!important;color:#fff!important;font-family:var(--font-display);font-weight:600;padding:11px 20px!important;border-radius:11px;box-shadow:0 10px 24px -12px rgba(19,193,86,.6)}
  .navbtn:hover{filter:brightness(1.05);transform:translateY(-1px)}
  .burger{display:none;flex-direction:column;gap:4px;width:46px;height:44px;border:1px solid var(--line);background:var(--mist);border-radius:11px;align-items:center;justify-content:center;cursor:pointer}
  .burger span{width:18px;height:2px;background:var(--ink);border-radius:2px}
  @media(max-width:980px){nav.links{display:none}.burger{display:flex}}

  /* SV-grade mobile menu */
  .mnav{position:fixed;inset:0;z-index:200;background:rgba(255,255,255,.86);backdrop-filter:blur(22px) saturate(1.2);display:flex;flex-direction:column;padding:18px 26px 30px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:.42s var(--ease)}
  .mnav.open{opacity:1;visibility:visible;transform:none}
  .mnav-head{display:flex;align-items:center;justify-content:space-between;height:64px}
  .mnav-head .plate img{height:56px}
  .mnav-x{width:46px;height:46px;border-radius:13px;border:1px solid var(--line);background:#fff;display:grid;place-items:center;cursor:pointer;color:var(--ink)}
  .mnav-x svg{width:20px;height:20px}
  .mnav-links{flex:1;display:flex;flex-direction:column;justify-content:center;gap:6px}
  .mnav-links a{font-family:var(--font-display);font-size:clamp(30px,9vw,46px);font-weight:800;letter-spacing:-.03em;color:var(--ink);padding:8px 0;opacity:0;transform:translateY(14px);transition:.5s var(--ease)}
  .mnav.open .mnav-links a{opacity:1;transform:none;transition-delay:calc(.06s * var(--i) + .08s)}
  .mnav-links a:active,.mnav-links a:hover{color:var(--teal)}
  .mnav-foot{display:flex;flex-direction:column;gap:14px}
  .mnav-foot .btn{width:100%}
  .mnav-call{text-align:center;font-size:14px;font-weight:600;color:var(--slate)}

  .hero{position:relative;background:var(--teal-d);color:#fff;overflow:hidden;isolation:isolate}
  .bgvideo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-5}
  .hero-media{position:absolute;inset:0;z-index:-5;overflow:hidden}
  .cms-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border:0}
  .img-slot.cms-filled{border-color:transparent}
  .img-slot.cms-filled>span{display:none}
  .mesh{position:absolute;inset:-20%;z-index:-4;filter:blur(60px);opacity:.85}
  .mesh span{position:absolute;border-radius:50%;mix-blend-mode:screen}
  .m1{width:55%;height:70%;background:radial-gradient(circle,#10a048,transparent 68%);top:-10%;right:-5%;animation:f1 20s var(--ease) infinite alternate}
  .m2{width:50%;height:65%;background:radial-gradient(circle,#157953,transparent 68%);bottom:-15%;left:-8%;animation:f2 26s var(--ease) infinite alternate}
  .m3{width:42%;height:55%;background:radial-gradient(circle,#1D5553,transparent 70%);top:25%;left:38%;animation:f3 30s var(--ease) infinite alternate}
  @keyframes f1{to{transform:translate(-70px,90px) scale(1.12)}}
  @keyframes f2{to{transform:translate(90px,-60px) scale(1.18)}}
  @keyframes f3{to{transform:translate(-50px,-70px) scale(.92)}}
  .veil{position:absolute;inset:0;z-index:-3;background:linear-gradient(160deg,rgba(9,30,26,var(--veil-top,.78)),rgba(15,54,49,var(--veil-bot,.55)) 70%)}
  .gridtex{position:absolute;inset:0;z-index:-2;opacity:.07;background-image:linear-gradient(#fff 1px,transparent 1px),linear-gradient(90deg,#fff 1px,transparent 1px);background-size:64px 64px;-webkit-mask-image:radial-gradient(78% 78% at 66% 30%,#000,transparent 82%);mask-image:radial-gradient(78% 78% at 66% 30%,#000,transparent 82%)}
  .sweep{position:absolute;inset:0;z-index:-1;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.06) 48%,transparent 60%);background-size:250% 100%;animation:sweep 9s linear infinite}
  @keyframes sweep{to{background-position:-150% 0}}
  .grain{position:absolute;inset:0;z-index:-1;opacity:.35;pointer-events:none;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E")}
  .hero .inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:84px 30px 96px;display:grid;grid-template-columns:1.12fr .88fr;gap:56px;align-items:center}
  @media(max-width:1000px){.hero .inner{grid-template-columns:1fr;gap:42px;padding:60px 30px 80px}}
  .hero h1{font-family:var(--font-hero);font-weight:800;font-size:clamp(40px,6vw,78px);line-height:1.02;letter-spacing:-.04em;color:#fff;margin:22px 0 22px}
  .hero h1 em{font-style:normal;font-weight:800;background:linear-gradient(100deg,#2fd877,#7df3a6);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;padding-right:.04em}
  .hero p.l1{font-size:18px;color:rgba(255,255,255,.9);max-width:52ch;margin-bottom:12px}
  .hero p.l2{font-size:14.5px;color:rgba(255,255,255,.62);max-width:52ch;margin-bottom:28px}
  .chips{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:32px}
  .chip{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);padding:8px 14px;border-radius:100px;font-size:12.5px;font-weight:500;backdrop-filter:blur(4px)}
  .chip .vc{width:16px;height:16px;flex:none}
  .actions{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
  .btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-body);font-weight:600;font-size:15px;padding:16px 28px;border-radius:13px;cursor:pointer;border:none;transition:.28s var(--ease)}
  .btn-grad{background:var(--grad);color:#fff;box-shadow:0 14px 34px -14px rgba(19,193,86,.7)}
  .btn-grad:hover{transform:translateY(-2px);box-shadow:0 20px 46px -16px rgba(19,193,86,.8)}
  .btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.32)}
  .btn-ghost:hover{background:#fff;color:var(--teal)}
  .btn-light{background:#fff;color:var(--teal)}
  .btn-light:hover{transform:translateY(-2px)}
  .btn-out{background:transparent;color:var(--teal);border:1.5px solid var(--line)}
  .btn-out:hover{background:var(--grad);color:#fff;border-color:transparent}
  .btn svg{width:17px;height:17px}
  .phone{display:flex;align-items:center;gap:12px;font-weight:600;color:#fff;cursor:pointer}
  .phone .ring{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);display:grid;place-items:center;transition:.25s}
  .phone:hover .ring{background:var(--green);border-color:var(--green)}
  .phone .ring svg{width:18px;height:18px;color:var(--green);transition:.25s}
  .phone:hover .ring svg{color:#04240f}
  .phone .num{font-family:var(--font-display);font-size:18px;font-weight:600;line-height:1}
  .phone small{display:block;font-weight:400;font-size:11.5px;color:rgba(255,255,255,.6);margin-top:3px}
  .formcard{position:relative;background:rgba(255,255,255,.98);border-radius:22px;padding:28px;box-shadow:0 60px 100px -36px rgba(0,0,0,.65);border:1px solid rgba(255,255,255,.5)}
  .formcard::before{content:"";position:absolute;inset:-1px;border-radius:23px;padding:1px;background:linear-gradient(140deg,rgba(19,193,86,.5),transparent 50%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
  .formcard h3{font-size:23px;color:var(--ink);margin-bottom:3px}
  .formcard .sub{font-size:13.5px;color:var(--slate);margin-bottom:18px}
  .frow{display:grid;grid-template-columns:1fr 1fr;gap:11px}
  .fld{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;font-family:inherit;font-size:14px;color:var(--ink);background:var(--mist);margin-bottom:11px;transition:.2s}
  textarea.fld{min-height:122px;line-height:1.55;resize:vertical}
  .fld:focus{outline:none;border-color:var(--green);background:#fff;box-shadow:0 0 0 4px rgba(19,193,86,.12)}
  select.fld{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23586b63' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center}
  .formcard .submit{width:100%;justify-content:center;background:var(--grad);color:#fff;margin-top:3px;box-shadow:0 14px 30px -14px rgba(19,193,86,.7)}
  .formcard .note{text-align:center;font-size:11.5px;color:var(--slate);margin-top:12px}
  .scrollcue{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:3;color:rgba(255,255,255,.45);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:7px}
  .scrollcue .m{width:21px;height:33px;border:1.5px solid rgba(255,255,255,.28);border-radius:12px;position:relative}
  .scrollcue .m::before{content:"";position:absolute;left:50%;top:6px;transform:translateX(-50%);width:3px;height:6px;border-radius:2px;background:var(--green);animation:sd 1.8s var(--ease) infinite}
  @keyframes sd{0%{opacity:0;top:6px}40%{opacity:1}80%{opacity:0;top:17px}100%{opacity:0}}

  .rise{opacity:0;transform:translateY(24px);animation:rise 1s var(--ease) forwards}
  @keyframes rise{to{opacity:1;transform:none}}
  .d1{animation-delay:.06s}.d2{animation-delay:.18s}.d3{animation-delay:.30s}.d4{animation-delay:.42s}.d5{animation-delay:.54s}.d6{animation-delay:.66s}
  .reveal{opacity:0;transform:translateY(28px);transition:.85s var(--ease)}
  .reveal.in{opacity:1;transform:none}
  @media(prefers-reduced-motion:reduce){.rise,.reveal{animation:none;opacity:1;transform:none;transition:none}.mesh span,.sweep{animation:none}}

  section.block{padding:78px 0;position:relative}
  .block.mist{background:var(--mist)}
  .sec-head{max-width:680px;margin-bottom:42px}
  .sec-head.center{margin:0 auto 46px;text-align:center}
  .sec-head h2{font-size:clamp(32px,4.4vw,52px);font-weight:600;margin:16px 0 16px;letter-spacing:-.025em}
  .sec-head h2 em{font-style:normal;font-weight:800;color:var(--teal)}
  .sec-head p{font-size:18px}

  .about{display:grid;grid-template-columns:1fr 1fr;gap:58px;align-items:center}
  @media(max-width:940px){.about{grid-template-columns:1fr;gap:38px}}
  .about-points{display:grid;gap:18px;margin-top:26px}
  .ipt{display:flex;gap:15px}
  .ipt .ic{width:48px;height:48px;border-radius:13px;background:#dff0e6;display:grid;place-items:center;flex:none}
  .ipt .ic svg{width:23px;height:23px}
  .ipt h4{font-size:18px;margin-bottom:3px;font-weight:600}
  .ipt p{font-size:14.5px}
  .about-visual{position:relative}
  .about-visual .img-slot{height:460px}
  .about-visual .badge{position:absolute;bottom:-22px;left:-16px;background:#fff;border-radius:18px;padding:18px 22px;box-shadow:var(--shadow);display:flex;align-items:center;gap:14px}
  .about-visual .badge .ring{width:50px;height:50px;border-radius:50%;background:var(--grad);display:grid;place-items:center;flex:none}
  .about-visual .badge .ring svg{width:24px;height:24px;color:#fff}
  .about-visual .badge b{font-family:var(--font-display);font-size:18px;color:var(--ink);display:block;line-height:1.1}
  .about-visual .badge span{font-size:12.5px}

  .svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
  @media(max-width:920px){.svc-grid{grid-template-columns:1fr}}
  .svc{position:relative;background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;transition:.38s var(--ease);display:flex;flex-direction:column}
  .svc:hover{transform:translateY(-7px);box-shadow:var(--shadow);border-color:transparent}
  .svc .img-slot{height:184px;border-radius:0;border-left:0;border-right:0;border-top:0}
  .svc .pad{padding:28px;display:flex;flex-direction:column;flex:1}
  .svc .ic{width:58px;height:58px;border-radius:15px;display:grid;place-items:center;background:var(--grad);margin:-58px 0 18px;position:relative;box-shadow:var(--shadow-sm)}
  .svc .ic svg{width:28px;height:28px}
  .svc h3{font-size:24px;margin-bottom:9px;font-weight:600}
  .svc>.pad>p{font-size:14.5px;margin-bottom:16px}
  .svc ul{list-style:none;display:flex;flex-wrap:wrap;gap:7px;margin-bottom:20px}
  .svc ul li{font-size:12.5px;background:var(--mist);border:1px solid var(--line);padding:6px 12px;border-radius:8px;color:var(--ink)}
  .svc .lk{margin-top:auto;display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14.5px;color:var(--teal)}
.lk svg{width:16px;height:16px;transition:transform .25s}
.lk:hover svg{transform:translateX(4px)}
  .svc .lk svg{width:16px;height:16px;transition:.25s}
  .svc:hover .lk svg{transform:translateX(4px)}
  .svc-band{margin-top:22px;background:var(--teal-d);border-radius:20px;padding:38px 42px;display:grid;grid-template-columns:auto 1fr auto;gap:30px;align-items:center;color:#fff;position:relative;overflow:hidden}
  .svc-band::before{content:"";position:absolute;right:-40px;top:-40px;width:240px;height:240px;border-radius:50%;background:var(--green);opacity:.14;filter:blur(20px)}
  .svc-band>*{position:relative;z-index:2}
  @media(max-width:780px){.svc-band{grid-template-columns:1fr;gap:18px;text-align:center;padding:30px}}
  .svc-band .ic{width:64px;height:64px;border-radius:16px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);display:grid;place-items:center;flex:none;margin:0 auto}
  .svc-band .ic svg{width:30px;height:30px;color:#fff}
  .svc-band h3{color:#fff;font-size:26px;margin-bottom:6px;font-weight:600}
  .svc-band p{color:rgba(255,255,255,.82);font-size:15px;max-width:62ch}

  .stats{background:var(--teal-d);border-radius:24px;padding:54px 34px;display:grid;grid-template-columns:repeat(var(--stat-cols,4),minmax(0,1fr));gap:26px;text-align:center;color:#fff;position:relative;overflow:hidden}
  .statband{background:var(--teal-d);padding:48px 0}
  .statband .stats{background:none;border-radius:0;padding:0;overflow:visible}
  .stats::before{content:"";position:absolute;left:-60px;bottom:-80px;width:280px;height:280px;border-radius:50%;background:var(--green);opacity:.12;filter:blur(30px)}
  .stats>div{position:relative;z-index:2}
  @media(max-width:720px){.stats{grid-template-columns:1fr 1fr;gap:36px 20px;padding:40px 24px}}
  .stats .n{font-family:var(--font-display);font-weight:600;font-size:clamp(34px,5vw,54px);line-height:1;color:#fff}
  .stats .n em{color:var(--green);font-style:normal}
  .stats .l{font-size:13px;color:rgba(255,255,255,.72);margin-top:10px}

  .phase-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch}
  @media(max-width:880px){.phase-grid{grid-template-columns:1fr;max-width:470px;margin:0 auto}}
  .phase{background:#fff;border:1px solid var(--line);border-radius:20px;padding:30px;display:flex;flex-direction:column;transition:.32s var(--ease);position:relative}
  .phase:hover{box-shadow:var(--shadow);transform:translateY(-6px)}
  .phase.feat{border:2px solid var(--green);box-shadow:var(--shadow)}
  .phase.feat::before{content:"Handover Standard";position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--grad);color:#fff;font-weight:600;font-size:11px;letter-spacing:.05em;text-transform:uppercase;padding:6px 16px;border-radius:100px;white-space:nowrap}
  .phase .stage{font-weight:600;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--teal);display:flex;align-items:center;gap:11px}
  .phase .stage .num{width:32px;height:32px;border-radius:10px;background:#dff0e6;display:grid;place-items:center;font-family:var(--font-display);font-size:15px;color:var(--teal)}
  .phase.feat .stage .num{background:var(--grad);color:#fff}
  .phase h3{font-size:25px;margin:16px 0 6px;font-weight:600}
  .phase .ideal{font-size:13px;color:var(--emer);font-weight:600;margin-bottom:20px}
  .phase ul{list-style:none;flex:1}
  .phase ul li{position:relative;padding-left:28px;font-size:14px;margin-bottom:11px}
  .phase ul li svg{position:absolute;left:0;top:2px;width:18px;height:18px}
  .phase .purpose{margin-top:20px;padding-top:18px;border-top:1px dashed var(--line);font-size:13px;font-style:normal;font-family:var(--font-display);color:var(--ink)}
  .phase .btn{margin-top:20px;justify-content:center;width:100%}

  .sector-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
  @media(max-width:820px){.sector-grid{grid-template-columns:1fr 1fr}}
  @media(max-width:480px){.sector-grid{grid-template-columns:1fr}}
  .sector{position:relative;border-radius:16px;overflow:hidden;min-height:230px;display:flex;flex-direction:column;justify-content:flex-end;padding:26px;color:#fff;isolation:isolate}
  .sector .img-slot{position:absolute;inset:0;border:none;border-radius:0;z-index:-2}
  .sector::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(transparent,rgba(9,30,26,.92))}
  .sector .ic{width:46px;height:46px;border-radius:13px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.2);display:grid;place-items:center;margin-bottom:auto;backdrop-filter:blur(4px)}
  .sector .ic svg{width:23px;height:23px;color:#fff}
  .sector h3{color:#fff;font-size:20px;margin-top:16px;font-weight:600}
  .sector p{font-size:13px;color:rgba(255,255,255,.82);margin-top:5px}

  .why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;align-items:stretch}
  .why-grid.cols-3{grid-template-columns:repeat(3,1fr)}
  .why-grid.cols-2{grid-template-columns:repeat(2,1fr)}
  .why-grid.cols-c{display:flex;flex-wrap:wrap;justify-content:center}
  .why-grid.cols-c>.why{flex:1 1 300px;max-width:362px}
  @media(max-width:900px){.why-grid,.why-grid.cols-2,.why-grid.cols-3{grid-template-columns:repeat(2,1fr)}}
  @media(max-width:520px){.why-grid,.why-grid.cols-2,.why-grid.cols-3{grid-template-columns:1fr}}
  .why{padding:30px;border:1px solid var(--line);border-radius:20px;background:#fff;transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease)}
  .why:hover{box-shadow:0 28px 56px -30px rgba(9,30,26,.42);transform:translateY(-6px);border-color:rgba(20,161,75,.28)}
  .why .ic{width:54px;height:54px;border-radius:16px;background:var(--grad);box-shadow:0 12px 24px -10px rgba(16,160,72,.6);display:grid;place-items:center;margin-bottom:20px;transition:transform .4s var(--ease)}
  .why:hover .ic{transform:scale(1.06) rotate(-3deg)}
  .why .ic svg{width:26px;height:26px;stroke:#fff}
  .why h4{font-family:var(--font-display);font-size:18px;letter-spacing:-.01em;margin-bottom:8px;font-weight:600;color:var(--ink)}
  .why p{font-size:14px;color:var(--slate)}

  .hs{background:var(--teal-d);color:#fff;border-radius:24px;padding:58px;position:relative;overflow:hidden}
  .hs::before{content:"";position:absolute;right:-60px;top:-60px;width:300px;height:300px;border-radius:50%;background:var(--green);opacity:.1;filter:blur(30px)}
  .hs .w2{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center}
  @media(max-width:820px){.hs{padding:40px}.hs .w2{grid-template-columns:1fr;gap:30px}}
  .hs h2{color:#fff;font-size:clamp(28px,3.8vw,42px);margin:16px 0;font-weight:600}
  .hs h2 em{font-style:normal;font-weight:800;color:var(--green-soft)}
  .hs p{color:rgba(255,255,255,.84)}
  .hs ul{list-style:none;display:grid;gap:14px}
  .hs ul li{position:relative;padding-left:32px;color:#eafff3;font-size:15px}
  .hs ul li svg{position:absolute;left:0;top:2px;width:21px;height:21px}

  .areas{display:flex;flex-wrap:wrap;gap:11px;justify-content:center}
  .pill{border:1px solid var(--line);border-radius:100px;padding:11px 21px;font-size:14.5px;font-weight:600;color:var(--ink);transition:.25s;cursor:pointer;background:#fff}
  .pill:hover{background:var(--grad);color:#fff;border-color:transparent;transform:translateY(-2px)}

  .final{position:relative;background:var(--teal-d);border-radius:28px;padding:66px;text-align:center;color:#fff;overflow:hidden}
  .final .mesh{opacity:.7}
  .final>.ct{position:relative;z-index:2}
  .final h2{color:#fff;font-size:clamp(30px,4.2vw,50px);margin:16px 0 14px;font-weight:600}
  .final h2 em{font-style:normal;font-weight:800;color:var(--green-soft)}
  .final p{color:rgba(255,255,255,.88);font-size:18px;max-width:56ch;margin:0 auto 30px}
  .final .row{display:flex;gap:15px;justify-content:center;flex-wrap:wrap}

  footer{background:var(--ink);color:#9db5ab;padding:74px 0 0}
  .foot-grid{display:grid;grid-template-columns:1.9fr 1fr 1fr 1.3fr;gap:40px;padding-bottom:50px}
  @media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr;gap:30px 26px}.foot-brand,.foot-grid>div:last-child{grid-column:1/-1}}
  @media(max-width:600px){.foot-bottom{flex-direction:column;align-items:flex-start;gap:10px}}
  @media(max-width:380px){.foot-grid{grid-template-columns:1fr}}
  .foot-brand .plate{background:#fff;border-radius:12px;padding:13px 16px;display:inline-block;margin-bottom:18px}
  .foot-brand .plate img{height:70px}
  .foot-brand p{font-size:14.5px;max-width:36ch;margin-bottom:18px}
  footer h4{font-family:var(--font-body);color:#fff;font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:18px;font-weight:600}
  footer ul{list-style:none}
  footer li{margin-bottom:11px}
  footer li a{font-size:14.5px}
  footer li a:hover{color:var(--green)}
  .foot-contact li{display:flex;gap:11px;align-items:flex-start;font-size:14.5px}
  .foot-contact svg{width:17px;height:17px;color:var(--green);flex:none;margin-top:3px}
  .foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding:24px 0;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:13px}
  .foot-bottom a:hover{color:var(--green)}

  .wa{position:fixed;right:20px;bottom:20px;z-index:80;width:58px;height:58px;border-radius:50%;background:#25D366;display:grid;place-items:center;box-shadow:0 14px 34px -10px rgba(37,211,102,.6);transition:.25s}
  .wa:hover{transform:scale(1.08)}
  .wa svg{width:29px;height:29px;color:#fff}
  /* slow accreditation scroller — bold text on brand band */
  .marquee{background:linear-gradient(110deg,#1D5553,#157953 52%,#10a048);padding:24px 0;overflow:hidden;position:relative}
  .marquee::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,rgba(255,255,255,.08),transparent 40%)}
  .marquee .track-wrap{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
  .marquee .track{display:flex;align-items:center;width:max-content;animation:mscroll 40s linear infinite}
  .marquee:hover .track{animation-play-state:paused}
  .marquee .item{display:inline-flex;align-items:center;font-family:var(--font-display);font-weight:800;font-size:clamp(17px,2vw,23px);letter-spacing:-.015em;color:#fff;white-space:nowrap}
  .marquee .item::after{content:"";width:7px;height:7px;background:#a8f5c4;transform:rotate(45deg);margin:0 32px;border-radius:1.5px;flex:none;box-shadow:0 0 10px rgba(168,245,196,.6)}
  @keyframes mscroll{to{transform:translateX(-50%)}}
  @media(max-width:600px){.marquee .item{font-size:16px}.marquee .item::after{margin:0 22px}}
  @media(prefers-reduced-motion:reduce){.marquee .track{animation:none;flex-wrap:wrap;justify-content:center;width:auto;gap:6px 0}}

/* ===== WordPress form handler states ===== */
.evg-hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0;overflow:hidden}
.evg-msg{margin:10px 0 0;font-size:14px;font-weight:600;min-height:1em}
  .evg-cf{margin:0 0 13px}
.evg-msg.ok{color:#0f7a3f}
.evg-msg.err{color:#c0392b}

/* ===== Inner pages (page.php / index.php / single.php / 404) ===== */
.page-hero{background:var(--grad);color:#eafff4;padding:140px 0 64px;position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;inset:0;background:radial-gradient(80% 120% at 80% -10%,rgba(168,245,196,.18),transparent 60%);pointer-events:none}
.page-hero .wrap{position:relative;z-index:2}
.page-hero h1{font-family:var(--font-display);font-size:clamp(30px,5vw,52px);letter-spacing:-.03em;margin:0;color:#fff}
.page-hero p{color:rgba(234,255,244,.82);margin:.7em 0 0;max-width:62ch}
.page-body{padding:64px 0 88px;background:var(--paper)}
.page-body .wrap{max-width:820px}
.page-body h2{font-family:var(--font-display);letter-spacing:-.02em;margin:1.5em 0 .5em;color:var(--ink)}
.page-body h3{font-family:var(--font-display);margin:1.2em 0 .4em;color:var(--ink)}
.page-body p,.page-body li{font-size:17px;line-height:1.75;color:var(--slate)}
.page-body a{color:#0f7a3f}
.page-body img{max-width:100%;height:auto;border-radius:14px}
.page-list{list-style:none;padding:0;margin:0;display:grid;gap:20px}
.page-list article{border:1px solid var(--line);border-radius:18px;padding:26px 28px;background:#fff;box-shadow:var(--shadow-sm)}
.page-list h2{margin:.1em 0 .3em;font-size:22px}
.post-meta{color:var(--slate);font-size:14px;margin:4px 0 0}
.btn-back{display:inline-flex;align-items:center;gap:8px;margin-top:28px;font-weight:600;color:#0f7a3f;text-decoration:none}
.nf-wrap{min-height:60vh;display:grid;place-items:center;text-align:center;padding:80px 20px}
.nf-wrap .big{font-family:var(--font-display);font-size:clamp(64px,16vw,150px);line-height:1;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* ===== Submit button styling in modal + calculator (mirrors .formcard .submit) ===== */
.qmodal-card .submit,.calc .submit{width:100%;justify-content:center;background:var(--grad);color:#fff;margin-top:3px;box-shadow:0 14px 30px -14px rgba(19,193,86,.7)}
.qmodal-card .submit:hover,.calc .submit:hover{filter:brightness(1.04)}

/* ===== Quote modal ===== */
.qmodal{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:20px}
.qmodal.open{display:flex}
.qmodal-backdrop{position:absolute;inset:0;background:rgba(6,17,14,.62);backdrop-filter:blur(5px)}
.qmodal-card{position:relative;z-index:1;width:100%;max-width:470px;max-height:92vh;overflow:auto;background:var(--paper);border-radius:22px;padding:30px 28px 26px;box-shadow:0 50px 100px -30px rgba(9,30,26,.55);animation:qpop .32s var(--ease)}
@keyframes qpop{from{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:none}}
.qmodal-card h3{font-family:var(--font-display);font-size:23px;letter-spacing:-.02em;margin:0 0 4px;color:var(--ink)}
.qmodal-card .sub{color:var(--slate);font-size:14px;margin:0 0 16px}
.qmodal-x{position:absolute;top:13px;right:13px;width:38px;height:38px;border:0;border-radius:50%;background:var(--mist-2);color:var(--ink);cursor:pointer;display:grid;place-items:center;transition:.2s}
.qmodal-x:hover{background:var(--line)}
.qmodal-x svg{width:18px;height:18px}
.evg-est-line{display:none;background:var(--mist-2);border:1px solid var(--line);border-radius:12px;padding:11px 13px;font-size:13px;font-weight:600;color:var(--teal);margin:0 0 13px;line-height:1.45}
  section[id]{scroll-margin-top:120px}
  .evg-est-line.est-disclaimer{margin:0 0 14px;font-weight:700;font-size:13px;line-height:1.5;color:#9a6b00;background:#fff8ec;border:1px solid #f3d27a;border-left:4px solid #e0a106;border-radius:10px;padding:10px 12px}
.est-hero{background:linear-gradient(120deg,rgba(16,160,72,.1),rgba(45,216,119,.14));border-color:rgba(16,160,72,.32);color:var(--teal-d);font-size:14px}

@media(max-width:520px){.qmodal{padding:0;align-items:stretch}.qmodal-card{max-width:none;width:100%;min-height:100vh;min-height:100dvh;max-height:100vh;max-height:100dvh;border-radius:0;padding:62px 18px 30px;overflow-y:auto;-webkit-overflow-scrolling:touch;animation:none}.qmodal-x{position:fixed;top:calc(12px + env(safe-area-inset-top));right:14px;z-index:210;width:42px;height:42px;background:#fff;box-shadow:0 6px 18px rgba(9,30,26,.28)}}

/* ===== Pricing + calculator ===== */
.pricing-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:22px;align-items:stretch}
.pricing-grid.one{grid-template-columns:minmax(0,640px);justify-content:center}
.price-list,.calc{background:var(--paper);border:1px solid var(--line);border-radius:22px;padding:30px 30px 26px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}
.calc{background:linear-gradient(180deg,#fff,#f6fbf8)}
.price-list h3,.calc h3{font-family:var(--font-display);font-size:20px;letter-spacing:-.02em;margin:0 0 16px;color:var(--ink)}
.rate-rows{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;flex:1}
.rate-rows li{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:13px 0;border-bottom:1px solid var(--line)}
.rate-rows li:last-child{border-bottom:0}
.rate-rows span{color:var(--ink);font-weight:500;font-size:15px}
.rate-rows b{font-family:var(--font-display);color:var(--teal);font-weight:800;font-size:16px;white-space:nowrap}
.rate-rows b i{font-style:normal;color:var(--slate);font-weight:600;font-size:12px;margin-left:1px}
.pnote,.cnote{color:var(--slate);font-size:12.5px;line-height:1.55;margin:16px 0 0}
.calc-fields{display:flex;flex-direction:column;gap:13px}
.cf{display:flex;flex-direction:column;gap:6px;font-size:12.5px;font-weight:700;color:var(--slate);letter-spacing:.02em;text-transform:uppercase}
.cf .fld{margin-bottom:0;text-transform:none;font-weight:500}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.calc-out{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:20px 0 18px}
.calc-out>div{background:var(--mist);border:1px solid var(--line);border-radius:14px;padding:14px 10px;text-align:center}
.calc-out span{display:block;font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--slate);margin-bottom:5px}
.calc-out b{font-family:var(--font-display);font-size:clamp(17px,2.3vw,23px);color:var(--teal);letter-spacing:-.01em}
.calc .c-book{width:100%;margin-top:auto}
@media(max-width:860px){.pricing-grid{grid-template-columns:1fr}}
@media(max-width:420px){.cf-row{grid-template-columns:1fr}.calc-out{gap:8px}.calc-out>div{padding:12px 6px}.calc-out b{font-size:17px}}

/* ===== Contact page ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:18px}
.contact-info .ci{display:flex;gap:14px;align-items:flex-start}
.contact-info .ci svg{width:22px;height:22px;flex:none;color:var(--teal);margin-top:2px}
.contact-info .ci b{display:block;font-family:var(--font-display);color:var(--ink);font-size:15px;margin-bottom:2px}
.contact-info .ci a,.contact-info .ci span{color:var(--slate);font-size:15px;text-decoration:none;line-height:1.5}
.contact-info .ci a:hover{color:var(--teal)}
.area-tags{display:flex;flex-wrap:wrap;gap:8px}
.area-tag{background:var(--mist-2);border:1px solid var(--line);border-radius:100px;padding:7px 14px;font-size:13px;font-weight:600;color:var(--teal)}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr}}

/* ===== Customizer image slots ===== */
.img-slot.ph{background:linear-gradient(135deg,var(--teal-2),var(--emer));border:0}
.img-slot.filled{border:0;background:none}
.img-slot.filled img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

  /* Customizer hero video background */
  .hero.has-video .mesh{display:none}
  @media(max-width:820px){.hero.has-video .mesh{display:block}}
  .hero.has-video .veil{background:linear-gradient(160deg,rgba(9,30,26,var(--veil-top,.74)),rgba(9,30,26,var(--veil-bot,.52)))}
  .hero-media .cms-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

  /* Accreditation / seal grid */
  .accred{margin-top:6px}
  .accred-cap{text-align:center;font-family:var(--font-body);font-size:12.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--slate);opacity:.82;margin-top:42px}
  .accred-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:22px}
  .accred-tile{display:grid;place-items:center;height:104px;padding:18px;overflow:hidden;background:var(--paper);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm)}
  .accred-tile img{max-height:62px;max-width:100%;width:auto;object-fit:contain;transition:.25s var(--ease)}
  .accred-tile:hover img{transform:scale(1.05)}
  .accred-tile.is-round{padding:11px}
  .accred-tile.is-round img{max-height:78px}
  .accred-grid.is-grayscale .accred-tile img{filter:grayscale(1);opacity:.85}
  .accred-grid.is-grayscale .accred-tile:hover img{filter:none;opacity:1}
  .accred-tile.is-text span{font-family:var(--font-display);font-weight:700;font-size:14px;line-height:1.2;color:var(--teal);text-align:center;letter-spacing:-.01em}
  @media(max-width:780px){.accred-grid{grid-template-columns:repeat(2,1fr);gap:11px}.accred-tile{height:92px;padding:14px}.accred-tile.is-round{padding:9px}.accred-tile.is-round img{max-height:66px}}

  /* Contact map embed */
  .map-embed.has-map{padding:0;min-height:0;display:block;background:none;border-radius:22px;overflow:hidden;border:1px solid var(--line);margin-top:26px}
  .map-embed.has-map iframe{display:block;width:100%;height:380px;border:0}
  @media(max-width:600px){.map-embed.has-map iframe{height:280px}}

  /* Testimonials */
  .tst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:34px}
  .tst{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:26px;box-shadow:var(--shadow-sm);margin:0;display:flex;flex-direction:column;gap:14px}
  .tst .stars{color:#f5b301;font-size:15px;letter-spacing:2px}
  .tst blockquote{font-size:15.5px;color:var(--ink);line-height:1.6;font-style:italic}
  .tst figcaption{display:flex;flex-direction:column;gap:2px;margin-top:auto}
  .tst figcaption b{font-family:var(--font-display);color:var(--ink);font-size:15px}
  .tst figcaption span{font-size:13px;color:var(--slate)}
  @media(max-width:860px){.tst-grid{grid-template-columns:1fr}}

  /* Footer designer credit */
  .evg-credit-link{color:var(--green-soft);text-decoration:underline;text-underline-offset:3px;font-weight:600}
  .evg-credit-link:hover{color:#fff}

  /* Mobile action bar (Quote | Calculator) + calculator modal */
  .mbar{display:none}
  @media(max-width:820px){
    .mbar{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--line)}
    .mbar a{display:flex;align-items:center;justify-content:center;gap:7px;padding:13px 8px;font-family:var(--font-display);font-weight:700;font-size:13.5px;letter-spacing:-.01em;color:#fff;text-decoration:none}
    .mbar .mbar-quote{background:var(--grad)}
    .mbar .mbar-calc{background:var(--teal);box-shadow:inset 1px 0 0 rgba(255,255,255,.14)}
    .mbar a svg{width:16px;height:16px;flex:none}
  }
  @media(min-width:521px){#calcmodal .qmodal-card{max-width:560px}}
  #calcmodal .evg-calc{background:none;border:0;padding:0;box-shadow:none}
  #calcmodal .evg-calc>h3{margin-top:0}

  /* EVG_MOBILE_SPACING — tighter vertical rhythm on phones */
  @media(max-width:680px){
    section.block{padding:50px 0}
    .sec-head{margin-bottom:28px}
    .sec-head.center{margin:0 auto 30px}
    .page-hero{padding:104px 0 46px}
    .page-body{padding:46px 0 58px}
    footer{padding:52px 0 0}
  }

  /* Feature split band + bolder inner hero (v2.7) */
  .split{display:grid;grid-template-columns:1.04fr .96fr;gap:50px;align-items:center}
  .split>*{min-width:0}
  .split-copy .eyebrow{margin-bottom:14px}
  .split-copy h2{font-size:38px;line-height:1.08;letter-spacing:-.02em;margin:0 0 16px}
  .split-copy>p{font-size:16px;color:var(--slate);margin:0 0 22px;max-width:46ch}
  .ticks{list-style:none;margin:0 0 26px;padding:0;display:grid;gap:12px}
  .ticks li{position:relative;padding-left:32px;font-size:15px;color:var(--ink);line-height:1.4}
  .ticks li::before{content:"";position:absolute;left:0;top:0;width:21px;height:21px;border-radius:7px;background:var(--grad)}
  .ticks li::after{content:"";position:absolute;left:6.5px;top:6px;width:8px;height:4px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg)}
  .split-media .img-slot{aspect-ratio:4/5;width:100%;border-radius:26px;overflow:hidden;box-shadow:0 44px 84px -42px rgba(9,30,26,.55)}
  .page-hero h1{font-size:clamp(34px,5vw,52px);line-height:1.05;letter-spacing:-.025em}
  @media(max-width:880px){.split{grid-template-columns:1fr;gap:28px}.split-media{order:-1}.split-copy h2{font-size:29px}.split-media .img-slot{aspect-ratio:16/10}}

  /* ===================== Services 2030 sample (scoped) ===================== */
  .hero-2030{position:relative;background:#071a16;color:#fff;padding:112px 0 56px;overflow:hidden;isolation:isolate}
  .hero-2030 .h2030-mesh{position:absolute;inset:0;z-index:-1;background:radial-gradient(58% 78% at 80% 16%,rgba(34,196,106,.42),transparent 60%),radial-gradient(52% 72% at 10% 92%,rgba(21,121,83,.55),transparent 62%),radial-gradient(42% 60% at 52% -8%,rgba(125,243,166,.14),transparent 55%)}
  .hero-2030::before{content:"";position:absolute;inset:0;z-index:0;opacity:.06;background-image:linear-gradient(#fff 1px,transparent 1px),linear-gradient(90deg,#fff 1px,transparent 1px);background-size:64px 64px;-webkit-mask-image:radial-gradient(80% 80% at 72% 26%,#000,transparent 82%);mask-image:radial-gradient(80% 80% at 72% 26%,#000,transparent 82%);pointer-events:none}
  .hero-2030 .wrap{position:relative;z-index:1;max-width:1080px}
  .h2030-badge{display:inline-flex;align-items:center;font:600 12px/1 var(--font-display);letter-spacing:.16em;text-transform:uppercase;color:#bff5d3;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);padding:10px 16px;border-radius:999px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}
  .hero-2030 h1{font-family:var(--font-display);font-weight:800;color:#fff;font-size:clamp(42px,7.4vw,92px);line-height:.98;letter-spacing:-.035em;margin:26px 0 0}
  .hero-2030 h1 em{font-style:normal;background:linear-gradient(100deg,#2fd877,#7df3a6);-webkit-background-clip:text;background-clip:text;color:transparent}
  .h2030-subhead{margin:18px 0 0;font-family:var(--font-display);font-weight:600;font-size:clamp(22px,3vw,32px);line-height:1.24;color:#eafaf0;max-width:680px;letter-spacing:-.01em}
  .h2030-lead{max-width:600px;margin:24px 0 0;font-size:clamp(16px,1.5vw,19px);line-height:1.6;color:rgba(255,255,255,.78)}
  .h2030-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
  .hero-2030 .btn-grad{background:var(--grad);color:#fff;border:0}
  .btn-ghost{background:transparent;border:1.5px solid rgba(255,255,255,.32);color:#fff}
  .btn-ghost:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.55)}
  .h2030-stats{display:grid;grid-template-columns:repeat(4,auto);gap:18px 54px;margin-top:40px;padding-top:26px;border-top:1px solid rgba(255,255,255,.14)}
  .h2030-stats b{display:block;font-family:var(--font-display);font-weight:800;font-size:clamp(30px,3.6vw,44px);line-height:1;letter-spacing:-.02em;background:linear-gradient(120deg,#fff,#9ff0bd);-webkit-background-clip:text;background-clip:text;color:transparent}
  .h2030-stats .plus{-webkit-text-fill-color:#2fd877;color:#2fd877}
  .h2030-stats small{display:block;margin-top:8px;font-size:13px;color:rgba(255,255,255,.6)}
  .page2030 .sec-head.center{text-align:left;max-width:800px;margin-left:0;margin-right:0}
  .page2030 .sec-head h2{font-size:clamp(30px,4.4vw,52px);letter-spacing:-.025em;line-height:1.05}
  .page2030 .sec-head>p{margin-left:0}
  .page2030 .why-grid{counter-reset:svc}
  .page2030 .why{counter-increment:svc;position:relative;overflow:hidden}
  .page2030 .why::after{content:counter(svc,decimal-leading-zero);position:absolute;top:20px;right:22px;font-family:var(--font-display);font-weight:800;font-size:15px;line-height:1;color:#cfeede;transition:color .4s var(--ease)}
  .page2030 .why::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--grad);transition:width .45s var(--ease)}
  .page2030 .why:hover{box-shadow:0 30px 64px -28px rgba(16,160,72,.55);border-color:transparent;transform:translateY(-8px)}
  .page2030 .why:hover::before{width:100%}
  .page2030 .why:hover::after{color:var(--green)}
  @media(max-width:680px){.hero-2030{padding:92px 0 46px}.h2030-stats{grid-template-columns:1fr 1fr;gap:24px 26px}}
/* back-to-top */
.totop{position:fixed;right:20px;bottom:88px;z-index:79;width:46px;height:46px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;box-shadow:0 12px 30px -10px rgba(9,30,26,.5);opacity:0;visibility:hidden;transform:translateY(8px);transition:.28s var(--ease);border:0;cursor:pointer}
.totop.show{opacity:1;visibility:visible;transform:none}
.totop:hover{filter:brightness(1.06);transform:translateY(-2px)}
.totop svg{width:22px;height:22px}

/* ===================================================================
   Optional comment field on quote / estimate pop-up forms
   =================================================================== */
.evg-comments{position:relative;margin:0 0 2px}
.evg-comments[hidden]{display:none !important}
.evg-comments textarea{width:100%;resize:vertical;min-height:84px}
.evg-cc{display:block;text-align:right;font-size:12px;color:var(--slate,#5b6b66);margin-top:4px}
.evg-cc b{font-weight:700;color:var(--ink,#1a2420)}

/* ===================================================================
   Inner-page hero photo (optional, per-page, Customizer toggle)
   Off by default -> hero stays exactly as the gradient design.
   On -> service photo fills the lighter side, tinted on-brand and
   fully responsive (right column on desktop, dimmed bg on mobile).
   =================================================================== */
.hero-2030.has-photo .h2030-photo{position:absolute;inset:0;width:100%;z-index:0;overflow:hidden}
.hero-2030.has-photo .h2030-photo img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.hero-2030.has-photo .h2030-photo-tint{position:absolute;inset:0;background:
  radial-gradient(58% 78% at 80% 16%,rgba(34,196,106,.26),transparent 60%),
  radial-gradient(52% 72% at 10% 92%,rgba(21,121,83,.38),transparent 62%),
  linear-gradient(180deg,rgba(6,22,18,.80),rgba(6,22,18,.72) 45%,rgba(6,22,18,.86))}
@media(min-width:981px){
  .hero-2030.has-photo .wrap{max-width:1080px;padding-right:0}
}
@media(max-width:980px){
  .hero-2030.has-photo .h2030-photo{width:100%;left:0}
  .hero-2030.has-photo .h2030-photo-tint{background:
    radial-gradient(60% 60% at 80% 12%,rgba(34,196,106,.24),transparent 60%),
    linear-gradient(180deg,rgba(6,22,18,.82),rgba(6,22,18,.88))}
}

  /* ===== FAQ accordion ===== */
  .faq-list{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
  .faq-cat{display:flex;align-items:center;gap:14px;margin:32px 4px 8px;font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:12.5px;letter-spacing:.16em;text-transform:uppercase}
  .faq-cat:first-child{margin-top:0}
  .faq-cat span{display:inline-flex;align-items:center;gap:11px;white-space:nowrap}
  .faq-cat span::before{content:"";width:22px;height:22px;border-radius:7px;background:var(--grad);box-shadow:var(--shadow-sm)}
  .faq-cat::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--line),transparent)}
  .faq-item{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:border-color .3s var(--ease),box-shadow .35s var(--ease),background .35s var(--ease)}
  .faq-item:hover{border-color:#cbe0d6}
  .faq-item.open{border-color:transparent;box-shadow:var(--shadow-sm);background:linear-gradient(180deg,#fff,#fafdfb)}
  .faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:21px 22px;margin:0;background:none;border:0;cursor:pointer;text-align:left;font-family:var(--font-display);font-weight:600;font-size:17.5px;letter-spacing:-.02em;line-height:1.34;color:var(--ink);transition:color .22s var(--ease)}
  .faq-q:hover,.faq-item.open .faq-q{color:var(--teal)}
  .faq-q:focus-visible{outline:2px solid var(--teal);outline-offset:-3px;border-radius:16px}
  .faq-qt{flex:1 1 auto}
  .faq-ic{flex:0 0 auto;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:var(--mist);color:var(--teal);transition:background .32s var(--ease),color .32s var(--ease)}
  .faq-ic svg{width:15px;height:15px;transition:transform .45s var(--ease)}
  .faq-item.open .faq-ic{background:var(--grad);color:#fff}
  .faq-item.open .faq-ic svg{transform:rotate(-180deg)}
  .faq-a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .42s var(--ease)}
  .faq-item.open .faq-a{grid-template-rows:1fr}
  .faq-a-in{overflow:hidden;min-height:0}
  .faq-a p{margin:0;padding:2px 22px 22px;color:var(--slate);font-size:16px;line-height:1.72}
  @media(max-width:560px){.faq-q{font-size:16px;padding:18px 17px;gap:12px}.faq-a p{padding:2px 17px 18px;font-size:15.5px}}
  @media(prefers-reduced-motion:reduce){.faq-a,.faq-ic svg{transition:none}}

/* =========================================================
   BLOG
   ========================================================= */
.blog-lede{background:linear-gradient(180deg,var(--mist) 0%,var(--paper) 100%);padding:54px 0 18px;border-bottom:1px solid var(--line)}
.blog-lede-head{max-width:760px;margin-bottom:30px}
.blog-lede-head h1{font-family:var(--font-display);font-size:clamp(30px,4.4vw,46px);line-height:1.05;letter-spacing:-.02em;margin:.32em 0 .28em;color:var(--ink)}
.blog-lede-sub{color:var(--slate);font-size:17px;max-width:60ch;margin:0}
.blog-lede-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:26px;align-items:stretch}

.blead{position:relative;display:flex;align-items:flex-end;min-height:360px;border-radius:22px;overflow:hidden;background:var(--teal-2);box-shadow:var(--shadow);isolation:isolate;text-decoration:none}
.blead img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform .7s var(--ease)}
.blead::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(9,30,26,0) 30%,rgba(9,30,26,.85) 100%)}
.blead.ph{background:var(--grad)}
.blead.ph::after{background:linear-gradient(180deg,rgba(9,30,26,.15),rgba(9,30,26,.6))}
.blead:hover img{transform:scale(1.05)}
.blead-tag{position:absolute;top:16px;left:16px;background:rgba(255,255,255,.92);color:var(--teal);font-weight:800;font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:6px 11px;border-radius:999px;z-index:1}
.blead-body{display:flex;flex-direction:column;gap:8px;padding:24px;color:#fff}
.blead-cat{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--green-soft)}
.blead-title{font-family:var(--font-display);font-size:clamp(21px,2.4vw,28px);line-height:1.16;font-weight:800;letter-spacing:-.01em}
.blead-meta{font-size:13px;opacity:.86}

.blog-recent{background:var(--paper);border:1px solid var(--line);border-radius:22px;padding:22px 24px;display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}
.blog-recent-t{font-family:var(--font-display);font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);margin:0 0 6px}
.blog-recent ul{list-style:none;margin:0;padding:0;flex:1}
.blog-recent li{border-bottom:1px solid var(--line)}
.blog-recent li:last-child{border-bottom:0}
.blog-recent li a{display:flex;flex-direction:column;gap:3px;padding:13px 0;text-decoration:none;transition:padding-left .25s var(--ease)}
.blog-recent li a:hover{padding-left:6px}
.br-title{font-weight:700;color:var(--ink);font-size:15px;line-height:1.3}
.blog-recent li a:hover .br-title{color:var(--teal)}
.br-date{font-size:12px;color:var(--slate);font-weight:600;letter-spacing:.02em}
.br-empty{color:var(--slate);padding:13px 0;font-size:14px}
.blog-recent-all{margin-top:14px;font-weight:700;font-size:14px;color:var(--teal);text-decoration:none}
.blog-recent-all:hover{text-decoration:underline}

.blog-main{padding:42px 0 64px}
.blog-cols{display:grid;grid-template-columns:1fr 320px;gap:38px;align-items:start}
.blog-arch-head{margin-bottom:26px}
.blog-arch-head h1{font-family:var(--font-display);font-size:clamp(26px,3.4vw,38px);letter-spacing:-.02em;color:var(--ink);margin:.3em 0 0}
.blog-feed{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.blog-empty{color:var(--slate);font-size:16px;padding:30px 0}

.bcard{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.bcard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.bcard-img{display:block;aspect-ratio:16/10;overflow:hidden;background:var(--mist-2)}
.bcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.bcard:hover .bcard-img img{transform:scale(1.06)}
.bcard-img.ph{background:var(--grad)}
.bcard-body{display:flex;flex-direction:column;gap:9px;padding:18px 19px 17px;flex:1}
.bcard-cat{align-self:flex-start;font-size:11px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--teal);text-decoration:none;background:var(--mist);padding:5px 10px;border-radius:999px}
.bcard-cat:hover{background:var(--mist-2)}
.bcard-title{font-family:var(--font-display);font-size:19px;line-height:1.25;letter-spacing:-.01em;margin:2px 0 0}
.bcard-title a{color:var(--ink);text-decoration:none}
.bcard-title a:hover{color:var(--teal)}
.bcard-meta{font-size:12.5px;color:var(--slate);font-weight:600;margin:0}
.bcard-ex{font-size:14.5px;line-height:1.55;color:var(--slate);margin:0;flex:1}
.bcard-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:6px;padding-top:13px;border-top:1px solid var(--line)}
.bcard-more{font-weight:700;font-size:14px;color:var(--teal);text-decoration:none;white-space:nowrap}
.bcard-more span{display:inline-block;transition:transform .25s var(--ease)}
.bcard-more:hover span{transform:translateX(4px)}

/* share */
.evg-share{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.evg-share-l{font-size:12px;font-weight:700;color:var(--slate);letter-spacing:.03em}
.evg-share.compact .evg-share-l{display:none}
.esh{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:9px;border:1px solid var(--line);color:var(--slate);background:var(--paper);transition:transform .2s var(--ease),background .2s,color .2s,border-color .2s}
.esh svg{width:16px;height:16px}
.esh:hover{transform:translateY(-2px);color:#fff}
.esh-wa:hover{background:#25D366;border-color:#25D366}
.esh-fb:hover{background:#1877F2;border-color:#1877F2}
.esh-tw:hover{background:#000;border-color:#000}
.esh-li:hover{background:#0A66C2;border-color:#0A66C2}
.evg-share-total{font-size:12.5px;color:var(--slate);margin-left:2px;white-space:nowrap}
.evg-share-total .esh-n{color:var(--ink);font-weight:800}
.evg-share.compact{gap:6px}
.evg-share.compact .esh{width:30px;height:30px}
.evg-share.compact .esh svg{width:14px;height:14px}
.evg-share.compact .evg-share-total{font-size:11.5px}

/* sidebar widgets */
.blog-aside{display:flex;flex-direction:column;gap:20px;position:sticky;top:96px}
.bwidget{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:22px 22px;box-shadow:var(--shadow-sm)}
.bwidget-t{font-family:var(--font-display);font-size:15px;letter-spacing:.01em;color:var(--ink);margin:0 0 12px;padding-bottom:11px;border-bottom:1px solid var(--line)}
.bwidget p{color:var(--slate);font-size:14.5px;line-height:1.6;margin:0 0 14px}
.bwidget ul{list-style:none;margin:0;padding:0}
.bwidget li{padding:8px 0;border-bottom:1px solid var(--line)}
.bwidget li:last-child{border-bottom:0}
.bwidget a{color:var(--teal);text-decoration:none}
.bwidget a:hover{text-decoration:underline}
.bwidget .btn{width:100%;justify-content:center}
.bwidget select,.bwidget input[type=search],.bwidget input[type=text]{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:10px;font:inherit}

/* load more */
.blog-more{display:flex;flex-direction:column;align-items:center;gap:14px;padding:34px 0 6px}
.blog-more-btn[disabled]{opacity:.6;pointer-events:none}
.blog-spin{display:flex;gap:6px}
.blog-spin span{width:9px;height:9px;border-radius:50%;background:var(--teal);animation:evgbounce 1s infinite ease-in-out}
.blog-spin span:nth-child(2){animation-delay:.15s}
.blog-spin span:nth-child(3){animation-delay:.3s}
@keyframes evgbounce{0%,80%,100%{transform:scale(.5);opacity:.4}40%{transform:scale(1);opacity:1}}

/* pagination (archive/index) */
.blog-archive .pagination,.blog-main .pagination{margin-top:34px}
.blog-main .nav-links{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.blog-main .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 12px;border:1px solid var(--line);border-radius:10px;color:var(--ink);text-decoration:none;font-weight:700;background:var(--paper)}
.blog-main .page-numbers.current{background:var(--grad);color:#fff;border-color:transparent}
.blog-main .page-numbers:hover:not(.current){border-color:var(--teal);color:var(--teal)}

/* single post */
.bpost-hero{position:relative;padding:50px 0 28px;background:var(--mist);border-bottom:1px solid var(--line);overflow:hidden}
.bpost-hero.has-img{padding:0;min-height:clamp(320px,42vw,480px);display:flex;align-items:flex-end;background:var(--teal-2)}
.bpost-cover{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.bpost-hero.has-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(9,30,26,.15) 35%,rgba(9,30,26,.86) 100%);z-index:1}
.bpost-hwrap{position:relative;z-index:2;padding-bottom:34px}
.bpost-hero.has-img .bpost-hwrap{color:#fff}
.bpost-hero.has-img h1,.bpost-hero.has-img .bpost-meta{color:#fff}
.bpost-back{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:14px;color:var(--teal);text-decoration:none;margin-bottom:14px}
.bpost-hero.has-img .bpost-back{color:#fff;opacity:.9}
.bpost-back:hover{opacity:1;text-decoration:underline}
.bpost-cat{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--teal);background:rgba(255,255,255,.9);padding:6px 12px;border-radius:999px;text-decoration:none;margin-bottom:14px}
.bpost-hwrap h1{font-family:var(--font-display);font-size:clamp(28px,4.6vw,48px);line-height:1.08;letter-spacing:-.02em;max-width:18ch;margin:.1em 0 .35em;color:var(--ink)}
.bpost-meta{font-size:14px;color:var(--slate);font-weight:600;margin:0}
.bpost-cols{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:46px;align-items:start;padding:40px 0 64px}
.bpost-content{min-width:0}
.bpost-content>.evg-share{padding-bottom:20px;margin-bottom:24px;border-bottom:1px solid var(--line)}
.bpost-body{font-size:17.5px;line-height:1.75;color:#22322c}
.bpost-body p{margin:0 0 1.25em}
.bpost-body h2{font-family:var(--font-display);font-size:1.7em;letter-spacing:-.01em;margin:1.5em 0 .5em;color:var(--ink)}
.bpost-body h3{font-family:var(--font-display);font-size:1.32em;margin:1.4em 0 .45em;color:var(--ink)}
.bpost-body a{color:var(--teal);text-decoration:underline;text-underline-offset:2px}
.bpost-body img{max-width:100%;height:auto;border-radius:14px;margin:1em 0}
.bpost-body blockquote{margin:1.4em 0;padding:6px 0 6px 22px;border-left:4px solid var(--green);color:var(--slate);font-style:italic;font-size:1.1em}
.bpost-body ul,.bpost-body ol{margin:0 0 1.25em;padding-left:1.3em}
.bpost-body li{margin:.4em 0}
.bpost-body figure{margin:1.2em 0}
.bpost-tags{margin-top:30px;font-size:14px;color:var(--slate)}
.bpost-tags a{color:var(--teal);text-decoration:none}.bpost-tags a:hover{text-decoration:underline}
.bpt-l{font-weight:700;color:var(--ink)}
.bpost-share-foot{margin-top:30px;padding-top:22px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;align-items:center;gap:14px}
.bps-l{font-weight:700;color:var(--ink);font-size:15px}
.bpost-aside{position:sticky;top:96px}

@media(max-width:1000px){
	.blog-cols,.bpost-cols{grid-template-columns:1fr}
	.blog-aside,.bpost-aside{position:static;flex-direction:row;flex-wrap:wrap}
	.blog-aside .bwidget{flex:1 1 280px}
}
@media(max-width:760px){
	.blog-lede-grid{grid-template-columns:1fr}
	.blog-feed{grid-template-columns:1fr}
	.blead{min-height:300px}
	.blog-aside{flex-direction:column}
}
