/* static/cafes/css/cafe-dashboard.css */
:root {
    --ink: #07080a;
    --ink2: #0d0f14;
    --glass: rgba(255,255,255,0.04);
    --glass2: rgba(255,255,255,0.07);
    --rim: rgba(255,255,255,0.07);
    --rim2: rgba(255,255,255,0.13);
    --gold: #c9a84c;
    --gold-lt: #e8c97a;
    --gold-dk: #7a5b1a;
    --gold-glow: rgba(201,168,76,0.22);
    --gold-dim: rgba(201,168,76,0.10);
    --emerald: #2ecc9a;
    --emerald-dim: rgba(46,204,154,0.10);
    --rose: #e8547a;
    --rose-dim: rgba(232,84,122,0.10);
    --sapphire: #5b9cf6;
    --sapphire-dim: rgba(91,156,246,0.10);
    --violet: #a78bfa;
    --violet-dim: rgba(167,139,250,0.10);
    --t1: #f0ede8;
    --t2: #9b9589;
    --t3: #5a5450;
    --r: 16px;
    --card-bg: #0d0f14;
    --card-shad: 0 8px 32px rgba(0,0,0,0.5);
    --chart-grid: rgba(255,255,255,0.04);
    --chart-tick: #5a5450;
    --body-bg: #07080a;
}

[data-theme="light"] {
    --ink: #f5f3ff;
    --ink2: #ffffff;
    --glass: rgba(255,255,255,0.72);
    --glass2: rgba(255,255,255,0.94);
    --rim: rgba(99,102,241,0.14);
    --rim2: rgba(99,102,241,0.28);
    --gold: #b45309;
    --gold-lt: #d97706;
    --gold-dk: #7c2d12;
    --gold-glow: rgba(180,83,9,0.2);
    --gold-dim: rgba(217,119,6,0.1);
    --emerald: #047857;
    --emerald-dim: rgba(4,120,87,0.1);
    --rose: #be123c;
    --rose-dim: rgba(190,18,60,0.1);
    --sapphire: #1d4ed8;
    --sapphire-dim: rgba(29,78,216,0.1);
    --violet: #6d28d9;
    --violet-dim: rgba(109,40,217,0.1);
    --t1: #1e1b4b;
    --t2: #3730a3;
    --t3: #818cf8;
    --card-bg: rgba(255,255,255,0.9);
    --card-shad: 0 4px 24px rgba(99,102,241,0.10), 0 1px 4px rgba(0,0,0,0.05);
    --chart-grid: rgba(99,102,241,0.07);
    --chart-tick: #818cf8;
    --body-bg: #f5f3ff;
}

[data-theme="vivid"] {
    --ink: #0a0b0f;
    --ink2: #0d0f14;
    --glass: rgba(10,11,15,0.70);
    --glass2: rgba(10,11,15,0.88);
    --rim: rgba(255,255,255,0.10);
    --rim2: rgba(255,255,255,0.20);
    --gold: #f59e0b;
    --gold-lt: #fcd34d;
    --gold-dk: #b45309;
    --gold-glow: rgba(245,158,11,0.35);
    --gold-dim: rgba(245,158,11,0.12);
    --emerald: #10b981;
    --emerald-dim: rgba(16,185,129,0.12);
    --rose: #f43f5e;
    --rose-dim: rgba(244,63,94,0.12);
    --sapphire: #60a5fa;
    --sapphire-dim: rgba(96,165,250,0.12);
    --violet: #c084fc;
    --violet-dim: rgba(192,132,252,0.12);
    --t1: #fff7ed;
    --t2: #fed7aa;
    --t3: #fdba74;
    --card-bg: rgba(10,11,15,0.78);
    --card-shad: 0 8px 36px rgba(0,0,0,0.50), 0 0 0 1px rgba(255,255,255,0.07);
    --chart-grid: rgba(255,255,255,0.05);
    --chart-tick: #fdba74;
    --body-bg: transparent;
}

