/* ============================================================
   HamaraPOS Brand CSS — single source of truth
   Loaded last in layouts/main.blade.php so rules win cascade.
   Each rebrand phase appends a new section below.

   PHASE 1 — Foundation: Tokens, Typography, Body, Header color
   ============================================================ */

/* ---------- Design tokens ---------- */
:root {
    /* Brand palette */
    --brand-primary:        #4F46E5;   /* Indigo 600 */
    --brand-primary-dark:   #4338CA;   /* Indigo 700 (hover/active) */
    --brand-primary-light:  #EEF2FF;   /* Indigo 50  (tint backgrounds) */
    --brand-accent:         #10B981;   /* Emerald 500 — success / transactions */
    --brand-accent-dark:    #059669;   /* Emerald 600 */
    --brand-accent-light:   #ECFDF5;   /* Emerald 50 */
    --brand-warning:        #F59E0B;   /* Amber 500 */
    --brand-warning-light:  #FFFBEB;
    --brand-danger:         #EF4444;   /* Red 500 */
    --brand-danger-light:   #FEF2F2;
    --brand-info:           #0EA5E9;   /* Sky 500 */

    /* Surfaces */
    --bg-base:              #F8FAFC;   /* Slate 50 — page background */
    --bg-surface:           #FFFFFF;   /* Card / panel background */
    --bg-surface-2:         #F1F5F9;   /* Subtle elevated zones */
    --bg-sidebar:           #0F172A;   /* Slate 900 — sidebar dark base */
    --bg-sidebar-2:         #1E293B;   /* Slate 800 — sidebar hover */

    /* Text */
    --text-primary:         #0F172A;   /* Slate 900 */
    --text-secondary:       #475569;   /* Slate 600 */
    --text-muted:           #94A3B8;   /* Slate 400 */
    --text-on-primary:      #FFFFFF;   /* Text on indigo */
    --text-on-sidebar:      #E2E8F0;   /* Slate 200 — sidebar default text */
    --text-on-sidebar-muted:#94A3B8;   /* Sidebar muted */

    /* Borders */
    --border-soft:          #E5E7EB;   /* Gray 200 */
    --border-soft-2:        #F1F5F9;   /* Slate 100 — very subtle */
    --border-strong:        #CBD5E1;   /* Slate 300 */

    /* Radii */
    --radius-sm:            6px;
    --radius-md:            10px;
    --radius-lg:            14px;
    --radius-pill:          9999px;

    /* Shadows (soft, blurred — never sharp) */
    --shadow-sm:            0 1px 2px rgba(15, 23, 42, .06);
    --shadow-md:            0 4px 12px rgba(15, 23, 42, .08);
    --shadow-lg:            0 10px 25px rgba(15, 23, 42, .10);
    --shadow-ring-primary:  0 0 0 3px rgba(79, 70, 229, .18);

    /* Motion */
    --transition-fast:      120ms ease;
    --transition-base:      180ms ease;

    /* Typography */
    --font-ui:              'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    --font-size-body:       14px;
    --font-size-sm:         13px;
    --font-size-xs:         12px;
    --line-height-base:     1.5;
}

/* ---------- Base typography ---------- */
body {
    font-family: var(--font-ui);
    font-size: var(--font-size-body);
    line-height: var(--line-height-base);
    color: var(--text-primary);
    background-color: var(--bg-base);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

/* Headings — Inter SemiBold/Bold, tight tracking */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: var(--font-ui);
    color: var(--text-primary);
    font-weight: 600;
    letter-spacing: -0.01em;
    line-height: 1.3;
}

h1, .h1 { font-size: 28px; font-weight: 700; }
h2, .h2 { font-size: 22px; }
h3, .h3 { font-size: 18px; }
h4, .h4 { font-size: 16px; }
h5, .h5 { font-size: 14px; }
h6, .h6 { font-size: 13px; text-transform: uppercase; letter-spacing: .04em; color: var(--text-secondary); }

/* Page-title text often comes from Azzara `.page-title` */
.page-title,
.page-inner .page-title {
    font-family: var(--font-ui);
    font-weight: 600;
    color: var(--text-primary);
}

/* Links */
a {
    color: var(--brand-primary);
    transition: color var(--transition-fast);
}
a:hover,
a:focus {
    color: var(--brand-primary-dark);
    text-decoration: none;
}

/* Paragraph + utility text colors */
p, label, span, td, th, li, div {
    /* don't force — let cascade work — but normalize muted helpers */
}
.text-muted   { color: var(--text-muted) !important; }
.text-primary { color: var(--brand-primary) !important; }
.text-success { color: var(--brand-accent) !important; }
.text-warning { color: var(--brand-warning) !important; }
.text-danger  { color: var(--brand-danger) !important; }

/* ---------- Header (top brand bar) ----------
   Azzara forces blue via [data-background-color="blue"].
   We override to brand indigo so Phase 1 instantly reads on-brand.
   Navbar/logo restyling itself is Phase 5 work.
*/
.main-header[data-background-color="blue"],
.main-header .logo-header[data-background="blue"],
.main-header .navbar-header[data-background="blue"] {
    background: var(--brand-primary) !important;
}

/* Soft bottom separator under the header */
.main-header {
    box-shadow: var(--shadow-sm);
}

/* ---------- Spinner (existing) — recolor to brand ---------- */
#spinner-div i.fa-spinner {
    color: var(--brand-primary) !important;
}

/* ============================================================
   PHASE 1 — Auth shell (login / register / password reset)
   Centered card on subtle gradient. No marketing image.
   Owned here so the layout file stays structural.
   ============================================================ */

/* Body class set by the auth layout — undo Azzara's
   `html, body { overflow: hidden; height: 100% }` so the viewport scrolls
   naturally. Using overflow:visible (not auto) so only the browser's viewport
   scrollbar appears — no double scrollbar. */
html:has(body.auth-body),
body.auth-body {
    overflow: visible !important;
    height: auto !important;
    min-height: 100vh !important;
}

.auth-shell {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    padding: 40px 24px;
    background:
        radial-gradient(1200px 600px at 90% -10%, rgba(79, 70, 229, .12), transparent 60%),
        radial-gradient(900px 500px at -10% 110%, rgba(16, 185, 129, .10), transparent 60%),
        var(--bg-base);
    position: relative;
    /* Both axes hidden so the spec doesn't auto-promote overflow-y to auto
       (which would create a second scrollbar). The shell grows to fit the
       card, so only the decorative gradient blobs ever get clipped. */
    overflow: hidden;
}

/* Soft decorative dots — pure CSS, no image dependency */
.auth-shell::before,
.auth-shell::after {
    content: "";
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    filter: blur(60px);
    z-index: 0;
}
.auth-shell::before {
    top: -120px;
    right: -120px;
    width: 380px;
    height: 380px;
    background: rgba(79, 70, 229, .18);
}
.auth-shell::after {
    bottom: -140px;
    left: -140px;
    width: 420px;
    height: 420px;
    background: rgba(16, 185, 129, .12);
}

.auth-card {
    /* margin:auto here centers vertically when there's room,
       and naturally sits-at-top + lets the page scroll when content is too tall.
       This avoids the classic "flex centering hides the top of the card" bug. */
    margin: auto;
    width: 100%;
    max-width: 440px;
    background: var(--bg-surface);
    border: 1px solid var(--border-soft);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    padding: 44px 38px 30px;
    position: relative;
    z-index: 1;
    overflow: hidden; /* contain the accent stripe inside rounded corners */
    animation: auth-card-in 240ms ease-out both;
}

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

/* Accent stripe at the top of every auth card — small premium detail. */
.auth-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--brand-primary), var(--brand-accent));
}

/* Wider variant for forms with more fields (e.g. register). */
.auth-card--wide {
    max-width: 520px;
}

/* Two-column field row inside the auth card. Collapses to single column on mobile. */
.auth-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
@media (max-width: 640px) {
    .auth-row {
        grid-template-columns: 1fr;
    }
}

/* Brand mark + wordmark at top of card */
.auth-brand {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 28px;
}
.auth-brand-mark {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-md);
    background: linear-gradient(135deg, var(--brand-primary), var(--brand-accent));
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    box-shadow: 0 6px 16px rgba(79, 70, 229, .22);
}
.auth-brand-name {
    font-size: 19px;
    font-weight: 700;
    color: var(--text-primary);
    letter-spacing: -0.01em;
}

/* Form area inside card */
.auth-content h1 {
    font-weight: 700;
    font-size: 28px;
    line-height: 1.2;
    color: var(--text-primary);
    letter-spacing: -0.025em;
    margin: 0 0 6px;
}
.auth-content p {
    font-size: 14px;
    color: var(--text-secondary);
    margin: 0 0 24px;
}

/* Kill Bootstrap's default form-group margin — we control row spacing
   ourselves with `.mt-3` between rows. This avoids 32px stacks between fields. */
.auth-content .form-group {
    margin-bottom: 0;
}

.auth-content label {
    font-size: 13px !important;
    color: var(--text-primary) !important;
    margin-bottom: 6px;
    display: inline-block;
    font-weight: 600;
    line-height: 1.4;
}

/* Defensive: force form elements to inherit body font so Azzara/Bootstrap
   can't sneak a different font into buttons or inputs. */
.auth-content button,
.auth-content input,
.auth-content select,
.auth-content textarea {
    font-family: var(--font-ui);
}

/* Form section labels (e.g. "Business", "Account") — small uppercase divider */
.form-section-label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
    margin: 24px 0 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-soft-2);
    display: flex;
    align-items: center;
    gap: 10px;
}
.form-section-label::before {
    content: "";
    width: 16px;
    height: 2px;
    background: linear-gradient(90deg, var(--brand-primary), var(--brand-accent));
    border-radius: 2px;
}
.form-section-label:first-child {
    margin-top: 4px;
}

.auth-content .form-control {
    border-radius: var(--radius-md);
    border: 1px solid var(--border-soft);
    padding: 13px 16px !important;
    font-size: 14px;
    height: auto;
    line-height: 1.4;
    color: var(--text-primary) !important;
    background-color: var(--bg-surface) !important;
    transition: border-color var(--transition-base), box-shadow var(--transition-base), background-color var(--transition-base);
}
.auth-content .form-control::placeholder {
    color: var(--text-muted);
    opacity: 1;
}
.auth-content .form-control:hover:not(:focus) {
    border-color: var(--border-strong);
    background-color: var(--bg-surface-2) !important;
}
.auth-content .form-control:focus {
    border-color: var(--brand-primary);
    outline: none;
    box-shadow: var(--shadow-ring-primary);
}
.auth-content .form-control.is-invalid {
    border-color: var(--brand-danger);
}
.auth-content .form-control.is-invalid:focus {
    box-shadow: 0 0 0 3px rgba(239, 68, 68, .18);
}

/* Primary action button — full-width inside the card */
.auth-content .btn-primary {
    background-color: var(--brand-primary);
    border: none;
    width: 100%;
    padding: 12px 16px;
    font-weight: 600;
    font-size: 14px;
    border-radius: var(--radius-md);
    color: var(--text-on-primary);
    box-shadow: var(--shadow-sm);
    transition: background-color var(--transition-base), transform var(--transition-base), box-shadow var(--transition-base);
}
.auth-content .btn-primary:hover {
    background-color: var(--brand-primary-dark);
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}
.auth-content .btn-primary:focus {
    box-shadow: var(--shadow-ring-primary);
}

/* Secondary links beneath the form */
.auth-links {
    margin-top: 18px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: flex-start;
}
.auth-content .links {
    font-size: 13px;
    color: var(--brand-primary);
    margin: 0;
    padding: 0;
    text-decoration: none;
    transition: color var(--transition-fast);
}
.auth-content .links:hover {
    color: var(--brand-primary-dark);
    text-decoration: underline;
}

/* Password show/hide toggle */
.password-wrapper { position: relative; }
.password-wrapper input.form-control {
    padding-right: 44px !important;
}
.password-wrapper .toggle-password {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    border: none;
    background: transparent;
    color: var(--text-muted);
    padding: 0;
    font-size: 1rem;
    cursor: pointer;
    z-index: 2;
    transition: color var(--transition-fast);
}
.password-wrapper .toggle-password:hover {
    color: var(--brand-primary);
}

/* Inline validation message */
.auth-content .text-danger.small {
    font-size: 12px;
    margin-top: 4px;
}
.auth-content .text-muted.small {
    font-size: 12px;
    color: var(--text-muted) !important;
    margin-top: 4px;
}

/* Card footer (optional brand attribution) */
.auth-footer {
    margin-top: 24px;
    padding-top: 18px;
    border-top: 1px solid var(--border-soft-2);
    text-align: center;
    font-size: 12px;
    color: var(--text-muted);
}

/* Alerts inside the auth card */
.auth-content .alert {
    border: 0;
    border-radius: var(--radius-md);
    padding: 12px 14px;
    font-size: 13px;
    margin-bottom: 18px;
}
.auth-content .alert-success {
    background: var(--brand-accent-light);
    color: var(--brand-accent-dark);
}
.auth-content .alert-danger {
    background: var(--brand-danger-light);
    color: var(--brand-danger);
}

/* Mobile */
@media (max-width: 480px) {
    .auth-shell { padding: 16px; }
    .auth-card { padding: 28px 22px 22px; }
    .auth-content h1 { font-size: 22px; }
}

/* End Phase 1 */

/* ============================================================
   PHASE 2 — Buttons & Form Controls (global)
   These rules style every Bootstrap button + form control across
   the admin shell. Auth-page styles (Phase 1) live under
   `.auth-content` selectors and out-rank these by specificity,
   so auth pages keep their bespoke styling.
   ============================================================ */

/* ---------- Base button ---------- */
.btn {
    font-family: var(--font-ui);
    font-weight: 600;
    font-size: 14px;
    line-height: 1.4;
    padding: 9px 18px;
    border-radius: var(--radius-md);
    border: 1px solid transparent;
    box-shadow: var(--shadow-sm);
    transition: background-color var(--transition-base),
                border-color var(--transition-base),
                color var(--transition-base),
                transform var(--transition-base),
                box-shadow var(--transition-base);
    letter-spacing: -0.005em;
    cursor: pointer;
}
.btn:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
}
.btn:active {
    transform: translateY(0);
    box-shadow: var(--shadow-sm);
}
.btn:focus,
.btn.focus {
    outline: none;
    box-shadow: var(--shadow-ring-primary);
}
.btn:disabled,
.btn.disabled {
    opacity: 0.55;
    cursor: not-allowed;
    transform: none !important;
    box-shadow: var(--shadow-sm) !important;
}

/* Icons inside buttons inherit the button's font-size & color */
.btn .fas,
.btn .far,
.btn .fab,
.btn .fa {
    font-size: inherit;
    line-height: 1;
}

/* ---------- Solid button variants ----------
   `!important` on background/border/color is required to win against
   Azzara's `.btn-primary { color: #0065A4 !important }` and the
   similar overrides it applies to every other solid variant. */
