/* ==========================================================================
   M'Burger POS - Point of Sale Stylesheet
   Full-screen dark theme matching M'Burger palette.
   ========================================================================== */

/* ===== VARIABLES ===== */
:root {
    --pos-bg: #1a1614;
    --pos-bg-warm: #242020;
    --pos-bg-soft: #2e2a28;
    --pos-bg-card: #302c2a;
    --pos-bg-hover: #3a3634;
    --pos-border: rgba(255, 255, 255, 0.08);
    --pos-border-light: rgba(255, 255, 255, 0.12);

    --pos-text: rgba(255, 255, 255, 0.95);
    --pos-text-soft: rgba(255, 255, 255, 0.70);
    --pos-text-muted: rgba(255, 255, 255, 0.45);

    --pos-brown: #8b7355;
    --pos-brown-light: #a68b6a;
    --pos-accent: #c8a090;
    --pos-mustard: #d4a94b;
    --pos-cream: #faf8f5;

    --pos-success: #7a9a6a;
    --pos-success-bg: rgba(122, 154, 106, 0.15);
    --pos-warning: #d4a94b;
    --pos-warning-bg: rgba(212, 169, 75, 0.15);
    --pos-danger: #c46a5a;
    --pos-danger-bg: rgba(196, 106, 90, 0.15);
    --pos-info: #6a8fc4;
    --pos-info-bg: rgba(106, 143, 196, 0.15);

    --pos-new: #d4a94b;
    --pos-preparing: #6a8fc4;
    --pos-ready: #7a9a6a;
    --pos-completed: rgba(255, 255, 255, 0.3);

    --pos-radius: 8px;
    --pos-radius-lg: 12px;
    --pos-radius-sm: 4px;

    --pos-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    --pos-transition: 200ms ease;
    --pos-font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

    --pos-topbar-h: 60px;
}

/* ===== RESET ===== */
.mburger-pos-body {
    margin: 0;
    padding: 0;
    font-family: var(--pos-font);
    font-size: 14px;
    line-height: 1.5;
    color: var(--pos-text);
    background: var(--pos-bg);
    overflow: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.mburger-pos-body *,
.mburger-pos-body *::before,
.mburger-pos-body *::after {
    box-sizing: border-box;
}

/* Hide WP admin bar on POS */
.mburger-pos-body #wpadminbar {
    display: none !important;
}
.mburger-pos-body {
    margin-top: 0 !important;
}

/* ===== ICONS ===== */
.pos-icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
}

/* ==========================================================================
   LOGIN SCREEN
   ========================================================================== */

.pos-login {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    min-height: 100dvh;
    padding: 20px;
    background:
        radial-gradient(ellipse at 30% 20%, rgba(139, 115, 85, 0.08) 0%, transparent 60%),
        radial-gradient(ellipse at 70% 80%, rgba(200, 160, 144, 0.06) 0%, transparent 60%),
        var(--pos-bg);
}

.pos-login__card {
    width: 100%;
    max-width: 400px;
    background: var(--pos-bg-warm);
    border-radius: var(--pos-radius-lg);
    border: 1px solid var(--pos-border);
    padding: 40px 32px;
    box-shadow: var(--pos-shadow);
}

.pos-login__logo {
    text-align: center;
    margin-bottom: 36px;
}

.pos-login__brand {
    display: block;
    font-size: 32px;
    font-weight: 700;
    color: var(--pos-cream);
    letter-spacing: -0.02em;
}

