/* =========================================================
   mondschön event pages. info-first layout.
   Genutzt von weiblichkeit-und-intimitaet, womens-retreat,
   jakobsweg-*, auszeit-morschach.
   ========================================================= */

:root {
  --ms-ink: #2D2028;
  --ms-plum: #4A2F3D;
  --ms-plum-deep: #3a2231;
  --ms-plum-mist: #7B5B6A;
  --ms-cream: #f7ede2;
  --ms-cream-warm: #efe1d1;
  --ms-cream-deep: #e2cdb6;
  --ms-copper: #c8915e;
  --ms-copper-soft: #d4a373;
  --ms-rose: #c95d8e;
  --ms-rose-soft: #e8b4cb;
  --ms-forest: #4a5b3e;
  --ms-teal: #4a7068;
  --ms-clay: #b56b4c;
  --ms-serif: 'Cormorant Garamond', Georgia, serif;
  --ms-sans: 'Plus Jakarta Sans', sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { background: var(--ms-cream); color: var(--ms-ink); font-family: var(--ms-sans); -webkit-font-smoothing: antialiased; overflow-x: hidden; margin: 0; }

/* NAV */
.ms-nav { position: fixed; top: 0; left: 0; right: 0; z-index: 50; display: flex; justify-content: space-between; align-items: center; padding: 22px clamp(24px, 5vw, 64px); background: rgba(58,34,49,0.85); backdrop-filter: blur(14px); transition: padding .4s ease, background .4s ease; }
.ms-nav.scrolled { padding: 14px clamp(24px, 5vw, 64px); background: rgba(58,34,49,0.95); }
.ms-nav-brand { font-family: var(--ms-serif); font-size: 22px; font-weight: 400; color: var(--ms-cream); text-decoration: none; }
.ms-nav-brand .a { color: var(--ms-copper-soft); font-weight: 500; }
.ms-nav-links { display: flex; gap: 28px; list-style: none; margin: 0; padding: 0; align-items: center; }
.ms-nav-links a { font-size: 11px; font-weight: 500; letter-spacing: 2px; text-transform: uppercase; color: rgba(247,237,226,0.72); text-decoration: none; transition: color .3s ease; }
.ms-nav-links a:hover { color: var(--ms-copper-soft); }
.ms-nav-cta { padding: 10px 20px; border: 1px solid rgba(247,237,226,0.32); border-radius: 100px; color: var(--ms-cream) !important; }
.ms-nav-cta:hover { background: var(--accent, var(--ms-copper)); color: var(--ms-plum-deep) !important; border-color: var(--accent, var(--ms-copper)); }
@media (max-width: 860px) { .ms-nav-links li:not(.ms-nav-cta-wrap) { display: none; } }

/* HERO */
.hero {
  padding: 130px clamp(24px, 5vw, 72px) 64px;
  background:
    radial-gradient(ellipse at 85% 15%, var(--hero-glow-a, rgba(200,145,94,0.22)) 0%, transparent 55%),
    radial-gradient(ellipse at 15% 90%, var(--hero-glow-b, rgba(74,91,62,0.28)) 0%, transparent 55%),
    linear-gradient(160deg, #2a1322 0%, #3a2231 55%, #4A2F3D 100%);
  color: var(--ms-cream); position: relative; overflow: hidden;
}
.hero-grid { max-width: 1180px; margin: 0 auto; display: grid; grid-template-columns: 1.3fr 1fr; gap: clamp(40px, 5vw, 72px); align-items: end; }
.hero-eyebrow { font-size: 11px; font-weight: 500; letter-spacing: 3.5px; text-transform: uppercase; color: var(--accent-soft, var(--ms-copper-soft)); margin-bottom: 18px; display: inline-flex; align-items: center; gap: 14px; }
.hero-eyebrow::before { content: ''; width: 30px; height: 1px; background: var(--accent, var(--ms-copper)); }
.hero-title { font-family: var(--ms-serif); font-size: clamp(46px, 6vw, 78px); font-weight: 300; line-height: 1; margin: 0 0 18px; letter-spacing: -1px; color: var(--ms-cream); }
.hero-title strong { font-weight: 400; color: var(--accent-soft, var(--ms-copper-soft)); }
.hero-sub { font-family: var(--ms-serif); font-size: clamp(20px, 2.4vw, 26px); font-weight: 300; color: rgba(247,237,226,0.82); margin: 0 0 32px; line-height: 1.35; max-width: 520px; }
.hero-lead { font-size: 15px; line-height: 1.75; color: rgba(247,237,226,0.72); max-width: 460px; margin: 0 0 36px; font-weight: 300; }
.hero-lead strong { color: var(--ms-cream); font-weight: 500; }
.hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; }

.btn { display: inline-flex; align-items: center; gap: 10px; font-size: 12px; font-weight: 500; letter-spacing: 1.6px; text-transform: uppercase; padding: 16px 28px; border-radius: 100px; text-decoration: none; transition: transform .4s, background .4s, color .4s, box-shadow .4s; cursor: pointer; }
.btn-primary { background: var(--accent, var(--ms-copper)); color: var(--ms-plum-deep); box-shadow: 0 10px 30px rgba(0,0,0,0.18); }
.btn-primary:hover { background: var(--ms-cream); transform: translateY(-2px); }
.btn-ghost { color: var(--ms-cream); border: 1px solid rgba(247,237,226,0.32); }
.btn-ghost:hover { background: rgba(247,237,226,0.08); }

.hero-facts { display: grid; gap: 2px; background: rgba(247,237,226,0.06); border: 1px solid rgba(247,237,226,0.18); border-radius: 6px; overflow: hidden; backdrop-filter: blur(8px); }
.hero-fact { padding: 18px 22px; display: grid; grid-template-columns: 100px 1fr; gap: 16px; align-items: baseline; background: rgba(247,237,226,0.02); }
.hero-fact dt { font-size: 10px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; color: var(--accent-soft, var(--ms-copper-soft)); margin: 0; }
.hero-fact dd { margin: 0; font-family: var(--ms-serif); font-size: 18px; font-weight: 400; color: var(--ms-cream); line-height: 1.3; }
.hero-fact dd .sub { display: block; font-family: var(--ms-sans); font-size: 12px; font-weight: 300; color: rgba(247,237,226,0.6); margin-top: 2px; }
@media (max-width: 860px) { .hero-grid { grid-template-columns: 1fr; } .hero { padding-top: 110px; } }

/* STRIP */
.strip { padding: 24px clamp(24px, 5vw, 72px); background: var(--ms-plum-deep); border-top: 1px solid rgba(247,237,226,0.08); }
.strip-inner { max-width: 1180px; margin: 0 auto; display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }
.pill { font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 8px 16px; border-radius: 100px; border: 1px solid var(--pill-border, rgba(212,163,115,0.3)); color: var(--accent-soft, var(--ms-copper-soft)); }

/* BENTO */
.bento { padding: clamp(56px, 8vw, 96px) clamp(24px, 5vw, 72px); background: var(--ms-cream); }
.bento-grid { max-width: 1180px; margin: 0 auto; display: grid; grid-template-columns: 1.2fr 1fr; gap: 20px; }
.bento-grid.eq { grid-template-columns: 1fr 1fr; }
.card { background: var(--ms-cream-warm); border-radius: 8px; padding: 32px clamp(24px, 3vw, 36px); position: relative; }
.card.dark { background: var(--ms-plum); color: var(--ms-cream); }
.card.forest { background: linear-gradient(135deg, #efe1d1 0%, #d4dec3 100%); border: 1px solid rgba(74,91,62,0.18); }
.card.rose { background: linear-gradient(135deg, #efe1d1 0%, #e8c8d2 100%); }
.card.clay { background: linear-gradient(135deg, #efe1d1 0%, #e2c4af 100%); border: 1px solid rgba(181,107,76,0.18); }
.card.teal { background: linear-gradient(135deg, #efe1d1 0%, #c4d5d2 100%); border: 1px solid rgba(74,112,104,0.18); }
.card-eyebrow { font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--ms-copper); margin-bottom: 14px; }
.card.dark .card-eyebrow { color: var(--accent-soft, var(--ms-copper-soft)); }
.card.forest .card-eyebrow { color: var(--ms-forest); }
.card.rose .card-eyebrow { color: var(--ms-rose); }
.card.clay .card-eyebrow { color: var(--ms-clay); }
.card.teal .card-eyebrow { color: var(--ms-teal); }
.card-title { font-family: var(--ms-serif); font-size: clamp(22px, 2.6vw, 30px); font-weight: 400; color: var(--ms-plum); line-height: 1.15; margin: 0 0 16px; letter-spacing: -0.3px; }
.card.dark .card-title { color: var(--ms-cream); }
.card-body p { font-size: 14.5px; line-height: 1.7; color: rgba(45,32,40,0.78); font-weight: 300; margin: 0 0 12px; }
.card.dark .card-body p { color: rgba(247,237,226,0.78); }

.feature-list { list-style: none; padding: 0; margin: 16px 0 0; display: flex; flex-wrap: wrap; gap: 8px; }
.feature-list li { font-size: 11px; font-weight: 600; letter-spacing: 1.2px; text-transform: uppercase; padding: 8px 14px; border-radius: 100px; background: rgba(255,255,255,0.55); color: var(--ms-plum); }
.card.forest .feature-list li { background: rgba(74,91,62,0.12); color: var(--ms-forest); }
.card.rose .feature-list li { background: rgba(201,93,142,0.14); color: var(--ms-rose); }
.card.clay .feature-list li { background: rgba(181,107,76,0.14); color: var(--ms-clay); }
.card.teal .feature-list li { background: rgba(74,112,104,0.14); color: var(--ms-teal); }
.card.dark .feature-list li { background: rgba(247,237,226,0.08); color: var(--accent-soft, var(--ms-copper-soft)); }

.bullet-list { list-style: none; padding: 0; margin: 12px 0 0; }
.bullet-list li { font-size: 14px; line-height: 1.7; color: rgba(45,32,40,0.78); padding-left: 18px; position: relative; margin-bottom: 4px; font-weight: 300; }
.bullet-list li::before { content: ''; position: absolute; left: 0; top: 11px; width: 5px; height: 5px; border-radius: 50%; background: var(--accent, var(--ms-copper)); }
.card.dark .bullet-list li { color: rgba(247,237,226,0.82); }
.card.dark .bullet-list li::before { background: var(--accent-soft, var(--ms-copper-soft)); }

/* SCHEDULE */
.schedule-table { width: 100%; border-collapse: collapse; margin-top: 8px; }
.schedule-table td { padding: 10px 0; vertical-align: top; border-bottom: 1px solid rgba(247,237,226,0.1); font-size: 13.5px; line-height: 1.55; }
.schedule-table td:first-child { color: var(--accent-soft, var(--ms-copper-soft)); font-family: var(--ms-serif); font-size: 15px; white-space: nowrap; padding-right: 24px; width: 130px; }
.schedule-table td:last-child { color: rgba(247,237,226,0.85); }
.schedule-table td strong { display: block; color: var(--ms-cream); font-size: 11px; font-weight: 700; letter-spacing: 1.3px; text-transform: uppercase; margin-bottom: 3px; }
.schedule-table tr:last-child td { border-bottom: none; }

/* PRICE TABLE */
.price-table { width: 100%; border-collapse: collapse; margin-top: 8px; }
.price-table td { padding: 11px 0; border-bottom: 1px solid rgba(45,32,40,0.08); font-size: 13.5px; line-height: 1.4; }
.price-table tr:last-child td { border-bottom: none; }
.price-table td:first-child { color: rgba(45,32,40,0.72); }
.price-table td:last-child { font-family: var(--ms-serif); font-weight: 500; font-size: 16px; color: var(--ms-plum); text-align: right; white-space: nowrap; }
.price-table .group-head td { padding-top: 18px; font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ms-copper); font-weight: 700; border-bottom: none; }
.price-total { margin-top: 24px; padding-top: 18px; border-top: 1px solid rgba(45,32,40,0.18); display: flex; justify-content: space-between; align-items: baseline; }
.price-total .lbl { font-size: 10px; letter-spacing: 1.6px; text-transform: uppercase; color: var(--ms-plum); font-weight: 700; }
.price-total .val { font-family: var(--ms-serif); font-size: 26px; color: var(--accent, var(--ms-rose)); font-weight: 500; }

/* HOSTS */
.hosts { padding: clamp(48px, 6vw, 72px) clamp(24px, 5vw, 72px); background: var(--ms-cream-warm); }
.hosts-inner { max-width: 1180px; margin: 0 auto; }
.hosts-eyebrow { font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--ms-copper); margin-bottom: 8px; }
.hosts-title { font-family: var(--ms-serif); font-size: clamp(26px, 3vw, 36px); font-weight: 400; color: var(--ms-plum); margin: 0 0 28px; letter-spacing: -0.3px; }
.hosts-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.hosts-grid.solo { grid-template-columns: 1fr; max-width: 620px; }
.host { display: grid; grid-template-columns: 88px 1fr; gap: 20px; align-items: start; padding: 22px; background: var(--ms-cream); border-radius: 8px; }
.host-avatar { width: 88px; height: 88px; border-radius: 50%; overflow: hidden; background: var(--ms-cream-deep); }
.host-avatar img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.host-avatar.placeholder { display: flex; align-items: center; justify-content: center; font-family: var(--ms-serif); font-size: 36px; color: var(--accent, var(--ms-copper)); border: 1px solid rgba(0,0,0,0.1); }
.host-name { font-family: var(--ms-serif); font-size: 22px; font-weight: 400; color: var(--ms-plum); margin: 0 0 4px; line-height: 1.1; }
.host-role { font-size: 10px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ms-copper); margin-bottom: 10px; }
.host-bio { font-size: 13px; line-height: 1.6; color: rgba(45,32,40,0.72); font-weight: 300; margin: 0 0 8px; }
.host-link { font-size: 11px; font-weight: 600; letter-spacing: 1.2px; text-transform: uppercase; color: var(--accent, var(--ms-rose)); text-decoration: none; display: inline-flex; align-items: center; gap: 6px; }
.host-link:hover { color: var(--ms-plum); }

/* CTA */
.cta { padding: clamp(56px, 8vw, 96px) clamp(24px, 5vw, 72px); background: linear-gradient(135deg, var(--ms-plum) 0%, var(--ms-plum-deep) 100%); color: var(--ms-cream); text-align: center; }
.cta-inner { max-width: 720px; margin: 0 auto; }
.cta-title { font-family: var(--ms-serif); font-size: clamp(32px, 4.5vw, 48px); font-weight: 300; line-height: 1.1; margin: 0 0 16px; letter-spacing: -0.5px; }
.cta-title strong { font-weight: 500; color: var(--accent-soft, var(--ms-copper-soft)); }
.cta-sub { font-size: 15px; line-height: 1.7; color: rgba(247,237,226,0.72); margin: 0 0 32px; font-weight: 300; }
.cta-buttons { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.cta-deadline { margin-top: 28px; font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: rgba(247,237,226,0.5); }

/* FOOTER */
.ms-footer { background: var(--ms-plum-deep); color: rgba(247,237,226,0.55); padding: 48px clamp(24px, 5vw, 72px) 36px; text-align: center; border-top: 1px solid rgba(247,237,226,0.05); }
.ms-footer-brand { font-family: var(--ms-serif); font-size: 24px; font-weight: 400; color: var(--ms-cream); margin-bottom: 10px; }
.ms-footer-brand .a { color: var(--ms-copper-soft); font-weight: 500; }
.ms-footer p { font-size: 12px; line-height: 1.7; font-weight: 300; margin: 0 0 14px; }
.ms-footer-links a { color: rgba(247,237,226,0.55); text-decoration: none; font-size: 11px; letter-spacing: 1px; transition: color .3s ease; }
.ms-footer-links a:hover { color: var(--ms-cream); }
.ms-footer-links .sep { margin: 0 10px; opacity: 0.4; }

@media (max-width: 860px) {
  .bento-grid, .bento-grid.eq { grid-template-columns: 1fr; }
  .hosts-grid { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
  .host { grid-template-columns: 64px 1fr; gap: 14px; padding: 18px; }
  .host-avatar { width: 64px; height: 64px; }
  .host-avatar.placeholder { font-size: 26px; }
}

/* =========================================================
   KONTRAST-FIXES.
   Eyebrows + Labels auf Cream-Hintergrund brauchen WCAG AA
   4.5:1. Original Copper #c8915e ist nur 2.4:1.
   ========================================================= */
.card .card-eyebrow,
.card.rose .card-eyebrow { color: #8a5d3a; }
.card.rose .card-eyebrow { color: #a8417a; }
.card.forest .card-eyebrow { color: #3a4730; }
.card.clay .card-eyebrow { color: #8a4830; }
.card.teal .card-eyebrow { color: #355550; }

/* Feature-List items auf Cream */
.feature-list li { color: var(--ms-plum); }
.card.rose .feature-list li { background: rgba(201,93,142,0.18); color: #a8417a; }
.card.forest .feature-list li { background: rgba(74,91,62,0.18); color: #3a4730; }
.card.clay .feature-list li { background: rgba(181,107,76,0.18); color: #8a4830; }
.card.teal .feature-list li { background: rgba(74,112,104,0.18); color: #355550; }

/* Price-Table group-heads */
.price-table .group-head td { color: #8a5d3a; }
.price-total .lbl { color: var(--ms-plum); }
.price-total .val { color: var(--ms-plum); }

/* Hosts-Section Labels */
.hosts-eyebrow { color: #8a5d3a; }
.host-role { color: #8a5d3a; }

/* Hero-Facts dt-labels brauchen nicht aendern (auf Dark Plum OK) */

/* Footer-Brand-Accent */
.ms-footer-brand .a { color: #e0b384; }

/* Host-link */
.host-link { color: #a8417a; }

/* =========================================================
   Page-spezifische Eyebrow / Label Faerbungen
   (Kontakt, Kinder, Weibliche Intimitaet, Jakobsweg etc.)
   ========================================================= */

/* Kontakt-Page */
.ko-eyebrow { color: #a8417a; }
.ko-intents-label, .ko-praxis-eyebrow { color: #8a5d3a; }
.ko-action-label { color: rgba(45,32,40,0.7); }
.ko-praxis-meta div { color: rgba(45,32,40,0.82); }

/* Kinder-Page */
.signals-eyebrow, .offers-eyebrow { color: #8a5d3a; }
.kids-eyebrow { color: #3a4730; }
.kids-list li { color: #3a4730; }

/* Offers (Weibliche Intimitaet, Kinder) */
.offer-eyebrow { color: #8a5d3a; }
.offer.featured .offer-eyebrow { color: #a8417a; }
.offer-cta { color: #a8417a; }

/* Termine-Liste (WI) */
.termine-eyebrow { color: #8a5d3a; }
.termin-date .where { color: #8a5d3a; }
.termin-price { color: #a8417a; }
.termin-price .sub { color: #8a5d3a; }

/* Jakobsweg-Touren */
.tour-tag { background: rgba(74,112,104,0.14); color: #355550; }
.tour-cta { color: #355550; }
.tour-num { color: rgba(74,112,104,0.5); }

/* Hero-Tag pills */
.event-tag { color: var(--accent-soft); }
.pill { color: var(--accent-soft); }

/* CTA-deadline (auf Dark Plum) */
.cta-deadline, .signup-deadline { color: rgba(247,237,226,0.7); }


