/* ===================================================================
   BOOM COMMERCE — Website Styles (v2)
   Premium / dunkel / editorial. Mobile-first.
   =================================================================== */

:root {
  --bg:        #0a0c11;
  --bg-2:      #0f1218;
  --surface:   #14181f;
  --surface-2: #1a1f29;
  --line:      rgba(255,255,255,.08);
  --line-2:    rgba(255,255,255,.14);
  --text:      #f4f6fa;
  --muted:     #98a2b3;
  --muted-2:   #6b7484;
  --accent:    #ff7a18;
  --accent-2:  #ff9244;
  --accent-deep:#e85f00;
  --green:     #36d399;
  --radius:    16px;
  --radius-lg: 24px;
  --maxw:      1140px;
  --shadow:    0 18px 50px -20px rgba(0,0,0,.7);
  --shadow-accent: 0 10px 30px -8px rgba(255,122,24,.45);
  --font-head: "Sora", system-ui, sans-serif;
  --font-body: "Inter", system-ui, -apple-system, sans-serif;
}

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

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 22px; }

section { padding: 72px 0; position: relative; }
@media (min-width: 800px){ section { padding: 110px 0; } }

/* ---------- Typography ---------- */
h1, h2, h3, h4 { font-family: var(--font-head); font-weight: 700; line-height: 1.08; letter-spacing: -.02em; margin: 0 0 .5em; }
h1 { font-size: clamp(2.1rem, 7vw, 4.4rem); }
h2 { font-size: clamp(1.7rem, 4.6vw, 3rem); }
h3 { font-size: clamp(1.15rem, 2.4vw, 1.5rem); }
p  { margin: 0 0 1em; color: var(--muted); }
.lead { font-size: clamp(1.05rem, 2.3vw, 1.3rem); color: #c7cdd9; }

.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-head); font-size: .8rem; font-weight: 600;
  letter-spacing: .14em; text-transform: uppercase; color: var(--accent-2);
  margin-bottom: 18px;
}
/* dashes removed per feedback — eyebrow is clean uppercase text */

.section-head { max-width: 720px; margin: 0 auto 54px; text-align: center; }
.section-head.left { margin-left: 0; text-align: left; }

