/* ============================================
   KARIN ZEILINGER – Freebie Funnel v3
   Weinrot #870059 | Gold #C9A227 | Creme #FDF6EC
============================================ */

@import url('https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600&family=Mulish:ital,wght@0,300;0,400;0,600;0,700;0,800;0,900;1,400;1,600&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --weinrot:    #870059;
  --weinrot-dk: #6a0047;
  --gold:       #C9A227;
  --gold-lt:    #D4AF37;
  --creme:      #FDF6EC;
  --creme-dk:   #F5ECD8;
  --weiss:      #ffffff;
  --grau-lt:    #E8E0D8;
  --grau-mid:   #999090;
  --text:       #505050;
  --text-dk:    #2a2020;
}

html { scroll-behavior: smooth; font-size: 18px; }

body {
  font-family: 'Mulish', sans-serif;
  font-size: 1rem;
  line-height: 1.8;
  color: var(--text);
  background: var(--weiss);
}

img { display: block; max-width: 100%; }
p { margin-bottom: 1rem; }
p:last-child { margin-bottom: 0; }
a { color: inherit; }

/* ---- TYPOGRAPHY ---- */
h1 {
  font-family: 'Lora', serif;
  font-weight: 700;
  line-height: 1.2;
  color: var(--text-dk);
}
h2 {
  font-family: 'Lora', serif;
  font-weight: 600;
  line-height: 1.3;
  color: var(--weinrot);
}
h3 { font-family: 'Mulish', sans-serif; font-weight: 800; color: var(--text-dk); }

/* ---- LAYOUT ---- */
.container { max-width: 860px; margin: 0 auto; padding: 0 28px; }
.container--sm { max-width: 660px; }
.container--wide { max-width: 1000px; }
.text-center { text-align: center; }

/* ---- HEADER ---- */
.site-header {
  background: var(--weiss);
  padding: 20px 0;
  border-bottom: 1px solid var(--grau-lt);
  text-align: center;
}
.site-header__name {
  font-family: 'Lora', serif;
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--weinrot);
  text-decoration: none;
  display: block;
}
.site-header__sub {
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--grau-mid);
  margin-top: 2px;
}

/* ---- HERO ---- */
.hero {
  background: var(--creme);
  padding: 80px 0 72px;
  text-align: center;
  border-bottom: 3px solid var(--weinrot);
}
.hero__eyebrow {
  display: inline-block;
  background: var(--weinrot);
  color: var(--weiss);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 6px 20px;
  border-radius: 40px;
  margin-bottom: 28px;
}
.hero h1 {
  font-size: clamp(2.2rem, 5vw, 3.5rem);
  max-width: 780px;
  margin: 0 auto 20px;
  color: var(--text-dk);
}
.hero h1 em {
  font-style: italic;
  color: var(--weinrot);
}
.hero__sub {
  font-family: 'Mulish', sans-serif;
  font-size: clamp(1.05rem, 2vw, 1.2rem);
  color: var(--text);
  max-width: 560px;
  margin: 0 auto 40px;
  line-height: 1.75;
}
.hero__cta-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.hero__disclaimer {
  font-size: 0.75rem;
  color: var(--grau-mid);
  letter-spacing: 0.04em;
}

/* ---- BUTTONS ---- */
.btn {
  display: inline-block;
  font-family: 'Mulish', sans-serif;
  font-weight: 800;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: transform 0.15s, box-shadow 0.15s, background 0.2s;
  border-radius: 4px;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }

.btn--primary {
  background: var(--weinrot);
  color: var(--weiss);
  padding: 18px 52px;
  font-size: 1rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  box-shadow: 0 4px 20px rgba(135,0,89,0.3);
}
.btn--primary:hover { background: var(--weinrot-dk); box-shadow: 0 6px 28px rgba(135,0,89,0.4); }

.btn--gold {
  background: var(--gold);
  color: var(--weiss);
  padding: 18px 52px;
  font-size: 1rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  box-shadow: 0 4px 20px rgba(201,162,39,0.35);
}
.btn--gold:hover { background: var(--gold-lt); }

