@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;600;700;800;900&family=Barlow:wght@300;400;500;600&display=swap');

:root {
  --blue:       #2b7fc1;
  --blue-dark:  #1f6099;
  --blue-light: #e8f4fd;
  --blue-mid:   #c8e0f2;
  --navy:       #0d2136;
  --white:      #ffffff;
  --off-white:  #f7fbff;
  --gray-light: #f0f6fb;
  --gray:       #637b96;
  --text:       #1a2e42;
  --border:     #daeaf5;
  --success:    #22c55e;
  --font-display:'Barlow Condensed',sans-serif;
  --font-body:   'Barlow',sans-serif;
  --shadow:     0 4px 24px rgba(43,127,193,0.10);
  --shadow-lg:  0 12px 40px rgba(43,127,193,0.14);
  --radius:     8px;
  --radius-lg:  14px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--text);background:var(--white);line-height:1.6;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
svg{display:block}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:800;line-height:1.1;color:var(--navy)}
h1{font-size:clamp(2.4rem,5.5vw,4.2rem)}
h2{font-size:clamp(1.9rem,4vw,2.8rem)}
h3{font-size:clamp(1.15rem,2.5vw,1.55rem)}
p{font-size:1rem;line-height:1.8}

.container{max-width:1160px;margin:0 auto;padding:0 32px}
.section{padding:96px 0}
.section-label{font-family:var(--font-display);font-size:.7rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);display:block;margin-bottom:12px}
.section-title{margin-bottom:16px}
.section-sub{font-size:1.05rem;color:var(--gray);max-width:520px;margin-bottom:52px;line-height:1.8}
.text-center{text-align:center}
.text-center .section-sub{margin-left:auto;margin-right:auto}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:10px;padding:13px 26px;border-radius:var(--radius);font-family:var(--font-display);font-size:.9rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;border:none;transition:all .2s ease;white-space:nowrap}
.btn-primary{background:var(--blue);color:var(--white)}
.btn-primary:hover{background:var(--blue-dark);transform:translateY(-1px);box-shadow:0 6px 20px rgba(43,127,193,.3)}
.btn-white{background:var(--white);color:var(--navy)}
.btn-white:hover{background:var(--blue-light);transform:translateY(-1px)}
.btn-outline-blue{background:transparent;border:2px solid var(--blue);color:var(--blue)}
.btn-outline-blue:hover{background:var(--blue);color:var(--white)}
.btn-outline-white{background:transparent;border:2px solid rgba(255,255,255,.6);color:var(--white)}
.btn-outline-white:hover{background:rgba(255,255,255,.12);border-color:var(--white)}
.btn-lg{padding:16px 32px;font-size:1rem;border-radius:10px}

/* LOGO */
.logo-svg{height:44px;width:auto;overflow:visible;flex-shrink:0;max-width:160px}

/* HEADER */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--white);border-bottom:1px solid var(--border);transition:box-shadow .3s}
.site-header.scrolled{box-shadow:0 2px 20px rgba(43,127,193,.1)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:68px;gap:12px}
.main-nav{display:flex;align-items:center;gap:2px;flex:1;justify-content:center}
.main-nav a{color:var(--gray);font-family:var(--font-display);font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:7px 11px;border-radius:var(--radius);transition:all .18s}
.main-nav a:hover,.main-nav a.active{color:var(--blue);background:var(--blue-light)}
.header-cta{display:flex;align-items:center;gap:12px;flex-shrink:0}
.header-phone{display:flex;align-items:center;gap:8px;color:var(--navy);font-family:var(--font-display);font-size:1rem;font-weight:800;letter-spacing:.02em;white-space:nowrap}
.badge-24{background:var(--blue-light);color:var(--blue);font-family:var(--font-display);font-size:.6rem;font-weight:800;letter-spacing:.12em;padding:4px 9px;border-radius:4px;text-transform:uppercase;border:1px solid var(--blue-mid)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.hamburger span{display:block;width:22px;height:2px;background:var(--navy);border-radius:2px;transition:all .3s}

/* ===================== HERO — CINEMATIC FULLSCREEN ===================== */
.hero {
  position: relative;
  min-height: 100vh;
  padding-top: 68px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--navy);
}

