/* ============================================================
   COSMOCLEAN – style.css  (Apple-inspired Design)
   ============================================================
   Brand Colors
   #000033  CC-Deep-Blue
   #000066  CC-Blue
   #66CD57  CC-Green   ← Primärakzent
   #B5FFA6  CC-Light-Green
   #EEFFEE  CC-Off-White
   ============================================================ */

/* ── CUSTOM PROPERTIES ── */
:root {
  /* Brand */
  --cc-dark:    #000033;
  --cc-blue:    #000066;
  --cc-green:   #66CD57;
  --cc-greend:  #4ab83c;
  --cc-lgreen:  #B5FFA6;
  --cc-bg:      #EEFFEE;
  --cc-border:  rgba(0, 0, 0, .08);
  --cc-text:    #1d1d1f;        /* Apple-typisches dunkles Grau */
  --cc-muted:   #6e6e73;        /* Apple-secondary-label */
  --cc-white:   #ffffff;

  /* Radius – moderat, nicht zu rund */
  --r-sm:  7px;
  --r-md:  12px;
  --r-lg:  16px;
  --r-xl:  18px;

  /* Schatten – sehr weich wie bei Apple */
  --sh-xs: 0 1px 3px  rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --sh-sm: 0 2px 8px  rgba(0,0,0,.07), 0 1px 3px rgba(0,0,0,.05);
  --sh-md: 0 8px 24px rgba(0,0,0,.08), 0 2px 8px rgba(0,0,0,.05);
  --sh-lg: 0 20px 60px rgba(0,0,0,.12), 0 4px 16px rgba(0,0,0,.06);

  --transition: .22s cubic-bezier(.4, 0, .2, 1);
}

/* ─────────────────────────────────────────
   SATOSHI – Selbst gehostete Variable Font
───────────────────────────────────────── */
@font-face {
  font-family: 'Satoshi';
  src: url('fonts/Satoshi-Variable.woff2') format('woff2'),
       url('fonts/Satoshi-Variable.woff')  format('woff');
  font-weight: 300 900;   /* deckt Light → Black ab */
  font-display: swap;
  font-style: normal;
}

/* ─────────────────────────────────────────
   RESET & BASE
───────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  /* Satoshi zuerst, danach System-Fallbacks */
  font-family: 'Satoshi', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  font-size: 15px;
  line-height: 1.6;
  color: var(--cc-text);
  /* Leicht grün getönter Hintergrund */
  background: #f0f7f0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-height: 100vh;
}

/* ─────────────────────────────────────────
   HEADER – frosted glass wie macOS Menüleiste
───────────────────────────────────────── */
.cc-header {
  position: sticky;
  top: 0;
  z-index: 200;
  background: rgba(0, 0, 51, .88);
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.cc-header-inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 12px 24px;
  display: flex;
  align-items: center;
  gap: 14px;
}

.cc-logo {
  height: 42px;
  width: auto;
  /* Kein Filter – Logo-3-Off-green-white.svg ist für dunkle Hintergründe optimiert */
  flex-shrink: 0;
}

.cc-logo-fallback {
  color: var(--cc-white);
  font-size: 1.05rem;
  font-weight: 700;
}

.cc-header-title {
  color: var(--cc-white);
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: -.02em;
  margin: 0;
}

.cc-header-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: rgba(102, 205, 87, .18);
  color: var(--cc-lgreen);
  border: .5px solid rgba(181,255,166,.3);
  border-radius: 20px;
  padding: 2px 9px;
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .04em;
  margin-top: 4px;
}

/* Grüner Akzent-Streifen */
.cc-stripe {
  height: 3px;
  background: linear-gradient(90deg, var(--cc-green) 0%, var(--cc-lgreen) 70%, transparent 100%);
}