.btn--outline {
  background: transparent;
  color: var(--weinrot);
  border: 2px solid var(--weinrot);
  padding: 14px 40px;
  font-size: 0.88rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.btn--outline:hover { background: var(--weinrot); color: var(--weiss); }

/* ---- STATS BAR ---- */
.stats-bar {
  background: var(--weinrot);
  padding: 28px 0;
}
.stats-bar .container {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
  flex-wrap: wrap;
}
.stat-item {
  text-align: center;
  padding: 8px 40px;
  border-right: 1px solid rgba(255,255,255,0.2);
  flex: 1;
  min-width: 160px;
}
.stat-item:last-child { border-right: none; }
.stat-item__num {
  font-family: 'Lora', serif;
  font-size: 2rem;
  font-weight: 700;
  color: var(--gold-lt);
  line-height: 1;
  margin-bottom: 4px;
}
.stat-item__label {
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(253,246,236,0.8);
}

/* ---- SECTIONS ---- */
.section { padding: 80px 0; }
.section--creme { background: var(--creme); }
.section--weiss { background: var(--weiss); }
.section--weinrot { background: var(--weinrot); }
.section--creme-dk { background: var(--creme-dk); }

.section__eyebrow {
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 12px;
}
.section__title {
  font-size: clamp(1.7rem, 3.5vw, 2.6rem);
  margin-bottom: 16px;
}
.section__intro {
  font-size: 1.05rem;
  color: var(--text);
  max-width: 600px;
  margin: 0 auto 48px;
}

/* ---- PROBLEM SECTION ---- */
.problem-list {
  list-style: none;
  max-width: 620px;
  margin: 0 auto 40px;
}
.problem-list li {
  padding: 14px 0 14px 44px;
  position: relative;
  font-size: 1.05rem;
  border-bottom: 1px solid var(--grau-lt);
  color: var(--text);
}
.problem-list li:last-child { border-bottom: none; }
.problem-list li::before {
  content: '✗';
  position: absolute;
  left: 0;
  top: 14px;
  width: 28px;
  height: 28px;
  background: rgba(135,0,89,0.08);
  color: var(--weinrot);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  font-size: 0.85rem;
  line-height: 28px;
  text-align: center;
}

/* ---- BRIDGE / PROMISE ---- */
.promise-box {
  background: var(--weinrot);
  border-radius: 6px;
  padding: 48px 56px;
  text-align: center;
  max-width: 700px;
  margin: 0 auto;
}
.promise-box h2 {
  color: var(--weiss);
  font-size: clamp(1.4rem, 3vw, 2rem);
  margin-bottom: 16px;
}
.promise-box p {
  color: rgba(253,246,236,0.88);
  font-size: 1.05rem;
}

/* ---- WORKBOOK SECTION ---- */
.workbook-grid {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 64px;
  align-items: start;
}
.workbook-cover {
  border-radius: 5px;
  overflow: hidden;
  box-shadow: 0 12px 48px rgba(0,0,0,0.18);
  position: sticky;
  top: 24px;
}
.workbook-cover img { width: 100%; display: block; }

.benefit-num-list { list-style: none; margin: 28px 0; }
.benefit-num-list li {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  padding: 18px 0;
  border-bottom: 1px solid var(--grau-lt);
}
.benefit-num-list li:last-child { border-bottom: none; }
.benefit-num {
  min-width: 40px;
  width: 40px;
  height: 40px;
  background: var(--weinrot);
  color: var(--weiss);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  font-size: 0.9rem;
  flex-shrink: 0;
  margin-top: 2px;
}
.benefit-text strong {
  display: block;
  color: var(--text-dk);
  font-size: 1rem;
  margin-bottom: 3px;
}
.benefit-text span { font-size: 0.9rem; color: var(--text); }

/* ---- CHECK LIST ---- */
.check-list { list-style: none; margin: 20px 0; }
.check-list li {
  padding: 8px 0 8px 36px;
  position: relative;
  font-size: 1rem;
  color: var(--text);
}
.check-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--gold);
  font-weight: 900;
  font-size: 1.1rem;
  top: 8px;
}

/* ---- BIO SECTION ---- */
.bio-grid {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 72px;
  align-items: start;
}
.bio-photo {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  object-position: top;
  border-radius: 5px;
  transform: scaleX(-1);
}
.bio-text h2 { margin-bottom: 20px; }
.bio-text p { font-size: 0.97rem; }
.bio-quote {
  margin: 28px 0;
  padding: 20px 24px;
  border-left: 3px solid var(--gold-lt);
  background: var(--creme);
  border-radius: 0 4px 4px 0;
}
.bio-quote p {
  font-family: 'Lora', serif;
  font-style: italic;
  font-size: 1.05rem;
  color: var(--text-dk);
  margin: 0;
}
.bio-signature {
  font-family: 'Lora', serif;
  font-style: italic;
  font-size: 1.15rem;
  color: var(--gold);
  margin-top: 4px;
}
.bio-sub {
  font-size: 0.8rem;
  color: var(--grau-mid);
  margin-top: 2px;
}

