:root{
  --bg:#ffffff; --ink:#111214; --muted:#6c7080; --grid:#eceef4;
  --accent:#ff2d7a; /* light: pink */ --accent-ink:#ffffff;
  --col:96px; --gut:16px; --maxw:calc(var(--col)*10 + var(--gut)*9);
  --pad-card:24px; --radius:14px; --shadow:0 14px 30px rgba(0,0,0,.12);
  --ease:cubic-bezier(.22,.61,.36,1);
}
html[data-theme="dark"]{
  --bg:#0b0c0f; --ink:#eef1f7; --muted:#9aa2b6; --grid:#1a1e2a;
  --accent:#00ef86; /* dark: giftgrün */ --accent-ink:#0b0c0f;
}

/* Base */
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--ink);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;line-height:1.5}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}
hr{border:0;border-top:1px solid var(--grid);margin:0}

/* Topbar (Landing-Referenz) */
.topbar{position:sticky;top:0;z-index:100;background:var(--bg)}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.brand{font-weight:800;letter-spacing:.2px}
.nav{display:flex;gap:18px}
.nav a{position:relative;opacity:.86;transition:opacity .15s;font:inherit}
.nav a:hover{opacity:1}
.toolbar{display:flex;gap:8px;align-items:center}
.smallbtn{
  font:inherit; padding:7px 11px; border:1px solid var(--grid);
  border-radius:10px; background:var(--bg); color:var(--ink); cursor:pointer;
  transition: transform .15s, box-shadow .15s, background .15s, color .15s;
  box-shadow: 0 3px 10px rgba(0,0,0,.04);
}
.smallbtn:hover{ transform: translateY(-1px); box-shadow: 0 6px 20px rgba(0,0,0,.06); }
.smallbtn:active{ transform: translateY(0); }
.smallbtn--nextDark{ color:#111; }

/* Aktiver Tab: Pill-Outline OHNE Füllung, Text immer lesbar */
.nav a.active{
  padding:6px 12px; border:2px solid var(--accent); border-radius:999px;
  background:transparent !important; color:var(--ink) !important; opacity:1;
}
/* evtl. alte animierte pseudo-Elemente neutralisieren */
.nav a.active::before{ content:none !important; }

/* Buttons */
.btn{
  display:inline-block; padding:12px 16px; border-radius:12px;
  border:1px solid var(--grid); background:var(--bg); color:var(--ink);
  cursor:pointer; box-shadow: var(--shadow);
  transition:.15s transform, .15s box-shadow, .15s background, .15s color;
}
.btn:hover{ transform: translateY(-1px); box-shadow: 0 18px 36px rgba(0,0,0,.16); }
.btn.primary{ background: var(--ink); color: var(--bg); border-color: var(--ink); }
.btn--accent{ background: var(--accent); color: var(--accent-ink); border-color: rgba(0,0,0,.06); }
.btn--ghost { background: var(--bg); color: var(--ink); border:1px solid var(--grid); }
.btn:focus,.smallbtn:focus{outline:2px dashed var(--grid);outline-offset:2px}

/* Hero */
.hero{position:relative;min-height:80svh;display:grid;align-content:center}
.grid-lines{
  position:absolute; inset:0; pointer-events:none;
  background-image:linear-gradient(to right,#eef0f5 1px,transparent 1px),linear-gradient(to bottom,#f3f4f7 1px,transparent 1px);
  background-size:var(--col) 100%,100% 8px;opacity:.7; z-index:0;
}
.hero > *:not(.grid-lines){ position:relative; z-index:1; }
html[data-theme="dark"] .grid-lines{
  background-image:linear-gradient(to right, rgba(255,255,255,.06) 1px, transparent 1px),
                   linear-gradient(to bottom, rgba(255,255,255,.05) 1px, transparent 1px);
}
.logo-block{display:inline-block;padding:10px 14px 8px;border:1px solid var(--grid);border-radius:12px;background:var(--bg)}
.logo-svg{display:block;width:min(72vw,920px);height:auto}
.h1{font-family:"Space Grotesk",system-ui,sans-serif;font-weight:800;letter-spacing:-.01em;line-height:.94;font-size:clamp(36px,7.6vw,96px);margin:12px 0 6px}
.claim{color:var(--muted);max-width:calc(var(--col)*7 + var(--gut)*6)}
.row{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}

/* Page scaffolding */
main.page{padding:44px 0}
h1.page-title{font-family:"Space Grotesk",system-ui,sans-serif;font-weight:800;letter-spacing:-.01em;font-size:clamp(28px,5.6vw,68px);margin:12px 0}
.sub{color:var(--muted);max-width:calc(var(--col)*7 + var(--gut)*6)}

/* Grid & Card */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--gut)}
.card{
  grid-column:span 4; border:1px solid var(--grid); border-radius:var(--radius);
  padding:var(--pad-card); background:var(--bg); box-shadow: var(--shadow);
  transition:transform .15s, box-shadow .15s, background .15s;
}
.card:hover{ transform: translateY(-2px); box-shadow: 0 22px 44px rgba(0,0,0,.16); }
.card .meta{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px}
.card .title{font-weight:700}
.card .kicker{font-size:.95rem;color:var(--muted)}
.card .badge{
  font-size:.86rem;border:1px solid var(--grid);padding:3px 8px;border-radius:999px;
  background: color-mix(in oklab, var(--accent) 12%, transparent);
}
@media (max-width:960px){ .card{grid-column:span 12} }