.pos-login__sub {
    display: block;
    font-size: 13px;
    color: var(--pos-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-top: 4px;
}

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

.pos-login__error {
    background: var(--pos-danger-bg);
    color: var(--pos-danger);
    padding: 10px 14px;
    border-radius: var(--pos-radius-sm);
    font-size: 13px;
    border: 1px solid rgba(196, 106, 90, 0.3);
}

.pos-login__footer {
    text-align: center;
    font-size: 12px;
    color: var(--pos-text-muted);
    margin-top: 28px;
}

/* ===== FORM FIELDS ===== */
.pos-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.pos-field label {
    font-size: 12px;
    font-weight: 600;
    color: var(--pos-text-soft);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.pos-field input,
.pos-field select,
.pos-field textarea {
    width: 100%;
    padding: 12px 14px;
    background: var(--pos-bg-soft);
    border: 1px solid var(--pos-border-light);
    border-radius: var(--pos-radius);
    color: var(--pos-text);
    font-family: var(--pos-font);
    font-size: 15px;
    transition: border-color var(--pos-transition), box-shadow var(--pos-transition);
    outline: none;
}

.pos-field input::placeholder {
    color: var(--pos-text-muted);
}

.pos-field input:focus,
.pos-field select:focus {
    border-color: var(--pos-brown-light);
    box-shadow: 0 0 0 3px rgba(139, 115, 85, 0.2);
}

.pos-field select {
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='rgba(255,255,255,0.5)'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    padding-right: 36px;
}

.pos-field select option {
    background: var(--pos-bg-warm);
    color: var(--pos-text);
}

.pos-field__separator {
    text-align: center;
    color: var(--pos-text-muted);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin: 4px 0;
}

/* ===== BUTTONS ===== */
.pos-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 18px;
    border: 1px solid transparent;
    border-radius: var(--pos-radius);
    font-family: var(--pos-font);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--pos-transition);
    outline: none;
    white-space: nowrap;
    position: relative;
    text-decoration: none;
}

.pos-btn:active {
    transform: scale(0.97);
}

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

.pos-btn--primary {
    background: var(--pos-brown);
    color: var(--pos-cream);
    border-color: var(--pos-brown);
}
.pos-btn--primary:hover:not(:disabled) {
    background: var(--pos-brown-light);
    border-color: var(--pos-brown-light);
}

.pos-btn--secondary {
    background: var(--pos-bg-soft);
    color: var(--pos-text);
    border-color: var(--pos-border-light);
}
.pos-btn--secondary:hover:not(:disabled) {
    background: var(--pos-bg-hover);
}

.pos-btn--danger {
    background: var(--pos-danger-bg);
    color: var(--pos-danger);
    border-color: rgba(196, 106, 90, 0.3);
}
.pos-btn--danger:hover:not(:disabled) {
    background: rgba(196, 106, 90, 0.25);
}

.pos-btn--outline {
    background: transparent;
    color: var(--pos-text-soft);
    border-color: var(--pos-border-light);
}
.pos-btn--outline:hover:not(:disabled) {
    background: var(--pos-bg-soft);
    color: var(--pos-text);
    border-color: var(--pos-brown);
}

.pos-btn--full {
    width: 100%;
}

.pos-btn--sm {
    padding: 6px 12px;
    font-size: 12px;
    border-radius: var(--pos-radius-sm);
}

.pos-btn--icon {
    padding: 8px;
    background: var(--pos-bg-soft);
    color: var(--pos-text-soft);
    border-color: var(--pos-border);
}
.pos-btn--icon:hover:not(:disabled) {
    background: var(--pos-bg-hover);
    color: var(--pos-text);
}

.pos-btn--active {
    background: var(--pos-warning-bg) !important;
    color: var(--pos-warning) !important;
    border-color: rgba(212, 169, 75, 0.3) !important;
}

.pos-btn--loading .pos-btn__text { visibility: hidden; }
.pos-btn--loading .pos-btn__loader { display: inline-block !important; }

.pos-btn__loader {
    width: 18px;
    height: 18px;
    border: 2px solid rgba(255, 255, 255, 0.2);
    border-top-color: var(--pos-cream);
    border-radius: 50%;
    animation: pos-spin 0.6s linear infinite;
    position: absolute;
}

.pos-btn__badge {
    position: absolute;
    top: -6px;
    right: -6px;
    font-size: 9px;
    font-weight: 700;
    padding: 2px 5px;
    border-radius: 10px;
    background: var(--pos-warning);
    color: var(--pos-bg);
    letter-spacing: 0.04em;
}

/* Order action buttons */
.pos-btn--accept {
    background: var(--pos-success-bg);
    color: var(--pos-success);
    border-color: rgba(122, 154, 106, 0.3);
}
.pos-btn--accept:hover:not(:disabled) {
    background: rgba(122, 154, 106, 0.3);
}

