/* ─── Variables ──────────────────────────────────────────────────────────── */
:root {
  --bg:        #1e1e1e;
  --surface:   #111118;
  --border:    #1e1e2e;
  --purple:    #9d5cff;
  --purple-dim:#6b3db5;
  --cyan:      #00e5ff;
  --orange:    #ffae00;
  --grey:      #3d3d3d;
  --text:      #e8e8f0;
  --muted:     #6b6b80;
  --danger:    #ff4d6d;
  --success:   #00c896;
  --twitch:    #9146ff;
  --paypal:    #003087;
}

/* ─── Reset & base ───────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: 'DM Sans', sans-serif;
  font-size: 16px;
  line-height: 1.6;
  min-height: 100vh;
  overflow-x: hidden;
}

body::before {
  content: '';
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 9999;
  opacity: 0.4;
}

/* ─── Shared gradient text ───────────────────────────────────────────────── */
.logo,
.welcome-text h1 span,
.hero h1 span,
.price-tag {
  background: linear-gradient(135deg, var(--purple), var(--orange));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ─── Nav ────────────────────────────────────────────────────────────────── */
nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.25rem 2.5rem;
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(12px);
  position: sticky; top: 0; z-index: 100;
  background: rgba(10, 10, 15, 0.8);
}

.logo {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: 1.3rem;
  letter-spacing: -0.02em;
}

.nav-right { display: flex; align-items: center; gap: 1rem; }

.avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 2px solid var(--purple);
  object-fit: cover;
}

.username { font-weight: 500; font-size: 0.9rem; color: var(--text); }

/* ─── Buttons ────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.65rem 1.4rem;
  border-radius: 8px;
  font-family: 'DM Sans', sans-serif;
  font-weight: 500;
  font-size: 0.9rem;
  cursor: pointer;
  border: none;
  text-decoration: none;
  transition: all 0.2s ease;
}

.btn-twitch { background: var(--twitch); color: #fff; }
@media (hover: hover) { .btn-twitch:hover { background: #7b34e0; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(145,70,255,0.35); } }

.btn-ghost { background: transparent; color: var(--muted); border: 1px solid var(--border); }
@media (hover: hover) { .btn-ghost:hover { color: var(--text); border-color: var(--muted); } }

.btn-twitch-hero { padding: 0.9rem 2.2rem; font-size: 1rem; border-radius: 10px; box-shadow: 0 0 30px rgba(145,70,255,0.25); }
.btn.btn-loading { pointer-events: none; opacity: 0.85; }

/* ─── Layout, cards, badges ──────────────────────────────────────────────── */
.container { max-width: 900px; margin: 0 auto; padding: 0 2rem; }

.card { background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 2rem; }

.badge { display: inline-flex; align-items: center; gap: 0.35rem; padding: 0.25rem 0.75rem; border-radius: 999px; font-size: 0.78rem; font-weight: 500; letter-spacing: 0.02em; }
.badge-success  { background: rgba(0,200,150,.12);  color: var(--success); border: 1px solid rgba(0,200,150,.2); }
.badge-locked   { background: rgba(255,77,109,.1);  color: var(--danger);  border: 1px solid rgba(255,77,109,.15); }
.badge-live     { background: rgba(229,20,20,.15);  color: #e52020;        border: 1px solid rgba(229,20,20,.25); }
.badge-offline  { background: rgba(107,107,128,.1); color: var(--muted);   border: 1px solid rgba(107,107,128,.15); }

/* ─── Index: hero ────────────────────────────────────────────────────────── */
.hero {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-height: calc(100vh - 73px);
  padding: 4rem 2rem;
  position: relative;
  overflow-x: clip;
}

.hero::before {
  content: '';
  position: absolute;
  top: 30%; left: 50%;
  transform: translate(-50%, -50%);
  width: 600px; height: 400px;
  background: radial-gradient(ellipse, rgba(157,92,255,0.15) 0%, transparent 70%);
  pointer-events: none;
}

.hero-eyebrow { font-size: 0.78rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--cyan); font-weight: 500; margin-bottom: 1.25rem; opacity: 0; animation: slideUp 0.6s ease forwards 0.1s; }

.hero h1 { font-family: 'Syne', sans-serif; font-weight: 800; font-size: clamp(2.5rem, 6vw, 4.5rem); line-height: 1.08; letter-spacing: -0.03em; max-width: 700px; margin-bottom: 1.5rem; opacity: 0; animation: slideUp 0.6s ease forwards 0.25s; }

.hero p { color: var(--muted); max-width: 480px; margin-bottom: 2.5rem; font-size: 1.05rem; opacity: 0; animation: slideUp 0.6s ease forwards 0.4s; }

.hero .cta { opacity: 0; animation: slideUp 0.6s ease forwards 0.55s; }

.features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; max-width: 700px; margin-top: 4rem; opacity: 0; animation: slideUp 0.6s ease forwards 0.7s; }

.feature { background: var(--surface); border: 1px solid var(--border); border-radius: 12px; padding: 1.25rem; text-align: left; }
.feature-icon  { font-size: 1.4rem; margin-bottom: 0.5rem; }
.feature-title { font-size: 0.85rem; font-weight: 600; color: var(--text); margin-bottom: 0.25rem; }
.feature-desc  { font-size: 0.78rem; color: var(--muted); }

.error-msg { margin-bottom: 1.5rem; padding: 0.75rem 1.25rem; background: rgba(255,77,109,.1); border: 1px solid rgba(255,77,109,.2); border-radius: 8px; color: var(--danger); font-size: 0.9rem; }

/* ─── Dashboard ──────────────────────────────────────────────────────────── */
.dashboard { padding: 3rem 2rem 5rem; }

.welcome-header { display: flex; align-items: center; gap: 1.25rem; margin-bottom: 2.5rem; opacity: 0; animation: slideUp 0.5s ease forwards; }

.welcome-avatar { width: 64px; height: 64px; border-radius: 50%; border: 3px solid var(--purple); box-shadow: 0 0 20px rgba(157,92,255,0.3); object-fit: cover; }

.welcome-text { min-width: 0; }
.welcome-text h1 { font-family: 'Syne', sans-serif; font-size: 1.75rem; font-weight: 800; letter-spacing: -0.02em; overflow-wrap: anywhere; }
.welcome-text p  { color: var(--muted); font-size: 0.9rem; margin-top: 0.2rem; }

.status-card { margin-bottom: 2rem; opacity: 0; animation: slideUp 0.5s ease forwards 0.15s; }

.status-row { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; }

.status-info h2 { font-family: 'Syne', sans-serif; font-size: 1.1rem; font-weight: 700; margin-bottom: 0.3rem; }
.status-info p  { font-size: 0.88rem; color: var(--muted); }

.paywall { opacity: 0; animation: slideUp 0.5s ease forwards 0.45s; }