body {
    background: var(--body-bg) !important;
    color: var(--t1);
}

[data-theme="vivid"] body {
    background: linear-gradient(135deg, #38165d 0%, #201447 45%, #111827 100%) fixed !important;
}

[data-theme="light"] .sidebar { background: #1e1b4b !important; border-color: rgba(99,102,241,0.2) !important; }
[data-theme="light"] .sidebar-toggle { background: #fff !important; border-color: rgba(99,102,241,0.2) !important; color: #6366f1 !important; }
[data-theme="light"] .nav-link-item { color: #818cf8 !important; }
[data-theme="light"] .nav-link-item:hover,
[data-theme="light"] .nav-link-item.active { color: #e0e7ff !important; background: rgba(99,102,241,0.18) !important; }
[data-theme="light"] .nav-section-label { color: #6366f1 !important; }
[data-theme="light"] .sidebar-logo .logo-text,
[data-theme="light"] .user-name { color: #e0e7ff !important; }
[data-theme="light"] .user-role { color: #818cf8 !important; }
[data-theme="vivid"] .sidebar,
[data-theme="vivid"] .sidebar-toggle { background-color: #0a0b0f !important; }
[data-theme="vivid"] .sidebar-logo .logo-text,
[data-theme="vivid"] .user-name { color: #ffffff !important; text-shadow: 0 1px 14px rgba(245,158,11,.35); }
[data-theme="vivid"] .logo-sub,
[data-theme="vivid"] .user-role { color: #fcd34d !important; }

@keyframes fadeUp { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:translateY(0); } }
@keyframes shimmerLine { 0% { background-position:-200% center; } 100% { background-position:200% center; } }
@keyframes growBar { from { transform:scaleX(0); } to { transform:scaleX(1); } }
.a1{animation:fadeUp .55s cubic-bezier(.22,1,.36,1) .05s both}.a2{animation:fadeUp .55s cubic-bezier(.22,1,.36,1) .13s both}.a3{animation:fadeUp .55s cubic-bezier(.22,1,.36,1) .21s both}.a4{animation:fadeUp .55s cubic-bezier(.22,1,.36,1) .29s both}

.app-topbar {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    margin-bottom: 1rem;
}
.theme-toggle {
    display: flex;
    align-items: center;
    background: var(--glass2);
    border: 1px solid var(--rim2);
    border-radius: 40px;
    padding: 4px;
    gap: 2px;
    backdrop-filter: blur(12px);
    box-shadow: var(--card-shad);
}
.tt-btn {
    display: inline-flex;
    align-items: center;
    gap: .38rem;
    padding: .38rem .85rem;
    border-radius: 30px;
    border: none;
    background: transparent;
    color: var(--t3);
    font-family: 'DM Sans', sans-serif;
    font-size: .73rem;
    font-weight: 700;
    letter-spacing: .04em;
    cursor: pointer;
    transition: color .25s, background .25s;
}
.tt-btn.active { color: var(--t1); background: var(--glass); }
.tt-btn[data-theme-target="dark"].active { background: rgba(201,168,76,0.12); color: var(--gold); }
.tt-btn[data-theme-target="light"].active { background: rgba(99,102,241,0.15); color: #6366f1; }
.tt-btn[data-theme-target="vivid"].active { background: rgba(192,132,252,0.18); color: #fcd34d; }

.dash-page { animation: fadeUp .45s cubic-bezier(.22,1,.36,1) both; }
.page-head {
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:1rem;
    margin-bottom:1.4rem;
    flex-wrap:wrap;
}
.page-title {
    margin: 0;
    font-weight: 800;
    font-size: 1.55rem;
    letter-spacing: -.04em;
    color: var(--t1);
}
.page-title em { font-style: normal; color: var(--gold); }
.page-sub { margin-top:.3rem; color:var(--t3); font-size:.82rem; }
.g-card {
    background: var(--card-bg);
    border:1px solid var(--rim);
    border-radius:var(--r);
    padding:1.4rem 1.5rem;
    position:relative;
    overflow:hidden;
    backdrop-filter:blur(12px);
    box-shadow: var(--card-shad);
    transition: background .3s, border-color .3s, box-shadow .3s, transform .25s;
}
.g-card:hover { border-color: var(--rim2); }
.g-title {
    font-weight:800;
    font-size:.95rem;
    color:var(--t1);
    margin-bottom:1.1rem;
    display:flex;
    align-items:center;
    gap:.5rem;
}
.gdot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.btn-luxe, .btn.btn-primary {
    background: linear-gradient(135deg, var(--gold-lt), var(--gold));
    border: 0 !important;
    color: #111827 !important;
    border-radius: 12px;
    font-weight: 800;
    box-shadow: 0 10px 26px var(--gold-glow);
}
.btn-luxe:hover, .btn.btn-primary:hover { filter: brightness(1.04); transform: translateY(-1px); }
.btn-ghost, .btn.btn-secondary {
    background: var(--glass2) !important;
    border: 1px solid var(--rim) !important;
    color: var(--t1) !important;
    border-radius: 12px;
    font-weight: 700;
}
.btn-outline-primary, .btn-outline-danger {
    border-color: var(--rim2) !important;
    color: var(--t2) !important;
    background: var(--glass) !important;
    border-radius: 10px !important;
}
.btn-outline-primary:hover { color: var(--sapphire) !important; }
.btn-outline-danger:hover { color: var(--rose) !important; }
.form-label { color: var(--t2); font-size:.75rem; font-weight:800; text-transform:uppercase; letter-spacing:.06em; }
.form-control, .form-select, .input-group-text {
    background: var(--glass2) !important;
    color: var(--t1) !important;
    border: 1px solid var(--rim) !important;
    border-radius: 12px !important;
}
.form-select option,
.form-control option,
select option {
    background: #0d0f14;
    color: #f0ede8;
}
[data-theme="light"] .form-select option,
[data-theme="light"] .form-control option,
[data-theme="light"] select option {
    background: #ffffff;
    color: #1e1b4b;
}
[data-theme="vivid"] .form-select option,
[data-theme="vivid"] .form-control option,
[data-theme="vivid"] select option {
    background: #0a0b0f;
    color: #fff7ed;
}
.dropdown-menu {
    background: var(--card-bg) !important;
    border: 1px solid var(--rim2) !important;
    box-shadow: var(--card-shad);
}
.dropdown-item {
    color: var(--t2) !important;
}
.dropdown-item:hover,
.dropdown-item:focus {
    color: var(--t1) !important;
    background: var(--glass2) !important;
}
.input-group .form-control { border-radius: 0 12px 12px 0 !important; }
.input-group .input-group-text { border-radius: 12px 0 0 12px !important; }
.form-control::placeholder { color: var(--t3) !important; }
.text-muted, small.text-muted { color: var(--t3) !important; }
.form-check-input { background-color: var(--glass2); border-color: var(--rim2); }
.form-check-input:checked { background-color: var(--gold); border-color: var(--gold); }
[data-theme="light"] input[type="date"] { color-scheme: light; }
[data-theme="light"] input[type="date"]::-webkit-calendar-picker-indicator { filter: invert(22%) sepia(76%) saturate(2482%) hue-rotate(230deg) brightness(84%) contrast(96%); opacity: 1; }
[data-theme="dark"] input[type="date"], input[type="date"] { color-scheme: dark; }
[data-theme="vivid"] input[type="date"] { color-scheme: dark; }
.alert-info {
    background: var(--sapphire-dim) !important;
    color: var(--t1) !important;
    border: 1px solid var(--rim) !important;
    border-radius: var(--r);
}
.category-grid { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:1rem; }
@media(max-width:1100px){ .category-grid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:700px){ .category-grid{grid-template-columns:1fr} }
.category-card { min-height: 170px; border-left: 4px solid var(--cat-color, var(--gold)); }
.category-card:hover { transform: translateY(-4px); }
.cat-icon {
    width:42px; height:42px; border-radius:14px;
    display:flex; align-items:center; justify-content:center;
    background: color-mix(in srgb, var(--cat-color, var(--gold)) 16%, transparent);
    color: var(--cat-color, var(--gold));
    font-size:1.05rem;
}
.cat-title { color: var(--t1); font-weight:800; font-size:1.02rem; margin:0; }
.cat-desc { color: var(--t3); font-size:.78rem; margin:.45rem 0 .75rem; min-height: 32px; }
.pill {
    display:inline-flex; align-items:center; gap:.28rem;
    padding:.22rem .6rem; border-radius:20px;
    font-size:.68rem; font-weight:800;
}
.pill-neutral { background:var(--glass2); color:var(--t2); }
.pill-green { background:var(--emerald-dim); color:var(--emerald); }
.pill-red { background:var(--rose-dim); color:var(--rose); }
.ce { color: var(--emerald) !important; }
.cr { color: var(--rose) !important; }
.empty-state { text-align:center; padding:2rem; }
.empty-state i { font-size:2rem; color:var(--sapphire); margin-bottom:.75rem; }

/* Order pages */
.order-page {
    animation: fadeUp .45s cubic-bezier(.22,1,.36,1) both;
}
.order-shell {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 340px;
    gap: 1rem;
    align-items: start;
}
.order-workspace {
    min-width: 0;
}
.order-summary-panel {
    position: sticky;
    top: 1rem;
}
.order-grid,
.product-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
    gap: 1rem;
}
.order-category,
.product-card,
.order-mini-card {
    color: var(--t1);
    font: inherit;
    text-decoration: none;
    background: var(--card-bg);
    border: 1px solid var(--rim);
    border-radius: var(--r);
    padding: 1rem;
    cursor: pointer;
    box-shadow: var(--card-shad);
    transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
    animation: fadeUp .45s cubic-bezier(.22,1,.36,1) both;
}
.order-category:hover,
.product-card:hover,
.order-mini-card:hover {
    transform: translateY(-4px);
    border-color: var(--rim2);
}
.order-category {
    border-top: 4px solid var(--cat-color, var(--gold));
    min-height: 178px;
    width: 100%;
}
.order-category-icon {
    width: 58px;
    height: 58px;
    margin: 0 auto .85rem;
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: color-mix(in srgb, var(--cat-color, var(--gold)) 18%, transparent);
    color: var(--cat-color, var(--gold));
    font-size: 1.55rem;
}
.order-category-icon img {
    width: 44px;
    height: 44px;
    object-fit: contain;
}
.order-card-title {
    color: var(--t1);
    font-weight: 800;
    margin: 0;
}
.order-card-meta {
    color: var(--t3);
    font-size: .78rem;
    margin: .4rem 0 .75rem;
}
.product-image {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: 12px;
    background: var(--glass);
}
.product-placeholder {
    width: 100%;
    aspect-ratio: 4 / 3;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--glass);
    color: var(--t3);
    font-weight: 800;
}
.search-container {
    position: relative;
}
.search-results {
    position: absolute;
    top: calc(100% + .45rem);
    left: 0;
    right: 0;
    display: none;
    z-index: 50;
    max-height: 320px;
    overflow: auto;
    background: var(--card-bg);
    border: 1px solid var(--rim2);
    border-radius: 14px;
    box-shadow: var(--card-shad);
    backdrop-filter: blur(14px);
}
.search-result-item {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .7rem .85rem;
    color: var(--t1);
    cursor: pointer;
    transition: background .18s ease;
}
.search-result-item:hover {
    background: var(--glass2);
}
.search-result-item img {
    width: 46px;
    height: 46px;
    border-radius: 10px;
    object-fit: cover;
}
.order-items-list {
    display: grid;
    gap: .75rem;
    margin: 1rem 0;
}
.order-line {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: .75rem;
    align-items: center;
    padding: .75rem;
    border: 1px solid var(--rim);
    border-radius: 14px;
    background: var(--glass);
    animation: fadeUp .28s cubic-bezier(.22,1,.36,1) both;
}
.order-line-name {
    color: var(--t1);
    font-weight: 800;
    line-height: 1.2;
}
.order-line-meta {
    color: var(--t3);
    font-size: .75rem;
    margin-top: .2rem;
}
.order-total-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    padding-top: 1rem;
    margin-top: 1rem;
    border-top: 1px solid var(--rim);
}
.order-total-row strong {
    color: var(--gold);
    font-size: 1.25rem;
}
.payment-toggle {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .5rem;
}
.payment-toggle .btn {
    border-radius: 12px !important;
    font-weight: 800;
}
.order-stat-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 1rem;
}
.order-stat {
    min-height: 128px;
}
.order-stat .stat-label {
    color: var(--t3);
    font-size: .72rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
}
.order-stat .stat-value {
    color: var(--t1);
    font-size: 1.45rem;
    font-weight: 800;
    margin-top: .45rem;
}
.order-table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--t2);
    --bs-table-border-color: var(--rim);
    --bs-table-striped-bg: var(--glass);
    --bs-table-striped-color: var(--t1);
    --bs-table-hover-bg: var(--glass2);
    --bs-table-hover-color: var(--t1);
    color: var(--t1);
    margin: 0;
    border-collapse: separate;
    border-spacing: 0 .45rem;
}
.order-page .table-responsive,
.g-card .table-responsive {
    border-radius: 16px;
    background:
        linear-gradient(180deg, var(--glass), transparent 46%),
        color-mix(in srgb, var(--card-bg) 82%, transparent);
    border: 1px solid var(--rim);
    padding: .35rem;
}
.g-card .table-responsive {
    overflow: auto;
}
.order-table thead th {
    color: var(--t3);
    font-size: .72rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    background: transparent !important;
    border: 0 !important;
    padding: .65rem .9rem;
}
.order-table > :not(caption) > * > * {
    color: inherit !important;
    box-shadow: none !important;
}
.order-table tbody td {
    color: var(--t2);
    background: color-mix(in srgb, var(--card-bg) 76%, transparent) !important;
    border-top: 1px solid var(--rim) !important;
    border-bottom: 1px solid var(--rim) !important;
    vertical-align: middle;
    padding: .85rem .9rem;
}
.order-table tbody tr td:first-child {
    border-left: 1px solid var(--rim) !important;
    border-radius: 14px 0 0 14px;
}
.order-table tbody tr td:last-child {
    border-right: 1px solid var(--rim) !important;
    border-radius: 0 14px 14px 0;
}
.order-table tbody tr:hover td {
    background: var(--glass2) !important;
    border-color: var(--rim2) !important;
}
.order-table tbody tr:hover {
    transform: translateY(-1px);
}
.table-subtext {
    color: var(--t3);
    font-size: .72rem;
    margin-top: .15rem;
}
.order-table code,
.dt code {
    color: var(--gold-lt);
    background: var(--gold-dim);
    border-radius: 8px;
    padding: .12rem .35rem;
}
.order-row {
    transition: background .18s ease, transform .18s ease;
}
.order-row:hover {
    background: transparent;
}
.status-badge,
.order-badge {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .32rem .65rem;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 800;
}
.status-completed { background: var(--emerald-dim); color: var(--emerald); }
.status-pending { background: var(--gold-dim); color: var(--gold-lt); }
.status-refunded { background: var(--sapphire-dim); color: var(--sapphire); }
.status-failed { background: var(--rose-dim); color: var(--rose); }
.order-badge-card { background: var(--sapphire-dim); color: var(--sapphire); }
.order-badge-cash { background: var(--emerald-dim); color: var(--emerald); }
.order-modal .modal-content,
.modal-content.order-modal-content {
    background: var(--card-bg);
    color: var(--t1);
    border: 1px solid var(--rim2);
    border-radius: var(--r);
    box-shadow: var(--card-shad);
}
.order-modal .modal-header,
.order-modal .modal-footer,
.modal-content.order-modal-content .modal-header,
.modal-content.order-modal-content .modal-footer {
    border-color: var(--rim);
}
.order-modal .btn-close,
.modal-content.order-modal-content .btn-close {
    filter: invert(1) grayscale(1);
    opacity: .75;
}
.alert-warning {
    background: var(--gold-dim) !important;
    color: var(--t1) !important;
    border: 1px solid var(--rim2) !important;
    border-radius: var(--r);
}
.pagination .page-link {
    background: var(--glass2);
    border-color: var(--rim);
    color: var(--t2);
}
.pagination .page-item.active .page-link {
    background: var(--gold);
    border-color: var(--gold);
    color: #111827;
    font-weight: 800;
}
.order-status-hero {
    max-width: 860px;
    margin: 0 auto;
}
.order-id-display {
    display: inline-flex;
    align-items: center;
    gap: .6rem;
    padding: .8rem 1rem;
    border-radius: 16px;
    background: var(--gold-dim);
    color: var(--gold-lt);
    font-size: 1.6rem;
    font-weight: 800;
    box-shadow: 0 0 26px var(--gold-glow);
}
.status-orb {
    width: 112px;
    height: 112px;
    margin: 1.4rem auto;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: var(--glass2);
    border: 1px solid var(--rim2);
    box-shadow: var(--card-shad);
    animation: pulseSoft 1.8s ease-in-out infinite;
}
.status-orb i {
    font-size: 3.4rem;
}
@keyframes pulseSoft {
    0%, 100% { transform: scale(1); box-shadow: var(--card-shad); }
    50% { transform: scale(1.035); box-shadow: 0 0 34px var(--gold-glow); }
}
.detail-list {
    display: grid;
    gap: .65rem;
}
.detail-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    color: var(--t2);
}
.detail-row span:first-child {
    color: var(--t3);
}
.order-empty {
    text-align: center;
    color: var(--t3);
    padding: 1.2rem;
    border: 1px dashed var(--rim2);
    border-radius: 14px;
    background: var(--glass);
}
@media (max-width: 1180px) {
    .order-shell {
        grid-template-columns: 1fr;
    }
    .order-summary-panel {
        position: static;
    }
    .order-stat-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 720px) {
    .order-grid,
    .product-grid,
    .order-stat-grid {
        grid-template-columns: 1fr;
    }
    .order-id-display {
        font-size: 1.2rem;
    }
}

/* Product and coupon management */
.menu-page {
    animation: fadeUp .45s cubic-bezier(.22,1,.36,1) both;
}
.menu-stat-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
}
.menu-stat {
    min-height: 112px;
}
.menu-stat-label {
    color: var(--t3);
    font-size: .7rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .08em;
}
.menu-stat-value {
    color: var(--t1);
    font-size: 1.35rem;
    font-weight: 800;
    margin-top: .4rem;
}
.menu-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 1rem;
}
.menu-card {
    min-height: 100%;
    border-top: 3px solid var(--card-accent, var(--gold));
}
.menu-card:hover {
    transform: translateY(-3px);
}
.menu-card-top {
    display: flex;
    gap: .9rem;
    align-items: flex-start;
}
.menu-thumb {
    width: 72px;
    height: 72px;
    border-radius: 16px;
    object-fit: cover;
    flex-shrink: 0;
    border: 1px solid var(--rim);
    background: var(--glass2);
}
.menu-thumb-placeholder {
    width: 72px;
    height: 72px;
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--t3);
    border: 1px solid var(--rim);
    background: var(--glass2);
}
.menu-title {
    color: var(--t1);
    font-weight: 800;
    font-size: 1rem;
    margin: 0;
    line-height: 1.2;
}
.menu-meta {
    color: var(--t3);
    font-size: .76rem;
    margin-top: .28rem;
}
.menu-price-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .65rem;
    margin-top: 1rem;
}
.menu-price-box {
    border: 1px solid var(--rim);
    border-radius: 14px;
    background: var(--glass);
    padding: .65rem;
}
.menu-price-label {
    color: var(--t3);
    font-size: .65rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .07em;
}
.menu-price-value {
    color: var(--t1);
    font-weight: 800;
    margin-top: .2rem;
}
.menu-card-actions {
    display: flex;
    justify-content: flex-end;
    gap: .45rem;
    margin-top: 1rem;
    padding-top: .9rem;
    border-top: 1px solid var(--rim);
}
.form-shell {
    max-width: 980px;
    margin: 0 auto;
}
.form-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(280px, .65fr);
    gap: 1rem;
    align-items: start;
}
.form-section {
    display: grid;
    gap: 1rem;
}
.form-panel {
    display: grid;
    gap: 1rem;
}
.field-hint,
.form-text {
    color: var(--t3) !important;
    font-size: .75rem;
}
.live-metric-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .65rem;
}
.live-metric {
    padding: .85rem;
    border-radius: 14px;
    border: 1px solid var(--rim);
    background: var(--glass);
    text-align: center;
}
.live-metric-label {
    color: var(--t3);
    font-size: .68rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .06em;
}
.live-metric-value {
    color: var(--t1);
    font-weight: 800;
    margin-top: .25rem;
}
.image-preview {
    width: 100%;
    max-height: 220px;
    object-fit: cover;
    border-radius: 16px;
    border: 1px solid var(--rim);
    background: var(--glass2);
}
.coupon-code {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    color: var(--gold-lt);
    background: var(--gold-dim);
    border: 1px solid var(--rim);
    border-radius: 12px;
    padding: .35rem .55rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
    font-weight: 800;
}
.product-picker {
    max-height: 340px;
    overflow: auto;
    display: grid;
    gap: .55rem;
    padding-right: .25rem;
}
.product-choice {
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: .7rem;
    border: 1px solid var(--rim);
    border-radius: 14px;
    background: var(--glass);
    cursor: pointer;
    transition: border-color .2s, background .2s, transform .2s;
}
.product-choice:hover {
    border-color: var(--rim2);
    background: var(--glass2);
    transform: translateY(-1px);
}
.product-choice .form-check-input {
    margin: 0;
    flex-shrink: 0;
}
.product-choice-title {
    color: var(--t1);
    font-weight: 800;
    line-height: 1.2;
}
.product-choice-meta {
    color: var(--t3);
    font-size: .74rem;
}
.switch-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: .85rem;
    border: 1px solid var(--rim);
    border-radius: 14px;
    background: var(--glass);
}
.switch-row .form-check {
    margin: 0;
}
.inventory-nav {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-bottom: 1rem;
}
.inventory-nav .btn {
    border-radius: 999px;
}
.inventory-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 1rem;
}
.inventory-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem;
}
.recipe-row {
    padding: .75rem;
    border: 1px solid var(--rim);
    border-radius: 14px;
    background: var(--glass);
}
.chart-panel {
    min-height: 300px;
}
.chart-panel canvas {
    max-height: 260px;
}
.finance-grid-2 {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(280px, .8fr);
    gap: 1rem;
    align-items: start;
}
.finance-filter-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: .85rem;
    align-items: end;
}
.finance-filter-grid.finance-sales-filter {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}
.finance-detail-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .75rem;
}
.finance-detail {
    padding: .75rem;
    border: 1px solid var(--rim);
    border-radius: 14px;
    background: var(--glass);
}
.finance-detail-label {
    color: var(--t3);
    font-size: .68rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .07em;
}
.finance-detail-value {
    color: var(--t1);
    font-weight: 800;
    margin-top: .25rem;
    overflow-wrap: anywhere;
}
.finance-summary {
    display: grid;
    gap: .6rem;
    padding: .85rem;
    border: 1px solid var(--rim);
    border-radius: 16px;
    background: var(--glass);
}
.finance-summary-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    color: var(--t2);
}
.finance-summary-row span:first-child {
    color: var(--t3);
}
.modal-content {
    background: var(--card-bg) !important;
    color: var(--t1) !important;
    border: 1px solid var(--rim2) !important;
    border-radius: var(--r) !important;
    box-shadow: var(--card-shad);
}
.modal-header,
.modal-footer {
    border-color: var(--rim) !important;
}
.btn-close {
    filter: invert(1) grayscale(1);
    opacity: .75;
}
[data-theme="light"] .btn-close {
    filter: none;
}
.finance-note {
    color: var(--t2);
    background: var(--glass);
    border: 1px solid var(--rim);
    border-radius: 14px;
    padding: .8rem;
    white-space: pre-wrap;
}
.account-shell {
    max-width: 1180px;
    margin: 0 auto;
}
.account-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(300px, .65fr);
    gap: 1rem;
    align-items: start;
}
.account-panel {
    display: grid;
    gap: 1rem;
}
.account-avatar {
    width: 132px;
    height: 132px;
    border-radius: 26px;
    border: 1px solid var(--rim2);
    background: var(--glass2);
    object-fit: cover;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--t3);
    font-size: 3rem;
    box-shadow: var(--card-shad);
}
.account-upload {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .4rem;
    margin-top: .85rem;
}
.account-stat-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: .75rem;
}
.account-mini-stat {
    padding: .85rem;
    border: 1px solid var(--rim);
    border-radius: 14px;
    background: var(--glass);
    text-align: center;
}
.account-mini-stat strong {
    color: var(--t1);
    display: block;
    font-size: 1.25rem;
}
.account-mini-stat span {
    color: var(--t3);
    font-size: .7rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .06em;
}
.settings-days {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}
.settings-days .btn {
    border-radius: 999px !important;
}
.danger-panel {
    border-color: color-mix(in srgb, var(--rose) 42%, var(--rim)) !important;
}
.danger-panel .g-title,
.danger-panel p {
    color: var(--rose);
}
.auth-page {
    min-height: 100vh;
    display: grid;
    place-items: center;
    padding: 2rem;
    background: var(--body-bg);
    color: var(--t1);
}
[data-theme="vivid"] .auth-page {
    background: linear-gradient(135deg, #38165d 0%, #201447 45%, #111827 100%) fixed;
}
.auth-card {
    width: min(100%, 440px);
}
.auth-brand {
    display: flex;
    align-items: center;
    gap: .85rem;
    margin-bottom: 1.2rem;
}
.auth-mark {
    width: 52px;
    height: 52px;
    border-radius: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--gold-dim);
    color: var(--gold-lt);
    border: 1px solid var(--rim2);
    font-size: 1.4rem;
}
.auth-title {
    margin: 0;
    color: var(--t1);
    font-size: 1.45rem;
    font-weight: 900;
    letter-spacing: -.04em;
}
.auth-sub {
    color: var(--t3);
    font-size: .82rem;
    margin-top: .15rem;
}
.auth-card input,
.auth-card select,
.auth-card textarea {
    background: var(--glass2) !important;
    color: var(--t1) !important;
    border: 1px solid var(--rim) !important;
    border-radius: 12px !important;
    width: 100%;
    padding: .65rem .85rem;
}
@media (max-width: 1180px) {
    .menu-stat-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .form-grid {
        grid-template-columns: 1fr;
    }
    .finance-grid-2,
    .finance-filter-grid,
    .account-grid {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 700px) {
    .menu-stat-grid,
    .menu-price-row,
    .live-metric-grid,
    .finance-detail-grid,
    .account-stat-grid {
        grid-template-columns: 1fr;
    }
}
