/* ==========================================================================
   Your Social Hero Partners — Landing Redesign (pickt.io -> Sunset Pop)
   landing-redesign.css | shared foundation: tokens, panels, buttons, pills,
   orbs, badges, marquee, motion. Sektions-spezifisches CSS lebt im jeweiligen
   landing-*.php <style>-Block (Self-contained-Partial-Pattern).
   Baut auf tokens.css auf (--yshp-*). NICHT die alte landing.css.
   ========================================================================== */

/* ==========================================================================
   0. LANDING-TOKENS (ergaenzend zu tokens.css)
   ========================================================================== */
:root {
  /* -- Block-Farben (Sunset Pop) -- */
  --l-purple:    var(--yshp-cta);     /* #5B21B6 */
  --l-orange:    var(--yshp-signal);  /* #FF7849 */
  --l-magenta:   var(--yshp-pop);     /* #EC4899 */
  --l-ink:       var(--yshp-ink);     /* #1E1B4B Midnight */
  --l-canvas:    #FFFBF5;             /* Creme-Buehne */
  --l-white:     #FFFFFF;

  /* -- Tints (heller Ton je Farbe, fuer Badges/Pills auf hellem Grund) -- */
  --l-tint-purple:  #F3EEFB;
  --l-tint-orange:  #FFF1EA;
  --l-tint-magenta: #FDECF5;

  /* -- Radien (groesser als Dashboard, pickt-floating-panel) -- */
  --l-r-panel:  36px;
  --l-r-card:   24px;
  --l-r-badge:  18px;
  --l-r-btn:    16px;
  --l-r-pill:   9999px;

  /* -- Panel-Layout -- */
  --l-stage-pad:    clamp(14px, 2.4vw, 28px);
  --l-panel-pad-y:  clamp(48px, 7vw, 104px);
  --l-panel-pad-x:  clamp(26px, 5vw, 80px);
  --l-section-gap:  clamp(52px, 8vw, 116px);
  --l-maxw:         1180px;

  /* -- Typo-Skala (fluid, tightes negatives Tracking = Premium-Hebel) -- */
  --l-fs-display: clamp(40px, 5.4vw, 76px);
  --l-fs-h2:      clamp(30px, 3.6vw, 54px);
  --l-fs-badge:   clamp(30px, 4.4vw, 62px);
  --l-fs-h3:      clamp(20px, 1.8vw, 26px);
  --l-fs-lead:    clamp(17px, 1.35vw, 21px);
  --l-fs-body:    16px;
  --l-fs-pill:    15px;
  --l-fs-eyebrow: 13px;

  /* -- On-Color-Text -- */
  --l-on-dark:        #FFFFFF;
  --l-on-dark-muted:  rgba(255,255,255,0.74);
  --l-on-dark-edge:   rgba(255,255,255,0.16);

  /* -- Deko-Orbs (transluzente Block-Farbe) -- */
  --l-orb-orange:  rgba(255,120,73,0.22);
  --l-orb-magenta: rgba(236,72,153,0.20);
  --l-orb-purple:  rgba(124,58,237,0.22);
  --l-orb-soft:    rgba(91,33,182,0.06);

  --l-ease: cubic-bezier(0.16, 1, 0.3, 1);
}

/* ==========================================================================
   1. BASE
   ========================================================================== */
