/* =========================
   Video Hero + Klick-Details (CLEAN)
========================= */

/* ---------- Globals ---------- */
:root {
    --boards-overlap: clamp(150px, 25vh, 450px);
    --anchor-offset: calc(var(--header-h) + 80px);
    --detail-pad: 18px;
}

/* Native Anchor Sprünge (Hash, etc.) */
html {
    scroll-padding-top: var(--anchor-offset);
}

*[id] {
    scroll-margin-top: var(--anchor-offset);
}

/* ---------- HERO VIDEO full-width ---------- */
.hero--video {
    position: relative;
    min-height: clamp(560px, 78vh, 900px);
    overflow: hidden;

    /* Video startet direkt unter dem Header */
    padding: 0;

    /* Platz für überlappende Boards */
    padding-bottom: var(--boards-overlap);
}

/* Video / Bild als Background */
.hero--video .hero-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.02);
}

/* Overlay für Lesbarkeit */
.hero--video .hero-overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        linear-gradient(90deg, rgba(9, 64, 104, .78), rgba(9, 64, 104, .22) 55%, rgba(9, 64, 104, .10)),
        linear-gradient(0deg, rgba(0, 0, 0, .35), transparent 55%);
}

/* Hero Layout */
.hero-grid--single {
    grid-template-columns: 1fr;
}

.hero--video .container {
    position: relative;
    z-index: 2;

    /* Inhalt tiefer, ohne Video-Start zu verschieben */
    padding-top: clamp(48px, 7vh, 120px);
}

.hero--video .hero-copy,
.hero--video .hero-copy h1 {
    color: var(--color-white);
}

.hero--video .hero-bullets {
    margin: 14px 0 16px;
    padding-left: 18px;
    color: var(--color-white-95);
}

.hero--video .hero-micro {
    color: var(--color-white-95);
}

.hero--video .hero-actions {
    margin-top: 18px;
}

@media (prefers-reduced-motion: reduce) {
    .hero--video .hero-bg {
        display: none;
    }
}

/* ---------- PCB über Hero "überlappen" ---------- */
#boards {
    position: relative;
    z-index: 10;
    /* über Video, unter Bestückungskopf */
    margin-top: calc(-1 * var(--boards-overlap));
    padding-top: 10px;
}

#boards .pcb-card {
    border-radius: 0;
    box-shadow: 0 18px 40px rgba(0, 0, 0, .18);
    backdrop-filter: blur(6px);
}

/* Mobile: Überlappung reduzieren */
@media (max-width: 700px) {
    :root {
        --boards-overlap: clamp(190px, 24vh, 360px);
    }
}

/* ---------- Klick-Karten als Buttons ---------- */
button.card,
button.step {
    appearance: none;
    -webkit-appearance: none;
    font: inherit;
    color: inherit;
    text-align: left;
}

button.card {
    width: 100%;
    display: block;
    cursor: pointer;
}

/* ---------- Prozess Steps ---------- */
.process-steps {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}

.step {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding: 16px;
    border: 1px solid var(--color-black-10);
    background: var(--panel);
    border-radius: 0;
    cursor: pointer;
    width: 100%;
}

.step-nr {
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border: 1px solid var(--color-black-12);
    font-weight: 900;
    flex: 0 0 auto;
}

@media (max-width: 980px) {
    .process-steps {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 520px) {
    .process-steps {
        grid-template-columns: 1fr;
    }
}

/* ---------- Media-Gallery ---------- */
.media-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.media-card {
    border: 1px solid var(--color-black-10);
    box-shadow: var(--shadow);
    background: var(--panel);
    overflow: hidden;
    border-radius: 0;
    margin: 0;
}

.media-card img,
.media-card video {
    width: 100%;
    height: auto;
    display: block;
    border: 0;
}

/* =========================
   DETAIL DIALOG (Modal)
========================= */

/* Dialog selbst */
.detail-dialog {
    width: min(980px, calc(100vw - 24px));
    border: 0;
    padding: 0;
    background: transparent;
}

.detail-dialog::backdrop {
    background: rgba(0, 0, 0, .62);
}

/* Panel: FULL BLEED, Default Weiß */
.detail-panel {
    position: relative;
    border: 1px solid var(--color-black-12);
    border-radius: 0;
    overflow: hidden;
    background: #fff;
    padding: 0;
    /* wichtig: keine weißen Innenränder */
    box-shadow: 0 24px 80px rgba(0, 0, 0, .35);
}

/* Close Button (nicht transparent!) */
.detail-close {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 42px;
    height: 42px;
    border: 1px solid var(--color-black-12);
    background: rgba(255, 255, 255, .95);
    color: var(--text);
    font-size: 26px;
    line-height: 1;
    cursor: pointer;
    border-radius: 0;
    z-index: 4;
}

/* Body: kein random margin-top (das war der "Rand passt nicht" Klassiker) */
.detail-body {
    margin: 0;
    padding: 0;
    background: #fff;
}

/* ---------- Full-Bleed Media Background ---------- */
.detail-has-media {
    position: relative;
    min-height: clamp(500px, 50vh, 500px);
    overflow: hidden;
    background: #fff;
    /* fallback wenn media fehlt */
}

.detail-media-bg {
    position: absolute;
    inset: 0;
    margin: 0;
    z-index: 0;
    background: #fff;
    /* fallback */
}

.detail-media-el {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;

    /* erst sichtbar, wenn geladen */
    opacity: 0;
}

.detail-has-media.is-media-loaded .detail-media-el {
    opacity: 1;
    transition: opacity .18s ease;
}

/* WEISSER Fade nach links (Textseite) */
.detail-media-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(90deg,
            rgba(255, 255, 255, 0.973) 30%,
            rgba(255, 255, 255, 0.678) 50%,
            rgba(255, 255, 255, 0) 70%);
    z-index: 1;
    /* über Video */
}

/* ---------- Title + Text Layout (im gleichen "Fenster") ---------- */
/* Wenn du einen Titel im Modal hast (z.B. #detailTitle), mach ihn zum Overlay */
#detailTitle {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 3;
    margin: 0;
    padding: var(--detail-pad) calc(var(--detail-pad) + 52px) 12px var(--detail-pad);

    /* weiße Fade-Leiste, damit Titel immer lesbar bleibt */
    background: linear-gradient(180deg,
            rgba(255, 255, 255, .95) 0%,
            rgba(255, 255, 255, .60) 60%,
            rgba(255, 255, 255, 0) 100%);
    backdrop-filter: blur(0px);
}

/* Content: einheitliche Ränder */
.detail-content {
    position: relative;
    z-index: 2;
    /* über Fade/Video */
    padding: calc(var(--detail-pad) + 56px) var(--detail-pad) var(--detail-pad);
    max-width: 52ch;
    color: var(--text);
}

/* Responsive */
@media (max-width: 900px) {
    .detail-has-media {
        min-height: 360px;
    }

    .detail-content {
        max-width: 100%;
    }
}

/* Fallback falls <dialog> nicht unterstützt */
.detail-dialog.is-open {
    position: fixed;
    inset: 0;
    display: grid;
    place-items: center;
    padding: 12px;
    background: rgba(0, 0, 0, .62);
    z-index: 8000;
}

/* ---------- Bestückkopf Tap Feedback ---------- */
.workarea.is-focus .nozzle {
    transform-box: fill-box;
    transform-origin: center;
    animation: nozzleTap .65s ease;
}

@keyframes nozzleTap {
    0% {
        transform: translateY(0);
    }

    45% {
        transform: translateY(12px);
    }

    100% {
        transform: translateY(0);
    }
}