/* Background photo */
.hero-bg-photo {
  position: absolute;
  inset: 0;
  background-image: url('img/bestelbus.jpeg');
  background-size: cover;
  background-position: center 30%;
  filter: brightness(0.38) saturate(0.85);
  transform: scale(1.03);
  transition: transform 8s ease;
}
.hero:hover .hero-bg-photo { transform: scale(1.0); }

/* Gradient overlay — left stays darker for text, right opens up */
.hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(105deg,
      rgba(7,16,34,0.82) 0%,
      rgba(7,16,34,0.65) 50%,
      rgba(43,127,193,0.25) 100%);
  pointer-events: none;
}

/* Subtle blue glow bottom-left */
.hero-glow {
  position: absolute;
  bottom: -100px; left: -100px;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(43,127,193,0.18) 0%, transparent 70%);
  pointer-events: none;
}

/* Content layout */
.hero-inner {
  position: relative;
  z-index: 3;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 64px;
  align-items: center;
  padding: 80px 0 100px;
  width: 100%;
}

/* Left — text */
.hero-content { position: relative; }

.hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(43,127,193,0.2);
  border: 1px solid rgba(74,158,255,0.4);
  backdrop-filter: blur(8px);
  border-radius: 100px; padding: 7px 18px; margin-bottom: 28px;
  font-family: var(--font-display); font-size: .72rem;
  font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
  color: #7ec8ff;
}
.hero-badge .dot {
  width: 6px; height: 6px;
  background: #7ec8ff;
  border-radius: 50%;
  animation: pulse 2s infinite;
  box-shadow: 0 0 6px rgba(126,200,255,0.6);
}
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(1.5)} }

