/* ============================================================
   KOPFKINO — Partner Creator one-pager  ·  creator.css
   Builds on site.css tokens (--ink, --red, --white, --mono …)
   Cinematic broadcast language: letterbox, ticks, REC, EPG
   ============================================================ */

.creator{ --gutter:clamp(20px,5vw,80px);
  /* ===== Creator-Theme — pro Creator in der jeweiligen HTML ueberschreibbar.
     Default = KOPFKINO Rotlicht. KOPFKINO-Chrome (Statusbar/Partner-Strip/Footer)
     bleibt immer Rotlicht und signalisiert "praesentiert von KOPFKINO". ===== */
  --cre:#E8593C; --cre-rgb:232,89,60; --cre-2:#ff6a47;
}
/* site.css-Akzente im Creator-Inhalt auf den Creator-Akzent umstellen */
.creator .eyebrow{ color:var(--cre); }
.creator .eyebrow::before{ background:var(--cre); }
.creator .btn.primary{ background:var(--cre); border-color:var(--cre); color:#0A0A0A; }
.creator .btn.primary:hover{ background:var(--cre-2); box-shadow:0 12px 40px -12px var(--cre); }
.creator .btn .dot{ background:var(--cre); }
.creator .btn.primary .dot{ background:#0A0A0A; }
.creator ::selection{ background:var(--cre); color:#0A0A0A; }

/* ---------- generic section frame ---------- */
.csec{ padding:clamp(72px,10vw,140px) 0; position:relative; }
.csec.tight{ padding:clamp(48px,7vw,96px) 0; }
.chead{ display:flex; align-items:flex-end; justify-content:space-between; gap:28px;
  flex-wrap:wrap; margin-bottom:clamp(36px,5vw,64px); }
.chead h2{ font-size:clamp(30px,5vw,60px); line-height:.96; letter-spacing:-.03em; }
.chead h2 em{ font-style:normal; color:var(--cre); }
.chead .h-meta{ font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--mid); display:flex; align-items:center; gap:10px;
  white-space:nowrap; }
.chead .h-meta .dot{ width:7px; height:7px; border-radius:50%; background:var(--cre);
  box-shadow:0 0 10px var(--cre); animation:pulse 1.3s infinite; }

/* ============================================================
   PARTNER STRIP (under statusbar)
   ============================================================ */
.partner-strip{ display:flex; align-items:center; justify-content:center; gap:14px;
  padding:11px var(--pad); border-bottom:1px solid var(--line);
  font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--mid); background:var(--ink-2); }
.partner-strip a{ color:var(--white); }
.partner-strip a:hover{ color:var(--red); }
.partner-strip .x{ color:var(--red); font-weight:700; }
.partner-strip .back{ color:var(--mid); display:inline-flex; gap:7px; align-items:center; }
.partner-strip .back:hover{ color:var(--white); }

/* ============================================================
   HERO
   ============================================================ */
.chero{ position:relative; overflow:hidden; padding:clamp(40px,6vw,80px) 0 clamp(56px,8vw,110px); }
.chero .beam{ position:absolute; top:-30%; left:50%; width:120%; height:90%;
  transform:translateX(-50%);
  background:radial-gradient(60% 60% at 50% 0%, rgba(var(--cre-rgb),.16), transparent 70%);
  pointer-events:none; }
.chero-grid{ display:grid; grid-template-columns:1.25fr .85fr; gap:clamp(28px,4vw,68px);
  align-items:center; position:relative; z-index:2; }
@media(max-width:900px){ .chero-grid{ grid-template-columns:1fr; gap:36px; } }

.chero .kick{ margin-bottom:22px; }
.chero h1{ font-size:clamp(54px,10vw,140px); line-height:.84; letter-spacing:-.04em;
  font-weight:800; text-wrap:balance; }
.chero h1 em{ font-style:normal; color:var(--cre); }
.chero h1.logo-h1{ margin:0; line-height:1; width:100%; }
.chero h1.logo-h1 img{ width:93%; max-width:660px; height:auto; display:block; }
.chero .roles{ margin-top:26px; display:flex; flex-wrap:wrap; gap:10px; }
.chero .roles span{ font-family:var(--mono); font-size:12px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--white); padding:8px 14px; border:1px solid var(--line);
  border-radius:999px; }
