:root{
  --vb-primary:#007DBA;
  --vb-primary-dark:#006A9F;
  --vb-bg:#f6f6f8;
  --vb-card:#ffffff;
  --vb-text:#1f2937;
  --vb-muted:#5f6b76;
  --vb-border:rgba(15, 23, 42, .10);
  --vb-shadow:0 10px 26px rgba(15, 23, 42, .08);
  --vb-radius:18px;
  --vb-max:1120px;
}

/* =========================================================
   BASE / DESKTOP
   ========================================================= */

*{box-sizing:border-box}
html,body{height:100%}

body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--vb-text);
  background:
    radial-gradient(1050px 520px at 18% -10%, rgba(0,125,186,.16), transparent 62%),
    radial-gradient(800px 420px at 88% 10%, rgba(0,125,186,.10), transparent 62%),
    var(--vb-bg);
  line-height:1.55;
}

a{color:var(--vb-primary); text-decoration:none}
a:hover{color:var(--vb-primary-dark); text-decoration:underline}

.wrap{max-width:1240px; margin:0 auto; padding:22px 12px 26px}
.shell{
  background: rgba(255,255,255,.55);
  border:1px solid rgba(15,23,42,.08);
  border-radius: 22px;
  box-shadow: 0 18px 40px rgba(15,23,42,.06);
  backdrop-filter: blur(6px);
  padding: 14px;
}

/* Header */
.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:10px 10px 16px;
}
.brand{display:flex; align-items:center; gap:12px; min-width:0}
.logo{
  width:62px; height:62px;
  border-radius:14px;
  background: rgba(255,255,255,.9);
  border:1px solid rgba(15,23,42,.10);
  display:grid; place-items:center;
  box-shadow:0 12px 22px rgba(15,23,42,.08);
  flex:0 0 auto;
  overflow:hidden;
}
.logo img,
.hub-logo img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
  padding:3px;
}
.brand-title{display:flex; flex-direction:column; gap:1px; min-width:0}
.brand-title strong{font-size:24px; letter-spacing:.2px}
.brand-title span{font-size:18px; color:var(--vb-muted)}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:12px;
  padding:10px 14px;
  font-weight:800;
  border:1px solid transparent;
  white-space:nowrap;
  transition: background .15s ease, transform .05s ease, box-shadow .15s ease, border-color .15s ease;
  user-select:none;
  cursor:pointer;
}
.btn:active{transform:translateY(1px)}
.btn-primary{
  background: var(--vb-primary);
  color:#fff;
  box-shadow:0 14px 26px rgba(0,125,186,.20);
}
.btn-primary:hover{background: var(--vb-primary-dark); text-decoration:none}
.btn-ghost{
  background: rgba(255,255,255,.88);
  border-color: rgba(15,23,42,.12);
  color: var(--vb-text);
  font-weight:700;
}
.btn-ghost:hover{border-color: rgba(0,125,186,.30); text-decoration:none}

/* Layout */
.main{padding: 0 10px 10px; display:grid; grid-template-columns: 1fr; gap:12px}
.card{
  background: var(--vb-card);
  border:1px solid var(--vb-border);
  border-radius: var(--vb-radius);
  box-shadow: var(--vb-shadow);
}
.card-pad{padding:20px}

.headline{
  margin:0 0 10px;
  font-size: clamp(22px, 2.4vw, 32px);
  line-height:1.15;
  letter-spacing:-.2px;
  text-align:center;
}
.subline{
  margin:0 auto 14px;
  max-width: 780px;
  color:var(--vb-muted);
  font-size:15px;
  text-align:center;
}

/* Promise pills */
.promise{
  display:flex; flex-wrap:wrap; gap:10px;
  justify-content:center;
  margin-top: 10px;
}
.pill{
  display:inline-flex; gap:9px; align-items:center;
  padding:8px 12px;
  border-radius:50%;
  border:1px solid rgba(15,23,42,.10);
  background:#fbfbfc;
  font-size:13px;
  color:#3b4650;
}
.dot{width:9px; height:9px; border-radius:50%; background:var(--vb-primary); display:inline-block}

/* HUB + RING */
.hub-wrap{
  position:relative;
  padding: 18px 12px 16px;
  min-height: 560px;
  overflow:hidden;
  border-top: 1px solid rgba(15,23,42,.06);
  background:
    radial-gradient(900px 420px at 50% 40%, rgba(0,125,186,.12), transparent 60%),
    radial-gradient(520px 280px at 18% 20%, rgba(0,125,186,.10), transparent 62%),
    radial-gradient(520px 280px at 82% 22%, rgba(0,125,186,.08), transparent 62%);
}

