/* Bennys Werkstatt – GTA 5 FiveM Bennys Design */
/* Rot / Schwarz / Weiß – Benny's Original Motor Works Style */

@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;600;700&family=Roboto+Condensed:wght@300;400;700&display=swap');

:root {
    --bg-dark: #0a0a0a;
    --bg-anthracite: #1a1a1a;
    --bg-card: #141414;
    --bg-elevated: #2d2d2d;
    --benny-red: #c0392b;
    --benny-red-light: #e74c3c;
    --benny-red-dim: #922b21;
    --gold-primary: #c0392b;
    --gold-light: #e74c3c;
    --gold-dim: #922b21;
    --text-primary: #f5f5f5;
    --text-muted: #b0b0b0;
    --danger: #c0392b;
    --warning: #f39c12;
    --success: #27ae60;
    --border: #333;
    --white-outline: #fff;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Roboto Condensed', sans-serif;
    background: var(--bg-dark);
    color: var(--text-primary);
    min-height: 100vh;
    overflow-x: hidden;
}

.app {
    display: flex;
    min-height: 100vh;
}

/* Sidebar */
.sidebar {
    width: 240px;
    background: var(--bg-anthracite);
    border-right: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    position: fixed;
    height: 100vh;
}

.logo {
    padding: 20px 16px;
    text-align: center;
    border-bottom: 2px solid var(--benny-red);
    background: linear-gradient(180deg, var(--bg-card) 0%, var(--bg-anthracite) 100%);
}

.logo-img {
    max-width: 100%;
    height: auto;
    max-height: 56px;
    object-fit: contain;
    display: block;
    margin: 0 auto 6px;
    filter: drop-shadow(0 0 2px rgba(255,255,255,0.3));
}

.logo-icon {
    font-size: 2.5rem;
    display: block;
    margin-bottom: 8px;
}

.logo h1 {
    font-family: 'Orbitron', sans-serif;
    font-size: 1.4rem;
    color: var(--benny-red);
    letter-spacing: 2px;
}

.logo-fallback {
    font-family: 'Orbitron', sans-serif;
    font-size: 1.5rem;
    color: var(--benny-red);
    display: block;
    margin-bottom: 4px;
}

.logo-sub {
    font-size: 0.7rem;
    color: var(--text-muted);
    letter-spacing: 3px;
    text-transform: uppercase;
}

.nav-menu {
    flex: 1;
    padding: 16px 0;
    overflow-y: auto;
}

.nav-btn {
    width: 100%;
    padding: 12px 20px;
    background: none;
    border: none;
    color: var(--text-muted);
    font-family: inherit;
    font-size: 0.9rem;
    text-align: left;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 12px;
    transition: all 0.2s;
    border-left: 3px solid transparent;
}

.nav-btn:hover {
    background: var(--bg-elevated);
    color: var(--benny-red-light);
}

.nav-btn.active {
    background: var(--bg-card);
    color: var(--benny-red);
    border-left-color: var(--benny-red);
}

.nav-icon {
    font-size: 1.1rem;
}

.sidebar-footer {
    padding: 16px;
    border-top: 1px solid var(--border);
}

.app-copyright {
    margin-top: 14px;
    padding-top: 12px;
    border-top: 1px solid var(--border);
    font-size: 0.78rem;
    color: var(--text-muted);
    line-height: 1.35;
}

.app-copyright strong {
    color: var(--text-primary);
    font-weight: 700;
}

.branch-selector label {
    display: block;
    font-size: 0.75rem;
    color: var(--text-muted);
    margin-bottom: 4px;
}

.branch-selector select {
    width: 100%;
    padding: 8px;
    background: var(--bg-dark);
    border: 1px solid var(--border);
    color: var(--text-primary);
    border-radius: 4px;
    font-size: 0.85rem;
}

.capital-display {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--border);
    font-size: 0.8rem;
    color: var(--text-muted);
}

.capital-display strong {
    display: block;
    font-size: 1.2rem;
    color: var(--benny-red);
    margin-top: 4px;
}

/* Main Content */
.main-content {
    flex: 1;
    margin-left: 240px;
    padding: 24px;
    background: var(--bg-dark);
}

.view {
    display: none;
}

.view.active {
    display: block;
    animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.view-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
}

.view-header-inventory {
    flex-wrap: wrap;
    gap: 16px;
}

.inventory-search {
    padding: 10px 16px;
    min-width: 220px;
    background: var(--bg-anthracite);
    border: 1px solid var(--border);
    color: var(--text-primary);
    border-radius: 4px;
    font-size: 0.95rem;
}

.inventory-search::placeholder {
    color: var(--text-muted);
}

.inventory-search:focus {
    outline: none;
    border-color: var(--gold-primary);
}

/* Admin-Bereich Button (Sidebar, unter Abmelden – gleicher Stil wie .logout-btn) */
.admin-area-btn {
    margin-top: 4px;
}

/* Admin-Bereich Overlay (eigene Seite nach PIN) */
.admin-area-overlay {
    position: fixed;
    inset: 0;
    background: var(--bg-dark);
    z-index: 1000;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.admin-area-overlay.hidden {
    display: none;
}

.admin-area-inner {
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: hidden;
}

.admin-area-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 24px;
    background: var(--bg-anthracite);
    border-bottom: 2px solid var(--gold-primary);
    flex-shrink: 0;
}

.admin-area-header h1 {
    font-family: 'Orbitron', sans-serif;
    font-size: 1.25rem;
    color: var(--gold-primary);
    margin: 0;
}

.admin-area-body {
    flex: 1;
    overflow-y: auto;
    padding: 20px;
}

.test-controls {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

.test-auto-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--text-muted);
    font-size: 0.9rem;
}

.test-summary { margin-bottom: 12px; }
.test-summary-cards { display: flex; flex-wrap: wrap; gap: 12px; }
.test-summary-ok { color: var(--success); font-weight: 600; }
.test-summary-fail { color: var(--danger); font-weight: 600; }
.test-summary-critical { color: var(--warning); font-weight: 600; }
.test-results-wrap { max-height: 400px; }
.test-row-fail { background: rgba(231, 76, 60, 0.1); }

