/* =====================================================================
   mnjam.mnjam — Design System v2  "Frisch & Pop"
   Hell, modern, farbig. Grotesk statt Serife. Runde Formen, klare Pop-Akzente.
   ===================================================================== */

:root{
  /* ---- Farbe: heller, frischer Pop ---- */
  --bg:        #FFFDF7;   /* warmes, helles Off-White (Hauptfläche) */
  --bg-tint:   #FFF0E9;   /* zarter Pfirsich-Ton für Wechselsektionen */
  --bg-mint:   #E9F8F0;   /* zartes Mint für Akzentsektionen */
  --card:      #FFFFFF;   /* Karten rein weiß */

  --ink:       #1B1A16;   /* Text, warmes Beinahe-Schwarz */
  --ink-2:     #57544B;   /* gedämpfter Text */
  --ink-3:     #918C7E;   /* sehr gedämpft / Fineprint */

  --coral:     #FF5A36;   /* Primär-Pop */
  --coral-deep:#E8431F;
  --coral-soft:#FFE3DB;

  --green:     #10B981;   /* Frisch / Wachstum */
  --green-deep:#0B9468;
  --green-soft:#D4F4E7;

  --yellow:    #FFC93C;   /* sonniger Akzent */
  --yellow-soft:#FFF1C9;

  --grape:     #6C4CF1;   /* gelegentlicher dritter Akzent */

  /* ---- Aliase für ältere Inline-Styles (Mapping auf neue Palette) ---- */
  --bone: var(--ink);
  --bone-dim: var(--ink-2);
  --bone-dimmer: var(--ink-3);
  --ink-soft: var(--bg-tint);
  --ink-raised: var(--card);
  --line-strong: var(--line-ink);
  --ember: var(--coral);
  --ember-text: var(--coral-deep);
  --ember-soft: var(--coral-deep);
  --ember-dim: var(--coral-soft);
  --sage: var(--green);
  --sage-text: var(--green-deep);
  --paper: var(--card);
  --paper-ink: var(--ink);
  --danger: var(--coral-deep);
  --ok: var(--green);

  --line:      #ECE6D8;   /* helle Trennlinien */
  --line-ink:  rgba(27,26,22,0.12);

  /* ---- Typografie: nur Grotesk/Sans ---- */
  --font-display: 'Bricolage Grotesque', 'Inter', system-ui, sans-serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono: var(--font-body);

  /* ---- Layout ---- */
  --container: 1180px;
  --container-narrow: 760px;
  --radius: 16px;
  --radius-lg: 26px;
  --radius-sm: 12px;
  --radius-pill: 999px;
  --gutter: clamp(20px, 5vw, 64px);

  --shadow-sm: 0 4px 14px rgba(27,26,22,0.06);
  --shadow:    0 14px 34px rgba(27,26,22,0.09);
  --shadow-lg: 0 26px 60px rgba(27,26,22,0.12);
  --shadow-coral: 0 14px 30px rgba(255,90,54,0.28);

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-pop: cubic-bezier(.34,1.56,.64,1);
}

/* ---------------------------------------------------------------------
   Reset
   --------------------------------------------------------------------- */