.ring-stage{
  position:absolute;
  inset: 6px 6px 10px;
  border-radius: 22px;
  background:
    radial-gradient(520px 240px at 50% 55%, rgba(0,125,186,.14), transparent 62%),
    radial-gradient(620px 300px at 50% 50%, rgba(255,255,255,.92), rgba(255,255,255,.75));
  border:1px solid rgba(0,125,186,.10);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.65);
  pointer-events:none;
}

.ring{
  position:relative;
  width:100%;
  height: 520px;
  border-radius: calc(var(--vb-radius) + 10px);
}
.ring-caption{
  margin: 34px auto 8px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  font-size:25px;
  font-weight:700;
  letter-spacing:.2px;
  color: var(--vb-muted);
}

.hub{position:absolute; inset:0; display:grid; place-items:center; pointer-events:none}
.hub-card{
  pointer-events:auto;
  width: clamp(300px, 34vw, 380px);
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  border:1px solid rgba(0,125,186,.16);
  background:
    radial-gradient(240px 220px at 35% 25%, rgba(0,125,186,.18), rgba(255,255,255,.92)),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.86));
  box-shadow:
    0 30px 70px rgba(15,23,42,.12),
    0 10px 24px rgba(0,125,186,.08);
  padding: 22px 18px;
  text-align:center;
  position:relative;

  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap: 6px;
}
.hub-card::before{
  content:"";
  position:absolute;
  inset:-10px;
  border-radius:999px;
  background: radial-gradient(closest-side, rgba(0,125,186,.14), transparent 65%);
  filter: blur(8px);
  z-index:-1;
}

.hub-logo{
  width:86px; height:86px;
  border-radius:22px;
  margin: 0 auto 10px;
  background: rgba(255,255,255,.9);
  border:1px solid rgba(15,23,42,.10);
  box-shadow:0 16px 34px rgba(15,23,42,.10);
  display:grid; place-items:center;
  overflow:hidden;
}
.hub-title{margin:0; font-size:20px; font-weight:900; letter-spacing:.2px}
.hub-text{margin:6px 0 0; color:var(--vb-muted); font-size:13.8px}
.hub-cta{margin-top: 14px; pointer-events:auto; display:flex; justify-content:center}

.practice{
  position:absolute;
  left:50%;
  top:50%;
  width: 250px;
  max-width: 52vw;

  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255,255,255,.92);
  border:1px solid rgba(15,23,42,.10);
  box-shadow:
    0 18px 36px rgba(15,23,42,.12),
    0 6px 14px rgba(15,23,42,.06);
  backdrop-filter: blur(6px);

  --r: clamp(260px, 28vw, 360px);

  transform:
    translate(-50%,-50%)
    rotate(var(--a))
    translate(var(--r))
    rotate(calc(-1 * var(--a)));

  transition: opacity .45s ease, transform .45s ease, box-shadow .2s ease, border-color .2s ease;
}
.practice:hover{
  border-color: rgba(0,125,186,.22);
  box-shadow:
    0 22px 42px rgba(15,23,42,.14),
    0 8px 18px rgba(15,23,42,.06);
}
.practice.is-fading{
  opacity:0;
  transform:
    translate(-50%,-50%)
    rotate(var(--a))
    translate(calc(var(--r) - 6px))
    rotate(calc(-1 * var(--a)));
}
.practice strong{display:block; font-size:15px; letter-spacing:-.1px}
.practice span{display:block; color:var(--vb-muted); font-size:13px; margin-top:3px}

.badge{
  display:inline-flex; align-items:center; gap:8px; margin-top:10px;
  font-size:12.6px; color:#33404a;
}
.shield{
  width:20px;height:20px;border-radius:7px;
  background: rgba(0,125,186,.10);
  border:1px solid rgba(0,125,186,.18);
  display:grid; place-items:center;
  flex:0 0 auto;
}
.shield svg{width:13px;height:13px;fill:var(--vb-primary)}

/* Search */
.search-row{display:flex; gap:10px; flex-wrap:wrap; align-items:center}

/* Conditions: Paket-Karten nebeneinander */
#konditionen .search-row{gap:20px; align-items:stretch}
#konditionen .search-row .faq-item{flex:1 1 320px; margin-top:0}
#paket-basis{border:2px solid var(--vb-primary); background:#f4f8fb}
#paket-pro{border:2px solid var(--vb-primary-dark); background:#e6f3fb}
#typisch{background:#f4f8fb}