.hero h1 { color: #fff; margin-bottom: 22px; letter-spacing: -.02em; text-shadow: 0 2px 20px rgba(0,0,0,0.4); }
.hero h1 em { color: #7ec8ff; font-style: normal; }
.hero-sub {
  color: rgba(255,255,255,0.72);
  font-size: 1.1rem; line-height: 1.8;
  margin-bottom: 36px; max-width: 520px;
}

.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 52px; }

/* Stats row */
.hero-stats {
  display: flex; gap: 0;
  padding-top: 36px;
  border-top: 1px solid rgba(255,255,255,0.12);
}
.hero-stat { padding-right: 32px; margin-right: 32px; border-right: 1px solid rgba(255,255,255,0.12); }
.hero-stat:last-child { border-right: none; margin-right: 0; padding-right: 0; }
.hero-stat-num { font-family: var(--font-display); font-size: 2.4rem; font-weight: 900; color: #fff; line-height: 1; }
.hero-stat-label { font-size: .76rem; color: rgba(255,255,255,0.45); margin-top: 5px; letter-spacing: .06em; text-transform: uppercase; }

/* Right — floating call card */
.hero-card {
  background: rgba(255,255,255,0.06);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 20px;
  padding: 36px 32px;
  position: relative;
  overflow: hidden;
}
.hero-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, #2b7fc1, #7ec8ff);
  border-radius: 20px 20px 0 0;
}
.hero-card-label {
  font-family: var(--font-display); font-size: .68rem; font-weight: 700;
  letter-spacing: .22em; text-transform: uppercase;
  color: rgba(255,255,255,.5); margin-bottom: 20px;
}
.hero-card-phone {
  display: flex; align-items: center; gap: 14px;
  background: var(--blue); border-radius: 12px;
  padding: 16px 20px; margin-bottom: 12px;
  transition: background .2s; cursor: pointer;
  text-decoration: none;
}
.hero-card-phone:hover { background: #1f6099; }
.hero-card-phone-icon {
  width: 44px; height: 44px;
  background: rgba(255,255,255,0.15);
  border-radius: 10px; display: flex;
  align-items: center; justify-content: center;
  flex-shrink: 0; color: #fff;
}
.hero-card-phone-num { font-family: var(--font-display); font-size: 1.5rem; font-weight: 900; color: #fff; line-height: 1; letter-spacing: .01em; }
.hero-card-phone-sub { font-size: .72rem; color: rgba(255,255,255,.6); margin-top: 2px; }
.hero-card-divider { font-size: .7rem; color: rgba(255,255,255,.35); text-align: center; margin: 12px 0; letter-spacing: .08em; text-transform: uppercase; }
.hero-card-feats { display: flex; flex-direction: column; gap: 10px; margin-top: 20px; padding-top: 20px; border-top: 1px solid rgba(255,255,255,.1); }
.hero-card-feat { display: flex; align-items: center; gap: 10px; font-size: .84rem; color: rgba(255,255,255,.8); }
.hero-card-feat-check {
  width: 20px; height: 20px;
  background: rgba(34,197,94,0.2);
  border-radius: 50%; display: flex;
  align-items: center; justify-content: center;
  flex-shrink: 0; color: #4ade80;
}

/* ===================== PAGE HERO — CINEMATIC ===================== */
.page-hero {
  position: relative;
  padding: 140px 0 0;
  overflow: hidden;
  min-height: 520px;
  display: flex;
  align-items: flex-end;
}
.page-hero > .container {
  width: 100%;
}
.page-hero-bg {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center 40%;
  filter: brightness(0.28) saturate(0.8);
}
.page-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(
    160deg,
    rgba(7,16,34,0.55) 0%,
    rgba(7,16,34,0.75) 50%,
    rgba(7,16,34,0.92) 100%
  );
}
.page-hero-inner {
  position: relative; z-index: 3;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 48px;
  width: 100%;
  padding-bottom: 52px;
}
.page-hero-content { flex: 1; min-width: 0; }
.page-hero h1 { color: #fff; margin-bottom: 14px; letter-spacing: -.02em; text-shadow: 0 2px 20px rgba(0,0,0,0.5); font-size: clamp(1.9rem, 4.5vw, 3.2rem); }
.page-hero p { color: rgba(255,255,255,.72); font-size: 1.05rem; margin-bottom: 28px; line-height: 1.8; max-width: 580px; }
.page-hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }

/* Price badge on page hero */
.hero-price-badge {
  background: rgba(10,20,40,0.55);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 16px;
  padding: 28px 32px;
  text-align: center;
  flex-shrink: 0;
  min-width: 200px;
  max-width: 240px;
  position: relative;
  overflow: hidden;
  align-self: flex-end;
}
.hero-price-badge::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--blue), #7ec8ff);
}
.hero-price-badge-label {
  font-family: var(--font-display); font-size: .65rem; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase;
  color: rgba(255,255,255,.5); margin-bottom: 8px;
}
.hero-price-badge-amount {
  font-family: var(--font-display); font-size: 2.8rem; font-weight: 900;
  color: #fff; line-height: 1; margin-bottom: 4px;
}
.hero-price-badge-amount sup {
  font-size: 1.2rem; font-weight: 700; vertical-align: super; margin-right: 2px;
}
.hero-price-badge-incl {
  font-size: .7rem; color: rgba(255,255,255,.45);
  margin-bottom: 12px;
}
.hero-price-badge-feats { display: flex; flex-direction: column; gap: 5px; }
.hero-price-badge-feat {
  display: flex; align-items: center; gap: 6px;
  font-size: .72rem; color: rgba(255,255,255,.7);
}
.hero-price-badge-feat svg { color: #4ade80; flex-shrink: 0; }

/* USP STRIP */
.usp-strip{background:var(--white);border-bottom:1px solid var(--border)}
.usp-strip-inner{display:grid;grid-template-columns:repeat(4,1fr)}
.usp-item{display:flex;align-items:center;gap:16px;padding:26px 28px;border-right:1px solid var(--border);transition:background .2s}
.usp-item:hover{background:var(--off-white)}
.usp-item:last-child{border-right:none}
.usp-icon-wrap{width:44px;height:44px;background:var(--blue-light);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--blue)}
.usp-text strong{display:block;font-family:var(--font-display);font-size:.92rem;font-weight:800;color:var(--navy);text-transform:uppercase;letter-spacing:.03em}
.usp-text span{font-size:.76rem;color:var(--gray);margin-top:2px;display:block}

/* SERVICES */
.services{background:var(--off-white)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.service-card{background:var(--white);border-radius:var(--radius-lg);padding:36px 30px;border:1px solid var(--border);transition:all .25s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}
.service-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--blue);transform:scaleX(0);transform-origin:left;transition:transform .3s ease}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--blue-mid)}
.service-card:hover::after{transform:scaleX(1)}
.service-icon-wrap{width:50px;height:50px;background:var(--blue-light);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--blue);transition:all .2s}
.service-card:hover .service-icon-wrap{background:var(--blue);color:var(--white)}
.service-card h3{margin-bottom:10px;font-size:1.1rem}
.service-card p{font-size:.87rem;color:var(--gray);margin-bottom:22px;line-height:1.7}
.service-link{font-family:var(--font-display);font-size:.76rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);display:inline-flex;align-items:center;gap:6px;transition:gap .2s}
.service-card:hover .service-link{gap:10px}

