:root{
  --bg0:#f5f7fb;
  --bg1:#eef2f7;
  --card:rgba(255,255,255,.72);
  --card2:rgba(255,255,255,.82);
  --text:#0f172a;
  --muted:#475569;
  --muted2:#64748b;
  --border:rgba(15,23,42,.10);
  --border2:rgba(15,23,42,.14);
  --shadow:0 18px 48px rgba(15,23,42,.10);
  --shadow2:0 12px 30px rgba(15,23,42,.09);
  --r-lg:18px;
  --r-xl:28px;

  --a:#2563eb;
  --b:#06b6d4;

  --max:1200px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:
    radial-gradient(900px 420px at 12% 0%, rgba(37,99,235,.14), transparent 55%),
    radial-gradient(900px 420px at 88% 12%, rgba(6,182,212,.12), transparent 55%),
    linear-gradient(180deg, var(--bg1), var(--bg0));
  overflow-x:hidden;
  line-height:1.6;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 18px}
@media(min-width:1024px){.container{padding:0 28px}}

.glass{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--r-xl);
  box-shadow:var(--shadow);
  backdrop-filter: blur(14px);
}
.glass-soft{
  background:var(--card2);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  box-shadow:var(--shadow2);
}

.topbar{
  position:sticky;top:0;z-index:50;
  background:linear-gradient(180deg, rgba(245,247,251,.90), rgba(245,247,251,.72), rgba(245,247,251,0));
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(15,23,42,.06);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:18px 0;
}
.brand{display:flex;align-items:center;gap:14px;min-width:220px}
.brand img{width:64px;height:64px;object-fit:contain;border-radius:18px}
.brand .name{display:flex;flex-direction:column;line-height:1.15}
.brand .name b{letter-spacing:.10em;font-size:.92rem;text-transform:uppercase}
.brand .name span{color:var(--muted2);font-size:.82rem;font-weight:600}

.menu{
  display:none;gap:16px;align-items:center;flex:1;justify-content:center;
  white-space: nowrap;
}
.menu a{
  color:var(--muted);font-weight:650;font-size:1.05rem;position:relative;padding:4px 0;
}
.menu a:hover{color:var(--text)}
.menu a::after{
  content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;
  background:linear-gradient(90deg,var(--a),var(--b));
  border-radius:999px;transition:width .18s ease;
}
.menu a:hover::after{width:100%}

.cta{display:none;gap:8px;align-items:center}
.pill{
  border:1px solid rgba(37,99,235,.18);
  background: rgba(37,99,235,.08);
  border-radius:999px;
  padding:.34rem .70rem;
  color:#1e293b;
  font-size:.82rem;
  font-weight:800;
  box-shadow:none;
  white-space: nowrap;
}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  padding:.55rem 1.05rem;border-radius:999px;
  border:1px solid var(--border2);
  background:rgba(255,255,255,.75);
  color:var(--text);font-weight:750;font-size:.95rem;
  box-shadow:var(--shadow2);
  transition: transform .12s ease, filter .12s ease, border-color .12s ease;
}
.btn:hover{transform:translateY(-1px);border-color:rgba(15,23,42,.18)}
.btn-primary{
  border:none;
  background:linear-gradient(135deg,var(--a),var(--b));
  color:white;
  box-shadow:0 16px 40px rgba(37,99,235,.22);
}
.btn-primary:hover{filter:brightness(1.03)}

.mobile-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:14px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.7);
  box-shadow:var(--shadow2);
}
.mobile-btn svg{width:22px;height:22px}
@media(min-width:920px){
  .menu{display:flex}
  .cta{display:flex}
  .mobile-btn{display:none}
}

.mobile-drawer{display:none;padding:14px 0 18px}
.mobile-drawer a{
  display:block;padding:10px 12px;border-radius:14px;
  color:var(--text);font-weight:700;
}
.mobile-drawer a:hover{background:rgba(15,23,42,.04)}
.mobile-drawer .row{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}

/* Hero glow background */
.hero{
  position: relative;
  padding: 62px 0 68px;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 400px at 20% 10%, rgba(37,99,235,.18), transparent 60%),
    radial-gradient(900px 500px at 80% 20%, rgba(6,182,212,.16), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.78), rgba(255,255,255,.86)),
    url("../img/hero-bg.jpg") center/cover no-repeat;
  z-index:0;
}
.hero .container{ position: relative; z-index:1; }