/* Text-Absätze in Conditions */
.form-class{margin:0 0 10px; color:var(--vb-muted); line-height:1.55}
ul.form-class{margin-top:0; padding-left:18px}

.search-input{
  flex:1 1 320px;
  padding:12px 12px;
  border-radius:12px;
  border:1px solid rgba(15,23,42,.14);
  font-size:15px;
  outline:none;
}
.search-input:focus{border-color: rgba(0,125,186,.45); box-shadow: 0 0 0 4px rgba(0,125,186,.12)}
.hint{color:var(--vb-muted); font-size:13px; margin-top:8px}

.results-meta{margin-top:10px; color:var(--vb-muted); font-size:13px}
.results{
  margin-top:12px;
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:12px;
}

.result-card{padding:14px}
.result-title{font-weight:900; font-size:14px}
.result-sub{color:var(--vb-muted); font-size:13px; margin-top:2px}
.result-tags{margin-top:8px; display:flex; gap:8px; flex-wrap:wrap}
.result-privacy{margin-top:8px; color:var(--vb-muted); font-size:12.5px}

/* Buttons direkt in der Tile */
.book-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin-top:10px;
}
.btn-sm{
  padding:9px 12px;
  border-radius:12px;
  font-weight:800;
}
.btn-disabled{
  opacity:.55;
  cursor:not-allowed;
  pointer-events:none;
}

/* Footer */
.footer{
  margin-top: 10px;
  padding:14px 16px;
  display:flex; flex-wrap:wrap; gap:10px;
  align-items:center; justify-content:space-between;
  color:var(--vb-muted);
  font-size:13px;
}
.footer .links{display:flex; gap:14px; flex-wrap:wrap}

/* FAQ */
.faq-card{margin-top:12px}
.faq-title{
  margin:0 0 16px;
  font-size:18px;
  letter-spacing:-.2px;
}
.faq-item{
  padding:14px 16px;
  border-radius:14px;
  background:#ffffff;
  border:1px solid rgba(15,23,42,.08);
  box-shadow: 0 8px 18px rgba(15,23,42,.04);
}
.faq-item + .faq-item{margin-top:12px}
.faq-item h3{margin:0 0 6px; font-size:15px}
.faq-item p{margin:0; font-size:14px; color:var(--vb-muted); line-height:1.5}

/* =========================================================
   Paket-Gemeinsam: Abschnittstitel ohne Bullet (global!)
   ========================================================= */
#paket-gemeinsam li.section-title{
  list-style: none !important;
  margin-top: 16px;
  margin-bottom: 6px;
  font-weight: 700;
  padding-left: 0;
}
#paket-gemeinsam li.section-title::marker{
  content: "" !important;
}
/* falls Bullets per ::before erzeugt werden */
#paket-gemeinsam li.section-title::before{
  content: none !important;
  display: none !important;
}

/* =========================================================
   Admin (scoped): NUR vetbooking.html
   Voraussetzung: <div class="vb-admin"> ... </div>
   ========================================================= */

.vb-admin .card-pad{
  max-width: 1060px;
  margin: 0 auto;
}

.vb-admin form{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px 28px;
  align-items:start;
}

.vb-admin .vb-full{grid-column: 1 / -1;}
.vb-admin .vb-block{min-width: 0;}

.vb-admin .faq-title{
  margin: 22px 0 10px;
  padding-top: 14px;
  border-top: 1px solid rgba(15,23,42,.08);
  font-size: 16px;
  letter-spacing: 0;
}
.vb-admin .vb-block .faq-title:first-of-type{
  border-top: 0;
  padding-top: 0;
  margin-top: 0;
}

.vb-admin form label{
  display:block;
  font-weight:700;
  margin-top: 12px;
  margin-bottom: 6px;
}

.vb-admin form input[type="text"],
.vb-admin form input[type="url"],
.vb-admin form input[type="time"],
.vb-admin form select{
  width:100%;
  max-width: 680px;
}

.vb-admin .vb-req{
  color: #b91c1c;
  font-weight: 800;
}

.vb-admin .vb-check{
  display:flex;
  align-items:center;
  gap:8px;
  font-weight:700;
  margin-top: 10px;
}

.vb-admin #result{
  margin-top:18px;
  background:#f8fafc;
  border:1px solid rgba(15,23,42,.08);
  border-radius:14px;
  padding:12px 14px;
  font-size:13px;
  color:#334155;
  white-space:pre-wrap;
}

