/* ==========================================================
   STADSPAGINA'S (slotenmaker-[plaats]) — los bestand
   Locatie: /www/wwwroot/www.sleutel24.nl/assets/css/stadspagina.css
   Kleuren aanpassen aan huisstijl: alleen de 2 variabelen hieronder.
   ========================================================== */
.sp {
  --sp-primary: #0f3f66;   /* hoofdkleur — pas aan naar huisstijl */
  --sp-accent:  #f7a600;   /* actie/spoed-kleur — pas aan naar huisstijl */
  --sp-ink: #182430;
  --sp-muted: #5a6b7c;
  --sp-bg-alt: #f4f7fa;
  --sp-line: #dfe6ee;
  color: var(--sp-ink);
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px 60px;
}
.sp h1, .sp h2, .sp h3 { line-height: 1.25; }
.sp h2 { font-size: 1.7rem; margin: 0 0 8px; }
.sp p { line-height: 1.65; }

/* Kruimelpad */
.sp-crumb { font-size: .85rem; color: var(--sp-muted); padding: 14px 0 4px; }
.sp-crumb a { color: var(--sp-muted); text-decoration: none; }
.sp-crumb a:hover { text-decoration: underline; }

/* Hero */
.sp-hero {
  background: linear-gradient(135deg, var(--sp-primary), #0a2c49);
  border-radius: 14px;
  color: #fff;
  margin-top: 10px;
}
.sp-hero-inner { padding: 44px 36px; max-width: 720px; }
.sp-hero h1 { font-size: 2.3rem; margin: 6px 0 12px; color: #fff; }
.sp-lead { font-size: 1.08rem; color: rgba(255,255,255,.92); margin: 0 0 22px; }
.sp-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: .8rem; font-weight: 700; letter-spacing: .06em;
  text-transform: uppercase; color: var(--sp-accent); margin: 0;
}
.sp-pulse {
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--sp-accent); display: inline-block;
  animation: sp-pulse 1.6s ease-out infinite;
}
@keyframes sp-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(247,166,0,.55); }
  100% { box-shadow: 0 0 0 12px rgba(247,166,0,0); }
}
@media (prefers-reduced-motion: reduce) {
  .sp-pulse { animation: none; }
}

