/* ========== THEME (no JS) ========== */
/* Default Light; respects prefers-color-scheme; Cookie-override via [data-theme] */
:root{
  --bg:#f7f9fd; --panel:#ffffff; --text:#0b1220; --muted:#56607a;
  --pri:#3b7cff; --pri-2:#7ea3ff; --bd:#e3e8f5; --shadow:0 10px 30px rgba(20,40,80,.08);
  --glass:rgba(255,255,255,.7);
}
@media (prefers-color-scheme: dark){
  :root{
    --bg:#0b1220; --panel:#121a2b; --text:#e9eefc; --muted:#a8b2c7;
    --pri:#5b8cff; --pri-2:#82a6ff; --bd:#23304d; --shadow:0 10px 30px rgba(0,0,0,.25);
    --glass:rgba(11,18,32,.55);
  }
}
html[data-theme="light"]{
  --bg:#f7f9fd; --panel:#ffffff; --text:#0b1220; --muted:#56607a;
  --pri:#3b7cff; --pri-2:#7ea3ff; --bd:#e3e8f5; --shadow:0 10px 30px rgba(20,40,80,.08);
  --glass:rgba(255,255,255,.7);
}
html[data-theme="dark"]{
  --bg:#0b1220; --panel:#121a2b; --text:#e9eefc; --muted:#a8b2c7;
  --pri:#5b8cff; --pri-2:#82a6ff; --bd:#23304d; --shadow:0 10px 30px rgba(0,0,0,.25);
  --glass:rgba(11,18,32,.55);
}

/* ========== RESET ========== */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg); color:var(--text);
  transition: background .25s ease, color .25s ease;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}

/* ========== BUTTONS ========== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 16px;border-radius:14px;border:1px solid var(--bd);
  box-shadow:var(--shadow);transition:transform .05s ease, opacity .2s ease, background .2s ease;
}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--pri);border-color:transparent;color:#fff}
.btn.ghost{background:transparent}
.btn.icon{width:42px;height:42px;padding:0;font-size:18px}
.btn.small{padding:6px 10px;border-radius:12px;font-size:.95rem}
.btn.full{width:100%}
.btn.xl{padding:14px 22px;font-size:1.05rem}

/* ========== HEADER ========== */
.nav{
  position:sticky;top:0;z-index:50;
  display:flex;gap:24px;align-items:center;justify-content:space-between;
  padding:14px 24px;background:var(--glass);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--bd);
}
.brand{
  font-weight:800;letter-spacing:.5px;display:flex;align-items:center;gap:10px
}
.logo-emoji{filter:saturate(120%);font-size:1.2rem}
.badge{
  background:var(--pri-2); color:#fff; border-radius:999px; padding:2px 8px;
  font-size:.72rem; margin-left:6px
}
nav{display:flex;gap:16px;align-items:center}
.nav a{opacity:.92;font-weight:600}
.nav a:hover{opacity:1}
.nav-actions{display:flex;align-items:center;gap:10px}

/* ========== LANG DROPDOWN (CSS-only) ========== */
.lang-menu{position:relative}
.lang-menu .lang-list{
  position:absolute; right:0; top:120%;
  display:none; min-width:200px; background:var(--panel);
  border:1px solid var(--bd); border-radius:12px; padding:6px; box-shadow:var(--shadow)
}
.lang-menu:hover .lang-list, .lang-menu:focus-within .lang-list{display:block}
.lang-list a{
  display:block; padding:8px 10px; border-radius:8px; color:var(--text)
}
.lang-list a:hover{background:rgba(127,143,255,.12)}
.lang-list a.active{font-weight:700}

/* ========== LAYOUT ========== */
main{max-width:1100px;margin:0 auto;padding:32px 20px}

/* HERO */
.hero{
  display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center;padding:36px 0
}
.hero h1{font-size:2.2rem;margin:.2rem 0}
.hero .sub{color:var(--muted);margin:8px 0 16px}
.hero .bullets{list-style:none;padding:0;margin:14px 0 0;display:grid;gap:6px;color:var(--muted)}
.hero-shot{
  border:1px solid var(--bd);background:var(--panel);padding:8px;
  border-radius:18px;box-shadow:var(--shadow)
}
.hero-shot img{width:100%;display:block;border-radius:12px}