/* Öffnungszeiten */
.vb-admin .vb-hours{margin-top: 8px;}
.vb-admin .vb-hours-row{
  display:grid;
  grid-template-columns: 120px repeat(2, 92px) 48px repeat(2, 92px) auto;
  gap: 10px;
  align-items:center;
  padding: 8px 0;
}
.vb-admin .vb-hours-row:not(:last-child){
  border-bottom: 1px solid rgba(15,23,42,.06);
}
.vb-admin .vb-hours-day{font-weight: 800;}
.vb-admin .vb-hours-sep{
  text-align:center;
  font-size:13px;
  color: var(--vb-muted);
}
.vb-admin .vb-hours-toggle{
  font-size:13px;
  color: var(--vb-primary);
  cursor:pointer;
  user-select:none;
  white-space:nowrap;
}

/* Sticky Save */
.vb-admin .vb-actions{
  position: sticky;
  bottom: 10px;
  z-index: 5;
  display:flex;
  align-items:center;
  gap: 12px;
  padding-top: 12px;
  margin-top: 8px;

  background: rgba(255,255,255,.90);
  backdrop-filter: blur(6px);
  border-top: 1px solid rgba(15,23,42,.08);
}

.vb-admin .vb-actions-hint{
  font-size: 13px;
  color: var(--vb-muted);
}

/* Domain input */
.vb-admin .vb-domain{
  display:flex;
  align-items:center;
  gap:10px;
}
.vb-admin .vb-domain input{
  flex: 1 1 auto;
  min-width: 160px;
}
.vb-admin .vb-domain-prefix,
.vb-admin .vb-domain-suffix{
  padding: 10px 12px;
  border: 1px solid var(--vb-border, rgba(15,23,42,.16));
  border-radius: 12px;
  background: rgba(255,255,255,.88);
  color: var(--vb-muted, rgba(15,23,42,.68));
  white-space: nowrap;
}
.vb-admin .vb-domain-hint{
  margin-top: 6px;
  color: var(--vb-muted, rgba(15,23,42,.68));
}
.vb-admin .vb-domain-hint.is-error{
  color: #b91c1c;
  font-weight: 700;
}
.vb-admin .vb-actions.vb-full{margin-top: 12px;}

/* Öffnungszeiten – Fix: identische Feldbreite (time) */
.vb-admin .vb-timeblock{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.vb-admin .vb-timeblock input[type="time"]{
  width: 120px !important;
  flex: 0 0 120px;
  max-width: 120px;
}
.vb-admin .vb-hours-toggle-spacer{visibility: hidden;}

/* Booking Screens (index.html) */
.vb-booking-flow{
  max-width: 1200px;
  margin: 3.5rem auto;
  padding: 0 1.25rem;
}
.vb-booking-flow h2{
  text-align: center;
  margin: 0 0 2rem 0;
}

/* 4 Spalten Desktop */
.vb-booking-steps{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.5rem;
  align-items: start;
  justify-items: center;
}
.vb-booking-steps figure{
  margin: 0;
  display: flex;
  flex-direction: column;
  text-align: center;
  align-items: center;
  height: 100%;
}
.vb-booking-steps img{
  width: 100%;
  height: auto;
  max-width: 200px;
  display: block;
  margin: 0 auto;
  border-radius: 8px;
}
.vb-booking-steps figcaption{
  margin-top: auto;
  padding-top: .75rem;
  min-height: 2.6em;
  line-height: 1.3;
  font-size: .95rem;
  color: #555;
}

/* Screenshots global */
.image-block{
  margin: 1.6rem auto;
  max-width: 560px;
}
.image-block img{
  display: block;
  width: 100%;
  max-width: 560px;
  height: auto;
  margin: 0 auto;
  border-radius: 4px;
  box-shadow: 0 3px 10px rgba(0,0,0,.05);
}
.image-caption{
  margin-top: .35rem;
  font-size: .8rem;
  color: #777;
  text-align: center;
}

/* tieraerzte.html – Text links, Screenshot rechts + Grid */
.text-image-row{
  display:flex;
  align-items:flex-start;
  gap: 24px;
}
.text-image-row .text-col{flex: 1 1 auto; min-width: 0;}
.text-image-row .image-col{
  flex: 0 0 420px;
  max-width: 420px;
}

.image-block--tight{
  max-width: 420px;
  margin: 0;
}
.image-block--tight img{max-width: 420px;}

.image-grid-2{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  align-items:start;
  margin-top: 12px;
}
.image-block--grid{max-width: 100%; margin: 0;}
.image-block--grid img{max-width: 100%;}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .btn{transition:none}
  .btn:active{transform:none}
  .practice{transition:none}
  .practice.is-fading{
    opacity:1;
    transform:
      translate(-50%,-50%)
      rotate(var(--a))
      translate(var(--r))
      rotate(calc(-1 * var(--a)));
  }
}