/* ---- TESTIMONIAL ---- */
.testimonial-stripe {
  background: var(--weinrot);
  padding: 40px 0;
  text-align: center;
}
.testimonial-stripe blockquote {
  font-family: 'Lora', serif;
  font-style: italic;
  font-size: clamp(1rem, 2vw, 1.2rem);
  color: rgba(253,246,236,0.92);
  max-width: 700px;
  margin: 0 auto 12px;
  line-height: 1.75;
}
.testimonial-stripe cite {
  font-size: 0.8rem;
  color: rgba(253,246,236,0.55);
  letter-spacing: 0.08em;
  font-style: normal;
}

/* ---- OPT-IN SECTION ---- */
.optin-section {
  background: var(--creme);
  padding: 80px 0;
}
.optin-wrap {
  max-width: 680px;
  margin: 0 auto;
  text-align: center;
}
.optin-wrap h2 { margin-bottom: 8px; }
.optin-wrap .section__intro { margin-bottom: 32px; }
.optin-card {
  background: var(--weiss);
  border: 1px solid var(--grau-lt);
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 4px 32px rgba(135,0,89,0.08);
  display: grid;
  grid-template-columns: 200px 1fr;
}
.optin-card__image {
  background: var(--creme-dk);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 36px;
}
.optin-card__image img {
  max-width: 200px;
  margin: 0 auto;
  border-radius: 5px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.18);
}
.optin-card__form { padding: 40px 48px; text-align: left; }
.optin-card__tagline {
  font-family: 'Lora', serif;
  font-weight: 600;
  font-size: 1.15rem;
  color: var(--weinrot);
  margin-bottom: 8px;
}
.optin-card__title {
  font-family: 'Lora', serif;
  font-style: italic;
  font-size: 0.92rem;
  color: var(--gold);
  line-height: 1.5;
  margin-bottom: 24px;
  padding-left: 14px;
  border-left: 2px solid var(--gold-lt);
}
.field { margin-bottom: 12px; }
.field input {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid var(--grau-lt);
  border-radius: 4px;
  background: var(--weiss);
  font-family: 'Mulish', sans-serif;
  font-size: 0.95rem;
  color: var(--text);
  outline: none;
  transition: border-color 0.2s;
}
.field input::placeholder { color: var(--grau-mid); }
.field input:focus { border-color: var(--weinrot); }
.btn-submit {
  width: 100%;
  margin-top: 8px;
  padding: 17px 24px;
  background: var(--weinrot);
  color: var(--weiss);
  font-family: 'Mulish', sans-serif;
  font-weight: 800;
  font-size: 0.9rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  transition: background 0.2s;
}
.btn-submit:hover { background: var(--weinrot-dk); }
.form-privacy {
  font-size: 0.73rem;
  color: var(--grau-mid);
  margin-top: 14px;
  line-height: 1.6;
  text-align: center;
}

/* ---- CTA REPEAT SECTION ---- */
.cta-section {
  background: var(--weinrot);
  padding: 72px 0;
  text-align: center;
}
.cta-section h2 { color: var(--weiss); margin-bottom: 12px; }
.cta-section p { color: rgba(253,246,236,0.82); margin-bottom: 32px; max-width: 520px; margin-left: auto; margin-right: auto; }

/* ---- CLOSING ---- */
.closing-section {
  background: var(--creme-dk);
  padding: 56px 0;
  text-align: center;
}
.closing-text { font-family: 'Lora', serif; font-style: italic; font-size: 1.1rem; color: var(--text); }
.closing-name { font-family: 'Lora', serif; font-style: italic; font-size: 1.4rem; color: var(--gold); margin-top: 4px; }

/* ---- FOOTER ---- */
.site-footer {
  background: var(--weinrot-dk);
  padding: 28px 0;
  text-align: center;
}
.site-footer__links {
  display: flex;
  justify-content: center;
  gap: 32px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}