/* PRICES */
.prices{background:var(--white)}
.prices-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px}
.price-card{background:var(--off-white);border-radius:var(--radius-lg);padding:32px 28px;border:1px solid var(--border);position:relative;transition:all .2s}
.price-card:hover{border-color:var(--blue-mid);box-shadow:var(--shadow)}
.price-card.featured{background:var(--blue);border-color:var(--blue)}
.price-card.featured .price-title,.price-card.featured .price-label,.price-card.featured .price-desc,.price-card.featured .price-includes li{color:rgba(255,255,255,.85)}
.price-card.featured .price-amount{color:var(--white)}
.price-card.featured .price-includes li::before{color:rgba(255,255,255,.7)}
.price-badge{display:inline-block;background:var(--blue);color:var(--white);font-family:var(--font-display);font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:4px 10px;border-radius:4px;margin-bottom:16px}
.price-card.featured .price-badge{background:rgba(255,255,255,.2)}
.price-label{font-family:var(--font-display);font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gray);margin-bottom:8px;display:block}
.price-title{font-family:var(--font-display);font-size:1.2rem;font-weight:800;color:var(--navy);margin-bottom:16px}
.price-amount{font-family:var(--font-display);font-size:2.8rem;font-weight:900;color:var(--blue);line-height:1;margin-bottom:4px}
.price-amount span{font-size:1.1rem;font-weight:600;vertical-align:super;margin-right:2px}
.price-desc{font-size:.82rem;color:var(--gray);margin-bottom:20px;line-height:1.6}
.price-includes{display:flex;flex-direction:column;gap:8px;padding-top:20px;border-top:1px solid var(--border)}
.price-card.featured .price-includes{border-top-color:rgba(255,255,255,.15)}
.price-includes li{display:flex;gap:8px;align-items:flex-start;font-size:.82rem;color:var(--text);line-height:1.5}
.price-includes li::before{content:'✓';color:var(--blue);font-weight:700;flex-shrink:0;margin-top:1px}
.prices-note{text-align:center;font-size:.82rem;color:var(--gray);padding:16px 24px;background:var(--blue-light);border-radius:var(--radius);border:1px solid var(--blue-mid)}

