/*
Theme Name: Chase
Theme URI: https://chasecarpetcleaners.co.uk
Author: Burntwood Business
Author URI: https://burntwood.business
Description: Fast, lightweight custom theme for Chase Carpet Cleaners. No page builder. Angular, logo-led design — all brand styling lives in this one stylesheet. Bump the Version below after any CSS/JS change to bust caches.
Version: 0.2.4
Requires at least: 6.4
Requires PHP: 8.0
License: GNU General Public License v2 or later
Text Domain: chase
*/

/* ============================================================
   Design tokens — angular system built around the logo chevron
   ============================================================ */
:root{
  --navy:#22335c;        /* primary ink / dark brand blue */
  --navy-deep:#1a2747;
  --cyan:#16aeeb;        /* bright accent (the logo's bright blue) */
  --cyan-dark:#0f8fc4;
  --blue:#2563d6;
  --ink:#161f33;
  --muted:#5a6781;
  --line:#e2e7f0;
  --bg:#ffffff;
  --bg-soft:#eef2f8;
  --bg-tint:#e7f5fd;
  --ok:#1faa59;

  --slant:34px;          /* diagonal divider depth */
  --notch:20px;          /* corner cut depth */
  --shadow:0 18px 40px rgba(20,31,58,.13);
  --shadow-sm:0 8px 20px rgba(20,31,58,.10);
  --wrap:1160px;
  --font:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.6;
  font-size:clamp(1rem,.96rem + .2vw,1.075rem);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-weight:800;line-height:1.08;color:var(--navy);margin:0 0 .5em;letter-spacing:-.025em;text-transform:none}
h1{font-size:clamp(2.2rem,1.4rem + 3.6vw,4rem)}
h2{font-size:clamp(1.8rem,1.2rem + 2.2vw,2.8rem)}
h3{font-size:clamp(1.2rem,1.05rem + .7vw,1.55rem)}
p{margin:0 0 1rem}
.wrap{width:min(var(--wrap),100% - 2.4rem);margin-inline:auto}
.section{padding:clamp(3rem,7vw,6.5rem) 0;position:relative}
.section--soft{background:var(--bg-soft)}
.section--tint{background:var(--bg-tint)}
.center{text-align:center}
.lead{font-size:1.18rem;color:var(--muted)}

/* Diagonal band: a colour block with slanted top & bottom edges */
.slant{clip-path:polygon(0 var(--slant),100% 0,100% calc(100% - var(--slant)),0 100%);
  padding-top:calc(clamp(3rem,7vw,6.5rem) + var(--slant));padding-bottom:calc(clamp(3rem,7vw,6.5rem) + var(--slant))}

/* ============================================================
   Eyebrow — chevron arrow (echoes the logo mark)
   ============================================================ */
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;text-transform:uppercase;
  font-size:.95rem;font-weight:800;letter-spacing:.16em;color:var(--blue);margin-bottom:1rem}
.eyebrow::before{content:"";width:20px;height:16px;background:var(--cyan);
  clip-path:polygon(0 0,55% 0,100% 50%,55% 100%,0 100%,45% 50%)}
.eyebrow.center{justify-content:center}
.eyebrow.light{color:#9fc8ec}
.eyebrow.light::before{background:var(--cyan)}

/* Angular highlight behind a heading word (replaces gradient text) */
.grad-text{position:relative;display:inline-block;color:var(--navy);z-index:0;white-space:nowrap}
.grad-text::after{content:"";position:absolute;left:-.08em;right:-.08em;bottom:.06em;height:.32em;
  background:var(--cyan);transform:skewX(-14deg);z-index:-1}

/* ============================================================
   Buttons — notched corner, solid, no gradient
   ============================================================ */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-weight:800;font-size:1rem;
  padding:.9rem 1.6rem;border:0;cursor:pointer;text-decoration:none;line-height:1;
  clip-path:polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 0px) 100%,0 100%,0 14px);
  transition:transform .14s ease,background .14s ease,color .14s ease}
