/* Docuflair E-Rechnung — df4-Look (dunkle Kopfzeile, roter Akzent), lokal, kein CDN */
:root {
    --df-dark: #1e293b;
    --df-accent: #c63010;
    --df-accent-dark: #a3260b;
    --df-accent-subtle: #fdf0ec;
    --df-bg: #f4f5f7;
    --df-bg-card: #ffffff;
    --df-bg-inset: #f8fafc;
    --df-border: #e3e5e8;
    --df-border-light: #eef0f2;
    --df-text: #222222;
    --df-text-secondary: #475569;
    --df-text-muted: #6c757d;
    --df-success: #1d7a33;
    --df-radius: .6rem;
    --df-radius-sm: .4rem;
    --df-shadow: 0 .4rem 1rem rgba(0,0,0,.08);
    --df-shadow-sm: 0 .15rem .4rem rgba(0,0,0,.05);
}

body {
    background: var(--df-bg);
    color: var(--df-text);
    font-family: "Segoe UI", system-ui, -apple-system, Arial, sans-serif;
}

a { color: var(--df-accent); }
a:hover { color: var(--df-accent-dark); }

.skip-link {
    position: absolute; left: -999px; top: 0; z-index: 1000;
    background: #fff; padding: .5rem 1rem; border: 2px solid var(--df-accent);
}
.skip-link:focus { left: .5rem; top: .5rem; }

/* Header (nicht sticky — wie Convert/Velkaris) */
.df-header { background: var(--df-dark); box-shadow: 0 1px 2px rgba(0, 0, 0, .12); }
/* Logo-Anker selbst zentrieren (wie Convert/redact-Demo): Logo als Flex-Item ohne Inline-Baseline-Lücke, kein vertikales .navbar-brand-Padding. */
.df-header .navbar-brand { display: flex; align-items: center; padding-top: 0; padding-bottom: 0; }
.df-header .navbar-brand img { height: 28px; display: block; }
/* Gap zwischen Logo, Produktname, Badge und CTA wie Convert/redact (.df-brand-group: 0.75rem). */
.df-brand-group { gap: 0.75rem; }
.df-header .navbar { min-height: 52px; padding-top: 0; padding-bottom: 0; padding-left: 1.25rem; padding-right: 1.25rem; }

/* Fokus-Indikatoren im Header (WCAG 2.4.7, wie Convert): heller Ring auf Slate. */
.df-cta:focus-visible, .df-iconbtn:focus-visible, .df-lang .dropdown-toggle:focus-visible,
.navbar-brand:focus-visible, .navbar-toggler:focus-visible {
    outline: 2px solid #fff; outline-offset: 2px;
}
/* Sprach-Dropdown-Einträge (auf Karte). */
.df-lang .dropdown-item:focus-visible { outline: 2px solid var(--df-accent); outline-offset: -2px; }