.pos-btn--refuse {
    background: var(--pos-danger-bg);
    color: var(--pos-danger);
    border-color: rgba(196, 106, 90, 0.3);
}
.pos-btn--refuse:hover:not(:disabled) {
    background: rgba(196, 106, 90, 0.3);
}

.pos-btn--ready {
    background: var(--pos-success-bg);
    color: var(--pos-success);
    border-color: rgba(122, 154, 106, 0.3);
}
.pos-btn--ready:hover:not(:disabled) {
    background: rgba(122, 154, 106, 0.3);
}

.pos-btn--complete {
    background: rgba(255, 255, 255, 0.06);
    color: var(--pos-text-soft);
    border-color: var(--pos-border-light);
}
.pos-btn--complete:hover:not(:disabled) {
    background: rgba(255, 255, 255, 0.12);
    color: var(--pos-text);
}

.pos-btn--delay {
    background: var(--pos-warning-bg);
    color: var(--pos-warning);
    border-color: rgba(212, 169, 75, 0.3);
}
.pos-btn--delay:hover:not(:disabled) {
    background: rgba(212, 169, 75, 0.3);
}

.pos-btn--credit {
    background: var(--pos-info-bg);
    color: var(--pos-info);
    border-color: rgba(106, 143, 196, 0.3);
}
.pos-btn--credit:hover:not(:disabled) {
    background: rgba(106, 143, 196, 0.3);
}

.pos-btn--problem {
    background: var(--pos-danger-bg);
    color: var(--pos-danger);
    border-color: rgba(196, 106, 90, 0.3);
}
.pos-btn--problem:hover:not(:disabled) {
    background: rgba(196, 106, 90, 0.3);
}

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

/* ==========================================================================
   MAIN APP LAYOUT
   ========================================================================== */

.pos-app {
    display: flex;
    flex-direction: column;
    height: 100vh;
    height: 100dvh;
    overflow: hidden;
}

/* ===== TOP BAR ===== */
.pos-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: var(--pos-topbar-h);
    padding: 0 16px;
    background: var(--pos-bg-warm);
    border-bottom: 1px solid var(--pos-border);
    flex-shrink: 0;
    z-index: 10;
}

