/* ==============================================
   DGZS Dossier-Generator — Bavaria Entertainment
   Tool-spezifisches CSS über dem Tinte-Kanon.

   Lade-Reihenfolge (in base.html/login.html):
     pico -> bavaria-theme.css (Tokens) -> tinte-base.css (Komponenten) -> style.css
   Palette (--t-*), Chrome (site-header/tab-nav/site-footer), Typografie und
   Buttons kommen jetzt aus dem Kanon (BENT-1652). Hier bleibt nur, was wirklich
   tool-eigen ist: Status-Pills, Buzz-Pill, Dossier-History, Batch-Ergebnisliste,
   Download-/Pitch-Buttons, Dropzone, Login-Card.
   ============================================== */

/* --- Tool-lokaler Alias-Shim (--be-*): mappt die tool-eigenen Komponenten auf
   die kanonischen --t-*-Tokens aus bavaria-theme.css. Theme-aware, weil die
   --t-* im Kanon Dark-Varianten haben. --be-radius kommt aus bavaria-theme.css. --- */
:root {
    --be-teal:              var(--t-teal);
    --be-teal-hover:        var(--t-teal-hi);
    --be-teal-focus:        var(--t-teal-tint);
    --be-body-bg:           var(--t-bg);
    --be-card-bg:           var(--t-card);
    --be-card-border:       var(--t-rule);
    --be-text:              var(--t-ink);
    --be-text-muted:        var(--t-muted);
    --be-badge-green:       var(--t-green);
    --be-badge-green-bg:    var(--t-green-tint);
    --be-badge-red:         var(--t-red);
    --be-badge-red-bg:      var(--t-red-tint);
}


/* ========================================
   UTILITIES
   ======================================== */

.hidden { display: none !important; }

.mono,
.tabular {
    font-family: var(--f-mono);
    font-variant-numeric: tabular-nums;
}


/* ========================================
   STATUS-PILLS (tool-eigen, im Header)
   „Verbunden mit meinGPT" + Auth-Indikator
   ======================================== */

.status-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.status-dot {
    width: 6px;
    height: 6px;
    border-radius: 3px;
    background: var(--t-green);
}

.status-pill--auth .status-dot {
    background: var(--t-teal, var(--t-green));
}


/* ========================================
   CARDS
   ======================================== */

.card {
    background-color: var(--be-card-bg);
    border: 1px solid var(--be-card-border);
    border-radius: var(--be-radius);
    padding: 1.5rem;
    margin-bottom: 1.5rem;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}

.card header {
    padding: 0;
    margin-bottom: 1rem;
    border-bottom: none;
}

.card header h1 { margin-bottom: 0.25rem; }
.card header p { color: var(--be-text-muted); margin: 0; }


/* ========================================
   STATUS-BANNER (Generierungs-Feedback)
   ======================================== */

.status {
    padding: 0.75rem;
    border-radius: var(--be-radius);
    font-size: 0.9rem;
    text-align: center;
    margin-bottom: 1rem;
}

.status:empty { display: none; }
.status.loading { background: var(--t-teal-tint); color: var(--t-teal); }
.status.success { background: var(--be-badge-green-bg); color: var(--be-badge-green); }
.status.error { background: var(--be-badge-red-bg); color: var(--be-badge-red); }
.status.warning { background: var(--t-amber-tint); color: var(--t-amber); }

/* BENT-657: Buzz-Insights-Pill — sichtbar machen, dass der Dossier-Generator
   den Presse-Spiegel aus dgzs-buzz integriert hat. Amber-Token signalisiert
   „Cross-Tool-Anreicherung", visuell zwischen Status und Download. */
.buzz-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.45rem 0.85rem;
    margin-bottom: 0.75rem;
    background: var(--t-amber-tint);
    color: var(--t-amber);
    border: 1px solid var(--t-rule);
    border-radius: 999px;
    font-size: 0.85rem;
    font-weight: 500;
}
.buzz-pill--empty {
    background: var(--t-hairline);
    color: var(--t-muted);
}

.hint-text {
    font-size: 0.875rem;
    color: var(--be-text-muted);
    margin-top: 0.5rem;
    margin-bottom: 0;
}


/* ========================================
   LOG
   ======================================== */

.log-entry {
    font-size: 0.85rem;
    color: var(--be-text);
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--t-hairline);
}

.log-entry:last-child { border-bottom: none; }


/* ========================================
   DOWNLOAD BUTTON (BENT-707)
   Kompakte Pille im Card-Footer.
   ======================================== */

.download-btn {
    display: inline-block;
    box-sizing: border-box;
    margin: 0;
    padding: 0.4rem 0.9rem;
    background: var(--be-teal);
    color: #fff;
    border: 1px solid var(--be-teal);
    border-radius: var(--be-radius);
    font-size: 0.9rem;
    line-height: 1.2;
    cursor: pointer;
    text-align: center;
    text-decoration: none;
}

.download-btn:hover {
    background: var(--be-teal-hover);
    border-color: var(--be-teal-hover);
    color: #fff;
}


/* ========================================
   BATCH RESULTS
   ======================================== */

textarea {
    font-family: inherit;
    resize: vertical;
}

.result-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.6rem 0;
    border-bottom: 1px solid var(--t-hairline);
    font-size: 0.9rem;
}

.result-row:last-child { border-bottom: none; }
.result-name { font-weight: 600; }

/* Status-Zelle hält Label + optionalen Download- + Retry-Button
   nebeneinander; gap statt inline margin-left aus dem JS (BENT-707). */
