/* =====================================================
   CAFE ADISYON - MODERN UI CSS
   Dark/Light Mode Support
   ===================================================== */

/* =====================================================
   CSS VARIABLES - LIGHT MODE (Default)
   ===================================================== */
:root {
    /* Primary Colors */
    --primary: #3b82f6;
    --primary-hover: #2563eb;
    --primary-light: #eff6ff;
    
    /* Status Colors */
    --success: #10b981;
    --success-hover: #059669;
    --success-light: #d1fae5;
    
    --danger: #ef4444;
    --danger-hover: #dc2626;
    --danger-light: #fee2e2;
    
    --warning: #f59e0b;
    --warning-hover: #d97706;
    --warning-light: #fef3c7;
    
    --info: #06b6d4;
    --info-hover: #0891b2;
    --info-light: #cffafe;
    
    /* Neutral Colors */
    --bg-primary: #f8fafc;
    --bg-secondary: #ffffff;
    --bg-tertiary: #f1f5f9;
    --bg-hover: #e2e8f0;
    --bg-card: #ffffff;        /* kart/panel arka planı */
    --bg-elevated: #ffffff;    /* yükseltilmiş yüzey */
    --text-on-gradient: #ffffff; /* pembe-mor gradyan üzeri yazı */
    
    --text-primary: #1e293b;
    --text-secondary: #64748b;
    --text-muted: #94a3b8;
    --text-inverse: #ffffff;
    
    --border-color: #e2e8f0;
    --border-light: #f1f5f9;
    
    /* Shadows */
    --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
    --shadow: 0 1px 3px rgba(0,0,0,0.1), 0 1px 2px rgba(0,0,0,0.06);
    --shadow-md: 0 4px 6px -1px rgba(0,0,0,0.1), 0 2px 4px -1px rgba(0,0,0,0.06);
    --shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -2px rgba(0,0,0,0.05);
    
    /* Sizing */
    --radius-sm: 6px;
    --radius: 8px;
    --radius-lg: 12px;
    --radius-xl: 16px;
    
    /* Navbar */
    --navbar-bg: #1e293b;
    --navbar-text: #f8fafc;
}

/* =====================================================
   DARK MODE
   ===================================================== */
[data-theme="dark"] {
    --primary: #60a5fa;
    --primary-hover: #3b82f6;
    --primary-light: #1e3a5f;
    
    --success: #34d399;
    --success-hover: #10b981;
    --success-light: #064e3b;
    
    --danger: #f87171;
    --danger-hover: #ef4444;
    --danger-light: #7f1d1d;
    
    --warning: #fbbf24;
    --warning-hover: #f59e0b;
    --warning-light: #78350f;
    
    --info: #22d3ee;
    --info-hover: #06b6d4;
    --info-light: #164e63;
    
    --bg-primary: #0f172a;
    --bg-secondary: #1e293b;
    --bg-tertiary: #334155;
    --bg-hover: #475569;
    --bg-card: #1e293b;
    --bg-elevated: #273548;
    --text-on-gradient: #ffffff;
    
    --text-primary: #f8fafc;
    --text-secondary: #cbd5e1;
    --text-muted: #94a3b8;
    --text-inverse: #1e293b;
    
    --border-color: #334155;
    --border-light: #475569;
    
    --shadow-sm: 0 1px 2px rgba(0,0,0,0.3);
    --shadow: 0 1px 3px rgba(0,0,0,0.4), 0 1px 2px rgba(0,0,0,0.3);
    --shadow-md: 0 4px 6px -1px rgba(0,0,0,0.4), 0 2px 4px -1px rgba(0,0,0,0.3);
    --shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.4), 0 4px 6px -2px rgba(0,0,0,0.3);
    
    --navbar-bg: #0f172a;
    --navbar-text: #f8fafc;
}

/* =====================================================
   BASE STYLES
   ===================================================== */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    height: 100%;
    height: 100dvh;
    overflow: hidden;
    overscroll-behavior: none;
    background: var(--bg-primary, #f8fafc);
}
html[data-theme="dark"] {
    background: var(--bg-primary, #0f172a) !important;
}

body {
    height: 100%;
    height: 100dvh;
    overflow: hidden;
    overscroll-behavior: none;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', sans-serif;
    background: var(--bg-primary);
    color: var(--text-primary);
    font-size: 14px;
    line-height: 1.5;
    transition: background-color 0.3s, color 0.3s;
    padding: 0;
}

/* =====================================================
   LAYOUT
   ===================================================== */
.page {
    display: flex;
    flex-direction: column;
    height: 100%;
    height: 100dvh;
    overflow: hidden;
}

/* Dashboard gibi scroll gereken sayfalar için page'i auto yap */
.page:has(.dash),
.page:has(.dash-lock) {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

main {
    flex: 1;
    padding: 12px;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
}

/* Sipariş, hızlı satış, ödeme ve masalar sayfalarında scroll olmasın — HER ZAMAN */
main:has(.split-container),
main:has(.pos-container),
main:has(.ml-shell),
main:has(.tbl-shell),
main:has(.payment-container),
main:has(.payment-layout) {
    overflow: hidden;
    padding: 0;
}

/* MOBİLDE tab-bar ile uyumlu — overflow hidden, tüm POS sayfaları */
@media (max-width: 991px) {
    main:has(.payment-container),
    main:has(.payment-layout),
    main:has(.split-container),
    main:has(.pos-container),
    main:has(.ml-shell),
    main:has(.tbl-shell) {
        overflow: hidden !important;
        padding: 0 !important;
    }
}

@media (min-width: 768px) {
    main {
        padding: 20px;
        padding-bottom: 20px; /* Desktop'ta normal padding */
    }
}

/* =====================================================
   NAVBAR
   ===================================================== */
.top-navbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--navbar-bg);
    padding: env(safe-area-inset-top, 0px) 16px 0;
    min-height: calc(56px + env(safe-area-inset-top, 0px));
    height: auto;
    box-shadow: var(--shadow-md);
    position: relative;
    z-index: 100;
}

.navbar-brand {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--navbar-text);
    text-decoration: none;
}

.navbar-links {
    display: flex;
    gap: 4px;
    align-items: center;
}

.nav-link {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    color: var(--navbar-text);
    text-decoration: none;
    border-radius: var(--radius);
    font-size: 0.875rem;
    opacity: 0.8;
    transition: all 0.2s;
}

.nav-link:hover {
    opacity: 1;
    background: rgba(255,255,255,0.1);
}

.nav-link i {
    font-size: 1.1rem;
}

.nav-link span {
    display: none;
}

@media (min-width: 768px) {
    .nav-link span {
        display: inline;
    }
}

/* Theme Toggle */
.theme-toggle {
    background: transparent;
    border: none;
    color: var(--navbar-text);
    padding: 8px 12px;
    cursor: pointer;
    border-radius: var(--radius);
    font-size: 1.2rem;
    opacity: 0.8;
    transition: all 0.2s;
    display: flex;
    align-items: center;
    gap: 6px;
}

.theme-toggle:hover {
    opacity: 1;
    background: rgba(255,255,255,0.1);
}

/* Yazıcı Servis Durum Badge */
.printer-status-badge {
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 5px 10px;
    border-radius: 20px;
    font-size: 0.78rem;
    font-weight: 600;
    cursor: default;
    transition: all 0.3s;
}
.printer-status-badge.active {
    background: rgba(34, 197, 94, 0.2);
    color: #22c55e;
    border: 1px solid rgba(34, 197, 94, 0.4);
}
.printer-status-badge.inactive {
    background: rgba(239, 68, 68, 0.2);
    color: #ef4444;
    border: 1px solid rgba(239, 68, 68, 0.4);
    animation: pulse-red 2s infinite;
}
@keyframes pulse-red {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.6; }
}

/* =====================================================
   BUTTONS - UNIFIED STYLES
   ===================================================== */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 16px;
    font-size: 0.875rem;
    font-weight: 500;
    border-radius: var(--radius);
    border: none;
    cursor: pointer;
    transition: all 0.2s;
    text-decoration: none;
    white-space: nowrap;
}

.btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.btn-sm {
    padding: 6px 12px;
    font-size: 0.8125rem;
}

.btn-lg {
    padding: 12px 20px;
    font-size: 1rem;
}

.btn-block, .w-100 {
    width: 100%;
}

/* Button Variants */
.btn-primary {
    background: var(--primary);
    color: var(--text-inverse);
}
.btn-primary:hover:not(:disabled) {
    background: var(--primary-hover);
}

.btn-success {
    background: var(--success);
    color: var(--text-inverse);
}
.btn-success:hover:not(:disabled) {
    background: var(--success-hover);
}

.btn-danger {
    background: var(--danger);
    color: var(--text-inverse);
}
.btn-danger:hover:not(:disabled) {
    background: var(--danger-hover);
}

.btn-warning {
    background: var(--warning);
    color: var(--text-inverse);
}
.btn-warning:hover:not(:disabled) {
    background: var(--warning-hover);
}

.btn-info {
    background: var(--info);
    color: var(--text-inverse);
}
.btn-info:hover:not(:disabled) {
    background: var(--info-hover);
}

.btn-secondary {
    background: var(--bg-tertiary);
    color: var(--text-primary);
    border: 1px solid var(--border-color);
}
.btn-secondary:hover:not(:disabled) {
    background: var(--bg-hover);
}

.btn-outline-primary {
    background: transparent;
    color: var(--primary);
    border: 1px solid var(--primary);
}
.btn-outline-primary:hover:not(:disabled) {
    background: var(--primary-light);
}

.btn-outline-danger {
    background: transparent;
    color: var(--danger);
    border: 1px solid var(--danger);
}
.btn-outline-danger:hover:not(:disabled) {
    background: var(--danger-light);
}

.btn-outline-success {
    background: transparent;
    color: var(--success);
    border: 1px solid var(--success);
}
.btn-outline-success:hover:not(:disabled) {
    background: var(--success-light);
}

.btn-outline-secondary {
    background: transparent;
    color: var(--text-secondary);
    border: 1px solid var(--border-color);
}
.btn-outline-secondary:hover:not(:disabled) {
    background: var(--bg-hover);
}

/* =====================================================
   CARDS
   ===================================================== */
.card {
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    border: 1px solid var(--border-color);
    overflow: hidden;
}

.card-header {
    padding: 16px 20px;
    border-bottom: 1px solid var(--border-color);
    background: var(--bg-tertiary);
}

.card-header h5, .card-header h6 {
    margin: 0;
    font-weight: 600;
}

.card-body {
    padding: 20px;
}

.card-footer {
    padding: 16px 20px;
    border-top: 1px solid var(--border-color);
    background: var(--bg-tertiary);
}

/* =====================================================
   FORMS
   ===================================================== */
.form-label {
    display: block;
    margin-bottom: 6px;
    font-weight: 500;
    color: var(--text-primary);
    font-size: 0.875rem;
}

.form-control {
    width: 100%;
    padding: 10px 14px;
    font-size: 0.9375rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    background: var(--bg-secondary);
    color: var(--text-primary);
    transition: border-color 0.2s, box-shadow 0.2s;
}

.form-control:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--primary-light);
}

.form-control-lg {
    padding: 12px 16px;
    font-size: 1rem;
}

.form-select {
    width: 100%;
    padding: 10px 14px;
    font-size: 0.9375rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    background: var(--bg-secondary);
    color: var(--text-primary);
    cursor: pointer;
}

textarea.form-control {
    resize: vertical;
    min-height: 80px;
}

.input-group {
    display: flex;
    gap: 8px;
}

.input-group .form-control {
    flex: 1;
}

.btn-group {
    display: flex;
}

.btn-group .btn {
    border-radius: 0;
    flex: 1;
}

.btn-group .btn:first-child {
    border-radius: var(--radius) 0 0 var(--radius);
}

.btn-group .btn:last-child {
    border-radius: 0 var(--radius) var(--radius) 0;
}

.flex-fill {
    flex: 1;
}

/* =====================================================
   ALERTS
   ===================================================== */
.alert {
    padding: 12px 16px;
    border-radius: var(--radius);
    margin-bottom: 16px;
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.alert-success {
    background: var(--success-light);
    color: var(--success);
    border: 1px solid var(--success);
}

.alert-danger {
    background: var(--danger-light);
    color: var(--danger);
    border: 1px solid var(--danger);
}

.alert-warning {
    background: var(--warning-light);
    color: var(--warning);
    border: 1px solid var(--warning);
}

.alert-info {
    background: var(--info-light);
    color: var(--info);
    border: 1px solid var(--info);
}

/* =====================================================
   TABLES
   ===================================================== */
.table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
}

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

.table th {
    font-weight: 600;
    background: var(--bg-tertiary);
    color: var(--text-secondary);
    font-size: 0.8125rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

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

.table-striped tbody tr:nth-child(even) {
    background: var(--bg-tertiary);
}

.table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.table-dark {
    background: var(--navbar-bg);
    color: white;
}

.table-dark th, .table-dark td {
    border-color: rgba(255,255,255,0.1);
}

.table-sm th, .table-sm td {
    padding: 8px 12px;
}

/* =====================================================
   MODALS
   ===================================================== */
.modal-backdrop-custom {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    padding: 20px;
}

.modal-dialog {
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    width: 100%;
    max-width: 500px;
    max-height: 90vh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.modal-content {
    display: flex;
    flex-direction: column;
    max-height: 90vh;
    overflow: hidden;
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
}

.modal-dialog.modal-lg {
    max-width: 800px;
}

.modal-dialog.modal-xl {
    max-width: 1000px;
}

.modal-header {
    padding: 16px 20px;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-shrink: 0;
    background: var(--bg-secondary);
    color: var(--text-primary);
}

.modal-title {
    font-size: 1.125rem;
    font-weight: 600;
    margin: 0;
}

.modal-body {
    padding: 20px;
    overflow-y: auto;
    flex: 1;
    min-height: 0;
    color: var(--text-primary);
}

.modal-footer {
    padding: 16px 20px;
    border-top: 1px solid var(--border-color);
    display: flex;
    gap: 12px;
    justify-content: flex-end;
    flex-shrink: 0;
    background: var(--bg-secondary);
}

.btn-close {
    background: transparent;
    border: none;
    font-size: 1.5rem;
    cursor: pointer;
    color: var(--text-secondary);
    padding: 0;
    line-height: 1;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius);
}

.btn-close::before {
    content: "×";
}

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

.btn-close-white {
    color: rgba(255,255,255,0.7);
}

.btn-close-white:hover {
    color: white;
    background: rgba(255,255,255,0.1);
}

/* Modal Header Colors */
.modal-header.bg-success {
    background: var(--success);
    color: white;
    border-bottom: none;
}

.modal-header.bg-danger {
    background: var(--danger);
    color: white;
    border-bottom: none;
}

.modal-header.bg-warning {
    background: var(--warning);
    color: white;
    border-bottom: none;
}

.modal-header.bg-info {
    background: var(--info);
    color: white;
    border-bottom: none;
}

/* =====================================================
   POS CONTAINER (QuickSale & OrderPage)
   ===================================================== */
.pos-container {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 80px);
    height: calc(100dvh - 80px);
    gap: 12px;
}

@media (min-width: 992px) {
    .pos-container {
        flex-direction: row;
    }
}

/* Products Panel */
.pos-products {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow: hidden;
}

/* pos-products mobil — pos-modern.css tarafından yönetiliyor */

/* Category Bar Wrapper */
.category-bar-wrapper {
    display: flex;
    align-items: center;
    background: var(--bg-tertiary);
    border-bottom: 1px solid var(--border-color);
    flex-shrink: 0;
    padding: 0;
}

.cat-arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    min-width: 32px;
    height: 100%;
    min-height: 44px;
    background: var(--bg-tertiary);
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    font-size: 0.9rem;
    transition: all 0.2s;
    flex-shrink: 0;
}

.cat-arrow:hover {
    background: var(--bg-hover);
    color: var(--primary);
}

.cat-arrow:active {
    transform: scale(0.9);
}

/* Category Bar */
.category-bar {
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
    padding: 8px;
    flex: 1;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
    flex-shrink: 0;
}

.category-bar::-webkit-scrollbar {
    display: none;
}

.category-bar::-webkit-scrollbar {
    width: 4px;
}

.category-bar::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 2px;
}

.cat-btn {
    padding: 6px 14px;
    border: none;
    border-radius: var(--radius-xl);
    font-size: 0.8rem;
    font-weight: 500;
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.2s;
    background: var(--bg-secondary);
    color: var(--text-secondary);
    border: 1px solid var(--border-color);
}

.cat-btn:hover {
    background: var(--bg-hover);
}

.cat-btn.active {
    background: var(--primary);
    color: white;
    border-color: var(--primary);
}

/* Products Grid */
.products-grid {
    flex: 1;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 6px;
    padding: 8px;
    overflow-y: auto;
    align-content: start;
}

@media (min-width: 480px) {
    .products-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (min-width: 768px) {
    .products-grid {
        grid-template-columns: repeat(4, 1fr);
        gap: 10px;
        padding: 12px;
    }
}

@media (min-width: 1200px) {
    .products-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (min-width: 1600px) {
    .products-grid {
        grid-template-columns: repeat(5, 1fr);
    }
}

/* Product Card */
.prod-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 12px 8px;
    min-height: 80px;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    background: var(--bg-secondary);
    cursor: pointer;
    transition: all 0.2s;
    text-align: center;
}

.prod-btn:hover {
    border-color: var(--primary);
    background: var(--primary-light);
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.prod-btn:active {
    transform: translateY(0);
}

.prod-name {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--text-primary);
    margin-bottom: 4px;
    line-height: 1.2;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    word-break: break-word;
}

.prod-price {
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--primary);
}

/* =====================================================
   RIGHT PANEL (Cart + Payment)
   ===================================================== */
.pos-right-panel {
    display: flex;
    flex-direction: column;
    min-height: 0;
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow: hidden;
}

@media (min-width: 992px) {
    .pos-right-panel {
        width: 380px;
        flex-shrink: 0;
    }
}

/* ─── pos-right-panel mobil — pos-modern.css'e taşındı ─── */

/* Cart Section */
.cart-section {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

/* Payment Section */
.payment-section {
    display: flex;
    flex-direction: column;
    padding: 8px;
    gap: 6px;
    border-top: 1px solid var(--border-color);
    background: var(--bg-tertiary);
    flex-shrink: 0;
}

.payment-amount-row {
    display: flex;
    align-items: center;
    gap: 8px;
}

.payment-amount-row .payment-amount-display {
    flex: 1;
}

.discount-btn {
    width: 100%;
    padding: 6px;
    margin-top: 4px;
    border: 1px dashed var(--danger);
    background: rgba(239, 68, 68, 0.08);
    color: var(--danger);
    border-radius: 6px;
    font-size: 0.8rem;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    transition: all 0.15s;
}

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

/* numpad-toggle kaldırıldı — numpad artık her zaman açık */
.numpad-toggle { display: none; }

.cart-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 14px;
    background: var(--bg-tertiary);
    border-bottom: 1px solid var(--border-color);
    font-weight: 600;
    flex-shrink: 0;
}

.cart-items {
    flex: 1;
    overflow-y: auto;
    min-height: 80px;
}

.cart-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    border-bottom: 1px solid var(--border-light);
}

.cart-item:hover {
    background: var(--bg-hover);
}

.cart-item-qty {
    display: flex;
    align-items: center;
    gap: 4px;
}

.cart-item-qty button {
    width: 42px;
    height: 42px;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-weight: 600;
    font-size: 1.2rem;
    -webkit-tap-highlight-color: transparent;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    justify-content: center;
}

.cart-item-qty button:hover {
    background: var(--bg-hover);
}

.cart-item-qty span {
    min-width: 32px;
    text-align: center;
    font-weight: 600;
    font-size: 1.05rem;
}

.cart-item-info {
    flex: 1;
    min-width: 0;
}

.cart-item-name {
    font-weight: 500;
    font-size: 0.875rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.cart-item-price {
    font-size: 0.8125rem;
    color: var(--text-secondary);
}

.cart-item-total {
    font-weight: 600;
    color: var(--primary);
}

.cart-item-remove {
    min-width: 42px;
    min-height: 42px;
    padding: 8px;
    border: none;
    background: transparent;
    cursor: pointer;
    border-radius: var(--radius-sm);
    color: var(--text-muted);
    font-size: 1.2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    -webkit-tap-highlight-color: transparent;
}

.cart-item-remove:hover {
    background: var(--danger-light);
    color: var(--danger);
}

.cart-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
    color: var(--text-muted);
}

.cart-empty i {
    font-size: 3rem;
    margin-bottom: 12px;
}

/* Cart Footer */
.cart-footer {
    border-top: 1px solid var(--border-color);
    background: var(--bg-tertiary);
}

.cart-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 16px;
    font-size: 1.125rem;
    font-weight: 700;
    background: var(--navbar-bg);
    color: white;
}

.cart-payment {
    padding: 12px;
}

.payment-input {
    margin-bottom: 12px;
}

.payment-input label {
    display: block;
    font-size: 0.8125rem;
    color: var(--text-secondary);
    margin-bottom: 4px;
}

.payment-input input {
    width: 100%;
    padding: 10px 14px;
    font-size: 1rem;
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    background: var(--bg-secondary);
    color: var(--text-primary);
}

.payment-change {
    padding: 10px;
    background: var(--success-light);
    color: var(--success);
    border-radius: var(--radius);
    text-align: center;
    margin-bottom: 12px;
    font-weight: 500;
}

.payment-buttons {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-bottom: 10px;
}

.pay-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 12px;
    border: none;
    border-radius: var(--radius);
    font-size: 0.9375rem;
    font-weight: 600;
    cursor: pointer;
    color: white;
    transition: all 0.2s;
}

.pay-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.pay-btn.cash {
    background: var(--success);
}

.pay-btn.cash:hover:not(:disabled) {
    background: var(--success-hover);
}