.paypal-pending-overlay { position: fixed; inset: 0; z-index: 2000; background: var(--bg); display: flex; align-items: center; justify-content: center; padding: 2rem; }
.paypal-pending-card { max-width: 460px; text-align: center; background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 2.5rem 2rem; }
.paypal-pending-card .obs-spin { color: var(--purple); }
.paypal-pending-card h2 { font-family: 'Syne', sans-serif; font-size: 1.5rem; font-weight: 800; letter-spacing: -0.02em; margin: 1rem 0 0.6rem; }
.paypal-pending-card p { color: var(--muted); font-size: 0.95rem; margin-bottom: 1.5rem; }

.paywall-card { text-align: center; padding: 3rem 2rem; background: var(--surface); border: 1px solid var(--border); border-radius: 16px; position: relative; overflow: hidden; }
.paywall-card::after { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 50% 120%, rgba(157,92,255,0.1) 0%, transparent 60%); pointer-events: none; }

.lock-icon { font-size: 3rem; margin-bottom: 1rem; display: block; }

.paywall-card h2 { font-family: 'Syne', sans-serif; font-size: 1.6rem; font-weight: 800; letter-spacing: -0.02em; margin-bottom: 0.75rem; }
.paywall-card p  { color: var(--muted); max-width: 420px; margin: 0 auto 2rem; }

.price-tag { display: inline-block; font-family: 'Syne', sans-serif; font-size: 2.5rem; font-weight: 800; margin-bottom: 0.25rem; }
.price-period { display: block; font-size: 0.85rem; color: var(--muted); margin-bottom: 2rem; }

.perks { display: flex; flex-direction: column; gap: 0.6rem; max-width: 300px; margin: 0 auto 2rem; text-align: left; }
.perk { display: flex; align-items: center; gap: 0.6rem; font-size: 0.9rem; color: var(--text); }
.perk::before { content: '✓'; display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; border-radius: 50%; background: rgba(0,200,150,.15); color: var(--success); font-size: 0.75rem; flex-shrink: 0; font-weight: 700; }