/* Stacks */
.stack{aspect-ratio:4/3;border-radius:12px;overflow:hidden;background:#0001}
.stack img{width:100%;height:100%;object-fit:cover;transition: transform .25s var(--ease); }
.stack:hover img{ transform: scale(1.03); }

/* Footer */
.footer{border-top:1px solid var(--grid);padding:16px 0;color:#333;margin-top:28px}
html[data-theme="dark"] .footer{color:#9aa2b6}

/* About */
.about-hero{display:grid;place-items:center;padding:12px;border:1px solid var(--grid);border-radius:12px;background:var(--bg);animation:aboutIn .8s var(--ease) both}
.about-hero img{width:min(520px, 90%);border-radius:12px;display:block}
@keyframes aboutIn{0%{transform:translateY(12px) scale(.98);opacity:0}60%{transform:translateY(-2px) scale(1.005);opacity:1}100%{transform:none}}

/* Cart link + badge (Akzent) */
.cartlink{
  position:relative; display:inline-grid; place-items:center; width:40px; height:36px;
  border:1px solid var(--grid); border-radius:10px; background:var(--bg); color:var(--ink);
  box-shadow: 0 6px 16px rgba(0,0,0,.06); transition: transform .15s, box-shadow .15s;
}
.cartlink:hover{ transform: translateY(-1px); box-shadow: 0 12px 26px rgba(0,0,0,.1); }
.cart-badge{
  position:absolute; top:-6px; right:-6px; min-width:18px; height:18px; padding:0 4px;
  font-size:12px; line-height:18px; text-align:center;
  background: var(--accent); color: var(--accent-ink); border-radius:999px; border:2px solid var(--bg);
}

/* Buy page quick helpers */
.buy-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px}
.buy-card{border:1px solid var(--grid);border-radius:var(--radius);padding:var(--pad-card);background:var(--bg);box-shadow:var(--shadow)}
.buy-title{font-weight:700;margin:0 0 2px}
.buy-muted{color:var(--muted);font-size:.95rem;margin-bottom:10px}
.buy-line{display:flex;align-items:center;gap:8px;margin:8px 0}
.buy-line select,.buy-line input{font:inherit;padding:6px 8px;border:1px solid var(--grid);border-radius:8px;background:var(--bg);color:var(--ink)}
.buy-actions{display:flex;gap:8px;margin-top:8px}
.buy-actions .btn{padding:10px 12px}
#buyImage img{border-radius:var(--radius)}
@media (max-width:900px){ .buy-grid{grid-template-columns:1fr} }
.cart-line{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-top:1px dashed var(--grid)}
.cart-line:first-child{border-top:0}
.mini-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--grid);border-radius:8px;background:var(--bg);color:var(--ink);cursor:pointer}
.mini-muted{color:var(--muted);font-size:.92rem}

/* === Cart-Badge: Zahl perfekt mittig === */
.cartlink .cart-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height: 1;           /* keine Zeilenhöhe-Verzerrung */
  min-width: 18px;
  height: 18px;
  padding: 0 4px;
}

/* === Theme-Button „Dark/Light“: leuchtet in der Akzentfarbe === */
html[data-theme="light"] #themeToggle,
html[data-theme="dark"]  #themeToggle{
  box-shadow:
    0 0 0 2px color-mix(in oklab, var(--accent) 22%, transparent),
    0 0 24px color-mix(in oklab, var(--accent) 45%, transparent);
  transition: box-shadow .18s ease, transform .12s ease;
}
#themeToggle:hover{
  transform: translateY(-1px);
  box-shadow:
    0 0 0 2px color-mix(in oklab, var(--accent) 28%, transparent),
    0 0 36px color-mix(in oklab, var(--accent) 65%, transparent);
}

/* === Page Transition Layer (configurable; JS steuert transform/dauer/ease) === */
#cmWipe{
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 1000;
  will-change: transform, filter, background;
  /* Startposition – JS setzt je nach Richtung/Modus die Ziel-Transforms */
  transform: translateX(-100%);
  /* Standard-Gradient (JS kann das überschreiben je nach Stil/Tint) */
  background:
    linear-gradient(120deg,
      color-mix(in oklab, var(--accent) 22%, var(--bg)) 0%,
      color-mix(in oklab, var(--accent) 12%, var(--bg)) 35%,
      var(--bg) 100%);
  /* Blur aus Dev steuerbar */
  filter: blur(var(--wipe-blur, 0px));
}