.btn:hover{text-decoration:none;transform:translate(-2px,-2px)}
.btn:active{transform:translate(0,0)}
.btn-gradient{background:var(--cyan);color:#06243a;box-shadow:6px 6px 0 rgba(34,51,92,.18)}
.btn-gradient:hover{background:var(--navy);color:#fff}
.btn-ink{background:var(--navy);color:#fff}
.btn-ink:hover{background:var(--cyan);color:#06243a}
.btn-ghost{background:transparent;color:var(--navy);box-shadow:inset 0 0 0 2px var(--navy)}
.btn-ghost:hover{background:var(--navy);color:#fff}
.btn-lg{padding:1.1rem 2rem;font-size:1.1rem}

/* ============================================================
   Tags / pills — parallelograms
   ============================================================ */
.pill{display:inline-block;padding:.4rem .95rem;font-size:.85rem;font-weight:700;
  background:#fff;color:var(--navy);box-shadow:inset 0 0 0 1.5px var(--cyan);
  clip-path:polygon(10px 0,100% 0,calc(100% - 10px) 100%,0 100%);transition:background .15s ease,color .15s ease}
.pill:hover{background:var(--cyan);color:#06243a}

/* ============================================================
   Cards — square with a cut corner + cyan notch flag
   ============================================================ */
.card{position:relative;background:#fff;box-shadow:var(--shadow-sm);padding:1.7rem;
  clip-path:polygon(0 0,calc(100% - var(--notch)) 0,100% var(--notch),100% 100%,0 100%);
  border-top:3px solid var(--navy);transition:transform .18s ease,box-shadow .18s ease}
.card::before{content:"";position:absolute;top:0;right:0;width:var(--notch);height:var(--notch);
  background:var(--cyan);clip-path:polygon(0 0,100% 0,100% 100%)}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.card-top{border-top-color:var(--cyan)}
.card-top-navy{border-top-color:var(--navy)}
.card-top-blue{border-top-color:var(--blue)}

/* Icon chip — angular tile */
.icon-chip{width:54px;height:54px;display:grid;place-items:center;background:var(--navy);color:var(--cyan);
  margin-bottom:1rem;font-size:1.45rem;clip-path:polygon(0 0,100% 0,100% 75%,75% 100%,0 100%);
  transition:transform .25s ease,background .25s ease,color .25s ease}
.card:hover .icon-chip{background:var(--cyan);color:#06243a;transform:translateY(-3px)}

/* Check list — chevron ticks */
.list-check{list-style:none;padding:0;margin:0;display:grid;gap:.65rem}
.list-check li{position:relative;padding-left:2rem}
.list-check li::before{content:"";position:absolute;left:0;top:.18em;width:14px;height:12px;background:var(--cyan);
  clip-path:polygon(0 0,55% 0,100% 50%,55% 100%,0 100%,45% 50%)}

.grid{display:grid;gap:clamp(1rem,2.5vw,1.8rem)}
@media(min-width:720px){.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.grid-4{grid-template-columns:repeat(4,1fr)}}

.grad-bar{height:6px;border:0;margin:0;background:var(--cyan);
  clip-path:polygon(0 0,100% 0,calc(100% - 14px) 100%,0 100%)}

/* ============================================================
   Header
   ============================================================ */
.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:3px solid var(--navy)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.55rem 0}
.brand{display:flex;align-items:center;gap:.7rem;font-weight:800;color:var(--navy)}
.brand img{width:50px;height:50px}
.brand span{font-size:1.05rem;line-height:1.02;text-transform:uppercase;letter-spacing:.02em}
.nav{display:flex;align-items:center;gap:1.4rem}
.nav a{color:var(--navy);font-weight:700;text-transform:uppercase;font-size:.82rem;letter-spacing:.06em;padding-bottom:2px;border-bottom:2px solid transparent}
.nav a:hover{color:var(--cyan-dark);text-decoration:none;border-bottom-color:var(--cyan)}
.header-cta{display:flex;align-items:center;gap:.6rem}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:.4rem}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--navy);margin:5px 0;transition:.2s}
@media(max-width:900px){
  .nav{position:fixed;inset:66px 0 auto 0;flex-direction:column;background:#fff;padding:1.2rem;
    border-bottom:3px solid var(--navy);transform:translateY(-130%);transition:transform .25s ease;gap:1rem;align-items:flex-start}
  .nav.open{transform:translateY(0)}
  .nav-toggle{display:block}
  .header-cta .btn-text{display:none}
}

/* ============================================================
   Hero — angular split, image in a chevron frame
   ============================================================ */
.hero{position:relative;background:var(--bg-soft);overflow:hidden}
.hero::before{content:"";position:absolute;top:-15%;right:-6%;width:46%;height:130%;background:var(--navy);
  clip-path:polygon(28% 0,100% 0,100% 100%,0 100%);opacity:1;z-index:0}
.hero__inner{position:relative;z-index:1;display:grid;gap:2.5rem;align-items:center;padding:clamp(2.5rem,6vw,5.5rem) 0}
@media(min-width:900px){.hero__inner{grid-template-columns:1.05fr .95fr}}
.hero h1{margin-bottom:.45em}
.hero .lead{max-width:46ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.5rem}
.hero__media{position:relative}
.hero-carousel{position:relative;aspect-ratio:5/4;box-shadow:var(--shadow);clip-path:polygon(0 5%,100% 0,100% 95%,0 100%)}
.hero-carousel img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.4s ease}
.hero-carousel img.is-active{opacity:1}
.hero__badge{position:absolute;bottom:-16px;left:-12px;background:var(--navy);color:#fff;
  padding:.75rem 1.1rem;display:flex;align-items:center;gap:.6rem;font-weight:800;
  clip-path:polygon(0 0,100% 0,calc(100% - 14px) 100%,0 100%)}
.stars{color:#ffb400;letter-spacing:1px}
.trust-row{display:flex;flex-wrap:wrap;gap:.7rem 1.6rem;margin-top:1.8rem;color:var(--muted);font-size:.95rem;font-weight:600}
.trust-row>span{display:inline-flex;align-items:center;gap:.4rem;white-space:nowrap}
.trust-row b{color:var(--navy)}
@media(max-width:899px){.hero::before{display:none}}

.area-list{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center}

/* Sticky mobile call bar */
.callbar{position:fixed;left:0;right:0;bottom:0;z-index:60;display:none;gap:.5rem;padding:.5rem;
  background:var(--navy);border-top:3px solid var(--cyan)}
.callbar .btn{flex:1;justify-content:center;padding:.85rem}
@media(max-width:900px){.callbar{display:flex}body{padding-bottom:74px}}

/* ============================================================
   Footer
   ============================================================ */
.site-footer{background:var(--navy-deep);color:#c4cfe4;padding:clamp(2.5rem,6vw,4rem) 0 1.5rem;
  border-top:6px solid var(--cyan)}
.site-footer h4{color:#fff;text-transform:uppercase;letter-spacing:.06em;font-size:.95rem}
.site-footer a{color:#c4cfe4}
.site-footer a:hover{color:#fff}
.footer-grid{display:grid;gap:2rem}
@media(min-width:760px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr}}
.footer-bottom{border-top:1px solid rgba(255,255,255,.14);margin-top:2rem;padding-top:1.2rem;
  display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between;font-size:.85rem;color:#94a4c4}
.social-row{display:flex;gap:.6rem;margin-top:.8rem}
.social-row a{width:42px;height:42px;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#fff;font-weight:800;
  clip-path:polygon(0 0,100% 0,100% 75%,75% 100%,0 100%)}
.social-row a:hover{background:var(--cyan);color:#06243a}

/* ============================================================
   Inner pages
   ============================================================ */
.page-hero{background:var(--navy);color:#fff;padding:clamp(2.5rem,6vw,4.5rem) 0;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;top:0;right:0;width:40%;height:100%;background:var(--cyan);
  opacity:.16;clip-path:polygon(35% 0,100% 0,100% 100%,0 100%)}
.page-hero h1{color:#fff;position:relative}
.prose{max-width:72ch}
.prose img{margin:1.5rem 0;clip-path:polygon(0 2%,100% 0,100% 98%,0 100%)}
.video-frame{margin:1.6rem auto;max-width:360px}
.video-frame video{display:block;width:100%;height:auto;background:#000;box-shadow:var(--shadow);clip-path:polygon(0 2%,100% 0,100% 98%,0 100%)}
.media-split{display:grid;gap:1.8rem;align-items:center;margin:1.6rem 0}
@media(min-width:680px){.media-split{grid-template-columns:1.1fr .9fr}}
.media-split h2{margin-top:0}
.media-split .video-frame{margin:0;max-width:320px;justify-self:center}
.prose h2{margin-top:2.2rem}
.faq details{background:#fff;border-left:4px solid var(--cyan);padding:1rem 1.2rem;margin-bottom:.8rem;box-shadow:var(--shadow-sm)}
.faq summary{font-weight:800;color:var(--navy);cursor:pointer;list-style:none}
.faq summary::-webkit-details-marker{display:none}

.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem}
@media(min-width:760px){.gallery{grid-template-columns:repeat(4,1fr)}}
.gallery img{aspect-ratio:1;object-fit:cover;
  clip-path:polygon(0 0,calc(100% - 16px) 0,100% 16px,100% 100%,0 100%);transition:transform .2s ease}
.gallery img:hover{transform:scale(1.03)}

/* Google reviews carousel */
.review{position:relative;margin:0;background:#fff;padding:1.6rem;box-shadow:var(--shadow-sm);
  border-top:3px solid var(--cyan);display:flex;flex-direction:column;gap:.6rem;
  clip-path:polygon(0 0,calc(100% - var(--notch)) 0,100% var(--notch),100% 100%,0 100%)}
.review .stars{font-size:1.05rem}
.review blockquote{margin:0;color:var(--ink);font-size:1rem;line-height:1.6}
.review figcaption{margin-top:auto;display:flex;flex-direction:column;color:var(--muted);font-size:.9rem}
.review figcaption strong{color:var(--navy)}
.reviews-carousel{position:relative}
.reviews-track{display:flex;gap:1.5rem;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  padding:.5rem;margin:-.5rem;scrollbar-width:none;-ms-overflow-style:none}
.reviews-track::-webkit-scrollbar{display:none}
.reviews-track .review{flex:0 0 calc((100% - 3rem)/3);scroll-snap-align:start}
@media(max-width:880px){.reviews-track .review{flex-basis:78%}}
.rev-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:46px;height:46px;
  border:0;background:var(--navy);color:#fff;font-size:1.6rem;line-height:1;cursor:pointer;
  clip-path:polygon(0 0,100% 0,100% 75%,75% 100%,0 100%);display:grid;place-items:center;transition:background .15s ease}
.rev-arrow:hover{background:var(--cyan);color:#06243a}
.rev-prev{left:-10px}.rev-next{right:-10px}
@media(max-width:600px){.rev-arrow{display:none}}

/* Jet-wash reveal CTA */
.jw-band{position:relative;overflow:hidden;text-align:center;background:#fff;border-top:3px solid var(--cyan);
  padding:clamp(2.6rem,5vw,4rem) clamp(1.4rem,4vw,3rem);box-shadow:var(--shadow-sm);
  clip-path:polygon(0 0,calc(100% - var(--notch)) 0,100% var(--notch),100% 100%,0 100%)}
.jw-clean{position:relative;z-index:1;max-width:48ch;margin-inline:auto;display:grid;gap:.6rem;justify-items:center}
.jw-grime{position:absolute;inset:0;z-index:2;clip-path:inset(0 0 0 0);
  background:
    radial-gradient(circle at 18% 32%,rgba(38,46,28,.55) 0 9%,transparent 10%),
    radial-gradient(circle at 68% 58%,rgba(28,38,24,.5) 0 8%,transparent 9%),
    radial-gradient(circle at 44% 80%,rgba(52,46,30,.5) 0 11%,transparent 12%),
    radial-gradient(circle at 84% 24%,rgba(40,48,30,.5) 0 7%,transparent 8%),
    repeating-linear-gradient(135deg,rgba(0,0,0,.10) 0 7px,transparent 7px 15px),
    linear-gradient(180deg,#827f63,#6a6a50)}
.jw-nozzle{position:absolute;top:0;bottom:0;left:-40px;width:48px;z-index:3;opacity:0;display:grid;place-items:center;pointer-events:none}
.is-cleaning .jw-grime{animation:jwwipe 2.9s cubic-bezier(.45,.05,.3,1) forwards}
.is-cleaning .jw-nozzle{animation:jwmove 2.9s cubic-bezier(.45,.05,.3,1) forwards}
@keyframes jwwipe{to{clip-path:inset(0 0 0 100%)}}
@keyframes jwmove{0%{opacity:1;left:-40px}88%{opacity:1}100%{left:calc(100% - 8px);opacity:0}}
@media(prefers-reduced-motion:reduce){.jw-grime,.jw-nozzle{display:none}}

@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto}}
