/* ============ Design-Token ============ */
:root{
  --bg:#0b1222; --bg-2:#0e162a;
  --panel:#111a31; --panel-2:#0f1830;
  --text:#e6e7ea; --muted:#9aa4b2;
  --accent:#22d3ee; --accent-2:#a78bfa;
  --ring: rgba(34,211,238,.45);
  --border: rgba(255,255,255,.09);
  --shadow: 0 18px 40px rgba(2,8,23,.45);
  --radius: 16px;
  --header-h: 66px
}

/* Reset & Base */
*{box-sizing:border-box}
html,body{margin:0;padding:0;scroll-behavior:smooth}
body{
  font-family: ui-sans-serif,system-ui,Segoe UI,Roboto,Arial;
  color:var(--text); line-height:1.55;
  background:
    radial-gradient(1300px 800px at 5% -10%, #162449 0%, transparent 60%),
    radial-gradient(1200px 900px at 95% -20%, #0d1a3a 0%, transparent 60%),
    var(--bg);
}

/* Ribbon */
.ribbon{position:relative; height:36px; overflow:hidden; border-bottom:1px solid var(--border); background:#0a142a}
.ribbon__track{display:flex; gap:32px; position:absolute; white-space:nowrap; animation:marquee 22s linear infinite; opacity:.75}
.ribbon__track span{padding:8px 0; text-transform:uppercase; font-weight:700; letter-spacing:.1em; color:var(--muted)}
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* Utilities */
.container{width:min(1160px, 92%); margin:0 auto}
.accent{color:var(--accent)}
.accent-gradient{background:linear-gradient(90deg,var(--accent),var(--accent-2)); -webkit-background-clip:text; background-clip:text; color:transparent}
.muted{color:var(--muted)}
.lead{font-size:1.1rem; color:var(--muted)}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  height:44px; padding:0 18px; border-radius:999px;
  text-decoration:none; font-weight:700; border:1px solid var(--border);
  transition:transform .2s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease;
  user-select:none; cursor:pointer;
}
.btn:hover{transform:translateY(-1px)}
.btn--tiny{height:36px; font-weight:700; padding:0 14px}
.btn--primary{background:linear-gradient(90deg,var(--accent),var(--accent-2)); color:#051019; border-color:transparent; box-shadow:0 8px 30px rgba(34,211,238,.25)}
.btn--glass{background:rgba(255,255,255,.06); color:var(--text)}

.section{padding:88px 0}
.section--alt{background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0) 60%)}
.section h2{font-size:2.15rem;margin:0 0 10px}
.section__intro{color:var(--muted); margin:0 0 28px}

/* Mesh Background (Hero) */
.mesh-bg{
  position:absolute; inset:-12% 0 auto 0; height:560px; z-index:0;
  background:
    radial-gradient(700px 300px at 18% 30%, rgba(34,211,238,.18), transparent 60%),
    radial-gradient(600px 300px at 75% 24%, rgba(167,139,250,.18), transparent 60%),
    radial-gradient(600px 360px at 50% 74%, rgba(34,211,238,.10), transparent 60%);
  filter:saturate(140%) blur(12px);
  pointer-events:none;
}

/* NAV */
.nav{position:sticky; top:0; z-index:50; backdrop-filter:saturate(130%) blur(6px); background:rgba(10,15,30,.55); border-bottom:1px solid var(--border)}
.nav__inner{display:flex; align-items:center; justify-content:space-between; height:66px}
.nav__links{display:flex; gap:22px}
.nav__links a{color:var(--muted); text-decoration:none; font-weight:700}
.nav__links a:hover{color:var(--text)}
.nav__cta{margin-left:8px}

/* ===== Masked Logo ===== */
.logo-cut{
  display:block;
  color:#000;
  filter:
    drop-shadow(0 0 26px rgba(255,255,255,.30))
    drop-shadow(0 3px 10px rgba(0,0,0,.40));
  shape-rendering: geometricPrecision;
  image-rendering: -webkit-optimize-contrast;
  transition:transform .18s ease, filter .18s ease;
}
.logo-cut--sm{height:50px; width:auto}
.logo-cut--xl{height:138px; width:auto}
.nav:hover .logo-cut--sm{ transform: translateY(-1px) }

/* HERO */
.hero{position:relative; padding:104px 0 46px; overflow:hidden}
.hero__content{position:relative; z-index:1; text-align:center}
.hero__logo-wrap{position:relative; display:inline-flex; justify-content:center; margin-bottom:14px}
.hero__logo-wrap::before{
  content:""; position:absolute; inset:-30% -24% -34% -24%;
  background:
    radial-gradient(48% 42% at 50% 42%, rgba(255,255,255,.22), transparent 62%),
    radial-gradient(70% 70% at 50% 56%, rgba(255,255,255,.10), transparent 72%);
  filter: blur(18px) saturate(120%); pointer-events:none; z-index:0;
}
.hero__logo-wrap > .logo-cut{ position:relative; z-index:1 }
.hero h1{font-size: clamp(2.2rem, 3.6vw, 3.6rem); line-height:1.12; margin:0 0 12px}
.hero__actions{display:flex; gap:12px; justify-content:center; margin:22px 0 30px}
.hero__metrics{display:flex; gap:26px; justify-content:center}
.metric{display:grid; justify-items:center}
.metric span{font-size:1.9rem; font-weight:900; background:linear-gradient(90deg,var(--accent),var(--accent-2)); -webkit-background-clip:text; background-clip:text; color:transparent}
.metric small{color:var(--muted); font-weight:700}

/* Screenshots */
.hero__shots{display:grid; gap:16px; grid-template-columns:1fr; justify-items:center}
.hero__shots img{
  width:min(980px, 100%); border-radius:18px; border:1px solid var(--border);
  box-shadow: var(--shadow); background: #0a1226;
}

/* Cards/Effekte */
.grid{display:grid; gap:18px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.card{
  background:linear-gradient(180deg,var(--panel),var(--panel-2));
  border:1px solid var(--border); border-radius:var(--radius); padding:18px;
  box-shadow:0 8px 24px rgba(5,10,25,.25);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.lift:hover{transform:translateY(-4px) scale(1.01); box-shadow:0 16px 44px rgba(5,10,25,.35); border-color:rgba(34,211,238,.25)}

/* Features */
.features{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
.feature{border-radius:14px; padding:14px; border:1px solid var(--border); background:#111a31}
.glass{background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)); backdrop-filter: blur(6px)}

/* Steps */
.steps{display:flex; gap:18px; list-style:none; padding:0; margin:26px 0 0}
.steps li{flex:1; display:flex; align-items:center; gap:10px; background:#0e1730; border:1px solid var(--border); padding:12px; border-radius:12px}
.steps span{display:inline-grid; place-items:center; width:26px; height:26px; border-radius:999px; font-weight:800; color:#051019; background:linear-gradient(90deg,var(--accent),var(--accent-2))}

/* Reports */
.report-teaser{display:grid; grid-template-columns:1.2fr .8fr; gap:24px; align-items:center}
.report-teaser__chart{border:1px solid var(--border); border-radius:16px; padding:18px; box-shadow:var(--shadow)}
.chart-placeholder{height:320px; display:grid; place-items:center; color:var(--muted); background:#0a132a; border-radius:12px}

/* CTA */
.cta-band{background:linear-gradient(90deg, rgba(34,211,238,.12), rgba(167,139,250,.12)); border-top:1px solid var(--border); border-bottom:1px solid var(--border)}
.cta-band__inner{display:flex; align-items:center; justify-content:space-between; gap:18px; padding:18px 0;}

/* Pricing */
.pricing{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
.price-card{background:linear-gradient(180deg,var(--panel),var(--panel-2)); border:1px solid var(--border); border-radius:16px; padding:18px; transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease}
.price-card:hover{transform:translateY(-4px); box-shadow:0 16px 44px rgba(5,10,25,.35)}
.price-card--highlight{outline:2px solid var(--accent); box-shadow:0 0 0 6px rgba(34,211,238,.07) inset}
.price{font-size:1.4rem; font-weight:800; margin:6px 0 12px}

/* FAQ */
.faq__item{background:#0f1830; border:1px solid var(--border); border-radius:12px; padding:12px; margin:10px 0}
.faq__item summary{cursor:pointer; font-weight:800}
.faq__item[open]{outline:1px solid rgba(34,211,238,.25)}

/* Kontakt */
.contact{display:grid; grid-template-columns:1.1fr .9fr; gap:22px}
.form{border:1px solid var(--border); border-radius:16px; padding:16px}
.form__row{display:grid; grid-template-columns:1fr 1fr; gap:12px}
label{display:block; font-weight:700; color:var(--muted)}
input, textarea{width:100%; margin-top:8px; background:#0f1830; color:var(--text); border:1px solid var(--border); border-radius:12px; padding:10px 12px; outline:none}
input:focus, textarea:focus{box-shadow:0 0 0 4px var(--ring); border-color:transparent}
.form__actions{display:flex; gap:12px; margin-top:10px}
.form__hint{color:var(--muted); font-size:.92rem}

/* Footer */
.footer{border-top:1px solid var(--border); padding:20px 0; background:#0a1224}
.foot{display:flex; justify-content:space-between; align-items:center; gap:16px}
.foot__links{display:flex; gap:16px}
.foot__links a{color:var(--muted); text-decoration:none}
.foot__links a:hover{color:var(--text)}

/* Reveal-on-Scroll */
.reveal-up{opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s ease}
.reveal-up.visible{opacity:1; transform:translateY(0)}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce){
  .ribbon__track{animation:none}
  .reveal-up{transition:none; opacity:1; transform:none}
}

/* Responsive */
@media (max-width:1024px){
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .features{grid-template-columns:repeat(2,1fr)}
  .report-teaser{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
}
@media (max-width:860px){
  .nav__links{display:none}
  .pricing{grid-template-columns:1fr}
}
@media (max-width:560px){
  .form__row{grid-template-columns:1fr}
}

/* ========= Modal (Datenschutz) ========= */
body.has-modal{ overflow:hidden; }
.modal-overlay{
  position:fixed; inset:0; z-index:9998;
  background:rgba(2,8,23,.62);
  opacity:0; pointer-events:none; transition:opacity .25s ease;
}
.modal{
  position:fixed; inset:0; z-index:9999;
  display:grid; place-items:center;
  opacity:0; pointer-events:none; transition:opacity .25s ease;
}
.modal[aria-hidden="false"], .modal[aria-hidden="false"] + .modal-overlay{
  opacity:1; pointer-events:auto;
}
.modal-panel{
  width:min(880px, 92vw); max-height:min(84vh, 100%);
  background:linear-gradient(180deg,var(--panel),var(--panel-2));
  color:var(--text); border:1px solid var(--border);
  border-radius:18px; box-shadow:var(--shadow);
  overflow:clip;
}
.modal-header{
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; padding:14px 16px;
  border-bottom:1px solid var(--border);
  background:linear-gradient(180deg, rgba(255,255,255,.03), transparent);
}
.modal-title{ font-size:18px; font-weight:800; letter-spacing:.2px; }
.modal-close{
  appearance:none; border:0; background:transparent; color:var(--text);
  font-size:18px; line-height:1; padding:8px 10px; border-radius:10px; cursor:pointer;
}
.modal-close:hover{ background:rgba(255,255,255,.07) }
.modal-close:focus-visible{ outline:2px solid var(--ring); outline-offset:2px; }
.modal-body{ padding:16px 18px; overflow:auto; }
.modal-body h1,.modal-body h2,.modal-body h3{ margin:14px 0 8px; font-weight:800; }
.modal-body p{ margin:8px 0; color:#c8d0e0; line-height:1.65; }
.modal-body a{ color:var(--accent); text-decoration:underline; }
/* Datenschutz-iframe */
.modal-body{ height: 70vh; }              /* konstante, angenehme Höhe */
.modal-iframe{
  display:block;
  width:100%;
  height:100%;
  border:0;
  background:#0f1830; /* harmoniert mit deinem Theme */
  border-radius: 0;   /* Panel hat schon Radius */
}
/* ===== Modern-Scrollbar (Modal) ===== */
.modal-body{
  /* Firefox */
  scrollbar-width: thin;
  scrollbar-color: var(--accent) rgba(255,255,255,.08);
}
/* WebKit (Chrome/Edge/Safari) */
.modal-body::-webkit-scrollbar{
  width: 12px;               /* Breite der Leiste */
}
.modal-body::-webkit-scrollbar-track{
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border-left: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
}
.modal-body::-webkit-scrollbar-thumb{
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
  border-radius: 999px;
  border: 3px solid transparent;      /* schafft „Pill“-Look */
  background-clip: padding-box;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.12);
}
.modal-body::-webkit-scrollbar-thumb:hover{
  filter: saturate(115%);
}
.modal-body::-webkit-scrollbar-thumb:active{
  filter: saturate(130%) brightness(1.05);
}
/* Kebab-Trigger (nur Icon) */
.nav-kebab{ display:none; background:transparent; border:0; padding:10px; border-radius:12px; color:var(--text); cursor:pointer; line-height:0 }
.nav-kebab .dot{ width:4px; height:4px; border-radius:50%; background:currentColor; display:inline-block; box-shadow:0 -6px 0 currentColor, 0 6px 0 currentColor }
.nav-kebab:hover{ background:rgba(255,255,255,.06) }
.nav-kebab:focus-visible{ outline:2px solid var(--ring); outline-offset:2px }

/* Panel-Grundstil (Desktop ausgeblendet) */
.nav-panel{ display:none }

/* Nur mobil aktivieren */
@media (max-width:960px){
  /* Desktop-Links im Header ausblenden, Kebab zeigen */
  .nav__links{ display:none }
  .nav-kebab{ display:inline-flex }

  /* Off-canvas Panel */
  .nav-panel{
    display:flex;
    position:fixed;
    top:var(--header-h); right:0; left:auto; bottom:0;
    inline-size:min(86vw, 380px);
    block-size:calc(100dvh - var(--header-h));
    padding:14px; gap:8px; flex-direction:column;
    overflow:auto; overscroll-behavior:contain;

    background:linear-gradient(180deg, var(--panel), var(--panel-2));
    border-left:1px solid rgba(255,255,255,.10);
    box-shadow:-26px 0 64px rgba(0,0,0,.38);

    transform:translateX(104%);
    transition:transform .28s cubic-bezier(.22,.61,.36,1);
    pointer-events:none; z-index:1101;
  }

  /* Öffnen rein per CSS */
  #navcheck:checked ~ .nav-panel{
    transform:translateX(0);
    pointer-events:auto;
  }

  /* Panel-Header */
  .nav-panel .menu-head{
    display:flex; align-items:center; justify-content:space-between;
    padding:4px 0 12px; margin-bottom:6px;
    border-bottom:1px solid rgba(255,255,255,.08);
  }
  .nav-panel .menu-title{ font-weight:900; letter-spacing:.02em }
  .nav-panel .menu-close{
    display:inline-grid; place-items:center;
    width:36px; height:36px; border-radius:10px; cursor:pointer; color:var(--text);
  }
  .nav-panel .menu-close:hover{ background:rgba(255,255,255,.08) }

  /* Links im Panel */
  .nav-panel a{
    display:flex; align-items:center; gap:10px;
    padding:12px 14px; border-radius:12px; text-decoration:none;
    color:var(--text); font-weight:700; letter-spacing:.01em; line-height:1.25;
    background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
    border:1px solid rgba(255,255,255,.06);
    transition:background .18s ease, border-color .18s ease, transform .12s ease;
  }
  .nav-panel a:hover{
    background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025));
    border-color:rgba(255,255,255,.14);
  }
  .nav-panel a:active{ transform:translateY(1px) }

  /* Seite horizontal nicht scrollen */
  html, body{ overflow-x:hidden }
  /* Optional: wenn offen, vertikal fixieren (moderne Browser) */
  html:has(#navcheck:checked), body:has(#navcheck:checked){ overflow:hidden }
}
/* ===== Kebab (rechts in der Topbar) ===== */
.nav__inner{ display:flex; align-items:center; justify-content:space-between }
.nav-kebab{
  display:inline-grid; place-items:center;
  height:38px; width:38px; margin-left:12px;
  border:1px solid var(--border);
  border-radius:999px; cursor:pointer; user-select:none;
  background:rgba(255,255,255,.06); color:var(--text);
  transition:transform .15s ease, background .15s ease, border-color .15s ease;
}
.nav-kebab:hover{ transform:translateY(-1px); background:rgba(255,255,255,.08) }
.nav-kebab:focus-visible{ outline:2px solid var(--ring); outline-offset:2px }
.nav-kebab .dot{
  width:2px; height:2px; border-radius:999px; background:currentColor; box-shadow:
    0 -6px 0 0 currentColor,
    0  0 0 0 currentColor,
    0  6px 0 0 currentColor;
}

.nav-panel{
  position: fixed; left: 0; right: 0; top: 0;
  z-index: 55;
  background: linear-gradient(180deg, var(--panel), var(--panel-2));
  border-bottom: 1px solid var(--border);
  padding: 12px 16px 16px;
  max-height: 75vh; overflow: auto;

  /* WICHTIG: komplett aus dem Viewport + keine Ränder/Schatten sichtbar */
  transform: translate3d(0, -130%, 0);   /* weiter als -100% */
  opacity: 0;
  visibility: hidden;
  box-shadow: none;
  pointer-events: none;

  /* weiche Animation */
  transition:
    transform .32s cubic-bezier(.2,.6,.2,1),
    opacity .22s ease,
    visibility 0s linear .22s,    /* erst nach Fade-out unsichtbar */
    box-shadow .22s ease;
  will-change: transform, opacity;
  backface-visibility: hidden;

  /* Extra-Sicherheit: Clip, falls Browser beim Rubberbanding was zeigt */
  clip-path: inset(0 0 100% 0);
}
.nav-overlay{
  position: fixed; inset: 0; z-index: 1099;
  background: rgba(2,8,23,.55);           /* kein transparenter/„durchsichtiger“ Look */
  backdrop-filter: blur(2px) saturate(120%);
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity .25s ease, visibility 0s linear .25s;
}

.menu-head{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding-bottom:8px; border-bottom:1px solid var(--border);
}
.menu-title{ font-weight:800; letter-spacing:.2px }
.menu-close{
  display:inline-grid; place-items:center;
  height:34px; width:34px; border:1px solid var(--border);
  border-radius:10px; cursor:pointer; background:rgba(255,255,255,.06);
}
.menu-close:hover{ background:rgba(255,255,255,.08) }

.nav-panel a{
  display:block; padding:12px 8px; border-radius:10px; color:var(--text); text-decoration:none; font-weight:700;
}
.nav-panel a:hover{ background:rgba(255,255,255,.06) }

#navcheck:checked ~ .nav-panel{
  transform: translate3d(0, 0, 0);
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  box-shadow: 0 18px 40px rgba(2,8,23,.45);
  transition:
    transform .32s cubic-bezier(.2,.6,.2,1),
    opacity .22s ease,
    visibility 0s,
    box-shadow .22s ease;
  clip-path: inset(0 0 0 0);
}

/* Sichtbarkeit: Desktop vs. Mobile */
@media (min-width:861px){
  .nav-kebab{ display:none }   /* nur auf Mobile sichtbar */
}
@media (max-width:860px){
  .nav__links{ display:none }  /* auf Mobile Navigation verbergen */
}
/* ——— Kebab-Icon ——— */
.nav-kebab{ display:none; background:transparent; border:0; padding:10px; border-radius:12px; color:var(--text); cursor:pointer; line-height:0 }
.nav-kebab .dot{ width:4px; height:4px; border-radius:50%; background:currentColor; display:inline-block; box-shadow:0 -6px 0 currentColor, 0 6px 0 currentColor }
.nav-kebab:hover{ background:rgba(255,255,255,.06) }
.nav-kebab:focus-visible{ outline:2px solid var(--ring); outline-offset:2px }

/* ——— Dropdown-Panel (Desktop verstecken) ——— */
.nav-drop{ display:none }

/* ——— Nur mobil ——— */
@media (max-width:960px){
  /* Desktop-Links im Header ausblenden, Kebab zeigen */
  .nav__links{ display:none }
  .nav-kebab{ display:inline-flex }

  /* Dropdown unter dem Header (slides down) */
@media (max-width:960px){
  .nav-drop{
    display:block;
    position:fixed;
    top: var(--header-h);
    left:0; right:0;
    transform: translateY(-110%) scale(.98);
    opacity: 0;
    transition:
      transform .34s cubic-bezier(.22,.61,.36,1),
      opacity .22s ease;
    z-index:1100;
    pointer-events:none;
  }

  .nav-drop .drop-inner{
    max-block-size: calc(100dvh - var(--header-h));
    overflow:auto;
    overscroll-behavior:contain;
    margin-inline:auto;
    width:min(92vw, 520px);
    border-radius: 16px;
    padding:12px;
    background: linear-gradient(180deg, var(--panel), var(--panel-2));
    border:1px solid rgba(255,255,255,.10);
    box-shadow: 0 24px 60px rgba(0,0,0,.45);
  }

  /* Kopfzeile im Panel */
  .drop-head{
    display:flex; align-items:center; justify-content:space-between;
    padding:4px 0 10px; margin-bottom:8px;
    border-bottom:1px solid rgba(255,255,255,.08);
  }
  .drop-title{ font-weight:900; letter-spacing:.02em }
  .drop-close{
    display:inline-grid; place-items:center;
    width:36px; height:36px; border-radius:10px; cursor:pointer; color:var(--text);
  }
  .drop-close:hover{ background:rgba(255,255,255,.08) }

  /* Links im Panel */
  .nav-drop a{
    display:flex; align-items:center; gap:10px;
    padding:12px 14px; border-radius:12px; text-decoration:none;
    color:var(--text); font-weight:700; letter-spacing:.01em; line-height:1.25;
    background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));
    border:1px solid rgba(255,255,255,.06);
    transition: background .18s ease, border-color .18s ease, transform .12s ease;
  }
  .nav-drop a + a{ margin-top:8px }
  .nav-drop a:hover{
    background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.025));
    border-color: rgba(255,255,255,.14);
  }
  .nav-drop a:active{ transform: translateY(1px) }

  #navcheck:checked ~ .nav-drop{
    transform: translateY(0) scale(1);
    opacity: 1;
    pointer-events: auto;
  }
  #navcheck:checked ~ .nav-overlay{
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transition: opacity .25s ease, visibility 0s;
  }}

  /* Seite horizontal nicht scrollen */
  html, body{ overflow-x:hidden }

  /* Optional: Scroll-Lock, solange offen (moderne Browser) */
  html:has(#navcheck:checked), body:has(#navcheck:checked){ overflow:hidden }
}
	  
	  /* ===== Mobile Fullscreen für "Module"-Sektion ===== */
@media (max-width: 960px){
  /* Section: immer in den Screen passen (abzgl. Header + Ribbon) */
  #module.section{
    /* Ribbon: 36px, Header: --header-h */
    min-height: calc(100dvh - var(--header-h) - 36px);
    display: flex;
    align-items: center;           /* Inhalt vertikal mittig */
    padding: 56px 0;               /* etwas kompakter als 88px */
  }
  #module .section__intro{ margin-bottom: 18px }

  /* Features etwas kompakter & flexibel */
  #module .features{
    display: grid;
    grid-template-columns: repeat( auto-fit, minmax(150px, 1fr) );
    gap: 12px;
  }
  #module .feature{ padding: 12px }

  /* ===== Steps als horizontaler Slider mit Snap ===== */
  #module .steps{
    display: grid;                 /* einfacher für Snap + Spaltenbreite */
    grid-auto-flow: column;
    grid-auto-columns: 82%;        /* Kartenbreite ~ Screenbreite */
    gap: 12px;

    overflow-x: auto;
    overscroll-behavior-x: contain;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    scroll-padding: 12px;

    padding: 2px 12px 6px;
    margin: 16px 0 0;

    /* Edge-Fade (Safari braucht -webkit-mask) */
    mask-image: linear-gradient(to right, transparent 0, black 24px, black calc(100% - 24px), transparent 100%);
    -webkit-mask-image: linear-gradient(to right, transparent 0, black 24px, black calc(100% - 24px), transparent 100%);
  }

  #module .steps li{
    scroll-snap-align: start;
    min-height: 64px;
    border-radius: 14px;
    padding: 12px;

    /* leichte Betonung im Slider */
    background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
    border: 1px solid rgba(255,255,255,.08);
    box-shadow: 0 8px 24px rgba(5,10,25,.20);
  }

  #module .steps span{
    width: 28px; height: 28px;     /* Nummern minimal größer */
    flex: 0 0 auto;
  }
}

