/* ============================================================
   Öffentliche Seite · andi24-Rahmen + Per-Projekt-Showcase
   ============================================================ */

.page-public{padding-top:var(--header-h)}

/* ---------- Header (andi24: dunkel, fixiert) ---------- */
.site-header{position:fixed;top:0;left:0;width:100%;height:var(--header-h);z-index:1000;
  background:var(--brand-slate);display:flex;align-items:center;
  box-shadow:0 2px 18px rgba(15,23,42,.18)}
.header-inner{max-width:var(--maxw);width:100%;margin:0 auto;padding:0 var(--sp-6);
  display:flex;align-items:center;justify-content:space-between;height:100%}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;height:100%}
.brand-logo-img{height:38px;width:auto;display:block}
.brand-tag{color:var(--brand-cyan);font-size:13px;font-weight:600}
.header-nav{display:flex;align-items:center;gap:var(--sp-6)}
.nav-link{color:#fff;font-weight:600;font-size:15px;text-decoration:none;transition:color .2s}
.nav-link:hover{color:var(--brand-cyan)}
.site-header .theme-toggle{width:38px;height:38px;border:1px solid rgba(255,255,255,.3);
  background:transparent;border-radius:var(--r-sm);cursor:pointer;display:grid;place-items:center;color:#fff}
.site-header .theme-toggle:hover{border-color:var(--brand-cyan);color:var(--brand-cyan)}
.theme-ico{width:16px;height:16px;border-radius:50%;background:currentColor;
  -webkit-mask:radial-gradient(circle at 68% 32%, transparent 42%, #000 43%);
          mask:radial-gradient(circle at 68% 32%, transparent 42%, #000 43%)}
.btn-cta{background:var(--brand-grad);color:#fff;text-decoration:none;font-weight:600;font-size:14px;
  padding:11px 24px;border-radius:var(--r-sm);box-shadow:0 4px 15px rgba(106,178,207,.3);
  transition:transform .3s, box-shadow .3s;white-space:nowrap}
.btn-cta:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(106,178,207,.5)}

/* ---------- Hero (dunkel) ---------- */
.hero{background:var(--brand-slate);padding:96px 0 110px;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-120px;top:-120px;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle, rgba(106,178,207,.22), transparent 65%);pointer-events:none}
.hero-inner{position:relative}
.hero-pill{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:#cfeaf3;
  background:rgba(106,178,207,.14);border:1px solid rgba(106,178,207,.3);padding:7px 14px;border-radius:var(--r-pill)}
.hero-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--brand-cyan);
  animation:pulse 2.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}
.hero h1{color:#fff;font-weight:700;font-size:clamp(34px,5vw,54px);line-height:1.12;
  letter-spacing:-1px;margin:18px 0}
.hero h1 .accentword{color:var(--brand-cyan)}
.hero p{color:rgba(255,255,255,.75);font-size:clamp(15px,2.2vw,19px);max-width:62ch}
.hero-stats{display:flex;gap:var(--sp-8);margin-top:var(--sp-8);color:rgba(255,255,255,.6);font-size:14px}
.hero-stats b{color:var(--brand-cyan);font-size:22px;margin-right:6px}

/* ---------- Sektionen ---------- */
.section{padding:var(--sp-16) 0}
.section--white{background:var(--bg)}
.section--alt{background:var(--bg-alt)}
.section-head{display:flex;align-items:center;flex-wrap:wrap;gap:var(--sp-3);margin-bottom:var(--sp-12);
  padding-bottom:var(--sp-4);border-bottom:1px solid var(--line)}
.section-head h2{min-width:0}
.section-head .snum{font-family:var(--mono);font-size:14px;color:var(--accent);font-weight:600}
.section-head h2{font-size:clamp(24px,4vw,40px);font-weight:700;color:var(--ink)}
.section-head .badge{font-size:11px;padding:5px 11px;border-radius:var(--r-pill);letter-spacing:.5px}
.badge.prd{color:var(--amber-ink);background:var(--amber-soft)}
.badge.ref{color:var(--accent-ink);background:var(--accent-soft)}
.section-count{margin-left:auto;font-family:var(--mono);font-size:12px;color:var(--muted)}

/* ---------- Showcase-Panels (per-Projekt-Theme) ---------- */
.shows{display:flex;flex-direction:column;gap:var(--sp-8)}
.show{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  background:linear-gradient(180deg, color-mix(in srgb, var(--p-accent) 8%, var(--surface)), var(--surface) 240px);
  box-shadow:var(--shadow);
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s, border-color .35s}
.show:hover{transform:translateY(-5px);
  box-shadow:0 22px 50px color-mix(in srgb, var(--p-accent) 26%, transparent);
  border-color:color-mix(in srgb, var(--p-accent) 45%, var(--line))}
.show-bar{height:6px;background:linear-gradient(90deg, var(--p-accent), var(--p-accent2, var(--p-accent)))}
.show-grid{display:grid;grid-template-columns:140px 1fr;gap:var(--sp-8);padding:var(--sp-12) var(--sp-12)}
.show-rail{display:flex;flex-direction:column;gap:var(--sp-4);align-items:flex-start}
.show-mark{width:64px;height:64px;border-radius:var(--r-andi-sm);display:grid;place-items:center;
  background:linear-gradient(135deg, var(--p-accent), var(--p-accent2, var(--p-accent)));
  color:#fff;font-family:var(--font-display);font-weight:700;font-size:20px;
  box-shadow:0 8px 22px color-mix(in srgb, var(--p-accent) 38%, transparent)}
.show-num{font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:1px;color:var(--p-accent)}
.show-kicker{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted)}
.show-top{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-3);flex-wrap:wrap}
.show-title{font-family:var(--font-display);font-size:clamp(24px,3.4vw,34px);font-weight:700;
  line-height:1.1;margin-bottom:var(--sp-3);color:var(--ink)}