html { overflow-x: clip; }
.ysh-landing,
body.ms-landing {
  margin: 0;
  overflow-x: clip;
  background: var(--l-canvas);
  color: var(--l-ink);
  font-family: var(--yshp-font);
  font-size: var(--l-fs-body);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.ysh-landing *,
.ysh-landing *::before,
.ysh-landing *::after,
body.ms-landing *,
body.ms-landing *::before,
body.ms-landing *::after { box-sizing: border-box; }

/* Headline-Reset via :where() -> Spezifität (0,0,1). So gilt der Reset als Default
   für alle Headlines, ABER jede sektionsspezifische `.l-xxx__h2`-Regel (0,1,0)
   gewinnt (Margins/Zentrierung/Farbe). Vorher war der Reset `.ysh-landing h2`
   (0,1,1) und überstimmte `margin: 0 auto` (-> Überschrift links statt mittig)
   und `margin-bottom` der Farb-Blöcke. */
:where(.ysh-landing) h1,
:where(.ysh-landing) h2,
:where(.ysh-landing) h3,
:where(body.ms-landing) h1,
:where(body.ms-landing) h2,
:where(body.ms-landing) h3 { margin: 0; font-weight: 700; color: var(--l-ink); }

/* Dark/Farb-Block-Headlines MÜSSEN weiß bleiben. Die globale h2/h3-Regel oben
   ist eine direkte Regel (Spezifität 0,1,1) und schlägt sonst die vererbte
   weiße Panel-Farbe → Headline würde dunkel/unlesbar auf dem farbigen Block.
   Diese Selektoren (0,2,0 / 0,3,0) überstimmen die globale Regel deterministisch. */
.ysh-landing .l-problem__h2,
.ysh-landing .l-marge__h2,
.ysh-landing .l-retention__h2,
.ysh-landing .l-trust__h2,
.ysh-landing .l-trust__pillar-title,
.ysh-landing .l-anfrage .l-h2,
.ysh-landing .l-anfrage h3,
body.ms-landing .l-problem__h2,
body.ms-landing .l-marge__h2,
body.ms-landing .l-retention__h2,
body.ms-landing .l-trust__h2,
body.ms-landing .l-trust__pillar-title,
body.ms-landing .l-anfrage .l-h2,
body.ms-landing .l-anfrage h3 { color: var(--l-on-dark); }

/* Display / Section headlines: tightes negatives Tracking */
.l-display {
  font-size: var(--l-fs-display);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.035em;
}
.l-h2 {
  font-size: var(--l-fs-h2);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.025em;
}
.l-lead {
  font-size: var(--l-fs-lead);
  font-weight: 400;
  line-height: 1.5;
  color: var(--yshp-lead);
}
.l-eyebrow {
  font-size: var(--l-fs-eyebrow);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--l-magenta);
  margin: 0 0 14px;
}

/* ==========================================================================
   2. SECTION / PANEL
   ========================================================================== */
.l-section { padding: 0 var(--l-stage-pad); margin-top: var(--l-section-gap); overflow-x: clip; scroll-margin-top: 84px; }
body.ms-landing #ms-landing,
.ysh-landing #ms-landing { overflow-x: clip; }
.l-section--flush { margin-top: 0; }

/* Voller Block, schwebt auf der Buehne mit grossem Radius */
.l-panel {
  position: relative;
  max-width: var(--l-maxw);
  margin: 0 auto;
  padding: var(--l-panel-pad-y) var(--l-panel-pad-x);
  border-radius: var(--l-r-panel);
  overflow: hidden;
  isolation: isolate;
}
.l-panel--ink      { background: var(--l-ink);    color: var(--l-on-dark); }
.l-panel--purple   { background: var(--l-purple); color: var(--l-on-dark); }
.l-panel--magenta-tint { background: var(--l-tint-magenta); }
.l-panel--sunset   { background: var(--yshp-gradient-brand); color: var(--l-on-dark); }
.l-panel--money    { background: linear-gradient(135deg, var(--l-orange), var(--l-magenta)); color: var(--l-on-dark); }
.l-panel--ink h2, .l-panel--ink h3,
.l-panel--purple h2, .l-panel--purple h3,
.l-panel--sunset h2, .l-panel--sunset h3,
.l-panel--money h2, .l-panel--money h3 { color: var(--l-on-dark); }
.l-panel--ink .l-lead,
.l-panel--purple .l-lead,
.l-panel--sunset .l-lead,
.l-panel--money .l-lead { color: var(--l-on-dark-muted); }

/* Canvas-Sektion (kein Block, nur Inhalt auf der Buehne) */
.l-canvas-inner { position: relative; max-width: var(--l-maxw); margin: 0 auto; }

