/* ============================================================
   LogicStudios — Kunden-Checkliste (Onboarding-Formular)
   Erbt Tokens aus base.css (data-dir="monolith" data-theme="dark")
   ============================================================ */

/* hidden-Attribut muss display: flex/grid IMMER schlagen */
[hidden] { display: none !important; }

body.cl {
  background:
    radial-gradient(1200px 700px at 50% -10%, rgba(52,120,246,0.12), transparent 60%),
    var(--bg);
  min-height: 100vh;
}

/* ---------- Fortschrittsleiste oben ---------- */
.cl-progress {
  position: fixed; top: 0; left: 0; right: 0; height: 3px; z-index: 80;
  background: transparent;
}
.cl-progress i { display: block; height: 100%; width: 0%; background: var(--accent); transition: width 0.15s ease; }

/* ---------- Top-Bar ---------- */
.cl-top {
  position: fixed; top: 3px; left: 0; right: 0; z-index: 70;
  height: 60px; display: flex; align-items: center;
  backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
  background: var(--nav-bg);
  border-bottom: 1px solid var(--line);
}
.cl-top-inner { width: 100%; max-width: 980px; margin: 0 auto; padding: 0 clamp(18px,4vw,32px); display: flex; align-items: center; gap: 12px; }
.cl-top-brand { display: flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: 700; letter-spacing: -0.02em; font-size: 16px; text-decoration: none; color: var(--ink); }
.cl-top-brand img { width: 26px; height: auto; }
.cl-top-tag { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-3); border-left: 1px solid var(--line); padding-left: 12px; }
.cl-top-spacer { flex: 1; }
.cl-step-count { font-family: var(--font-mono); font-size: 12px; color: var(--ink-2); }
.cl-step-count b { color: var(--accent); }

/* ---------- Container ---------- */
.cl-wrap { max-width: 860px; margin: 0 auto; padding: 0 clamp(18px,4vw,32px); }
.cl-main { padding-top: 64px; }

/* ---------- Hero ---------- */
.cl-hero { text-align: center; padding: clamp(64px,9vw,120px) 0 clamp(40px,6vw,72px); }
.cl-hero .mark { width: clamp(64px,10vw,92px); margin: 0 auto 22px; }
.cl-hero-eyebrow { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-mono); font-size: 13px; font-weight: 500; letter-spacing: 0.18em; text-transform: uppercase; color: var(--accent); background: color-mix(in oklab, var(--accent) 12%, transparent); border: 1px solid color-mix(in oklab, var(--accent) 40%, transparent); border-radius: 999px; padding: 7px 16px; margin: 0 0 20px; }

/* ---------- Einzel-Paket & Reveal ---------- */
.cl-packs--single { grid-template-columns: minmax(0, 480px); justify-content: center; }
.cl-reveal { display: none; margin-top: 26px; animation: clReveal 0.3s ease both; }
#sec-paket:has(input[name="paket"]:checked) #starter-extra { display: block; }
@keyframes clReveal { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.cl-upgrade .cl-pack { max-width: 480px; }
.cl-domain-field { display: none; margin-top: 16px; }
#sec-setup:has(input[name="hosting"][value="Ja"]:checked) .cl-domain-field { display: block; animation: clReveal 0.3s ease both; }
.cl-domain-field.is-open { display: block; animation: clReveal 0.3s ease both; }
.cl-info-head { font-family: var(--font-mono); font-size: 13px; font-weight: 500; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); margin: 28px 0 10px; }
.cl-hero h1 { font-family: var(--font-display); font-weight: 700; letter-spacing: -0.035em; font-size: clamp(34px,5.4vw,60px); line-height: 1.04; text-wrap: balance; }
.cl-hero .lede { margin: 22px auto 0; max-width: 52ch; }
.cl-hero-meta { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-top: 32px; }
.cl-chip { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; color: var(--ink-2); background: var(--card); border: 1px solid var(--line); border-radius: 999px; padding: 8px 16px; }
.cl-chip i { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); }

/* ---------- Sektion-Block ---------- */
.cl-sec { padding: clamp(40px,6vw,72px) 0; border-top: 1px solid var(--line); scroll-margin-top: 80px; }
.cl-sec-head { display: flex; gap: 18px; align-items: flex-start; margin-bottom: 28px; }
.cl-sec-num { font-family: var(--font-mono); font-size: 13px; font-weight: 500; color: var(--accent); border: 1px solid var(--line-strong); border-radius: 10px; padding: 6px 11px; flex-shrink: 0; margin-top: 4px; }
.cl-sec-head h2 { font-family: var(--font-display); font-weight: 700; letter-spacing: -0.03em; font-size: clamp(26px,3.4vw,38px); line-height: 1.1; }
.cl-sec-head p { color: var(--ink-2); margin: 10px 0 0; font-size: 16px; max-width: 60ch; }