.chero .roles span.par{ color:var(--cre); border-color:rgba(var(--cre-rgb),.4); }
.chero .lead{ margin-top:28px; color:var(--mid); font-size:clamp(15px,1.5vw,19px);
  line-height:1.65; max-width:52ch; }
.chero .lead strong{ color:var(--white); font-weight:600; }
.chero .cta{ margin-top:34px; display:flex; gap:14px; flex-wrap:wrap; }

/* live pill (status) */
.livestat{ display:inline-flex; align-items:center; gap:12px; font-family:var(--mono);
  font-size:12px; letter-spacing:.16em; text-transform:uppercase; padding:9px 16px;
  border-radius:999px; border:1px solid var(--line); color:var(--mid);
  background:rgba(8,8,8,.5); }
.livestat .d{ width:9px; height:9px; border-radius:50%; background:var(--mid); flex:none; }
.livestat.is-live{ color:var(--white); border-color:rgba(var(--cre-rgb),.5); }
.livestat.is-live .d{ background:var(--cre); box-shadow:0 0 12px var(--cre); animation:pulse 1.2s infinite; }
.livestat b{ color:var(--white); font-weight:700; }

/* portrait */
.cportrait{ position:relative; aspect-ratio:4/5; border:1px solid var(--line);
  background:linear-gradient(180deg,var(--ink-3),var(--ink)); overflow:hidden; }
.cportrait img{ width:100%; height:100%; object-fit:cover;
  filter:contrast(1.05) saturate(1.03); }
.cportrait .mono-fallback{ position:absolute; inset:0; display:flex; align-items:center;
  justify-content:center; font-weight:800; font-size:clamp(70px,12vw,150px); color:var(--ink-3);
  letter-spacing:-.04em; user-select:none; }
.cportrait .scrim{ position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(180deg, transparent 45%, rgba(5,5,5,.6) 100%); }
.cportrait .c{ position:absolute; width:18px; height:18px; border:1px solid var(--cre); z-index:3; }
.cportrait .c.tl{ top:12px; left:12px; border-right:0; border-bottom:0; }
.cportrait .c.tr{ top:12px; right:12px; border-left:0; border-bottom:0; }
.cportrait .c.bl{ bottom:12px; left:12px; border-right:0; border-top:0; }
.cportrait .c.br{ bottom:12px; right:12px; border-left:0; border-top:0; }
.cportrait .ov-top{ position:absolute; top:24px; left:26px; right:26px; display:flex;
  justify-content:space-between; align-items:center; z-index:4;
  font-family:var(--mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(245,244,240,.8); }
.cportrait .ov-bot{ position:absolute; left:26px; right:26px; bottom:26px; z-index:4;
  font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  color:rgba(245,244,240,.7); display:flex; justify-content:space-between; }
.cportrait .scan{ position:absolute; inset:0; z-index:3; pointer-events:none; opacity:.25;
  mix-blend-mode:overlay;
  background:repeating-linear-gradient(0deg, rgba(0,0,0,.3) 0 1px, transparent 1px 3px); }

/* stat ticker */
.cstats{ margin-top:clamp(40px,5vw,64px); display:grid; grid-template-columns:repeat(4,1fr);
  border:1px solid var(--line); border-radius:4px; overflow:hidden; position:relative; z-index:2; }
@media(max-width:680px){ .cstats{ grid-template-columns:repeat(2,1fr); } }
.cstats .st{ padding:22px 24px; border-right:1px solid var(--line); min-width:0; }
.cstats .st:last-child{ border-right:0; }
@media(max-width:680px){ .cstats .st:nth-child(2){ border-right:0; }
  .cstats .st:nth-child(1),.cstats .st:nth-child(2){ border-bottom:1px solid var(--line); } }
.cstats .st .v{ font-size:clamp(26px,3vw,40px); font-weight:800; letter-spacing:-.02em;
  font-variant-numeric:tabular-nums; }
.cstats .st .v em{ font-style:normal; color:var(--cre); }
.cstats .st .k{ margin-top:6px; font-family:var(--mono); font-size:10px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--mid); }