.pay-btn.card {
    background: var(--primary);
}

.pay-btn.card:hover:not(:disabled) {
    background: var(--primary-hover);
}

.clear-btn {
    width: 100%;
    padding: 10px;
    border: 1px solid var(--danger);
    background: transparent;
    color: var(--danger);
    border-radius: var(--radius);
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
}

.clear-btn:hover:not(:disabled) {
    background: var(--danger-light);
}

.clear-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* =====================================================
   ORDER PAGE - SPLIT VIEW
   ===================================================== */
.split-container {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 80px);
    height: calc(100dvh - 80px);
    gap: 12px;
}

@media (min-width: 992px) {
    .split-container {
        flex-direction: row;
    }
}

.split-left {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow: hidden;
}

/* ─── split-left kaldırıldı (kullanılmıyor) ─── */

.split-right {
    display: flex;
    flex-direction: column;
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow: hidden;
    min-height: 0;
}

@media (min-width: 992px) {
    .split-right {
        width: 460px;
        flex-shrink: 0;
    }
}

@media (min-width: 1400px) {
    .split-right {
        width: 520px;
    }
}

@media (min-width: 1800px) {
    .split-right {
        width: 580px;
    }
}

/* ─── split-right kaldırıldı (kullanılmıyor) ─── */

/* Order Header */
.order-header {
    padding: 8px 10px;
    background: var(--bg-tertiary);
    border-bottom: 1px solid var(--border-color);
}

.order-header h5 {
    margin: 0;
    font-size: 0.88rem;
    font-weight: 600;
}

.order-header small {
    color: var(--text-secondary);
    font-size: 0.8125rem;
}

.order-header-info {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 8px 10px;
    background: var(--navbar-bg);
    color: white;
    flex-shrink: 0;
}

.order-header-info .header-left h5 {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: white;
}

.order-header-info .header-left small {
    color: var(--text-muted);
    font-size: 0.8125rem;
}

.order-header-info .header-right {
    text-align: right;
}

.order-header-info .header-right small {
    color: var(--warning);
}

.order-header-info .header-hourly {
    width: 100%;
    padding-top: 8px;
    margin-top: 8px;
    border-top: 1px solid rgba(255,255,255,0.2);
    font-size: 0.8125rem;
    color: var(--info);
}

.order-header-info .header-hourly i {
    margin-right: 4px;
}

/* Order Items */
.order-items {
    flex: 1;
    overflow-y: auto;
    min-height: 0;
}

/* order-item tanımı ORDER PAGE SPECIFIC STYLES bölümünde */

.order-item.cancelled {
    opacity: 0.5;
    text-decoration: line-through;
}

.order-item.printed {
    background: var(--success-light);
}

.order-item-checkbox {
    width: 20px;
    height: 20px;
    cursor: pointer;
    accent-color: var(--primary);
}

.order-item-qty {
    display: flex;
    align-items: center;
    gap: 4px;
    background: var(--bg-tertiary);
    padding: 4px 10px;
    border-radius: var(--radius-sm);
    font-weight: 600;
    font-size: 0.875rem;
    min-width: 36px;
    justify-content: center;
}

.order-item-info {
    flex: 1;
    min-width: 0;
}

.order-item-name {
    font-weight: 500;
    font-size: 0.875rem;
}

.order-item-note {
    font-size: 0.75rem;
    color: var(--warning);
    font-style: italic;
}

.order-item-total {
    font-weight: 600;
    color: var(--primary);
}

.order-item-actions {
    display: flex;
    gap: 4px;
}

.order-item-actions button {
    padding: 6px 8px;
    border: none;
    background: var(--bg-tertiary);
    cursor: pointer;
    border-radius: var(--radius-sm);
    color: var(--text-secondary);
    font-size: 0.875rem;
}

.order-item-actions button:hover {
    background: var(--bg-hover);
    color: var(--text-primary);
}

/* Order Footer */
.order-footer {
    border-top: 1px solid var(--border-color);
    background: var(--bg-tertiary);
}

.order-summary {
    padding: 8px 10px;
}

.order-summary-row {
    display: flex;
    justify-content: space-between;
    padding: 3px 0;
    font-size: 0.82rem;
}

.order-summary-row.total {
    font-size: 1rem;
    font-weight: 700;
    padding-top: 6px;
    margin-top: 6px;
    border-top: 1px solid var(--border-color);
}

.action-buttons {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
    padding: 8px 10px;
}

/* =====================================================
   TABLES PAGE
   ===================================================== */
.tables-header {
    display: none;
}

.tables-header h4 {
    margin: 0;
    font-weight: 600;
}

.filter-buttons {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 8px;
}

@media (max-width: 576px) {
    .filter-buttons {
        flex-wrap: nowrap;
        overflow-x: auto;
        scrollbar-width: none;
        -ms-overflow-style: none;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 4px;
    }
    .filter-buttons::-webkit-scrollbar { display: none; }
}

.filter-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    border-radius: var(--radius-xl);
    font-size: 0.8125rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
    color: var(--text-secondary);
    flex-shrink: 0;
    white-space: nowrap;
}

.filter-btn:hover {
    background: var(--bg-hover);
}

.filter-btn.active {
    background: var(--primary);
    color: white;
    border-color: var(--primary);
}

.filter-btn.success.active {
    background: var(--success);
    border-color: var(--success);
}

.filter-btn.danger.active {
    background: var(--danger);
    border-color: var(--danger);
}

.filter-btn.warning.active {
    background: var(--warning);
    border-color: var(--warning);
}

.filter-btn .badge {
    background: rgba(255,255,255,0.2);
    padding: 2px 6px;
    border-radius: 10px;
    font-size: 0.75rem;
}

/* Section Filters */
.section-filters {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 12px;
}

@media (max-width: 576px) {
    .section-filters {
        flex-wrap: nowrap;
        overflow-x: auto;
        scrollbar-width: none;
        -ms-overflow-style: none;
        -webkit-overflow-scrolling: touch;
        padding-bottom: 4px;
    }
    .section-filters::-webkit-scrollbar { display: none; }
}

.section-btn {
    padding: 8px 16px;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    border-radius: var(--radius);
    font-size: 0.8125rem;
    font-weight: 500;
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    transition: all 0.2s;
    color: var(--text-secondary);
}

.section-btn:hover {
    background: var(--bg-hover);
}

.section-btn.active {
    background: var(--navbar-bg);
    color: white;
    border-color: var(--navbar-bg);
}

/* Section Divider - Tümü görünümde bölüm başlıkları */
.section-divider {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 6px 2px;
    margin-top: 6px;
}

.section-divider:first-child {
    margin-top: 0;
}

.section-divider-text {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.3px;
    white-space: nowrap;
}

.section-divider-count {
    font-size: 0.7rem;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    padding: 2px 8px;
    border-radius: 10px;
    font-weight: 500;
    white-space: nowrap;
}

.section-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--border-color);
    order: 99; /* count'tan sonra çizgi gelsin */
}

/* Tables Grid */
.tables-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
    margin-bottom: 4px;
}

@media (min-width: 576px) {
    .tables-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (min-width: 768px) {
    .tables-grid {
        grid-template-columns: repeat(4, 1fr);
        gap: 12px;
    }
}

@media (min-width: 992px) {
    .tables-grid {
        grid-template-columns: repeat(6, 1fr);
    }
}

@media (min-width: 1200px) {
    .tables-grid {
        grid-template-columns: repeat(7, 1fr);
    }
}

@media (min-width: 1400px) {
    .tables-grid {
        grid-template-columns: repeat(8, 1fr);
    }
}

/* Table Card */
.table-card {
    background: var(--bg-secondary);
    border-radius: var(--radius);
    padding: 12px;
    cursor: pointer;
    transition: all 0.2s;
    border: 2px solid var(--border-color);
    position: relative;
    min-height: 70px;
}

.table-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.table-card.empty {
    border-color: var(--success);
}

.table-card.occupied {
    border-color: var(--danger);
    background: var(--danger-light);
}

.table-card.reserved {
    border-color: var(--warning);
    background: var(--warning-light);
}

.table-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 4px;
}

.table-name {
    font-weight: 700;
    font-size: 0.9rem;
}

.table-type {
    font-size: 0.6875rem;
    padding: 2px 6px;
    border-radius: var(--radius-sm);
    font-weight: 600;
    text-transform: uppercase;
}

.table-type.okey {
    background: var(--warning);
    color: white;
}

.table-type.vip {
    background: var(--danger);
    color: white;
}

.table-info-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.table-section {
    font-size: 0.7rem;
    color: var(--text-muted);
}

.table-amount {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--danger);
}

.table-time {
    font-size: 0.75rem;
    color: var(--text-secondary);
}

.table-capacity {
    font-size: 0.7rem;
    color: var(--text-muted);
}

.table-fee {
    font-size: 0.75rem;
    color: var(--info);
    font-weight: 500;
}

.table-status-badge {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
}

.table-status-badge.empty {
    background: var(--success);
}

.table-status-badge.occupied {
    background: var(--danger);
}

.table-status-badge.reserved {
    background: var(--warning);
}

/* =====================================================
   DASHBOARD
   ===================================================== */
.dashboard-card {
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    padding: 20px;
    box-shadow: var(--shadow);
    text-align: center;
    transition: all 0.2s;
    border: 1px solid var(--border-color);
}

.dashboard-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}

.dashboard-card .card-icon {
    font-size: 2.5rem;
    margin-bottom: 12px;
}

.dashboard-card .card-value {
    font-size: 1.75rem;
    font-weight: 700;
    margin-bottom: 4px;
}

.dashboard-card .card-label {
    color: var(--text-secondary);
    font-size: 0.875rem;
}

/* Dashboard Card - Mobile */
@media (max-width: 576px) {
    .dashboard-card {
        padding: 12px 10px;
    }
    
    .dashboard-card .card-icon {
        font-size: 1.8rem;
        margin-bottom: 6px;
    }
    
    .dashboard-card .card-value {
        font-size: 1.25rem;
        margin-bottom: 2px;
    }
    
    .dashboard-card .card-label {
        font-size: 0.7rem;
    }
    
    .welcome-title {
        font-size: 1.3rem;
    }
}

/* =====================================================
   SETTINGS
   ===================================================== */
.settings-page {
    padding-bottom: 20px;
}

.settings-sidebar {
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: 20px;
    border: 1px solid var(--border-color);
}

.settings-sidebar .list-group-item {
    padding: 12px 16px;
    border: none;
    border-bottom: 1px solid var(--border-color);
    background: var(--bg-secondary);
    color: var(--text-primary);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: all 0.2s;
}

.settings-sidebar .list-group-item:last-child {
    border-bottom: none;
}

.settings-sidebar .list-group-item:hover {
    background: var(--bg-hover);
}

.settings-sidebar .list-group-item.active {
    background: var(--primary);
    color: white;
}

/* Settings Mobil Responsive */
@media (max-width: 768px) {
    .settings-page .row {
        flex-direction: column;
    }
    
    .settings-page .col-md-3 {
        width: 100%;
        max-width: 100%;
        flex: none;
        margin-bottom: 15px;
    }
    
    .settings-page .col-md-9 {
        width: 100%;
        max-width: 100%;
        flex: none;
    }
    
    .settings-sidebar {
        display: flex;
        flex-wrap: nowrap;
        gap: 0;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }
    
    .settings-sidebar::-webkit-scrollbar {
        display: none;
    }
    
    .settings-sidebar .list-group-item {
        flex: 0 0 auto;
        min-width: 100px;
        padding: 10px 12px;
        font-size: 0.8rem;
        justify-content: center;
        text-align: center;
        border-bottom: none;
        border-right: 1px solid var(--border-color);
    }
    
    .settings-sidebar .list-group-item:last-child {
        border-right: none;
    }
    
    .settings-sidebar .list-group-item i {
        margin-right: 4px !important;
    }
}

@media (max-width: 576px) {
    .settings-sidebar .list-group-item {
        min-width: 80px;
        padding: 8px 10px;
        font-size: 0.7rem;
        flex-direction: column;
        gap: 3px;
    }
    
    .settings-sidebar .list-group-item i {
        margin-right: 0 !important;
        font-size: 1rem;
    }
}

/* =====================================================
   BADGES
   ===================================================== */
.badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 8px;
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: var(--radius-sm);
}

.badge.bg-success { background: var(--success); color: white; }
.badge.bg-danger { background: var(--danger); color: white; }
.badge.bg-warning { background: var(--warning); color: white; }
.badge.bg-info { background: var(--info); color: white; }
.badge.bg-primary { background: var(--primary); color: white; }
.badge.bg-secondary { background: var(--bg-tertiary); color: var(--text-primary); }

/* =====================================================
   PROGRESS BAR
   ===================================================== */
.progress {
    height: 8px;
    background: var(--bg-tertiary);
    border-radius: var(--radius);
    overflow: hidden;
}

.progress-bar {
    height: 100%;
    background: var(--primary);
    transition: width 0.3s;
}

.progress-bar.bg-success { background: var(--success); }
.progress-bar.bg-danger { background: var(--danger); }
.progress-bar.bg-warning { background: var(--warning); }

/* =====================================================
   SETTINGS CARDS & DATA LIST
   ===================================================== */
.settings-card {
    background: var(--bg-secondary);
    border-radius: 12px;
    border: 1px solid var(--border-color);
    overflow: hidden;
}

.settings-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px;
    border-bottom: 1px solid var(--border-color);
}

.settings-card-header h5 {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
}

.settings-card-body {
    padding: 0;
}

.empty-state {
    padding: 40px 20px;
    text-align: center;
    color: var(--text-secondary);
}

.empty-state i {
    font-size: 2.5rem;
    margin-bottom: 12px;
    opacity: 0.5;
}

.empty-state p {
    margin: 0;
    font-size: 0.9rem;
}

.data-list {
    display: flex;
    flex-direction: column;
}

.data-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    border-bottom: 1px solid var(--border-color);
}

.data-item:last-child {
    border-bottom: none;
}

.data-item-main {
    flex: 1;
    min-width: 0;
}

.data-item-title {
    font-weight: 600;
    font-size: 0.95rem;
    margin-bottom: 2px;
}

.data-item-subtitle {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.8rem;
    color: var(--text-secondary);
    flex-wrap: wrap;
}

.data-item-status {
    flex-shrink: 0;
}

.data-item-actions {
    display: flex;
    gap: 4px;
    flex-shrink: 0;
}

.data-item-actions .btn {
    padding: 6px 10px;
}

.color-dot {
    width: 20px;
    height: 20px;
    border-radius: 50%;
    flex-shrink: 0;
}

.data-item.inactive {
    opacity: 0.5;
}

/* ── Modern Card Grid ── */
.card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 16px;
    padding: 16px;
}

.card-grid-item {
    background: var(--bg-secondary);
    border-radius: 12px;
    border: 1px solid var(--border-color);
    overflow: hidden;
    transition: box-shadow 0.2s, transform 0.15s;
    display: flex;
    flex-direction: column;
}

.card-grid-item:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,0.08);
    transform: translateY(-2px);
}

.card-grid-item.inactive {
    opacity: 0.5;
}

.card-grid-accent {
    height: 4px;
    flex-shrink: 0;
}

.card-grid-body {
    padding: 16px;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.card-grid-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 8px;
}

.card-grid-title {
    font-weight: 700;
    font-size: 1rem;
    line-height: 1.3;
    color: var(--text-primary);
}

.card-grid-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}

.card-grid-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
    white-space: nowrap;
}