.kicker{
  display:inline-flex;align-items:center;gap:.55rem;
  border:1px solid var(--border);
  background:rgba(255,255,255,.65);
  padding:.38rem .75rem;border-radius:999px;
  color:var(--muted);font-weight:650;font-size:.85rem;
  box-shadow:var(--shadow2);
}
h1{
  margin:12px 0 10px;
  font-size: clamp(2.2rem, 3.5vw + 1rem, 3.4rem);
  line-height:1.05;
  letter-spacing:-.02em;
}
.grad{
  background:linear-gradient(135deg,var(--a),var(--b));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.sub{color:var(--muted);font-size:1.05rem;max-width:56rem}

/* Milkglass hero box */
.hero-glass{
  padding: 22px 22px;
  border-radius: 28px;
  max-width: 920px;
  position:relative;
  overflow:hidden;
}
.hero-glass.glass{
  background: rgba(255,255,255,.60);
  border: 1px solid rgba(15,23,42,.10);
  backdrop-filter: blur(18px);
}
.hero-glass::after{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius: 30px;
  padding: 2px;
  background: linear-gradient(135deg, rgba(37,99,235,.35), rgba(6,182,212,.25), rgba(255,255,255,0));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events:none;
}
.hero-glass .actions{margin-top:14px}

.hero-card{margin-top:18px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1fr;gap:16px;padding:22px}
@media(min-width:980px){.hero-grid{grid-template-columns:1.1fr .9fr;gap:22px;padding:28px}}

.badges{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 16px}
.badge{
  border:1px solid var(--border);
  background:rgba(255,255,255,.65);
  padding:.28rem .70rem;border-radius:999px;
  color:var(--muted);font-weight:650;font-size:.85rem;
}
.actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}
.meta{
  margin-top:16px;color:var(--muted2);font-size:.9rem;
  display:flex;flex-wrap:wrap;gap:10px 18px;
}
.meta strong{color:var(--text)}

.panel{
  border-radius:var(--r-xl);
  border:1px solid var(--border);
  background:linear-gradient(180deg, rgba(255,255,255,.78), rgba(255,255,255,.60));
  box-shadow:var(--shadow2);
  padding:18px;
  position:relative;
  overflow:hidden;
}
.panel::before{
  content:"";position:absolute;inset:-45%;
  background:
    radial-gradient(circle at 10% 0%, rgba(37,99,235,.18), transparent 55%),
    radial-gradient(circle at 100% 80%, rgba(6,182,212,.16), transparent 55%);
  pointer-events:none;
}
.panel > *{position:relative}

.grid-2{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:540px){.grid-2{grid-template-columns:1fr 1fr}}
.tile{
  border-radius:18px;border:1px solid var(--border);
  background:rgba(255,255,255,.78);
  padding:14px;
}
.tile h3{margin:0 0 6px;font-size:1rem}
.tile p{margin:0;color:var(--muted);font-size:.92rem}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.chip{
  border:1px solid var(--border);
  background:rgba(255,255,255,.62);
  color:var(--muted);
  font-size:.78rem;font-weight:650;
  padding:.18rem .55rem;border-radius:999px;
}

.section{padding:22px 0}
.section h2{margin:0 0 8px;font-size:1.55rem;letter-spacing:-.01em}
.section .lead{margin:0 0 16px;color:var(--muted);font-size:1rem}

.cards{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:860px){.cards{grid-template-columns:repeat(3,1fr)}}
.card{
  border-radius:20px;border:1px solid var(--border);
  background:rgba(255,255,255,.78);
  box-shadow:var(--shadow2);
  padding:16px;
  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.card:hover{transform:translateY(-2px);border-color:rgba(15,23,42,.18);box-shadow:0 20px 52px rgba(15,23,42,.12)}
.card .icon{font-size:1.35rem;margin-bottom:8px}
.card h3{margin:0 0 6px;font-size:1.05rem}
.card p{margin:0;color:var(--muted);font-size:.93rem}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.tag{border:1px solid var(--border);background:rgba(255,255,255,.62);color:var(--muted);border-radius:999px;padding:.18rem .55rem;font-size:.78rem;font-weight:650}

.split{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:980px){.split{grid-template-columns:1.1fr .9fr;gap:18px}}
.box{padding:18px}
.step{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:flex-start;margin-top:10px}
.n{
  width:32px;height:32px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--border);
  background:rgba(255,255,255,.78);
  color:var(--a);font-weight:800;
}
.step h3{margin:0 0 4px;font-size:1rem}
.step p{margin:0;color:var(--muted);font-size:.93rem}

