/* =========================================================
   Crowborough Surveyors – Main Stylesheet
   crowboroughsurveyors.com
   ========================================================= */

/* ── CSS Custom Properties ─────────────────────────────── */
:root {
  --primary:       #1a3a5c;
  --primary-dark:  #0f2540;
  --primary-light: #2e5f8a;
  --accent:        #c8963e;
  --accent-dark:   #a07830;
  --accent-light:  #e0b060;
  --neutral-50:    #f9fafb;
  --neutral-100:   #f3f4f6;
  --neutral-200:   #e5e7eb;
  --neutral-300:   #d1d5db;
  --neutral-600:   #4b5563;
  --neutral-700:   #374151;
  --neutral-800:   #1f2937;
  --neutral-900:   #111827;
  --white:         #ffffff;
  --font-sans:     'Inter', sans-serif;
  --font-heading:  'Playfair Display', serif;
  --radius-sm:     4px;
  --radius-md:     8px;
  --radius-lg:     16px;
  --radius-xl:     24px;
  --shadow-sm:     0 1px 3px rgba(0,0,0,.12), 0 1px 2px rgba(0,0,0,.08);
  --shadow-md:     0 4px 6px rgba(0,0,0,.1),  0 2px 4px rgba(0,0,0,.06);
  --shadow-lg:     0 10px 25px rgba(0,0,0,.15),0 4px 10px rgba(0,0,0,.08);
  --shadow-xl:     0 20px 50px rgba(0,0,0,.18),0 8px 20px rgba(0,0,0,.1);
  --transition:    all .3s cubic-bezier(.4,0,.2,1);
}

/* ── Reset & Base ───────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--font-sans);
  color:var(--neutral-800);
  background:var(--white);
  line-height:1.7;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:var(--transition)}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* ── Typography ─────────────────────────────────────────── */
h1,h2,h3,h4,h5{
  font-family:var(--font-heading);
  line-height:1.25;
  color:var(--primary);
}
h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:700}
h2{font-size:clamp(1.6rem,3.5vw,2.5rem);font-weight:700}
h3{font-size:clamp(1.2rem,2.5vw,1.75rem);font-weight:600}
h4{font-size:clamp(1rem,2vw,1.25rem);font-weight:600}
p{margin-bottom:1em;font-size:1rem;color:var(--neutral-700)}
p:last-child{margin-bottom:0}

/* ── Layout Utilities ───────────────────────────────────── */
.container{
  width:100%;
  max-width:1200px;
  margin:0 auto;
  padding:0 1.5rem;
}
.section{padding:5rem 0}
.section-sm{padding:3rem 0}
.section-title{
  text-align:center;
  margin-bottom:3rem;
}
.section-title h2{margin-bottom:.75rem}
.section-title p{
  max-width:640px;
  margin:0 auto;
  color:var(--neutral-600);
  font-size:1.05rem;
}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}

/* ── Gallery Grid ─────────────────────────────────── */
.gallery-grid{align-items:stretch}
.gallery-figure{
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-md);
  background:var(--white);
  display:flex;
  flex-direction:column;
  margin:0;
}
.gallery-img-wrap{
  width:100%;
  height:260px;          /* fixed equal height for all images */
  overflow:hidden;
  flex-shrink:0;
}
.gallery-img-wrap img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
  transition:transform .4s ease;
}
.gallery-figure:hover .gallery-img-wrap img{
  transform:scale(1.05);
}
.gallery-figure figcaption{
  padding:.75rem 1rem;
  background:var(--neutral-50);
  font-size:.85rem;
  color:var(--neutral-600);
  text-align:center;
  border-top:1px solid var(--neutral-200);
  flex-grow:1;
  display:flex;
  align-items:center;
  justify-content:center;
}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.flex{display:flex}
.flex-center{display:flex;align-items:center;justify-content:center}
.flex-between{display:flex;align-items:center;justify-content:space-between}
.text-center{text-align:center}
.text-white{color:var(--white) !important}
.bg-primary{background:var(--primary)}
.bg-light{background:var(--neutral-50)}
.bg-dark{background:var(--neutral-900)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ── Buttons ────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.75rem 1.75rem;
  border-radius:var(--radius-md);
  font-size:.95rem;
  font-weight:600;
  letter-spacing:.02em;
  transition:var(--transition);
  text-decoration:none;
}
.btn-primary{
  background:var(--accent);
  color:var(--white);
  box-shadow:0 4px 15px rgba(200,150,62,.35);
}
.btn-primary:hover{background:var(--accent-dark);transform:translateY(-2px);box-shadow:0 6px 20px rgba(200,150,62,.45)}
.btn-secondary{
  background:transparent;
  color:var(--white);
  border:2px solid rgba(255,255,255,.7);
}
.btn-secondary:hover{background:rgba(255,255,255,.1);border-color:var(--white)}
.btn-outline{
  background:transparent;
  color:var(--primary);
  border:2px solid var(--primary);
}
.btn-outline:hover{background:var(--primary);color:var(--white)}
.btn-lg{padding:1rem 2.25rem;font-size:1.05rem}
.btn-sm{padding:.5rem 1.25rem;font-size:.875rem}

