/* That Refurb Guy — watercolour theme (palette pulled from the hero video) */
:root{
  /* washed olive-sage from the painted foliage */
  --sage:        #A8B58A;
  --sage-deep:   #7A8964;
  --sage-soft:   #DAE0CD;
  --sage-wash:   #EFF1E7;
  /* dusty rose / blush — replaces the harsher terracotta */
  --terra:       #C8A294;
  --terra-deep:  #A47A6C;
  --terra-soft:  #EAD9D0;
  /* washed window-sky blue */
  --slate:       #88A4B0;
  --slate-soft:  #C9D8DE;
  --slate-wash:  #E5EBEE;
  /* warm linen / sand / paper */
  --linen:       #EFE7D7;
  --paper:       #FBF6EB;
  --cream:       #F5ECDC;
  --ink:         #3A3530;
  --ink-soft:    #6E665E;
  --ink-faint:   #B4ACA0;
  --line:        #DFD7C5;
  --line-soft:   #EAE2D2;
  --radius:      14px;
  --radius-lg:   20px;
  --shadow-soft: 0 6px 22px rgba(58,57,54,.06);
  --shadow-mid:  0 14px 38px rgba(58,57,54,.10);
  --font-display:'Fraunces','Source Serif Pro',Georgia,serif;
  --font-body:   'Inter','Segoe UI',system-ui,-apple-system,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--sage-deep);text-decoration:none}
a:hover{text-decoration:underline}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;color:var(--ink);letter-spacing:-.01em;line-height:1.18;margin:0 0 .5em}
h1{font-size:clamp(2.2rem,4.4vw,3.4rem);font-weight:550}
h2{font-size:clamp(1.7rem,3vw,2.4rem)}
h3{font-size:1.25rem}
p{margin:0 0 1em}

.wrap{max-width:1180px;margin:0 auto;padding:0 24px}

.eyebrow{
  display:inline-block;font-family:var(--font-body);font-size:12px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--terra-deep);
  padding:6px 12px;background:var(--terra-soft);border-radius:99px;margin-bottom:14px;
}
.lede{font-size:1.1rem;color:var(--ink-soft);max-width:60ch}

/* ── Header ───────────────────────────────────────────────────────────────── */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(252,250,245,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line-soft);
}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;gap:18px}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand-mark{
  height:48px;width:auto;max-width:240px;object-fit:contain;display:block;
  /* tint pure-black artwork to the warm ink, blend softly with the cream header */
  filter:brightness(0) saturate(100%) invert(21%) sepia(6%) saturate(330%) hue-rotate(355deg);
  mix-blend-mode:multiply;
  transition:filter .18s;
}
.brand:hover .brand-mark{
  filter:brightness(0) saturate(100%) invert(36%) sepia(15%) saturate(670%) hue-rotate(80deg);
}
.site-nav{display:flex;align-items:center;gap:6px}
.site-nav a{
  padding:9px 14px;border-radius:99px;color:var(--ink-soft);font-weight:500;font-size:14px;
}
.site-nav a:hover{color:var(--ink);background:var(--sage-wash);text-decoration:none}
.site-nav a.active{color:var(--ink);background:var(--sage-soft)}
.nav-cta{margin-left:6px}
.nav-toggle{
  display:none;background:transparent;border:0;cursor:pointer;padding:8px;
  width:42px;height:42px;flex-direction:column;justify-content:center;gap:5px;
}
.nav-toggle span{display:block;height:2px;background:var(--ink);border-radius:2px;transition:.2s}