/* ============================================================
   LIVE STAGE
   ============================================================ */
.stage-grid{ display:grid; grid-template-columns:1.7fr 1fr; gap:clamp(20px,2.5vw,32px); }
@media(max-width:900px){ .stage-grid{ grid-template-columns:1fr; } }
.stage{ position:relative; aspect-ratio:16/9; background:var(--black);
  border:1px solid var(--line); overflow:hidden; }
.stage iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.stage .poster{ position:absolute; inset:0; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:18px; text-align:center; padding:28px;
  background:radial-gradient(70% 70% at 50% 35%, rgba(var(--cre-rgb),.10), transparent 70%), var(--black); }
.stage .poster .big{ font-weight:800; font-size:clamp(22px,3vw,38px); letter-spacing:-.02em; line-height:1.05; }
.stage .poster .big em{ font-style:normal; color:var(--cre); }
.stage .poster .sm{ font-family:var(--mono); font-size:11px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--mid); }
.stage .poster.hide{ display:none; }
.stage .c{ position:absolute; width:20px; height:20px; border:1px solid rgba(245,244,240,.3); z-index:5; pointer-events:none; }
.stage .c.tl{ top:12px; left:12px; border-right:0; border-bottom:0; }
.stage .c.tr{ top:12px; right:12px; border-left:0; border-bottom:0; }
.stage .c.bl{ bottom:12px; left:12px; border-right:0; border-top:0; }
.stage .c.br{ bottom:12px; right:12px; border-left:0; border-top:0; }

/* mode badge — LIVE vs VOD vs OFFLINE, must be unmistakable */
.stage-badge{ position:absolute; top:16px; left:16px; z-index:6; display:flex; align-items:center;
  gap:9px; padding:8px 14px; border-radius:999px; font-family:var(--mono); font-size:11px;
  letter-spacing:.18em; text-transform:uppercase; font-weight:700; backdrop-filter:blur(6px);
  border:1px solid; pointer-events:none; }
