/*
Theme Name: Best EPC Pro
Theme URI: https://bestepc.co.uk/
Author: Best EPC
Description: Dynamic theme for Best EPC — accredited EPC, legionella and property photography service across the UK. Custom post types for Services & Locations, order tracking, a DEA assessor login area, editable business details, and the EPC rating-scale design.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: best-epc
*/

/* =========================================================
   Best EPC — shared stylesheet (bestepc.co.uk)
   Palette derived from the official EPC A–G band colours.
   ========================================================= */
:root{
  --green-900:#06301f; --green-700:#0b7a4b; --green-500:#19b459; --green-100:#e3f5ea;
  --amber:#f5b700; --ink:#14241c; --muted:#5a6b62; --bg:#f7f9f6; --surface:#ffffff; --line:#dde7e0;
  --band-a:#008054; --band-b:#19b459; --band-c:#8dce46; --band-d:#ffd500; --band-e:#fcaa65; --band-f:#ef8023; --band-g:#e9153b;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Figtree",system-ui,sans-serif;color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,.display{font-family:"Space Grotesk",sans-serif;letter-spacing:-.02em;line-height:1.1}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
.eyebrow{font-family:"Space Grotesk";font-size:.8rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--green-700)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-family:"Space Grotesk";padding:.85rem 1.5rem;border-radius:999px;transition:transform .15s ease,box-shadow .15s ease;border:2px solid transparent;cursor:pointer}
.btn:focus-visible{outline:3px solid var(--green-900);outline-offset:2px}
.btn-primary{background:var(--green-700);color:#fff;box-shadow:0 6px 18px rgba(11,122,75,.28)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(11,122,75,.34)}
.btn-ghost{border-color:var(--line);color:var(--ink);background:#fff}
.btn-ghost:hover{border-color:var(--green-500);transform:translateY(-2px)}
.btn-white{background:#fff;border-color:#fff;color:var(--green-900)}

/* utility bar */
.util{background:var(--green-900);color:#dff3e8;font-size:.86rem}
.util .wrap{display:flex;justify-content:space-between;align-items:center;padding:.5rem 24px;gap:1rem}
.util a{font-weight:600;color:#fff}
.util .dot{color:var(--green-500)}
@media(max-width:680px){.util .hide-sm{display:none}}

/* header + nav */
header.site{position:sticky;top:0;z-index:50;background:rgba(247,249,246,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;padding:1rem 24px}
.logo{display:flex;align-items:center;gap:.6rem;font-family:"Space Grotesk";font-weight:700;font-size:1.25rem;color:var(--green-900)}
.logo .mark{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--green-500),var(--green-700));display:grid;place-items:center;color:#fff;font-weight:700;font-size:1rem;flex:none}
/* logo image (header) */
.brand-link{display:inline-flex;align-items:center;line-height:0}
.brand-link img,.brand-link .custom-logo{height:50px;width:auto;display:block}
@media(max-width:520px){.brand-link img,.brand-link .custom-logo{height:42px}}
/* logo image (footer, reversed) */
footer.site .brand img{height:46px;width:auto;display:block}
nav.main{display:flex;gap:1.3rem;align-items:center}
nav.main a.navlink{font-weight:500;font-size:.92rem;color:var(--ink)}
nav.main a.navlink:hover,nav.main a.navlink.active{color:var(--green-700)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;transition:.2s}
@media(max-width:920px){
  .nav-toggle{display:block}
  nav.main{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:flex-start;gap:.2rem;background:var(--bg);border-bottom:1px solid var(--line);padding:1rem 24px;display:none}
  nav.main.open{display:flex}
  nav.main a.navlink{padding:.5rem 0;width:100%}
  nav.main .btn{margin-top:.5rem}
}

/* hero (home) */
.hero{padding:72px 0 64px}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(2.2rem,4.6vw,3.5rem);font-weight:700;margin:.7rem 0 1.1rem}
.hero p.lead{font-size:1.12rem;color:var(--muted);max-width:34ch;margin-bottom:1.8rem}
.cta-row{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:1.8rem}
.chips{display:flex;flex-wrap:wrap;gap:.5rem}
.chip{font-size:.82rem;font-weight:600;color:var(--green-900);background:var(--green-100);padding:.4rem .8rem;border-radius:999px;display:inline-flex;align-items:center;gap:.4rem}
.chip svg{width:14px;height:14px}
@media(max-width:860px){.hero .wrap{grid-template-columns:1fr;gap:40px}.hero p.lead{max-width:none}}

/* page hero (inner pages) */
.page-hero{background:linear-gradient(135deg,var(--green-100),var(--bg));border-bottom:1px solid var(--line);padding:64px 0 56px}
.page-hero h1{font-size:clamp(2rem,4vw,3rem);font-weight:700;margin:.6rem 0 1rem;max-width:20ch}
.page-hero p{font-size:1.12rem;color:var(--muted);max-width:60ch;margin-bottom:1.6rem}

/* rating card */
.rating-card{background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:26px;box-shadow:0 24px 60px -28px rgba(6,48,31,.45)}
.rating-card .rc-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.rating-card .rc-head strong{font-family:"Space Grotesk";font-size:1.05rem}
.rating-card .rc-head span{font-size:.78rem;color:var(--muted)}
.scale{display:flex;flex-direction:column;gap:7px;margin-top:14px}
.band{display:flex;align-items:center;height:34px;border-radius:7px;color:#0a2417;font-weight:700;font-family:"Space Grotesk";padding:0 12px;position:relative;transform-origin:left center;animation:grow .7s cubic-bezier(.2,.8,.2,1) backwards}
.band .letter{width:22px}
.band .range{font-size:.78rem;font-weight:600;opacity:.8;font-family:"Figtree"}
.band.a{background:var(--band-a);color:#fff;width:46%;animation-delay:.05s}
.band.b{background:var(--band-b);width:56%;animation-delay:.12s}
.band.c{background:var(--band-c);width:66%;animation-delay:.19s}
.band.d{background:var(--band-d);width:76%;animation-delay:.26s}
.band.e{background:var(--band-e);width:86%;animation-delay:.33s}
.band.f{background:var(--band-f);width:93%;animation-delay:.40s}
.band.g{background:var(--band-g);color:#fff;width:100%;animation-delay:.47s}
.band.active{box-shadow:0 0 0 3px #fff,0 0 0 6px currentColor}
.band .you{position:absolute;right:10px;background:#06301f;color:#fff;font-family:"Figtree";font-size:.68rem;font-weight:700;padding:.15rem .5rem;border-radius:999px}
@keyframes grow{from{transform:scaleX(.2);opacity:0}to{transform:scaleX(1);opacity:1}}
@media(prefers-reduced-motion:reduce){.band{animation:none}}

/* trust strip */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:30px 24px;text-align:center}
.trust .stat{font-family:"Space Grotesk";font-size:1.5rem;font-weight:700;color:var(--green-700)}
.trust .lbl{font-size:.85rem;color:var(--muted)}
@media(max-width:680px){.trust .wrap{grid-template-columns:repeat(2,1fr);gap:22px}}

/* sections */
section{padding:76px 0}
.sec-head{max-width:62ch;margin-bottom:42px}
.sec-head h2{font-size:clamp(1.7rem,3vw,2.3rem);font-weight:700;margin:.6rem 0 .7rem}
.sec-head p{color:var(--muted);font-size:1.05rem}
.prose p{margin-bottom:1.1rem;font-size:1.04rem}
.prose h2{font-size:clamp(1.5rem,2.6vw,2rem);margin:2rem 0 .8rem}
.prose h3{font-size:1.25rem;margin:1.4rem 0 .5rem}
.prose ul{margin:0 0 1.1rem 1.2rem}
.prose li{margin-bottom:.4rem}
.prose a{color:var(--green-700);font-weight:600;text-decoration:underline}
.layout{display:grid;grid-template-columns:1.6fr .9fr;gap:48px;align-items:start}
@media(max-width:860px){.layout{grid-template-columns:1fr;gap:32px}}
.aside{background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px;position:sticky;top:90px}
.aside h3{font-size:1.1rem;margin-bottom:.4rem}
.aside .price{font-family:"Space Grotesk";font-size:2rem;font-weight:700;color:var(--green-700);margin:.2rem 0 .6rem}
.aside p{color:var(--muted);font-size:.92rem;margin-bottom:1rem}
.aside .btn{width:100%;justify-content:center;margin-bottom:.5rem}

/* why grid */
.why{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.why .item{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px}
.why .item h3{font-size:1.15rem;margin-bottom:.4rem;display:flex;align-items:center;gap:.6rem}
.why .item .ic{width:34px;height:34px;border-radius:9px;background:var(--green-100);display:grid;place-items:center;flex:none}
.why .item .ic svg{width:18px;height:18px;stroke:var(--green-700);fill:none}
.why .item p{color:var(--muted);font-size:.97rem}
@media(max-width:680px){.why{grid-template-columns:1fr}}

/* services grid */
.services{background:var(--green-900);color:#eaf6ef}
.services .sec-head h2{color:#fff}.services .sec-head p{color:#a9c7b8}.services .eyebrow{color:var(--green-500)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:16px;padding:26px;transition:background .2s;display:block}
.svc:hover{background:rgba(255,255,255,.09)}
.svc h3{font-size:1.15rem;color:#fff;margin-bottom:.4rem}
.svc p{color:#a9c7b8;font-size:.93rem;margin-bottom:.8rem}
.svc .price{font-family:"Space Grotesk";font-weight:700;color:var(--green-500)}
@media(max-width:780px){.svc-grid{grid-template-columns:1fr}}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.step .num{font-family:"Space Grotesk";font-size:2.6rem;font-weight:700;color:var(--green-500);line-height:1}
.step h3{font-size:1.2rem;margin:.5rem 0 .4rem}
.step p{color:var(--muted);font-size:.97rem}
@media(max-width:780px){.steps{grid-template-columns:1fr;gap:22px}}

/* areas */
.pill-row{display:flex;flex-wrap:wrap;gap:.6rem}
.area-pill{background:#fff;border:1px solid var(--line);border-radius:999px;padding:.55rem 1.1rem;font-weight:500;font-size:.95rem}
.area-pill:hover{border-color:var(--green-500);color:var(--green-700)}

/* price cta */
.pricecta{background:linear-gradient(135deg,var(--green-700),var(--green-900));color:#fff;border-radius:24px;padding:48px;text-align:center}
.pricecta .big{font-family:"Space Grotesk";font-size:clamp(2.4rem,6vw,3.6rem);font-weight:700;color:var(--amber)}
.pricecta h2{font-size:1.9rem;margin:.4rem 0 .6rem;color:#fff}
.pricecta p{color:#cfe6da;max-width:46ch;margin:0 auto 1.6rem}

/* faq */
.faq details{background:#fff;border:1px solid var(--line);border-radius:14px;padding:4px 22px;margin-bottom:12px}
.faq summary{font-family:"Space Grotesk";font-weight:600;font-size:1.05rem;padding:18px 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--green-700);font-weight:400;flex:none}
.faq details[open] summary::after{content:"–"}
.faq details p{color:var(--muted);padding:0 0 18px}

/* contact form */
.cform{background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px}
.cform label{display:block;font-weight:600;font-size:.9rem;margin:.9rem 0 .35rem}
.cform input,.cform textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:.8rem;font-family:inherit;font-size:1rem;background:var(--bg)}
.cform input:focus,.cform textarea:focus{outline:2px solid var(--green-500);border-color:var(--green-500)}

/* footer */
footer.site{background:var(--green-900);color:#b9d4c5;padding:56px 0 30px;font-size:.95rem}
footer.site .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;margin-bottom:36px}
footer.site h4{font-family:"Space Grotesk";color:#fff;font-size:1rem;margin-bottom:1rem}
footer.site a{color:#b9d4c5}footer.site a:hover{color:#fff}
footer.site ul{list-style:none}footer.site li{margin-bottom:.5rem}
footer.site .brand{display:flex;align-items:center;gap:.6rem;color:#fff;font-family:"Space Grotesk";font-weight:700;font-size:1.2rem;margin-bottom:.8rem}
footer.site .legal{border-top:1px solid rgba(255,255,255,.12);padding-top:20px;font-size:.84rem;color:#86a896;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
@media(max-width:780px){footer.site .cols{grid-template-columns:1fr;gap:28px}}


/* ===== primary nav (wp_nav_menu) ===== */
nav.main .primary-menu{list-style:none;display:flex;gap:1.25rem;align-items:center;margin:0;padding:0}
nav.main .primary-menu li{position:relative}
nav.main .primary-menu a{font-weight:500;font-size:.92rem;color:var(--ink)}
nav.main .primary-menu a:hover,nav.main .primary-menu .current-menu-item>a{color:var(--green-700)}
/* dropdown (sub-menus) */
nav.main .primary-menu .sub-menu{display:none;position:absolute;top:140%;left:0;background:#fff;border:1px solid var(--line);border-radius:12px;padding:8px;min-width:200px;box-shadow:0 18px 40px -20px rgba(6,48,31,.5);z-index:60}
nav.main .primary-menu li:hover>.sub-menu{display:block}
nav.main .primary-menu .sub-menu li a{display:block;padding:.5rem .7rem;border-radius:8px}
nav.main .primary-menu .sub-menu li a:hover{background:var(--green-100)}
@media(max-width:920px){
  nav.main .primary-menu{flex-direction:column;align-items:flex-start;gap:.2rem;width:100%}
  nav.main .primary-menu a{padding:.5rem 0;display:block;width:100%}
  nav.main .primary-menu .sub-menu{position:static;display:block;border:0;box-shadow:none;padding:0 0 0 12px;background:transparent}
}

/* ===== login form (assessor area) ===== */
.cform input[type=text],.cform input[type=email],.cform input[type=password],.cform input[type=tel],.cform textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:.8rem;font-family:inherit;font-size:1rem;background:var(--bg);margin-bottom:.4rem}
.login-username,.login-password,.login-remember{margin-bottom:.6rem}
.login-remember label{font-weight:500;font-size:.9rem;color:var(--muted)}
.login-submit .button,.cform .button{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-family:'Space Grotesk';padding:.85rem 1.5rem;border-radius:999px;background:var(--green-700);color:#fff;border:0;cursor:pointer}

/* ===== track order steps ===== */
.track-steps{display:flex;flex-direction:column;gap:0;margin-top:8px}
.track-step{display:flex;align-items:center;gap:14px;padding:12px 0;position:relative}
.track-step .dotmark{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:#eef2ef;color:var(--muted);font-weight:700;font-family:'Space Grotesk';font-size:.9rem;flex:none}
.track-step.done .dotmark{background:var(--green-700);color:#fff}
.track-step .lbl{font-weight:600;color:var(--muted)}
.track-step.done .lbl{color:var(--ink)}
.track-step:not(:last-child)::after{content:"";position:absolute;left:14px;top:42px;bottom:-6px;width:2px;background:var(--line)}
.track-step.done:not(:last-child)::after{background:var(--green-500)}

/* ===== assessor job table ===== */
.job-table{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff}
.job-row{display:grid;grid-template-columns:1fr 2fr 1fr;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line);align-items:center}
.job-row:last-child{border-bottom:0}
.job-head{background:var(--bg);font-weight:600;font-family:'Space Grotesk';font-size:.85rem;color:var(--muted)}
@media(max-width:640px){.job-row{grid-template-columns:1fr 1fr}.job-row span:nth-child(2){display:none}}

/* ===== quote wizard ===== */
.quote-hero{background:linear-gradient(135deg,var(--green-100),var(--bg));border-bottom:1px solid var(--line);padding:56px 0 40px;text-align:center}
.quote-hero h1{font-size:clamp(1.9rem,4vw,3rem);font-weight:700;max-width:18ch;margin:.5rem auto .8rem}
.quote-hero p{color:var(--muted);max-width:50ch;margin:0 auto}
.quote-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:34px;box-shadow:0 30px 70px -36px rgba(6,48,31,.4)}
.qstep{display:none}
.qstep.shown{display:block;animation:qfade .35s ease}
@keyframes qfade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.qline{height:1px;background:var(--line);margin:26px 0}
.qhead{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.qhead h2{font-size:clamp(1.4rem,2.6vw,2rem);font-weight:700}
.qbadge{background:var(--green-100);color:var(--green-900);font-family:'Space Grotesk';font-weight:600;font-size:.85rem;padding:.35rem .9rem;border-radius:999px;white-space:nowrap}
.qsub{color:var(--muted);margin:.4rem 0 1.4rem}
.qopts{display:grid;gap:14px}
.qopts-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:640px){.qopts-3{grid-template-columns:1fr 1fr}}
.qopt{background:var(--bg);border:2px solid var(--line);border-radius:14px;padding:18px 12px;font-family:'Space Grotesk';font-weight:600;font-size:1rem;color:var(--ink);cursor:pointer;transition:.15s;text-transform:uppercase;letter-spacing:.02em}
.qopt:hover{border-color:var(--green-500);transform:translateY(-2px)}
.qopt.selected{border-color:var(--amber);box-shadow:0 0 0 3px rgba(245,183,0,.18);background:#fff;position:relative}
.qopt.selected::after{content:"✓";position:absolute;top:-10px;right:-10px;width:24px;height:24px;background:var(--amber);color:#06301f;border-radius:50%;display:grid;place-items:center;font-size:.8rem;font-weight:700}
.qgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:6px}
@media(max-width:640px){.qgrid{grid-template-columns:1fr}}
.quote-card label{display:block;font-weight:600;font-size:.85rem;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);margin:1rem 0 .4rem}
.quote-card input,.quote-card select{width:100%;border:1px solid var(--line);border-radius:12px;padding:.9rem;font-family:inherit;font-size:1rem;background:var(--bg)}
.quote-card input:focus,.quote-card select:focus{outline:2px solid var(--green-500);border-color:var(--green-500)}
.req{color:#e9153b}
.pc-row{display:flex;gap:10px}
.pc-row input{flex:1}
.pc-row .btn{white-space:nowrap}
@media(max-width:520px){.pc-row{flex-direction:column}}
.pc-status{margin-top:12px;font-weight:500}
.pc-status.ok{background:var(--green-100);color:var(--green-900);padding:14px;border-radius:12px;text-align:center}
.pc-status.err{color:#9b1c1c}
.qsubmit{width:100%;justify-content:center;margin-top:1.4rem;font-size:1.05rem;padding:1rem}
.quote-done{text-align:center;padding:20px}
.quote-done .tick{width:64px;height:64px;border-radius:50%;background:var(--green-700);color:#fff;display:grid;place-items:center;font-size:2rem;margin:0 auto 16px}
.quote-done h2{font-size:1.7rem;margin-bottom:.5rem}
.quote-done p{color:var(--muted);max-width:46ch;margin:0 auto .6rem}
.quote-done .ref a{color:var(--green-700);font-weight:600}
/* trustpilot band */
.trustpilot-band{padding:40px 0;background:#fff;border-top:1px solid var(--line);text-align:center}
