/* ==========================================================================
   EXPERIMENTELLES Dashboard-Leselayout (?view=lab) – Prototyp.
   Lädt ZUSÄTZLICH zu reader.css. ALLES hier ist unter .qlab gescoped – das
   klassische Layout (reader.css), die IDs/data-actions und der geteilte
   Such-Partial bleiben unverändert. Branding bleibt erhalten.
   ========================================================================== */

.qlab {
    --qlab-rail: 19rem;                  /* breit genug: keine beschnittenen Bedienelemente */
    --qlab-maxw: var(--maxw);            /* an die globale Navbar-/Containerbreite gekoppelt */
    --qlab-measure: 52rem;               /* prominente Lesespalte (klassisch bleibt 48rem) */
    --qlab-gap: clamp(1.5rem, 2.6vw, 2.4rem);
    --qlab-header: 81px;                 /* Höhe der vollbreiten Navigationsleiste */
    --qlab-mbar: 3.5rem;                 /* Höhe der mobilen Steuerleiste (Sticky-Offset) */
    --qlab-panel: color-mix(in srgb, #fff 50%, transparent);  /* milchig-weiße Seitenleisten (50 %) */
    --qlab-panel-gap: clamp(1.25rem, 2.2vw, 1.9rem);          /* Abstand der Panels oben/unten (mehr Luft zur Pille) */
    display: grid;
    grid-template-columns: var(--qlab-rail) minmax(0, 1fr) var(--qlab-rail);
    gap: var(--qlab-gap);
    /* stretch: die Leisten-Zellen füllen die volle Zeilenhöhe → Sticky klebt bis zum Inhaltsende. */
    align-items: stretch;
    width: min(calc(100% - (var(--gutter, 24px) * 2)), var(--qlab-maxw));
    margin-inline: auto;
    /* Oben: Luft zwischen Header-Pille und Inhalt/Leisten. Unten: die Leisten
       (und die Lesefläche) enden nie bündig am Footer, sondern mit Abstand. */
    padding-block: clamp(1.1rem, 2.4vw, 1.75rem) clamp(2rem, 4.5vw, 3.25rem);
}

/* Mobile-Steuerleiste + Scrim: nur ≤860px sichtbar. */
.qlab__mbar { display: none; }
.qlab__scrim { display: none; }

/* Reader verwaltet seinen oberen Bereich selbst – globalen Nav-Inhaltsabstand
   (#main padding-top) hier aufheben, sonst doppelter Abstand. */
.view-lab #main { padding-top: 0; }
/* Kopfzeile bleibt sichtbar (Desktop/Tablet), Leisten sitzen exakt darunter. */
@media (min-width: 861px) {
    .view-lab .site-header { position: sticky; top: 0; z-index: 50; }
}

/* ---- Seitenleisten: klebend, volle Höhe, intern scrollbar, ohne Scrollbalken */
.qlab__rail { min-width: 0; }
.qlab__rail-inner {
    position: sticky;
    top: calc(var(--qlab-header) + var(--qlab-panel-gap));
    height: calc(100vh - var(--qlab-header) - var(--qlab-panel-gap) * 2);
    height: calc(100dvh - var(--qlab-header) - var(--qlab-panel-gap) * 2);
    display: grid;
    align-content: start;
    gap: clamp(.9rem, 1.8vw, 1.25rem);
    overflow-x: hidden;
    overflow-y: auto;
    overscroll-behavior: contain;
    padding: clamp(1rem, 2.5vw, 1.5rem) clamp(1rem, 1.4vw, 1.25rem);
    background: var(--qlab-panel);
    border-radius: 18px;
    scrollbar-width: none;
    -ms-overflow-style: none;
}
.qlab__rail-inner::-webkit-scrollbar { width: 0; height: 0; display: none; }

/* Linke Leiste: Fortschritt + Suren-Kopf bleiben oben, nur die lange Surenliste
   scrollt – so wird der nach Wegfall der Suche frei gewordene Platz voll genutzt. */
.qlab__rail--left .qlab__rail-inner { display: flex; flex-direction: column; overflow: hidden; }

.qlab__nav-head { flex: none; display: flex; align-items: center; justify-content: space-between; gap: .6rem; }
.qlab__rail-title { margin: 0; font-family: var(--font-display-medium); font-size: 1rem; color: var(--text-strong); }

/* Rechte Leiste ist selbst die (milchig-weiße) Fläche → Karte ohne eigene Füllung. */
.qlab__card { padding: 0; background: transparent; }

/* Minimaler Fortschrittsbalken – oben in der linken Seitenleiste (klebt mit der
   Leiste, daher beim Lesen immer sichtbar). */
.qlab__progress { flex: none; margin: 0 0 clamp(.85rem, 2vw, 1.15rem); }
.qlab .qprogress { position: static; width: 100%; margin: 0; height: 5px; border-radius: 999px; background: color-mix(in srgb, var(--secondary) 13%, transparent); overflow: hidden; }
.qlab .qprogress__fill { display: block; height: 100%; width: 0; border-radius: 999px; background: var(--gold); transition: width .5s var(--ease-out-soft); }

/* Surenliste – füllt die verbleibende Höhe und scrollt intern (Balken verborgen). */
.qlab__nav { flex: 1; min-height: 0; display: flex; flex-direction: column; gap: .55rem; }
.qlab__surahs {
    flex: 1; min-height: 0; overflow-y: auto; overscroll-behavior: contain;
    list-style: none; margin: 0; padding: 0; display: grid; gap: .15rem;
    scrollbar-width: none; -ms-overflow-style: none;
}
.qlab__surahs::-webkit-scrollbar { width: 0; height: 0; display: none; }
.qlab__surah {
    display: flex; align-items: center; gap: .7rem;
    padding: .5rem .55rem; border-radius: 12px;
    text-decoration: none; color: var(--text-default);
    transition: background var(--transition);
}
.qlab__surah:hover { background: color-mix(in srgb, var(--secondary) 8%, transparent); }
.qlab__surah.is-active { background: color-mix(in srgb, var(--secondary) 10%, transparent); }
.qlab__surah:focus-visible { outline: var(--focus-ring); outline-offset: 2px; }
.qlab__surah-num {
    flex: none; display: grid; place-items: center;
    width: 1.7rem; height: 1.7rem; border-radius: 8px;
    background: color-mix(in srgb, var(--secondary) 8%, transparent);
    color: var(--text-muted); font-size: .76rem; font-weight: 700; font-variant-numeric: tabular-nums;
}
.qlab__surah.is-active .qlab__surah-num { background: var(--gold); color: #fff; }
.qlab__surah.is-active .qlab__surah-name { color: var(--gold); }
.qlab__surah-body { display: grid; min-width: 0; }
/* Arabischer (transliterierter) Name als Hauptzeile, Übersetzung kleiner darunter. */
.qlab__surah-name { font-family: var(--font-display-medium); font-size: .98rem; color: var(--text-strong); line-height: 1.2; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.qlab__surah-trans { font-size: .76rem; color: var(--text-muted); line-height: 1.25; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ---- Mitte: Lesespalte als primärer Fokus -------------------------------- */
.qlab__main { min-width: 0; }
.qlab__head {
    max-width: var(--qlab-measure); margin: 0 auto clamp(1.3rem, 3vw, 2rem);
    padding-top: clamp(.85rem, 2vw, 1.35rem);
}

/* Titelzeile + kompakter Einstellungs-Button rechts */
.qlab__titlerow { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; }
.qlab__titlebox { min-width: 0; }
.qlab__settings { position: relative; inset: auto; flex: none; margin-top: .35rem; }
/* Einstellungs-Zahnrad: klarer, runder Hover (kühle Navy-Tönung statt Creme),
   Gold-Tönung wenn das Popover offen ist. */
.qlab__settings .qbar__gear { color: var(--text-muted); }
.qlab__settings .qbar__gear:hover { background: color-mix(in srgb, var(--secondary) 12%, transparent); color: var(--text-strong); }
.qlab__settings .qbar__gear[aria-expanded="true"] { background: color-mix(in srgb, var(--gold) 16%, transparent); color: var(--gold); }
.qlab .qbar__gear:focus-visible { outline: var(--focus-ring); outline-offset: 2px; }
.qlab__popover { right: 0; left: auto; max-width: min(20rem, calc(100vw - 2rem)); }
.qlab__surah-title { margin: 0; font-family: var(--font-display-medium); font-size: clamp(1.9rem, 1.4rem + 2vw, 2.7rem); line-height: 1.05; color: var(--text-strong); }
/* Deutschen Untertitel unter dem (arabischen) Sure-Namen in BEIDEN Ansichten
   ausblenden (Vers-für-Vers wie auch Buchseiten). */
.qlab__surah-sub { display: none; }

/* Lesefläche: GENAU EINE weiße Karte. */
.qlab__stage { position: relative; }
.qlab__stage-inner { background: transparent; padding: 0; }
.qlab .qflow {
    max-width: var(--qlab-measure);
    background: var(--surface-card);
    border-radius: clamp(16px, 2vw, 22px);
    padding: clamp(1.6rem, 3.2vw, 2.8rem) clamp(1.4rem, 3vw, 2.4rem);
}
/* Buchseiten-Ansicht im Lab ohne erhabenen Schatten – flach, passend zu den
   randlosen weißen Karten des Dashboards. */
.qlab .qbook__page { box-shadow: none; }

/* ---- Verslayout: NUR im Lab (klassischer Reader unberührt) ---------------- */
.qlab .qayah { gap: 1.2rem; padding: clamp(1.05rem, 2.6vw, 1.5rem) 2.7rem clamp(1.05rem, 2.6vw, 1.5rem) 0; }
.qlab .qayah + .qayah { border-top: 1px solid color-mix(in srgb, var(--secondary) 6%, transparent); }
/* Fußnoten als ruhiger, deutlich sekundärer Block. */
.qlab .ayah-footnotes {
    margin-top: 1.1rem; padding: .85rem 1rem;
    border-top: 0; border-radius: 12px;
    background: color-mix(in srgb, var(--secondary) 3%, var(--surface-mix));
    font-size: .82rem; line-height: 1.55; color: var(--text-muted);
}
.qlab .footnote-ref a { font-size: .58em; opacity: .65; }
.qlab .footnote-ref a:hover, .qlab .footnote-ref a:focus-visible { opacity: 1; color: var(--gold); }
/* Kopier-Aktion dezent sichtbar (nicht erst bei Hover), wird beim Hover deutlich. */
.qlab .qayah__actions { opacity: .35; }
.qlab .qayah:hover .qayah__actions, .qlab .qayah:focus-within .qayah__actions { opacity: 1; }
/* Abschnitts-Überschriften lesen sich als Struktur (dezente Gold-Haarlinie). */
.qlab .qheading { margin: clamp(1.7rem, 3.6vw, 2.3rem) 0 .55rem; padding-bottom: .45rem; border-bottom: 1px solid color-mix(in srgb, var(--gold) 26%, transparent); }

/* Lock-Overlay zentriert über der (begrenzten, verwischten) Lesefläche –
   gilt für beide Ansichten: Vers-für-Vers (.qflow) UND Buchseiten (.qbook). */
.qlab.is-locked .qflow,
.qlab.is-locked .qbook { max-height: 72vh; overflow: hidden; filter: blur(6px); pointer-events: none; user-select: none; }
.qlab .qlock { position: absolute; inset: 0; display: grid; place-items: center; padding: 1.5rem; }

/* ---- Info-Panel (rechte Leiste): Fakten gestapelt + scannbare Beschreibung - */
/* Kompakt: je Fakt eine Zeile – Label links, Wert rechts. */
.qlab__facts { margin: 0 0 .75rem; display: grid; gap: .15rem; }
.qlab__facts > div { display: flex; align-items: baseline; justify-content: space-between; gap: .8rem; padding: .3rem 0; }
.qlab__facts > div + div { border-top: 1px solid color-mix(in srgb, var(--secondary) 7%, transparent); }
.qlab__facts dt { margin: 0; color: var(--text-muted); font-size: .76rem; text-transform: uppercase; letter-spacing: .06em; }
.qlab__facts dd { margin: 0; color: var(--text-strong); font-weight: 600; font-size: .9rem; text-align: right; }
.qlab__desc { margin-top: 1rem; padding-top: .9rem; border-top: 1px solid color-mix(in srgb, var(--secondary) 9%, transparent); }
.qlab__desc p { margin: 0 0 .7rem; font-size: .92rem; line-height: 1.7; color: color-mix(in srgb, var(--text-muted) 85%, var(--text-default)); hyphens: auto; }
.qlab__desc p:first-child { color: var(--text-strong); }
.qlab__desc p:last-child { margin-bottom: 0; }

/* ---- Tablet (861–1200px): 2 Spalten, rechte Leiste einspaltig darunter ----- */
@media (max-width: 1200px) {
    .qlab { grid-template-columns: var(--qlab-rail) minmax(0, 1fr); --qlab-header: 72px; }
    .qlab__rail--right { grid-column: 1 / -1; }
    .qlab__rail--right .qlab__rail-inner {
        position: static; height: auto; overflow: visible; padding-block: 0;
        display: grid; grid-template-columns: 1fr; max-width: 52rem;
    }
}

/* ---- Mobil (≤860px): app-artige Steuerleiste oben + Bottom-Sheets --------- */
@media (max-width: 860px) {
    .qlab { display: block; padding-block: 0 clamp(2rem, 7vw, 3rem); }
    .qlab__main { min-width: 0; }

    .qlab__mbar {
        display: flex; align-items: center; gap: .35rem;
        position: sticky; top: 0; z-index: 30;
        margin: 0 calc(var(--gutter, 16px) * -1) clamp(.85rem, 3vw, 1.3rem);
        padding: .5rem var(--gutter, 16px);
        /* Gleicher Ton wie der Seitenhintergrund – die Leiste verschmilzt mit der Seite. */
        background: var(--bg-page);
    }
    /* Surenname: oben ausgeblendet (die große Überschrift steht direkt darunter –
       keine Dopplung); blendet beim Scrollen ein, sobald die Überschrift weg ist. */
    .qlab__mbar-title {
        flex: 1; min-width: 0; margin: 0 .5rem 0 .25rem;
        font-family: var(--font-display-medium); font-size: 1.12rem; color: var(--text-strong);
        white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
        opacity: 0; transform: translateY(3px);
        transition: opacity .25s var(--ease-out-soft), transform .25s var(--ease-out-soft);
    }
    .qlab.is-name-shown .qlab__mbar-title { opacity: 1; transform: none; }
    .qlab__mbtn {
        flex: none; display: grid; place-items: center;
        width: 2.5rem; height: 2.5rem; border: 0; border-radius: 12px;
        background: transparent; color: var(--secondary); cursor: pointer;
        transition: background var(--transition);
    }
    .qlab__mbtn:hover, .qlab__mbtn[aria-expanded="true"] { background: color-mix(in srgb, var(--secondary) 11%, transparent); }
    .qlab__mbtn:focus-visible { outline: var(--focus-ring); outline-offset: 2px; }
    .qlab__mbtn svg { width: 1.25rem; height: 1.25rem; }

    .qlab__head { max-width: none; padding-top: 0; border-bottom: 0; }
    /* Kein separater Fortschrittsbalken auf Mobil – er sitzt in der Steuerleiste. */
    .qlab__progress { display: none; }
    /* Dünner Fortschrittsbalken an der Unterkante der oberen Steuerleiste. */
    .qlab__mbar .qprogress {
        position: absolute; left: 0; right: 0; bottom: 0;
        height: 3px; border-radius: 0; pointer-events: none;   /* nie Taps der Buttons abfangen */
        background: color-mix(in srgb, var(--secondary) 14%, transparent);
    }
    /* Nur den Zahnrad-Button ausblenden – der Container bleibt, damit das darin
       liegende #qsettings als Bottom-Sheet einblenden kann (sonst würde der
       Sheet von display:none des Containers mit verborgen). Einstellungen
       öffnet auf Mobil der Button in der Steuerleiste (data-lab-sheet). */
    .qlab__titlerow .qlab__settings { position: static; margin: 0; }
    .qlab__titlerow .qlab__settings .qbar__gear { display: none; }

    /* Desktop-Leisten + Einstellungs-Popover werden zu Bottom-Sheets */
    .qlab__rail,
    .qlab #qsettings {
        position: fixed; left: 0; right: 0; bottom: 0; top: auto; z-index: 80;
        display: flex; flex-direction: column;
        width: auto; max-width: none; margin: 0; max-height: 86vh;   /* volle Breite (Popover-Begrenzung aufheben) */
        padding: .55rem 0 var(--sab, 0px);   /* Inhalt frei vom Home-Indicator */
        border-radius: 22px 22px 0 0;
        background: var(--surface-raised);
        box-shadow: 0 -12px 44px -20px rgba(0, 0, 0, .55);
        /* Geschlossen: weit unter den Bildschirm UND unsichtbar geschaltet, damit
           weder ein Rand noch der nach oben fallende Schatten am unteren Rand
           „durchspickt" (translateY allein ließ je nach Gerät einen Spalt). */
        transform: translateY(120%);
        visibility: hidden;
        transition: transform .34s var(--ease-out-soft), visibility 0s linear .34s;
    }
    .qlab #qsettings,
    .qlab #qsettings[hidden] { display: flex; }
    .qlab__rail.is-sheet,
    .qlab #qsettings.is-sheet {
        transform: translateY(0); visibility: visible;
        transition: transform .34s var(--ease-out-soft), visibility 0s;
    }
    .qlab__rail::before,
    .qlab #qsettings::before {
        content: ""; flex: none; width: 2.5rem; height: 4px;
        margin: 0 auto .55rem; border-radius: 999px;
        background: color-mix(in srgb, var(--secondary) 22%, transparent);
    }
    .qlab__rail-inner {
        position: static; height: auto; max-height: none; flex: 1 1 auto; min-height: 0;
        overflow: auto; overscroll-behavior: contain;
        padding: 0 clamp(1.2rem, 4vw, 1.6rem) clamp(1.3rem, 5vw, 1.8rem);
        grid-template-columns: 1fr;
        background: transparent; border-radius: 0;   /* das Sheet selbst ist die Fläche */
    }
    .qlab #qsettings {
        gap: 1.1rem;
        padding: .55rem clamp(1.3rem, 4vw, 1.7rem) clamp(1.4rem, 5vw, 1.8rem);
        overflow: auto; overscroll-behavior: contain;
    }
    /* Sheet-Scrollbalken ebenfalls ausgeblendet (konsistent mit den Leisten). */
    .qlab__rail-inner, .qlab #qsettings { scrollbar-width: none; }
    .qlab__rail-inner::-webkit-scrollbar, .qlab #qsettings::-webkit-scrollbar { display: none; }

    .qlab__scrim { display: block; position: fixed; inset: 0; z-index: 75; background: rgba(15, 25, 40, .42); }
    .qlab__scrim[hidden] { display: none; }
}

/* ---- Dunkelmodus: dezente, sichtbare Tönungen auf den dunklen Flächen -----
   Karten/Lesefläche folgen automatisch via --surface-card; hier nur die
   subtilen, auf Dunkel sichtbaren Tönungen (sonst „unsichtbar" auf der Karte). */
html[data-theme="dark"] .qlab { --qlab-panel: color-mix(in srgb, #fff 5%, transparent); }  /* milchig, aber nicht grell auf Dunkel */
html[data-theme="dark"] .qlab__surah:hover { background: color-mix(in srgb, #fff 9%, transparent); }
html[data-theme="dark"] .qlab__surah-num { background: color-mix(in srgb, #fff 9%, transparent); }
html[data-theme="dark"] .qlab .ayah-footnotes { background: color-mix(in srgb, #fff 5%, transparent); }