/* ─────────────────────────────────────────
   HERO
───────────────────────────────────────── */
.cc-hero {
  background: linear-gradient(160deg, var(--cc-dark) 0%, #001a4d 60%, #002a1a 100%);
  padding: 48px 24px 54px;
  position: relative;
  overflow: hidden;
}

/* Subtile Licht-Kugel im Hintergrund */
.cc-hero::after {
  content: '';
  position: absolute;
  top: -60px; right: -80px;
  width: 360px; height: 360px;
  background: radial-gradient(circle, rgba(102,205,87,.18) 0%, transparent 70%);
  pointer-events: none;
}

.cc-hero-inner {
  max-width: 900px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.cc-hero-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(102,205,87,.15);
  color: var(--cc-lgreen);
  border: .5px solid rgba(181,255,166,.3);
  border-radius: 20px;
  padding: 5px 13px;
  font-size: .73rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 16px;
}

.cc-hero h2 {
  color: var(--cc-white);
  font-size: clamp(1.5rem, 4vw, 2rem);
  font-weight: 700;
  letter-spacing: -.03em;
  line-height: 1.2;
  margin-bottom: 12px;
}

.cc-hero p {
  color: rgba(255,255,255,.65);
  font-size: .92rem;
  max-width: 480px;
  line-height: 1.65;
}

.cc-hero-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 22px;
}

.cc-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,.07);
  color: rgba(255,255,255,.8);
  border: .5px solid rgba(255,255,255,.13);
  border-radius: 20px;
  padding: 6px 13px;
  font-size: .76rem;
  font-weight: 500;
  backdrop-filter: blur(8px);
}

.cc-pill i { color: var(--cc-green); }

/* ─────────────────────────────────────────
   SCHRITT-LEISTE
───────────────────────────────────────── */
.cc-progress-bar {
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(0,0,0,.06);
}

.cc-progress-inner {
  max-width: 900px;
  margin: 0 auto;
  display: flex;
  overflow-x: auto;
  scrollbar-width: none;
}

.cc-progress-inner::-webkit-scrollbar { display: none; }

.cc-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 11px 14px;
  font-size: .69rem;
  font-weight: 600;
  letter-spacing: .02em;
  color: var(--cc-muted);
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: color var(--transition), border-color var(--transition);
  gap: 3px;
  cursor: default;
}

.cc-step i { font-size: .88rem; }

.cc-step.active {
  color: var(--cc-dark);
  border-bottom-color: var(--cc-green);
}

.cc-step.active i { color: var(--cc-green); }

/* ─────────────────────────────────────────
   HAUPT-WRAPPER
───────────────────────────────────────── */
.cc-main {
  max-width: 900px;
  margin: 28px auto 64px;
  padding: 0 16px;
}

/* ─────────────────────────────────────────
   KARTEN – Apple-Card-Stil
───────────────────────────────────────── */
.cc-card {
  background: var(--cc-white);
  border-radius: var(--r-xl);          /* großzügig gerundet */
  box-shadow: var(--sh-sm);
  border: .5px solid rgba(0,0,0,.06);
  margin-bottom: 14px;
  /* overflow: hidden entfernt – verhinderte sonst das Dropdown-Panel */
  transition: box-shadow var(--transition), transform var(--transition);
}

.cc-card:hover {
  box-shadow: var(--sh-md);
  transform: translateY(-1px);
}

/* Farbiger Topbar */
.cc-card::before {
  content: '';
  display: block;
  height: 3px;
  background: linear-gradient(90deg, var(--cc-green), var(--cc-lgreen) 80%, transparent);
  border-radius: var(--r-xl) var(--r-xl) 0 0;  /* obere Ecken abrunden wie die Card */
}

.cc-card-body { padding: 26px 30px 28px; }

/* Abschnitts-Header */
.cc-section-head {
  display: flex;
  align-items: center;
  gap: 11px;
  margin-bottom: 20px;
  padding-bottom: 14px;
  border-bottom: 1px solid #f2f2f7;   /* Apple-typische sehr helle Linie */
}

