@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;600;800&family=Roboto+Mono:wght@500;700&display=swap");

html{
  height: auto !important;
  min-height: 100% !important;
  display: block !important;
  overflow-y: auto !important;
  scroll-behavior: smooth;
}
:root{
  --txt: rgba(12,14,22,0.92);
  --muted: rgba(12,14,22,0.62);
  --stroke: rgba(15,20,35,0.10);
  --shadow2: 0 12px 30px rgba(16, 24, 40, 0.10);

  --a1: rgba(0, 160, 255, 0.95);
  --a2: rgba(120, 90, 255, 0.90);
  --a3: rgba(255, 120, 170, 0.85);

  --cardRadius: 26px;

  /* Border etwas dicker */
  --ring: 4.2px;
  --glow: 18px;

  /* langsamer */
  --borderSpin: 14s;
  --glowSpin: 22s;

  --miniSpin: 16s;
  --miniGlowSpin: 26s;
  --chipSpin: 14s;
}

*{margin:0;padding:0;box-sizing:border-box}

body{
  min-height: 100% !important;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--txt);
  background: #eef2f7;
  overflow-x: hidden;
  overflow-y: auto !important;
}

main{display:block}
a{color:inherit;text-decoration:none}

/* VANTA background */
#your-element-selector{
  position: fixed;
  inset: 0;
  z-index: -2;
}
#your-element-selector:after{
  content:"";
  position:absolute;
  inset:0;
  z-index: -1;
  background:
    radial-gradient(1000px 650px at 25% 10%, rgba(255,255,255,0.55), transparent 60%),
    radial-gradient(900px 600px at 80% 40%, rgba(255,255,255,0.35), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.20));
  pointer-events:none;
}

/* Button */
.btn{
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid var(--stroke);
  background: rgba(255,255,255,0.74);
  color: var(--txt);
  font-weight: 800;
  cursor:pointer;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
  box-shadow: 0 10px 22px rgba(16,24,40,0.06);
  user-select:none;
}
.btn:hover{
  transform: translateY(-2px);
  box-shadow: 0 16px 30px rgba(16,24,40,0.10);
  background: rgba(255,255,255,0.92);
}
.btn.ghost{background: rgba(255,255,255,0.58)}
.btn.primary{background: linear-gradient(135deg, rgba(0,160,255,0.16), rgba(120,90,255,0.14));}
.btn.full{width:100%}

.langRow{display:flex; gap:10px; align-items:center;}
.langBtn{padding: 10px 12px;}

/* Search wrap + suggestions */
.searchWrap{
  width: 100%;
  max-width: 760px;
  position: relative;
}
.search{
  width: 100%;
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.74);
  border: 1px solid var(--stroke);
  box-shadow: 0 14px 28px rgba(16,24,40,0.08);
}
.search input{
  width:100%;
  border:none;
  outline:none;
  background: transparent;
  color: var(--txt);
  font-size: 14px;
}
.search input::placeholder{color: rgba(12,14,22,0.48)}
.k{
  font-family:"Roboto Mono", monospace;
  font-weight: 900;
  color: rgba(12,14,22,0.55);
  border: 1px solid var(--stroke);
  background: rgba(255,255,255,0.7);
  padding: 4px 8px;
  border-radius: 10px;
  font-size: 12px;
}

/* ✅ Autocomplete panel */
.suggest{
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 10px);
  border-radius: 18px;
  border: 1px solid rgba(15,20,35,0.10);
  background: rgba(255,255,255,0.80);
  backdrop-filter: blur(14px);
  box-shadow: 0 22px 50px rgba(16,24,40,0.14);
  overflow: hidden;
  display: none;
  z-index: 50;
}
.suggest.show{display:block;}
.suggestHead{
  padding: 10px 12px;
  font-size: 12px;
  color: rgba(12,14,22,0.62);
  border-bottom: 1px solid rgba(15,20,35,0.08);
  font-weight: 800;
}
.suggestItem{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 12px;
  cursor: pointer;
  transition: background .12s ease;
}
.suggestItem:hover{background: rgba(0,0,0,0.04);}
.suggestLeft{
  display:flex;
  flex-direction: column;
  gap: 2px;
}
.suggestTitle{
  font-weight: 900;
  letter-spacing:-0.01em;
}
.suggestMeta{
  font-size: 12px;
  color: rgba(12,14,22,0.58);
  font-family: "Roboto Mono", monospace;
}
.suggestPill{
  font-size: 11px;
  font-weight: 900;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(15,20,35,0.10);
  background: rgba(255,255,255,0.68);
}

/* Hero */
.hero{padding: 44px 18px 26px 18px;}
.heroGrid{max-width: 1180px;margin: 0 auto;display:grid;grid-template-columns: 1fr;gap: 18px;}
.heroLeft{
  width:100%;
  display:flex;
  flex-direction: column;
  gap: 14px;
  align-items:center;
  text-align:center;
}

