/* ============================================================================
 * Family Projekt — geteilte Stile (alle Seiten).
 * Tokens/Holo/Glas-Rand aus dem abgenommenen Mockup mockup-startseite-v3.html.
 * Themen (Dunkel/Neon/Hell) werden in app.js per CSS-Variablen auf :root gesetzt.
 * ========================================================================== */
@property --rot { syntax:'<angle>'; inherits:false; initial-value:0deg; }

:root{
  --bg:#0b0d14; --bg2:#11151f; --card:rgba(22,29,42,.55); --line:rgba(255,255,255,.10);
  --text:#eef2f8; --muted:#9aa7b6; --accent:#6ee7d3; --accent2:#a78bfa; --accent3:#7c9cff;
  --gold:#e6b450; --ok:#46d27f;
  --header-bg:rgba(11,13,20,.55);
  --glow:0 0 26px rgba(167,139,250,.30),0 0 60px rgba(110,231,211,.14);
  --shadow:0 12px 34px rgba(0,0,0,.40),0 4px 10px rgba(0,0,0,.25);
  --holo-text:linear-gradient(100deg,#a9f4e6,#cfe0ff,#e6d4ff,#bdeede,#cfe0ff,#a9f4e6);
  --holo-border:conic-gradient(from var(--rot),#7fe9d8,#9fb8ff,#c6a9ff,#7fe9d8,#bdeede,#7fe9d8);
  --sans:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --mono:ui-monospace,"SFMono-Regular",Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--sans);line-height:1.6;overflow-x:hidden;transition:background .35s,color .35s;min-height:100vh}
a{color:var(--accent);text-decoration:none}
.wrap{max-width:1060px;margin:0 auto;padding:0 20px}
.muted{color:var(--muted)}
.center{text-align:center}

/* three.js-Hintergrund (Canvas) + sanfter Farbschleier */
#bg{position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.5}
body::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(60% 50% at 78% 0%,rgba(124,156,255,.14),transparent 60%),radial-gradient(55% 45% at 5% 100%,rgba(110,231,211,.10),transparent 60%)}

@keyframes holo-rot{to{--rot:360deg}}
@keyframes holoflow{to{background-position:300% center}}
@keyframes shimmer{0%{transform:translateX(-160%) skewX(-18deg)}100%{transform:translateX(260%) skewX(-18deg)}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(255,90,138,.5)}50%{box-shadow:0 0 0 8px rgba(255,90,138,0)}}

.holo{background:var(--holo-text);background-size:300% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:holoflow 8s linear infinite;font-weight:900}

/* Kopf */
header{position:sticky;top:0;z-index:30;background:var(--header-bg);backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);border-bottom:1px solid var(--line)}
.bar{display:flex;align-items:center;gap:14px;min-height:60px;flex-wrap:wrap;padding:6px 0}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:1.14rem;color:var(--text)}
.brand .mark{width:30px;height:30px;border-radius:9px;flex-shrink:0;box-shadow:var(--glow)}
nav.top{margin-left:auto;display:flex;gap:6px;flex-wrap:wrap;align-items:center}
/* Ruhezustand wie bisher; beim Hover wird der Link zum Glas-Button
   (gleiche Optik/Neigung/Holo wie „Ansehen"/„Noch eine entdecken"), theme-adaptiv. */
nav.top a{position:relative;overflow:hidden;color:var(--muted);font-size:.9rem;padding:7px 12px;border-radius:10px;
  transform:perspective(420px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));
  transition:transform .14s ease,color .15s,background .2s,box-shadow .2s}
nav.top a::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:
    radial-gradient(86px 52px at var(--mx,50%) var(--my,20%),rgba(255,255,255,.5),transparent 60%),
    linear-gradient(180deg,rgba(255,255,255,.3),rgba(255,255,255,0) 50%),
    linear-gradient(115deg,transparent 26%,color-mix(in srgb,var(--accent3) 60%,transparent) 44%,color-mix(in srgb,var(--accent) 56%,transparent) 52%,color-mix(in srgb,var(--accent2) 60%,transparent) 60%,transparent 76%);
  background-size:auto,auto,240% 100%;background-position:0 0,0 0,var(--mx,50%) 0;
  mix-blend-mode:screen;opacity:0;transition:opacity .2s}
