/* ===== Selbst gehostete Schrift (Instrument Sans, Variable) — DSGVO: kein Google-Request ===== */
@font-face{font-family:'Instrument Sans';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/instrument-sans-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Instrument Sans';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/instrument-sans-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Instrument Sans';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/instrument-sans-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Instrument Sans';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/instrument-sans-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Instrument Sans';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/instrument-sans-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;}
@font-face{font-family:'Instrument Sans';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/instrument-sans-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}

:root{
  --bg:#F9F7F5;
  --card:#FCFCFB;
  --card-soft:#F4F3F0;
  --ink:#19191A;
  --muted:#8C8C86;
  --faint:#B6B5AF;
  --line:rgba(25,25,26,.08);
  --green:#36A85B;
  --leaf:#3CA35C;
  --bark:#7B4B27;
  --shadow:0 1px 2px rgba(25,25,26,.04), 0 18px 40px -22px rgba(25,25,26,.28);
  --shadow-hover:0 1px 2px rgba(25,25,26,.05), 0 26px 50px -24px rgba(25,25,26,.34);
  --r-lg:30px;
  --r-md:20px;
}

*{box-sizing:border-box;margin:0;padding:0}

html{scroll-behavior:smooth}

body{
  font-family:'Instrument Sans',system-ui,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  padding:18px 16px 64px;
  letter-spacing:-.01em;
  position:relative;
}

/* Noise-Effekt entfernt */
.noise{display:none}

.wrap{max-width:480px;margin:0 auto;display:flex;flex-direction:column;gap:14px;position:relative;z-index:1}

/* entrance */
.fade{opacity:0;transform:translateY(14px);animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards}
.fade:nth-child(2){animation-delay:.06s}
.fade:nth-child(3){animation-delay:.12s}
.fade:nth-child(4){animation-delay:.18s}
.fade:nth-child(5){animation-delay:.24s}
.fade:nth-child(6){animation-delay:.30s}
@keyframes rise{to{opacity:1;transform:none}}

/* ---------- TOP BAR ---------- */
.bar{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--card);
  border-radius:999px;
  padding:11px 16px 11px 18px;
  box-shadow:var(--shadow);
}
.brand{display:flex;align-items:center;gap:10px;font-weight:600;font-size:.95rem;text-decoration:none;color:inherit}
.brand .logo{width:32px;height:32px;flex-shrink:0;display:grid;place-items:center;
  background:var(--card-soft);border:1px solid var(--line);border-radius:50%;
  position:relative;overflow:visible;cursor:pointer;-webkit-tap-highlight-color:transparent}
.brand .logo svg{width:20px;height:auto;display:block;transform-origin:center bottom}

.avail{display:flex;align-items:center;gap:7px;font-size:.82rem;font-weight:500;color:var(--muted)}
.avail .dot{width:8px;height:8px;border-radius:50%;background:var(--green);position:relative}
.avail .dot::after{content:"";position:absolute;inset:-4px;border-radius:50%;background:var(--green);opacity:.35;animation:pulse 2.2s ease-out infinite}
@keyframes pulse{0%{transform:scale(.6);opacity:.5}100%{transform:scale(1.8);opacity:0}}