/* ── Header / Navigation ────────────────────────────────── */
#site-header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:1000;
  background:rgba(26,58,92,.97);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  transition:var(--transition);
  box-shadow:0 2px 20px rgba(0,0,0,.2);
}
#site-header.scrolled{
  background:rgba(15,37,64,.98);
  box-shadow:0 4px 30px rgba(0,0,0,.3);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:74px;
  padding:0 1.5rem;
  max-width:1200px;
  margin:0 auto;
}
.site-logo{
  display:flex;
  align-items:center;
  gap:.75rem;
  text-decoration:none;
}
.logo-icon{
  width:44px;height:44px;
  background:var(--accent);
  border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:1.25rem;
  color:var(--white);
  flex-shrink:0;
}
.logo-text{
  display:flex;
  flex-direction:column;
}
.logo-name{
  font-family:var(--font-heading);
  font-size:1.1rem;
  font-weight:700;
  color:var(--white);
  line-height:1.1;
}
.logo-tagline{
  font-size:.65rem;
  color:var(--accent-light);
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:500;
}

/* Main Nav */
#main-nav{
  display:flex;
  align-items:center;
  gap:.25rem;
}
#main-nav a{
  color:rgba(255,255,255,.88);
  font-size:.9rem;
  font-weight:500;
  padding:.5rem .9rem;
  border-radius:var(--radius-sm);
  transition:var(--transition);
  white-space:nowrap;
}
#main-nav a:hover,#main-nav a.active{
  color:var(--accent-light);
  background:rgba(255,255,255,.08);
}
.nav-cta{
  background:var(--accent) !important;
  color:var(--white) !important;
  padding:.5rem 1.1rem !important;
}
.nav-cta:hover{background:var(--accent-dark) !important}

/* Mobile Nav Toggle */
.nav-toggle{
  display:none;
  flex-direction:column;
  gap:5px;
  padding:.5rem;
  background:none;
  border:none;
  cursor:pointer;
}
.nav-toggle span{
  display:block;
  width:24px;height:2px;
  background:var(--white);
  border-radius:2px;
  transition:var(--transition);
}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Accreditation bar */
.accred-bar{
  background:var(--primary-dark);
  border-top:1px solid rgba(255,255,255,.1);
  padding:.45rem 1.5rem;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:1.5rem;
  font-size:.78rem;
  color:rgba(255,255,255,.7);
  letter-spacing:.04em;
}
.accred-bar span{
  display:flex;align-items:center;gap:.4rem;
}
.accred-badge{
  background:var(--accent);
  color:var(--white);
  padding:.15rem .45rem;
  border-radius:3px;
  font-weight:700;
  font-size:.72rem;
  letter-spacing:.05em;
}

/* ── Hero Section ───────────────────────────────────────── */
#hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:flex-start;
  overflow:hidden;
  padding-top:115px;
}
.hero-video-bg{
  position:absolute;
  inset:0;
  z-index:0;
}
.hero-video-bg video{
  width:100%;height:100%;
  object-fit:cover;
  opacity:.35;
}
.hero-bg-image{
  position:absolute;
  inset:0;
  background-image:url('../images/hero-surveyor.jpg');
  background-size:cover;
  background-position:center;
  z-index:0;
}
.hero-bg-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(
    135deg,
    rgba(15,37,64,.92) 0%,
    rgba(26,58,92,.82) 50%,
    rgba(15,37,64,.75) 100%
  );
  z-index:1;
}
/* Animated particles */
.hero-particles{
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
  overflow:hidden;
}
.particle{
  position:absolute;
  border-radius:50%;
  background:rgba(200,150,62,.3);
  animation:floatParticle linear infinite;
}
@keyframes floatParticle{
  0%{transform:translateY(100vh) scale(0);opacity:0}
  10%{opacity:.6}
  90%{opacity:.3}
  100%{transform:translateY(-100px) scale(1);opacity:0}
}

