/* ========== 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%);
}