/* ── Buttons ──────────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 22px;border-radius:99px;border:1px solid transparent;cursor:pointer;
  font-family:var(--font-body);font-weight:600;font-size:15px;
  text-decoration:none;line-height:1;transition:.15s;
}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--sage-deep);color:#fff}
.btn-primary:hover{background:#587a64}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{background:var(--sage-wash);border-color:var(--sage-soft)}
.btn-danger{background:#b15252;color:#fff}
.btn-lg{padding:15px 28px;font-size:16px}
.btn-sm{padding:8px 14px;font-size:13px}
.btn-block{display:flex;width:100%}

/* ── Flash messages ───────────────────────────────────────────────────────── */
.flash-wrap{max-width:1180px;margin:14px auto 0;padding:0 24px}
.flash{padding:12px 16px;border-radius:var(--radius);margin-bottom:10px;font-size:14px}
.flash-success{background:var(--sage-wash);color:var(--sage-deep);border:1px solid var(--sage-soft)}
.flash-error  {background:#fbeded;color:#a33;border:1px solid #f0c8c8}

/* ── Hero ─────────────────────────────────────────────────────────────────── */
.hero{position:relative;padding:64px 0 80px;overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(60% 50% at 15% 10%,var(--terra-soft) 0,transparent 60%),
    radial-gradient(45% 40% at 90% 20%,var(--sage-soft) 0,transparent 65%),
    radial-gradient(55% 45% at 70% 95%,var(--slate-wash) 0,transparent 70%);
  opacity:.65;z-index:-1;
}
.hero-inner{display:grid;grid-template-columns:1.2fr .9fr;gap:60px;align-items:center}
.hero-text h1{margin-bottom:16px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin:24px 0 28px}
.trust{
  list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:8px 14px;
  font-size:13px;color:var(--ink-soft);
}
.trust li{display:flex;align-items:center;gap:6px}
.trust li::before{content:"✓";color:var(--sage-deep);font-weight:700}
.hero-art{position:relative;aspect-ratio:1/1;max-width:440px;margin-left:auto}
.wash{position:absolute;border-radius:50%;filter:blur(0.5px);mix-blend-mode:multiply;opacity:.78}

/* Background video mode — looping cinematic hero */
.hero-bg-video{
  min-height:560px;
  padding:80px 0 90px;
  overflow:hidden;
  color:#fff;
}
.hero-bg-video::before{display:none}             /* hide watercolour gradient bg */
.hero-bg{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;display:block;z-index:0;background:#1a1a1a;
}
.hero-scrim{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(100deg, rgba(20,20,18,.78) 0%, rgba(20,20,18,.55) 45%, rgba(20,20,18,.25) 75%, rgba(20,20,18,.1) 100%),
    linear-gradient(0deg, rgba(20,20,18,.35), rgba(20,20,18,0) 40%);
}
.hero-bg-video .hero-inner{position:relative;z-index:2;grid-template-columns:1fr;max-width:760px;margin:0 auto 0 0}
.hero-bg-video .hero-text{max-width:680px}
.hero-bg-video h1{color:#fff;text-shadow:0 2px 16px rgba(0,0,0,.35)}
.hero-bg-video .lede{color:rgba(255,255,255,.92)}
.hero-bg-video .eyebrow{background:rgba(255,255,255,.16);color:#fff;backdrop-filter:blur(4px)}
.hero-bg-video .trust{color:rgba(255,255,255,.88)}
.hero-bg-video .trust li::before{color:#A8C8B5}
.hero-bg-video .btn-ghost{color:#fff;border-color:rgba(255,255,255,.5);background:rgba(255,255,255,.08)}
.hero-bg-video .btn-ghost:hover{background:rgba(255,255,255,.16);border-color:#fff}
.wash-sage {width:78%;height:78%;background:radial-gradient(circle at 30% 30%,var(--sage-soft),transparent 70%);top:0;left:0}
.wash-terra{width:65%;height:65%;background:radial-gradient(circle at 30% 30%,var(--terra-soft),transparent 70%);bottom:6%;right:0}
.wash-slate{width:55%;height:55%;background:radial-gradient(circle at 30% 30%,var(--slate-soft),transparent 70%);top:18%;right:24%}

/* ── Sections ─────────────────────────────────────────────────────────────── */
.section{padding:70px 0}
.section-cream{background:var(--cream)}
.section-linen{background:var(--linen)}
.section-head{text-align:center;max-width:760px;margin:0 auto 44px}
.section-head .lede{margin:0 auto}
.section-cta{text-align:center;margin-top:36px}

.two-col{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:start}
.body-text p{color:var(--ink-soft);font-size:1.02rem}

/* ── Card grids ───────────────────────────────────────────────────────────── */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card-soft{
  background:var(--paper);border:1px solid var(--line-soft);
  border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-soft);
  transition:.18s;
}
.card-soft:hover{transform:translateY(-3px);box-shadow:var(--shadow-mid);border-color:var(--sage-soft)}
.card-soft h3{margin-bottom:10px;color:var(--ink)}
.card-soft p{color:var(--ink-soft);margin-bottom:10px}
.card-soft .detail{font-size:12.5px;color:var(--ink-faint);letter-spacing:.02em;margin:0}

/* ── Process ──────────────────────────────────────────────────────────────── */
.process{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step}
.process li{
  background:var(--paper);border:1px solid var(--line-soft);
  border-radius:var(--radius-lg);padding:28px;position:relative;
}
.step-num{
  position:absolute;top:-14px;left:24px;
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;border-radius:50%;
  background:var(--terra);color:#fff;font-weight:700;font-size:14px;
}
.process h3{margin:6px 0 8px}
.process p{color:var(--ink-soft);margin:0;font-size:.95rem}

/* ── Gallery ──────────────────────────────────────────────────────────────── */
.gallery-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:14px;
}
.gallery-item{
  position:relative;overflow:hidden;border-radius:var(--radius);
  aspect-ratio:4/3;background:var(--sage-wash);display:block;
}
.gallery-item img{
  width:100%;height:100%;object-fit:cover;transition:transform .35s ease;
}
.gallery-item:hover img{transform:scale(1.05)}
.gallery-caption{
  position:absolute;left:0;right:0;bottom:0;
  background:linear-gradient(to top,rgba(58,57,54,.8),transparent);
  color:#fff;padding:24px 14px 12px;font-size:13px;font-weight:500;
}
.gallery-filter{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px;justify-content:center}
.chip{
  background:var(--paper);border:1px solid var(--line);color:var(--ink-soft);
  padding:7px 16px;border-radius:99px;cursor:pointer;font-size:13px;font-weight:500;
}
.chip-active{background:var(--sage-deep);color:#fff;border-color:var(--sage-deep)}
.empty-state{
  text-align:center;padding:60px 20px;
  background:var(--sage-wash);border-radius:var(--radius-lg);
}
.empty-state h3{margin-bottom:8px}
.empty-state p{color:var(--ink-soft);max-width:520px;margin:0 auto 22px}

/* ── Reviews ──────────────────────────────────────────────────────────────── */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.review-card{
  background:var(--paper);border:1px solid var(--line-soft);
  border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-soft);
}
.stars{color:#d6a85b;letter-spacing:2px;font-size:1.1rem;margin-bottom:10px}
.review-text{color:var(--ink);font-size:1rem;margin-bottom:14px;font-style:italic}
.review-author{color:var(--ink-soft);font-size:.92rem;margin:0;font-weight:500}

/* ── Areas covered ────────────────────────────────────────────────────────── */
.areas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.area-card{
  background:var(--paper);border:1px solid var(--line-soft);
  border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-soft);
  display:flex;flex-direction:column;gap:10px;transition:.18s;
}
.area-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-mid);border-color:var(--sage-soft)}
.area-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.area-card h2{font-size:1.1rem;margin:0;line-height:1.25}
.area-postcode{
  font-size:11px;font-weight:700;letter-spacing:.06em;
  background:var(--terra-soft);color:var(--terra-deep);
  padding:4px 10px;border-radius:99px;white-space:nowrap;
}
.area-card p{color:var(--ink-soft);margin:0;font-size:.95rem}
.area-cta{
  margin-top:auto;font-size:13.5px;font-weight:600;color:var(--sage-deep);
  align-self:flex-start;
}
.areas-chips{
  list-style:none;padding:0;margin:0 auto;display:flex;flex-wrap:wrap;
  gap:10px;justify-content:center;max-width:860px;
}
.areas-chips a{
  display:inline-flex;gap:6px;align-items:center;
  padding:8px 16px;border-radius:99px;background:var(--paper);
  border:1px solid var(--line);color:var(--ink);font-size:13.5px;font-weight:500;
}
.areas-chips a:hover{background:var(--sage-wash);border-color:var(--sage-soft);text-decoration:none}
.areas-chips a span{color:var(--ink-soft);font-weight:400;font-size:12px}

/* ── Values (about) ───────────────────────────────────────────────────────── */
.values-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.value-card{
  background:var(--sage-wash);border-radius:var(--radius-lg);padding:22px;
}
.value-card h3{margin:0 0 6px;font-size:1.05rem}
.value-card p{color:var(--ink-soft);margin:0;font-size:.95rem}

/* ── CTA band ─────────────────────────────────────────────────────────────── */
.cta-band{
  background:linear-gradient(135deg,var(--terra-soft),var(--sage-soft));
}
.cta-inner{text-align:center;max-width:680px;margin:0 auto}
.cta-inner h2{color:var(--ink)}
.cta-inner .btn{margin-top:18px}

/* ── Page head (interior pages) ───────────────────────────────────────────── */
.page-head{
  background:linear-gradient(180deg,var(--sage-wash),transparent);
  padding:60px 0 30px;text-align:center;
}
.page-head .lede{margin:0 auto}

/* ── Forms ────────────────────────────────────────────────────────────────── */
.form{display:flex;flex-direction:column;gap:14px}
.form label{display:flex;flex-direction:column;gap:6px;font-size:14px;font-weight:600;color:var(--ink)}
.form input,.form textarea,.form select{
  font:inherit;color:var(--ink);
  padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--paper);transition:.15s;
}
.form input:focus,.form textarea:focus,.form select:focus{
  outline:none;border-color:var(--sage);box-shadow:0 0 0 3px var(--sage-wash);
}
.form textarea{resize:vertical;min-height:90px}
.form .btn{align-self:flex-start}
.form-help{font-size:13px;color:var(--ink-soft);margin:0}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-narrow{max-width:560px;margin:0 auto}

.contact-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:start}
.contact-aside{background:var(--sage-wash);padding:28px;border-radius:var(--radius-lg)}
.contact-aside h3{margin-top:0}
.contact-aside p{margin:0 0 14px;font-size:.95rem;color:var(--ink-soft)}
.contact-aside p strong{color:var(--ink)}

