/* ════════════════════════════════════════════════════════════
   MINALOVE PUBLIC · ml-public.css
   Eigenständige Design-Basis für den öffentlichen Außenauftritt.
   UNABHÄNGIG von lbl-core.js und den App-Tokens (--ml-*).
   Eigener Namespace: --mlp-*

   Seiten: entdecken.html · fuer-studios.html · sa_onboarding.html
   Farbsystem gespiegelt aus minalove-tokens.css (Teal-Navy),
   wird hier aber bewusst dupliziert, damit der Auftritt
   separat steuerbar bleibt.
════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,400;1,9..144,500&family=Geist:wght@300;400;500;600;700&display=swap');

:root {
  /* ── Teal-Navy · Markenfarbe (fix, gespiegelt aus App) ── */
  --mlp-primary-900: #0D2F42;
  --mlp-primary-800: #133D56;
  --mlp-primary-700: #1A4F6E;   /* Haupt-Teal-Navy */
  --mlp-primary-600: #236B8E;
  --mlp-primary-400: #5B9AB5;
  --mlp-primary-200: #C2DCE8;
  --mlp-primary-100: #D6EAF2;
  --mlp-primary-50:  #EAF4F9;

  /* ── Coral · primärer Marketing-Akzent (Testen, Anmelden) ── */
  --mlp-coral-900: #991825;
  --mlp-coral-700: #C42035;
  --mlp-coral-600: #E8455A;
  --mlp-coral:     #E8455A;
  --mlp-coral-400: #F07585;
  --mlp-coral-100: #FBD0D8;
  --mlp-coral-50:  #FEF0F2;

  /* ── Cobalt/Blau · Buchen-CTAs (Endkunden-Buchung) ── */
  --mlp-book-700: #1A52D0;
  --mlp-book-600: #2563EB;
  --mlp-book-400: #4F83F5;
  --mlp-book-100: #DBEAFE;
  --mlp-book-50:  #EFF5FE;

  /* ── Neutral / Text ── */
  --mlp-ink:     #10212B;
  --mlp-ink-2:   #3D5666;
  --mlp-ink-3:   #6E8593;
  --mlp-line:    #D6E6EE;
  --mlp-line-2:  #E8F1F5;
  --mlp-cream:   #F7FBFD;
  --mlp-white:   #ffffff;

  /* ── Semantisch ── */
  --mlp-success:    #2E9E6B;
  --mlp-success-bg: #DEF3E9;
  --mlp-warning:    #C79A5B;
  --mlp-warning-bg: #FAF1E2;
  --mlp-danger:     #E8455A;
  --mlp-danger-bg:  #FEF0F2;

  /* ── Typografie ── */
  --mlp-font-display: 'Fraunces', Georgia, serif;     /* Headlines */
  --mlp-font-ui:      'Geist', system-ui, sans-serif; /* Body, UI, Software-Fenster */

  /* ── Radius ── */
  --mlp-radius-sm:   10px;
  --mlp-radius:      16px;
  --mlp-radius-lg:   22px;
  --mlp-radius-full: 9999px;

  /* ── Shadow ── */
  --mlp-shadow-sm: 0 4px 16px -6px rgba(13,47,66,.16);
  --mlp-shadow:    0 16px 48px -16px rgba(13,47,66,.26);
  --mlp-shadow-lg: 0 36px 90px -28px rgba(13,47,66,.40);

  /* ── Z-Index ── */
  --mlp-z-nav:   1000;
  --mlp-z-modal: 1100;
}

/* ════════════════════════════════════════
   RESET & BASE
═══════════════════════════════════════════ */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--mlp-font-ui);
  background: var(--mlp-cream);
  color: var(--mlp-ink);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
h1, h2, h3, h4 { font-family: var(--mlp-font-display); font-weight: 600; letter-spacing: -.02em; line-height: 1.1; }
em { font-style: italic; color: var(--mlp-primary-700); }
a { text-decoration: none; color: inherit; }
button { font-family: inherit; cursor: pointer; }
img { max-width: 100%; display: block; }