.site-footer a {
  font-size: 0.8rem;
  color: #ffffff;
  text-decoration: none;
  transition: color 0.2s;
}
.site-footer a:hover { color: var(--creme); }
.site-footer__copy { font-size: 0.72rem; color: #ffffff; }

/* ---- DIVIDER ---- */
.gold-line {
  width: 56px;
  height: 2px;
  background: var(--gold);
  margin: 16px auto 32px;
}
.gold-line--left { margin-left: 0; }

/* ---- MAILERLITE OVERRIDES ---- */
#mlb2-40747616.ml-form-embedContainer { display:block; margin:0; width:100% !important; }
#mlb2-40747616.ml-form-embedContainer .ml-form-embedWrapper { background-color:transparent !important; border:none !important; border-radius:0 !important; display:block !important; width:100% !important; max-width:100% !important; }
#mlb2-40747616.ml-form-embedContainer .ml-form-embedWrapper.embedForm { max-width:100% !important; }
#mlb2-40747616.ml-form-embedContainer .ml-form-align-center { text-align:left !important; }
#mlb2-40747616.ml-form-embedContainer .ml-form-embedBody { padding:0 !important; }
#mlb2-40747616.ml-form-embedContainer .ml-form-embedContent { margin-bottom:0 !important; }
#mlb2-40747616.ml-form-embedContainer .ml-form-formContent { margin-bottom:0 !important; }
#mlb2-40747616.ml-form-embedContainer .ml-form-fieldRow { margin-bottom:12px !important; }
#mlb2-40747616.ml-form-embedContainer .ml-form-fieldRow.ml-last-item { margin-bottom:0 !important; }
#mlb2-40747616.ml-form-embedContainer .ml-form-embedBody .ml-form-fieldRow input {
  background-color:#fff !important; color:#505050 !important;
  border:1px solid #E8E0D8 !important; border-radius:4px !important;
  font-family:'Mulish',sans-serif !important; font-size:0.95rem !important;
  padding:14px 16px !important; width:100% !important;
  box-sizing:border-box !important; line-height:1.5 !important; height:auto !important;
}
#mlb2-40747616.ml-form-embedContainer .ml-form-embedBody .ml-form-fieldRow input:focus { border-color:#870059 !important; outline:none; }
#mlb2-40747616.ml-form-embedContainer .ml-form-embedBody .ml-form-fieldRow input::placeholder { color:#999090 !important; }
#mlb2-40747616.ml-form-embedContainer .ml-form-embedBody .ml-form-embedSubmit { margin:8px 0 0 !important; }
#mlb2-40747616.ml-form-embedContainer .ml-form-embedBody .ml-form-embedSubmit button {
  background-color:#870059 !important; border:none !important; border-radius:4px !important;
  font-family:'Mulish',sans-serif !important; font-size:0.9rem !important;
  font-weight:800 !important; letter-spacing:0.1em !important; text-transform:uppercase !important;
  padding:17px 24px !important; width:100% !important; color:#fff !important; cursor:pointer;
}
#mlb2-40747616.ml-form-embedContainer .ml-form-embedBody .ml-form-embedSubmit button:hover { background-color:#6a0047 !important; }
#mlb2-40747616.ml-form-embedContainer .ml-form-successBody { padding:0 !important; }
#mlb2-40747616.ml-form-embedContainer .ml-form-successContent h4 { font-family:'Lora',serif !important; color:#870059 !important; font-size:1.2rem !important; }
#mlb2-40747616.ml-form-embedContainer .ml-form-successContent p { font-family:'Mulish',sans-serif !important; color:#505050 !important; }
#mlb2-40747616.ml-form-embedContainer .ml-field-group label { display:none !important; }

/* ---- CONFIRMATION PAGE ---- */
.confirm-hero { background:var(--creme); padding:72px 0 48px; text-align:center; }
.confirm-hero h1 { font-size:clamp(1.8rem,4vw,2.8rem); max-width:600px; margin:0 auto 16px; }
.confirm-hero p { font-family:'Lora',serif; font-style:italic; color:var(--text); }
.steps-section { background:var(--creme); padding:0 0 72px; }
.steps-container { max-width:620px; margin:0 auto; padding:0 28px; }
.step-item { display:flex; gap:20px; align-items:flex-start; background:var(--weiss); border:1px solid var(--grau-lt); border-radius:5px; padding:20px 24px; margin-bottom:10px; }
.step-num { min-width:34px; width:34px; height:34px; background:var(--gold-lt); color:var(--weiss); border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:900; font-size:0.85rem; flex-shrink:0; }
.step-text { font-size:0.93rem; color:var(--text); line-height:1.6; padding-top:6px; }
.wait-box { background:var(--weiss); border:1px solid var(--grau-lt); border-radius:5px; padding:32px 36px; text-align:center; margin-top:32px; }
.wait-box h3 { color:var(--weinrot); font-family:'Lora',serif; font-weight:600; font-size:1.1rem; margin-bottom:12px; }
.wait-box p { font-size:0.92rem; color:var(--text); font-style:italic; }
.belief-tags { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin-top:16px; }
.belief-tag { background:var(--creme-dk); border:1px solid var(--grau-lt); border-radius:40px; padding:6px 16px; font-size:0.8rem; font-style:italic; color:var(--text); }