.hero-content{
  position:relative;
  z-index:3;
  width:100%;
  padding:0.5rem 0 3rem;
}
.hero-inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3rem;
  align-items:flex-start;
  max-width:1200px;
  margin:0 auto;
  padding:0.5rem 1.5rem 3rem;
}
.hero-text .badge{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  background:rgba(200,150,62,.2);
  border:1px solid rgba(200,150,62,.4);
  color:var(--accent-light);
  padding:.4rem 1rem;
  border-radius:50px;
  font-size:.8rem;
  font-weight:600;
  letter-spacing:.05em;
  text-transform:uppercase;
  margin-bottom:1.25rem;
}
.hero-text h1{
  color:var(--white);
  margin-bottom:1.25rem;
  text-shadow:0 2px 10px rgba(0,0,0,.3);
}
.hero-text h1 em{
  font-style:normal;
  color:var(--accent-light);
}
.hero-text p{
  color:rgba(255,255,255,.85);
  font-size:1.1rem;
  margin-bottom:2rem;
  max-width:520px;
}
.hero-btns{
  display:flex;
  gap:1rem;
  flex-wrap:wrap;
  margin-bottom:2.5rem;
}
.hero-stats{
  display:flex;
  gap:2rem;
  flex-wrap:wrap;
}
.hero-stat{
  text-align:center;
}
.hero-stat .num{
  font-family:var(--font-heading);
  font-size:2rem;
  font-weight:700;
  color:var(--accent-light);
  line-height:1;
  display:block;
}
.hero-stat .lbl{
  font-size:.75rem;
  color:rgba(255,255,255,.65);
  letter-spacing:.06em;
  text-transform:uppercase;
  margin-top:.25rem;
  display:block;
}
.hero-stat-divider{
  width:1px;
  height:40px;
  background:rgba(255,255,255,.15);
  align-self:center;
}

/* Push hero text down to match form top edge */
.hero-text{
  padding-top:0;
}

/* Hero Form */
.hero-form-wrap{
  margin-top:0;
  background:rgba(255,255,255,.97);
  border-radius:var(--radius-lg);
  padding:1.75rem 2rem;
  box-shadow:var(--shadow-xl);
  position:relative;
  overflow:hidden;
  align-self:flex-start;
}
.hero-form-wrap::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:4px;
  background:linear-gradient(90deg,var(--accent),var(--primary-light));
}
.hero-form-wrap h3{
  font-size:1.3rem;
  margin-bottom:.4rem;
  color:var(--primary);
}
.hero-form-wrap p{
  font-size:.9rem;
  color:var(--neutral-600);
  margin-bottom:1.25rem;
}
.trust-badges{
  display:flex;
  gap:.75rem;
  margin-top:1.25rem;
  flex-wrap:wrap;
}
.trust-badge{
  display:flex;
  align-items:center;
  gap:.35rem;
  font-size:.75rem;
  color:var(--neutral-600);
  font-weight:500;
}
.trust-badge svg{color:var(--accent)}

/* ── Services Overview Cards ────────────────────────────── */
.service-card{
  background:var(--white);
  border-radius:var(--radius-lg);
  padding:2rem 1.75rem;
  box-shadow:var(--shadow-md);
  transition:var(--transition);
  border:1px solid var(--neutral-200);
  position:relative;
  overflow:hidden;
}
.service-card::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:3px;
  background:linear-gradient(90deg,var(--accent),var(--primary-light));
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .4s ease;
}
.service-card:hover::before{transform:scaleX(1)}
.service-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-xl);
}
.service-icon{
  width:56px;height:56px;
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  border-radius:var(--radius-md);
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;
  color:var(--white);
  margin-bottom:1.25rem;
}
.service-card h3{
  font-size:1.15rem;
  margin-bottom:.6rem;
  color:var(--primary);
}
.service-card p{
  font-size:.9rem;
  color:var(--neutral-600);
  margin-bottom:1rem;
}
.service-link{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  font-size:.875rem;
  font-weight:600;
  color:var(--accent);
  transition:var(--transition);
}
.service-link:hover{gap:.7rem;color:var(--accent-dark)}