nav.top a>*{position:relative}
nav.top a.active{color:var(--text);background:linear-gradient(180deg,rgba(140,150,170,.14),rgba(18,23,33,.20))}
nav.top a:hover,nav.top a:focus-visible{color:var(--text);
  background:linear-gradient(180deg,rgba(140,150,170,.18),rgba(18,23,33,.26));
  box-shadow:
    inset 0 1.5px 1px rgba(255,255,255,.45),
    inset 0 -3px 5px rgba(0,0,0,.42),
    inset 0 0 0 1px color-mix(in srgb,var(--accent) 60%,transparent),
    0 8px 18px rgba(0,0,0,.4),var(--glow)}
nav.top a:hover::before,nav.top a:focus-visible::before{opacity:1}
.pill{position:relative;overflow:hidden;font-family:var(--mono);font-size:.74rem;color:var(--muted);background:rgba(127,127,127,.10);border:1px solid var(--line);border-radius:999px;padding:6px 11px;cursor:pointer;user-select:none;
  transform:perspective(420px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));
  transition:transform .14s ease,color .15s,border-color .15s,box-shadow .2s;
  box-shadow:inset 0 1.5px 1px rgba(255,255,255,.35),inset 0 -2px 4px rgba(0,0,0,.4),inset 0 0 0 1px rgba(255,255,255,.06)}
.pill::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(70px 48px at var(--mx,50%) var(--my,18%),rgba(255,255,255,.5),transparent 60%),linear-gradient(180deg,rgba(255,255,255,.25),transparent 52%);
  mix-blend-mode:screen;opacity:.4;transition:opacity .2s}
.pill>*{position:relative}
.pill:hover{color:var(--text);border-color:var(--accent);box-shadow:inset 0 1.5px 1px rgba(255,255,255,.4),inset 0 -2px 4px rgba(0,0,0,.45),var(--glow)}
.pill:hover::before{opacity:.9}

