/* ========================================================================
   Confessions II — Visual Layer (Light, contrast-first)
   Layered AFTER app.css. Bone-white canvas, deep-plum text, magenta &
   lavender accents — Confessions DNA without the eye-strain.
   ======================================================================== */

:root,
[data-theme="dark"],
[data-bs-theme="dark"] {
    /* ---- Confessions palette (light) ------------------------------ */
    --bone-cream:      #F8F4EA;  /* page bg, warm off-white */
    --bone-pearl:      #FFFFFF;  /* card surfaces */
    --bone-mist:       #F1ECE0;  /* hover / alt surface */

    --plum-ink:        #2A1147;  /* primary text — deep aubergine */
    --plum-mid:        #5A3F8C;  /* body text */
    --plum-mute:       #7E6BA8;  /* captions, muted */

    --magenta-silk:    #C9237B;  /* primary accent */
    --magenta-deep:    #9C1565;  /* hover / pressed */
    --hot-pink:        #E63A8E;  /* highlights, CTAs */
    --acid-mint:       #1FBF8E;  /* sparing — wins, positive moments */
    --golden-warn:     #D89933;  /* warnings */
    --crimson-neg:     #D73164;  /* negatives, danger */

    --lavender-haze:   #C9B8E8;  /* decorative tints */
    --lavender-mute:   #B5A6D2;  /* borders, dividers */

    /* Signaling */
    --negative:        var(--crimson-neg);
    --positive:        var(--acid-mint);

    /* Gradients */
    --shimmer:         linear-gradient(135deg, #B084E5 0%, #C9237B 50%, #E63A8E 100%);
    --silk-veil:       radial-gradient(ellipse at 30% 0%, rgba(201, 35, 123, 0.08) 0%, transparent 55%);
    --acid-glow:       radial-gradient(ellipse at 90% 100%, rgba(31, 191, 142, 0.06) 0%, transparent 50%);

    /* ---- Map onto existing --hb-* aliases ------------------------- */
    --hb-bg:            var(--bone-cream);
    --hb-surface:       var(--bone-pearl);
    --hb-surface-alt:   var(--bone-mist);
    --hb-border:        rgba(126, 107, 168, 0.18);
    --hb-text:          var(--plum-ink);
    --hb-text-muted:    var(--plum-mute);

    --hb-primary:       var(--magenta-silk);
    --hb-primary-soft:  rgba(201, 35, 123, 0.10);
    --hb-success:       var(--acid-mint);
    --hb-success-soft:  rgba(31, 191, 142, 0.12);
    --hb-warning:       var(--golden-warn);
    --hb-warning-soft:  rgba(216, 153, 51, 0.14);
    --hb-danger:        var(--crimson-neg);
    --hb-danger-soft:   rgba(215, 49, 100, 0.12);

    /* Lila-tinted shadows but light, never harsh */
    --hb-shadow-sm: 0 1px 2px rgba(90, 63, 140, 0.10);
    --hb-shadow:    0 6px 20px -6px rgba(90, 63, 140, 0.18);
    --hb-shadow-lg: 0 18px 50px -12px rgba(201, 35, 123, 0.22);

    /* Slow hovers — trance-state */
    --hb-transition: 320ms cubic-bezier(0.4, 0, 0.2, 1);

    /* Bootstrap overrides */
    --bs-body-bg:          var(--hb-bg);
    --bs-body-color:       var(--hb-text);
    --bs-border-color:     var(--hb-border);
    --bs-primary:          var(--magenta-silk);
    --bs-primary-rgb:      201, 35, 123;
    --bs-secondary-color:  var(--plum-mid);
    --bs-link-color:       var(--magenta-silk);
    --bs-link-hover-color: var(--magenta-deep);
}

/* ---- Typography ---------------------------------------------------- */
:root {
    --font-display: 'Space Grotesk', system-ui, sans-serif;
    --font-body:    'Inter', system-ui, sans-serif;
    --font-mono:    'JetBrains Mono', ui-monospace, monospace;
}

body {
    font-family: var(--font-body);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    letter-spacing: -0.005em;
    color: var(--hb-text);
    background:
        var(--silk-veil),
        var(--acid-glow),
        var(--bone-cream);
    background-attachment: fixed;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-display);
    letter-spacing: -0.025em;
    color: var(--plum-ink);
}