/* Optional: etwas dichter auf sehr kleinen Geräten */
@media (max-width: 420px){
  #module .features{ grid-template-columns: 1fr 1fr }
  #module .steps{ grid-auto-columns: 88% }
}

	  /* ===== Elegante Checklist (Reports) ===== */
.report-teaser__text{ display:flex; flex-direction:column; gap:16px }

.checklist{
  list-style:none; padding:0; margin:0;
  display:grid; gap:12px;
  grid-template-columns: 1fr 1fr;               /* Desktop: 2 Spalten */
}
@media (max-width: 920px){
  .checklist{ grid-template-columns: 1fr }      /* Mobile: 1 Spalte */
}

/* Karten-Look pro Zeile */
.checklist li{
  position:relative;
  padding:14px 14px 14px 52px;
  border-radius:14px;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.08);
  box-shadow: 0 10px 28px rgba(5,10,25,.22);
  color:var(--text);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.checklist li:hover{
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(5,10,25,.28);
  border-color: rgba(34,211,238,.22);
}

/* runder Icon-Spot links + Häkchen via CSS-Mask */
.checklist li::before{
  content:"";
  position:absolute; left:14px; top:50%; transform:translateY(-50%);
  inline-size:28px; block-size:28px; border-radius:999px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  box-shadow: 0 6px 18px rgba(34,211,238,.28);
  -webkit-mask:
    url('data:image/svg+xml;utf8, \
      <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"> \
        <path fill="black" d="M9.5 16.3L4.9 11.7l1.6-1.6 3 3 7.1-7.1 1.6 1.6z"/> \
      </svg>') center/16px 16px no-repeat;
  mask:
    url('data:image/svg+xml;utf8, \
      <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"> \
        <path fill="black" d="M9.5 16.3L4.9 11.7l1.6-1.6 3 3 7.1-7.1 1.6 1.6z"/> \
      </svg>') center/16px 16px no-repeat;
}