/* PRICING */
.pricing{padding:24px 0}
.pricing h2{font-size:1.6rem;margin:0 0 16px}
.price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}
.card.price{
  background:var(--panel);border:1px solid var(--bd);border-radius:18px;
  padding:22px;max-width:420px;box-shadow:var(--shadow)
}
.card.price h3{margin:.2rem 0}
.card.price .muted{color:var(--muted);margin:6px 0 12px}
.tagline{display:flex;align-items:flex-end;gap:6px;margin:8px 0 14px}
.price{font-size:2.2rem;font-weight:800}
.per{color:var(--muted);margin-bottom:6px}
.fine{color:var(--muted)}

/* HOW */
.how{padding:24px 0 60px}
.how h2{font-size:1.6rem;margin:0 0 12px}
.steps{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;list-style:none;padding:0;margin:10px 0 18px
}
.steps li{
  background:var(--panel);border:1px solid var(--bd);border-radius:16px;
  padding:12px;text-align:center;box-shadow:var(--shadow)
}
.steps img{width:100%;height:180px;object-fit:cover;border-radius:10px;margin-bottom:8px}
.center{text-align:center}

/* ========== FOOTER (stylish, centered) ========== */
.foot{
  border-top:1px solid var(--bd);
  padding:28px 16px 36px;
  text-align:center;
  display:grid;
  gap:10px;
  color:var(--muted);
}
.foot .links a{
  color:var(--text);
  opacity:.85;
  padding:6px 10px;
  border-radius:10px;
  transition:opacity .2s, background .2s, transform .05s;
}
.foot .links a:hover{
  opacity:1;
  background:rgba(127,143,255,.12);
}
.foot .links a:active{ transform: translateY(1px); }
.foot .dot{ color:var(--muted); opacity:.7; }
.foot .brandline{
  display:inline-flex; align-items:center; gap:8px;
  justify-content:center;
  color:var(--text);
  opacity:.9;
}
.foot .legal{ display:block; margin-top:2px; }
/* Fix: Footer-Links wirklich zentrieren */
.foot .links{
  display:flex;         /* statt inline-flex */
  justify-content:center;
  align-items:center;
  width:100%;
  margin:0 auto;        /* Safety */
  text-align:center;
}
.foot .links a{ text-align:center; }
@media (max-width:520px){
  .foot .links{ flex-wrap:wrap; justify-content:center; }
}
/* ========== RESPONSIVE ========== */
@media (max-width:900px){
  .hero{grid-template-columns:1fr}
  nav{display:none} /* optional: Navigation bei Mobile vereinfachen */
  .steps{grid-template-columns:1fr}
}
@media (max-width:520px){
  .foot .links{ flex-wrap:wrap; gap:8px; }
  .foot .dot{ display:none; }
}
:root{
  /* Light Defaults */
  --bg:#f7f9fd; --panel:#ffffff; --text:#0b1220; --muted:#56607a;
  --pri:#3b7cff; --pri-2:#7ea3ff; --bd:#e3e8f5; --shadow:0 10px 30px rgba(20,40,80,.08);
  --glass:rgba(255,255,255,.7);
}
@media (prefers-color-scheme: dark){
  :root{
    /* Dark Auto (ohne Cookie) */
    --bg:#0b1220; --panel:#121a2b; --text:#e9eefc; --muted:#a8b2c7;
    --pri:#5b8cff; --pri-2:#82a6ff; --bd:#23304d; --shadow:0 10px 30px rgba(0,0,0,.25);
    --glass:rgba(11,18,32,.55);
  }
}


.hero.compact {padding: 32px 0}
.content-grid .card h3 {margin: 0 0 8px}
.kv p {margin: 0 0 8px}
.stack .muted {color: var(--muted)}
.faq-list {margin-top: 8px}