/* REVIEWS */
.reviews{background:var(--off-white)}
.reviews-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:48px;flex-wrap:wrap;gap:24px}
.reviews-score{display:flex;align-items:center;gap:20px}
.score-num{font-family:var(--font-display);font-size:4rem;font-weight:900;color:var(--navy);line-height:1}
.score-stars{color:#f59e0b;font-size:1.4rem;letter-spacing:3px;display:block;margin-bottom:4px}
.score-label{font-size:.8rem;color:var(--gray)}
.score-bar-wrap{display:flex;flex-direction:column;gap:5px}
.score-bar-row{display:flex;align-items:center;gap:8px;font-size:.75rem;color:var(--gray)}
.score-bar{flex:1;height:6px;background:var(--blue-mid);border-radius:3px;overflow:hidden;min-width:80px}
.score-bar-fill{height:100%;background:var(--blue);border-radius:3px}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review-card{background:var(--white);border-radius:var(--radius-lg);padding:28px;border:1px solid var(--border)}
.review-stars{color:#f59e0b;font-size:1rem;letter-spacing:2px;margin-bottom:12px}
.review-text{font-size:.9rem;color:var(--text);line-height:1.7;margin-bottom:18px;font-style:italic}
.review-author{display:flex;align-items:center;gap:12px}
.review-avatar{width:38px;height:38px;background:var(--blue-light);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:.95rem;font-weight:800;color:var(--blue);flex-shrink:0}
.review-name{font-family:var(--font-display);font-size:.88rem;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.04em}
.review-meta{font-size:.72rem;color:var(--gray);margin-top:1px}
.reviews-cta{text-align:center;margin-top:36px;font-size:.85rem;color:var(--gray)}
.reviews-cta a{color:var(--blue);font-weight:600}

/* WHY */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.why-visual-box{background:var(--blue);border-radius:var(--radius-lg);padding:48px 40px;position:relative;overflow:hidden}
.why-visual-box::before{content:'';position:absolute;top:-60px;right:-60px;width:240px;height:240px;background:rgba(255,255,255,.08);border-radius:50%}
.why-big-num{font-family:var(--font-display);font-size:6rem;font-weight:900;color:var(--white);line-height:1;display:block}
.why-big-label{color:rgba(255,255,255,.7);font-size:1rem;margin-top:6px}
.why-rating-card{background:var(--white);border-radius:var(--radius);padding:18px 22px;margin-top:24px;display:flex;align-items:center;gap:14px;box-shadow:0 4px 16px rgba(0,0,0,.08)}
.stars{color:#f59e0b;font-size:1.1rem;letter-spacing:2px}
.why-rating-text strong{font-family:var(--font-display);font-size:1rem;color:var(--navy)}
.why-rating-text span{display:block;font-size:.76rem;color:var(--gray)}
.why-list{display:flex;flex-direction:column;gap:24px;margin-top:36px}
.why-item{display:flex;gap:16px;align-items:flex-start}
.why-item-icon{width:44px;height:44px;background:var(--blue-light);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;color:var(--blue)}
.why-item h4{font-size:1rem;margin-bottom:4px;font-weight:700}
.why-item p{font-size:.87rem;color:var(--gray)}

/* WERKGEBIED */
.werkgebied{background:var(--blue)}
.werkgebied .section-label{color:rgba(255,255,255,.55)}
.werkgebied .section-title{color:var(--white)}
.werkgebied .section-sub{color:rgba(255,255,255,.65)}
.areas-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.area-pill{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius);padding:14px 10px;text-align:center;font-family:var(--font-display);font-size:.86rem;font-weight:700;color:rgba(255,255,255,.8);letter-spacing:.04em;text-transform:uppercase;transition:all .2s}
.area-pill:hover,.area-pill.main{background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.5);color:var(--white)}

/* PROCESS */
.process{background:var(--off-white)}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);position:relative}
.process-steps::before{content:'';position:absolute;top:34px;left:12%;right:12%;height:2px;background:var(--blue-mid);z-index:0}
.process-step{text-align:center;padding:0 20px;position:relative;z-index:1}
.step-num{width:68px;height:68px;background:var(--white);border:2px solid var(--blue);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.4rem;font-weight:900;color:var(--blue);margin:0 auto 22px;box-shadow:0 4px 16px rgba(43,127,193,.15)}
.process-step h3{font-size:1rem;margin-bottom:8px}
.process-step p{font-size:.83rem;color:var(--gray)}

/* FAQ */
.faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.faq-item{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--white)}
.faq-question{width:100%;background:none;border:none;padding:20px 24px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--navy);text-align:left;gap:16px;transition:background .2s}
.faq-question:hover{background:var(--off-white)}
.faq-icon{width:24px;height:24px;background:var(--blue-light);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--blue);transition:all .3s;font-size:1rem;font-weight:700;line-height:1}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--blue);color:var(--white)}
.faq-answer{display:none;padding:0 24px 20px;font-size:.92rem;color:var(--gray);line-height:1.8}
.faq-item.open .faq-answer{display:block}

/* CONTACT */
.contact{background:var(--off-white)}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:start}
.contact-info-block{display:flex;flex-direction:column;gap:22px}
.contact-info-item{display:flex;gap:14px;align-items:flex-start}
.contact-info-icon{width:42px;height:42px;background:var(--blue-light);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--blue)}
.contact-info-item strong{display:block;font-family:var(--font-display);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--navy);margin-bottom:2px}
.contact-info-item span,.contact-info-item a{font-size:.93rem;color:var(--gray)}
.contact-info-item a:hover{color:var(--blue)}
.open-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.2);color:#16a34a;border-radius:100px;padding:7px 16px;font-size:.72rem;font-weight:700;font-family:var(--font-display);letter-spacing:.12em;text-transform:uppercase;margin-top:12px}
.open-badge .dot{width:7px;height:7px;background:#22c55e;border-radius:50%;animation:pulse 2s infinite}
.contact-form{background:var(--white);border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow);border:1px solid var(--border)}
.form-title{font-family:var(--font-display);font-size:1.35rem;font-weight:800;color:var(--navy);margin-bottom:4px;text-transform:uppercase}
.form-sub{font-size:.85rem;color:var(--gray);margin-bottom:28px}
.form-group{margin-bottom:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group label{display:block;font-family:var(--font-display);font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--navy);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:var(--font-body);font-size:.93rem;color:var(--text);background:var(--white);transition:all .2s;outline:none;appearance:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(43,127,193,.1)}
.form-group textarea{resize:vertical;min-height:110px}
.form-submit{width:100%;padding:15px;font-size:.95rem;justify-content:center;margin-top:8px;border-radius:var(--radius)}
.form-privacy{font-size:.73rem;color:var(--gray);text-align:center;margin-top:12px;line-height:1.6}
.form-success{display:none;text-align:center;padding:32px 20px}
.form-success .success-icon{font-size:2.8rem;margin-bottom:12px}
.form-success h3{color:#16a34a;margin-bottom:8px}
.form-success p{font-size:.88rem;color:var(--gray)}

/* CTA BANNER */
.cta-banner{background:var(--blue);padding:80px 0}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:40px}
.cta-inner h2{color:var(--white)}
.cta-inner p{color:rgba(255,255,255,.75);margin-top:10px;font-size:1rem;line-height:1.7}
.cta-actions{display:flex;gap:12px;flex-wrap:wrap;flex-shrink:0}