/* Knoppen */
.sp-cta-row { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 20px; }
.sp-btn {
  display: inline-block; padding: 14px 26px; border-radius: 8px;
  font-weight: 700; text-decoration: none; text-align: center;
  transition: transform .12s ease, box-shadow .12s ease;
}
.sp-btn:focus-visible { outline: 3px solid var(--sp-accent); outline-offset: 2px; }
.sp-btn-primary { background: var(--sp-accent); color: #1a1a1a; }
.sp-btn-primary:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(0,0,0,.22); }
.sp-btn-ghost { background: transparent; color: #fff; border: 2px solid rgba(255,255,255,.55); }
.sp-btn-ghost:hover { border-color: #fff; }

/* USP-lijst in hero */
.sp-usps { list-style: none; display: flex; flex-wrap: wrap; gap: 8px 18px; margin: 0; padding: 0; }
.sp-usps li {
  font-size: .9rem; color: rgba(255,255,255,.9); padding-left: 20px; position: relative;
}
.sp-usps li::before {
  content: "✓"; position: absolute; left: 0; color: var(--sp-accent); font-weight: 700;
}

/* Secties */
.sp-section { padding: 44px 0 8px; }
.sp-section-alt {
  background: var(--sp-bg-alt); border-radius: 14px;
  padding: 40px 36px 28px; margin-top: 36px;
}
.sp-intro { color: var(--sp-muted); max-width: 640px; margin-top: 0; }

/* Diensten-grid */
.sp-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 22px; }
.sp-card {
  display: block; background: #fff; border: 1px solid var(--sp-line);
  border-radius: 12px; padding: 20px; text-decoration: none; color: var(--sp-ink);
  transition: border-color .12s ease, box-shadow .12s ease;
}
.sp-card:hover { border-color: var(--sp-primary); box-shadow: 0 4px 14px rgba(15,63,102,.10); }
.sp-card h3 { margin: 0 0 6px; font-size: 1.05rem; color: var(--sp-primary); }
.sp-card p { margin: 0; font-size: .92rem; color: var(--sp-muted); }

/* Wijken-chips */
.sp-chips { list-style: none; display: flex; flex-wrap: wrap; gap: 8px; padding: 0; margin: 18px 0 6px; }
.sp-chips li {
  background: #fff; border: 1px solid var(--sp-line); border-radius: 999px;
  padding: 7px 15px; font-size: .88rem; color: var(--sp-ink);
}

/* Tarieven */
.sp-tarieven { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 22px; }
.sp-tarief {
  background: #fff; border: 1px solid var(--sp-line); border-radius: 12px;
  padding: 22px 20px; text-align: center;
}
.sp-tarief h3 { margin: 0 0 4px; font-size: 1rem; color: var(--sp-muted); font-weight: 600; }
.sp-prijs { font-size: 1.9rem; font-weight: 800; color: var(--sp-primary); margin: 2px 0; }
.sp-tijd { font-size: .85rem; color: var(--sp-muted); margin: 0; }
.sp-note { margin-top: 16px; }
.sp-note a { color: var(--sp-primary); font-weight: 600; }

/* Waarom-blok */
.sp-waarom { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 20px; }
.sp-waarom h3 { font-size: 1.02rem; color: var(--sp-primary); margin: 0 0 6px; }
.sp-waarom p { font-size: .93rem; color: var(--sp-muted); margin: 0; }

/* FAQ */
.sp-faq {
  border: 1px solid var(--sp-line); border-radius: 10px;
  margin-top: 10px; background: #fff; overflow: hidden;
}
.sp-faq summary {
  cursor: pointer; padding: 15px 18px; font-weight: 600; list-style: none;
  display: flex; justify-content: space-between; align-items: center; gap: 12px;
}
.sp-faq summary::-webkit-details-marker { display: none; }
.sp-faq summary::after { content: "+"; font-size: 1.3rem; color: var(--sp-primary); flex-shrink: 0; }
.sp-faq[open] summary::after { content: "–"; }
.sp-faq summary:focus-visible { outline: 3px solid var(--sp-accent); outline-offset: -3px; }
.sp-faq p { padding: 0 18px 16px; margin: 0; color: var(--sp-muted); }

/* Slot-CTA */
.sp-cta-end {
  background: var(--sp-primary); color: #fff; border-radius: 14px;
  text-align: center; padding: 42px 24px; margin-top: 44px;
}
.sp-cta-end h2 { color: #fff; }
.sp-cta-end p { color: rgba(255,255,255,.9); margin: 8px 0 20px; }

/* Sticky bel-balk — alleen mobiel */
.sp-callbar { display: none; }

/* ---------- Tablet ---------- */
@media (max-width: 900px) {
  .sp-grid, .sp-waarom { grid-template-columns: repeat(2, 1fr); }
  .sp-hero-inner { padding: 36px 26px; }
  .sp-hero h1 { font-size: 2rem; }
}

/* ---------- Smartphone ---------- */
@media (max-width: 600px) {
  .sp { padding-bottom: 90px; } /* ruimte voor sticky bel-balk */
  .sp-grid, .sp-tarieven, .sp-waarom { grid-template-columns: 1fr; }
  .sp-hero-inner { padding: 30px 20px; }
  .sp-hero h1 { font-size: 1.65rem; }
  .sp h2 { font-size: 1.35rem; }
  .sp-section-alt { padding: 28px 20px 20px; }
  .sp-btn { width: 100%; }
  .sp-callbar {
    display: flex; align-items: center; justify-content: center; gap: 10px;
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 999;
    background: var(--sp-accent, #f7a600); color: #1a1a1a;
    font-weight: 700; text-decoration: none; padding: 15px 12px;
    box-shadow: 0 -3px 14px rgba(0,0,0,.18);
  }
}