.btn-primary,
.btn-primary:not(:disabled):not(.disabled):active,
.btn-primary:not(:disabled):not(.disabled).active {
    background-color: var(--brand-primary) !important;
    border-color: var(--brand-primary) !important;
    color: var(--text-on-primary) !important;
}
.btn-primary:hover,
.btn-primary:focus {
    background-color: var(--brand-primary-dark) !important;
    border-color: var(--brand-primary-dark) !important;
    color: var(--text-on-primary) !important;
}

.btn-success,
.btn-success:not(:disabled):not(.disabled):active,
.btn-success:not(:disabled):not(.disabled).active {
    background-color: var(--brand-accent) !important;
    border-color: var(--brand-accent) !important;
    color: #fff !important;
}
.btn-success:hover,
.btn-success:focus {
    background-color: var(--brand-accent-dark) !important;
    border-color: var(--brand-accent-dark) !important;
    color: #fff !important;
}
.btn-success:focus {
    box-shadow: 0 0 0 3px rgba(16, 185, 129, .22);
}

.btn-danger,
.btn-danger:not(:disabled):not(.disabled):active,
.btn-danger:not(:disabled):not(.disabled).active {
    background-color: var(--brand-danger) !important;
    border-color: var(--brand-danger) !important;
    color: #fff !important;
}
.btn-danger:hover,
.btn-danger:focus {
    background-color: #DC2626 !important;
    border-color: #DC2626 !important;
    color: #fff !important;
}
.btn-danger:focus {
    box-shadow: 0 0 0 3px rgba(239, 68, 68, .22);
}

.btn-warning,
.btn-warning:not(:disabled):not(.disabled):active,
.btn-warning:not(:disabled):not(.disabled).active {
    background-color: var(--brand-warning) !important;
    border-color: var(--brand-warning) !important;
    color: #fff !important;
}
.btn-warning:hover,
.btn-warning:focus {
    background-color: #D97706 !important;
    border-color: #D97706 !important;
    color: #fff !important;
}
.btn-warning:focus {
    box-shadow: 0 0 0 3px rgba(245, 158, 11, .22);
}

.btn-info,
.btn-info:not(:disabled):not(.disabled):active,
.btn-info:not(:disabled):not(.disabled).active {
    background-color: var(--brand-info) !important;
    border-color: var(--brand-info) !important;
    color: #fff !important;
}
.btn-info:hover,
.btn-info:focus {
    background-color: #0284C7 !important;
    border-color: #0284C7 !important;
    color: #fff !important;
}

.btn-secondary,
.btn-secondary:not(:disabled):not(.disabled):active,
.btn-secondary:not(:disabled):not(.disabled).active {
    background-color: var(--text-secondary) !important;
    border-color: var(--text-secondary) !important;
    color: #fff !important;
}
.btn-secondary:hover,
.btn-secondary:focus {
    background-color: var(--text-primary) !important;
    border-color: var(--text-primary) !important;
    color: #fff !important;
}

/* Icons inside solid buttons must inherit the button's color
   so they render white. Azzara doesn't force icon color, but it does
   force `.btn i { font-size: 22px !important }` — so we also force
   our own icon sizing below. */
.btn-primary > .fa, .btn-primary > .fas, .btn-primary > .far, .btn-primary > .fab,
.btn-success > .fa, .btn-success > .fas, .btn-success > .far, .btn-success > .fab,
.btn-danger  > .fa, .btn-danger  > .fas, .btn-danger  > .far, .btn-danger  > .fab,
.btn-warning > .fa, .btn-warning > .fas, .btn-warning > .far, .btn-warning > .fab,
.btn-info    > .fa, .btn-info    > .fas, .btn-info    > .far, .btn-info    > .fab,
.btn-secondary > .fa, .btn-secondary > .fas, .btn-secondary > .far, .btn-secondary > .fab,
.btn-dark    > .fa, .btn-dark    > .fas, .btn-dark    > .far, .btn-dark    > .fab {
    color: inherit !important;
}

.btn-light {
    background-color: var(--bg-surface-2);
    border-color: var(--border-soft);
    color: var(--text-primary);
}
.btn-light:hover,
.btn-light:focus {
    background-color: var(--bg-surface);
    border-color: var(--border-strong);
    color: var(--text-primary);
}

.btn-dark {
    background-color: var(--text-primary);
    border-color: var(--text-primary);
    color: #fff;
}
.btn-dark:hover,
.btn-dark:focus {
    background-color: var(--bg-sidebar);
    border-color: var(--bg-sidebar);
    color: #fff;
}

/* ---------- Outline variants ---------- */
.btn-outline-primary {
    background-color: transparent;
    border-color: var(--brand-primary);
    color: var(--brand-primary);
    box-shadow: none;
}
.btn-outline-primary:hover,
.btn-outline-primary:focus {
    background-color: var(--brand-primary);
    border-color: var(--brand-primary);
    color: var(--text-on-primary);
}

.btn-outline-success {
    background-color: transparent;
    border-color: var(--brand-accent);
    color: var(--brand-accent);
    box-shadow: none;
}
.btn-outline-success:hover,
.btn-outline-success:focus {
    background-color: var(--brand-accent);
    border-color: var(--brand-accent);
    color: #fff;
}

.btn-outline-danger {
    background-color: transparent;
    border-color: var(--brand-danger);
    color: var(--brand-danger);
    box-shadow: none;
}
.btn-outline-danger:hover,
.btn-outline-danger:focus {
    background-color: var(--brand-danger);
    border-color: var(--brand-danger);
    color: #fff;
}

.btn-outline-warning {
    background-color: transparent;
    border-color: var(--brand-warning);
    color: var(--brand-warning);
    box-shadow: none;
}
.btn-outline-warning:hover,
.btn-outline-warning:focus {
    background-color: var(--brand-warning);
    border-color: var(--brand-warning);
    color: #fff;
}

.btn-outline-info {
    background-color: transparent;
    border-color: var(--brand-info);
    color: var(--brand-info);
    box-shadow: none;
}
.btn-outline-info:hover,
.btn-outline-info:focus {
    background-color: var(--brand-info);
    border-color: var(--brand-info);
    color: #fff;
}

.btn-outline-secondary {
    background-color: transparent;
    border-color: var(--border-strong);
    color: var(--text-secondary);
    box-shadow: none;
}
.btn-outline-secondary:hover,
.btn-outline-secondary:focus {
    background-color: var(--bg-surface-2);
    border-color: var(--text-secondary);
    color: var(--text-primary);
}

/* ---------- Size variants ---------- */
.btn-sm,
.btn-group-sm > .btn {
    padding: 6px 12px;
    font-size: 13px;
    border-radius: var(--radius-sm);
}
.btn-xs {
    padding: 4px 10px;
    font-size: 12px;
    border-radius: var(--radius-sm);
}
.btn-lg,
.btn-group-lg > .btn {
    padding: 12px 24px;
    font-size: 15px;
    border-radius: var(--radius-md);
}
.btn-block {
    display: block;
    width: 100%;
}

/* ---------- Link button ---------- */
.btn-link {
    background-color: transparent;
    border-color: transparent;
    color: var(--brand-primary);
    box-shadow: none;
    text-decoration: none;
    font-weight: 600;
}
.btn-link:hover,
.btn-link:focus {
    color: var(--brand-primary-dark);
    text-decoration: underline;
    background-color: transparent;
    transform: none;
    box-shadow: none;
}

/* ---------- Button groups ---------- */
.btn-group .btn + .btn {
    margin-left: 4px;
}

/* ---------- Form group spacing ---------- */
.form-group {
    margin-bottom: 18px;
}

/* ---------- Form controls (global) ---------- */
.form-control {
    font-family: var(--font-ui);
    font-size: 14px;
    line-height: 1.4;
    padding: 10px 14px;
    height: auto;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-soft);
    background-color: var(--bg-surface);
    color: var(--text-primary);
    box-shadow: none;
    transition: border-color var(--transition-base),
                box-shadow var(--transition-base),
                background-color var(--transition-base);
}
.form-control::placeholder {
    color: var(--text-muted);
    opacity: 1;
}
.form-control:hover:not(:focus):not(:disabled):not([readonly]) {
    border-color: var(--border-strong);
}
.form-control:focus {
    border-color: var(--brand-primary);
    background-color: var(--bg-surface);
    color: var(--text-primary);
    box-shadow: var(--shadow-ring-primary);
    outline: none;
}
.form-control:disabled,
.form-control[readonly] {
    background-color: var(--bg-surface-2);
    color: var(--text-muted);
    cursor: not-allowed;
}
.form-control.is-invalid {
    border-color: var(--brand-danger);
    background-image: none;
    padding-right: 14px;
}
.form-control.is-invalid:focus {
    box-shadow: 0 0 0 3px rgba(239, 68, 68, .18);
}
.form-control.is-valid {
    border-color: var(--brand-accent);
    background-image: none;
    padding-right: 14px;
}
.form-control.is-valid:focus {
    box-shadow: 0 0 0 3px rgba(16, 185, 129, .18);
}

.form-control-sm {
    padding: 6px 10px;
    font-size: 13px;
    border-radius: var(--radius-sm);
}
.form-control-lg {
    padding: 13px 16px;
    font-size: 15px;
}

/* ---------- Select ---------- */
select.form-control,
.custom-select {
    font-family: var(--font-ui);
    font-size: 14px;
    padding: 10px 36px 10px 14px;
    border-radius: var(--radius-md);
    border: 1px solid var(--border-soft);
    background-color: var(--bg-surface);
    color: var(--text-primary);
    height: auto;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 16 16'%3E%3Cpath fill='%2394A3B8' d='M4.5 6.5L8 10l3.5-3.5z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    background-size: 12px;
    transition: border-color var(--transition-base),
                box-shadow var(--transition-base);
}
select.form-control:hover:not(:focus):not(:disabled),
.custom-select:hover:not(:focus):not(:disabled) {
    border-color: var(--border-strong);
}
select.form-control:focus,
.custom-select:focus {
    border-color: var(--brand-primary);
    box-shadow: var(--shadow-ring-primary);
    outline: none;
}
select.form-control:disabled,
.custom-select:disabled {
    background-color: var(--bg-surface-2);
    color: var(--text-muted);
    cursor: not-allowed;
}

/* ---------- Textarea ---------- */
textarea.form-control {
    min-height: 90px;
    padding: 12px 14px;
    line-height: 1.5;
    resize: vertical;
}

/* ---------- Form labels ---------- */
.form-group > label,
label.col-form-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 6px;
}

/* ---------- Help text / inline error ---------- */
.form-text,
small.form-text {
    color: var(--text-muted);
    font-size: 12px;
    margin-top: 4px;
}
.invalid-feedback {
    color: var(--brand-danger);
    font-size: 12px;
    margin-top: 4px;
}

/* ---------- Input groups ---------- */
.input-group-text {
    background-color: var(--bg-surface-2);
    border: 1px solid var(--border-soft);
    color: var(--text-secondary);
    border-radius: var(--radius-md);
    padding: 10px 14px;
    font-size: 14px;
}
.input-group > .form-control:not(:first-child),
.input-group > .custom-select:not(:first-child) {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}
.input-group > .form-control:not(:last-child),
.input-group > .custom-select:not(:last-child) {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

/* ---------- Custom checkbox & radio (Bootstrap 4 .custom-control) ---------- */
.custom-control {
    min-height: 22px;
    padding-left: 1.75rem;
}
.custom-control-label {
    font-size: 14px;
    color: var(--text-primary);
    cursor: pointer;
    padding-top: 2px;
}
.custom-control-label::before {
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-strong);
    background-color: var(--bg-surface);
    width: 18px;
    height: 18px;
    top: 2px;
    transition: background-color var(--transition-fast),
                border-color var(--transition-fast),
                box-shadow var(--transition-fast);
}
.custom-control-label::after {
    width: 18px;
    height: 18px;
    top: 2px;
}
.custom-control-input:checked ~ .custom-control-label::before {
    background-color: var(--brand-primary);
    border-color: var(--brand-primary);
}
.custom-control-input:focus ~ .custom-control-label::before {
    box-shadow: var(--shadow-ring-primary);
}
.custom-control-input:disabled ~ .custom-control-label {
    color: var(--text-muted);
}
.custom-control-input:disabled ~ .custom-control-label::before {
    background-color: var(--bg-surface-2);
}
.custom-radio .custom-control-label::before {
    border-radius: 50%;
}

/* ---------- Custom switch ---------- */
.custom-switch {
    padding-left: 2.5rem;
}
.custom-switch .custom-control-label::before {
    border-radius: 12px;
    height: 22px;
    width: 40px;
    top: 0;
    left: -2.5rem;
}
.custom-switch .custom-control-label::after {
    border-radius: 50%;
    width: 18px;
    height: 18px;
    background-color: #fff;
    top: 2px;
    left: calc(-2.5rem + 2px);
    transition: transform var(--transition-base);
}
.custom-switch .custom-control-input:checked ~ .custom-control-label::after {
    transform: translateX(18px);
    background-color: #fff;
}

/* ---------- Native form-check (Bootstrap 4 .form-check) ---------- */
.form-check-input {
    width: 16px;
    height: 16px;
    accent-color: var(--brand-primary);
    margin-top: 4px;
}
.form-check-label {
    font-size: 14px;
    color: var(--text-primary);
    cursor: pointer;
    padding-left: 4px;
}

/* ---------- File input (Bootstrap 4 .custom-file) ---------- */
.custom-file {
    height: auto;
}
.custom-file-input {
    cursor: pointer;
    height: auto;
}
.custom-file-label {
    border-radius: var(--radius-md);
    border: 1px solid var(--border-soft);
    color: var(--text-primary);
    background-color: var(--bg-surface);
    height: auto;
    padding: 10px 14px;
    font-size: 14px;
}
.custom-file-label::after {
    background-color: var(--brand-primary);
    color: var(--text-on-primary);
    border: none;
    padding: 10px 14px;
    font-weight: 600;
}
.custom-file-input:focus ~ .custom-file-label {
    border-color: var(--brand-primary);
    box-shadow: var(--shadow-ring-primary);
}

/* End Phase 2 */

/* ============================================================
   PHASE 3 — Cards & Containers
   Cards become modern SaaS surfaces with soft borders, layered
   shadows, generous padding, and a gentle hover lift when clickable.
   Page headers / breadcrumbs / panels get the same treatment.
   ============================================================ */

/* ---------- Base card ---------- */
.card {
    background-color: var(--bg-surface);
    border: 1px solid var(--border-soft);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    margin-bottom: 22px;
    overflow: hidden; /* clip inner colored regions to the rounded outline */
    transition: transform var(--transition-base),
                box-shadow var(--transition-base),
                border-color var(--transition-base);
}

/* Hover lift — only for clickable cards. Opt-in via `.card-clickable`,
   `<a class="card">`, `role="button"`, or `tabindex`. */
a.card,
.card-clickable,
.card[role="button"],
.card[tabindex] {
    cursor: pointer;
    text-decoration: none;
    color: inherit;
}
a.card:hover,
a.card:focus,
.card-clickable:hover,
.card-clickable:focus,
.card[role="button"]:hover,
.card[role="button"]:focus,
.card[tabindex]:hover,
.card[tabindex]:focus {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    border-color: var(--border-strong);
    outline: none;
}