.heroLogo{
  width: min(420px, 78vw);
  height: auto;
  filter: drop-shadow(0 18px 32px rgba(16,24,40,0.22));
  transform: translateZ(0);
}

.hero h1{
  font-size: clamp(34px, 4.2vw, 60px);
  line-height: 1.02;
  letter-spacing: -0.05em;
}
.grad{
  background: linear-gradient(90deg, var(--a1), var(--a2), var(--a3));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.heroRow{
  display:flex;
  gap: 10px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:center;
}

/* Stats */
.heroMini{
  width: 100%;
  max-width: 760px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
  padding-bottom: 2px;
}
.miniCard{
  padding: 14px 14px;
  border-radius: 18px;
  background: rgba(255,255,255,0.56);
  border: 1px solid rgba(12,14,22,0.10);
  box-shadow: var(--shadow2);
  min-height: 64px;
  position: relative;
  overflow: hidden;
  appearance: none;
  -webkit-appearance: none;
  outline: none;
  text-align: left;
  width: 100%;
  transition: transform .18s ease, box-shadow .18s ease;
}
.miniLink{cursor:pointer;}
.miniLink:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 38px rgba(16,24,40,0.12);
}
.miniCard::before{
  content:"";
  position:absolute;
  inset: 0;
  border-radius: 18px;
  padding: 2.8px;
  background: conic-gradient(from var(--angle), var(--a1), var(--a2), var(--a3), var(--a1));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  opacity: 0.92;
  pointer-events:none;
  animation: spinAngle var(--miniSpin) linear infinite;
}
.miniCard::after{
  content:"";
  position:absolute;
  inset: -16px;
  border-radius: 22px;
  background: conic-gradient(from var(--angle), var(--a1), var(--a2), var(--a3), var(--a1));
  filter: blur(18px);
  opacity: 0.14;
  pointer-events:none;
  animation: spinAngle var(--miniGlowSpin) linear infinite;
}
.miniN,.miniL{position:relative; z-index:1;}
.miniN{font-weight: 900; font-size: 18px}
.miniL{font-size: 12px; color: var(--muted); margin-top: 2px}

/* Sections */
.section{padding: 44px 18px;}
.sectionHead{
  max-width: 1180px;
  margin: 0 auto 12px auto;
  display:flex;
  justify-content: space-between;
  align-items:flex-end;
  gap: 10px;
  flex-wrap:wrap;
}
.sectionHead h2{font-size: 20px; letter-spacing: -0.02em;}

/* Chips */
.chips{
  max-width: 1180px;
  margin: 0 auto 18px auto;
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
}
.chipBtn{
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid var(--stroke);
  background: rgba(255,255,255,0.70);
  font-weight: 900;
  cursor:pointer;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
  user-select:none;
  position: relative;
  overflow: hidden;
}
.chipBtn:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 26px rgba(16,24,40,0.10);
  background: rgba(255,255,255,0.88);
}
.chipBtn.active{
  background: linear-gradient(135deg, rgba(0,160,255,0.14), rgba(120,90,255,0.12));
}

/* Featured Stream */
.streamWrap{
  max-width: 1180px;
  margin: 0 auto;
  overflow: hidden;
  padding: 10px 0 0 0;
  border-radius: 18px;
}
.stream{
  height: 310px;
  display:flex;
  align-items:center;
  position:relative;
  perspective: 1100px;
  perspective-origin: 50% 50%;
}
.streamLine{
  display:flex;
  align-items:center;
  gap: 26px;
  white-space: nowrap;
  will-change: transform;
  padding-left: 8vw;
  cursor: default;
  user-select: none;
}
.streamCard{
  width: 420px;
  height: 245px;
  flex-shrink:0;
  position: relative;
  background: transparent;
  overflow: visible;
  cursor:pointer;
  user-select:none;
  transform-style: preserve-3d;
}

/* ✅ FIX: graue “Kästen” entfernen -> kein Border/Shadow/Background am Inner */
.cardInner{
  width: 100%;
  height: 100%;
  border-radius: var(--cardRadius);
  overflow: hidden;
  position: relative;

  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;

  transform: translateZ(0);
  will-change: transform, filter, opacity;
}

/* ✅ Glow */
.cardInner::before{
  content:"";
  position:absolute;
  inset: -12px;
  border-radius: inherit;
  background: conic-gradient(from var(--angle), var(--a1), var(--a2), var(--a3), var(--a1));
  filter: blur(var(--glow));
  opacity: 0.22;
  z-index: -1;
  animation: spinAngle var(--glowSpin) linear infinite;
  pointer-events:none;
}

/* ✅ ANIMIERTE BORDER */
.cardInner::after{
  content:"";
  position:absolute;
  inset: 0;
  border-radius: inherit;
  padding: var(--ring);
  background:
    conic-gradient(
      from var(--angle),
      transparent 0deg 300deg,
      var(--a1) 320deg,
      var(--a2) 340deg,
      var(--a3) 360deg
    );
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  z-index: 3;
  pointer-events:none;
  animation: spinAngle var(--borderSpin) linear infinite;
  opacity: 0.98;
}