.cc-num {
  background: var(--cc-dark);
  color: var(--cc-green);
  border-radius: 50%;
  width: 30px; height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .74rem;
  font-weight: 800;
  flex-shrink: 0;
  letter-spacing: 0;
}

.cc-section-title {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--cc-muted);
  margin: 0;
}

.cc-section-icon {
  color: var(--cc-green);
  font-size: .95rem;
  margin-left: auto;
  opacity: .5;
}

/* ─────────────────────────────────────────
   FORM-LABELS & HELPER
───────────────────────────────────────── */
.form-label {
  font-size: .8rem;
  font-weight: 600;
  color: var(--cc-muted);
  margin-bottom: 7px;
  display: block;
  letter-spacing: .01em;
}

.req  { color: var(--cc-green); margin-left: 2px; }
.opt  { color: #aeaeb2; font-weight: 400; font-size: .75rem; margin-left: 4px; }

/* ─────────────────────────────────────────
   INPUTS – Apple-Style (filled look)
───────────────────────────────────────── */
.form-control,
.form-select {
  background: #f5f5f7;               /* Apple-typisches Eingabefeld-Grau */
  border: 1.5px solid transparent;
  border-radius: var(--r-sm);
  padding: 11px 14px;
  font-size: .9rem;
  font-family: inherit;
  color: var(--cc-text);
  width: 100%;
  transition: background var(--transition), border-color var(--transition),
              box-shadow var(--transition);
  -webkit-appearance: none;
  appearance: none;
}

.form-control::placeholder { color: #bbbbc0; }

.form-control:focus,
.form-select:focus {
  outline: none;
  background: var(--cc-white);
  border-color: var(--cc-green);
  box-shadow: 0 0 0 4px rgba(102,205,87,.15);
}

.form-control.is-invalid {
  background: #fff5f5;
  border-color: #ff3b30 !important;   /* Apple-Rot */
  box-shadow: 0 0 0 4px rgba(255,59,48,.12) !important;
}

textarea.form-control {
  min-height: 108px;
  resize: vertical;
  line-height: 1.55;
}

/* Custom Select-Pfeil */
.form-select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='%2366CD57' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14L2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 40px;
  cursor: pointer;
}

/* ─────────────────────────────────────────
   KACHELN (Checkbox / Radio)
───────────────────────────────────────── */
.cc-tile-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}

.cc-tile {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: var(--r-sm);
  border: 1.5px solid #e8e8ed;       /* Apple-typisch */
  background: #f5f5f7;
  cursor: pointer;
  font-size: .87rem;
  font-weight: 500;
  color: var(--cc-text);
  user-select: none;
  width: 100%;
  transition: background var(--transition), border-color var(--transition),
              box-shadow var(--transition);
  -webkit-tap-highlight-color: transparent;
}

.cc-tile:hover {
  background: #eef8ec;
  border-color: rgba(102,205,87,.5);
}

/* Checked – grüner Tint wie iOS Selektion */
.cc-tile:has(input:checked) {
  background: rgba(102,205,87,.1);
  border-color: var(--cc-green);
  color: var(--cc-dark);
  font-weight: 600;
  box-shadow: 0 0 0 0px rgba(102,205,87,.3);
}

.cc-tile input[type="checkbox"],
.cc-tile input[type="radio"] {
  width: 18px; height: 18px;
  accent-color: var(--cc-green);
  flex-shrink: 0;
  cursor: pointer;
}

.cc-tile-icon {
  color: var(--cc-green);
  font-size: .85rem;
  flex-shrink: 0;
  opacity: .75;
}

/* Freitextfeld Sonstiges */
#sonstiges-feld {
  display: none;
  grid-column: 1 / -1;
  margin-top: 4px;
}

/* ─────────────────────────────────────────
   TABELLE
───────────────────────────────────────── */
.cc-table-wrap {
  overflow-x: auto;
  border-radius: var(--r-md);
  box-shadow: var(--sh-xs);
  margin-bottom: 22px;
}