/* Numbers always tabular */
.hb-stat-value,
.hb-table .text-end,
td[data-col="wert"],
td[data-col="bereinigt"],
td[data-col="anzahl"],
td[data-col="gebuehren"],
td[data-col="paarwert"],
td[data-col="rrr"],
td[data-col="stueck"],
td[data-col="betrag"],
.hb-amount,
.hb-num {
    font-family: var(--font-mono);
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.01em;
}

html { color-scheme: light; }

/* Bootstrap caps .container-xxl at 1320px on screens ≥1400px wide.
   On modern wide displays that wastes a lot of real estate — bump it. */
@media (min-width: 1400px) {
    .container-xxl { max-width: 1640px; }
}
@media (min-width: 1920px) {
    .container-xxl { max-width: 1820px; }
}

/* ---- Action column ------------------------------------------------- */
.hb-col-actions { width: 1px; white-space: nowrap; }
.hb-table.hb-table-fixed .hb-col-actions { width: 116px; }
.hb-table td:last-child { white-space: nowrap; }
.hb-table th[data-col="name"],
.hb-table th[data-col="beschreibung"] { width: 100%; }
/* Icon-only buttons brauchen kein Bootstrap-Standard-Padding —
   das verschwendet bei schmalen Action-Spalten Platz und schiebt den
   Hover-Highlight über den Spaltenrand hinaus. */
.hb-table td .btn-sm.border-0 {
    padding: 0.25rem 0.4rem;
    line-height: 1;
}

/* ---- Cards: silk-edge magenta shimmer at top ---------------------- */
.hb-card { position: relative; background: var(--bone-pearl); border: 1px solid var(--hb-border); }
.hb-card::before {
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 1px;
    background: var(--shimmer);
    opacity: 0.7;
    pointer-events: none;
}

/* Stat-grid cards inherit but get a subtle hover lift */
.hb-stat {
    background: var(--bone-pearl);
    border: 1px solid var(--hb-border);
    transition: transform var(--hb-transition), box-shadow var(--hb-transition);
    position: relative;
}
.hb-stat:hover { transform: translateY(-2px); box-shadow: var(--hb-shadow); }
/* Shimmer gradient on the accent variant — same effect as on .hb-card,
   but stronger and the only top-edge "ribbon" instead of a solid border. */
.hb-stat--accent {
    border-top: 0;
    background-image:
        linear-gradient(var(--bone-pearl), var(--bone-pearl)),
        var(--shimmer);
    background-clip: padding-box, border-box;
    background-origin: border-box;
    border-top: 3px solid transparent;
}
.hb-stat--success { border-top-color: var(--acid-mint); }
.hb-stat--warning { border-top-color: var(--golden-warn); }
.hb-stat--danger  { border-top-color: var(--crimson-neg); }

.hb-stat-label {
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--plum-mute);
}
.hb-stat-value {
    color: var(--plum-ink);
    font-weight: 600;
    font-size: 1.7rem;
}
.hb-stat-hint { color: var(--plum-mute); }

/* ---- Tables: soft hover sweep, no zebra --------------------------- */
.hb-table thead th {
    background: var(--bone-mist);
    color: var(--plum-mute);
    font-weight: 600;
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border-bottom: 1px solid var(--hb-border);
}
.hb-table tbody tr:hover {
    background: linear-gradient(90deg,
        rgba(201, 35, 123, 0.04) 0%,
        rgba(201, 35, 123, 0.08) 50%,
        rgba(201, 35, 123, 0.04) 100%);
}
.hb-table tbody td { color: var(--plum-ink); }
.hb-day-row { background: var(--bone-mist); font-weight: 600; }