/* ── Why Choose Us ──────────────────────────────────────── */
.why-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1.5rem;
}
.why-item{
  display:flex;
  gap:1rem;
  padding:1.5rem;
  background:var(--white);
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-sm);
  transition:var(--transition);
  border:1px solid var(--neutral-200);
}
.why-item:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.why-icon{
  width:44px;height:44px;
  min-width:44px;
  background:linear-gradient(135deg,rgba(200,150,62,.15),rgba(200,150,62,.05));
  border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:1.25rem;
  color:var(--accent);
}
.why-item h4{font-size:1rem;margin-bottom:.35rem;color:var(--primary)}
.why-item p{font-size:.875rem;color:var(--neutral-600);margin:0}

/* ── Reviews / Testimonials ─────────────────────────────── */
.reviews-section{background:var(--neutral-50)}
.reviews-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
}
.review-card{
  background:var(--white);
  border-radius:var(--radius-lg);
  padding:1.75rem;
  box-shadow:var(--shadow-sm);
  border:1px solid var(--neutral-200);
  transition:var(--transition);
  position:relative;
}
.review-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.review-stars{
  display:flex;gap:.2rem;
  margin-bottom:.9rem;
}
.review-stars span{color:#f59e0b;font-size:1rem}
.review-text{
  font-size:.925rem;
  color:var(--neutral-700);
  line-height:1.65;
  margin-bottom:1.1rem;
  font-style:italic;
}
.review-author{
  display:flex;
  align-items:center;
  gap:.75rem;
}
.review-avatar{
  width:42px;height:42px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;
  color:var(--white);
  font-weight:700;
  font-family:var(--font-heading);
  flex-shrink:0;
}
.review-name{font-weight:600;font-size:.9rem;color:var(--primary)}
.review-location{font-size:.78rem;color:var(--neutral-600)}
.review-badge{
  position:absolute;
  top:1.25rem;right:1.25rem;
  background:var(--neutral-100);
  border-radius:50px;
  padding:.25rem .6rem;
  font-size:.7rem;
  color:var(--neutral-600);
  font-weight:600;
}
.review-source-icon{font-size:.85rem}

/* ── Process Steps ──────────────────────────────────────── */
.process-steps{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1.5rem;
  position:relative;
}
.process-steps::before{
  content:'';
  position:absolute;
  top:32px;left:10%;right:10%;
  height:2px;
  background:linear-gradient(90deg,var(--accent),var(--primary-light),var(--accent));
  z-index:0;
}
.step-item{
  text-align:center;
  position:relative;
  z-index:1;
}
.step-num{
  width:64px;height:64px;
  border-radius:50%;
  background:var(--primary);
  color:var(--white);
  font-family:var(--font-heading);
  font-size:1.4rem;
  font-weight:700;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1rem;
  border:4px solid var(--white);
  box-shadow:0 0 0 2px var(--primary),var(--shadow-md);
  transition:var(--transition);
}
.step-item:hover .step-num{
  background:var(--accent);
  box-shadow:0 0 0 2px var(--accent),var(--shadow-md);
  transform:scale(1.05);
}
.step-item h4{font-size:1rem;margin-bottom:.4rem}
.step-item p{font-size:.85rem;color:var(--neutral-600);margin:0}

/* ── CTA Banner ─────────────────────────────────────────── */
.cta-banner{
  background:linear-gradient(135deg,var(--primary-dark),var(--primary));
  color:var(--white);
  text-align:center;
  padding:5rem 1.5rem;
  position:relative;
  overflow:hidden;
}
.cta-banner::before{
  content:'';
  position:absolute;
  top:-50%;left:-50%;
  width:200%;height:200%;
  background:radial-gradient(ellipse at center,rgba(200,150,62,.12) 0%,transparent 70%);
  animation:rotateBg 20s linear infinite;
}
@keyframes rotateBg{to{transform:rotate(360deg)}}
.cta-banner h2,.cta-banner p{position:relative;z-index:1}
.cta-banner h2{color:var(--white);margin-bottom:1rem}
.cta-banner p{color:rgba(255,255,255,.8);max-width:600px;margin:0 auto 2rem}
.cta-btns{
  display:flex;
  gap:1rem;
  justify-content:center;
  flex-wrap:wrap;
  position:relative;z-index:1;
}

/* ── Stats Bar ──────────────────────────────────────────── */
.stats-bar{
  background:linear-gradient(90deg,var(--primary-dark),var(--primary));
  padding:3rem 1.5rem;
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:2rem;
  text-align:center;
}
.stat-item .num{
  font-family:var(--font-heading);
  font-size:2.75rem;
  font-weight:700;
  color:var(--accent-light);
  line-height:1;
  display:block;
}
.stat-item .lbl{
  color:rgba(255,255,255,.7);
  font-size:.85rem;
  margin-top:.4rem;
  display:block;
  letter-spacing:.04em;
}

/* ── Team Cards ─────────────────────────────────────────── */
.team-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2rem;
}
.team-card{
  background:var(--white);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-md);
  transition:var(--transition);
  border:1px solid var(--neutral-200);
}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-xl)}
.team-photo{
  width:100%;
  height:280px;
  object-fit:cover;
  object-position:top center;
}
.team-info{
  padding:1.5rem;
}
.team-name{
  font-size:1.15rem;
  margin-bottom:.2rem;
  color:var(--primary);
}
.team-role{
  font-size:.85rem;
  color:var(--accent);
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
  margin-bottom:.75rem;
}
.team-bio{
  font-size:.875rem;
  color:var(--neutral-600);
  line-height:1.6;
}