/* Override Azzara's colored card backgrounds — keep cards on-brand */
.card[data-background-color],
.card[data-background] {
    background-color: var(--bg-surface);
    color: var(--text-primary);
}

/* ---------- Card header ---------- */
.card-header,
.card > .card-header,
.card > .header {
    background-color: var(--bg-surface);
    border-bottom: 1px solid var(--border-soft);
    padding: 18px 22px;
    color: var(--text-primary);
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    /* The outer card has overflow:hidden + radius — header inherits the rounded top naturally. */
}

.card-header h1, .card-header h2, .card-header h3, .card-header h4,
.card-header .card-title,
.card .card-title,
.card-title {
    font-family: var(--font-ui);
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
    letter-spacing: -0.01em;
    line-height: 1.3;
}

.card-subtitle,
.card .card-subtitle {
    font-size: 13px;
    color: var(--text-secondary);
    margin-top: 4px;
    margin-bottom: 0;
}

/* Action area on the right side of card header */
.card-header .card-tools,
.card-header .card-action,
.card-header .pull-right,
.card-header .ml-auto {
    margin-left: auto;
}

/* ---------- Card body ---------- */
.card-body,
.card > .card-body,
.card > .body {
    padding: 22px;
    color: var(--text-primary);
    background-color: transparent;
}

/* A card with no header → body gets the rounded top of the card */
.card > .card-body:first-child {
    padding-top: 22px;
}

/* ---------- Card footer ---------- */
.card-footer,
.card > .card-footer,
.card > .footer {
    background-color: var(--bg-surface-2);
    border-top: 1px solid var(--border-soft-2);
    padding: 14px 22px;
    color: var(--text-secondary);
    font-size: 13px;
}

/* ---------- Card text helpers ---------- */
.card-text {
    color: var(--text-secondary);
    font-size: 14px;
    line-height: 1.5;
}

/* ---------- Card grid spacing ---------- */
.card-deck .card,
.card-group .card,
.card-columns .card {
    margin-bottom: 18px;
}

/* ---------- Dashboard stat tile (Azzara `.card-stats` convention) ---------- */
.card-stats .card-body {
    padding: 20px 22px;
}
.card-stats .icon-big,
.card-stats .info-icon {
    width: 52px;
    height: 52px;
    border-radius: var(--radius-md);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    background: linear-gradient(135deg, var(--brand-primary), var(--brand-accent));
    color: #fff;
    box-shadow: 0 6px 14px rgba(79, 70, 229, .18);
}
.card-stats .icon-big i,
.card-stats .info-icon i {
    color: #fff !important;
}
.card-stats .numbers .card-category,
.card-stats .card-category {
    font-size: 11px;
    color: var(--text-muted);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 2px;
}
.card-stats .numbers .card-title,
.card-stats .h2 {
    font-size: 24px;
    font-weight: 700;
    color: var(--text-primary);
    letter-spacing: -0.025em;
    margin: 0;
}

/* ---------- Page header / title bar ---------- */
.page-inner,
.page-inner-fill {
    padding: 24px 28px;
}

.page-header {
    background-color: transparent;
    box-shadow: none;
    border: none;
    padding: 0;
    margin-bottom: 22px;
    min-height: auto;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
}
.page-header .page-title,
.page-title {
    font-family: var(--font-ui);
    font-size: 22px;
    font-weight: 700;
    color: var(--text-primary);
    letter-spacing: -0.02em;
    margin: 0;
    line-height: 1.2;
}
.page-header .page-category {
    font-size: 13px;
    color: var(--text-secondary);
    margin: 0;
}

/* Push the right-side action block to the end */
.page-header .btn-group,
.page-header .page-header-actions,
.page-header > .ml-auto {
    margin-left: auto;
}

/* ---------- Breadcrumbs ---------- */
.breadcrumb,
.breadcrumbs {
    background-color: transparent;
    padding: 0;
    margin: 0;
    font-size: 13px;
    border-radius: 0;
}
.breadcrumb-item {
    color: var(--text-muted);
}
.breadcrumb-item a {
    color: var(--brand-primary);
    text-decoration: none;
    transition: color var(--transition-fast);
}
.breadcrumb-item a:hover {
    color: var(--brand-primary-dark);
    text-decoration: underline;
}
.breadcrumb-item + .breadcrumb-item::before {
    color: var(--text-muted);
    content: "/";
    padding: 0 6px;
}
.breadcrumb-item.active {
    color: var(--text-secondary);
    font-weight: 500;
}

/* ---------- Horizontal divider ---------- */
hr {
    border: none;
    border-top: 1px solid var(--border-soft);
    margin: 22px 0;
}

/* ---------- Legacy panels ---------- */
.panel {
    background-color: var(--bg-surface);
    border: 1px solid var(--border-soft);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    margin-bottom: 22px;
    overflow: hidden;
}
.panel-heading {
    background-color: var(--bg-surface);
    border-bottom: 1px solid var(--border-soft);
    padding: 18px 22px;
    color: var(--text-primary);
    font-weight: 600;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}
.panel-body {
    padding: 22px;
    color: var(--text-primary);
}
.panel-footer {
    background-color: var(--bg-surface-2);
    border-top: 1px solid var(--border-soft-2);
    padding: 14px 22px;
    color: var(--text-secondary);
}

/* ---------- Main content area ---------- */
.main-panel > .content,
.main-panel .content {
    background-color: var(--bg-base);
}

/* ---------- Generic boxes / wells (legacy) ---------- */
.box,
.well {
    background-color: var(--bg-surface);
    border: 1px solid var(--border-soft);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    padding: 18px;
    margin-bottom: 18px;
}

/* End Phase 3 */

/* ============================================================
   PHASE 4 — Tables: the Data Cockpit
   Restyles Bootstrap `.table` + Yajra DataTables across the admin
   shell. Header becomes a subtle slate strip, rows get a light
   indigo hover wash, pagination matches Phase 2 buttons, and sort
   indicators use brand colors.
   ============================================================ */

/* ---------- Base table ---------- */
.table {
    font-family: var(--font-ui);
    font-size: 14px;
    color: var(--text-primary);
    background-color: transparent;
    margin-bottom: 0;
    border-collapse: separate;
    border-spacing: 0;
    width: 100%;
}

.table th,
.table td {
    padding: 12px 16px;
    vertical-align: middle;
    border-top: none;
    border-bottom: 1px solid var(--border-soft-2);
}

.table thead th {
    background-color: var(--bg-surface-2);
    color: var(--text-secondary);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    border-top: 1px solid var(--border-soft);
    border-bottom: 1px solid var(--border-soft);
    padding: 13px 16px;
    white-space: nowrap;
    vertical-align: middle;
    line-height: 1.3;
}

.table tbody tr {
    transition: background-color var(--transition-fast);
}
.table tbody tr:last-child td {
    border-bottom: none;
}

/* ---------- Row hover wash ---------- */
.table tbody tr:hover,
.table-hover tbody tr:hover {
    background-color: rgba(79, 70, 229, .04);
}

/* ---------- Zebra striping (subtle) ---------- */
.table-striped tbody tr:nth-of-type(odd) {
    background-color: rgba(15, 23, 42, .02);
}
.table-striped tbody tr:nth-of-type(odd):hover {
    background-color: rgba(79, 70, 229, .05);
}

/* DataTables auto-applies tr.odd / tr.even */
.table.dataTable tbody tr.odd {
    background-color: rgba(15, 23, 42, .02);
}
.table.dataTable tbody tr.even {
    background-color: transparent;
}
.table.dataTable tbody tr.odd:hover,
.table.dataTable tbody tr.even:hover {
    background-color: rgba(79, 70, 229, .05);
}

/* ---------- Compact density (opt-in via .table-sm) ---------- */
.table-sm th,
.table-sm td {
    padding: 8px 12px;
    font-size: 13px;
}

/* ---------- Bordered variant ---------- */
.table-bordered,
.table-bordered th,
.table-bordered td {
    border: 1px solid var(--border-soft-2);
}
.table-bordered thead th {
    border-bottom-width: 1px;
}

/* ---------- Sticky header (opt-in via .table-sticky) ---------- */
.table-sticky thead th {
    position: sticky;
    top: 0;
    z-index: 2;
    /* solid background needed for sticky to occlude rows underneath */
    background-color: var(--bg-surface-2);
}

/* ---------- Cell content helpers ---------- */
.table td a {
    color: var(--brand-primary);
    text-decoration: none;
    transition: color var(--transition-fast);
}
.table td a:hover {
    color: var(--brand-primary-dark);
    text-decoration: underline;
}

.table td .avatar-img,
.table td img.rounded {
    object-fit: cover;
}

/* ---------- Action buttons in cells ----------
   Fixed 32px-square icon buttons. Flex-centered so every FA glyph
   renders identically. Icons sized at 14px — large enough that even
   thin glyphs (edit, plus, etc.) read clearly inside an indigo button. */
.table td .btn,
.table td .btn-group > .btn,
.table td form > .btn {
    padding: 0 10px;
    font-size: 14px;
    line-height: 1;
    min-width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-sm);
    box-shadow: none;
}
.table td .btn .fa,
.table td .btn .fas,
.table td .btn .far,
.table td .btn .fab,
.table td .btn i {
    /* !important needed to beat Azzara's `.btn i { font-size: 22px !important }` */
    font-size: 14px !important;
    line-height: 1 !important;
    /* explicitly center the glyph within its em-box */
    display: inline-block;
    vertical-align: middle;
    color: inherit !important;
}
.table td .btn:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-sm);
}
/* Spacing between consecutive action buttons (anchor → anchor → form) */
.table td .btn + .btn,
.table td .btn + .delete-form,
.table td .btn + form,
.table td form + .btn,
.table td .delete-form + .btn,
.table td form + form {
    margin-left: 4px;
}
.table td .delete-form,
.table td form.d-inline {
    display: inline-block;
}
/* Optional .btn-icon modifier — square icon-only button */
.table td .btn-icon,
.table td .btn.btn-icon {
    width: 30px;
    min-width: 30px;
    padding: 0;
}

/* ---------- Empty state ---------- */
.dataTables_empty,
.table tbody tr td.dataTables_empty {
    text-align: center;
    color: var(--text-muted);
    padding: 36px 16px !important;
    font-size: 14px;
    background-color: transparent !important;
}

/* ============================================================
   DataTables wrapper, controls, sorting, pagination
   ============================================================ */

.dataTables_wrapper {
    padding: 16px 18px 6px;
    color: var(--text-secondary);
    font-size: 13px;
}

/* Top + bottom rows (length/filter + info/paginate) */
.dataTables_wrapper .row {
    margin-left: 0;
    margin-right: 0;
}
.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_filter,
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_paginate {
    color: var(--text-secondary);
    font-size: 13px;
}

.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_filter {
    margin-bottom: 14px;
    font-weight: 500;
}

.dataTables_wrapper .dataTables_length label,
.dataTables_wrapper .dataTables_filter label {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 0;
    color: var(--text-secondary);
    font-weight: 500;
}
.dataTables_wrapper .dataTables_filter label {
    justify-content: flex-end;
}

/* Length select — keep compact; beats Bootstrap's `.form-control { width:100% }`. */
.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_length select.form-control,
.dataTables_wrapper .dataTables_length .custom-select {
    font-size: 13px !important;
    padding: 6px 28px 6px 10px !important;
    height: auto !important;
    width: auto !important;
    min-width: 72px !important;
    max-width: 90px !important;
    flex: 0 0 auto !important;
    display: inline-block !important;
    border: 1px solid var(--border-soft) !important;
    border-radius: var(--radius-sm) !important;
    background-color: var(--bg-surface) !important;
    color: var(--text-primary);
}
.dataTables_wrapper .dataTables_length select:focus {
    border-color: var(--brand-primary) !important;
    box-shadow: var(--shadow-ring-primary) !important;
    outline: none;
}

/* Filter / search input */
.dataTables_wrapper .dataTables_filter input,
.dataTables_wrapper .dataTables_filter input[type="search"] {
    font-size: 13px !important;
    padding: 7px 12px !important;
    height: auto;
    min-width: 220px;
    margin-left: 0;
    border: 1px solid var(--border-soft) !important;
    border-radius: var(--radius-md) !important;
    background-color: var(--bg-surface) !important;
    color: var(--text-primary);
    transition: border-color var(--transition-base),
                box-shadow var(--transition-base);
}
.dataTables_wrapper .dataTables_filter input:focus {
    border-color: var(--brand-primary) !important;
    box-shadow: var(--shadow-ring-primary) !important;
    outline: none;
}

/* Sort indicators on header cells */
.table thead th.sorting,
.table thead th.sorting_asc,
.table thead th.sorting_desc,
.table thead th.sorting_asc_disabled,
.table thead th.sorting_desc_disabled {
    cursor: pointer;
    position: relative;
    padding-right: 28px;
    user-select: none;
    /* Kill Bootstrap-DataTables default background image */
    background-image: none !important;
}
.table thead th.sorting::after,
.table thead th.sorting_asc::after,
.table thead th.sorting_desc::after {
    content: "";
    position: absolute;
    right: 10px;
    top: 50%;
    width: 8px;
    height: 12px;
    transform: translateY(-50%);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 8px 12px;
}
.table thead th.sorting::after {
    /* Both arrows, faded — neutral state */
    background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 12'%3E%3Cpath fill='%2394A3B8' opacity='.5' d='M4 0L0 4h8z'/%3E%3Cpath fill='%2394A3B8' opacity='.5' d='M4 12L0 8h8z'/%3E%3C/svg%3E");
}
.table thead th.sorting_asc::after {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 12'%3E%3Cpath fill='%234F46E5' d='M4 0L0 4h8z'/%3E%3Cpath fill='%2394A3B8' opacity='.25' d='M4 12L0 8h8z'/%3E%3C/svg%3E");
}
.table thead th.sorting_desc::after {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 12'%3E%3Cpath fill='%2394A3B8' opacity='.25' d='M4 0L0 4h8z'/%3E%3Cpath fill='%234F46E5' d='M4 12L0 8h8z'/%3E%3C/svg%3E");
}
.table thead th.sorting:hover {
    background-color: var(--border-soft-2);
    color: var(--text-primary);
}

/* Info text ("Showing 1 to 10 of 142 entries") */
.dataTables_wrapper .dataTables_info {
    color: var(--text-muted);
    font-size: 13px;
    padding-top: 14px;
}

/* ---------- Pagination ----------
   Sized to fit ~10 buttons in ~500px so "Previous … 5 numbers … last … Next"
   stays on one row even with 5-digit page counts. */
.dataTables_wrapper .dataTables_paginate {
    padding-top: 12px;
    text-align: right;
    /* No flex on the outer wrapper — text-align right keeps the UL aligned
       without flex-wrap quirks that pushed Next to a second line. */
}

.dataTables_wrapper .dataTables_paginate .pagination {
    margin: 0;
    gap: 3px;
    display: inline-flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    padding-left: 0;
    list-style: none;
    vertical-align: middle;
}
.dataTables_wrapper .dataTables_paginate .pagination .page-item {
    list-style: none;
    margin: 0;
}