/* ---------- SPRACH-SWITCHER ---------- */
.bar-right{display:flex;align-items:center;gap:11px;min-width:0}
.lang{display:inline-flex;background:var(--card-soft);border:1px solid var(--line);border-radius:999px;padding:2px;flex-shrink:0}
.lang-btn{
  font:inherit;font-size:.72rem;font-weight:600;letter-spacing:.02em;
  color:var(--muted);background:transparent;border:0;border-radius:999px;
  padding:5px 9px;cursor:pointer;line-height:1;text-decoration:none;
  transition:background .15s, color .15s;
}
.lang-btn[aria-current="true"]{background:var(--ink);color:#fff}
.lang-btn:not([aria-current="true"]):hover{color:var(--ink)}
.lang-btn:focus-visible{outline:2px solid var(--ink);outline-offset:2px}

/* ---------- TOP-BAR CTA: Projekt anfragen ---------- */
.cta{
  font:inherit;font-size:.82rem;font-weight:600;line-height:1;
  color:#fff;background:var(--ink);border:1px solid var(--ink);
  text-decoration:none;white-space:nowrap;flex-shrink:0;
  padding:8px 14px;border-radius:999px;
  transition:transform .15s, box-shadow .15s;
}
.cta:hover{transform:translateY(-1px);box-shadow:var(--shadow-hover)}
.cta:active{transform:translateY(0)}
.cta:focus-visible{outline:2px solid var(--ink);outline-offset:2px}

/* Unter dem Bento-Breakpoint ist die .wrap auf 480px begrenzt -> Navi schlank halten:
   Markenname und „Verfügbar"-Text ausblenden, nur Logo + (Dot) + CTA + Sprachwahl. */
@media (max-width:899px){
  .brand-name{display:none}
  .avail .avail-txt{display:none}
}
@media (max-width:430px){
  .bar{padding:9px 10px 9px 12px}
  .bar-right{gap:8px}
  .cta{padding:7px 11px;font-size:.78rem}
}

/* ---------- DESKTOP: BENTO (Karten nebeneinander) ---------- */
@media (min-width:900px){
  .wrap{
    max-width:980px;
    display:block;            /* Flex aus, Mehrspalten an */
    column-count:2;
    column-gap:16px;
  }
  .wrap > *{
    -webkit-column-break-inside:avoid;
    break-inside:avoid;       /* Karten nie über Spalten zerreißen */
    margin:0 0 16px;          /* ersetzt das Flex-gap */
  }
  .bar{column-span:all}       /* Topbar über volle Breite */
  .foot{column-span:all;margin-bottom:0}
}

/* Startseite hat mehr Kacheln → auf großen Screens 3 Spalten */
@media (min-width:1300px){
  body#home .wrap{
    max-width:1300px;
    column-count:3;
  }
}

/* ---------- INTRO ---------- */
.intro{
  background:var(--card);
  border-radius:var(--r-lg);
  padding:26px 26px 30px;
  box-shadow:var(--shadow);
}
.who{display:flex;align-items:center;gap:13px;margin-bottom:26px}
.avatar{
  width:76px;height:76px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(150deg,#2b2b2c,#4a4a48 60%,#6d6c66);
  color:#fff;display:grid;place-items:center;
  font-weight:600;font-size:1.02rem;letter-spacing:.02em;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.12);
}
img.avatar{object-fit:cover;display:block}
.who .nm{font-weight:600;font-size:1rem;line-height:1.2}
.who .rl{font-size:.85rem;color:var(--muted)}

.headline{
  font-weight:500;
  font-size:clamp(1.7rem,7vw,2.15rem);
  line-height:1.08;
  letter-spacing:-.025em;
}
.headline em{font-style:normal;color:var(--faint)}

.blurb{
  margin-top:18px;
  color:var(--muted);
  font-size:1rem;
  max-width:38ch;
}

/* ---------- EYEBROW + BACK (Unterseiten) ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:7px;
  font-size:.74rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  color:var(--leaf);
  background:rgba(60,163,92,.10);
  padding:5px 11px;border-radius:999px;
  margin-bottom:16px;
}
.back{
  display:inline-flex;align-items:center;gap:7px;
  margin-top:22px;
  font-size:.88rem;font-weight:500;color:var(--muted);
  text-decoration:none;
  transition:color .18s, gap .18s;
}
.back:hover{color:var(--ink);gap:10px}
.back .ar{font-size:1rem;transition:transform .18s}
.back:hover .ar{transform:translateX(-2px)}

/* ---------- SECTION ---------- */
.section{
  background:var(--card);
  border-radius:var(--r-lg);
  padding:24px 22px 22px;
  box-shadow:var(--shadow);
}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;margin:2px 4px 18px}
.sec-title{font-weight:500;font-size:1.32rem;letter-spacing:-.02em}
.sec-count{font-size:.8rem;color:var(--faint);font-weight:500}