.show-tagline{color:var(--ink);font-size:17px;font-weight:600;margin-bottom:var(--sp-3)}
.show-intro{color:var(--muted);font-size:15px;max-width:70ch;margin-bottom:var(--sp-4);line-height:1.7}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:var(--sp-6)}
.chip{font-family:var(--mono);font-size:11px;color:var(--p-accent);
  background:color-mix(in srgb, var(--p-accent) 12%, transparent);
  border:1px solid color-mix(in srgb, var(--p-accent) 28%, transparent);
  border-radius:var(--r-pill);padding:4px 11px}
.show-foot{display:flex;align-items:center;gap:var(--sp-4);flex-wrap:wrap;
  border-top:1px solid var(--line);padding-top:var(--sp-6)}
.live-link{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;text-decoration:none;
  color:#fff;background:linear-gradient(135deg, var(--p-accent), var(--p-accent2, var(--p-accent)));
  padding:13px 28px;border-radius:var(--r-andi-sm);
  transition:transform .25s, box-shadow .25s}
.live-link:hover{transform:translateY(-2px);box-shadow:0 10px 22px color-mix(in srgb, var(--p-accent) 42%, transparent)}
.nolive{font-family:var(--mono);font-size:12px;color:var(--muted);
  border:1px dashed var(--line-strong);padding:10px 16px;border-radius:var(--r-sm)}

/* Status */
.status{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11px;
  letter-spacing:.4px;padding:5px 10px;border-radius:var(--r-pill)}
.status .dot{width:7px;height:7px;border-radius:50%}
.s-dev{color:var(--amber-ink);background:var(--amber-soft)} .s-dev .dot{background:var(--amber)}
.s-live{color:var(--live-ink);background:var(--live-soft)} .s-live .dot{background:var(--live)}
.s-pre{color:var(--accent-ink);background:var(--accent-soft)} .s-pre .dot{background:var(--accent)}
.s-idle{color:var(--idle-ink);background:var(--idle-soft)} .s-idle .dot{background:var(--idle)}