/* FOOTER */
.site-footer{background:var(--navy);border-top:3px solid var(--blue);padding:72px 0 0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:56px;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.07)}
.footer-desc{font-size:.85rem;color:rgba(255,255,255,.4);line-height:1.75;max-width:240px;margin-top:16px}
.footer-col h4{font-family:var(--font-display);font-size:.66rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:18px}
.footer-links{display:flex;flex-direction:column;gap:11px}
.footer-links a{color:rgba(255,255,255,.5);font-size:.87rem;transition:color .2s}
.footer-links a:hover{color:var(--white)}
.footer-contact-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px}
.footer-contact-item .fc-icon{color:rgba(43,127,193,.7);flex-shrink:0;margin-top:2px}
.footer-contact-item span,.footer-contact-item a{color:rgba(255,255,255,.45);font-size:.84rem;line-height:1.5}
.footer-contact-item a:hover{color:var(--white)}
.footer-bottom{padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.footer-copy{font-size:.75rem;color:rgba(255,255,255,.22)}
.footer-bottom-links{display:flex;gap:20px}
.footer-bottom-links a{font-size:.75rem;color:rgba(255,255,255,.22);transition:color .2s}
.footer-bottom-links a:hover{color:rgba(255,255,255,.6)}

/* FLOATING CALL BUTTON */
.floating-call{position:fixed;bottom:24px;right:24px;z-index:999}
.floating-call a{display:flex;align-items:center;gap:9px;background:var(--blue);color:var(--white);border-radius:100px;padding:13px 22px;font-family:var(--font-display);font-size:.82rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;box-shadow:0 4px 20px rgba(43,127,193,.45);transition:all .22s}
.floating-call a:hover{background:var(--blue-dark);transform:translateY(-2px);box-shadow:0 8px 28px rgba(43,127,193,.55)}

/* STICKY MOBILE BAR */
.sticky-mobile-bar{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:998;
  background:var(--white);border-top:1px solid var(--border);
  padding:12px 20px;
  box-shadow:0 -4px 20px rgba(43,127,193,.12);
}
.sticky-mobile-bar a{display:flex;align-items:center;justify-content:center;gap:10px;background:var(--blue);color:var(--white);border-radius:10px;padding:14px 20px;font-family:var(--font-display);font-size:1rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;width:100%}

/* BREADCRUMB */
.breadcrumb{background:var(--white);border-bottom:1px solid var(--border);padding:12px 0}
.breadcrumb-inner{display:flex;align-items:center;gap:8px;font-size:.78rem;color:var(--gray)}
.breadcrumb-inner a{color:var(--gray);transition:color .2s}
.breadcrumb-inner a:hover{color:var(--blue)}
.breadcrumb-inner span{color:var(--text);font-weight:600}

/* PAGE HERO */
.page-hero{background:var(--white);padding:110px 0 80px;position:relative;overflow:hidden;border-bottom:1px solid var(--border)}
.page-hero::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 50% 100% at 100% 50%,var(--blue-light) 0%,transparent 60%)}
.page-hero-inner{position:relative;z-index:2;max-width:660px}
.page-hero h1{color:var(--navy);margin-bottom:18px;letter-spacing:-.02em}
.page-hero p{color:var(--gray);font-size:1.06rem;margin-bottom:32px;line-height:1.8}
.page-hero-actions{display:flex;gap:12px;flex-wrap:wrap}

