/* =====================================================================
   components.css  –  Wiederverwendbare Bausteine
   ---------------------------------------------------------------------
   Buttons, Marquee (Marken-Laufband), Karten (Video/Portfolio),
   Formular-Elemente, Badges, Marquee. Seitenübergreifend nutzbar.
   ===================================================================== */

/* ---- Buttons ------------------------------------------------------- */
.btn {
  --pad: 1rem 2rem;
  display: inline-flex; align-items: center; gap: 0.7rem;
  padding: var(--pad);
  font-size: var(--fs-small); letter-spacing: 0.12em; text-transform: uppercase;
  border-radius: 100px; position: relative; overflow: hidden;
  transition: color .4s var(--ease-out), transform .3s var(--ease-out);
  will-change: transform;
}
.btn span { position: relative; z-index: 1; }
.btn svg { position: relative; z-index: 1; width: 1.05em; height: 1.05em; transition: transform .4s var(--ease-out); }
.btn:hover svg { transform: translateX(4px); }

/* Füll-Effekt von unten beim Hover */
.btn::before {
  content: ""; position: absolute; inset: 0; z-index: 0;
  transform: translateY(101%); transition: transform .5s var(--ease-out);
}
.btn:hover::before { transform: translateY(0); }

.btn--primary { background: var(--gelb); color: var(--gruen-nacht); }
.btn--primary::before { background: var(--creme); }
.btn--primary:hover { color: var(--gruen-nacht); }

.btn--ghost { border: 1px solid var(--line); color: var(--fg); }
.btn--ghost::before { background: var(--gelb); }
.btn--ghost:hover { color: var(--gruen-nacht); border-color: var(--gelb); }

.btn--lg { --pad: 1.25rem 2.6rem; font-size: 0.95rem; }

/* ---- Marquee / Marken-Laufband ------------------------------------
   Logo-Chip-Design: jedes Logo sitzt in einem hellen, abgerundeten
   Plättchen und behält seine Originalfarben. Das funktioniert
   einheitlich für transparente UND hintergrundbehaftete Logos
   (z. B. idealo, Opera, Saily) – kein Weiß-Filter, der Logos mit
   eigenem Hintergrund in weiße Klötze verwandelt.
   Standard leicht entsättigt, beim Hover volle Farbe + Anheben.        */
.marquee { overflow: hidden; width: 100%; -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.marquee__track { display: flex; width: max-content; gap: clamp(1rem, 2vw, 1.8rem); align-items: center; animation: marquee 42s linear infinite; }
.marquee:hover .marquee__track { animation-play-state: paused; }
.marquee__item {
  flex: 0 0 auto; height: clamp(64px, 7vw, 84px); min-width: clamp(150px, 16vw, 210px);
  display: grid; place-items: center; padding: 0 clamp(1.4rem, 2.5vw, 2.2rem);
  background: var(--creme); border-radius: 16px;
  transition: transform .4s var(--ease-out), box-shadow .4s var(--ease-out);
}
.marquee__item img {
  max-height: calc(clamp(26px, 3vw, 38px) * var(--logo-scale, 1)); width: auto; object-fit: contain;
  filter: grayscale(1); opacity: 0.78;
  transition: opacity .4s var(--ease-out), filter .4s var(--ease-out);
}
.marquee__item:hover { transform: translateY(-4px); box-shadow: 0 14px 30px rgba(0,0,0,.28); }
.marquee__item:hover img { filter: grayscale(0); opacity: 1; }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ---- Video-Karte (Startseite) ------------------------------------- */
.video-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 1.8vw, 1.6rem); }
.video-card {
  position: relative; border-radius: var(--radius); overflow: hidden;
  aspect-ratio: 16 / 10; background: var(--card);
  border: 1px solid var(--line); display: block;
  transition: transform .6s var(--ease-out);
}
.video-card__media { position: absolute; inset: 0; }
.video-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--ease-out), filter .6s; }
/* Farbverlauf-Platzhalter (wenn kein eigenes Thumbnail in der JSON steht) */
.video-card__ph, .masonry__ph {
  background:
    radial-gradient(120% 120% at 20% 10%, color-mix(in srgb, var(--gruen-hell) 70%, transparent), transparent 55%),
    radial-gradient(120% 120% at 90% 90%, color-mix(in srgb, var(--gelb) 22%, transparent), transparent 55%),
    var(--gruen-tief);
}
.video-card__ph { position: absolute; inset: 0; display: grid; place-items: center; font-family: var(--font-display); font-size: 4rem; color: rgba(243,239,228,.28); }
.masonry__ph { width: 100%; }
.video-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(14,33,20,.92), rgba(14,33,20,.15) 55%, transparent); transition: opacity .5s; }
.video-card:hover { transform: translateY(-6px); }
.video-card:hover .video-card__media img { transform: scale(1.07); }
.video-card__meta { position: absolute; left: 0; right: 0; bottom: 0; z-index: 2; padding: 1.3rem 1.4rem; }
.video-card__tag { font-size: 0.7rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gelb); }
.video-card__title { font-family: var(--font-display); font-size: clamp(1.1rem, 1.6vw, 1.5rem); text-transform: uppercase; line-height: 1; margin-top: 0.4rem; }
.video-card__play {
  position: absolute; top: 1.1rem; right: 1.1rem; z-index: 3;
  width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center;
  background: rgba(243,239,228,.12); backdrop-filter: blur(6px); border: 1px solid var(--line);
  transform: scale(0.6); opacity: 0; transition: transform .5s var(--ease-out), opacity .4s, background .3s;
}
.video-card:hover .video-card__play { transform: scale(1); opacity: 1; }
.video-card__play:hover { background: var(--gelb); color: var(--gruen-nacht); }