/* ---- DOWNLOAD PAGE ---- */
.download-section { background:var(--creme); padding:80px 0; text-align:center; }
.download-check { color:var(--gold-lt); font-size:2.5rem; margin-bottom:20px; }
.download-section h1 { font-size:clamp(2rem,4.5vw,3rem); max-width:600px; margin:0 auto 12px; }
.btn-download {
  display:inline-block; padding:18px 52px;
  border:2px solid var(--gold-lt); border-radius:40px;
  background:transparent; color:var(--gold);
  font-family:'Mulish',sans-serif; font-weight:800;
  font-size:0.85rem; letter-spacing:0.14em; text-transform:uppercase;
  text-decoration:none; transition:background 0.2s,color 0.2s;
}
.btn-download:hover { background:var(--gold-lt); color:var(--weiss); }
.upsell-section { background:var(--creme-dk); padding:0 0 80px; }
.upsell-card {
  background:var(--weiss); border:1px solid var(--grau-lt); border-radius:6px;
  padding:48px; max-width:820px; margin:0 auto;
  display:grid; grid-template-columns:1fr 280px; gap:48px; align-items:start;
}
.upsell-badge { display:inline-block; font-size:0.68rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--gold); border:1px solid var(--gold-lt); border-radius:40px; padding:4px 14px; margin-bottom:16px; }
.upsell-card h2 { font-size:clamp(1.4rem,3vw,1.9rem); margin-bottom:16px; }
.upsell-card p { font-size:0.93rem; color:var(--text); line-height:1.8; }
.upsell-list { list-style:none; margin:20px 0 24px; }
.upsell-list li { padding:7px 0 7px 24px; position:relative; font-size:0.93rem; color:var(--text); }
.upsell-list li::before { content:'✓'; position:absolute; left:0; color:var(--gold-lt); font-weight:900; }
.upsell-price { font-family:'Lora',serif; font-weight:700; font-size:2rem; color:var(--text-dk); margin-bottom:4px; }
.upsell-price span { font-size:1rem; font-weight:400; color:var(--grau-mid); font-family:'Mulish',sans-serif; }
.upsell-note { font-size:0.76rem; color:var(--grau-mid); margin-bottom:24px; }
.btn-upsell { display:inline-block; padding:16px 28px; background:var(--weinrot); color:var(--weiss); font-family:'Mulish',sans-serif; font-weight:800; font-size:0.82rem; letter-spacing:0.1em; text-transform:uppercase; text-decoration:none; border-radius:4px; transition:background 0.2s; border:none; cursor:pointer; }
.btn-upsell:hover { background:var(--weinrot-dk); }
.upsell-photo { width:100%; height:auto; border-radius:5px; display:block; }

/* ---- RESPONSIVE ---- */
@media (max-width: 760px) {
  .workbook-grid { grid-template-columns:1fr; }
  .workbook-cover { max-width:220px; margin:0 auto; position:static; }
  .bio-grid { grid-template-columns:1fr; gap:36px; }
  .bio-photo { aspect-ratio:4/3; }
  .stats-bar .container { gap:0; }
  .stat-item { padding:12px 20px; min-width:140px; }
  .optin-card { grid-template-columns:1fr; }
  .optin-card__image { padding:28px; }
  .optin-card__image img { max-width:160px; }
  .optin-card__form { padding:32px 24px; }
  .promise-box { padding:36px 28px; }
  .upsell-card { grid-template-columns:1fr; padding:32px 24px; }
  .upsell-photo { max-width:300px; }
  .container { padding:0 20px; }
  .section { padding:56px 0; }
}
@media (max-width: 480px) {
  .hero { padding:56px 0 52px; }
  .btn--primary, .btn--gold { padding:16px 36px; }
  .stat-item { min-width:100%; border-right:none; border-bottom:1px solid rgba(255,255,255,0.15); }
  .stat-item:last-child { border-bottom:none; }

  /* Formularfelder auf Mobile besser lesbar */
  #mlb2-40747616.ml-form-embedContainer .ml-form-embedBody .ml-form-fieldRow input {
    border:2px solid #999090 !important;
    color:#2a2020 !important;
    font-size:1rem !important;
    padding:16px !important;
  }
  #mlb2-40747616.ml-form-embedContainer .ml-form-embedBody .ml-form-fieldRow input::placeholder {
    color:#707070 !important;
  }
  #mlb2-40747616.ml-form-embedContainer .ml-form-embedBody .ml-form-fieldRow input:focus {
    border-color:#870059 !important;
  }
}