/* ── FAQ Accordion ──────────────────────────────────────── */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{
  border:1px solid var(--neutral-200);
  border-radius:var(--radius-md);
  margin-bottom:.75rem;
  overflow:hidden;
  background:var(--white);
  transition:var(--transition);
}
.faq-item.open{box-shadow:var(--shadow-md)}
.faq-question{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:1.1rem 1.5rem;
  cursor:pointer;
  user-select:none;
}
.faq-question h4{
  font-size:1rem;
  font-family:var(--font-sans);
  font-weight:600;
  color:var(--primary);
  margin:0;
}
.faq-icon{
  width:28px;height:28px;
  border-radius:50%;
  background:var(--neutral-100);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;
  color:var(--primary);
  transition:var(--transition);
  flex-shrink:0;
  margin-left:1rem;
}
.faq-item.open .faq-icon{
  background:var(--accent);
  color:var(--white);
  transform:rotate(45deg);
}
.faq-answer{
  max-height:0;
  overflow:hidden;
  transition:max-height .4s ease, padding .3s ease;
}
.faq-item.open .faq-answer{max-height:500px}
.faq-answer-inner{
  padding:0 1.5rem 1.25rem;
  font-size:.925rem;
  color:var(--neutral-700);
  line-height:1.7;
}

/* ── Blog Cards ─────────────────────────────────────────── */
.blog-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2rem;
}
.blog-card{
  background:var(--white);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  border:1px solid var(--neutral-200);
  transition:var(--transition);
  display:flex;
  flex-direction:column;
}
.blog-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.blog-card-image{
  width:100%;
  height:200px;
  object-fit:cover;
  transition:transform .4s ease;
}
.blog-card:hover .blog-card-image{transform:scale(1.04)}
.blog-card-image-wrap{overflow:hidden;height:200px}
.blog-card-body{
  padding:1.5rem;
  flex:1;
  display:flex;
  flex-direction:column;
}
.blog-category{
  display:inline-block;
  background:rgba(200,150,62,.12);
  color:var(--accent-dark);
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.07em;
  text-transform:uppercase;
  padding:.3rem .75rem;
  border-radius:50px;
  margin-bottom:.75rem;
}
.blog-card-body h3{
  font-size:1.05rem;
  margin-bottom:.6rem;
  color:var(--primary);
  line-height:1.35;
}
.blog-card-body p{
  font-size:.875rem;
  color:var(--neutral-600);
  flex:1;
  margin-bottom:1rem;
}
.blog-meta{
  display:flex;
  align-items:center;
  gap:1rem;
  font-size:.78rem;
  color:var(--neutral-600);
  margin-top:auto;
}
.blog-meta span{display:flex;align-items:center;gap:.3rem}
.blog-read-more{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  font-size:.85rem;
  font-weight:600;
  color:var(--accent);
  margin-top:.75rem;
  transition:var(--transition);
}
.blog-read-more:hover{gap:.7rem;color:var(--accent-dark)}