.cc-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 360px;
  background: var(--cc-white);
}

.cc-table thead th {
  background: var(--cc-dark);
  color: var(--cc-lgreen);
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 12px 16px;
  text-align: left;
}

.cc-table thead th:first-child { border-radius: var(--r-md) 0 0 0; }
.cc-table thead th:last-child  { border-radius: 0 var(--r-md) 0 0; text-align: center; }

.cc-table tbody tr { transition: background var(--transition); }

.cc-table tbody tr:hover td { background: #f0fce9; }

.cc-table tbody td {
  padding: 13px 16px;
  font-size: .87rem;
  border-bottom: 1px solid #f2f2f7;
  vertical-align: middle;
}

.cc-table tbody tr:last-child td { border-bottom: none; }

.cc-table td:last-child { text-align: center; }

.size-name {
  font-weight: 700;
  font-size: .88rem;
  color: var(--cc-dark);
}

.size-range {
  font-size: .74rem;
  color: var(--cc-muted);
}

.cc-table input[type="number"] {
  width: 76px;
  text-align: center;
  background: #f5f5f7;
  border: 1.5px solid transparent;
  border-radius: var(--r-sm);
  padding: 7px 8px;
  font-size: .9rem;
  font-family: inherit;
  font-weight: 600;
  color: var(--cc-dark);
  transition: background var(--transition), border-color var(--transition),
              box-shadow var(--transition);
}

.cc-table input[type="number"]:focus {
  outline: none;
  background: var(--cc-white);
  border-color: var(--cc-green);
  box-shadow: 0 0 0 4px rgba(102,205,87,.15);
}

/* ─────────────────────────────────────────
   DATEI-UPLOAD
───────────────────────────────────────── */
.cc-upload {
  border: 1.5px dashed #ccccd3;
  border-radius: var(--r-lg);
  background: #f5f5f7;
  padding: 34px 20px;
  text-align: center;
  cursor: pointer;
  transition: border-color var(--transition), background var(--transition),
              box-shadow var(--transition);
}

.cc-upload:hover {
  border-color: var(--cc-green);
  background: #eef8ec;
  box-shadow: 0 0 0 4px rgba(102,205,87,.1);
}

.cc-upload input[type="file"] { display: none; }

.cc-upload-icon {
  font-size: 2rem;
  color: var(--cc-green);
  margin-bottom: 10px;
  opacity: .85;
}

.cc-upload-title {
  font-size: .92rem;
  font-weight: 600;
  color: var(--cc-dark);
  display: block;
  margin-bottom: 5px;
}

.cc-upload-hint {
  font-size: .76rem;
  color: var(--cc-muted);
}

/* ─────────────────────────────────────────
   UPLOAD – Drag-State & kompakt
───────────────────────────────────────── */
.cc-upload-drag {
  border-color: var(--cc-green);
  background: rgba(102,205,87,.07);
  transform: scale(1.01);
}

.cc-upload-compact {
  padding: 12px 20px;
  flex-direction: row;
  gap: 12px;
  justify-content: flex-start;
}

.cc-upload-compact .cc-upload-hint { display: none; }

/* ─────────────────────────────────────────
   BILDVORSCHAU-RASTER
───────────────────────────────────────── */
.cc-preview-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 14px;
}

.cc-preview-card {
  position: relative;
  border-radius: var(--r-md);
  overflow: hidden;
  background: #f5f5f7;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: var(--sh-sm);
  aspect-ratio: 1 / 1;
  animation: fadeScaleIn .2s cubic-bezier(.4,0,.2,1);
}

@keyframes fadeScaleIn {
  from { opacity: 0; transform: scale(.92); }
  to   { opacity: 1; transform: scale(1);   }
}

