
:root{
  --orange:#ff6a00;
  --orange2:#ff7f1f;
  --dark:#090909;
  --charcoal:#151515;
  --soft:#f7f7f5;
  --muted:#666;
  --line:rgba(255,255,255,.18);
  --radius:24px;
  --shadow:0 20px 60px rgba(0,0,0,.18);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  color:#151515;
  background:#fff;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.skip-link{position:absolute;left:-999px;top:0;background:#fff;color:#000;padding:10px;z-index:999}
.skip-link:focus{left:10px}
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:0 16px 10px;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(0,0,0,.08);
}
.top-banner{margin:0 -16px 10px;background:#111;color:#fff;overflow:hidden;border-bottom:1px solid rgba(255,255,255,.12)}
.marquee{display:flex;width:max-content;animation:scrollText 24s linear infinite;white-space:nowrap;font-weight:950;letter-spacing:.01em;font-size:13px}
.marquee span{display:inline-block;padding:8px 28px;color:#fff}
.marquee b{color:var(--orange)}
@keyframes scrollText{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.nav-wrap{max-width:1180px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:10px;font-weight:900;letter-spacing:-.03em}
.brand img{height:54px;width:auto}
.nav{display:flex;gap:20px;align-items:center;font-weight:800;font-size:14px}
.nav a{opacity:.78}
.header-contact{font-weight:950;color:#111!important;opacity:1!important}
.nav a:hover,.nav a.active{opacity:1;color:var(--orange)}
.nav-cta{background:var(--orange);color:#fff!important;padding:11px 16px;border-radius:999px;opacity:1!important;box-shadow:0 10px 24px rgba(255,106,0,.25)}
.menu-btn{display:none;border:0;background:#111;color:#fff;border-radius:14px;padding:11px 13px;font-weight:900}
.hero{
  min-height:100svh;
  display:grid;
  align-items:center;
  padding:112px 18px 54px;
  position:relative;
  overflow:hidden;
  isolation:isolate;
  background:#111;
}
.hero::before{
  content:"";
  position:absolute;inset:0;
  background-image:
    linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.54),rgba(0,0,0,.72)),
    var(--hero-1);
  background-size:cover;
  background-position:center;
  animation:heroFade 24s infinite;
  z-index:-2;
}
.hero::after{
  content:"";
  position:absolute;inset:0;
  background:radial-gradient(circle at 25% 25%, rgba(255,106,0,.22), transparent 35%),
             linear-gradient(0deg,rgba(0,0,0,.35),transparent 42%);
  z-index:-1;
}
@keyframes heroFade{
  0%,26%{background-image:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.54),rgba(0,0,0,.72)),var(--hero-1)}
  33%,59%{background-image:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.54),rgba(0,0,0,.72)),var(--hero-2)}
  66%,92%{background-image:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.54),rgba(0,0,0,.72)),var(--hero-3)}
}
.hero-inner{max-width:1180px;margin:0 auto;width:100%;color:#fff}
.kicker{display:inline-flex;align-items:center;gap:9px;padding:8px 12px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.1);font-weight:900;font-size:13px;letter-spacing:.02em;text-transform:uppercase}
.kicker span{width:9px;height:9px;background:var(--orange);border-radius:999px;box-shadow:0 0 0 7px rgba(255,106,0,.16)}
.hero .kicker,.page-hero .kicker{display:none}
.hero h1,.page-hero h1{
  font-size:clamp(43px,8vw,96px);
  line-height:.92;
  letter-spacing:-.07em;
  margin:22px 0 18px;
  max-width:940px;
}
.hero h1 strong,.page-hero h1 strong,.orange{color:var(--orange)}
.hero p,.page-hero p{font-size:clamp(18px,2.3vw,25px);line-height:1.45;max-width:770px;color:rgba(255,255,255,.86);font-weight:600}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:15px 20px;border-radius:999px;font-weight:950;border:1px solid transparent;box-shadow:0 16px 30px rgba(0,0,0,.18)}
.btn.primary{background:var(--orange);color:#fff}
.btn.dark{background:#111;color:#fff}
.btn.ghost{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.26)}
.trust-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:42px;max-width:920px}
.trust-card{padding:18px;border-radius:20px;border:1px solid var(--line);background:rgba(255,255,255,.1);backdrop-filter:blur(6px)}
.trust-card b{display:block;font-size:26px;color:#fff;letter-spacing:-.04em}
.trust-card span{display:block;color:rgba(255,255,255,.76);font-weight:700;font-size:13px;margin-top:4px}
section{padding:76px 18px}
.container{max-width:1180px;margin:0 auto}
.section-title{font-size:clamp(34px,5vw,64px);line-height:.98;letter-spacing:-.06em;margin:0 0 16px}
.lead{font-size:19px;line-height:1.65;color:#555;max-width:820px;font-weight:600}
.grid{display:grid;gap:18px}
.cards{grid-template-columns:repeat(3,1fr);margin-top:32px}
.card{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:var(--radius);padding:28px;box-shadow:0 12px 40px rgba(0,0,0,.06)}
.card.highlight{background:#111;color:#fff;position:relative;overflow:hidden}
.card.highlight::after{content:"";position:absolute;right:-80px;top:-80px;width:180px;height:180px;background:var(--orange);border-radius:50%;opacity:.35}
.icon{font-size:30px;margin-bottom:18px}
.card h3{font-size:25px;margin:0 0 10px;letter-spacing:-.04em}
.card p{margin:0;color:#666;line-height:1.6;font-weight:600}
.card.highlight p{color:rgba(255,255,255,.78)}
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:center}
.image-panel{min-height:520px;border-radius:32px;background-size:cover;background-position:center;box-shadow:var(--shadow);position:relative;overflow:hidden}
.image-panel::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.56),transparent 50%)}
.text-panel{padding:18px}
.feature-list{display:grid;gap:12px;margin-top:24px}
.feature{display:flex;gap:12px;align-items:flex-start;padding:14px;border:1px solid rgba(0,0,0,.08);border-radius:18px;background:#fff;font-weight:800}
.tick{background:var(--orange);color:#fff;width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex:0 0 28px}
.band{
  background:#111;color:#fff;
  background-image:linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.62)),var(--band-img);
  background-size:cover;background-position:center;
}
.band .container{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:center}
.band p{color:rgba(255,255,255,.82)}
.badge-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.badge{padding:18px;border-radius:19px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.16);font-weight:950}
.service-strip{background:var(--soft)}
.service-links{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:28px}
.service-link{min-height:250px;border-radius:26px;overflow:hidden;position:relative;background-size:cover;background-position:center;color:#fff;display:flex;align-items:flex-end;padding:22px;box-shadow:var(--shadow);background-color:#111}
.service-link::before{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.82),rgba(0,0,0,.08))}
.service-link > div{position:relative;z-index:1}
.service-link h3{font-size:23px;letter-spacing:-.04em;margin:0 0 8px}
.service-link p{margin:0;color:rgba(255,255,255,.82);font-weight:700;line-height:1.45}
.page-hero{
  min-height:64svh;
  display:grid;align-items:end;
  padding:130px 18px 58px;
  color:#fff;position:relative;isolation:isolate;background:#111;
}
.page-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(0,0,0,.86),rgba(0,0,0,.54)),var(--page-img);background-size:cover;background-position:center;z-index:-1}
.content-two{display:grid;grid-template-columns:.9fr 1.1fr;gap:24px;align-items:start}
.info-box{background:#111;color:#fff;border-radius:28px;padding:28px;position:sticky;top:98px}
.info-box p{color:rgba(255,255,255,.78);line-height:1.6}
.list{display:grid;gap:14px}
.list-item{padding:22px;border-radius:22px;border:1px solid rgba(0,0,0,.08);background:#fff;box-shadow:0 10px 30px rgba(0,0,0,.05)}
.list-item h3{margin:0 0 8px;font-size:23px;letter-spacing:-.04em}
.list-item p{margin:0;color:#555;line-height:1.6;font-weight:600}
.form-wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:22px}
form{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:28px;padding:26px;box-shadow:0 12px 40px rgba(0,0,0,.08)}
label{display:block;font-weight:900;margin:14px 0 7px}
input,textarea,select{width:100%;padding:15px 14px;border:1px solid rgba(0,0,0,.14);border-radius:14px;font:inherit;background:#fff}
textarea{min-height:135px;resize:vertical}
.full{width:100%;margin-top:18px;border:none;cursor:pointer}
.footer{background:#080808;color:#fff;padding:40px 18px}
.footer-inner{max-width:1180px;margin:0 auto;display:flex;justify-content:space-between;gap:20px;align-items:center;flex-wrap:wrap}
.footer img{height:56px;background:#fff;border-radius:10px;padding:3px}
.footer p{margin:0;color:rgba(255,255,255,.72);font-weight:700}
.footer a{color:var(--orange);font-weight:950}
.mobile-sticky{display:none}
@media(max-width:900px){
  .menu-btn{display:block}
  .nav{position:absolute;left:14px;right:14px;top:78px;display:none;flex-direction:column;align-items:stretch;background:#fff;border-radius:22px;padding:14px;box-shadow:0 18px 60px rgba(0,0,0,.2)}
  .nav.open{display:flex}
  .nav a{padding:12px;border-radius:14px}
  .nav-cta{text-align:center}
  .brand img{height:46px}
  .hero{padding-top:106px;min-height:92svh}
  .hero h1,.page-hero h1{font-size:46px;letter-spacing:-.06em}
  .hero p,.page-hero p{font-size:18px}
  .trust-row{grid-template-columns:repeat(2,1fr)}
  section{padding:56px 16px}
  .cards,.service-links,.band .container,.split,.content-two,.form-wrap{grid-template-columns:1fr}
  .service-links{gap:14px}
  .service-link{min-height:210px}
  .image-panel{min-height:360px;border-radius:26px}
  .band .container{gap:26px}
  .badge-grid{grid-template-columns:1fr}
  .info-box{position:static}
  .footer-inner{align-items:flex-start}
  .mobile-sticky{position:fixed;bottom:12px;left:12px;right:12px;display:flex;z-index:1001;background:var(--orange);color:#fff;justify-content:center;padding:14px;border-radius:999px;font-weight:950;box-shadow:0 16px 36px rgba(0,0,0,.3)}
  body{padding-bottom:70px}
}
@media(max-width:520px){
  .hero h1,.page-hero h1{font-size:40px}
  .cta-row .btn{width:100%}
  .trust-row{grid-template-columns:1fr}
  .section-title{font-size:36px}
  .card{padding:23px}
}

.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:30px}
.review-card{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:24px;padding:24px;box-shadow:0 12px 36px rgba(0,0,0,.07)}
.review-top{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.avatar{width:42px;height:42px;border-radius:50%;background:var(--orange);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:950}
.review-name{font-weight:950;line-height:1.1}.google-style{font-size:13px;color:#777;font-weight:800}.stars{color:#ffb400;letter-spacing:1px;font-size:19px;margin:10px 0}.review-card p{font-weight:650;line-height:1.6;color:#444;margin:0}
.contact-lines{display:grid;gap:10px;margin-top:18px}.contact-lines a{color:var(--orange);font-weight:950}
@media(max-width:900px){
  .reviews-grid{grid-template-columns:1fr}
  .site-header{padding-bottom:10px}
  .marquee{font-size:12px;animation-duration:18s}.marquee span{padding:7px 20px}
  .hero{padding-top:124px}.page-hero{padding-top:142px;min-height:58svh}
  .hero::before{background-size:cover,contain;background-position:center,center top;background-repeat:no-repeat;background-color:#050505}
  .page-hero::before{background-size:cover,contain;background-position:center,center;background-repeat:no-repeat;background-color:#050505}
  .hero::after{background:linear-gradient(90deg,rgba(0,0,0,.7),rgba(0,0,0,.42)),linear-gradient(0deg,rgba(0,0,0,.5),transparent 45%)}
  .menu-btn{border-radius:22px;padding:13px 18px}
}
@media(max-width:520px){.service-link{min-height:230px;background-size:contain;background-repeat:no-repeat;background-color:#111;background-position:center top}.service-link::before{background:linear-gradient(0deg,rgba(0,0,0,.9) 0%,rgba(0,0,0,.3) 60%,rgba(0,0,0,.04) 100%)}}


/* v3 mobile image and service-card polish */
.hero .kicker,
.page-hero .kicker{
  display:none !important;
}

.service-link{
  background-color:#111;
  background-repeat:no-repeat;
  background-size:cover;
  background-position:center;
}
.service-link::before{
  background:
    linear-gradient(0deg,rgba(0,0,0,.82),rgba(0,0,0,.24)),
    radial-gradient(circle at 70% 20%,rgba(255,106,0,.12),transparent 34%);
}
.service-link h3,
.service-link p{
  text-shadow:0 2px 12px rgba(0,0,0,.55);
}

@media(max-width:900px){
  .hero{
    min-height:auto;
    padding-top:104px;
    padding-bottom:54px;
    background:#050505;
  }
  .hero::before{
    background-size:100% auto, 100% auto !important;
    background-position:center top, center top !important;
    background-repeat:no-repeat !important;
  }
  .hero::after{
    background:
      linear-gradient(180deg,rgba(0,0,0,.44) 0%,rgba(0,0,0,.60) 18%,#050505 42%,#050505 100%),
      radial-gradient(circle at 25% 20%, rgba(255,106,0,.16), transparent 34%);
  }
  .page-hero{
    min-height:auto;
    padding-top:112px;
    padding-bottom:54px;
    background:#050505;
    align-items:end;
  }
  .page-hero::before{
    background-size:100% auto !important;
    background-position:center top !important;
    background-repeat:no-repeat !important;
    opacity:1;
  }
  .page-hero::after{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(180deg,rgba(0,0,0,.40) 0%,rgba(0,0,0,.55) 28%,#050505 62%,#050505 100%);
    z-index:-1;
  }
  .hero-inner,
  .page-hero .container{
    padding-top:170px;
  }
  .hero h1,
  .page-hero h1{
    margin-top:0;
  }
  .service-link{
    min-height:260px;
    background-size:cover;
    background-position:center;
  }
}

@media(max-width:520px){
  .hero-inner,
  .page-hero .container{
    padding-top:150px;
  }
  .hero::before{
    background-size:100% auto, 112% auto !important;
  }
  .page-hero::before{
    background-size:112% auto !important;
  }
  .service-link{
    min-height:235px;
    background-size:cover;
  }
}

/* Individual page image tuning on mobile */
@media(max-width:900px){
  body.repairs-page .page-hero::before{background-position:center top !important;background-size:108% auto !important;}
  body.servicing-page .page-hero::before{background-position:center top !important;background-size:110% auto !important;}
  body.spares-page .page-hero::before{background-position:center top !important;background-size:108% auto !important;}
  body.refurbished-page .page-hero::before{background-position:center top !important;background-size:108% auto !important;}
  body.reviews-page .page-hero::before{background-position:center top !important;background-size:110% auto !important;}
}


/* v4 final visual corrections */
.service-link{
  position:relative !important;
  isolation:isolate !important;
  overflow:hidden !important;
  background-color:#111 !important;
  background-size:cover !important;
  background-position:center !important;
}
.service-link::after{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  z-index:0 !important;
  background-image:var(--card-img) !important;
  background-size:cover !important;
  background-position:center !important;
  opacity:.72 !important;
  transform:scale(1.02) !important;
}
.service-link::before{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  z-index:1 !important;
  background:
    linear-gradient(0deg,rgba(0,0,0,.92) 0%,rgba(0,0,0,.62) 46%,rgba(0,0,0,.18) 100%),
    radial-gradient(circle at 80% 20%,rgba(255,106,0,.22),transparent 34%) !important;
}
.service-link > div{
  position:relative !important;
  z-index:2 !important;
}

/* Desktop page hero: give text more width and stop heading collisions */
.page-hero .container{
  max-width:1180px !important;
}
.page-hero h1{
  max-width:980px !important;
  font-size:clamp(52px,6.6vw,88px) !important;
  line-height:.94 !important;
  letter-spacing:-.065em !important;
}
.page-hero p{
  max-width:860px !important;
}

/* Mobile: make image area look deliberate, not like a tiny strip with black void */
@media(max-width:900px){
  .hero,
  .page-hero{
    padding-top:0 !important;
    padding-bottom:0 !important;
    min-height:auto !important;
    display:block !important;
    overflow:hidden !important;
  }

  .hero::before,
  .page-hero::before{
    background-size:cover !important;
    background-position:center top !important;
    background-repeat:no-repeat !important;
    height:100% !important;
    opacity:1 !important;
  }

  .hero::after,
  .page-hero::after{
    content:"" !important;
    position:absolute !important;
    inset:0 !important;
    z-index:-1 !important;
    background:
      linear-gradient(180deg,rgba(0,0,0,.35) 0%,rgba(0,0,0,.58) 34%,rgba(0,0,0,.88) 68%,#050505 100%) !important;
  }

  .hero-inner,
  .page-hero .container{
    padding:260px 18px 58px !important;
    max-width:100% !important;
  }

  .hero h1,
  .page-hero h1{
    font-size:clamp(38px,11vw,52px) !important;
    line-height:.98 !important;
    letter-spacing:-.055em !important;
    max-width:100% !important;
    margin-bottom:22px !important;
  }
  .hero p,
  .page-hero p{
    font-size:20px !important;
    line-height:1.5 !important;
    max-width:100% !important;
  }

  .service-link{
    min-height:260px !important;
  }
  .service-link::after{
    opacity:.82 !important;
  }
}

/* Tune individual mobile backgrounds so the Dyson product is visible */
@media(max-width:520px){
  .hero-inner,
  .page-hero .container{
    padding-top:230px !important;
  }

  body.home-page .hero::before{
    background-size:auto 42%, auto 42% !important;
    background-position:center 98px, center 98px !important;
  }

  body.repairs-page .page-hero::before{
    background-size:auto 42% !important;
    background-position:center 102px !important;
  }
  body.servicing-page .page-hero::before{
    background-size:auto 42% !important;
    background-position:center 102px !important;
  }
  body.spares-page .page-hero::before{
    background-size:auto 42% !important;
    background-position:center 102px !important;
  }
  body.refurbished-page .page-hero::before{
    background-size:auto 38% !important;
    background-position:center 104px !important;
  }
  body.reviews-page .page-hero::before{
    background-size:auto 42% !important;
    background-position:center 102px !important;
  }

  .service-link{
    min-height:245px !important;
    border-radius:24px !important;
  }
}


/* v5: final image-led mobile hero and visible service-card photos */

/* Make the 4 service tabs obviously image-backed */
.service-link{
  position:relative !important;
  isolation:isolate !important;
  overflow:hidden !important;
  background-color:#111 !important;
  background-image:var(--card-img) !important;
  background-size:cover !important;
  background-position:center !important;
}
.service-link::after{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  z-index:0 !important;
  background-image:var(--card-img) !important;
  background-size:cover !important;
  background-position:center !important;
  opacity:1 !important;
  filter:saturate(1.08) contrast(1.04) brightness(1.05) !important;
  transform:none !important;
}
.service-link::before{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  z-index:1 !important;
  background:
    linear-gradient(180deg,rgba(0,0,0,.08) 0%,rgba(0,0,0,.10) 34%,rgba(0,0,0,.76) 100%) !important;
}
.service-link > div{
  position:relative !important;
  z-index:2 !important;
}
.service-link h3,
.service-link p{
  text-shadow:0 3px 14px rgba(0,0,0,.82) !important;
}

/* Desktop page hero text fitting */
.page-hero h1{
  max-width:1050px !important;
  font-size:clamp(48px,6vw,82px) !important;
  line-height:.96 !important;
}

/* Mobile hero rule: image fills the hero, text over the top, no big blank black sections */
@media(max-width:900px){
  .hero,
  .page-hero{
    min-height:calc(100svh - 118px) !important;
    display:grid !important;
    align-items:end !important;
    padding:0 !important;
    background:#111 !important;
    overflow:hidden !important;
    position:relative !important;
  }

  .hero::before,
  .page-hero::before{
    content:"" !important;
    position:absolute !important;
    inset:0 !important;
    z-index:-2 !important;
    background-size:cover !important;
    background-position:center center !important;
    background-repeat:no-repeat !important;
    opacity:1 !important;
    height:auto !important;
  }

  .hero::after,
  .page-hero::after{
    content:"" !important;
    position:absolute !important;
    inset:0 !important;
    z-index:-1 !important;
    background:
      linear-gradient(180deg,rgba(0,0,0,.16) 0%,rgba(0,0,0,.18) 26%,rgba(0,0,0,.48) 58%,rgba(0,0,0,.78) 100%),
      linear-gradient(90deg,rgba(0,0,0,.52) 0%,rgba(0,0,0,.20) 58%,rgba(0,0,0,.22) 100%) !important;
  }

  .hero-inner,
  .page-hero .container{
    width:100% !important;
    max-width:100% !important;
    padding:220px 22px 52px !important;
    margin:0 !important;
  }

  .hero h1,
  .page-hero h1{
    font-size:clamp(38px,10.5vw,50px) !important;
    line-height:.98 !important;
    letter-spacing:-.055em !important;
    max-width:100% !important;
    margin:0 0 20px !important;
  }

  .hero p,
  .page-hero p{
    font-size:19px !important;
    line-height:1.48 !important;
    max-width:100% !important;
    color:rgba(255,255,255,.90) !important;
  }

  .cta-row{
    margin-top:24px !important;
  }

  /* Clearer image-backed cards on mobile */
  .service-link{
    min-height:260px !important;
    background-size:cover !important;
    background-position:center !important;
  }
  .service-link::after{
    opacity:1 !important;
  }
  .service-link::before{
    background:linear-gradient(180deg,rgba(0,0,0,.08) 0%,rgba(0,0,0,.16) 42%,rgba(0,0,0,.84) 100%) !important;
  }

  /* Make sticky CTA less intrusive so it doesn't cover the first section so aggressively */
  .mobile-sticky{
    bottom:10px !important;
    left:18px !important;
    right:18px !important;
    padding:13px 14px !important;
  }
}

/* Per-page mobile composition: use clear product images, avoid the black image with the Dyson word */
@media(max-width:520px){
  .hero,
  .page-hero{
    min-height:calc(100svh - 114px) !important;
  }

  .hero-inner,
  .page-hero .container{
    padding:210px 21px 48px !important;
  }

  body.home-page .hero::before{
    background-image:linear-gradient(90deg,rgba(0,0,0,.30),rgba(0,0,0,.16)),url('/assets/cordless.jpg') !important;
    background-size:cover !important;
    background-position:center top !important;
  }

  body.repairs-page .page-hero::before{
    background-image:linear-gradient(90deg,rgba(0,0,0,.26),rgba(0,0,0,.16)),url('/assets/cordless.jpg') !important;
    background-size:cover !important;
    background-position:center top !important;
  }

  body.servicing-page .page-hero::before{
    background-image:linear-gradient(90deg,rgba(0,0,0,.24),rgba(0,0,0,.12)),url('/assets/classic.webp') !important;
    background-size:cover !important;
    background-position:center center !important;
  }

  body.spares-page .page-hero::before{
    background-image:linear-gradient(90deg,rgba(0,0,0,.22),rgba(0,0,0,.12)),url('/assets/brush.jpg') !important;
    background-size:cover !important;
    background-position:center center !important;
  }

  body.refurbished-page .page-hero::before{
    background-image:linear-gradient(90deg,rgba(0,0,0,.22),rgba(0,0,0,.12)),url('/assets/range.jpg') !important;
    background-size:cover !important;
    background-position:center center !important;
  }

  body.reviews-page .page-hero::before{
    background-image:linear-gradient(90deg,rgba(0,0,0,.24),rgba(0,0,0,.12)),url('/assets/classic.webp') !important;
    background-size:cover !important;
    background-position:center center !important;
  }

  body.contact-page .page-hero::before{
    background-image:linear-gradient(90deg,rgba(0,0,0,.30),rgba(0,0,0,.14)),url('/assets/lineup.jpg') !important;
    background-size:cover !important;
    background-position:center center !important;
  }
}

/* Slightly taller service image cards on desktop so image is clearer */
@media(min-width:901px){
  .service-link{
    min-height:280px !important;
  }
}


/* FINAL SERVICE CARD IMAGE FIX
   The 4 homepage service tabs are intentionally direct image cards:
   clear photo first, bottom-only gradient second, readable text third. */
.service-links .service-link{
  position:relative !important;
  isolation:isolate !important;
  overflow:hidden !important;
  min-height:320px !important;
  border-radius:28px !important;
  background-color:#111 !important;
  background-image:var(--card-img) !important;
  background-size:cover !important;
  background-position:center center !important;
  background-repeat:no-repeat !important;
  display:flex !important;
  align-items:flex-end !important;
  padding:26px !important;
  box-shadow:0 24px 60px rgba(0,0,0,.22) !important;
}

/* Remove previous dark photo layer completely */
.service-links .service-link::after{
  display:none !important;
  content:none !important;
}

/* Bottom-only readability gradient. Image stays visible across most of card. */
.service-links .service-link::before{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  z-index:1 !important;
  background:
    linear-gradient(180deg,
      rgba(0,0,0,0.00) 0%,
      rgba(0,0,0,0.05) 28%,
      rgba(0,0,0,0.42) 68%,
      rgba(0,0,0,0.88) 100%
    ) !important;
  pointer-events:none !important;
}

.service-links .service-link > div{
  position:relative !important;
  z-index:2 !important;
  max-width:100% !important;
}

.service-links .service-link h3{
  margin:0 0 8px !important;
  color:#fff !important;
  font-size:26px !important;
  line-height:1.05 !important;
  letter-spacing:-.045em !important;
  text-shadow:0 4px 18px rgba(0,0,0,.95) !important;
}

.service-links .service-link p{
  color:rgba(255,255,255,.92) !important;
  font-size:16px !important;
  line-height:1.42 !important;
  font-weight:850 !important;
  text-shadow:0 3px 14px rgba(0,0,0,.95) !important;
}

/* Deliberate framing per card */
.service-links .service-link.card-repairs{background-position:center center !important;}
.service-links .service-link.card-servicing{background-position:center center !important;}
.service-links .service-link.card-spares{background-position:center center !important;}
.service-links .service-link.card-refurbished{background-position:center center !important;}

@media(max-width:900px){
  .service-links .service-link{
    min-height:280px !important;
    padding:24px !important;
    background-size:cover !important;
  }
  .service-links .service-link h3{
    font-size:25px !important;
  }
}

@media(max-width:520px){
  .service-links .service-link{
    min-height:250px !important;
    border-radius:24px !important;
  }
}


/* ==========================================================================
   FINAL CORRECTED SERVICE IMAGE CARDS
   Built with real <img> elements so the photos cannot be hidden by background
   CSS conflicts. Image first, bottom gradient second, text third.
   ========================================================================== */

.service-image-grid{
  display:grid !important;
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:18px !important;
  margin-top:28px !important;
}

.service-image-card{
  position:relative !important;
  display:flex !important;
  align-items:flex-end !important;
  min-height:330px !important;
  border-radius:28px !important;
  overflow:hidden !important;
  isolation:isolate !important;
  background:#111 !important;
  box-shadow:0 22px 58px rgba(0,0,0,.22) !important;
  border:1px solid rgba(0,0,0,.08) !important;
  transform:translateZ(0) !important;
}

.service-image-card img{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center center !important;
  z-index:0 !important;
  opacity:1 !important;
  filter:saturate(1.08) contrast(1.06) brightness(1.04) !important;
  transform:scale(1.01) !important;
}

.service-image-card.card-repairs img{object-position:center center !important;}
.service-image-card.card-servicing img{object-position:center center !important;}
.service-image-card.card-spares img{object-position:center center !important;}
.service-image-card.card-refurbished img{object-position:center center !important;}

.service-image-shade{
  position:absolute !important;
  inset:0 !important;
  z-index:1 !important;
  background:
    linear-gradient(180deg,
      rgba(0,0,0,0.00) 0%,
      rgba(0,0,0,0.04) 30%,
      rgba(0,0,0,0.46) 68%,
      rgba(0,0,0,0.90) 100%
    ) !important;
  pointer-events:none !important;
}

.service-image-copy{
  position:relative !important;
  z-index:2 !important;
  padding:26px !important;
  width:100% !important;
}

.service-image-copy h3{
  color:#fff !important;
  font-size:26px !important;
  line-height:1.05 !important;
  letter-spacing:-.045em !important;
  margin:0 0 9px !important;
  text-shadow:0 4px 18px rgba(0,0,0,.95) !important;
}

.service-image-copy p{
  color:rgba(255,255,255,.92) !important;
  font-size:16px !important;
  line-height:1.45 !important;
  font-weight:850 !important;
  margin:0 !important;
  text-shadow:0 3px 14px rgba(0,0,0,.95) !important;
}

.service-image-card:hover img{
  transform:scale(1.055) !important;
  transition:transform .45s ease !important;
}

@media(max-width:1050px){
  .service-image-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }
}

@media(max-width:620px){
  .service-image-grid{
    grid-template-columns:1fr !important;
    gap:14px !important;
  }
  .service-image-card{
    min-height:255px !important;
    border-radius:24px !important;
  }
  .service-image-copy{
    padding:22px !important;
  }
  .service-image-copy h3{
    font-size:25px !important;
  }
}

/* Desktop safety: make old service-link cards irrelevant if any remain */
.service-links .service-link:not(.service-image-card){
  display:none !important;
}


/* ==========================================================================
   Final client amendments
   ========================================================================== */

.mobile-sticky{
  gap:10px !important;
  background:transparent !important;
  box-shadow:none !important;
  padding:0 !important;
}
.mobile-sticky .sticky-btn{
  flex:1 1 0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  text-align:center !important;
  min-height:54px !important;
  border-radius:999px !important;
  font-weight:950 !important;
  font-size:15px !important;
  line-height:1.1 !important;
  box-shadow:0 14px 32px rgba(0,0,0,.22) !important;
}
.mobile-sticky .sticky-book{background:var(--orange) !important;color:#fff !important;}
.mobile-sticky .sticky-call{background:#111 !important;color:#fff !important;border:1px solid rgba(255,255,255,.18) !important;}

@media(max-width:900px){
  .hero .cta-row,.page-hero .cta-row{
    margin-top:18px !important;
    transform:translateY(-8px) !important;
  }
  .hero,.page-hero{padding-bottom:18px !important;}
}

@media(max-width:520px){
  body.home-page .hero::before{
    animation:mobileHeroFade 24s infinite !important;
    background-size:cover !important;
    background-position:center center !important;
  }
  @keyframes mobileHeroFade{
    0%,29%{background-image:linear-gradient(90deg,rgba(0,0,0,.30),rgba(0,0,0,.16)),url('/assets/cordless.jpg') !important;background-position:center center !important;}
    34%,63%{background-image:linear-gradient(90deg,rgba(0,0,0,.28),rgba(0,0,0,.14)),url('/assets/classic.webp') !important;background-position:center center !important;}
    68%,100%{background-image:linear-gradient(90deg,rgba(0,0,0,.28),rgba(0,0,0,.14)),url('/assets/lineup.jpg') !important;background-position:center center !important;}
  }
}

.icon-list .list-item{
  display:grid !important;
  grid-template-columns:52px 1fr !important;
  gap:16px !important;
  align-items:start !important;
}
.box-icon{
  width:52px !important;height:52px !important;border-radius:18px !important;
  display:flex !important;align-items:center !important;justify-content:center !important;
  background:rgba(255,106,0,.12) !important;color:var(--orange) !important;
  font-size:25px !important;border:1px solid rgba(255,106,0,.22) !important;
}
.icon-list .list-item > div h3{margin-top:0 !important;}

.footer-contact-links{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:10px 16px !important;
  align-items:center !important;
}
.footer-contact-links .footer-credit{color:rgba(255,255,255,.72) !important;}
.footer-contact-links .footer-credit a{color:var(--orange) !important;}
.footer p.footer-details{max-width:680px !important;line-height:1.4 !important;}

.review-cta-wrap{margin-top:26px !important;}


/* Before / After Slider */
.before-after-feature{
  background:#fff;
}
.before-after-intro{
  margin-bottom:28px;
}
.comparison-slider{
  position:relative;
  width:100%;
  max-width:920px;
  margin:0 auto;
  border-radius:30px;
  overflow:hidden;
  box-shadow:0 24px 70px rgba(0,0,0,.22);
  background:#111;
  aspect-ratio:4/3;
  border:1px solid rgba(0,0,0,.08);
}
.comparison-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}
.comparison-after{
  z-index:1;
}
.comparison-before-wrap{
  position:absolute;
  inset:0;
  z-index:2;
  width:50%;
  overflow:hidden;
}
.comparison-before{
  width:100%;
  max-width:none;
}
.comparison-range{
  position:absolute;
  inset:0;
  z-index:5;
  width:100%;
  height:100%;
  opacity:0;
  cursor:ew-resize;
}
.comparison-handle{
  position:absolute;
  top:0;
  bottom:0;
  left:50%;
  z-index:4;
  width:3px;
  background:#fff;
  box-shadow:0 0 0 1px rgba(0,0,0,.18),0 0 24px rgba(0,0,0,.35);
  transform:translateX(-50%);
  pointer-events:none;
}
.comparison-handle::after{
  content:"↔";
  position:absolute;
  top:50%;
  left:50%;
  width:54px;
  height:54px;
  transform:translate(-50%,-50%);
  border-radius:999px;
  background:var(--orange);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:950;
  font-size:22px;
  box-shadow:0 14px 35px rgba(0,0,0,.35);
}
.comparison-label{
  position:absolute;
  top:18px;
  z-index:6;
  padding:8px 13px;
  border-radius:999px;
  background:rgba(0,0,0,.72);
  color:#fff;
  font-weight:950;
  font-size:14px;
  backdrop-filter:blur(8px);
  pointer-events:none;
}
.label-before{left:18px}
.label-after{right:18px}
@media(max-width:700px){
  .comparison-slider{
    border-radius:24px;
    aspect-ratio:3/4;
  }
  .comparison-handle::after{
    width:48px;
    height:48px;
    font-size:20px;
  }
}


/* Desktop before/after slider correction only */
.comparison-slider{
  max-width:760px !important;
  aspect-ratio:3/4 !important;
  background:#111 !important;
}

.comparison-img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center center !important;
}

.comparison-before-wrap{
  height:100% !important;
}

.comparison-before-wrap .comparison-before{
  position:absolute !important;
  inset:0 auto 0 0 !important;
  height:100% !important;
  max-width:none !important;
  object-fit:cover !important;
  object-position:center center !important;
}

@media(min-width:901px){
  .comparison-slider{
    max-width:820px !important;
    aspect-ratio:3/4 !important;
  }
}

@media(max-width:700px){
  .comparison-slider{
    aspect-ratio:3/4 !important;
  }
}


/* FIX: desktop before/after too large */
@media (min-width: 1024px){
  .comparison-slider{
    max-width: 700px !important;
    margin: 0 auto !important;
    aspect-ratio: 4/5 !important;
  }
}



/* Additional gallery before/after examples */
.additional-gallery-sliders{
  padding-top:36px;
}
.gallery-comparison-block{
  margin:38px auto 58px;
  max-width:900px;
}
.gallery-comparison-block h3{
  font-size:clamp(24px,3vw,34px);
  line-height:1;
  letter-spacing:-.04em;
  margin:0 0 18px;
  text-align:center;
}
.gallery-comparison-block .comparison-slider{
  margin-top:0 !important;
}


/* Workshop photo on contact page */
.workshop-photo-section{
  padding-top:20px;
  background:#fff;
}
.workshop-photo{
  width:100%;
  max-width:980px;
  margin:0 auto;
  border-radius:28px;
  box-shadow:0 24px 70px rgba(0,0,0,.16);
  object-fit:cover;
}
@media(max-width:700px){
  .workshop-photo{
    border-radius:22px;
  }
}