/* ── Areas Grid ─────────────────────────────────────────── */
.areas-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
}
.area-item{
  background:var(--white);
  border:1px solid var(--neutral-200);
  border-radius:var(--radius-md);
  padding:1rem 1.25rem;
  display:flex;
  align-items:center;
  gap:.6rem;
  font-size:.9rem;
  color:var(--neutral-700);
  font-weight:500;
  transition:var(--transition);
}
.area-item:hover{
  border-color:var(--accent);
  color:var(--primary);
  background:rgba(200,150,62,.05);
  transform:translateY(-2px);
  box-shadow:var(--shadow-sm);
}
.area-pin{color:var(--accent);font-size:1rem}

/* ── Contact Section ────────────────────────────────────── */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:4rem;
  align-items:start;
}
.contact-info h3{
  font-size:1.4rem;
  margin-bottom:1.25rem;
}
.contact-detail{
  display:flex;
  gap:1rem;
  margin-bottom:1.25rem;
  align-items:flex-start;
}
.contact-detail-icon{
  width:40px;height:40px;
  min-width:40px;
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;
  color:var(--white);
}
.contact-detail-text h4{font-size:.875rem;font-weight:600;color:var(--primary);margin-bottom:.15rem}
.contact-detail-text p{font-size:.875rem;color:var(--neutral-600);margin:0}

/* ── Footer ─────────────────────────────────────────────── */
#site-footer{
  background:var(--primary-dark);
  color:rgba(255,255,255,.75);
  padding:4rem 0 2rem;
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:3rem;
  margin-bottom:3rem;
}
.footer-brand .logo-name{font-size:1.25rem}
.footer-brand p{
  font-size:.875rem;
  margin-top:1rem;
  line-height:1.7;
  color:rgba(255,255,255,.65);
}
.footer-col h4{
  font-family:var(--font-sans);
  font-size:.85rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--accent-light);
  margin-bottom:1.1rem;
}
.footer-col ul li{margin-bottom:.6rem}
.footer-col ul li a{
  font-size:.875rem;
  color:rgba(255,255,255,.65);
  transition:var(--transition);
}
.footer-col ul li a:hover{color:var(--accent-light);padding-left:.3rem}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:1.75rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:1rem;
}
.footer-bottom p{font-size:.8rem;color:rgba(255,255,255,.5);margin:0}
.footer-legal{
  display:flex;gap:1.5rem;
}
.footer-legal a{
  font-size:.82rem;
  color:rgba(255,255,255,.75);
  transition:var(--transition);
  text-decoration:none;
  padding:.2rem 0;
}
.footer-legal a:hover{
  color:var(--accent-light);
  text-decoration:none;
}
/* Sitemap link – same plain style as Privacy Policy & Terms of Service */
.footer-legal a[href="sitemap.html"],
.footer-legal a[href="../sitemap.html"]{
  color:rgba(255,255,255,.75);
  background:none;
  border:none;
  border-radius:0;
  padding:.2rem 0;
  text-decoration:none;
  font-weight:normal;
  letter-spacing:normal;
  transition:var(--transition);
}
.footer-legal a[href="sitemap.html"]:hover,
.footer-legal a[href="../sitemap.html"]:hover{
  background:none;
  border-color:transparent;
  color:var(--accent-light);
  text-decoration:none;
}
.footer-accreditations{
  display:flex;
  gap:.75rem;
  margin-top:1.25rem;
  flex-wrap:wrap;
}
.footer-accred{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  border-radius:var(--radius-sm);
  padding:.3rem .8rem;
  font-size:.75rem;
  font-weight:700;
  letter-spacing:.05em;
  color:var(--accent-light);
}

/* ── Page Header (Inner Pages) ──────────────────────────── */
.page-header{
  background:linear-gradient(135deg,var(--primary-dark),var(--primary));
  color:var(--white);
  padding:8rem 0 4rem;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.page-header::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;bottom:0;
  background-image:url('../images/hero-surveyor.jpg');
  background-size:cover;
  background-position:center;
  opacity:.1;
  z-index:0;
}
.page-header .container{position:relative;z-index:1}
.page-header h1{color:var(--white);margin-bottom:.75rem}
.page-header p{color:rgba(255,255,255,.8);font-size:1.1rem;max-width:640px;margin:0 auto}
.breadcrumb{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  margin-bottom:1rem;
  font-size:.85rem;
}
.breadcrumb a{color:rgba(255,255,255,.6);transition:var(--transition)}
.breadcrumb a:hover{color:var(--accent-light)}
.breadcrumb span{color:rgba(255,255,255,.4)}