/* CONTENT */
.content-block{padding:88px 0}
.content-two-col{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.content-box{background:var(--off-white);border-radius:var(--radius-lg);padding:36px;border-left:3px solid var(--blue)}
.content-box h3{margin-bottom:14px}
.content-list{display:flex;flex-direction:column;gap:12px;margin-top:18px}
.content-list li{display:flex;gap:10px;align-items:flex-start;font-size:.9rem;color:var(--text);line-height:1.65}
.content-list li::before{content:'✓';color:var(--blue);font-weight:700;flex-shrink:0;margin-top:2px}
.info-card{background:var(--navy);border-radius:var(--radius-lg);padding:32px;border:1px solid rgba(43,127,193,.15)}
.info-card h3{color:var(--white);margin-bottom:12px}
.info-card p{color:rgba(255,255,255,.6);font-size:.9rem;margin-bottom:22px}

/* RESPONSIVE */
@media(max-width:1024px){
  .hero{grid-template-columns:1fr}
  .hero-right{display:none}
  .hero-left{padding:80px 0}
  .hero-left-inner{padding:0;max-width:100%}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .prices-grid{grid-template-columns:repeat(2,1fr)}
  .reviews-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:1fr;gap:48px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .areas-grid{grid-template-columns:repeat(3,1fr)}
  .contact-grid{grid-template-columns:1fr}
  .content-two-col{grid-template-columns:1fr;gap:28px}
  .cta-inner{flex-direction:column;text-align:center}
}
@media(max-width:768px){
  .section{padding:64px 0}
  .container{padding:0 16px}
  .main-nav{display:none}
  .main-nav.open{display:flex;flex-direction:column;position:fixed;top:70px;left:0;right:0;background:var(--white);padding:12px;border-bottom:1px solid var(--border);gap:2px;z-index:999;box-shadow:0 8px 24px rgba(43,127,193,.1)}
  .main-nav.open a{padding:12px 16px;font-size:.9rem}
  .hamburger{display:flex}
  .logo-svg{height:34px;max-width:130px}
  .floating-call{display:none}
  .sticky-mobile-bar{display:block}
  body{padding-bottom:72px}
  .usp-strip-inner{grid-template-columns:repeat(2,1fr)}
  .services-grid{grid-template-columns:1fr}
  .prices-grid{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .process-steps{grid-template-columns:repeat(2,1fr)}
  .process-steps::before{display:none}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;text-align:center}
  .form-row{grid-template-columns:1fr}
  .areas-grid{grid-template-columns:repeat(2,1fr)}
  .hero-left{padding:40px 0 48px}
  .hero h1{font-size:2.4rem}
  .hero-sub{font-size:.98rem}
  .hero-actions{flex-direction:column;gap:10px}
  .hero-actions .btn-lg{width:100%;justify-content:center}
  .hero-stats{gap:0;flex-wrap:nowrap}
  .hero-stat{padding-right:20px;margin-right:20px}
  .hero-stat-num{font-size:1.7rem}
  .reviews-header{flex-direction:column;align-items:flex-start}
  .header-cta .btn{display:none}
  .header-phone{font-size:.88rem;gap:6px}
  .badge-24{font-size:.55rem;padding:3px 7px}
  .cta-inner{gap:24px}
  /* Photo+panel sections stack vertically on mobile */
  [style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
  /* Force photo in photo-pair to be reasonable height on mobile */
  .gallery-grid { grid-template-columns: 1fr !important; }
  .gallery-item.large { grid-column: span 1 !important; }
  .gallery-item img { min-height: 200px; }
}
@media(max-width:480px){
  .hero h1{font-size:2.1rem}
  .hero-stat{padding-right:14px;margin-right:14px}
  .usp-strip-inner{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr}
  .areas-grid{grid-template-columns:repeat(2,1fr)}
}

/* ===================== PHOTO GALLERY ===================== */
.gallery { background: var(--white); }
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto auto;
  gap: 12px;
}
.gallery-item {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: var(--gray-light);
}
.gallery-item.large {
  grid-column: span 2;
  grid-row: span 1;
}
.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
  min-height: 220px;
}
.gallery-item:hover img { transform: scale(1.03); }
.gallery-caption {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(13,33,54,0.82));
  color: var(--white);
  padding: 28px 18px 16px;
  font-family: var(--font-display);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  opacity: 0;
  transition: opacity 0.3s;
}
.gallery-item:hover .gallery-caption { opacity: 1; }