.pricing{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:980px){.pricing{grid-template-columns:repeat(3,1fr)}}
.price{
  border-radius:22px;border:1px solid var(--border);
  background:rgba(255,255,255,.80);
  box-shadow:var(--shadow2);
  padding:18px;
  position:relative;
  overflow:hidden;
}
.price.featured{
  border-color:rgba(37,99,235,.26);
  box-shadow:0 22px 64px rgba(37,99,235,.18);
}
.price .ribbon{
  position:absolute;top:14px;right:14px;
  border:1px solid rgba(37,99,235,.22);
  background:rgba(37,99,235,.10);
  color:var(--a);
  border-radius:999px;padding:.22rem .60rem;
  font-size:.78rem;font-weight:800;
}
.price h3{margin:0 0 6px;font-size:1.05rem}
.price .p{font-size:2.1rem;font-weight:900;letter-spacing:-.02em;margin:8px 0}
.price small{color:var(--muted2)}
.price ul{margin:12px 0 0;padding-left:18px;color:var(--muted);font-weight:650}
.price li{margin:7px 0}

.faq{display:grid;gap:10px}
.faq details{border-radius:18px;border:1px solid var(--border);background:rgba(255,255,255,.78);padding:12px 14px}
.faq summary{cursor:pointer;font-weight:800;color:var(--text)}
.faq p{margin:10px 0 0;color:var(--muted)}

.form{display:grid;gap:10px}
.field{display:grid;gap:6px}
label{font-size:.82rem;color:var(--muted2);font-weight:700}
input,textarea,select{
  border-radius:14px;border:1px solid var(--border);
  background:rgba(255,255,255,.82);
  padding:.62rem .8rem;
  font:inherit;
  outline:none;
  transition: box-shadow .12s ease, border-color .12s ease;
}
input:focus,textarea:focus,select:focus{border-color: rgba(37,99,235,.35);box-shadow: 0 0 0 4px rgba(37,99,235,.12)}
textarea{min-height:130px;resize:vertical}
.notice{color:var(--muted2);font-size:.86rem}

.footer{margin-top:18px;border-top:1px solid rgba(15,23,42,.06);padding:18px 0 28px;color:var(--muted2);font-size:.9rem}
.footer a{color:var(--muted);font-weight:700}
.footer a:hover{color:var(--a)}

.reveal{opacity:0;transform:translateY(12px);transition:opacity .55s ease, transform .55s ease}
.reveal.in{opacity:1;transform:none}

.blob{
  position:absolute;inset:auto auto 0 0;
  width:420px;height:420px;border-radius:50%;
  background: radial-gradient(circle at 30% 30%, rgba(37,99,235,.22), transparent 60%),
              radial-gradient(circle at 70% 70%, rgba(6,182,212,.18), transparent 60%);
  filter: blur(12px);
  animation: floaty 12s ease-in-out infinite;
  pointer-events:none;
  opacity:.9;
}
.blob.b2{
  left:auto;right:-120px;bottom:120px;
  width:520px;height:520px;
  animation-duration: 14s;
}
@keyframes floaty{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(18px,-18px) scale(1.03)}
}

.to-top{
  position:fixed;right:18px;bottom:18px;z-index:60;
  width:46px;height:46px;border-radius:16px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.78);
  box-shadow:var(--shadow2);
  display:none;align-items:center;justify-content:center;
}
.to-top.show{display:flex}

/* ===== V3 Premium Additions ===== */

.hero{
  position: relative;
  padding: 62px 0 68px;
  text-align: center;
  overflow: hidden;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 400px at 20% 10%, rgba(37,99,235,.18), transparent 60%),
    radial-gradient(900px 500px at 80% 20%, rgba(6,182,212,.16), transparent 60%),
    linear-gradient(180deg, #eef3f9, #f6f9fc);
  z-index:0;
}
.hero .container{position:relative; z-index:1;}

.hero-glass{
  max-width: 980px;
  margin: 0 auto;
  padding: 0;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}

.badges{justify-content:center}
.actions{justify-content:center}
.meta{justify-content:center}
.sub{margin-left:auto;margin-right:auto}

.hero-card{margin-top:34px}

/* Rating badge */
.rating-badge{
  display:inline-flex; align-items:center; justify-content:center;
  gap:.5rem;
  border-radius: 999px;
  padding:.42rem .82rem;
  border:1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.70);
  box-shadow: 0 12px 30px rgba(15,23,42,.08);
  color: var(--text);
  font-weight: 850;
  font-size: .92rem;
}

