/* ============================================================
   77NEUN BEWERTUNGSTOOL – Clean Dashboard Design 2026
   ============================================================ */

@import url('../fonts/plus-jakarta-inter.css');

:root {
    /* ── Palette 2026: Warm Anthrazit mit Joomla-6-artigem "Atmen" ──
       6 Grund-Toene + 1 Stern-Gelb.
       Hintergrund ist leicht getoent (nicht weiss), damit sich die
       weissen Cards mit Soft-Shadow sichtbar darueber absetzen.
    */
    --bg:           #f1f3f6;    /* leicht kuehl-getoent, "Joomla-like" */
    --bg-white:     #ffffff;    /* Cards sitzen auf --bg */
    --bg-subtle:    #f7f8fa;    /* innere Akzente (heller als --bg) */
    --bg-elevated:  #e5e7eb;    /* Track-Styles (Progress-Bars etc.) */
    --border:       #e4e7ec;    /* ganz dezent, meist ungenutzt zugunsten shadow */
    --accent:       #0f172a;    /* Deep Slate (Sidebar, Buttons, Akzente) */
    --accent-light: #f1f3f6;    /* fuer aktiv-Hover-Hintergruende */
    --accent-hover: #020617;    /* Slate-950 */
    --success:      #16a34a;    /* EIN Ton fuer Positiv: Border + Text + Icon */
    --success-light:#dcfce7;
    --danger:       #dc2626;    /* EIN Ton fuer Negativ: Border + Text + Icon */
    --danger-light: #fee2e2;
    --warning:      #eab308;    /* ausschliesslich fuer Sternchen-Icons */
    --warning-light:#fef9c3;
    --text:         #18181b;
    --text-2:       #3f3f46;
    --text-muted:   #6b7280;
    --text-faint:   #a1a1aa;
    --r-xs: 8px; --r-sm: 12px; --r: 16px; --r-lg: 20px; --r-xl: 24px;

    /* Shadows: zweistufig (nah + fern) fuer echte Tiefe. Joomla-6-Stil. */
    --shadow-xs: 0 1px 2px rgba(16,24,40,.04), 0 1px 1px rgba(16,24,40,.03);
    --shadow-sm: 0 1px 3px rgba(16,24,40,.05), 0 2px 6px rgba(16,24,40,.04);
    --shadow:    0 2px 4px rgba(16,24,40,.05), 0 8px 16px rgba(16,24,40,.06);
    --shadow-md: 0 4px 8px rgba(16,24,40,.06), 0 16px 24px rgba(16,24,40,.08);
    --shadow-lg: 0 8px 16px rgba(16,24,40,.08), 0 24px 40px rgba(16,24,40,.10);

    --font-display:'Plus Jakarta Sans',sans-serif;
    --font-body:   'Inter',sans-serif;
    --transition:  all 0.2s cubic-bezier(0.4,0,0.2,1);
    --sidebar-bg:   #1A1714;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}

/* LAYOUT */
.app-wrapper{display:flex;min-height:100vh;max-width:1920px}
.sidebar{width:256px;background:var(--sidebar-bg);border-right:none;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;border-radius:0 20px 20px 0;box-shadow:4px 0 20px rgba(0,0,0,.08)}
.sidebar-logo{padding:24px 22px 18px;border-bottom:1px solid rgba(255,255,255,.12)}
.sidebar-logo .logo-text{font-family:var(--font-display);font-weight:800;font-size:1.1rem;letter-spacing:-.3px;color:#ffffff}
.sidebar-logo .logo-text span{color:#f5a623}
.sidebar-logo .logo-sub{font-size:.68rem;color:rgba(255,255,255,.5);margin-top:2px;letter-spacing:.04em;text-transform:uppercase;font-weight:500}
.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}
.nav-section-title{font-size:.67rem;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.35);padding:14px 10px 5px;font-weight:600}
.nav-item{display:flex;align-items:center;gap:9px;padding:10px 12px;border-radius:var(--r-sm);color:rgba(255,255,255,.7);text-decoration:none;font-size:.875rem;font-weight:500;transition:var(--transition);margin-bottom:2px}
.nav-item:hover{background:rgba(255,255,255,.1);color:#ffffff}
.nav-item.active{background:rgba(255,255,255,.18);color:#ffffff;font-weight:600}
.nav-item .icon{width:17px;height:17px;flex-shrink:0}
.nav-badge{margin-left:auto;background:#e74c3c;color:white;font-size:.68rem;font-weight:700;padding:2px 6px;border-radius:20px}
.sidebar-footer{padding:10px 10px;border-top:1px solid rgba(255,255,255,.12)}
.sidebar-user{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--r-sm);font-size:.84rem;color:rgba(255,255,255,.6)}
.sidebar-user .avatar{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:.76rem;color:#ffffff;flex-shrink:0}
.main-content{margin-left:256px;flex:1;padding:36px 40px;max-width:calc(100vw - 256px)}

/* HEADER */
.page-header{margin-bottom:30px}
.page-title{font-family:var(--font-display);font-size:1.6rem;font-weight:800;letter-spacing:-.4px;color:var(--text);line-height:1.2}
.page-subtitle{font-size:.875rem;color:var(--text-muted);margin-top:4px}

/* CARDS */
.card{background:var(--bg-white);border:none;border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow-sm);transition:var(--transition)}
.card:hover{box-shadow:var(--shadow)}

/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px;margin-bottom:26px}
.stat-card{background:var(--bg-white);border:none;border-radius:var(--r-lg);padding:22px 24px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
a.stat-card{transition:transform .3s ease, box-shadow .3s ease}
a.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.stat-icon{width:40px;height:40px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;margin-bottom:12px;font-size:1rem}
.stat-icon.purple{background:var(--accent-light);color:var(--accent)}
.stat-icon.green{background:var(--success-light);color:var(--success)}
.stat-icon.red{background:var(--danger-light);color:var(--danger)}
.stat-icon.yellow{background:var(--warning-light);color:var(--warning)}
.stat-label{font-size:.72rem;font-weight:600;color:var(--text-muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.06em}
.stat-value{font-family:var(--font-display);font-size:1.9rem;font-weight:800;color:var(--text);line-height:1;letter-spacing:-.5px}
.stat-value.accent{color:var(--accent)} .stat-value.success{color:var(--success)} .stat-value.danger{color:var(--danger)}
.stat-sub{font-size:.75rem;color:var(--text-muted);margin-top:5px}

/* TABELLE */
.table-wrapper{overflow-x:auto;border-radius:var(--r);border:none;box-shadow:var(--shadow-sm)}
table{width:100%;border-collapse:collapse;font-size:.875rem}
thead th{background:var(--bg-subtle);padding:12px 18px;text-align:left;font-size:.7rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-weight:600;border-bottom:1px solid var(--border)}
tbody tr{border-bottom:1px solid var(--border);transition:var(--transition)}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--bg-subtle)}
tbody td{padding:12px 18px;color:var(--text-2);vertical-align:middle}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 18px;border-radius:var(--r-sm);font-family:var(--font-body);font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--transition);text-decoration:none;border:none;white-space:nowrap;line-height:1.4}
.btn-primary{background:var(--accent);color:white;box-shadow:0 2px 8px rgba(27,108,168,.25)}
.btn-primary:hover{background:var(--accent-hover);box-shadow:0 4px 16px rgba(27,108,168,.35);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}
.btn-ghost:hover{background:var(--bg-subtle);color:var(--text);border-color:#d1d5db}
.btn-success{background:var(--success);color:white}
.btn-success:hover{background:#26a69a}
.btn-danger{background:transparent;color:var(--danger);border:1px solid #f5c6cb}
.btn-danger:hover{background:var(--danger-light)}
.btn-sm{padding:6px 12px;font-size:.8rem}

/* FORMULARE */
.form-group{margin-bottom:18px}
label{display:block;font-size:.8rem;font-weight:600;color:var(--text-2);margin-bottom:6px}
input[type="text"],input[type="email"],input[type="password"],input[type="tel"],input[type="url"],select,textarea{width:100%;background:var(--bg-white);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:11px 14px;color:var(--text);font-family:var(--font-body);font-size:.9rem;transition:var(--transition);outline:none;box-shadow:none}
input[type="color"]{width:100%;height:44px;padding:3px 5px;border:1.5px solid var(--border);border-radius:var(--r-sm);cursor:pointer;background:var(--bg-white);outline:none;box-shadow:none;transition:var(--transition)}
input[type="color"]::-webkit-color-swatch-wrapper{padding:2px;border-radius:8px}
input[type="color"]::-webkit-color-swatch{border:none;border-radius:7px}
input[type="color"]::-moz-color-swatch{border:none;border-radius:7px}
input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(27,108,168,.1)}
input::placeholder{color:var(--text-faint)}

/* ─── Sichtbarer Tastatur-Fokus (a11y, WCAG 2.4.7) ───
   :focus-visible greift NUR bei Tastatur-Navigation (Tab), NICHT beim Maus-Klick.
   Fuer Maus-Nutzer aendert sich also NICHTS. Textfelder behalten ihren eigenen
   Border+Shadow-Fokus (oben), Buttons/Links/Slider/Checkboxen bekommen hier einen
   klaren Ring. Auf dunklen Flaechen (Sidebar/Hero) hell, sonst Slate. */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:3px}
.sidebar :focus-visible,.mobile-topbar :focus-visible,.bb-hero :focus-visible,.bb-page-hero :focus-visible,.mb-hero :focus-visible,.dash-mb-card :focus-visible{outline-color:#fff}
textarea{resize:vertical;min-height:100px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-hint{font-size:.75rem;color:var(--text-muted);margin-top:5px;line-height:1.5}

/* ALERTS */
.alert{padding:12px 16px;border-radius:var(--r-sm);font-size:.875rem;margin-bottom:16px;display:flex;align-items:flex-start;gap:8px;line-height:1.5;border:none}
.alert-success{background:var(--success-light);color:#0a6c5f}
.alert-error{background:var(--danger-light);color:#922b21}
.alert-info{background:var(--accent-light);color:#0f4c75}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:600;letter-spacing:.02em}
.badge-success{background:var(--success-light);color:#0a6c5f}
.badge-danger{background:var(--danger-light);color:#922b21}
.badge-neutral{background:var(--bg-subtle);color:var(--text-muted)}
.badge-purple{background:var(--accent-light);color:#0f4c75}

/* STERNE */
.stars{display:inline-flex;gap:1px;color:var(--warning);font-size:.9rem}

/* LOGIN */
.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e8f4fd 0%,#f0f2f5 50%,#dcfce7 100%);padding:20px}
.login-card{width:100%;max-width:420px;background:var(--bg-white);border:none;border-radius:var(--r-xl);padding:42px 38px;box-shadow:var(--shadow-lg);animation:slideUp .35s cubic-bezier(.4,0,.2,1)}
@keyframes slideUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.login-logo{font-family:var(--font-display);font-weight:800;font-size:1.15rem;letter-spacing:-.3px;color:var(--text)}
.login-logo span{color:var(--accent)}
.login-title{font-family:var(--font-display);font-size:1.4rem;font-weight:800;margin-bottom:6px;margin-top:26px;letter-spacing:-.3px}
.login-sub{color:var(--text-muted);font-size:.875rem;margin-bottom:26px;line-height:1.6}

/* FEEDBACK-SEITE */
.feedback-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:#f0f2f5}
.feedback-card{width:100%;max-width:460px;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg);background:white}
.feedback-header{padding:30px 30px 22px;text-align:center}
.feedback-logo{max-height:54px;max-width:180px;object-fit:contain;margin-bottom:14px;display:block}
.feedback-title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;line-height:1.3}
.feedback-sub{font-size:.875rem;margin-top:5px;opacity:.75}
.feedback-body{background:white;padding:26px 30px 30px;border-top:1px solid rgba(0,0,0,.06)}
.star-rating{display:flex;justify-content:center;gap:8px;margin-bottom:22px}
.star-btn{background:none;border:none;cursor:pointer;font-size:2.1rem;color:#dfe6e9;transition:var(--transition);padding:4px;line-height:1}
.star-btn:hover,.star-btn.active{color:#f5a623;transform:scale(1.15)}
.go-to-google-btn{display:block;width:100%;padding:13px;background:#4285f4;color:white;text-align:center;border-radius:var(--r-sm);text-decoration:none;font-family:var(--font-display);font-size:.93rem;font-weight:700;transition:var(--transition);margin-top:12px;box-shadow:0 2px 8px rgba(66,133,244,.3)}
.go-to-google-btn:hover{background:#3367d6;transform:translateY(-1px)}
.feedback-textarea{width:100%;border:1.5px solid var(--border);border-radius:var(--r-sm);padding:11px 13px;font-family:var(--font-body);font-size:.9rem;color:var(--text);resize:vertical;min-height:88px;transition:var(--transition);outline:none}
.feedback-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(27,108,168,.1)}
.feedback-input{width:100%;border:1.5px solid var(--border);border-radius:var(--r-sm);padding:10px 13px;font-family:var(--font-body);font-size:.875rem;color:var(--text);transition:var(--transition);outline:none;margin-bottom:9px}
.feedback-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(27,108,168,.1)}
.feedback-submit-btn{width:100%;padding:13px;border:none;border-radius:var(--r-sm);font-family:var(--font-display);font-size:.93rem;font-weight:700;cursor:pointer;transition:var(--transition);color:white;margin-top:5px;box-shadow:0 2px 8px rgba(0,0,0,.1)}
.feedback-submit-btn:hover{opacity:.92;transform:translateY(-1px)}
.step{display:none} .step.active{display:block}
.danke-screen{text-align:center;padding:30px 16px;display:none}
.danke-screen.visible{display:block}
.danke-emoji{font-size:3rem;margin-bottom:12px}
.danke-title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--text)}
.danke-text{color:var(--text-muted);margin-top:7px;font-size:.875rem;line-height:1.6}

/* UTILITY */
.flex{display:flex} .items-center{align-items:center} .justify-between{justify-content:space-between}
.gap-3{gap:12px} .gap-4{gap:16px} .mt-4{margin-top:16px} .mt-6{margin-top:24px} .mb-4{margin-bottom:16px} .mb-6{margin-bottom:24px}
.text-muted{color:var(--text-muted);font-size:.875rem} .text-small{font-size:.8rem}
.fw-bold{font-weight:700;font-family:var(--font-display)} .truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}
.dot-green{background:var(--success)} .dot-red{background:var(--danger)} .dot-yellow{background:var(--warning)}
.divider{border:none;border-top:1px solid var(--border);margin:20px 0}

/* Scrollbar */
::-webkit-scrollbar{width:5px} ::-webkit-scrollbar-track{background:transparent} ::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

/* Responsive */
@media(max-width:900px){
    .sidebar{display:none}
    .main-content{margin-left:0 !important;max-width:100vw !important;padding:20px 16px}
    .form-row{grid-template-columns:1fr !important}
    .stats-grid{grid-template-columns:1fr 1fr}
}

@media (max-width: 768px) {
    .main-content{padding:16px !important}
    .stats-grid{gap:10px}
    .stat-value{font-size:1.6rem}
    .table-wrapper{font-size:.8rem}
    tbody td{padding:10px 12px}
    thead th{padding:9px 12px}
    .btn{min-height:40px}
    .btn-sm{min-height:34px}
    .login-card{padding:32px 24px;border-radius:16px}
    .login-title{font-size:1.25rem}
    input,textarea,select{font-size:16px !important}
    .flex.items-center.justify-between{flex-wrap:wrap;gap:10px}
    .page-header{margin-bottom:20px}
    .page-title{font-size:1.35rem}
}

@media (max-width: 480px) {
    .stats-grid{grid-template-columns:1fr 1fr;gap:8px}
    .stat-card{padding:14px 16px}
    .login-wrapper{padding:12px}
    .login-card{padding:28px 20px}
}

/* ============================================================
   Mobile Topbar + Burger-Menü (global)
   ============================================================ */
.mobile-topbar{display:none;background:var(--bg-white);border-bottom:none;padding:14px 16px;position:sticky;top:0;z-index:200;align-items:center;justify-content:space-between;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.burger-btn{background:var(--bg-subtle);border:none;border-radius:10px;padding:6px 8px;cursor:pointer;color:var(--text-muted);display:flex;align-items:center}
.burger-btn:hover{background:var(--border)}

.mobile-nav-overlay{display:none;position:fixed;inset:0;z-index:500;background:rgba(0,0,0,.35);backdrop-filter:blur(3px)}
.mobile-nav-overlay.open{display:block;animation:mnavFadeIn .15s ease}
@keyframes mnavFadeIn{from{opacity:0}to{opacity:1}}

.mobile-nav-panel{position:absolute;top:0;right:0;width:280px;max-width:85vw;height:100%;background:var(--bg-white);padding:20px;box-shadow:-4px 0 20px rgba(0,0,0,.1);overflow-y:auto;animation:mnavSlideIn .2s ease;border-radius:20px 0 0 20px}
@keyframes mnavSlideIn{from{transform:translateX(100%)}to{transform:none}}

.mobile-nav-item{display:block;padding:11px 14px;border-radius:var(--r-sm);color:var(--text);text-decoration:none;font-size:.88rem;font-weight:500;transition:background .12s}
.mobile-nav-item:hover{background:var(--bg-subtle)}
.mobile-nav-item.active{background:var(--accent-light);color:var(--accent);font-weight:600}

.mobile-nav-section{font-size:.68rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:14px 14px 4px;margin-top:4px}
.mobile-nav-section:first-of-type{margin-top:0;padding-top:0}

@media (max-width: 900px) {
    .sidebar{display:none !important}
    .mobile-topbar{display:flex}
    .main-content{margin-left:0 !important;max-width:100vw !important;padding:16px !important}
}

/* ============================================================
   KOMPONENTEN-LAYER (bb-*) — Single Source of Truth
   Wird schrittweise auf allen Seiten eingesetzt, um einheit-
   liche Optik zu erreichen. Alte Klassen (.card, .stat-card)
   bleiben erhalten, bis alle Seiten migriert sind.
   ============================================================ */

/* ── Section (Gliederungs-Einheit mit Ueberschrift) ── */
.bb-section{margin:0 0 44px}
.bb-section:last-child{margin-bottom:0}
.bb-section-head{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.bb-section-icon{font-size:1.2rem;line-height:1;flex-shrink:0}
.bb-section-title{font-family:var(--font-display);font-size:1.2rem;font-weight:800;color:var(--text);letter-spacing:-.01em;margin:0}
.bb-section-sub{font-size:.84rem;color:var(--text-muted);margin:2px 0 0 0}
.bb-section-line{flex:1;height:1px;background:var(--border);margin-left:4px}
.bb-section-action{margin-left:auto;font-size:.82rem;color:var(--accent);font-weight:600;text-decoration:none;white-space:nowrap}
.bb-section-action:hover{text-decoration:underline}

.bb-eyebrow{font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}

/* ── Grid (12-Spalten mit sauberen Breakpoints) ── */
.bb-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}
.bb-grid--gap-sm{gap:12px}
.bb-grid--gap-lg{gap:28px}
.bb-col-3{grid-column:span 3}
.bb-col-4{grid-column:span 4}
.bb-col-5{grid-column:span 5}
.bb-col-6{grid-column:span 6}
.bb-col-7{grid-column:span 7}
.bb-col-8{grid-column:span 8}
.bb-col-9{grid-column:span 9}
.bb-col-12{grid-column:span 12}
@media (max-width:1200px){
    .bb-col-3{grid-column:span 6}
    .bb-col-4{grid-column:span 6}
    .bb-col-5{grid-column:span 12}
    .bb-col-7{grid-column:span 12}
    .bb-col-8{grid-column:span 12}
    .bb-col-9{grid-column:span 12}
}
@media (max-width:700px){
    .bb-col-3,.bb-col-4,.bb-col-6{grid-column:span 12}
}

/* ── Standard-Card ── */
.bb-card{background:var(--bg-white);border-radius:var(--r-lg);padding:22px 24px;box-shadow:var(--shadow-sm);transition:box-shadow .2s, transform .2s}
.bb-card:hover{box-shadow:var(--shadow)}
.bb-card--flush{padding:0;overflow:hidden}
.bb-card--accent{border-top:3px solid var(--accent)}
.bb-card--success{border-top:3px solid var(--success)}
.bb-card--warn{border-top:3px solid var(--warning)}
.bb-card--danger{border-top:3px solid var(--danger)}
a.bb-card{text-decoration:none;color:inherit;display:block}
a.bb-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}

.bb-card-head{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.bb-card-head-icon{font-size:1rem;flex-shrink:0}
.bb-card-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--text);margin:0}
.bb-card-sub{font-size:.8rem;color:var(--text-muted);margin-top:2px}

/* ── Buttons (Styleguide — EINZIGE QUELLE) ─────────────────────────────
   Kanonisches Button-System fuers gesamte Kunden-Dashboard.
   Siehe bewertungsboost-styleguide.md. Loest die alten Seiten-/Inline-Klassen
   ab — Mapping:  prx-btn = --primary · twx-77neun-btn = --dark · twx-tip-btn = --ghost
   .bb-btn--primary  Amber-Gradient, DIE eine Haupt-Aktion (auffaelliger CTA)
   .bb-btn--dark     Warm-Anthrazit-Gradient, dunkle starke Aktion
   .bb-btn--ghost    transparent + Slate-Border + Slate-Text, fuellt sich beim Hover (heller CTA)
   .bb-btn--white    weiss + grauer Border, neutrale Sekundaer-/Abbrechen-Aktion
   .bb-btn--ghost-light  transparent + heller Border (nur auf dunklen Flaechen/Hero)
   .bb-btn--sm kompakt (Tabellen/Cards/Toolbars) · .bb-btn--block volle Breite */
.bb-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1.5px solid transparent;border-radius:13px;padding:13px 26px;font-family:var(--font-body);font-size:.92rem;font-weight:700;line-height:1.3;cursor:pointer;text-decoration:none;white-space:nowrap;transition:filter .15s,transform .15s,box-shadow .15s,background .15s,border-color .15s,color .15s}
.bb-btn--primary{background:linear-gradient(135deg,#f5a623,#D4622B);color:#fff;box-shadow:0 10px 26px -12px rgba(212,98,43,.6)}
.bb-btn--primary:hover{filter:brightness(1.05);transform:translateY(-1px);color:#fff}
.bb-btn--dark{background:linear-gradient(135deg,#1A1714,#2a2420);color:#fff;box-shadow:0 8px 22px -12px rgba(26,23,20,.55)}
.bb-btn--dark:hover{filter:brightness(1.18);transform:translateY(-1px);color:#fff}
.bb-btn--white{background:var(--bg-white);color:var(--text);border-color:var(--border);box-shadow:var(--shadow-xs)}
.bb-btn--white:hover{border-color:#cfd4dc;transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.bb-btn--ghost{background:transparent;color:var(--accent);border-color:var(--accent)}
.bb-btn--ghost:hover{background:var(--accent);color:#fff;transform:translateY(-1px)}
.bb-btn--ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.bb-btn--ghost-light:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.7)}
.bb-btn--sm{padding:9px 18px;font-size:.83rem;border-radius:11px;gap:6px}
.bb-btn--block{width:100%}
.bb-btn--icon svg{width:16px;height:16px;flex-shrink:0}
.bb-btn[disabled],.bb-btn:disabled{opacity:.55;cursor:not-allowed;transform:none;filter:none}

/* ── Sektions-Label (kleiner Slate-Strich + Titel) ── */
.bb-section-label{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:var(--text);margin:28px 0 14px}
.bb-section-label::before{content:"";width:4px;height:1.05em;border-radius:2px;background:var(--accent);flex-shrink:0}

/* Split-Card (2-spaltig innerhalb einer Card) — feste Desktop-Hoehe,
   damit sie mit Geschwister-Cards im Grid exakt gleich gross ist. */
.bb-card-split{display:flex;height:420px}
.bb-card-split-left{flex:0 0 45%;padding:22px 24px;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}
.bb-card-split-right{flex:1;padding:16px;background:var(--bg-subtle);overflow-y:auto}
@media (max-width:900px){
    .bb-card-split{flex-direction:column;height:auto}
    .bb-card-split-left{flex:none;border-right:none;border-bottom:1px solid var(--border);padding:18px 20px;overflow:visible}
    .bb-card-split-right{max-height:320px}
}

/* ── KPI-Tile ── */
.bb-kpi{background:var(--bg-white);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:5px;transition:box-shadow .2s, transform .2s}
a.bb-kpi{text-decoration:none;color:inherit}
a.bb-kpi:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.bb-kpi-head{display:flex;align-items:center;gap:6px;font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}
.bb-kpi-head-icon{font-size:.9rem}
.bb-kpi-value{font-family:var(--font-display);font-size:1.7rem;font-weight:800;color:var(--text);line-height:1.1;margin-top:2px}
.bb-kpi-sub{font-size:.72rem;color:var(--text-muted)}
.bb-kpi--accent{border-left:3px solid var(--accent)}
.bb-kpi--success{border-left:3px solid var(--success)}
.bb-kpi--success .bb-kpi-value{color:var(--success)}
.bb-kpi--danger{border-left:3px solid var(--danger)}
.bb-kpi--danger .bb-kpi-value{color:var(--danger)}
.bb-kpi--neutral{border-left:3px solid var(--text-faint)}
.bb-kpi--neutral .bb-kpi-value{color:var(--text-muted)}

/* ── Banner (Handlungs-/Info-Hinweise) ──
   Default: weisse Card mit Shadow — konsistent mit anderen Cards.
   Varianten legen dezente Farb-Tints darueber (Joomla-6-Stil). */
.bb-banner{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-white);border-radius:var(--r-sm);box-shadow:var(--shadow-xs);font-size:.86rem;color:var(--text);text-decoration:none;transition:box-shadow .2s,transform .2s}
.bb-banner:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.bb-banner-icon{font-size:1.3rem;flex-shrink:0}
.bb-banner-body{flex:1;min-width:0}
.bb-banner-title{font-size:.88rem;font-weight:700;color:var(--text)}
.bb-banner-sub{font-size:.78rem;color:var(--text-muted);margin-top:2px}
.bb-banner-arrow{font-size:.82rem;color:var(--accent);font-weight:600;white-space:nowrap}
.bb-banner-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:2px 6px;opacity:.4;transition:opacity .15s}
.bb-banner-close:hover{opacity:1}
/* Joomla-6-artige getoente Varianten: ganz leichte Tint-Hintergruende
   ohne Gradient, ohne separate Borders. Der Shadow gibt die Tiefe. */
.bb-banner--info{background:#eef5fb}
.bb-banner--info .bb-banner-title{color:#1e4d7a}
.bb-banner--success{background:#ecfdf5}
.bb-banner--success .bb-banner-title{color:#0f5132}
.bb-banner--warn{background:#fef8ec}
.bb-banner--warn .bb-banner-title{color:#92610b}
.bb-banner--celebrate{background:#fef6e0;box-shadow:0 2px 8px rgba(234,179,8,.15), 0 1px 2px rgba(0,0,0,.04)}
.bb-banner--celebrate .bb-banner-title{color:#7a5208;font-size:.95rem}
.bb-banner--celebrate .bb-banner-sub{color:#7a5208}
.bb-banner-stack{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}

/* Banner mit Progress-Balken (z.B. Erste Schritte) */
.bb-banner-progress{height:4px;background:var(--bg-elevated);border-radius:99px;margin-top:8px;overflow:hidden}
.bb-banner-progress-fill{height:100%;background:var(--accent);border-radius:99px;opacity:.82;transition:width .4s cubic-bezier(.16,1,.3,1)}

/* ── Pill (einheitliche Filter-/Status-Pills) ── */
.bb-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-white);border:1px solid var(--border);border-radius:var(--r-sm);font-size:.8rem;font-weight:500;color:var(--text);text-decoration:none;transition:border-color .2s,background .2s;cursor:pointer}
.bb-pill:hover{border-color:var(--accent)}
.bb-pill--active{background:var(--accent-light);border-color:var(--accent);color:var(--accent);font-weight:600}
.bb-pill--success{background:var(--success-light);border-color:#86efac;color:#15803d}
.bb-pill--danger{background:var(--danger-light);border-color:#fca5a5;color:#991b1b}
.bb-pill--muted{background:var(--bg-subtle);color:var(--text-muted);border-color:transparent}

/* ── Empty State ── */
.bb-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:32px 20px;color:var(--text-muted)}
.bb-empty-icon{font-size:2rem;opacity:.5;margin-bottom:10px}
.bb-empty-title{font-size:.95rem;font-weight:600;color:var(--text)}
.bb-empty-sub{font-size:.82rem;margin-top:4px;line-height:1.5;max-width:340px}
.bb-empty-action{margin-top:14px;display:inline-block;background:var(--accent);color:#fff;padding:8px 18px;border-radius:var(--r-sm);font-size:.82rem;font-weight:600;text-decoration:none}
.bb-empty-action:hover{background:var(--accent-hover)}

/* ── Hero-Header (dunkler Begruessungs-Block ganz oben auf Dashboard-Seiten)
   Deep Slate Gradient mit Lichtreflex oben rechts, Gegenschein unten links
   und langsam wanderndem Shimmer. */
.bb-hero{position:relative;color:#fff;border-radius:var(--r-xl);padding:36px 40px 32px;margin-bottom:28px;box-shadow:var(--shadow);overflow:hidden;background:linear-gradient(105deg,rgba(18,15,12,.93) 0%,rgba(26,23,20,.82) 45%,rgba(26,23,20,.55) 100%),var(--hero-img,none) center/cover no-repeat,#1A1714}
.bb-hero::before{content:'';position:absolute;top:-60%;right:-12%;width:65%;height:180%;background:radial-gradient(ellipse at center,rgba(212,98,43,.28) 0%,rgba(212,98,43,.10) 40%,transparent 65%);pointer-events:none}
/* Gegenschein unten links + wanderndes Shimmer */
.bb-hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 12% 110%,rgba(245,166,35,.14) 0%,transparent 55%);pointer-events:none}
/* (bb-hero-shimmer entfernt — kein Shine mehr, wie tipps/produkte) */
.bb-hero-shimmer{display:none}
.bb-hero-content{position:relative;z-index:1;display:flex;align-items:flex-start;justify-content:space-between;gap:24px;flex-wrap:wrap}
.bb-hero-main{flex:1;min-width:260px}
.bb-hero-eyebrow{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#f5a623;margin-bottom:16px}
.bb-hero-title{font-family:var(--font-display);font-size:2rem;font-weight:800;letter-spacing:-.02em;color:#fff;line-height:1.15;margin:0}
.bb-hero-sub{font-size:.95rem;color:rgba(255,255,255,.72);margin-top:10px;max-width:680px;line-height:1.55}
.bb-hero-meta{font-size:.78rem;color:rgba(255,255,255,.5);margin-top:10px;letter-spacing:.02em}

/* Rechter Hero-Seitenbereich (Preview + Hints gestapelt) */
.bb-hero-aside{display:flex;flex-direction:column;gap:10px;flex:0 0 38%;max-width:420px;min-width:280px}

/* Preview-Card im Hero: heller Hintergrund, eigenes Farb-Treatment */
.bb-hero .bb-preview-card{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.1);align-self:stretch}
.bb-hero .bb-preview-card:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.2);transform:translateY(-1px)}
.bb-hero .bb-preview-card-label{color:rgba(255,255,255,.55)}
.bb-hero .bb-preview-card-url{color:#fff;max-width:none}
.bb-hero .bb-preview-card-arrow{color:#fff}

/* Hero-Hint: kompaktes Banner im Dunkel-Stil (fuer offene Aktionen) */
.bb-hero-hint{display:flex;align-items:center;gap:10px;padding:10px 14px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);border-radius:12px;color:#fff;text-decoration:none;transition:background .2s, border-color .2s, transform .2s;min-height:52px}
.bb-hero-hint:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.18);transform:translateY(-1px)}
.bb-hero-hint-icon{font-size:1.15rem;flex-shrink:0;line-height:1}
.bb-hero-hint-body{flex:1;min-width:0}
.bb-hero-hint-title{font-size:.8rem;font-weight:700;color:#fff;line-height:1.25}
.bb-hero-hint-sub{font-size:.7rem;color:rgba(255,255,255,.6);margin-top:2px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bb-hero-hint-arrow{font-size:.78rem;color:rgba(255,255,255,.65);font-weight:600;flex-shrink:0}
.bb-hero-hint-close{background:none;border:none;color:rgba(255,255,255,.4);cursor:pointer;font-size:.95rem;padding:2px 4px;line-height:1;transition:color .2s;flex-shrink:0}
.bb-hero-hint-close:hover{color:rgba(255,255,255,.9)}

.bb-hero-hint-progress{height:3px;background:rgba(255,255,255,.12);border-radius:99px;margin-top:5px;overflow:hidden}
.bb-hero-hint-progress-fill{height:100%;background:rgba(255,255,255,.75);border-radius:99px;transition:width .4s cubic-bezier(.16,1,.3,1)}

/* Celebrate-Variante: Gold-Akzent fuer Meilensteine */
.bb-hero-hint--celebrate{background:rgba(250,204,21,.12);border-color:rgba(250,204,21,.22)}
.bb-hero-hint--celebrate:hover{background:rgba(250,204,21,.18);border-color:rgba(250,204,21,.35)}
.bb-hero-hint--celebrate .bb-hero-hint-title{color:#fde68a}
.bb-hero-hint--celebrate .bb-hero-hint-sub{color:rgba(253,230,138,.7)}

@media (max-width:900px){
    .bb-hero-aside{flex:1 1 100%;max-width:none}
}
@media (max-width:700px){
    .bb-hero{padding:26px 22px 22px;border-radius:var(--r-lg)}
    .bb-hero-title{font-size:1.5rem}
    .bb-hero-sub{font-size:.88rem}
}

/* ── Numbered Card (fuer Quick-Actions mit Schritt-Nummern) ── */
.bb-card-num{position:relative;padding-top:30px}
.bb-card-num-badge{position:absolute;top:-14px;left:22px;width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;font-family:var(--font-display);font-size:.92rem;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);letter-spacing:-.02em}

/* ── Preview-Card im Header (Feedback-Seite Vorschau) ── */
.bb-preview-card{display:inline-flex;align-items:center;gap:10px;background:var(--bg-white);border:1px solid var(--border);border-radius:var(--r-sm);padding:8px 14px 8px 10px;text-decoration:none;color:inherit;transition:border-color .2s,transform .2s}
.bb-preview-card:hover{border-color:var(--accent);transform:translateY(-1px)}
.bb-preview-card-qr{width:42px;height:42px;border-radius:10px;background:#fff;box-shadow:0 2px 6px rgba(0,0,0,.08), 0 0 0 1px rgba(0,0,0,.04);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.bb-preview-card-qr canvas{display:block;max-width:100%;max-height:100%}
.bb-preview-card-body{display:flex;flex-direction:column;line-height:1.2;min-width:0}
.bb-preview-card-label{font-size:.68rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}
.bb-preview-card-url{font-size:.8rem;color:var(--text);font-weight:600;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}
.bb-preview-card-arrow{color:var(--accent);font-size:.86rem;margin-left:2px}

/* ── Sidebar-Gruppen-Label (bereits als .nav-section-title vorhanden) ──
   Wird ausgeweitet fuer bessere Abstaende in der gruppierten Sidebar */
.nav-section-title{margin-top:10px}
.nav-section-title:first-of-type{margin-top:4px}

/* ── Feedback-Item (einheitliche Chatbubble-Review-Optik) ── */
.bb-review{background:var(--bg-white);border-left:3px solid var(--border);border-radius:0 8px 8px 0;padding:10px 12px;margin-bottom:6px}
.bb-review--pos{border-left-color:var(--success)}
.bb-review--neg{border-left-color:var(--danger)}
.bb-review-head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px}
.bb-review-author{font-size:.78rem;font-weight:700;color:var(--text)}
.bb-review-stars{font-size:.7rem;color:var(--warning);letter-spacing:1px}
.bb-review-text{font-size:.75rem;color:var(--text-muted);line-height:1.5;font-weight:300}
.bb-review-meta{font-size:.62rem;color:var(--text-muted);opacity:.6;margin-top:3px}

/* ── API-Usage-Widgets im Admin-Dashboard (Anthropic + Google) ──
   Status-Farben werden vom PHP als CSS-Custom-Properties uebergeben:
     <div class="card api-widget" style="--api-color:#10b981;--api-bg:#ecfdf5;">
   Beide Widgets teilen sich exakt dasselbe Klassen-Set. */
.api-widget{padding:20px 22px;background:linear-gradient(135deg,#fff 0%,var(--api-bg,#f5f5f4) 100%);border-left:4px solid var(--api-color,#10b981)}
/* Header: linker Block (Title+Sub) darf schrumpfen, Prozent bleibt fest rechts oben.
   min-width:0 ist Pflicht, damit der lange Sub-Text wirklich umbricht statt den
   Prozent-Block in die naechste Zeile zu druecken. */
.api-widget__header{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-start;justify-content:space-between;margin-bottom:12px}
.api-widget__header > div:first-child{flex:1 1 0;min-width:0}
.api-widget__title{display:flex;align-items:center;gap:10px;margin-bottom:4px;flex-wrap:wrap}
.api-widget__title strong{font-size:.82rem;letter-spacing:.03em}
.api-widget__status{font-size:.65rem;background:var(--api-color);color:#fff;padding:2px 8px;border-radius:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.api-widget__sub{font-size:.78rem;color:var(--text-muted)}
.api-widget__sub strong{color:var(--text)}
.api-widget__sub strong.is-accent{color:var(--api-color)}
.api-widget__percent{font-size:.78rem;color:var(--text-muted);text-align:right;min-width:140px;flex:0 0 auto}
.api-widget__percent-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700}
.api-widget__percent-value{font-size:1.6rem;font-weight:800;color:var(--api-color);line-height:1;margin:2px 0}
.api-widget__percent-hint{font-size:.62rem;color:var(--text-muted);font-weight:700;margin-top:2px}
.api-widget__bar{background:rgba(255,255,255,.5);border-radius:99px;height:10px;overflow:hidden;margin-bottom:12px}
.api-widget__bar-fill{height:100%;background:var(--api-color);border-radius:99px;transition:width .8s ease}
.api-widget__grid{display:grid;grid-template-columns:120px repeat(5,1fr);gap:10px;align-items:stretch;margin-bottom:8px}
.api-widget__grid:last-of-type{margin-bottom:10px}
.api-widget__rowlabel{display:flex;align-items:center;gap:6px;padding:0 4px;font-size:.7rem;font-weight:800;color:var(--text);text-transform:uppercase;letter-spacing:.04em}
.api-widget__rowlabel-icon{font-size:1rem;line-height:1}
.api-widget__cell{background:rgba(255,255,255,.6);padding:10px 14px;border-radius:10px}
.api-widget__cell-label{font-size:.62rem;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.api-widget__cell-value{font-size:1.1rem;font-weight:800;color:var(--text);line-height:1.2}
.api-widget__cell-value.is-error{color:#ef4444}
.api-widget__cell-value.is-accent{color:var(--api-color)}
.api-widget__cell-sub{font-size:.62rem;color:var(--text-muted);margin-top:2px}
/* BB-Reihe (Bewertungsboost, orange) */
.api-widget__grid--bb .api-widget__rowlabel{color:#D4622B}
.api-widget__grid--bb .api-widget__cell{background:rgba(255,255,255,.55);border-left:3px solid #D4622B;padding:8px 14px}
.api-widget__grid--bb .api-widget__cell-value{color:#D4622B;font-size:1rem}
.api-widget__grid--bb .api-widget__cell-value.is-error{color:#ef4444}
/* MR-Reihe (Mitbewerberradar, indigo) */
.api-widget__grid--mr .api-widget__rowlabel{color:#1e40af}
.api-widget__grid--mr .api-widget__cell{background:rgba(255,255,255,.55);border-left:3px solid #1e40af;padding:8px 14px}
.api-widget__grid--mr .api-widget__cell-value{color:#1e40af;font-size:1rem}
.api-widget__grid--mr .api-widget__cell-value.is-error{color:#ef4444}
.api-widget__grid--reg .api-widget__rowlabel{color:#0f766e}
.api-widget__grid--reg .api-widget__cell{background:rgba(255,255,255,.55);border-left:3px solid #0f766e;padding:8px 14px}
.api-widget__grid--reg .api-widget__cell-value{color:#0f766e;font-size:1rem}
.api-widget__grid--reg .api-widget__cell-value.is-error{color:#ef4444}
.api-widget__foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:10px;flex-wrap:wrap}
.api-widget__foot-note{font-size:.7rem;color:var(--text-muted);margin:0;line-height:1.5}
.api-widget__sparkline{height:44px;position:relative}

/* ─── Mobile: API-Widgets als 2-Spalten-Karten-Grid ───
   Das alte 6-spaltige Desktop-Grid (Label + 5 Cells) wird auf Mobile
   umgebaut: Row-Label sitzt ueber den Cells (volle Breite), Cells
   selbst werden 2-spaltig. Das ist deutlich besser scanbar als alles
   in einer Spalte stapeln. */
@media (max-width:900px){
  .api-widget{padding:16px 14px}
  .api-widget__header{gap:10px}
  .api-widget__percent{text-align:right}
  .api-widget__percent-value{font-size:1.35rem}

  .api-widget__grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:12px}
  .api-widget__rowlabel{grid-column:1 / -1;padding:8px 2px 0;font-size:.72rem}
  .api-widget__cell{padding:8px 10px}
  .api-widget__cell-label{font-size:.6rem}
  .api-widget__cell-value{font-size:1.05rem}
  .api-widget__grid--bb .api-widget__cell-value,
  .api-widget__grid--mr .api-widget__cell-value,
  .api-widget__grid--reg .api-widget__cell-value{font-size:.95rem}

  .api-widget__foot{flex-direction:column;align-items:stretch}
  .api-widget__foot-note{order:2}
  .api-widget__foot a, .api-widget__foot button{order:1;text-align:center;justify-content:center}
}

/* ─── Sehr schmale Geraete (< 420px): Header wrappt, Prozent darunter ─── */
@media (max-width:420px){
  .api-widget__header{flex-wrap:wrap}
  .api-widget__percent{flex:1 1 100%;text-align:left;min-width:0;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
  .api-widget__percent-value{font-size:1.2rem;margin:0}
  .api-widget__percent-hint{margin:0}
}


/* ╔══════════════════════════════════════════════════════════════════╗
   ║  LIGHT CINEMATIC POLISH (Mai 2026)                              ║
   ║                                                                  ║
   ║  Ziel: gesamtes Kunden-Portal optisch aufwerten ohne struktur-  ║
   ║  elle Aenderungen — anlehnend an die helle Bewertungsboost-     ║
   ║  Landingpage-Hero-Optik. Wirkt cinematisch und modern, bleibt   ║
   ║  vertrauenswuerdig (heller Hintergrund, dunkle Schrift = Trust-  ║
   ║  Pflicht laut Recherche).                                       ║
   ║                                                                  ║
   ║  Pattern:                                                        ║
   ║   - Subtile Pastell-Verlauf-Hintergruende statt platter Farben  ║
   ║   - Weichere Schatten mit Farb-Tint (Accent-getoent)             ║
   ║   - Groessere Border-Radius (Cards 16-20px statt 12-16px)        ║
   ║   - Hover-Effekte: weicher Lift + Glow statt hartem Shadow      ║
   ║   - Stagger-Reveal-Animationen auf Page-Load (.bb-stagger)      ║
   ║   - Modernere Typografie (groessere Titel, bessere Hierarchie)   ║
   ║   - Focus-Glow auf Inputs (sanft, accent-tinted)                 ║
   ║   - Glassmorphism-light auf wichtigen Cards (backdrop-filter)   ║
   ║                                                                  ║
   ║  Bestehende Klassen werden GEZIELT erweitert/ueberschrieben —   ║
   ║  keine Renames, keine HTML-Aenderungen noetig. JS-Selektoren    ║
   ║  bleiben unberuehrt. Pure visueller Polish.                     ║
   ╚══════════════════════════════════════════════════════════════════╝ */

/* ─── Erweiterte Custom Properties fuer den Polish-Layer ─── */
:root{
    /* Color-tinted Shadows (Joomla-6-meets-cinematic) — fuer Hover */
    --shadow-accent:    0 2px 6px rgba(15,23,42,.05), 0 18px 36px -8px rgba(15,23,42,.14);
    --shadow-accent-lg: 0 4px 10px rgba(15,23,42,.06), 0 28px 56px -12px rgba(15,23,42,.18);
    --shadow-glow-warm: 0 0 0 1px rgba(245,166,35,.18), 0 20px 50px -15px rgba(245,166,35,.28);
    --shadow-glow-success: 0 0 0 1px rgba(34,197,94,.18), 0 20px 50px -15px rgba(34,197,94,.28);

    /* Subtile Hintergrund-Verlauefe */
    --grad-light:    radial-gradient(at 0% 0%, #f7f8fa 0%, transparent 50%), radial-gradient(at 100% 100%, #eef2f6 0%, transparent 60%), #f1f3f6;
    --grad-card:     linear-gradient(165deg, rgba(255,255,255,.96) 0%, rgba(247,248,250,.88) 100%);
    --grad-card-hover: linear-gradient(165deg, rgba(255,255,255,1) 0%, rgba(247,248,250,.95) 100%);

    /* Standardisierte Transitions */
    --tr-card:    transform .35s cubic-bezier(.22,1,.36,1), box-shadow .35s cubic-bezier(.22,1,.36,1), background .25s ease;
    --tr-button:  transform .25s cubic-bezier(.22,1,.36,1), box-shadow .25s cubic-bezier(.22,1,.36,1), background .2s ease, color .2s ease;
}

/* ─── Body-Hintergrund mit sanftem Pastell-Verlauf ───
   Statt platt #f1f3f6 ein subtiler Verlauf — gibt der Seite Tiefe
   ohne aufdringlich zu werden. Auf Druckvorlagen-Editor + Login
   wird mit eigenem Hintergrund ueberschrieben. */
body{
    background: var(--grad-light);
    background-attachment: fixed;
}

/* ─── Card-Polish ───
   Sanfter Verlauf-Hintergrund + groesserer Border-Radius +
   weicherer Hover-Lift mit color-getintem Shadow. Wirkt auf
   alle bestehenden .card und .bb-card-Aufrufe gleichermaßen. */
.card,
.bb-card{
    background: var(--grad-card);
    border-radius: 20px;
    transition: var(--tr-card);
}
.card:hover,
.bb-card:hover{
    background: var(--grad-card-hover);
    box-shadow: var(--shadow-accent);
    transform: translateY(-2px);
}
a.bb-card:hover,
a.stat-card:hover{
    transform: translateY(-3px);
    box-shadow: var(--shadow-accent-lg);
}

/* Card mit Border-Top-Akzent: dezenter, mit etwas Glow */
.bb-card--accent,
.bb-card--success,
.bb-card--warn,
.bb-card--danger{
    border-top-width: 4px;
    position: relative;
}

/* ─── KPI-Tile Polish ─── */
.bb-kpi{
    background: var(--grad-card);
    border-radius: 18px;
    padding: 20px 22px;
    transition: var(--tr-card);
}
.bb-kpi:hover{
    background: var(--grad-card-hover);
    box-shadow: var(--shadow-accent);
}
a.bb-kpi:hover{
    transform: translateY(-3px);
    box-shadow: var(--shadow-accent-lg);
}
.bb-kpi-value{font-size:1.85rem;letter-spacing:-.03em}

/* ─── Stat-Card Polish (Legacy) ─── */
.stat-card{
    background: var(--grad-card);
    border-radius: 20px;
    padding: 24px 26px;
    transition: var(--tr-card);
}
.stat-value{font-size:2rem;letter-spacing:-.04em}

/* ─── Buttons Polish ───
   Groessere padding, weicher Hover-Lift, Color-getinted Glow.
   Wirkt auf alle .btn und .bb-stage-btn-Variants. */
.btn{
    padding: 11px 22px;
    border-radius: 14px;
    font-weight: 700;
    letter-spacing: -.005em;
    transition: var(--tr-button);
}
.btn-primary{
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-hover) 100%);
    box-shadow: 0 6px 16px -4px rgba(15,23,42,.32), 0 2px 4px rgba(15,23,42,.18);
}
.btn-primary:hover{
    transform: translateY(-2px);
    box-shadow: 0 12px 28px -6px rgba(15,23,42,.42), 0 4px 8px rgba(15,23,42,.22);
}
.btn-primary:active{transform: translateY(0);transition-duration: .1s}
.btn-success{
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
    box-shadow: 0 6px 16px -4px rgba(16,185,129,.4), 0 2px 4px rgba(16,185,129,.2);
}
.btn-success:hover{
    background: linear-gradient(135deg, #059669 0%, #047857 100%);
    transform: translateY(-2px);
    box-shadow: 0 12px 28px -6px rgba(16,185,129,.5), 0 4px 8px rgba(16,185,129,.25);
}
.btn-ghost{
    border-width: 1.5px;
    border-radius: 14px;
    transition: var(--tr-button);
}
.btn-ghost:hover{
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm);
}

/* ╔══════════════════════════════════════════════════════════════════╗
   ║  INPUTS — Light Cinematic (Mai 2026, Phase 4)                   ║
   ║                                                                  ║
   ║  Pattern uebernommen von .bb-stage-input (Wizard) und global    ║
   ║  ausgerollt. Wirkt auf alle bestehenden Inputs/Selects/         ║
   ║  Textareas + File-Upload + Color-Picker — keine HTML-Aenderung. ║
   ║                                                                  ║
   ║  Look:                                                           ║
   ║   - Groessere Padding (14px 16px)                                ║
   ║   - Border-Radius 14px (cinematischer)                           ║
   ║   - Subtiler Hintergrund-Tint (#fcfdfe statt platt weiss)       ║
   ║   - Hover: weicher Border + minimal Lift (-1px) + Schatten      ║
   ║   - Focus: warm Color-Tint (Gold) + grosser Glow + Lift         ║
   ║   - Labels: Caps + Letter-Spacing + Spacing                      ║
   ║   - File-Inputs: Custom Button-Look                              ║
   ║   - Selects: Custom Pfeil als Hintergrund-SVG                    ║
   ╚══════════════════════════════════════════════════════════════════╝ */

/* Form-Group bekommt mehr Atem-Raum */
.form-group{margin-bottom: 22px}
.form-group:last-child{margin-bottom: 0}

/* Labels: cinematic Caps-Style (von .bb-stage-input geklaut).
   WICHTIG: nur DIREKTE Child-Labels von .form-group / .bb-stage-input
   bekommen den Caps-Look. Komplexe Labels mit verschachtelten Inhalten
   (z.B. .notify-item, .bb-ansprache-option, inline Radio/Checkbox-Labels)
   wuerden sonst ihre eigenen Spans als Caps rendern — wir vererben sonst
   text-transform + letter-spacing + font-weight ueber die label-Wurzel. */
.form-group > label,
.bb-stage-input > label{
    display: block;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: var(--text-2);
    margin-bottom: 8px;
}

/* Form-Hint unter dem Input — moderne Optik */
.form-hint{
    font-size: .78rem;
    color: var(--text-muted);
    margin-top: 8px;
    line-height: 1.5;
}

/* Haupt-Input-Selektor: alle relevanten Felder einheitlich */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="url"],
input[type="search"],
input[type="number"],
input[type="date"],
input[type="time"],
input[type="datetime-local"],
select,
textarea{
    width: 100%;
    padding: 14px 16px;
    background: linear-gradient(165deg, #ffffff 0%, #fcfdfe 100%);
    border: 1.5px solid #e1e5ec;
    border-radius: 14px;
    font-family: var(--font-body);
    font-size: .92rem;
    color: var(--text);
    line-height: 1.45;
    box-shadow: 0 1px 2px rgba(15,23,42,.02), inset 0 1px 0 rgba(255,255,255,.6);
    transition: border-color .2s ease, box-shadow .25s ease, transform .2s ease, background .2s ease;
    box-sizing: border-box;
}
input[type="text"]:hover,
input[type="email"]:hover,
input[type="password"]:hover,
input[type="tel"]:hover,
input[type="url"]:hover,
input[type="search"]:hover,
input[type="number"]:hover,
input[type="date"]:hover,
input[type="time"]:hover,
input[type="datetime-local"]:hover,
select:hover,
textarea:hover{
    border-color: #b8c1ce;
    box-shadow: 0 4px 12px -4px rgba(15,23,42,.08), inset 0 1px 0 rgba(255,255,255,.6);
}
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="tel"]:focus,
input[type="url"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="date"]:focus,
input[type="time"]:focus,
input[type="datetime-local"]:focus,
select:focus,
textarea:focus{
    outline: none;
    border-color: #f5a623;
    background: #fff;
    transform: translateY(-1px);
    box-shadow:
        0 0 0 4px rgba(245,166,35,.14),
        0 8px 24px -8px rgba(245,166,35,.25),
        0 2px 6px rgba(15,23,42,.06);
}

/* Disabled / Readonly: sichtbar 'gedimmt' */
input:disabled,
input[readonly],
select:disabled,
textarea:disabled,
textarea[readonly]{
    background: #f5f6fa !important;
    color: var(--text-muted);
    cursor: not-allowed;
    box-shadow: none;
}
input:disabled:hover,
input[readonly]:hover,
select:disabled:hover,
textarea:disabled:hover{
    border-color: #e1e5ec;
    transform: none;
    box-shadow: none;
}

/* Placeholder */
input::placeholder,
textarea::placeholder{
    color: #a1a8b5;
    opacity: 1;
    font-weight: 400;
}

/* ─── SELECT: custom Pfeil als Hintergrund-SVG ───
   WICHTIG: background-position/repeat/size sind hier explizit hardcoded
   und werden NICHT in :hover/:focus ueberschrieben. Wenn ein lokales
   CSS background-image:none setzt (z.B. .ep-select fuer Editor), muss
   es das in :focus ebenfalls tun — sonst kommt der Pfeil im Focus zurueck
   (Specificity: select:focus > .ep-select). Siehe .ep-select-Block.
*/
select{
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    padding-right: 44px;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 14px center;
    background-size: 16px;
    cursor: pointer;
}
select:focus{
    /* nur Farbe wechseln, background-position/repeat/size bleiben vom select{} */
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f5a623' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 14px center;
    background-size: 16px;
}

/* ─── TEXTAREA: angepasste Default-Hoehe + Resize ─── */
textarea{
    resize: vertical;
    min-height: 110px;
    line-height: 1.55;
}

/* ─── FILE-UPLOAD: Custom Button-Look ─── */
input[type="file"]{
    width: 100%;
    padding: 12px 14px;
    background: linear-gradient(165deg, #ffffff 0%, #fcfdfe 100%);
    border: 1.5px dashed #cbd2dc;
    border-radius: 14px;
    font-family: var(--font-body);
    font-size: .88rem;
    color: var(--text-muted);
    cursor: pointer;
    transition: border-color .2s ease, background .2s ease, transform .2s ease, box-shadow .25s ease;
    box-sizing: border-box;
}
input[type="file"]:hover{
    border-color: #f5a623;
    background: linear-gradient(165deg, #fffbf3 0%, #fff7e6 100%);
    color: var(--text);
}
input[type="file"]:focus{
    outline: none;
    border-color: #f5a623;
    border-style: solid;
    background: #fff;
    box-shadow:
        0 0 0 4px rgba(245,166,35,.14),
        0 8px 24px -8px rgba(245,166,35,.25);
}
/* WebKit: der "Datei auswaehlen"-Button selbst */
input[type="file"]::-webkit-file-upload-button{
    background: linear-gradient(135deg, #1A1714 0%, #2a2420 100%);
    color: #fff;
    border: none;
    padding: 8px 16px;
    border-radius: 9px;
    font-family: var(--font-body);
    font-size: .82rem;
    font-weight: 700;
    letter-spacing: -.005em;
    cursor: pointer;
    margin-right: 12px;
    transition: filter .2s ease, transform .15s ease;
    box-shadow: 0 4px 10px -2px rgba(15,23,42,.25);
}
input[type="file"]::-webkit-file-upload-button:hover{
    filter: brightness(1.15);
    transform: translateY(-1px);
}
/* Firefox: gleiches Pattern */
input[type="file"]::file-selector-button{
    background: linear-gradient(135deg, #1A1714 0%, #2a2420 100%);
    color: #fff;
    border: none;
    padding: 8px 16px;
    border-radius: 9px;
    font-family: var(--font-body);
    font-size: .82rem;
    font-weight: 700;
    letter-spacing: -.005em;
    cursor: pointer;
    margin-right: 12px;
    transition: filter .2s ease, transform .15s ease;
    box-shadow: 0 4px 10px -2px rgba(15,23,42,.25);
}
input[type="file"]::file-selector-button:hover{
    filter: brightness(1.15);
    transform: translateY(-1px);
}

/* ─── INPUT[type="color"]: groesseres Swatch + sanftes Hover ─── */
input[type="color"]{
    width: 56px;
    height: 48px;
    padding: 4px;
    border: 1.5px solid #e1e5ec;
    border-radius: 12px;
    cursor: pointer;
    background: #fff;
    box-shadow: 0 1px 2px rgba(15,23,42,.02), inset 0 1px 0 rgba(255,255,255,.6);
    transition: border-color .2s ease, box-shadow .25s ease, transform .2s ease;
}
input[type="color"]:hover{
    border-color: #f5a623;
    transform: translateY(-1px);
    box-shadow: 0 6px 14px -4px rgba(245,166,35,.3);
}
input[type="color"]::-webkit-color-swatch-wrapper{padding: 0; border-radius: 8px; overflow: hidden}
input[type="color"]::-webkit-color-swatch{border: none; border-radius: 8px}
input[type="color"]::-moz-color-swatch{border: none; border-radius: 8px}

/* ─── INPUT[type="checkbox"] + RADIO: groesser + Akzent-Farbe ─── */
input[type="checkbox"],
input[type="radio"]{
    width: 18px;
    height: 18px;
    accent-color: var(--accent);
    cursor: pointer;
    margin: 0 6px 0 0;
    vertical-align: middle;
}

/* Inline-Buttons innerhalb von Input-Gruppen sollen ihr Look behalten */
input[type="submit"],
input[type="button"],
input[type="reset"]{
    width: auto;
    padding: 12px 22px;
    border-radius: 14px;
    font-family: var(--font-body);
    font-weight: 700;
    font-size: .92rem;
    cursor: pointer;
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-hover) 100%);
    color: #fff;
    border: none;
    box-shadow: 0 6px 16px -4px rgba(15,23,42,.32);
    transition: transform .2s ease, box-shadow .25s ease;
}
input[type="submit"]:hover,
input[type="button"]:hover{
    transform: translateY(-2px);
    box-shadow: 0 12px 28px -6px rgba(15,23,42,.42);
}

/* Reduce-Motion: keine Transforms */
@media (prefers-reduced-motion: reduce){
    input:focus,
    select:focus,
    textarea:focus,
    input[type="color"]:hover,
    input[type="file"]::-webkit-file-upload-button:hover,
    input[type="file"]::file-selector-button:hover,
    input[type="submit"]:hover,
    input[type="button"]:hover{
        transform: none;
    }
}

/* ─── Pills Polish ─── */
.bb-pill{
    border-radius: 10px;
    padding: 7px 14px;
    font-weight: 600;
    transition: var(--tr-button);
}
.bb-pill:hover{
    transform: translateY(-1px);
    box-shadow: var(--shadow-xs);
}
.bb-pill--active{
    box-shadow: 0 4px 10px -2px rgba(15,23,42,.18);
}

/* ─── Page-Header Polish ─── */
.page-title{
    font-size: 1.9rem;
    letter-spacing: -.025em;
}
.page-subtitle{
    font-size: .92rem;
    margin-top: 6px;
}

/* ─── Section-Head Polish ─── */
.bb-section-title{
    font-size: 1.32rem;
    letter-spacing: -.02em;
}
.bb-section-sub{
    font-size: .88rem;
    margin-top: 4px;
}

/* ─── Stagger-Reveal ENTFERNT (Juni 2026) ───
   Das gestaffelte Hochschieben/Einblenden beim Seitenladen kollidierte mit dem
   View-Transition-Crossfade beim Seitenwechsel. Die .bb-stagger-Klasse bleibt im
   Markup erhalten, hat aber keinen Effekt mehr (Elemente sind sofort sichtbar). */
.bb-stagger > *{ opacity: 1; }

/* ─── Page-Header Entrance ENTFERNT (Juni 2026, s.o. Stagger) ─── */

/* ─── Banner Polish ─── */
.bb-banner{
    border-radius: 14px;
    padding: 16px 20px;
    transition: var(--tr-card);
}
.bb-banner:hover{
    transform: translateY(-2px);
    box-shadow: var(--shadow-sm);
}

/* ─── Tabellen Polish ─── */
.table-wrapper{
    border-radius: 16px;
    background: var(--grad-card);
}
thead th{
    background: rgba(247,248,250,.6);
    font-weight: 700;
    color: var(--text-2);
    letter-spacing: .05em;
}
tbody tr{transition: background .15s ease}
tbody tr:hover{background: rgba(247,248,250,.7)}

/* ─── Hero (heller) — Variante fuer Cinematic Light ───
   Optional ueber .bb-hero--light, falls eine Seite einen
   hellen Hero will. Bisheriger Dark-Hero (.bb-hero) bleibt
   bestehen, weil er auf Dashboard etabliert ist. */
.bb-hero--light{
    background: linear-gradient(135deg, #f8fafc 0%, #eef2f7 50%, #e2e8f0 100%);
    color: var(--text);
}
.bb-hero--light::before{
    background: radial-gradient(ellipse at center, rgba(15,23,42,.04) 0%, transparent 65%);
}
.bb-hero--light::after{
    background: radial-gradient(ellipse at 12% 110%, rgba(56,189,248,.12) 0%, transparent 55%);
}
.bb-hero--light .bb-hero-title{color: var(--text)}
.bb-hero--light .bb-hero-sub{color: var(--text-muted)}
.bb-hero--light .bb-hero-eyebrow{
    background: rgba(15,23,42,.08);
    color: var(--accent);
}

/* ─── Empty-State Polish ─── */
.bb-empty-action{
    border-radius: 12px;
    padding: 10px 22px;
    box-shadow: 0 6px 16px -4px rgba(15,23,42,.3);
    transition: var(--tr-button);
}
.bb-empty-action:hover{
    transform: translateY(-2px);
    box-shadow: 0 12px 28px -6px rgba(15,23,42,.4);
}

/* ─── Badges Polish ─── */
.badge{
    padding: 4px 11px;
    border-radius: 99px;
    font-weight: 700;
    letter-spacing: .015em;
}

/* ─── Login-Card cinematic ─── */
.login-card{
    background: var(--grad-card);
    border-radius: 24px;
    padding: 48px 42px;
    box-shadow:
        0 24px 60px -12px rgba(15,23,42,.18),
        0 8px 20px -4px rgba(15,23,42,.08),
        inset 0 1px 0 rgba(255,255,255,.7);
}
.login-wrapper{
    background:
        radial-gradient(ellipse at top left, rgba(15,166,142,.12) 0%, transparent 50%),
        radial-gradient(ellipse at bottom right, rgba(245,166,35,.12) 0%, transparent 50%),
        linear-gradient(135deg, #f8fafc 0%, #eef2f7 100%);
}
.login-title{
    font-size: 1.55rem;
    letter-spacing: -.025em;
}

/* ─── Form-Group spacing leicht erhoeht ─── */
.form-group{margin-bottom: 20px}

/* ─── Scrollbar moderner ─── */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-thumb{background:rgba(15,23,42,.15);border-radius:99px;transition:background .2s}
::-webkit-scrollbar-thumb:hover{background:rgba(15,23,42,.25)}

/* ╔══════════════════════════════════════════════════════════════════╗
   ║  BB-PAGE-HERO (Phase 2 — Mai 2026)                              ║
   ║                                                                  ║
   ║  Heller cineastischer Hero-Block fuer Seiten ohne eigenen       ║
   ║  Hero (Mitbewerber, QR-Code, Profil, Erste-Schritte etc.).      ║
   ║                                                                  ║
   ║  Im Gegensatz zu .bb-hero (dunkel, etabliert auf Dashboard +    ║
   ║  Bewertungen) ist .bb-page-hero hell mit weichem Pastell-       ║
   ║  Verlauf + dezenten Aurora-Lichtreflexen. Trust-tauglich        ║
   ║  (helle Schrift auf hellem Grund waere lese-feindlich),          ║
   ║  cinematisch durch die Tiefe der Layer.                          ║
   ║                                                                  ║
   ║  Struktur:                                                       ║
   ║   <div class="bb-page-hero">                                    ║
   ║     <div class="bb-page-hero-eyebrow">OPTIONAL EYEBROW</div>    ║
   ║     <h1 class="bb-page-hero-title">Titel</h1>                   ║
   ║     <p class="bb-page-hero-sub">Subtitle</p>                    ║
   ║     <div class="bb-page-hero-meta">optionale Meta-Info</div>   ║
   ║   </div>                                                         ║
   ╚══════════════════════════════════════════════════════════════════╝ */

.bb-page-hero{
    position: relative;
    overflow: hidden;
    border-radius: 24px;
    padding: clamp(28px,5vw,56px);
    margin-bottom: 28px;
    color: #fff;
    background:
        linear-gradient(105deg, rgba(18,15,12,.93) 0%, rgba(26,23,20,.82) 45%, rgba(26,23,20,.55) 100%),
        var(--hero-img, none) center/cover no-repeat,
        #1A1714;
    box-shadow: 0 2px 6px rgba(15,23,42,.06), 0 22px 50px -16px rgba(15,23,42,.30);
    /* On-Load-Entrance entfernt (Juni 2026): kollidierte mit dem View-Transition-Crossfade. */
}
/* Cineastische Glow-Reflexe (amber/orange), identisch zu tipps/produkte */
.bb-page-hero::before{
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 80% 14%, rgba(212,98,43,.30), transparent 46%),
        radial-gradient(circle at 8% 94%, rgba(245,166,35,.16), transparent 46%);
}
@media (prefers-reduced-motion: reduce){
    .bb-page-hero{animation:none}
}
/* Inhalt steht ueber den dekorativen Schichten */
.bb-page-hero > *{position: relative; z-index: 1}

.bb-page-hero-eyebrow{
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: #f5a623;
    margin-bottom: 14px;
}
.bb-page-hero-title{
    font-family: var(--font-display);
    font-size: clamp(1.55rem, 3.2vw, 2.2rem);
    font-weight: 800;
    letter-spacing: -.028em;
    color: #fff;
    line-height: 1.12;
    margin: 0;
}
.bb-page-hero-sub{
    font-size: 1rem;
    color: rgba(250,246,241,.72);
    margin-top: 10px;
    max-width: 64ch;
    line-height: 1.55;
}
.bb-page-hero-meta{
    font-size: .82rem;
    color: rgba(250,246,241,.5);
    margin-top: 14px;
    letter-spacing: .01em;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
/* CTA-Reihe + Mini-Zeile (wie tipps/produkte) */
.bb-page-hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:22px}
.bb-page-hero-mini{display:flex;flex-wrap:wrap;gap:18px;font-size:.82rem;color:rgba(250,246,241,.55);margin-top:18px}
/* Aktions-Slot oben rechts (z.B. Profil "Alle Einstellungen speichern") */
.bb-page-hero-actions{position:absolute;top:clamp(20px,4vw,40px);right:clamp(20px,4vw,40px);z-index:2;display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
/* Optional: Aside-Bereich rechts (z.B. Stats, Quick-Action) */
.bb-page-hero-row{
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 28px;
    flex-wrap: wrap;
}
.bb-page-hero-main{flex: 1 1 auto; min-width: 0}
.bb-page-hero-aside{flex: 0 0 auto}

@media (max-width: 700px){
    .bb-page-hero{padding: 26px 22px 24px; border-radius: 20px}
    .bb-page-hero-sub{font-size: .92rem}
    .bb-page-hero-row{flex-direction: column; align-items: flex-start; gap: 16px}
    .bb-page-hero-aside{width: 100%}
    .bb-page-hero-actions{position: static; margin-top: 16px; justify-content: flex-start}
}

/* ╔══════════════════════════════════════════════════════════════════╗
   ║  SIDEBAR + MOBILE-TOPBAR POLISH (Phase 3 — Mai 2026)            ║
   ║                                                                  ║
   ║  Pure visueller Polish ohne HTML-Aenderungen. Sidebar bekommt    ║
   ║  Tiefe durch sanften vertikalen Gradient, Active-Indicator-Line, ║
   ║  weichere Hover-Animationen, subtilen Glow auf Logo + Avatar.   ║
   ║  Mobile-Topbar bekommt Glassmorphism (backdrop-blur).            ║
   ║  Mobile-Nav-Panel bekommt cinematic Reveal-Animation.            ║
   ╚══════════════════════════════════════════════════════════════════╝ */

/* ─── Sidebar: vertikaler Gradient + Inner-Glow ─── */
.sidebar{
    background:
        radial-gradient(ellipse at top, rgba(245,166,35,.06) 0%, transparent 55%),
        linear-gradient(180deg, #2a2420 0%, #1A1714 100%);
    box-shadow:
        4px 0 24px rgba(0,0,0,.12),
        inset -1px 0 0 rgba(255,255,255,.04);
}

/* Sidebar-Logo: subtle Glow + Color-Verlauf auf 77NEUN-Span */
.sidebar-logo{
    padding: 28px 22px 20px;
    position: relative;
}
.sidebar-logo::after{
    content: '';
    position: absolute;
    bottom: 0;
    left: 18px;
    right: 18px;
    height: 1px;
    background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,.18) 50%, transparent 100%);
}
.sidebar-logo .logo-text span{
    background: linear-gradient(135deg, #fbbf24 0%, #f5a623 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Nav-Section-Titles: mehr Spacing + bessere Hierarchie */
.nav-section-title{
    padding: 18px 14px 6px;
    font-size: .65rem;
    letter-spacing: .12em;
    color: rgba(255,255,255,.38);
    font-weight: 700;
}

/* Nav-Items: Active-Indicator-Line links + weichere Hover-Animation */
.nav-item{
    padding: 11px 14px;
    border-radius: 12px;
    position: relative;
    white-space: nowrap;
    transition: background .2s ease, color .2s ease, transform .2s ease, padding-left .2s ease;
}
.nav-item:hover{
    background: rgba(255,255,255,.07);
    color: #fff;
    padding-left: 16px;
}
.nav-item.active{
    background: linear-gradient(90deg, rgba(255,255,255,.14) 0%, rgba(255,255,255,.08) 100%);
    color: #fff;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.nav-item.active::before{
    content: '';
    position: absolute;
    left: 0;
    top: 22%;
    bottom: 22%;
    width: 3px;
    border-radius: 0 3px 3px 0;
    background: linear-gradient(180deg, #fbbf24 0%, #f5a623 100%);
    box-shadow: 0 0 8px rgba(245,166,35,.5);
}
.nav-item .icon{
    transition: transform .2s ease;
}
.nav-item:hover .icon{
    transform: scale(1.08);
}

/* Nav-Badge (ungelesene Bewertungen): weicher Glow */
.nav-badge{
    background: #ef4444;
    box-shadow: 0 2px 6px rgba(239,68,68,.4);
    padding: 2px 7px;
    font-size: .65rem;
}

/* Sidebar-Footer: subtiler Trenner-Verlauf */
.sidebar-footer{
    padding: 12px 10px;
    border-top: 1px solid transparent;
    position: relative;
}
.sidebar-footer::before{
    content: '';
    position: absolute;
    top: 0;
    left: 18px;
    right: 18px;
    height: 1px;
    background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,.14) 50%, transparent 100%);
}

/* User-Avatar mit subtle Border-Glow */
.sidebar-user .avatar{
    background: linear-gradient(135deg, rgba(255,255,255,.18) 0%, rgba(255,255,255,.08) 100%);
    box-shadow:
        0 0 0 1px rgba(255,255,255,.1),
        0 4px 12px rgba(0,0,0,.25);
    color: #fff;
}

/* ─── Mobile-Topbar: Glassmorphism ─── */
.mobile-topbar{
    background: rgba(255,255,255,.85);
    backdrop-filter: blur(14px) saturate(1.3);
    -webkit-backdrop-filter: blur(14px) saturate(1.3);
    border-bottom: 1px solid rgba(15,23,42,.06);
    box-shadow:
        0 4px 16px rgba(15,23,42,.06),
        0 1px 2px rgba(15,23,42,.04);
}
.burger-btn{
    background: rgba(15,23,42,.06);
    border-radius: 12px;
    padding: 8px 10px;
    transition: background .2s ease, transform .2s ease;
}
.burger-btn:hover{
    background: rgba(15,23,42,.12);
    transform: scale(1.05);
}
.burger-btn:active{
    transform: scale(.95);
}

/* ─── Mobile-Nav-Overlay: cinematischer Backdrop ─── */
.mobile-nav-overlay{
    background: rgba(15,23,42,.45);
    backdrop-filter: blur(6px) saturate(.85);
    -webkit-backdrop-filter: blur(6px) saturate(.85);
}

/* Mobile-Nav-Panel: weiche Slide-Animation + Schatten */
.mobile-nav-panel{
    background: var(--grad-card);
    box-shadow:
        -16px 0 40px rgba(15,23,42,.18),
        -4px 0 8px rgba(15,23,42,.06);
    border-radius: 24px 0 0 24px;
    padding: 24px 18px;
}
@keyframes mnavSlideIn{
    from{transform: translateX(100%); opacity: 0}
    to{transform: translateX(0); opacity: 1}
}
.mobile-nav-panel{
    animation: mnavSlideIn .3s cubic-bezier(.22,1,.36,1);
}

/* Mobile-Nav-Items: weichere Hover-Animation */
.mobile-nav-item{
    border-radius: 12px;
    padding: 12px 14px;
    transition: background .15s ease, transform .15s ease, padding-left .15s ease;
}
.mobile-nav-item:hover{
    background: var(--bg-subtle);
    padding-left: 16px;
}
.mobile-nav-item.active{
    background: rgba(15,23,42,.08);
    color: var(--accent);
    font-weight: 700;
    position: relative;
}
.mobile-nav-item.active::before{
    content: '';
    position: absolute;
    left: 0;
    top: 22%;
    bottom: 22%;
    width: 3px;
    border-radius: 0 3px 3px 0;
    background: linear-gradient(180deg, #fbbf24 0%, #f5a623 100%);
}

.mobile-nav-section{
    font-size: .65rem;
    letter-spacing: .12em;
    color: var(--text-muted);
    padding: 18px 14px 6px;
    font-weight: 700;
}

/* Varianten — Akzent-Farbe der Aurora kann pro Seite getauscht werden */
/* (Hero-Varianten entfernt — alle Seiten-Heroes sind jetzt identisch:
   warmes Anthrazit + Amber-Glow. Eine Quelle, kein Sonderfall pro Seite.) */

/* ╔══════════════════════════════════════════════════════════════════╗
   ║  GLOBAL MODAL-SYSTEM (Mai 2026 — Phase 4c)                      ║
   ║                                                                  ║
   ║  Verschoben aus kunde/profil.php in den globalen Polish-Layer   ║
   ║  damit Modale auf JEDER Seite verwendbar sind (Druckvorlagen-   ║
   ║  Editor, Admin etc.). FOUC-Schutz im Markup erforderlich:       ║
   ║   <div class="bb-modal-overlay" hidden style="visibility:hidden;║
   ║        opacity:0;" id="...">                                    ║
   ║                                                                  ║
   ║  Beim Oeffnen via JS: removeAttribute('hidden') +               ║
   ║   style.removeProperty('visibility') + style.removeProperty(    ║
   ║   'opacity') + classList.add('is-open')                          ║
   ╚══════════════════════════════════════════════════════════════════╝ */
.bb-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, .55);
    z-index: 9990;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity .2s ease, visibility 0s linear .2s;
}
.bb-modal-overlay.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transition: opacity .2s ease, visibility 0s linear 0s;
}
.bb-modal {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, .25);
    max-width: 520px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    transform: scale(.95);
    transition: transform .2s ease;
}
.bb-modal-overlay.is-open .bb-modal { transform: scale(1); }
.bb-modal-head {
    padding: 22px 26px 16px;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: 12px;
}
.bb-modal-icon {
    width: 44px;
    height: 44px;
    flex: 0 0 44px;
    background: #fef3c7;
    color: #b45309;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
}
.bb-modal-icon.is-danger {
    background: var(--danger-light);
    color: var(--danger);
}
.bb-modal-title {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--text);
    margin: 0;
}
.bb-modal-body {
    padding: 18px 26px 22px;
    font-size: .92rem;
    color: var(--text);
    line-height: 1.55;
}
.bb-modal-body p { margin: 0 0 14px; }
.bb-modal-body p:last-child { margin-bottom: 0; }
.bb-modal-body strong { color: var(--text); font-weight: 700; }
.bb-modal-actions {
    padding: 16px 26px 22px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    border-top: 1px solid var(--border);
    background: var(--bg-subtle);
    border-radius: 0 0 16px 16px;
}
@media (max-width: 480px) {
    .bb-modal-actions { grid-template-columns: 1fr; }
}

/* Standard-Modal-Buttons (auch separat verwendbar) */
.bb-stage-btn {
    padding: 13px 18px;
    border-radius: 10px;
    font-size: .92rem;
    font-weight: 700;
    cursor: pointer;
    font-family: inherit;
    border: 1.5px solid transparent;
    transition: all .15s;
    text-align: center;
}
.bb-stage-btn-primary {
    background: linear-gradient(135deg, #f5a623, #D4622B);
    color: #fff;
    box-shadow: 0 4px 14px rgba(212, 98, 43, .28);
}
.bb-stage-btn-primary:hover {
    box-shadow: 0 6px 20px rgba(212, 98, 43, .38);
    transform: translateY(-1px);
}
.bb-stage-btn-secondary {
    background: var(--bg-subtle);
    color: var(--text);
    border-color: var(--border);
}
.bb-stage-btn-secondary:hover {
    background: #fff;
    border-color: var(--text-muted);
}
/* Danger-Variante fuer irreversible Loesch-Aktionen (z.B. Foto-Loeschen) */
.bb-stage-btn-danger {
    background: linear-gradient(135deg, var(--danger), #b91c1c);
    color: #fff;
    box-shadow: 0 4px 14px rgba(220, 38, 38, .28);
}
.bb-stage-btn-danger:hover {
    box-shadow: 0 6px 20px rgba(220, 38, 38, .38);
    transform: translateY(-1px);
}

/* ─── Digistore-Testpay-Banner ───────────────────────────────────── */
/* Aktiv-Variante: knall-rot, weisse Schrift, leichter Puls — niemand soll
   das uebersehen, weil im Testpay-Modus keine echten Kaeufe ankommen.
   Inaktiv-Variante: dezent neutral, nur damit der Toggle erreichbar bleibt. */
.bb-testpay-banner {
    border-radius: 12px;
    padding: 14px 18px;
    margin-bottom: 18px;
    font-size: .92rem;
    line-height: 1.45;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
}
.bb-testpay-banner__text {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 260px;
    flex: 1;
}
.bb-testpay-banner__icon {
    font-size: 1.4rem;
    line-height: 1;
}
.bb-testpay-banner__sub {
    display: block;
    font-size: .85rem;
    opacity: .92;
    margin-top: 2px;
}
.bb-testpay-banner__form {
    margin: 0;
    flex-shrink: 0;
}
.bb-testpay-banner__btn {
    font-size: .82rem;
    padding: 9px 16px;
    border-radius: 8px;
    border: 0;
    cursor: pointer;
    font-weight: 700;
    letter-spacing: .02em;
    transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}

/* Aktiv-Zustand: Alarm-Rot */
.bb-testpay-banner--alarm {
    background: linear-gradient(135deg, #d62828 0%, #a01919 100%);
    border: 1px solid #7a1010;
    color: #fff;
    box-shadow: 0 6px 22px -8px rgba(214, 40, 40, .55), inset 0 1px 0 rgba(255,255,255,.12);
    animation: bbTestpayPulse 2.4s ease-in-out infinite;
}
.bb-testpay-banner--alarm .bb-testpay-banner__sub {
    color: rgba(255,255,255,.92);
}
.bb-testpay-banner--alarm .bb-testpay-banner__btn {
    background: #fff;
    color: #a01919;
}
.bb-testpay-banner--alarm .bb-testpay-banner__btn:hover {
    background: #fff;
    color: #7a1010;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0,0,0,.18);
}
@keyframes bbTestpayPulse {
    0%, 100% { box-shadow: 0 6px 22px -8px rgba(214, 40, 40, .55), inset 0 1px 0 rgba(255,255,255,.12); }
    50%      { box-shadow: 0 8px 30px -6px rgba(214, 40, 40, .80), inset 0 1px 0 rgba(255,255,255,.12); }
}

/* Inaktiv-Zustand: neutral */
.bb-testpay-banner--ok {
    background: linear-gradient(135deg, #f4f6f8, #e7ebef);
    border: 1px solid #c2cad3;
    color: #4a5560;
}
.bb-testpay-banner--ok .bb-testpay-banner__btn {
    background: var(--accent, #1b6ca8);
    color: #fff;
}
.bb-testpay-banner--ok .bb-testpay-banner__btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0,0,0,.12);
}

@media (prefers-reduced-motion: reduce) {
    .bb-testpay-banner--alarm { animation: none; }
    .bb-testpay-banner__btn:hover { transform: none !important; }
}

/* ─── Reduce-Motion-Respekt fuer alle Hover-Transforms ─── */
@media (prefers-reduced-motion: reduce){
    .card,.bb-card,.bb-kpi,.stat-card,.btn,.btn-ghost,.btn-primary,.btn-success,
    .bb-pill,.bb-banner,.bb-empty-action,a.bb-card,a.bb-kpi,a.stat-card,
    tbody tr{
        transition: none !important;
    }
    .card:hover,.bb-card:hover,.bb-kpi:hover,.stat-card:hover,.btn:hover,
    .bb-pill:hover,.bb-banner:hover,.bb-empty-action:hover{
        transform: none !important;
    }
}