.paypal-note { margin-top: 1rem; font-size: 0.78rem; color: var(--muted); }
.no-slots-notice { margin-top: 1.5rem; padding: 0.85rem 1.25rem; background: rgba(255,100,100,.08); border: 1px solid rgba(255,100,100,.18); border-radius: 10px; color: #ff8080; font-size: 0.88rem; text-align: center; }

.stream-preview-card { margin-bottom: 2rem; opacity: 0; animation: slideUp 0.5s ease forwards 0.3s; }
.stream-preview-summary { width: 100%; display: flex; align-items: center; gap: 0.75rem; background: none; border: none; padding: 0; margin: 0; cursor: pointer; user-select: none; text-align: left; color: inherit; }
.stream-preview-chevron { flex-shrink: 0; color: var(--muted); transition: transform 0.2s ease; }
.stream-preview-body { margin-top: 1.25rem; }
.stream-preview-iframe { width: 100%; aspect-ratio: 16 / 9; border: none; border-radius: 8px; background: #000; display: block; }

.obs-card { margin-bottom: 2rem; opacity: 0; animation: slideUp 0.5s ease forwards 0.3s; }

.stream-entry-right { display: flex; align-items: center; gap: 0.4rem; margin-left: auto; flex-shrink: 0; }

.btn-srt-assign { display: inline-flex; align-items: center; gap: 0.25rem; padding: 0.15rem 0.55rem; border-radius: 999px; font-size: 0.7rem; font-weight: 700; border: 1.5px solid; cursor: pointer; background: transparent; font-family: 'DM Sans', sans-serif; letter-spacing: 0.04em; transition: background 0.15s, color 0.15s, border-color 0.15s; }
.btn-srt-assign-icon { display: none; }
.btn-srt-assign--active .btn-srt-assign-icon { display: inline-flex; }
.btn-srt-assign[data-slot$="-1"] { color: #4a9eff; border-color: rgba(74,158,255,.35); }
.btn-srt-assign[data-slot$="-2"] { color: #4cca8a; border-color: rgba(76,202,138,.35); }
@media (hover: hover) { .btn-srt-assign[data-slot$="-1"]:hover { background: rgba(74,158,255,.1); border-color: #4a9eff; } }
@media (hover: hover) { .btn-srt-assign[data-slot$="-2"]:hover { background: rgba(76,202,138,.1); border-color: #4cca8a; } }
.btn-srt-assign--active[data-slot$="-1"] { background: rgba(74,158,255,.18); border-color: #4a9eff; color: #4a9eff; box-shadow: 0 0 0 2px rgba(74,158,255,.2); }
.btn-srt-assign--active[data-slot$="-2"] { background: rgba(76,202,138,.18); border-color: #4cca8a; color: #4cca8a; box-shadow: 0 0 0 2px rgba(76,202,138,.2); }
.btn-srt-assign--flash-ok  { background: rgba(0,200,150,.2)  !important; border-color: var(--success) !important; color: var(--success) !important; }
.btn-srt-assign--flash-err { background: rgba(255,77,109,.15) !important; border-color: var(--danger)  !important; color: var(--danger)  !important; }
.btn-srt-assign--offline   { opacity: 0.4; pointer-events: none; }
.btn-srt-assign:disabled   { opacity: 0.45; cursor: not-allowed; }
.btn-srt-assign--loading   { opacity: 1 !important; }

/* ── App-Konfiguration (Moblin / IRL Pro) ────────────────────────────────── */
.btn-app-config {
  display: inline-flex; align-items: center; padding: 0.15rem 0.6rem; border-radius: 999px;
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.04em; cursor: pointer;
  background: transparent; border: 1.5px solid rgba(157,92,255,.35); color: var(--purple);
  font-family: 'DM Sans', sans-serif; transition: background 0.15s, border-color 0.15s, color 0.15s;
}
@media (hover: hover) { .btn-app-config:hover { background: rgba(157,92,255,.12); border-color: var(--purple); } }

.app-config-modal { position: relative; width: min(420px, 92vw); display: flex; flex-direction: column; }
.app-config-modal p { margin-right: 1.5rem; }
.app-config-close { position: absolute; top: 0.5rem; right: 0.7rem; background: none; border: none; color: var(--muted); font-size: 1.5rem; line-height: 1; cursor: pointer; padding: 0; }
@media (hover: hover) { .app-config-close:hover { color: var(--text); } }
.app-config-proto-toggle { display: flex; gap: 0.4rem; margin: 0.9rem 0; }
.app-config-qr { align-self: center; background: #fff; border-radius: 10px; padding: 12px; line-height: 0; margin-bottom: 0.9rem; min-height: 60px; }
.app-config-qr svg { display: block; width: 220px; height: 220px; max-width: 62vw; max-height: 62vw; }
.app-config-url-row { display: flex; align-items: center; gap: 0.5rem; background: var(--bg); border: 1px solid var(--border); border-radius: 8px; padding: 0.5rem 0.65rem; margin-bottom: 0.85rem; }
.app-config-url { flex: 1; font-family: 'Courier New', Courier, monospace; font-size: 0.78rem; color: var(--text); white-space: nowrap; overflow-x: auto; overflow-y: hidden; min-width: 0; scrollbar-width: thin; }
.app-config-open { display: none; align-items: center; justify-content: center; gap: 0.5rem; margin-top: 0; padding: 0.65rem 1.25rem; background: var(--purple); color: #fff; border-radius: 8px; font-size: 0.9rem; font-weight: 600; text-decoration: none; transition: opacity 0.15s; }
@media (hover: hover) { .app-config-open:hover { opacity: 0.9; } }

.obs-confirm-actions .btn-confirm-primary { flex: 1; padding: 0.7rem 1rem; border-radius: 10px; border: 1px solid rgba(74,158,255,.35); background: rgba(74,158,255,.1); color: #4a9eff; font-family: 'DM Sans', sans-serif; font-size: 0.9rem; font-weight: 600; cursor: pointer; transition: background 0.15s, border-color 0.15s; }
@media (hover: hover) { .obs-confirm-actions .btn-confirm-primary:hover { background: rgba(74,158,255,.18); border-color: #4a9eff; } }

.btn-obs-link { display: inline-flex; align-items: center; gap: 0.5rem; margin-top: 1.25rem; padding: 0.65rem 1.25rem; background: var(--accent); color: #fff; border-radius: 8px; font-size: 0.9rem; font-weight: 600; text-decoration: none; transition: opacity 0.15s; }
@media (hover: hover) { .btn-obs-link:hover { opacity: 0.85; } }

.cancelled-msg { margin-bottom: 1.5rem; padding: 0.75rem 1.25rem; background: rgba(255,180,0,.08); border: 1px solid rgba(255,180,0,.15); border-radius: 8px; color: #ffd166; font-size: 0.9rem; text-align: center; }

/* ─── SRT/RTMP-Relais card ────────────────────────────────────────────────────── */
.stream-card { margin-bottom: 2rem; opacity: 0; animation: slideUp 0.5s ease forwards 0.3s; }

.stream-title { font-family: 'Syne', sans-serif; font-size: 1.1rem; font-weight: 700; }

/* ─── Region badge ───────────────────────────────────────────────────────── */
.region-badge { display: inline-flex; align-items: center; gap: 0.3rem; padding: 0.15rem 0.55rem; border-radius: 999px; font-size: 0.72rem; font-weight: 600; letter-spacing: 0.02em; }
.region-badge--eu { background: rgba(157,92,255,.12); color: var(--purple); border: 1px solid rgba(157,92,255,.2); }
.region-badge--as { background: rgba(0,229,255,.1);  color: var(--cyan);   border: 1px solid rgba(0,229,255,.18); }
.region-badge--us { background: rgba(0,200,150,.1);  color: var(--success);border: 1px solid rgba(0,200,150,.18); }

/* ─── Kind badge (SRT/RTMP) ──────────────────────────────────────────────── */
.kind-badge { display: inline-flex; align-items: center; padding: 0.12rem 0.5rem; border-radius: 999px; font-size: 0.68rem; font-weight: 700; letter-spacing: 0.06em; }
.kind-badge--srt  { background: rgba(255,200,80,.12); color: #e8b04a; border: 1px solid rgba(255,200,80,.22); }
.kind-badge--rtmp { background: rgba(120,180,255,.12); color: #6aa9ff; border: 1px solid rgba(120,180,255,.22); }

.stream-add-section { border-top: 1px solid var(--border); margin-top: 1rem; padding-top: 1.25rem; }
.stream-add-label { display: block; font-size: 0.75rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 0.75rem; }

.stream-add-kind-toggle { display: inline-flex; gap: 0.4rem; margin-bottom: 0.85rem; }
.btn-kind-toggle { padding: 0.35rem 0.9rem; border-radius: 999px; border: 1px solid var(--border); background: transparent; color: var(--muted); font-size: 0.78rem; font-weight: 600; letter-spacing: 0.04em; cursor: pointer; transition: all 0.15s ease; }
@media (hover: hover) { .btn-kind-toggle:hover { color: var(--text); border-color: rgba(255,255,255,.25); } }
.btn-kind-toggle--active { background: rgba(157,92,255,.15); color: var(--purple); border-color: rgba(157,92,255,.35); }
.btn-kind-toggle:disabled, .btn-kind-toggle--disabled { opacity: 0.4; cursor: not-allowed; }
@media (hover: hover) { .btn-kind-toggle:disabled:hover { color: var(--muted); border-color: var(--border); } }

.server-buttons { display: flex; gap: 0.75rem; flex-wrap: wrap; }
.server-buttons form { flex: 1; display: flex; }

.btn-server { width: 100%; display: flex; flex-direction: column; align-items: center; gap: 0.35rem; padding: 0.9rem 1rem; border-radius: 10px; border: 1px solid var(--border); background: var(--surface); color: var(--text); font-family: 'DM Sans', sans-serif; font-size: 0.85rem; font-weight: 500; cursor: pointer; transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s; }
.btn-server > span { font-size: 0.78rem; color: var(--muted); }
@media (hover: hover) { .btn-server:hover { transform: translateY(-2px); } }
@media (hover: hover) { .btn-server--eu:hover { border-color: var(--purple); box-shadow: 0 4px 16px rgba(157,92,255,.2); } }
@media (hover: hover) { .btn-server--as:hover { border-color: var(--cyan);   box-shadow: 0 4px 16px rgba(0,229,255,.15); } }
@media (hover: hover) { .btn-server--us:hover { border-color: var(--success); box-shadow: 0 4px 16px rgba(0,200,150,.15); } }
.btn-server:disabled { opacity: 0.4; cursor: not-allowed; filter: grayscale(0.6); }
@media (hover: hover) { .btn-server:disabled:hover { transform: none; box-shadow: none; border-color: var(--border); } }

.stream-entry { padding-top: 0; }
.stream-entry--bordered { border-top: 1px solid var(--border); margin-top: 0.25rem; padding-top: 0.25rem; }
.stream-entry summary { list-style: none; }
.stream-entry summary::-webkit-details-marker { display: none; }

.stream-entry-summary { display: flex; align-items: center; flex-wrap: wrap; gap: 0.6rem; cursor: pointer; padding: 0.75rem 0; user-select: none; border-radius: 6px; }
@media (hover: hover) { .stream-entry-summary:hover .stream-entry-label { color: var(--text); } }

.stream-chevron { color: var(--muted); flex-shrink: 0; transition: transform 0.2s ease; transform: rotate(0deg); }
details.stream-entry[open] > .stream-entry-summary .stream-chevron { transform: rotate(90deg); }

.stream-entry-label { font-family: 'Syne', sans-serif; font-size: 0.82rem; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; transition: color 0.15s; }
.stream-status-badge { font-size: 0.7rem; font-weight: 600; padding: 0.15rem 0.45rem; border-radius: 99px; letter-spacing: 0.02em; white-space: nowrap; }
.stream-status-badge--live { background: rgba(0,200,150,.12); color: var(--success); }
.stream-status-badge--offline { background: rgba(160,160,160,.1); color: var(--muted); }
.stream-status-badge--na { background: rgba(255,100,100,.1); color: #ff8080; }
.stream-status-badge--pos1 { background: rgba(74,158,255,.12);  color: #4a9eff; }
.stream-status-badge--pos2 { background: rgba(76,202,138,.12);  color: #4cca8a; }

.stream-fields { padding-bottom: 0.5rem; }

.btn-delete-stream { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; border: 1px solid transparent; border-radius: 6px; background: transparent; color: var(--muted); cursor: pointer; transition: color 0.15s, background 0.15s, border-color 0.15s; }
@media (hover: hover) { .btn-delete-stream:hover { color: var(--danger); background: rgba(255,77,109,.08); border-color: rgba(255,77,109,.2); } }

.stream-field { margin-bottom: 1rem; }
.stream-field:last-of-type { margin-bottom: 0; }

.stream-label { display: block; font-size: 0.75rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 0.4rem; }

.stream-value-row { display: flex; align-items: center; gap: 0.5rem; background: var(--bg); border: 1px solid var(--border); border-radius: 8px; padding: 0.6rem 0.75rem; }

.stream-value { flex: 1; font-family: 'Courier New', Courier, monospace; font-size: 0.82rem; color: var(--orange); white-space: nowrap; overflow-x: auto; overflow-y: hidden; min-width: 0; scrollbar-width: thin; }

.btn-copy { flex-shrink: 0; display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; border: none; border-radius: 6px; background: transparent; color: var(--muted); cursor: pointer; transition: color 0.15s, background 0.15s; }
@media (hover: hover) { .btn-copy:hover { color: var(--text); background: var(--border); } }
.btn-copy.copied { color: var(--success); }

.error-banner { margin-bottom: 1.5rem; padding: 0.75rem 1.25rem; background: rgba(255,77,109,.1); border: 1px solid rgba(255,77,109,.2); border-radius: 8px; color: var(--danger); font-size: 0.9rem; text-align: center; }

/* ─── Animation ──────────────────────────────────────────────────────────── */
@keyframes slideUp {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ─── OBS Control card ───────────────────────────────────────────────────── */
.obs-control-card { margin-bottom: 2rem; opacity: 0; animation: slideUp 0.5s ease forwards 0.3s; }

.obs-ctrl-buttons { display: grid; grid-template-columns: 1fr 1fr; gap: 0.75rem; }

.btn-obs-ctrl { display: flex; align-items: center; justify-content: center; gap: 0.55rem; padding: 0.8rem 1rem; border-radius: 10px; border: 1px solid var(--border); background: var(--bg); color: var(--text); font-family: 'DM Sans', sans-serif; font-size: 0.9rem; font-weight: 500; cursor: pointer; transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s, background 0.15s; }
.btn-obs-ctrl:disabled { opacity: 0.45; cursor: not-allowed; transform: none !important; box-shadow: none !important; }

.btn-obs-ctrl--start { border-color: rgba(0,200,150,.2);   color: var(--success); }
@media (hover: hover) { .btn-obs-ctrl--start:not(:disabled):hover  { border-color: var(--success); background: rgba(0,200,150,.08);  box-shadow: 0 4px 16px rgba(0,200,150,.15);  transform: translateY(-1px); } }

.btn-obs-ctrl--stop  { border-color: rgba(255,77,109,.2);  color: var(--danger); }
@media (hover: hover) { .btn-obs-ctrl--stop:not(:disabled):hover   { border-color: var(--danger);  background: rgba(255,77,109,.08); box-shadow: 0 4px 16px rgba(255,77,109,.15); transform: translateY(-1px); } }

.btn-obs-ctrl--refresh { border-color: rgba(100,149,237,.2); color: #6a9cf7; }
@media (hover: hover) { .btn-obs-ctrl--refresh:not(:disabled):hover { border-color: #6a9cf7; background: rgba(100,149,237,.08); box-shadow: 0 4px 16px rgba(100,149,237,.15); transform: translateY(-1px); } }
.btn-obs-ctrl--refresh:only-of-type,
.btn-obs-ctrl--refresh:last-child:nth-child(3) { grid-column: span 2; }

.btn-obs-ctrl--restart { border-color: rgba(255,180,0,.2); color: #ffd166; }
@media (hover: hover) { .btn-obs-ctrl--restart:not(:disabled):hover { border-color: #ffd166; background: rgba(255,180,0,.08); box-shadow: 0 4px 16px rgba(255,180,0,.15); transform: translateY(-1px); } }

.obs-start-bar { display: flex; }
.obs-start-bar .btn-obs-ctrl { flex: 1; font-weight: 600; }


.btn-obs-ctrl--ok    { background: rgba(0,200,150,.12)  !important; border-color: var(--success) !important; }
.btn-obs-ctrl--err   { background: rgba(255,77,109,.1)  !important; border-color: var(--danger)  !important; }
.btn-obs-ctrl--live  { background: rgba(0,200,150,.15)  !important; border-color: var(--success) !important; color: var(--success) !important; box-shadow: 0 0 0 1px rgba(0,200,150,.25), 0 0 14px rgba(0,200,150,.18); }

.obs-section-label { display: block; font-family: 'Syne', sans-serif; font-size: 0.82rem; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; margin: 1rem 0 0.6rem; }
.obs-section-toggle { display: flex; align-items: center; gap: 0.4rem; background: none; border: none; padding: 0; font-family: inherit; cursor: pointer; text-align: left; transition: color 0.15s; }
@media (hover: hover) { .obs-section-toggle:hover { color: var(--text); } }
.obs-section-chevron { flex-shrink: 0; transition: transform 0.2s ease; }

.obs-sources-collapsed-stats { display: none; margin-left: auto; gap: 0.35rem; align-items: center; }
.obs-section-toggle[aria-expanded="false"] .obs-sources-collapsed-stats { display: inline-flex; }
.obs-sources-collapsed-badge { font-family: 'DM Sans', sans-serif; font-size: 0.7rem; font-weight: 600; padding: 0.1rem 0.5rem; border-radius: 999px; letter-spacing: 0.02em; border: 1px solid; white-space: nowrap; text-transform: none; }
.obs-sources-collapsed-badge--pos1 { color: #4a9eff; border-color: rgba(74,158,255,.35); background: rgba(74,158,255,.1); }
.obs-sources-collapsed-badge--pos2 { color: #4cca8a; border-color: rgba(76,202,138,.35); background: rgba(76,202,138,.1); }

.obs-scenes-panel { display: grid; grid-template-columns: 1fr 1fr; gap: 0.5rem; max-height: 260px; overflow-y: auto; }
.btn-scene-item { padding: 0.55rem 0.75rem; border-radius: 8px; border: 1px solid var(--border); background: var(--bg); color: var(--text); font-family: 'DM Sans', sans-serif; font-size: 0.82rem; font-weight: 500; cursor: pointer; text-align: left; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; transition: border-color 0.15s, background 0.15s, color 0.15s; }
@media (hover: hover) { .btn-scene-item:not(:disabled):hover { border-color: var(--purple); background: rgba(157,92,255,.08); color: var(--text); } }
.btn-scene-item:disabled { opacity: 0.45; cursor: not-allowed; }
.btn-scene-item--active { border-color: var(--purple) !important; background: rgba(157,92,255,.12) !important; color: var(--text) !important; }
.btn-scene-item--err { border-color: var(--danger) !important; background: rgba(255,77,109,.08) !important; }
.btn-scene-item--bot { display: inline-flex; align-items: center; gap: 0.4rem; }
.btn-scene-item-icon { flex-shrink: 0; display: inline-flex; opacity: 0.6; }
.btn-scene-item--bot.btn-scene-item--active .btn-scene-item-icon { opacity: 1; }

.card-message { margin-bottom: 0.85rem; padding: 0.6rem 0.85rem; border-radius: 8px; font-size: 0.85rem; opacity: 0; transition: opacity 0.5s ease; }
.card-message--error   { background: rgba(255,77,109,.08); border: 1px solid rgba(255,77,109,.22); color: #ff8a8a; }
.card-message--success { background: rgba(0,200,150,.08); border: 1px solid rgba(0,200,150,.22); color: #4fe0b0; }

.obs-stream-status-badge { display: inline-flex; align-items: center; padding: 0.2rem 0.65rem; border-radius: 999px; font-size: 0.75rem; font-weight: 600; letter-spacing: 0.03em; white-space: nowrap; }
.obs-stream-status-badge--live    { background: rgba(0,200,150,.12);  color: var(--success); border: 1px solid rgba(0,200,150,.25); }
.obs-stream-status-badge--offline { background: rgba(107,107,128,.1); color: var(--muted);   border: 1px solid rgba(107,107,128,.2); }
.obs-stream-status-badge--error   { background: rgba(255,77,109,.1);  color: var(--danger);  border: 1px solid rgba(255,77,109,.2); }
.obs-stream-status-badge--starting { background: rgba(255,200,80,.12); color: #e8b04a; border: 1px solid rgba(255,200,80,.25); }

@keyframes obs-spin { to { transform: rotate(360deg); } }
.obs-spin { animation: obs-spin 0.7s linear infinite; display: inline-block; vertical-align: middle; }

/* ─── Confirm overlay ────────────────────────────────────────────────────── */
.obs-confirm-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.6); backdrop-filter: blur(4px); z-index: 1000; align-items: center; justify-content: center; }
.obs-confirm-overlay.visible { display: flex; }
.obs-confirm-modal { background: var(--surface); border: 1px solid var(--border); border-radius: 16px; padding: 2rem; width: min(380px, 90vw); box-shadow: 0 8px 40px rgba(0,0,0,.5); animation: slideUp 0.18s ease; }
.obs-confirm-modal p { margin: 0 0 0.4rem; font-size: 1rem; font-weight: 600; color: var(--text); }
.obs-confirm-modal small { color: var(--muted); font-size: 0.82rem; }
.obs-confirm-actions { display: flex; gap: 0.75rem; margin-top: 1.5rem; }
.obs-confirm-actions .btn-confirm-stop { flex: 1; padding: 0.7rem 1rem; border-radius: 10px; border: 1px solid rgba(255,77,109,.35); background: rgba(255,77,109,.1); color: var(--danger); font-family: 'DM Sans', sans-serif; font-size: 0.9rem; font-weight: 600; cursor: pointer; transition: background 0.15s, border-color 0.15s; }
@media (hover: hover) { .obs-confirm-actions .btn-confirm-stop:hover { background: rgba(255,77,109,.18); border-color: var(--danger); } }
.obs-confirm-actions .btn-confirm-cancel { flex: 1; padding: 0.7rem 1rem; border-radius: 10px; border: 1px solid var(--border); background: transparent; color: var(--muted); font-family: 'DM Sans', sans-serif; font-size: 0.9rem; font-weight: 500; cursor: pointer; transition: color 0.15s, border-color 0.15s; }
@media (hover: hover) { .obs-confirm-actions .btn-confirm-cancel:hover { color: var(--text); border-color: var(--muted); } }

/* ─── OBS Sources ────────────────────────────────────────────────────────── */
.obs-sources-panel { display: flex; flex-direction: column; gap: 0.4rem; max-height: 280px; overflow-y: auto; }
.obs-sources-empty, .obs-sources-loading { font-size: 0.8rem; color: var(--muted); padding: 0.4rem 0; }

.source-item { display: flex; align-items: center; gap: 0.5rem; padding: 0.5rem 0.65rem; border-radius: 8px; border: 1px solid var(--border); background: var(--bg); transition: border-color 0.15s; flex-wrap: wrap; }
.source-item--saved  { border-color: var(--success) !important; }
.source-item--hidden .source-item-name { opacity: 0.4; }

.source-item-left { display: flex; align-items: center; gap: 0.2rem; flex: 1; min-width: 0; }
.source-item-name { flex: 1; font-size: 0.82rem; font-weight: 500; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; }

.source-kind-badge { flex-shrink: 0; font-size: 0.68rem; font-weight: 600; color: var(--muted); background: rgba(107,107,128,.12); border: 1px solid rgba(107,107,128,.18); border-radius: 4px; padding: 0.1rem 0.4rem; letter-spacing: 0.04em; }

.source-item-btns { display: flex; align-items: center; gap: 0.15rem; flex-shrink: 0; }

.btn-source-move { display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; border: none; border-radius: 5px; background: transparent; color: var(--muted); cursor: pointer; transition: color 0.15s, background 0.15s; }
@media (hover: hover) { .btn-source-move:not(:disabled):hover { color: var(--text); background: var(--border); } }
.btn-source-move:disabled { opacity: 0.2; cursor: not-allowed; }

.btn-source-vis { display: inline-flex; align-items: center; justify-content: center; width: 26px; height: 26px; border: 1px solid transparent; border-radius: 5px; background: transparent; color: var(--muted); cursor: pointer; transition: color 0.15s, background 0.15s, border-color 0.15s; }
@media (hover: hover) { .btn-source-vis:not(:disabled):hover { color: var(--success); background: rgba(0,200,150,.08); border-color: rgba(0,200,150,.2); } }
.btn-source-vis--hidden { color: var(--danger); }
@media (hover: hover) { .btn-source-vis--hidden:not(:disabled):hover { color: var(--danger); background: rgba(255,77,109,.08); border-color: rgba(255,77,109,.2); } }

.btn-source-mute { display: inline-flex; align-items: center; justify-content: center; width: 26px; height: 26px; border: 1px solid transparent; border-radius: 5px; background: transparent; color: var(--muted); cursor: pointer; transition: color 0.15s, background 0.15s, border-color 0.15s; }
@media (hover: hover) { .btn-source-mute:not(:disabled):hover { color: var(--success); background: rgba(0,200,150,.08); border-color: rgba(0,200,150,.2); } }
.btn-source-mute--muted { color: var(--danger); }
@media (hover: hover) { .btn-source-mute--muted:not(:disabled):hover { color: var(--danger); background: rgba(255,77,109,.08); border-color: rgba(255,77,109,.2); } }

.btn-source-edit { display: inline-flex; align-items: center; justify-content: center; width: 26px; height: 26px; border: 1px solid transparent; border-radius: 5px; background: transparent; color: var(--muted); cursor: pointer; transition: color 0.15s, background 0.15s, border-color 0.15s; }
@media (hover: hover) { .btn-source-edit:hover { color: var(--purple); background: rgba(157,92,255,.08); border-color: rgba(157,92,255,.2); } }

.btn-source-delete { display: inline-flex; align-items: center; justify-content: center; width: 26px; height: 26px; border: 1px solid transparent; border-radius: 5px; background: transparent; color: var(--muted); cursor: pointer; transition: color 0.15s, background 0.15s, border-color 0.15s; }
@media (hover: hover) { .btn-source-delete:hover { color: var(--danger); background: rgba(255,77,109,.08); border-color: rgba(255,77,109,.2); } }

.source-url-form { width: 100%; display: flex; flex-direction: column; gap: 0.4rem; margin-top: 0.35rem; }
.source-url-form-btns { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.source-url-input { width: 100%; padding: 0.45rem 0.65rem; border-radius: 7px; border: 1px solid var(--border); background: var(--bg); color: var(--text); font-family: 'DM Sans', sans-serif; font-size: 0.82rem; outline: none; transition: border-color 0.15s; box-sizing: border-box; }
.source-url-input:focus { border-color: var(--purple); }

.btn-source-url-save { padding: 0.45rem 0.9rem; border-radius: 7px; border: 1px solid rgba(157,92,255,.3); background: rgba(157,92,255,.1); color: var(--purple); font-family: 'DM Sans', sans-serif; font-size: 0.82rem; font-weight: 600; cursor: pointer; transition: background 0.15s, border-color 0.15s; white-space: nowrap; }
@media (hover: hover) { .btn-source-url-save:not(:disabled):hover { background: rgba(157,92,255,.18); border-color: var(--purple); } }
.btn-source-url-save:disabled { opacity: 0.5; cursor: not-allowed; }

.btn-source-url-cancel { padding: 0.45rem 0.9rem; border-radius: 7px; border: 1px solid var(--border); background: transparent; color: var(--muted); font-family: 'DM Sans', sans-serif; font-size: 0.82rem; cursor: pointer; transition: color 0.15s; white-space: nowrap; }
@media (hover: hover) { .btn-source-url-cancel:hover { color: var(--text); } }

.source-inline-confirm { width: 100%; display: flex; align-items: center; gap: 0.5rem; margin-top: 0.3rem; }
.source-confirm-msg { flex: 1; font-size: 0.8rem; color: var(--danger); }
.btn-confirm-yes { padding: 0.3rem 0.7rem; border-radius: 6px; border: 1px solid rgba(255,77,109,.35); background: rgba(255,77,109,.1); color: var(--danger); font-size: 0.78rem; font-weight: 600; cursor: pointer; font-family: 'DM Sans', sans-serif; transition: background 0.15s; }
@media (hover: hover) { .btn-confirm-yes:hover { background: rgba(255,77,109,.18); border-color: var(--danger); } }
.btn-confirm-no { padding: 0.3rem 0.7rem; border-radius: 6px; border: 1px solid var(--border); background: transparent; color: var(--muted); font-size: 0.78rem; cursor: pointer; font-family: 'DM Sans', sans-serif; transition: color 0.15s; }
@media (hover: hover) { .btn-confirm-no:hover { color: var(--text); } }

.obs-add-source-bar { display: flex; gap: 0.5rem; margin-top: 0.75rem; flex-wrap: wrap; }
.btn-add-source { display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.45rem 0.85rem; border-radius: 7px; border: 1px solid var(--border); background: transparent; color: var(--muted); font-family: 'DM Sans', sans-serif; font-size: 0.8rem; font-weight: 500; cursor: pointer; transition: color 0.15s, border-color 0.15s, background 0.15s; }
@media (hover: hover) { .btn-add-source:hover { color: var(--text); border-color: var(--purple); background: rgba(157,92,255,.06); } }

.obs-add-source-form { display: flex; flex-direction: column; gap: 0.5rem; margin-top: 0.65rem; padding: 0.85rem; border-radius: 8px; border: 1px solid var(--border); background: rgba(157,92,255,.04); }
.obs-add-source-btns { display: flex; gap: 0.5rem; flex-wrap: wrap; }

/* ─── Restreams card ─────────────────────────────────────────────────────── */
.restreams-card { margin-bottom: 2rem; opacity: 0; animation: slideUp 0.5s ease forwards 0.3s; }

.restreams-list { display: flex; flex-direction: column; gap: 0.4rem; }

.restreams-count-badge { font-size: 0.72rem; color: var(--muted); background: rgba(107,107,128,.1); border: 1px solid rgba(107,107,128,.18); border-radius: 999px; padding: 0.15rem 0.55rem; margin-left: auto; }

.restream-platform-badge { flex-shrink: 0; font-size: 0.68rem; font-weight: 700; border-radius: 4px; padding: 0.1rem 0.45rem; letter-spacing: 0.04em; }
.restream-platform-badge--twitch  { background: rgba(145,70,255,.15); color: #9146ff; border: 1px solid rgba(145,70,255,.25); }
.restream-platform-badge--youtube { background: rgba(255,50,50,.12);  color: #ff4444; border: 1px solid rgba(255,50,50,.2); }
.restream-platform-badge--kick    { background: rgba(83,185,72,.12);  color: #53b948; border: 1px solid rgba(83,185,72,.2); }

.restream-select { width: 100%; padding: 0.45rem 0.65rem; border-radius: 7px; border: 1px solid var(--border); background: var(--bg); color: var(--text); font-family: 'DM Sans', sans-serif; font-size: 0.82rem; outline: none; transition: border-color 0.15s; cursor: pointer; }
.restream-select:focus { border-color: var(--purple); }

.restream-form-body { display: flex; flex-direction: column; gap: 0.5rem; margin-top: 0.5rem; }

.twitch-search-dropdown { background: var(--bg); border: 1px solid var(--border); border-radius: 7px; max-height: 240px; overflow-y: auto; }
.twitch-search-dropdown:empty { display: none; }
.twitch-suggestion { display: flex; align-items: center; gap: 0.55rem; padding: 0.45rem 0.65rem; cursor: pointer; border-bottom: 1px solid var(--border); font-size: 0.85rem; }
.twitch-suggestion:last-child { border-bottom: none; }
@media (hover: hover) { .twitch-suggestion:hover { background: rgba(145,70,255,.08); } }
.twitch-suggestion--empty { cursor: default; color: var(--muted); justify-content: center; }
@media (hover: hover) { .twitch-suggestion--empty:hover { background: transparent; } }
.twitch-suggestion img { width: 26px; height: 26px; border-radius: 50%; object-fit: cover; }
.twitch-suggestion-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.twitch-live-dot { color: var(--danger); font-size: 0.7rem; }

.twitch-channel-preview { display: flex; align-items: center; gap: 0.6rem; padding: 0.5rem 0.7rem; background: var(--bg); border: 1px solid var(--border); border-radius: 7px; }
.twitch-channel-preview img { width: 28px; height: 28px; border-radius: 50%; object-fit: cover; }
.twitch-channel-preview-name { font-weight: 500; font-size: 0.9rem; }

.twitch-invite-msg { font-size: 0.78rem; color: var(--muted); min-height: 1.1rem; }
.twitch-invite-msg--ok  { color: var(--success); }
.twitch-invite-msg--err { color: var(--danger); }

.source-item--pending { opacity: 0.92; border-left: 3px solid var(--purple); }
.restream-pending-status { font-size: 0.72rem; color: var(--muted); margin-left: 0.5rem; flex-shrink: 0; }
.restream-pending-countdown { font-family: 'DM Sans', monospace; font-size: 0.78rem; color: var(--purple); margin-left: 0.4rem; flex-shrink: 0; min-width: 3.2rem; }

.restream-state-badge { flex-shrink: 0; font-size: 0.66rem; font-weight: 700; border-radius: 4px; padding: 0.1rem 0.4rem; letter-spacing: 0.04em; margin-left: 0.4rem; text-transform: uppercase; }
.restream-state-badge--added   { background: rgba(0,200,150,.15); color: var(--success); border: 1px solid rgba(0,200,150,.25); }
.restream-state-badge--updated { background: rgba(255,180,0,.12); color: #ffd166;        border: 1px solid rgba(255,180,0,.25); }
.restream-state-badge--deleted { background: rgba(255,77,109,.1); color: var(--danger);  border: 1px solid rgba(255,77,109,.2); }

.source-item--pending-added   { border-left: 3px solid var(--success); }
.source-item--pending-updated { border-left: 3px solid #ffd166; }
.source-item--pending-deleted { border-left: 3px solid var(--danger); opacity: 0.55; }
.source-item--pending-deleted .source-item-name { text-decoration: line-through; }

.restreams-save-bar { display: flex; align-items: center; gap: 0.6rem; margin-top: 0.85rem; padding: 0.6rem 0.85rem; border-radius: 8px; background: rgba(255,180,0,.06); border: 1px solid rgba(255,180,0,.2); }
.restreams-pending-count { flex: 1; font-size: 0.82rem; color: var(--text); }

.restreams-live-lock-banner { margin-bottom: 0.85rem; padding: 0.6rem 0.85rem; border-radius: 8px; background: rgba(229,20,20,.08); border: 1px solid rgba(229,20,20,.22); color: #ff8a8a; font-size: 0.85rem; }
.restreams-obs-down-banner { margin-bottom: 0.85rem; padding: 0.6rem 0.85rem; border-radius: 8px; background: rgba(255,174,0,.08); border: 1px solid rgba(255,174,0,.25); color: #ffd166; font-size: 0.85rem; }
.restreams-card--live-locked .btn-source-edit,
.restreams-card--live-locked .btn-source-delete,
.restreams-card--live-locked .btn-add-source { opacity: 0.45; cursor: not-allowed; pointer-events: none; }
.restreams-card--live-locked .btn-source-url-save,
.restreams-card--live-locked .btn-source-url-cancel { opacity: 0.5; cursor: not-allowed; pointer-events: none; }
.restreams-card--obs-down .btn-source-edit,
.restreams-card--obs-down .btn-source-delete,
.restreams-card--obs-down .btn-add-source { opacity: 0.45; cursor: not-allowed; pointer-events: none; }
.restreams-card--obs-down .btn-source-url-save,
.restreams-card--obs-down .btn-source-url-cancel { opacity: 0.5; cursor: not-allowed; pointer-events: none; }

/* ─── Invitations card (recipient) ───────────────────────────────────────── */
.invitations-card { margin-bottom: 2rem; opacity: 0; animation: slideUp 0.5s ease forwards 0.18s; }
.invitations-header { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 1rem; }
.invitations-list { display: flex; flex-direction: column; gap: 0.5rem; }

.invitation-item { display: flex; align-items: center; gap: 0.85rem; padding: 0.85rem 1rem; border-radius: 10px; border: 1px solid rgba(0,229,255,.2); background: rgba(0,229,255,.05); flex-wrap: wrap; }
.invitation-info { flex: 1; min-width: 200px; }
.invitation-msg { font-size: 0.9rem; color: var(--text); margin: 0; }
.invitation-msg strong { color: var(--cyan); font-weight: 600; }
.invitation-meta { display: flex; align-items: center; gap: 0.3rem; margin-top: 0.3rem; font-size: 0.78rem; color: var(--muted); }
.invitation-countdown { font-family: 'DM Sans', monospace; color: var(--cyan); }

/* Typ-Kennzeichnung in der gemeinsamen "Einladungen"-Card */
.invitation-type-badge { display: inline-block; font-size: 0.66rem; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; border-radius: 4px; padding: 0.1rem 0.45rem; margin-bottom: 0.4rem; }
.invitation-type-badge--restream { color: var(--cyan); background: rgba(0,229,255,.1); border: 1px solid rgba(0,229,255,.25); }
.invitation-type-badge--admin    { color: var(--orange); background: rgba(255,174,0,.12); border: 1px solid rgba(255,174,0,.3); }
.invitation-item--admin { border-color: rgba(255,174,0,.25); background: rgba(255,174,0,.05); }
.invitation-item--admin .invitation-msg strong { color: var(--orange); }
.invitation-item--admin .invitation-countdown   { color: var(--orange); }

.invitation-actions { display: flex; gap: 0.5rem; flex-shrink: 0; flex-wrap: wrap; }
.btn-invitation-accept { padding: 0.5rem 1.1rem; border-radius: 7px; border: 1px solid rgba(0,200,150,.35); background: rgba(0,200,150,.1); color: var(--success); font-family: 'DM Sans', sans-serif; font-size: 0.85rem; font-weight: 600; cursor: pointer; transition: background 0.15s, border-color 0.15s; }
@media (hover: hover) { .btn-invitation-accept:not(:disabled):hover { background: rgba(0,200,150,.2); border-color: var(--success); } }
.btn-invitation-accept:disabled { opacity: 0.5; cursor: not-allowed; }

.btn-invitation-reject { padding: 0.5rem 1.1rem; border-radius: 7px; border: 1px solid var(--border); background: transparent; color: var(--muted); font-family: 'DM Sans', sans-serif; font-size: 0.85rem; cursor: pointer; transition: color 0.15s, border-color 0.15s; }
@media (hover: hover) { .btn-invitation-reject:not(:disabled):hover { color: var(--text); border-color: var(--muted); } }
.btn-invitation-reject:disabled { opacity: 0.5; cursor: not-allowed; }


/* ─── Active restream links (recipient) ──────────────────────────────────── */
.active-links-card { margin-bottom: 2rem; opacity: 0; animation: slideUp 0.5s ease forwards 0.22s; }

.active-link-item { border-color: rgba(0,200,150,.25); background: rgba(0,200,150,.05); }
.active-link-item .invitation-msg strong { color: var(--success); }


/* ─── Admin-Zugriff ──────────────────────────────────────────────────────── */
.admin-view-banner {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap;
  margin-bottom: 1.5rem; padding: 0.85rem 1.1rem; border-radius: 10px;
  border: 1px solid rgba(255,174,0,.35); background: rgba(255,174,0,.08);
}
.admin-view-banner-info { display: flex; align-items: center; gap: 0.65rem; flex-wrap: wrap; font-size: 0.9rem; color: var(--text); }
.admin-view-banner-info strong { color: var(--orange); font-weight: 600; }
.admin-view-badge {
  padding: 0.2rem 0.6rem; border-radius: 6px; font-size: 0.72rem; font-weight: 700; letter-spacing: .03em;
  text-transform: uppercase; color: var(--orange); background: rgba(255,174,0,.14); border: 1px solid rgba(255,174,0,.4);
}
.btn-admin-back {
  padding: 0.5rem 1.1rem; border-radius: 7px; border: 1px solid var(--border); background: transparent;
  color: var(--muted); font-family: 'DM Sans', sans-serif; font-size: 0.85rem; font-weight: 500; cursor: pointer;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}
@media (hover: hover) { .btn-admin-back:not(:disabled):hover { color: var(--text); border-color: var(--orange); background: rgba(255,174,0,.06); } }
.btn-admin-back:disabled { opacity: 0.5; cursor: not-allowed; }

.advanced-settings-card { margin-bottom: 2rem; opacity: 0; animation: slideUp 0.5s ease forwards 0.2s; }
.advanced-section + .advanced-section { margin-top: 1.25rem; padding-top: 1.25rem; border-top: 1px solid var(--border); }
.advanced-section-title { font-family: 'Syne', sans-serif; font-size: 0.95rem; font-weight: 700; margin-bottom: 0.25rem; }
.advanced-section-desc { font-size: 0.82rem; color: var(--muted); line-height: 1.5; margin: 0 0 0.75rem; }
.admin-switcher-btns { display: flex; flex-direction: column; gap: 0.5rem; }
.btn-admin-switch {
  display: inline-flex; align-items: center; gap: 0.4rem; padding: 0.5rem 1rem; border-radius: 7px;
  border: 1px solid rgba(255,174,0,.35); background: rgba(255,174,0,.08); color: var(--orange);
  font-family: 'DM Sans', sans-serif; font-size: 0.85rem; font-weight: 600; cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
@media (hover: hover) { .btn-admin-switch:not(:disabled):hover { background: rgba(255,174,0,.18); border-color: var(--orange); } }
.btn-admin-switch:disabled { opacity: 0.5; cursor: not-allowed; }

.admin-switcher-item { display: flex; flex-direction: column; gap: 0.4rem; }
.admin-switcher-item-btns { display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap; }
.btn-admin-leave {
  padding: 0.5rem 0.85rem; border-radius: 7px; border: 1px solid var(--border); background: transparent;
  color: var(--muted); font-family: 'DM Sans', sans-serif; font-size: 0.8rem; cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
}
@media (hover: hover) { .btn-admin-leave:not(:disabled):hover { color: var(--danger); border-color: var(--danger); } }
.btn-admin-leave:disabled { opacity: 0.5; cursor: not-allowed; }

.admin-manage-body { display: flex; flex-direction: column; gap: 0.5rem; }
.admin-manage-row {
  display: flex; align-items: center; gap: 0.85rem; flex-wrap: wrap; padding: 0.85rem 1rem;
  border-radius: 10px; border: 1px solid rgba(255,174,0,.2); background: rgba(255,174,0,.05);
}
.admin-manage-info { flex: 1; min-width: 200px; font-size: 0.9rem; color: var(--text); }
.admin-manage-info strong { color: var(--orange); font-weight: 600; }
.admin-manage-info .restream-pending-countdown { font-family: 'DM Sans', monospace; color: var(--orange); }
.btn-admin-remove {
  padding: 0.5rem 0.85rem; border-radius: 7px; border: 1px solid var(--border); background: transparent;
  color: var(--muted); font-family: 'DM Sans', sans-serif; font-size: 0.8rem; cursor: pointer; flex-shrink: 0;
  transition: color 0.15s, border-color 0.15s;
}
@media (hover: hover) { .btn-admin-remove:not(:disabled):hover { color: var(--danger); border-color: var(--danger); } }
.btn-admin-remove:disabled { opacity: 0.5; cursor: not-allowed; }

.admin-notification {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  margin-bottom: 1rem; padding: 0.8rem 1.1rem; border-radius: 10px;
  border: 1px solid rgba(255,174,0,.35); background: rgba(255,174,0,.08);
  color: var(--text); font-size: 0.9rem;
}
.admin-notification strong { color: var(--orange); font-weight: 600; }
.admin-notification-dismiss {
  flex-shrink: 0; width: 1.6rem; height: 1.6rem; border-radius: 6px;
  border: 1px solid var(--border); background: transparent; color: var(--muted);
  font-size: 0.8rem; line-height: 1; cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
}
@media (hover: hover) { .admin-notification-dismiss:hover { color: var(--text); border-color: var(--orange); } }

/* ─── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 600px) {
  .features { grid-template-columns: 1fr; }
  .welcome-header { flex-direction: column; text-align: center; }
  .container { padding: 0 0.25rem; }
  .card { padding: 1rem; }
  .region-badge-name { display: none; }
  .stream-entry-summary { flex-wrap: wrap; }
  nav { flex-direction: column; gap: 0.6rem; padding: 0.85rem 1rem; position: static; }
  .nav-right { width: 100%; justify-content: center; flex-wrap: wrap; }
  #obs-sources-panel .source-item-left { flex-basis: 100%; }
  .source-item-btns { margin-left: auto; }
  .restreams-save-bar { flex-wrap: wrap; }
  .restreams-pending-count { flex-basis: 100%; }
  .app-config-open { display: inline-flex; }
}