/* Kopf-Status (SBKIM-Lampen + Siegel-Badge) */
.status{display:inline-flex;align-items:center;gap:9px;margin-left:4px}
.lamp{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:.68rem;color:var(--muted);cursor:default}
.lamp .dot{width:9px;height:9px;border-radius:50%;background:#444;box-shadow:0 0 0 0 transparent;transition:.3s}
.lamp.on .dot{background:var(--ok);box-shadow:0 0 8px rgba(70,210,127,.7)}
.lamp.warn .dot{background:#ff5a8a;box-shadow:0 0 8px rgba(255,90,138,.7);animation:pulse 1.1s ease-in-out infinite}
#sbkim-siegel-badge{cursor:pointer}

/* Dock-Zone in der Navleiste + andockbares Status-Widget (Modul 17 ersetzt) */
.fp-dock{display:inline-flex;align-items:center;min-height:34px}
.fp-sw .fp-sw-slots{display:inline-flex;align-items:center;gap:9px}
.fp-sw-lamp{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:.68rem;color:var(--muted);white-space:nowrap;user-select:none}
.fp-sw-lamp .dot{width:9px;height:9px;border-radius:50%;background:#444;transition:.3s}
.fp-sw-lamp.on .dot{background:var(--ok);box-shadow:0 0 8px rgba(70,210,127,.7)}
.fp-sw-lamp.warn .dot{background:#ff5a8a;box-shadow:0 0 8px rgba(255,90,138,.7);animation:pulse 1.1s ease-in-out infinite}
.fp-sw-lamp[data-slot="siegel"]{cursor:pointer}
/* Docked: kompakt, greifbar — waagerechte Lampen-Leiste */
.fp-sw.docked{display:inline-flex;align-items:center;cursor:grab;padding:4px 8px;border:1px dashed transparent;border-radius:9px;touch-action:none}
.fp-sw.docked:hover{border-color:var(--line)}
/* Floating: GLEICHE waagerechte Form, nur frei schwebend + kleines ✕.
   KEINE Hochkant-/Quadrat-Form, kein „Status"-Text (Klaus 2026-06-27). */
.fp-sw.floating{position:fixed;z-index:60;display:inline-flex;flex-direction:row;align-items:center;gap:9px;cursor:grab;touch-action:none;
  background:var(--card);border:1px solid var(--line);border-radius:999px;
  backdrop-filter:blur(12px) saturate(1.2);-webkit-backdrop-filter:blur(12px) saturate(1.2);box-shadow:var(--shadow);padding:7px 13px}
.fp-sw-x{display:none;width:20px;height:20px;flex-shrink:0;border-radius:50%;border:1px solid var(--line);background:rgba(127,127,127,.14);color:var(--text);cursor:pointer;font-size:.7rem;line-height:1;align-items:center;justify-content:center;padding:0}
.fp-sw-x:hover{border-color:#ff5a8a;color:#ff8585}
.fp-sw.floating .fp-sw-x{display:flex}
.fp-sw.dragging{opacity:.92;cursor:grabbing}
.fp-sw-restore{font-family:var(--mono);font-size:.7rem;color:var(--muted);background:rgba(127,127,127,.10);border:1px solid var(--line);border-radius:999px;padding:6px 11px;cursor:pointer}
.fp-sw-restore:hover{color:var(--text);border-color:var(--accent);box-shadow:var(--glow)}
header.fp-dock-hot .fp-dock{box-shadow:0 0 0 2px var(--accent) inset;border-radius:9px}

/* Glas-Cabochon-Buttons: geschliffene Kante (inset-Schatten) + maus-folgender
   holografischer Schimmer in Theme-Farben (var(--mx)/var(--my) aus app.js). */
.btn{position:relative;display:inline-flex;align-items:center;gap:8px;font-weight:700;border-radius:14px;padding:13px 22px;font-size:.96rem;cursor:pointer;border:1px solid transparent;overflow:hidden;text-decoration:none;font-family:var(--sans);line-height:1.2;
  transform:perspective(640px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));
  transform-style:preserve-3d;transition:transform .14s ease,box-shadow .2s ease;
  box-shadow:
    inset 0 2px 1px rgba(255,255,255,.7),         /* heller Schliff oben */
    inset 0 -5px 9px rgba(0,0,0,.52),             /* tiefe Wölbung unten */
    inset 11px 0 17px rgba(255,255,255,.07),
    inset -11px 0 19px rgba(0,0,0,.42),
    inset 0 0 0 1px rgba(255,255,255,.12),        /* scharfe Schliffkante */
    0 14px 30px rgba(0,0,0,.48),0 4px 8px rgba(0,0,0,.36)}
.btn::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:
    radial-gradient(108px 76px at var(--mx,50%) var(--my,24%),rgba(255,255,255,.72),transparent 56%),
    linear-gradient(180deg,rgba(255,255,255,.36),rgba(255,255,255,0) 46%),
    linear-gradient(115deg,transparent 26%,color-mix(in srgb,var(--accent3) 62%,transparent) 43%,color-mix(in srgb,var(--accent) 58%,transparent) 51%,color-mix(in srgb,var(--accent2) 62%,transparent) 60%,transparent 76%);
  background-size:auto,auto,240% 100%;
  background-position:0 0,0 0,var(--mx,50%) 0;
  mix-blend-mode:screen;opacity:.45;transition:opacity .22s}
/* zweite Schliffkanten-Brechung: heller Rand, der sich mit der Neigung verschiebt */
.btn::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(60% 140% at var(--mx,50%) -10%,rgba(255,255,255,.5),transparent 40%);
  mix-blend-mode:screen;opacity:0;transition:opacity .22s}
.btn:hover::before,.btn:focus-visible::before{opacity:1}
.btn:hover::after,.btn:focus-visible::after{opacity:.85}
.btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent3) 60%,var(--accent2));color:#08121a}
.btn.primary:hover{box-shadow:inset 0 2px 1px rgba(255,255,255,.75),inset 0 -5px 9px rgba(0,0,0,.5),inset 0 0 0 1px rgba(255,255,255,.16),0 16px 32px rgba(0,0,0,.5),var(--glow)}
.btn.ghost{background:linear-gradient(180deg,rgba(140,150,170,.16),rgba(18,23,33,.24));border:1px solid var(--line);color:var(--text)}
.btn.ghost:hover{border-color:var(--accent);box-shadow:inset 0 2px 1px rgba(255,255,255,.5),inset 0 -5px 9px rgba(0,0,0,.5),0 16px 32px rgba(0,0,0,.5),var(--glow)}
.btn.gold{background:linear-gradient(135deg,var(--gold),#caa33f);color:#1a1405}
/* schmale, flache Glas-Buttons (Footer-Schnell-Links) — gleiche Effekte, kleiner */
.btn.slim{padding:6px 13px;font-size:.78rem;font-weight:600;border-radius:10px;gap:5px;
  box-shadow:inset 0 1.5px .5px rgba(255,255,255,.5),inset 0 -2px 4px rgba(0,0,0,.4),inset 0 0 0 1px rgba(255,255,255,.08),0 5px 14px rgba(0,0,0,.34)}
.btn.slim:hover{box-shadow:inset 0 1.5px .5px rgba(255,255,255,.5),inset 0 -2px 4px rgba(0,0,0,.42),inset 0 0 0 1px color-mix(in srgb,var(--accent) 50%,transparent),0 6px 16px rgba(0,0,0,.4),var(--glow)}
.applinks{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:16px}
.applinks .lbl{font-family:var(--mono);font-size:.72rem;color:var(--muted);margin-right:2px}
.btn[disabled]{opacity:.55;cursor:not-allowed}
@media (prefers-reduced-motion: reduce){
  .btn,.pill,.mic,.area,.disc-shot,.doodle,.listing,nav.top a{transition:none}
  .btn{transform:none}
  .pill,nav.top a{transform:none}
  .mic{transform:translateY(-50%)}
  .area,.listing{transform:translateY(var(--lift,0px))}
  .disc-shot{transform:none}
  .doodle .title{transform:none}
}

/* Eingabe + Mikrofon (überall, wo Text geschrieben wird) */
.field{position:relative;display:flex;align-items:center}
.field input,.field textarea{width:100%;background:rgba(127,127,127,.10);border:1px solid var(--line);color:var(--text);border-radius:12px;padding:13px 50px 13px 15px;font-size:1rem;font-family:var(--sans)}
.field textarea{resize:vertical;min-height:96px;line-height:1.5}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:var(--glow)}
.mic{position:absolute;right:7px;top:50%;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:rgba(127,127,127,.10);color:var(--accent);font-size:1.05rem;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;
  transform:translateY(-50%) perspective(280px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));
  transition:transform .14s ease,border-color .15s,box-shadow .15s;
  box-shadow:inset 0 1.5px 1px rgba(255,255,255,.4),inset 0 -2px 4px rgba(0,0,0,.42),inset 0 0 0 1px rgba(255,255,255,.07)}