/* Rescue-Invarianten: partielles CSS wird nach wp_head() ausgegeben. */
body.ms-landing .l-methode__visual,
.ysh-landing .l-methode__visual {
  align-self: start !important;
  grid-template-columns: 1fr !important;
}

body.ms-landing .l-ablauf__card,
.ysh-landing .l-ablauf__card {
  flex: 1 0 auto !important;
}

body.ms-landing .ms-l-header__logo,
.ysh-landing .ms-l-header__logo {
  align-items: center !important;
}

body.ms-landing .l-trust__intro,
.ysh-landing .l-trust__intro {
  max-width: none !important;
}

body.ms-landing .l-trust__band,
.ysh-landing .l-trust__band {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: clamp(20px, 3vw, 48px);
  margin: clamp(28px, 4vw, 44px) auto clamp(6px, 1vw, 12px);
  padding: clamp(24px, 3vw, 38px) clamp(20px, 3vw, 44px);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--l-on-dark-edge);
  border-radius: var(--l-r-card);
  max-width: 900px;
}

body.ms-landing .l-trust__bandstat,
.ysh-landing .l-trust__bandstat {
  flex: 1 1 200px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

body.ms-landing .l-trust__bandnumwrap,
.ysh-landing .l-trust__bandnumwrap {
  display: inline-block;
  line-height: 1;
  white-space: nowrap;
}

body.ms-landing .l-hcard--p4,
.ysh-landing .l-hcard--p4 {
  top: 31% !important;
}

@media (min-width: 901px) {
  body.ms-landing .l-value__grid,
  .ysh-landing .l-value__grid {
    grid-template-columns: repeat(6, 1fr) !important;
  }

  body.ms-landing .l-value__grid .l-vcard,
  .ysh-landing .l-value__grid .l-vcard {
    grid-column: span 2 !important;
  }

  body.ms-landing .l-value__grid .l-vcard:nth-child(4),
  .ysh-landing .l-value__grid .l-vcard:nth-child(4) {
    grid-column: 2 / span 2 !important;
  }

  body.ms-landing .l-value__grid .l-vcard:nth-child(5),
  .ysh-landing .l-value__grid .l-vcard:nth-child(5) {
    grid-column: 4 / span 2 !important;
  }
}

@media (max-width: 900px) {
  body.ms-landing .l-value__grid,
  .ysh-landing .l-value__grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  body.ms-landing .l-value__grid .l-vcard,
  body.ms-landing .l-value__grid .l-vcard:nth-child(4),
  body.ms-landing .l-value__grid .l-vcard:nth-child(5),
  .ysh-landing .l-value__grid .l-vcard,
  .ysh-landing .l-value__grid .l-vcard:nth-child(4),
  .ysh-landing .l-value__grid .l-vcard:nth-child(5) {
    grid-column: auto !important;
  }
}

@media (max-width: 600px) {
  body.ms-landing .l-value__grid,
  .ysh-landing .l-value__grid {
    grid-template-columns: 1fr !important;
  }
}

/* ==========================================================================
   3. DEKO-ORBS
   ========================================================================== */
.l-orb {
  position: absolute;
  border-radius: 50%;
  z-index: 0;
  pointer-events: none;
  filter: blur(2px);
}
.l-orb--orange  { background: radial-gradient(circle, var(--l-orb-orange), transparent 70%); }
.l-orb--magenta { background: radial-gradient(circle, var(--l-orb-magenta), transparent 70%); }
.l-orb--purple  { background: radial-gradient(circle, var(--l-orb-purple), transparent 70%); }
.l-panel > .l-orb { z-index: 0; }
.l-panel > *:not(.l-orb) { position: relative; z-index: 1; }

/* ==========================================================================
   4. BUTTONS
   ========================================================================== */
.l-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 17px 32px;
  border: 2px solid transparent;
  border-radius: var(--l-r-btn);
  font-family: var(--yshp-font);
  font-size: 17px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: -0.01em;
  text-decoration: none;
  cursor: pointer;
  transition: transform 0.2s var(--l-ease), box-shadow 0.2s var(--l-ease), background 0.15s ease, color 0.15s ease;
}
.l-btn svg { transition: transform 0.2s var(--l-ease); }
.l-btn:hover svg { transform: translateX(3px); }
.l-btn:hover { transform: translateY(-2px); }