/* Cookie-Override -> html[data-theme="light"|"dark"] */
html[data-theme="light"]{ /* gleiche Werte wie :root (light) */ }
html[data-theme="dark"]{  /* gleiche Werte wie @media dark */   }

.how-it-works .steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;list-style:none;margin:0;padding:0}
.how-it-works figure{background:var(--panel);border:1px solid var(--bd);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);margin:0}
.how-it-works img{display:block;width:100%;height:auto}
.how-it-works figcaption{padding:14px}
.how-it-works h3{margin:0 0 6px;font-size:1.05rem;line-height:1.25}

/* Testimonials */
.testimonials h2 { margin: 0 0 12px; font-size: 1.2rem; }
.testi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
}
.card.quote blockquote { margin: 0 0 8px; line-height: 1.45; }
.card.quote p { margin: 0; }

/* Testimonials */
.testimonials h2 { margin: 0 0 12px; font-size: 1.2rem; }
.testi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
}

/* Speech-bubble cards */
.card.quote.bubble {
  position: relative;
  background: color-mix(in srgb, var(--panel) 88%, #fff 12%);
  border: 1px solid color-mix(in srgb, var(--bd) 70%, #fff 30%);
  border-radius: 16px;
  padding: 16px 16px 18px;
  box-shadow: var(--shadow);
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}

/* bubble tail */
.card.quote.bubble::after {
  content: "";
  position: absolute;
  left: 18px;
  bottom: -8px;
  width: 16px; height: 16px;
  background: inherit;
  border-left: inherit; border-bottom: inherit;
  transform: rotate(45deg);
  box-shadow: 2px 2px 0 rgba(0,0,0,0.02);
}

/* content styling */
.card.quote blockquote { margin: 0 0 8px; line-height: 1.5; }
.card.quote p { margin: 0; font-size: .98rem; }
.card.quote footer { font-size: .85rem; }

/* subtle quote mark */
.card.quote.bubble blockquote p::before {
  content: "“";
  margin-right: 2px;
  opacity: .6;
}
.card.quote.bubble blockquote p::after {
  content: "”";
  margin-left: 2px;
  opacity: .6;
}

/* hover */
.card.quote.bubble:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(0,0,0,.08);
  border-color: color-mix(in srgb, var(--bd) 50%, var(--accent, #6c5ce7) 50%);
}

/* dark mode tweak (if your theme uses data-theme) */
html[data-theme="dark"] .card.quote.bubble {
  background: color-mix(in srgb, var(--panel) 92%, #000 8%);
  border-color: color-mix(in srgb, var(--bd) 80%, #000 20%);
}

/* === SITE GRADIENT (bullet-proof, last in file) ======================= */
/* === FINAL GRADIENT PATCH (must be last) =============================== */
body{ background:transparent !important; }
/* LIGHT */
.site-bg{
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:
    /* Center burst */
    radial-gradient(1000px 600px at 50% 50%, rgba(99,102,241,.32) 0%, rgba(99,102,241,.18) 28%, rgba(99,102,241,0) 60%),
    /* Left push */
    radial-gradient(1000px 600px at 0% 50%, rgba(14,165,233,.26) 12%, rgba(14,165,233,.12) 34%, rgba(14,165,233,0) 62%),
    /* Right push */
    radial-gradient(1000px 600px at 100% 50%, rgba(253,224,71,.22) 12%, rgba(253,224,71,.10) 34%, rgba(253,224,71,0) 62%),
    linear-gradient(#f7f9fd,#f7f9fd) !important;
  background-attachment:fixed; background-repeat:no-repeat; background-size:cover;
}

/* DARK (data-theme) */
html[data-theme="dark"] .site-bg{
  background:
    radial-gradient(1000px 600px at 50% 50%, rgba(59,130,246,.34) 0%, rgba(59,130,246,.20) 28%, rgba(59,130,246,0) 60%),
    radial-gradient(1000px 600px at 0% 50%, rgba(20,184,166,.28) 12%, rgba(20,184,166,.14) 34%, rgba(20,184,166,0) 62%),
    radial-gradient(1000px 600px at 100% 50%, rgba(234,179,8,.22) 12%, rgba(234,179,8,.10) 34%, rgba(234,179,8,0) 62%),
    linear-gradient(#0b1220,#0b1220) !important;
}

/* DARK (System) */
@media (prefers-color-scheme: dark){
  html:not([data-theme]) .site-bg{
    background:
      radial-gradient(1000px 600px at 50% 50%, rgba(59,130,246,.34) 0%, rgba(59,130,246,.20) 28%, rgba(59,130,246,0) 60%),
      radial-gradient(1000px 600px at 0% 50%, rgba(20,184,166,.28) 12%, rgba(20,184,166,.14) 34%, rgba(20,184,166,0) 62%),
      radial-gradient(1000px 600px at 100% 50%, rgba(234,179,8,.22) 12%, rgba(234,179,8,.10) 34%, rgba(234,179,8,0) 62%),
      linear-gradient(#0b1220,#0b1220) !important;
  }
}
/* Scrollbare Sprachliste */
/* === LANGUAGE MENU (scrollable + theming) =============================== */
/* Container */
.lang-menu{ position:relative; }
.lang-menu .lang-list{
  position:absolute; right:0; top:120%;
  display:none; min-width:220px;
  background: var(--panel); /* fallback – wird unten von --lang-bg überschrieben */
  border:1px solid var(--bd); border-radius:12px; padding:6px; box-shadow:var(--shadow);
  /* Scroll */
  max-height: min(60vh, 28rem);
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;

  /* Theme vars (Light default) */
  --lang-bg: #ffffff;
  --lang-fg: #0b1220;
  --lang-hover: rgba(0,0,0,.06);
  --lang-active: #3b82f6;
  --lang-scroll: #c7c7c7;

  background: var(--lang-bg);
  color: var(--lang-fg);
}
.lang-menu:hover .lang-list,
.lang-menu:focus-within .lang-list{ display:block; }

/* Items (explizit inkl. visited, um Browser-Defaults zu brechen) */
.lang-list a,
.lang-list a:link,
.lang-list a:visited{
  display:block;
  padding:8px 10px;
  border-radius:8px;
  text-decoration:none;
  color: var(--lang-fg) !important;   /* überstimmt globale a-Farben */
}
.lang-list a:hover,
.lang-list a:focus-visible{
  background: var(--lang-hover);
  outline: none;
}
.lang-list a.active{
  background: var(--lang-active);
  color:#fff !important;
  font-weight:700;
}

/* dezente Scrollbar */
.lang-list{ scrollbar-width: thin; scrollbar-color: var(--lang-scroll) transparent; }
.lang-list::-webkit-scrollbar{ width:8px; }
.lang-list::-webkit-scrollbar-thumb{ background: var(--lang-scroll); border-radius:8px; }
.lang-list::-webkit-scrollbar-track{ background: transparent; }

/* DARK MODE — System */
@media (prefers-color-scheme: dark){
  /* nur greifen, wenn kein data-theme gesetzt ist */
  html:not([data-theme]) .lang-list{
    --lang-bg: #121a2b;
    --lang-fg: #e9eefc;
    --lang-hover: rgba(255,255,255,.08);
    --lang-active: #5b8cff;
    --lang-scroll: #5b6b7a;
    border-color: rgba(255,255,255,.12);
    box-shadow: 0 10px 30px rgba(0,0,0,.25);
  }
}

/* DARK MODE — Cookie-Override via data-theme */
html[data-theme="dark"] .lang-list{
  --lang-bg: #121a2b;
  --lang-fg: #e9eefc;
  --lang-hover: rgba(255,255,255,.08);
  --lang-active: #5b8cff;
  --lang-scroll: #5b6b7a;
  border-color: rgba(255,255,255,.12);
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
}

/* Notfall: falls eine sehr spezifische Regel a-Farbe überschreibt */
.lang-list.lang-list a{ color: var(--lang-fg) !important; }