.mic::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(40px 30px at var(--mx,50%) var(--my,20%),rgba(255,255,255,.55),transparent 62%),linear-gradient(180deg,rgba(255,255,255,.3),transparent 55%);
  mix-blend-mode:screen;opacity:.5;transition:opacity .2s}
.mic:hover::before{opacity:1}
.mic:hover{border-color:var(--accent);box-shadow:var(--glow)}
.mic.live{color:#fff;background:linear-gradient(135deg,#ff5a8a,#a06bff);border-color:transparent;animation:pulse 1.1s ease-in-out infinite}

section{padding:32px 0}
h1{font-size:clamp(1.9rem,5vw,2.9rem);line-height:1.12;margin:0 0 14px}
h2{font-size:1.55rem;margin:0 0 6px}
.sub{color:var(--muted);margin:0 0 22px;max-width:62ch}
.lead{color:var(--muted);max-width:62ch;font-size:1.06rem}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);border:1px solid var(--line);border-radius:999px;padding:5px 12px;margin-bottom:18px}

/* Glas-Karten: Leucht-Rand läuft UM den ganzen Container */
.glass{position:relative;background:var(--card);border:1px solid transparent;border-radius:16px;
  backdrop-filter:blur(14px) saturate(1.2);-webkit-backdrop-filter:blur(14px) saturate(1.2);box-shadow:var(--shadow)}
.glass::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1.4px;
  background:var(--holo-border);animation:holo-rot 16s linear infinite;
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;opacity:.5;transition:opacity .2s}
.glass:hover::before{opacity:1}

/* Startseite — Bild des Tages */
.hero{padding:46px 0 8px}
.doodle{position:relative;border-radius:22px;padding:2px;background:var(--holo-border);animation:holo-rot 14s linear infinite;box-shadow:var(--shadow),var(--glow)}
.doodle .inner{border-radius:20px;background:linear-gradient(180deg,rgba(17,21,31,.92),rgba(11,13,20,.96));overflow:hidden}
/* Pad: Bild liegt vollflächig; Verhältnis passt sich per JS dem Bild an. */
.doodle .pad{position:relative;aspect-ratio:16/5;
  background:radial-gradient(700px 240px at 80% -30%,rgba(124,156,255,.18),transparent 60%),radial-gradient(520px 200px at 4% 130%,rgba(110,231,211,.14),transparent 60%)}
