/* Roofer Doncaster theme. Colours from the existing brand: red, near-black, charcoal, grey. */

:root{
  --red:#F43939;
  --red-dark:#d32020;
  --dark:#091216;
  --charcoal:#282828;
  --grey:#797979;
  --line:#e7e9ec;
  --light:#f5f6f8;
  --white:#fff;
  --maxw:1180px;
  --radius:14px;
  --shadow:0 10px 30px rgba(9,18,22,.10);
  --shadow-sm:0 4px 14px rgba(9,18,22,.08);
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font);color:var(--charcoal);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--red);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{color:var(--dark);line-height:1.15;margin:0 0 .5em;font-weight:800;letter-spacing:-.02em}
h1{font-size:clamp(2rem,4vw,3.1rem)}
h2{font-size:clamp(1.6rem,3vw,2.3rem)}
h3{font-size:1.2rem}
p{margin:0 0 1rem}

.rd-container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
.rd-skip{position:absolute;left:-9999px}
.rd-skip:focus{left:10px;top:10px;background:#fff;padding:10px;z-index:1000}

/* Buttons */
.rd-btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;border-radius:999px;padding:.8rem 1.4rem;cursor:pointer;border:2px solid transparent;transition:.18s;text-decoration:none;line-height:1;white-space:nowrap}
/* Keep phone numbers on one line wherever they appear as a link */
a[href^="tel:"]{white-space:nowrap}
.rd-btn:hover{text-decoration:none;transform:translateY(-2px)}
.rd-btn--call{background:var(--red);color:#fff;box-shadow:0 8px 20px rgba(244,57,57,.35)}
.rd-btn--call:hover{background:var(--red-dark);color:#fff}
.rd-btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.rd-btn--ghost:hover{background:#fff;color:var(--dark)}
.rd-btn--dark{background:var(--dark);color:#fff}
.rd-btn--dark:hover{background:#000;color:#fff}
.rd-btn--lg{padding:1rem 1.7rem;font-size:1.05rem}
.rd-btn__icon{display:inline-flex}

.rd-eyebrow{display:inline-flex;align-items:center;gap:.4rem;color:var(--red);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;margin:0 0 .6rem}

/* Header */
.rd-topbar{background:var(--dark);color:#cfd6da;font-size:.85rem}
.rd-topbar__inner{display:flex;gap:1.5rem;align-items:center;justify-content:center;flex-wrap:wrap;padding:.5rem 20px}
.rd-topbar__item{display:inline-flex;align-items:center;gap:.4rem;color:#cfd6da}
.rd-topbar__item svg{width:16px;height:16px;color:var(--red)}
.rd-topbar a:hover{color:#fff;text-decoration:none}

.rd-nav{position:sticky;top:0;z-index:200;background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow-sm)}
.rd-nav__inner{display:flex;align-items:center;gap:1.2rem;padding:.7rem 20px}
.rd-brand__text{display:flex;flex-direction:column;line-height:1.1}
.rd-brand__text strong{color:var(--dark);font-size:1.3rem;font-weight:800}
.rd-brand__text span{color:var(--grey);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em}
.custom-logo{max-height:60px;width:auto}
.rd-menu{margin-left:auto}
.rd-menu__list{display:flex;gap:.3rem;list-style:none;margin:0;padding:0}
.rd-menu__list a{color:var(--charcoal);font-weight:600;padding:.6rem .9rem;border-radius:8px;display:block}
.rd-menu__list a:hover{background:var(--light);color:var(--dark);text-decoration:none}
.rd-nav__cta{margin-left:.4rem}
.rd-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;margin-left:auto}
.rd-burger span{width:26px;height:3px;background:var(--dark);border-radius:2px;transition:.2s}

/* Hero */
.rd-hero{background:linear-gradient(120deg,var(--dark) 0%,#0d1c24 60%,var(--charcoal) 100%);color:#fff;position:relative;overflow:hidden}
.rd-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(244,57,57,.18),transparent 45%)}
.rd-hero__inner{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center;padding:4rem 20px}
.rd-hero h1{color:#fff}
.rd-hero__sub{color:#c9d2d7;font-size:1.15rem;max-width:36ch}
.rd-hero__actions{display:flex;gap:.8rem;flex-wrap:wrap;margin:1.4rem 0}
.rd-hero__usps{list-style:none;display:flex;gap:1.3rem;flex-wrap:wrap;padding:0;margin:.5rem 0 0;color:#dfe5e8;font-weight:600}
.rd-hero__usps li{display:inline-flex;align-items:center;gap:.4rem}
.rd-hero__usps svg{color:var(--red)}

.rd-quotecard{background:#fff;color:var(--charcoal);border-radius:var(--radius);padding:1.8rem;box-shadow:var(--shadow)}
.rd-quotecard h2{font-size:1.4rem;margin-bottom:.2rem}
.rd-quotecard p{color:var(--grey);margin-bottom:1rem}
.rd-quotecard__call a{font-weight:800}

/* Trust strip */
.rd-trust{background:var(--light);border-bottom:1px solid var(--line)}
.rd-trust__inner{display:flex;justify-content:space-around;flex-wrap:wrap;gap:1rem;padding:1.1rem 20px}
.rd-trust__item{display:inline-flex;align-items:center;gap:.6rem;font-weight:700;color:var(--dark)}
.rd-trust__item svg{color:var(--red)}

/* Sections */
.rd-section{padding:4rem 0}
.rd-section--alt{background:var(--light)}
.rd-section--dark{background:var(--dark);color:#fff}
.rd-section__head{text-align:center;max-width:680px;margin:0 auto 2.2rem}
.rd-section__head--light h2{color:#fff}
.rd-section__lead{color:var(--grey);font-size:1.1rem}
.rd-section--dark .rd-section__lead{color:#c9d2d7}
.rd-section__cta{text-align:center;margin-top:2rem}

/* Grids + cards */
.rd-grid{display:grid;gap:1.3rem}
.rd-grid--services{grid-template-columns:repeat(4,1fr)}
.rd-grid--gallery{grid-template-columns:repeat(4,1fr)}
.rd-grid--posts{grid-template-columns:repeat(3,1fr)}
.rd-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;transition:.2s}
.rd-card:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:transparent}
.rd-service h3{margin-bottom:.4rem}
.rd-service p{color:var(--grey);font-size:.95rem}
.rd-card__link{display:inline-flex;align-items:center;gap:.3rem;font-weight:700;margin-top:.3rem}

/* Why choose us */
.rd-why{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center}
.rd-why__media img{border-radius:var(--radius);box-shadow:var(--shadow)}
.rd-checklist{list-style:none;padding:0;margin:0 0 1.5rem}
.rd-checklist li{display:flex;align-items:center;gap:.6rem;padding:.4rem 0;font-weight:600}
.rd-checklist svg{color:var(--red);flex:none}

/* Gallery */
.rd-galitem{display:block;overflow:hidden;border-radius:12px;aspect-ratio:1/1}
.rd-galitem img{width:100%;height:100%;object-fit:cover;transition:.3s}
.rd-galitem:hover img{transform:scale(1.07)}
.rd-gallery-full{grid-template-columns:repeat(4,1fr)}

/* Areas */
.rd-arealist{list-style:none;display:grid;grid-template-columns:repeat(5,1fr);gap:.6rem;padding:0;margin:0}
.rd-arealist li{display:flex;align-items:center;gap:.4rem;color:#dfe5e8}
.rd-arealist svg{color:var(--red);flex:none}

/* CTA band */
.rd-cta-band{background:var(--red);color:#fff}
.rd-cta-band__inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;padding:2.6rem 20px}
.rd-cta-band h2{color:#fff;margin-bottom:.2rem}
.rd-cta-band p{margin:0;color:rgba(255,255,255,.9)}
.rd-cta-band__actions{display:flex;gap:.7rem;flex-wrap:wrap}
.rd-cta-band .rd-btn--call{background:#fff;color:var(--red);box-shadow:none}
.rd-cta-band .rd-btn--call:hover{background:var(--dark);color:#fff}

/* Page heroes */
.rd-pagehero{background:var(--light);border-bottom:1px solid var(--line);padding:2.6rem 0}
.rd-pagehero--lg{background:linear-gradient(120deg,var(--dark),var(--charcoal));color:#fff;padding:3.4rem 0}
.rd-pagehero--lg h1{color:#fff}
.rd-pagehero__sub{color:#c9d2d7;font-size:1.1rem;max-width:55ch;margin-bottom:1.3rem}
.rd-page{padding:3rem 20px}
.rd-prose{max-width:820px}

/* Services detail */
.rd-servicerow{border:1px solid var(--line);border-radius:var(--radius);padding:1.8rem;margin-bottom:1.1rem}
.rd-servicerow--alt{background:var(--light)}
.rd-servicerow h2{font-size:1.5rem}
.rd-servicerow p{color:var(--grey)}
.rd-servicerow .rd-btn{margin-top:.4rem}

/* Contact */
.rd-contact{display:grid;grid-template-columns:.9fr 1.1fr;gap:2.5rem}
.rd-contact__callcard{display:flex;align-items:center;gap:1rem;background:var(--red);color:#fff;border-radius:var(--radius);padding:1.3rem 1.5rem;margin-bottom:1.4rem}
.rd-contact__callcard:hover{background:var(--red-dark);text-decoration:none}
.rd-contact__callicon{display:inline-flex;background:rgba(255,255,255,.2);border-radius:50%;padding:.6rem}
.rd-contact__callcard small{display:block;opacity:.9;font-size:.8rem}
.rd-contact__callcard strong{font-size:1.5rem}
.rd-contact__list{list-style:none;padding:0;margin:0 0 1.5rem}
.rd-contact__list li{display:flex;align-items:center;gap:.6rem;padding:.45rem 0}
.rd-contact__list svg{color:var(--red);flex:none}
.rd-contact__areas{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:.3rem;padding:0;color:var(--grey)}
.rd-map{margin-top:1rem;line-height:0}

/* Service detail */
.rd-servicedetail{display:grid;grid-template-columns:1fr 340px;gap:2.5rem;align-items:start}
.rd-servicedetail__main h2{font-size:1.4rem;margin-top:1.4rem}
.rd-servicedetail__side .rd-quotecard{position:sticky;top:90px;margin-bottom:1.3rem}
.rd-otherservices{background:var(--light);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem}
.rd-otherservices h3{font-size:1.1rem;margin-bottom:.5rem}
.rd-otherservices ul{list-style:none;padding:0;margin:0}
.rd-otherservices li{padding:.28rem 0}
.rd-otherservices a{display:flex;align-items:center;gap:.4rem;color:var(--charcoal);font-weight:600}
.rd-otherservices a:hover{color:var(--red);text-decoration:none}
.rd-otherservices svg{color:var(--red);flex:none}

/* About */
.rd-aboutgrid{margin-top:2.5rem}
.rd-checklist--2col{display:grid;grid-template-columns:1fr 1fr;gap:.2rem 1.5rem}

/* Posts */
.rd-post__thumb img{border-radius:12px 12px 0 0}
.rd-post{padding:0;overflow:hidden}
.rd-post__body{padding:1.3rem}

/* Forms (CF7) */
.wpcf7 input[type=text],.wpcf7 input[type=email],.wpcf7 input[type=tel],.wpcf7 textarea,.wpcf7 select{
  width:100%;padding:.8rem .9rem;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:1rem;margin-bottom:.7rem;background:#fff}
.wpcf7 input:focus,.wpcf7 textarea:focus{outline:2px solid var(--red);border-color:var(--red)}
.wpcf7 input[type=submit]{background:var(--red);color:#fff;border:0;border-radius:999px;padding:.9rem 1.6rem;font-weight:700;font-size:1rem;cursor:pointer;width:100%}
.wpcf7 input[type=submit]:hover{background:var(--red-dark)}
.wpcf7 .wpcf7-spinner{margin:.5rem auto 0;display:block}

/* Sticky mobile call bar */
.rd-stickycall{display:none;position:fixed;left:0;right:0;bottom:0;z-index:300;background:var(--dark);padding:.55rem;gap:.5rem;box-shadow:0 -6px 20px rgba(0,0,0,.25)}
.rd-stickycall a{flex:1;text-align:center;font-weight:800;border-radius:10px;padding:.75rem;display:inline-flex;align-items:center;justify-content:center;gap:.4rem}
.rd-stickycall a:hover{text-decoration:none}
.rd-stickycall__call{background:var(--red);color:#fff}
.rd-stickycall__quote{background:#fff;color:var(--dark)}

/* Footer */
.rd-footer{background:var(--dark);color:#aeb8bd;padding:3rem 0 0}
.rd-footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem}
.rd-footer h3{color:#fff;font-size:1.3rem}
.rd-footer h4{color:#fff;font-size:1rem;margin-bottom:.8rem}
.rd-footer__muted{color:#8b969b;font-size:.92rem}
.rd-footer ul{list-style:none;padding:0;margin:0}
.rd-footer li{padding:.22rem 0}
.rd-footer a{color:#aeb8bd}
.rd-footer a:hover{color:#fff}
.rd-footer__phone{color:#fff;font-weight:800;font-size:1.15rem;display:inline-flex;align-items:center;gap:.4rem}
.rd-footer__phone svg{color:var(--red)}
.rd-footer__areas{columns:2;font-size:.9rem}
.rd-footer__bar{border-top:1px solid rgba(255,255,255,.1);margin-top:2.5rem;font-size:.85rem}
.rd-footer__bar-inner{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;padding:1.1rem 20px}
.rd-powered a{color:var(--red);font-weight:700}

/* Lightbox */
.rd-lightbox{display:none;position:fixed;inset:0;z-index:500;background:rgba(9,18,22,.92);align-items:center;justify-content:center}
.rd-lightbox.is-open{display:flex}
.rd-lightbox__img{max-width:90vw;max-height:85vh;border-radius:8px}
.rd-lightbox button{position:absolute;background:rgba(255,255,255,.12);color:#fff;border:0;font-size:2rem;width:54px;height:54px;border-radius:50%;cursor:pointer}
.rd-lightbox__close{top:20px;right:20px}
.rd-lightbox__prev{left:20px}
.rd-lightbox__next{right:20px}
.rd-lightbox button:hover{background:rgba(255,255,255,.25)}

.rd-pagination{margin-top:2rem;text-align:center}
.rd-pagination .page-numbers{padding:.5rem .8rem;border:1px solid var(--line);border-radius:8px;margin:0 .15rem}
.rd-pagination .current{background:var(--red);color:#fff;border-color:var(--red)}

/* Responsive */
@media(max-width:980px){
  .rd-hero__inner,.rd-why,.rd-contact{grid-template-columns:1fr}
  .rd-grid--services,.rd-grid--gallery,.rd-gallery-full{grid-template-columns:repeat(3,1fr)}
  .rd-grid--posts{grid-template-columns:repeat(2,1fr)}
  .rd-footer__grid{grid-template-columns:1fr 1fr}
  .rd-arealist{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:760px){
  .rd-menu{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);padding:.6rem;box-shadow:var(--shadow)}
  .rd-menu.is-open{display:block}
  .rd-menu__list{flex-direction:column}
  .rd-nav__inner{position:relative}
  .rd-nav__cta{display:none}
  .rd-burger{display:flex}
  .rd-topbar__hours{display:none}
  .rd-grid--services,.rd-grid--gallery,.rd-gallery-full,.rd-grid--posts{grid-template-columns:repeat(2,1fr)}
  .rd-arealist{grid-template-columns:repeat(2,1fr)}
  .rd-footer__grid{grid-template-columns:1fr}
  .rd-cta-band__inner{flex-direction:column;text-align:center}
  .rd-stickycall{display:flex}
  body{padding-bottom:64px}
}
@media(max-width:420px){
  .rd-grid--services,.rd-grid--gallery,.rd-gallery-full{grid-template-columns:1fr 1fr}
}
@media(max-width:880px){
  .rd-servicedetail{grid-template-columns:1fr}
  .rd-servicedetail__side .rd-quotecard{position:static}
  .rd-checklist--2col{grid-template-columns:1fr}
}