/* ── Highlight Box ──────────────────────────────────────── */
.highlight-box{
  background:linear-gradient(135deg,rgba(200,150,62,.08),rgba(26,58,92,.06));
  border:1px solid rgba(200,150,62,.2);
  border-left:4px solid var(--accent);
  border-radius:var(--radius-md);
  padding:1.5rem 2rem;
  margin:2rem 0;
}
.highlight-box h4{color:var(--primary);margin-bottom:.5rem}
.highlight-box p{margin:0;font-size:.9rem}

/* ── Info Image Split ───────────────────────────────────── */
.split-section{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:5rem;
  align-items:flex-start;
}
.split-section.reverse{direction:rtl}
.split-section.reverse>*{direction:ltr}
.split-image{
  border-radius:var(--radius-xl);
  overflow:hidden;
  box-shadow:var(--shadow-xl);
  position:relative;
  align-self:flex-start;
}
.split-text{
  align-self:flex-start;
}
.split-image img{
  width:100%;
  height:420px;
  object-fit:cover;
  transition:transform .6s ease;
}
.split-image:hover img{transform:scale(1.04)}
.split-image-badge{
  position:absolute;
  bottom:1.5rem;left:1.5rem;
  background:var(--white);
  border-radius:var(--radius-md);
  padding:.75rem 1.1rem;
  box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:.6rem;
}
.split-image-badge .badge-icon{font-size:1.5rem}
.split-image-badge .badge-text strong{display:block;font-size:.9rem;color:var(--primary)}
.split-image-badge .badge-text span{font-size:.75rem;color:var(--neutral-600)}
.split-text h2{margin-top:0;margin-bottom:1rem}
.split-text p{color:var(--neutral-600);margin-bottom:1rem}
.split-text .feature-list{margin:1.5rem 0}
.feature-list li{
  display:flex;align-items:flex-start;gap:.75rem;
  margin-bottom:.75rem;
  font-size:.925rem;
  color:var(--neutral-700);
}
.feature-list li::before{
  content:'✓';
  display:flex;align-items:center;justify-content:center;
  width:22px;height:22px;
  min-width:22px;
  background:var(--accent);
  color:var(--white);
  border-radius:50%;
  font-size:.7rem;
  font-weight:700;
  margin-top:.1rem;
}

/* ── Chart / Data Viz ───────────────────────────────────── */
.chart-wrap{
  background:var(--white);
  border-radius:var(--radius-lg);
  padding:2rem;
  box-shadow:var(--shadow-md);
  border:1px solid var(--neutral-200);
}
.chart-wrap h3{margin-bottom:1.5rem;text-align:center}

/* ── Scroll Animations ──────────────────────────────────── */
[data-aos]{
  opacity:0;
  transform:translateY(30px);
  transition:opacity .6s ease, transform .6s ease;
}
[data-aos].aos-animate{
  opacity:1;
  transform:translateY(0);
}
[data-aos="fade-left"]{transform:translateX(-30px)}
[data-aos="fade-left"].aos-animate{transform:translateX(0)}
[data-aos="fade-right"]{transform:translateX(30px)}
[data-aos="fade-right"].aos-animate{transform:translateX(0)}
[data-aos="zoom-in"]{transform:scale(.9)}
[data-aos="zoom-in"].aos-animate{transform:scale(1)}

/* ── Skip to content ────────────────────────────────────── */
.skip-link{
  position:absolute;
  top:-9999px;
  left:0;
  background:var(--accent);
  color:var(--white);
  padding:.5rem 1rem;
  border-radius:0 0 var(--radius-sm) var(--radius-sm);
  z-index:9999;
  font-weight:600;
}
.skip-link:focus{top:0}

/* ── HubSpot Form Override ──────────────────────────────── */
.hs-form-frame,.hs_submit,.hs-button{width:100% !important}
.hs-form-private{font-family:var(--font-sans) !important}