.cc-preview-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.cc-preview-name {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: rgba(0,0,20,.55);
  color: #fff;
  font-size: .65rem;
  font-weight: 500;
  padding: 4px 7px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.cc-preview-remove {
  position: absolute;
  top: 5px; right: 5px;
  width: 22px; height: 22px;
  border-radius: 50%;
  border: none;
  background: rgba(0,0,0,.55);
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .7rem;
  line-height: 1;
  transition: background var(--transition);
}

.cc-preview-remove:hover { background: rgba(200,30,30,.8); }

/* ─────────────────────────────────────────
   HONEYPOT (für Menschen komplett unsichtbar)
───────────────────────────────────────── */
.cc-honeypot {
  display: none !important;   /* Browser ignoriert Feld komplett – kein Validierungs-Tooltip */
}

/* ─────────────────────────────────────────
   reCAPTCHA-BEREICH
───────────────────────────────────────── */
.cc-recaptcha-wrap {
  display: flex;
  justify-content: center;
  margin-bottom: 18px;
  min-height: 0;        /* wird 0 wenn reCAPTCHA noch nicht aktiv */
}

.cc-recaptcha-wrap:empty { display: none; }

/* ─────────────────────────────────────────
   SUBMIT-SPINNER
───────────────────────────────────────── */
.btn-cc-spinner {
  display: none;
  width: 16px;
  height: 16px;
  border: 2.5px solid rgba(0,0,30,.25);
  border-top-color: var(--cc-dark);
  border-radius: 50%;
  animation: spin .7s linear infinite;
  flex-shrink: 0;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

.btn-cc-loading {
  opacity: .82;
  cursor: not-allowed;
  pointer-events: none;
}

/* ─────────────────────────────────────────
   ABSENDE-BEREICH
───────────────────────────────────────── */
.cc-submit-wrap {
  background: var(--cc-white);
  border-radius: var(--r-xl);
  border: .5px solid rgba(0,0,0,.06);
  box-shadow: var(--sh-sm);
  padding: 36px 30px;
  text-align: center;
  overflow: hidden;
  position: relative;
}

/* Sehr subtiler grüner Glow oben */
.cc-submit-wrap::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--cc-green), var(--cc-lgreen) 70%, transparent);
}

/* Apple-Stil Button */
.btn-cc {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--cc-green);
  color: var(--cc-dark);
  border: none;
  border-radius: var(--r-lg);        /* pill-ähnlich */
  padding: 15px 48px;
  font-size: .97rem;
  font-weight: 700;
  font-family: inherit;
  letter-spacing: -.01em;
  cursor: pointer;
  box-shadow: 0 4px 20px rgba(102,205,87,.4), 0 1px 4px rgba(0,0,0,.1);
  transition: background var(--transition), transform var(--transition),
              box-shadow var(--transition);
  -webkit-tap-highlight-color: transparent;
}

.btn-cc:hover {
  background: var(--cc-greend);
  transform: translateY(-2px) scale(1.01);
  box-shadow: 0 8px 28px rgba(102,205,87,.5), 0 2px 8px rgba(0,0,0,.1);
}

.btn-cc:active {
  transform: scale(.98);
  box-shadow: 0 2px 10px rgba(102,205,87,.3);
}

.cc-privacy {
  font-size: .73rem;
  color: #aeaeb2;
  margin-top: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  letter-spacing: .01em;
}

.cc-privacy i { color: var(--cc-green); opacity: .8; }

/* ─────────────────────────────────────────
   SUB-LABEL
───────────────────────────────────────── */
.cc-sub-label {
  font-size: .72rem;
  font-weight: 700;
  color: var(--cc-muted);
  text-transform: uppercase;
  letter-spacing: .09em;
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 10px;
  margin-top: 20px;
}

.cc-sub-label i { color: var(--cc-green); }

/* ─────────────────────────────────────────
   INFO-BOX
───────────────────────────────────────── */
.cc-info-box {
  background: #f0fce9;
  border-radius: var(--r-sm);
  padding: 10px 14px;
  font-size: .8rem;
  color: #2e6b22;
  margin-bottom: 16px;
  display: flex;
  align-items: flex-start;
  gap: 8px;
  border: .5px solid rgba(102,205,87,.3);
}

