/* kreatigo Buchungs-Widget · Theming nur über diese CSS-Variablen ────────── */
.kb {
  --kb-accent:   #C8788E;
  --kb-accent-fg:#ffffff;
  --kb-bg:       #ffffff;
  --kb-surface:  #faf6f7;
  --kb-border:   #e7dde0;
  --kb-text:     #2a2226;
  --kb-muted:    #8a7e83;
  --kb-radius:   14px;
  --kb-font:     system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  font-family: var(--kb-font); color: var(--kb-text);
  max-width: 560px; margin: 0 auto;
}
.kb *, .kb *::before, .kb *::after { box-sizing: border-box; }

.kb-steps { display:flex; gap:8px; margin-bottom:20px; }
.kb-step  { flex:1; height:4px; border-radius:99px; background:var(--kb-border); transition:.3s; }
.kb-step.on { background:var(--kb-accent); }

.kb-h { font-size:1.15rem; font-weight:650; margin:0 0 4px; }
.kb-sub { color:var(--kb-muted); font-size:.9rem; margin:0 0 16px; }

.kb-cards { display:grid; gap:10px; }
.kb-card {
  display:flex; justify-content:space-between; align-items:center; gap:12px;
  padding:14px 16px; border:1px solid var(--kb-border); border-radius:var(--kb-radius);
  background:var(--kb-bg); color:var(--kb-text); cursor:pointer; text-align:left; transition:.15s; width:100%;
}
.kb-card:hover { border-color:var(--kb-accent); transform:translateY(-1px); }
.kb-card.sel  { border-color:var(--kb-accent); box-shadow:0 0 0 1px var(--kb-accent) inset; }
.kb-card-name { display:block; font-weight:600; }
.kb-card-desc { display:block; color:var(--kb-muted); font-size:.82rem; margin-top:3px; }
.kb-card-meta { color:var(--kb-muted); font-size:.82rem; white-space:nowrap; text-align:right; }
.kb-card-price { color:var(--kb-text); font-weight:600; }

.kb-row { display:flex; gap:10px; flex-wrap:wrap; align-items:center; margin-bottom:14px; }
.kb-date { padding:11px 13px; border:1px solid var(--kb-border); border-radius:10px; font:inherit; color:inherit; background:var(--kb-bg); }

.kb-slots { display:grid; grid-template-columns:repeat(auto-fill,minmax(84px,1fr)); gap:8px; }
.kb-slot  { padding:11px 6px; border:1px solid var(--kb-border); border-radius:10px; background:var(--kb-bg);
  color:var(--kb-text); cursor:pointer; font:inherit; font-weight:600; transition:.12s; }
.kb-slot:hover { border-color:var(--kb-accent); }
.kb-slot.sel { background:var(--kb-accent); color:var(--kb-accent-fg); border-color:var(--kb-accent); }
.kb-empty { color:var(--kb-muted); font-size:.9rem; padding:14px 0; }

.kb-field { margin-bottom:12px; }
.kb-field label { display:block; font-size:.82rem; color:var(--kb-muted); margin-bottom:5px; }
.kb-field input, .kb-field textarea {
  width:100%; padding:11px 13px; border:1px solid var(--kb-border); border-radius:10px;
  font:inherit; color:inherit; background:var(--kb-bg); }
.kb-field textarea { min-height:74px; resize:vertical; }

.kb-summary { background:var(--kb-surface); border-radius:var(--kb-radius); padding:14px 16px; margin-bottom:16px; font-size:.92rem; }
.kb-summary b { font-weight:650; }

.kb-actions { display:flex; gap:10px; margin-top:18px; }
.kb-btn {
  flex:1; padding:13px 18px; border-radius:11px; border:0; font:inherit; font-weight:650; cursor:pointer;
  background:var(--kb-accent); color:var(--kb-accent-fg); transition:.15s; }
.kb-btn:hover { filter:brightness(1.05); }
.kb-btn:disabled { opacity:.5; cursor:not-allowed; }
.kb-btn.ghost { background:transparent; color:var(--kb-muted); border:1px solid var(--kb-border); flex:0 0 auto; }

.kb-done { text-align:center; padding:24px 8px; }
.kb-done .check { width:56px; height:56px; border-radius:50%; background:var(--kb-accent); color:var(--kb-accent-fg);
  display:grid; place-items:center; margin:0 auto 14px; font-size:1.6rem; }
.kb-err { color:#c0392b; font-size:.88rem; margin-top:10px; min-height:1.1em; }