/* Base pagination button — minimal, borderless numeric pills.
   Previous/Next get an outline (below) so they read as distinct nav controls. */
.dataTables_wrapper .dataTables_paginate .paginate_button,
.dataTables_wrapper .dataTables_paginate .pagination .page-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 32px;
    height: 32px;
    padding: 0 8px;
    margin: 0 !important;
    border: 1px solid transparent !important;
    border-radius: var(--radius-sm) !important;
    background-color: transparent !important;
    color: var(--text-secondary) !important;
    font-size: 13px;
    font-weight: 600;
    line-height: 1;
    cursor: pointer;
    text-decoration: none !important;
    box-shadow: none !important;
    transition: background-color var(--transition-fast),
                border-color var(--transition-fast),
                color var(--transition-fast),
                box-shadow var(--transition-fast);
}

/* Previous / Next — same borderless minimal look as numeric pages,
   but with stronger text color and a bit more horizontal padding so
   they still read as distinct nav controls. */
.dataTables_wrapper .dataTables_paginate .paginate_button.previous,
.dataTables_wrapper .dataTables_paginate .paginate_button.next,
.dataTables_wrapper .dataTables_paginate .pagination .page-item.previous .page-link,
.dataTables_wrapper .dataTables_paginate .pagination .page-item.next .page-link {
    border-color: transparent !important;
    background-color: transparent !important;
    padding: 0 14px;
    color: var(--text-primary) !important;
}

/* Ellipsis "…" — truly passive, no border, no hover */
.dataTables_wrapper .dataTables_paginate .paginate_button.ellipsis,
.dataTables_wrapper .dataTables_paginate .pagination .page-item.disabled:not(.previous):not(.next) .page-link {
    border-color: transparent !important;
    background-color: transparent !important;
    color: var(--text-muted) !important;
    min-width: 22px;
    padding: 0 4px;
    cursor: default;
    pointer-events: none;
}

/* Hover wash — numeric pages */
.dataTables_wrapper .dataTables_paginate .paginate_button:hover,
.dataTables_wrapper .dataTables_paginate .pagination .page-link:hover {
    background-color: var(--brand-primary-light) !important;
    color: var(--brand-primary) !important;
    border-color: transparent !important;
}

/* Hover for Previous / Next — same wash as numbers, no border */
.dataTables_wrapper .dataTables_paginate .paginate_button.previous:hover,
.dataTables_wrapper .dataTables_paginate .paginate_button.next:hover,
.dataTables_wrapper .dataTables_paginate .pagination .page-item.previous .page-link:hover,
.dataTables_wrapper .dataTables_paginate .pagination .page-item.next .page-link:hover {
    background-color: var(--brand-primary-light) !important;
    border-color: transparent !important;
    color: var(--brand-primary) !important;
}

/* Current page — solid indigo with a soft indigo glow */
.dataTables_wrapper .dataTables_paginate .paginate_button.current,
.dataTables_wrapper .dataTables_paginate .paginate_button.current:hover,
.dataTables_wrapper .dataTables_paginate .pagination .page-item.active .page-link,
.dataTables_wrapper .dataTables_paginate .pagination .page-item.active .page-link:hover {
    background: var(--brand-primary) !important;
    border-color: var(--brand-primary) !important;
    color: var(--text-on-primary) !important;
    box-shadow: 0 4px 12px rgba(79, 70, 229, .28) !important;
}

/* Disabled Previous / Next — borderless, muted, no hover */
.dataTables_wrapper .dataTables_paginate .paginate_button.previous.disabled,
.dataTables_wrapper .dataTables_paginate .paginate_button.next.disabled,
.dataTables_wrapper .dataTables_paginate .pagination .page-item.previous.disabled .page-link,
.dataTables_wrapper .dataTables_paginate .pagination .page-item.next.disabled .page-link,
.dataTables_wrapper .dataTables_paginate .paginate_button.previous.disabled:hover,
.dataTables_wrapper .dataTables_paginate .paginate_button.next.disabled:hover {
    background-color: transparent !important;
    border-color: transparent !important;
    color: var(--text-muted) !important;
    cursor: not-allowed;
}

/* ---------- Table sitting inside a .card ---------- */
.card > .dataTables_wrapper {
    padding: 16px 18px 8px;
}
.card > .table,
.card > .table-responsive > .table,
.card > .card-body > .dataTables_wrapper {
    margin-bottom: 0;
}
/* Let table touch card sides nicely */
.card .table-responsive {
    border-radius: 0;
}

/* ---------- Mobile pagination — compact "Previous • current • Next" ----------
   On narrow viewports the full page-number list wraps into a messy multi-row
   grid. Hide every numeric button except the active one, hide the ellipsis,
   and center-align Prev / active / Next. */
@media (max-width: 767.98px) {
    .dataTables_wrapper .dataTables_paginate {
        text-align: center !important;
        padding-top: 8px;
    }
    .dataTables_wrapper .dataTables_paginate .pagination {
        justify-content: center !important;
        flex-wrap: nowrap;
        gap: 4px;
    }

    /* Bootstrap 4 / page-item markup */
    .dataTables_wrapper .dataTables_paginate .pagination .page-item:not(.previous):not(.next):not(.active),
    .dataTables_wrapper .dataTables_paginate .pagination .page-item.disabled:not(.previous):not(.next) {
        display: none !important;
    }

    /* Legacy DataTables / .paginate_button markup */
    .dataTables_wrapper .dataTables_paginate .paginate_button:not(.previous):not(.next):not(.current):not(.first):not(.last) {
        display: none !important;
    }
    .dataTables_wrapper .dataTables_paginate .paginate_button.ellipsis {
        display: none !important;
    }

    /* Active page sits between Previous and Next */
    .dataTables_wrapper .dataTables_paginate .pagination .page-link,
    .dataTables_wrapper .dataTables_paginate .paginate_button {
        min-width: 36px;
        height: 36px;
        padding: 0 14px;
        font-size: 13px;
    }

    /* Info text centered + smaller */
    .dataTables_wrapper .dataTables_info {
        text-align: center !important;
        font-size: 12px;
        padding-top: 8px;
    }

    /* Length + filter controls — stack and shrink */
    .dataTables_wrapper .dataTables_length,
    .dataTables_wrapper .dataTables_filter {
        text-align: center !important;
        margin-bottom: 10px !important;
    }
    .dataTables_wrapper .dataTables_filter label,
    .dataTables_wrapper .dataTables_length label {
        justify-content: center !important;
    }
    .dataTables_wrapper .dataTables_filter input {
        min-width: 0 !important;
        width: 100%;
        max-width: 280px;
    }
}

/* End Phase 4 */

/* ============================================================
   PHASE 5 — Sidebar & Navbar
   Dark sidebar with indigo-glow active state, clean white topbar,
   prominent POS quick-action, refined dropdowns. The Phase-1 indigo
   topbar gives way to a calmer SaaS pattern — brand identity now
   carried by the sidebar accents and CTAs.
   ============================================================ */

/* ---------- Main header (topbar) — calm white surface ----------
   Azzara forces colored backgrounds on BOTH the main-header AND its
   .logo-header / .navbar-header children via attribute selectors on the
   parent. We mirror that selector shape so our override has equal-or-
   higher specificity (and we load later, so we win the cascade). */
.main-header,
.main-header[data-background-color="blue"],
.main-header[data-background-color="dark"],
.main-header[data-background-color="purple"],
.main-header[data-background-color="light-blue"],
.main-header[data-background-color="green"],
.main-header[data-background-color="orange"],
.main-header[data-background-color="red"] {
    background: var(--bg-surface) !important;
    box-shadow: var(--shadow-sm) !important;
    border-bottom: 1px solid var(--border-soft);
}

/* Children — Azzara paints each child colored when the parent
   has data-background-color. Override at the SAME shape. */
.main-header[data-background-color="blue"]   .logo-header,
.main-header[data-background-color="blue"]   .navbar-header,
.main-header[data-background-color="dark"]   .logo-header,
.main-header[data-background-color="dark"]   .navbar-header,
.main-header[data-background-color="purple"] .logo-header,
.main-header[data-background-color="purple"] .navbar-header,
.main-header[data-background-color="light-blue"] .logo-header,
.main-header[data-background-color="light-blue"] .navbar-header,
.main-header[data-background-color="green"]  .logo-header,
.main-header[data-background-color="green"]  .navbar-header,
.main-header[data-background-color="orange"] .logo-header,
.main-header[data-background-color="orange"] .navbar-header,
.main-header[data-background-color="red"]    .logo-header,
.main-header[data-background-color="red"]    .navbar-header,
.main-header .logo-header,
.main-header .navbar-header,
.main-header .logo-header[data-background],
.main-header .navbar-header[data-background] {
    background: var(--bg-surface) !important;
}

/* Logo / brand area — same white surface as the rest of the topbar.
   Beats Azzara's `data-background="blue"` and the inline `style="color:white"`
   on the company-name <h3> inside logo-header.blade.php. */
.main-header .logo-header,
.main-header .logo-header[data-background],
.main-header .logo-header[data-background-color],
.main-header .logo-header[data-background-color="blue"],
.main-header .logo-header[data-background="blue"] {
    background: var(--bg-surface) !important;
    border-right: 1px solid var(--border-soft) !important;
}
.main-header .logo-header .logo {
    color: var(--text-primary) !important;
    font-family: var(--font-ui);
    font-weight: 700;
    font-size: 16px;
    letter-spacing: -0.01em;
    text-decoration: none !important;
}
.main-header .logo-header .logo h1,
.main-header .logo-header .logo h2,
.main-header .logo-header .logo h3,
.main-header .logo-header .logo h4,
.main-header .logo-header .logo > div h3,
.logo-header .logo h3 {
    color: var(--text-primary) !important;
    font-family: var(--font-ui) !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    letter-spacing: -0.01em !important;
    line-height: 1.2 !important;
    margin: 0 !important;
    padding: 0 !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 170px;
    text-transform: uppercase;
}

/* Keep gap between the wordmark and the hamburger / toggler */
.main-header .logo-header .logo,
.main-header .logo-header > a.logo {
    padding-right: 16px !important;
    overflow: hidden;
    flex-shrink: 1;
    min-width: 0;
}

/* The inline `style="display:flex; align-items:center;"` wrapper inside .logo */
.main-header .logo-header .logo > div {
    align-items: center;
    height: 100%;
}
.main-header .logo-header .logo span {
    color: var(--brand-primary) !important;
}

/* Toggler buttons (hamburger / vertical-dots / minimize) on the logo-header.
   Default desktop styling — colored, transparent background. */
.main-header .logo-header .navbar-toggler,
.main-header .logo-header .topbar-toggler,
.main-header .logo-header .btn-minimize {
    color: var(--text-secondary) !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}
.main-header .logo-header .navbar-toggler:hover,
.main-header .logo-header .topbar-toggler:hover,
.main-header .logo-header .btn-minimize:hover {
    color: var(--brand-primary) !important;
}
.main-header .logo-header .navbar-toggler-icon {
    background: transparent !important;
    color: inherit !important;
}
.main-header .logo-header .navbar-toggler-icon i,
.main-header .logo-header .topbar-toggler i,
.main-header .logo-header .btn-minimize i {
    color: inherit !important;
    font-size: 16px !important;
}

/* ----- Mobile / narrow viewport: force the hamburger to be visible -----
   Azzara sets `.navbar-toggler { display: none; opacity: 0 }` by default
   and only shows it via media queries that our overrides accidentally beat. */
@media (max-width: 991.98px) {
    .main-header .logo-header .navbar-toggler,
    .main-header .logo-header .sidenav-toggler,
    .main-header .navbar-toggler {
        display: inline-flex !important;
        opacity: 1 !important;
        visibility: visible !important;
        align-items: center;
        justify-content: center;
        padding: 6px 10px !important;
        margin-right: 8px;
        color: var(--text-primary) !important;
        font-size: 18px !important;
        background: var(--bg-surface) !important;
        border: 1px solid var(--border-soft) !important;
        border-radius: var(--radius-sm) !important;
        cursor: pointer;
        height: auto !important;
        width: auto !important;
    }
    .main-header .logo-header .navbar-toggler:hover,
    .main-header .navbar-toggler:hover {
        border-color: var(--brand-primary) !important;
        color: var(--brand-primary) !important;
    }
    /* Render the bars glyph via a pseudo-element on the span itself,
       and hide the inner <i> (which Bootstrap was hiding via 1em × 1em
       constraints). This way the icon always shows regardless of what
       Bootstrap/Azzara do to the inner element. */
    .main-header .logo-header .navbar-toggler-icon {
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        width: auto !important;
        height: auto !important;
        background-image: none !important;
        background: transparent !important;
        color: inherit !important;
        font-size: 18px !important;
        line-height: 1 !important;
        vertical-align: middle;
    }
    .main-header .logo-header .navbar-toggler-icon::before {
        content: "\f0c9" !important;          /* fa-bars */
        font-family: "Font Awesome 5 Solid" !important;
        font-weight: 900 !important;
        font-size: 18px !important;
        line-height: 1 !important;
        /* Explicit dark color — `color: inherit` was picking up white from
           somewhere in the cascade. Force the slate-900 token directly. */
        color: var(--text-primary) !important;
        display: inline-block;
    }
    /* Also force the button + span colors so the inherited chain stays dark
       (defensive — if any rule re-sets color on the button, this beats it) */
    .main-header .logo-header .navbar-toggler,
    .main-header .logo-header .navbar-toggler:focus,
    .main-header .logo-header .navbar-toggler:active,
    .main-header .logo-header .navbar-toggler-icon {
        color: var(--text-primary) !important;
    }
    /* Hide the inner <i>, the pseudo-element takes its place */
    .main-header .logo-header .navbar-toggler-icon > i,
    .main-header .logo-header .navbar-toggler-icon > .fa,
    .main-header .logo-header .navbar-toggler-icon > .fas {
        display: none !important;
    }
    /* If a <button> directly contains the <i> (no span wrapper), keep it visible */
    .main-header .logo-header .navbar-toggler > i,
    .main-header .logo-header .navbar-toggler > .fa,
    .main-header .logo-header .navbar-toggler > .fas {
        color: inherit !important;
        font-size: 18px !important;
        line-height: 1 !important;
        display: inline-block !important;
        vertical-align: middle;
    }

    /* The topbar-toggler ("more" with ellipsis) — keep accessible on mobile too */
    .main-header .logo-header .topbar-toggler.more {
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        padding: 6px 8px !important;
        color: var(--text-secondary) !important;
        font-size: 18px !important;
    }

    /* Ensure the sidebar can overlay content when toggled open */
    .sidebar {
        z-index: 1000;
    }

    /* Logo wordmark — shrink further on narrow viewports */
    .main-header .logo-header .logo h1,
    .main-header .logo-header .logo h2,
    .main-header .logo-header .logo h3,
    .main-header .logo-header .logo h4 {
        max-width: 140px !important;
        font-size: 13px !important;
    }
}

/* Navbar (right-side area) padding */
.main-header .navbar-header {
    padding-left: 18px;
    padding-right: 18px;
}