/* Sicherheitsnetz für aktive Nav-Pill (immer Outline, Text lesbar) */
.topbar .nav a.active{
  padding:6px 12px; border:2px solid var(--accent); border-radius:999px;
  background: transparent !important; color: var(--ink) !important; opacity:1;
}
.topbar .nav a.active::before{ content:none !important; }

/* === Mini-Cart Drawer (global) ========================================== */
#cmCartOverlay{position:fixed;inset:0;background:rgba(0,0,0,.4);backdrop-filter:saturate(1.05) blur(2px);opacity:0;pointer-events:none;transition:opacity .18s ease;z-index:9998}
#cmMiniCart{position:fixed;top:0;right:0;bottom:0;width:min(520px,92vw);background:var(--bg);border-left:1px solid var(--grid);box-shadow:0 10px 40px rgba(0,0,0,.35);transform:translateX(100%);transition:transform .22s ease;z-index:9999;display:flex;flex-direction:column}
#cmMiniCart header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border-bottom:1px solid var(--grid)}
#cmMiniCart .cmc-body{padding:12px 14px;overflow:auto;display:flex;flex-direction:column;gap:12px}
#cmMiniCart .cmc-sec{display:flex;flex-direction:column;gap:8px}
#cmMiniCart h3{margin:0}
#cmMiniCart .row{display:grid;grid-template-columns:1fr auto;gap:10px;border:1px solid var(--grid);border-radius:10px;padding:8px;background:var(--bg)}
#cmMiniCart .meta{display:flex;flex-direction:column;gap:4px}
#cmMiniCart .title{font-weight:700}
#cmMiniCart .muted{color:var(--muted);font-size:.9rem}
#cmMiniCart .ops{display:flex;align-items:center;gap:8px}
#cmMiniCart .qtybox{display:inline-flex;border:1px solid var(--grid);border-radius:8px;overflow:hidden}
#cmMiniCart .qtybox button{width:28px;height:28px;border:0;background:var(--bg);color:var(--ink);cursor:pointer}
#cmMiniCart .qtybox input{width:38px;text-align:center;border:0;background:var(--bg);color:var(--ink)}
#cmMiniCart .price{min-width:92px;text-align:right;font-weight:800}
#cmMiniCart .badge{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--grid);border-radius:999px;padding:2px 8px;font-size:.78rem}
#cmMiniCart .b-abo{border-color:#059669;color:#065f46;background:#ecfdf5}
#cmMiniCart .b-addon{border-color:#6366f1;color:#3730a3;background:#eef2ff}
#cmMiniCart .b-print{border-color:#6b7280;color:#374151;background:#f3f4f6}
#cmMiniCart .b-svc{border-color:var(--grid)}
#cmMiniCart .total{display:flex;align-items:center;justify-content:space-between;margin-top:8px;font-weight:800}
#cmMiniCart .empty{color:var(--muted);margin:6px 0}
#cmMiniCart .footer{margin-top:8px;display:flex;gap:8px;justify-content:flex-end}
#cmMiniCart .btn.primary{font-weight:700}

/* sichtbarer Zustand */
.cmCart--open #cmCartOverlay{opacity:1;pointer-events:auto}
.cmCart--open #cmMiniCart{transform:translateX(0)}
@media (prefers-reduced-motion: reduce){
  #cmCartOverlay,#cmMiniCart{transition:none}
}
/* Nav: keine Linienanimation unter dem aktiven Menüpunkt */
.nav a.active::after { content: none !important; }
.nav a.active:hover::after {
  animation: none !important;
  transform: none !important;
}
/* === Hover & Motion – Konsistenz ====================================== */
/* Karten: weicher Lift + GPU Hint */
.sub-card,
.svc-card {
  will-change: transform, box-shadow;
}

/* Gemeinsamer Hover-Lift (Abo & Einmalig) */
.sub-card:hover,
.sub-card:focus-within,
.svc-card:hover,
.svc-card:focus-within {
  transform: translateY(-4px);
  box-shadow: 0 10px 24px rgba(0,0,0,.12);
}

/* Falls die Karte mit mp-reveal reingeblendet wurde:
   Hover muss die laufende Reveal-Animation IMMER überstimmen */
.card.mp-reveal:hover,
.card.mp-reveal:focus-within {
  animation: none !important;         /* Reveal-Anim stoppen */
  opacity: 1 !important;              /* nie „ausblenden“ */
  transform: translateY(-4px) !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.12) !important;
}

/* Demo-Button: identischer weicher Mini-Shift wie andere Buttons */
#ctaDemo.btn {
  transition: transform .18s ease;
}
#ctaDemo.btn:hover {
  transform: translateY(-1px);
}

.svc-card.mp-reveal:hover,
.svc-card.mp-reveal:focus-within { animation: none !important; }