/* ---- Buttons: shimmer primary, magenta outline secondary ---------- */
.btn-primary {
    background: var(--shimmer);
    background-size: 200% 100%;
    background-position: 0% 50%;
    border: 0;
    color: #FFFFFF;
    font-weight: 500;
    letter-spacing: -0.01em;
    transition: background-position var(--hb-transition), transform var(--hb-transition), box-shadow var(--hb-transition);
}
.btn-primary:hover,
.btn-primary:focus {
    background-position: 100% 50%;
    color: #FFFFFF;
    box-shadow: 0 6px 20px -6px rgba(201, 35, 123, 0.45);
    transform: translateY(-1px);
}
.btn-outline-secondary {
    background: transparent;
    border: 1px solid var(--lavender-mute);
    color: var(--plum-mid);
    transition: var(--hb-transition);
}
.btn-outline-secondary:hover {
    background: var(--bone-mist);
    border-color: var(--magenta-silk);
    color: var(--magenta-silk);
}
.btn-outline-primary {
    border-color: var(--magenta-silk);
    color: var(--magenta-silk);
}
.btn-outline-primary:hover {
    background: var(--magenta-silk);
    color: #FFFFFF;
}
.btn-outline-danger {
    border-color: var(--crimson-neg);
    color: var(--crimson-neg);
}
.btn-outline-danger:hover {
    background: var(--crimson-neg);
    color: #FFFFFF;
}