/* ---------- LINK ROW ---------- */
.links{display:flex;flex-direction:column;gap:9px}
.row{
  display:flex;align-items:center;gap:14px;
  text-decoration:none;color:inherit;
  background:var(--card-soft);
  border:1px solid var(--line);
  border-radius:var(--r-md);
  padding:14px 16px;
  transition:transform .18s cubic-bezier(.2,.7,.2,1), background .18s, box-shadow .18s;
}
.row:hover{transform:translateY(-2px);background:#fff;box-shadow:var(--shadow-hover)}
.row:active{transform:translateY(0)}
.row:focus-visible{outline:2px solid var(--ink);outline-offset:2px}

.ico{
  width:40px;height:40px;flex-shrink:0;border-radius:12px;
  display:grid;place-items:center;font-size:1.15rem;
  background:#fff;border:1px solid var(--line);
}
.meta{flex:1;min-width:0}
.ttl{display:flex;align-items:center;flex-wrap:wrap;gap:6px 8px;font-weight:500;font-size:.98rem;line-height:1.2}
.dsc{display:block;font-size:.84rem;color:var(--muted);margin-top:2px;overflow-wrap:anywhere}
.arrow{
  flex-shrink:0;align-self:center;
  width:18px;height:18px;font-size:0;
  color:var(--faint);background-color:currentColor;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='6' y1='18' x2='18' y2='6'/%3E%3Cpolyline points='9 6 18 6 18 15'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='6' y1='18' x2='18' y2='6'/%3E%3Cpolyline points='9 6 18 6 18 15'/%3E%3C/svg%3E") center/contain no-repeat;
  transition:transform .18s, color .18s, background-color .18s;
}
.row:hover .arrow{transform:translate(2px,-2px);color:var(--ink)}

.badge{font-size:.62rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;
  padding:2px 7px;border-radius:999px;line-height:1.4}
.badge.live{color:var(--green);background:rgba(54,168,91,.12)}
.badge.new{color:#19191A;background:rgba(25,25,26,.07)}
.badge.hot{color:#B26A00;background:rgba(255,159,28,.16)}

/* ---------- ICONS (moderne SVGs statt Emojis) ---------- */
.ico svg{width:21px;height:21px;display:block}
.ico-lemon{background:#FFE600;border-color:rgba(25,25,26,.12);overflow:hidden}
.ico-lemon img{width:100%;height:100%;object-fit:cover;display:block}
.ico-mygastro img{width:26px;height:26px;object-fit:contain;display:block}

.eyebrow svg{width:14px;height:14px;display:block;flex-shrink:0}

/* ---------- TOOL-MARQUEE ---------- */
.marquee{
  display:flex;flex-direction:column;gap:10px;
  /* Ränder weich ausblenden, damit Chips in die Karte „hineinlaufen“ */
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
}
.marquee-row{display:flex;overflow:hidden}
.marquee-track{
  display:flex;flex:0 0 auto;width:max-content;
  animation:marquee 36s linear infinite;
  will-change:transform;
}
.marquee-row--reverse .marquee-track{animation-direction:reverse}
.marquee-group{display:flex;align-items:center;gap:10px;padding-right:10px;flex:0 0 auto}
.marquee:hover .marquee-track{animation-play-state:paused}

@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

.chip{
  display:inline-flex;align-items:center;gap:9px;flex:0 0 auto;
  background:var(--card-soft);border:1px solid var(--line);border-radius:999px;
  padding:7px 14px 7px 8px;
  font-size:.86rem;font-weight:500;color:var(--ink);white-space:nowrap;line-height:1;
}
.chip img{
  width:24px;height:24px;flex-shrink:0;display:block;
  border-radius:7px;object-fit:cover;
}

/* Brand-Logo-Kachel oben auf einer Unterseite */
.page-logo{
  width:56px;height:56px;border-radius:16px;
  display:grid;place-items:center;margin-bottom:20px;
  background:var(--card-soft);border:1px solid var(--line);
}
.page-logo svg{width:32px;height:32px;display:block}

/* Logo-Topper über einer Sektion (z. B. Chrome Extensions) */
.sec-logo{display:flex;justify-content:center;margin-bottom:16px}
.sec-logo .tile{
  width:52px;height:52px;border-radius:15px;
  display:grid;place-items:center;
  background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);
}
.sec-logo .tile svg{width:30px;height:30px;display:block}

/* group sub-heading inside a section (2-Blöcke-Leistungen) */
.group-label{
  font-size:.74rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  color:var(--faint);margin:18px 4px 10px;
}
.group-label:first-of-type{margin-top:2px}

/* ---------- FEATURE LIST (Unterseiten) ---------- */
.feature-list{list-style:none;display:flex;flex-direction:column;gap:11px}
.feature-list li{
  display:flex;align-items:flex-start;gap:12px;
  font-size:.96rem;line-height:1.4;
}
.feature-list li::before{
  content:"";flex-shrink:0;margin-top:3px;
  width:18px;height:18px;border-radius:50%;
  background:rgba(60,163,92,.14);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2336A85B' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;background-size:11px;
}

/* ---------- BUILD NOTE ---------- */
.note{
  background:var(--ink);color:#EDEDEA;
  border-radius:var(--r-md);
  padding:16px 18px;margin-bottom:12px;
  font-size:.92rem;line-height:1.55;
}
.note b{color:#fff;font-weight:600}
.note a{color:#fff;font-weight:600;text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:3px;text-decoration-color:rgba(255,255,255,.55);transition:text-decoration-color .15s}
.note a:hover{text-decoration-color:#fff}
.note a:focus-visible{outline:2px solid #fff;outline-offset:3px;border-radius:3px}

/* ---------- FOOTER ---------- */
.foot{text-align:center;padding-top:34px;margin-top:10px}
.socials{display:flex;gap:9px;justify-content:center;margin-bottom:14px}
.soc{
  width:46px;height:46px;display:grid;place-items:center;
  background:var(--card);border-radius:14px;
  text-decoration:none;color:var(--ink);font-weight:500;font-size:.86rem;
  box-shadow:var(--shadow);transition:transform .18s, box-shadow .18s;
}
.soc:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.soc svg{width:20px;height:20px;display:block;color:var(--ink)}
.soc svg path{fill:var(--ink)}
.copy{font-size:.8rem;color:var(--muted)}
.legal{display:flex;gap:8px;justify-content:center;align-items:center;margin-top:8px;font-size:.8rem}
.legal a{color:var(--muted);text-decoration:none;transition:color .15s}
.legal a:hover{color:var(--ink)}
.legal a:focus-visible{outline:2px solid var(--ink);outline-offset:2px;border-radius:4px}
.legal-sep{color:var(--faint)}

/* ---------- RECHTS-/PROSA-SEITEN (Impressum, Datenschutz) ---------- */
.prose{display:flex;flex-direction:column;gap:14px}
.prose h2{font-size:1.04rem;font-weight:600;letter-spacing:-.01em;margin-top:8px}
.prose h2:first-child{margin-top:0}
.prose p{font-size:.94rem;line-height:1.6}
.prose address{font-style:normal;font-size:.94rem;line-height:1.7}
.prose a{color:var(--ink);text-decoration:underline;text-underline-offset:2px}
.prose a:hover{color:var(--green)}
.prose .muted{color:var(--muted)}
.prose ul{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:2px}
.prose ul li{position:relative;padding-left:18px;font-size:.94rem;line-height:1.55}
.prose ul li::before{content:"";position:absolute;left:0;top:.6em;width:5px;height:5px;border-radius:50%;background:var(--green)}
.prose .updated{font-size:.84rem;color:var(--faint);margin-top:4px}
@media (min-width:900px){
  body.legal-page .wrap{column-count:1;max-width:720px}
}

/* ---------- MULTISTEP FORM ---------- */
.form-service{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.84rem;font-weight:500;color:var(--muted);
  background:var(--card-soft);border:1px solid var(--line);
  padding:7px 13px;border-radius:999px;margin:0 4px 18px;
}
.form-service b{color:var(--ink);font-weight:600}
.form-service[hidden]{display:none}

.prog{height:5px;background:var(--card-soft);border:1px solid var(--line);border-radius:999px;overflow:hidden;margin:0 4px 20px}
.prog-bar{display:block;height:100%;width:33.33%;background:var(--ink);border-radius:999px;transition:width .35s cubic-bezier(.2,.7,.2,1)}

.q{font-weight:500;font-size:.95rem;margin:0 4px 11px}
.opts{display:flex;flex-wrap:wrap;gap:8px}
.opt{
  display:inline-flex;align-items:center;gap:8px;
  font:inherit;font-size:.9rem;font-weight:500;color:var(--ink);
  background:var(--card-soft);border:1px solid var(--line);border-radius:14px;
  padding:11px 14px;cursor:pointer;
  transition:transform .15s, background .15s, border-color .15s, color .15s;
}
.opt svg{width:15px;height:15px;display:block;flex-shrink:0}
.opt:hover{background:#fff;transform:translateY(-1px)}
.opt[aria-pressed="true"]{background:var(--ink);color:#fff;border-color:var(--ink)}
.opt:focus-visible{outline:2px solid var(--ink);outline-offset:2px}

.inp{
  width:100%;font:inherit;font-size:.95rem;color:var(--ink);
  background:var(--card-soft);border:1px solid var(--line);border-radius:14px;
  padding:13px 15px;margin-top:9px;outline:none;
  transition:border-color .15s, background .15s;
}
.inp::placeholder{color:var(--faint)}
.inp:focus{background:#fff;border-color:var(--ink)}
.ta{resize:vertical;min-height:84px;line-height:1.5}
.err{color:#C0392B;font-size:.82rem;margin:10px 4px 0}

/* ---------- BUDGET-SLIDER ---------- */
.range-wrap{margin:4px 4px 0}
.range-val{display:block;font-weight:600;font-size:1.5rem;letter-spacing:-.02em;line-height:1;margin-bottom:16px}
.range{-webkit-appearance:none;appearance:none;width:100%;height:24px;background:transparent;cursor:pointer;outline:none;display:block}
.range::-webkit-slider-runnable-track{height:8px;border-radius:999px;border:1px solid var(--line);
  background:linear-gradient(to right, var(--ink) 0 var(--p,40%), var(--card-soft) var(--p,40%) 100%)}
.range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;margin-top:-9px;
  width:24px;height:24px;border-radius:50%;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)}
.range::-moz-range-track{height:8px;border-radius:999px;border:1px solid var(--line);background:var(--card-soft)}
.range::-moz-range-progress{height:8px;border-radius:999px;background:var(--ink)}
.range::-moz-range-thumb{width:24px;height:24px;border:1px solid var(--line);border-radius:50%;background:#fff;box-shadow:var(--shadow)}
.range:focus-visible::-webkit-slider-thumb{outline:2px solid var(--ink);outline-offset:2px}
.range:focus-visible::-moz-range-thumb{outline:2px solid var(--ink);outline-offset:2px}
.range-ends{display:flex;justify-content:space-between;margin:9px 2px 0;font-size:.78rem;color:var(--faint);font-weight:500}

/* ---------- CONSENT-CHECKBOX ---------- */
.consent{display:flex;align-items:flex-start;gap:10px;margin-top:14px;cursor:pointer}
.consent input{margin:2px 0 0;width:18px;height:18px;flex-shrink:0;accent-color:var(--ink);cursor:pointer}
.consent-txt{font-size:.84rem;color:var(--muted);line-height:1.45}
.consent-txt a{color:var(--ink);text-decoration:underline;text-underline-offset:2px}
.consent-txt a:hover{color:var(--green)}

/* Honeypot – für Menschen unsichtbar */
.hp{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden;opacity:0}

/* Lade-/Deaktiviert-Zustand der Buttons */
.btn[disabled]{opacity:.6;cursor:default;transform:none!important;box-shadow:none!important}

.nav{display:flex;gap:10px;margin-top:20px}
.nav[hidden]{display:none}
.btn{
  font:inherit;font-weight:600;font-size:.95rem;cursor:pointer;flex:1;
  border:1px solid var(--ink);border-radius:14px;padding:12px 20px;
  background:var(--ink);color:#fff;
  transition:transform .15s, box-shadow .15s;
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.btn:active{transform:translateY(0)}
.btn.ghost{background:transparent;color:var(--ink);flex:0 0 auto}
.btn.ghost:hover{background:var(--card-soft);box-shadow:none}

.done{text-align:center;padding:8px 6px 4px}
.done-ico{width:50px;height:50px;border-radius:50%;background:rgba(54,168,91,.14);
  color:var(--green);display:grid;place-items:center;font-size:1.45rem;font-weight:700;margin:0 auto 14px}
.done-ico svg{width:26px;height:26px;display:block}
.done-t{font-weight:500;font-size:1.18rem}
.done-s{color:var(--muted);font-size:.92rem;margin:6px auto 18px;max-width:36ch}

@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}
.shake{animation:shake .35s}

@media (prefers-reduced-motion:reduce){
  .fade{animation:none;opacity:1;transform:none}
  .avail .dot::after{animation:none}
  .noise{animation:none}
  .shake{animation:none}
  .marquee-track{animation:none}
  .marquee-row{overflow-x:auto;scrollbar-width:none}
  .marquee-row::-webkit-scrollbar{display:none}
  *{transition:none!important}
}

/* ===== Lange Service-Seiten (Intro nutzt die bestehende .prose-Regel oben) ===== */
.steps{ list-style:none; counter-reset:step; padding:0; margin:0; display:grid; gap:12px; }
.steps li{ counter-increment:step; position:relative; padding-left:40px; line-height:1.5; }
.steps li::before{ content:counter(step); position:absolute; left:0; top:-2px;
  width:26px; height:26px; border-radius:999px; display:grid; place-items:center;
  font-size:.8rem; font-weight:600; background:var(--leaf); color:#fff; }

.faq{ display:grid; gap:8px; }
.faq details{ border:1px solid rgba(0,0,0,.08); border-radius:12px; padding:0 14px; background:rgba(255,255,255,.5); }
.faq summary{ cursor:pointer; padding:14px 0; font-weight:600; list-style:none; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:'+'; float:right; opacity:.5; }
.faq details[open] summary::after{ content:'–'; }
.faq details > p{ margin:0 0 14px; line-height:1.6; color:var(--muted,#55524c); }

/* ===== Consent-Manager / Cookie-Banner ===== */
.cc{
  position:fixed;left:0;right:0;bottom:0;z-index:9999;
  display:flex;justify-content:center;
  padding:14px 14px calc(14px + env(safe-area-inset-bottom));
  pointer-events:none;
}
.cc-card{
  pointer-events:auto;width:100%;max-width:560px;
  max-height:calc(100vh - 28px);overflow-y:auto;
  background:var(--card);border:1px solid var(--line);
  border-radius:var(--r-lg);box-shadow:var(--shadow-hover);
  padding:20px 20px 18px;
  transform:translateY(18px);opacity:0;
  transition:transform .28s cubic-bezier(.2,.7,.2,1), opacity .28s;
}
.cc--in .cc-card{transform:none;opacity:1}
.cc-title{font-weight:600;font-size:1.06rem;letter-spacing:-.01em}
.cc-text{margin-top:7px;color:var(--muted);font-size:.9rem;line-height:1.5}
.cc-priv{color:var(--ink);text-decoration:underline;text-underline-offset:2px}
.cc-priv:hover{color:var(--green)}

.cc-cats{display:flex;flex-direction:column;gap:4px;margin:14px 0 2px}
.cc-cats[hidden]{display:none}
.cc-cat{padding:12px 0;border-top:1px solid var(--line)}
.cc-cat:first-child{border-top:0}
.cc-cat-h{display:flex;align-items:center;justify-content:space-between;gap:12px}
.cc-cat-name{font-weight:500;font-size:.94rem}
.cc-cat-d{margin-top:4px;color:var(--muted);font-size:.82rem;line-height:1.45;max-width:46ch}
.cc-always{font-size:.74rem;font-weight:600;letter-spacing:.02em;color:var(--leaf);
  background:rgba(60,163,92,.12);padding:4px 10px;border-radius:999px;white-space:nowrap}

/* Schalter */
.cc-switch{position:relative;display:inline-block;flex-shrink:0;width:42px;height:24px;cursor:pointer}
.cc-switch input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer}
.cc-track{position:absolute;inset:0;background:var(--card-soft);border:1px solid var(--line);
  border-radius:999px;transition:background .18s,border-color .18s}
.cc-track::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;
  background:#fff;box-shadow:0 1px 2px rgba(25,25,26,.25);transition:transform .18s}
.cc-switch input:checked + .cc-track{background:var(--ink);border-color:var(--ink)}
.cc-switch input:checked + .cc-track::after{transform:translateX(18px)}
.cc-switch input:focus-visible + .cc-track{outline:2px solid var(--ink);outline-offset:2px}

.cc-actions{display:flex;flex-wrap:wrap;gap:9px;margin-top:16px}
.cc-btn{
  font:inherit;font-weight:600;font-size:.88rem;line-height:1;cursor:pointer;
  border:1px solid var(--line);border-radius:999px;padding:11px 16px;
  background:var(--card-soft);color:var(--ink);flex:1 1 auto;white-space:nowrap;
  transition:transform .15s,background .15s,box-shadow .15s,border-color .15s;
}
.cc-btn:hover{transform:translateY(-1px);background:#fff;box-shadow:var(--shadow)}
.cc-btn:active{transform:translateY(0)}
.cc-btn:focus-visible{outline:2px solid var(--ink);outline-offset:2px}
.cc-btn--primary{background:var(--ink);color:#fff;border-color:var(--ink);flex-grow:1.4}
.cc-btn--primary:hover{background:var(--ink);box-shadow:var(--shadow-hover)}

.cc-reopen{cursor:pointer}

@media (max-width:430px){
  .cc-btn{flex-basis:100%}
}
@media (prefers-reduced-motion:reduce){
  .cc-card{transition:none;transform:none;opacity:1}
}