.pos-topbar__left {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.pos-topbar__brand {
    font-size: 20px;
    font-weight: 800;
    color: var(--pos-mustard);
    letter-spacing: -0.03em;
    flex-shrink: 0;
}

.pos-topbar__logo {
    height: 32px;
    width: auto;
    flex-shrink: 0;
    opacity: 0.9;
}

.pos-topbar__restaurant {
    font-size: 15px;
    font-weight: 600;
    color: var(--pos-text);
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.pos-topbar__center {
    display: flex;
    align-items: center;
    gap: 24px;
}

.pos-topbar__stats {
    display: flex;
    gap: 16px;
}

.pos-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1px;
}

.pos-stat__count {
    font-size: 20px;
    font-weight: 700;
    color: var(--pos-text);
    line-height: 1;
}

.pos-stat__label {
    font-size: 10px;
    color: var(--pos-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.pos-stat[data-stat="pending"] .pos-stat__count { color: var(--pos-new); }
.pos-stat[data-stat="preparing"] .pos-stat__count { color: var(--pos-preparing); }
.pos-stat[data-stat="ready"] .pos-stat__count { color: var(--pos-ready); }

.pos-topbar__revenue {
    font-size: 13px;
    color: var(--pos-text-soft);
}
.pos-topbar__revenue strong {
    color: var(--pos-success);
    font-weight: 700;
}

.pos-topbar__right {
    display: flex;
    align-items: center;
    gap: 8px;
}

.pos-topbar__clock {
    font-size: 13px;
    color: var(--pos-text-muted);
    font-variant-numeric: tabular-nums;
    margin-right: 8px;
}

/* ==========================================================================
   KANBAN BOARD
   ========================================================================== */

.pos-kanban {
    display: flex;
    flex: 1;
    gap: 0;
    overflow: hidden;
}

.pos-column {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
    border-right: 1px solid var(--pos-border);
}

.pos-column:last-child {
    border-right: none;
}

.pos-column__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    background: var(--pos-bg-warm);
    border-bottom: 1px solid var(--pos-border);
    flex-shrink: 0;
}

.pos-column__title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 700;
    color: var(--pos-text);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin: 0;
}

.pos-column__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

.pos-column--new .pos-column__dot { background: var(--pos-new); }
.pos-column--preparing .pos-column__dot { background: var(--pos-preparing); }
.pos-column--ready .pos-column__dot { background: var(--pos-ready); }
.pos-column--completed .pos-column__dot { background: var(--pos-completed); }

.pos-column__count {
    font-size: 12px;
    font-weight: 700;
    color: var(--pos-text-muted);
    background: var(--pos-bg-soft);
    padding: 2px 8px;
    border-radius: 10px;
    min-width: 24px;
    text-align: center;
}

.pos-column__body {
    flex: 1;
    overflow-y: auto;
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* Scrollbar styling */
.pos-column__body::-webkit-scrollbar {
    width: 4px;
}
.pos-column__body::-webkit-scrollbar-track {
    background: transparent;
}
.pos-column__body::-webkit-scrollbar-thumb {
    background: var(--pos-border-light);
    border-radius: 4px;
}

/* ==========================================================================
   ORDER CARDS
   ========================================================================== */

.pos-card {
    background: var(--pos-bg-card);
    border-radius: var(--pos-radius);
    border: 1px solid var(--pos-border);
    overflow: visible;
    transition: box-shadow var(--pos-transition), border-color var(--pos-transition);
    animation: pos-card-in 0.3s ease;
}

.pos-card:hover {
    border-color: var(--pos-border-light);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.2);
}

/* Status-specific left border */
.pos-card--processing { border-left: 3px solid var(--pos-new); }
.pos-card--preparing { border-left: 3px solid var(--pos-preparing); }
.pos-card--ready { border-left: 3px solid var(--pos-ready); }
.pos-card--completed {
    border-left: 3px solid var(--pos-completed);
    opacity: 0.65;
}

@keyframes pos-card-in {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.pos-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 12px 6px;
    gap: 8px;
}

.pos-card__number {
    font-size: 15px;
    font-weight: 800;
    color: var(--pos-text);
    font-variant-numeric: tabular-nums;
}

.pos-card__time {
    font-size: 12px;
    color: var(--pos-text-muted);
    font-variant-numeric: tabular-nums;
}

.pos-card__timer {
    font-size: 11px;
    font-weight: 700;
    color: var(--pos-preparing);
    background: var(--pos-info-bg);
    padding: 2px 8px;
    border-radius: 10px;
}

.pos-card__timer--urgent {
    color: var(--pos-danger);
    background: var(--pos-danger-bg);
    animation: pos-pulse 1s infinite;
}

@keyframes pos-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

.pos-card__badge {
    margin: 0 12px 6px;
    display: inline-block;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 3px 8px;
    border-radius: 4px;
}

.pos-card__badge--dinein {
    background: rgba(122, 154, 106, 0.2);
    color: var(--pos-success);
    border: 1px solid rgba(122, 154, 106, 0.3);
}

.pos-card__badge--takeaway {
    background: var(--pos-info-bg);
    color: var(--pos-info);
    border: 1px solid rgba(106, 143, 196, 0.3);
}

.pos-card__customer {
    padding: 0 12px 8px;
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.pos-card__customer strong {
    font-size: 13px;
    font-weight: 600;
    color: var(--pos-text);
}

.pos-card__customer span {
    font-size: 11px;
    color: var(--pos-text-muted);
}

.pos-card__pickup {
    padding: 0 12px 6px;
    font-size: 11px;
    color: var(--pos-mustard);
    font-weight: 600;
}

.pos-card__items {
    padding: 0 12px;
    border-top: 1px solid var(--pos-border);
    padding-top: 8px;
}

.pos-card__item {
    display: flex;
    align-items: baseline;
    gap: 6px;
    padding: 3px 0;
    font-size: 12px;
    flex-wrap: wrap;
}

.pos-card__qty {
    font-weight: 700;
    color: var(--pos-text-soft);
    min-width: 22px;
}

.pos-card__name {
    flex: 1;
    color: var(--pos-text);
    font-weight: 500;
}

.pos-card__price {
    font-variant-numeric: tabular-nums;
    color: var(--pos-text-muted);
    font-size: 11px;
}

.pos-card__cuisson {
    display: inline-block;
    padding: 1px 8px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    background: rgba(212, 169, 75, 0.15);
    color: var(--pos-accent);
    margin-left: 4px;
}

.pos-card__supps {
    width: 100%;
    padding-left: 28px;
    font-size: 11px;
    color: var(--pos-accent);
    font-style: italic;
}

.pos-card__notes {
    padding: 6px 12px;
    font-size: 11px;
    color: var(--pos-warning);
    font-style: italic;
    border-top: 1px dashed var(--pos-border);
}

.pos-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 12px;
    border-top: 1px solid var(--pos-border);
    margin-top: 6px;
}

.pos-card__total {
    font-size: 16px;
    font-weight: 800;
    color: var(--pos-cream);
}

.pos-card__actions {
    display: flex;
    gap: 6px;
}

/* ==========================================================================
   SIDEBAR (Clients)
   ========================================================================== */

.pos-sidebar {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: 380px;
    max-width: 100vw;
    background: var(--pos-bg-warm);
    border-left: 1px solid var(--pos-border);
    display: flex;
    flex-direction: column;
    z-index: 50;
    box-shadow: -4px 0 24px rgba(0, 0, 0, 0.3);
    animation: pos-slide-in 0.3s ease;
}

@keyframes pos-slide-in {
    from { transform: translateX(100%); }
    to { transform: translateX(0); }
}

.pos-sidebar__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--pos-border);
    flex-shrink: 0;
}