/* Counters */
.counters{
  display:grid;
  grid-template-columns: 1fr;
  gap:12px;
  margin-top: 16px;
}
@media(min-width:860px){
  .counters{grid-template-columns: repeat(3, 1fr);}
}
.counter{
  border-radius: 22px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.78);
  box-shadow: var(--shadow2);
  padding: 16px;
  text-align: left;
}
.counter .num{
  font-size: 2.1rem;
  font-weight: 950;
  letter-spacing: -0.02em;
  margin: 0;
  background: linear-gradient(135deg,var(--a),var(--b));
  -webkit-background-clip:text; background-clip:text; color: transparent;
}
.counter .lbl{
  margin: 2px 0 0;
  color: var(--muted);
  font-weight: 750;
}

/* Logo grid */
.logo-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:12px;
}
@media(min-width:860px){
  .logo-grid{grid-template-columns: repeat(4, 1fr);}
}
.logo-tile{
  border-radius: 22px;
  border:1px solid var(--border);
  background: rgba(255,255,255,.78);
  box-shadow: var(--shadow2);
  padding: 18px 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height: 86px;
  position: relative;
  overflow:hidden;
  transition: transform .14s ease, border-color .14s ease, box-shadow .14s ease;
}
.logo-tile::before{
  content:"";
  position:absolute;
  inset:-60%;
  background:
    radial-gradient(circle at 20% 20%, rgba(37,99,235,.18), transparent 55%),
    radial-gradient(circle at 80% 80%, rgba(6,182,212,.14), transparent 55%);
  opacity: 0;
  transition: opacity .18s ease;
}
.logo-tile:hover{
  transform: translateY(-3px);
  border-color: rgba(37,99,235,.22);
  box-shadow: 0 24px 68px rgba(15,23,42,.12);
}
.logo-tile:hover::before{opacity:1}
.logo-tile span{
  position:relative;
  font-weight: 900;
  color: var(--muted);
  letter-spacing: .02em;
}

/* Reviews stars */
.stars{
  font-size: 1.1rem;
  letter-spacing: .08em;
  color: #facc15;
  margin-bottom: 6px;
}



/* V3.1 layout tweaks */
.hero .kicker{margin-top:0;margin-bottom:14px}
.hero h1{margin-top:14px}



/* Center feature chips inside service cards */
.service-card .tags,
.card .tags{
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:10px;
  margin-top:14px;
}
.service-card .tag,
.card .tag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}



/* Premium Footer */
.footer-premium{
  margin-top: 60px;
  padding: 54px 0 34px;
  background:
    radial-gradient(900px 320px at 20% 0%, rgba(37,99,235,.12), transparent 60%),
    radial-gradient(900px 320px at 80% 0%, rgba(6,182,212,.10), transparent 60%),
    linear-gradient(180deg, #f3f6fb, #eef2f8);
  border-top: 1px solid rgba(15,23,42,.08);
}
.footer-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap:18px;
}
@media(min-width:860px){
  .footer-grid{grid-template-columns: 1.2fr 1fr 1fr 1.2fr;}
}
.footer-card{
  border-radius: 24px;
  border: 1px solid rgba(15,23,42,.08);
  background: rgba(255,255,255,.78);
  box-shadow: 0 18px 50px rgba(15,23,42,.10);
  padding: 18px 18px;
}
.footer-title{
  font-weight: 950;
  margin: 0 0 10px;
  letter-spacing: -0.01em;
}
.footer-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:10px;
}
.footer-list a{color: var(--text); text-decoration:none; font-weight:750; opacity:.9}
.footer-list a:hover{opacity:1; text-decoration:underline}
.footer-meta{
  display:flex; gap:10px; flex-wrap:wrap; margin-top:10px;
}
.social-btn{
  display:inline-flex; align-items:center; justify-content:center;
  height: 42px; padding:0 14px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.85);
  font-weight: 850;
  text-decoration:none;
  color: var(--text);
  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease;
}
.social-btn:hover{
  transform: translateY(-2px);
  border-color: rgba(37,99,235,.22);
  box-shadow: 0 18px 46px rgba(15,23,42,.10);
}
.footer-bottom{
  margin-top: 18px;
  display:flex;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
  color: var(--muted);
  font-weight: 750;
}
.map-embed{
  width:100%;
  height: 190px;
  border:0;
  border-radius: 18px;
}



/* V3.2 chip centering fix */
.tags{
  width:100%;
  justify-content:center !important;
}
.tag{
  min-width: 86px;
}
.service-card .tags, .card .tags{
  width:100%;
  justify-content:center !important;
}



/* Taller map on Standort section */
.map-embed--tall{height: 320px;}