.result-status {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.result-row.waiting .result-status { color: var(--be-text-muted); }
.result-row.active .result-status { color: var(--t-teal); }
.result-row.done .result-status { color: var(--be-badge-green); }
.result-row.error .result-status { color: var(--be-badge-red); }

.result-time { font-size: 0.8rem; color: var(--be-text-muted); }

.result-download {
    background: var(--be-teal);
    color: #fff;
    padding: 0.25rem 0.7rem;
    border-radius: 3px;
    text-decoration: none;
    font-size: 0.8rem;
    line-height: 1.2;
}

.result-download:hover {
    background: var(--be-teal-hover);
    color: #fff;
}


/* ========================================
   ACTION-PILLS (BENT-707/730)
   Kompakte inline-Outline-Buttons für Card-Footer, Banner, Job-Listen.
   ======================================== */

.reset-btn,
.retry-btn,
.abort-btn {
    display: inline-block;
    box-sizing: border-box;
    width: auto;
    margin: 0;
    padding: 0.4rem 0.9rem;
    font-size: 0.9rem;
    line-height: 1.2;
}

.abort-btn {
    border-color: var(--be-badge-red);
    color: var(--be-badge-red);
}

.abort-btn:hover {
    background-color: var(--be-badge-red);
    border-color: var(--be-badge-red);
    color: #fff;
}

.batch-actions-row,
.single-actions-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: stretch;
    margin-top: 0.75rem;
}

.batch-actions-row > *,
.single-actions-row > * {
    margin: 0;
}

.retry-single-btn {
    padding: 0.2rem 0.6rem;
    font-size: 0.8rem;
    line-height: 1.2;
}

#resume-banner button,
#server-jobs button {
    padding: 0.25rem 0.7rem;
    font-size: 0.85rem;
    line-height: 1.2;
}

.upload-disabled-hint {
    font-size: 0.875rem;
    color: var(--be-text-muted);
}

.batch-preview {
    margin-top: 0.5rem;
}

.failed-textarea {
    font-size: 0.8rem;
    background: var(--be-badge-red-bg);
    border-color: var(--be-badge-red);
    margin-top: 0.5rem;
}

.download-hint {
    text-align: center;
}


/* ========================================
   DROPZONE (tool-eigener Upload)
   ======================================== */

.dropzone {
    border: 2px dashed var(--be-card-border);
    border-radius: 8px;
    padding: 1.5rem;
    text-align: center;
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s;
    margin-bottom: 1rem;
}
.dropzone:hover,
.dropzone.dragover {
    border-color: var(--be-teal);
    background: var(--be-teal-focus);
}
.dropzone p { margin: 0 0 0.25rem; }
.dropzone small { color: var(--be-text-muted); }
.file-list {
    list-style: none;
    padding: 0;
    margin: 0.75rem 0 0;
    text-align: left;
}
.file-list li {
    padding: 0.25rem 0;
    font-size: 0.9rem;
    border-bottom: 1px solid var(--be-card-border);
}
.file-list li a {
    color: var(--be-text-muted);
    margin-left: 0.5rem;
    text-decoration: none;
}
.file-list li a:hover { color: var(--be-badge-red); }


/* ========================================
   HISTORY (BENT-707)
   ======================================== */

.history-card {
    margin-top: 2rem;
}

.history-subtitle {
    margin: 0;
}

.server-jobs-list {
    margin: 0;
    padding-left: 1.2rem;
}

.server-jobs-list li {
    margin-bottom: 0.4rem;
}

.history-show {
    opacity: 0.7;
}

.dossier-history {
    list-style: none;
    padding: 0;
    margin: 0;
}

.dossier-history li {
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--t-hairline);
}

.dossier-history li:last-child { border-bottom: none; }

.history-entry {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.history-name {
    font-weight: 600;
    font-size: 0.9rem;
}

.history-meta {
    color: var(--be-text-muted);
    font-size: 0.8rem;
}

.history-actions {
    margin-left: auto;
    display: flex;
    gap: 0.5rem;
}

.history-link {
    background: var(--be-teal);
    color: #fff;
    padding: 0.2rem 0.5rem;
    border-radius: 3px;
    text-decoration: none;
    font-size: 0.8rem;
}

.history-link:hover {
    background: var(--be-teal-hover);
    color: #fff;
}


/* ========================================
   PITCH BUTTON (BENT-707)
   ======================================== */

.pitch-generate-btn {
    display: inline-block;
    box-sizing: border-box;
    width: auto;
    margin: 0;
    padding: 0.4rem 0.9rem;
    font-size: 0.9rem;
    line-height: 1.2;
}


/* ========================================
   FOOTER-LINKS (tool-eigen: Impressum/Datenschutz)
   ======================================== */

.footer-links {
    display: flex;
    gap: 1.5rem;
}

.footer-links a {
    color: var(--be-text-muted);
    text-decoration: none;
    font-size: 0.85rem;
    transition: color 0.2s ease;
}

.footer-links a:hover { color: var(--be-teal); }

@media (max-width: 576px) {
    .footer-content {
        flex-direction: column;
        text-align: center;
    }
}


/* ========================================
   AUTH — Login-Seite (BENT-837)
   ======================================== */

.login-main {
    min-height: 70vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 48px 16px;
}

.login-card {
    width: 100%;
    max-width: 380px;
    background: var(--t-card, #fff);
    border: 1px solid var(--t-rule, #e2e2e2);
    border-radius: 12px;
    padding: 32px;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.06);
}

.login-brand {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    margin-bottom: 24px;
    text-align: center;
}

.login-brand .brand-mark {
    margin-bottom: 8px;
}

.login-card form {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.login-error {
    color: var(--t-red, #b3261e);
    background: var(--t-red-tint, rgba(179, 38, 30, 0.08));
    border-radius: 8px;
    padding: 10px 12px;
    margin-bottom: 16px;
    font-size: 14px;
    text-align: center;
}