.streamImg{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
  border-radius: inherit;
  transform: translateZ(0);
}

/* Gallery */
.grid{
  max-width: 1180px;
  margin: 0 auto;
  columns: 3 320px;
  column-gap: 16px;
}
.tile{
  break-inside: avoid;
  margin: 0 0 16px 0;
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(12,14,22,0.08);
  background: rgba(255,255,255,0.70);
  box-shadow: var(--shadow2);
}
.tileInner{position:relative; overflow:hidden}
.tile img{
  width:100%;
  display:block;
  transform: scale(1.02);
  transition: transform .30s ease, filter .30s ease;
  filter: brightness(1.03) contrast(1.04);
}
.tile:hover img{transform: scale(1.06); filter: brightness(1.08) contrast(1.06)}
.tileOverlay{
  position:absolute; inset:0;
  background:
    radial-gradient(800px 250px at 20% 20%, rgba(255,255,255,0.30), transparent 60%),
    linear-gradient(120deg, rgba(255,255,255,0.08), rgba(0,0,0,0.10));
  pointer-events:none;
}

/* Footer */
.footer{padding: 30px 18px}
.foot{
  max-width: 1180px;
  margin: 0 auto;
  display:flex;
  justify-content: center;
  gap: 10px;
  color: rgba(12,14,22,0.62);
  font-size: 12px;
}

/* Modal */
.modal{position:fixed; inset:0; z-index:200; display:none;}
.modal.show{display:block}
.modalBackdrop{position:absolute; inset:0; background: rgba(10,12,18,0.35); backdrop-filter: blur(10px);}
.modalPanel{
  position: relative;
  max-width: 1100px;
  width: calc(100% - 24px);
  margin: 6vh auto;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,0.35);
  background: rgba(255,255,255,0.82);
  backdrop-filter: blur(16px);
  box-shadow: 0 24px 70px rgba(16,24,40,0.16);
  overflow: hidden;
  max-height: 88vh;
  display:flex;
  flex-direction: column;
}
.modalTop{
  flex: 0 0 auto;
  display:flex;
  justify-content: space-between;
  align-items:center;
  gap: 12px;
  padding: 14px 14px;
  border-bottom: 1px solid rgba(12,14,22,0.08);
}
.modalTitle{font-weight: 900; letter-spacing:-0.02em}
.modalSub{font-size: 12px; color: var(--muted); margin-top: 4px}
.modalBody{
  flex: 1 1 auto;
  display:grid;
  grid-template-columns: 1.25fr 0.75fr;
  gap: 14px;
  padding: 14px;
  overflow: auto;
}
.modalPreview{
  border-radius: 18px;
  overflow: auto;
  border: 1px solid rgba(12,14,22,0.10);
  background: rgba(255,255,255,0.65);
  min-height: 420px;
  max-height: 100%;
  position: relative;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}
.modalPreview img{width:100%; height:auto; object-fit: contain; display:block}
.modalOverlay{
  position:absolute; inset:0;
  pointer-events:none;
  background: linear-gradient(180deg, rgba(255,255,255,0.18), transparent 35%, rgba(0,0,0,0.08));
}
.pillRow{
  position:absolute; left: 12px; right: 12px; top: 12px;
  display:flex; justify-content: space-between; align-items:center;
}
.pill{
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(12,14,22,0.10);
  background: rgba(255,255,255,0.72);
  font-family:"Roboto Mono", monospace;
  font-weight: 900;
  font-size: 12px;
}
.pill.ghost{opacity:0.78}
.modalSide{display:flex; flex-direction: column; gap: 12px;}
.panel{
  border-radius: 18px;
  border: 1px solid rgba(12,14,22,0.10);
  background: rgba(255,255,255,0.65);
  padding: 12px;
}
.panelTitle{font-weight: 900; margin-bottom: 10px}
.resRow{display:flex; flex-wrap:wrap; gap: 8px; margin-bottom: 10px;}
.tagRow{display:flex; flex-wrap:wrap; gap: 8px}
.tag{
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid rgba(12,14,22,0.10);
  background: rgba(255,255,255,0.78);
  font-family:"Roboto Mono", monospace;
  font-weight: 900;
  font-size: 12px;
}
.quickRow{display:flex; gap: 10px; flex-wrap:wrap}

/* angle animation */
@property --angle { syntax: "<angle>"; inherits: false; initial-value: 0deg; }
@keyframes spinAngle { to { --angle: 360deg; } }

@media (max-width: 980px){
  .grid{columns: 2 280px;}
  .stream{height: 280px;}
  .streamCard{width: 78vw; height: 44vw;}
  .modalBody{grid-template-columns: 1fr;}
  .heroMini{grid-template-columns: 1fr;}
}
@media (max-width: 560px){
  .grid{columns: 1;}
  .streamLine{gap: 18px;}
  .streamCard{width: 86vw; height: 52vw;}
}