/* =========================================================
   TABLET (<= 980px)
   ========================================================= */

@media (max-width: 980px){
  .hub-wrap{min-height: 720px}
  .ring{height:720px}
  .hub-card{width:min(420px, 92%);}
  .practice{
    width: min(420px, 90vw);
    --r: clamp(240px, 40vw, 320px);
  }
  .results{grid-template-columns:1fr}
  .ring-stage{inset: 6px 6px 10px;}

  .vb-admin form{grid-template-columns: 1fr;}

  .vb-booking-steps{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .vb-booking-steps img{max-width: 420px;}

  .text-image-row .image-col{
    flex-basis: 360px;
    max-width: 360px;
  }
  .image-block--tight{max-width: 360px;}
  .image-block--tight img{max-width: 360px;}
}

/* =========================================================
   MOBILE (<= 768px / <=700px / <=640px / <=520px)
   ========================================================= */

@media (max-width: 768px){
  .text-image-row{
    flex-direction: column;
    gap: 14px;
  }
  .text-image-row .image-col{
    flex: none;
    max-width: 100%;
  }
  .image-block--tight{
    max-width: 100%;
    margin: 0 auto;
  }
  .image-block--tight img{max-width: 100%;}
  .image-grid-2{
    grid-template-columns: 1fr;
    gap: 14px;
  }

  /* Mobile Karten-Hervorhebung – identisch zur Desktop-Logik */
  #paket-basis,
  #paket-pro{
    border-radius: 16px;
    padding: 18px;
    margin-bottom: 20px;
    background: #f6fbff;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.06);
  }
  #paket-basis{border: 1px solid #cfe6f4;}
  #paket-pro{
    border: 2px solid #007DBA;
    background: #eef7fd;
    box-shadow: 0 8px 22px rgba(0, 125, 186, 0.15);
  }
}

/* Orbit -> Kacheln (<=700px) */
@media (max-width: 700px){
  .hub-wrap{min-height:auto; padding: 14px 10px 16px;}
  .ring{height:auto; display:flex; flex-direction:column; gap:12px; padding: 8px 6px 16px;}
  .practice{
    position:relative;
    left:auto; top:auto;
    transform:none;
    width:100%;
    max-width:none;
    order:2;
  }
  .hub{
    position:relative;
    inset:auto;
    display:block;
    order:1;
  }
  .hub-card{
    margin: 6px auto 10px;
    width: min(360px, 92%);
  }
  .logo{width:52px; height:52px;}
  .hub-logo{width:72px; height:72px;}
  .logo img,
  .hub-logo img{padding:0;}
}

/* Header Buttons umbrechen (<=640px) */
@media (max-width: 640px){
  .topbar{
    flex-wrap: wrap;
    gap: 10px;
    align-items: flex-start;
  }
  .topbar .brand{flex: 1 1 100%;}
  .topbar > a.btn.btn-ghost{
    flex: 1 1 calc(50% - 10px);
    justify-content: center;
    text-align: center;
    white-space: nowrap;
  }
  .topbar > a.btn.btn-ghost:last-of-type{flex-basis: 100%;}

  /* Mobile: Swipe durch 4 Schritte (Scroll-Snap) */
  .vb-booking-steps{
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 92%;
    grid-template-columns: none;
    gap: 0.5rem;

    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding: 0 0.25rem 0.5rem;

    scrollbar-width: thin;
  }
  .vb-booking-steps figure{
    scroll-snap-align: center;
    scroll-snap-stop: always;
    padding: 0;
  }
  .vb-booking-steps img{
    width: 100%;
    max-width: 420px;
  }

  /* Mobile: White-Padding schlanker */
  .wrap{padding: 12px 8px 16px;}
  .shell{padding: 8px; border-radius: 18px;}
  .main{padding: 0 6px 8px; gap: 10px;}
  .card-pad{padding: 14px;}

  .vb-booking-flow{
    margin: 2rem auto;
    padding: 0 0.5rem;
  }
  .vb-booking-flow h2{margin-bottom: 1.25rem;}
}

@media (max-width: 520px){
  .practice{ --r: clamp(200px, 56vw, 260px); }
}