.doodle .pad img.tagesimg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:0}
.doodle .pad .fp-dust{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1}
/* Schriftzug oben mittig ÜBER dem Bild, wackelt wie die Buttons (eigene Neigung). */
.doodle .title{position:absolute;top:0;left:0;right:0;text-align:center;padding-top:clamp(10px,2.4vw,22px);z-index:2;
  font-size:clamp(1.7rem,4.6vw,2.7rem);text-shadow:0 2px 14px rgba(0,0,0,.55);
  opacity:.76;                                  /* leicht transparent → Hintergrund schimmert durch */
  transform:perspective(700px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));transform-origin:top center;
  transition:transform .28s cubic-bezier(.22,.61,.36,1);   /* sanftes Wegkippen statt Ruck */
  will-change:transform;backface-visibility:hidden;-webkit-backface-visibility:hidden}
.doodle .ph{position:absolute;left:50%;top:56%;transform:translateX(-50%);z-index:2;font-family:var(--mono);font-size:.78rem;color:var(--muted);border:1px dashed var(--line);border-radius:8px;padding:6px 12px;background:rgba(0,0,0,.25)}
.lead.hero-lead{margin:20px auto 0;text-align:center}

.searchrow{margin:22px auto 0;max-width:680px;display:flex;gap:10px}
.searchrow .field{flex:1}

/* Weekly Discovery */
.discover{padding:22px}
.disc-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.disc-head .ey{display:inline-flex;align-items:center;gap:8px;font-size:.76rem;letter-spacing:.07em;text-transform:uppercase;color:var(--accent);border:1px solid var(--line);border-radius:999px;padding:6px 12px}
.disc-card{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.disc-shot{width:188px;height:118px;flex-shrink:0;border-radius:12px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:2.1rem;overflow:hidden;
  background:radial-gradient(120px 80px at 30% 20%,rgba(124,156,255,.22),transparent),linear-gradient(180deg,rgba(127,127,127,.10),rgba(0,0,0,.12));transition:.25s}
.disc-shot img{width:100%;height:100%;object-fit:cover}
.disc-shot{transform:perspective(800px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg))}
.disc-shot.flash{box-shadow:var(--glow);transform:perspective(800px) scale(1.02)}
.disc-info{flex:1;min-width:200px}
.disc-info h3{margin:0 0 4px;font-size:1.25rem}
.disc-info p{margin:0 0 12px;color:var(--muted)}
.disc-fair{font-size:.8rem;color:var(--muted);margin-top:14px}

/* Drei Bereiche / Karten-Raster */
.areas{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}
.area{padding:18px;display:block;color:inherit;
  transform:perspective(1000px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(var(--lift,0px));
  transition:transform .18s ease,box-shadow .18s}
.area:hover{--lift:-3px;box-shadow:var(--shadow),var(--glow)}
.area::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(240px 180px at var(--mx,50%) var(--my,50%),rgba(255,255,255,.15),transparent 60%);
  opacity:0;transition:opacity .25s;mix-blend-mode:screen}
.area:hover::after{opacity:1}
.area .ico{font-size:1.7rem}
.area h3{margin:10px 0 4px;font-size:1.15rem}
.area p{margin:0;color:var(--muted);font-size:.93rem}
.area .go{display:inline-block;margin-top:12px;color:var(--accent);font-family:var(--mono);font-size:.86rem}