/* Topbar: Produktname + Gratis-Badge + grüner Outline-CTA + Theme-Toggle (analog convert.docuflair.com) */
.df-product-name { color: #fff; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; font-size: 1rem; line-height: 1; }
/* Marken-Amber für die BS5-.badge (rounded-pill, text-uppercase kommen aus Utilities im Markup) */
.df-demo-badge { background: #f59e0b; color: #1e293b; letter-spacing: .5px; }
.df-cta {
    display: inline-flex; align-items: center; gap: .4rem; text-decoration: none;
    color: #e9ecef; background: transparent; border: 1px solid rgba(255,255,255,.25);
    padding: .3rem .8rem; border-radius: .4rem; font-size: .9rem; font-weight: 500;
    transition: background .15s, color .15s, border-color .15s;
}
.df-cta:hover, .df-cta:focus { color: #fff; background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.45); text-decoration: none; }
.df-cta-outline-green { color: #16a34a; border-color: #16a34a; }
.df-cta-outline-green:hover, .df-cta-outline-green:focus { background: #16a34a; border-color: #16a34a; color: #fff; }
.df-iconbtn {
    display: inline-grid; place-items: center; width: 34px; height: 34px;
    color: #e9ecef; background: transparent; border: 1px solid rgba(255,255,255,.25);
    border-radius: .4rem; cursor: pointer; transition: background .15s, color .15s, border-color .15s;
}
.df-iconbtn:hover, .df-iconbtn:focus { color: #fff; background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.45); }
.df-iconbtn .icon-sun { display: none; }
[data-theme="dark"] .df-iconbtn .icon-moon { display: none; }
[data-theme="dark"] .df-iconbtn .icon-sun { display: inline; }

/* Sprach-Umschalter im df-Stil (umrandeter Button + theme-aware Dropdown, wie Theme-Toggle/CTA) */
.df-lang .dropdown-toggle {
    display: inline-flex; align-items: center; gap: .4rem;
    color: #e9ecef; background: transparent; border: 1px solid rgba(255,255,255,.25);
    padding: .3rem .7rem; border-radius: .4rem; font-size: .9rem; font-weight: 500;
}
.df-lang .dropdown-toggle:hover, .df-lang .dropdown-toggle:focus { color: #fff; background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.45); }
.df-lang .dropdown-menu {
    --bs-dropdown-min-width: 11rem; --bs-dropdown-bg: var(--df-bg-card); --bs-dropdown-color: var(--df-text);
    --bs-dropdown-border-color: var(--df-border); --bs-dropdown-link-color: var(--df-text);
    --bs-dropdown-link-hover-bg: var(--df-bg-inset); --bs-dropdown-link-hover-color: var(--df-text);
    box-shadow: var(--df-shadow); border-radius: .4rem;
}
.df-lang .dropdown-item.active { background: var(--df-accent); color: #fff; }
/* Zweispaltiger Menüeintrag: Sprachcode (gedämpft, feste Spalte) + Name — wie Convert/redact (.vk-lang-switcher-item). */
.df-lang .df-lang-item { display: flex; align-items: center; gap: 10px; }
.df-lang .df-lang-code { display: inline-block; width: 28px; flex: 0 0 28px; font-weight: 600; font-size: .72rem; letter-spacing: .5px; opacity: .7; }
.df-lang .df-lang-item.active .df-lang-code { opacity: 1; color: #fff; }

/* Hero */
.df-hero {
    background: linear-gradient(180deg, #3a3a3a 0%, var(--df-dark) 100%);
    color: #fff; padding: 3rem 0 2.5rem;
}
.df-hero h1 { font-weight: 700; }
.df-hero .lead { color: #d6d8db; }
.df-trust { color: #cfd2d6; font-size: .95rem; }
.df-trust .fa-check { color: #56b561; }

/* Trust-Pills (Hero) — Container-Layout via Utilities (list-unstyled d-flex flex-wrap gap-2) im Markup */
.df-trust-pills li {
    display: inline-flex; align-items: center; gap: .4rem;
    padding: .35rem .85rem; border-radius: 999px;
    background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.18);
    color: #e9ecef; font-size: .82rem; font-weight: 500; line-height: 1.2; white-space: nowrap;
}
.df-trust-pills li .fa { color: #56b561; }

/* Produkt-Visual: "Fenster"-Mockup */
.df-eyebrow {
    font-size: .72rem; font-weight: 700; letter-spacing: .1em;
    text-transform: uppercase; color: var(--df-accent); margin-bottom: .4rem;
}
.df-window {
    border: 1px solid var(--df-border); border-radius: var(--df-radius);
    overflow: hidden; box-shadow: var(--df-shadow); background: var(--df-bg-card);
}
.df-window-bar {
    display: flex; align-items: center; gap: 6px; padding: .6rem .85rem;
    background: var(--df-bg-inset); border-bottom: 1px solid var(--df-border);
}
.df-window-dot { width: 9px; height: 9px; border-radius: 50%; }
.df-window-dot.r { background: #ff5f57; }
.df-window-dot.y { background: #febc2e; }
.df-window-dot.g { background: #28c840; }
.df-window-bar .fname { font-size: .74rem; color: var(--df-text-muted); margin-left: .4rem; }
.df-window-body { padding: 1rem 1.2rem; margin: 0; font-size: .78rem; line-height: 1.7;
    color: var(--df-text-secondary); background: #1e2227; color: #e6e6e6; overflow-x: auto; }
.df-window-body .k { color: #7ee0a2; }
.df-window-body .v { color: #ffd479; }

/* Dropzone */
.df-dropzone {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: .5rem; padding: 1.9rem 1rem;
    border: 2px dashed #cbd5e1; border-radius: 10px;
    background: var(--df-bg-inset); color: var(--df-text-secondary);
    text-align: center; cursor: pointer; outline: none;
    transition: border-color .15s, background .15s, color .15s;
}
.df-dropzone .df-dz-icon { font-size: 2.1rem; opacity: .85; color: inherit; }
.df-dropzone:hover, .df-dropzone:focus-within, .df-dropzone.dragover {
    border-color: var(--df-accent); background: var(--df-accent-subtle); color: var(--df-accent);
}
[data-theme="dark"] .df-dropzone { border-color: #3a4150; }
.df-dz-hint { color: var(--df-text-muted); font-size: .8rem; }

/* Datei-Liste unter der Dropzone (Design-Basis: convert.docuflair.com) */
.df-filelist { list-style: none; margin: 0; padding: 0; }
.df-file-item {
    display: flex; align-items: center; gap: .6rem; text-align: left;
    background: var(--df-bg-inset); border: 1px solid var(--df-border-light); border-radius: var(--df-radius-sm);
    padding: .5rem .7rem; margin-bottom: .4rem;
}
.df-file-item .df-file-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 500; }
.df-file-item .df-file-size { color: var(--df-text-muted); font-size: .82rem; }
.df-file-item .df-file-size.too-big { color: var(--df-accent); font-weight: 600; }
.df-file-btn {
    display: inline-grid; place-items: center; width: 26px; height: 26px; flex-shrink: 0;
    border: 1px solid var(--df-border); border-radius: 4px; background: transparent;
    color: var(--df-text-muted); cursor: pointer; font-size: .8rem;
    transition: color .15s, border-color .15s, background .15s;
}
.df-file-btn:hover, .df-file-btn:focus-visible { color: var(--df-accent); border-color: var(--df-accent); background: var(--df-accent-subtle); }
.df-inline-error { color: var(--df-accent); font-size: .85rem; }

/* Tool cards */
.df-tool-card {
    display: block; height: 100%; background: var(--df-bg-card); border: 1px solid var(--df-border);
    border-radius: .6rem; padding: 1.25rem; text-decoration: none; color: inherit;
    transition: box-shadow .15s, transform .15s, border-color .15s;
}
.df-tool-card:hover, .df-tool-card:focus {
    box-shadow: var(--df-shadow); transform: translateY(-2px);
    border-color: var(--df-accent); color: inherit;
}
.df-tool-card .df-tool-icon { color: var(--df-accent); font-size: 1.6rem; }

/* Section rhythm: Utility my-5 (= 3rem) im Markup statt .df-section */
/* "soft" lifted cards (Steps / Why) */
.df-soft {
    background: var(--df-bg-card); border: 1px solid var(--df-border);
    border-radius: var(--df-radius); transition: box-shadow .15s, transform .15s;
}
.df-soft:hover { box-shadow: var(--df-shadow); transform: translateY(-2px); }
.df-step-num {
    flex-shrink: 0; width: 28px; height: 28px; display: inline-flex; align-items: center;
    justify-content: center; background: var(--df-accent); color: #fff; border-radius: 999px;
    font-weight: 600; font-size: .85rem;
}
.df-usp-ico { flex-shrink: 0; color: var(--df-success); margin-top: 1px; }

/* Vergleichstabelle — Scroll-Wrapper via BS5 .table-responsive im Markup */
.df-cmp { width: 100%; border-collapse: collapse; font-size: .88rem; }
.df-cmp thead th {
    text-align: left; padding: .55rem .6rem; border-bottom: 2px solid var(--df-border);
    font-weight: 600; color: var(--df-text-secondary); white-space: nowrap;
}
.df-cmp thead .df-cmp-own { color: var(--df-success); background: rgba(34,197,94,.08); border-bottom-color: #16a34a; }
.df-cmp tbody th { text-align: left; padding: .55rem .6rem; font-weight: 500; color: var(--df-text); border-bottom: 1px solid var(--df-border-light); }
.df-cmp tbody td { padding: .55rem .6rem; border-bottom: 1px solid var(--df-border-light); white-space: nowrap; }
.df-cmp tbody tr:last-child th, .df-cmp tbody tr:last-child td { border-bottom: 0; }
.df-cmp-yes { color: #16a34a; font-weight: 600; background: rgba(34,197,94,.05); }
.df-cmp-no { color: #94a3b8; }
.df-cmp-partial { color: #d97706; }

/* FAQ */
.df-faq { border: 1px solid var(--df-border); border-radius: 8px; padding: .6rem .9rem; margin-bottom: .5rem; background: var(--df-bg-card); }
.df-faq summary { cursor: pointer; font-weight: 500; color: var(--df-text); }
.df-faq[open] summary { margin-bottom: .5rem; }
.df-faq p { margin: 0; color: var(--df-text-secondary); font-size: .92rem; }

/* Buttons — Marken-Variante über die nativen BS5-Button-Variablen
   (Hover/Active/Disabled/Focus-Ring kommen damit korrekt aus .btn; Markup: class="btn btn-df") */
.btn-df {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--df-accent);
    --bs-btn-border-color: var(--df-accent);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--df-accent-dark);
    --bs-btn-hover-border-color: var(--df-accent-dark);
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: var(--df-accent-dark);
    --bs-btn-active-border-color: var(--df-accent-dark);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: var(--df-accent);
    --bs-btn-disabled-border-color: var(--df-accent);
    --bs-btn-focus-shadow-rgb: 198, 48, 16;
}

/* Funnel CTA */
.df-funnel {
    background: var(--df-bg-card); border: 1px solid var(--df-border); border-left: 4px solid var(--df-accent);
    border-radius: .5rem; padding: 1.25rem 1.5rem;
}

/* Result status */
.df-status-ok { color: #1d7a33; }
.df-status-bad { color: var(--df-accent); }
.df-badge-rule {
    font-family: ui-monospace, "Cascadia Code", Consolas, monospace;
    background: #2b2f33; color: #fff; border-radius: .25rem; padding: .1rem .4rem; font-size: .82rem;
}
.df-card { background: var(--df-bg-card); border: 1px solid var(--df-border); border-radius: .6rem; }
.df-xml-preview {
    background: #1e2227; color: #e6e6e6; border-radius: .4rem; padding: 1rem;
    max-height: 22rem; overflow: auto; font-size: .82rem; white-space: pre; word-break: normal;
}

footer.df-footer { background: var(--df-dark); color: #cfd2d6; }
footer.df-footer a { color: #fff; text-decoration: none; }
footer.df-footer a:hover { color: #fff; text-decoration: underline; }
/* Datenschutz-Hinweis: Utilities "small text-muted" im Markup statt .df-privacy */

/* Theme-korrekte Tabellen: BS5-Table-Variablen an die df-Variablen koppeln.
   Das Theme setzt nur data-theme (nie data-bs-theme) — ohne diese Kopplung rendert
   Bootstrap im Dark-Mode dunkle Schrift auf dunkler Karte. */
.table {
    --bs-table-color: var(--df-text); --bs-table-bg: transparent;
    --bs-table-border-color: var(--df-border);
    color: var(--df-text); border-color: var(--df-border);
}

/* Lesbare Rechnungsdarstellung ("Anzeigen" / Prüfen / Extrahieren) — Dokument-Look */
.df-inv { padding: 1.5rem; }
@media (min-width: 768px) { .df-inv { padding: 2.25rem 2.5rem; } }
/* Überschriften folgen dem Theme (vorher var(--df-dark) → im Dark-Mode unsichtbar) */
.df-invoice-view h2, .df-invoice-view h3 { color: var(--df-text); }

.df-inv-head {
    display: flex; flex-wrap: wrap; gap: 1rem; justify-content: space-between; align-items: flex-start;
    border-bottom: 2px solid var(--df-accent); padding-bottom: 1rem; margin-bottom: 1.25rem;
}
.df-inv-number { font-size: 1.5rem; font-weight: 700; margin: 0; letter-spacing: -.01em; }
.df-inv-headtotal { text-align: right; }
.df-inv-headtotal-label { font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: var(--df-text-muted); }
.df-inv-headtotal-value { font-size: 1.6rem; font-weight: 700; color: var(--df-accent); font-variant-numeric: tabular-nums; line-height: 1.2; }
.df-inv-headtotal-due { font-size: .85rem; color: var(--df-text-secondary); }

/* Meta-Chips: Label oben (Kleinkapitälchen), Wert darunter */
.df-inv-meta { display: flex; flex-wrap: wrap; gap: .6rem 2rem; margin: 0 0 1.25rem; }
.df-inv-meta > div { min-width: 7rem; }
.df-inv-meta dt { font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: var(--df-text-muted); margin-bottom: .1rem; }
.df-inv-meta dd { margin: 0; font-size: .92rem; }

/* Parteien als Inset-Panels */
.df-inv-party { background: var(--df-bg-inset); border: 1px solid var(--df-border-light); border-radius: var(--df-radius-sm); padding: .9rem 1.1rem; height: 100%; }
.df-inv-party-label { font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; color: var(--df-text-muted); margin-bottom: .4rem; }
.df-inv-party-label .fa { color: var(--df-accent); }
.df-inv-party-name { font-weight: 600; margin-bottom: .15rem; }

.df-inv-section { font-size: .8rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--df-text-secondary); margin-bottom: .5rem; }
.df-inv-section .fa { color: var(--df-accent); }

/* Beträge mit Tabellenziffern — Spalten "tanzen" nicht */
.df-num { font-variant-numeric: tabular-nums; white-space: nowrap; }
.df-inv-table { margin-bottom: .5rem; font-size: .92rem; }
.df-inv-table thead th { font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .06em; color: var(--df-text-muted); border-bottom: 2px solid var(--df-border); white-space: nowrap; }
.df-inv-table tbody td { border-bottom-color: var(--df-border-light); padding-top: .55rem; padding-bottom: .55rem; }
.df-inv-table tbody tr:last-child td { border-bottom: 0; }
.df-inv-table-sub { font-size: .85rem; }

/* Summen-Box mit prominentem Zahlbetrag */
.df-inv-totals { background: var(--df-bg-inset); border: 1px solid var(--df-border-light); border-radius: var(--df-radius-sm); padding: 1rem 1.25rem; }
.df-inv-totals-row { display: flex; justify-content: space-between; gap: 1rem; padding: .2rem 0; font-size: .92rem; color: var(--df-text-secondary); }
.df-inv-payable { display: flex; justify-content: space-between; align-items: baseline; gap: 1rem; border-top: 2px solid var(--df-accent); margin-top: .5rem; padding-top: .6rem; font-weight: 700; }
.df-inv-payable-amt { font-size: 1.35rem; color: var(--df-accent); }

/* Zahlungs-Block: GiroCode (EPC-QR) + IBAN/BIC-Chips mit Copy-Button */
.df-inv-pay { border-top: 1px solid var(--df-border-light); padding-top: 1rem; margin-top: .5rem; }
.df-inv-qr { width: 138px; text-align: center; }
.df-inv-qr svg { display: block; width: 138px; height: 138px; background: #fff; border: 1px solid var(--df-border); border-radius: var(--df-radius-sm); }
.df-inv-qr figcaption { font-size: .72rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--df-text-muted); margin-top: .3rem; }
.df-inv-paydata { display: grid; grid-template-columns: max-content 1fr; gap: .25rem 1rem; margin: 0; font-size: .92rem; }
.df-inv-paydata > div { display: contents; }
.df-inv-paydata dt { font-weight: 500; color: var(--df-text-secondary); }
.df-inv-paydata dd { margin: 0; }
.df-inv-code { display: inline-flex; align-items: center; gap: .35rem; }
.df-inv-code code { background: var(--df-bg-inset); border: 1px solid var(--df-border-light); border-radius: .3rem; padding: .1rem .45rem; color: var(--df-text); font-size: .88em; }
.df-copybtn {
    display: inline-grid; place-items: center; width: 26px; height: 26px;
    border: 1px solid var(--df-border); border-radius: .3rem; background: var(--df-bg-card);
    color: var(--df-text-secondary); cursor: pointer; transition: color .15s, border-color .15s, background .15s;
}
.df-copybtn:hover, .df-copybtn:focus-visible { color: var(--df-accent); border-color: var(--df-accent); background: var(--df-accent-subtle); }
.df-copybtn.copied { color: var(--df-success); border-color: var(--df-success); background: transparent; }

.df-inv-notes { border-top: 1px solid var(--df-border-light); padding-top: 1rem; margin-top: 1rem; }

/* Erstellen-Wizard (Stepper + Schritt-Panes + aufklappbare „Weitere"-Blöcke) */
.df-stepper { padding: 0; }
.df-stepper-item {
    display: inline-flex; align-items: center; gap: .4rem;
    padding: .25rem .7rem .25rem .35rem; border-radius: 999px; font-size: .85rem;
    color: var(--df-text-muted); background: var(--df-bg-inset); border: 1px solid var(--df-border);
}
.df-stepper-item .df-step-num { width: 22px; height: 22px; font-size: .72rem; background: var(--df-text-muted); }
.df-stepper-item.active { color: var(--df-text); border-color: var(--df-accent); }
.df-stepper-item.active .df-step-num { background: var(--df-accent); }
.df-stepper-item.done .df-step-num { background: var(--df-success); }
.df-stepper[data-interactive] .df-stepper-item { cursor: pointer; }
.df-stepper[data-interactive] .df-stepper-item:focus-visible { outline: 2px solid var(--df-accent); outline-offset: 2px; }
@media (max-width: 575.98px) { .df-stepper-label { display: none; } }

.df-item .form-label.small { margin-bottom: .15rem; font-weight: 500; }
.df-more > summary { cursor: pointer; }
.df-more[open] > summary { margin-bottom: .35rem; }
.df-wizard-nav { position: sticky; bottom: 0; background: var(--df-bg-card); }

/* Inline-USt-Prüfungs-Ergebnis am Parteien-Feld (Erstellen): kontrastsichere Status-Farben in beiden Themes. */
[data-vat-result] { margin-top: .25rem; min-height: 1.1em; }
[data-vat-result].text-success { color: var(--df-success) !important; }
[data-vat-result].text-danger { color: var(--df-accent) !important; }
[data-vat-result].text-warning { color: #b45309 !important; }
[data-theme="dark"] [data-vat-result].text-danger { color: #f87171 !important; }
[data-theme="dark"] [data-vat-result].text-warning { color: #fbbf24 !important; }


[data-theme="dark"] {
    --df-bg: #15181d;
    --df-bg-card: #1e2228;
    --df-bg-inset: #23272e;
    --df-border: #2c313a;
    --df-border-light: #262b33;
    --df-text: #e6e8eb;
    --df-text-secondary: #aeb6c2;
    --df-text-muted: #8a93a0;
    --df-accent-subtle: #2a1a16;
    --df-success: #4ade80;
    --df-shadow: 0 .4rem 1rem rgba(0,0,0,.45);
}
[data-theme="dark"] .text-muted { color: var(--df-text-muted) !important; }
[data-theme="dark"] .df-cmp-no { color: #6b7280; }
[data-theme="dark"] .df-window-body { background: #11141a; }

/* Druckansicht: nur die Rechnung, ohne Navigation/Funnel/Buttons */
@media print {
    header.df-header, footer.df-footer, .df-funnel, .df-print-hide, nav { display: none !important; }
    .df-invoice-view { border: 0 !important; box-shadow: none !important; padding: 0 !important; }
    /* Drucker entfernen Hintergründe — Panels nur mit Rahmen drucken; GiroCode bleibt sichtbar */
    .df-inv-party, .df-inv-totals, .df-inv-code code { background: #fff !important; }
    a[href]:after { content: ""; }
    body { background: #fff; }
}

/* FormGuard-Honeypot (Bot-Schutz): für Menschen unsichtbar — Bots füllen das Feld trotzdem aus.
   Bewusst per Off-Screen-Positionierung statt display:none (manche Bots überspringen display:none). */
.fg-trap { position: absolute !important; left: -9999px !important; top: auto !important; width: 1px; height: 1px; overflow: hidden; }