/* Topbar action button group spacing */
.navbar-header .topbar-nav .nav-item + .nav-item {
    margin-left: 6px;
}

/* POS quick-action button — prominent CTA */
.navbar-header .topbar-nav a.btn-success,
.navbar-header .topbar-nav .btn.btn-success {
    background: var(--brand-accent) !important;
    border-color: var(--brand-accent) !important;
    color: #fff !important;
    padding: 8px 16px !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    border-radius: var(--radius-md) !important;
    box-shadow: 0 4px 12px rgba(16, 185, 129, .25) !important;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: background var(--transition-base),
                transform var(--transition-base),
                box-shadow var(--transition-base);
}
.navbar-header .topbar-nav a.btn-success:hover {
    background: var(--brand-accent-dark) !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(16, 185, 129, .32) !important;
}
.navbar-header .topbar-nav a.btn-success i {
    color: #fff !important;
    font-size: 13px !important;
}

/* Language switcher — clean custom class, no .btn / .btn-success baggage.
   Means no cascade fight with Phase 2's .btn-success white-color rule. */
.navbar-header .topbar-nav .lang-toggle,
.navbar-header .topbar-nav a.lang-toggle,
a.lang-toggle {
    background: var(--bg-surface) !important;
    border: 1px solid var(--border-soft) !important;
    color: var(--text-primary) !important;
    padding: 6px 14px !important;
    font-weight: 500 !important;
    font-size: 13px !important;
    border-radius: var(--radius-md) !important;
    box-shadow: none !important;
    display: inline-flex !important;
    align-items: center;
    gap: 6px;
    text-decoration: none !important;
    line-height: 1 !important;
    height: 34px;
    cursor: pointer;
}
.navbar-header .topbar-nav .lang-toggle:hover,
.navbar-header .topbar-nav .lang-toggle:focus,
a.lang-toggle:hover {
    border-color: var(--brand-primary) !important;
    color: var(--brand-primary) !important;
    background: var(--bg-surface) !important;
    text-decoration: none !important;
    transform: none;
}
.navbar-header .topbar-nav .lang-toggle i,
.navbar-header .topbar-nav .lang-toggle .lang-toggle__label,
a.lang-toggle i,
a.lang-toggle .lang-toggle__label {
    color: inherit !important;
    font-size: 13px !important;
    line-height: 1 !important;
}

/* Profile avatar — zero padding on the anchor so Bootstrap's default
   `.nav-link { padding: .5rem 1rem }` doesn't push the avatar below
   center in a 55px navbar. Avatar tuned to 32px so it sits comfortably. */
.navbar-header .profile-pic,
.navbar-header a.profile-pic,
.navbar-header .nav-link.profile-pic {
    cursor: pointer;
    margin-left: 6px;
    padding: 0 !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    height: 40px;
    line-height: 1 !important;
}
.navbar-header .profile-pic .avatar-sm,
.navbar-header a.profile-pic .avatar-sm {
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    overflow: hidden;
    border: 2px solid var(--border-soft);
    transition: border-color var(--transition-base);
    display: inline-block;
    flex-shrink: 0;
}
.navbar-header .profile-pic .avatar-sm .avatar-img,
.navbar-header .profile-pic .avatar-sm img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
    display: block;
}
.navbar-header .profile-pic:hover .avatar-sm {
    border-color: var(--brand-primary);
}

/* Align all topbar items along the navbar mid-line */
.navbar-header .topbar-nav,
.navbar-header .topbar-nav.navbar-nav {
    align-items: center !important;
    height: 100%;
}
.navbar-header .topbar-nav .nav-item {
    display: flex;
    align-items: center;
}

/* Dropdown menus from topbar */
.dropdown-menu {
    background: var(--bg-surface);
    border: 1px solid var(--border-soft);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    padding: 6px;
    margin-top: 6px;
    min-width: 200px;
    font-size: 13px;
}
.dropdown-menu .dropdown-item,
.dropdown-menu a.dropdown-item {
    border-radius: var(--radius-sm);
    padding: 8px 12px;
    color: var(--text-primary);
    transition: background-color var(--transition-fast),
                color var(--transition-fast);
    font-size: 13px;
}
.dropdown-menu .dropdown-item:hover,
.dropdown-menu .dropdown-item:focus {
    background-color: var(--brand-primary-light);
    color: var(--brand-primary);
}
.dropdown-menu .dropdown-item.active,
.dropdown-menu .dropdown-item:active {
    background-color: var(--brand-primary);
    color: var(--text-on-primary);
}
.dropdown-menu .dropdown-item i {
    width: 16px;
    text-align: center;
    margin-right: 8px;
    color: inherit;
}
.dropdown-divider {
    border-top: 1px solid var(--border-soft);
    margin: 6px 0;
}

/* Profile dropdown user-box */
.dropdown-user .user-box {
    padding: 14px 14px 10px;
    display: flex;
    gap: 12px;
    align-items: center;
}
.dropdown-user .user-box img {
    width: 44px !important;
    height: 44px !important;
    border-radius: 50%;
    object-fit: cover;
}
.dropdown-user .user-box .u-text h4 {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 2px;
}
.dropdown-user .user-box .u-text p {
    font-size: 12px;
    color: var(--text-secondary);
    margin: 0 0 6px;
}
.dropdown-user .user-box .btn {
    padding: 4px 10px !important;
    font-size: 12px !important;
}

/* ---------- Sidebar — light, premium SaaS feel ----------
   White surface, slate text, indigo accent on hover/active.
   Matches the white topbar for a unified, airy app shell. */
.sidebar,
.sidebar[data-background-color],
.sidebar[data-background-color="dark"],
.sidebar[data-background-color="white"],
.sidebar[data-background-color="white2"] {
    background: var(--bg-surface) !important;
    box-shadow: none;
    border-right: 1px solid var(--border-soft);
}

.sidebar .sidebar-wrapper,
.sidebar .sidebar-content {
    background: transparent;
}

/* User info block at the top of the sidebar — flexbox so all info lines
   (name, email, branch) align together to the right of the avatar instead
   of wrapping under it (which is what `float: left` was causing). */
.sidebar .user {
    padding: 16px 20px !important;
    border-bottom: 1px solid var(--border-soft);
    background: transparent !important;
    margin-bottom: 6px;
    display: flex !important;
    align-items: center;
    gap: 12px;
}
.sidebar .user::after {
    display: none !important;
}

/* Force the avatar out of the floated layout */
.sidebar .user .avatar-sm,
.sidebar .user > .avatar-sm.float-left {
    float: none !important;
    margin: 0 !important;
    flex-shrink: 0;
    width: 40px;
    height: 40px;
}
.sidebar .user .avatar-img,
.sidebar .user img.avatar-img {
    width: 40px !important;
    height: 40px !important;
    border-radius: 50% !important;
    object-fit: cover;
    border: 2px solid var(--border-soft);
    background: var(--bg-surface-2);
    display: block;
}

/* Info column — takes remaining space */
.sidebar .user .info {
    padding-left: 0 !important;
    flex: 1;
    min-width: 0;        /* allow ellipsis on long emails */
    overflow: hidden;
}
.sidebar .user .info a {
    color: var(--text-primary) !important;
    font-weight: 600;
    font-size: 13px;
    text-decoration: none;
    display: block;
    line-height: 1.2;
}
.sidebar .user .info a > span:first-child {
    display: flex;
    flex-direction: column;
    gap: 1px;
    line-height: 1.25;
}
.sidebar .user .info .user-level {
    color: var(--text-secondary) !important;
    font-size: 11px !important;
    display: block !important;
    font-weight: 400;
    margin-top: 1px;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}

/* Section dividers — thin horizontal line between groups. No text labels. */
.sidebar .nav li.sidebar-divider,
.sidebar .nav .sidebar-divider {
    list-style: none;
    margin: 8px 20px !important;
    padding: 0;
    height: 1px;
    background: var(--border-soft);
    border: none;
    display: block;
    box-shadow: none;
}

/* Hide the old section heading entirely if any still slip through */
.sidebar .nav li.nav-section,
.sidebar .nav-section {
    display: none !important;
}

/* Nav items — tightened spacing.
   Azzara forces `.sidebar .nav > .nav-item a { padding: 6px 25px; margin-bottom: 3px }`
   and `.sidebar .nav { margin-top: 20px }`. We override all of them. */
.sidebar .nav {
    padding: 0 !important;
    margin-top: 4px !important;
}
.sidebar .nav > .nav-item {
    margin: 0 12px !important;
    list-style: none;
    padding: 0 !important;
}
.sidebar .nav > .nav-item > a {
    color: var(--text-secondary) !important;
    padding: 7px 12px !important;
    margin-bottom: 1px !important;
    border-radius: var(--radius-sm) !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    line-height: 1.3 !important;
    display: flex !important;
    align-items: center;
    gap: 12px;
    text-decoration: none !important;
    transition: background-color var(--transition-fast),
                color var(--transition-fast);
    position: relative;
    width: auto !important;
}
.sidebar .nav > .nav-item > a:hover,
.sidebar .nav > .nav-item > a:focus {
    background-color: var(--bg-surface-2) !important;
    color: var(--text-primary) !important;
}

.sidebar .nav > .nav-item > a > i {
    font-size: 15px !important;
    width: 20px;
    text-align: center;
    color: var(--text-muted) !important;
    margin: 0 !important;
    line-height: 1;
    transition: color var(--transition-fast);
}
.sidebar .nav > .nav-item:hover > a > i {
    color: var(--brand-primary) !important;
}
.sidebar .nav > .nav-item > a > p {
    margin: 0 !important;
    flex: 1;
    color: inherit !important;
    font-size: 13.5px !important;
}

/* Caret for collapsible items */
.sidebar .nav > .nav-item > a > .caret {
    margin: 0 !important;
    color: var(--text-muted) !important;
    font-size: 10px;
    transition: transform var(--transition-base);
    border: none !important;
    width: auto !important;
    height: auto !important;
}
.sidebar .nav > .nav-item > a[aria-expanded="true"] > .caret {
    transform: rotate(180deg);
}

/* ----- Active states (overriding Azzara's defaults) -----
   Azzara forces these with !important:
     .sidebar .nav>.nav-item.active>a:before { background:#1d7af3; width:3px; height:100% }
     .nav-item.active>a { background:rgba(0,0,0,.03) }
     .nav-item.submenu  { background:rgba(0,0,0,.03) }
     .nav-item.active a i { color:#4d7cfe }
   We kill all of them and apply a single-emphasis pattern. */

/* Kill Azzara's blue strip pseudo on ALL active items + the bg/color tint */
.sidebar .nav > .nav-item.active > a::before,
.sidebar .nav > .nav-item.active:hover > a::before,
.sidebar .nav > .nav-item.submenu > a::before,
.sidebar .nav-item a[data-toggle="collapse"][aria-expanded="true"]::before {
    display: none !important;
    content: none !important;
    background: none !important;
    width: 0 !important;
    height: 0 !important;
    opacity: 0 !important;
}

/* Kill Azzara's grey background on submenu container + active item */
.sidebar .nav > .nav-item.submenu,
.sidebar .nav > .nav-item.active,
.sidebar .nav .nav-item.submenu,
.sidebar .nav .nav-item.active {
    background: transparent !important;
}

/* Parent of an open/active submenu — color emphasis only, no bg */
.sidebar .nav > .nav-item.active > a,
.sidebar .nav > .nav-item.active:hover > a,
.sidebar .nav > .nav-item.submenu > a,
.sidebar .nav > .nav-item.submenu:hover > a {
    background-color: transparent !important;
    color: var(--brand-primary) !important;
    font-weight: 600 !important;
    position: relative;
}
.sidebar .nav > .nav-item.active > a > i,
.sidebar .nav > .nav-item.active > a > p,
.sidebar .nav > .nav-item.submenu > a > i,
.sidebar .nav > .nav-item.submenu > a > p,
.sidebar .nav > .nav-item.active a i {
    color: var(--brand-primary) !important;
}

/* Leaf active menu (no submenu — Dashboard, POS) — pale indigo pill + glow strip */
.sidebar .nav > .nav-item.active:not(.submenu) > a {
    background-color: var(--brand-primary-light) !important;
}
.sidebar .nav > .nav-item.active:not(.submenu) > a::before {
    display: block !important;
    content: "" !important;
    position: absolute !important;
    left: -12px !important;
    top: 8px !important;
    bottom: 8px !important;
    width: 3px !important;
    height: auto !important;
    background: linear-gradient(180deg, var(--brand-primary), var(--brand-accent)) !important;
    border-radius: 0 3px 3px 0 !important;
    box-shadow: 0 0 10px rgba(79, 70, 229, .35) !important;
    opacity: 1 !important;
    z-index: 1;
}

/* ----- Submenu (collapsible) — tightened. Azzara has 25px of vertical padding here. ----- */
.sidebar .nav .nav-collapse {
    padding: 2px 0 4px 30px !important;
    margin: 0 0 2px !important;
    list-style: none;
    background: transparent !important;
}
.sidebar .nav .nav-collapse li {
    list-style: none;
    margin: 0 !important;
    padding: 0 !important;
}
.sidebar .nav .nav-collapse li a {
    color: var(--text-secondary) !important;
    padding: 6px 14px !important;
    margin-bottom: 0 !important;
    display: block;
    text-decoration: none !important;
    font-size: 12.5px !important;
    line-height: 1.3 !important;
    border-radius: var(--radius-sm) !important;
    transition: background-color var(--transition-fast),
                color var(--transition-fast);
    background: transparent !important;
    position: relative;
    margin-right: 12px;
}
.sidebar .nav .nav-collapse li a:hover {
    background-color: var(--bg-surface-2) !important;
    color: var(--text-primary) !important;
}

/* Kill Azzara's default ::before bullet on .sub-item */
.sidebar .nav .nav-collapse li a .sub-item {
    color: inherit !important;
    margin-left: 0 !important;
    opacity: 1 !important;
    font-size: inherit !important;
    position: static !important;
}
.sidebar .nav .nav-collapse li a .sub-item::before,
.sidebar .nav .nav-collapse li a:hover .sub-item::before {
    display: none !important;
    content: none !important;
    opacity: 0 !important;
}

/* Active sub-item — subtle indigo tint + small left accent strip */
.sidebar .nav .nav-collapse li.active > a {
    background-color: var(--brand-primary-light) !important;
    color: var(--brand-primary) !important;
    font-weight: 600 !important;
}
.sidebar .nav .nav-collapse li.active > a::before {
    content: "";
    position: absolute;
    left: -8px;
    top: 6px;
    bottom: 6px;
    width: 2px;
    background: var(--brand-primary);
    border-radius: 2px;
}

/* Sidebar scrollbar (Chromium / Firefox) — slate, not white-on-dark */
.sidebar .sidebar-wrapper {
    scrollbar-width: thin;
    scrollbar-color: var(--border-strong) transparent;
}
.sidebar .sidebar-wrapper::-webkit-scrollbar {
    width: 6px;
}
.sidebar .sidebar-wrapper::-webkit-scrollbar-track {
    background: transparent;
}
.sidebar .sidebar-wrapper::-webkit-scrollbar-thumb {
    background: var(--border-strong);
    border-radius: 3px;
}
.sidebar .sidebar-wrapper::-webkit-scrollbar-thumb:hover {
    background: var(--text-muted);
}

