:root{
  --bg:#0B0F14;
  --surface:#14191F;
  --surface-2:#1F262E;
  --border:#2A323D;
  --text:#F1F5F9;
  --text-dim:#94A3B8;
  --blue:#2563EB;
  --blue-dark:#1E40AF;
  --red:#DC2626;
  --red-dark:#B91C1C;
  --gold:#F59E0B;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:200px}
@media (max-width:760px){html{scroll-padding-top:120px}}
section[id],[id]:target{scroll-margin-top:200px}
@media (max-width:760px){section[id],[id]:target{scroll-margin-top:120px}}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:'Oswald',sans-serif;font-weight:700;letter-spacing:0.5px;line-height:1.1}
h1{font-size:clamp(2.2rem,6vw,4.2rem);text-transform:uppercase}
h2{font-size:clamp(1.8rem,4.5vw,2.8rem);text-transform:uppercase}
h3{font-size:1.3rem;text-transform:uppercase}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:100%;max-width:1180px;margin:0 auto;padding:0 20px}

/* Header & Nav */
header{
  position:sticky;top:0;z-index:50;
  background:rgba(11,15,20,0.95);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--border);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:12px;flex-wrap:wrap}
.logo{
  font-family:'Oswald',sans-serif;
  display:inline-flex;align-items:center;
  line-height:0;text-decoration:none;
}
.logo img{
  display:block;
  height:95px;width:auto;
  background:transparent;
}
.logo-tagline{display:none}
.top-strip{
  background:var(--surface);
  border-bottom:1px solid var(--border);
  padding:8px 0;
  text-align:center;
  font-family:'Oswald',sans-serif;
  font-size:0.85rem;
  letter-spacing:2px;
  font-weight:700;
}
.top-strip .tag-line-1{color:#fff}
.top-strip .tag-line-2{color:var(--red);margin-left:12px}
@media (max-width:760px){
  .logo img{height:62px}
  .top-strip{font-size:0.7rem;letter-spacing:1.2px;padding:6px 8px}
  .top-strip .tag-line-2{margin-left:6px;display:block;margin-top:2px}
}
.nav-links{display:none}
.nav-center{display:flex;flex-direction:column;align-items:center;gap:6px}
.nav-actions{display:flex;align-items:center;gap:10px}
.nav-phone{font-family:'Oswald',sans-serif;font-size:1.1rem;color:var(--red);font-weight:700;letter-spacing:1px}
.nav-phone:hover{color:#fff}
.logo-right{display:none}
@media (min-width:720px){
  .logo-right{display:inline-flex}
}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:'Oswald',sans-serif;font-weight:700;font-size:0.95rem;
  letter-spacing:1.5px;text-transform:uppercase;
  padding:14px 22px;border:none;cursor:pointer;
  transition:transform 0.15s,box-shadow 0.15s,background 0.15s;
  border-radius:2px;
}
.btn-red{background:var(--red);color:#fff;box-shadow:0 4px 0 var(--red-dark)}
.btn-red:hover{background:#EF4444;transform:translateY(-1px)}
.btn-blue{background:var(--blue);color:#fff;box-shadow:0 4px 0 var(--blue-dark)}
.btn-blue:hover{background:#3B82F6;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:#fff;border:2px solid var(--border)}
.btn-ghost:hover{border-color:var(--blue)}
.btn-lg{padding:18px 28px;font-size:1.05rem}

/* Hero */
.hero{
  position:relative;
  padding:60px 0 70px;
  overflow:hidden;
  background:
    linear-gradient(180deg,rgba(11,15,20,0.7) 0%,rgba(11,15,20,0.95) 100%),
    repeating-linear-gradient(45deg,#1a2230 0,#1a2230 2px,#0B0F14 2px,#0B0F14 30px);
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 30% 20%,rgba(37,99,235,0.18) 0%,transparent 60%);
  pointer-events:none;
}
.hero-inner{position:relative;display:grid;grid-template-columns:1fr;gap:30px;align-items:center}
.eyebrow{
  display:inline-block;
  font-family:'Oswald',sans-serif;font-size:0.85rem;
  letter-spacing:3px;text-transform:uppercase;
  color:var(--blue);font-weight:600;
  margin-bottom:14px;
}
.eyebrow::before{content:"▸ ";color:var(--red)}
.hero h1{margin-bottom:18px}
.hero h1 .accent{color:var(--blue)}
.hero-sub{font-size:1.15rem;color:var(--text-dim);max-width:560px;margin-bottom:28px}
.symptom-box{
  background:var(--surface);
  border:1px solid var(--border);
  border-left:4px solid var(--blue);
  border-radius:6px;
  padding:22px 24px;
  margin:22px 0 28px;
  max-width:600px;
}
.symptom-title{
  font-family:'Oswald',sans-serif;
  font-size:1.15rem;font-weight:700;
  text-transform:uppercase;letter-spacing:1px;
  color:#fff;margin-bottom:16px;
}
.symptom-list{
  list-style:none;display:grid;gap:11px;
}
.symptom-list li{
  position:relative;padding-left:30px;
  font-size:1.02rem;color:var(--text);line-height:1.35;
}
.symptom-list li::before{
  content:"✓";position:absolute;left:0;top:-1px;
  color:var(--blue);font-weight:700;font-size:1.15rem;
}
.symptom-closer{
  margin:18px 0 0;
  font-family:'Oswald',sans-serif;
  font-size:1.4rem;font-weight:600;
  color:#fff;line-height:1.25;
}
.symptom-closer strong{color:var(--gold);font-weight:700}
@media (min-width:560px){
  .symptom-list{grid-template-columns:1fr 1fr;gap:11px 22px}
}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:30px}
.hero-photo{
  position:relative;
  aspect-ratio:4/3;
  background:linear-gradient(135deg,#0B0F14 0%,#1F2937 100%);
  border:1px solid var(--border);
  border-radius:4px;
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.photo-label{
  position:absolute;top:14px;left:14px;
  background:rgba(0,0,0,0.7);color:#fff;
  font-family:'Oswald',sans-serif;font-size:0.75rem;letter-spacing:2px;
  padding:6px 12px;border-radius:2px;
}
.photo-placeholder{color:var(--text-dim);font-size:0.9rem;text-align:center;padding:30px;line-height:1.5}
.photo-placeholder strong{color:#fff;display:block;margin-bottom:6px;font-family:'Oswald',sans-serif;letter-spacing:1px}
.photo-number{
  position:absolute;top:14px;right:14px;
  background:var(--red);color:#fff;
  font-family:'Oswald',sans-serif;font-size:1.6rem;font-weight:700;
  width:54px;height:54px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  border:3px solid #fff;
  z-index:5;
  box-shadow:0 4px 12px rgba(0,0,0,0.5);
}
.ba-single{
  position:relative;
  aspect-ratio:16/10;
  background:linear-gradient(135deg,#1a2840 0%,#0a1828 100%);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-dim);font-size:0.9rem;
  text-align:center;padding:30px;
}
.ba-single .ba-tag{position:absolute;top:10px;left:10px}
.ba-single .ba-tag.after{left:auto;right:80px}

/* Hero compact (service pages) */
.hero-compact{padding:50px 0 60px}
.hero-compact .hero-inner{grid-template-columns:1fr}
.hero-compact h1{font-size:clamp(2rem,5vw,3.4rem)}

/* Trust strip */
.trust-strip{
  background:var(--surface);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:18px 0;
}
.trust-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:16px 30px;text-align:center}
.trust-item{display:flex;align-items:center;gap:8px;font-family:'Oswald',sans-serif;font-size:0.85rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim)}
.trust-item .icon{color:var(--gold);font-size:1.1rem}

/* Sections */
section{padding:70px 0}
.section-eyebrow{
  text-align:center;
  font-family:'Oswald',sans-serif;font-size:0.85rem;letter-spacing:3px;
  text-transform:uppercase;color:var(--red);font-weight:600;margin-bottom:12px;
}
.section-title{text-align:center;margin-bottom:14px}
.section-lede{text-align:center;color:var(--text-dim);max-width:680px;margin:0 auto 50px;font-size:1.05rem}

/* Content prose (for service pages) */
.prose{max-width:760px;margin:0 auto}
.prose p{margin-bottom:18px;font-size:1.05rem;color:var(--text)}
.prose p.dim{color:var(--text-dim)}
.prose ul{margin:0 0 24px 24px;color:var(--text)}
.prose li{margin-bottom:8px;font-size:1.02rem}
.prose h2{text-align:left;margin:40px 0 16px}
.prose h3{margin:30px 0 12px;color:var(--blue)}

/* Why us */
.why-grid{display:grid;grid-template-columns:1fr;gap:18px}
.why-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-left:4px solid var(--blue);
  padding:24px;border-radius:2px;
}
.why-card:nth-child(even){border-left-color:var(--red)}
.why-card h3{margin-bottom:8px;font-size:1.1rem;color:#fff}
.why-card p{color:var(--text-dim);font-size:0.95rem}

/* Services grid */
.services{background:var(--surface)}
.services-grid{display:grid;grid-template-columns:1fr;gap:16px}
.service-card{
  background:var(--surface-2);
  border:1px solid var(--border);
  padding:26px;
  border-radius:3px;
  transition:transform 0.15s,border-color 0.15s;
  position:relative;
  overflow:hidden;
  display:block;
  color:inherit;
}
.service-card::before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--blue)}
.service-card:hover{transform:translateY(-2px);border-color:var(--blue)}
.service-num{font-family:'Oswald',sans-serif;color:var(--red);font-size:0.8rem;letter-spacing:2px;margin-bottom:8px}
.service-card h3{margin-bottom:10px;color:#fff}
.service-card p{color:var(--text-dim);font-size:0.95rem;margin-bottom:14px}
.service-link{font-family:'Oswald',sans-serif;font-size:0.85rem;letter-spacing:1.5px;color:var(--blue);text-transform:uppercase}
.service-link::after{content:" →"}

/* Before/after */
.gallery-grid{display:grid;grid-template-columns:1fr;gap:24px}
.ba-card{background:var(--surface);border:1px solid var(--border);border-radius:3px;overflow:hidden}
.ba-photos{display:grid;grid-template-columns:1fr 1fr;position:relative}
.ba-photo{
  aspect-ratio:1;
  display:flex;align-items:center;justify-content:center;
  position:relative;
  color:var(--text-dim);font-size:0.85rem;
  padding:20px;text-align:center;
}
.ba-before{background:linear-gradient(135deg,#3a2820 0%,#1a1010 100%)}
.ba-after{background:linear-gradient(135deg,#1a2840 0%,#0a1828 100%)}
.ba-tag{
  position:absolute;top:10px;left:10px;
  font-family:'Oswald',sans-serif;font-size:0.7rem;letter-spacing:2px;
  background:rgba(0,0,0,0.85);padding:4px 10px;border-radius:2px;
}
.ba-tag.after{background:var(--blue);left:auto;right:10px}
.ba-caption{padding:18px 22px}
.ba-caption h4{font-family:'Oswald',sans-serif;font-size:1.1rem;text-transform:uppercase;margin-bottom:4px}
.ba-caption p{color:var(--text-dim);font-size:0.9rem}

/* Reviews */
.reviews{background:var(--surface)}
.rating-row{display:flex;justify-content:center;align-items:center;gap:14px;margin-bottom:40px;flex-wrap:wrap}
.stars{color:var(--gold);font-size:1.5rem;letter-spacing:2px}
.rating-text{font-family:'Oswald',sans-serif;font-size:1.1rem;letter-spacing:1px}
.reviews-grid{display:grid;grid-template-columns:1fr;gap:20px}
.review-card{
  background:var(--bg);
  border:1px solid var(--border);
  padding:26px;border-radius:3px;
  position:relative;
}
.review-stars{color:var(--gold);margin-bottom:12px;font-size:1.1rem;letter-spacing:2px}
.review-text{color:var(--text);font-size:1rem;font-style:italic;margin-bottom:18px;line-height:1.6}
.review-meta{display:flex;justify-content:space-between;align-items:center;font-size:0.85rem}
.review-name{font-family:'Oswald',sans-serif;letter-spacing:1px;color:#fff}
.review-source{color:var(--text-dim);font-family:'Oswald',sans-serif;font-size:0.75rem;letter-spacing:1.5px;text-transform:uppercase}

/* Owner block */
.owner-block{
  background:linear-gradient(135deg,var(--surface) 0%,var(--surface-2) 100%);
  border:1px solid var(--border);
  border-radius:4px;
  padding:36px;
  display:grid;grid-template-columns:1fr;gap:24px;align-items:center;
}
.owner-photo{
  aspect-ratio:1;
  background:linear-gradient(135deg,#1a2530 0%,#0a1018 100%);
  border:1px solid var(--border);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--text-dim);font-size:0.9rem;
  max-width:280px;justify-self:center;
  padding:20px;text-align:center;
}
.owner-block h2{text-align:left;margin-bottom:14px}
.owner-block p{color:var(--text-dim);margin-bottom:16px;font-size:1.02rem}
.owner-signature{font-family:'Oswald',sans-serif;color:var(--blue);font-weight:600;letter-spacing:1px}

/* Service area */
.area{background:var(--surface)}
.towns{
  display:flex;flex-wrap:wrap;justify-content:center;gap:10px 14px;
  max-width:780px;margin:30px auto 0;
}
.town{
  background:var(--surface-2);border:1px solid var(--border);
  padding:8px 16px;border-radius:20px;
  font-family:'Oswald',sans-serif;font-size:0.85rem;letter-spacing:1px;
}

/* Final CTA */
.final-cta{
  background:
    linear-gradient(135deg,rgba(220,38,38,0.15) 0%,rgba(37,99,235,0.15) 100%),
    var(--bg);
  border-top:3px solid var(--red);
  border-bottom:3px solid var(--blue);
  padding:60px 0;
  text-align:center;
}
.final-cta h2{margin-bottom:18px}
.final-cta p{color:var(--text-dim);font-size:1.1rem;margin-bottom:30px;max-width:560px;margin-left:auto;margin-right:auto}
.big-phone{
  font-family:'Oswald',sans-serif;font-size:clamp(2rem,8vw,3.5rem);font-weight:700;
  color:var(--red);letter-spacing:3px;margin-bottom:20px;display:block;
}
.big-phone:hover{color:#fff}

/* Form */
.form-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:4px;
  padding:32px;
  max-width:560px;margin:30px auto 0;
  text-align:left;
}
.form-card h3{margin-bottom:18px;color:#fff}
.form-row{margin-bottom:14px}
label{display:block;font-family:'Oswald',sans-serif;font-size:0.8rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim);margin-bottom:6px}
input,select,textarea{
  width:100%;background:var(--bg);border:1px solid var(--border);
  color:var(--text);padding:12px 14px;border-radius:2px;
  font-family:inherit;font-size:1rem;
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue)}
textarea{min-height:90px;resize:vertical}

/* FAQ */
.faq{max-width:760px;margin:0 auto}
.faq-item{
  background:var(--surface);
  border:1px solid var(--border);
  border-left:3px solid var(--blue);
  padding:22px 24px;border-radius:3px;
  margin-bottom:12px;
}
.faq-item h4{
  font-family:'Oswald',sans-serif;font-size:1.05rem;
  margin-bottom:8px;text-transform:none;letter-spacing:0.3px;
  color:#fff;
}
.faq-item p{color:var(--text-dim);font-size:0.98rem;margin:0}

/* Footer */
footer{
  background:#06090C;
  border-top:1px solid var(--border);
  padding:40px 0 20px;
  color:var(--text-dim);
  font-size:0.9rem;
}
.footer-grid{display:grid;grid-template-columns:1fr;gap:24px;margin-bottom:24px}
.footer-col h4{font-family:'Oswald',sans-serif;font-size:0.9rem;letter-spacing:2px;color:#fff;margin-bottom:12px;text-transform:uppercase}
.footer-col a{display:block;color:var(--text-dim);padding:4px 0}
.footer-col a:hover{color:var(--blue)}
.footer-bottom{border-top:1px solid var(--border);padding-top:18px;text-align:center;font-size:0.8rem}

/* Tablet+ */
@media (min-width:720px){
  .nav-links{display:flex;gap:24px;font-family:'Oswald',sans-serif;font-size:0.95rem;letter-spacing:1.5px;text-transform:uppercase}
  .nav-links a:hover{color:var(--blue)}
  .nav-phone{font-size:1.4rem}
  .hero{padding:90px 0 100px}
  .hero-inner{grid-template-columns:0.6fr 1.4fr;gap:30px}
  .hero-compact{padding:70px 0 80px}
  section{padding:90px 0}
  .why-grid{grid-template-columns:1fr 1fr}
  .services-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .reviews-grid{grid-template-columns:1fr 1fr 1fr}
  .owner-block{grid-template-columns:240px 1fr;padding:48px}
  .footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}
}
@media (min-width:1024px){
  .services-grid{grid-template-columns:1fr 1fr 1fr}
}

/* FAQ accordion */
.faq-list{display:flex;flex-direction:column;gap:12px;max-width:880px;margin:30px auto 0}
.faq-item{
  background:var(--surface);
  border:1px solid var(--border);
  border-left:4px solid var(--blue);
  border-radius:6px;
  overflow:hidden;
}
.faq-item summary{
  cursor:pointer;
  padding:20px 24px;
  font-family:'Oswald',sans-serif;
  font-size:1.05rem;
  font-weight:600;
  letter-spacing:0.5px;
  color:#fff;
  list-style:none;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  transition:color 0.15s;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";
  color:var(--blue);
  font-size:1.6rem;
  font-weight:700;
  line-height:1;
  flex-shrink:0;
}
.faq-item[open] summary::after{content:"\2212"}
.faq-item[open] summary{color:var(--blue)}
.faq-item summary:hover{color:var(--blue)}
.faq-answer{padding:0 24px 22px 24px;color:var(--text);font-size:1.02rem;line-height:1.55}
.faq-answer p{margin:0}