.mlp-container { max-width: 1180px; margin: 0 auto; padding: 0 28px; }
.mlp-section { padding: 88px 0; }

/* ════════════════════════════════════════
   NAVIGATION
═══════════════════════════════════════════ */
.mlp-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: var(--mlp-z-nav);
  background: rgba(247,251,253,.85);
  backdrop-filter: blur(16px) saturate(140%);
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  border-bottom: 1px solid transparent;
  transition: border-color .3s, box-shadow .3s;
}
.mlp-nav.scrolled { border-bottom-color: var(--mlp-line); box-shadow: var(--mlp-shadow-sm); }
.mlp-nav-inner { display: flex; align-items: center; justify-content: space-between; height: 70px; }

.mlp-brand { display: flex; align-items: center; gap: 11px; font-family: var(--mlp-font-display); font-size: 24px; font-weight: 600; color: var(--mlp-primary-700); letter-spacing: -.5px; }
.mlp-brand span { color: var(--mlp-ink); }

/* ── Logo-Mark (M mit Herz) als CSS-Mask: per color einfärbbar ──
   Standard: Teal-Navy. Auf dunklen Flächen .mlp-logo-mark--light setzen. */
.mlp-logo-mark {
  width: 30px; height: 33px; flex-shrink: 0;
  background-color: var(--mlp-primary-700);
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20viewBox%3D%220%200%20687.000000%20752.000000%22%20fill%3D%22%23000%22%3E%3Cg%20transform%3D%22translate%280.000000%2C752.000000%29%20scale%280.100000%2C-0.100000%29%22%20fill%3D%22%23000%22%20stroke%3D%22none%22%3E%3Cpath%20d%3D%22M905%207434%20c-16%20-2%20-70%20-9%20-119%20-15%20-167%20-21%20-272%20-77%20-421%20-223%20-107%0A-105%20-165%20-186%20-231%20-320%20l-54%20-109%200%20-2994%200%20-2995%2059%20-122%20c193%20-404%20505%0A-604%20906%20-582%20245%2013%20386%2080%20579%20274%20247%20249%20243%20224%20257%201457%205%20501%2013%20936%0A17%20969%20l7%2058%2085%20-88%20c47%20-49%20225%20-246%20395%20-439%20628%20-708%20722%20-805%20807%20-829%0A339%20-99%20513%20-26%20856%20359%2069%2077%20301%20335%20516%20573%20l391%20432%207%20-427%20c31%20-1895%2025%0A-1838%20238%20-2054%20262%20-264%20592%20-350%20935%20-242%20298%2094%20556%20364%20610%20638%2047%20241%2058%0A1084%2045%203485%20-15%202770%20-6%202667%20-263%202917%20-218%20212%20-389%20283%20-680%20283%20-243%200%0A-432%20-61%20-594%20-192%20-120%20-98%20-1322%20-1413%20-1341%20-1469%20-5%20-14%2037%20-11%20150%2011%0A456%2089%20860%20-78%201081%20-447%2095%20-158%20102%20-192%20101%20-468%200%20-327%20-18%20-379%20-214%0A-640%20-163%20-217%20-1041%20-1180%20-1332%20-1461%20-147%20-142%20-281%20-169%20-452%20-91%20-80%2037%0A-453%20422%20-1007%201042%20-569%20636%20-667%20818%20-645%201200%2021%20383%20270%20715%20626%20835%20107%0A36%20516%2038%20673%204%2064%20-15%2012%2051%20-453%20571%20-761%20851%20-942%201018%20-1168%201076%20-75%2019%0A-295%2033%20-367%2023z%22/%3E%3C/g%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20viewBox%3D%220%200%20687.000000%20752.000000%22%20fill%3D%22%23000%22%3E%3Cg%20transform%3D%22translate%280.000000%2C752.000000%29%20scale%280.100000%2C-0.100000%29%22%20fill%3D%22%23000%22%20stroke%3D%22none%22%3E%3Cpath%20d%3D%22M905%207434%20c-16%20-2%20-70%20-9%20-119%20-15%20-167%20-21%20-272%20-77%20-421%20-223%20-107%0A-105%20-165%20-186%20-231%20-320%20l-54%20-109%200%20-2994%200%20-2995%2059%20-122%20c193%20-404%20505%0A-604%20906%20-582%20245%2013%20386%2080%20579%20274%20247%20249%20243%20224%20257%201457%205%20501%2013%20936%0A17%20969%20l7%2058%2085%20-88%20c47%20-49%20225%20-246%20395%20-439%20628%20-708%20722%20-805%20807%20-829%0A339%20-99%20513%20-26%20856%20359%2069%2077%20301%20335%20516%20573%20l391%20432%207%20-427%20c31%20-1895%2025%0A-1838%20238%20-2054%20262%20-264%20592%20-350%20935%20-242%20298%2094%20556%20364%20610%20638%2047%20241%2058%0A1084%2045%203485%20-15%202770%20-6%202667%20-263%202917%20-218%20212%20-389%20283%20-680%20283%20-243%200%0A-432%20-61%20-594%20-192%20-120%20-98%20-1322%20-1413%20-1341%20-1469%20-5%20-14%2037%20-11%20150%2011%0A456%2089%20860%20-78%201081%20-447%2095%20-158%20102%20-192%20101%20-468%200%20-327%20-18%20-379%20-214%0A-640%20-163%20-217%20-1041%20-1180%20-1332%20-1461%20-147%20-142%20-281%20-169%20-452%20-91%20-80%2037%0A-453%20422%20-1007%201042%20-569%20636%20-667%20818%20-645%201200%2021%20383%20270%20715%20626%20835%20107%0A36%20516%2038%20673%204%2064%20-15%2012%2051%20-453%20571%20-761%20851%20-942%201018%20-1168%201076%20-75%2019%0A-295%2033%20-367%2023z%22/%3E%3C/g%3E%3C/svg%3E") center / contain no-repeat;
}
.mlp-logo-mark--light { background-color: #fff; }
.mlp-logo-mark--coral { background-color: var(--mlp-coral-600); }

.mlp-nav-links { display: flex; align-items: center; gap: 6px; }
.mlp-nav-links a { font-size: 14px; font-weight: 500; color: var(--mlp-ink-2); padding: 8px 14px; border-radius: 9px; transition: .2s; }
.mlp-nav-links a:hover { background: var(--mlp-primary-50); color: var(--mlp-primary-700); }

.mlp-burger { display: none; flex-direction: column; gap: 5px; background: none; border: none; padding: 8px; }
.mlp-burger span { width: 24px; height: 2px; background: var(--mlp-ink); border-radius: 2px; transition: .3s; }

@media (max-width: 880px) {
  .mlp-nav-links {
    position: fixed; inset: 70px 0 auto 0;
    background: var(--mlp-cream);
    flex-direction: column; gap: 0; padding: 0;
    max-height: 0; overflow: hidden; transition: max-height .35s;
    border-bottom: 1px solid var(--mlp-line);
  }
  .mlp-nav-links.open { max-height: 480px; }
  .mlp-nav-links a { width: 100%; text-align: center; padding: 18px; border-top: 1px solid var(--mlp-line); border-radius: 0; }
  .mlp-burger { display: flex; }
}

/* ════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════ */
.mlp-btn {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: inherit; font-size: 15px; font-weight: 600;
  padding: 14px 28px; border-radius: var(--mlp-radius-full);
  border: none; cursor: pointer; transition: all .22s;
  white-space: nowrap;
}
.mlp-btn-arrow { transition: transform .22s; }
.mlp-btn:hover .mlp-btn-arrow { transform: translateX(4px); }

/* Coral = primärer Marketing-CTA (Testen, Anmelden) */
.mlp-btn-coral { background: var(--mlp-coral-600); color: #fff; box-shadow: 0 12px 28px -10px rgba(232,69,90,.5); }
.mlp-btn-coral:hover { background: var(--mlp-coral-700); transform: translateY(-2px); box-shadow: 0 18px 38px -10px rgba(232,69,90,.6); }

/* Blau = Buchen-CTA (Endkunden-Buchung) */
.mlp-btn-book { background: var(--mlp-book-600); color: #fff; box-shadow: 0 12px 28px -10px rgba(37,99,235,.5); }
.mlp-btn-book:hover { background: var(--mlp-book-700); transform: translateY(-2px); box-shadow: 0 18px 38px -10px rgba(37,99,235,.6); }

/* Teal-Navy = sekundär/Marke */
.mlp-btn-primary { background: var(--mlp-primary-700); color: #fff; box-shadow: 0 12px 28px -10px rgba(26,79,110,.5); }
.mlp-btn-primary:hover { background: var(--mlp-primary-800); transform: translateY(-2px); }

.mlp-btn-ghost { background: var(--mlp-white); color: var(--mlp-ink); border: 1px solid var(--mlp-line); }
.mlp-btn-ghost:hover { border-color: var(--mlp-primary-600); color: var(--mlp-primary-700); transform: translateY(-2px); }

.mlp-btn-sm { padding: 10px 18px; font-size: 13.5px; }
.mlp-btn-lg { padding: 17px 36px; font-size: 16px; }

/* ════════════════════════════════════════
   PILL / BADGE / CHIP
═══════════════════════════════════════════ */
.mlp-pill {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--mlp-white); border: 1px solid var(--mlp-primary-100);
  color: var(--mlp-primary-800);
  font-size: 12.5px; font-weight: 600;
  padding: 7px 16px; border-radius: var(--mlp-radius-full);
  box-shadow: var(--mlp-shadow-sm);
}
.mlp-pill::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--mlp-success); box-shadow: 0 0 0 3px rgba(46,158,107,.2); }
.mlp-pill.no-dot::before { display: none; }

.mlp-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 11px; font-weight: 600; padding: 3px 10px; border-radius: var(--mlp-radius-full); }
.mlp-badge-success { background: var(--mlp-success-bg); color: #1f6e44; }
.mlp-badge-book    { background: var(--mlp-book-100);    color: var(--mlp-book-700); }
.mlp-badge-warning { background: var(--mlp-warning-bg);  color: #8a6a2e; }
.mlp-badge-coral   { background: var(--mlp-coral-50);    color: var(--mlp-coral-700); }

.mlp-chip {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--mlp-white); border: 1px solid var(--mlp-line);
  border-radius: var(--mlp-radius-full); padding: 11px 20px;
  font-size: 14.5px; font-weight: 500; color: var(--mlp-ink);
  transition: .25s; cursor: default;
}
.mlp-chip:hover { border-color: var(--mlp-primary-600); color: var(--mlp-primary-700); transform: translateY(-3px); box-shadow: var(--mlp-shadow-sm); }

/* ════════════════════════════════════════
   FORM
═══════════════════════════════════════════ */
.mlp-field { margin-bottom: 16px; }
.mlp-label { display: block; font-size: 11.5px; font-weight: 600; text-transform: uppercase; letter-spacing: .6px; color: var(--mlp-ink-3); margin-bottom: 6px; }
.mlp-label .req { color: var(--mlp-coral-600); }
.mlp-input, .mlp-select, .mlp-textarea {
  width: 100%; padding: 13px 15px;
  border: 1px solid var(--mlp-line); border-radius: var(--mlp-radius-sm);
  font-family: inherit; font-size: 15px; color: var(--mlp-ink);
  background: var(--mlp-white); transition: border-color .2s, box-shadow .2s;
}
.mlp-input:focus, .mlp-select:focus, .mlp-textarea:focus {
  outline: none; border-color: var(--mlp-book-600);
  box-shadow: 0 0 0 3px var(--mlp-book-100);
}
.mlp-textarea { min-height: 110px; resize: vertical; }
.mlp-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 540px) { .mlp-field-row { grid-template-columns: 1fr; } }

