/*
Theme Name: Central Pure Clean
Theme URI: https://centralpureclean.example
Author: Central Pure Clean LLP
Description: One-page business theme for Central Pure Clean LLP - exterior cleaning specialists. Brand colours and layout based on the company logo, with phone-first calls to action. Phone number, hours and tagline are editable under Appearance > Customise.
Version: 1.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: central-pure-clean
Tags: one-column, custom-menu, custom-logo, business
*/

:root{
  --navy:#122a5c;
  --navy-deep:#0c1d42;
  --blue:#1d4ba0;
  --green:#5fa928;
  --green-bright:#7cc832;
  --sky:#cfe9fb;
  --sky-deep:#9ed3f5;
  --paper:#f4f8fc;
  --ink:#1b2438;
  --white:#ffffff;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto} *,*::before,*::after{animation:none!important;transition:none!important}}
body{font-family:'Barlow',sans-serif;color:var(--ink);background:var(--white);line-height:1.6}
img{max-width:100%;display:block}
a{color:inherit}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
h1,h2,h3,.disp{font-family:'Barlow Condensed',sans-serif;line-height:1.05;text-transform:uppercase}
.eyebrow{font-family:'Barlow Condensed',sans-serif;font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:.95rem;color:var(--green);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:34px;height:4px;background:var(--green-bright);border-radius:2px}

/* ---------- top bar ---------- */
.topbar{background:var(--navy-deep);color:var(--sky);font-size:.9rem;padding:8px 0}
.topbar .wrap{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.topbar strong{color:var(--white)}

/* ---------- header ---------- */
header{position:sticky;top:0;z-index:50;background:var(--white);box-shadow:0 2px 14px rgba(12,29,66,.12)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:10px 0}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none}
.brand img{width:62px;height:62px}
.brand .bt{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-style:italic;text-transform:uppercase;font-size:1.45rem;line-height:.95;color:var(--navy)}
.brand .bt span{color:var(--green)}
.brand .bs{font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--blue)}
nav.links{display:flex;gap:26px;font-weight:600;font-size:.98rem}
nav.links a{text-decoration:none;color:var(--navy);padding:6px 0;border-bottom:3px solid transparent;transition:border-color .2s}
nav.links a:hover,nav.links a:focus-visible{border-color:var(--green-bright)}
.call-btn{display:inline-flex;align-items:center;gap:10px;background:var(--green);color:var(--white);text-decoration:none;font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:1.25rem;letter-spacing:.03em;padding:10px 22px;border-radius:999px;box-shadow:0 4px 0 #47831c;transition:transform .15s,box-shadow .15s;white-space:nowrap}
.call-btn:hover,.call-btn:focus-visible{transform:translateY(2px);box-shadow:0 2px 0 #47831c}
.call-btn svg{width:20px;height:20px;fill:var(--white)}
:focus-visible{outline:3px solid var(--green-bright);outline-offset:2px}
@media(max-width:900px){nav.links{display:none}}

/* ---------- hero ---------- */
.hero{background:linear-gradient(165deg,var(--navy-deep) 0%,var(--navy) 45%,var(--blue) 100%);color:var(--white);position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;inset:auto -10% -120px -10%;height:220px;background:var(--white);border-radius:50% 50% 0 0/100% 100% 0 0}
.hero .wrap{display:grid;grid-template-columns:1.05fr 1fr;gap:56px;align-items:center;padding-top:72px;padding-bottom:170px;position:relative;z-index:1}
.hero h1{font-size:clamp(2.6rem,5.2vw,4.3rem);font-weight:800;font-style:italic}
.hero h1 em{font-style:italic;color:var(--green-bright)}
.hero p.lede{margin:22px 0 30px;font-size:1.18rem;color:var(--sky);max-width:34rem}
.hero .eyebrow{color:var(--green-bright)}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.ghost-btn{display:inline-flex;align-items:center;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:1.15rem;letter-spacing:.04em;text-transform:uppercase;color:var(--white);text-decoration:none;border:2px solid rgba(255,255,255,.5);padding:11px 24px;border-radius:999px;transition:border-color .2s,background .2s}
.ghost-btn:hover,.ghost-btn:focus-visible{border-color:var(--green-bright);background:rgba(124,200,50,.12)}
.hero-trust{margin-top:30px;display:flex;gap:22px;flex-wrap:wrap;font-size:.92rem;color:var(--sky)}
.hero-trust span{display:flex;align-items:center;gap:8px}
.tick{width:18px;height:18px;border-radius:50%;background:var(--green-bright);display:inline-flex;align-items:center;justify-content:center;color:var(--navy-deep);font-weight:800;font-size:.75rem;flex:none}

/* ---------- hero photo (signature) ---------- */
.ba{position:relative;border-radius:18px;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.45);border:5px solid var(--white);background:var(--navy-deep)}
.ba img{width:100%;height:auto;display:block}
.ba .tag{position:absolute;top:14px;font-family:'Barlow Condensed',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:.95rem;padding:5px 14px;border-radius:999px;color:#fff;pointer-events:none}
.ba .tag.b{left:14px;background:rgba(12,29,66,.85)}
.ba .tag.a{right:14px;background:var(--green)}
.ba-hint{text-align:center;margin-top:14px;color:var(--sky);font-size:.92rem}
@media(max-width:900px){
  .hero .wrap{grid-template-columns:1fr;gap:36px;padding-top:44px;padding-bottom:140px}
  .hero p.lede{font-size:1.08rem}
  .hero-ctas{justify-content:flex-start}
}
@media(max-width:480px){
  .hero .wrap{padding-top:34px;padding-bottom:120px}
  .hero-ctas .call-btn,.hero-ctas .ghost-btn{width:100%;justify-content:center;text-align:center}
  .ba{border-width:4px;border-radius:14px}
}

/* ---------- results gallery ---------- */
.results{padding:80px 0;background:var(--navy);color:var(--sky);position:relative;overflow:hidden}
.results .sec-head h2{color:#fff}
.results .sec-head p{color:var(--sky)}
.results .eyebrow{color:var(--green-bright)}
.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.res-card{background:var(--navy-deep);border-radius:16px;overflow:hidden;border:1px solid rgba(158,211,245,.25);box-shadow:0 14px 34px rgba(0,0,0,.35)}
.res-card figure{position:relative;margin:0}
.res-card img{width:100%;height:auto;display:block}
.res-card .tag{position:absolute;top:12px;font-family:'Barlow Condensed',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:.85rem;padding:4px 12px;border-radius:999px;color:#fff}
.res-card .tag.b{left:12px;background:rgba(12,29,66,.85)}
.res-card .tag.a{right:12px;background:var(--green)}
.res-card .cap{padding:18px 20px}
.res-card .cap h3{font-size:1.3rem;font-weight:800;color:#fff;margin-bottom:4px}
.res-card .cap p{font-size:.92rem;color:var(--sky-deep);margin:0}
@media(max-width:900px){.res-grid{grid-template-columns:1fr;max-width:560px;margin:0 auto}}

/* ---------- why section ---------- */
.why{padding:90px 0 60px;background:var(--white)}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.why h2{font-size:clamp(2rem,3.6vw,3rem);font-weight:800;font-style:italic;color:var(--navy);margin:12px 0 20px}
.why h2 em{color:var(--green);font-style:italic}
.why p{margin-bottom:16px;color:#3c4658;font-size:1.05rem}
.why p strong{color:var(--navy)}
.stat-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.stat{background:var(--paper);border-radius:16px;padding:26px 22px;border-top:6px solid var(--green-bright);box-shadow:0 6px 18px rgba(12,29,66,.07)}
.stat:nth-child(2){border-top-color:var(--blue)}
.stat:nth-child(3){border-top-color:var(--blue)}
.stat .num{font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:2.6rem;color:var(--navy);line-height:1}
.stat .lbl{font-weight:700;color:var(--navy);margin:8px 0 6px}
.stat p{font-size:.93rem;color:#4a5468;margin:0}
@media(max-width:900px){.why-grid{grid-template-columns:1fr}.stat-cards{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.stat-cards{grid-template-columns:1fr}}

/* ---------- services ---------- */
.services{padding:80px 0;background:linear-gradient(180deg,var(--paper),#e8f1fa)}
.sec-head{text-align:center;max-width:46rem;margin:0 auto 50px}
.sec-head h2{font-size:clamp(2rem,3.6vw,3rem);font-weight:800;font-style:italic;color:var(--navy);margin:12px 0 14px}
.sec-head p{color:#3c4658;font-size:1.05rem}
.svc-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.svc{background:var(--white);border-radius:16px;overflow:hidden;box-shadow:0 8px 22px rgba(12,29,66,.10);border:1px solid #dbe6f2;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s}
.svc:hover{transform:translateY(-6px);box-shadow:0 16px 32px rgba(12,29,66,.16)}
.svc .icon{height:96px;background:linear-gradient(150deg,var(--navy),var(--blue));display:flex;align-items:center;justify-content:center}
.svc .icon svg{width:52px;height:52px;fill:none;stroke:var(--sky);stroke-width:1.6}
.svc .body{padding:18px 18px 22px;display:flex;flex-direction:column;gap:8px;flex:1}
.svc h3{font-size:1.3rem;font-weight:800;color:var(--navy)}
.svc p{font-size:.9rem;color:#4a5468;flex:1}
.svc .more{font-family:'Barlow Condensed',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--green);font-size:.95rem}
@media(max-width:1020px){.svc-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.svc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:440px){.svc-grid{grid-template-columns:1fr}}

/* ---------- process ---------- */
.process{padding:80px 0;background:var(--white)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:step}
.step{position:relative;background:var(--paper);border-radius:16px;padding:60px 26px 28px;border:1px solid #dbe6f2}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);position:absolute;top:-22px;left:26px;font-family:'Barlow Condensed',sans-serif;font-weight:800;font-style:italic;font-size:2rem;background:var(--green);color:#fff;width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:4px solid var(--white);box-shadow:0 6px 16px rgba(12,29,66,.18)}
.step h3{font-size:1.4rem;color:var(--navy);margin-bottom:8px;font-weight:800}
.step p{font-size:.97rem;color:#4a5468}
@media(max-width:820px){.steps{grid-template-columns:1fr;gap:44px}}

/* ---------- cta banner ---------- */
.cta-band{background:linear-gradient(135deg,var(--green) 0%,var(--green-bright) 100%);padding:70px 0;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;right:-80px;top:-80px;width:340px;height:340px;border-radius:50%;background:rgba(255,255,255,.14)}
.cta-band .wrap{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;position:relative}
.cta-band h2{color:#fff;font-size:clamp(1.9rem,3.4vw,2.8rem);font-weight:800;font-style:italic;max-width:32rem}
.big-phone{display:inline-flex;align-items:center;gap:16px;background:var(--navy-deep);color:#fff;text-decoration:none;font-family:'Barlow Condensed',sans-serif;font-weight:800;font-size:clamp(1.7rem,3vw,2.4rem);letter-spacing:.04em;padding:18px 36px;border-radius:999px;box-shadow:0 8px 0 rgba(12,29,66,.45);transition:transform .15s,box-shadow .15s}
.big-phone:hover,.big-phone:focus-visible{transform:translateY(3px);box-shadow:0 5px 0 rgba(12,29,66,.45)}
.big-phone svg{width:30px;height:30px;fill:var(--green-bright)}
.cta-sub{color:#0c1d42;font-weight:600;margin-top:10px}

/* ---------- contact ---------- */
.contact{padding:80px 0;background:var(--navy-deep);color:var(--sky)}
.contact .wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.contact h2{color:#fff;font-size:clamp(2rem,3.4vw,2.8rem);font-weight:800;font-style:italic;margin:12px 0 16px}
.contact p{margin-bottom:14px}
.contact .logo-big{width:min(330px,80%);height:auto;margin:0 auto;filter:drop-shadow(0 18px 40px rgba(0,0,0,.5))}
.contact ul{list-style:none;margin-top:20px;display:grid;gap:12px}
.contact li{display:flex;gap:12px;align-items:flex-start}
.contact li strong{color:#fff}
@media(max-width:820px){.contact .wrap{grid-template-columns:1fr}}

/* ---------- footer ---------- */
footer{background:#070f24;color:#8ea3c4;padding:26px 0;font-size:.88rem}
footer .wrap{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}
footer a{color:var(--sky);text-decoration:none}

/* ---------- mobile floating call ---------- */
.float-call{display:none}
@media(max-width:700px){
  body{padding-bottom:86px}
  .brand .bs{display:none}
  .brand .bt br{display:none}
  .brand .bt{font-size:1.12rem;line-height:1.1}
  .brand img{width:46px;height:46px}
  .brand{gap:10px}
  .nav{padding:8px 0;gap:10px}
  .nav .call-btn{font-size:1rem;padding:8px 14px;gap:7px}
  .nav .call-btn svg{width:16px;height:16px}
  .topbar{font-size:.8rem}
  .float-call{display:flex;position:fixed;bottom:14px;left:14px;right:14px;z-index:60;justify-content:center}
  .float-call a{width:100%;justify-content:center;font-size:1.4rem;padding:14px}
}

/* ---------- WordPress-specific ---------- */
.admin-bar header{top:32px}
@media(max-width:782px){.admin-bar header{top:46px}}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px)}
nav.links ul{display:flex;gap:26px;list-style:none;margin:0;padding:0}
nav.links li{margin:0}
/* Generic inner page content */
.page-content{padding:70px 0}
.page-content h1{font-size:clamp(2rem,3.6vw,3rem);font-weight:800;font-style:italic;color:var(--navy);margin-bottom:20px}
.page-content .entry{max-width:46rem}
.page-content p{margin-bottom:16px;color:#3c4658}