/* Smooth collapse animation */
.sidebar .collapse,
.sidebar .collapsing {
    transition: height var(--transition-base) !important;
}

/* ---------- Sidebar minimize / collapsed mode ----------
   Azzara toggles `body.sidebar_minimize`. The sidebar narrows to icons.
   Hide all labels (info column, item text, caret) and center the avatar
   so the user block doesn't dominate the collapsed width. */
body.sidebar_minimize .sidebar .user,
.sidebar_minimize .sidebar .user {
    padding: 12px 0 !important;
    justify-content: center !important;
    gap: 0 !important;
}
body.sidebar_minimize .sidebar .user .info,
.sidebar_minimize .sidebar .user .info {
    display: none !important;
}
body.sidebar_minimize .sidebar .user .avatar-sm,
.sidebar_minimize .sidebar .user .avatar-sm {
    width: 32px !important;
    height: 32px !important;
    margin: 0 !important;
}
body.sidebar_minimize .sidebar .user .avatar-img,
.sidebar_minimize .sidebar .user .avatar-img {
    width: 32px !important;
    height: 32px !important;
    border-width: 1.5px !important;
}

/* When the user hovers the collapsed sidebar, Azzara restores the full
   width temporarily. Bring the info column back so the user block reads
   normally during hover. */
body.sidebar_minimize .sidebar:hover .user,
.sidebar_minimize .sidebar:hover .user {
    padding: 16px 20px !important;
    justify-content: flex-start !important;
    gap: 12px !important;
}
body.sidebar_minimize .sidebar:hover .user .info,
.sidebar_minimize .sidebar:hover .user .info {
    display: block !important;
}
body.sidebar_minimize .sidebar:hover .user .avatar-sm,
.sidebar_minimize .sidebar:hover .user .avatar-sm {
    width: 40px !important;
    height: 40px !important;
}
body.sidebar_minimize .sidebar:hover .user .avatar-img,
.sidebar_minimize .sidebar:hover .user .avatar-img {
    width: 40px !important;
    height: 40px !important;
    border-width: 2px !important;
}

/* Hide menu labels and carets in collapsed mode (Azzara already does this
   for the default sidebar, but our overrides re-shown them) */
body.sidebar_minimize .sidebar:not(:hover) .nav > .nav-item > a > p,
body.sidebar_minimize .sidebar:not(:hover) .nav > .nav-item > a > .caret,
body.sidebar_minimize .sidebar:not(:hover) .sidebar-divider {
    display: none !important;
}
body.sidebar_minimize .sidebar:not(:hover) .nav > .nav-item > a {
    justify-content: center !important;
    padding: 9px 0 !important;
}
body.sidebar_minimize .sidebar:not(:hover) .nav > .nav-item > a > i {
    margin: 0 !important;
}
/* Suppress the active-state strip when collapsed (it would float outside the icon area) */
body.sidebar_minimize .sidebar:not(:hover) .nav > .nav-item.active:not(.submenu) > a::before {
    display: none !important;
}

/* End Phase 5 */

/* ============================================================
   POS / Add New Order page enhancements
   Targets `admin/orders/create.blade.php`. Product cards become
   clickable tiles with floating indigo price chips. Cart panel
   sticks to the right with a clean total + empty state.
   ============================================================ */

/* ---------- Category filter chips (top of product grid) ----------
   Horizontal scrollable row. "All" + one chip per category. Each chip
   shows the category name and a small count badge. Active chip is
   indigo-filled; inactive is a soft pill with hover wash. */
.pos-categories {
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 2px 2px 14px;
    margin: 0 -2px 14px;
    border-bottom: 1px solid var(--border-soft);
    scrollbar-width: thin;
    scrollbar-color: var(--border-strong) transparent;
}
.pos-categories::-webkit-scrollbar { height: 4px; }
.pos-categories::-webkit-scrollbar-track { background: transparent; }
.pos-categories::-webkit-scrollbar-thumb {
    background: var(--border-strong);
    border-radius: 2px;
}

.pos-category-chip {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 14px;
    background: var(--bg-surface);
    border: 1px solid var(--border-soft);
    color: var(--text-secondary);
    font-family: var(--font-ui);
    font-size: 13px;
    font-weight: 600;
    border-radius: 999px;
    cursor: pointer;
    transition: background-color var(--transition-fast),
                border-color var(--transition-fast),
                color var(--transition-fast),
                box-shadow var(--transition-fast),
                transform var(--transition-fast);
    box-shadow: none;
    line-height: 1.3;
    white-space: nowrap;
}
.pos-category-chip:hover {
    background: var(--brand-primary-light);
    border-color: var(--brand-primary-light);
    color: var(--brand-primary);
}
.pos-category-chip:focus {
    outline: none;
    box-shadow: var(--shadow-ring-primary);
}
.pos-category-chip.is-active {
    background: var(--brand-primary);
    border-color: var(--brand-primary);
    color: var(--text-on-primary);
    box-shadow: 0 4px 12px rgba(79, 70, 229, .25);
}
.pos-category-chip.is-active:hover {
    background: var(--brand-primary-dark);
    border-color: var(--brand-primary-dark);
    color: var(--text-on-primary);
}

/* Categories with zero items — subordinate visually so the user can still
   see every category but understands at a glance which ones are empty. */
.pos-category-chip.is-empty {
    opacity: 0.5;
}
.pos-category-chip.is-empty:hover {
    opacity: 1;
}

/* Small count badge inside the chip */
.pos-category-chip__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 18px;
    padding: 0 6px;
    border-radius: 999px;
    background: rgba(15, 23, 42, .08);
    color: var(--text-secondary);
    font-size: 11px;
    font-weight: 700;
    line-height: 1;
    transition: background var(--transition-fast), color var(--transition-fast);
}
.pos-category-chip:hover .pos-category-chip__count {
    background: rgba(79, 70, 229, .14);
    color: var(--brand-primary);
}
.pos-category-chip.is-active .pos-category-chip__count {
    background: rgba(255, 255, 255, .22);
    color: #fff;
}

/* ---------- Product card ---------- */
#product-list .pos-product-card,
#product-list > .col-lg-3 > .card.pos-product-card {
    background: var(--bg-surface);
    border: 1px solid var(--border-soft) !important;
    border-radius: var(--radius-md) !important;
    box-shadow: var(--shadow-sm) !important;
    margin-bottom: 16px;
    position: relative;
    overflow: hidden;
    transition: transform var(--transition-base),
                box-shadow var(--transition-base),
                border-color var(--transition-base);
    height: calc(100% - 16px);
    display: flex;
    flex-direction: column;
}
#product-list .pos-product-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md) !important;
    border-color: var(--brand-primary) !important;
}

#product-list .pos-product-card .card-body {
    padding: 16px !important;
    display: flex;
    flex-direction: column;
    flex: 1;
}

/* Price chip — replaces the heavy bg-dark badge */
#product-list .pos-product-card__price {
    position: absolute;
    top: 10px;
    right: 10px;
    background: linear-gradient(135deg, var(--brand-primary), var(--brand-primary-dark));
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    padding: 4px 11px;
    border-radius: 999px;
    box-shadow: 0 3px 8px rgba(79, 70, 229, .28);
    letter-spacing: 0.01em;
    line-height: 1.3;
    z-index: 2;
}
#product-list .pos-product-card__price::after {
    content: "/=";
    margin-left: 2px;
    font-size: 11px;
    opacity: 0.75;
}

/* Product name */
#product-list .pos-product-card__name {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 14px;
    padding-right: 62px;
    line-height: 1.35;
    min-height: 36px;
    flex: 1;
}

/* Add to Cart button — pale indigo at rest, solid on hover */
#product-list .pos-product-card__btn,
#product-list .pos-product-card .add-to-cart {
    background: var(--brand-primary-light) !important;
    border: 1px solid var(--brand-primary-light) !important;
    color: var(--brand-primary) !important;
    font-weight: 600 !important;
    font-size: 12px !important;
    padding: 8px 10px !important;
    border-radius: var(--radius-sm) !important;
    box-shadow: none !important;
    transition: all var(--transition-fast);
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 6px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    width: 100%;
    cursor: pointer;
}
#product-list .pos-product-card__btn::before {
    content: "\f067"; /* fa-plus */
    font-family: "Font Awesome 5 Solid";
    font-weight: 900;
    font-size: 10px;
}
#product-list .pos-product-card__btn:hover,
#product-list .pos-product-card .add-to-cart:hover {
    background: var(--brand-primary) !important;
    border-color: var(--brand-primary) !important;
    color: var(--text-on-primary) !important;
    transform: none !important;
    box-shadow: 0 4px 10px rgba(79, 70, 229, .26) !important;
}

/* Custom item card — dashed indigo border distinguishes it as an action */
#product-list .pos-product-card.pos-product-card--custom {
    border: 1.5px dashed var(--brand-primary) !important;
    background: linear-gradient(135deg, rgba(79, 70, 229, .03), rgba(16, 185, 129, .03));
    box-shadow: none !important;
}
#product-list .pos-product-card.pos-product-card--custom:hover {
    background: linear-gradient(135deg, rgba(79, 70, 229, .06), rgba(16, 185, 129, .06));
    border-color: var(--brand-primary-dark) !important;
}
#product-list .pos-product-card__btn--custom {
    background: transparent !important;
    border: none !important;
    color: var(--brand-primary) !important;
}
#product-list .pos-product-card__btn--custom::before {
    content: none !important;
}
#product-list .pos-product-card__btn--custom:hover {
    background: var(--brand-primary-light) !important;
    color: var(--brand-primary) !important;
    box-shadow: none !important;
}

/* ---------- Cart / total panel ---------- */
.total-box.pos-cart,
.pos-cart {
    background: var(--bg-surface) !important;
    border: 1px solid var(--border-soft) !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-sm) !important;
    padding: 20px !important;
    position: sticky;
    top: 80px;
    display: flex;
    flex-direction: column;
}

/* Header: small label + big indigo amount */
.pos-cart__header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    padding-bottom: 14px;
    margin-bottom: 14px;
    border-bottom: 1px solid var(--border-soft);
}
.pos-cart__label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
}
.pos-cart__amount {
    font-size: 28px;
    font-weight: 700;
    color: var(--brand-primary);
    letter-spacing: -0.025em;
    line-height: 1;
}
.pos-cart__amount::after {
    content: "/=";
    font-size: 13px;
    color: var(--text-muted);
    font-weight: 500;
    margin-left: 2px;
}

/* Cart items list */
.pos-cart__items {
    list-style: none;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent;
    border: none !important;
    min-height: 240px;
    max-height: 380px;
    overflow-y: auto;
    border-radius: 0;
}

/* Empty cart state */
.pos-cart__items:empty {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-surface-2);
    border: 1px dashed var(--border-soft) !important;
    border-radius: var(--radius-md);
    margin: 4px 0 !important;
}
.pos-cart__items:empty::before {
    content: "\f07a\A\A Tap a product to add";  /* fa-shopping-cart + newlines */
    font-family: "Font Awesome 5 Solid", var(--font-ui);
    white-space: pre-wrap;
    text-align: center;
    color: var(--text-muted);
    font-size: 13px;
    font-weight: 500;
    line-height: 1.5;
    padding: 40px 20px;
}
.pos-cart__items:empty::first-line {
    font-size: 36px;
    opacity: 0.4;
}

/* Cart item rows */
#cart-items .list-group-item,
.pos-cart__items .list-group-item {
    border: none !important;
    border-bottom: 1px solid var(--border-soft-2) !important;
    padding: 10px 8px !important;
    font-size: 13px !important;
    color: var(--text-primary) !important;
    background: transparent !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    font-weight: 500;
    border-radius: 0 !important;
}
#cart-items .list-group-item:last-child,
.pos-cart__items .list-group-item:last-child {
    border-bottom: none !important;
}
#cart-items .list-group-item:hover,
.pos-cart__items .list-group-item:hover {
    background: var(--bg-surface-2) !important;
}

/* Remove (×) button inside cart row */
#cart-items .remove-item.btn-danger,
#cart-items .remove-item,
.pos-cart__items .remove-item {
    padding: 0 !important;
    min-width: 26px !important;
    width: 26px !important;
    height: 26px !important;
    font-size: 16px !important;
    line-height: 1 !important;
    background: transparent !important;
    border: none !important;
    color: var(--text-muted) !important;
    box-shadow: none !important;
    border-radius: 50% !important;
    transition: all var(--transition-fast);
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
#cart-items .remove-item:hover,
.pos-cart__items .remove-item:hover {
    background: var(--brand-danger-light) !important;
    color: var(--brand-danger) !important;
    transform: none !important;
}

/* Action buttons — Place Order + Print stacked */
.pos-cart__actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--border-soft);
}
.pos-cart__actions #place-order-btn,
.pos-cart__actions #print-order-btn {
    width: 100% !important;
    padding: 11px !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    letter-spacing: 0.02em;
    margin: 0 !important;
}
.pos-cart__actions #place-order-btn {
    background: var(--brand-primary) !important;
    border-color: var(--brand-primary) !important;
    color: var(--text-on-primary) !important;
    box-shadow: 0 4px 12px rgba(79, 70, 229, .22) !important;
}
.pos-cart__actions #place-order-btn:hover {
    background: var(--brand-primary-dark) !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(79, 70, 229, .28) !important;
}
.pos-cart__actions #print-order-btn {
    background: var(--brand-accent) !important;
    border-color: var(--brand-accent) !important;
    color: #fff !important;
    box-shadow: 0 4px 12px rgba(16, 185, 129, .22) !important;
}
.pos-cart__actions #print-order-btn:hover {
    background: var(--brand-accent-dark) !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(16, 185, 129, .28) !important;
}

/* Page header — back arrow as a subtle pill */
.page-inner .card-header .btn-primary.btn-xs {
    padding: 7px 12px !important;
    border-radius: var(--radius-sm) !important;
    background: var(--brand-primary-light) !important;
    border-color: var(--brand-primary-light) !important;
    color: var(--brand-primary) !important;
    box-shadow: none !important;
    min-width: 32px;
    height: 32px;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
}
.page-inner .card-header .btn-primary.btn-xs:hover {
    background: var(--brand-primary) !important;
    color: var(--text-on-primary) !important;
    transform: translateY(-1px);
}
.page-inner .card-header .btn-primary.btn-xs i {
    color: inherit !important;
}

/* ---------- Mobile responsiveness ---------- */
@media (max-width: 991.98px) {
    .total-box.pos-cart,
    .pos-cart {
        position: static !important;
        margin-top: 18px;
    }
}
@media (max-width: 575.98px) {
    .pos-cart__amount {
        font-size: 24px;
    }
    #product-list .pos-product-card__name {
        padding-right: 56px;
        min-height: 32px;
    }
}

/* End POS */

/* ============================================================
   Select2 — third-party dropdown widget restyling
   Azzara wires Select2 onto every `.form-control` select. Default
   Select2 highlight is `#5897fb` bright blue — replaced with our
   brand indigo across trigger, dropdown panel, and option states.
   ============================================================ */