*,*::before,*::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
}
body{
  margin:0; background: var(--bg); color: var(--ink);
  font-family: var(--font-body); font-size: 16px; line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img{ max-width:100%; display:block; }
a{ color: inherit; text-decoration:none; }
ul{ margin:0; padding:0; }
button{ font-family: inherit; cursor:pointer; }
h1,h2,h3,h4,h5{ margin:0; font-family: var(--font-display); font-weight:700; letter-spacing:-0.02em; line-height:1.05; }
p{ margin:0; }
:focus-visible{ outline: 3px solid var(--coral); outline-offset: 3px; border-radius: 4px; }

/* ---------------------------------------------------------------------
   Layout helpers
   --------------------------------------------------------------------- */
.container{ max-width: var(--container); margin:0 auto; padding:0 var(--gutter); }
.container-narrow{ max-width: var(--container-narrow); margin:0 auto; padding:0 var(--gutter); }
.section{ padding: clamp(52px,6.5vw,88px) 0; position:relative; }
.section--tight{ padding: clamp(34px,5vw,60px) 0; }
.section--soft{ background: var(--bg-tint); padding: clamp(52px,6.5vw,88px) 0; }
.section--mint{ background: var(--bg-mint); padding: clamp(52px,6.5vw,88px) 0; }
.grid{ display:grid; gap: 26px; }
.grid-2{ grid-template-columns: repeat(2,1fr); }
.grid-3{ grid-template-columns: repeat(3,1fr); }
.grid-4{ grid-template-columns: repeat(4,1fr); }
@media (max-width: 980px){ .grid-3,.grid-4{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 640px){ .grid-2,.grid-3,.grid-4{ grid-template-columns: 1fr; } }

.stack{ display:flex; flex-direction:column; }
.row{ display:flex; align-items:center; }
.center{ text-align:center; }

/* ---------------------------------------------------------------------
   Eyebrow / Dividers
   --------------------------------------------------------------------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-family: var(--font-body); font-size:0.8rem; font-weight:700;
  letter-spacing:0.08em; text-transform:uppercase; color: var(--coral);
}
.eyebrow::before{ content:""; width:9px; height:9px; border-radius:50%; background: var(--coral); }
.eyebrow--muted{ color: var(--ink-2); }
.eyebrow--muted::before{ background: var(--ink-3); }
.eyebrow--green{ color: var(--green-deep); } .eyebrow--green::before{ background: var(--green); }

.h-rule{ height:2px; background: var(--line); border:0; margin:0; border-radius:2px; }
.h-rule--strong{ background: var(--line-ink); }

.lede{ color: var(--ink-2); font-size: 1.1rem; max-width: 640px; }
.lede--center{ margin-inline:auto; text-align:center; }

.divider-tag{ display:flex; align-items:center; gap:18px; margin-bottom:20px; }
.divider-tag .h-rule{ flex:1; }

.fineprint{ font-size:0.82rem; color: var(--ink-3); }

/* ---------------------------------------------------------------------
   Buttons — chunky, rund, pop
   --------------------------------------------------------------------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family: var(--font-body); font-weight:700; font-size:0.98rem;
  padding: 15px 28px; border-radius: var(--radius-pill);
  border:2px solid transparent; transition: transform .22s var(--ease-pop), background .2s var(--ease), border-color .2s var(--ease), color .2s var(--ease), box-shadow .2s var(--ease);
  white-space:nowrap;
}
.btn-primary{ background: var(--coral); color:#fff; box-shadow: var(--shadow-coral); }
.btn-primary:hover{ background: var(--coral-deep); transform: translateY(-2px) scale(1.02); }
.btn-ghost{ background: transparent; border-color: var(--ink); color: var(--ink); }
.btn-ghost:hover{ background: var(--ink); color:#fff; transform: translateY(-2px); }
.btn-green{ background: var(--green); color:#fff; box-shadow: 0 14px 30px rgba(16,185,129,0.28); }
.btn-green:hover{ background: var(--green-deep); transform: translateY(-2px) scale(1.02); }
.btn-link{ color: var(--coral); font-weight:700; border-bottom:2px solid transparent; padding:0; border-radius:0; }
.btn-link:hover{ border-color: var(--coral); }
.btn-arrow::after{ content:"→"; transition: transform .22s var(--ease); }
.btn-arrow:hover::after{ transform: translateX(4px); }
.btn-block{ width:100%; justify-content:center; }
.btn-sm{ padding:11px 20px; font-size:0.88rem; }

/* ---------------------------------------------------------------------
   Header / Navigation
   --------------------------------------------------------------------- */
.site-header{
  position: sticky; top:0; z-index:50;
  background: rgba(255,253,247,0.85); backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
}
.site-header__inner{ display:flex; align-items:center; justify-content:space-between; gap: clamp(24px, 3vw, 52px); height: 76px; }
.logo{ font-family: var(--font-display); font-size: 1.4rem; font-weight:800; letter-spacing:-0.03em; color: var(--ink); }
.logo em{ font-style:normal; color: var(--coral); }
.nav{ display:flex; align-items:center; gap: 26px; }
.nav__links{ display:flex; align-items:center; gap: 22px; list-style:none; }
.nav__links a{ display:inline-flex; align-items:center; font-size:0.94rem; font-weight:500; color: var(--ink-2); position:relative; padding:6px 2px; white-space:nowrap; transition: color .2s var(--ease); }
.nav__links a:hover, .nav__links a[aria-current="page"]{ color: var(--ink); }
.nav__links a::after{ content:""; position:absolute; left:2px; right:100%; bottom:0; height:2px; background: var(--coral); border-radius:2px; transition: right .25s var(--ease); }
.nav__links a:hover::after, .nav__links a[aria-current="page"]::after{ right:2px; }
.nav__cta{ display:flex; align-items:center; gap:14px; }
.nav__toggle{ display:none; background:#fff; border:2px solid var(--ink); border-radius:var(--radius-pill); color:var(--ink); padding:8px 16px; font-weight:700; font-size:0.82rem; }

@media (max-width: 1040px){
  .nav__links{ display:none; }
  .nav__toggle{ display:inline-flex; }
  .nav.is-open .nav__links{
    display:flex; flex-direction:column; gap:0;
    position:absolute; top:76px; left:0; right:0; background: var(--card);
    border-bottom:1px solid var(--line); padding: 8px var(--gutter) 18px; box-shadow: var(--shadow);
  }
  .nav.is-open .nav__links a{ padding: 13px 0; border-bottom:1px solid var(--line); white-space:normal; }
  .nav__cta .btn-ghost{ display:none; }
}

/* ---------------------------------------------------------------------
   Hero (Basis — Animationen in home.css)
   --------------------------------------------------------------------- */
.hero{ padding: clamp(52px,8vw,96px) 0 clamp(36px,6vw,64px); position:relative; overflow:hidden; }
.hero__grid{ display:grid; grid-template-columns: 1.2fr 0.9fr; gap: 54px; align-items:center; }
@media (max-width: 980px){ .hero__grid{ grid-template-columns:1fr; } }
.hero h1{
  font-size: clamp(2.6rem, 5.4vw, 4.6rem); font-weight:800; line-height:1.0; letter-spacing:-0.035em;
  margin: 20px 0 24px; max-width: 16ch;
}
.hero h1 em{ font-style:normal; color: var(--coral); }
.hero__actions{ display:flex; gap:14px; margin-top: 30px; flex-wrap:wrap; }
.hero__note{ margin-top:20px; font-size:0.9rem; color: var(--ink-3); font-weight:500; }

/* Highlight-Marker hinter einem Wort */
.hl{ position:relative; white-space:nowrap; z-index:0; }
.hl::before{
  content:""; position:absolute; left:-.1em; right:-.1em; bottom:.06em; top:.42em; z-index:-1;
  background: var(--yellow); border-radius: 6px; transform: rotate(-1.4deg);
}
.hl--green::before{ background: var(--green-soft); }
.hl--coral::before{ background: var(--coral-soft); }

/* Formel-Karte */
.formula{
  display:flex; align-items:center; flex-wrap:wrap; gap: 12px;
  font-family: var(--font-display); font-weight:600; font-size: clamp(0.95rem, 1.6vw, 1.15rem);
  border:2px solid var(--ink); border-radius: var(--radius);
  padding: 22px 24px; background: var(--card); box-shadow: var(--shadow-sm);
}
.formula__term{ color: var(--ink); white-space:nowrap; }
.formula__op{ color: var(--coral); }
.formula__result{ color: var(--green-deep); white-space:nowrap; }

/* ---------------------------------------------------------------------
   KPI strip
   --------------------------------------------------------------------- */
.kpi-strip{ display:grid; grid-template-columns: repeat(4,1fr); background: var(--card); border:2px solid var(--ink); border-radius: var(--radius-lg); overflow:hidden; box-shadow: var(--shadow); }
.kpi{ padding: 28px 24px; border-right:2px solid var(--line); }
.kpi:last-child{ border-right:0; }
.kpi__value{ font-family: var(--font-display); font-weight:800; font-size: 2.4rem; color: var(--ink); letter-spacing:-0.03em; }
.kpi__value .unit{ color: var(--coral); }
.kpi__label{ margin-top:8px; font-size:0.84rem; color: var(--ink-2); }
@media (max-width: 760px){ .kpi-strip{ grid-template-columns: repeat(2,1fr); } .kpi{ border-bottom:2px solid var(--line);} .kpi:nth-child(2){ border-right:0; } .kpi:nth-child(3),.kpi:nth-child(4){ border-bottom:0; } }

/* ---------------------------------------------------------------------
   Cards
   --------------------------------------------------------------------- */
.card{
  background: var(--card); border:1px solid var(--line); border-radius: var(--radius-lg);
  padding: 30px 28px; transition: transform .25s var(--ease-pop), box-shadow .25s var(--ease), border-color .25s var(--ease);
  box-shadow: var(--shadow-sm);
}
.card:hover{ transform: translateY(-4px); box-shadow: var(--shadow); border-color: var(--coral); }
.card h3{ font-size:1.25rem; margin-bottom:10px; }
.card p{ color: var(--ink-2); font-size:0.96rem; }
.card__num{ display:inline-block; font-family: var(--font-body); font-size:0.74rem; font-weight:800; letter-spacing:0.06em; text-transform:uppercase; color: var(--coral-deep); background: var(--coral-soft); padding:5px 11px; border-radius: var(--radius-pill); margin-bottom:14px; }

.card--service{ display:flex; flex-direction:column; gap:12px; }
.card--service ul{ margin-top:auto; padding-top:8px; list-style:none; display:flex; flex-direction:column; gap:6px; }
.card--service li{ font-size:0.88rem; color: var(--ink-2); padding-left:18px; position:relative; }
.card--service li::before{ content:""; position:absolute; left:0; top:.55em; width:7px; height:7px; border-radius:50%; background: var(--green); }

/* Audience / problem cards */
.problem-card{ background: var(--card); border:1px solid var(--line); border-left:6px solid var(--coral); border-radius: var(--radius); padding: 24px 24px 24px 22px; box-shadow: var(--shadow-sm); transition: transform .22s var(--ease-pop), box-shadow .22s var(--ease); }
.problem-card:nth-child(2n){ border-left-color: var(--green); }
.problem-card:nth-child(3n){ border-left-color: var(--yellow); }
.problem-card:hover{ transform: translateY(-3px); box-shadow: var(--shadow); }
.problem-card h4{ font-size:1.1rem; color: var(--ink); margin-bottom:7px; }
.problem-card p{ color: var(--ink-2); font-size:0.93rem; }

/* Industry chips — bunte Pills */
.chip-grid{ display:flex; flex-wrap:wrap; gap:11px; }
.chip{
  border:2px solid var(--ink); border-radius: var(--radius-pill); padding:10px 20px;
  font-size:0.9rem; font-weight:600; color: var(--ink); background:var(--card); transition: all .2s var(--ease-pop);
}
.chip:hover{ background: var(--coral); border-color: var(--coral); color:#fff; transform: translateY(-2px); }
.chip:nth-child(3n):hover{ background: var(--green); border-color: var(--green); }
.chip:nth-child(3n+1):hover{ background: var(--yellow); border-color: var(--yellow); color: var(--ink); }

/* ---------------------------------------------------------------------
   Step cards (Arbeitsweise) — ersetzt das alte Ticket-Konzept
   --------------------------------------------------------------------- */
.pass-rail{ position:relative; }
.pass-rail__bar{ display:none; }
.pass-rail__items{ display:grid; grid-template-columns: repeat(4,1fr); gap:20px; }
@media (max-width: 900px){ .pass-rail__items{ grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px){ .pass-rail__items{ grid-template-columns: 1fr; } }
.ticket{
  background: var(--card); border:1px solid var(--line); border-radius: var(--radius-lg);
  padding: 26px 22px; position:relative; box-shadow: var(--shadow-sm);
  transition: transform .25s var(--ease-pop), box-shadow .25s var(--ease);
}
.ticket:hover{ transform: translateY(-4px); box-shadow: var(--shadow); }
.ticket::before{
  content:""; position:absolute; top:0; left:26px; right:26px; height:5px; border-radius:0 0 5px 5px; background: var(--coral);
}
.ticket:nth-child(2)::before{ background: var(--green); }
.ticket:nth-child(3)::before{ background: var(--yellow); }
.ticket:nth-child(4)::before{ background: var(--grape); }
.ticket__no{ font-family: var(--font-display); font-weight:800; font-size:2.2rem; color: var(--coral); letter-spacing:-0.04em; line-height:1; }
.ticket:nth-child(2) .ticket__no{ color: var(--green); }
.ticket:nth-child(3) .ticket__no{ color: #E0A91F; }
.ticket:nth-child(4) .ticket__no{ color: var(--grape); }
.ticket__title{ font-family: var(--font-display); font-weight:700; font-size:1.15rem; margin:12px 0 7px; color: var(--ink); }
.ticket__text{ font-size:0.9rem; color: var(--ink-2); }

/* ---------------------------------------------------------------------
   Packages
   --------------------------------------------------------------------- */
.package{
  border:1px solid var(--line); border-radius: var(--radius-lg); padding:34px 30px;
  display:flex; flex-direction:column; background: var(--card); position:relative; box-shadow: var(--shadow-sm);
  transition: transform .25s var(--ease-pop), box-shadow .25s var(--ease);
}
.package:hover{ transform: translateY(-4px); box-shadow: var(--shadow); }
.package--featured{ border:2px solid var(--coral); background: linear-gradient(180deg, var(--coral-soft), var(--card) 38%); box-shadow: var(--shadow); }
.package__tag{ position:absolute; top:-14px; left:30px; background: var(--coral); color:#fff; font-weight:800; font-size:0.74rem; letter-spacing:0.04em; padding:6px 14px; border-radius: var(--radius-pill); text-transform:uppercase; box-shadow: var(--shadow-coral); }
.package__title{ font-size:1.7rem; font-weight:800; margin-top:8px; }
.package__sub{ color: var(--ink-2); font-size:0.94rem; margin-top:8px; }
.package ul{ list-style:none; margin: 22px 0; display:flex; flex-direction:column; gap:11px; }
.package li{ font-size:0.92rem; color: var(--ink-2); padding-left:26px; position:relative; }
.package li::before{ content:"✓"; position:absolute; left:0; top:-1px; color:#fff; background: var(--green); width:18px; height:18px; border-radius:50%; font-size:0.7rem; display:flex; align-items:center; justify-content:center; font-weight:800; }
.package__result{ font-size:0.92rem; color: var(--ink); border-top:1px solid var(--line); padding-top:18px; margin-bottom:22px; }
.package__result strong{ color: var(--coral-deep); display:block; font-weight:800; font-size:0.72rem; letter-spacing:0.06em; text-transform:uppercase; margin-bottom:7px; }

/* ---------------------------------------------------------------------
   FAQ accordion
   --------------------------------------------------------------------- */
.faq-item{ border-bottom:2px solid var(--line); }
.faq-q{
  width:100%; background:none; border:0; color: var(--ink); text-align:left;
  display:flex; justify-content:space-between; align-items:center; gap:16px;
  padding: 24px 0; font-size:1.1rem; font-family: var(--font-display); font-weight:700;
}
.faq-q::after{ content:"+"; flex:none; width:30px; height:30px; border-radius:50%; background: var(--coral-soft); color: var(--coral-deep); font-size:1.2rem; display:flex; align-items:center; justify-content:center; transition: transform .25s var(--ease-pop), background .2s; }
.faq-item.is-open .faq-q::after{ transform: rotate(135deg); background: var(--coral); color:#fff; }
.faq-a{ max-height:0; overflow:hidden; transition: max-height .3s var(--ease); }
.faq-a__inner{ padding: 0 0 24px; color: var(--ink-2); font-size:0.98rem; max-width:70ch; }

/* ---------------------------------------------------------------------
   Lead wizard
   --------------------------------------------------------------------- */
.wizard{ background: var(--card); border:2px solid var(--ink); border-radius: var(--radius-lg); padding: clamp(26px,4vw,44px); box-shadow: var(--shadow); }
.wizard__progress{ display:flex; gap:6px; margin-bottom: 28px; }
.wizard__progress span{ flex:1; height:5px; background: var(--line); border-radius:5px; transition: background .3s var(--ease); }
.wizard__progress span.is-done{ background: var(--coral); }
.wizard__step{ display:none; }
.wizard__step.is-active{ display:block; animation: fadeUp .35s var(--ease); }
@keyframes fadeUp{ from{ opacity:0; transform: translateY(10px); } to{ opacity:1; transform:none; } }
.wizard__label{ font-weight:800; font-size:0.74rem; letter-spacing:0.06em; text-transform:uppercase; color: var(--coral); }
.wizard__question{ font-family: var(--font-display); font-weight:700; font-size:1.5rem; margin: 10px 0 22px; }
.option-grid{ display:grid; grid-template-columns: repeat(2,1fr); gap:10px; }
@media (max-width:560px){ .option-grid{ grid-template-columns:1fr; } }
.option{
  border:2px solid var(--line); border-radius: var(--radius-sm); padding:14px 16px;
  font-size:0.94rem; font-weight:500; cursor:pointer; transition: all .18s var(--ease-pop); background:#fff;
}
.option:hover{ border-color: var(--coral); transform: translateY(-1px); }
.option.is-selected{ border-color: var(--coral); background: var(--coral-soft); font-weight:700; }
.wizard__nav{ display:flex; justify-content:space-between; margin-top: 28px; }
.field{ margin-bottom:16px; }
.field label{ display:block; font-size:0.84rem; font-weight:600; margin-bottom:7px; color: var(--ink); }
.field input, .field textarea, .field select{
  width:100%; border:2px solid var(--line); border-radius: var(--radius-sm);
  padding:13px 15px; font-family: var(--font-body); font-size:0.96rem; background:#fff; color: var(--ink);
  transition: border-color .18s var(--ease);
}
.field input:focus, .field textarea:focus{ border-color: var(--coral); outline:none; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width:560px){ .field-row{ grid-template-columns:1fr; } }
.consent{ display:flex; gap:10px; align-items:flex-start; font-size:0.84rem; color: var(--ink-2); }
.consent input{ margin-top:3px; width:18px; height:18px; accent-color: var(--coral); }
.wizard__success{ text-align:center; padding: 30px 0; }

/* ---------------------------------------------------------------------
   Footer
   --------------------------------------------------------------------- */
.site-footer{ border-top:1px solid var(--line); padding: 64px 0 32px; background: var(--bg-tint); }
.footer__grid{ display:grid; grid-template-columns: 1.3fr 1fr 1fr 1fr; gap: 40px; }
@media (max-width: 760px){ .footer__grid{ grid-template-columns: 1fr 1fr; } }
.footer__col h5{ font-weight:800; font-size:0.78rem; letter-spacing:0.06em; text-transform:uppercase; color: var(--ink-3); margin-bottom:16px; }
.footer__col ul{ list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer__col a{ color: var(--ink-2); font-size:0.93rem; font-weight:500; }
.footer__col a:hover{ color: var(--coral); }
.footer__brand p{ color: var(--ink-2); font-size:0.93rem; max-width:32ch; margin-top:14px; }
.footer__bottom{ margin-top: 48px; padding-top: 24px; border-top:1px solid var(--line); display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px; }
.footer__bottom p{ color: var(--ink-3); font-size:0.82rem; max-width:62ch; }
.footer__legal-links{ display:flex; gap:18px; list-style:none; }
.footer__legal-links a{ font-size:0.82rem; color: var(--ink-3); }
.footer__legal-links a:hover{ color: var(--coral); }

/* ---------------------------------------------------------------------
   Breadcrumb / page header (subpages)
   --------------------------------------------------------------------- */
.page-head{ padding: 52px 0 8px; }
.breadcrumb{ font-size:0.84rem; font-weight:500; color: var(--ink-3); margin-bottom:18px; }
.breadcrumb a{ color: var(--ink-2); }
.breadcrumb a:hover{ color: var(--coral); }
.page-head h1{ font-size: clamp(2.1rem,4.4vw,3.2rem); font-weight:800; max-width:24ch; letter-spacing:-0.03em; }

/* ---------------------------------------------------------------------
   Notebox (rechtliche Hinweise) — frisch, freundlich
   --------------------------------------------------------------------- */
.notebox{
  border:1px solid var(--green-soft); border-left:6px solid var(--green);
  background: var(--green-soft); border-radius: var(--radius);
  padding: 20px 24px; font-size:0.9rem; color: var(--ink-2);
}
.notebox strong{ color: var(--ink); }

/* Help center article list */
.article-row{ display:flex; justify-content:space-between; align-items:center; padding: 22px 24px; gap:20px; background:var(--card); border:1px solid var(--line); border-radius: var(--radius); margin-bottom:12px; transition: transform .2s var(--ease-pop), box-shadow .2s var(--ease), border-color .2s; box-shadow: var(--shadow-sm); }
.article-row:hover{ transform: translateX(6px); border-color: var(--coral); box-shadow: var(--shadow); }
.article-row__title{ font-size:1.08rem; font-weight:600; color: var(--ink); }
.article-row__cat{ font-weight:700; font-size:0.74rem; color: var(--coral-deep); background: var(--coral-soft); padding:5px 12px; border-radius: var(--radius-pill); white-space:nowrap; text-transform:uppercase; letter-spacing:0.04em; }

/* Reveal-on-scroll */
.reveal{ opacity:0; transform: translateY(20px); transition: opacity .6s var(--ease), transform .6s var(--ease-pop); }
.reveal.is-visible{ opacity:1; transform:none; }
.reveal[data-delay="1"]{ transition-delay:.08s; }
.reveal[data-delay="2"]{ transition-delay:.16s; }
.reveal[data-delay="3"]{ transition-delay:.24s; }
.reveal[data-delay="4"]{ transition-delay:.32s; }
.reveal[data-delay="5"]{ transition-delay:.40s; }

/* ---------------------------------------------------------------------
   CTA band — heller, runder Block mit Pop
   --------------------------------------------------------------------- */
.cta-band{
  border-radius: var(--radius-lg);
  background: var(--ink); color: #fff;
  padding: clamp(34px,5vw,56px); display:flex; align-items:center; justify-content:space-between; gap:32px; flex-wrap:wrap;
  box-shadow: var(--shadow);
}
.cta-band .eyebrow{ color: var(--yellow); } .cta-band .eyebrow::before{ background: var(--yellow); }
.cta-band h3{ font-size:1.8rem; font-weight:800; max-width:26ch; color:#fff; letter-spacing:-0.02em; }
.cta-band .lede{ color: rgba(255,255,255,0.78); }
.cta-band--green{ background: var(--green); }
.cta-band--green .eyebrow{ color:#fff; } .cta-band--green .eyebrow::before{ background:#fff; }
.cta-band--coral{ background: var(--coral); }
.cta-band--coral .eyebrow{ color:#fff; } .cta-band--coral .eyebrow::before{ background:#fff; }
/* primary button on dark bands becomes white */
.cta-band .btn-primary{ background:#fff; color: var(--ink); box-shadow: 0 10px 24px rgba(0,0,0,0.18); }
.cta-band .btn-primary:hover{ background: var(--yellow); color: var(--ink); }
.cta-band .btn-ghost{ border-color:#fff; color:#fff; }
.cta-band .btn-ghost:hover{ background:#fff; color: var(--ink); }

/* ---------------------------------------------------------------------
   Über uns — Gründer-Portrait
   --------------------------------------------------------------------- */
.bio__photo img{ width:100%; height:auto; border-radius:var(--radius-lg); box-shadow:var(--shadow); display:block; }
.bio__caption{ margin-top:14px; display:inline-flex; align-items:center; gap:9px; font-size:0.92rem; font-weight:600; color:var(--ink-2); }
.bio__caption::before{ content:""; width:9px; height:9px; border-radius:50%; background:var(--coral); flex:none; }
@media (max-width:640px){ .bio__photo{ max-width:440px; margin:0 auto; } }

.footer__contact{ margin-top:14px; font-weight:500; }

/* ---------------------------------------------------------------------
   Referenzen — durchlaufende Logo-Leiste (Marquee)
   --------------------------------------------------------------------- */
.logos{ margin-top: clamp(44px,6vw,68px); }
.logos__label{ text-align:center; font-size:0.8rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-3); margin-bottom:30px; padding:0 var(--gutter); }
.marquee{ overflow:hidden; position:relative;
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent);
  mask-image:linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent); }
.marquee__track{ display:flex; align-items:center; gap:60px; width:max-content; animation: marquee 48s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee__track img{ height:30px; width:auto; flex:none; opacity:0.48; transition:opacity .25s var(--ease); }
.marquee__track img:hover{ opacity:0.9; }
@keyframes marquee{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media (max-width:640px){ .marquee__track{ gap:42px; } .marquee__track img{ height:26px; } }
@media (prefers-reduced-motion: reduce){
  .marquee{ mask-image:none; -webkit-mask-image:none; overflow-x:auto; }
  .marquee__track{ animation:none; }
}


/* mnjam.mnjam social links */
.social-linkset {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}

.social-linkset--hero {
  margin-top: 18px;
  margin-bottom: 16px;
}

.social-linkset--contact {
  margin-top: 18px;
}

.social-linkset__label {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(27, 26, 22, 0.58);
}

.social-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  min-height: 42px;
  padding: 0 15px;
  border: 1px solid rgba(27, 26, 22, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: var(--ink, #1b1a16);
  font-size: 0.88rem;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  box-shadow: 0 12px 34px rgba(27, 26, 22, 0.08);
  backdrop-filter: blur(14px);
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.social-chip:hover {
  transform: translateY(-2px);
  border-color: rgba(27, 26, 22, 0.28);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 18px 44px rgba(27, 26, 22, 0.12);
}

.social-chip svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  flex: 0 0 auto;
}

.social-chip--instagram {
  color: #ff4f35;
}

.social-chip--facebook {
  color: #1877f2;
}

.social-chip--instagram span,
.social-chip--facebook span {
  color: var(--ink, #1b1a16);
}

.social-card {
  position: relative;
  overflow: hidden;
}

.social-card::after {
  content: "";
  position: absolute;
  width: 180px;
  height: 180px;
  right: -70px;
  top: -70px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255, 79, 53, 0.16), rgba(193, 245, 224, 0.05) 62%, transparent 72%);
  pointer-events: none;
}

@media (max-width: 640px) {
  .social-linkset--hero {
    margin-top: 16px;
  }

  .social-linkset__label {
    width: 100%;
    min-height: auto;
  }

  .social-chip {
    min-height: 44px;
  }
}


/* Hero social finishing */
.social-linkset--hero-viz {
  justify-content: flex-end;
  margin-top: 18px;
  margin-bottom: 0;
  max-width: 520px;
  margin-left: auto;
  padding-right: 4px;
}

.social-linkset--hero-viz .social-chip {
  min-height: 40px;
  padding: 0 14px;
  background: rgba(255, 255, 255, 0.78);
  border-color: rgba(27, 26, 22, 0.13);
}

@media (max-width: 900px) {
  .social-linkset--hero-viz {
    justify-content: flex-start;
    margin-left: 0;
    max-width: none;
    padding-right: 0;
  }
}


/* Branchen Referenzen Proof Section */
.reference-proof {
  max-width: 760px;
}

.reference-proof__lead {
  margin: 0 0 18px;
  font-size: clamp(1.03rem, 1.35vw, 1.18rem);
  line-height: 1.55;
  color: rgba(27, 26, 22, 0.82);
}

.reference-proof__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}

.reference-proof__item {
  position: relative;
  overflow: hidden;
  padding: 18px 18px 17px;
  border: 1px solid rgba(27, 26, 22, 0.10);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.54);
  box-shadow: 0 16px 40px rgba(27, 26, 22, 0.055);
}

.reference-proof__item::after {
  content: "";
  position: absolute;
  width: 110px;
  height: 110px;
  right: -58px;
  top: -58px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255, 79, 53, 0.16), rgba(193, 245, 224, 0.04) 64%, transparent 72%);
  pointer-events: none;
}

.reference-proof__item span {
  display: inline-flex;
  margin-bottom: 10px;
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #ff4f35;
}

.reference-proof__item h3 {
  margin: 0 0 8px;
  font-size: 1.02rem;
  line-height: 1.18;
  color: var(--ink, #1b1a16);
}

.reference-proof__item p {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.45;
  color: rgba(27, 26, 22, 0.72);
}

.reference-proof__closing {
  margin: 18px 0 0;
  padding: 15px 17px;
  border-left: 4px solid #ff4f35;
  border-radius: 16px;
  background: rgba(255, 79, 53, 0.065);
  font-size: 1rem;
  font-weight: 750;
  line-height: 1.5;
  color: rgba(27, 26, 22, 0.86);
}

@media (max-width: 760px) {
  .reference-proof__grid {
    grid-template-columns: 1fr;
  }
}