/* ── Cookie Banner ──────────────────────────────────────── */
#cookie-banner{
  position:fixed;
  bottom:0;left:0;right:0;
  background:var(--primary-dark);
  color:var(--white);
  padding:1rem 1.5rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  z-index:5000;
  box-shadow:0 -4px 20px rgba(0,0,0,.3);
  flex-wrap:wrap;
}
#cookie-banner p{font-size:.85rem;color:rgba(255,255,255,.85);margin:0}
#cookie-banner a{color:var(--accent-light);text-decoration:underline}
.cookie-btns{display:flex;gap:.75rem;flex-shrink:0}
.btn-accept-cookies{
  background:var(--accent);color:var(--white);
  padding:.5rem 1.25rem;border-radius:var(--radius-sm);
  font-size:.85rem;font-weight:600;cursor:pointer;border:none;
}
.btn-decline-cookies{
  background:transparent;color:rgba(255,255,255,.7);
  padding:.5rem 1.25rem;border-radius:var(--radius-sm);
  font-size:.85rem;font-weight:600;cursor:pointer;
  border:1px solid rgba(255,255,255,.3);
}

/* ── Back to top ────────────────────────────────────────── */
#back-to-top{
  position:fixed;
  bottom:2rem;right:2rem;
  width:46px;height:46px;
  background:var(--primary);
  color:var(--white);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;
  box-shadow:var(--shadow-lg);
  z-index:900;
  opacity:0;
  transform:translateY(20px);
  transition:var(--transition);
  cursor:pointer;
  border:none;
}
#back-to-top.visible{opacity:1;transform:translateY(0)}
#back-to-top:hover{background:var(--accent);transform:translateY(-3px)}

/* ── Map placeholder ────────────────────────────────────── */
.map-wrap{
  border-radius:var(--radius-xl);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  height:400px;
  background:var(--neutral-200);
  position:relative;
}
.map-wrap iframe{width:100%;height:100%;border:0}

/* ── Survey comparison table ────────────────────────────── */
.comparison-table{
  width:100%;
  border-collapse:collapse;
  font-size:.9rem;
  box-shadow:var(--shadow-md);
  border-radius:var(--radius-lg);
  overflow:hidden;
}
.comparison-table th{
  background:var(--primary);
  color:var(--white);
  padding:1rem 1.25rem;
  text-align:left;
  font-weight:600;
  font-size:.875rem;
}
.comparison-table td{
  padding:.9rem 1.25rem;
  border-bottom:1px solid var(--neutral-200);
  color:var(--neutral-700);
}
.comparison-table tr:nth-child(even) td{background:var(--neutral-50)}
.comparison-table tr:last-child td{border-bottom:none}
.comparison-table .check{color:#10b981;font-size:1.1rem}
.comparison-table .cross{color:#ef4444;font-size:1.1rem}

/* ── Responsive ─────────────────────────────────────────── */
@media(max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .process-steps{grid-template-columns:repeat(2,1fr)}
  .process-steps::before{display:none}
  .areas-grid{grid-template-columns:repeat(3,1fr)}
}

@media(max-width:768px){
  .section{padding:3.5rem 0}
  .hero-inner{grid-template-columns:1fr}
  .hero-text p{max-width:100%}
  .grid-2,.grid-3,.team-grid,.reviews-grid,.blog-grid,.split-section,.contact-grid{
    grid-template-columns:1fr !important;
    direction:ltr;
  }
  .split-section{gap:2.5rem}
  .areas-grid{grid-template-columns:repeat(2,1fr)}
  #main-nav{
    position:fixed;
    top:74px;left:0;right:0;
    background:var(--primary-dark);
    flex-direction:column;
    align-items:stretch;
    gap:0;
    padding:1rem;
    transform:translateY(-110%);
    transition:transform .35s cubic-bezier(.4,0,.2,1);
    box-shadow:0 10px 30px rgba(0,0,0,.3);
  }
  #main-nav.open{transform:translateY(0)}
  #main-nav a{padding:.85rem 1rem;border-radius:var(--radius-sm);font-size:.95rem}
  .nav-toggle{display:flex}
  .accred-bar{display:none}
  .hero-stats{gap:1rem}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .footer-legal{justify-content:center}
  .why-grid{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:480px){
  .areas-grid{grid-template-columns:1fr}
  .grid-4{grid-template-columns:1fr}
  .hero-btns{flex-direction:column}
  .cta-btns{flex-direction:column;align-items:center}
  .stats-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
}

/* ── Print ──────────────────────────────────────────────── */
@media print{
  #site-header,#site-footer,#cookie-banner,#back-to-top,.hero-particles{display:none}
  body{color:#000;background:#fff}
}