.l-btn--primary { background: var(--l-purple); color: #fff; box-shadow: var(--yshp-shadow-sm); }
.l-btn--primary:hover { background: var(--yshp-cta-hover); box-shadow: var(--yshp-shadow-lg); }

.l-btn--accent { background: var(--l-orange); color: #fff; box-shadow: var(--yshp-shadow-sm); }
.l-btn--accent:hover { background: var(--yshp-signal-hover); box-shadow: var(--yshp-shadow-lg); }

.l-btn--on-dark { background: #fff; color: var(--l-ink); box-shadow: var(--yshp-shadow-md); }
.l-btn--on-dark:hover { box-shadow: var(--yshp-shadow-xl); }

.l-btn--ghost-light { background: transparent; border-color: var(--l-on-dark-edge); color: #fff; }
.l-btn--ghost-light:hover { background: rgba(255,255,255,0.10); }

.l-btn--link {
  background: transparent; border: none; padding: 17px 8px;
  color: var(--l-purple); font-weight: 600;
}
.l-panel--ink .l-btn--link,
.l-panel--purple .l-btn--link { color: #fff; }

/* ==========================================================================
   5. PILL-TAGS
   ========================================================================== */
.l-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: var(--l-r-pill);
  background: #fff;
  color: var(--l-ink);
  font-size: var(--l-fs-pill);
  font-weight: 600;
  line-height: 1;
  box-shadow: var(--yshp-shadow-xs);
  white-space: nowrap;
}
.l-pill svg, .l-pill .l-pill__emoji { flex-shrink: 0; }
.l-pill__emoji { font-size: 17px; }
.l-pill--on-dark { background: rgba(255,255,255,0.10); color: #fff; border: 1px solid var(--l-on-dark-edge); box-shadow: none; }

/* ==========================================================================
   6. HERO WORT-BADGES (gestapelte, mehrfarbige Headline-Woerter)
   ========================================================================== */
.l-badge {
  display: inline-block;
  padding: 0.06em 0.32em;
  border-radius: var(--l-r-badge);
  line-height: 1.18;
  letter-spacing: -0.03em;
}
.l-badge--purple  { color: var(--l-purple);  background: var(--l-tint-purple); }
.l-badge--orange  { color: var(--l-orange);  background: var(--l-tint-orange); }
.l-badge--magenta { color: var(--l-magenta); background: var(--l-tint-magenta); }
.l-badge--fill    { color: #fff; background: var(--l-orange); }

/* ==========================================================================
   7. EMOJI-ZIELGRUPPEN-MARQUEE
   ========================================================================== */
.l-marquee {
  overflow: hidden;
  width: 100%;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.l-marquee__track {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  white-space: nowrap;
  animation: l-marquee 38s linear infinite;
  will-change: transform;
}
.l-marquee__track .l-pill { box-shadow: var(--yshp-shadow-sm); }
@keyframes l-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ==========================================================================
   8. MOTION (Scroll-Reveal + Float)
   ========================================================================== */
/* Progressive Enhancement: Reveal-Versteck NUR wenn JS aktiv (.l-js am <html>).
   Ohne JS bleibt der Inhalt sofort sichtbar (kein Blank-Risiko). */
.l-reveal {
  transition: opacity 0.6s var(--l-ease), transform 0.6s var(--l-ease);
}
.l-js .l-reveal {
  opacity: 0;
  transform: translateY(24px);
}
.l-reveal.is-in { opacity: 1; transform: none; }

@keyframes l-float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-7px); }
}

@media (prefers-reduced-motion: reduce) {
  .l-marquee__track { animation: none; }
  .l-reveal { opacity: 1; transform: none; transition: none; }
  .l-float { animation: none !important; }
}