/* Single-select trigger — match our .form-control look */
.select2-container--default .select2-selection--single,
.select2-container--bootstrap4 .select2-selection--single {
    height: auto !important;
    min-height: 42px;
    padding: 8px 14px !important;
    border: 1px solid var(--border-soft) !important;
    border-radius: var(--radius-md) !important;
    background-color: var(--bg-surface) !important;
    transition: border-color var(--transition-base),
                box-shadow var(--transition-base);
    box-shadow: none !important;
    display: flex;
    align-items: center;
}
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--bootstrap4.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--open .select2-selection--single {
    border-color: var(--brand-primary) !important;
    box-shadow: var(--shadow-ring-primary) !important;
    outline: none !important;
}
.select2-container--default:hover .select2-selection--single {
    border-color: var(--border-strong) !important;
}

.select2-container--default .select2-selection__rendered,
.select2-container--default .select2-selection--single .select2-selection__rendered {
    color: var(--text-primary) !important;
    font-family: var(--font-ui) !important;
    font-size: 14px !important;
    line-height: 1.4 !important;
    padding-left: 0 !important;
    padding-right: 28px !important;
}
.select2-container--default .select2-selection__placeholder {
    color: var(--text-muted) !important;
}

/* Chevron arrow — slate at rest, indigo when open */
.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 100% !important;
    width: 28px !important;
    right: 4px !important;
    top: 0 !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow b {
    border-color: var(--text-muted) transparent transparent transparent !important;
    border-width: 5px 5px 0 5px !important;
}
.select2-container--default.select2-container--open .select2-selection--single .select2-selection__arrow b {
    border-color: transparent transparent var(--brand-primary) transparent !important;
    border-width: 0 5px 5px 5px !important;
}

/* Clear (×) button on multi-select / clearable */
.select2-container--default .select2-selection__clear {
    color: var(--text-muted) !important;
    font-size: 16px;
    margin-right: 6px;
    transition: color var(--transition-fast);
}
.select2-container--default .select2-selection__clear:hover {
    color: var(--brand-danger) !important;
}

/* ---------- Dropdown panel ---------- */
.select2-dropdown,
.select2-container--default .select2-dropdown {
    border: 1px solid var(--border-soft) !important;
    border-radius: var(--radius-md) !important;
    box-shadow: var(--shadow-lg) !important;
    background-color: var(--bg-surface) !important;
    overflow: hidden;
    margin-top: 4px;
}

/* Search box at the top of the dropdown */
.select2-search--dropdown .select2-search__field {
    border: 1px solid var(--border-soft) !important;
    border-radius: var(--radius-sm) !important;
    padding: 8px 12px !important;
    font-family: var(--font-ui) !important;
    font-size: 13px !important;
    color: var(--text-primary) !important;
    background-color: var(--bg-surface) !important;
    transition: border-color var(--transition-base),
                box-shadow var(--transition-base);
}
.select2-search--dropdown .select2-search__field:focus {
    border-color: var(--brand-primary) !important;
    box-shadow: var(--shadow-ring-primary) !important;
    outline: none !important;
}
.select2-search--dropdown {
    padding: 8px !important;
    border-bottom: 1px solid var(--border-soft-2);
}

/* ---------- Option rows ---------- */
.select2-results__options {
    padding: 6px !important;
    max-height: 320px !important;
}
.select2-container--default .select2-results__option {
    padding: 8px 12px !important;
    color: var(--text-primary) !important;
    font-family: var(--font-ui) !important;
    font-size: 13.5px !important;
    border-radius: var(--radius-sm) !important;
    margin: 1px 0;
    transition: background-color var(--transition-fast),
                color var(--transition-fast);
    line-height: 1.4;
}

/* Highlighted = hover or keyboard-focus — replace bright Select2 blue */
.select2-container--default .select2-results__option--highlighted,
.select2-container--default .select2-results__option--highlighted[aria-selected],
.select2-container--default .select2-results__option--highlighted[data-selected="true"] {
    background-color: var(--brand-primary-light) !important;
    color: var(--brand-primary) !important;
}

/* Currently selected option */
.select2-container--default .select2-results__option--selected,
.select2-container--default .select2-results__option[aria-selected="true"],
.select2-container--default .select2-results__option[data-selected="true"] {
    background-color: var(--brand-primary) !important;
    color: var(--text-on-primary) !important;
    font-weight: 600;
}
/* Selected + highlighted (e.g. selected option being hovered) */
.select2-container--default .select2-results__option--highlighted.select2-results__option--selected,
.select2-container--default .select2-results__option--highlighted[aria-selected="true"] {
    background-color: var(--brand-primary-dark) !important;
    color: var(--text-on-primary) !important;
}

/* Disabled option */
.select2-container--default .select2-results__option--disabled {
    color: var(--text-muted) !important;
    cursor: not-allowed !important;
}

/* "No results found" placeholder */
.select2-container--default .select2-results__option.select2-results__option--no-results {
    color: var(--text-muted) !important;
    font-style: italic;
    text-align: center;
    padding: 16px 12px !important;
}

/* End Select2 */

/* ============================================================
   PHASE 6 — Toasts, Modals, Badges, Alerts, Empty States
   Polish for every small surface that shows up across modules.
   ============================================================ */

/* ---------- Modals (Bootstrap 4) ---------- */
.modal-content {
    border: 1px solid var(--border-soft);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    background: var(--bg-surface);
    overflow: hidden;
}
.modal-header {
    border-bottom: 1px solid var(--border-soft);
    padding: 18px 22px;
    display: flex;
    align-items: center;
    background: var(--bg-surface);
}
.modal-title {
    font-family: var(--font-ui);
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
    letter-spacing: -0.01em;
    margin: 0;
    line-height: 1.3;
}
.modal-body {
    padding: 22px;
    color: var(--text-primary);
    font-size: 14px;
    line-height: 1.5;
}
.modal-footer {
    border-top: 1px solid var(--border-soft);
    padding: 14px 22px;
    background: var(--bg-surface-2);
    border-bottom-left-radius: var(--radius-lg);
    border-bottom-right-radius: var(--radius-lg);
    gap: 8px;
}
.modal-footer .btn + .btn {
    margin-left: 0;   /* gap handles spacing now */
}

/* × close button */
.modal-header .close,
.modal .close,
button.close {
    background: transparent !important;
    border: none !important;
    color: var(--text-muted) !important;
    font-size: 22px !important;
    font-weight: 400 !important;
    opacity: 1 !important;
    padding: 4px 10px !important;
    margin: -8px -10px -8px auto !important;
    border-radius: var(--radius-sm) !important;
    transition: background-color var(--transition-fast), color var(--transition-fast) !important;
    cursor: pointer;
    text-shadow: none !important;
    box-shadow: none !important;
    line-height: 1 !important;
}
.modal-header .close:hover,
.modal .close:hover,
button.close:hover {
    background: var(--bg-surface-2) !important;
    color: var(--text-primary) !important;
}

/* Backdrop — subtle, slate instead of pure black */
.modal-backdrop {
    background-color: var(--text-primary);
}
.modal-backdrop.show {
    opacity: 0.55;
}

/* Modal dialog max-width on larger screens */
.modal-dialog {
    margin: 32px auto;
}
@media (max-width: 575.98px) {
    .modal-dialog {
        margin: 16px;
    }
    .modal-header, .modal-body, .modal-footer {
        padding: 16px 18px;
    }
}

/* ---------- Badges ---------- */
.badge {
    font-family: var(--font-ui);
    font-weight: 600;
    font-size: 11px;
    padding: 4px 10px;
    border-radius: 999px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    line-height: 1.3;
    vertical-align: middle;
}

/* Solid color variants — kept simple, brand-aligned */
.badge-primary {
    background: var(--brand-primary);
    color: var(--text-on-primary);
}
.badge-success {
    background: var(--brand-accent);
    color: #fff;
}
.badge-danger {
    background: var(--brand-danger);
    color: #fff;
}
.badge-warning {
    background: var(--brand-warning);
    color: #fff;
}
.badge-info {
    background: var(--brand-info);
    color: #fff;
}
.badge-secondary {
    background: var(--text-secondary);
    color: #fff;
}
.badge-light {
    background: var(--bg-surface-2);
    color: var(--text-primary);
    border: 1px solid var(--border-soft);
}
.badge-dark {
    background: var(--text-primary);
    color: #fff;
}

/* Soft variants — modern SaaS status pill pattern (opt-in via .badge-soft-X) */
.badge-soft-primary {
    background: var(--brand-primary-light);
    color: var(--brand-primary);
}
.badge-soft-success {
    background: var(--brand-accent-light);
    color: var(--brand-accent-dark);
}
.badge-soft-danger {
    background: var(--brand-danger-light);
    color: var(--brand-danger);
}
.badge-soft-warning {
    background: var(--brand-warning-light);
    color: #B45309; /* amber-700 for AA contrast */
}
.badge-soft-info {
    background: rgba(14, 165, 233, .12);
    color: #0369A1; /* sky-700 */
}
.badge-soft-secondary {
    background: var(--bg-surface-2);
    color: var(--text-secondary);
}

/* Dot inside badge — small status indicator */
.badge .badge-dot,
.badge-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: currentColor;
    display: inline-block;
    margin-right: 6px;
    flex-shrink: 0;
}

/* Badge pill — explicit modifier (default radius is already pill, but keep for compat) */
.badge-pill {
    border-radius: 999px;
}

/* ---------- Alerts ---------- */
.alert {
    border-radius: var(--radius-md);
    border: 1px solid transparent;
    padding: 14px 18px;
    font-size: 14px;
    margin-bottom: 18px;
    font-family: var(--font-ui);
    line-height: 1.5;
    display: flex;
    align-items: flex-start;
    gap: 10px;
}
.alert-primary {
    background: var(--brand-primary-light);
    color: var(--brand-primary-dark);
    border-color: rgba(79, 70, 229, .22);
}
.alert-success {
    background: var(--brand-accent-light);
    color: var(--brand-accent-dark);
    border-color: rgba(16, 185, 129, .25);
}
.alert-danger {
    background: var(--brand-danger-light);
    color: var(--brand-danger);
    border-color: rgba(239, 68, 68, .25);
}
.alert-warning {
    background: var(--brand-warning-light);
    color: #92400E;
    border-color: rgba(245, 158, 11, .3);
}
.alert-info {
    background: rgba(14, 165, 233, .08);
    color: #075985;
    border-color: rgba(14, 165, 233, .25);
}
.alert-secondary,
.alert-light {
    background: var(--bg-surface-2);
    color: var(--text-secondary);
    border-color: var(--border-soft);
}
.alert .close {
    color: inherit !important;
    opacity: 0.65 !important;
    margin-left: auto !important;
}
.alert .close:hover {
    opacity: 1 !important;
    background: rgba(0, 0, 0, .04) !important;
}

/* Optional leading icon inside alert (visual hint) */
.alert .alert-icon,
.alert > i:first-child {
    flex-shrink: 0;
    font-size: 16px;
    line-height: 1.5;
}

/* ---------- SweetAlert2 ---------- */
.swal2-popup {
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-lg) !important;
    font-family: var(--font-ui) !important;
    padding: 26px !important;
    border: 1px solid var(--border-soft) !important;
}
.swal2-title {
    font-family: var(--font-ui) !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--text-primary) !important;
    letter-spacing: -0.01em !important;
    padding: 0 !important;
    margin: 0 0 6px !important;
}
.swal2-html-container,
.swal2-content {
    font-family: var(--font-ui) !important;
    font-size: 14px !important;
    color: var(--text-secondary) !important;
    margin: 0 !important;
    line-height: 1.5 !important;
}
.swal2-actions {
    margin-top: 18px !important;
    gap: 8px;
}

.swal2-confirm,
.swal2-styled.swal2-confirm {
    background: var(--brand-primary) !important;
    border: none !important;
    border-radius: var(--radius-md) !important;
    padding: 9px 22px !important;
    font-family: var(--font-ui) !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    box-shadow: 0 4px 12px rgba(79, 70, 229, .22) !important;
    color: var(--text-on-primary) !important;
    transition: background var(--transition-base), transform var(--transition-base), box-shadow var(--transition-base);
}
.swal2-confirm:hover,
.swal2-styled.swal2-confirm:hover {
    background: var(--brand-primary-dark) !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(79, 70, 229, .28) !important;
}
.swal2-cancel,
.swal2-styled.swal2-cancel {
    background: var(--bg-surface-2) !important;
    color: var(--text-primary) !important;
    border: 1px solid var(--border-soft) !important;
    border-radius: var(--radius-md) !important;
    padding: 9px 22px !important;
    font-family: var(--font-ui) !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    box-shadow: none !important;
}
.swal2-cancel:hover {
    background: var(--bg-surface) !important;
    border-color: var(--border-strong) !important;
    transform: translateY(-1px);
}
.swal2-deny,
.swal2-styled.swal2-deny {
    background: var(--brand-danger) !important;
    border: none !important;
    border-radius: var(--radius-md) !important;
    color: #fff !important;
    box-shadow: 0 4px 12px rgba(239, 68, 68, .22) !important;
}

/* Icon colors mapped to brand tokens */
.swal2-icon.swal2-success {
    border-color: var(--brand-accent) !important;
    color: var(--brand-accent) !important;
}
.swal2-icon.swal2-success .swal2-success-line-tip,
.swal2-icon.swal2-success .swal2-success-line-long {
    background-color: var(--brand-accent) !important;
}
.swal2-icon.swal2-success .swal2-success-ring {
    border-color: rgba(16, 185, 129, .3) !important;
}
.swal2-icon.swal2-success [class^="swal2-success-circular-line"],
.swal2-icon.swal2-success .swal2-success-fix {
    background-color: var(--bg-surface) !important;
}
.swal2-icon.swal2-error {
    border-color: var(--brand-danger) !important;
    color: var(--brand-danger) !important;
}
.swal2-icon.swal2-error [class^="swal2-x-mark-line"] {
    background-color: var(--brand-danger) !important;
}
.swal2-icon.swal2-warning {
    border-color: var(--brand-warning) !important;
    color: var(--brand-warning) !important;
}
.swal2-icon.swal2-info {
    border-color: var(--brand-info) !important;
    color: var(--brand-info) !important;
}
.swal2-icon.swal2-question {
    border-color: var(--brand-primary) !important;
    color: var(--brand-primary) !important;
}

/* Toast variant (top-end positioned via Toast.fire) */
.swal2-toast {
    box-shadow: var(--shadow-lg) !important;
    border: 1px solid var(--border-soft) !important;
    border-radius: var(--radius-md) !important;
    padding: 14px 18px !important;
    background: var(--bg-surface) !important;
}
.swal2-toast .swal2-title {
    font-size: 14px !important;
    margin: 0 0 2px !important;
}
.swal2-toast .swal2-html-container {
    font-size: 13px !important;
    color: var(--text-secondary) !important;
}
/* Toast icon — keep SweetAlert2's natural size. The success icon is a
   stack of absolutely-positioned divs that need their default geometry to
   render the checkmark correctly; shrinking the .swal2-icon container
   collapses those proportions into a weird angular blob. */