.stage-badge .sb-dot{ width:9px; height:9px; border-radius:50%; flex:none; }
/* LIVE — Rotlicht, pulsierend */
.stage-badge[data-mode="live"]{ color:#fff; background:rgba(255,0,0,.18); border-color:rgba(255,0,0,.55); }
.stage-badge[data-mode="live"] .sb-dot{ background:#FF0000; box-shadow:0 0 12px #FF0000; animation:pulse 1.1s infinite; }
/* VOD — neutral/amber, KEIN Puls, eckiger "Film"-Marker */
.stage-badge[data-mode="vod"]{ color:#F2D9A0; background:rgba(8,8,8,.62); border-color:rgba(242,217,160,.5); }
.stage-badge[data-mode="vod"] .sb-dot{ background:transparent; border-radius:2px; width:11px; height:9px;
  border:1.5px solid #F2D9A0; box-shadow:none; animation:none; }
/* OFFLINE — gedimmt */
.stage-badge[data-mode="offline"]{ color:var(--mid); background:rgba(8,8,8,.55); border-color:var(--line); }
.stage-badge[data-mode="offline"] .sb-dot{ background:var(--dim); }

.stage-side{ display:flex; flex-direction:column; gap:16px; }
.nowcard{ border:1px solid var(--line); background:var(--ink-2); padding:24px; flex:1;
  display:flex; flex-direction:column; gap:16px; }
.nowcard .lab{ font-family:var(--mono); font-size:10px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--cre); }
.nowcard .title{ font-size:clamp(17px,1.8vw,21px); font-weight:700; line-height:1.3; letter-spacing:-.01em; }
.nowcard .game{ font-family:var(--mono); font-size:12px; letter-spacing:.06em; color:var(--mid);
  display:flex; align-items:center; gap:9px; }
.nowcard .game .gd{ width:6px; height:6px; border-radius:50%; background:var(--cre); }
.nowcard .meta-row{ display:flex; gap:22px; margin-top:auto; padding-top:16px; border-top:1px solid var(--line); }
.nowcard .meta-row .m .mv{ font-weight:700; font-size:18px; font-variant-numeric:tabular-nums; }
.nowcard .meta-row .m .mk{ font-family:var(--mono); font-size:9px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--mid); margin-top:3px; }

/* ---------- channel tabs (Stream / DJ-Set) — Twitch-Anstrich ---------- */
.creator{ --tw:#9146FF; --tw-rgb:145,70,255; }
.tw-meta{ color:#b69bff !important; }
.tw-meta .tw-glyph{ width:15px; height:15px; fill:#9146FF; vertical-align:-3px; margin-right:2px; }
.ch-tabs{ display:flex; gap:12px; margin-bottom:20px; flex-wrap:wrap; }
.ch-tab{ flex:1 1 200px; display:flex; align-items:center; gap:13px; cursor:pointer;
  border:1px solid var(--line); background:var(--ink-2); color:var(--white);
  padding:12px 16px; border-radius:4px; text-align:left; transition:.25s; font:inherit; position:relative; }
.ch-tab::before{ content:""; position:absolute; top:0; left:0; right:0; height:3px; background:#9146FF;
  opacity:.5; transition:opacity .25s; }
.ch-tab:hover{ background:var(--ink-3); }
.ch-tab:hover::before{ opacity:.8; }
.ch-tab.active{ border-color:rgba(var(--tw-rgb),.6); background:rgba(var(--tw-rgb),.10); }
.ch-tab.active::before{ opacity:1; }
.ch-tab .tw-badge{ width:34px; height:34px; border-radius:9px; flex:none; background:#9146FF;
  display:flex; align-items:center; justify-content:center; transition:.25s; }
.ch-tab .tw-badge svg{ width:19px; height:19px; fill:#fff; display:block; }
.ch-tab.is-live .tw-badge{ box-shadow:0 0 14px rgba(var(--tw-rgb),.7); animation:pulse 1.4s infinite; }
.ch-tab .ch-info{ display:flex; flex-direction:column; gap:2px; line-height:1.1; }
.ch-tab .ch-name{ font-weight:700; font-size:15px; letter-spacing:-.01em; }
.ch-tab .ch-sub{ font-family:var(--mono); font-size:10px; letter-spacing:.04em; color:var(--mid); }
.ch-tab .ch-live{ margin-left:auto; font-family:var(--mono); font-size:9px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--dim); padding:4px 9px; border:1px solid var(--line); border-radius:999px; }
.ch-tab.is-live .ch-live{ color:#fff; background:#9146FF; border-color:#9146FF; }

/* Live-Stage: Twitch-Akzentstreifen oben */
.stage::after{ content:""; position:absolute; top:0; left:0; right:0; height:3px; background:#9146FF; z-index:6; }

/* ============================================================
   SENDEPLAN / EPG
   ============================================================ */
.epg-top{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; margin-bottom:24px; }
.next-chip{ display:inline-flex; align-items:center; gap:12px; border:1px solid rgba(var(--cre-rgb),.4);
  border-radius:999px; padding:10px 18px; background:rgba(var(--cre-rgb),.06); }
.next-chip .lab{ font-family:var(--mono); font-size:10px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--cre); }
.next-chip .val{ font-weight:700; font-size:15px; font-variant-numeric:tabular-nums; }
.next-chip .val.live{ color:var(--cre); }

.epg{ display:grid; grid-template-columns:repeat(7,1fr); border:1px solid var(--line);
  border-radius:4px; overflow:hidden; }
@media(max-width:860px){ .epg{ grid-template-columns:1fr; } }
.epg .day{ border-right:1px solid var(--line); min-height:170px; display:flex; flex-direction:column;
  background:var(--ink); }
.epg .day:last-child{ border-right:0; }
@media(max-width:860px){ .epg .day{ border-right:0; border-bottom:1px solid var(--line); min-height:0;
  flex-direction:row; align-items:stretch; }
  .epg .day:last-child{ border-bottom:0; } }
.epg .day .dh{ padding:12px 14px; border-bottom:1px solid var(--line); display:flex;
  align-items:center; justify-content:space-between; }
@media(max-width:860px){ .epg .day .dh{ border-bottom:0; border-right:1px solid var(--line);
  flex-direction:column; align-items:flex-start; gap:4px; justify-content:center; min-width:88px; } }
.epg .day .dh .dn{ font-family:var(--mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--white); }
.epg .day .dh .dd{ font-family:var(--mono); font-size:10px; color:var(--dim); }
.epg .day .slot{ padding:16px 14px; display:flex; flex-direction:column; gap:8px; flex:1; }
.epg .day .slot .tm{ font-weight:800; font-size:19px; letter-spacing:-.01em; font-variant-numeric:tabular-nums; }
.epg .day .slot .pg{ font-size:13px; color:var(--mid); line-height:1.35; }
.epg .day .slot .tag{ margin-top:auto; font-family:var(--mono); font-size:9px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--cre); display:inline-flex; align-items:center; gap:6px; }
.epg .day .slot.off{ color:var(--dim); }
.epg .day .slot.off .tm{ font-size:14px; font-weight:600; color:var(--dim); letter-spacing:.08em;
  font-family:var(--mono); text-transform:uppercase; }
.epg .day.today{ background:linear-gradient(180deg, rgba(var(--cre-rgb),.08), transparent 60%); }
.epg .day.today .dh{ background:var(--cre); }
.epg .day.today .dh .dn,.epg .day.today .dh .dd{ color:#0A0A0A; }
.epg .day.today .dh .dd{ opacity:.7; }
.epg .day.is-live .slot .tag{ color:var(--white); }
.epg-note{ margin-top:18px; font-family:var(--mono); font-size:10px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--dim); }

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,72px); align-items:center; }
@media(max-width:840px){ .about-grid{ grid-template-columns:1fr; } }
.about-copy p{ color:var(--mid); font-size:clamp(15px,1.4vw,18px); line-height:1.7; margin-bottom:20px; }
.about-copy p strong{ color:var(--white); font-weight:600; }
.about-copy .pull{ font-size:clamp(22px,2.6vw,34px); font-weight:800; line-height:1.18;
  letter-spacing:-.02em; color:var(--white); margin:0 0 26px; text-wrap:balance; }
.about-copy .pull em{ font-style:normal; color:var(--cre); }
.about-media{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.about-media .ph{ position:relative; aspect-ratio:3/4; border:1px solid var(--line);
  overflow:hidden; background:var(--ink-3); }
.about-media .ph.tall{ aspect-ratio:auto; }
.about-media .ph:nth-child(2){ margin-top:34px; }
.about-media .ph img{ width:100%; height:100%; object-fit:cover; display:block; }

/* ============================================================
   SOCIAL FEED
   ============================================================ */
.social-grid{ display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(20px,2.5vw,32px); align-items:start; }
@media(max-width:900px){ .social-grid{ grid-template-columns:1fr; } }
.tiktok-wrap{ border:1px solid var(--line); background:#000; padding:0; position:relative;
  width:100%; max-width:340px; margin:0 auto; aspect-ratio:9/16; max-height:600px; overflow:hidden; }
.tiktok-wrap .tt-player{ position:absolute; inset:0; width:100%; height:100%; border:0; display:block; }
.tiktok-wrap .tt-link{ position:absolute; inset:0; z-index:3; cursor:pointer; }
.tiktok-wrap .tt-fallback{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:12px; letter-spacing:.08em; color:var(--mid); text-align:center; padding:24px; }
.tiktok-wrap .tt-fallback:hover{ color:var(--cre); }
.feed-col{ display:flex; flex-direction:column; gap:16px; }
.feed-card{ border:1px solid var(--line); background:var(--ink-2); overflow:hidden; position:relative; transition:border-color .3s, transform .3s; }
.feed-card::before{ content:""; position:absolute; top:0; left:0; right:0; height:3px; z-index:2; }
.feed-card.ig::before{ background:linear-gradient(90deg,#feda75,#fa7e1e,#d62976,#962fbf,#4f5bd5); }
.feed-card.tt::before{ background:linear-gradient(90deg,#25F4EE,#fff,#FE2C55); }
.feed-card:hover{ border-color:rgba(255,255,255,.18); transform:translateY(-2px); }
.feed-card .fc-top{ display:flex; align-items:center; gap:13px; padding:16px 16px 14px;
  border-bottom:1px solid var(--line); }
.feed-card .fc-top .ic{ width:38px; height:38px; border-radius:10px; flex:none;
  display:flex; align-items:center; justify-content:center; color:#fff; }
.feed-card .fc-top .ic svg{ width:21px; height:21px; display:block; }
.feed-card .fc-top .ic.ig{ background:linear-gradient(135deg,#feda75 0%,#fa7e1e 25%,#d62976 55%,#962fbf 80%,#4f5bd5 100%); }
.feed-card .fc-top .ic.tt{ background:#000; border:1px solid rgba(37,244,238,.45); position:relative; }
.feed-card .fc-top .h{ font-weight:700; font-size:15px; letter-spacing:-.01em; }
.feed-card .fc-top .hl{ font-family:var(--mono); font-size:10px; color:var(--mid); letter-spacing:.08em; }
.feed-card .fc-top .pf{ margin-left:auto; font-family:var(--mono); font-size:9px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--dim); }
.feed-card .shots{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:1px; background:var(--line); }
.feed-card .shots a{ display:block; aspect-ratio:1; overflow:hidden; position:relative; }
.feed-card .shots a img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .35s, opacity .35s; }
.feed-card .shots a:hover img{ transform:scale(1.06); opacity:.82; }
.feed-card .fc-foot{ padding:14px 16px; display:flex; align-items:center; justify-content:space-between; }
.feed-card .fc-foot a{ font-family:var(--mono); font-size:11px; letter-spacing:.12em;
  text-transform:uppercase; color:var(--white); display:inline-flex; gap:8px; align-items:center; }
.feed-card .fc-foot a:hover{ color:var(--cre); }
.feed-card .fc-foot .cnt{ font-family:var(--mono); font-size:10px; color:var(--dim); letter-spacing:.1em; }

/* ============================================================
   PARTNERS / BRANDS
   ============================================================ */
.brands{ display:flex; flex-wrap:wrap; gap:14px; }
.brands .b{ flex:1 1 180px; border:1px solid var(--line); background:var(--ink-2);
  padding:26px 24px; display:flex; flex-direction:column; gap:8px; transition:.3s; }
.brands .b:hover{ border-color:rgba(var(--cre-rgb),.4); background:var(--ink-3); }
.brands .b .bn{ font-weight:800; font-size:22px; letter-spacing:-.01em; }
.brands .b .br{ font-family:var(--mono); font-size:10px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--mid); }

/* ============================================================
   BOOKING
   ============================================================ */
.booking{ border-top:1px solid var(--line); }
.book-grid{ display:grid; grid-template-columns:1.2fr 1fr; gap:clamp(32px,5vw,72px); align-items:center; }
@media(max-width:840px){ .book-grid{ grid-template-columns:1fr; gap:36px; } }
.book-grid h2{ font-size:clamp(32px,5.5vw,68px); line-height:.96; letter-spacing:-.03em; }
.book-grid h2 em{ font-style:normal; color:var(--cre); }
.book-grid .sub{ margin-top:22px; color:var(--mid); font-size:clamp(15px,1.5vw,19px); line-height:1.6; max-width:46ch; }
.book-cta{ margin-top:32px; display:flex; gap:14px; flex-wrap:wrap; }
.socials-list{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media(max-width:480px){ .socials-list{ grid-template-columns:1fr; } }
.socials-list a{ border:1px solid var(--line); background:var(--ink-2); padding:18px 20px;
  display:flex; align-items:center; justify-content:space-between; transition:.3s; }
.socials-list a:hover{ border-color:rgba(var(--cre-rgb),.4); background:var(--ink-3); transform:translateY(-2px); }
.socials-list a .pl{ font-weight:600; font-size:15px; }
.socials-list a .hd{ font-family:var(--mono); font-size:11px; color:var(--mid); letter-spacing:.06em; }
.socials-list a .ar{ color:var(--cre); transition:transform .3s; }
.socials-list a:hover .ar{ transform:translate(3px,-3px); }

/* ============================================================
   ROBUST REVEAL  —  never hide via opacity/clip (works even when
   CSS transitions can't tick, e.g. print / frozen capture).
   Keep a gentle transform-only entrance for real browsers.
   ============================================================ */
.creator .reveal,
.creator .clip,
.creator .img-zoom{ opacity:1 !important; clip-path:none !important; }
@media (prefers-reduced-motion:no-preference){
  .creator .reveal{ transform:translateY(26px); transition:transform .9s cubic-bezier(.2,.7,.2,1); }
  .creator .reveal.in{ transform:none; }
}
@media (prefers-reduced-motion:reduce){
  .creator .reveal{ transform:none !important; }
}

/* ============================================================
   INTRO TRAILER — Vollbild beim Seitenaufruf
   ============================================================ */
.nika-intro{ position:relative; height:100svh; width:100%; overflow:hidden; background:#000; z-index:40; }
.intro-video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.intro-scrim{ position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(180deg, rgba(0,0,0,.30) 0%, transparent 24%, transparent 56%, rgba(0,0,0,.72) 100%); }

.intro-scroll{ position:absolute; left:50%; bottom:30px; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:10px; z-index:4; cursor:pointer;
  background:none; border:0; color:#fff; font-family:var(--mono); font-size:13px; font-weight:700; letter-spacing:.26em; text-transform:uppercase; }
.intro-scroll .t{ text-shadow:0 0 16px rgba(var(--cre-rgb),.65), 0 1px 10px rgba(0,0,0,.7); transition:letter-spacing .3s; }
.intro-scroll:hover .t{ letter-spacing:.34em; }
.intro-scroll .bolt svg{ width:30px; height:40px; fill:var(--cre); display:block; }
@media (prefers-reduced-motion:no-preference){
  .intro-scroll .bolt{ display:block; animation:boltDrop 1.5s ease-in-out infinite; }
  .intro-scroll .bolt svg{ animation:boltFlash 1.5s steps(1,end) infinite; }
}
@keyframes boltDrop{ 0%,100%{ transform:translateY(0); } 55%{ transform:translateY(6px); } }
@keyframes boltFlash{
  0%   { opacity:.4; filter:drop-shadow(0 0 2px var(--cre)); }
  6%   { opacity:1; filter:drop-shadow(0 0 16px var(--cre)) drop-shadow(0 0 5px #fff); }
  12%  { opacity:.45; filter:drop-shadow(0 0 2px var(--cre)); }
  20%  { opacity:1; filter:drop-shadow(0 0 18px var(--cre)) drop-shadow(0 0 6px #fff); }
  30%  { opacity:.55; filter:drop-shadow(0 0 3px var(--cre)); }
  100% { opacity:.4; filter:drop-shadow(0 0 2px var(--cre)); }
}

.intro-sound{ position:absolute; top:22px; right:22px; z-index:4; cursor:pointer;
  display:inline-flex; align-items:center; gap:9px; font-family:var(--mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase;
  color:#fff; background:rgba(8,8,8,.5); border:1px solid rgba(245,244,240,.4); border-radius:999px; padding:8px 14px;
  backdrop-filter:blur(6px); transition:border-color .3s, background .3s; }
.intro-sound:hover{ background:rgba(8,8,8,.7); }
.intro-sound .dot{ width:7px; height:7px; border-radius:50%; background:var(--dim); transition:.3s; }
.intro-sound.on{ border-color:rgba(var(--cre-rgb),.6); }
.intro-sound.on .dot{ background:var(--cre); box-shadow:0 0 9px var(--cre); }

/* ---- Großer animierter Ton-Prompt (mittig) ---- */
.intro-unmute{ position:absolute; left:50%; top:68%; transform:translate(-50%,-50%); z-index:5;
  display:flex; flex-direction:column; align-items:center; gap:16px; cursor:pointer;
  background:none; border:0; color:#fff; -webkit-tap-highlight-color:transparent;
  transition:opacity .5s ease, transform .5s ease; }
.intro-unmute .ic{ position:relative; width:78px; height:78px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; background:rgba(8,8,8,.42);
  border:1.5px solid rgba(245,244,240,.9); backdrop-filter:blur(4px); }
.intro-unmute .ic svg{ width:32px; height:32px; fill:#fff; display:block; }
.intro-unmute .ic svg.ic-on{ display:none; }
.intro-unmute .ic::before, .intro-unmute .ic::after{ content:""; position:absolute; inset:-2px;
  border-radius:50%; border:1.5px solid rgba(245,244,240,.55); }
.intro-unmute .lbl{ font-family:var(--mono); font-size:12px; letter-spacing:.24em; text-transform:uppercase;
  color:#fff; text-shadow:0 1px 12px rgba(0,0,0,.6); }
@media (prefers-reduced-motion:no-preference){
  .intro-unmute .ic{ animation:unmuteBob 2.4s ease-in-out infinite; }
  .intro-unmute .ic::before{ animation:unmutePulse 2.4s ease-out infinite; }
  .intro-unmute .ic::after{ animation:unmutePulse 2.4s ease-out infinite 1.2s; }
  .intro-unmute .lbl{ animation:unmuteGlow 2.4s ease-in-out infinite; }
}
@keyframes unmuteBob{ 0%,100%{ transform:scale(1); } 50%{ transform:scale(1.07); } }
@keyframes unmutePulse{ 0%{ transform:scale(1); opacity:.7; } 100%{ transform:scale(2); opacity:0; } }
@keyframes unmuteGlow{ 0%,100%{ opacity:.65; } 50%{ opacity:1; } }
/* Ton aktiv → Prompt schrumpft in eine kleine Ecke-Toggle */
.nika-intro.sound-on .intro-unmute{ left:auto; right:22px; top:24px; transform:none;
  flex-direction:row; gap:9px; background:rgba(8,8,8,.5); border:1px solid rgba(var(--cre-rgb),.6);
  border-radius:999px; padding:8px 13px 8px 9px; backdrop-filter:blur(6px); }
.nika-intro.sound-on .intro-unmute .ic{ width:22px; height:22px; border:0; background:none; animation:none; }
.nika-intro.sound-on .intro-unmute .ic::before,
.nika-intro.sound-on .intro-unmute .ic::after{ display:none; }
.nika-intro.sound-on .intro-unmute .ic svg{ width:17px; height:17px; }
.nika-intro.sound-on .intro-unmute .ic-off{ display:none; }
.nika-intro.sound-on .intro-unmute .ic-on{ display:block; }
.nika-intro.sound-on .intro-unmute .lbl{ font-size:10px; letter-spacing:.16em; }
.nika-intro.sound-on .intro-unmute,
.nika-intro.sound-on .intro-unmute *{ animation:none !important; }

/* Statusleiste + Partner-Strip werden per JS beim Scrollen eingeblendet */
.statusbar, .partner-strip{ transition:opacity .45s ease; }

/* TikTok-Ton: Ecke-Toggle (fixiert, erscheint nur wenn unten Ton läuft) */
.tt-mute{ position:fixed; top:14px; right:18px; z-index:300; cursor:pointer;
  display:inline-flex; align-items:center; gap:8px; font-family:var(--mono); font-size:10px;
  letter-spacing:.16em; text-transform:uppercase; color:#fff; background:rgba(8,8,8,.6);
  border:1px solid rgba(var(--cre-rgb),.6); border-radius:999px; padding:8px 13px 8px 9px;
  backdrop-filter:blur(6px); opacity:0; pointer-events:none; transform:translateY(-6px);
  transition:opacity .35s ease, transform .35s ease; }
.tt-mute.show{ opacity:1; pointer-events:auto; transform:none; }
.tt-mute .ic{ display:inline-flex; }
.tt-mute .ic svg{ width:15px; height:15px; fill:#fff; display:block; }