/* ---- Forms: cream surface, magenta focus ring -------------------- */
.form-control,
.form-select {
    background: var(--bone-pearl);
    border: 1px solid var(--lavender-mute);
    color: var(--plum-ink);
    transition: border-color 200ms ease, box-shadow 200ms ease;
}
.form-control:focus,
.form-select:focus {
    border-color: var(--magenta-silk);
    box-shadow: 0 0 0 3px rgba(201, 35, 123, 0.18);
    background: var(--bone-pearl);
    color: var(--plum-ink);
}
label, .form-label {
    color: var(--plum-mute);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

/* ---- Navbar -------------------------------------------------------- */
.hb-navbar {
    background: #FFFFFF;
    border-bottom: 1px solid var(--hb-border);
}
.hb-navbar .nav-link {
    color: var(--plum-mid);
    font-weight: 500;
    transition: color var(--hb-transition);
}
.hb-navbar .nav-link:hover { color: var(--magenta-silk); }
.hb-navbar .nav-link.active { color: var(--magenta-silk); }
.hb-navbar .dropdown-menu,
.dropdown-menu {
    --bs-dropdown-bg: #FFFFFF;
    --bs-dropdown-color: var(--plum-mid);
    --bs-dropdown-link-color: var(--plum-mid);
    --bs-dropdown-link-hover-bg: var(--hb-primary-soft);
    --bs-dropdown-link-hover-color: var(--magenta-deep);
    --bs-dropdown-border-color: var(--hb-border);
    background-color: #FFFFFF !important;
    border: 1px solid var(--hb-border);
    box-shadow: 0 18px 50px -12px rgba(90, 63, 140, 0.30);
    border-radius: var(--hb-radius);
    padding: 0.4rem;
    margin-top: 0.4rem;
    min-width: 12rem;
    position: absolute;
    z-index: 1080;
    isolation: isolate;
    overflow: hidden;
    backdrop-filter: none;
}
.hb-navbar .dropdown-menu::before {
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 2px;
    background: var(--shimmer);
    opacity: 0.85;
}
.hb-navbar .dropdown-item {
    color: var(--plum-mid);
    padding: 0.45rem 0.7rem;
    border-radius: calc(var(--hb-radius) - 2px);
    font-weight: 500;
    transition: background var(--hb-transition), color var(--hb-transition);
}
.hb-navbar .dropdown-item:hover,
.hb-navbar .dropdown-item:focus {
    background: var(--hb-primary-soft);
    color: var(--magenta-deep);
}

/* ---- Pills / chips ------------------------------------------------- */
.hb-chip {
    background: var(--hb-primary-soft);
    color: var(--magenta-deep);
    font-weight: 500;
    border-radius: 999px;
    padding: 0.18rem 0.55rem;
    font-size: 0.78rem;
}
.hb-chip--primary { background: var(--shimmer); color: #FFFFFF; }
.hb-chip--success { background: rgba(31, 191, 142, 0.16); color: #0F8060; }
.hb-chip--danger  { background: rgba(215, 49, 100, 0.14); color: var(--crimson-neg); }
.hb-chip--warning { background: rgba(216, 153, 51, 0.18); color: #7A5512; }

/* Generic Bootstrap .badge styling — readable on dark coloured backgrounds. */
.badge {
    font-weight: 500;
    border-radius: 999px;
    padding: 0.22rem 0.6rem;
    font-size: 0.78rem;
    color: #FFFFFF;
}
.badge.bg-success { background-color: var(--acid-mint) !important; color: #06301F; }
.badge.bg-warning { background-color: var(--golden-warn) !important; color: #3A2810; }
.badge.bg-danger  { background-color: var(--crimson-neg) !important; color: #FFFFFF; }
.badge.bg-secondary { background-color: var(--lavender-mute) !important; color: #FFFFFF; }
.badge.bg-dark    { background-color: var(--plum-ink) !important; color: #FFFFFF; }
.badge.bg-info    { background-color: var(--lavender-haze) !important; color: var(--plum-ink); }

/* ---- Amounts: positive / negative semantic colors ---------------- */
.text-success { color: var(--acid-mint) !important; }
.text-danger  { color: var(--crimson-neg) !important; }
.text-warning { color: var(--golden-warn) !important; }
.text-muted   { color: var(--plum-mute) !important; }

/* ---- Login screen — the album cover -------------------------------- */
.hb-login-body {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.5rem;
    background:
        radial-gradient(ellipse at 25% 15%, rgba(201, 35, 123, 0.14) 0%, transparent 55%),
        radial-gradient(ellipse at 80% 90%, rgba(176, 132, 229, 0.10) 0%, transparent 55%),
        radial-gradient(ellipse at 100% 0%, rgba(31, 191, 142, 0.05) 0%, transparent 50%),
        var(--bone-cream);
    background-attachment: fixed;
}
.hb-login {
    width: 100%;
    max-width: 420px;
}
.hb-login-card {
    padding: 2.5rem 2rem;
    border-radius: var(--hb-radius-lg);
    box-shadow: var(--hb-shadow-lg);
}
.hb-login-brand { margin-bottom: 1.75rem; }
.hb-login-brand-label {
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--magenta-silk);
    margin-bottom: 0.5rem;
}
.hb-login-title {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: 1.6rem;
    line-height: 1.2;
    letter-spacing: -0.02em;
    color: var(--plum-ink);
    margin: 0;
}
.hb-login-alert {
    padding: 0.7rem 0.9rem;
    border-radius: var(--hb-radius);
    font-size: 0.9rem;
    margin-bottom: 1.25rem;
}
.hb-login-alert--error {
    background: var(--hb-danger-soft);
    color: var(--crimson-neg);
    border: 1px solid rgba(215, 49, 100, 0.25);
}
.hb-login-field { margin-bottom: 1rem; }
.hb-login-form .form-label { margin-bottom: 0.35rem; }

/* ---- Modal — Confessions card ------------------------------------- */
.modal-content {
    background: var(--bone-pearl);
    border: 1px solid var(--hb-border);
    border-radius: var(--hb-radius-lg);
    box-shadow: var(--hb-shadow-lg);
    position: relative;
    overflow: hidden;
}
.modal-content::before {
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 2px;
    background: var(--shimmer);
    opacity: 0.85;
}
.modal-header {
    border-bottom: 1px solid var(--hb-border);
    color: var(--plum-ink);
}
.modal-title { font-family: var(--font-display); font-weight: 500; letter-spacing: -0.02em; }
.modal-footer { border-top: 1px solid var(--hb-border); }

/* ---- Toast — magenta shimmer left edge ---------------------------- */
#hbToastContainer .hb-toast {
    border-left-width: 3px;
    border-radius: var(--hb-radius);
    box-shadow: var(--hb-shadow-lg);
}

/* ---- Floating bulk-action bar — shimmer top edge ------------------ */
.hb-action-float {
    border-radius: 999px;
    padding: 0.55rem 1rem;
    backdrop-filter: saturate(140%) blur(10px);
    box-shadow: 0 10px 32px -8px rgba(201, 35, 123, 0.35);
    position: fixed;
    bottom: var(--hb-space-6);
    left: 50%;
    transform: translateX(-50%);
}
.hb-action-float::before {
    content: '';
    position: absolute; top: 0; left: 12px; right: 12px; height: 1px;
    background: var(--shimmer);
    border-radius: 999px;
}

/* ---- Footer with PA-speaker grille --------------------------------- */
.hb-footer {
    border-top: 1px solid var(--hb-border);
    background: var(--bone-pearl);
    position: relative;
    overflow: hidden;
}
.hb-footer::before {
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: var(--shimmer);
    opacity: 0.5;
}
/* Tiny speaker cones along the footer — radial gradients in repeating pattern.
   Echoes the wall-of-speakers from the Confessions II cover. */
.hb-footer::after {
    content: '';
    position: absolute; bottom: 0; left: 0; right: 0; height: 8px;
    background-image:
        radial-gradient(circle at 50% 50%,
            rgba(201, 35, 123, 0.22) 0%,
            rgba(201, 35, 123, 0.05) 35%,
            transparent 60%);
    background-size: 28px 8px;
    background-repeat: repeat-x;
    opacity: 0.6;
}

/* ---- Empty state — lyrical, lavender ------------------------------- */
.hb-empty {
    text-align: center;
    padding: var(--hb-space-8) var(--hb-space-4);
}
.hb-empty .hb-empty-icon {
    color: var(--lavender-mute);
    font-size: 2.2rem;
    opacity: 0.7;
    margin-bottom: var(--hb-space-3);
}
.hb-empty .hb-empty-title {
    font-family: var(--font-display);
    color: var(--plum-ink);
    font-size: 1.25rem;
    font-weight: 500;
    letter-spacing: -0.02em;
    margin-bottom: var(--hb-space-2);
}
.hb-empty .hb-empty-message {
    color: var(--plum-mute);
    font-size: 0.95rem;
    max-width: 32rem;
    margin: 0 auto;
}

/* ---- Hero-Stat (the album-cover number) --------------------------- */
.hb-hero-stat {
    padding: 2rem 0 1.5rem;
    margin-bottom: 1.5rem;
    border-bottom: 1px solid var(--hb-border);
}
.hb-hero-stat__label {
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--plum-mute);
    margin-bottom: 0.4rem;
}
.hb-hero-stat__value {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: clamp(2.6rem, 7vw, 5.5rem);
    line-height: 1;
    letter-spacing: -0.04em;
    font-variant-numeric: tabular-nums;
    background: var(--shimmer);
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
    margin-bottom: 0.4rem;
}
.hb-hero-stat--positive .hb-hero-stat__value {
    background: linear-gradient(135deg, #1FBF8E 0%, #5FC8A6 50%, #C9237B 100%);
    background-clip: text;
    -webkit-background-clip: text;
}
.hb-hero-stat--negative .hb-hero-stat__value {
    background: linear-gradient(135deg, #B084E5 0%, #C9237B 50%, #D73164 100%);
    background-clip: text;
    -webkit-background-clip: text;
}
.hb-hero-stat__hint {
    color: var(--plum-mute);
    font-size: 0.95rem;
}
@media (prefers-reduced-motion: no-preference) {
    .hb-hero-stat__value { animation: hb-pulse 4.8s ease-in-out infinite; transform-origin: left center; }
}

/* ---- Form switch / checkbox — magenta when on -------------------- */
.form-check-input {
    border-color: var(--lavender-mute);
    background-color: var(--bone-cream);
}
.form-check-input:checked {
    background-color: var(--magenta-silk);
    border-color: var(--magenta-silk);
}
.form-check-input:focus {
    border-color: var(--magenta-silk);
    box-shadow: 0 0 0 0.2rem rgba(201, 35, 123, 0.18);
}
.form-switch .form-check-input {
    /* Bootstrap's switch knob is an inline SVG that uses the border-color of
       the input's "off" state. Override the data-URI so the off-state knob
       is lavender instead of the default Bootstrap blue. */
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%237E6BA8'/%3e%3c/svg%3e");
}
.form-switch .form-check-input:checked {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23ffffff'/%3e%3c/svg%3e");
}

/* ---- Inline code (IBANs, IDs etc.) — readable on cream ----------- */
code, .text-monospace {
    font-family: var(--font-mono);
    font-variant-numeric: tabular-nums;
    color: var(--plum-ink);
    background: var(--bone-mist);
    padding: 0.1rem 0.4rem;
    border-radius: 4px;
    font-size: 0.92em;
}

/* ---- Fixed-layout Tabellen ---------------------------------------- */
/* Wenn .hb-table-fixed aktiv ist, gelten die <th>-Pixelbreiten exakt;
   die einzige Spalte ohne Breite (Beschreibung) bekommt den Rest. So werden
   Status/Kategorie/Betrag-Felder nie mehr von einer langen Beschreibung
   weggequetscht und das Card-overflow:hidden klippt nichts mehr. */
.hb-table.hb-table-fixed { table-layout: fixed; }

/* Beschreibung-Spalte: einzeilig mit Ellipsis. */
.hb-table .hb-beschreibung-cell {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}
.hb-table .hb-beschreibung-text { display: inline; vertical-align: middle; }
/* Selects/Inputs in fixed-layout-Zeilen: 100 % der Zelle, damit sie ihre
   sichtbare Breite voll nutzen können statt von ihrem Default constraint. */
.hb-table.hb-table-fixed td .form-select,
.hb-table.hb-table-fixed td .form-control,
.hb-table.hb-table-fixed td .hb-inline-input,
.hb-table.hb-table-fixed td .hb-inline-select { width: 100%; }

/* ---- Source-Chip (Buchung-Herkunft: EB/B4) ----------------------- */
.hb-source {
    display: inline-block;
    font-family: var(--font-mono);
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    padding: 0.08rem 0.32rem;
    border-radius: 4px;
    margin-right: 0.4rem;
    vertical-align: 1px;
    line-height: 1.2;
    text-transform: uppercase;
}
.hb-source-eb { background: rgba(31, 191, 142, 0.16); color: #0F8060; }
.hb-source-b4 { background: rgba(126, 107, 168, 0.18); color: var(--plum-mid); }

/* ---- AI-Match wand button — magenta accent ----------------------- */
.hb-ai-match {
    color: var(--magenta-silk);
    transition: transform var(--hb-transition), color var(--hb-transition);
}
.hb-ai-match:hover { color: var(--magenta-deep); transform: translateY(-1px); }
.hb-ai-match:disabled { color: var(--lavender-mute); }

/* ---- Day-row tag (Buchungen / Wiederkehrende) --------------------- */
.hb-day-row td {
    padding-top: var(--hb-space-3);
    padding-bottom: var(--hb-space-3);
    color: var(--plum-mid);
}
.hb-day-row--over-limit td:first-child {
    box-shadow: inset 3px 0 0 var(--crimson-neg);
}
.hb-limit-badge {
    display: inline-block;
    background: var(--hb-danger-soft);
    color: var(--crimson-neg);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    padding: 0.15rem 0.5rem;
    border-radius: 999px;
    margin-left: 0.5rem;
}

/* ---- Filter bar polish -------------------------------------------- */
.hb-filter-bar {
    background: var(--bone-pearl);
    border: 1px solid var(--hb-border);
    box-shadow: var(--hb-shadow-sm);
}
.hb-filter-bar .form-control,
.hb-filter-bar .form-select {
    background: var(--bone-cream);
    border-color: var(--hb-border);
}
.hb-filter-bar .form-control:focus,
.hb-filter-bar .form-select:focus {
    background: var(--bone-pearl);
}

/* Schnell-Filter / What-if Mode pills — Bootstrap btn-group restyled */
.btn-group .btn,
.btn-group-sm .btn { border-radius: 0; }
.btn-group .btn:first-child,
.btn-group-sm .btn:first-child { border-top-left-radius: 999px; border-bottom-left-radius: 999px; }
.btn-group .btn:last-child,
.btn-group-sm .btn:last-child { border-top-right-radius: 999px; border-bottom-right-radius: 999px; }

.btn-check:checked + .btn-outline-primary,
.btn-check:checked + .btn-outline-secondary {
    background: var(--magenta-silk);
    border-color: var(--magenta-silk);
    color: #FFFFFF;
}
.btn-check:checked + .btn-outline-success {
    background: var(--acid-mint);
    border-color: var(--acid-mint);
    color: #073B2D;
}
.btn-check:checked + .btn-outline-warning {
    background: var(--golden-warn);
    border-color: var(--golden-warn);
    color: #3A2810;
}

/* ---- Compact info-card (e.g. What-if Modus block on Wiederkehrende) */
.hb-card .hb-card-body strong { color: var(--plum-mute); font-weight: 600; font-size: 0.78rem; letter-spacing: 0.08em; text-transform: uppercase; }
.hb-card .hb-card-body strong + span#wbSum,
.hb-card .hb-card-body span.fs-5 {
    font-family: var(--font-mono);
    font-variant-numeric: tabular-nums;
    color: var(--plum-ink);
    letter-spacing: -0.01em;
}

/* ---- Action-bar — masthead with shimmer baseline ------------------ */
.hb-action-bar {
    align-items: flex-end;
    padding-bottom: 0.9rem;
    margin-bottom: 1.5rem;
    border-bottom: 0;
    position: relative;
}
.hb-action-bar::after {
    content: '';
    position: absolute;
    left: 0; right: 0; bottom: 0;
    height: 1px;
    background: linear-gradient(90deg,
        var(--magenta-silk) 0%,
        rgba(201, 35, 123, 0.35) 24%,
        var(--hb-border) 60%,
        transparent 100%);
}
.hb-action-bar h1,
.hb-action-bar h2 {
    font-family: var(--font-display);
    color: var(--plum-ink);
    font-weight: 500;
    font-size: clamp(1.5rem, 2.6vw, 2rem);
    letter-spacing: -0.03em;
    line-height: 1.1;
    margin: 0;
    display: flex;
    align-items: baseline;
    gap: 0.6rem;
}
.hb-action-bar .hb-count {
    font-family: var(--font-mono);
    font-variant-numeric: tabular-nums;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--magenta-silk);
    background: transparent;
    border: 0;
    padding: 0;
    letter-spacing: 0;
    vertical-align: baseline;
    transform: none;
    /* monospace digits sit slightly below the cap-line of the display sans
       title — nudge up to align baselines */
    position: relative;
    top: -0.2em;
}
.hb-action-bar .hb-count::before {
    content: '·';
    color: var(--lavender-mute);
    margin-right: 0.5em;
    font-family: var(--font-display);
    font-weight: 400;
}

/* ---- Save indicator (inline-edit success flash) -------------------- */
.hb-save-indicator { color: var(--acid-mint); }

/* ---- Motion: 120 BPM stat-pulse, bass-drop card reveal ------------ */
@media (prefers-reduced-motion: no-preference) {
    .hb-stat-value { animation: hb-pulse 4.8s ease-in-out infinite; }
    @keyframes hb-pulse {
        0%, 100% { transform: scale(1); }
        50%      { transform: scale(1.012); }
    }
    .hb-card,
    .hb-stat {
        animation: hb-bass-drop 700ms cubic-bezier(0.16, 1, 0.3, 1) both;
    }
    @keyframes hb-bass-drop {
        0%   { opacity: 0; transform: translateY(8px); }
        100% { opacity: 1; transform: translateY(0); }
    }
}