.swal2-toast .swal2-icon {
    margin-right: 12px !important;
}
.swal2-timer-progress-bar {
    background: var(--brand-primary) !important;
}

/* Loader (spinner) */
.swal2-loader {
    border-color: var(--brand-primary) transparent var(--brand-primary) transparent !important;
}

/* Modal-style swal popup backdrop — ONLY when it's a centered modal popup.
   SweetAlert2 v11 puts `swal2-toast-shown` on the <html> element (NOT on
   the container) when a toast is active. We use that as the ancestor signal
   to keep the container transparent + click-through during toasts. */
.swal2-container.swal2-backdrop-show {
    background: rgba(15, 23, 42, .55) !important;
}
html.swal2-toast-shown .swal2-container,
html.swal2-toast-shown .swal2-container.swal2-backdrop-show,
.swal2-container:has(.swal2-toast) {
    background: transparent !important;
    pointer-events: none !important;
}
html.swal2-toast-shown .swal2-toast,
.swal2-container:has(.swal2-toast) .swal2-toast {
    pointer-events: auto !important;
}

/* ---------- DataTable empty state enhancement ----------
   Adds a subtle icon above the "No data" text. The base styling already
   came from Phase 4; this just enriches it. */
.dataTables_empty {
    position: relative;
    padding: 50px 16px 36px !important;
    font-size: 14px !important;
    color: var(--text-muted) !important;
}
.dataTables_empty::before {
    content: "\f15c"; /* fa-file-alt */
    font-family: "Font Awesome 5 Solid";
    font-size: 36px;
    color: var(--border-strong);
    display: block;
    margin-bottom: 10px;
    opacity: 0.65;
}

/* ---------- Empty-state partial styles (opt-in) ---------- */
.empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
    text-align: center;
    color: var(--text-muted);
}
.empty-state__icon {
    width: 64px;
    height: 64px;
    border-radius: var(--radius-lg);
    background: var(--bg-surface-2);
    border: 1px solid var(--border-soft);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    color: var(--text-muted);
    margin-bottom: 16px;
}
.empty-state__title {
    font-family: var(--font-ui);
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 4px;
    letter-spacing: -0.01em;
}
.empty-state__message {
    font-size: 13.5px;
    color: var(--text-secondary);
    margin: 0 0 16px;
    max-width: 360px;
    line-height: 1.5;
}
.empty-state__action {
    margin-top: 4px;
}

/* End Phase 6 */

/* ============================================================
   DASHBOARD — modern SaaS POS overview
   Hero greeting, KPI grid, quick actions, branch performance,
   catalog snapshot, and a polished Chart.js section.
   ============================================================ */

.dashboard {
    padding: 24px 28px !important;
}

/* ---------- Hero greeting strip ---------- */
.dashboard-hero {
    background: linear-gradient(135deg, var(--brand-primary), var(--brand-primary-dark) 60%, #312E81);
    border-radius: var(--radius-lg);
    padding: 26px 28px;
    color: #fff;
    display: flex;
    align-items: center;
    gap: 18px;
    margin-bottom: 22px;
    position: relative;
    overflow: hidden;
    box-shadow: 0 12px 30px rgba(79, 70, 229, .22);
}
.dashboard-hero::before {
    content: "";
    position: absolute;
    top: -80px;
    right: -80px;
    width: 280px;
    height: 280px;
    border-radius: 50%;
    background: radial-gradient(closest-side, rgba(16, 185, 129, .35), transparent 70%);
    pointer-events: none;
}
.dashboard-hero::after {
    content: "";
    position: absolute;
    bottom: -110px;
    left: -60px;
    width: 240px;
    height: 240px;
    border-radius: 50%;
    background: radial-gradient(closest-side, rgba(255, 255, 255, .12), transparent 70%);
    pointer-events: none;
}

.dashboard-hero__greeting {
    flex: 1;
    position: relative;
    z-index: 1;
}
.dashboard-hero__date {
    font-size: 12px;
    font-weight: 600;
    color: rgba(255, 255, 255, .75);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin: 0 0 4px;
}
.dashboard-hero__title {
    font-family: var(--font-ui);
    font-size: 26px;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: #fff;
    margin: 0 0 4px;
    line-height: 1.2;
}
.dashboard-hero__title .text-brand {
    background: linear-gradient(90deg, #fff, #C7D2FE);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}
.dashboard-hero__sub {
    font-size: 13px;
    color: rgba(255, 255, 255, .82);
    margin: 0;
    font-weight: 500;
}

.dashboard-hero__cta {
    background: rgba(255, 255, 255, .14);
    border: 1px solid rgba(255, 255, 255, .22);
    color: #fff !important;
    border-radius: var(--radius-md);
    padding: 12px 18px;
    display: inline-flex;
    align-items: center;
    gap: 12px;
    backdrop-filter: blur(8px);
    transition: background var(--transition-base), transform var(--transition-base), box-shadow var(--transition-base);
    text-decoration: none !important;
    position: relative;
    z-index: 1;
    flex-shrink: 0;
}
.dashboard-hero__cta:hover {
    background: rgba(255, 255, 255, .22);
    transform: translateY(-1px);
    box-shadow: 0 8px 18px rgba(0, 0, 0, .15);
    color: #fff !important;
}
.dashboard-hero__cta-icon {
    width: 38px;
    height: 38px;
    border-radius: var(--radius-sm);
    background: rgba(255, 255, 255, .22);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
}
.dashboard-hero__cta-label {
    display: block;
    font-weight: 600;
    font-size: 14px;
    line-height: 1.1;
}
.dashboard-hero__cta-sub {
    display: block;
    font-size: 11px;
    color: rgba(255, 255, 255, .75);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: 2px;
}

/* ---------- KPI grid ---------- */
.kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 26px;
}
@media (max-width: 991.98px) { .kpi-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 575.98px) { .kpi-grid { grid-template-columns: 1fr; } }

.kpi-card {
    background: var(--bg-surface);
    border: 1px solid var(--border-soft);
    border-radius: var(--radius-lg);
    padding: 18px 18px 16px;
    box-shadow: var(--shadow-sm);
    position: relative;
    overflow: hidden;
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.kpi-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}
/* Top gradient stripe per tone */
.kpi-card::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
}
.kpi-card--primary::before { background: linear-gradient(90deg, var(--brand-primary), var(--brand-primary-dark)); }
.kpi-card--accent::before  { background: linear-gradient(90deg, var(--brand-accent),  var(--brand-accent-dark)); }
.kpi-card--warning::before { background: linear-gradient(90deg, var(--brand-warning), #D97706); }
.kpi-card--success::before { background: linear-gradient(90deg, var(--brand-accent),  var(--brand-primary)); }
.kpi-card--info::before    { background: linear-gradient(90deg, var(--brand-info),    #0284C7); }
.kpi-card--danger::before  { background: linear-gradient(90deg, var(--brand-danger),  #DC2626); }

.kpi-card__head {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}
.kpi-card__icon {
    width: 36px;
    height: 36px;
    border-radius: var(--radius-sm);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 15px;
    flex-shrink: 0;
}
.kpi-card--primary .kpi-card__icon { background: linear-gradient(135deg, var(--brand-primary), var(--brand-primary-dark)); }
.kpi-card--accent  .kpi-card__icon { background: linear-gradient(135deg, var(--brand-accent),  var(--brand-accent-dark)); }
.kpi-card--warning .kpi-card__icon { background: linear-gradient(135deg, var(--brand-warning), #D97706); }
.kpi-card--success .kpi-card__icon { background: linear-gradient(135deg, var(--brand-accent),  var(--brand-primary)); }
.kpi-card--info    .kpi-card__icon { background: linear-gradient(135deg, var(--brand-info),    #0284C7); }
.kpi-card--danger  .kpi-card__icon { background: linear-gradient(135deg, var(--brand-danger),  #DC2626); }

.kpi-card__label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
}

.kpi-card__value {
    font-size: 28px;
    font-weight: 700;
    color: var(--text-primary);
    letter-spacing: -0.025em;
    line-height: 1.1;
    margin-bottom: 8px;
}
.kpi-card__suffix {
    font-size: 13px;
    color: var(--text-muted);
    margin-left: 3px;
    font-weight: 500;
}

.kpi-card__delta {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    font-weight: 600;
    padding: 3px 8px;
    border-radius: 999px;
}
.kpi-card__delta i { font-size: 10px; }
.kpi-card__delta--positive {
    background: var(--brand-accent-light);
    color: var(--brand-accent-dark);
}
.kpi-card__delta--negative {
    background: var(--brand-danger-light);
    color: var(--brand-danger);
}
.kpi-card__delta--neutral {
    background: var(--bg-surface-2);
    color: var(--text-muted);
}
.kpi-card__delta-label {
    color: var(--text-muted);
    font-weight: 500;
    margin-left: 4px;
}
.kpi-card__delta--positive .kpi-card__delta-label,
.kpi-card__delta--negative .kpi-card__delta-label {
    color: inherit;
    opacity: 0.7;
}

/* ---------- Section header ---------- */
.dashboard-section { margin-bottom: 26px; }
.dashboard-section__head {
    margin-bottom: 14px;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.dashboard-section__title {
    font-family: var(--font-ui);
    font-size: 16px;
    font-weight: 700;
    color: var(--text-primary);
    letter-spacing: -0.01em;
    margin: 0;
    line-height: 1.3;
}
.dashboard-section__sub {
    font-size: 13px;
    color: var(--text-secondary);
    margin: 0;
}

/* ---------- Quick actions ---------- */
.quick-actions {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 14px;
}
@media (max-width: 1199.98px) { .quick-actions { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 575.98px)  { .quick-actions { grid-template-columns: repeat(2, 1fr); } }

.quick-action {
    background: var(--bg-surface);
    border: 1px solid var(--border-soft);
    border-radius: var(--radius-md);
    padding: 18px 16px;
    text-decoration: none !important;
    color: var(--text-primary) !important;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
    transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
    position: relative;
    overflow: hidden;
}
.quick-action:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    border-color: var(--brand-primary);
    color: var(--text-primary) !important;
}
.quick-action__icon {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-sm);
    background: var(--brand-primary-light);
    color: var(--brand-primary);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    transition: background var(--transition-base), color var(--transition-base);
    margin-bottom: 4px;
}
.quick-action:hover .quick-action__icon {
    background: var(--brand-primary);
    color: var(--text-on-primary);
}
.quick-action__label {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
    line-height: 1.2;
}
.quick-action__sub {
    font-size: 12px;
    color: var(--text-secondary);
    line-height: 1.3;
}

/* The primary action (POS) — solid gradient tile, white text */
.quick-action--primary {
    background: linear-gradient(135deg, var(--brand-primary), var(--brand-primary-dark));
    color: #fff !important;
    border-color: transparent;
    box-shadow: 0 8px 22px rgba(79, 70, 229, .22);
}
.quick-action--primary:hover {
    color: #fff !important;
    border-color: transparent;
    box-shadow: 0 12px 28px rgba(79, 70, 229, .3);
}
.quick-action--primary .quick-action__icon {
    background: rgba(255, 255, 255, .22);
    color: #fff;
}
.quick-action--primary:hover .quick-action__icon {
    background: rgba(255, 255, 255, .32);
    color: #fff;
}
.quick-action--primary .quick-action__label { color: #fff; }
.quick-action--primary .quick-action__sub { color: rgba(255, 255, 255, .82); }

/* ---------- Two-column row ---------- */
.dashboard-row {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 22px;
    margin-bottom: 26px;
}
@media (max-width: 991.98px) {
    .dashboard-row { grid-template-columns: 1fr; }
}

/* ---------- Branch grid ---------- */
.branch-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 14px;
}
.branch-card {
    background: var(--bg-surface);
    border: 1px solid var(--border-soft);
    border-radius: var(--radius-md);
    padding: 16px 18px;
    transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}
.branch-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    border-color: var(--border-strong);
}
.branch-card__head {
    margin-bottom: 12px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-soft-2);
}
.branch-card__title {
    font-family: var(--font-ui);
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
    letter-spacing: -0.01em;
    line-height: 1.2;
}
.branch-card__company {
    font-size: 12px;
    color: var(--text-muted);
    font-weight: 500;
    display: block;
    margin-top: 2px;
}
.branch-card__stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin-bottom: 12px;
}
.branch-card__stat { display: flex; flex-direction: column; gap: 2px; }
.branch-card__stat-label {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-muted);
}
.branch-card__stat-value {
    font-size: 15px;
    font-weight: 700;
    color: var(--text-primary);
    letter-spacing: -0.01em;
}
.branch-card__stat-value small {
    font-size: 11px;
    color: var(--text-muted);
    font-weight: 500;
    margin-left: 1px;
}
.branch-card__stat-value--positive { color: var(--brand-accent-dark); }
.branch-card__stat-value--negative { color: var(--brand-danger); }
.branch-card__net {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    padding-top: 10px;
    border-top: 1px dashed var(--border-soft);
    font-size: 12px;
    text-transform: uppercase;
    font-weight: 700;
    letter-spacing: 0.06em;
    color: var(--text-muted);
}
.branch-card__net strong {
    font-size: 18px;
    font-weight: 700;
    letter-spacing: -0.01em;
    text-transform: none;
}
.branch-card__net strong.is-positive { color: var(--brand-accent-dark); }
.branch-card__net strong.is-negative { color: var(--brand-danger); }
.branch-card__net strong small {
    font-size: 12px;
    color: var(--text-muted);
    font-weight: 500;
    margin-left: 1px;
}

/* ---------- Catalog snapshot side card ---------- */
.catalog-card {
    background: var(--bg-surface);
    border: 1px solid var(--border-soft);
    border-radius: var(--radius-md);
    padding: 14px 18px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.catalog-card__row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border-soft-2);
}
.catalog-card__row:last-child {
    padding-bottom: 0;
    border-bottom: none;
}
.catalog-card__icon {
    width: 36px;
    height: 36px;
    border-radius: var(--radius-sm);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 14px;
    flex-shrink: 0;
}
.catalog-card__label {
    flex: 1;
    font-size: 13px;
    font-weight: 600;
    color: var(--text-primary);
}
.catalog-card__value {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-primary);
    letter-spacing: -0.01em;
}

/* ---------- Chart card ---------- */
.chart-card {
    background: var(--bg-surface);
    border: 1px solid var(--border-soft);
    border-radius: var(--radius-lg);
    padding: 22px;
    box-shadow: var(--shadow-sm);
    height: 360px;
    position: relative;
}

/* ---------- No-permission view ---------- */
.dashboard-no-perm {
    text-align: center;
    padding: 60px 24px;
    background: var(--bg-surface);
    border: 1px solid var(--border-soft);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
}
.dashboard-no-perm h1 {
    font-size: 26px;
    font-weight: 700;
    color: var(--text-primary);
    letter-spacing: -0.02em;
    margin: 0 0 6px;
}
.dashboard-no-perm p {
    color: var(--text-secondary);
    margin: 2px 0;
    font-size: 14px;
}

/* End Dashboard */