/* ════════════════════════════════════════
   CARD
═══════════════════════════════════════════ */
.mlp-card {
  background: var(--mlp-white); border: 1px solid var(--mlp-line);
  border-radius: var(--mlp-radius); padding: 28px;
  box-shadow: var(--mlp-shadow-sm);
}
.mlp-card-hover { transition: transform .3s, box-shadow .3s, border-color .3s; }
.mlp-card-hover:hover { transform: translateY(-6px); box-shadow: var(--mlp-shadow); border-color: var(--mlp-primary-200); }

/* ════════════════════════════════════════
   SECTION HEADERS
═══════════════════════════════════════════ */
.mlp-eyebrow { font-size: 12px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--mlp-primary-600); margin-bottom: 12px; }
.mlp-sec-head { text-align: center; max-width: 640px; margin: 0 auto 52px; }
.mlp-sec-head h2 { font-size: clamp(30px, 4.5vw, 46px); margin-bottom: 14px; }
.mlp-sec-head p { color: var(--mlp-ink-2); font-size: 17px; }

/* ════════════════════════════════════════
   INTERAKTIVES SOFTWARE-FENSTER
═══════════════════════════════════════════ */
.mlp-win {
  background: var(--mlp-white); border-radius: 18px; border: 1px solid var(--mlp-line);
  box-shadow: var(--mlp-shadow-lg); overflow: hidden;
  max-width: 1000px; margin: 0 auto;
  transition: transform .5s cubic-bezier(.2,.7,.2,1);
}
.mlp-win-bar { display: flex; align-items: center; gap: 7px; padding: 13px 18px; border-bottom: 1px solid var(--mlp-line); background: var(--mlp-primary-50); }
.mlp-win-bar i { width: 11px; height: 11px; border-radius: 50%; }
.mlp-win-bar i:nth-child(1){ background: #9CC6D8; }
.mlp-win-bar i:nth-child(2){ background: var(--mlp-primary-400); }
.mlp-win-bar i:nth-child(3){ background: var(--mlp-primary-700); }
.mlp-win-url { margin-left: 14px; font-size: 12px; color: var(--mlp-ink-3); }
.mlp-win-body { display: grid; grid-template-columns: 210px 1fr; min-height: 420px; }
.mlp-win-side { background: linear-gradient(180deg, #fff, #F1F8FB); border-right: 1px solid var(--mlp-line); padding: 20px 14px; }
.mlp-win-logo { font-family: var(--mlp-font-display); font-size: 17px; color: var(--mlp-primary-700); margin-bottom: 22px; font-weight: 600; padding-left: 8px; }
.mlp-tab {
  display: flex; align-items: center; gap: 11px; padding: 11px 13px;
  border-radius: 10px; font-size: 13px; color: var(--mlp-ink-2);
  margin-bottom: 3px; border: none; background: none; width: 100%; text-align: left;
  font-family: inherit; transition: .18s;
}
.mlp-tab:hover { background: var(--mlp-primary-50); }
.mlp-tab.active { background: var(--mlp-book-600); color: #fff; font-weight: 600; box-shadow: 0 8px 20px -8px rgba(37,99,235,.6); }
.mlp-tab .ic { width: 18px; height: 18px; border-radius: 6px; background: var(--mlp-primary-100); flex-shrink: 0; }
.mlp-tab.active .ic { background: rgba(255,255,255,.35); }
.mlp-win-main { padding: 26px 28px; position: relative; }
.mlp-panel { display: none; animation: mlp-fade .4s ease; }
.mlp-panel.show { display: block; }
@keyframes mlp-fade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.mlp-panel-h { font-family: var(--mlp-font-display); font-size: 22px; margin-bottom: 3px; }
.mlp-panel-sub { font-size: 12.5px; color: var(--mlp-ink-3); margin-bottom: 20px; }
.mlp-kpis { display: grid; grid-template-columns: repeat(3,1fr); gap: 13px; margin-bottom: 18px; }
.mlp-kpi { background: var(--mlp-cream); border: 1px solid var(--mlp-line); border-radius: 13px; padding: 15px; }
.mlp-kpi .l { font-size: 10px; color: var(--mlp-ink-3); text-transform: uppercase; letter-spacing: .5px; }
.mlp-kpi .v { font-family: var(--mlp-font-display); font-size: 26px; margin-top: 5px; }
.mlp-kpi .v.up { color: var(--mlp-success); }
.mlp-cal-row { display: flex; align-items: center; gap: 12px; padding: 10px 0; border-bottom: 1px dashed var(--mlp-line); }
.mlp-cal-row:last-child { border: none; }
.mlp-cal-t { font-size: 12px; color: var(--mlp-ink-3); width: 48px; }
.mlp-cal-appt { flex: 1; background: #fff; border-left: 3px solid var(--mlp-book-600); border-radius: 7px; padding: 9px 13px; font-size: 12.5px; box-shadow: var(--mlp-shadow-sm); }
.mlp-cal-appt.g { border-left-color: var(--mlp-warning); }
.mlp-cal-appt.s { border-left-color: var(--mlp-success); }
.mlp-dtbl { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.mlp-dtbl th { text-align: left; color: var(--mlp-ink-3); font-weight: 600; font-size: 10.5px; text-transform: uppercase; letter-spacing: .5px; padding: 8px 10px; border-bottom: 1px solid var(--mlp-line); }
.mlp-dtbl td { padding: 11px 10px; border-bottom: 1px solid var(--mlp-line); }
.mlp-hint { position: absolute; bottom: 18px; right: 24px; font-size: 11px; color: var(--mlp-ink-3); display: flex; align-items: center; gap: 6px; }
.mlp-hint .blink { width: 6px; height: 6px; border-radius: 50%; background: var(--mlp-book-600); animation: mlp-blink 1.4s infinite; }
@keyframes mlp-blink { 0%,100%{ opacity: 1; } 50%{ opacity: .2; } }
@media (max-width: 720px) {
  .mlp-win-body { grid-template-columns: 1fr; }
  .mlp-win-side { display: none; }
  .mlp-kpis { grid-template-columns: 1fr 1fr; }
}

/* ════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════ */
.mlp-foot { background: var(--mlp-primary-900); color: #bcd6e0; padding: 64px 0 40px; }
.mlp-foot a { color: #bcd6e0; transition: color .2s; }
.mlp-foot a:hover { color: #fff; }
.mlp-foot-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 48px; }
.mlp-foot h4 { font-family: var(--mlp-font-ui); font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .6px; color: #fff; margin-bottom: 16px; }
.mlp-foot ul { list-style: none; }
.mlp-foot li { padding: 5px 0; font-size: 14px; }
.mlp-foot-brand { font-family: var(--mlp-font-display); font-size: 26px; font-weight: 600; color: #fff; margin-bottom: 14px; }
.mlp-foot-bottom { border-top: 1px solid rgba(255,255,255,.12); padding-top: 28px; font-size: 13px; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
@media (max-width: 760px) { .mlp-foot-grid { grid-template-columns: 1fr 1fr; gap: 28px; } }

/* ════════════════════════════════════════
   ANIMATION UTILITIES
═══════════════════════════════════════════ */
@keyframes mlp-rise { to { opacity: 1; transform: translateY(0); } }
.mlp-rise { opacity: 0; transform: translateY(28px); animation: mlp-rise .9s cubic-bezier(.2,.7,.2,1) forwards; }
.mlp-rise.d1 { animation-delay: .12s; }
.mlp-rise.d2 { animation-delay: .24s; }
.mlp-rise.d3 { animation-delay: .36s; }
.mlp-rise.d4 { animation-delay: .48s; }

/* Scroll-Reveal (von ml-public.js gesteuert) */
.mlp-reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.mlp-reveal.in { opacity: 1; transform: translateY(0); }

/* ════════════════════════════════════════
   PRICING-TOGGLE (Monatlich / Jährlich)
═══════════════════════════════════════════ */
.mlp-toggle { display: inline-flex; align-items: center; gap: 14px; background: var(--mlp-white); border: 1px solid var(--mlp-line); border-radius: var(--mlp-radius-full); padding: 6px; box-shadow: var(--mlp-shadow-sm); }
.mlp-toggle button { border: none; background: none; font-family: inherit; font-size: 14px; font-weight: 600; color: var(--mlp-ink-2); padding: 9px 20px; border-radius: var(--mlp-radius-full); transition: .2s; cursor: pointer; }
.mlp-toggle button.active { background: var(--mlp-primary-700); color: #fff; }
.mlp-toggle .save { font-size: 11px; font-weight: 700; color: var(--mlp-success); background: var(--mlp-success-bg); padding: 2px 8px; border-radius: var(--mlp-radius-full); margin-left: 2px; }

/* ════════════════════════════════════════
   VERGLEICHSTABELLE
═══════════════════════════════════════════ */
.mlp-compare-wrap { overflow-x: auto; border: 1px solid var(--mlp-line); border-radius: var(--mlp-radius); background: var(--mlp-white); box-shadow: var(--mlp-shadow-sm); }
.mlp-compare { width: 100%; border-collapse: collapse; min-width: 680px; }
.mlp-compare thead th { position: sticky; top: 70px; background: var(--mlp-white); z-index: 2; }
.mlp-compare th, .mlp-compare td { padding: 16px 20px; text-align: center; border-bottom: 1px solid var(--mlp-line-2); }
.mlp-compare th:first-child, .mlp-compare td:first-child { text-align: left; }
.mlp-compare thead th { padding-top: 24px; padding-bottom: 24px; }
.mlp-compare .plan-name { font-family: var(--mlp-font-display); font-size: 21px; font-weight: 600; color: var(--mlp-ink); }
.mlp-compare .plan-name.featured { color: var(--mlp-primary-700); }
.mlp-compare .plan-price { font-size: 13px; color: var(--mlp-ink-3); font-weight: 400; margin-top: 2px; }
.mlp-compare .col-featured { background: var(--mlp-primary-50); }
.mlp-compare tbody th { font-weight: 500; font-size: 14.5px; color: var(--mlp-ink); }
.mlp-compare .grp td, .mlp-compare .grp th { background: var(--mlp-cream); font-family: var(--mlp-font-display); font-size: 13px; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; color: var(--mlp-primary-700); padding-top: 14px; padding-bottom: 14px; }
.mlp-compare .yes { color: var(--mlp-success); font-weight: 700; font-size: 17px; }
.mlp-compare .no { color: var(--mlp-line); font-size: 17px; }
.mlp-compare .val { font-size: 14px; font-weight: 600; color: var(--mlp-ink); }
.mlp-compare tbody tr:hover td, .mlp-compare tbody tr:hover th { background: var(--mlp-primary-50); }
.mlp-compare tbody tr:hover td.col-featured { background: var(--mlp-primary-100); }

/* ════════════════════════════════════════
   FAQ-ACCORDION
═══════════════════════════════════════════ */
.mlp-faq { max-width: 760px; margin: 0 auto; }
.mlp-faq-item { border: 1px solid var(--mlp-line); border-radius: var(--mlp-radius-sm); margin-bottom: 12px; background: var(--mlp-white); overflow: hidden; transition: border-color .2s, box-shadow .2s; }
.mlp-faq-item[open] { border-color: var(--mlp-primary-200); box-shadow: var(--mlp-shadow-sm); }
.mlp-faq-item summary { list-style: none; cursor: pointer; padding: 20px 24px; font-weight: 600; font-size: 16px; color: var(--mlp-ink); display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.mlp-faq-item summary::-webkit-details-marker { display: none; }
.mlp-faq-item summary::after { content: '+'; font-size: 24px; font-weight: 400; color: var(--mlp-primary-600); transition: transform .25s; flex-shrink: 0; line-height: 1; }
.mlp-faq-item[open] summary::after { transform: rotate(45deg); }
.mlp-faq-item .mlp-faq-body { padding: 0 24px 22px; font-size: 15px; color: var(--mlp-ink-2); line-height: 1.65; }