/* Werkzeug-Landingpage */
.back{color:var(--muted);font-size:.85rem}
.cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:4px}
.microcopy{margin-top:14px;font-size:.85rem;color:var(--muted)}
.feat{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px}
.f{padding:20px}
.f .ico{font-size:1.5rem;margin-bottom:8px}
.f h3{margin:0 0 6px;font-size:1.06rem}
.f p{margin:0;color:var(--muted);font-size:.93rem}
.price{padding:28px;display:flex;gap:24px;flex-wrap:wrap;align-items:center;justify-content:space-between}
.price .big{font-size:1.9rem;font-weight:800}
.price .big small{font-size:.95rem;font-weight:500;color:var(--muted)}
.price .note{color:var(--muted);font-size:.9rem;max-width:42ch}
.trust{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.t{display:flex;gap:11px;align-items:flex-start;font-size:.92rem;color:var(--muted)}
.t .d{color:var(--ok);font-size:1.1rem;flex-shrink:0}
.t b{color:var(--text)}
.badge-soon{font-family:var(--mono);font-size:.7rem;color:var(--gold);border:1px solid var(--gold);border-radius:5px;padding:1px 7px;margin-left:8px}

/* Screenshot-Galerie */
.shot{margin:24px 0 0;border:1px solid var(--line);border-radius:16px;background:linear-gradient(180deg,var(--bg2),var(--bg));overflow:hidden}
.shot-top{display:flex;gap:7px;padding:12px 14px;border-bottom:1px solid var(--line)}
.shot-top i{width:11px;height:11px;border-radius:50%;background:var(--line);display:inline-block}
.shot-body{aspect-ratio:16/8;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;color:var(--muted);background:repeating-linear-gradient(45deg,rgba(255,255,255,.012) 0 12px,transparent 12px 24px)}
.shot-body img{width:100%;height:100%;object-fit:contain}
.shot-body .ph{font-family:var(--mono);font-size:.82rem;border:1px dashed var(--line);border-radius:8px;padding:8px 14px}
.shot-body .bubble{width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-size:1.5rem}
.thumbs{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.thumb,.addthumb{position:relative;width:88px;height:56px;border-radius:9px;border:1px solid var(--line);background:linear-gradient(180deg,var(--bg2),var(--card));color:var(--muted);font-family:var(--mono);font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb.active{border-color:var(--accent);color:var(--text);box-shadow:0 0 0 1px var(--accent) inset}
.thumb .x{position:absolute;top:-7px;right:-7px;width:19px;height:19px;border-radius:50%;background:var(--card);border:1px solid var(--line);font-size:.72rem;display:flex;align-items:center;justify-content:center;z-index:2}
.thumb .x:hover{color:#ff8585;border-color:#ff8585}
.addthumb{border-style:dashed;font-size:1.25rem;color:var(--accent)}
.galnote{color:var(--muted);font-size:.82rem;margin:12px 0 0}

/* Netzwerk-Raum — dreistufiges Versprechen */
.stages{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-top:8px}
.stage{padding:20px}
.stage .n{font-family:var(--mono);font-size:.78rem;color:var(--accent);border:1px solid var(--line);border-radius:999px;padding:3px 10px;display:inline-block;margin-bottom:10px}
.stage h3{margin:0 0 6px;font-size:1.08rem}
.stage p{margin:0;color:var(--muted);font-size:.93rem}
.note-box{padding:18px;margin-top:18px;font-size:.92rem;color:var(--muted)}
.note-box b{color:var(--text)}
.prep{display:inline-block;font-family:var(--mono);font-size:.7rem;color:var(--gold);border:1px solid var(--gold);border-radius:5px;padding:1px 7px;margin-left:6px;text-transform:uppercase;letter-spacing:.04em}

/* Marktplatz — Listing-Karten + Formular */
.listings{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-top:8px}
.listing{padding:0;overflow:hidden;display:flex;flex-direction:column;
  transform:perspective(1000px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(var(--lift,0px));
  transition:transform .18s ease,box-shadow .18s}
.listing:hover{--lift:-3px;box-shadow:var(--shadow),var(--glow)}
.listing::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(260px 200px at var(--mx,50%) var(--my,50%),rgba(255,255,255,.13),transparent 60%);
  opacity:0;transition:opacity .25s;mix-blend-mode:screen;z-index:1}
.listing:hover::after{opacity:1}
.listing .img{aspect-ratio:16/9;background:linear-gradient(180deg,var(--bg2),var(--bg));display:flex;align-items:center;justify-content:center;overflow:hidden;border-bottom:1px solid var(--line)}
.listing .img img{width:100%;height:100%;object-fit:cover}
.listing .body{padding:14px 16px 16px}
.listing h3{margin:0 0 4px;font-size:1.08rem}
.listing .by{font-family:var(--mono);font-size:.74rem;color:var(--accent);margin:0 0 8px}
.listing p{margin:0 0 12px;color:var(--muted);font-size:.9rem}
.listing .ext{font-family:var(--mono);font-size:.82rem}
.form-grid{display:grid;gap:14px;max-width:560px}
.form-grid label{font-size:.86rem;color:var(--muted);display:block;margin-bottom:6px}
.haftung{padding:16px;margin-top:18px;font-size:.86rem;color:var(--muted);border-left:3px solid var(--gold)}

/* Andock-Wizard (Modul 19) — eingebettet im Netzwerk-Raum */
#andockWizard{padding:20px}
.sbkim-aw-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:14px}
.sbkim-aw-grid label{display:block;font-size:.86rem;color:var(--muted)}
.sbkim-aw-grid input,.sbkim-aw-grid select{width:100%;margin-top:6px;background:rgba(127,127,127,.10);border:1px solid var(--line);color:var(--text);border-radius:10px;padding:11px 13px;font-size:.95rem;font-family:var(--sans)}
.sbkim-aw-grid input:focus,.sbkim-aw-grid select:focus{outline:none;border-color:var(--accent);box-shadow:var(--glow)}
#andockWizard button#sbkim-aw-go{display:inline-flex;align-items:center;gap:8px;font-weight:700;border-radius:12px;padding:11px 18px;font-size:.94rem;cursor:pointer;border:1px solid transparent;background:linear-gradient(135deg,var(--accent),var(--accent3) 60%,var(--accent2));color:#08121a;box-shadow:var(--shadow)}
#andockWizard #sbkim-aw-status{margin-left:12px;font-size:.88rem;color:var(--muted)}
#andockWizard #sbkim-aw-out{margin-top:16px}
#andockWizard #sbkim-aw-out h4{margin:14px 0 6px;font-size:.95rem}
#andockWizard pre{background:rgba(0,0,0,.30);border:1px solid var(--line);border-radius:10px;padding:12px;overflow:auto;font-family:var(--mono);font-size:.78rem;line-height:1.5;color:#cfe0ff;max-height:300px}
#andockWizard #sbkim-aw-pr{display:inline-block;margin-top:10px;font-family:var(--mono);font-size:.86rem;color:var(--accent)}
/* Newcomer-Komfort: geführter Ausgang (Kopier-Knöpfe + 'in deinem Repo anlegen') */
.fp-aw-extra{margin-top:16px;padding-top:14px;border-top:1px solid var(--line)}
.fp-aw-extra h4{margin:0 0 8px;font-size:.95rem}
.fp-aw-extra .fp-aw-steps{margin:0 0 12px;padding-left:20px;color:var(--muted);font-size:.86rem;line-height:1.6}
.fp-aw-extra .fp-aw-row{display:flex;gap:10px;flex-wrap:wrap;margin:8px 0}

/* Bild-des-Tages-Wechsel-Fenster (5-fach-Klick) */
.fp-bild-modal{position:fixed;inset:0;z-index:1000;display:none;place-items:center;padding:18px}
.fp-bild-modal.open{display:grid}
.fp-bild-modal .backdrop{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px)}
.fp-bild-card{position:relative;z-index:1;width:min(580px,94vw);background:var(--card);border:1px solid var(--line);border-radius:16px;backdrop-filter:blur(14px) saturate(1.2);-webkit-backdrop-filter:blur(14px) saturate(1.2);box-shadow:var(--shadow);padding:22px}
.fp-bild-card h3{margin:0 0 6px;font-size:1.2rem}
.fp-bild-card .sub{margin:0}
.fp-bild-drop{margin-top:14px;border:2px dashed var(--line);border-radius:12px;padding:28px 18px;text-align:center;color:var(--muted);cursor:pointer;transition:border-color .2s,box-shadow .2s,color .2s}
.fp-bild-drop.hot{border-color:var(--accent);box-shadow:var(--glow);color:var(--text)}
.fp-bild-prev{margin-top:14px;max-height:220px;border:1px solid var(--line);border-radius:10px;overflow:hidden;display:none;background:rgba(0,0,0,.3)}
.fp-bild-prev img{width:100%;max-height:220px;object-fit:contain;display:block}
.fp-bild-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.fp-bild-note{margin-top:14px;font-size:.8rem;color:var(--muted);line-height:1.5;border-left:3px solid var(--gold);padding-left:10px}
.fp-bild-close{position:absolute;top:10px;right:10px;width:30px;height:30px;border-radius:50%;border:1px solid var(--line);background:rgba(127,127,127,.14);color:var(--text);cursor:pointer;font-size:.9rem}
.fp-bild-close:hover{border-color:var(--accent)}

footer{border-top:1px solid var(--line);padding:28px 0;color:var(--muted);font-size:.85rem;margin-top:20px}
footer .frow{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
footer a{color:var(--muted)} footer a:hover{color:var(--accent)}

@media (prefers-reduced-motion: reduce){ *{animation:none!important} }