/* Typografie-Feinschliff */
.checklist li{
  font-weight:700; letter-spacing:.01em;
}
.checklist li em{ font-style:normal; color:var(--accent) } /* falls du einzelne Wörter <em> markierst */

/* kleine „Tag“-Pillen automatisch für CSV/PDF etc. (optional, ohne HTML-Änderung) */
.checklist li:has(:not(.tag)) {
  /* nichts – nur Selektor-Vorbereitung */
}
.checklist li::after{
  /* Erkennbare Kürzel hervorheben, wenn im Text vorkommend */
  content: attr(data-tags);
  display: none;
}
	  
	  /* Footer: Links auf Mobil untereinander */
@media (max-width: 640px){
  .foot{
    display: flex;
    flex-direction: column;      /* Text und Links untereinander */
    gap: 10px;
    align-items: flex-start;     /* linksbündig; nimm 'center' für zentriert */
  }
  .foot__links{
    display: flex;
    flex-direction: column;      /* Links stapeln */
    gap: 6px;
    width: 100%;
  }
  .foot__links a{
    display: block;              /* ganze Zeile klickbar */
    padding: 8px 0;
  }
}

	  /* ===== Brand Lighting (Halo + Glow + Ring) ===== */

/* Basis: Positionierungs-Context für Halo-Layer */
.brand{ position: relative; isolation: isolate; }

