/* Shop-spezifische Komponenten — ergänzt redesign.css (Tokens, Nav, Footer).
   Klassen nach CI-HANDOFF: .v2btn, Produktkarten im vorlagen.html-Stil. */

.wrap { max-width: 1280px; margin: 0 auto; padding: 0 var(--pad); }
.wrap--narrow { max-width: 860px; }

/* ── Hero / Sektionsköpfe ─────────────────────────────────────────────── */
.shop-hero { padding-top: clamp(40px, 7vw, 88px); padding-bottom: clamp(24px, 4vw, 48px); }
.eyebrow {
  font-family: var(--mono); font-size: 11px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--accent); margin: 0 0 14px;
}
.shop-hero h1 {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(40px, 6vw, 72px); line-height: 1; letter-spacing: -.025em;
  margin: 0 0 18px; -webkit-hyphens: auto; hyphens: auto; overflow-wrap: break-word;
}
.shop-hero h1 em { font-style: italic; color: var(--accent); }
.lede { font-size: clamp(16px, 2.2vw, 19px); line-height: 1.6; color: var(--ink-2); max-width: 60ch; margin: 0; }

.section-head { margin: clamp(40px,6vw,72px) 0 24px; }
.section-head h2 { font-family: var(--serif); font-weight: 500; font-size: clamp(26px,3.4vw,34px); letter-spacing: -.01em; margin: 0; }

/* ── Produktraster ────────────────────────────────────────────────────── */
.grid { display: grid; gap: 22px; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }

.pak {
  display: flex; flex-direction: column; background: var(--bg);
  border: var(--rule); border-radius: var(--rad); overflow: hidden;
}
.pak__img { aspect-ratio: 3/2; width: 100%; object-fit: cover; background: var(--bg-2); display: block; }
.pak__body { display: flex; flex-direction: column; gap: 10px; padding: 22px; flex: 1; }
.pak__kicker { font-family: var(--mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-3); }
.pak__name { font-family: var(--serif); font-weight: 500; font-size: 20px; line-height: 1.25; margin: 0; color: var(--ink); }
.pak__count { font-size: 14px; color: var(--ink-2); margin: 0; }
.pak__spacer { flex: 1; }
.pak__price { display: flex; align-items: baseline; gap: 8px; margin-top: 6px; }
.pak__price b { font-family: var(--sans); font-weight: 800; font-size: 28px; color: var(--ink); }
.pak__price span { font-family: var(--mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-3); }

/* ── Bundle-Anker & Featured-Karte ───────────────────────────────────── */
.pak--featured {
  border: 2px solid var(--accent);
  position: relative;
}
.pak__badge {
  position: absolute;
  top: 12px; right: 12px;
  font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase;
  background: var(--accent); color: var(--accent-ink);
  padding: 4px 10px; border-radius: 999px;
  z-index: 1;
}
.pak__anchor-row {
  display: flex; align-items: baseline; gap: 8px; margin-bottom: 2px;
}
.pak__anchor {
  font-family: var(--mono); font-size: 13px; color: var(--ink-3);
  text-decoration: line-through;
}
.pak__save {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: .06em; text-transform: uppercase; color: var(--accent);
}

/* ── Trust-Zeile im Checkout ─────────────────────────────────────────── */
.trustbar {
  font-family: var(--mono); font-size: 11px; letter-spacing: .06em;
  text-transform: uppercase; color: var(--ink-3);
  text-align: center; margin: 10px 0 0;
}

/* ── Paket-Inhalte (was ist enthalten) ───────────────────────────────── */
.pak__contents { margin: 8px 0 2px; }
.pak__contents > summary {
  list-style: none; cursor: pointer;
  display: flex; align-items: center; gap: 8px;
  padding: 11px 14px; min-height: 44px;
  border: 1px solid var(--line-2); border-radius: 999px;
  background: var(--bg-2); color: var(--ink);
  font-family: var(--mono); font-size: 11px; letter-spacing: .06em; text-transform: uppercase;
  transition: border-color .2s, color .2s, background .2s;
}
.pak__contents > summary:hover { border-color: var(--accent); color: var(--accent); background: var(--bg); }
.pak__contents > summary::-webkit-details-marker { display: none; }
.pak__contents > summary::before { content: "📄"; font-size: 13px; }
.pak__contents > summary::after { content: "▾"; margin-left: auto; font-size: 13px; color: var(--ink-3); transition: transform .2s; }
.pak__contents[open] > summary::after { transform: rotate(180deg); }
.pak__contents[open] > summary { border-color: var(--accent); color: var(--accent); }
.pak__contents ul { list-style: none; margin: 6px 0 10px; padding: 0; }
.pak__contents li {
  font-size: 13.5px; line-height: 1.5; color: var(--ink-2);
  padding: 4px 0 4px 22px; position: relative;
}
.pak__contents li::before {
  content: "✓"; position: absolute; left: 0; top: 4px;
  color: var(--accent); font-weight: 700; font-size: 12px;
}