.card-grid-badge.blue { background: rgba(59,130,246,0.1); color: #3b82f6; }
.card-grid-badge.green { background: rgba(34,197,94,0.1); color: #16a34a; }
.card-grid-badge.red { background: rgba(239,68,68,0.1); color: #dc2626; }
.card-grid-badge.orange { background: rgba(249,115,22,0.1); color: #ea580c; }
.card-grid-badge.purple { background: rgba(168,85,247,0.1); color: #9333ea; }
.card-grid-badge.gray { background: rgba(107,114,128,0.1); color: #6b7280; }
.card-grid-badge.yellow { background: rgba(234,179,8,0.1); color: #ca8a04; }

.card-grid-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    font-size: 0.82rem;
    color: var(--text-secondary);
}

.card-grid-meta-item {
    display: flex;
    align-items: center;
    gap: 5px;
}

.card-grid-meta-item i {
    font-size: 0.85rem;
    opacity: 0.7;
}

.card-grid-price {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--primary, #1B4F8A);
}

.card-grid-footer {
    display: flex;
    gap: 6px;
    padding: 12px 16px;
    border-top: 1px solid var(--border-color);
    background: var(--bg-primary);
}

.card-grid-footer .btn {
    flex: 1;
    padding: 7px 12px;
    font-size: 0.82rem;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
}

.card-grid-filter {
    display: flex;
    gap: 10px;
    padding: 16px 16px 0;
    flex-wrap: wrap;
}

.card-grid-filter .form-select {
    width: auto;
    min-width: 150px;
    border-radius: 10px;
    font-size: 0.85rem;
    padding: 8px 12px;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    color: var(--text-primary);
}

.card-grid-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 48px 20px;
    color: var(--text-secondary);
}

.card-grid-empty i {
    font-size: 2.5rem;
    opacity: 0.4;
    display: block;
    margin-bottom: 12px;
}

/* Color preview swatch */
.color-swatch {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    flex-shrink: 0;
    border: 2px solid rgba(0,0,0,0.08);
}

@media (max-width: 576px) {
    .settings-card-header {
        padding: 12px;
        flex-wrap: wrap;
        gap: 8px;
    }

    .settings-card-header h5 {
        font-size: 0.95rem;
    }

    .data-item {
        flex-wrap: wrap;
        padding: 10px 12px;
        gap: 8px;
    }

    .data-item-main {
        flex: 1 1 100%;
    }

    .data-item-status {
        order: -1;
    }

    .data-item-actions {
        margin-left: auto;
    }

    .data-item-actions .btn {
        padding: 5px 8px;
    }

    .card-grid {
        grid-template-columns: 1fr;
        gap: 12px;
        padding: 12px;
    }

    .card-grid-filter {
        padding: 12px 12px 0;
    }
}

/* =====================================================
   UTILITIES
   ===================================================== */
.text-center { text-align: center; }
.text-end { text-align: right; }
.text-start { text-align: left; }

.text-primary { color: var(--primary) !important; }
.text-success { color: var(--success) !important; }
.text-danger { color: var(--danger) !important; }
.text-warning { color: var(--warning) !important; }
.text-info { color: var(--info) !important; }
.text-muted { color: var(--text-muted) !important; }
.text-white { color: white !important; }
.text-dark { color: var(--text-primary) !important; }

.bg-primary { background-color: var(--primary) !important; }
.bg-success { background-color: var(--success) !important; }
.bg-danger { background-color: var(--danger) !important; }
.bg-warning { background-color: var(--warning) !important; }
.bg-info { background-color: var(--info) !important; }
.bg-light { background-color: var(--bg-tertiary) !important; }
.bg-dark { background-color: var(--navbar-bg) !important; }
.bg-white { background-color: var(--bg-secondary) !important; }

.fw-bold { font-weight: 700; }
.fw-semibold { font-weight: 600; }
.fw-medium { font-weight: 500; }

.mb-0 { margin-bottom: 0 !important; }
.mb-1 { margin-bottom: 4px !important; }
.mb-2 { margin-bottom: 8px !important; }
.mb-3 { margin-bottom: 16px !important; }
.mb-4 { margin-bottom: 24px !important; }

.mt-0 { margin-top: 0 !important; }
.mt-1 { margin-top: 4px !important; }
.mt-2 { margin-top: 8px !important; }
.mt-3 { margin-top: 16px !important; }
.mt-4 { margin-top: 24px !important; }

.me-1 { margin-right: 4px; }
.me-2 { margin-right: 8px; }
.me-3 { margin-right: 16px; }

.ms-1 { margin-left: 4px; }
.ms-2 { margin-left: 8px; }
.ms-3 { margin-left: 16px; }

.p-0 { padding: 0 !important; }
.p-2 { padding: 8px !important; }
.p-3 { padding: 16px !important; }
.p-4 { padding: 24px !important; }

.py-3 { padding-top: 16px !important; padding-bottom: 16px !important; }
.py-4 { padding-top: 24px !important; padding-bottom: 24px !important; }
.py-5 { padding-top: 48px !important; padding-bottom: 48px !important; }

.px-3 { padding-left: 16px !important; padding-right: 16px !important; }
.px-2 { padding-left: 8px !important; padding-right: 8px !important; }

.py-1 { padding-top: 4px !important; padding-bottom: 4px !important; }

.display-1 { font-size: 4rem; font-weight: 300; }

.d-flex { display: flex; }
.d-grid { display: grid; }
.d-none { display: none; }
.d-block { display: block; }

/* Modal buttons grid */
.d-grid.gap-2 {
    display: grid;
    gap: 8px;
}

.d-grid .btn {
    width: 100%;
}

/* Modal buttons - flex layout */
.modal-buttons {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.modal-buttons .btn {
    width: 100%;
    padding: 12px 16px;
    font-size: 0.9375rem;
}

.flex-column { flex-direction: column; }
.align-items-center { align-items: center; }
.align-items-end { align-items: flex-end; }
.justify-content-between { justify-content: space-between; }
.justify-content-center { justify-content: center; }
.flex-wrap { flex-wrap: wrap; }

.gap-1 { gap: 4px; }
.gap-2 { gap: 8px; }
.gap-3 { gap: 16px; }

.row {
    display: flex;
    flex-wrap: wrap;
    margin: -8px;
}

.col-4, .col-6, .col-12,
.col-md-3, .col-md-4, .col-md-6, .col-md-9 {
    padding: 8px;
}

.col-4 { width: 33.333%; }
.col-6 { width: 50%; }
.col-12 { width: 100%; }

@media (min-width: 768px) {
    .col-md-3 { width: 25%; }
    .col-md-4 { width: 33.333%; }
    .col-md-6 { width: 50%; }
    .col-md-9 { width: 75%; }
}

.g-2 { margin: -4px; }
.g-2 > * { padding: 4px; }
.g-4 { margin: -12px; }
.g-4 > * { padding: 12px; }

.list-group {
    display: flex;
    flex-direction: column;
}

.list-group-item-action {
    cursor: pointer;
}

hr {
    border: none;
    border-top: 1px solid var(--border-color);
    margin: 16px 0;
}

/* =====================================================
   PAYMENT PAGE STYLES
   ===================================================== */
.payment-container {
    display: flex;
    flex-direction: column;
    gap: 12px;
    height: calc(100vh - 80px);
    height: calc(100dvh - 80px);
}

@media (min-width: 992px) {
    .payment-container {
        flex-direction: row;
    }
}

.payment-left {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 12px;
    min-height: 0;
    overflow: hidden;
}

/* payment-left mobil — pos-modern.css tarafından yönetiliyor */

@media (min-width: 992px) {
    .payment-left {
        flex: 2;
    }
}

.payment-right {
    display: flex;
    flex-direction: column;
    min-height: 0;
    overflow: hidden;
}

.payment-right .payment-card {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

@media (min-width: 992px) {
    .payment-right {
        flex: 1;
        max-width: 360px;
        flex-shrink: 0;
    }
}

/* payment-right mobil — pos-modern.css tarafından yönetiliyor */

.payment-card {
    background: var(--bg-secondary);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
}

.payment-card.mt-2 {
    flex: none;
    margin-top: 8px;
}

.payment-card.payment-main-card {
    flex: 1;
    min-height: 300px;
}

.payment-card-header {
    padding: 8px 14px;
    background: var(--bg-tertiary);
    border-bottom: 1px solid var(--border-color);
    font-weight: 600;
    font-size: 0.9rem;
}

.payment-card-header.bg-primary {
    background: var(--primary);
    color: white;
    border-bottom: none;
}

.payment-card-footer {
    padding: 12px 16px;
    background: var(--bg-tertiary);
    border-top: 1px solid var(--border-color);
}

.payment-items-list {
    flex: 1;
    overflow-y: auto;
    min-height: 0;
}

.payment-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 14px;
    border-bottom: 1px solid var(--border-light);
    cursor: pointer;
    transition: all 0.2s;
    position: relative;
}

.payment-item:hover {
    background: var(--bg-hover);
}

.payment-item.paid {
    background: var(--success-light);
    opacity: 0.7;
}

.payment-item.selected {
    background: var(--primary-light);
    border-left: 3px solid var(--primary);
}

.payment-item .item-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.payment-item .item-name {
    font-weight: 500;
    font-size: 0.875rem;
}

.payment-item .item-detail {
    font-size: 0.75rem;
    color: var(--text-muted);
}

.payment-item .item-status {
    text-align: right;
}

.payment-item .item-amount {
    font-weight: 600;
    color: var(--primary);
    display: block;
}

.payment-item .item-remaining {
    font-size: 0.75rem;
    color: var(--text-muted);
}

.payment-item .item-selected-badge {
    position: absolute;
    top: 4px;
    right: 4px;
    display: flex;
    align-items: center;
    gap: 4px;
    background: var(--primary);
    color: white;
    padding: 2px 8px;
    border-radius: var(--radius-xl);
    font-size: 0.75rem;
}

.payment-item .btn-clear {
    background: none;
    border: none;
    color: white;
    cursor: pointer;
    padding: 0;
    line-height: 1;
}

.summary-row {
    display: flex;
    justify-content: space-between;
    padding: 4px 0;
    font-size: 0.875rem;
}

.summary-row.total {
    font-size: 1.125rem;
    font-weight: 700;
    padding-top: 8px;
    margin-top: 8px;
    border-top: 1px solid var(--border-color);
}

/* Numpad */
.numpad-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 4px;
    padding: 0;
}

.numpad-btn {
    padding: 6px 4px;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    border-radius: var(--radius);
    font-size: 0.95rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    color: var(--text-primary);
}

.numpad-btn:hover {
    background: var(--bg-hover);
}

.numpad-btn.danger {
    background: var(--danger);
    color: white;
    border-color: var(--danger);
}

.numpad-btn.danger:hover {
    background: var(--danger-hover);
}

/* Quick amounts */
.quick-amounts {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 4px;
    padding: 6px 10px;
    background: var(--bg-tertiary);
    border-bottom: 1px solid var(--border-color);
}

.quick-amount-btn, .quick-btn {
    padding: 6px 12px;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    border-radius: var(--radius);
    font-size: 0.8rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
    color: var(--text-primary);
}

.quick-amount-btn:hover, .quick-btn:hover {
    background: var(--primary-light);
    border-color: var(--primary);
}

.quick-btn.warning {
    background: var(--warning);
    color: white;
    border-color: var(--warning);
}

.quick-btn.warning:hover {
    background: var(--warning-hover);
}

/* Amount Display */
.amount-display {
    padding: 16px;
    text-align: center;
    background: var(--bg-tertiary);
    border-bottom: 1px solid var(--border-color);
}

.amount-display small {
    color: var(--text-muted);
    display: block;
    margin-bottom: 4px;
}

.amount-display h2 {
    margin: 0;
    font-size: 2rem;
    color: var(--primary);
}

/* Numpad Clear */
.numpad-btn.clear {
    background: var(--danger);
    color: white;
    border-color: var(--danger);
}

.numpad-btn.clear:hover {
    background: var(--danger-hover);
}

/* Payment buttons - 4 column */
.payment-buttons {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    padding: 12px;
}

.pay-btn.debit {
    background: #8b5cf6;
}

.pay-btn.debit:hover:not(:disabled) {
    background: #7c3aed;
}

.pay-btn.meal {
    background: #f97316;
}

.pay-btn.meal:hover:not(:disabled) {
    background: #ea580c;
}

/* Action buttons */
.action-buttons {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    padding: 12px;
    border-top: 1px solid var(--border-color);
}

/* Selected items */
.selected-items-list {
    padding: 8px 12px;
}

.selected-item {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
    font-size: 0.875rem;
    border-bottom: 1px solid var(--border-light);
}

.selected-item:last-child {
    border-bottom: none;
}

/* Payments list */
.payments-list {
    padding: 8px 12px;
}

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

.payment-row:last-child {
    border-bottom: none;
}

.payment-row .btn-cancel {
    background: none;
    border: none;
    color: var(--danger);
    cursor: pointer;
    padding: 4px 8px;
    margin-left: 8px;
    border-radius: var(--radius-sm);
}

.payment-row .btn-cancel:hover {
    background: var(--danger-light);
}

/* =====================================================
   SCROLLBAR STYLING
   ===================================================== */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: var(--bg-tertiary);
}

::-webkit-scrollbar-thumb {
    background: var(--border-color);
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--text-muted);
}

/* =====================================================
   ORDER PAGE SPECIFIC STYLES
   ===================================================== */
.order-item {
    display: flex;
    flex-direction: column;
    gap: 3px;
    padding: 8px 12px;
    border-bottom: 1px solid var(--border-light);
    cursor: pointer;
    transition: background 0.15s;
}

.order-item:hover {
    background: var(--bg-hover);
}

.order-item.selected {
    background: var(--primary-light);
    border-left: 3px solid var(--primary);
}

.order-item.printed {
    border-left: 3px solid var(--success);
}

.order-item.complimentary {
    opacity: 0.7;
}

.order-item.refunded {
    background: rgba(239, 68, 68, 0.08);
}

/* Üst satır: isim (sol) + fiyat (sağ) */
.oi-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
}

.oi-name {
    font-weight: 600;
    font-size: 0.85rem;
    color: var(--text-primary);
    flex: 1;
    min-width: 0;
    text-align: left;
}

.oi-badge {
    display: inline-block;
    font-size: 0.6rem;
    padding: 1px 5px;
    border-radius: 4px;
    font-weight: 600;
    vertical-align: middle;
    margin-left: 4px;
}

.oi-badge.yeni { background: var(--success); color: white; }
.oi-badge.ikram { background: var(--info); color: white; }
.oi-badge.iade { background: var(--warning); color: #000; }

.oi-price {
    font-weight: 700;
    font-size: 0.85rem;
    color: var(--primary);
    white-space: nowrap;
}

.oi-price.strike {
    text-decoration: line-through;
    color: var(--text-muted);
}

.oi-note {
    font-size: 0.72rem;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: 4px;
}

/* Alt satır: miktar + birim fiyat (sade) */
.oi-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.oi-qty {
    display: flex;
    align-items: center;
    gap: 8px;
}

.qty-val {
    min-width: 36px;
    text-align: center;
    font-weight: 700;
    font-size: 1.1rem;
}

.oi-unit {
    font-size: 0.85rem;
    color: var(--text-secondary);
    font-weight: 500;
}

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

/* Seçili satır altında açılan geniş aksiyon paneli */
.oi-action-bar {
    display: flex;
    gap: 8px;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px dashed var(--border-color);
    animation: oi-action-fade 0.15s ease-out;
}
.oi-action {
    flex: 1;
    min-height: 52px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    padding: 8px 4px;
    border: 1px solid var(--border-color);
    background: var(--bg-card, #fff);
    border-radius: 10px;
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-secondary, #4b5563);
    -webkit-tap-highlight-color: transparent;
    transition: all 0.15s;
}
.oi-action i { font-size: 1.25rem; line-height: 1; }
.oi-action:hover { background: var(--bg-hover, #f3f4f6); }
.oi-action:active { transform: scale(0.96); }
.oi-action.move {
    color: var(--primary, #4a90e2);
    border-color: var(--primary, #4a90e2);
    background: rgba(74,144,226,0.06);
}
.oi-action.move:hover { background: rgba(74,144,226,0.14); }
.oi-action.delete {
    color: var(--danger, #dc3545);
    border-color: var(--danger, #dc3545);
    background: rgba(220,53,69,0.06);
}
.oi-action.delete:hover { background: rgba(220,53,69,0.14); }
@keyframes oi-action-fade {
    from { opacity: 0; transform: translateY(-4px); }
    to { opacity: 1; transform: translateY(0); }
}

.oi-act-btn {
    width: 46px;
    height: 46px;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    border-radius: 8px;
    cursor: pointer;
    font-size: 1.15rem;
    display: flex;
    align-items: center;
    -webkit-tap-highlight-color: transparent;
    justify-content: center;
    font-size: 0.8rem;
    color: var(--text-secondary);
    transition: all 0.15s;
}

.oi-act-btn.move:hover { color: var(--primary); border-color: var(--primary); }
.oi-act-btn.delete:hover { color: var(--danger); border-color: var(--danger); }

.item-qty {
    display: flex;
    align-items: center;
    gap: 4px;
}

.qty-btn {
    width: 46px;
    height: 46px;
    border: 1px solid var(--border-color);
    background: var(--bg-secondary);
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-weight: 700;
    font-size: 1.4rem;
    -webkit-tap-highlight-color: transparent;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
}

.qty-btn:hover {
    background: var(--bg-hover);
}

.qty-btn.minus:hover {
    background: var(--danger-light);
    border-color: var(--danger);
    color: var(--danger);
}

.qty-btn.plus:hover {
    background: var(--success-light);
    border-color: var(--success);
    color: var(--success);
}

.item-details {
    flex: 1;
    min-width: 0;
}

.item-name {
    font-weight: 500;
    font-size: 0.875rem;
}

.item-note {
    font-size: 0.75rem;
    color: var(--warning);
    font-style: italic;
}

.item-price {
    font-weight: 600;
    color: var(--primary);
    white-space: nowrap;
}

/* Order Summary */
.order-summary {
    padding: 12px 16px;
    background: var(--bg-tertiary);
    border-radius: var(--radius);
}

.total-row {
    display: flex;
    justify-content: space-between;
    padding: 4px 0;
    font-size: 0.875rem;
}

.total-row.grand-total {
    font-size: 1.25rem;
    font-weight: 700;
    padding-top: 8px;
    margin-top: 8px;
    border-top: 2px solid var(--border-color);
}

/* Order Actions */
.order-actions {
    padding: 12px 16px;
    background: var(--bg-tertiary);
    border-top: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.action-row {
    display: flex;
    gap: 8px;
}

.action-btn {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 8px;
    border: none;
    border-radius: var(--radius);
    font-size: 0.8125rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
    color: white;
    white-space: nowrap;
    overflow: hidden;
}

.action-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.action-btn.primary { background: var(--primary); }
.action-btn.primary:hover:not(:disabled) { background: var(--primary-hover); }

.action-btn.success { background: var(--success); }
.action-btn.success:hover:not(:disabled) { background: var(--success-hover); }

.action-btn.danger { background: var(--danger); }
.action-btn.danger:hover:not(:disabled) { background: var(--danger-hover); }

.action-btn.warning { background: var(--warning); }
.action-btn.warning:hover:not(:disabled) { background: var(--warning-hover); }

.action-btn.info { background: var(--info); }
.action-btn.info:hover:not(:disabled) { background: var(--info-hover); }

.action-btn.secondary { 
    background: var(--bg-secondary); 
    color: var(--text-primary);
    border: 1px solid var(--border-color);
}
.action-btn.secondary:hover:not(:disabled) { background: var(--bg-hover); }

.action-btn.dark { background: var(--navbar-bg); }
.action-btn.dark:hover:not(:disabled) { opacity: 0.9; }

/* Loading Spinner */
.loading-spinner {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 50vh;
}

.spinner-border {
    width: 48px;
    height: 48px;
    border: 4px solid var(--border-color);
    border-top-color: var(--primary);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* Cash Register Warning */
.cash-register-warning {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 60vh;
    text-align: center;
    padding: 20px;
}

.cash-register-warning .warning-icon {
    font-size: 4rem;
    margin-bottom: 16px;
}

.cash-register-warning h4 {
    margin-bottom: 8px;
    color: var(--danger);
}

.cash-register-warning p {
    color: var(--text-secondary);
    margin-bottom: 20px;
}

/* =====================================================
   PRODUCT CARD - POS Style (Referans: resim üst, isim orta, fiyat alt)
   ===================================================== */
/* Ürün kartı wrapper — favori yıldızı için relative container */
.prod-card-wrapper {
    position: relative;
    display: flex;
}
.prod-card-wrapper > .prod-card {
    flex: 1 1 auto;
    width: 100%;
}
.prod-fav-btn {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 26px;
    height: 26px;
    border: none;
    background: rgba(0,0,0,0.35);
    color: rgba(255,255,255,0.7);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.72rem;
    cursor: pointer;
    z-index: 2;
    transition: all 0.15s;
    -webkit-tap-highlight-color: transparent;
    padding: 0;
}
.prod-fav-btn:hover { background: rgba(0,0,0,0.5); color: #fff; }
.prod-fav-btn.active {
    background: rgba(236,72,153,0.2);
    color: #ec4899;
}
.prod-fav-btn.active:hover {
    background: rgba(236,72,153,0.35);
}

.prod-card {
    display: flex;
    flex-direction: column;
    border-radius: 12px;
    cursor: pointer;
    transition: all 0.15s ease;
    overflow: hidden;
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    padding: 0;
    text-align: center;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}

.prod-card:hover {
    border-color: var(--primary);
    box-shadow: 0 4px 16px rgba(0,0,0,0.12);
    transform: translateY(-2px);
}

.prod-card:active {
    transform: scale(0.97);
    box-shadow: none;
}

.prod-card.disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Resim alanı - kart genişliğinin 60%'ı */
.prod-card-img {
    width: 100%;
    aspect-ratio: 4/3;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f3f4f6;
}

.prod-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.2s;
}

.prod-card:hover .prod-card-img img {
    transform: scale(1.05);
}

/* Logo fallback */
.prod-card-img img.logo-fallback {
    width: 45%;
    height: 45%;
    object-fit: contain;
    opacity: 0.3;
}

/* İsim + Fiyat alanı */
.prod-card-body {
    padding: 8px 6px 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
}

.prod-card-name {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-primary);
    line-height: 1.2;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    word-break: break-word;
    max-width: 100%;
}

.prod-card-price {
    font-size: 0.9rem;
    font-weight: 800;
    color: var(--text-primary);
}
.prod-card-price.prod-price-discounted {
    color: #dc2626;
}
.prod-price-old {
    color: var(--text-muted);
    font-size: 0.75rem;
    font-weight: 500;
    margin-right: 3px;
}
.prod-discount-badge {
    position: absolute;
    top: 4px;
    right: 4px;
    background: #dc2626;
    color: #fff;
    font-size: 0.65rem;
    font-weight: 700;
    padding: 2px 5px;
    border-radius: 4px;
    z-index: 1;
}
.prod-card-img { position: relative; }

/* Dark mode */
.prod-card-img { background: var(--bg-tertiary); }

/* Eski prod-btn uyumluluk */
.prod-btn { display: none; }

/* Category Button Active State */
.cat-btn.active {
    color: white !important;
    border-color: transparent !important;
}

/* =====================================================
   ADDITIONAL UTILITIES
   ===================================================== */
.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.border-top { border-top: 1px solid var(--border-color); }
.border-bottom { border-bottom: 1px solid var(--border-color); }
.border-secondary { border-color: var(--border-light) !important; }

.text-decoration-line-through { text-decoration: line-through; }

.mx-2 { margin-left: 8px; margin-right: 8px; }
.mx-3 { margin-left: 16px; margin-right: 16px; }
.ms-auto { margin-left: auto; }

.pt-2 { padding-top: 8px; }
.pb-2 { padding-bottom: 8px; }

.small, small { font-size: 0.8125rem; }

h2, h3, h4, h5, h6 {
    margin: 0;
    font-weight: 600;
}

h2 { font-size: 1.5rem; }
h3 { font-size: 1.25rem; }
h4 { font-size: 1.125rem; }
h5 { font-size: 1rem; }
h6 { font-size: 0.875rem; }

strong { font-weight: 600; }

/* =====================================================
   PRINT
   ===================================================== */
@media print {
    .top-navbar, .btn, button, .theme-toggle {
        display: none !important;
    }
    body {
        background: white;
        color: black;
    }
}

/* =====================================================
   QUICK NOTE CHIPS
   ===================================================== */
.quick-notes-container {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.quick-note-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: var(--bg-tertiary);
    border: 1px solid var(--border-color);
    border-radius: var(--radius-xl);
    font-size: 0.875rem;
    color: var(--text-primary);
}

.quick-note-chip .chip-remove {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    padding: 0;
    border: none;
    background: var(--danger);
    color: white;
    border-radius: 50%;
    cursor: pointer;
    font-size: 0.7rem;
    transition: all 0.2s;
}

.quick-note-chip .chip-remove:hover {
    background: var(--danger-hover);
    transform: scale(1.1);
}

.quick-note-chip .chip-remove i {
    line-height: 1;
}

/* =====================================================
   MOBILE RESPONSIVE - KAPSAMLI DÜZELTMELER
   ===================================================== */

/* Touch cihazları için temel ayarlar */
* {
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
}

/* =====================================================
   TELEFON DİKEY (max-width: 576px)
   ===================================================== */
@media (max-width: 576px) {
    /* GENEL */
    main {
        padding: 8px !important;
    }
    
    .top-navbar {
        height: auto;
        min-height: calc(50px + env(safe-area-inset-top, 0px));
        padding: env(safe-area-inset-top, 0px) 8px 0;
        gap: 4px;
    }
    
    .navbar-brand {
        font-size: 0.9rem;
        white-space: nowrap;
    }
    
    .navbar-links {
        gap: 2px;
        flex-shrink: 0;
    }
    
    .nav-link {
        padding: 6px;
    }
    
    .nav-link i {
        font-size: 1.1rem;
    }
    
    .theme-toggle {
        padding: 6px !important;
        min-width: 32px;
    }
    
    /* MASALAR SAYFASI */
    .tables-header {
        flex-direction: column;
        gap: 10px;
        padding: 10px;
    }
    
    .tables-header h4 {
        font-size: 1.1rem;
    }
    
    .filter-buttons {
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
        width: 100%;
    }
    
    .filter-btn {
        flex: 1;
        min-width: 70px;
        padding: 8px 6px;
        font-size: 0.7rem;
    }
    
    .filter-btn .badge {
        font-size: 0.65rem;
        padding: 2px 5px;
    }
    
    .section-filters {
        display: flex;
        flex-wrap: nowrap;
        overflow-x: auto;
        gap: 6px;
        padding: 8px;
        -webkit-overflow-scrolling: touch;
    }
    
    .section-btn {
        flex-shrink: 0;
        padding: 6px 12px;
        font-size: 0.75rem;
        white-space: nowrap;
    }
    
    .tables-grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 8px !important;
        padding: 8px !important;
    }
    
    .table-card {
        padding: 10px !important;
        min-height: 90px !important;
    }
    
    .table-card .table-name {
        font-size: 0.9rem !important;
    }
    
    .table-card .table-section {
        font-size: 0.65rem !important;
    }
    
    .table-card .table-amount {
        font-size: 0.85rem !important;
    }
    
    .table-card .table-capacity,
    .table-card .table-time,
    .table-card .table-fee {
        font-size: 0.7rem !important;
    }
    
    /* HIZLI SATIŞ & SİPARİŞ - MOBİL LAYOUT (pos-modern.css tab-bar ile uyumlu) */
    .pos-container,
    .split-container {
        flex-direction: column !important;
        height: calc(100dvh - 70px) !important;
        max-height: calc(100dvh - 70px) !important;
        gap: 0 !important;
        overflow: hidden !important;
    }

    .pos-products,
    .split-left {
        flex: 1 1 0 !important;
        min-height: 0 !important;
        max-height: none !important;
        overflow: hidden !important;
    }

    .pos-right-panel,
    .split-right {
        flex: 1 1 0 !important;
        min-height: 0 !important;
        max-height: none !important;
        overflow: hidden !important;
    }
    
    /* KATEGORİ BAR */
    .category-bar {
        display: flex;
        flex-wrap: nowrap !important;
        overflow-x: auto !important;
        gap: 6px !important;
        padding: 8px !important;
        max-height: none !important;
        -webkit-overflow-scrolling: touch;
    }
    
    .cat-btn {
        flex-shrink: 0 !important;
        padding: 8px 14px !important;
        font-size: 0.8rem !important;
        white-space: nowrap !important;
    }
    
    /* ÜRÜN GRİD */
    .products-grid {
        display: grid !important;
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 6px !important;
        padding: 8px !important;
        max-height: none !important;
        overflow-y: auto !important;
    }
    
    .prod-btn {
        padding: 8px 4px !important;
        min-height: 65px !important;
    }
    
    .prod-name {
        font-size: 0.7rem !important;
        -webkit-line-clamp: 2 !important;
    }
    
    .prod-price {
        font-size: 0.8rem !important;
    }
    
    /* SEPET */
    .cart-section,
    .order-card {
        border-radius: 8px;
    }
    
    .cart-header,
    .order-header {
        padding: 10px 12px !important;
    }
    
    .cart-header h5,
    .order-header h5,
    .order-title {
        font-size: 0.9rem !important;
    }
    
    .cart-list,
    .order-items,
    .cart-items {
        flex: 1 !important;
        max-height: none !important;
        overflow-y: auto !important;
        min-height: 0 !important;
    }
    
    .cart-item,
    .order-item {
        padding: 6px 8px !important;
        font-size: 0.75rem !important;
        gap: 6px !important;
    }

    .cart-item .item-name,
    .order-item .item-name {
        font-size: 0.75rem !important;
    }

    .cart-item .item-price,
    .order-item .item-price {
        font-size: 0.7rem !important;
    }

    .qty-btn {
        width: 28px !important;
        height: 28px !important;
        font-size: 0.8rem !important;
    }

    .item-qty span {
        font-size: 0.8rem !important;
    }
    
    /* TUTAR ALANI */
    .amount-section,
    .amount-display {
        padding: 10px !important;
    }
    
    .amount-input,
    .amount-value {
        font-size: 1.5rem !important;
    }
    
    .total-display {
        font-size: 1.1rem !important;
    }
    
    /* NUMPAD */
    .numpad,
    .numpad-grid {
        display: grid !important;
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 4px !important;
        padding: 8px !important;
    }
    
    .num-btn,
    .numpad-btn {
        padding: 12px 8px !important;
        font-size: 1.1rem !important;
        min-height: 44px !important;
    }
    
    /* HIZLI TUTARLAR */
    .quick-amounts,
    .quick-btns {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 4px !important;
        padding: 6px 8px !important;
    }
    
    .quick-btn,
    .quick-btns button {
        padding: 8px 4px !important;
        font-size: 0.7rem !important;
        min-height: 36px !important;
    }
    
    /* ÖDEME BUTONLARI */
    .payment-buttons,
    .pay-btns {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 6px !important;
        padding: 8px !important;
    }
    
    .pay-btn {
        padding: 12px 8px !important;
        font-size: 0.8rem !important;
        min-height: 65px !important;
    }
    
    .pay-btn i {
        font-size: 1.1rem !important;
    }
    
    /* ACTION BUTONLAR */
    .action-buttons,
    .action-row {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 6px !important;
        padding: 8px !important;
    }
    
    .action-btn {
        flex: 1 !important;
        min-width: 80px !important;
        padding: 10px 8px !important;
        font-size: 0.75rem !important;
    }
    
    /* MODAL — mobil tam ekran, alttan açılır */
    .modal-backdrop-custom {
        padding: 0;
        align-items: flex-end;
    }

    .modal-dialog,
    .modal-dialog-custom {
        width: 100% !important;
        max-width: 100% !important;
        max-height: 90vh !important;
        border-radius: 16px 16px 0 0 !important;
        margin: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        overflow: hidden !important;
    }

    .modal-content {
        width: 100% !important;
        max-width: 100% !important;
        max-height: 90vh !important;
        border-radius: 16px 16px 0 0 !important;
        margin: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        overflow: hidden !important;
    }

    .modal-header {
        padding: 12px 14px !important;
        flex-shrink: 0 !important;
    }

    .modal-title {
        font-size: 1rem !important;
    }

    .modal-body {
        padding: 12px 14px !important;
        overflow-y: auto !important;
        flex: 1 !important;
        min-height: 0 !important;
        -webkit-overflow-scrolling: touch;
    }

    .modal-footer {
        flex-shrink: 0 !important;
    }

    .modal-body .mb-3,
    .modal-body .mb-2 {
        margin-bottom: 8px !important;
    }

    .modal-body .form-label {
        font-size: 0.8rem !important;
        margin-bottom: 2px !important;
    }

    .modal-body .form-control,
    .modal-body .form-select,
    .modal-body input,
    .modal-body select,
    .modal-body textarea {
        padding: 8px 10px !important;
        font-size: 0.85rem !important;
    }

    .modal-body .row {
        gap: 0 !important;
    }

    .modal-body .row > [class*="col-"] {
        padding: 4px 0 !important;
        width: 100% !important;
    }

    /* Fiyat alanları yan yana kalsın */
    .modal-body .row > .col-md-3 {
        width: 50% !important;
        padding: 4px 4px !important;
    }

    .modal-footer {
        padding: 10px 14px !important;
        gap: 8px;
    }

    .modal-footer .btn {
        flex: 1;
        padding: 10px 8px !important;
        font-size: 0.85rem !important;
    }
    
    /* ALERT */
    .alert {
        padding: 10px 12px;
        font-size: 0.85rem;
    }
    
    /* FORM */
    .form-control,
    .form-select {
        font-size: 16px !important; /* iOS zoom engelle */
        padding: 10px 12px;
    }
    
    /* BADGE */
    .badge {
        font-size: 0.7rem;
        padding: 3px 6px;
    }

    /* DASHBOARD */
    .dashboard-card {
        padding: 12px !important;
    }

    .dashboard-card h2,
    .dashboard-card .stat-value {
        font-size: 1.3rem !important;
    }

    .dashboard-card .stat-label,
    .dashboard-card small {
        font-size: 0.7rem !important;
    }

    .row.g-3 > [class*="col-"] {
        padding-left: 4px;
        padding-right: 4px;
    }

    .row.g-3 {
        margin-left: -4px;
        margin-right: -4px;
        row-gap: 8px !important;
    }

    .welcome-title {
        font-size: 1.2rem !important;
    }

    /* ÜRÜN KARTLARI (prod-card) — sadece POS sayfalarında */
    .products-grid .prod-card-name {
        font-size: 0.65rem !important;
    }

    .products-grid .prod-card-price {
        font-size: 0.65rem !important;
    }

    /* AYARLAR — kompakt */
    .settings-card-header {
        flex-direction: column;
        gap: 6px;
    }

    /* Ayarlar masalar/ürünler grid — tek sütun */
    .settings-page .card-grid {
        grid-template-columns: 1fr !important;
        gap: 8px !important;
    }

    /* ÖDEME SAYFASI - MOBİL SCROLL — pos-modern.css'e taşındı */

    /* KASA SAYFASI */
    .cash-register-card {
        padding: 12px !important;
    }

    .cash-register-card h5 {
        font-size: 1rem !important;
    }

    .cash-register-card .amount {
        font-size: 1.2rem !important;
    }

    /* SİPARİŞ AKSİYON BUTONLARI */
    .order-actions {
        padding: 6px 8px !important;
        gap: 4px !important;
    }

    .action-row {
        gap: 4px !important;
    }

    .action-btn {
        padding: 6px 4px !important;
        font-size: 0.65rem !important;
        gap: 3px !important;
    }

    .action-btn i {
        font-size: 0.8rem !important;
    }

    .order-summary {
        padding: 6px 10px !important;
    }

    .total-row {
        font-size: 0.8rem !important;
        padding: 2px 0 !important;
    }

    .total-row.grand-total {
        font-size: 0.95rem !important;
    }

    .order-header {
        padding: 8px 10px !important;
    }

    .order-header h5 {
        font-size: 0.9rem !important;
    }

    /* iOS ZOOM ENGELLEME */
    input[type="text"],
    input[type="number"],
    input[type="password"],
    input[type="email"],
    input[type="tel"],
    select,
    textarea {
        font-size: 16px !important; /* iOS zoom engellemek için */
    }
}

/* =====================================================
   TELEFON YATAY (landscape)
   ===================================================== */
@media (max-width: 896px) and (orientation: landscape) {
    main {
        padding: 6px !important;
    }
    
    .top-navbar {
        height: auto;
        min-height: calc(44px + env(safe-area-inset-top, 0px));
        padding-top: env(safe-area-inset-top, 0px);
    }
    
    /* YATAY LAYOUT - YAN YANA */
    .pos-container,
    .split-container {
        flex-direction: row !important;
        height: calc(100vh - 50px) !important;
        height: calc(100dvh - 50px) !important;
        gap: 8px !important;
    }
    
    .pos-products,
    .split-left {
        flex: 1 !important;
        min-width: 0 !important;
        height: 100% !important;
        max-height: none !important;
    }
    
    .pos-right-panel,
    .split-right {
        width: 280px !important;
        flex-shrink: 0 !important;
        height: 100% !important;
        max-height: none !important;
        overflow-y: auto !important;
    }
    
    .category-bar {
        max-height: 50px !important;
        padding: 6px !important;
    }
    
    .cat-btn {
        padding: 5px 10px !important;
        font-size: 0.7rem !important;
    }
    
    .products-grid {
        grid-template-columns: repeat(4, 1fr) !important;
        max-height: calc(100% - 56px) !important;
        gap: 4px !important;
    }
    
    .prod-btn {
        min-height: 65px !important;
        padding: 6px 4px !important;
    }
    
    .prod-name {
        font-size: 0.65rem !important;
    }
    
    .prod-price {
        font-size: 0.7rem !important;
    }
    
    .cart-list,
    .order-items {
        max-height: 80px !important;
    }
    
    .numpad-grid,
    .numpad {
        gap: 3px !important;
    }
    
    .num-btn,
    .numpad-btn {
        padding: 8px 4px !important;
        font-size: 0.9rem !important;
        min-height: 36px !important;
    }
    
    .quick-amounts,
    .quick-btns {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    
    .payment-buttons,
    .pay-btns {
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 4px !important;
    }
    
    .pay-btn {
        padding: 8px 4px !important;
        font-size: 0.7rem !important;
        min-height: 40px !important;
    }
    
    /* MASALAR - YATAY */
    .tables-grid {
        grid-template-columns: repeat(4, 1fr) !important;
    }
}

/* =====================================================
   TABLET DİKEY (577px - 768px)
   ===================================================== */
@media (min-width: 577px) and (max-width: 768px) {
    main {
        padding: 12px;
    }
    
    /* MASALAR */
    .tables-grid {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 10px;
    }
    
    .filter-buttons {
        gap: 8px;
    }
    
    .filter-btn {
        padding: 8px 12px;
        font-size: 0.8rem;
    }
    
    /* HIZLI SATIŞ - DİKEY LAYOUT */
    .pos-container,
    .split-container {
        flex-direction: column !important;
        height: calc(100vh - 70px) !important;
        height: calc(100dvh - 70px) !important;
    }

    .pos-products,
    .split-left {
        flex: 1 !important;
        min-height: 0 !important;
        max-height: none !important;
        overflow: hidden !important;
    }

    .pos-right-panel,
    .split-right {
        flex: 1 !important;
        min-height: 0 !important;
        max-height: none !important;
        overflow: hidden !important;
    }

    .products-grid {
        grid-template-columns: repeat(4, 1fr) !important;
    }

    .prod-btn {
        min-height: 65px !important;
    }
    
    .payment-buttons,
    .pay-btns {
        grid-template-columns: repeat(4, 1fr) !important;
    }
}

/* =====================================================
   TABLET YATAY (769px - 1024px)
   ===================================================== */
@media (min-width: 769px) and (max-width: 1024px) {
    /* MASALAR */
    .tables-grid {
        grid-template-columns: repeat(4, 1fr) !important;
    }

    /* HIZLI SATIŞ - YATAY LAYOUT (split-container için, pos-container artık grid) */
    .split-container {
        flex-direction: row !important;
        height: calc(100vh - 76px) !important;
        height: calc(100dvh - 76px) !important;
    }

    .split-left {
        flex: 1 !important;
        max-height: none !important;
    }

    .split-right {
        width: 300px !important;
        flex-shrink: 0 !important;
    }

    /* 769-1024: 3 sütun yeterli — kartlar okunabilir kalır */
    .products-grid {
        grid-template-columns: repeat(3, 1fr) !important;
    }

    .cart-list,
    .order-items {
        max-height: none !important;
        flex: 1 1 auto !important;
        min-height: 0 !important;
        overflow-y: auto !important;
    }
}

/* =====================================================
   BÜYÜK EKRAN (1025px+)
   ===================================================== */
@media (min-width: 1025px) {
    .tables-grid {
        grid-template-columns: repeat(5, 1fr) !important;
    }

    /* pos-container artık grid ile yönetiliyor, sadece split-container burada */
    .split-container {
        flex-direction: row !important;
        height: calc(100vh - 76px) !important;
        height: calc(100dvh - 76px) !important;
    }

    .split-left {
        flex: 1 !important;
    }

    .split-right {
        width: 340px !important;
    }

    /* Ödeme sayfası */
    .payment-container {
        flex-direction: row !important;
        height: calc(100vh - 76px) !important;
        overflow: hidden !important;
    }

    .payment-right {
        max-width: 340px !important;
        overflow: hidden !important;
    }

    .payment-right .payment-card {
        overflow: hidden !important;
    }
}

/* =====================================================
   TOUCH-FRIENDLY IMPROVEMENTS
   ===================================================== */
@media (hover: none) and (pointer: coarse) {
    /* Touch cihazlar için daha büyük tıklama alanları */
    .btn {
        min-height: 44px;
    }
    
    .table-card {
        min-height: 80px;
    }
    
    .cat-btn,
    .section-btn,
    .filter-btn {
        min-height: 40px;
    }
    
    .prod-btn {
        min-height: 70px;
    }
    
    .num-btn,
    .numpad-btn {
        min-height: 48px;
    }
    
    .pay-btn {
        min-height: 52px;
    }
    
    /* Hover efektlerini kaldır */
    .btn:hover,
    .table-card:hover,
    .prod-btn:hover,
    .prod-card:hover {
        transform: none;
        box-shadow: none;
    }

    /* Active state ekle */
    .btn:active,
    .table-card:active,
    .prod-btn:active,
    .prod-card:active {
        opacity: 0.8;
        transform: scale(0.97);
    }

    /* Scrollbar gizle (mobilde gereksiz) */
    ::-webkit-scrollbar {
        width: 3px;
        height: 3px;
    }
    ::-webkit-scrollbar-thumb {
        background: rgba(0,0,0,0.15);
        border-radius: 3px;
    }
}

/* =====================================================
   IMAGE UPLOAD COMPONENT
   ===================================================== */
.image-upload-area {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.image-preview {
    position: relative;
    width: 64px;
    height: 64px;
    flex-shrink: 0;
}

.image-preview img {
    width: 100%;
    height: 100%;
    border-radius: var(--radius-md, 10px);
    object-fit: cover;
    border: 2px solid var(--border-color, #e5e7eb);
}

.image-remove-btn {
    position: absolute;
    top: -6px;
    right: -6px;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: var(--danger, #ef4444);
    color: white;
    border: 2px solid var(--bg-primary, white);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.6rem;
    cursor: pointer;
    padding: 0;
    transition: transform 0.15s;
}

.image-remove-btn:hover { transform: scale(1.15); }

.image-upload-btn {
    position: relative;
    overflow: hidden;
}

.image-file-input,
.image-upload-btn input[type="file"] {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
    z-index: 2;
    width: 100%;
    height: 100%;
}

.image-upload-placeholder {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border: 2px dashed var(--border-color, #d1d5db);
    border-radius: var(--radius-md, 10px);
    color: var(--text-secondary, #6b7280);
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    background: var(--bg-secondary, #f8fafc);
}

.image-upload-btn:hover .image-upload-placeholder {
    border-color: var(--primary, #3b82f6);
    color: var(--primary, #3b82f6);
    background: var(--primary-light, #eff6ff);
}

.image-upload-placeholder i { font-size: 1.1rem; }

.image-upload-area small {
    width: 100%;
    display: block;
    margin-top: 2px;
}

/* =====================================================
   ALLERGEN CHIPS
   ===================================================== */
.allergen-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.allergen-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 6px 14px;
    border-radius: 20px;
    border: 2px solid var(--border-color, #d1d5db);
    background: var(--bg-primary, white);
    color: var(--text-secondary, #6b7280);
    font-size: 0.8rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    font-family: inherit;
}

.allergen-chip:hover {
    border-color: #f59e0b;
    color: #d97706;
}

.allergen-chip.selected {
    background: rgba(249,115,22,0.1);
    border-color: #f59e0b;
    color: #c2410c;
}

.allergen-chip i {
    font-size: 0.85rem;
}

.allergen-chip.selected i {
    color: #f59e0b;
}

/* İçerik Uyarı Toggle Butonları */
.warn-toggle {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border: 2px solid var(--border-color);
    border-radius: var(--radius);
    background: var(--bg-secondary);
    color: var(--text-secondary);
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s;
    width: 100%;
}

.warn-toggle:hover {
    border-color: var(--text-secondary);
}

.warn-toggle.active.danger {
    background: #fef2f2;
    border-color: #ef4444;
    color: #dc2626;
    font-weight: 600;
}

.warn-toggle.active.danger i {
    color: #ef4444;
}

[data-theme="dark"] .warn-toggle.active.danger {
    background: rgba(239,68,68,0.15);
    border-color: #ef4444;
    color: #f87171;
}

/* ═══════════════════════════════════════════════════════════════
   POS PAGES — RESPONSIVE REDESIGN v2
   OrderPage / QuickSale / PaymentPage için mobil tab + masaüstü polish
   ═══════════════════════════════════════════════════════════════ */

/* ─── Mobil Tab Bar ─── */
/* Varsayılan: gizli (masaüstünde split-view zaten her şeyi gösteriyor) */
.mobile-tab-bar {
    display: none;
}

.mt-tab {
    flex: 1;
    min-height: 56px;
    border: none;
    background: var(--bg-card, #fff);
    color: var(--text-secondary, #6b7280);
    font-size: 0.95rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    cursor: pointer;
    position: relative;
    border-bottom: 3px solid transparent;
    -webkit-tap-highlight-color: transparent;
    transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.mt-tab i { font-size: 1.2rem; }
.mt-tab.active {
    color: var(--primary, #4a90e2);
    border-bottom-color: var(--primary, #4a90e2);
    background: rgba(74,144,226,0.06);
}
.mt-tab:active { transform: scale(0.98); }
.mt-badge {
    background: var(--danger, #dc3545);
    color: #fff;
    border-radius: 999px;
    padding: 2px 8px;
    font-size: 0.72rem;
    font-weight: 700;
    min-width: 22px;
    text-align: center;
}
.mt-badge.primary { background: var(--primary, #4a90e2); }

/* ─── Mobil tab switcher — pos-modern.css'e taşındı ─── */

/* ─── Mobil kategori/view toggle — pos-modern.css'e taşındı ─── */

/* ─── Sticky alt action bar — pos-modern.css'e taşındı ─── */

/* ─── Masaüstü polishing — daha okunaklı sepet/adisyon ─── */
@media (min-width: 992px) {
    /* OrderPage: sağ panel zaten 460-580px arası genişlik var */
    .order-item { padding: 14px 16px; }
    .oi-name { font-size: 1rem; font-weight: 600; }
    .oi-price { font-size: 1.05rem; font-weight: 700; }
}

/* ─── Header bar (masa adı / ticket / süre) — daha temiz görünüm ─── */
.order-header-info {
    padding: 16px 18px !important;
    background: linear-gradient(135deg, var(--primary, #4a90e2), var(--primary-dark, #357abd)) !important;
    color: #fff !important;
}
.order-header-info h5 { font-size: 1.2rem !important; margin: 0 !important; font-weight: 700 !important; }
.order-header-info small { opacity: 0.88; font-family: monospace; font-size: 0.78rem; }

/* ─── Ürün kartlarını biraz büyüt (touch friendly) — 1400+ için ─── */
@media (min-width: 1400px) {
    .prod-card {
        min-height: 130px;
        border-radius: 12px !important;
    }
    .prod-card-img { height: 64px !important; }
    .prod-card-name { font-size: 0.82rem !important; font-weight: 600 !important; line-height: 1.2; }
    .prod-card-price { font-size: 0.88rem !important; font-weight: 700 !important; }
}

/* ─── Mobil daha küçük (<576px) ─── */
@media (max-width: 575px) {
    .mt-tab { font-size: 0.85rem; min-height: 50px; }
    .mt-tab i { font-size: 1.1rem; }
    .prod-card { min-height: 110px; }
    .prod-card-name { font-size: 0.85rem !important; }
    .prod-card-price { font-size: 0.92rem !important; }
    .products-grid { padding: 8px !important; gap: 6px !important; }
    .order-header-info { padding: 12px 14px !important; }
    .order-header-info h5 { font-size: 1.05rem !important; }
}

/* ═══════════════════════════════════════════════════════════════
   KRİTİK BUTONLAR HER ZAMAN GÖRÜNÜR — flex-shrink garantisi
   Cart çok uzun olsa veya numpad açılsa bile Ödeme/Yazdır butonları kaybolmasın
   ═══════════════════════════════════════════════════════════════ */

/* OrderPage sağ panel */
.split-right {
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
}
.split-right .order-header-info,
.split-right .order-summary,
.split-right .order-actions {
    flex-shrink: 0 !important;
}
.split-right .cart-items {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
}

/* QuickSale sağ panel */
.pos-right-panel {
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    overflow: hidden !important;
}
.pos-right-panel .cart-section {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow: hidden !important;
}
.pos-right-panel .cart-tabs,
.pos-right-panel .cart-header,
.pos-right-panel .cart-summary,
.pos-right-panel .pending-payments {
    flex-shrink: 0 !important;
}
.pos-right-panel .cart-items {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
}
.pos-right-panel .payment-section {
    flex-shrink: 0 !important;
    border-top: 1px solid var(--border-color, #e5e7eb);
    background: var(--bg-card, #fff);
    box-shadow: 0 -4px 12px rgba(0,0,0,0.04);
}

/* ─── split-container kaldırıldı (kullanılmıyor) ─── */

/* ─── OrderPage Ödeme butonunu BÜYÜK ve belirgin yap ─── */
.order-actions .action-btn.success {
    min-height: 56px;
    font-size: 1.05rem;
    font-weight: 700;
}
.order-actions .action-btn {
    min-height: 48px;
    font-size: 0.92rem;
}

/* ═══════════════════════════════════════════════════════════════
   MOBİL MODERN REDESIGN — Profesyonel POS görünümü
   ═══════════════════════════════════════════════════════════════ */

/* Floating bottom cart button — varsayılan: gizli */
.fab-cart {
    display: none;
}

/* ─── Sadece mobilde aktif ─── */
@media (max-width: 991px) {
    /* Ürün kartlarını yeniden tasarla: 2 sütun, büyük, görsel ağırlıklı */
    .products-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
        padding: 14px !important;
        max-height: none !important;
    }

    .prod-card {
        min-height: 150px !important;
        border-radius: 14px !important;
        padding: 12px 10px 14px !important;
        background: var(--bg-card, #fff) !important;
        border: 1px solid var(--border-color, #e5e7eb) !important;
        box-shadow: 0 2px 4px rgba(0,0,0,0.04) !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 8px !important;
        transition: transform 0.1s, box-shadow 0.15s !important;
    }
    .prod-card:active {
        transform: scale(0.96) !important;
        box-shadow: 0 1px 2px rgba(0,0,0,0.08) !important;
    }
    .prod-card-img {
        flex: 1;
        min-height: 70px;
        max-height: 90px;
        border-radius: 10px;
        background: var(--bg-secondary, #f3f4f6);
        overflow: hidden;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .prod-card-img img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .prod-card-img img.logo-fallback {
        width: 50%;
        height: 50%;
        object-fit: contain;
        opacity: 0.35;
    }
    .prod-card-body {
        display: flex;
        flex-direction: column;
        gap: 4px;
        align-items: flex-start;
        text-align: left;
    }
    .prod-card-name {
        font-size: 0.92rem !important;
        font-weight: 600 !important;
        line-height: 1.2 !important;
        color: var(--text-primary, #1f2937) !important;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }
    .prod-card-price {
        font-size: 1rem !important;
        font-weight: 700 !important;
        color: var(--primary, #4a90e2) !important;
    }

    /* Floating cart button — alttan slide-up, full-width */
    .fab-cart {
        display: flex;
        position: fixed;
        bottom: calc(12px + env(safe-area-inset-bottom, 0px));
        left: 12px;
        right: 12px;
        z-index: 100;
        align-items: center;
        justify-content: space-between;
        gap: 12px;
        padding: 14px 18px;
        min-height: 60px;
        background: linear-gradient(135deg, var(--primary, #4a90e2), var(--primary-dark, #357abd));
        color: #fff;
        border: none;
        border-radius: 14px;
        box-shadow: 0 6px 20px rgba(74,144,226,0.4);
        font-size: 1rem;
        font-weight: 700;
        cursor: pointer;
        -webkit-tap-highlight-color: transparent;
        animation: fab-slide-up 0.25s ease-out;
    }
    .fab-cart:active { transform: scale(0.98); }
    .fab-cart-left, .fab-cart-right {
        display: flex; align-items: center; gap: 10px;
    }
    .fab-cart-count {
        background: rgba(255,255,255,0.25);
        padding: 4px 10px;
        border-radius: 999px;
        font-size: 0.85rem;
        font-weight: 700;
        min-width: 32px;
        text-align: center;
    }
    .fab-cart-right strong { font-size: 1.15rem; }
    .fab-cart-right i { font-size: 1.2rem; }
    @keyframes fab-slide-up {
        from { transform: translateY(80px); opacity: 0; }
        to { transform: translateY(0); opacity: 1; }
    }

    /* Sepet/Adisyon görünümünde FAB gizli — pos-modern.css'e taşındı */

    /* Kategori barını sıkıştır */
    .category-bar-wrapper {
        padding: 6px 8px !important;
        background: var(--bg-card, #fff) !important;
        border-bottom: 1px solid var(--border-color, #e5e7eb) !important;
    }
    .cat-btn {
        padding: 8px 14px !important;
        font-size: 0.88rem !important;
        font-weight: 600 !important;
        border-radius: 999px !important;
        min-height: 38px !important;
        white-space: nowrap !important;
    }
    .cat-arrow {
        min-width: 32px !important;
        min-height: 38px !important;
    }

    /* Adisyon header'ı kompakt */
    .order-header-info {
        padding: 12px 14px !important;
    }
    .order-header-info h5 {
        font-size: 1rem !important;
    }

    /* Cart items: daha rahat */
    .cart-items {
        padding: 8px !important;
    }
}

/* ─── Çok küçük mobil (<480px) ─── */
@media (max-width: 480px) {
    .products-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 10px !important;
        padding: 10px !important;
        max-height: none !important;
    }
    .prod-card { min-height: 135px !important; padding: 10px 8px 12px !important; }
    .prod-card-img { min-height: 60px; max-height: 75px; }
    .prod-card-name { font-size: 0.85rem !important; }
    .prod-card-price { font-size: 0.95rem !important; }
    .fab-cart { padding: 12px 14px; min-height: 56px; font-size: 0.92rem; }
    .fab-cart-right strong { font-size: 1.05rem; }
}

/* ═══════════════════════════════════════════════════════════════
   GURME BISTRO PATTERN — Dikey kategori sidebar + ürün grid + adisyon
   Modern restaurant POS layout — tüm cihazlarda aynı mantık
   ═══════════════════════════════════════════════════════════════ */

/* split-left: yatay column → row (sol kategori şeridi | ürünler)
   NOT: .pos-products (QuickSale) KAPSANMIYOR — orada kategori bar üstte yatay kalır */
.split-left {
    flex-direction: row !important;
    overflow: hidden !important;
    background: var(--bg-card, #fff) !important;
}
.pos-products {
    flex-direction: column !important; /* QuickSale: kategori üstte yatay, ürünler altta */
    overflow: hidden !important;
    background: var(--bg-card, #fff) !important;
}

/* Kategori şeridi DİKEY sol sidebar haline gelir */
.category-bar-wrapper {
    flex-direction: column !important;
    width: 120px !important;
    min-width: 120px !important;
    max-width: 120px !important;
    flex-shrink: 0 !important;
    background: var(--bg-secondary, #f8f9fa) !important;
    border-right: 1px solid var(--border-color, #e5e7eb) !important;
    padding: 10px 8px !important;
    overflow: hidden !important;
    border-bottom: none !important;
    border-radius: 0 !important;
}
.category-bar {
    flex-direction: column !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    flex: 1 !important;
    gap: 8px !important;
    padding: 0 !important;
    background: transparent !important;
    margin: 0 !important;
    width: 100% !important;
}
.category-bar::-webkit-scrollbar { width: 4px; }
.category-bar::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.15); border-radius: 2px; }

/* Yatay scroll okları gizli — dikey scroll yetiyor */
.cat-arrow { display: none !important; }

/* Kategori butonları: dikey icon-üstte, label-altta */
.cat-btn {
    width: 100% !important;
    min-height: 70px !important;
    border-radius: 12px !important;
    background: var(--bg-card, #fff) !important;
    border: 2px solid transparent !important;
    color: var(--text-primary, #1f2937) !important;
    font-size: 0.78rem !important;
    font-weight: 600 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
    padding: 8px 4px !important;
    text-align: center !important;
    line-height: 1.2 !important;
    word-break: break-word !important;
    cursor: pointer !important;
    transition: all 0.15s !important;
    -webkit-tap-highlight-color: transparent !important;
    box-shadow: 0 1px 2px rgba(0,0,0,0.04) !important;
}
.cat-btn:hover {
    background: var(--bg-hover, #f3f4f6) !important;
    transform: translateY(-1px);
}
.cat-btn:active { transform: scale(0.97); }
.cat-btn.active {
    color: #fff !important;
    border-color: rgba(0,0,0,0.1) !important;
    box-shadow: 0 4px 12px rgba(74,144,226,0.35) !important;
    transform: none !important;
}

/* Products grid — kompakt, çok ürün gözüksün */
.products-grid {
    flex: 1 !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 8px !important;
    padding: 10px !important;
    overflow-y: auto !important;
    align-content: start !important;
    background: var(--bg-card, #fff) !important;
    border-radius: 0 !important;
    grid-auto-rows: min-content !important;
}
/* 1200+ → 4 sütun, 1600+ → 5, 1800+ → 6 (aşağıda override'lar var) */

/* Ürün kartı: kompakt, dense — modern POS style */
.prod-card {
    display: flex !important;
    flex-direction: column !important;
    background: var(--bg-card, #fff) !important;
    border: 1px solid var(--border-color, #e5e7eb) !important;
    border-radius: 10px !important;
    overflow: hidden !important;
    padding: 0 !important;
    min-height: 0 !important;
    cursor: pointer !important;
    transition: transform 0.1s, border-color 0.15s, box-shadow 0.15s !important;
    -webkit-tap-highlight-color: transparent !important;
    box-shadow: 0 1px 2px rgba(0,0,0,0.04) !important;
}
.prod-card:hover {
    border-color: var(--primary, #4a90e2) !important;
    box-shadow: 0 2px 6px rgba(0,0,0,0.08) !important;
}
.prod-card:active { transform: scale(0.96); }
.prod-card-img {
    flex: 0 0 auto !important;
    height: 50px !important;
    background: var(--bg-secondary, #f3f4f6) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
    padding: 0 !important;
}
.prod-card-img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}
.prod-card-img img.logo-fallback {
    width: 40% !important;
    height: 40% !important;
    object-fit: contain !important;
    opacity: 0.25 !important;
}
.prod-card-body {
    flex: 1 !important;
    padding: 6px 8px 8px !important;
    background: var(--bg-card, #fff) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    text-align: left !important;
    gap: 2px !important;
    justify-content: space-between !important;
}
.prod-card-name {
    font-size: 0.75rem !important;
    font-weight: 600 !important;
    color: var(--text-primary, #1f2937) !important;
    line-height: 1.25 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    word-break: break-word !important;
    white-space: normal !important;
    min-height: 2em !important;
}
.prod-card-price {
    font-size: 0.78rem !important;
    font-weight: 700 !important;
    color: var(--primary, #4a90e2) !important;
}

/* ─── Desktop (1200+): 4 sütun ─── */
@media (min-width: 1200px) {
    .products-grid { grid-template-columns: repeat(4, 1fr) !important; }
}
/* ─── Geniş ekran: 5-6 sütun ─── */
@media (min-width: 1600px) {
    .products-grid { grid-template-columns: repeat(5, 1fr) !important; }
}
@media (min-width: 1800px) {
    .products-grid { grid-template-columns: repeat(6, 1fr) !important; }
}

/* ─── Tablet dar (640-768px): 4 sütun, kategori daralt ─── */
@media (max-width: 768px) and (min-width: 640px) {
    .category-bar-wrapper {
        width: 84px !important;
        min-width: 84px !important;
        max-width: 84px !important;
        padding: 6px 5px !important;
    }
    .cat-btn { font-size: 0.7rem !important; min-height: 52px !important; }
    .products-grid { grid-template-columns: repeat(4, 1fr) !important; gap: 7px !important; padding: 8px !important; }
}

/* ─── Mobil (<640px): 2 sütun, kartlar viewport'u dolduracak şekilde ─── */
@media (max-width: 639px) {
    .category-bar-wrapper {
        width: 70px !important;
        min-width: 70px !important;
        max-width: 70px !important;
        padding: 6px 4px !important;
    }
    .cat-btn {
        font-size: 0.65rem !important;
        min-height: 50px !important;
        border-radius: 8px !important;
        padding: 5px 2px !important;
        gap: 2px !important;
    }
    .ml-products,
    .pos-products {
        display: flex !important;
        flex-direction: column !important;
        flex: 1 1 0 !important;
        min-height: 0 !important;
        height: 100% !important;
    }
    /* Grid — tab-bar ile uyumlu, flex parent'tan yükseklik alır */
    .products-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 10px !important;
        padding: 10px !important;
        align-content: start !important;
        flex: 1 1 0 !important;
        min-height: 0 !important;
        max-height: none !important;
        height: auto !important;
        overflow-y: auto !important;
    }
    .prod-card {
        min-height: 155px !important;
        border-radius: 12px !important;
        height: 100% !important;
        display: flex !important;
        flex-direction: column !important;
    }
    .prod-card-img {
        flex: 1 1 auto !important;
        min-height: 85px !important;
        height: auto !important;
    }
    .prod-card-body {
        flex: 0 0 auto !important;
        padding: 10px 12px 12px !important;
    }
    .prod-card-name { font-size: 0.92rem !important; line-height: 1.25 !important; font-weight: 700 !important; }
    .prod-card-price { font-size: 1.05rem !important; font-weight: 800 !important; }
}

/* ─── Tablet dar / orta telefon (480-640px): 3 sütun olabilir, kompakt ─── */
@media (min-width: 480px) and (max-width: 639px) {
    .products-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        grid-auto-rows: minmax(175px, 1fr) !important;
    }
    .prod-card { min-height: 175px !important; }
    .prod-card-img { height: 105px !important; flex: 0 0 105px !important; }
}

/* ─── Çok dar (<360px): 2 sütun, biraz küçült ─── */
@media (max-width: 359px) {
    .products-grid {
        gap: 8px !important;
        padding: 8px !important;
        grid-auto-rows: minmax(140px, 1fr) !important;
    }
    .prod-card { min-height: 140px !important; }
    .prod-card-img { height: 80px !important; flex: 0 0 80px !important; }
    .prod-card-name { font-size: 0.82rem !important; }
}

/* ─── Çok dar (<340px): kategori daha dar ─── */
@media (max-width: 340px) {
    .category-bar-wrapper { width: 60px !important; min-width: 60px !important; max-width: 60px !important; }
    .cat-btn { font-size: 0.58rem !important; min-height: 46px !important; }
}

/* ═══════════════════════════════════════════════════════════════
   SAĞ PANEL — daha geniş, modern POS aksiyonları
   ═══════════════════════════════════════════════════════════════ */

/* Sağ panel daha geniş — adisyon ve butonlar rahat */
@media (min-width: 992px) {
    .split-right { width: 480px !important; }
}
@media (min-width: 1200px) {
    .split-right { width: 540px !important; }
}
@media (min-width: 1600px) {
    .split-right { width: 600px !important; }
}

/* Order actions container */
.order-actions {
    padding: 10px 12px !important;
    background: var(--bg-secondary, #f8f9fa) !important;
    border-top: 1px solid var(--border-color, #e5e7eb) !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
}

/* Selection chip'ler — sadece bir ürün seçiliyken üstte görünür */
.action-chips {
    display: flex;
    gap: 6px;
    padding: 8px;
    background: rgba(74,144,226,0.08);
    border-radius: 10px;
    animation: chip-fade 0.15s ease-out;
    overflow-x: auto;
}
@keyframes chip-fade {
    from { opacity: 0; transform: translateY(-4px); }
    to { opacity: 1; transform: translateY(0); }
}
.chip-btn {
    flex: 1;
    min-height: 38px;
    border: 1px solid var(--border-color, #e5e7eb);
    background: var(--bg-card, #fff);
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    padding: 6px 4px;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-secondary, #4b5563);
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    transition: all 0.12s;
    white-space: nowrap;
}
.chip-btn i { font-size: 0.92rem; line-height: 1; }
.chip-btn:hover:not(:disabled) { background: var(--bg-hover, #f3f4f6); }
.chip-btn:active:not(:disabled) { transform: scale(0.96); }
.chip-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.chip-btn.info { color: #0891b2; border-color: #0891b2; }
.chip-btn.info:hover:not(:disabled) { background: rgba(8,145,178,0.08); }
.chip-btn.warning { color: #d97706; border-color: #d97706; }
.chip-btn.warning:hover:not(:disabled) { background: rgba(217,119,6,0.08); }
.chip-btn.primary { color: var(--primary, #4a90e2); border-color: var(--primary, #4a90e2); }
.chip-btn.primary:hover:not(:disabled) { background: rgba(74,144,226,0.08); }

/* Secondary row: Yazdır + İndirim (outline ikincil görünüm) */
.action-row.secondary-row {
    display: flex;
    gap: 8px;
}
.action-row.secondary-row .action-btn {
    flex: 1;
    min-height: 38px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    border-radius: 8px !important;
    border: 1.5px solid var(--border-color, #e5e7eb) !important;
    background: var(--bg-card, #fff) !important;
    color: var(--text-primary, #1f2937) !important;
}
.action-btn.outline-primary {
    color: var(--primary, #4a90e2) !important;
    border-color: var(--primary, #4a90e2) !important;
}
.action-btn.outline-primary:hover:not(:disabled) { background: rgba(74,144,226,0.08) !important; }
.action-btn.outline-danger {
    color: var(--danger, #dc3545) !important;
    border-color: var(--danger, #dc3545) !important;
}
.action-btn.outline-danger:hover:not(:disabled) { background: rgba(220,53,69,0.08) !important; }
.action-btn.outline-dark {
    color: var(--text-secondary, #4b5563) !important;
    border-color: var(--text-secondary, #4b5563) !important;
}

/* Primary row: Masalar (geri ikonu) + ÖDEME (dominant) */
.action-row.primary-row {
    display: flex;
    gap: 8px;
    align-items: stretch;
}
.action-row.primary-row .back-btn {
    flex: 0 0 48px !important;
    min-height: 52px !important;
    font-size: 1.1rem !important;
    border-radius: 10px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}
.action-row.primary-row .pay-cta {
    flex: 1 !important;
    min-height: 52px !important;
    border-radius: 10px !important;
    background: linear-gradient(135deg, #10b981, #059669) !important;
    border: none !important;
    color: #fff !important;
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    padding: 0 10px !important;
    box-shadow: 0 4px 14px rgba(16,185,129,0.4) !important;
    transition: transform 0.1s, box-shadow 0.15s !important;
}
.action-row.primary-row .pay-cta:hover:not(:disabled) {
    box-shadow: 0 6px 20px rgba(16,185,129,0.55) !important;
}
.action-row.primary-row .pay-cta:active:not(:disabled) { transform: scale(0.98) !important; }
.action-row.primary-row .pay-cta i { font-size: 1.2rem; }
.action-row.primary-row .pay-cta span { letter-spacing: 0.05em; }
.action-row.primary-row .pay-cta strong {
    margin-left: auto;
    font-size: 1rem;
    font-weight: 800;
    background: rgba(255,255,255,0.2);
    padding: 3px 8px;
    border-radius: 8px;
}

/* ─── Sepet satırı (.order-item) — kompakt, qty controls daha modern ─── */
.cart-items {
    padding: 8px !important;
    background: var(--bg-secondary, #f8f9fa) !important;
}
.order-item {
    background: var(--bg-card, #fff) !important;
    border: 1px solid transparent !important;
    border-radius: 10px !important;
    margin-bottom: 6px !important;
    padding: 10px 12px !important;
    cursor: pointer !important;
    transition: border-color 0.15s, box-shadow 0.15s, background 0.15s !important;
}
.order-item.selected {
    border-color: var(--primary, #4a90e2) !important;
    background: rgba(74,144,226,0.04) !important;
    box-shadow: 0 2px 8px rgba(74,144,226,0.15) !important;
}
.order-item.printed { background: var(--bg-card, #fff) !important; }
.order-item.complimentary { background: rgba(8,145,178,0.06) !important; }
.order-item.refunded { background: rgba(220,53,69,0.06) !important; opacity: 0.7; }

/* Quantity butonları — yumuşak yuvarlak gri */
.qty-btn {
    width: 38px !important;
    height: 38px !important;
    border: none !important;
    background: var(--bg-secondary, #f1f3f5) !important;
    color: var(--text-primary, #1f2937) !important;
    border-radius: 10px !important;
    font-size: 1.2rem !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    -webkit-tap-highlight-color: transparent !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background 0.12s, transform 0.1s !important;
}
.qty-btn:hover:not(:disabled) { background: var(--bg-hover, #e5e7eb) !important; }
.qty-btn:active:not(:disabled) { transform: scale(0.92); }
.qty-btn.minus:hover:not(:disabled) {
    background: rgba(220,53,69,0.1) !important;
    color: var(--danger, #dc3545) !important;
}
.qty-btn.plus:hover:not(:disabled) {
    background: rgba(16,185,129,0.1) !important;
    color: #10b981 !important;
}
.qty-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.qty-val {
    min-width: 32px !important;
    font-size: 1.05rem !important;
    font-weight: 700 !important;
    text-align: center !important;
    color: var(--text-primary, #1f2937) !important;
}
.oi-qty {
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
    background: transparent !important;
}
.oi-bottom {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 12px !important;
}
.oi-unit {
    font-size: 0.85rem !important;
    color: var(--text-secondary, #6b7280) !important;
    font-weight: 500 !important;
}
.oi-name {
    font-size: 0.98rem !important;
    font-weight: 600 !important;
    color: var(--text-primary, #1f2937) !important;
}
.oi-price {
    font-size: 1.05rem !important;
    font-weight: 700 !important;
    color: var(--text-primary, #1f2937) !important;
}

/* TOPLAM özet kartı daha vurgulu */
.order-summary {
    background: var(--bg-card, #fff) !important;
    border-radius: 10px !important;
    padding: 8px 10px !important;
    margin: 4px 8px 0 !important;
    border: 1px solid var(--border-color, #e5e7eb) !important;
}
.total-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 2px 0;
    font-size: 0.82rem;
}
.total-row.grand-total {
    border-top: 1px solid var(--border-color, #e5e7eb);
    padding-top: 6px;
    margin-top: 4px;
    font-size: 1.1rem !important;
    font-weight: 800 !important;
    color: var(--primary, #4a90e2);
}

/* ─── Mobil: chip'ler daha kompakt, ödeme CTA dominant kalır ─── */
@media (max-width: 991px) {
    .action-chips { padding: 6px; }
    .chip-btn { font-size: 0.72rem; min-height: 38px; }
    .chip-btn i { font-size: 0.88rem; }
    .action-row.primary-row .pay-cta { font-size: 0.92rem !important; min-height: 48px !important; }
    .action-row.primary-row .back-btn { flex: 0 0 44px !important; min-height: 48px !important; }
    .action-row.primary-row .pay-cta strong { font-size: 0.95rem; }
}
/* ─── 1400px+: Order page action area restore ─── */
@media (min-width: 1400px) {
    .chip-btn { min-height: 48px; border-radius: 10px; }
    .chip-btn i { font-size: 1.1rem; }
    .action-row.secondary-row .action-btn { min-height: 46px !important; font-size: 0.92rem !important; border-radius: 10px !important; }
    .action-row.primary-row .back-btn { flex: 0 0 64px !important; min-height: 72px !important; font-size: 1.4rem !important; border-radius: 12px !important; }
    .action-row.primary-row .pay-cta { min-height: 72px !important; font-size: 1.1rem !important; border-radius: 12px !important; gap: 12px !important; padding: 0 16px !important; }
    .action-row.primary-row .pay-cta i { font-size: 1.6rem; }
    .action-row.primary-row .pay-cta strong { font-size: 1.25rem; padding: 4px 12px; }
    .order-summary { padding: 12px 14px !important; margin: 4px 12px 0 !important; border-radius: 12px !important; }
    .total-row { font-size: 0.92rem; padding: 3px 0; }
    .total-row.grand-total { font-size: 1.3rem !important; padding-top: 8px; margin-top: 6px; }
    .order-summary-row { font-size: 0.875rem; }
    .order-summary-row.total { font-size: 1.125rem; }
    .action-buttons { gap: 10px; padding: 12px 16px; }
}

/* ═══════════════════════════════════════════════════════════════
   MENULUX-STYLE 4-COLUMN LAYOUT
   [ Actions | Cart | Products | Categories ]
   ═══════════════════════════════════════════════════════════════ */

.ml-shell {
    display: grid;
    grid-template-columns: 92px 320px 1fr 140px;
    height: calc(100vh - 70px);
    height: calc(100dvh - 70px);
    background: var(--bg-secondary, #f3f4f6);
    overflow: hidden;
    gap: 0;
}

/* ─── Sol aksiyon şeridi ─── */
.ml-actions {
    background: linear-gradient(180deg, #2d1b4e, #1a0f2e);
    padding: 12px 8px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    overflow-y: auto;
    overflow-x: hidden;
}
.ml-actions::-webkit-scrollbar { width: 4px; }
.ml-actions::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.2); border-radius: 2px; }
.ml-act {
    width: 100%;
    min-height: 64px;
    background: transparent;
    color: rgba(255,255,255,0.82);
    border: none;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    cursor: pointer;
    font-size: 0.7rem;
    font-weight: 600;
    transition: all 0.12s;
    -webkit-tap-highlight-color: transparent;
}
.ml-act i { font-size: 1.35rem; line-height: 1; }
.ml-act:hover:not(:disabled) {
    background: rgba(255,255,255,0.12);
    color: #fff;
}
.ml-act:active:not(:disabled) { transform: scale(0.94); }
.ml-act:disabled, .ml-act.disabled { opacity: 0.35; cursor: not-allowed; }
.ml-act.ikram:hover:not(:disabled) { background: rgba(8,145,178,0.3); color: #67e8f9; }
.ml-act.iade:hover:not(:disabled) { background: rgba(245,158,11,0.3); color: #fbbf24; }
.ml-act.iskonto:hover:not(:disabled) { background: rgba(220,38,38,0.3); color: #fca5a5; }
.ml-act.yazdir:hover:not(:disabled) { background: rgba(74,144,226,0.3); color: #93c5fd; }

/* ─── Cart kolonu ─── */
.ml-cart {
    background: var(--bg-card, #fff);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border-right: 1px solid var(--border-color, #e5e7eb);
    min-height: 0;
}
.ml-cart-header {
    background: linear-gradient(135deg, #ec4899, #8b5cf6);
    color: #fff;
    padding: 14px 16px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-shrink: 0;
}
.ml-cart-title {
    display: flex; align-items: center; gap: 10px;
    font-size: 1.05rem; font-weight: 700;
}
.ml-cart-num {
    background: rgba(255,255,255,0.25);
    border-radius: 8px;
    padding: 3px 9px;
    font-size: 0.88rem;
    font-weight: 800;
    min-width: 30px;
    text-align: center;
}
.ml-cart-meta {
    display: flex; flex-direction: column; align-items: flex-end;
    font-size: 0.78rem; opacity: 0.92;
}
.ml-cart-elapsed { font-weight: 600; }

.ml-cart .cart-items {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    padding: 4px 0 !important;
    background: var(--bg-card, #fff) !important;
}
.ml-cart-row {
    padding: 10px 14px;
    border-bottom: 1px solid var(--border-color, #f0f0f0);
    cursor: pointer;
    transition: background 0.12s, border-left 0.12s;
    -webkit-tap-highlight-color: transparent;
    border-left: 3px solid transparent;
}
.ml-cart-row:hover { background: var(--bg-hover, #f9fafb); }
.ml-cart-row.selected {
    background: rgba(139,92,246,0.06);
    border-left-color: #8b5cf6;
}
.ml-cart-row.printed { opacity: 0.85; }
.ml-cart-row.complimentary { background: rgba(8,145,178,0.06); }
.ml-cart-row.refunded { background: rgba(220,53,69,0.05); opacity: 0.6; }

.ml-row-main {
    display: grid;
    grid-template-columns: 36px 1fr auto;
    gap: 6px;
    align-items: baseline;
}
.ml-row-qty {
    font-weight: 700;
    color: var(--primary, #8b5cf6);
    font-size: 0.95rem;
}
.ml-row-name {
    font-size: 0.92rem;
    font-weight: 500;
    color: var(--text-primary, #1f2937);
    line-height: 1.3;
}
.ml-row-price {
    font-weight: 700;
    color: var(--text-primary, #1f2937);
    font-size: 0.95rem;
    white-space: nowrap;
}
.ml-row-price.strike { text-decoration: line-through; opacity: 0.6; }

.ml-row-note {
    margin: 4px 0 0 36px;
    padding: 4px 8px;
    background: rgba(245,158,11,0.08);
    border-radius: 6px;
    color: #92400e;
    font-size: 0.78rem;
}
.ml-row-modifiers {
    margin: 4px 0 0 36px;
    padding-left: 8px;
    border-left: 2px solid var(--primary, #8b5cf6);
}
.ml-row-mod {
    display: flex;
    justify-content: space-between;
    font-size: 0.8rem;
    color: #6b7280;
    padding: 1px 0;
}

.ml-row-controls {
    display: flex;
    gap: 6px;
    margin: 8px 0 4px 36px;
    align-items: center;
    flex-wrap: wrap;
}
.ml-qty-btn {
    width: 38px; height: 38px;
    border: none;
    background: var(--bg-secondary, #f3f4f6);
    color: var(--text-primary, #1f2937);
    border-radius: 8px;
    font-size: 1.15rem;
    font-weight: 700;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    display: flex; align-items: center; justify-content: center;
    transition: background 0.1s, transform 0.1s;
}
.ml-qty-btn.minus:hover:not(:disabled) { background: rgba(220,53,69,0.12); color: var(--danger, #dc3545); }
.ml-qty-btn.plus:hover:not(:disabled) { background: rgba(16,185,129,0.12); color: #10b981; }
.ml-qty-btn:active:not(:disabled) { transform: scale(0.92); }
.ml-qty-btn:disabled { opacity: 0.35; cursor: not-allowed; }
.ml-qty-val {
    min-width: 28px;
    text-align: center;
    font-weight: 800;
    font-size: 1rem;
}
.ml-row-act {
    width: 36px; height: 36px;
    border: 1px solid var(--border-color, #e5e7eb);
    background: var(--bg-card, #fff);
    color: var(--text-secondary, #6b7280);
    border-radius: 8px;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    -webkit-tap-highlight-color: transparent;
    transition: all 0.12s;
}
.ml-row-act:hover { background: var(--bg-hover, #f3f4f6); }
.ml-row-act:active { transform: scale(0.94); }
.ml-row-act.delete { color: var(--danger, #dc3545); border-color: var(--danger, #dc3545); }
.ml-row-act.delete:hover { background: rgba(220,53,69,0.08); }

.ml-row-meta {
    margin: 4px 0 0 36px;
    font-size: 0.72rem;
    color: #9ca3af;
    display: flex; gap: 4px; align-items: center; flex-wrap: wrap;
}

.ml-cart-footer {
    flex-shrink: 0;
    padding: 12px;
    border-top: 1px solid var(--border-color, #e5e7eb);
    background: var(--bg-secondary, #f9fafb);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}
.ml-totals-mini {
    width: 100%;
    display: flex;
    justify-content: space-between;
    font-size: 0.82rem;
    padding-bottom: 8px;
    border-bottom: 1px dashed var(--border-color, #e5e7eb);
    color: var(--text-secondary, #6b7280);
}
.ml-pay-cta {
    flex: 1;
    min-height: 56px;
    background: linear-gradient(135deg, #10b981, #059669);
    color: #fff;
    border: none;
    border-radius: 12px;
    font-size: 1.05rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    cursor: pointer;
    box-shadow: 0 4px 14px rgba(16,185,129,0.35);
    -webkit-tap-highlight-color: transparent;
    transition: transform 0.1s, box-shadow 0.15s;
}
.ml-pay-cta:hover:not(:disabled) {
    box-shadow: 0 6px 20px rgba(16,185,129,0.5);
}
.ml-pay-cta:active:not(:disabled) { transform: scale(0.98); }
.ml-pay-cta:disabled { opacity: 0.35; cursor: not-allowed; box-shadow: none; }
.ml-grand-total {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--text-primary, #1f2937);
    min-width: 130px;
    text-align: right;
}

/* ─── Products kolonu ─── */
.ml-products {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    background: var(--bg-card, #fff);
    min-height: 0;
    position: relative;
}
.ml-products-header {
    flex-shrink: 0;
    padding: 12px 16px;
    border-bottom: 1px solid var(--border-color, #e5e7eb);
    background: var(--bg-card, #fff);
}
.ml-breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.92rem;
    color: var(--text-secondary, #6b7280);
    font-weight: 500;
}
.ml-breadcrumb i { font-size: 1rem; }
.ml-breadcrumb strong { color: var(--text-primary, #1f2937); font-weight: 700; }

.ml-products .products-grid {
    flex: 1 !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 10px !important;
    padding: 12px !important;
    overflow-y: auto !important;
    background: var(--bg-card, #fff) !important;
    grid-auto-rows: min-content !important;
}

/* ─── Ürün kartı görsellerini her ekranda tutarlı 4:3 yap ─── */
@media (min-width: 992px) {
    .pos-products .prod-card,
    .ml-products .prod-card {
        height: auto !important;
        min-height: 0 !important;
    }
    .pos-products .prod-card-img,
    .ml-products .prod-card-img {
        flex: 0 0 auto !important;
        height: auto !important;
        min-height: 0 !important;
        aspect-ratio: 4 / 3 !important;
        width: 100% !important;
        overflow: hidden !important;
    }
    .pos-products .prod-card-img img,
    .ml-products .prod-card-img img {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
    }
    .pos-products .prod-card-img img.logo-fallback,
    .ml-products .prod-card-img img.logo-fallback {
        width: 42% !important;
        height: 42% !important;
        object-fit: contain !important;
        opacity: 0.25 !important;
    }
}

/* ─── Kategoriler (sağ, koyu mor sidebar) ─── */
.ml-categories {
    background: linear-gradient(180deg, #4c1d95, #2e1065);
    color: #fff;
    padding: 16px 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    min-height: 0;
}
.ml-cat-title {
    padding: 0 14px 12px;
    font-size: 0.72rem;
    letter-spacing: 0.1em;
    color: rgba(255,255,255,0.55);
    font-weight: 700;
    text-transform: uppercase;
    margin: 0;
    flex-shrink: 0;
}
.ml-cat-list {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 0 10px 16px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-y;
    overscroll-behavior: contain;
}
.ml-cat-list::-webkit-scrollbar { width: 4px; }
.ml-cat-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.2); border-radius: 2px; }
.ml-cat-btn {
    flex: 0 0 auto;
    background: transparent;
    border: none;
    color: rgba(255,255,255,0.82);
    text-align: center;
    padding: 10px 6px;
    border-radius: 10px;
    font-size: 0.78rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.15s;
    overflow-wrap: anywhere;
    word-break: break-word;
    white-space: normal;
    line-height: 1.25;
    -webkit-tap-highlight-color: transparent;
    max-width: 100%;
}
.ml-cat-btn:hover:not(.active) {
    background: rgba(255,255,255,0.1);
    color: #fff;
}
.ml-cat-btn.active {
    background: var(--bg-card, #fff) !important;
    color: #2e1065 !important;
    box-shadow: 0 4px 14px rgba(0,0,0,0.2);
    font-weight: 800;
}

/* ─── Responsive: tablet 992-1400 ─── */
@media (min-width: 992px) and (max-width: 1399px) {
    .ml-shell { grid-template-columns: 78px 290px 1fr 120px; }
    .ml-act { min-height: 56px; font-size: 0.65rem; }
    .ml-act i { font-size: 1.2rem; }
    .ml-products .products-grid { grid-template-columns: repeat(3, 1fr) !important; }
}

/* ─── Geniş ekran 1400+ ─── */
@media (min-width: 1400px) {
    .ml-shell { grid-template-columns: 100px 360px 1fr 160px; }
    .ml-products .products-grid { grid-template-columns: repeat(4, 1fr) !important; }
}
@media (min-width: 1800px) {
    .ml-products .products-grid { grid-template-columns: repeat(5, 1fr) !important; }
}

/* ─── ml-shell mobil layout — pos-modern.css'e taşındı ─── */

/* ─── 480px products-grid — pos-modern.css'e taşındı ─── */

/* ═══════════════════════════════════════════════════════════════
   TABLES PAGE — Menulux gradient + improved table cards
   ═══════════════════════════════════════════════════════════════ */

/* Filter butonlar — Menulux başlık stili */
.filter-buttons {
    background: linear-gradient(135deg, #ec4899, #8b5cf6);
    padding: 12px 14px !important;
    border-radius: 14px !important;
    margin: 8px !important;
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.filter-buttons .filter-btn {
    background: rgba(255,255,255,0.15) !important;
    color: #fff !important;
    border: 1px solid rgba(255,255,255,0.25) !important;
    border-radius: 999px !important;
    padding: 8px 16px !important;
    font-weight: 600 !important;
    font-size: 0.88rem !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    transition: all 0.15s;
}
.filter-buttons .filter-btn:hover {
    background: rgba(255,255,255,0.25) !important;
}
.filter-buttons .filter-btn.active {
    background: #fff !important;
    color: #8b5cf6 !important;
    border-color: #fff !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15) !important;
}
.filter-buttons .filter-btn.success.active { color: #059669 !important; }
.filter-buttons .filter-btn.danger.active { color: #dc2626 !important; }
.filter-buttons .filter-btn.warning.active { color: #d97706 !important; }
.filter-buttons .filter-btn .badge {
    background: rgba(255,255,255,0.3) !important;
    color: inherit !important;
    border-radius: 8px !important;
    padding: 2px 8px !important;
    font-size: 0.75rem !important;
    font-weight: 700 !important;
}
.filter-buttons .filter-btn.active .badge {
    background: rgba(139,92,246,0.15) !important;
}

/* Section filters — pill style */
.section-filters {
    padding: 0 14px !important;
    margin: 0 !important;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.section-filters .section-btn {
    background: var(--bg-card, #fff) !important;
    border: 1px solid var(--border-color, #e5e7eb) !important;
    border-radius: 999px !important;
    padding: 8px 16px !important;
    font-weight: 600 !important;
    font-size: 0.88rem !important;
    color: var(--text-secondary, #4b5563) !important;
    transition: all 0.15s;
}
.section-filters .section-btn:hover {
    border-color: #8b5cf6 !important;
    color: #8b5cf6 !important;
}
.section-filters .section-btn.active {
    background: linear-gradient(135deg, #ec4899, #8b5cf6) !important;
    color: #fff !important;
    border-color: transparent !important;
    box-shadow: 0 2px 8px rgba(139,92,246,0.25) !important;
}

/* Section divider */
.section-divider {
    padding: 18px 16px 8px !important;
    display: flex;
    align-items: center;
    gap: 12px;
}
.section-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--border-color, #e5e7eb);
}
.section-divider-text {
    font-size: 0.85rem !important;
    font-weight: 800 !important;
    color: var(--text-muted, #6b7280) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
}

/* Table cards — Menulux modern */
.tables-grid {
    padding: 8px 14px !important;
    gap: 10px !important;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)) !important;
}
.table-card {
    background: var(--bg-card, #fff) !important;
    border: 1px solid var(--border-color, #e5e7eb) !important;
    border-radius: 14px !important;
    padding: 16px 12px !important;
    min-height: 110px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
    cursor: pointer !important;
    transition: all 0.15s !important;
    -webkit-tap-highlight-color: transparent !important;
    overflow: hidden !important;
}
.table-card::before {
    content: '';
    position: absolute;
    top: 0; left: 50%;
    transform: translateX(-50%);
    width: 32px;
    height: 4px;
    background: var(--border-color, #e5e7eb);
    border-radius: 0 0 4px 4px;
}
.table-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(0,0,0,0.1);
}
.table-card:active { transform: scale(0.97); }

/* Status colors — Menulux palette */
.table-card.occupied {
    background: linear-gradient(135deg, #ef4444, #dc2626) !important;
    color: #fff !important;
    border-color: transparent !important;
    box-shadow: 0 4px 12px rgba(239, 68, 68, 0.3) !important;
}
.table-card.occupied .table-name { color: #fff !important; }
.table-card.occupied .table-amount {
    color: #fff !important;
    background: rgba(255,255,255,0.18);
    padding: 4px 10px;
    border-radius: 8px;
    margin-top: 4px;
    font-weight: 800 !important;
    font-size: 1rem !important;
    letter-spacing: 0.02em;
}
.table-card.occupied .table-time {
    color: rgba(255,255,255,0.95) !important;
    font-weight: 600 !important;
    font-size: 0.78rem !important;
    margin-top: 4px;
}
.table-card.occupied .table-customer {
    color: rgba(255,255,255,0.95) !important;
    font-weight: 600 !important;
}
.table-card.occupied .wait-icon {
    background: rgba(255,255,255,0.3) !important;
    color: #fff !important;
}
.table-card.occupied::before { background: rgba(255,255,255,0.5); }
.table-card.reserved {
    background: linear-gradient(135deg, #fbbf24, #f59e0b) !important;
    color: #fff !important;
    border-color: transparent !important;
}
.table-card.reserved::before { background: rgba(255,255,255,0.5); }
.table-card.cleaning {
    background: linear-gradient(135deg, #3b82f6, #2563eb) !important;
    color: #fff !important;
    border-color: transparent !important;
}
.table-card.cleaning::before { background: rgba(255,255,255,0.5); }

.table-card .table-name {
    font-size: 1.1rem !important;
    font-weight: 800 !important;
    margin-bottom: 4px !important;
}
.table-card .table-status,
.table-card .table-amount,
.table-card small {
    font-size: 0.8rem !important;
    opacity: 0.9 !important;
}
.table-card.occupied .table-amount {
    font-size: 1.05rem !important;
    font-weight: 800 !important;
    margin-top: 2px;
}

/* Table card içindeki info-row tam genişlik (Salon4 kişi bug fix) */
.table-card .table-info-row {
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
    gap: 6px !important;
    margin-top: 2px;
}
.table-card .table-section,
.table-card .table-capacity {
    font-size: 0.78rem !important;
    color: var(--text-muted, #9ca3af) !important;
}
.table-card .table-section::after {
    content: ' ·';
    margin-left: 2px;
    opacity: 0.6;
}

/* ═══════════════════════════════════════════════════════════════
   QUICKSALE — Menulux görsel polish (CSS-only override)
   ═══════════════════════════════════════════════════════════════ */

/* ─── 992-1199px: Payment ürünlerin altına, sepet+kategoriler tam boy ─── */
@media (min-width: 992px) and (max-width: 1199px) {
    .pos-container {
        display: grid !important;
        grid-template-columns: 56px 250px 1fr 110px !important;
        grid-template-rows: 1fr auto !important;
        gap: 4px !important;
        padding: 4px !important;
        background: var(--bg-secondary, #f3f4f6) !important;
        flex-direction: unset !important;
    }
    .pos-products, .qs-categories, .qs-actions {
        border-radius: 12px !important;
        box-shadow: 0 1px 3px rgba(0,0,0,0.05) !important;
        overflow: hidden !important;
    }
    /* Actions: sol kenar, tam boy */
    .qs-actions {
        order: 1;
        grid-column: 1;
        grid-row: 1 / 3;
    }
    /* pos-right-panel contents olarak cart & payment ayrı grid item */
    .pos-right-panel {
        order: 2;
        display: contents !important;
        background: transparent !important;
        box-shadow: none !important;
    }
    /* Sepet: tam boy (2 satır kapsıyor) */
    .pos-right-panel > .cart-section {
        order: 2;
        grid-column: 2;
        grid-row: 1 / 3;
        background: var(--bg-card, #fff) !important;
        border-radius: 12px !important;
        box-shadow: 0 1px 3px rgba(0,0,0,0.05) !important;
        overflow: hidden !important;
        border-bottom: none !important;
        max-height: none !important;
        min-height: 0 !important;
        display: flex !important;
        flex-direction: column !important;
    }
    /* Ürünler: üst satır, orta sütun */
    .pos-products {
        order: 3;
        grid-column: 3;
        grid-row: 1;
        min-width: 0;
    }
    /* Kategoriler: sağ kenar, tam boy */
    .qs-categories {
        order: 4;
        grid-column: 4;
        grid-row: 1 / 3;
    }
    /* Payment: ürünlerin altında, SADECE orta sütun */
    .pos-right-panel > .payment-section {
        order: 5;
        grid-column: 3;
        grid-row: 2;
        background: var(--bg-card, #fff) !important;
        border-radius: 12px !important;
        box-shadow: 0 1px 3px rgba(0,0,0,0.05) !important;
        overflow: hidden !important;
        display: flex !important;
        flex-direction: row !important;
        max-height: 240px !important;
        min-height: 210px !important;
    }

}

/* ─── 1200px+: Orijinal 5-sütun düzeni ─── */
@media (min-width: 1200px) {
    .pos-container {
        display: grid !important;
        grid-template-columns: 84px 260px 260px 1fr 140px !important;
        gap: 10px !important;
        padding: 10px !important;
        background: var(--bg-secondary, #f3f4f6) !important;
        flex-direction: unset !important;
    }
    .pos-products, .qs-categories, .qs-actions {
        border-radius: 14px !important;
        box-shadow: 0 1px 3px rgba(0,0,0,0.05) !important;
        overflow: hidden !important;
    }
    .qs-actions { order: 1; }
    .pos-right-panel {
        order: 2;
        display: contents !important;
        background: transparent !important;
        box-shadow: none !important;
    }
    .pos-right-panel > .cart-section {
        order: 2;
        background: var(--bg-card, #fff) !important;
        border-radius: 14px !important;
        box-shadow: 0 1px 3px rgba(0,0,0,0.05) !important;
        overflow: hidden !important;
        border-bottom: none !important;
        max-height: none !important;
        min-height: 0 !important;
        display: flex !important;
        flex-direction: column !important;
    }
    .pos-right-panel > .payment-section {
        order: 3;
        background: var(--bg-card, #fff) !important;
        border-radius: 14px !important;
        box-shadow: 0 1px 3px rgba(0,0,0,0.05) !important;
        overflow: hidden !important;
        display: flex !important;
        flex-direction: column !important;
    }
    .pos-products { order: 4; min-width: 0; }
    .qs-categories { order: 5; }
}
@media (min-width: 1400px) {
    .pos-container {
        grid-template-columns: 92px 300px 300px 1fr 160px !important;
    }
    .qs-pay-top { padding: 10px 14px 0; }
    .qs-pay-middle { padding: 10px 14px; gap: 10px; }
    .qs-pay-bottom { padding: 10px 14px 14px; }
    .qs-pay-bottom .payment-buttons-grid { gap: 8px; }
    .qs-pay-bottom .pay-btn { min-height: 56px; font-size: 0.95rem; border-radius: 12px; gap: 8px; }
    .qs-pay-bottom .pay-btn i { font-size: 1.15rem; }
    /* cr3 restore */
    .cr3 { padding: 12px 16px; }
    .cr3-name { font-size: 0.95rem; }
    .cr3-price { font-size: 1.05rem; }
    .cr3-qty-prefix { font-size: 0.85rem; min-width: 28px; }
    .cr3-desc { font-size: 0.85rem; }
    .cr3-line3 { margin-top: 10px; gap: 12px; }
    .cr3-qty { gap: 8px; }
    .cr3-q { width: 32px !important; height: 32px !important; }
    .cr3-q i { font-size: 0.95rem !important; }
    .cr3-q-val { font-size: 1.1rem !important; min-width: 24px !important; }
    .cr3-meta { font-size: 0.78rem !important; }
    .cr3-actions { gap: 8px; margin-top: 12px; padding-top: 12px; }
    .cr3-act { min-height: 44px; font-size: 0.85rem; border-radius: 10px; }
    /* cart-footer restore */
    .ml-cart-footer { padding: 16px 18px !important; gap: 12px !important; }
    .ml-total-amount { font-size: 1.9rem; }
    .ml-pay-cta { min-height: 64px !important; font-size: 1.15rem !important; border-radius: 14px !important; }
    .pos-right-panel .cart-section .cart-summary { padding: 12px 14px !important; }
}
@media (min-width: 1800px) {
    .pos-container {
        grid-template-columns: 100px 360px 360px 1fr 180px !important;
    }
}

/* QuickSale aksiyon sidebar (Menulux koyu mor) */
.qs-actions {
    background: linear-gradient(180deg, #2d1b4e, #1a0f2e) !important;
    padding: 12px 8px !important;
    display: flex;
    flex-direction: column;
    gap: 6px;
    overflow-y: auto;
}
.qs-actions::-webkit-scrollbar { width: 4px; }
.qs-actions::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.2); border-radius: 2px; }
.qs-actions .ml-act { width: 100%; }

/* ═══════════════════════════════════════════════════════════════
   QUICKSALE pos-right-panel — mobilde 2-row grid (cart üst + payment alt)
   Desktop'ta display:contents ile direkt parent grid'e açılır
   ═══════════════════════════════════════════════════════════════ */
/* ─── pos-right-panel mobil grid — pos-modern.css'e taşındı ─── */
.pos-right-panel .cart-section {
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    overflow: hidden !important;
    border-bottom: 1px solid var(--border-color, #e5e7eb);
}
.pos-right-panel .cart-items {
    flex: 1 1 auto !important;
    min-height: 100px !important;
    overflow-y: auto !important;
    background: var(--bg-card, #fff) !important;
}
.pos-right-panel .cart-tabs,
.pos-right-panel .cart-header,
.pos-right-panel .cart-summary,
.pos-right-panel .pending-payments {
    flex-shrink: 0 !important;
}

/* payment-section: 3 bölge — top sabit / middle scroll / bottom sabit */
.pos-right-panel .payment-section {
    display: flex !important;
    min-height: 0 !important;
    overflow: hidden !important;
    background: var(--bg-card, #fff);
}
/* 1200+: dikey layout (varsayılan) */
@media (min-width: 1200px) {
    .pos-right-panel .payment-section {
        flex-direction: column !important;
    }
}
/* 992-1199: yatay layout (ürünlerin altında) */
@media (min-width: 992px) and (max-width: 1199px) {
    .pos-right-panel .payment-section {
        flex-direction: row !important;
    }
}
/* <992: dikey (mobil) */
@media (max-width: 991px) {
    .pos-right-panel .payment-section {
        flex-direction: column !important;
    }
}
.qs-pay-top {
    flex-shrink: 0;
    padding: 6px 10px 0;
    border-bottom: 1px solid var(--border-color, #f0f0f0);
}
.qs-pay-middle {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.qs-pay-bottom {
    flex-shrink: 0;
    padding: 6px 10px 10px;
    border-top: 1px solid var(--border-color, #e5e7eb);
    background: var(--bg-card, #fff);
    box-shadow: 0 -4px 12px rgba(0,0,0,0.04);
}
.qs-pay-bottom .payment-buttons-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
}
.qs-pay-bottom .pay-btn {
    min-height: 42px;
    border: none;
    border-radius: 10px;
    color: #fff;
    font-size: 0.82rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    transition: transform 0.1s, filter 0.15s;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.qs-pay-bottom .pay-btn i { font-size: 1rem; }
.qs-pay-bottom .pay-btn:active:not(:disabled) { transform: scale(0.97); }
.qs-pay-bottom .pay-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.qs-pay-bottom .pay-btn.cash { background: linear-gradient(135deg, #10b981, #059669); }
.qs-pay-bottom .pay-btn.card { background: linear-gradient(135deg, #3b82f6, #1d4ed8); }
.qs-pay-bottom .pay-btn.debit { background: linear-gradient(135deg, #8b5cf6, #6d28d9); }
.qs-pay-bottom .pay-btn.meal { background: linear-gradient(135deg, #f59e0b, #d97706); }
.qs-pay-bottom .pay-btn:hover:not(:disabled) { filter: brightness(1.08); }

/* Inline tutar + split group: varsayılan gizli, sadece 992-1199 yatay düzende gösterilir */
.qs-pay-amount-inline { display: none; }
.qs-pay-split-group { display: contents; }

/* Numpad grid içinde daha güzel */
.qs-pay-middle .numpad-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 4px;
}
.qs-pay-middle .numpad-btn {
    min-height: 34px;
    border: 1px solid var(--border-color, #e5e7eb);
    background: var(--bg-card, #fff);
    border-radius: 8px;
    font-size: 1.05rem;
    font-weight: 700;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    transition: background 0.1s;
}
.qs-pay-middle .numpad-btn:hover { background: var(--bg-hover, #f3f4f6); }
.qs-pay-middle .numpad-btn:active { transform: scale(0.97); }
.qs-pay-middle .numpad-btn.clear {
    background: var(--danger, #dc3545) !important;
    color: #fff !important;
    border-color: var(--danger, #dc3545) !important;
}
.qs-pay-middle .quick-amounts {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 4px !important;
}
.qs-pay-middle .quick-btn {
    min-height: 36px;
    border: 1px solid var(--border-color, #e5e7eb);
    background: var(--bg-card, #fff);
    border-radius: 8px;
    font-weight: 700;
    font-size: 0.78rem;
    cursor: pointer;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    word-break: break-word;
    text-align: center;
    line-height: 1.3;
    align-content: center;
}
.qs-pay-middle .quick-btn:hover { background: var(--bg-hover, #f3f4f6); }
.qs-pay-middle .quick-btn.remaining-btn {
    background: linear-gradient(135deg, #10b981, #059669) !important;
    color: #fff !important;
    border-color: transparent !important;
}
.qs-pay-middle .split-btn {
    width: 100%;
    min-height: 48px;
    background: linear-gradient(135deg, #ec4899, #8b5cf6) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 10px !important;
    font-weight: 700 !important;
    cursor: pointer;
}
.qs-pay-middle .split-btn:disabled {
    background: var(--bg-secondary, #e5e7eb) !important;
    color: var(--text-muted, #9ca3af) !important;
    opacity: 0.6 !important;
}

/* ─── Hesap bölme parçaları ─── */
.split-portions {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
    width: 100%;
}
.split-portion-btn {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 1px;
    min-height: 44px;
    padding: 5px 4px;
    border: 2px solid #3b82f6;
    border-radius: 8px;
    background: rgba(59,130,246,0.08);
    color: #1d4ed8;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
}
.split-portion-btn:active:not(:disabled) { transform: scale(0.96); }
.split-portion-btn.paid {
    border-color: #10b981;
    background: rgba(16,185,129,0.12);
    color: #059669;
    opacity: 0.7;
    cursor: default;
}
.split-portion-num { font-size: 0.72rem; font-weight: 600; opacity: 0.8; }
.split-portion-amt { font-size: 0.9rem; font-weight: 800; white-space: nowrap; }
.split-portion-check {
    position: absolute;
    top: 2px;
    right: 4px;
    font-size: 0.8rem;
    color: #10b981;
}

/* ─── 992-1199: Payment yatay düzen override (dosya sonunda — override garantisi) ─── */
@media (min-width: 992px) and (max-width: 1199px) {
    /* Ödenecek tutar gizle — middle içinde inline olarak gösteriliyor */
    .qs-pay-top {
        display: none !important;
    }
    /* Split group: tahsil tutar üstte, kişiye böl altta — dikey */
    .qs-pay-split-group {
        display: flex !important;
        flex-direction: column !important;
        gap: 6px !important;
        flex: 0 0 150px !important;
        width: 150px !important;
        min-width: 150px !important;
        justify-content: center !important;
    }
    .qs-pay-amount-inline {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 2px !important;
        padding: 6px 8px !important;
        background: rgba(16,185,129,0.08) !important;
        border-radius: 8px !important;
    }
    .qs-pay-amount-inline small {
        font-size: 0.7rem !important;
        opacity: 0.7 !important;
        white-space: nowrap !important;
    }
    .qs-pay-amount-inline .amount-val {
        font-size: 1.05rem !important;
        font-weight: 800 !important;
        color: #10b981 !important;
        white-space: nowrap !important;
    }
    .qs-pay-split-group .split-btn-container {
        width: 100% !important;
    }
    .qs-pay-split-group .split-btn {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 1px !important;
        width: 100% !important;
        min-width: 0 !important;
        min-height: 48px !important;
        height: auto !important;
        white-space: normal !important;
        overflow-wrap: anywhere !important;
        word-break: break-word !important;
        line-height: 1.2 !important;
        padding: 6px 6px !important;
        text-align: center !important;
    }
    .qs-pay-split-group .split-btn i { display: inline !important; }
    .qs-pay-split-group .split-btn .split-btn-main {
        display: block !important;
        font-size: 0.78rem !important;
        font-weight: 700 !important;
    }
    .qs-pay-split-group .split-btn .split-btn-sub {
        display: block !important;
        font-size: 0.72rem !important;
        opacity: 0.9 !important;
    }
    /* Bölme parçaları: 175px sütuna sığsın — 2 sütun, dikey kaydırmalı */
    .qs-pay-split-group .split-portions {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 4px !important;
        width: 100% !important;
        max-height: 150px !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        padding-right: 2px !important;
    }
    .qs-pay-split-group .split-portion-btn {
        min-height: 38px !important;
        padding: 3px 2px !important;
        border-width: 1.5px !important;
    }
    .qs-pay-split-group .split-portion-num { font-size: 0.62rem !important; }
    .qs-pay-split-group .split-portion-amt { font-size: 0.72rem !important; }
    /* Yatay taşmayı tamamen engelle */
    .qs-pay-middle {
        flex: 1 1 auto !important;
        flex-direction: row !important;
        overflow: hidden !important;
        gap: 4px !important;
        padding: 4px !important;
        align-items: stretch !important;
    }
    .qs-pay-middle .numpad-grid {
        flex-shrink: 0 !important;
        width: 152px !important;
    }
    .qs-pay-middle .numpad-btn {
        min-height: 34px !important;
        font-size: 0.98rem !important;
    }
    .qs-pay-middle .quick-amounts {
        flex-shrink: 0 !important;
        width: 70px !important;
        grid-template-columns: 1fr !important;
    }
    .qs-pay-middle .quick-btn {
        min-height: 34px !important;
        font-size: 0.74rem !important;
        white-space: nowrap !important;
        padding-left: 2px !important;
        padding-right: 2px !important;
    }
    .qs-pay-middle .split-btn-container {
        flex-shrink: 0 !important;
    }
    /* Ödeme butonları alt alta (tek sütun) */
    .qs-pay-bottom {
        flex: 1 1 auto !important;
        min-width: 150px !important;
        border-top: none !important;
        border-left: 1px solid var(--border-color, #f0f0f0) !important;
        padding: 6px !important;
        display: flex !important;
        flex-direction: column !important;
        justify-content: center !important;
        box-shadow: none !important;
    }
    .qs-pay-bottom .payment-buttons-grid {
        display: flex !important;
        flex-direction: column !important;
        gap: 6px !important;
        height: 100% !important;
    }
    .qs-pay-bottom .pay-btn {
        flex: 1 1 0 !important;
        min-height: 44px !important;
        font-size: 0.9rem !important;
        font-weight: 700 !important;
        padding: 6px 10px !important;
        border-radius: 10px !important;
        white-space: nowrap !important;
    }
    .qs-pay-bottom .pay-btn i {
        font-size: 1.05rem !important;
    }
}

/* ─── cart-section mobil — pos-modern.css'e taşındı ─── */

/* QuickSale ürün alanı header (breadcrumb) */
.qs-products-header {
    padding: 12px 16px;
    background: var(--bg-card, #fff);
    border-bottom: 1px solid var(--border-color, #e5e7eb);
    flex-shrink: 0;
}
.qs-breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.95rem;
    color: var(--text-secondary, #6b7280);
    font-weight: 500;
}
.qs-breadcrumb i { font-size: 1rem; }
.qs-breadcrumb strong { color: var(--text-primary, #1f2937); font-weight: 700; }

/* QuickSale kategoriler sağ sidebar (koyu mor — Menulux) */
.qs-categories {
    background: linear-gradient(180deg, #4c1d95, #2e1065);
    color: #fff;
    padding: 14px 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    min-height: 0;
}
.qs-cat-title {
    padding: 0 14px 12px;
    font-size: 0.7rem;
    letter-spacing: 0.12em;
    color: rgba(255,255,255,0.55);
    font-weight: 700;
    text-transform: uppercase;
    margin: 0;
    flex-shrink: 0;
}
.qs-cat-list {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 0 10px 12px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-y;
    overscroll-behavior: contain;
}
.qs-cat-list::-webkit-scrollbar { width: 4px; }
.qs-cat-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.2); border-radius: 2px; }
.qs-cat-btn {
    flex: 0 0 auto;
    background: transparent;
    border: none;
    color: rgba(255,255,255,0.82);
    text-align: center;
    padding: 10px 6px;
    border-radius: 10px;
    font-size: 0.78rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.15s;
    overflow-wrap: anywhere;
    word-break: break-word;
    white-space: normal;
    line-height: 1.25;
    -webkit-tap-highlight-color: transparent;
    max-width: 100%;
}
.qs-cat-btn:hover:not(.active) {
    background: rgba(255,255,255,0.1);
    color: #fff;
}
.qs-cat-btn.active {
    background: var(--bg-card, #fff) !important;
    color: #2e1065 !important;
    box-shadow: 0 4px 14px rgba(0,0,0,0.2);
    font-weight: 800;
}

/* ─── QuickSale mobil layout — pos-modern.css'e taşındı ─── */
@media (min-width: 1400px) {
    .pos-right-panel { width: 500px !important; }
}

/* QuickSale cart-tabs gradient */
.cart-tabs {
    background: linear-gradient(135deg, #ec4899, #8b5cf6) !important;
    padding: 8px !important;
}
.cart-tab {
    background: rgba(255,255,255,0.18) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 10px !important;
    padding: 8px 14px !important;
    font-weight: 600 !important;
    font-size: 0.88rem !important;
    -webkit-tap-highlight-color: transparent !important;
}
.cart-tab:hover { background: rgba(255,255,255,0.3) !important; }
.cart-tab.active {
    background: #fff !important;
    color: #8b5cf6 !important;
    font-weight: 700 !important;
}
.cart-tab.add-cart {
    background: rgba(255,255,255,0.12) !important;
    min-width: 44px !important;
}
.cart-tab .cart-badge {
    background: rgba(255,255,255,0.3) !important;
    color: inherit !important;
    border-radius: 999px !important;
    padding: 1px 7px !important;
    font-size: 0.75rem !important;
    font-weight: 700 !important;
    margin-left: 6px !important;
}
.cart-tab.active .cart-badge {
    background: rgba(139,92,246,0.15) !important;
}

/* QuickSale: pos-products üst category-bar — Menulux pill-style */
.pos-products .category-bar-wrapper {
    background: var(--bg-card, #fff) !important;
    border-bottom: 1px solid var(--border-color, #e5e7eb) !important;
    padding: 10px 12px !important;
    flex-direction: row !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
}
.pos-products .category-bar {
    flex-direction: row !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    gap: 6px !important;
}
.pos-products .cat-btn {
    flex-direction: row !important;
    border-radius: 999px !important;
    padding: 8px 14px !important;
    font-size: 0.88rem !important;
    min-height: 38px !important;
    flex-shrink: 0 !important;
    width: auto !important;
}

/* ÖDEME AL CTA QuickSale stili */
.pos-right-panel .cart-section .cart-summary {
    background: var(--bg-secondary, #f9fafb) !important;
    padding: 8px 10px !important;
    border-top: 1px solid var(--border-color, #e5e7eb) !important;
}

/* ═══════════════════════════════════════════════════════════════
   GLOBAL: Menulux gradient header utility (her sayfada kullanılabilir)
   ═══════════════════════════════════════════════════════════════ */
.menulux-header-bar {
    background: linear-gradient(135deg, #ec4899, #8b5cf6);
    color: #fff;
    padding: 14px 18px;
    border-radius: 12px;
    margin: 8px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    box-shadow: 0 2px 8px rgba(139,92,246,0.25);
}

/* ═══════════════════════════════════════════════════════════════
   MOBİL MENULUX POLISH — pink-purple identity + improved UX
   ═══════════════════════════════════════════════════════════════ */

/* ─── Mobil Menulux polish — pos-modern.css'e taşındı ─── */

/* ═══════════════════════════════════════════════════════════════
   PEMBE-MOR THEME — Tüm sayfalarda primary butonlar Menulux'a uyum
   ═══════════════════════════════════════════════════════════════ */

/* OrderPage ml-shell başlığı — pembe-mor gradient (zaten vardı, vurgulu) */
.ml-cart-header {
    background: linear-gradient(135deg, #ec4899, #8b5cf6) !important;
}
.ml-row-qty { color: #8b5cf6 !important; }
.ml-cart-row.selected {
    background: rgba(236,72,153,0.06) !important;
    border-left-color: #ec4899 !important;
}

/* Brand color uyumu — ÖDEME AL yeşil korunuyor (zıt renk vurgu) */

/* ═══════════════════════════════════════════════════════════════
   CR3 — Cart Row v3 (Menulux mobil paterni)
   - UPPERCASE isim + sağda pembe fiyat
   - Açıklama satırı (not + yan ürünler) gri
   - Sol meta (kullanıcı/saat veya birim fiyat) + sağ pembe + N - kontroller
   ═══════════════════════════════════════════════════════════════ */

.cr3 {
    background: var(--bg-card, #fff);
    padding: 8px 10px;
    border-bottom: 1px solid var(--border-color, #f0f0f0);
    cursor: pointer;
    transition: background 0.12s;
    -webkit-tap-highlight-color: transparent;
    border-left: 3px solid transparent;
}
.cr3:hover { background: var(--bg-hover, #fafafa); }
.cr3.selected {
    background: rgba(236,72,153,0.04);
    border-left-color: #ec4899;
}
.cr3.printed { opacity: 0.92; }
.cr3.complimentary { background: rgba(8,145,178,0.06); }
.cr3.refunded { background: rgba(220,53,69,0.05); opacity: 0.7; }

.cr3-line1 {
    display: flex;
    align-items: baseline;
    gap: 6px;
}
.cr3-qty-prefix {
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--text-muted, #94a3b8);
    flex-shrink: 0;
    min-width: 22px;
}
.cr3-name {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--text-primary, #111827);
    line-height: 1.25;
    flex: 1;
}
.cr3-name .oi-badge { font-size: 0.65rem; padding: 2px 6px; }
.cr3-price {
    font-size: 0.88rem;
    font-weight: 800;
    color: #ec4899;
    white-space: nowrap;
}
.cr3-price.strike { text-decoration: line-through; opacity: 0.55; }

.cr3-line2 {
    margin-top: 4px;
}
.cr3-desc {
    font-size: 0.75rem;
    color: var(--text-muted, #9ca3af);
    font-weight: 500;
    line-height: 1.3;
}

.cr3-line3 {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 4px;
    gap: 6px;
}
.cr3-meta {
    font-size: 0.78rem;
    color: var(--text-muted, #9ca3af);
    display: flex;
    align-items: center;
    gap: 4px;
    flex-wrap: wrap;
}
.cr3-meta i { font-size: 0.85rem; }
.cr3-sep { opacity: 0.5; }

/* Pembe yuvarlak +/− butonlar (Menulux mobil tarzı) */
.cr3-qty {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
}
.cr3-q {
    width: 28px;
    height: 28px;
    border: none;
    border-radius: 50%;
    background: #ec4899;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
    font-weight: 700;
    box-shadow: 0 2px 6px rgba(236,72,153,0.35);
    -webkit-tap-highlight-color: transparent;
    transition: transform 0.1s, box-shadow 0.12s, filter 0.12s;
}
.cr3-q i { font-size: 0.95rem; line-height: 1; }
.cr3-q:hover:not(:disabled) { filter: brightness(1.08); box-shadow: 0 3px 9px rgba(236,72,153,0.5); }
.cr3-q:active:not(:disabled) { transform: scale(0.9); }
.cr3-q:disabled {
    opacity: 0.35;
    cursor: not-allowed;
    box-shadow: none;
}
.cr3-q-val {
    min-width: 20px;
    text-align: center;
    font-size: 0.92rem;
    font-weight: 800;
    color: var(--text-primary, #111827);
}

/* Seçili satırın altında genişleyen aksiyon barı */
.cr3-actions {
    display: flex;
    gap: 4px;
    margin-top: 6px;
    padding-top: 6px;
    border-top: 1px dashed var(--border-color, #e5e7eb);
    animation: cr3-fade 0.15s ease-out;
}
@keyframes cr3-fade {
    from { opacity: 0; transform: translateY(-4px); }
    to { opacity: 1; transform: translateY(0); }
}
.cr3-act {
    flex: 1;
    min-height: 36px;
    border: 1px solid var(--border-color, #e5e7eb);
    background: var(--bg-card, #fff);
    border-radius: 8px;
    cursor: pointer;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-secondary, #4b5563);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    -webkit-tap-highlight-color: transparent;
    transition: background 0.12s, transform 0.1s;
}
.cr3-act i { font-size: 1rem; }
.cr3-act:hover { background: var(--bg-hover, #f3f4f6); }
.cr3-act:active { transform: scale(0.97); }
.cr3-act.danger {
    color: var(--danger, #dc3545);
    border-color: var(--danger, #dc3545);
}
.cr3-act.danger:hover { background: rgba(220,53,69,0.08); }

/* ═══════════════════════════════════════════════════════════════
   ml-cart footer (TOPLAM satırı + ÖDEME AL CTA Menulux style)
   ═══════════════════════════════════════════════════════════════ */

.ml-cart-footer {
    padding: 10px 12px !important;
    flex-direction: column !important;
    gap: 8px !important;
    align-items: stretch !important;
    background: var(--bg-card, #fff) !important;
    border-top: 1px solid var(--border-color, #e5e7eb) !important;
}
.ml-total-line {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 4px 0;
}
.ml-total-label {
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    color: #ec4899;
    text-transform: uppercase;
}
.ml-total-amount {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--text-primary, #111827);
    letter-spacing: -0.01em;
}

.ml-pay-cta {
    width: 100%;
    min-height: 48px !important;
    background: linear-gradient(135deg, #10b981, #059669) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 10px !important;
    font-size: 0.95rem !important;
    font-weight: 800 !important;
    letter-spacing: 0.05em;
    cursor: pointer !important;
    box-shadow: 0 6px 20px rgba(16,185,129,0.4) !important;
    transition: transform 0.1s, box-shadow 0.15s, filter 0.12s !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
}
.ml-pay-cta:hover:not(:disabled) {
    filter: brightness(1.05);
    box-shadow: 0 8px 24px rgba(16,185,129,0.55) !important;
}
.ml-pay-cta:active:not(:disabled) { transform: scale(0.98); }
.ml-pay-cta:disabled {
    opacity: 0.4;
    cursor: not-allowed;
    box-shadow: none !important;
}

.ml-totals-mini {
    width: 100%;
    display: flex;
    justify-content: space-between;
    gap: 8px;
    font-size: 0.85rem;
    padding-bottom: 10px;
    border-bottom: 1px dashed var(--border-color, #e5e7eb);
    color: var(--text-muted, #6b7280);
}

/* Desktop ≥992px: qty prefix line1'de + line3'te kompakt +/- butonlar görünür */
@media (min-width: 992px) {
    .cr3-qty-prefix { display: inline-block; }
    .cr3-line3 { display: flex !important; }
    .cr3 { padding: 8px 10px; }
    .cr3-q { width: 26px !important; height: 26px !important; }
    .cr3-q i { font-size: 0.78rem !important; }
    .cr3-q-val { font-size: 0.88rem !important; min-width: 18px !important; }
    .cr3-meta { font-size: 0.7rem !important; }
}

/* Mobile <992px: Menulux mobil paterni — prefix gizli, inline +/- butonlar görünür */
@media (max-width: 991px) {
    .cr3-qty-prefix { display: none; }
    .cr3 { padding: 12px 14px; }
    .cr3-name { font-size: 0.9rem; }
    .cr3-price { font-size: 1rem; }
    .cr3-q { width: 36px; height: 36px; }
    .cr3-q i { font-size: 1.05rem; }
    .cr3-q-val { font-size: 1.15rem; min-width: 28px; }
    .ml-total-amount { font-size: 1.7rem; }
    .ml-pay-cta { min-height: 58px; font-size: 1.05rem; }
}

/* QuickSale cart items: cr3 padding cart-items içinde */
.pos-right-panel .cart-items {
    padding: 0 !important;
}

/* ═══════════════════════════════════════════════════════════════
   TABLES PAGE — Menulux 3-kolon: Adisyon | Grid | Bölüm Sidebar
   ═══════════════════════════════════════════════════════════════ */
.tbl-shell {
    display: grid;
    grid-template-columns: 280px 1fr 180px;
    height: calc(100vh - 70px);
    height: calc(100dvh - 70px);
    background: var(--bg-primary, #f3f4f6);
    overflow: hidden;
    gap: 0;
}

/* ─── Sol: Açık adisyonlar ─── */
.tbl-adisyons {
    background: var(--bg-card, #fff);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border-right: 1px solid var(--border-color, #e5e7eb);
    min-height: 0;
}
.tbl-adisyons-head {
    padding: 14px 18px;
    display: flex;
    align-items: center;
    gap: 10px;
    border-bottom: 1px solid var(--border-color, #e5e7eb);
    flex-shrink: 0;
}
.tbl-adisyons-count {
    background: #ec4899;
    color: #fff;
    border-radius: 999px;
    padding: 3px 11px;
    font-size: 0.92rem;
    font-weight: 800;
    min-width: 30px;
    text-align: center;
}
.tbl-adisyons-title {
    color: #ec4899;
    font-size: 0.95rem;
    font-weight: 800;
    letter-spacing: 0.06em;
}
.tbl-adisyons-list {
    flex: 1 1 auto;
    overflow-y: auto;
    min-height: 0;
    padding: 4px 0;
}
.tbl-adisyons-empty {
    padding: 36px 18px;
    text-align: center;
    color: var(--text-muted, #94a3b8);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}
.tbl-adisyons-empty i { font-size: 2rem; opacity: 0.5; }

.tbl-adisyon-item {
    width: 100%;
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--border-color, #f0f0f0);
    padding: 10px 14px;
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    transition: background 0.12s;
    text-align: left;
    min-width: 0;
}
.tbl-adisyon-item:hover { background: var(--bg-hover, #f9fafb); }
.tbl-adisyon-item:active { background: var(--bg-secondary, #f3f4f6); }
.tbl-adisyon-num {
    background: #ec4899;
    color: #fff;
    border-radius: 50%;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.82rem;
    font-weight: 800;
    flex-shrink: 0;
}
.tbl-adisyon-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.tbl-adisyon-name {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--text-primary, #1f2937);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 1.2;
}
.tbl-adisyon-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    justify-content: space-between;
}
.tbl-adisyon-time {
    font-size: 0.78rem;
    color: var(--text-secondary, #6b7280);
    font-weight: 500;
    font-variant-numeric: tabular-nums;
}
.tbl-adisyon-amount {
    font-size: 0.92rem;
    font-weight: 800;
    color: var(--text-primary, #1f2937);
    white-space: nowrap;
}

.tbl-adisyons-total {
    padding: 16px 18px;
    border-top: 1px solid var(--border-color, #e5e7eb);
    background: var(--bg-secondary, #f9fafb);
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    flex-shrink: 0;
}
.tbl-total-label {
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    color: var(--text-muted, #6b7280);
}
.tbl-total-amount {
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--text-primary, #1f2937);
    letter-spacing: -0.01em;
}

/* ─── Orta: Masa grid alanı ─── */
.tbl-grid-area {
    display: flex;
    flex-direction: column;
    background: var(--bg-secondary, #fafafa);
    overflow: hidden;
    min-height: 0;
}
.tbl-breadcrumb {
    padding: 14px 20px;
    background: var(--bg-card, #fff);
    border-bottom: 1px solid var(--border-color, #e5e7eb);
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.95rem;
    color: var(--text-secondary, #6b7280);
    flex-shrink: 0;
}
.tbl-breadcrumb i { font-size: 1.05rem; }
.tbl-breadcrumb strong {
    color: var(--text-primary, #1f2937);
    font-weight: 700;
}
.tbl-grid-scroll {
    flex: 1;
    overflow-y: auto;
    min-height: 0;
    padding: 8px 14px 14px;
}

/* ─── Sağ: Bölüm/Filtre sidebar (koyu mor) ─── */
.tbl-sections {
    background: linear-gradient(180deg, #4c1d95, #2e1065);
    color: #fff;
    padding: 14px 8px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    overflow-y: auto;
}
.tbl-sec-title {
    padding: 0 10px 12px;
    font-size: 0.72rem;
    letter-spacing: 0.12em;
    color: rgba(255,255,255,0.55);
    font-weight: 700;
    text-transform: uppercase;
    margin: 0;
    flex-shrink: 0;
}
.tbl-sec-btn {
    background: transparent;
    border: none;
    color: rgba(255,255,255,0.82);
    text-align: left;
    padding: 12px 14px;
    border-radius: 10px;
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.15s;
    -webkit-tap-highlight-color: transparent;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    letter-spacing: 0.03em;
}
.tbl-sec-btn:hover:not(.active) {
    background: rgba(255,255,255,0.08);
    color: #fff;
}
.tbl-sec-btn.active {
    background: var(--bg-card, #fff) !important;
    color: #2e1065 !important;
    font-weight: 800;
    box-shadow: 0 4px 14px rgba(0,0,0,0.2);
}
.tbl-sec-badge {
    background: rgba(255,255,255,0.18);
    color: inherit;
    border-radius: 8px;
    padding: 2px 8px;
    font-size: 0.72rem;
    font-weight: 700;
    min-width: 22px;
    text-align: center;
}
.tbl-sec-btn.active .tbl-sec-badge {
    background: rgba(74,29,149,0.12);
}
.tbl-sec-badge.danger { background: rgba(239,68,68,0.85); color: #fff; }
.tbl-sec-badge.success { background: rgba(16,185,129,0.85); color: #fff; }
.tbl-sec-badge.warning { background: rgba(245,158,11,0.85); color: #fff; }
.tbl-sec-btn.active .tbl-sec-badge.danger { background: #ef4444; }
.tbl-sec-btn.active .tbl-sec-badge.success { background: #10b981; }
.tbl-sec-btn.active .tbl-sec-badge.warning { background: #f59e0b; }
.tbl-sec-divider {
    height: 1px;
    background: rgba(255,255,255,0.12);
    margin: 8px 6px;
}

/* Eski filter-buttons / section-filters gizli (sidebar'da bunlar var) */
.tbl-shell ~ .filter-buttons,
.tbl-shell ~ .section-filters,
.tbl-shell + .filter-buttons,
.tbl-shell + .section-filters { display: none !important; }
body:has(.tbl-shell) > .filter-buttons,
body:has(.tbl-shell) > .section-filters { display: none !important; }

/* ─── Tablet 768-1200: kompakt ─── */
@media (max-width: 1199px) and (min-width: 768px) {
    .tbl-shell { grid-template-columns: 240px 1fr 150px; }
    .tbl-adisyon-item { padding: 10px 12px; gap: 8px; }
    .tbl-adisyon-num { width: 24px; height: 24px; font-size: 0.75rem; }
    .tbl-adisyon-name { font-size: 0.88rem; }
    .tbl-total-amount { font-size: 1.4rem; }
}

/* Masaüstünde mobil tab bar gizle */
.tbl-mobile-tabs { display: none; }

/* ─── Mobil (<768px): tek kolon stack ─── */
@media (max-width: 767px) {
    .tbl-shell {
        display: flex !important;
        flex-direction: column !important;
        height: 100% !important;
        max-height: 100% !important;
        overflow: hidden !important;
        padding: 0 !important;
        grid-template-columns: unset !important;
        grid-template-rows: unset !important;
    }
    .tbl-sections {
        order: -1 !important;
        flex-direction: row !important;
        flex-shrink: 0 !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        padding: 8px !important;
        gap: 6px !important;
        background: linear-gradient(135deg, #4c1d95, #2e1065) !important;
        border-radius: 0 !important;
    }
    .tbl-sec-title { display: none !important; }
    .tbl-sec-divider { display: none !important; }
    .tbl-sec-btn {
        flex-shrink: 0 !important;
        padding: 8px 12px !important;
        font-size: 0.78rem !important;
        white-space: nowrap !important;
    }
    /* ── Mobil tab bar ── */
    .tbl-mobile-tabs {
        display: flex !important;
        order: -2 !important;
        flex-shrink: 0 !important;
        background: var(--card-bg, #fff) !important;
        border-bottom: 1px solid var(--border-color, #e5e7eb) !important;
    }
    .tbl-mob-tab {
        flex: 1 !important;
        padding: 10px 8px !important;
        border: none !important;
        background: transparent !important;
        font-size: 0.85rem !important;
        font-weight: 600 !important;
        color: var(--text-secondary) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 4px !important;
        transition: all 0.15s !important;
        position: relative !important;
    }
    .tbl-mob-tab.active {
        color: var(--primary) !important;
        border-bottom: 2px solid var(--primary) !important;
    }
    .tbl-mob-tab-badge {
        background: #ef4444 !important;
        color: white !important;
        font-size: 0.7rem !important;
        min-width: 18px !important;
        height: 18px !important;
        border-radius: 9px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        padding: 0 5px !important;
        font-weight: 700 !important;
    }

    /* ── Masalar tab aktif ── */
    .tbl-grid-area {
        flex: 1 1 0 !important;
        min-height: 0 !important;
        order: 0 !important;
        overflow: hidden !important;
        border-radius: 0 !important;
    }
    .tbl-grid-scroll {
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch !important;
        height: 100% !important;
        padding: 8px !important;
    }
    .tbl-adisyons {
        order: 1 !important;
        flex: 1 1 0 !important;
        min-height: 0 !important;
        border-right: none !important;
        border-top: 1px solid var(--border-color, #e5e7eb) !important;
        display: flex !important;
        flex-direction: column !important;
        overflow: hidden !important;
        border-radius: 0 !important;
        max-height: none !important;
    }
    .tbl-adisyons .tbl-adisyons-list {
        flex: 1 1 0 !important;
        min-height: 0 !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch !important;
    }
    .tbl-adisyons .tbl-adisyons-total { flex-shrink: 0 !important; }
    .tbl-adisyons-head { padding: 10px 14px !important; flex-shrink: 0 !important; }
    .tbl-adisyon-item { padding: 10px 12px !important; }

    /* ── Tab switching: masalar tab ── */
    [data-mobile-tab="tables"] > .tbl-adisyons { display: none !important; }
    [data-mobile-tab="tables"] > .tbl-grid-area { display: flex !important; flex-direction: column !important; }

    /* ── Tab switching: adisyonlar tab ── */
    [data-mobile-tab="orders"] > .tbl-grid-area { display: none !important; }
    [data-mobile-tab="orders"] > .tbl-adisyons { display: flex !important; }
    [data-mobile-tab="orders"] > .tbl-sections { display: none !important; }
}


/* ─── Final mobile polish — pos-modern.css'e taşındı ─── */
/* ─── Tüm mobil layout blokları pos-modern.css'e taşındı ─── */

/* ─── iOS PWA safe area — alt kısım (home indicator) ─── */
/* Masalar: adisyon footer */
.tbl-adisyons-total {
    padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px));
}
/* Hızlı satış: ödeme butonları */
.qs-pay-bottom {
    padding-bottom: env(safe-area-inset-bottom, 0px);
}
/* Masalar: tab bar (mobil) */
.tbl-mobile-tabs {
    padding-bottom: 0; /* üstte, safe area gerekmez */
}
/* Sipariş/POS: alt butonlar */
.ml-pay-bar,
.ml-bottom-bar {
    padding-bottom: calc(8px + env(safe-area-inset-bottom, 0px));
}
/* PaymentPage: ödeme tipi butonları */
.payment-types {
    padding-bottom: env(safe-area-inset-bottom, 0px);
}
/* Dashboard */
.dash {
    padding-bottom: env(safe-area-inset-bottom, 0px);
}
/* Ayarlar */
.settings-container {
    padding-bottom: env(safe-area-inset-bottom, 0px);
}

/* ─── Dark mode polish — kart arka planları + metin renkleri ─── */
[data-theme="dark"] .ml-cart-header,
[data-theme="dark"] .order-header,
[data-theme="dark"] .filter-buttons {
    color: #fff !important;
}
[data-theme="dark"] .tbl-adisyons,
[data-theme="dark"] .ml-cart,
[data-theme="dark"] .ml-products,
[data-theme="dark"] .pos-products,
[data-theme="dark"] .payment-left,
[data-theme="dark"] .payment-right,
[data-theme="dark"] .pos-right-panel .cart-section,
[data-theme="dark"] .pos-right-panel .payment-section {
    background: var(--bg-card) !important;
    color: var(--text-primary) !important;
}
[data-theme="dark"] .cr3 {
    background: var(--bg-card) !important;
    border-bottom-color: var(--border-color) !important;
}
[data-theme="dark"] .cr3-name { color: var(--text-primary) !important; }
[data-theme="dark"] .cr3-desc { color: var(--text-muted) !important; }
[data-theme="dark"] .cr3-q { box-shadow: 0 2px 6px rgba(236,72,153,0.5); }

[data-theme="dark"] .ml-total-amount,
[data-theme="dark"] .tbl-total-amount,
[data-theme="dark"] .ml-row-price,
[data-theme="dark"] .tbl-adisyon-name,
[data-theme="dark"] .tbl-adisyon-amount {
    color: var(--text-primary) !important;
}

[data-theme="dark"] .prod-card {
    background: var(--bg-card) !important;
    border-color: var(--border-color) !important;
}
[data-theme="dark"] .prod-card-name { color: var(--text-primary) !important; }
[data-theme="dark"] .prod-card-img { background: var(--bg-tertiary) !important; }

[data-theme="dark"] .table-card:not(.occupied):not(.reserved):not(.cleaning) {
    background: var(--bg-card) !important;
    border-color: var(--border-color) !important;
    color: var(--text-primary) !important;
}
[data-theme="dark"] .table-card .table-name { color: var(--text-primary); }

[data-theme="dark"] .ml-cat-btn,
[data-theme="dark"] .qs-cat-btn,
[data-theme="dark"] .tbl-sec-btn { color: rgba(255,255,255,0.82); }

[data-theme="dark"] .ml-cat-btn.active,
[data-theme="dark"] .qs-cat-btn.active,
[data-theme="dark"] .tbl-sec-btn.active {
    background: var(--bg-card) !important;
    color: var(--primary) !important;
}

[data-theme="dark"] .numpad-btn,
[data-theme="dark"] .qs-pay-middle .numpad-btn,
[data-theme="dark"] .quick-btn,
[data-theme="dark"] .qs-pay-middle .quick-btn {
    background: var(--bg-tertiary) !important;
    color: var(--text-primary) !important;
    border-color: var(--border-color) !important;
}