.cc-info-box i { color: var(--cc-green); flex-shrink: 0; margin-top: 1px; }

/* ─────────────────────────────────────────
   TOAST
───────────────────────────────────────── */
.cc-toast-wrap {
  position: fixed;
  bottom: 28px;
  right: 20px;
  z-index: 9999;
}

.toast {
  border-radius: var(--r-md) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: var(--sh-lg) !important;
}

/* ─────────────────────────────────────────
   DANKE-SEITE
───────────────────────────────────────── */
.cc-thanks-wrap {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.cc-thanks-main {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px 16px;
}

.cc-thanks-card {
  background: var(--cc-white);
  border-radius: var(--r-xl);
  box-shadow: var(--sh-lg);
  border: .5px solid rgba(0,0,0,.05);
  overflow: hidden;
  max-width: 500px;
  width: 100%;
  text-align: center;
}

.cc-thanks-card::before {
  content: '';
  display: block;
  height: 3px;
  background: linear-gradient(90deg, var(--cc-green), var(--cc-lgreen) 70%, transparent);
}

.cc-thanks-body { padding: 44px 40px 48px; }

.cc-check-ring {
  width: 82px; height: 82px;
  border-radius: 50%;
  background: rgba(102,205,87,.1);
  border: 2px solid rgba(102,205,87,.4);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 26px;
  animation: popIn .5s cubic-bezier(.36,.07,.19,.97);
}

@keyframes popIn {
  0%   { transform: scale(.3); opacity: 0; }
  70%  { transform: scale(1.08); }
  100% { transform: scale(1); opacity: 1; }
}

.cc-thanks-card h2 {
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: -.03em;
  color: var(--cc-dark);
  margin-bottom: 12px;
}

.cc-thanks-card .lead {
  font-size: .93rem;
  color: var(--cc-text);
  line-height: 1.65;
  margin-bottom: 6px;
}

.cc-thanks-card .sub {
  font-size: .78rem;
  color: var(--cc-muted);
  margin-bottom: 0;
}

.cc-thanks-hr {
  border: none;
  border-top: 1px solid #f2f2f7;
  margin: 26px 0;
}

/* Schritt-Liste auf Danke-Seite */
.cc-steps-list {
  list-style: none;
  text-align: left;
  margin-bottom: 24px;
}

.cc-steps-list li {
  display: flex;
  align-items: center;
  gap: 13px;
  font-size: .85rem;
  color: var(--cc-text);
  padding: 8px 0;
  border-bottom: 1px solid #f2f2f7;
}

.cc-steps-list li:last-child { border-bottom: none; }

.step-dot {
  background: var(--cc-green);
  color: var(--cc-dark);
  border-radius: 50%;
  width: 24px; height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .72rem;
  font-weight: 800;
  flex-shrink: 0;
}

.cc-contact-box {
  background: #f5f5f7;
  border-radius: var(--r-md);
  padding: 14px 18px;
  margin-bottom: 26px;
  font-size: .84rem;
  color: var(--cc-muted);
}

.cc-contact-box a {
  color: var(--cc-dark);
  font-weight: 700;
  text-decoration: none;
}

.cc-contact-box a:hover { color: var(--cc-greend); }

.btn-cc-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--cc-green);
  color: var(--cc-dark);
  font-weight: 700;
  font-size: .9rem;
  font-family: inherit;
  text-decoration: none;
  border-radius: var(--r-lg);
  padding: 13px 36px;
  box-shadow: 0 4px 20px rgba(102,205,87,.4);
  transition: background var(--transition), transform var(--transition);
}

.btn-cc-link:hover {
  background: var(--cc-greend);
  color: var(--cc-dark);
  transform: translateY(-2px);
}