.pos-sidebar__header h2 {
    font-size: 16px;
    font-weight: 700;
    margin: 0;
    color: var(--pos-text);
}

.pos-sidebar__search {
    padding: 12px 20px;
    border-bottom: 1px solid var(--pos-border);
    flex-shrink: 0;
}

.pos-sidebar__search input {
    width: 100%;
    padding: 10px 14px;
    background: var(--pos-bg-soft);
    border: 1px solid var(--pos-border-light);
    border-radius: var(--pos-radius);
    color: var(--pos-text);
    font-family: var(--pos-font);
    font-size: 14px;
    outline: none;
}

.pos-sidebar__search input:focus {
    border-color: var(--pos-brown-light);
}

.pos-sidebar__body {
    flex: 1;
    overflow-y: auto;
    padding: 12px 20px;
}

.pos-sidebar__empty {
    color: var(--pos-text-muted);
    font-size: 13px;
    text-align: center;
    padding: 32px 0;
}

/* Client card */
.pos-client-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    background: var(--pos-bg-soft);
    border-radius: var(--pos-radius);
    margin-bottom: 8px;
    border: 1px solid var(--pos-border);
}

.pos-client-card__info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.pos-client-card__info strong {
    font-size: 13px;
    font-weight: 600;
    color: var(--pos-text);
}

