/*
Theme Name: Proper Heat
Theme URI: https://www.properheat.co.uk/
Author: Welch Marketing
Author URI: https://www.welchmarketing.co.uk/
Description: Premium, zero plugin WordPress theme for Proper Heat Ltd, Gas Safe registered boiler specialists in Guildford and Surrey. Auto builds every page, local SEO location pages, schema markup and a working contact form on activation.
Version: 1.0.2
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: proper-heat
*/

/* =========================================================
   FONTS (self hosted, no Google CDN)
   ========================================================= */
@font-face{font-family:"DM Sans";src:url(assets/fonts/dm-sans-500.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"DM Sans";src:url(assets/fonts/dm-sans-600.woff2) format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"DM Sans";src:url(assets/fonts/dm-sans-700.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"DM Sans";src:url(assets/fonts/dm-sans-800.woff2) format("woff2");font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url(assets/fonts/inter-400.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url(assets/fonts/inter-500.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url(assets/fonts/inter-600.woff2) format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Inter";src:url(assets/fonts/inter-700.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}

/* =========================================================
   TOKENS
   ========================================================= */
:root{
  --green:#76bb40;
  --green-d:#5f9a31;
  --green-dd:#4d7d28;
  --orange:#eb5434;
  --orange-d:#d33f20;
  --ink:#16241c;          /* deep warm near-black green */
  --ink-2:#2b3a30;
  --body:#3f4a43;
  --muted:#6b7670;
  --line:#e4e9e5;
  --bg:#ffffff;
  --bg-soft:#f5f8f3;
  --bg-tint:#eef4e8;
  --white:#ffffff;
  --radius:16px;
  --radius-lg:24px;
  --radius-sm:10px;
  --shadow-sm:0 2px 10px rgba(22,36,28,.06);
  --shadow:0 14px 40px rgba(22,36,28,.10);
  --shadow-lg:0 30px 70px rgba(22,36,28,.16);
  --maxw:1200px;
  --head:"DM Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --text:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}

/* =========================================================
   RESET
   ========================================================= */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:var(--text);color:var(--body);background:var(--bg);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4,h5{font-family:var(--head);color:var(--ink);line-height:1.12;margin:0 0 .5em;font-weight:800;letter-spacing:-.02em}
h1{font-size:clamp(2.1rem,5vw,3.6rem)}
h2{font-size:clamp(1.7rem,3.4vw,2.6rem)}
h3{font-size:clamp(1.25rem,2vw,1.55rem);font-weight:700}
h4{font-size:1.15rem;font-weight:700}
p{margin:0 0 1.1rem}
a{color:var(--green-dd);text-decoration:none;transition:color .2s}
a:hover{color:var(--orange)}
img{max-width:100%;height:auto;display:block}
ul{margin:0 0 1.1rem;padding-left:1.2rem}
li{margin-bottom:.4rem}
strong{font-weight:700;color:var(--ink-2)}

/* =========================================================
   LAYOUT
   ========================================================= */
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:84px 0}
.section--soft{background:var(--bg-soft)}
.section--tint{background:var(--bg-tint)}
.section--ink{background:var(--ink);color:#d8e2db}
.section--ink h1,.section--ink h2,.section--ink h3{color:#fff}
.section--sm{padding:56px 0}
.eyebrow{display:inline-block;font-family:var(--head);font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--green-dd);margin-bottom:14px}
.section--ink .eyebrow{color:var(--green)}
.lead{font-size:1.15rem;color:var(--muted);max-width:60ch}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}
.sec-head{max-width:720px;margin:0 auto 52px}
.sec-head.center{text-align:center}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--head);font-weight:700;font-size:1rem;padding:15px 30px;border-radius:999px;border:0;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,background .18s;line-height:1;text-align:center}
.btn svg{width:18px;height:18px;flex:none;color:currentColor}
.btn,.btn:hover,.btn:focus,.btn:visited{text-decoration:none}
.btn--primary,.btn--primary:link,.btn--primary:visited{background:var(--orange);color:#fff;box-shadow:0 10px 24px rgba(235,84,52,.32)}
.btn--primary:hover,.btn--primary:focus{background:var(--orange-d);color:#fff;transform:translateY(-2px);box-shadow:0 16px 32px rgba(235,84,52,.4)}
.btn--green{background:var(--green);color:#fff;box-shadow:0 10px 24px rgba(118,187,64,.3)}
.btn--green:hover{background:var(--green-d);color:#fff;transform:translateY(-2px)}
.btn--ghost,.btn--ghost:link,.btn--ghost:visited{background:transparent;color:var(--ink);border:2px solid var(--line)}
.btn--ghost:hover,.btn--ghost:focus{border-color:var(--green);color:var(--green-dd);transform:translateY(-2px)}
.btn--white,.btn--white:link,.btn--white:visited{background:#fff;color:var(--ink)}
.btn--white:hover,.btn--white:focus{background:#f1f1f1;color:var(--ink);transform:translateY(-2px)}
.btn--lg{padding:18px 38px;font-size:1.08rem}
.btn--block{width:100%;justify-content:center}
.btn-row{display:flex;flex-wrap:wrap;gap:14px}
.btn-row.center{justify-content:center}

/* =========================================================
   HEADER
   ========================================================= */
.topbar{background:var(--ink);color:#c9d6cd;font-size:.86rem}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-top:9px;padding-bottom:9px}
.topbar a{color:#c9d6cd;font-weight:500;display:inline-flex;align-items:center;gap:7px}
.topbar a:hover{color:#fff}
.topbar svg{width:15px;height:15px;color:var(--green)}
.topbar__left{display:flex;gap:22px;flex-wrap:wrap}
.topbar__right{display:flex;align-items:center;gap:8px;color:#9fb0a5}
.topbar__right .badge{display:inline-flex;align-items:center;gap:6px;background:rgba(118,187,64,.16);color:#bfe39a;padding:4px 11px;border-radius:999px;font-weight:600;font-size:.78rem}

.site-header{position:sticky;top:0;z-index:90;background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);transition:box-shadow .25s}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-top:14px;padding-bottom:14px}
.brand{display:flex;align-items:center;gap:12px;flex:0 0 auto;margin-right:auto}
.brand img{height:54px;width:auto}
.brand__txt{display:flex;flex-direction:column;line-height:1}
.brand__name{font-family:var(--head);font-weight:800;font-size:1.18rem;color:var(--ink);letter-spacing:-.02em}
.brand__tag{font-size:.72rem;color:var(--muted);font-weight:500;letter-spacing:.02em}

.main-nav{display:flex;align-items:center;gap:4px}
.main-nav ul{list-style:none;display:flex;align-items:center;gap:2px;margin:0;padding:0}
.main-nav li{margin:0;position:relative}
.main-nav a{font-family:var(--head);font-weight:600;font-size:.97rem;color:var(--ink-2);padding:10px 15px;border-radius:9px;display:block}
.main-nav a:hover,.main-nav .current-menu-item>a,.main-nav .current_page_item>a{color:var(--green-dd);background:var(--bg-tint)}
.main-nav .menu-item-has-children>a::after{content:"";display:inline-block;width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);margin-left:7px;vertical-align:1px}
.main-nav .sub-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:248px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s;list-style:none;display:block}
.main-nav li:hover>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
.main-nav .sub-menu a{padding:9px 13px;font-size:.92rem;border-radius:8px}
.main-nav .sub-menu .menu-item-has-children>a::after{transform:rotate(-45deg)}
.header-cta{display:flex;align-items:center;gap:12px;flex:0 0 auto}
.header-cta .callbtn{display:inline-flex;align-items:center;gap:9px;font-family:var(--head);font-weight:700;color:var(--ink);font-size:1.02rem}
.header-cta .callbtn span{display:flex;flex-direction:column;line-height:1.1}
.header-cta .callbtn small{font-size:.68rem;color:var(--muted);font-weight:600;letter-spacing:.05em;text-transform:uppercase}
.header-cta .callbtn .ic{width:40px;height:40px;border-radius:50%;background:var(--bg-tint);display:flex;align-items:center;justify-content:center;color:var(--green-dd)}
.header-cta .callbtn .ic svg{width:18px;height:18px}

.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:10px;border-radius:10px}
.burger span{width:26px;height:3px;background:var(--ink);border-radius:3px;transition:.3s}
.burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* mobile drawer */
.mobile-nav{position:fixed;inset:0 0 0 auto;width:min(86vw,360px);background:#fff;z-index:120;transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-lg);overflow-y:auto;padding:24px;display:flex;flex-direction:column}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}
.mobile-nav__top img{height:46px}
.mobile-close{background:none;border:0;font-size:2rem;line-height:1;color:var(--ink);cursor:pointer}
.mobile-nav ul{list-style:none;padding:0;margin:0}
.mobile-nav li{margin:0;border-bottom:1px solid var(--line)}
.mobile-nav a{display:block;padding:14px 4px;font-family:var(--head);font-weight:600;color:var(--ink-2)}
.mobile-nav .sub-menu{padding-left:14px}
.mobile-nav .sub-menu a{font-weight:500;font-size:.94rem;color:var(--body);padding:11px 4px}
.mobile-nav .m-cta{margin-top:22px;display:flex;flex-direction:column;gap:12px}
.overlay{position:fixed;inset:0;background:rgba(22,36,28,.5);z-index:110;opacity:0;visibility:hidden;transition:.3s}
.overlay.open{opacity:1;visibility:visible}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;background:var(--ink);color:#e8efe9;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
   radial-gradient(900px 480px at 88% -8%,rgba(118,187,64,.22),transparent 60%),
   radial-gradient(700px 420px at -5% 110%,rgba(235,84,52,.18),transparent 55%)}
.hero__grid{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;padding:84px 0 90px}
.hero__badges{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.pill{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);color:#dfe9e1;padding:7px 14px;border-radius:999px;font-size:.82rem;font-weight:600;font-family:var(--head)}
.pill svg{width:14px;height:14px;color:var(--green)}
.hero h1{color:#fff;margin-bottom:20px}
.hero h1 .hl{color:var(--green)}
.hero .eyebrow{color:#9fe06a}
.hero .eyebrow svg{color:var(--green)}
.hero .lead{color:#c4d2c8;font-size:1.18rem;max-width:52ch}
.hero__copy{position:relative}
.hero__lead{font-size:1.18rem;color:#c4d2c8;max-width:52ch;margin-bottom:30px}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px}
.hero .btn--ghost,.hero .btn--ghost:link,.hero .btn--ghost:visited,.page-hero .btn--ghost,.page-hero .btn--ghost:link,.page-hero .btn--ghost:visited{color:#fff;border-color:rgba(255,255,255,.5)}
.hero .btn--ghost:hover,.hero .btn--ghost:focus,.page-hero .btn--ghost:hover,.page-hero .btn--ghost:focus{color:#fff;border-color:#fff;background:rgba(255,255,255,.08)}
.hero__trust{display:flex;gap:26px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.12);padding-top:24px}
.hero__trust .t{display:flex;flex-direction:column}
.hero__trust .t b{font-family:var(--head);font-size:1.7rem;color:#fff;font-weight:800;line-height:1}
.hero__trust .t span{font-size:.82rem;color:#9fb0a5;margin-top:4px}
.hero__media{position:relative}
.hero__media img{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;object-fit:cover;aspect-ratio:4/3.4}
.hero__card{position:absolute;left:-22px;bottom:26px;background:#fff;color:var(--ink);border-radius:16px;padding:16px 20px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:13px;max-width:260px}
.hero__card .star{color:#f5a623;font-size:1rem;letter-spacing:1px}
.hero__card b{font-family:var(--head);display:block;font-size:1.05rem}
.hero__card small{color:var(--muted);font-size:.8rem}
.hero__floatbadge{position:absolute;right:-14px;top:24px;background:var(--green);color:#fff;border-radius:14px;padding:12px 16px;box-shadow:var(--shadow);font-family:var(--head);font-weight:700;text-align:center;line-height:1.15}
.hero__floatbadge b{font-size:1.5rem;display:block}
.hero__floatbadge small{font-size:.72rem;opacity:.92}

/* trust strip */
.trustbar{background:#fff;border-bottom:1px solid var(--line)}
.trustbar .wrap{display:flex;align-items:center;justify-content:center;gap:38px;flex-wrap:wrap;padding:20px 24px}
.trustbar .ti{display:flex;align-items:center;gap:10px;font-family:var(--head);font-weight:600;color:var(--ink-2);font-size:.95rem}
.trustbar .ti svg{width:22px;height:22px;color:var(--green-dd)}

/* =========================================================
   CARDS / SERVICES
   ========================================================= */
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

.svc-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;transition:transform .22s,box-shadow .22s,border-color .22s;display:flex;flex-direction:column;height:100%;position:relative;overflow:hidden}
.svc-card::after{content:"";position:absolute;left:0;top:0;height:4px;width:100%;background:linear-gradient(90deg,var(--green),var(--orange));transform:scaleX(0);transform-origin:left;transition:transform .3s}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.svc-card:hover::after{transform:scaleX(1)}
.svc-card .ico{width:56px;height:56px;border-radius:14px;background:var(--bg-tint);display:flex;align-items:center;justify-content:center;color:var(--green-dd);margin-bottom:18px}
.svc-card .ico svg{width:28px;height:28px}
.svc-card h3{margin-bottom:9px}
.svc-card p{color:var(--muted);font-size:.96rem;margin-bottom:16px;flex:1}
.svc-card .more{font-family:var(--head);font-weight:700;font-size:.92rem;color:var(--green-dd);display:inline-flex;align-items:center;gap:6px}
.svc-card .more svg{width:15px;height:15px;transition:transform .2s}
.svc-card:hover .more svg{transform:translateX(4px)}

/* feature / why us */
.feature{display:flex;gap:16px;align-items:flex-start}
.feature .ico{width:52px;height:52px;border-radius:13px;flex:none;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--green),var(--green-dd));color:#fff}
.feature .ico svg{width:25px;height:25px}
.feature h4{margin-bottom:5px}
.feature p{color:var(--muted);font-size:.95rem;margin:0}

/* split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split__media img{border-radius:var(--radius-lg);box-shadow:var(--shadow);width:100%;object-fit:cover}
.checklist{list-style:none;padding:0;margin:0 0 26px}
.checklist li{display:flex;gap:12px;align-items:flex-start;margin-bottom:13px;font-size:1rem;color:var(--ink-2)}
.checklist li svg{width:22px;height:22px;color:var(--green);flex:none;margin-top:2px}

/* steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:step}
.step{position:relative;padding-top:8px}
.step__n{width:48px;height:48px;border-radius:50%;background:var(--ink);color:#fff;font-family:var(--head);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:16px}
.step h4{margin-bottom:7px}
.step p{color:var(--muted);font-size:.94rem;margin:0}

/* reviews */
.review-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;display:flex;flex-direction:column;height:100%;box-shadow:var(--shadow-sm)}
.review-card .stars{color:#f5a623;letter-spacing:2px;margin-bottom:14px;font-size:1.05rem}
.review-card p{font-size:.98rem;color:var(--ink-2);flex:1;font-style:italic}
.review-card .who{display:flex;align-items:center;gap:12px;margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.review-card .avt{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--green),var(--orange));color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--head);font-weight:800;font-size:1.1rem}
.review-card .who b{font-family:var(--head);display:block;font-size:.96rem;color:var(--ink)}
.review-card .who small{color:var(--muted);font-size:.8rem;display:inline-flex;align-items:center;gap:5px}
.review-card .who small svg{width:13px;height:13px}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gallery a,.gallery figure{margin:0;border-radius:14px;overflow:hidden;position:relative;aspect-ratio:1;box-shadow:var(--shadow-sm)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gallery a:hover img,.gallery figure:hover img{transform:scale(1.07)}

/* CTA band */
.cta-band{background:linear-gradient(120deg,var(--green-dd),var(--green));color:#fff;border-radius:var(--radius-lg);padding:54px;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(500px 300px at 85% 120%,rgba(235,84,52,.4),transparent 60%)}
.cta-band>*{position:relative}
.cta-band h2{color:#fff;margin-bottom:12px}
.cta-band p{color:rgba(255,255,255,.92);max-width:54ch;margin:0 auto 26px;font-size:1.1rem}

/* =========================================================
   FORMS
   ========================================================= */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:34px;box-shadow:var(--shadow)}
.field{margin-bottom:16px}
.field label{display:block;font-family:var(--head);font-weight:600;font-size:.9rem;color:var(--ink-2);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:11px;font-family:var(--text);font-size:1rem;color:var(--ink);background:#fcfdfc;transition:border-color .2s,box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 4px rgba(118,187,64,.15)}
.field textarea{min-height:130px;resize:vertical}
.field-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.hp-field{position:absolute;left:-9999px;top:-9999px;opacity:0;height:0;width:0;overflow:hidden}
.form-note{font-size:.85rem;color:var(--muted);margin-top:8px}
.form-alert{padding:14px 18px;border-radius:12px;margin-bottom:18px;font-weight:600;font-family:var(--head)}
.form-alert--ok{background:#e7f5da;color:#3c6018;border:1px solid #bfe39a}
.form-alert--err{background:#fde7e2;color:#a8341a;border:1px solid #f4b8a9}

.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start}
.info-list{list-style:none;padding:0;margin:0}
.info-list li{display:flex;gap:15px;align-items:flex-start;margin-bottom:22px}
.info-list .ic{width:48px;height:48px;border-radius:12px;background:var(--bg-tint);color:var(--green-dd);display:flex;align-items:center;justify-content:center;flex:none}
.info-list .ic svg{width:22px;height:22px}
.info-list b{font-family:var(--head);display:block;color:var(--ink);margin-bottom:2px}
.info-list a,.info-list span{color:var(--body)}

/* =========================================================
   PAGE HERO (interior)
   ========================================================= */
.page-hero{background:var(--ink);color:#dde7e0;position:relative;overflow:hidden;padding:64px 0}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 360px at 90% -20%,rgba(118,187,64,.2),transparent 60%)}
.page-hero .wrap{position:relative}
.page-hero h1{color:#fff;margin-bottom:12px}
.page-hero p{color:#c4d2c8;max-width:60ch;margin:0;font-size:1.1rem}
.breadcrumb{font-size:.86rem;color:#9fb0a5;margin-bottom:16px}
.breadcrumb a{color:#bcd0c2}
.breadcrumb span{margin:0 8px;opacity:.6}

/* content */
.content{max-width:760px}
.content.wide{max-width:920px}
.content h2{margin-top:1.8em}
.content h3{margin-top:1.5em}
.content ul li{margin-bottom:.55rem}
.content img{border-radius:14px;margin:1.5em 0}
.prose-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:48px;align-items:start}
.sidecard{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:26px;position:sticky;top:120px}
.sidecard h4{margin-bottom:14px}
.sidecard ul{list-style:none;padding:0;margin:0}
.sidecard li{margin-bottom:4px}
.sidecard a{display:block;padding:9px 12px;border-radius:9px;font-family:var(--head);font-weight:600;font-size:.92rem;color:var(--ink-2)}
.sidecard a:hover,.sidecard .active a{background:#fff;color:var(--green-dd)}

/* FAQ */
.faq{max-width:800px;margin:0 auto}
.faq-item{border:1px solid var(--line);border-radius:14px;margin-bottom:14px;overflow:hidden;background:#fff}
.faq-q{width:100%;text-align:left;background:none;border:0;padding:20px 24px;font-family:var(--head);font-weight:700;font-size:1.05rem;color:var(--ink);cursor:pointer;display:flex;justify-content:space-between;gap:16px;align-items:center}
.faq-q .pm{flex:none;width:24px;height:24px;position:relative;transition:transform .3s}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--green-dd);border-radius:2px;top:50%;left:50%;transform:translate(-50%,-50%)}
.faq-q .pm::before{width:14px;height:2.5px}
.faq-q .pm::after{width:2.5px;height:14px;transition:transform .3s}
.faq-item.open .pm::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a__inner{padding:0 24px 20px;color:var(--muted)}

/* areas */
.area-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.area-chip{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:11px;padding:13px 16px;font-family:var(--head);font-weight:600;font-size:.94rem;color:var(--ink-2);transition:.2s}
.area-chip:hover{border-color:var(--green);color:var(--green-dd);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.area-chip svg{width:16px;height:16px;color:var(--green);flex:none}

/* blog */
.post-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.post-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.post-card .thumb{aspect-ratio:16/10;overflow:hidden;background:var(--bg-tint)}
.post-card .thumb img{width:100%;height:100%;object-fit:cover}
.post-card .pc-body{padding:24px;display:flex;flex-direction:column;flex:1}
.post-card .meta{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin-bottom:8px}
.post-card h3{font-size:1.2rem;margin-bottom:10px}
.post-card p{color:var(--muted);font-size:.94rem;flex:1}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{background:var(--ink);color:#a9b8ae;padding:64px 0 0;font-size:.95rem}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand img{height:54px;margin-bottom:16px}
.footer-brand p{color:#9fb0a5;font-size:.92rem;max-width:34ch}
.foot-social{display:flex;gap:10px;margin-top:18px}
.foot-social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:#cdd9d0}
.foot-social a:hover{background:var(--green);color:#fff}
.foot-social svg{width:17px;height:17px}
.site-footer h5{font-family:var(--head);color:#fff;font-size:1rem;font-weight:700;margin:0 0 16px;letter-spacing:-.01em}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin-bottom:9px}
.site-footer a{color:#a9b8ae}
.site-footer a:hover{color:var(--green)}
.foot-contact li{display:flex;gap:10px;align-items:flex-start;margin-bottom:13px}
.foot-contact svg{width:17px;height:17px;color:var(--green);flex:none;margin-top:3px}
.footer-bottom{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding:22px 0;color:#8a9a8f;font-size:.84rem}
.footer-bottom a{color:#8a9a8f}

.floating-call{position:fixed;right:18px;bottom:18px;z-index:80;display:none;width:60px;height:60px;border-radius:50%;background:var(--orange);color:#fff;align-items:center;justify-content:center;box-shadow:0 10px 26px rgba(235,84,52,.45);animation:pulse 2.4s infinite}
.floating-call svg{width:26px;height:26px}
@keyframes pulse{0%{box-shadow:0 10px 26px rgba(235,84,52,.45),0 0 0 0 rgba(235,84,52,.5)}70%{box-shadow:0 10px 26px rgba(235,84,52,.45),0 0 0 16px rgba(235,84,52,0)}100%{box-shadow:0 10px 26px rgba(235,84,52,.45),0 0 0 0 rgba(235,84,52,0)}}

/* =========================================================
   ANIMATIONS
   ========================================================= */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}*{animation:none!important;scroll-behavior:auto!important}}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:1024px){
  .hero__grid{grid-template-columns:1fr;gap:40px}
  .hero__media{max-width:560px}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .footer-top{grid-template-columns:1fr 1fr}
  .prose-grid{grid-template-columns:1fr}
  .sidecard{position:static}
  .area-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:860px){
  .main-nav,.header-cta .callbtn{display:none}
  .burger{display:flex}
  .topbar__left{gap:16px}
  .floating-call{display:flex}
}
@media(max-width:720px){
  .section{padding:60px 0}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .split{grid-template-columns:1fr;gap:32px}
  .split--rev .split__media{order:-1}
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .steps{grid-template-columns:1fr}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr;gap:30px}
  .field-2{grid-template-columns:1fr}
  .cta-band{padding:38px 24px}
  .area-grid{grid-template-columns:repeat(2,1fr)}
  .topbar__left .tb-hours{display:none}
  .hero__card{left:10px}
  .hero__floatbadge{right:10px}
}
@media(max-width:460px){
  .wrap{padding:0 18px}
  .topbar{font-size:.78rem}
  .topbar__right{display:none}
  .brand img{height:46px}
  .area-grid{grid-template-columns:1fr}
}

/* =========================================================
   TEMPLATE ADDITIONS (pages, services, locations, footer)
   ========================================================= */

/* aliases + sec-head */
.section--alt{background:var(--bg-soft)}
.kicker{display:inline-block;font-family:var(--head);font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--green-dd);margin-bottom:14px}
.section--ink .kicker,.sec-head--light .kicker{color:var(--green)}
.sec-head{text-align:center}
.sec-head h2{margin-bottom:12px}
.sec-head p{color:var(--muted);font-size:1.08rem;max-width:60ch;margin:0 auto}
.sec-head--light h2{color:#fff}
.sec-head--light p{color:#bcd0c2}
.narrow{max-width:900px}
.mt{margin-top:34px}

/* grids */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px 34px}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

/* feature uses h3 in templates */
.feature h3{margin-bottom:5px;font-size:1.12rem}

/* hero stats + badge */
.hero__stats{display:flex;gap:30px;margin-top:34px;flex-wrap:wrap}
.hero__stats .stat b{font-family:var(--head);font-weight:800;font-size:1.7rem;color:#fff;display:block;line-height:1}
.hero__stats .stat span{font-size:.86rem;color:#aebbb2}
.hero__media{position:relative}
.hero__badge{position:absolute;left:18px;bottom:18px;background:#fff;border-radius:14px;padding:12px 16px;box-shadow:var(--shadow);display:flex;align-items:center;gap:10px;font-size:.86rem;color:var(--ink-2);max-width:220px}
.hero__badge svg{width:26px;height:26px;color:var(--green-dd);flex:none}
.hero__badge b{font-family:var(--head)}
.eyebrow svg,.kicker svg{width:15px;height:15px;vertical-align:-2px;margin-right:4px}

/* page hero extras */
.page-hero__sub{color:#c4d2c8;max-width:62ch;margin:6px 0 0;font-size:1.1rem}
.page-hero .btn-row{margin-top:22px}
.page-hero__ico{display:inline-flex;width:58px;height:58px;border-radius:14px;background:rgba(118,187,64,.16);color:var(--green);align-items:center;justify-content:center;margin-bottom:16px}
.page-hero__ico svg{width:30px;height:30px}
.crumbs{font-size:.86rem;color:#9fb0a5;margin-bottom:16px}
.crumbs a{color:#bcd0c2}
.crumbs a:hover{color:#fff}
.crumbs span[aria-hidden]{margin:0 8px;opacity:.6}

/* prose */
.prose{max-width:760px;margin:0 auto}
.prose h2{margin:1.6em 0 .5em;font-size:1.6rem}
.prose h3{margin:1.4em 0 .5em;font-size:1.25rem}
.prose p{margin-bottom:1.1em;color:var(--body);line-height:1.75}
.prose a{color:var(--green-dd);text-decoration:underline;text-underline-offset:2px}
.prose ul{margin:0 0 1.2em}

/* content grid (service/location) */
.content-grid{display:grid;grid-template-columns:1.5fr .8fr;gap:48px;align-items:start}
.content-main{max-width:none;margin:0}
.content-main h2{margin-top:0}
.content-side{position:relative}

/* tick list */
.tick-list{list-style:none;padding:0;margin:0 0 26px}
.tick-list li{display:flex;gap:11px;align-items:flex-start;margin-bottom:12px;font-size:1rem;color:var(--ink-2)}
.tick-list li svg{width:21px;height:21px;color:var(--green);flex:none;margin-top:2px}
.tick-list a{color:var(--ink-2)}
.tick-list a:hover{color:var(--green-dd)}
.tick-list.two-col{display:grid;grid-template-columns:1fr 1fr;gap:0 24px}

/* sidecard refinements */
.sidecard h3{margin-bottom:8px;font-family:var(--head)}
.sidecard p{color:var(--muted);font-size:.94rem;margin-bottom:16px}
.sidecard .btn{margin-bottom:10px}
.sidecard__trust{margin-top:14px;padding-top:16px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:9px}
.sidecard__trust span{display:flex;align-items:center;gap:9px;font-size:.9rem;color:var(--ink-2);font-family:var(--head);font-weight:600}
.sidecard__trust svg{width:18px;height:18px;color:var(--green-dd);flex:none}

/* inline cta */
.inline-cta{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;background:var(--bg-tint);border-radius:var(--radius);padding:22px 26px;margin:28px 0}
.inline-cta b{font-family:var(--head);display:block;color:var(--ink)}
.inline-cta span{color:var(--muted);font-size:.94rem}

/* areas */
.area-grid{display:flex;flex-wrap:wrap;gap:12px}
.area-chip{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:10px 18px;font-family:var(--head);font-weight:600;font-size:.92rem;color:var(--ink-2);transition:border-color .2s,color .2s,transform .2s}
.area-chip svg{width:15px;height:15px;color:var(--green-dd)}
.area-chip:hover{border-color:var(--green);color:var(--green-dd);transform:translateY(-2px)}
.area-grid--lg{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.area-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;display:flex;flex-direction:column;gap:6px;transition:transform .2s,box-shadow .2s,border-color .2s}
.area-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.area-card .ico{width:46px;height:46px;border-radius:12px;background:var(--bg-tint);color:var(--green-dd);display:flex;align-items:center;justify-content:center;margin-bottom:6px}
.area-card .ico svg{width:22px;height:22px}
.area-card b{font-family:var(--head);font-size:1.1rem;color:var(--ink)}
.area-card .more{font-family:var(--head);font-weight:700;font-size:.86rem;color:var(--green-dd);display:inline-flex;align-items:center;gap:5px;margin-top:auto}
.area-card .more svg{width:14px;height:14px}

/* accreditations */
.accred{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.accred__item{display:flex;gap:16px;align-items:flex-start;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.accred__item .ico{width:54px;height:54px;border-radius:13px;background:linear-gradient(135deg,var(--green),var(--green-dd));color:#fff;display:flex;align-items:center;justify-content:center;flex:none}
.accred__item .ico svg{width:26px;height:26px}
.accred__item h3{margin-bottom:5px;font-size:1.1rem}
.accred__item p{color:var(--muted);font-size:.94rem;margin:0}

/* contact page */
.contact-grid{grid-template-columns:1fr 1.1fr}
.contact-info h2{margin-bottom:14px}
.contact-info>p{color:var(--muted);margin-bottom:26px}
.contact-list{list-style:none;padding:0;margin:0 0 26px}
.contact-list li{display:flex;gap:15px;align-items:flex-start;margin-bottom:20px}
.contact-list .ico{width:48px;height:48px;border-radius:12px;background:var(--bg-tint);color:var(--green-dd);display:flex;align-items:center;justify-content:center;flex:none}
.contact-list .ico svg{width:22px;height:22px}
.contact-list b{font-family:var(--head);display:block;color:var(--ink);margin-bottom:2px}
.contact-list a,.contact-list span{color:var(--body)}
.contact-list a:hover{color:var(--green-dd)}
.contact-badges,.f-badges,.contact-badges{display:flex;gap:12px;flex-wrap:wrap}
.f-badge{display:inline-flex;align-items:center;gap:7px;background:var(--bg-tint);border-radius:999px;padding:8px 14px;font-family:var(--head);font-weight:600;font-size:.84rem;color:var(--ink-2)}
.f-badge svg{width:16px;height:16px;color:var(--green-dd)}

/* rating summary */
.rating-summary{display:flex;align-items:center;gap:12px;margin-top:16px}
.rating-summary .stars{color:#f5a623;letter-spacing:2px;font-size:1.2rem}
.rating-summary span{color:#c4d2c8}
.rating-summary b{color:#fff}

/* blog */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.post-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}
.post-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.post-card__img{display:block;aspect-ratio:16/10;overflow:hidden}
.post-card__img img{width:100%;height:100%;object-fit:cover}
.post-card__img--ph{display:flex;align-items:center;justify-content:center;background:var(--bg-tint);color:var(--green-dd)}
.post-card__img--ph svg{width:46px;height:46px}
.post-card__body{padding:22px 24px;display:flex;flex-direction:column;flex:1}
.post-card__date{font-size:.82rem;color:var(--muted);margin-bottom:8px}
.post-card h2{font-size:1.2rem;margin-bottom:10px}
.post-card h2 a{color:var(--ink)}
.post-card h2 a:hover{color:var(--green-dd)}
.post-card p{color:var(--muted);font-size:.94rem;flex:1;margin-bottom:14px}
.post-card .more{font-family:var(--head);font-weight:700;font-size:.88rem;color:var(--green-dd);display:inline-flex;gap:6px;align-items:center}
.post-card .more svg{width:14px;height:14px}
.post-hero-img{margin:0 0 28px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.post-hero-img img{width:100%;display:block}
.pagination{margin-top:40px;text-align:center}
.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 12px;border-radius:10px;border:1px solid var(--line);margin:0 4px;font-family:var(--head);font-weight:600;color:var(--ink-2)}
.pagination .page-numbers.current{background:var(--green);color:#fff;border-color:var(--green)}
.pagination a.page-numbers:hover{border-color:var(--green);color:var(--green-dd)}

/* footer */
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:40px;padding:64px 0 44px}
.f-logo{height:auto;width:170px;margin-bottom:16px;filter:brightness(0) invert(1);opacity:.95}
.f-about p{color:#a9b8af;font-size:.94rem;line-height:1.7}
.f-social{display:flex;gap:10px;margin-top:18px}
.f-social a{width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:#cfdcd3;transition:background .2s,color .2s}
.f-social a:hover{background:var(--green);color:#fff}
.f-social svg{width:19px;height:19px}
.site-footer h4{color:#fff;font-size:1.02rem;margin-bottom:16px}
.f-list{list-style:none;padding:0;margin:0}
.f-list li{margin-bottom:10px}
.f-list a{color:#a9b8af;font-size:.93rem}
.f-list a:hover{color:var(--green)}
.f-contact-list{list-style:none;padding:0;margin:0 0 18px}
.f-contact-list li{display:flex;gap:11px;align-items:flex-start;margin-bottom:13px;color:#a9b8af;font-size:.93rem}
.f-contact-list li svg{width:18px;height:18px;color:var(--green);flex:none;margin-top:2px}
.f-contact-list a{color:#cfdcd3}
.f-contact-list a:hover{color:var(--green)}
.f-badges .f-badge{background:rgba(255,255,255,.08);color:#cfdcd3}
.f-badges .f-badge svg{color:var(--green)}

/* responsive for template additions */
@media (max-width:1024px){
  .svc-grid,.feature-grid,.review-grid,.post-grid{grid-template-columns:repeat(2,1fr)}
  .area-grid--lg{grid-template-columns:repeat(3,1fr)}
  .content-grid{grid-template-columns:1fr;gap:36px}
  .content-side .sidecard{position:static}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:720px){
  .svc-grid,.feature-grid,.review-grid,.post-grid{grid-template-columns:1fr}
  .area-grid--lg{grid-template-columns:repeat(2,1fr)}
  .accred{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:34px}
  .tick-list.two-col{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:28px;padding:48px 0 36px}
  .hero__stats{gap:22px}
  .inline-cta{flex-direction:column;align-items:flex-start}
}
@media (max-width:460px){
  .area-grid--lg{grid-template-columns:1fr}
}