.accent { color: var(--accent-2); }
.grad { background: linear-gradient(96deg,#ffffff 0%,#fff0e0 32%,#ffb877 62%,var(--accent-2) 88%,var(--accent) 100%); -webkit-background-clip:text; background-clip:text; color: transparent; -webkit-text-fill-color:transparent; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content:center; gap: 10px;
  font-family: var(--font-head); font-weight: 600; font-size: 1rem;
  padding: 15px 28px; border-radius: 999px; border: 1px solid transparent;
  cursor: pointer; transition: transform .18s ease, box-shadow .25s ease, background .2s ease;
  white-space: nowrap;
}
.btn-primary {
  background: linear-gradient(135deg, var(--accent), var(--accent-deep));
  color: #fff; box-shadow: var(--shadow-accent);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 16px 40px -8px rgba(255,122,24,.6); }
.btn-ghost { background: rgba(255,255,255,.04); color: #f4f6fa; border-color: rgba(255,255,255,.35); }
.btn-ghost:hover { border-color: var(--accent); color: var(--accent-2); background: rgba(255,122,24,.08); }
.btn .arrow { transition: transform .2s ease; }
.btn:hover .arrow { transform: translateX(4px); }

/* ---------- Header ---------- */
.site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  transition: background .3s ease, border-color .3s ease, backdrop-filter .3s;
  border-bottom: 1px solid transparent;
}
.site-header.scrolled {
  background: rgba(10,12,17,.82); backdrop-filter: blur(14px);
  border-bottom-color: var(--line);
}
.nav { display: flex; align-items: center; justify-content: space-between; height: 70px; }
.brand { font-family: var(--font-head); font-weight: 800; font-size: 1.3rem; letter-spacing: -.02em; }
.brand b { color: var(--accent); }
.nav-links { display: none; gap: 30px; align-items: center; }
.nav-links a { color: var(--muted); font-size: .95rem; font-weight: 500; transition: color .2s; }
.nav-links a:hover { color: var(--text); }
.nav .btn { padding: 11px 22px; font-size: .92rem; }
/* Nav-CTA: klar lesbar auch ueber dem orangen Hero-Glow oben rechts */
.nav .btn-primary {
  background: linear-gradient(135deg, #ff8a2c, #d24f00);
  color: #fff; font-weight: 700;
  border: 1.5px solid rgba(255,255,255,.45);
  box-shadow: 0 6px 16px -6px rgba(0,0,0,.55);
  text-shadow: 0 1px 2px rgba(60,20,0,.35);
}
.nav .btn-primary:hover { box-shadow: 0 10px 22px -8px rgba(0,0,0,.6); border-color: rgba(255,255,255,.7); transform: translateY(-2px); }
@media (min-width: 940px){ .nav-links { display: flex; } }
.burger { display:flex; flex-direction:column; gap:5px; background:none;border:none;cursor:pointer; padding:8px; }
.burger span { width:24px;height:2px;background:var(--text);transition:.3s; }
@media (min-width: 940px){ .burger { display:none; } }

/* ---------- Hero ---------- */
.hero { padding-top: 140px; padding-bottom: 70px; overflow: hidden; }
.hero::before {
  content:""; position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(60% 50% at 75% 10%, rgba(255,122,24,.16), transparent 70%),
    radial-gradient(50% 40% at 10% 90%, rgba(255,122,24,.07), transparent 70%);
}
.hero-grid { display: grid; gap: 48px; align-items: center; }
@media (min-width: 940px){ .hero-grid { grid-template-columns: 1.05fr .95fr; gap: 60px; } }
.hero h1 { margin-bottom: 22px; }
.hero .lead { max-width: 540px; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 32px; }
.hero-trust { margin-top: 30px; font-size: .9rem; color: var(--muted-2); display:flex; align-items:center; gap:10px; }
.hero-trust b { color: var(--text); }

/* result card */
.result-card {
  background: linear-gradient(160deg, var(--surface-2), var(--surface));
  border: 1px solid var(--line); border-radius: var(--radius-lg);
  padding: 28px; box-shadow: var(--shadow);
}
.result-card .rc-head { display:flex; align-items:center; justify-content:space-between; margin-bottom: 20px; }
.result-card .rc-tag { font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted-2); }
.rc-dot { width:9px;height:9px;border-radius:50%;background:var(--green); box-shadow:0 0 0 4px rgba(54,211,153,.15); }
.rc-rows { display:grid; gap:14px; }
.rc-row { display:flex; align-items:baseline; justify-content:space-between; gap:14px; padding-bottom:14px; border-bottom:1px solid var(--line); }
.rc-row:last-child{ border-bottom:none; padding-bottom:0; }
.rc-label { color: var(--muted); font-size: .95rem; }
.rc-val { font-family: var(--font-head); font-weight: 700; font-size: 1.5rem; }
.rc-val.up { color: var(--green); }
.rc-val.down { color: var(--accent-2); }

/* ---------- Logos ---------- */
.logos { padding: 46px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.logos p { text-align:center; font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted-2); margin-bottom:24px; }
.logo-row { display:flex; flex-wrap:wrap; gap: 14px 34px; justify-content:center; align-items:center; }
.logo-row span { font-family:var(--font-head); font-weight:600; font-size:1.05rem; color:#cfd5e0; opacity:.55; transition:opacity .2s; }
.logo-row span:hover{ opacity:1; }

/* ---------- Cards / Problem ---------- */
.cards { display:grid; gap:22px; }
@media (min-width:760px){ .cards.c3 { grid-template-columns: repeat(3,1fr); } .cards.c2 { grid-template-columns: repeat(2,1fr);} }
.card {
  background: var(--surface); border:1px solid var(--line); border-radius: var(--radius);
  padding: 30px; transition: transform .2s ease, border-color .2s ease;
}
.card:hover { transform: translateY(-4px); border-color: var(--line-2); }
.card .ic { width:46px;height:46px;border-radius:12px; display:grid;place-items:center; background:rgba(255,122,24,.12); color:var(--accent-2); margin-bottom:18px; font-size:1.3rem; }
.card h3 { margin-bottom:10px; }
.card p { margin:0; font-size:.97rem; }

/* ---------- Two customers ---------- */
.two-cust { display:grid; gap:22px; }
@media (min-width:760px){ .two-cust { grid-template-columns:1fr 1fr; } }
.cust {
  border:1px solid var(--line); border-radius:var(--radius); padding:32px;
  background: linear-gradient(165deg, var(--surface-2), var(--surface));
}
.cust .num { font-family:var(--font-head); font-size:.85rem; color:var(--accent-2); letter-spacing:.1em; }
.cust h3 { margin:8px 0 12px; font-size:1.45rem; }

/* ---------- Flywheel ---------- */
.flywheel-sec { background: var(--bg-2); }
.fly-grid { display:grid; gap:44px; align-items:center; }
@media (min-width:920px){ .fly-grid { grid-template-columns: 1fr 1fr; } }
.flywheel-stage { display:flex; justify-content:center; }
.flywheel { width: 100%; max-width: 420px; aspect-ratio: 1/1; }
.fly-rotor { transform-origin: 200px 200px; animation: flyspin 36s linear infinite; }
@keyframes flyspin { to { transform: rotate(360deg); } }
.fly-node-label { transform-origin: center; animation: flycounter 36s linear infinite; }
@keyframes flycounter { to { transform: rotate(-360deg); } }
.flywheel:hover .fly-rotor,
.flywheel:hover .fly-node-label { animation-duration: 14s; }
@media (prefers-reduced-motion: reduce){
  .fly-rotor, .fly-node-label { animation: none !important; }
}
.fly-list { list-style:none; padding:0; margin: 22px 0 0; display:grid; gap:14px; }
.fly-list li { display:flex; gap:14px; align-items:flex-start; }
.fly-list .step { flex:none; width:30px;height:30px;border-radius:50%; background:rgba(255,122,24,.14); color:var(--accent-2); font-family:var(--font-head); font-weight:700; font-size:.9rem; display:grid;place-items:center; }
.fly-list b { color:var(--text); }

/* ---------- System steps ---------- */
.steps { display:grid; gap:18px; }
@media (min-width:760px){ .steps { grid-template-columns: repeat(5,1fr); } }
.step-card { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:24px; position:relative; }
.step-card .n { font-family:var(--font-head); font-weight:800; font-size:1.6rem; color:var(--accent); opacity:.55; }
.step-card h3 { font-size:1.05rem; margin:10px 0 6px; }
.step-card p { font-size:.88rem; margin:0; }

/* ---------- Napkin Flywheel ---------- */
.napkin-card {
  max-width: 560px; margin: 0 auto; position: relative;
  border-radius: 18px;
  transform: rotate(-1.1deg);
  filter: drop-shadow(0 28px 55px rgba(0,0,0,.55));
}
.napkin-card::before {
  content:""; position:absolute; top:-14px; left:50%; transform:translateX(-50%) rotate(2deg);
  width:120px; height:30px; background: rgba(245,235,210,.55);
  border:1px solid rgba(0,0,0,.06); border-radius:3px;
  box-shadow: 0 4px 8px rgba(0,0,0,.18); z-index:2;
}
.flywheel-napkin { width:100%; height:auto; display:block; border-radius:18px; }

/* build-on animation (plays when scrolled into view) */
.flywheel-napkin .fw-node   { opacity:0; }
.flywheel-napkin .fw-center { opacity:0; transform: scale(.85); transform-box: fill-box; transform-origin: center; }
.flywheel-napkin .fw-arrow  { stroke-dasharray: 320; stroke-dashoffset: 320; }
.flywheel-napkin .fw-ring   { transform-box: fill-box; transform-origin: center; }

.flywheel-napkin.fw-play .fw-center { animation: fwPop .7s cubic-bezier(.2,.8,.3,1.3) forwards, fwPulse 4.5s ease-in-out 1.4s infinite; }
.flywheel-napkin.fw-play .fw-node   { animation: fwIn .55s ease forwards; animation-delay: .3s; }
.flywheel-napkin.fw-play .fw-ring   { animation: fwSpin 55s linear infinite; }
.flywheel-napkin .fw-ring2, .flywheel-napkin .fw-orbit { transform-box: view-box; transform-origin: 440px 700px; opacity:0; }
.flywheel-napkin.fw-play .fw-ring2  { animation: fwReveal .5s ease 1.4s forwards, fwSpin 6s linear 1.4s infinite; }
.flywheel-napkin.fw-play .fw-orbit  { animation: fwReveal .5s ease 1.6s forwards, fwSpin 6s linear 1.6s infinite; }
.flywheel-napkin.fw-play .fw-arrow  { animation: fwDraw .7s ease forwards; }
.flywheel-napkin.fw-play .fw-arrow:nth-of-type(1){animation-delay:.45s}
.flywheel-napkin.fw-play .fw-arrow:nth-of-type(2){animation-delay:.57s}
.flywheel-napkin.fw-play .fw-arrow:nth-of-type(3){animation-delay:.69s}
.flywheel-napkin.fw-play .fw-arrow:nth-of-type(4){animation-delay:.81s}
.flywheel-napkin.fw-play .fw-arrow:nth-of-type(5){animation-delay:.93s}
.flywheel-napkin.fw-play .fw-arrow:nth-of-type(6){animation-delay:1.05s}
.flywheel-napkin.fw-play .fw-arrow:nth-of-type(7){animation-delay:1.17s}
.flywheel-napkin.fw-play .fw-arrow:nth-of-type(8){animation-delay:1.29s}

@keyframes fwPop   { to { opacity:1; transform: scale(1); } }
@keyframes fwIn    { from { opacity:0; } to { opacity:1; } }
@keyframes fwDraw  { to { stroke-dashoffset: 0; } }
@keyframes fwSpin  { to { transform: rotate(360deg); } }
@keyframes fwReveal{ to { opacity:1; } }
@keyframes fwPulse { 0%,100%{ transform: scale(1); } 50%{ transform: scale(1.028); } }

@media (prefers-reduced-motion: reduce){
  .flywheel-napkin .fw-node{opacity:1}
  .flywheel-napkin .fw-center{opacity:1; transform:none}
  .flywheel-napkin .fw-arrow{stroke-dashoffset:0}
  .flywheel-napkin .fw-ring,
  .flywheel-napkin .fw-ring2,
  .flywheel-napkin .fw-orbit{animation:none !important; opacity:.6}
  .flywheel-napkin .fw-orbit{opacity:1}
}

/* ---------- Store metaphor callout ---------- */
.callout {
  border-radius:var(--radius-lg); border:1px solid var(--line);
  background: linear-gradient(135deg, rgba(255,122,24,.10), rgba(255,122,24,.02));
  padding: 40px 30px;
}
@media (min-width:760px){ .callout{ padding:54px; } }
.callout h2 { margin-bottom:18px; }
.callout .cols { display:grid; gap:22px; margin-top:26px; }
@media (min-width:760px){ .callout .cols { grid-template-columns:repeat(3,1fr); } }
.callout .cols div { border-left:2px solid var(--accent); padding-left:16px; }
.callout .cols b { color:var(--text); display:block; margin-bottom:4px; font-family:var(--font-head); }
.callout .cols p { font-size:.92rem; margin:0; }

/* ---------- Cases ---------- */
.case-grid { display:grid; gap:22px; }
@media (min-width:860px){ .case-grid { grid-template-columns:repeat(3,1fr); } }
.case {
  border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  background:var(--surface); transition:transform .2s, border-color .2s;
}
.case:hover { transform:translateY(-4px); border-color:var(--accent); }
.case .top { padding:26px 26px 0; }
.case .cat { font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted-2); }
.case .big { font-family:var(--font-head); font-weight:800; font-size:2.4rem; color:var(--green); margin:10px 0 4px; }
.case .desc { padding:14px 26px 26px; }
.case .desc p { font-size:.92rem; margin:0; }
.case .metrics { display:flex; gap:18px; padding:0 26px 24px; flex-wrap:wrap; }
.case .metrics span { font-size:.82rem; color:var(--muted); }
.case .metrics b { color:var(--text); font-family:var(--font-head); }

/* ---------- Compare table ---------- */
.compare { width:100%; border-collapse:collapse; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.compare th, .compare td { padding:16px 18px; text-align:left; border-bottom:1px solid var(--line); font-size:.95rem; }
.compare thead th { font-family:var(--font-head); background:var(--surface-2); }
.compare thead th.boom { color:var(--accent-2); }
.compare td.boom { color:var(--text); }
.compare td.boom::before { content:"✓ "; color:var(--green); font-weight:700; }
.compare td.other { color:var(--muted-2); }
.compare td.other::before { content:"– "; }
.compare tbody tr:last-child td { border-bottom:none; }
.table-scroll { overflow-x:auto; -webkit-overflow-scrolling:touch; }

/* ---------- Founder ---------- */
.founder { display:grid; gap:40px; align-items:center; }
@media (min-width:880px){ .founder { grid-template-columns: .85fr 1.15fr; } }
.founder-photo {
  border-radius:var(--radius-lg); border:1px solid var(--line); aspect-ratio:4/5;
  background: linear-gradient(160deg, var(--surface-2), var(--surface));
  display:grid; place-items:center; text-align:center; color:var(--muted-2); padding:24px;
  background-size:cover; background-position:center;
}
.founder blockquote { font-family:var(--font-head); font-size:clamp(1.3rem,2.6vw,1.9rem); line-height:1.3; color:var(--text); margin:0 0 26px; font-weight:600; }
.founder blockquote .accent { font-style:normal; }
.kpis { display:flex; gap:30px; flex-wrap:wrap; }
.kpi b { display:block; font-family:var(--font-head); font-size:2rem; color:var(--accent-2); }
.kpi span { font-size:.85rem; color:var(--muted); }

/* ---------- Process ---------- */
.proc { display:grid; gap:22px; counter-reset:p; }
@media (min-width:760px){ .proc { grid-template-columns:repeat(3,1fr); } }
.proc .p {
  border:1px solid var(--line); border-radius:var(--radius); padding:30px; background:var(--surface); position:relative;
}
.proc .p .n { font-family:var(--font-head); font-weight:800; color:var(--accent); font-size:1.1rem; }
.proc .p h3 { margin:12px 0 8px; font-size:1.2rem; }
.proc .p p { margin:0; font-size:.93rem; }

/* ---------- For whom ---------- */
.forwho { display:grid; gap:22px; }
@media (min-width:760px){ .forwho { grid-template-columns:1fr 1fr; } }
.forwho .col { border:1px solid var(--line); border-radius:var(--radius); padding:30px; background:var(--surface); }
.forwho ul { list-style:none; padding:0; margin:14px 0 0; display:grid; gap:12px; }
.forwho li { display:flex; gap:12px; font-size:.96rem; color:#cdd3df; }
.forwho .yes li::before { content:"✓"; color:var(--green); font-weight:700; }
.forwho .no li::before { content:"✕"; color:var(--muted-2); font-weight:700; }

/* ---------- FAQ ---------- */
.faq { max-width:780px; margin:0 auto; }
.faq details { border-bottom:1px solid var(--line); padding:6px 0; }
.faq summary { cursor:pointer; list-style:none; padding:18px 0; font-family:var(--font-head); font-weight:600; font-size:1.08rem; display:flex; justify-content:space-between; gap:14px; }
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after { content:"+"; color:var(--accent-2); font-size:1.4rem; line-height:1; transition:transform .2s; }
.faq details[open] summary::after { transform:rotate(45deg); }
.faq details p { padding:0 0 18px; margin:0; }

/* ---------- Final CTA ---------- */
.final {
  text-align:center; border-radius:var(--radius-lg); padding:60px 24px;
  background: linear-gradient(135deg, rgba(255,122,24,.18), rgba(255,122,24,.03));
  border:1px solid var(--line);
}
@media (min-width:760px){ .final { padding:84px 40px; } }
.final h2 { max-width:760px; margin:0 auto 28px; }

/* ---------- Footer ---------- */
.site-footer { border-top:1px solid var(--line); padding:50px 0 36px; }
.foot-grid { display:flex; flex-wrap:wrap; gap:30px; justify-content:space-between; align-items:flex-start; }
.foot-grid .brand { margin-bottom:8px; }
.foot-links { display:flex; gap:26px; flex-wrap:wrap; }
.foot-links a { color:var(--muted); font-size:.92rem; }
.foot-links a:hover { color:var(--accent-2); }
.foot-bottom { margin-top:34px; padding-top:22px; border-top:1px solid var(--line); display:flex; flex-wrap:wrap; gap:12px; justify-content:space-between; color:var(--muted-2); font-size:.85rem; }

/* ---------- Reveal animation ---------- */
.reveal { opacity:0; transform:translateY(24px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal { opacity:1; transform:none; } }

/* =================================================================
   Revision 2 — Logo, Hero-Glow, Delta-Karte, Grafiken, Team
   ================================================================= */

/* Wordmark logo */
.brand { display:flex; align-items:baseline; gap:7px; font-family:var(--font-head); }
.brand b { font-weight:800; font-size:1.4rem; letter-spacing:-.01em; color:var(--text); }
.brand span { font-weight:600; font-size:.72rem; letter-spacing:.3em; color:var(--accent); text-transform:uppercase; }

/* Hero highlight — orange with soft glow */
.hl { color:var(--accent-2); text-shadow:0 0 30px rgba(255,122,24,.55), 0 0 8px rgba(255,122,24,.4); }

/* Delta card (replaces result card in hero) */
.delta-card { background:linear-gradient(160deg,var(--surface-2),var(--surface)); border:1px solid var(--line); border-radius:var(--radius-lg); padding:28px; box-shadow:var(--shadow); }
.delta-bars { display:grid; gap:14px; margin:20px 0 22px; }
.db-row { display:flex; align-items:center; gap:14px; }
.db-label { width:66px; flex:none; font-size:.85rem; color:var(--muted); }
.db-track { flex:1; height:18px; border-radius:9px; background:rgba(255,255,255,.06); overflow:hidden; }
.db-fill { height:100%; border-radius:9px; }
.db-fill.full { width:100%; background:linear-gradient(90deg,var(--accent),var(--accent-2)); box-shadow:0 0 18px rgba(255,122,24,.4); }
.db-fill.ist { width:38%; background:#3a4150; }
.delta-gap { display:flex; align-items:center; gap:15px; border-top:1px solid var(--line); padding-top:18px; }
.delta-brace { width:6px; height:42px; border-radius:3px; background:var(--accent); flex:none; }
.delta-gap b { font-family:var(--font-head); color:var(--text); display:block; font-size:1.05rem; }
.delta-gap span { font-size:.9rem; color:var(--muted); }

/* Two-customers graphic */
.twocust-graphic { max-width:720px; margin:0 auto 38px; }
.twocust-graphic svg { width:100%; height:auto; display:block; }

/* Store metaphor mini-icons */
.store-cols .store-ic { width:88px; height:auto; display:block; margin-bottom:14px; }

/* Process flow connectors */
.proc .p h3 em { font-style:normal; color:var(--accent-2); font-size:.85rem; font-weight:600; }
@media (min-width:760px){
  .proc-flow .p { position:relative; }
  .proc-flow .p:not(:last-child)::after { content:"→"; position:absolute; right:-19px; top:46%; transform:translateY(-50%); color:var(--accent); font-family:var(--font-head); font-size:1.7rem; z-index:3; }
}

/* Team — circular photos + alternating layout */
.founder-photo { border:none; background:none; aspect-ratio:auto; padding:0; display:block; }
.founder-photo img { width:100%; max-width:340px; aspect-ratio:1/1; border-radius:50%; background:#fff; border:1px solid var(--line); box-shadow:var(--shadow); margin:0 auto; display:block; }
@media (min-width:880px){
  .founder.reverse { grid-template-columns:1.15fr .85fr; }
  .founder.reverse .founder-photo { order:2; }
}
.founder .eyebrow { margin-bottom:14px; }

/* Socials & inline links */
.socials { display:flex; gap:12px; align-items:center; margin-top:18px; flex-wrap:wrap; }
.socials a { width:40px; height:40px; border-radius:50%; display:grid; place-items:center; border:1px solid var(--line-2); color:var(--muted); transition:transform .2s, color .2s, border-color .2s; }
.socials a:hover { color:var(--accent-2); border-color:var(--accent); transform:translateY(-2px); }
.socials a svg { width:19px; height:19px; fill:currentColor; }
.socials a.pill { width:auto; height:40px; border-radius:999px; padding:0 16px; font-family:var(--font-head); font-weight:600; font-size:.85rem; color:var(--accent-2); border-color:var(--accent); }
.socials a.pill:hover { background:rgba(255,122,24,.12); }
.inline-link { color:var(--accent-2); text-decoration:underline; text-underline-offset:2px; }
.inline-link:hover { color:var(--accent); }

/* Specialist team icons (stroke style) */
.card .ic svg { width:24px; height:24px; fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }

/* Hero video placeholder */
.hero-video .video-frame { aspect-ratio:4/5; border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line); background:linear-gradient(160deg,var(--surface-2),var(--surface)); position:relative; box-shadow:var(--shadow); max-width:420px; margin:0 auto; }
.hero-video video { width:100%; height:100%; object-fit:cover; display:block; }
.video-poster { position:absolute; inset:0; display:grid; place-items:center; background-size:cover; background-position:center top; }
.video-poster::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(10,12,17,.25), rgba(10,12,17,.78)); }
.vp-badge { position:absolute; top:16px; left:16px; z-index:2; background:rgba(0,0,0,.45); backdrop-filter:blur(6px); padding:7px 13px; border-radius:999px; font-size:.8rem; color:#fff; font-family:var(--font-head); font-weight:600; }
.play-btn { position:relative; z-index:2; width:76px; height:76px; border-radius:50%; border:none; cursor:pointer; background:linear-gradient(135deg,var(--accent),var(--accent-deep)); box-shadow:var(--shadow-accent); display:grid; place-items:center; transition:transform .2s; }
.play-btn::before { content:""; position:absolute; inset:-10px; border-radius:50%; border:2px solid rgba(255,122,24,.5); animation:playPulse 2.2s ease-out infinite; }
.play-btn:hover { transform:scale(1.07); }
.play-btn svg { width:30px; height:30px; fill:#fff; margin-left:4px; }
.vp-hint { position:absolute; bottom:16px; left:0; right:0; z-index:2; text-align:center; font-size:.8rem; color:rgba(255,255,255,.75); }
@keyframes playPulse { 0%{ transform:scale(1); opacity:.8; } 100%{ transform:scale(1.4); opacity:0; } }
@media (prefers-reduced-motion: reduce){ .play-btn::before{ animation:none; } }

/* System steps — sequential reveal */
.steps-flow .step-card { opacity:0; transform:translateY(16px); }
.steps-flow.play .step-card { animation:stepIn .5s cubic-bezier(.2,.8,.3,1.2) forwards; }
.steps-flow.play .step-card:nth-child(1){ animation-delay:.05s; }
.steps-flow.play .step-card:nth-child(2){ animation-delay:.22s; }
.steps-flow.play .step-card:nth-child(3){ animation-delay:.39s; }
.steps-flow.play .step-card:nth-child(4){ animation-delay:.56s; }
.steps-flow.play .step-card:nth-child(5){ animation-delay:.73s; }
.step-card .n { transition:color .3s; }
.steps-flow.play .step-card .n { animation:nPop .5s ease forwards; }
@keyframes stepIn { to { opacity:1; transform:none; } }
@keyframes nPop { 0%{ transform:scale(.6); } 60%{ transform:scale(1.15); color:var(--accent-2); } 100%{ transform:scale(1); } }
@media (prefers-reduced-motion: reduce){ .steps-flow .step-card{ opacity:1; transform:none; } }

/* Why Boom — visual comparison */
.vs-wrap { display:grid; gap:18px; align-items:stretch; }
@media (min-width:820px){ .vs-wrap { grid-template-columns:1fr auto 1fr; gap:18px; align-items:center; } }
.vs-card { border:1px solid var(--line); border-radius:var(--radius); padding:30px; background:var(--surface); }
.vs-card.boom { border-color:var(--accent); background:linear-gradient(165deg,rgba(255,122,24,.12),rgba(255,122,24,.02)); box-shadow:var(--shadow-accent); }
.vs-head { font-family:var(--font-head); font-weight:800; font-size:1.3rem; margin-bottom:20px; }
.vs-card.boom .vs-head { color:var(--text); }
.vs-card.other .vs-head { color:var(--muted); }
.vs-logo { color:var(--accent); }
.vs-card ul { list-style:none; margin:0; padding:0; display:grid; gap:14px; }
.vs-card li { display:flex; gap:12px; font-size:.96rem; line-height:1.4; }
.vs-card li::before { flex:none; font-weight:800; }
.vs-card.boom li { color:#dfe4ec; }
.vs-card.boom li::before { content:"✓"; color:var(--green); }
.vs-card.other li { color:var(--muted-2); }
.vs-card.other li::before { content:"✕"; color:#5a6373; }
.vs-badge { justify-self:center; align-self:center; width:50px; height:50px; border-radius:50%; background:var(--accent); color:#fff; font-family:var(--font-head); font-weight:800; display:grid; place-items:center; box-shadow:var(--shadow-accent); }

/* Lead magnet */
.leadmag { display:grid; gap:36px; align-items:center; border:1px solid var(--line); border-radius:var(--radius-lg); padding:36px; background:linear-gradient(135deg,rgba(255,122,24,.08),rgba(255,122,24,.01)); }
@media (min-width:840px){ .leadmag { grid-template-columns:1.1fr .9fr; padding:54px; } }
.leadmag-points { list-style:none; padding:0; margin:18px 0 0; display:grid; gap:12px; }
.leadmag-points li { display:flex; gap:12px; color:#cdd3df; font-size:.97rem; }
.leadmag-points li::before { content:"✓"; color:var(--green); font-weight:800; }
.leadmag-form-wrap { display:flex; flex-direction:column; align-items:center; gap:22px; }
.leadmag-doc svg { width:130px; filter:drop-shadow(0 16px 30px rgba(0,0,0,.5)); transform:rotate(-3deg); }
.leadmag-form { width:100%; display:grid; gap:12px; }
.leadmag-form input { width:100%; padding:14px 16px; border-radius:12px; border:1px solid var(--line-2); background:var(--surface); color:var(--text); font-family:var(--font-body); font-size:1rem; }
.leadmag-form input::placeholder { color:var(--muted-2); }
.leadmag-form input:focus { outline:none; border-color:var(--accent); }
.leadmag-fine { text-align:center; font-size:.8rem; color:var(--muted-2); }
.hp { position:absolute; left:-9999px; }

/* Potenzial-Analyse Wizard */
.wizard { max-width:640px; margin:0 auto; }
.wiz-progress { height:6px; background:rgba(255,255,255,.08); border-radius:3px; margin-bottom:30px; overflow:hidden; }
.wiz-progress span { display:block; height:100%; background:linear-gradient(90deg,var(--accent),var(--accent-2)); width:25%; transition:width .35s ease; border-radius:3px; }
.wiz-step { display:none; }
.wiz-step.active { display:block; animation:fwIn .4s ease; }
.wiz-step h2 { font-size:clamp(1.4rem,3.5vw,2rem); margin-bottom:8px; }
.wiz-q { color:var(--muted); margin-bottom:24px; }
.wiz-field { width:100%; padding:16px 18px; border-radius:12px; border:1px solid var(--line-2); background:var(--surface); color:var(--text); font-size:1.05rem; font-family:var(--font-body); margin-bottom:12px; }
.wiz-field::placeholder { color:var(--muted-2); }
.wiz-field:focus { outline:none; border-color:var(--accent); }
.wiz-options { display:grid; gap:12px; }
.wiz-opt { display:flex; align-items:center; gap:12px; padding:16px 18px; border:1px solid var(--line-2); border-radius:12px; cursor:pointer; transition:border-color .2s, background .2s; }
.wiz-opt:hover { border-color:var(--accent); }
.wiz-opt input { accent-color:var(--accent); width:18px; height:18px; flex:none; }
.wiz-opt:has(input:checked) { border-color:var(--accent); background:rgba(255,122,24,.10); }
.wiz-nav { display:flex; justify-content:space-between; gap:12px; margin-top:28px; }
.wiz-back { background:transparent; border:1px solid var(--line-2); color:var(--muted); }
.wiz-back:hover { color:var(--text); border-color:var(--line-2); }
.wiz-hint { font-size:.85rem; color:var(--muted-2); margin-top:16px; text-align:center; }
.wiz-steps-count { font-family:var(--font-head); font-size:.8rem; color:var(--accent-2); letter-spacing:.1em; text-transform:uppercase; margin-bottom:10px; }

/* Danke / next-steps list */
.nextsteps { max-width:560px; margin:30px auto 0; text-align:left; display:grid; gap:16px; }
.nextstep { display:flex; gap:16px; align-items:flex-start; border:1px solid var(--line); border-radius:var(--radius); padding:20px; background:var(--surface); }
.nextstep .ns-n { flex:none; width:34px; height:34px; border-radius:50%; background:rgba(255,122,24,.14); color:var(--accent-2); font-family:var(--font-head); font-weight:700; display:grid; place-items:center; }
.nextstep b { font-family:var(--font-head); display:block; margin-bottom:3px; }
.nextstep p { margin:0; font-size:.93rem; }

/* Chat-style speech bubbles mit Avataren */
.chat { display:flex; flex-direction:column; gap:18px; max-width:680px; margin:0 auto; }
.chat-row { display:flex; gap:12px; align-items:flex-end; }
.chat-row.right { flex-direction:row-reverse; }
.chat-avatar { width:46px; height:46px; flex:none; border-radius:50%; overflow:hidden; border:1px solid var(--line-2); background:#222834; }
.chat-avatar svg { width:100%; height:100%; display:block; }
.chat-bubble { background:var(--surface-2); border:1px solid var(--line); border-radius:18px 18px 18px 4px; padding:14px 18px 12px; max-width:80%; }
.chat-row.right .chat-bubble { border-radius:18px 18px 4px 18px; background:rgba(255,122,24,.10); border-color:rgba(255,122,24,.30); }
.chat-bubble p { margin:0 0 5px; font-style:italic; color:#e8ebf1; font-size:.97rem; line-height:1.5; }
.chat-bubble span { font-size:.76rem; color:var(--accent-2); font-family:var(--font-head); font-weight:600; }

/* Speech bubbles (echte Kundenaussagen) */
.bubbles { display:grid; gap:16px; max-width:880px; margin:0 auto; }
@media (min-width:760px){
  .bubbles { grid-template-columns:repeat(2,1fr); }
  .bubbles .bubble:last-child { grid-column:span 2; max-width:62%; justify-self:center; }
}
.bubble { position:relative; background:var(--surface-2); border:1px solid var(--line); border-radius:16px; padding:20px 22px 16px; }
.bubble::after { content:""; position:absolute; bottom:-9px; left:34px; width:16px; height:16px; background:var(--surface-2); border-right:1px solid var(--line); border-bottom:1px solid var(--line); transform:rotate(45deg); }
.bubble p { margin:0 0 8px; color:#e8ebf1; font-size:1rem; font-style:italic; line-height:1.5; }
.bubble span { font-size:.8rem; color:var(--accent-2); font-family:var(--font-head); font-weight:600; }
.bubble-note { text-align:center; font-size:.78rem; color:var(--muted-2); margin-top:20px; }

/* CTA microcopy */
.cta-fine { font-size:.85rem; color:var(--muted-2); margin-top:10px; }

/* Case study detail */
.case-chips { display:flex; flex-wrap:wrap; gap:10px; margin-top:24px; }
.case-chips span { background:var(--surface); border:1px solid var(--line-2); border-radius:999px; padding:9px 16px; font-size:.88rem; color:#cdd3df; font-family:var(--font-head); font-weight:600; }
.case-story { display:grid; gap:18px; }
@media (min-width:760px){ .case-story { grid-template-columns:1fr 1fr; } }
.cs-block { border:1px solid var(--line); border-radius:var(--radius); padding:26px; background:var(--surface); }
.cs-label { font-family:var(--font-head); font-size:.8rem; letter-spacing:.1em; text-transform:uppercase; color:var(--accent-2); display:block; margin-bottom:10px; }
.cs-block p { margin:0; color:#cdd3df; }

/* Compact system strip */
.syssteps { display:flex; flex-wrap:wrap; gap:10px 6px; align-items:center; justify-content:center; }
.syssteps span { background:var(--surface); border:1px solid var(--line); border-radius:999px; padding:12px 20px; font-family:var(--font-head); font-weight:600; font-size:.95rem; color:var(--text); }
.syssteps span b { color:var(--accent-2); margin-right:6px; }
.syssteps i { color:var(--accent); font-style:normal; font-weight:800; font-size:1.2rem; }
@media (max-width:640px){ .syssteps i { transform:rotate(90deg); } .syssteps { flex-direction:column; } }

/* Two-customers compact (inside diagnosis) */
.diag-twocust { margin-top:48px; padding-top:40px; border-top:1px solid var(--line); }

/* Testimonial */
.testimonial { max-width:760px; margin:44px auto 0; text-align:center; border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:34px 20px; }
.testimonial p { font-family:var(--font-head); font-size:clamp(1.15rem,2.4vw,1.55rem); line-height:1.4; color:var(--text); margin:0 0 18px; font-weight:600; }
.testimonial footer { display:flex; gap:10px; justify-content:center; align-items:baseline; flex-wrap:wrap; }
.ts-name { font-family:var(--font-head); color:var(--accent-2); font-weight:700; }
.ts-role { color:var(--muted-2); font-size:.9rem; }

/* Founder + team illustration */
.team-illu { max-width:620px; margin:0 auto 46px; text-align:center; }
.team-illu svg { width:100%; height:auto; max-width:520px; }
.team-illu-cap { font-family:var(--font-head); color:var(--muted); font-size:.95rem; margin-top:8px; }

/* ============================================================
   POLISH PASS (v3) — Premium-Feinschliff, reiner CSS/JS-Stack
   Gekapselt am Dateiende; via styles.pre-polish.bak rückrollbar.
   ============================================================ */
:root{
  --ease-out: cubic-bezier(.16,1,.3,1);
  --ease-soft: cubic-bezier(.22,.61,.36,1);
}

/* 1) Smootheres, „premium" Reveal (sanfter, mit Mini-Scale) */
.reveal{
  transform: translateY(30px) scale(.985);
  transition: opacity .8s var(--ease-out) var(--rd,0s), transform .8s var(--ease-out) var(--rd,0s);
  will-change: opacity, transform;
}
.reveal.in{ transform: none; }
@media (prefers-reduced-motion: reduce){ .reveal{ transform:none !important; } }

/* 2) Karten-Hover: weicher Lift + Akzent-Glow statt harter Kante */
.card, .case{
  transition: transform .4s var(--ease-out), border-color .35s ease, box-shadow .4s ease;
}
.card:hover{
  transform: translateY(-6px);
  border-color: rgba(255,122,24,.45);
  box-shadow: 0 22px 50px -24px rgba(255,122,24,.45), 0 2px 0 rgba(255,255,255,.03) inset;
}
.case{ position:relative; }
.case:hover{
  transform: translateY(-6px);
  border-color: rgba(255,122,24,.5);
  box-shadow: 0 24px 55px -26px rgba(255,122,24,.5);
}
/* dezenter oberer Lichtrand auf Karten */
.card::before, .case::before{
  content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background: linear-gradient(180deg, rgba(255,255,255,.05), transparent 38%);
  opacity:0; transition:opacity .4s ease;
}
.card:hover::before, .case:hover::before{ opacity:1; }

/* 3) Primär-Button: Glanz-Sweep beim Hover */
.btn-primary{ position:relative; overflow:hidden; }
.btn-primary::after{
  content:""; position:absolute; top:0; left:-130%; width:60%; height:100%;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,.35), transparent);
  transform: skewX(-18deg); transition: left .6s var(--ease-soft);
}
.btn-primary:hover::after{ left:140%; }
.btn{ transition: transform .25s var(--ease-out), box-shadow .3s ease, background .25s ease; }

/* 4) Nav-Links: animierte Unterstreichung */
.nav-links a:not(.btn){ position:relative; }
.nav-links a:not(.btn)::after{
  content:""; position:absolute; left:0; bottom:-4px; height:2px; width:100%;
  background: var(--accent); border-radius:2px;
  transform: scaleX(0); transform-origin:left; transition: transform .3s var(--ease-out);
}
.nav-links a:not(.btn):hover::after{ transform: scaleX(1); }

/* 5) Logo-Leiste: Hover hebt einzelnes Logo sauber heraus */
.logo-row span{ transition: opacity .25s ease, transform .25s var(--ease-out); }
.logo-row:hover span{ opacity:.3; }
.logo-row span:hover{ opacity:1; transform: translateY(-2px); }

/* 6) Section-Headlines: Eyebrow bekommt feinen Fade-Up-Versatz */
.section-head .eyebrow{ transition: opacity .8s var(--ease-out) .05s, transform .8s var(--ease-out) .05s; }

/* 7) Zugängliche Fokus-States (Tastatur-Navigation) */
a:focus-visible, button:focus-visible, .btn:focus-visible,
input:focus-visible, summary:focus-visible{
  outline: 2px solid var(--accent-2);
  outline-offset: 3px;
  border-radius: 6px;
}

/* 8) FAQ: weicheres Aufklappen */
.faq details{ transition: background .25s ease; }
.faq summary{ transition: color .2s ease; }

/* 9) Bild-/Video-Karten & Result-Card: gleiche Hover-Sprache */
.result-card{ transition: transform .4s var(--ease-out), box-shadow .4s ease; }
.result-card:hover{ transform: translateY(-4px); box-shadow: 0 26px 60px -28px rgba(0,0,0,.8); }

/* 10) Socials: weicher als bisher */
.socials a:hover{ transform: translateY(-3px) scale(1.05); color: var(--accent-2); border-color: var(--accent); }


/* ============ POLISH v3.1 — Logo-Marquee, Case-Hover, Serviette, Legal ============ */

/* Hover NIE durch Stagger-Delay verzoegern */
.card:hover, .case:hover, .card, .case{ transition-delay: 0s !important; }

/* Logo-Leiste: laufendes Band (Logos spaeter als <img class="logo-item">) */
.logos{ padding: 40px 0; overflow: hidden; }
.logo-marquee{
  position: relative; overflow: hidden; margin-top: 22px;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.logo-track{ display: flex; align-items: center; gap: 64px; width: max-content; animation: logoScroll 36s linear infinite; }
.logo-item{
  font-family: var(--font-head); font-weight: 600; font-size: 1.15rem;
  color: #cfd5e0; opacity: .5; white-space: nowrap;
  transition: opacity .25s ease, transform .25s var(--ease-out), color .25s ease;
}
.logo-item img{ height: 34px; width: auto; display: block; filter: grayscale(1) brightness(1.7); opacity: .8; transition: filter .25s, opacity .25s, transform .25s var(--ease-out); }
.logo-item:hover{ opacity: 1; color: #fff; transform: scale(1.07); }
.logo-item:hover img{ filter: none; opacity: 1; transform: scale(1.07); }
@keyframes logoScroll{ from{ transform: translateX(0); } to{ transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce){
  .logo-track{ animation: none; flex-wrap: wrap; justify-content: center; gap: 18px 40px; }
}

/* Case-Karten: deutlicher Lift + Metriken leuchten orange beim Hover */
.case{ transition: transform .4s var(--ease-out), border-color .35s ease, box-shadow .4s ease !important; }
.case:hover{
  transform: translateY(-9px);
  border-color: rgba(255,122,24,.6);
  box-shadow: 0 28px 60px -24px rgba(255,122,24,.5);
}
.case .metrics span, .case .metrics b, .case .cat, .case .desc p{ transition: color .3s ease; }
.case:hover .metrics span{ color: var(--accent-2); }
.case:hover .metrics b{ color: var(--accent); }
.case:hover .cat{ color: var(--accent-2); }

/* Footer-Legal-Links (Platzhalter) */
.foot-legal a{ color: var(--muted); transition: color .2s ease; }
.foot-legal a:hover{ color: var(--accent-2); }


/* DTC: Praxis-Beleg-Kasten (ersetzt losen Satz) */
.dtc-proof{
  margin-top: 28px; padding: 22px 26px;
  border: 1px solid var(--line); border-left: 3px solid var(--accent);
  border-radius: 0 14px 14px 0; background: var(--surface);
}
.dtc-proof-tag{
  font-family: var(--font-head); font-weight: 600; font-size: .76rem;
  letter-spacing: .14em; text-transform: uppercase; color: var(--accent-2);
  display: block; margin-bottom: 8px;
}
.dtc-proof p{ margin: 0; color: #dfe4ec; line-height: 1.65; }
.dtc-proof b{ color: var(--text); }


/* ============ Logo-Marquee: Bild-Logos (weiss, einheitlich) ============ */
img.logo-item{
  height: 30px; width: auto; display: block;
  opacity: .62; filter: none;
  transition: opacity .25s ease, transform .25s var(--ease-out);
}
img.logo-item:hover{ opacity: 1; transform: scale(1.08); }

/* ============ Launch: Hero-Portrait (statt Video) + Case "In Arbeit" ============ */
.hero-portrait{
  position: relative; max-width: 430px; margin: 0 auto; text-align: center;
  border-radius: var(--radius-lg); padding: 34px 30px 28px;
  background: linear-gradient(165deg, rgba(255,122,24,.14), var(--surface));
  border: 1px solid var(--line); box-shadow: var(--shadow);
}
.hero-portrait img{
  width: 220px; height: 220px; object-fit: cover; object-position: center top;
  border-radius: 50%; margin: 0 auto 18px; display: block;
  background: #f4efe3; border: 1px solid var(--line-2);
}
.hero-portrait-cap b{ font-family: var(--font-head); font-size: 1.2rem; display: block; color: var(--text); }
.hero-portrait-cap span{ color: var(--muted); font-size: .9rem; }

.case-soon{ cursor: default; opacity: .72; }
.case-soon:hover{ transform: none; border-color: var(--line); box-shadow: none; }
.case-soon::before{ display: none; }
.case-soon .big{ color: var(--muted-2); }