/* ===== V3.2 Footer Simplified (override) ===== */
.footer-premium{
  margin-top: 54px;
  padding: 34px 0 22px;
  background:
    radial-gradient(900px 320px at 20% 0%, rgba(37,99,235,.10), transparent 60%),
    radial-gradient(900px 320px at 80% 0%, rgba(6,182,212,.08), transparent 60%),
    linear-gradient(180deg, #f4f7fc, #eef2f8);
  border-top: 1px solid rgba(15,23,42,.08);
}
.footer-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap:18px;
}
@media(min-width:860px){
  .footer-grid{grid-template-columns: 1.35fr 1fr 1fr 1.35fr;}
}
.footer-col h4{
  margin:0 0 10px;
  font-weight: 950;
  letter-spacing: -0.01em;
}
.footer-col p{margin:0 0 10px; color:var(--muted); font-weight:750}
.footer-links{
  list-style:none; padding:0; margin:0;
  display:grid; gap:10px;
}
.footer-links a{color:var(--text); text-decoration:none; font-weight:800; opacity:.92}
.footer-links a:hover{text-decoration:underline; opacity:1}
.footer-social{display:flex; gap:10px; flex-wrap:wrap; margin-top:10px}
.footer-mini{
  display:flex; gap:12px; flex-wrap:wrap; align-items:center;
  padding: 10px 14px;
  border-radius: 18px;
  border: 1px solid rgba(15,23,42,.08);
  background: rgba(255,255,255,.70);
}
.footer-logo{
  width:48px;height:48px;border-radius:14px;
  border:1px solid rgba(15,23,42,.08);
  background:rgba(255,255,255,.80);
  padding:6px;
}
.footer-bottom{
  margin-top: 16px;
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  color: var(--muted);
  font-weight: 800;
}

/* V3.2 hero top tighten */
@media(min-width:860px){
  .hero{padding-top: 52px;}
}

/* ===== V4 Logo größer ===== */
.nav-logo img{
  height: 64px !important;
  width: auto;
}
@media(min-width: 860px){
  .nav-logo img{
    height: 74px !important;
  }
}

/* ===== Firmenkunden / Referenzen Grid ===== */
.clients-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit,minmax(160px,1fr));
  gap:24px;
  margin-top:30px;
}
.client-item{
  background:rgba(255,255,255,.65);
  backdrop-filter: blur(12px);
  border:1px solid rgba(15,23,42,.08);
  border-radius:18px;
  padding:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:.3s;
}
.client-item:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 30px rgba(0,0,0,.08);
}
.client-item img{
  max-width:100%;
  max-height:60px;
  object-fit:contain;
}

/* ===== V4.1 Premium Client Logo Hover ===== */
.client-item{
  position:relative;
  overflow:hidden;
}
.client-item::after{
  content:"";
  position:absolute;
  inset:-40%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.55), transparent);
  transform: translateX(-120%) rotate(12deg);
  transition: transform .55s ease;
  pointer-events:none;
}
.client-item img{
  filter: grayscale(100%) contrast(1.05) opacity(.90);
  transition: filter .25s ease, transform .25s ease;
}
.client-item:hover img{
  filter: grayscale(0%) contrast(1.02) opacity(1);
  transform: scale(1.03);
}
.client-item:hover::after{
  transform: translateX(120%) rotate(12deg);
}
.client-item:hover{
  border-color: rgba(37,99,235,.22);
  box-shadow: 0 18px 44px rgba(15,23,42,.10);
}

/* ===== Google Reviews Slider ===== */
.reviews-wrap{margin-top:28px}
.reviews-head{
  display:flex;justify-content:space-between;align-items:flex-end;gap:14px;flex-wrap:wrap;
}
.reviews-actions{display:flex;gap:10px;flex-wrap:wrap}
.reviews-slider{
  margin-top:16px;
  display:grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(280px, 1fr);
  gap:16px;
  overflow:auto;
  scroll-snap-type:x mandatory;
  padding-bottom:10px;
}
.review-card{
  scroll-snap-align:start;
  border-radius:22px;
  border:1px solid rgba(15,23,42,.08);
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(12px);
  box-shadow: 0 16px 42px rgba(15,23,42,.08);
  padding:16px 16px;
  min-height: 160px;
}
.review-top{display:flex;justify-content:space-between;gap:12px;align-items:center}
.review-name{font-weight:950}
.review-stars{font-weight:950}
.review-meta{color:var(--muted);font-weight:750;font-size:.95rem;margin-top:4px}
.review-text{margin-top:10px;color:var(--text);opacity:.92;font-weight:750;line-height:1.4}
.review-text.clamp{
  display:-webkit-box;
  -webkit-line-clamp:4;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