/* ─────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────── */
@media (max-width: 640px) {
  /* ── Header: auf Handy nur Logo + Badge, kein langer Titel ── */
  .cc-header-inner  { padding: 10px 14px; gap: 10px; }
  .cc-logo          { height: 34px; }
  .cc-header-title  { display: none; }      /* Titel weg auf Mobil */
  .cc-header-badge  { display: none; }      /* Badge weg auf Mobil */

  /* Hero etwas kompakter */
  .cc-hero          { padding: 24px 16px 30px; }
  .cc-hero h2       { font-size: 1.3rem; }
  .cc-hero p        { font-size: .86rem; }
  .cc-hero-pills    { gap: 6px; }
  .cc-pill          { font-size: .71rem; padding: 5px 10px; }

  /* Schrittleiste: nur Icons */
  .cc-step          { padding: 10px 11px; }
  .cc-step span     { display: none; }

  /* Karten */
  .cc-main          { margin-top: 16px; padding: 0 10px; }
  .cc-card-body     { padding: 16px 14px 18px; }
  .cc-card          { border-radius: 12px; }
  .cc-card::before  { height: 2px; }

  /* Kacheln einspaltig */
  .cc-tile-grid     { grid-template-columns: 1fr; }
  .cc-tile          { padding: 11px 12px; font-size: .85rem; }

  /* Button */
  .btn-cc           { width: 100%; justify-content: center; padding: 15px; font-size: .93rem; }
  .cc-submit-wrap   { padding: 22px 14px 24px; border-radius: 12px; }

  /* Danke-Seite */
  .cc-thanks-body   { padding: 28px 18px 32px; }
  .cc-thanks-card h2{ font-size: 1.15rem; }
  .cc-thanks-card   { border-radius: 14px; }
}

@media (max-width: 400px) {
  /* Extra kleine Phones */
  .cc-hero-pills    { display: none; }
  .cc-hero h2       { font-size: 1.15rem; }
  .cc-hero-label    { font-size: .67rem; padding: 4px 10px; }
}

/* ─────────────────────────────────────────
   VALIDIERUNGS-BANNER (elegant, inline)
───────────────────────────────────────── */
.cc-error-banner {
  display: none;                          /* Standardmäßig versteckt */
  align-items: center;
  gap: 10px;
  background: rgba(255, 59, 48, .07);    /* Apple-Rot, sehr dezent */
  border: 1px solid rgba(255, 59, 48, .2);
  border-radius: var(--r-md);
  padding: 13px 16px;
  margin-bottom: 18px;
  font-size: .84rem;
  color: #c0392b;
  animation: slideDown .25s cubic-bezier(.4, 0, .2, 1);
}

.cc-error-banner.visible { display: flex; }

.cc-error-banner i {
  font-size: 1rem;
  color: #ff3b30;
  flex-shrink: 0;
}