@media (max-width: 768px) {
  .gallery-grid { grid-template-columns: repeat(2, 1fr); }
  .gallery-item.large { grid-column: span 2; }
  .gallery-item img { min-height: 160px; }
  .gallery-caption { opacity: 1; font-size: 0.72rem; padding: 20px 12px 10px; }
}
@media (max-width: 480px) {
  .gallery-grid { grid-template-columns: 1fr; gap: 8px; }
  .gallery-item.large { grid-column: span 1; }
}

/* Photo + blue panel sections */
.photo-panel {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}
.photo-panel img {
  width: 100%;
  height: 360px;
  object-fit: cover;
  display: block;
}
.photo-panel-text {
  background: var(--blue);
  padding: 48px 40px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media (max-width: 768px) {
  .photo-panel { grid-template-columns: 1fr; }
  .photo-panel img { height: 240px; }
  .photo-panel-text { padding: 28px 24px; }
}

/* ===================== MOBILE HERO FIXES ===================== */
@media (max-width: 768px) {

  /* Homepage hero */
  .hero { min-height: auto; padding-top: 68px; display: block; }
  .hero-inner { display: flex; flex-direction: column; gap: 0; padding: 44px 0 52px; }
  .hero-content { width: 100%; }
  .hero-card { display: none !important; }
  .hero h1 { font-size: clamp(1.9rem, 7vw, 2.4rem); line-height: 1.15; }
  .hero-sub { font-size: .95rem; max-width: 100%; }
  .hero-badge { font-size: .65rem; padding: 6px 14px; }
  .hero-actions { flex-direction: column; gap: 10px; margin-bottom: 36px; }
  .hero-actions .btn { width: 100%; justify-content: center; }
  .hero-stats { flex-wrap: nowrap; gap: 0; }
  .hero-stat { padding-right: 16px; margin-right: 16px; }
  .hero-stat-num { font-size: 1.6rem; }

  /* Subpage hero — full rewrite for mobile */
  .page-hero {
    display: block;
    padding: 0;
    min-height: auto;
  }
  .page-hero-bg {
    position: absolute; inset: 0;
    height: 100%;
  }
  .page-hero-overlay {
    position: absolute; inset: 0;
  }
  .page-hero > .container {
    position: relative;
    z-index: 3;
    padding-top: 100px;
    padding-bottom: 0;
    width: 100%;
  }
  .page-hero-inner {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding-bottom: 0;
  }
  .page-hero-content {
    width: 100%;
    padding-bottom: 28px;
  }
  .page-hero h1 {
    font-size: clamp(1.7rem, 6.5vw, 2.2rem);
    line-height: 1.15;
    color: #fff;
  }
  .page-hero p { font-size: .92rem; color: rgba(255,255,255,.72); }
  .page-hero-actions { flex-direction: column; gap: 10px; }
  .page-hero-actions .btn { width: 100%; justify-content: center; }

  /* Price badge: full-width solid blue bar under text */
  .hero-price-badge {
    position: relative;
    width: calc(100% + 32px);
    margin: 0 -16px;
    border-radius: 0;
    min-width: unset;
    max-width: none;
    padding: 18px 16px;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    text-align: left;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    background: var(--blue);
    border: none;
    border-top: 1px solid rgba(255,255,255,.15);
    align-self: auto;
  }
  .hero-price-badge::before { display: none; }
  .hero-price-badge-label { display: none; }
  .hero-price-badge-amount { font-size: 2.2rem; flex-shrink: 0; white-space: nowrap; margin-bottom: 0; }
  .hero-price-badge-amount sup { font-size: 1rem; }
  .hero-price-badge-incl { font-size: .7rem; margin-bottom: 6px; }
  .hero-price-badge-feats { gap: 4px; flex: 1; }
  .hero-price-badge-feat { font-size: .72rem; }
}

@media (max-width: 420px) {
  .hero h1 { font-size: 1.75rem; }
  .page-hero h1 { font-size: 1.6rem; }
  .hero-price-badge-amount { font-size: 1.8rem; }
}