/* ── Garantie-Badge (Zufriedenheitsgarantie bei Mängeln) ─────────────── */
.guarantee {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 10.5px; letter-spacing: .06em;
  text-transform: uppercase; color: var(--ink-2);
  border: 1px solid var(--line-2); border-radius: 999px;
  padding: 6px 12px; text-decoration: none; background: var(--bg);
}
.guarantee:hover { border-color: var(--accent); color: var(--ink); }
.guarantee__seal { color: var(--accent); font-size: 13px; }
.pak .guarantee { margin-top: 10px; width: 100%; justify-content: center; }

/* ── Gratis-Leitfaden: prominenter Navy-Block ────────────────────────── */
.freeguide {
  background: var(--bg-deep); color: var(--bg-deep-ink);
  border-radius: var(--rad); overflow: hidden;
  display: grid; grid-template-columns: minmax(0, 42%) 1fr; gap: 0;
  align-items: stretch; margin: 8px 0;
}
/* Cover ist Querformat → ganz zeigen (contain) statt im schmalen Streifen zerschneiden */
.freeguide__img {
  width: 100%; height: 100%; display: block;
  object-fit: contain; object-position: center;
  background: var(--bg-deep); padding: clamp(14px, 2vw, 26px);
}
.freeguide__body { padding: clamp(24px, 4vw, 36px); }
.freeguide__eyebrow {
  font-family: var(--mono); font-size: 11px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--accent); margin: 0 0 10px;
}
.freeguide__title {
  font-family: var(--serif); font-weight: 500; font-size: clamp(22px, 3vw, 28px);
  line-height: 1.2; margin: 0 0 10px; color: var(--bg-deep-ink);
}
.freeguide__body .lede { color: oklch(0.85 0.012 75); }
.freeguide .field label { color: oklch(0.80 0.012 75); }
.freeguide .field input[type=text],
.freeguide .field input[type=email] {
  color: var(--bg-deep-ink);
  -webkit-text-fill-color: var(--bg-deep-ink);
  border-bottom-color: oklch(0.58 0.04 240);
}
.freeguide .field input::placeholder { color: oklch(0.72 0.02 240); opacity: 1; }
.freeguide .field input:focus { border-color: var(--accent); outline-color: var(--accent); }
.freeguide .consent { color: oklch(0.82 0.012 75); }
.freeguide .consent a { color: var(--accent); }
.freeguide .row { display: flex; gap: 12px; flex-wrap: wrap; align-items: flex-end; margin-top: 6px; }
.freeguide .field { flex: 1; min-width: 200px; margin: 8px 0; }
.freeguide .msg { margin-top: 10px; font-size: 14px; }
.freeguide .msg.ok { color: oklch(0.86 0.08 152); } .freeguide .msg.err { color: oklch(0.78 0.12 25); }

/* ── Buttons (CI-HANDOFF §4) ──────────────────────────────────────────── */
.v2btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 15px 26px; border: 0; border-radius: 999px; font-family: var(--sans);
  font-size: 15px; font-weight: 600; line-height: 1; white-space: nowrap; cursor: pointer;
  text-decoration: none; transition: transform .2s, background .2s, color .2s, border-color .2s; }