/* ── Legal pages ──────────────────────────────────────────────────────────── */
.legal-wrap{max-width:760px;margin:0 auto}
.legal-wrap h2{font-size:1.3rem;margin-top:32px}
.legal-wrap ul{padding-left:1.2em;color:var(--ink-soft)}
.legal-wrap p{color:var(--ink-soft)}
.legal-wrap a{color:var(--sage-deep);text-decoration:underline}

/* ── Footer ───────────────────────────────────────────────────────────────── */
.site-footer{
  background:var(--ink);color:#d0cdc4;
  padding:60px 0 24px;margin-top:60px;
}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:36px}
.footer-col h4{color:#fff;font-family:var(--font-body);font-size:13px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;margin:0 0 14px}
.footer-col a{display:block;color:#cbc8be;margin-bottom:8px;font-size:14px}
.footer-col a:hover{color:#fff}
.footer-brand{font-family:var(--font-display);font-size:1.4rem;color:#fff;margin-bottom:6px}
.footer-tag{margin-bottom:10px;font-size:14px}
.footer-coverage{font-size:13px;color:#a8a59d}
.footer-hours{font-size:13px;color:#a8a59d;margin-top:8px}
.socials{display:flex;gap:14px;margin-top:8px}
.socials a{display:inline}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
  border-top:1px solid #4a4843;padding-top:18px;font-size:13px;color:#8d8a82;
}
.footer-built a{color:#cbc8be}

/* ── Cookie banner ────────────────────────────────────────────────────────── */
.cookie-banner{
  position:fixed;bottom:18px;left:18px;right:18px;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:14px 18px;box-shadow:var(--shadow-mid);z-index:80;
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;max-width:520px;margin:0 auto;
}
.cookie-banner[hidden]{display:none}
.cookie-banner p{margin:0;font-size:14px;color:var(--ink-soft);flex:1;min-width:220px}

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media(max-width:980px){
  .hero{padding:48px 0 60px}
  .hero-inner{grid-template-columns:1fr;gap:36px}
  .hero-art{order:-1;max-width:320px;margin:0 auto}
  .two-col{grid-template-columns:1fr;gap:28px}
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .process{grid-template-columns:repeat(2,1fr)}
  .reviews-grid{grid-template-columns:repeat(2,1fr)}
  .areas-grid{grid-template-columns:repeat(2,1fr)}
  .values-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:28px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
}
@media(max-width:680px){
  .brand-mark{height:38px;max-width:180px}
  .nav-toggle{display:flex}
  .site-nav{
    position:fixed;top:64px;left:0;right:0;
    flex-direction:column;align-items:stretch;
    background:var(--paper);border-bottom:1px solid var(--line);
    padding:14px 18px 22px;gap:4px;
    transform:translateY(-120%);transition:transform .22s;
    box-shadow:var(--shadow-mid);
  }
  .site-nav.open{transform:translateY(0)}
  .site-nav a{padding:12px 14px;border-radius:var(--radius)}
  .nav-cta{margin-top:6px;text-align:center}
  .section{padding:50px 0}
  .card-grid{grid-template-columns:1fr}
  .process{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .areas-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:24px}
  .form-row{grid-template-columns:1fr}
  .hero-cta .btn{flex:1;min-width:0}
}