.test-report { margin-bottom: 16px; }
.test-report-section { margin-bottom: 12px; padding: 10px 14px; border-radius: 6px; }
.test-report-section ul { margin: 6px 0 0 0; padding-left: 20px; }
.test-report-critical { background: rgba(231, 76, 60, 0.15); border-left: 4px solid var(--danger); }
.test-report-warning { background: rgba(243, 156, 18, 0.15); border-left: 4px solid var(--warning); }
.test-report-optimization { background: rgba(52, 152, 219, 0.15); border-left: 4px solid #3498db; }
.test-log-title { font-size: 0.95rem; margin: 16px 0 8px 0; color: var(--text-muted); }
.test-log-wrap { max-height: 180px; overflow-y: auto; font-size: 0.85rem; color: var(--text-muted); border: 1px solid var(--border); border-radius: 6px; padding: 10px; background: var(--bg-elevated); }
.test-log-list { list-style: none; padding: 0; margin: 0; }
.test-log-list li { padding: 4px 0; border-bottom: 1px solid rgba(255,255,255,0.05); }
.test-log-list li:last-child { border-bottom: none; }
.test-log-time { opacity: 0.8; margin-right: 8px; }

.admin-area-body .permissions-admin-tabs {
    margin-bottom: 16px;
}

.admin-perm-tab {
    padding: 8px 14px;
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--text-primary);
    font-size: 0.9rem;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s;
}

.admin-perm-tab:hover {
    background: var(--bg-card);
    border-color: var(--gold-primary);
}

.admin-perm-tab.active {
    background: var(--gold-primary);
    border-color: var(--gold-primary);
    color: var(--bg-dark);
    font-weight: 600;
}

.admin-perm-panel {
    display: none;
}

.admin-perm-panel.active {
    display: block;
}

.view-header h2 {
    font-family: 'Orbitron', sans-serif;
    font-size: 1.5rem;
    color: var(--benny-red);
    letter-spacing: 1px;
}

.view-desc {
    color: var(--text-muted);
    font-size: 0.9rem;
    margin-bottom: 20px;
}

/* Einstellungen */
.settings-content {
    padding: 0 4px;
}

.settings-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 20px;
}