.v2btn--primary { background: var(--bg-deep); color: var(--bg-deep-ink); }
.v2btn--primary:hover { transform: translateY(-1px); background: var(--accent); color: var(--accent-ink); }
.v2btn--ghost { background: transparent; border: 1px solid var(--line-2); color: var(--ink); }
.v2btn--ghost:hover { border-color: var(--ink); background: var(--bg-2); }
.v2btn--full { width: 100%; }
.v2btn--green { background: oklch(0.55 0.09 152); color: #fff; }
.v2btn--green:hover { transform: translateY(-1px); background: oklch(0.50 0.10 152); color: #fff; }
.v2btn:active { transform: translateY(0) scale(.99); }      /* Tap-Feedback (Mobile) */
.v2btn:disabled { opacity: .55; cursor: default; transform: none; }
.v2btn { min-height: 48px; }                                 /* Touch-Ziel ≥44px */

/* ── Checkout-Panel (Pflichtinfos + Consent + Bestellbutton) ──────────── */
.co__backdrop { position: fixed; inset: 0; background: oklch(0.22 0.04 240 / .55);
  opacity: 0; visibility: hidden; transition: opacity .2s; z-index: 60; }
.co__backdrop.is-open { opacity: 1; visibility: visible; }
.co {
  position: fixed; z-index: 61; left: 50%; top: 50%; transform: translate(-50%, -48%);
  width: min(560px, calc(100vw - 32px)); max-height: calc(100vh - 32px); overflow-y: auto;
  background: var(--bg); border: var(--rule); border-radius: var(--rad);
  padding: clamp(22px, 4vw, 34px); opacity: 0; visibility: hidden; transition: opacity .2s, transform .2s;
}
.co.is-open { opacity: 1; visibility: visible; transform: translate(-50%, -50%); }
.co__close { position: absolute; top: 14px; right: 16px; background: 0; border: 0; font-size: 22px; cursor: pointer; color: var(--ink-3); }
.co h3 { font-family: var(--serif); font-weight: 500; font-size: 22px; margin: 0 8px 4px 0; }
.co__info { border: var(--rule); border-radius: var(--rad); padding: 14px 16px; margin: 16px 0; background: var(--bg-2); font-size: 14px; line-height: 1.6; color: var(--ink-2); }
.co__info b { color: var(--ink); }
.co__total { font-family: var(--sans); font-weight: 800; font-size: 22px; color: var(--ink); }

.field { display: block; margin: 14px 0; }
.field label { display: block; font-family: var(--mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 6px; }
.field input[type=text], .field input[type=email] {
  width: 100%; padding: 10px 2px; border: 0; border-bottom: 1px solid var(--line-2);
  background: transparent; font-family: var(--sans); font-size: 16px; color: var(--ink); }
.field input:focus { outline: 2px solid var(--accent); outline-offset: 2px; border-color: var(--accent); }
.field textarea { width: 100%; padding: 10px 2px; border: 0; border-bottom: 1px solid var(--line-2); background: transparent; font-family: var(--sans); font-size: 16px; color: var(--ink); min-height: 90px; resize: vertical; }
.field textarea:focus { outline: 2px solid var(--accent); outline-offset: 2px; border-color: var(--accent); }

.consent { display: flex; gap: 10px; align-items: flex-start; margin: 14px 0; font-size: 13.5px; line-height: 1.5; color: var(--ink-2); }
.consent input { margin-top: 3px; width: 18px; height: 18px; accent-color: var(--bg-deep); flex: none; }
.consent a { color: var(--accent); }

.co__err { color: var(--danger); font-size: 13.5px; margin: 8px 0 0; min-height: 1em; }
.co__legalnote { font-size: 12px; color: var(--ink-3); margin: 14px 0 0; line-height: 1.5; }

/* ── Gratis-Muster ────────────────────────────────────────────────────── */
.sample { border: var(--rule); border-radius: var(--rad); padding: clamp(22px,4vw,32px); background: var(--bg); margin: 16px 0; }
.sample .row { display: flex; gap: 12px; flex-wrap: wrap; align-items: flex-end; }
.sample .field { flex: 1; min-width: 200px; margin: 8px 0; }
.msg { margin-top: 10px; font-size: 14px; }
.msg.ok { color: oklch(0.47 0.055 152); } .msg.err { color: var(--danger); }

/* ── Content-Seiten (AGB, Erfolg) ─────────────────────────────────────── */
.doc { padding-top: clamp(40px,6vw,72px); padding-bottom: clamp(40px,6vw,72px); }
.doc h1 { font-family: var(--serif); font-weight: 400; font-size: clamp(34px,5vw,52px); letter-spacing: -.02em; margin: 0 0 8px; }
.doc h2 { font-family: var(--serif); font-weight: 500; font-size: 22px; margin: 28px 0 8px; }
.doc p, .doc li { font-size: 16px; line-height: 1.7; color: var(--ink-2); }
.doc a { color: var(--accent); }
/* Button-Links im .doc-Kontext behalten ihre eigene Schriftfarbe (nicht .doc a gold) */
.doc a.v2btn--green,
.doc a.v2btn--primary { color: #fff; }
.doc a.v2btn--green:hover,
.doc a.v2btn--primary:hover { color: #fff; }
.doc a.v2btn--ghost { color: var(--ink); }
.doc a.v2btn--ghost:hover { color: var(--ink); }
/* Erfolgs-Häkchen (ersetzt ✅) — gestylt, kein Emoji */
.status-check {
  width: 56px; height: 56px; margin: 0 auto 6px;
  border-radius: 50%;
  border: 2px solid var(--accent);
  display: flex; align-items: center; justify-content: center;
}
.status-check::after {
  content: ""; width: 16px; height: 9px;
  border-left: 2.5px solid var(--accent);
  border-bottom: 2.5px solid var(--accent);
  transform: rotate(-45deg) translate(1px, -2px);
}
.status-card { border: var(--rule); border-radius: var(--rad); padding: clamp(28px,5vw,44px); text-align: center; background: var(--bg); }
.status-card .big { font-size: 40px; }

/* Kontrast: gedämpften Ton etwas abdunkeln (WCAG-AA-Lesbarkeit kleiner Captions) */
[data-dir="A"] { --ink-3: oklch(0.50 0.018 60); }

/* Hero-Claim */
.hero-claim { font-family: var(--mono); text-transform: uppercase; letter-spacing: .14em; font-size: 12px; color: var(--accent); margin: 16px 0 0; }

/* Karten beruhigen: Bild klar vom Text trennen */
.pak__img { border-bottom: var(--rule); }

/* FAQ — schlichtes, elegantes Akkordeon */
#faq { padding-bottom: clamp(48px, 6vw, 84px); }
.faq-list { border-top: 1px solid var(--line-2); margin-top: 6px; }
.faq { border-bottom: 1px solid var(--line-2); }
.faq > summary {
  list-style: none; cursor: pointer; display: flex; align-items: center; gap: 20px;
  padding: 22px 4px; min-height: 44px;
  font-family: var(--serif); font-weight: 400; font-size: clamp(17px,2.1vw,21px);
  color: var(--ink); transition: color .15s;
}
.faq > summary:hover { color: var(--accent); }
.faq[open] > summary { color: var(--accent); }
.faq > summary::-webkit-details-marker { display: none; }
.faq > summary::after {
  content: ""; flex: none; margin-left: auto; width: 10px; height: 10px;
  border-right: 1.5px solid var(--ink-3); border-bottom: 1.5px solid var(--ink-3);
  transform: rotate(45deg) translateY(-3px); transition: transform .25s, border-color .15s;
}
.faq > summary:hover::after, .faq[open] > summary::after { border-color: var(--accent); }
.faq[open] > summary::after { transform: rotate(225deg) translateY(0); }
.faq > div { padding: 2px 40px 24px 4px; font-size: 16px; line-height: 1.7; color: var(--ink-2); max-width: 68ch; }

/* Kontakt — schlichte Zeile */
.faq-contact { margin: 30px 0 0; font-size: 16px; line-height: 1.6; color: var(--ink-2); }
.faq-contact strong { color: var(--ink); }
.faq-contact a { color: var(--accent); font-weight: 600; white-space: nowrap; }

@media (max-width: 600px) {
  /* Etwas mehr Rand-Luft auf Mobile */
  .wrap { padding-left: 22px; padding-right: 22px; }
  .grid { grid-template-columns: 1fr; gap: 16px; }
  /* Bilder bleiben 1:1 (voll sichtbar, kein Crop) */
  /* Gratis-Leitfaden: Bild oben, Text unten, Formular gestapelt */
  .freeguide { grid-template-columns: 1fr; }
  .freeguide__img { aspect-ratio: 16/9; object-fit: cover; padding: 0; }
  .freeguide .row, .sample .row { flex-direction: column; align-items: stretch; }
  .freeguide .row .v2btn, .sample .row .v2btn { width: 100%; justify-content: center; }
  /* Checkout-Panel: volle Breite, oben andocken */
  .co { top: 0; left: 0; transform: none; width: 100vw; max-height: 100vh; border-radius: 0; }
  .co.is-open { transform: none; }
  .shop-hero { padding-top: clamp(24px, 8vw, 40px); }
  /* Größere Touch-Ziele für Consent-Checkboxen */
  .consent { padding: 4px 0; }
  .consent input { width: 22px; height: 22px; }
  /* FAQ-Kontakt-Callout stapeln */
  .faq-contact { grid-template-columns: 1fr; }
}

/* Bewegung reduzieren (Barrierefreiheit, PRODUCT.md) */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { transition-duration: .01ms !important; animation-duration: .01ms !important; scroll-behavior: auto !important; }
}