.pos-client-card__info span {
    font-size: 11px;
    color: var(--pos-text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.pos-client-card__points {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex-shrink: 0;
}

.pos-client-card__pts {
    font-size: 18px;
    font-weight: 800;
    color: var(--pos-mustard);
    line-height: 1;
}

.pos-client-card__label {
    font-size: 10px;
    color: var(--pos-text-muted);
    text-transform: uppercase;
}

/* ==========================================================================
   MODALS
   ========================================================================== */

.pos-modal {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 100;
    padding: 20px;
}

.pos-modal__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(4px);
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.pos-modal--visible .pos-modal__overlay {
    opacity: 1;
}

.pos-modal__content {
    position: relative;
    width: 100%;
    max-width: 480px;
    max-height: 90vh;
    background: var(--pos-bg-warm);
    border-radius: var(--pos-radius-lg);
    border: 1px solid var(--pos-border);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transform: scale(0.95) translateY(10px);
    opacity: 0;
    transition: transform 0.3s ease, opacity 0.3s ease;
}

.pos-modal--visible .pos-modal__content {
    transform: scale(1) translateY(0);
    opacity: 1;
}

.pos-modal__content--sm {
    max-width: 380px;
}

.pos-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px 12px;
    flex-shrink: 0;
}

.pos-modal__header h2 {
    font-size: 18px;
    font-weight: 700;
    margin: 0;
    color: var(--pos-text);
}

.pos-modal__subtitle {
    font-size: 14px;
    color: var(--pos-text-soft);
    margin: 0 0 12px;
    font-weight: 600;
}

.pos-modal__body {
    padding: 12px 24px 24px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* Rush options */
.pos-rush__options {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
}

.pos-rush__current {
    text-align: center;
    font-size: 13px;
    color: var(--pos-text-muted);
    margin-top: 4px;
}
.pos-rush__current strong {
    color: var(--pos-warning);
    font-size: 18px;
}

/* QR Display */
.pos-qr__display {
    text-align: center;
    padding: 20px 0;
}

.pos-qr__code {
    font-size: 36px;
    font-weight: 800;
    color: var(--pos-mustard);
    letter-spacing: 0.1em;
    font-family: 'Courier New', monospace;
    margin-bottom: 12px;
}

.pos-qr__info {
    font-size: 16px;
    color: var(--pos-text);
    margin: 0;
}
.pos-qr__info strong {
    color: var(--pos-success);
    font-size: 24px;
}

.pos-qr__url {
    font-size: 11px;
    color: var(--pos-text-muted);
    word-break: break-all;
    margin: 8px 0;
}

.pos-qr__expiry {
    font-size: 12px;
    color: var(--pos-danger);
    font-weight: 600;
}

/* ==========================================================================
   TOASTS
   ========================================================================== */

.pos-toasts {
    position: fixed;
    bottom: 20px;
    right: 20px;
    display: flex;
    flex-direction: column-reverse;
    gap: 8px;
    z-index: 200;
    pointer-events: none;
}

.pos-toast {
    padding: 12px 20px;
    border-radius: var(--pos-radius);
    font-size: 13px;
    font-weight: 600;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
    transform: translateX(120%);
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.4s ease;
    opacity: 0;
    pointer-events: auto;
    max-width: 360px;
}

.pos-toast--visible {
    transform: translateX(0);
    opacity: 1;
}

.pos-toast--success {
    background: var(--pos-success);
    color: #fff;
}
.pos-toast--error {
    background: var(--pos-danger);
    color: #fff;
}
.pos-toast--warning {
    background: var(--pos-warning);
    color: var(--pos-bg);
}
.pos-toast--info {
    background: var(--pos-info);
    color: #fff;
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

/* Tablet */
@media (max-width: 1024px) {
    .pos-topbar__center {
        display: none;
    }

    .pos-topbar__clock {
        display: none;
    }

    .pos-kanban {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scroll-snap-type: x mandatory;
    }

    .pos-column {
        min-width: 300px;
        flex: 0 0 300px;
        scroll-snap-align: start;
    }

    .pos-sidebar {
        width: 100vw;
    }
}

/* Mobile */
@media (max-width: 640px) {
    .pos-topbar {
        padding: 0 8px;
        gap: 4px;
    }

    .pos-topbar__restaurant {
        font-size: 13px;
        max-width: 120px;
    }

    .pos-topbar__right {
        gap: 4px;
    }

    .pos-btn--icon {
        padding: 6px;
    }

    .pos-icon {
        width: 18px;
        height: 18px;
    }

    .pos-column {
        min-width: 85vw;
        flex: 0 0 85vw;
    }

    .pos-column__body {
        padding: 8px;
    }

    .pos-card__footer {
        flex-direction: column;
        gap: 8px;
        align-items: stretch;
    }

    .pos-card__actions {
        justify-content: stretch;
    }

    .pos-card__actions .pos-btn {
        flex: 1;
    }

    .pos-modal__content {
        max-width: 100%;
    }

    .pos-toasts {
        right: 8px;
        left: 8px;
        bottom: 8px;
    }

    .pos-toast {
        max-width: 100%;
    }

    .pos-login__card {
        padding: 28px 20px;
    }
}

/* Ultra-wide / large screens */
@media (min-width: 1600px) {
    .pos-card__number {
        font-size: 17px;
    }

    .pos-card__total {
        font-size: 18px;
    }

    .pos-topbar__stats {
        gap: 24px;
    }
}