/* Präziser, satter Glow direkt am SVG-Logo */
.brand--lit .logo-cut{
  position: relative; z-index: 2;
  /* überschreibt den Standard-Filter aus .logo-cut */
  filter:
    drop-shadow(0 2px 10px rgba(0,0,0,.45))
    drop-shadow(0 0 18px color-mix(in srgb, var(--accent) 40%, transparent))
    drop-shadow(0 0 28px color-mix(in srgb, var(--accent-2) 36%, transparent));
  transition: filter .25s ease;
}

/* Weicher Halo hinter dem Logo (hellt die Fläche subtil auf) */
.brand--lit::before{
  content:"";
  position:absolute; inset:-10px;
  z-index: 1; border-radius: 16px;
  background:
    radial-gradient(120% 120% at 48% 45%,
      color-mix(in srgb, var(--accent) 16%, transparent) 0%,
      color-mix(in srgb, var(--accent-2) 10%, transparent) 40%,
      transparent 70%);
  filter: blur(10px) saturate(120%);
  opacity: .9; pointer-events: none;
}

/* Eleganter, ganz leichter Licht-Ring um das Logo */
.brand--lit::after{
  content:"";
  position:absolute; inset:-4px;
  z-index: 0;
  background:
    conic-gradient(from 0deg,
      color-mix(in srgb, var(--accent) 60%, transparent),
      color-mix(in srgb, var(--accent-2) 60%, transparent),
      color-mix(in srgb, var(--accent) 60%, transparent));
  /* innen freistellen -> nur Ring sichtbar */
  -webkit-mask: radial-gradient(closest-side, transparent 62%, #000 64%);
          mask: radial-gradient(closest-side, transparent 62%, #000 64%);
  opacity:.45; filter: blur(8px);
  animation: brandRingSpin 16s linear infinite;
  pointer-events: none;
}

/* dezente Interaktion */
.brand--lit:hover .logo-cut{
  filter:
    drop-shadow(0 2px 10px rgba(0,0,0,.45))
    drop-shadow(0 0 22px color-mix(in srgb, var(--accent) 52%, transparent))
    drop-shadow(0 0 34px color-mix(in srgb, var(--accent-2) 48%, transparent));
}
.brand--lit:hover::after{ opacity:.58; }

@media (prefers-reduced-motion: reduce){
  .brand--lit::after{ animation: none; }
}
@keyframes brandRingSpin { to { transform: rotate(360deg); } }

/* Optional: mini-Spot unter dem Brand im sehr dunklen Header */
.nav .brand.brand--lit{
  --spot: color-mix(in srgb, var(--accent) 6%, transparent);
  background: radial-gradient(120px 60px at 50% 50%, var(--spot), transparent 70%);
  border-radius: 14px;
}

	  
	  /* ===== 25Desk Payments – eleganter Checkout ===== */
.hero--compact{ padding:72px 0 28px }

.notice{
  display:flex; gap:16px; align-items:center; justify-content:space-between;
  background:linear-gradient(180deg, var(--panel), var(--panel-2));
  border:1px solid var(--border); border-radius:var(--radius); padding:14px 16px;
}
.notice__email label{ display:block; font-weight:800; color:var(--muted) }
.notice__email input{
  display:block; margin-top:8px; width:280px; max-width:90vw;
  background:#0f1830; color:var(--text); border:1px solid var(--border);
  border-radius:12px; padding:10px 12px; outline:none;
}
.notice__email input:focus{ box-shadow:0 0 0 4px var(--ring); border-color:transparent }

.pricing-section{ padding-top: 32px }
.payments-grid .card{ position:relative }
.payments-grid .card.popular{ outline:2px solid var(--accent); box-shadow:0 0 0 6px rgba(34,211,238,.08) inset }

.qty-panel{
  display:flex; align-items:center; gap:10px; margin:10px 0 18px;
  background:rgba(255,255,255,.03); border:1px solid var(--border); border-radius:12px; padding:10px;
}
.qty-panel input{
  width:100px; border-radius:10px; border:1px solid var(--border);
  background:#0c1730; color:var(--text); padding:8px 10px; outline:none;
}
.qty-panel input:focus{ box-shadow:0 0 0 3px var(--ring); border-color:transparent }

.pay-legal{ margin-top:12px }

.btn.disabled, .btn:disabled{ opacity:.6; cursor:not-allowed; transform:none !important }

@media (max-width:960px){
  .notice{ flex-direction:column; align-items:stretch; gap:10px }
  .notice__email input{ width:100% }
}