.cc-error-banner strong { color: #a93226; }

/* Shake-Animation beim Versuch abzusenden */
@keyframes shake {
  0%, 100% { transform: translateX(0); }
  20%       { transform: translateX(-6px); }
  40%       { transform: translateX(6px); }
  60%       { transform: translateX(-4px); }
  80%       { transform: translateX(4px); }
}

.shake { animation: shake .35s cubic-bezier(.36,.07,.19,.97) both; }

@keyframes slideDown {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Inline-Feldhinweis */
.cc-field-hint {
  font-size: .74rem;
  color: #ff3b30;
  margin-top: 5px;
  display: none;
  align-items: center;
  gap: 4px;
}

.cc-field-hint.visible { display: flex; }

/* Feld-Error-State */
.form-control.cc-invalid {
  background: #fff5f5;
  border-color: #ff3b30 !important;
  box-shadow: 0 0 0 3px rgba(255, 59, 48, .12) !important;
}

/* ─────────────────────────────────────────
   DSGVO-ZUSTIMMUNG
───────────────────────────────────────── */
.cc-dsgvo-wrap {
  background: #f9faf9;
  border: 1px solid var(--cc-border);
  border-radius: var(--r-md);
  padding: 16px 18px;
  margin-bottom: 22px;
}

.cc-dsgvo-label {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
  font-size: .84rem;
  line-height: 1.55;
  color: var(--cc-text);
  user-select: none;
}

.cc-dsgvo-label input[type="checkbox"] {
  width: 20px;
  height: 20px;
  accent-color: var(--cc-green);
  flex-shrink: 0;
  margin-top: 1px;
  cursor: pointer;
}

.cc-dsgvo-label a {
  color: var(--cc-dark);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.cc-dsgvo-label a:hover { color: var(--cc-greend); }

.cc-dsgvo-error {
  font-size: .74rem;
  color: #ff3b30;
  margin-top: 8px;
  display: none;
  align-items: center;
  gap: 4px;
}

.cc-dsgvo-error.visible { display: flex; }

/* Wenn DSGVO nicht gecheckt – rote Umrandung der Box */
.cc-dsgvo-wrap.cc-invalid {
  border-color: rgba(255, 59, 48, .4);
  background: #fff5f5;
}

/* ─────────────────────────────────────────
   CUSTOM DROPDOWN (ersetzt <select>)
───────────────────────────────────────── */
.cc-dropdown {
  position: relative;
  user-select: none;
}

/* Der sichtbare "Trigger"-Button */
.cc-dropdown-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  background: #f5f5f7;
  border: 1.5px solid transparent;
  border-radius: var(--r-sm);
  padding: 11px 14px;
  font-size: .9rem;
  font-family: inherit;
  color: var(--cc-text);
  width: 100%;
  cursor: pointer;
  text-align: left;
  transition: background var(--transition), border-color var(--transition),
              box-shadow var(--transition);
}

.cc-dropdown-trigger:hover {
  background: #eef0ee;
}

.cc-dropdown-trigger.open {
  background: var(--cc-white);
  border-color: var(--cc-green);
  box-shadow: 0 0 0 3px rgba(102,205,87,.18);
}

/* Pfeil-Icon */
.cc-dropdown-arrow {
  color: var(--cc-green);
  font-size: .8rem;
  transition: transform var(--transition);
  flex-shrink: 0;
}

.cc-dropdown-trigger.open .cc-dropdown-arrow {
  transform: rotate(180deg);
}

/* Dropdown-Panel */
.cc-dropdown-panel {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: var(--cc-white);
  border: 1px solid rgba(0,0,0,.1);
  border-radius: var(--r-md);
  box-shadow: 0 8px 32px rgba(0,0,0,.14), 0 2px 8px rgba(0,0,0,.08);
  overflow: hidden;
  z-index: 500;
  animation: dropIn .18s cubic-bezier(.4,0,.2,1);
}

.cc-dropdown-panel.open {
  display: block;
}

@keyframes dropIn {
  from { opacity: 0; transform: translateY(-8px) scale(.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Einzelne Option */
.cc-dropdown-option {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 16px;
  font-size: .88rem;
  color: var(--cc-text);
  cursor: pointer;
  transition: background var(--transition);
  border-bottom: 1px solid #f2f2f7;
}

.cc-dropdown-option:last-child {
  border-bottom: none;
}

.cc-dropdown-option:hover {
  background: #f0fce9;
}

.cc-dropdown-option.selected {
  color: var(--cc-dark);
  font-weight: 600;
  background: rgba(102,205,87,.08);
}

.cc-dropdown-option .opt-check {
  color: var(--cc-green);
  font-size: .85rem;
  margin-left: auto;
  opacity: 0;
}

.cc-dropdown-option.selected .opt-check {
  opacity: 1;
}

/* ─────────────────────────────────────────
   KLEINE HILFSMITTEL
───────────────────────────────────────── */
.text-green  { color: var(--cc-green); }
.text-dark   { color: var(--cc-dark); }
.text-muted  { color: var(--cc-muted) !important; }