/* Dunkles Panel (theme_mode = dark, z.B. Kunst & Tattoo) */
.show--dark{background:linear-gradient(180deg,#14181c,#0f1316 60%);border-color:#262c31}
.show--dark .show-title,.show--dark .show-tagline{color:#f2efe9}
.show--dark .show-intro{color:#b6b1a8}
.show--dark .show-foot{border-top-color:#262c31}
.show--dark .show-kicker{color:#9a948b}

/* ---------- Schaufenster / Vitrine (gerahmter Blick aufs echte Live-Projekt) ---------- */
.vitrine{position:relative;display:grid;grid-template-columns:1fr;gap:var(--sp-8);
  border:1px solid var(--line);border-radius:var(--r);overflow:hidden;padding:var(--sp-8);
  background:linear-gradient(180deg, color-mix(in srgb, var(--p-accent) 10%, var(--surface)), var(--surface) 300px);
  box-shadow:var(--shadow);
  transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s, border-color .4s}
.vitrine:hover{transform:translateY(-5px);
  box-shadow:0 26px 60px color-mix(in srgb, var(--p-accent) 28%, transparent);
  border-color:color-mix(in srgb, var(--p-accent) 45%, var(--line))}

/* Fensterrahmen mit Akzent-Glow */
.vitrine-frame{display:block;position:relative;padding:10px;border-radius:var(--r-sm);
  text-decoration:none;cursor:pointer;
  background:linear-gradient(160deg,
    color-mix(in srgb, var(--p-accent) 32%, #0b0f1a),
    color-mix(in srgb, var(--p-accent2, var(--p-accent)) 26%, #0b0f1a));
  box-shadow:0 16px 44px color-mix(in srgb, var(--p-accent) 30%, transparent),
             inset 0 0 0 1px color-mix(in srgb, var(--p-accent) 42%, transparent)}
.vitrine-frame--static{cursor:default}

/* Glasscheibe = Ausschnitt aufs echte Produkt (Peek) */
.vitrine-glass{position:relative;height:clamp(300px,52vw,470px);overflow:hidden;
  border-radius:6px;background:#0b0f1a;isolation:isolate}
.vitrine-shot{position:absolute;inset:0;width:100%;height:100%;display:block;
  object-fit:cover;object-position:top center;
  transition:object-position 1.4s cubic-bezier(.2,.7,.2,1)}
.vitrine-frame:hover .vitrine-shot{object-position:bottom center}

/* Apertur: Innenvignette (Schlüsselloch-Nick) + unterer Fade „da ist mehr dahinter" */
.vitrine-aperture{position:absolute;inset:0;pointer-events:none;border-radius:6px;z-index:2;
  box-shadow:inset 0 0 64px 12px rgba(11,15,26,.50);
  background:linear-gradient(180deg, transparent 52%,
    color-mix(in srgb, var(--p-accent) 24%, #0b0f1a) 100%)}

/* Glanz/Reflexion, wandert beim Hover über die Scheibe */
.vitrine-sheen{position:absolute;inset:0;pointer-events:none;border-radius:6px;z-index:2;
  mix-blend-mode:screen;opacity:0;transform:translateX(-30%);
  background:linear-gradient(115deg, transparent 32%, rgba(255,255,255,.16) 46%, transparent 60%);
  transition:transform 1.2s ease, opacity .5s ease}
.vitrine-frame:hover .vitrine-sheen{opacity:1;transform:translateX(30%)}

/* „Tür"-Hinweis, erscheint beim Hover */
.vitrine-peek{position:absolute;left:50%;bottom:16px;z-index:3;
  display:inline-flex;align-items:center;font-size:12px;font-weight:600;letter-spacing:.4px;color:#fff;
  background:color-mix(in srgb, var(--p-accent) 72%, #0b0f1a);
  border:1px solid color-mix(in srgb, #fff 26%, transparent);
  padding:9px 17px;border-radius:var(--r-pill);box-shadow:0 8px 20px rgba(0,0,0,.38);
  opacity:0;transform:translate(-50%,8px);transition:opacity .35s ease, transform .35s ease}
.vitrine-frame:hover .vitrine-peek{opacity:1;transform:translate(-50%,0)}

/* Kopf (ÜBER dem Fenster): Mark + Kicker + Titel + Tagline */
.vitrine-head{display:flex;align-items:flex-start;gap:var(--sp-4)}
.vitrine-mark{flex:0 0 auto;width:52px;height:52px;border-radius:var(--r-andi-sm);display:grid;place-items:center;
  background:linear-gradient(135deg, var(--p-accent), var(--p-accent2, var(--p-accent)));
  color:#fff;font-family:var(--font-display);font-weight:700;font-size:18px;
  box-shadow:0 8px 22px color-mix(in srgb, var(--p-accent) 38%, transparent)}
.vitrine-headtext{display:flex;flex-direction:column;gap:4px;min-width:0}
.vitrine-kicker{font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted)}
.vitrine-title{font-family:var(--font-display);font-size:clamp(26px,3.6vw,36px);font-weight:700;
  line-height:1.08;color:var(--ink)}
.vitrine-tagline{color:var(--ink);font-size:16px;font-weight:600}

/* Körper (NEBEN): Fenster links, Meta-Seitenleiste rechts */
.vitrine-body{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(230px,1fr);
  gap:var(--sp-8);align-items:stretch}
.vitrine-side{display:flex;flex-direction:column;gap:var(--sp-6)}
.vitrine-facts{display:flex;flex-direction:column}
.vitrine-facts .fact{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);
  padding:11px 0;border-bottom:1px solid var(--line)}
.vitrine-facts .fact:first-child{padding-top:0}
.vitrine-facts dt{font-family:var(--mono);font-size:11px;letter-spacing:.6px;text-transform:uppercase;color:var(--muted)}
.vitrine-facts dd{font-size:14px;font-weight:600;color:var(--ink);text-align:right}
.vitrine-techlabel{display:block;font-size:11px;letter-spacing:.6px;text-transform:uppercase;
  color:var(--muted);margin-bottom:10px}
.vitrine-cta{margin-top:auto}
.vitrine-cta .live-link{width:100%;justify-content:center}

/* Beschreibung (UNTER dem Fenster): kurzer Lead + Marketing-/SEO-Fließtext */
.vitrine-intro{color:var(--ink);font-size:16px;font-weight:600;line-height:1.6;max-width:74ch}
.vitrine-copy{max-width:74ch}
.vitrine-copy p{color:var(--muted);font-size:15px;line-height:1.78;margin-top:.85em}
.vitrine-copy p:first-child{margin-top:.4em}
.vitrine--dark .vitrine-copy p{color:#b6b1a8}
/* Marketing-Text in der Karten-Darstellung */
.show-copy{max-width:72ch;margin-bottom:var(--sp-6)}
.show-copy p{color:var(--muted);font-size:14.5px;line-height:1.75;margin-top:.7em}
.show-copy p:first-child{margin-top:.5em}
.show--dark .show-copy p{color:#b6b1a8}

@media (max-width:760px){
  .vitrine-body{grid-template-columns:1fr}
  /* Flex/Grid-Items dürfen unter ihre Inhalts-Mindestbreite schrumpfen … */
  .vitrine,.vitrine-body,.vitrine-frame,.vitrine-side,.vitrine-head,.vitrine-headtext{min-width:0}
  /* … und lange Einzelwörter (z.B. „Prinzregentenpraxis") brechen statt zu überlaufen */
  .vitrine-title,.vitrine-tagline,.vitrine-intro,.vitrine-kicker,.vitrine-copy p,.live-link{overflow-wrap:anywhere}
}

/* Dunkle Vitrine (theme_mode = dark) */
.vitrine--dark{background:linear-gradient(180deg,#14181c,#0f1316 60%);border-color:#262c31}
.vitrine--dark .vitrine-title,.vitrine--dark .vitrine-tagline,.vitrine--dark .vitrine-facts dd{color:#f2efe9}
.vitrine--dark .vitrine-intro{color:#b6b1a8}
.vitrine--dark .vitrine-kicker,.vitrine--dark .vitrine-techlabel,.vitrine--dark .vitrine-facts dt{color:#9a948b}
.vitrine--dark .vitrine-facts .fact{border-bottom-color:#262c31}

@media (prefers-reduced-motion: reduce){
  .vitrine-shot,.vitrine-sheen{transition:none}
  .vitrine-frame:hover .vitrine-shot{object-position:top center}
  .vitrine-frame:hover .vitrine-sheen{opacity:0}
}

/* ---------- Hinweise ---------- */
.notice{background:var(--amber-soft);color:var(--amber-ink);border:1px solid var(--line);
  border-radius:var(--r-sm);padding:var(--sp-4) var(--sp-6);margin:var(--sp-8) 0}
.notice code{font-family:var(--mono);font-size:.92em}
.empty{color:var(--muted);font-size:14px}

/* ---------- Footer (andi24: dunkel) ---------- */
.site-footer{background:var(--brand-slate);color:#fff;margin-top:0}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:var(--sp-8);padding-top:var(--sp-16);padding-bottom:var(--sp-12)}
.footer-brand p{color:rgba(255,255,255,.7);font-size:14px;margin:var(--sp-4) 0;max-width:42ch}
.socials{display:flex;gap:10px}
.socials a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;text-decoration:none;font-family:var(--mono);
  font-size:13px;transition:.3s}
.socials a:hover{background:var(--brand-cyan);transform:translateY(-3px)}
.footer-col h4{font-family:var(--font-display);font-size:15px;margin-bottom:var(--sp-4);color:#fff}
.footer-col a{display:block;color:rgba(255,255,255,.8);text-decoration:none;font-size:14px;
  padding:5px 0;transition:.25s}
.footer-col a:hover{color:var(--brand-cyan);padding-left:5px}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--sp-3);
  border-top:1px solid rgba(255,255,255,.12);padding-top:var(--sp-6);padding-bottom:var(--sp-8);
  font-size:13px;color:rgba(255,255,255,.55)}
.footer-bottom .mono{font-family:var(--mono)}

/* ---------- Motion ---------- */
[data-reveal]{opacity:0;transform:translateY(26px);
  transition:opacity .6s ease, transform .6s cubic-bezier(.2,.7,.2,1)}
[data-reveal].is-in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  [data-reveal]{opacity:1;transform:none;transition:none}
  .hero-pill .dot{animation:none}
}

@media (max-width:820px){
  .footer-top{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1 / -1}
}
@media (max-width:640px){
  .nav-link{display:none}
  /* Header schlanker, damit Marke + Toggle + CTA in die Viewport-Breite passen */
  .header-inner{padding:0 var(--sp-4)}
  .brand-tag{display:none}
  .brand-logo-img{height:32px}
  .header-nav{gap:var(--sp-3)}
  .btn-cta{padding:9px 15px;font-size:13px}
  .show-grid{grid-template-columns:1fr;padding:var(--sp-8) var(--sp-6)}
  .show-rail{flex-direction:row;align-items:center}
  .hero-stats{gap:var(--sp-6)}
  /* Vitrine-Innenabstand auf Mobil reduzieren (mehr Platz für Inhalt) */
  .vitrine{padding:var(--sp-6)}
}