.settings-card {
    background: var(--bg-elevated, #2a2a35);
    border: 1px solid var(--border-color, #333);
    border-radius: 8px;
    padding: 20px;
}

.settings-card h3 {
    margin: 0 0 12px 0;
    font-size: 1.1rem;
    color: var(--text-primary);
}

.settings-card .text-muted {
    font-size: 0.9rem;
    margin-bottom: 12px;
}

.settings-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
    margin-top: 12px;
}

.settings-actions label {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.settings-actions input[type="number"],
.settings-actions input[type="text"],
.settings-actions input[type="password"] {
    max-width: 100px;
    padding: 6px 10px;
    background: var(--bg-anthracite);
    border: 1px solid var(--border);
    border-radius: 4px;
    color: var(--text-primary);
}

.settings-card--full {
    grid-column: 1 / -1;
}

.color-schemes {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.color-scheme-option {
    padding: 12px 20px;
    border: 2px solid var(--border);
    border-radius: 8px;
    cursor: pointer;
    font-family: inherit;
    font-size: 0.95rem;
    background: var(--bg-anthracite);
    color: var(--text-primary);
    transition: border-color 0.2s, transform 0.1s;
}

.color-scheme-option:hover {
    border-color: var(--gold-primary);
}

.color-scheme-option.active {
    border-color: var(--gold-primary);
    background: rgba(201, 162, 39, 0.15);
    color: var(--gold-primary);
}

.logo-preview {
    margin-bottom: 12px;
    min-height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-dark);
    border-radius: 8px;
    padding: 12px;
}

.logo-preview img {
    max-width: 100%;
    max-height: 80px;
    object-fit: contain;
}

/* POS - Fertige Services Übersicht */
.pos-stock-overview {
    background: var(--bg-anthracite);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 16px;
    margin-bottom: 20px;
}

.pos-stock-title {
    font-size: 0.8rem;
    color: var(--text-muted);
    text-transform: uppercase;
    margin-bottom: 12px;
}

.pos-stock-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 24px;
}

.pos-stock-item {
    display: flex;
    gap: 8px;
    font-size: 0.9rem;
}

.pos-stock-item.pos-stock-empty .pos-stock-qty {
    color: var(--danger);
}

.pos-stock-name {
    color: var(--text-muted);
}

.pos-stock-qty {
    color: var(--gold-primary);
    font-weight: 700;
}

/* POS Kassa – Design wie Foodtruck (Bennys Farben) */
.pos-kassa-frame {
    background: #0c0c0e;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 8px 40px rgba(0,0,0,0.5), 0 0 0 1px rgba(0,0,0,0.5);
    max-width: 1400px;
    margin: 0 auto;
}

.pos-kassa-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 24px;
    background: linear-gradient(180deg, #1a1a1e 0%, #121216 100%);
    border-bottom: 2px solid #2a2a30;
}

.pos-header-receipt { font-size: 0.9rem; color: #888; }
.pos-header-time { font-size: 0.85rem; color: #666; font-variant-numeric: tabular-nums; }

.pos-btn-beleg {
    padding: 8px 16px;
    background: linear-gradient(135deg, var(--gold-primary), #b8860b);
    color: var(--bg-dark);
    border: none;
    border-radius: 8px;
    font-weight: 700;
    cursor: pointer;
}
.pos-btn-beleg:hover { opacity: 0.95; }

.pos-total-display {
    display: flex;
    flex-direction: column;
    align-items: center;
    font-family: 'JetBrains Mono', Consolas, monospace;
    font-size: 2.5rem;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    color: #fff;
}

.pos-discount-info { font-size: 0.9rem; color: #4ade80; margin-bottom: 4px; }
.pos-discount-info.hidden { display: none; }

.pos-kassa-body {
    display: grid;
    grid-template-columns: 420px 1fr;
    gap: 0;
    min-height: 520px;
}

.pos-left-panel {
    display: flex;
    flex-direction: column;
    background: #16161a;
    border-right: 1px solid #2a2a30;
}

.pos-cart-area {
    flex: 0 0 auto;
    max-height: 220px;
    overflow-y: auto;
    background: #fff;
    border-bottom: 1px solid #e0e0e0;
    margin: 0;
}

.pos-cart-area .cart-table { width: 100%; border-collapse: collapse; }
.pos-cart-area .cart-table th,
.pos-cart-area .cart-table td {
    padding: 10px 12px;
    text-align: left;
    border-bottom: 1px solid #eee;
    font-size: 0.85rem;
    color: #222;
}
.pos-cart-area .cart-table th {
    background: #f5f5f5;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #555;
}
.pos-cart-area .cart-table .price-cell,
.pos-cart-area .cart-table .cart-qty-cell { text-align: right; font-variant-numeric: tabular-nums; }
.pos-cart-area .cart-table .cart-price-original { text-decoration: line-through; color: #888; margin-right: 6px; }
.pos-cart-area .cart-table .cart-price-discounted { font-weight: 600; color: #2d8a2d; }
.pos-cart-area .cart-table .cart-remove {
    background: #fee;
    border: 1px solid #ecc;
    color: #c44;
    cursor: pointer;
    padding: 4px 10px;
    font-size: 1rem;
    font-weight: 700;
    border-radius: 4px;
}
.pos-cart-area .cart-table .cart-remove:hover { background: #fcc; }

/* Numpad wie Foodtruck */
.pos-numpad-area { padding: 16px; flex: 1; display: flex; flex-direction: column; gap: 12px; }
.pos-numpad {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
}
.pos-numpad-spacer { display: block; visibility: hidden; min-height: 48px; }

.pos-num-btn {
    height: 48px;
    border: none;
    border-radius: 8px;
    font-size: 1.1rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.12s;
}
.pos-num-btn.pos-num, .pos-num-btn.pos-num-00, .pos-num-btn.pos-num-comma {
    background: #3a3a42;
    color: #fff;
}
.pos-num-btn.pos-num:hover, .pos-num-btn.pos-num-00:hover { background: #4a4a54; }
.pos-num-btn.pos-num-clear { background: #a03030; color: #fff; }
.pos-num-btn.pos-num-clear:hover { background: #c04040; }
.pos-num-btn.pos-num-pm { background: #2a2a32; color: #888; }

.pos-extra-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}
.pos-extra-row label { color: #999; font-size: 0.85rem; }
.pos-extra-row .pos-extra-input,
.pos-extra-row .pos-extra-select {
    background: #2a2a30;
    border: 1px solid #3a3a42;
    color: #fff;
    max-width: 140px;
    padding: 8px 10px;
    border-radius: 6px;
}
.pos-extra-row .pos-extra-select { min-width: 120px; cursor: pointer; }

.pos-order-open-row { padding: 6px 0 0; }
.pos-btn-order-open {
    width: 100%;
    padding: 10px 16px;
    background: linear-gradient(135deg, var(--gold-primary), #b8860b);
    color: var(--bg-dark);
    border: none;
    border-radius: 8px;
    font-weight: 700;
    cursor: pointer;
}
.pos-btn-order-open:hover { opacity: 0.95; }

.pos-payment-keys { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
.pos-payment-keys-original .pos-btn {
    height: 48px;
    border: none;
    border-radius: 8px;
    font-size: 0.9rem;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.12s;
}
.pos-payment-keys-original .pos-btn-cancel { background: #4a4a54; color: #e0e0e0; }
.pos-payment-keys-original .pos-btn-cancel:hover { background: #c0392b; color: #fff; }
.pos-payment-keys-original .pos-btn-maintenance {
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    color: var(--text-primary);
}
.pos-payment-keys-original .pos-btn-maintenance:hover { border-color: var(--gold-primary); color: var(--gold-primary); }
.pos-payment-keys-original .pos-btn-pay {
    background: linear-gradient(135deg, #27ae60, #1e8449);
    color: #fff;
}
.pos-payment-keys-original .pos-btn-pay:hover { background: linear-gradient(135deg, #2ecc71, #27ae60); }
.pos-payment-keys-original .pos-btn-npc {
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    color: var(--text-primary);
}
.pos-payment-keys-original .pos-btn-npc:hover { border-color: var(--gold-primary); color: var(--gold-primary); }
.pos-payment-keys-original .pos-btn-spieler {
    background: linear-gradient(135deg, var(--gold-primary), #b8860b);
    color: var(--bg-dark);
}
.pos-payment-keys-original .pos-btn-spieler:hover { background: linear-gradient(135deg, #d4af37, var(--gold-primary)); color: var(--bg-dark); }

.pos-actions-cost { padding: 8px 0 0; display: flex; flex-wrap: wrap; align-items: center; gap: 8px; }

.pos-totals--compact { padding: 12px 16px; background: #16161a; color: #e0e0e0; font-size: 0.9rem; }
.pos-stammkunde-row { padding: 8px 0; gap: 10px; }

/* Rechte Spalte: Filter, Letzte Artikel, Produktgrid (Foodtruck-Style) */
.pos-right-panel {
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    background: var(--bg-card);
}

.pos-filter-bar {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 0;
    padding: 10px;
    background: rgba(18, 18, 26, 0.55);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
}
.pos-filter-spacer { flex: 1; }
.pos-search {
    min-width: 180px;
    max-width: 320px;
    padding: 10px 14px;
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    color: var(--text-primary);
    border-radius: var(--radius-md);
    font-size: 0.95rem;
}
.pos-search::placeholder { color: var(--text-muted); }
.pos-search:focus { outline: none; border-color: var(--gold-primary); }

.pos-recent {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 0;
}
.pos-recent-label, .pos-recent-title {
    width: 100%;
    font-size: 0.75rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 1px;
}
.pos-recent-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.15s;
}
.pos-recent-btn:hover { border-color: var(--gold-primary); color: var(--text-primary); }

.pos-right-panel .product-grid {
    flex: 1;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 12px;
}

.pos-footer-row {
    padding: 12px 20px;
    background: #16161a;
    border-top: 1px solid #2a2a30;
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: center;
}
.pos-footer-row .pos-employee-selector { display: flex; align-items: center; gap: 10px; }
.pos-footer-row .pos-employee-selector label { color: #999; font-size: 0.9rem; }
.pos-footer-row .pos-employee-select {
    background: #2a2a30;
    color: #fff;
    border: 1px solid #3a3a42;
    padding: 8px 12px;
    border-radius: 6px;
}
.pos-filter-btn {
    appearance: none;
    border: 1px solid var(--border);
    background: var(--bg-elevated);
    color: var(--text-secondary);
    padding: 10px 14px;
    border-radius: var(--radius-md);
    cursor: pointer;
    font-weight: 600;
    transition: border-color 0.15s, background 0.15s, color 0.15s;
}
.pos-filter-btn:hover { border-color: var(--gold-primary); color: var(--text-primary); }
.pos-filter-btn.active {
    background: linear-gradient(135deg, rgba(212, 168, 58, 0.22), rgba(212, 168, 58, 0.06));
    border-color: var(--gold-primary);
    color: var(--gold-primary);
}

.pos-footer-row .pos-employee-selector {
    display: flex;
    align-items: center;
    gap: 10px;
}

.pos-footer-row .pos-employee-selector label {
    color: #999;
    font-size: 0.85rem;
}

.pos-footer-row .pos-employee-select {
    background: #3a3a40;
    color: #fff;
    border: 1px solid #4a4a50;
}

/* Legacy/fallback */
.pos-container {
    display: grid;
    grid-template-columns: 380px 1fr;
    gap: 24px;
    max-width: 1200px;
    margin: 0 auto;
}

.pos-display {
    background: var(--bg-anthracite);
    border: 2px solid var(--border);
    border-radius: 8px;
    padding: 20px;
    min-height: 500px;
    display: flex;
    flex-direction: column;
}

.pos-header {
    display: flex;
    justify-content: space-between;
    font-family: 'Orbitron', sans-serif;
    font-size: 0.7rem;
    color: var(--gold-primary);
    letter-spacing: 2px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--border);
}

.pos-cart {
    flex: 1;
    overflow-y: auto;
    margin: 16px 0;
}

.cart-table {
    width: 100%;
    border-collapse: collapse;
}

.cart-table th, .cart-table td {
    padding: 8px 0;
    text-align: left;
    border-bottom: 1px solid var(--border);
}

.cart-table th {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-transform: uppercase;
}

.cart-table .cart-remove {
    background: none;
    border: none;
    color: var(--danger);
    cursor: pointer;
    padding: 2px 8px;
    font-size: 1rem;
}

.cart-table .cart-remove:hover {
    opacity: 0.9;
}

.cart-table .price-cell,
.cart-table .cart-qty-cell {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.cart-table .cart-price-original {
    text-decoration: line-through;
    color: var(--text-muted);
    margin-right: 6px;
}

.cart-table .cart-price-discounted {
    font-weight: 600;
    color: var(--gold-primary);
}

.pos-totals {
    border-top: 2px solid var(--gold-primary);
    padding-top: 16px;
}

.pos-subtotal {
    display: flex;
    justify-content: space-between;
    font-size: 0.9rem;
    margin-bottom: 8px;
}

.pos-total {
    display: flex;
    justify-content: space-between;
    font-family: 'Orbitron', sans-serif;
    font-size: 1.3rem;
    color: var(--gold-primary);
}

.pos-discount-row,
.pos-tip-row {
    display: flex;
    justify-content: space-between;
    font-size: 0.9rem;
    margin-bottom: 6px;
}

.pos-discount-row.hidden,
.pos-tip-row.hidden {
    display: none !important;
}

.pos-stammkunde-row,
.pos-extra-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 10px;
    flex-wrap: wrap;
}

.pos-stammkunde-select,
.pos-extra-input {
    padding: 6px 10px;
    border-radius: 6px;
    border: 1px solid var(--border);
    background: var(--bg-anthracite);
    color: var(--text-primary);
    max-width: 180px;
}

.pos-recent {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 8px;
}

.pos-recent-label {
    font-size: 0.85rem;
    color: var(--text-muted);
}

.pos-recent-btn {
    padding: 6px 12px;
    font-size: 0.8rem;
    border-radius: 6px;
    border: 1px solid var(--border);
    background: var(--bg-anthracite);
    color: var(--text-primary);
    cursor: pointer;
}

.pos-recent-btn:hover {
    border-color: var(--gold-primary);
    color: var(--gold-primary);
}

.pos-happy-hour-badge {
    margin-left: 12px;
    padding: 4px 10px;
    background: var(--gold-primary);
    color: var(--bg-dark);
    border-radius: 6px;
    font-size: 0.8rem;
    font-weight: 700;
}

.pos-buttons {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.product-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 12px;
}

/* Produkt-Buttons: Foodtruck-Style – farbige Karten, weiße Schrift */
.pos-product-btn {
    padding: 16px 12px;
    border: none;
    border-radius: 10px;
    color: #fff;
    font-family: inherit;
    font-size: 0.9rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.15s;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.2);
}

.pos-product-color-food { background: linear-gradient(145deg, #27ae60, #1e8449); }
.pos-product-color-drink { background: linear-gradient(145deg, #3498db, #2980b9); }
.pos-product-color-3 { background: linear-gradient(145deg, #f39c12, #d68910); }
.pos-product-color-4 { background: linear-gradient(145deg, #9b59b6, #8e44ad); }
.pos-product-color-5 { background: linear-gradient(145deg, #e74c3c, #c0392b); }

.pos-product-btn:hover:not(:disabled) {
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0,0,0,0.3);
}

.pos-product-icon {
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    border-radius: 10px;
    background: rgba(255,255,255,0.2);
    font-size: 1.25rem;
    line-height: 1;
}

.pos-product-name { line-height: 1.1; }

.pos-product-btn .price {
    display: block;
    font-size: 0.85rem;
    font-weight: 700;
    opacity: 0.95;
}

.pos-product-btn .stock-badge {
    display: block;
    font-size: 0.7rem;
    opacity: 0.8;
}

.pos-product-btn.pos-product-out {
    opacity: 0.5;
    filter: grayscale(0.5);
}

.pos-product-btn.pos-product-warning {
    box-shadow: 0 0 0 2px rgba(243, 156, 18, 0.6);
}

.pos-product-btn.pos-product-critical {
    box-shadow: 0 0 0 2px rgba(231, 76, 60, 0.6);
}

.pos-stock-item.pos-stock-warning .pos-stock-qty {
    color: var(--warning);
}

.pos-stock-item.pos-stock-critical .pos-stock-qty {
    color: var(--danger);
}

.pos-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.pos-actions-cost {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid #333;
    align-items: center;
    gap: 8px;
}

.pos-left-panel .pos-cost-label {
    color: #aaa;
}

.pos-cost-label {
    font-size: 0.8rem;
    color: var(--text-muted);
    text-transform: uppercase;
}

.pos-cost-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.pos-left-panel .pos-btn-cost {
    background: #3a3a40 !important;
    color: #fff !important;
    border: 1px solid #4a4a50 !important;
    border-radius: 2px !important;
}

.pos-btn-cost {
    background: var(--bg-elevated) !important;
    color: var(--text-primary) !important;
    border: 2px solid var(--border);
    font-size: 0.85rem;
}

.pos-left-panel .pos-btn-cost:hover {
    background: #4a4a54 !important;
    border-color: #5a5a64 !important;
    color: #fff !important;
}

.pos-btn-cost:hover {
    border-color: var(--benny-red) !important;
    color: var(--benny-red-light) !important;
}

.pos-btn {
    flex: 1;
    padding: 16px;
    border: none;
    border-radius: 8px;
    font-family: inherit;
    font-size: 1rem;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.2s;
}

.pos-btn.cancel {
    background: var(--bg-elevated);
    color: var(--text-muted);
}

.pos-btn.cancel:hover {
    background: var(--danger);
    color: white;
}

.pos-btn.pay {
    background: var(--gold-primary);
    color: var(--bg-dark);
}

.pos-btn.pay:hover {
    background: var(--gold-light);
    transform: translateY(-2px);
}

.pos-btn-npc {
    background: var(--bg-elevated);
    color: var(--text-primary);
    border: 2px solid var(--border);
}

.pos-btn-npc:hover {
    background: var(--gold-dim);
    color: var(--bg-dark);
}

.pos-btn-spieler {
    background: var(--gold-primary);
    color: var(--bg-dark);
}

/* KPI Dashboard */
.dashboard-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
}

.dashboard-period select {
    padding: 8px 16px;
    background: var(--bg-anthracite);
    border: 1px solid var(--border);
    color: var(--text-primary);
    border-radius: 4px;
}

.kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    margin-bottom: 32px;
}

.kpi-card {
    background: var(--bg-anthracite);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 24px;
    position: relative;
}

.kpi-card[data-status="green"] { border-left: 4px solid var(--success); }
.kpi-card[data-status="yellow"] { border-left: 4px solid var(--warning); }
.kpi-card[data-status="red"] { border-left: 4px solid var(--danger); }

.kpi-label {
    display: block;
    font-size: 0.8rem;
    color: var(--text-muted);
    margin-bottom: 8px;
}

.kpi-value {
    font-family: 'Orbitron', sans-serif;
    font-size: 1.5rem;
    color: var(--gold-primary);
}

.kpi-status {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 12px;
    height: 12px;
    border-radius: 50%;
}

.kpi-status.green { background: var(--success); }
.kpi-status.yellow { background: var(--warning); }
.kpi-status.red { background: var(--danger); }

.dashboard-charts {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 24px;
    margin-bottom: 32px;
}

.chart-container {
    background: var(--bg-anthracite);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 20px;
    height: 300px;
}

.top-sellers-section h3 {
    font-family: 'Orbitron', sans-serif;
    margin-bottom: 16px;
    color: var(--gold-primary);
}

.ranking-table {
    width: 100%;
    border-collapse: collapse;
}

.ranking-table th, .ranking-table td {
    padding: 12px 16px;
    text-align: left;
    border-bottom: 1px solid var(--border);
}

.ranking-table th {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-transform: uppercase;
}

/* Data Tables */
.data-table {
    width: 100%;
    border-collapse: collapse;
    background: var(--bg-anthracite);
    border-radius: 8px;
    overflow: hidden;
}

.data-table th, .data-table td {
    padding: 12px 16px;
    text-align: left;
    border-bottom: 1px solid var(--border);
}

.data-table th {
    background: var(--bg-card);
    font-size: 0.75rem;
    color: var(--text-muted);
    text-transform: uppercase;
}

.data-table tr:hover {
    background: var(--bg-elevated);
}

.status-warning {
    color: var(--warning);
}

.status-danger {
    color: var(--danger);
}

.status-ok {
    color: var(--success);
}

.row-low-stock {
    background: rgba(192, 57, 43, 0.15) !important;
}

.row-low-stock .rest-cell {
    color: var(--danger);
    font-weight: 700;
}

.btn-inventory-edit, .btn-inventory-delete, .btn-sale-delete {
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    color: var(--text-primary);
    padding: 4px 10px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 1rem;
}

.btn-inventory-edit:hover {
    background: var(--gold-primary);
    color: var(--bg-dark);
}

.btn-inventory-delete:hover, .btn-sale-delete:hover {
    background: var(--danger);
    color: white;
}

/* Buttons */
.btn-primary {
    padding: 10px 20px;
    background: var(--gold-primary);
    border: none;
    border-radius: 4px;
    color: var(--bg-dark);
    font-family: inherit;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.2s;
}

.btn-primary:hover {
    background: var(--gold-light);
}

/* Recipes Grid */
.recipes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 20px;
}

.recipe-card {
    background: var(--bg-anthracite);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 20px;
}

.recipe-card h3 {
    font-family: 'Orbitron', sans-serif;
    color: var(--gold-primary);
    margin-bottom: 12px;
}

.recipe-card ul {
    list-style: none;
}

.recipe-card li {
    padding: 4px 0;
    display: flex;
    justify-content: space-between;
}

.recipe-card li.ingredient-missing {
    color: var(--danger);
}

.recipe-card li.ingredient-missing small {
    margin-left: 8px;
    opacity: 0.9;
}

.recipe-card-unavailable {
    border-color: var(--danger);
    opacity: 0.9;
}

.recipe-unavailable {
    background: rgba(192, 57, 43, 0.2);
    color: var(--danger);
    padding: 8px 12px;
    border-radius: 4px;
    font-size: 0.85rem;
    margin-bottom: 12px;
}

/* Production */
.production-form {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 24px;
    flex-wrap: wrap;
}

.production-form select, .production-form input {
    padding: 10px 16px;
    background: var(--bg-anthracite);
    border: 1px solid var(--border);
    color: var(--text-primary);
    border-radius: 4px;
}

.production-form input[type="number"] {
    width: 80px;
}

#production-feedback {
    margin-top: 12px;
    padding: 12px;
    border-radius: 4px;
    width: 100%;
}

#production-feedback.success {
    background: rgba(39, 174, 96, 0.2);
    color: var(--success);
}

#production-feedback.error {
    background: rgba(192, 57, 43, 0.2);
    color: var(--danger);
}

.production-recipe-preview {
    background: var(--bg-anthracite);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 20px;
}

/* Orders Layout */
.orders-layout {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 24px;
}

/* Aufträge (Werkstatt-Aufträge) */
.auftraege-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}

.auftraege-open h3,
.auftraege-done h3 {
    font-family: 'Orbitron', sans-serif;
    color: var(--gold-primary);
    margin-bottom: 16px;
}

.auftraege-done .btn-secondary {
    margin-bottom: 12px;
}

.auftraege-done-container {
    margin-top: 8px;
}

.auftraege-done-container.hidden {
    display: none;
}

.auftraege-assign-select {
    padding: 6px 10px;
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    color: var(--text-primary);
    border-radius: 6px;
    font-size: 0.85rem;
    min-width: 120px;
}

@media (max-width: 900px) {
    .auftraege-layout {
        grid-template-columns: 1fr;
    }
}

.einkaufsliste h3, .bestellungen h3 {
    font-family: 'Orbitron', sans-serif;
    color: var(--gold-primary);
    margin-bottom: 16px;
}

.orders-section-delivered {
    margin-top: 24px;
}

.order-actions {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.btn-order-deliver {
    padding: 6px 12px;
    background: var(--success);
    border: 1px solid var(--border);
    color: #fff;
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.85rem;
}

.btn-order-deliver:hover {
    filter: brightness(1.1);
}

.btn-order-delete {
    padding: 6px 12px;
    background: var(--danger);
    border: 1px solid var(--border);
    color: #fff;
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.85rem;
}

.btn-order-delete:hover {
    filter: brightness(1.1);
}

.btn-shopping-delete {
    padding: 6px 12px;
    background: var(--danger);
    border: 1px solid var(--border);
    color: #fff;
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.85rem;
}

.btn-shopping-delete:hover {
    filter: brightness(1.1);
}

.einkaufsliste-actions {
    margin-top: 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.open-orders-header td {
    font-size: 0.85rem;
    color: var(--text-muted);
    padding-top: 16px;
    border-top: 1px solid var(--border);
}

.open-orders-inline {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.open-order-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 12px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 6px;
}

.open-order-info {
    font-size: 0.9rem;
    color: var(--text-muted);
}

.btn-order-delete-inline {
    padding: 6px 12px;
    background: var(--danger);
    border: 1px solid var(--border);
    color: #fff;
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.85rem;
}

.btn-order-delete-inline:hover {
    filter: brightness(1.1);
}

.btn-secondary {
    padding: 10px 16px;
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    color: var(--text-primary);
    border-radius: 6px;
    cursor: pointer;
    font-family: inherit;
    font-size: 0.9rem;
}

.btn-secondary:hover {
    background: var(--bg-card);
    border-color: var(--gold-primary);
}

#btn-place-order {
    margin-top: 0;
}

/* Branches */
.branches-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 20px;
}

.branch-card {
    background: var(--bg-anthracite);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 20px;
}

.branch-card h3 {
    color: var(--benny-red);
    margin-bottom: 8px;
}

/* Kostenstellen */
.cost-centers-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}

.cost-center-card {
    background: var(--bg-anthracite);
    border: 1px solid var(--border);
    border-left-width: 4px;
    border-radius: 8px;
    padding: 16px;
}

.cost-center-card h3 {
    font-size: 1rem;
    color: var(--text-primary);
    margin-bottom: 4px;
}

.cost-center-id {
    font-size: 0.75rem;
    color: var(--text-muted);
}

.cost-list-table {
    margin-top: 16px;
}

/* Finance */
.finance-overview {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 24px;
}

.finance-card {
    background: var(--bg-anthracite);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 24px;
}

.finance-card h3 {
    font-family: 'Orbitron', sans-serif;
    color: var(--gold-primary);
    margin-bottom: 16px;
}

.finance-row {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    border-bottom: 1px solid var(--border);
}

/* Modal – Dark Urban Popup */
.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.85);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    backdrop-filter: blur(4px);
}

.modal-overlay.hidden {
    display: none;
}

.modal {
    background: var(--bg-anthracite);
    border: 2px solid var(--gold-primary);
    border-radius: 12px;
    padding: 0;
    max-width: 480px;
    width: 90%;
    box-shadow: 0 0 40px rgba(201, 162, 39, 0.2);
}

.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 24px;
    border-bottom: 1px solid var(--border);
    background: var(--bg-card);
    border-radius: 10px 10px 0 0;
}

.modal-header h3 {
    color: var(--gold-primary);
    margin: 0;
    font-family: 'Orbitron', sans-serif;
    font-size: 1.1rem;
}

.modal-close {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 1.5rem;
    cursor: pointer;
    padding: 0 8px;
    line-height: 1;
}

.modal-close:hover {
    color: var(--gold-primary);
}

.modal-message, .modal-label {
    padding: 20px 24px;
    color: var(--text-primary);
}

.modal-input {
    width: calc(100% - 48px);
    margin: 0 24px 20px;
    padding: 12px 16px;
    background: var(--bg-dark);
    border: 2px solid var(--border);
    color: var(--text-primary);
    border-radius: 6px;
    font-size: 1rem;
}

.modal-input:focus {
    outline: none;
    border-color: var(--gold-primary);
}

.modal .modal-actions {
    display: flex;
    gap: 12px;
    padding: 20px 24px;
    border-top: 1px solid var(--border);
}

.btn-modal-cancel {
    padding: 10px 20px;
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    color: var(--text-muted);
    border-radius: 6px;
    cursor: pointer;
    font-family: inherit;
}

.btn-modal-cancel:hover {
    background: var(--bg-card);
    color: var(--text-primary);
}

/* Rechte-Modal (Mitarbeiter) */
.modal:has(.modal-body--rights) {
    max-width: 560px;
    width: 95%;
}

.modal-body--rights {
    padding: 20px 26px;
    display: flex;
    flex-direction: column;
    gap: 20px;
    max-height: 70vh;
    overflow-y: auto;
}

.rights-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 18px 20px;
}

.rights-card--admin {
    background: rgba(201, 162, 39, 0.08);
    border-color: rgba(201, 162, 39, 0.25);
}

.rights-card--nested {
    margin-left: 12px;
    border-left: 3px solid var(--gold-primary);
    background: var(--bg-elevated);
}

.rights-card-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--gold-primary);
    margin: 0 0 12px 0;
}

.rights-card-hint {
    font-size: 0.8rem;
    color: var(--text-muted);
    margin: 8px 0 0 0;
    line-height: 1.35;
}

.rights-checkbox-grid {
    display: flex;
    flex-direction: column;
    gap: 4px;
    max-height: 200px;
    overflow-y: auto;
}

.rights-checkbox-row {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    border-radius: 6px;
    cursor: pointer;
    transition: background 0.15s;
}

.rights-checkbox-row:hover {
    background: var(--bg-elevated);
}

.rights-checkbox-row input[type="checkbox"] {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

.rights-checkbox-row--highlight {
    font-weight: 500;
}

.rights-label {
    display: block;
    font-size: 0.9rem;
    color: var(--text-muted);
    margin-bottom: 8px;
}

.rights-pin-input {
    width: 100%;
    max-width: 200px;
}

/* RBAC Matrix (Einstellungen) */
.rbac-matrix {
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 14px;
    max-height: 420px;
    overflow-y: auto;
}

.rbac-role-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

.rbac-role-block {
    padding: 10px 0;
}

.rbac-role-block h4 {
    color: var(--gold-primary);
}

.rbac-checkboxes {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.rbac-cat {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.rbac-cat-title {
    color: var(--text-muted);
    font-size: 0.85rem;
    margin-bottom: 2px;
}

.rbac-check {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px 0;
    font-size: 0.9rem;
    cursor: pointer;
}

.rbac-check input {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

/* Granulare Rechte im Rechte-Modal */
.rights-granular-grid {
    display: flex;
    flex-direction: column;
    gap: 10px;
    max-height: 240px;
    overflow-y: auto;
}

.rights-granular-cat {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 16px;
    align-items: center;
}

.rights-granular-cat .rbac-cat-title {
    width: 100%;
    margin-bottom: 4px;
}

.rights-granular-cat .rbac-check {
    margin: 0;
}

@media (max-width: 720px) {
    .rbac-role-grid {
        grid-template-columns: 1fr;
    }
}

/* Permissions Admin Tabs (Dark Urban) */
.permissions-admin-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 14px;
    border-bottom: 1px solid var(--border-color, #333);
    padding-bottom: 8px;
}

.perm-tab {
    padding: 8px 14px;
    background: var(--bg-elevated, #2a2a35);
    border: 1px solid var(--border-color, #333);
    border-radius: 6px;
    color: var(--text-primary);
    font-size: 0.9rem;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s;
}

.perm-tab:hover {
    background: var(--bg-card, #333);
    border-color: var(--gold-primary, #c9a227);
}

.perm-tab.active {
    background: var(--gold-primary, #c9a227);
    border-color: var(--gold-primary);
    color: var(--bg-dark, #1a1a22);
    font-weight: 600;
}

.perm-panel {
    display: none;
}

.perm-panel.active {
    display: block;
}

.perm-admin-table-wrap {
    max-height: 360px;
    overflow: auto;
    border: 1px solid var(--border-color, #333);
    border-radius: 8px;
    background: var(--bg-elevated);
}

.perm-admin-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9rem;
}

.perm-admin-table th,
.perm-admin-table td {
    padding: 10px 12px;
    text-align: left;
    border-bottom: 1px solid var(--border-color, #333);
}

.perm-admin-table th {
    background: rgba(0,0,0,0.25);
    color: var(--gold-primary);
    font-weight: 600;
    position: sticky;
    top: 0;
    z-index: 1;
}

.perm-admin-table code {
    font-size: 0.85em;
    background: rgba(0,0,0,0.3);
    padding: 2px 6px;
    border-radius: 4px;
}

.perm-type {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 0.8rem;
}

.perm-type-read { background: rgba(46, 204, 113, 0.2); color: #2ecc71; }
.perm-type-create { background: rgba(52, 152, 219, 0.2); color: #3498db; }
.perm-type-update { background: rgba(241, 196, 15, 0.2); color: #f1c40f; }
.perm-type-delete { background: rgba(231, 76, 60, 0.2); color: #e74c3c; }
.perm-type-execute { background: rgba(155, 89, 182, 0.2); color: #9b59b6; }

.perm-admin-search {
    width: 100%;
    max-width: 320px;
    margin-bottom: 10px;
    padding: 8px 12px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    color: var(--text-primary);
    font-size: 0.95rem;
}

.perm-admin-search::placeholder {
    color: var(--text-muted);
}

/* Order detail */
.orders-history-container {
    max-height: 400px;
    overflow-y: auto;
}

.order-items-cell {
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
}

.btn-order-detail {
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    color: var(--gold-primary);
    padding: 4px 10px;
    border-radius: 4px;
    cursor: pointer;
}

.btn-order-detail:hover {
    background: var(--gold-primary);
    color: var(--bg-dark);
}

.order-detail {
    margin-top: 16px;
    padding: 16px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 8px;
}

.order-detail.hidden {
    display: none;
}

.order-detail-content {
    position: relative;
}

.order-detail-close {
    position: absolute;
    top: -8px;
    right: 0;
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 1.2rem;
    cursor: pointer;
}

.order-detail-close:hover {
    color: var(--gold-primary);
}

.order-detail-items {
    list-style: none;
    padding: 0;
}

.order-detail-items li {
    padding: 4px 0;
}

.order-detail-total {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--border);
}

/* Finance editable */
.finance-editable {
    position: relative;
}

.finance-editable .btn-edit {
    margin-left: 8px;
    background: none;
    border: none;
    color: var(--gold-primary);
    cursor: pointer;
    padding: 2px 6px;
}

.finance-editable .btn-edit:hover {
    color: var(--gold-light);
}

.btn-finance-reset {
    font-size: 0.85rem;
    padding: 8px 16px;
}

.text-muted {
    color: var(--text-muted);
}

/* Sales Filter & Summary */
.view-header-sales {
    flex-wrap: wrap;
    gap: 16px;
}

.sales-filter {
    display: flex;
    align-items: center;
    gap: 8px;
}

.sales-filter label {
    font-size: 0.9rem;
    color: var(--text-muted);
}

.sales-filter select {
    padding: 8px 12px;
    background: var(--bg-anthracite);
    border: 1px solid var(--border);
    color: var(--text-primary);
    border-radius: 4px;
}

.sales-summary {
    margin-top: 20px;
    padding: 20px;
    background: var(--bg-anthracite);
    border: 1px solid var(--border);
    border-radius: 8px;
}

.sales-summary-title {
    font-family: 'Orbitron', sans-serif;
    color: var(--gold-primary);
    margin-bottom: 16px;
}

.sales-summary-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 24px 48px;
}

.sales-summary-item {
    display: flex;
    flex-direction: column;
}

.sales-summary-item span {
    font-size: 0.85rem;
    color: var(--text-muted);
}

.sales-summary-item strong {
    font-size: 1.2rem;
    color: var(--gold-primary);
}

/* Responsive */
@media (max-width: 1024px) {
    .pos-container {
        grid-template-columns: 1fr;
    }

    .kpi-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .dashboard-charts {
        grid-template-columns: 1fr;
    }

    .orders-layout {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .sidebar {
        width: 60px;
    }

    .logo h1, .logo-sub, .nav-btn span:not(.nav-icon) {
        display: none;
    }

    .main-content {
        margin-left: 60px;
    }

    .kpi-grid {
        grid-template-columns: 1fr;
    }
}

/* Login Overlay (wie Referenzsystem) */
.login-overlay {
    position: fixed;
    inset: 0;
    background: var(--bg-dark);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9998;
}
.login-overlay.hidden { display: none; }
.login-box {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 32px;
    width: 100%;
    max-width: 360px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.5);
}
.login-box h2 { margin: 0 0 4px; font-size: 1.5rem; color: var(--text-primary); font-family: 'Orbitron', sans-serif; }
.login-subtitle { color: var(--text-muted); font-size: 0.95rem; margin-bottom: 24px; }
.login-form { display: flex; flex-direction: column; gap: 16px; }
.login-field label { display: block; font-size: 0.85rem; color: var(--text-muted); margin-bottom: 4px; }
.login-input {
    width: 100%;
    padding: 12px 14px;
    font-size: 1rem;
    border: 1px solid var(--border);
    border-radius: 6px;
    background: var(--bg-anthracite);
    color: var(--text-primary);
    box-sizing: border-box;
}
.login-input:focus { outline: none; border-color: var(--benny-red); }
.login-btn { width: 100%; padding: 12px; font-size: 1rem; margin-top: 8px; }
.logout-btn {
    display: block;
    width: 100%;
    padding: 8px 12px;
    margin-bottom: 10px;
    font-size: 0.85rem;
    background: transparent;
    border: 1px solid var(--border);
    border-radius: 6px;
    color: var(--text-muted);
    cursor: pointer;
    transition: all 0.15s;
}
.logout-btn:hover { background: var(--bg-elevated); color: var(--danger); border-color: rgba(192,57,43,0.5); }
.login-setup-hint { color: var(--text-muted); font-size: 0.9rem; margin-bottom: 8px; }

/* Toast & Loading (Struktur wie Referenzsystem) */
.toast-container {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 10000;
    display: flex;
    flex-direction: column;
    gap: 8px;
    pointer-events: none;
}
.toast {
    padding: 12px 20px;
    border-radius: 6px;
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    color: var(--text-primary);
    font-size: 0.95rem;
    box-shadow: 0 4px 12px rgba(0,0,0,0.4);
    animation: toast-in 0.25s ease;
}
.toast-success { border-left: 4px solid var(--success); }
.toast-error { border-left: 4px solid var(--danger); }
.toast-info { border-left: 4px solid var(--gold-primary); }
@keyframes toast-in {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

.loading-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.7);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 9999;
    gap: 16px;
}
.loading-overlay.hidden { display: none; }
.loading-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid var(--border);
    border-top-color: var(--benny-red);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}
.loading-text { color: var(--text-muted); }
@keyframes spin { to { transform: rotate(360deg); } }

/* Globale Suche */
.global-search-modal {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.75);
    z-index: 9000;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 80px 20px 0;
}
.global-search-modal.hidden { display: none; }
.global-search-content {
    width: 100%;
    max-width: 560px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 8px 32px rgba(0,0,0,0.5);
}
.global-search-input {
    width: 100%;
    padding: 14px 18px;
    font-size: 1rem;
    background: var(--bg-anthracite);
    border: none;
    border-bottom: 1px solid var(--border);
    color: var(--text-primary);
    outline: none;
}
.global-search-input::placeholder { color: var(--text-muted); }
.global-search-results {
    max-height: 360px;
    overflow-y: auto;
    padding: 8px 0;
}
.global-search-item {
    padding: 10px 18px;
    color: var(--text-primary);
    cursor: default;
    border-bottom: 1px solid transparent;
}
.global-search-item:hover { background: var(--bg-elevated); }
.global-search-type {
    display: inline-block;
    min-width: 80px;
    font-size: 0.8rem;
    color: var(--text-muted);
}