@media (max-width: 900px) { .video-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .video-grid { grid-template-columns: 1fr; } }

/* ---- Formular ------------------------------------------------------ */
.form { display: grid; gap: 1.6rem; }
.form__row { display: grid; gap: 1.6rem; grid-template-columns: 1fr 1fr; }
.field { position: relative; display: flex; flex-direction: column; gap: 0.5rem; }
.field label { font-size: var(--fs-small); letter-spacing: 0.14em; text-transform: uppercase; color: var(--creme-dim); }
.field label .req { color: var(--rot); }
.field input, .field textarea, .field select {
  background: var(--card); border: 1px solid var(--line); border-radius: 12px;
  padding: 0.95rem 1.1rem; color: var(--fg); width: 100%;
  transition: border-color .3s, background .3s, box-shadow .3s;
}
.field textarea { resize: vertical; min-height: 130px; }
.field input::placeholder, .field textarea::placeholder { color: rgba(243,239,228,.32); }
.field input:focus, .field textarea:focus, .field select:focus {
  outline: none; border-color: var(--gelb); background: var(--card-hover);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--gelb) 18%, transparent);
}
.field select { appearance: none; cursor: pointer; }

/* Service-Auswahl als anklickbare Chips (Mehrfachauswahl) */
.choice-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.9rem; }
.choice {
  position: relative; border: 1px solid var(--line); border-radius: 14px;
  padding: 1.1rem 1.2rem; cursor: pointer; transition: border-color .3s, background .3s, transform .2s;
  display: flex; flex-direction: column; gap: 0.3rem;
}
.choice:hover { background: var(--card-hover); transform: translateY(-2px); }
.choice input { position: absolute; opacity: 0; pointer-events: none; }
.choice__check { width: 20px; height: 20px; border-radius: 6px; border: 1px solid var(--line); position: absolute; top: 1.1rem; right: 1.1rem; display: grid; place-items: center; transition: background .3s, border-color .3s; }
.choice__check svg { width: 12px; height: 12px; opacity: 0; transform: scale(.5); transition: opacity .3s, transform .3s; color: var(--gruen-nacht); }
.choice__title { font-family: var(--font-display); text-transform: uppercase; font-size: 1.1rem; }
.choice__sub { font-size: var(--fs-small); color: var(--creme-dim); }
.choice:has(input:checked) { border-color: var(--gelb); background: color-mix(in srgb, var(--gelb) 8%, transparent); }
.choice:has(input:checked) .choice__check { background: var(--gelb); border-color: var(--gelb); }
.choice:has(input:checked) .choice__check svg { opacity: 1; transform: scale(1); }

@media (max-width: 680px) {
  .form__row { grid-template-columns: 1fr; }
  .choice-grid { grid-template-columns: 1fr; }
}

/* ---- Badge / Tag --------------------------------------------------- */
.pill { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.4rem 0.9rem; border: 1px solid var(--line); border-radius: 100px; font-size: var(--fs-small); color: var(--creme-dim); }

/* ---- Scroll-Hinweis ------------------------------------------------ */
.scroll-cue { position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 0.6rem; font-size: 0.7rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--creme-dim); }
.scroll-cue i { width: 1px; height: 42px; background: var(--line); position: relative; overflow: hidden; }
.scroll-cue i::after { content: ""; position: absolute; top: -50%; left: 0; width: 100%; height: 50%; background: var(--gelb); animation: scrollCue 1.8s var(--ease-io) infinite; }
@keyframes scrollCue { to { top: 100%; } }