/* ---------- Hinweis-Box (Erklärungen) ---------- */
.cl-note { display: flex; gap: 14px; background: var(--card); border: 1px solid var(--line); border-radius: 16px; padding: 18px 20px; margin: 0 0 24px; }
.cl-note .ic { width: 28px; height: 28px; flex-shrink: 0; border-radius: 8px; display: grid; place-items: center; background: color-mix(in oklab, var(--accent) 18%, transparent); color: var(--accent); font-family: var(--font-mono); font-weight: 700; font-size: 14px; }
.cl-note p { margin: 0; font-size: 15px; color: var(--ink-2); line-height: 1.55; }
.cl-note strong { color: var(--ink); font-weight: 600; }
.cl-note.warn .ic { background: color-mix(in oklab, #f6a434 20%, transparent); color: #f6b452; }

/* ---------- Felder ---------- */
.cl-field { margin-bottom: 18px; }
.cl-field > label { display: block; font-size: 14px; font-weight: 600; color: var(--ink); margin-bottom: 8px; }
.cl-field .hint { font-weight: 400; color: var(--ink-3); font-size: 13px; }
.cl-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
input[type="text"].cl-in, input[type="email"].cl-in, input[type="tel"].cl-in, input[type="url"].cl-in, textarea.cl-in {
  width: 100%; font-family: var(--font-body); font-size: 15px; color: var(--ink);
  background: var(--card); border: 1px solid var(--line); border-radius: 12px;
  padding: 13px 15px; transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
textarea.cl-in { resize: vertical; min-height: 96px; line-height: 1.5; }
.cl-in::placeholder { color: var(--ink-3); }
.cl-in:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 22%, transparent); }

/* ---------- Pakete / Preise ---------- */
.cl-anchor { text-align: center; margin: 0 auto 30px; max-width: 60ch; }
.cl-anchor .big { font-family: var(--font-display); font-weight: 700; letter-spacing: -0.03em; font-size: clamp(38px,6vw,64px); color: var(--ink); line-height: 1; }
.cl-anchor .big span { color: var(--accent); }
.cl-anchor .sub { color: var(--ink-2); margin-top: 12px; font-size: 16px; }
.cl-anchor .micro { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.04em; color: var(--ink-3); margin-top: 8px; }

.cl-packs { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; }
.cl-pack {
  position: relative; cursor: pointer; display: flex; flex-direction: column;
  background: var(--card); border: 1px solid var(--line); border-radius: 20px;
  padding: 24px 22px; transition: border-color 0.2s ease, transform 0.2s ease, background 0.2s ease;
}
.cl-pack:hover { transform: translateY(-3px); border-color: var(--line-strong); }
.cl-pack input { position: absolute; opacity: 0; pointer-events: none; }
.cl-pack .tier { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-3); display: flex; align-items: center; gap: 8px; }
.cl-pack-info { width: 18px; height: 18px; flex-shrink: 0; border-radius: 50%; border: 1px solid var(--line-strong); background: transparent; color: var(--ink-2); font-family: var(--font-display); font-style: italic; font-weight: 700; font-size: 11px; line-height: 1; cursor: pointer; display: grid; place-items: center; letter-spacing: 0; transition: background 0.2s, color 0.2s, border-color 0.2s; }
.cl-pack-info:hover { background: var(--accent); border-color: var(--accent); color: #fff; }
/* Paket-Detail-Modal */
.cl-pkgmodal { position: fixed; inset: 0; z-index: 120; display: grid; place-items: center; padding: 20px; }
.cl-pkgmodal-back { position: absolute; inset: 0; background: rgba(0,0,0,0.62); backdrop-filter: blur(3px); }
.cl-pkgmodal-card { position: relative; width: 100%; max-width: 620px; max-height: 88vh; overflow-y: auto; background: var(--card); border: 1px solid var(--line-strong); border-radius: 20px; padding: clamp(24px,4vw,38px); box-shadow: 0 30px 80px rgba(0,0,0,0.6); }
.cl-pkgmodal-x { position: absolute; top: 16px; right: 16px; width: 34px; height: 34px; border-radius: 50%; background: var(--bg-2); border: 1px solid var(--line); color: var(--ink-2); font-size: 20px; line-height: 1; cursor: pointer; }
.cl-pkgmodal-x:hover { color: var(--ink); border-color: var(--line-strong); }
.cl-pkgmodal-tier { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); }
.cl-pkgmodal-card h3 { font-family: var(--font-display); font-weight: 700; letter-spacing: -0.02em; font-size: clamp(24px,3.2vw,32px); margin: 8px 0 0; }
.cl-pkgmodal-sub { color: var(--ink-2); font-size: 15px; margin: 8px 0 0; }
.cl-pkgmodal-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 24px; }
@media (max-width: 600px) { .cl-pkgmodal-cols { grid-template-columns: 1fr; } }
.cl-pkgmodal-col { background: var(--bg-2); border: 1px solid var(--line); border-radius: 14px; padding: 18px 18px 20px; }
.cl-pkgmodal-col .hd { display: flex; align-items: center; gap: 9px; font-size: 14px; font-weight: 700; color: var(--ink); margin-bottom: 14px; }
.cl-pkgmodal-col .hd .i { width: 22px; height: 22px; border-radius: 50%; display: grid; place-items: center; font-size: 13px; color: #fff; }
.cl-pkgmodal-col.in .hd .i { background: #36c46b; }
.cl-pkgmodal-col.out .hd .i { background: var(--ink-3); }
.cl-pkgmodal-col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.cl-pkgmodal-col li { font-size: 13.5px; line-height: 1.5; color: var(--ink-2); padding-left: 20px; position: relative; }
.cl-pkgmodal-col.in li::before { content: "✓"; position: absolute; left: 0; top: 0; color: #36c46b; font-weight: 700; }
.cl-pkgmodal-col.out li::before { content: "–"; position: absolute; left: 0; top: 0; color: var(--ink-3); font-weight: 700; }
.cl-pkgmodal-col li b { color: var(--ink); font-weight: 600; }
.cl-pkgmodal-foot { font-size: 13px; color: var(--ink-3); margin: 22px 0 0; line-height: 1.55; border-top: 1px solid var(--line); padding-top: 16px; }
@media print { .cl-pkgmodal { display: none !important; } }
.cl-pack .price { font-family: var(--font-display); font-weight: 700; letter-spacing: -0.03em; font-size: 34px; margin: 10px 0 2px; line-height: 1; }
.cl-pack .price small { font-size: 14px; font-weight: 500; color: var(--ink-3); letter-spacing: 0; }
.cl-pack .price .was { display: block; font-size: 13px; font-weight: 500; color: var(--ink-3); text-decoration: line-through; letter-spacing: 0; margin-bottom: 2px; }
.cl-pack .desc { font-size: 13.5px; color: var(--ink-2); margin: 8px 0 16px; line-height: 1.5; min-height: 40px; }
.cl-pack ul { list-style: none; margin: 0 0 18px; padding: 0; display: flex; flex-direction: column; gap: 9px; }
.cl-pack li { font-size: 13.5px; color: var(--ink-2); display: flex; gap: 9px; align-items: flex-start; line-height: 1.4; }
.cl-pack li::before { content: ""; width: 15px; height: 15px; flex-shrink: 0; margin-top: 2px; border-radius: 5px; background: color-mix(in oklab, var(--accent) 22%, transparent); position: relative; }
.cl-pack li::after { content: "✓"; position: absolute; margin-left: 3px; margin-top: 0px; font-size: 10px; color: var(--accent); font-weight: 700; }
.cl-pack .pick { margin-top: auto; text-align: center; font-size: 13px; font-weight: 600; color: var(--ink-2); border: 1px solid var(--line-strong); border-radius: 999px; padding: 10px; transition: all 0.2s ease; }
.cl-pack.featured { border-color: color-mix(in oklab, var(--accent) 50%, var(--line)); }
.cl-pack .badge { position: absolute; top: -10px; left: 22px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; background: var(--accent); color: #fff; padding: 4px 10px; border-radius: 999px; }
.cl-pack .badge.alt { background: var(--card-2); color: var(--ink-2); border: 1px solid var(--line); left: auto; right: 22px; }
.cl-pack input:checked ~ .pick { background: var(--accent); color: #fff; border-color: var(--accent); }
.cl-pack:has(input:checked) { border-color: var(--accent); background: color-mix(in oklab, var(--accent) 7%, var(--card)); box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 18%, transparent); }
.cl-pack .check { position: absolute; top: 18px; right: 18px; width: 22px; height: 22px; border-radius: 50%; border: 1px solid var(--line-strong); display: grid; place-items: center; font-size: 12px; color: transparent; transition: all 0.2s ease; }
.cl-pack input:checked ~ .check { background: var(--accent); border-color: var(--accent); color: #fff; }

/* ---------- Add-ons ---------- */
.cl-addons { display: grid; grid-template-columns: 1fr; gap: 14px; margin-top: 18px; }
.cl-addon { background: var(--card); border: 1px solid var(--line); border-radius: 16px; padding: 18px; }
.cl-addon .t { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; }
.cl-addon .t b { font-size: 15px; }
.cl-addon .t .p { font-family: var(--font-mono); font-size: 14px; color: var(--accent); white-space: nowrap; }
.cl-addon p { margin: 8px 0 0; font-size: 13px; color: var(--ink-2); line-height: 1.5; }
.cl-check.cl-locked { pointer-events: none; }

/* ---------- Farb-Picker ---------- */
.cl-swatches { display: grid; grid-template-columns: repeat(auto-fill, minmax(96px,1fr)); gap: 12px; }
.cl-sw { position: relative; cursor: pointer; border-radius: 14px; overflow: hidden; border: 1px solid var(--line); transition: transform 0.15s ease; }
.cl-sw:hover { transform: translateY(-2px); }
.cl-sw input { position: absolute; opacity: 0; pointer-events: none; }
.cl-sw .col { height: 64px; }
.cl-sw .nm { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.04em; color: var(--ink-2); padding: 7px 8px; background: var(--card); display: flex; justify-content: space-between; align-items: center; }
.cl-sw .tick { position: absolute; top: 8px; right: 8px; width: 22px; height: 22px; border-radius: 50%; background: rgba(0,0,0,0.35); backdrop-filter: blur(4px); display: grid; place-items: center; color: #fff; font-size: 12px; opacity: 0; transform: scale(0.6); transition: all 0.18s ease; }
.cl-sw:has(input:checked) { border-color: var(--accent); box-shadow: 0 0 0 2px color-mix(in oklab, var(--accent) 40%, transparent); }
.cl-sw:has(input:checked) .tick { opacity: 1; transform: scale(1); }

/* ---------- Font-Picker ---------- */
.cl-fonts { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; }
.cl-font { position: relative; cursor: pointer; background: var(--card); border: 1px solid var(--line); border-radius: 16px; padding: 20px 22px; transition: border-color 0.2s ease, transform 0.15s ease; }
.cl-font:hover { transform: translateY(-2px); border-color: var(--line-strong); }
.cl-font input { position: absolute; opacity: 0; pointer-events: none; }
.cl-font .samp { font-size: 30px; line-height: 1.05; color: var(--ink); }
.cl-font .meta { display: flex; justify-content: space-between; align-items: center; margin-top: 14px; }
.cl-font .meta b { font-size: 14px; }
.cl-font .meta span { font-family: var(--font-mono); font-size: 11px; color: var(--ink-3); }
.cl-font .tick { width: 20px; height: 20px; border-radius: 50%; border: 1px solid var(--line-strong); display: grid; place-items: center; font-size: 11px; color: transparent; transition: all 0.2s ease; }
.cl-font:has(input:checked) { border-color: var(--accent); background: color-mix(in oklab, var(--accent) 6%, var(--card)); }
.cl-font:has(input:checked) .tick { background: var(--accent); border-color: var(--accent); color: #fff; }

/* ---------- Scrollbare Schrift-Auswahl ---------- */
.cl-fontscroll {
  max-height: 380px; overflow-y: auto; -webkit-overflow-scrolling: touch;
  border: 1px solid var(--line); border-radius: 16px; background: var(--bg-2);
  padding: 8px; display: flex; flex-direction: column; gap: 6px;
}
.cl-fontscroll::-webkit-scrollbar { width: 10px; }
.cl-fontscroll::-webkit-scrollbar-thumb { background: var(--line-strong); border-radius: 999px; border: 3px solid var(--bg-2); }
.cl-fontopt {
  position: relative; display: flex; align-items: center; gap: 16px; cursor: pointer;
  padding: 14px 16px; border-radius: 12px; border: 1px solid transparent;
  background: var(--card); transition: border-color 0.18s ease, background 0.18s ease;
}
.cl-fontopt:hover { border-color: var(--line-strong); }
.cl-fontopt input { position: absolute; opacity: 0; pointer-events: none; }
.cl-fontopt .fsamp { flex: 1; min-width: 0; font-size: clamp(22px, 3.4vw, 30px); line-height: 1.05; color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cl-fontopt .fmeta { flex-shrink: 0; text-align: right; }
.cl-fontopt .fmeta b { display: block; font-size: 13px; font-weight: 600; color: var(--ink); }
.cl-fontopt .fmeta span { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.06em; color: var(--ink-3); }
.cl-fontopt .tick { flex-shrink: 0; width: 22px; height: 22px; border-radius: 50%; border: 1px solid var(--line-strong); display: grid; place-items: center; font-size: 12px; color: transparent; transition: all 0.18s ease; }
.cl-fontopt:has(input:checked) { border-color: var(--accent); background: color-mix(in oklab, var(--accent) 8%, var(--card)); }
.cl-fontopt:has(input:checked) .tick { background: var(--accent); border-color: var(--accent); color: #fff; }
@media (max-width: 560px) { .cl-fontopt .fmeta b { font-size: 12px; } .cl-fontopt .fmeta span { display: none; } }

/* ---------- Live-Moodboard (heller Karton) ---------- */
.cl-mood { background: #fbfaf7; color: #1f1d18; border: 1px solid var(--line); border-radius: 20px; overflow: hidden; box-shadow: var(--shadow); }
.cl-mood-top { text-align: center; padding: 36px 22px 30px; background: #ffffff; }
.cl-mood-kl { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: #a8a294; }
.cl-mood-brand { font-family: Georgia, serif; font-weight: 600; font-size: clamp(34px, 5.4vw, 58px); line-height: 1.04; letter-spacing: -0.01em; color: #2c2a24; margin: 10px 0 0; word-break: break-word; }
.cl-mood-band { display: grid; grid-template-columns: 1fr 1fr; min-height: 132px; }
.cl-mood-half { display: grid; place-items: center; padding: 18px; transition: background 0.3s ease; }
#mood-bandL { background: #cdd6c4; }
#mood-bandR { background: #6f7544; }
.cl-mood-mark { font-family: Georgia, serif; font-size: 52px; line-height: 1; color: #6f7544; width: 92px; height: 92px; border-radius: 50%; border: 2px solid currentColor; display: grid; place-items: center; transition: color 0.3s ease; }
.cl-mood-word { font-family: Georgia, serif; font-size: clamp(26px, 4vw, 44px); letter-spacing: 0.12em; color: #d39a2e; transition: color 0.3s ease; word-break: break-word; text-align: center; }
.cl-mood-row { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; padding: 30px clamp(20px, 3vw, 34px); background: #fbfaf7; }
.cl-mood-cap { display: block; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: #a8a294; margin-bottom: 14px; }
.cl-mood-pal { display: flex; flex-wrap: wrap; gap: 14px; }
.cl-mood-sw { text-align: center; }
.cl-mood-sw .dot { width: 46px; height: 46px; border-radius: 50%; border: 1px solid rgba(0,0,0,0.08); }
.cl-mood-sw .hex { display: block; font-family: var(--font-mono); font-size: 9.5px; color: #8b857a; margin-top: 6px; letter-spacing: 0.02em; }
.cl-mood-empty { font-size: 13px; color: #b8b2a6; }
.cl-mood-fontwrap { display: flex; gap: 18px; align-items: flex-start; }
.cl-mood-aa { font-family: Georgia, serif; font-size: 46px; line-height: 0.9; color: #2c2a24; flex-shrink: 0; transition: color 0.3s ease; }
.cl-mood-fname { font-size: 14px; font-weight: 600; color: #2c2a24; }
.cl-mood-fsamp { font-family: Georgia, serif; font-size: 13px; color: #57534a; line-height: 1.5; margin: 8px 0 0; max-width: 40ch; }
.cl-mood-imgwrap { padding: 4px clamp(20px, 3vw, 34px) 30px; background: #fbfaf7; }
.cl-mood-imgs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.cl-mood-imgs image-slot { display: block; width: 100%; aspect-ratio: 3 / 4; }
@media (max-width: 620px) { .cl-mood-row { grid-template-columns: 1fr; gap: 22px; } .cl-mood-imgs { grid-template-columns: repeat(2, 1fr); } }

/* Beispiel-Vorlage + interaktive Palette/Schrift im Moodboard */
.cl-ex-btn { font-family: var(--font-mono); font-size: 12px; color: var(--accent); background: none; border: 1px solid var(--accent); border-radius: 999px; padding: 4px 13px; cursor: pointer; margin-left: 8px; transition: background .2s, color .2s; }
.cl-ex-btn:hover { background: var(--accent); color: #fff; }
.cl-ex { margin: 14px 0 6px; }
.cl-ex img { width: 100%; max-width: 430px; border-radius: 14px; border: 1px solid var(--line); box-shadow: var(--shadow); }
.cl-ex-cap { display: block; font-family: var(--font-mono); font-size: 11px; color: var(--ink-3); margin-top: 8px; }
.cl-mood-pal { display: flex; flex-wrap: wrap; gap: 14px; align-items: flex-start; }
.cl-colorchip { position: relative; text-align: center; }
.cl-colorchip .dot { display: block; width: 46px; height: 46px; border-radius: 50%; border: 1px solid rgba(0,0,0,0.12); }
.cl-colorchip .hex { display: block; font-family: var(--font-mono); font-size: 9px; color: #8b857a; margin-top: 6px; letter-spacing: 0.02em; }
.cl-colorchip .rm { position: absolute; top: -6px; right: -6px; width: 20px; height: 20px; border-radius: 50%; background: #2c2a24; color: #fff; border: 2px solid #fbfaf7; font-size: 12px; line-height: 1; cursor: pointer; display: grid; place-items: center; padding: 0; }
.cl-colorchip .rm:hover { background: #c8533b; }
.cl-emptyslot { width: 46px; height: 46px; border-radius: 50%; border: 2px dashed #d6cfbf; }
.cl-addcolor { margin-top: 16px; font-family: var(--font-mono); font-size: 12px; color: #2c2a24; background: #fff; border: 1px solid #ddd6c8; border-radius: 999px; padding: 9px 16px; cursor: pointer; display: inline-flex; align-items: center; gap: 7px; transition: border-color .2s; }
.cl-addcolor span { font-size: 15px; line-height: 1; }
.cl-addcolor:hover { border-color: #2c2a24; }
.cl-colorpop { margin-top: 14px; background: #fff; border: 1px solid #e4ddcd; border-radius: 14px; padding: 16px; }
.cl-colorpop-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(30px, 1fr)); gap: 9px; }
.cl-colorpop-grid .ps { width: 100%; aspect-ratio: 1; border-radius: 8px; border: 1px solid rgba(0,0,0,0.1); cursor: pointer; transition: transform .12s; padding: 0; }
.cl-colorpop-grid .ps:hover { transform: scale(1.14); }
.cl-colorpop-custom { display: flex; align-items: center; gap: 10px; margin-top: 14px; padding-top: 14px; border-top: 1px dashed #e4ddcd; font-size: 13px; color: #57534a; }
.cl-colorpop-custom input[type="color"] { width: 44px; height: 32px; border: 1px solid #ddd6c8; border-radius: 8px; background: #fff; cursor: pointer; padding: 2px; }
.cl-colorpop-custom button { font-family: var(--font-mono); font-size: 11px; color: #fff; background: var(--accent); border: none; border-radius: 999px; padding: 8px 14px; cursor: pointer; }
.cl-mood-fbtn { margin-top: 16px; font-family: var(--font-mono); font-size: 12px; color: #2c2a24; background: #fff; border: 1px solid #ddd6c8; border-radius: 999px; padding: 9px 16px; cursor: pointer; transition: border-color .2s; }
.cl-mood-fbtn:hover { border-color: #2c2a24; }
.cl-mood-row .cl-fontscroll { margin-top: 12px; max-height: 300px; background: #f2efe8; border-color: #e4ddcd; }
.cl-mood-row .cl-fontopt { background: #fff; border-color: #ece6d8; }
.cl-mood-row .cl-fontopt .fsamp, .cl-mood-row .cl-fontopt .fmeta b { color: #2c2a24; }
.cl-mood-row .cl-fontopt .fmeta span { color: #9a958c; }
.cl-mood-row .cl-fontopt .tick { border-color: #cfc8b8; }
.cl-mood-row .cl-fontopt:has(input:checked) { background: #f4efe5; border-color: var(--accent); }
.cl-mood-row .cl-fontopt:has(input:checked) .tick { background: var(--accent); border-color: var(--accent); color: #fff; }

/* ---------- Checkbox-Liste (Menüpunkte) ---------- */
.cl-checks { display: grid; grid-template-columns: repeat(2,1fr); gap: 10px; }
.cl-check { display: flex; align-items: center; gap: 12px; cursor: pointer; background: var(--card); border: 1px solid var(--line); border-radius: 12px; padding: 13px 15px; transition: border-color 0.2s ease; }
.cl-check:hover { border-color: var(--line-strong); }
.cl-check input { position: absolute; opacity: 0; pointer-events: none; }
.cl-box { width: 20px; height: 20px; flex-shrink: 0; border-radius: 6px; border: 1px solid var(--line-strong); display: grid; place-items: center; font-size: 12px; color: transparent; transition: all 0.18s ease; }
.cl-check input:checked ~ .cl-box, .cl-consent input:checked ~ .cl-box { background: var(--accent); border-color: var(--accent); color: #fff; }
.cl-check span:not(.cl-box) { font-size: 14.5px; color: var(--ink); }
.cl-check:has(input:checked) { border-color: color-mix(in oklab, var(--accent) 40%, var(--line)); }

/* ---------- Ja/Nein-Matrix ---------- */
.cl-matrix { display: flex; flex-direction: column; gap: 10px; }
.cl-row { display: flex; align-items: center; gap: 16px; background: var(--card); border: 1px solid var(--line); border-radius: 14px; padding: 16px 18px; }
.cl-row .q { flex: 1; }
.cl-row .q b { font-size: 15px; display: block; }
.cl-row .q small { font-size: 12.5px; color: var(--ink-3); display: block; margin-top: 3px; }
.cl-toggle { display: inline-flex; background: var(--bg-2); border: 1px solid var(--line); border-radius: 999px; padding: 3px; flex-shrink: 0; }
.cl-toggle label { cursor: pointer; }
.cl-toggle input { position: absolute; opacity: 0; pointer-events: none; }
.cl-toggle span { display: inline-block; font-size: 13px; font-weight: 600; color: var(--ink-2); padding: 7px 18px; border-radius: 999px; transition: all 0.18s ease; }
.cl-toggle input:checked + span { color: #fff; }
.cl-toggle label.yes input:checked + span { background: var(--accent); }
.cl-toggle label.no input:checked + span { background: var(--card-2); color: var(--ink); }

/* ---------- Consent (große Zustimmung) ---------- */
.cl-consent { display: flex; gap: 14px; cursor: pointer; background: var(--card); border: 1px solid var(--line); border-radius: 16px; padding: 18px 20px; align-items: flex-start; transition: border-color 0.2s ease; }
.cl-consent:hover { border-color: var(--line-strong); }
.cl-consent input { position: absolute; opacity: 0; pointer-events: none; }
.cl-consent .cl-box { margin-top: 1px; }
.cl-consent .txt { font-size: 14.5px; color: var(--ink-2); line-height: 1.55; }
.cl-consent .txt b { color: var(--ink); font-weight: 600; }
.cl-consent:has(input:checked) { border-color: color-mix(in oklab, var(--accent) 45%, var(--line)); background: color-mix(in oklab, var(--accent) 5%, var(--card)); }

/* ---------- AGB ---------- */
.cl-agb { background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: clamp(22px,3vw,34px); }
.cl-agb h3 { font-family: var(--font-display); font-size: 17px; font-weight: 700; letter-spacing: -0.02em; margin: 26px 0 8px; color: var(--ink); }
.cl-agb h3:first-child { margin-top: 0; }
.cl-agb h3 .n { font-family: var(--font-mono); font-size: 13px; color: var(--accent); margin-right: 8px; }
.cl-agb p { font-size: 14px; color: var(--ink-2); line-height: 1.6; margin: 0 0 8px; }
.cl-agb strong { color: var(--ink); font-weight: 600; }
.cl-agb .hl { background: color-mix(in oklab, var(--accent) 14%, transparent); border-radius: 4px; padding: 1px 5px; color: var(--ink); }

/* ---------- Abschluss ---------- */
.cl-finish { text-align: center; padding: clamp(48px,7vw,88px) 0 clamp(64px,9vw,110px); }
.cl-finish h2 { font-family: var(--font-display); font-weight: 700; letter-spacing: -0.03em; font-size: clamp(28px,4vw,44px); }
.cl-finish p { color: var(--ink-2); margin: 14px auto 0; max-width: 48ch; }
.cl-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 30px; }
.cl-saved { font-family: var(--font-mono); font-size: 12px; color: var(--ink-3); margin-top: 22px; display: flex; align-items: center; justify-content: center; gap: 8px; }
.cl-saved i { width: 7px; height: 7px; border-radius: 50%; background: #36c46b; }

.cl-success { max-width: 540px; margin: 32px auto 0; background: color-mix(in oklab, #36c46b 10%, var(--card)); border: 1px solid color-mix(in oklab, #36c46b 45%, var(--line)); border-radius: 18px; padding: 30px 28px; }
.cl-success-ic { width: 46px; height: 46px; border-radius: 50%; background: #36c46b; color: #fff; display: grid; place-items: center; font-size: 24px; font-weight: 700; margin: 0 auto 14px; }
.cl-success h3 { font-family: var(--font-display); font-size: 22px; font-weight: 700; letter-spacing: -0.02em; margin: 0 0 8px; }
.cl-success p { color: var(--ink-2); font-size: 15px; margin: 0; }
.cl-success a { color: var(--accent); }
.cl-order { text-align: left; margin: 18px 0 0; padding: 16px; background: var(--bg); border: 1px solid var(--line); border-radius: 12px; font-family: var(--font-mono); font-size: 12px; line-height: 1.6; color: var(--ink); white-space: pre-wrap; word-break: break-word; max-height: 320px; overflow: auto; }

.cl-foot { border-top: 1px solid var(--line); padding: 30px 0; text-align: center; }
.cl-foot span { font-size: 13px; color: var(--ink-3); }

/* ---------- Responsive ---------- */
@media (max-width: 720px) {
  .cl-grid2, .cl-packs, .cl-addons, .cl-fonts, .cl-checks { grid-template-columns: 1fr; }
  .cl-top-tag { display: none; }
  .cl-row { flex-direction: column; align-items: stretch; gap: 12px; }
  .cl-toggle { align-self: flex-start; }
}

/* ---------- Live-Preis-Widget ---------- */
body.cl { padding-bottom: 90px; }
.cl-check em { font-style: normal; color: var(--accent); font-family: var(--font-mono); font-size: 12px; margin-left: 6px; }
.cl-check em.incl { color: #36c46b; }
.cl-seitgrp { font-size: 12px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-3); margin: 6px 0 12px; }
.cl-seitgrp + .cl-checks { margin-bottom: 22px; }
.cl-price { position: fixed; z-index: 75; right: 20px; bottom: 20px; width: 300px; max-width: calc(100vw - 32px); background: var(--card); border: 1px solid var(--line-strong); border-radius: 18px; box-shadow: 0 24px 60px rgba(0,0,0,0.5); overflow: hidden; }
.cl-price-head { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 12px; background: none; border: none; cursor: pointer; padding: 15px 18px; text-align: left; color: var(--ink); font-family: var(--font-body); }
.cl-price-label { display: block; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-3); }
.cl-price-total { display: block; font-family: var(--font-display); font-weight: 700; font-size: 27px; letter-spacing: -0.02em; line-height: 1.1; margin-top: 3px; }
.cl-price-total .ab { font-size: 13px; color: var(--ink-3); font-weight: 500; }
.cl-price-month { display: block; font-size: 12px; color: var(--accent); margin-top: 3px; }
.cl-price-caret { color: var(--ink-3); font-size: 13px; transition: transform 0.2s ease; }
.cl-price.collapsed .cl-price-caret { transform: rotate(180deg); }
.cl-price.collapsed .cl-price-body { display: none; }
.cl-price-body { padding: 0 18px 18px; }
.cl-price-rows { display: flex; flex-direction: column; gap: 7px; margin: 4px 0 14px; padding-top: 14px; border-top: 1px solid var(--line); }
.cl-price-rows .r { display: flex; justify-content: space-between; gap: 12px; font-size: 13px; color: var(--ink-2); }
.cl-price-rows .r b { color: var(--ink); font-weight: 600; font-variant-numeric: tabular-nums; white-space: nowrap; margin-left: auto; }
.cl-price-rows .r-x { appearance: none; border: 0; background: transparent; color: var(--ink-2); cursor: pointer; font-size: 16px; line-height: 1; padding: 0 4px; margin-left: 6px; border-radius: 6px; }
.cl-price-rows .r-x:hover { color: #e03e2f; background: color-mix(in oklab, #e03e2f 14%, transparent); }
.cl-price-rows .r-hint span { color: var(--ink-2); font-size: 13px; line-height: 1.5; }
.cl-price-rows .r.disc, .cl-price-rows .r.disc b { color: #36c46b; }
.cl-price-rows .r.inq { color: var(--accent); }
.cl-price-rows .r.inq b { color: var(--accent); font-weight: 600; }
.cl-price-rows .r.incl-row { font-size: 12px; padding-left: 2px; }
.cl-price-rows .r.incl-row span { color: var(--ink-2); }
.cl-price-rows .r.incl-row b { color: #36c46b; font-weight: 600; }
.cl-price-rows .r.net { border-top: 1px solid var(--line); padding-top: 8px; margin-top: 3px; }
.cl-price-rows .r.net b { font-weight: 700; }
.cl-price-rows .r.sum { border-top: 1px solid var(--line); padding-top: 8px; margin-top: 3px; }
.cl-price-rows .r.sum span, .cl-price-rows .r.sum b { font-weight: 700; color: var(--ink); font-size: 14.5px; }
.cl-price-voucher label { display: block; font-size: 12px; font-weight: 600; margin: 4px 0 8px; }
.cl-voucher-row { display: flex; gap: 8px; }
.cl-voucher-row input { flex: 1; min-width: 0; background: var(--bg-2); border: 1px solid var(--line); border-radius: 10px; padding: 9px 11px; color: var(--ink); font-size: 13px; font-family: var(--font-mono); text-transform: uppercase; }
.cl-voucher-row input::placeholder { text-transform: none; color: var(--ink-3); }
.cl-voucher-row input:focus { outline: none; border-color: var(--accent); }
.cl-voucher-row button { background: var(--accent); color: #fff; border: none; border-radius: 10px; padding: 9px 14px; font-size: 13px; font-weight: 600; cursor: pointer; white-space: nowrap; }
.cl-voucher-msg { font-size: 12px; margin: 8px 0 0; min-height: 1em; color: var(--ink-3); }
.cl-voucher-msg.ok { color: #36c46b; }
.cl-voucher-msg.err { color: #e0559b; }
.cl-price-cta { display: block; text-align: center; margin-top: 14px; background: var(--accent); color: #fff; text-decoration: none; padding: 11px; border-radius: 999px; font-size: 14px; font-weight: 600; }
.cl-price-cta:hover { filter: brightness(1.08); }
@media (max-width: 720px) {
  .cl-price { right: 0; left: 0; bottom: 0; width: 100%; max-width: 100%; border-radius: 16px 16px 0 0; }
  body.cl { padding-bottom: 76px; }
}
@media print { .cl-price { display: none !important; } }

/* ---------- Modus-Auswahl (Basic / Advanced) ---------- */
.cl-sec--start { border-top: none; padding-top: clamp(20px,3vw,32px); }
.cl-modus .price.txt { font-size: 18px; font-weight: 600; letter-spacing: -0.01em; }
.cl-modus .cl-pack .desc { min-height: 0; }

/* Detail-Leiste — nur im Schnell-Start sichtbar */
.cl-detailbar { display: none; gap: 14px; align-items: flex-start; background: var(--card); border: 1px solid var(--line); border-radius: 16px; padding: 18px 20px; margin: 8px 0 4px; }
.cl-detailbar .ic { flex-shrink: 0; width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; background: color-mix(in srgb, var(--accent) 18%, transparent); color: var(--accent); font-size: 14px; font-weight: 700; }
.cl-detailbar p { margin: 0; font-size: 15px; color: var(--ink-2); line-height: 1.55; }
.cl-detailbar button { background: none; border: none; color: var(--accent); font: inherit; font-weight: 600; cursor: pointer; padding: 0; text-decoration: underline; text-underline-offset: 3px; }
body[data-modus="advanced"] .cl-detailbar { display: flex; }
body[data-modus="advanced"].show-details .cl-detailbar { display: none; }

/* Optionale Sektionen im Schnell-Start ausblenden, bis aufgeklappt */
body[data-modus="advanced"] .cl-optional { display: none; }
body[data-modus="advanced"].show-details .cl-optional { display: block; }

/* ---------- Druck ---------- */
@media print {
  .cl-top, .cl-progress, .cl-actions, .cl-top-spacer, .cl-detailbar { display: none !important; }
  body.cl { background: #fff; color: #111; }
  body[data-modus="advanced"] .cl-optional { display: block !important; }
  .cl-sec { break-inside: avoid; }
}
