/**
 * =============================================================
 *  ADMIN DESIGN SYSTEM
 * =============================================================
 */

/* @import url('https://fonts.googleapis.com/css2?family=Space+Mono:wght@400;700&family=DM+Sans:wght@300;400;500;600;700&display=swap'); */

/* ── CSS Variables ─────────────────────────────────────────── */
:root {
    --cd-bg:          #ffffff;
    --cd-border:      #ebebeb;
    --cd-gold:        #f5c518;
    --cd-gold-dim:    rgba(245,197,24,.12);
    --cd-indigo:      #3b5bdb;
    --cd-indigo-dim:  rgba(59,91,219,.08);
    --cd-green:       #12b886;
    --cd-red:         #e03131;
    --cd-orange:      #f76707;
    --cd-text:        rgba(7,7,7,.85);
    --cd-muted:       #aaa;
    --sb-height:      64px;   /* shared sidebar-header / navbar height */
}

/* ── Base page wrapper ─────────────────────────────────────── */
.ds-page { font-family: 'DM Sans', sans-serif; }
.ds-page * { box-sizing: border-box; }

/* ── Header ────────────────────────────────────────────────── */
.mu-header {
    background: var(--cd-bg);
    border-radius: 16px;
    padding: 20px 24px;
    margin-bottom: 14px;
    border: 1px solid #ebebeb;
    display: flex; align-items: center;
    justify-content: space-between;
    flex-wrap: wrap; gap: 12px;
}
.mu-header-title {
    font-family: 'DM Sans', sans-serif;
    font-size: 15px; font-weight: 700;
    color: var(--cd-text);
    display: flex; align-items: center; gap: 10px;
}
.mu-title-icon {
    width: 32px; height: 32px;
    background: var(--cd-gold-dim);
    border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    font-size: 14px; color: var(--cd-gold); flex-shrink: 0;
}
.mu-header-sub { font-size: 11px; color: #aaa; margin-top: 4px; letter-spacing: .3px; }

/* ── Toolbar ────────────────────────────────────────────────── */
.mu-toolbar { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

/* ── Breadcrumb ─────────────────────────────────────────────── */
.mu-breadcrumb {
    display: flex; align-items: center; gap: 6px;
    font-size: 11px; color: #bbb;
}
.mu-breadcrumb a { color: #999; text-decoration: none; transition: color .12s; }
.mu-breadcrumb a:hover { color: var(--cd-indigo); }
.mu-breadcrumb i { font-size: 9px; color: #ddd; }

/* ── Panel ──────────────────────────────────────────────────── */
.mu-panel {
    background: #fff; border-radius: 14px;
    box-shadow: 0 2px 16px rgba(0,0,0,.06), 0 0 0 1px rgba(0,0,0,.04);
    overflow: hidden;
}
.mu-panel-head {
    padding: 14px 20px 12px;
    border-bottom: 1px solid #f0f0f0;
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 10px;
}
.mu-panel-label {
    font-size: 9.5px; font-weight: 700;
    letter-spacing: 1.6px; text-transform: uppercase;
    color: #aaa; display: flex; align-items: center; gap: 7px;
}
.mu-panel-label i { color: var(--cd-indigo); font-size: 11px; }
.mu-panel-body { padding: 24px; }

/* ── Section label ──────────────────────────────────────────── */
.mu-section-lbl {
    font-size: 9px; font-weight: 700; letter-spacing: 1.4px; text-transform: uppercase;
    color: #bbb; display: flex; align-items: center; gap: 8px;
    margin-bottom: 14px;
}
.mu-section-lbl i { color: var(--cd-indigo); font-size: 11px; }
.mu-section-lbl::after { content: ''; flex: 1; height: 1px; background: #eee; }

/* ── Divider ────────────────────────────────────────────────── */
.mu-divider { border: none; height: 1px; background: #f0f0f0; margin: 24px 0; }

/* ── Buttons ────────────────────────────────────────────────── */
.mu-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 7px 14px; border-radius: 8px;
    font-size: 11.5px; font-weight: 700; letter-spacing: .3px;
    border: none; cursor: pointer; transition: all .15s;
    font-family: 'DM Sans', sans-serif; text-decoration: none;
    white-space: nowrap;
}
.mu-btn-primary { background: var(--cd-indigo); color: #fff; box-shadow: 0 2px 8px rgba(59,91,219,.3); }
.mu-btn-primary:hover { background: #3451c7; color: #fff; transform: translateY(-1px); box-shadow: 0 4px 14px rgba(59,91,219,.4); }
.mu-btn-ghost { background: transparent; color: #666; border: 1.5px solid #e0e0e0; }
.mu-btn-ghost:hover { background: #f5f5f5; border-color: #ccc; color: #333; }
.mu-btn-danger { background: rgba(224,49,49,.07); color: var(--cd-red); border: 1.5px solid rgba(224,49,49,.18); }
.mu-btn-danger:hover { background: rgba(224,49,49,.13); }
.mu-btn-gold { background: var(--cd-gold); color: #1a1000; box-shadow: 0 2px 8px rgba(245,197,24,.3); }
.mu-btn-gold:hover { background: #e6b800; color: #1a1000; transform: translateY(-1px); }
.mu-btn-success { background: rgba(18,184,134,.08); color: var(--cd-green); border: 1.5px solid rgba(18,184,134,.22); }
.mu-btn-success:hover { background: rgba(18,184,134,.15); }

/* ── Inline action buttons ──────────────────────────────────── */
.mu-action-btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 30px; height: 30px; border-radius: 7px;
    border: 1.5px solid #e8e8e8; background: transparent;
    font-size: 12px; cursor: pointer;
    transition: all .15s; text-decoration: none; color: #666;
}
.mu-action-btn.edit:hover    { border-color: var(--cd-gold);   background: rgba(245,197,24,.08);  color: #a87500; }
.mu-action-btn.view:hover    { border-color: var(--cd-indigo); background: rgba(59,91,219,.07);   color: var(--cd-indigo); }
.mu-action-btn.danger:hover  { border-color: var(--cd-red);    background: rgba(224,49,49,.07);   color: var(--cd-red); }
.mu-action-btn.archive:hover { border-color: var(--cd-indigo); background: rgba(59,91,219,.07);   color: var(--cd-indigo); }
.mu-action-btn.block:hover   { border-color: #aaa;             background: #f5f5f5;               color: #333; }

/* ── Form controls ──────────────────────────────────────────── */
.mu-form-label {
    font-size: 10px; font-weight: 700; letter-spacing: .8px; text-transform: uppercase;
    color: #888; margin-bottom: 6px; display: block;
}
.mu-form-control {
    border-radius: 8px; border: 1.5px solid #e8e8e8; font-size: 13px;
    padding: 9px 12px; width: 100%; transition: border-color .15s, box-shadow .15s;
    font-family: 'DM Sans', sans-serif; background: #fff; color: #333;
}
.mu-form-control:focus {
    outline: none; border-color: var(--cd-indigo);
    box-shadow: 0 0 0 3px rgba(59,91,219,.1);
}
.mu-form-control::placeholder { color: #bbb; }
.mu-form-control:disabled { background: #f8f8f8; color: #bbb; cursor: not-allowed; }
textarea.mu-form-control { resize: vertical; min-height: 100px; }
select.mu-form-control { cursor: pointer; }
.mu-form-hint { font-size: 10.5px; color: #bbb; margin-top: 5px; display: block; line-height: 1.5; }

/* ── Toggle / checkbox wrap ─────────────────────────────────── */
.mu-check-wrap {
    display: flex; align-items: flex-start; gap: 12px;
    padding: 14px 16px; background: #fff;
    border: 1.5px solid #e8e8e8; border-radius: 10px;
    cursor: pointer; transition: border-color .15s; margin-bottom: 4px;
}
.mu-check-wrap:hover { border-color: var(--cd-indigo); }
.mu-check-wrap input[type="checkbox"] { accent-color: var(--cd-indigo); margin-top: 2px; flex-shrink: 0; }
.mu-check-label { font-size: 13px; font-weight: 700; color: #222; }
.mu-check-sub   { font-size: 10.5px; color: #999; margin-top: 3px; line-height: 1.5; }

/* ── Info badge ─────────────────────────────────────────────── */
.mu-info-badge {
    background: rgba(59,91,219,.06); border: 1px solid rgba(59,91,219,.14);
    border-radius: 10px; padding: 10px 14px; font-size: 12px; color: #555;
    display: flex; gap: 9px; line-height: 1.6; margin-bottom: 20px;
}
.mu-info-badge i { color: var(--cd-indigo); font-size: 14px; flex-shrink: 0; margin-top: 1px; }

/* ── Flash alerts ───────────────────────────────────────────── */
.mu-alert {
    border-radius: 10px; font-size: 13px;
    display: flex; align-items: center; gap: 10px;
    padding: 10px 14px; margin-bottom: 14px;
}
.mu-alert.success { background: rgba(18,184,134,.08); border: 1px solid rgba(18,184,134,.2); color: #0ca678; }
.mu-alert.danger  { background: rgba(224,49,49,.07);  border: 1px solid rgba(224,49,49,.18); color: #c92a2a; }

/* ── Status badges ──────────────────────────────────────────── */
.mu-status {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 3px 10px; border-radius: 20px;
    font-size: 10.5px; font-weight: 700;
    font-family: 'DM Sans', sans-serif;
}
.mu-status.active   { background: rgba(18,184,134,.1);  color: #0ca678; border: 1px solid rgba(18,184,134,.2); }
.mu-status.inactive { background: rgba(108,117,125,.1); color: #868e96; border: 1px solid rgba(108,117,125,.2); }
.mu-status.pending  { background: rgba(245,197,24,.1);  color: #a87500; border: 1px solid rgba(245,197,24,.25); }
.mu-status.other    { background: rgba(245,197,24,.1);  color: #a87500; border: 1px solid rgba(245,197,24,.25); }

/* ── Generic badges ─────────────────────────────────────────── */
.mu-badge {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 3px 10px; border-radius: 20px;
    font-size: 10.5px; font-weight: 700;
    font-family: 'DM Sans', sans-serif; border: 1px solid transparent;
}
.mu-badge-primary { background: rgba(59,91,219,.1);  color: var(--cd-indigo); border-color: rgba(59,91,219,.2); }
.mu-badge-success { background: rgba(18,184,134,.1); color: #0ca678;          border-color: rgba(18,184,134,.2); }
.mu-badge-danger  { background: rgba(224,49,49,.08); color: var(--cd-red);    border-color: rgba(224,49,49,.18); }
.mu-badge-neutral { background: #f0f0f0;             color: #666;             border-color: #e0e0e0; }

/* ── Badge action variants ──────────────────────────────────── */
.mu-badge.role    { background: rgba(59,91,219,.08);  color: var(--cd-indigo); border-color: rgba(59,91,219,.18); }
.mu-badge.create  { background: rgba(18,184,134,.08); color: #0ca678;          border-color: rgba(18,184,134,.2); }
.mu-badge.update  { background: rgba(59,91,219,.08);  color: var(--cd-indigo); border-color: rgba(59,91,219,.18); }
.mu-badge.delete  { background: rgba(224,49,49,.07);  color: var(--cd-red);    border-color: rgba(224,49,49,.18); }
.mu-badge.login   { background: rgba(245,197,24,.1);  color: #a87500;          border-color: rgba(245,197,24,.25); }
.mu-badge.export  { background: rgba(108,117,125,.1); color: #6c757d;          border-color: rgba(108,117,125,.2); }
.mu-badge.view    { background: rgba(108,117,125,.1); color: #6c757d;          border-color: rgba(108,117,125,.2); }
.mu-badge.admin   { background: rgba(224,49,49,.1);   color: #c92a2a;          border-color: rgba(224,49,49,.2); }
.mu-badge.subadmin{ background: rgba(245,197,24,.1);  color: #a87500;          border-color: rgba(245,197,24,.25); }
.mu-badge.staff   { background: rgba(59,91,219,.1);   color: #3451c7;          border-color: rgba(59,91,219,.2); }

/* ── Modal ──────────────────────────────────────────────────── */
.mu-modal .modal-content { border-radius: 16px; border: none; box-shadow: 0 24px 60px rgba(0,0,0,.18); overflow: hidden; }
.mu-modal .modal-header  { background: #fff; border-bottom: 1px solid #f0f0f0; padding: 16px 20px; }
.mu-modal .modal-body    { padding: 20px; background: #fafafa; }
.mu-modal .modal-footer  { background: #fff; border-top: 1px solid #f0f0f0; padding: 12px 20px; }
.mu-modal .modal-title   { font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 700; color: #1a1a2e; display: flex; align-items: center; gap: 9px; }
.mu-modal-icon { width: 26px; height: 26px; background: var(--cd-gold-dim); border-radius: 6px; display: flex; align-items: center; justify-content: center; font-size: 12px; color: #c49a00; }

/* ── Stats / quantity box ───────────────────────────────────── */
.mu-qty-box { background: #fafafa; border: 1.5px solid #eee; border-radius: 10px; padding: 16px 20px; margin-top: 4px; }
.mu-qty-box-title { font-family: 'DM Sans', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: #aaa; margin-bottom: 14px; display: flex; align-items: center; gap: 7px; }
.mu-qty-box-title i { color: var(--cd-indigo); }

.mu-stats-card { background: rgba(59,91,219,.04); border: 1.5px solid rgba(59,91,219,.12); border-radius: 12px; padding: 16px 20px; margin-bottom: 20px; }
.mu-stats-title { font-family: 'DM Sans', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: #aaa; margin-bottom: 14px; display: flex; align-items: center; gap: 7px; }
.mu-stats-title i { color: var(--cd-indigo); }
.mu-stats-table { width: 100%; border-collapse: collapse; }
.mu-stats-table thead th { font-size: 9px; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase; color: #aaa; padding: 8px 12px; background: #fafafa; border-bottom: 1px solid #eee; text-align: left; }
.mu-stats-table tbody td { padding: 10px 12px; border-bottom: 1px solid #f5f5f5; font-size: 12.5px; color: #444; vertical-align: middle; }
.mu-stats-table tbody tr:last-child td { border-bottom: none; }
.mu-stats-table tbody tr:hover td { background: rgba(59,91,219,.02); }

/* ── Empty state ────────────────────────────────────────────── */
.mu-empty-state { text-align: center; padding: 32px 20px; background: #fafafa; border-radius: 10px; border: 1.5px dashed #e0e0e0; }
.mu-empty-state i { font-size: 2rem; color: #ddd; display: block; margin-bottom: 8px; }
.mu-empty-state p { font-size: 12px; color: #bbb; margin-bottom: 12px; }

/* ── Invite message wrapper ─────────────────────────────────── */
.mu-invite-wrapper { margin-top: 12px; padding: 16px; background: rgba(59,91,219,.04); border: 1.5px solid rgba(59,91,219,.15); border-radius: 10px; animation: mu-slide-down .2s ease; }
@keyframes mu-slide-down { from { opacity:0; transform:translateY(-6px); } to { opacity:1; transform:translateY(0); } }
.mu-char-counter { float: right; font-size: 10px; color: #bbb; margin-top: 4px; font-family: 'DM Sans', sans-serif; transition: color .2s; }
.mu-char-counter.near-limit { color: #f59e0b; }
.mu-char-counter.at-limit   { color: var(--cd-red); font-weight: 700; }

/* ── Select2 overrides ──────────────────────────────────────── */
.select2-container--default .select2-selection--multiple,
.select2-container--default .select2-selection--single {
    border: 1.5px solid #e8e8e8 !important; border-radius: 8px !important;
    min-height: 40px !important; font-family: 'DM Sans', sans-serif !important;
}
.select2-container--default.select2-container--focus .select2-selection--multiple,
.select2-container--default.select2-container--focus .select2-selection--single {
    border-color: var(--cd-indigo) !important;
    box-shadow: 0 0 0 3px rgba(59,91,219,.1) !important;
}
.select2-container--default .select2-selection--multiple .select2-selection__choice {
    background: rgba(59,91,219,.08) !important;
    border: 1px solid rgba(59,91,219,.2) !important;
    color: var(--cd-indigo) !important; border-radius: 5px !important;
    font-size: 11.5px !important;
}
.select2-dropdown { border: 1.5px solid #e8e8e8 !important; border-radius: 8px !important; }

/* ── Livewire / DataTable shared table styles ───────────────── */
.ds-page .table, .ds-page table { width: 100% !important; border-collapse: collapse !important; font-family: 'DM Sans', sans-serif !important; }
.ds-page .table thead th, .ds-page table thead th { font-size: 9px !important; font-weight: 700 !important; letter-spacing: 1.4px !important; text-transform: uppercase !important; color: #aaa !important; padding: 10px 16px !important; background: #fafafa !important; border-bottom: 1px solid #f0f0f0 !important; border-top: none !important; white-space: nowrap; }
.ds-page .table tbody td, .ds-page table tbody td { padding: 12px 16px !important; border-bottom: 1px solid #f8f8f8 !important; font-size: 13px !important; vertical-align: middle !important; color: #333 !important; border-top: none !important; }
.ds-page .table tbody tr:last-child td, .ds-page table tbody tr:last-child td { border-bottom: none !important; }
.ds-page .table tbody tr:hover td, .ds-page table tbody tr:hover td { background: #fcfcff !important; }
.ds-page .table-striped > tbody > tr:nth-of-type(odd) > * { background: transparent !important; --bs-table-accent-bg: transparent !important; }

/* ── Livewire pagination ────────────────────────────────────── */
.ds-page nav[role="navigation"] { padding: 12px 16px; border-top: 1px solid #f2f2f2; }
.ds-page nav[role="navigation"] span,
.ds-page nav[role="navigation"] button,
.ds-page nav[role="navigation"] a { font-size: 11.5px !important; font-family: 'DM Sans', sans-serif !important; border-radius: 6px !important; }
.ds-page nav[role="navigation"] [aria-current="page"] span,
.ds-page nav[role="navigation"] button[aria-current="page"] { background: var(--cd-indigo) !important; color: #fff !important; border-color: var(--cd-indigo) !important; }

/* ── Livewire table action buttons ──────────────────────────── */
.ds-page table .btn.btn-sm { display: inline-flex !important; align-items: center !important; justify-content: center !important; width: 30px !important; height: 30px !important; padding: 0 !important; border-radius: 7px !important; font-size: 12px !important; border: 1.5px solid #e8e8e8 !important; background: transparent !important; color: #666 !important; box-shadow: none !important; transition: all .15s !important; }
.ds-page table .btn.btn-sm i, .ds-page table .btn.btn-sm svg { display: inline-block !important; font-size: 12px !important; line-height: 1 !important; visibility: visible !important; opacity: 1 !important; }
.ds-page table .btn-success.btn-sm { border-color: rgba(59,91,219,.2) !important; color: var(--cd-indigo) !important; }
.ds-page table .btn-success.btn-sm:hover { border-color: var(--cd-indigo) !important; background: rgba(59,91,219,.07) !important; }
.ds-page table .btn-warning.btn-sm { border-color: rgba(245,197,24,.3) !important; color: #a87500 !important; }
.ds-page table .btn-warning.btn-sm:hover { border-color: var(--cd-gold) !important; background: rgba(245,197,24,.08) !important; }
.ds-page table .btn-info.btn-sm    { border-color: rgba(18,184,134,.25) !important; color: #0ca678 !important; }
.ds-page table .btn-info.btn-sm:hover { border-color: var(--cd-green) !important; background: rgba(18,184,134,.08) !important; }
.ds-page table .btn-danger.btn-sm  { border-color: rgba(224,49,49,.22) !important; color: var(--cd-red) !important; }
.ds-page table .btn-danger.btn-sm:hover { border-color: var(--cd-red) !important; background: rgba(224,49,49,.07) !important; }
.ds-page table .btn-secondary.btn-sm { border-color: #e0e0e0 !important; color: #bbb !important; }
.ds-page table .btn-secondary.btn-sm:hover { background: #f5f5f5 !important; color: #555 !important; }

/* ── Livewire table badges ───────────────────────────────────── */
.ds-page table .badge.bg-success { background: rgba(18,184,134,.1) !important; color: #0ca678 !important; border: 1px solid rgba(18,184,134,.2) !important; border-radius: 20px !important; font-size: 10.5px !important; font-weight: 700 !important; font-family: 'DM Sans', sans-serif !important; padding: 3px 10px !important; }
.ds-page table .badge.bg-danger  { background: rgba(224,49,49,.08) !important; color: #c92a2a !important; border: 1px solid rgba(224,49,49,.18) !important; border-radius: 20px !important; font-size: 10.5px !important; font-weight: 700 !important; font-family: 'DM Sans', sans-serif !important; padding: 3px 10px !important; }

/* ── Drop / upload zone ─────────────────────────────────────── */
.mu-drop-zone { border: 2px dashed #e0e0e0; border-radius: 10px; padding: 20px; text-align: center; cursor: pointer; transition: all .15s; background: #fff; }
.mu-drop-zone:hover    { border-color: var(--cd-indigo); background: #f8f9ff; }
.mu-drop-zone.has-file { border-color: var(--cd-green);  background: #f0fbf7; }

/* ── Import / Export ─────────────────────────────────────────── */
.mu-import-opt { display: flex; align-items: center; gap: 12px; padding: 10px 14px; border-radius: 10px; border: 1.5px solid #e8e8e8; cursor: pointer; transition: all .15s; background: #fff; margin-bottom: 8px; }
.mu-import-opt:hover, .mu-import-opt.selected { border-color: var(--cd-indigo); background: rgba(59,91,219,.04); }
.mu-export-opt { display: flex; align-items: flex-start; gap: 14px; padding: 14px 16px; border-radius: 12px; border: 1.5px solid #e8e8e8; cursor: pointer; transition: all .15s; background: #fff; text-align: left; width: 100%; }
.mu-export-opt:hover { border-color: var(--cd-indigo); background: #f6f8ff; }
.mu-export-icon { width: 40px; height: 40px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
.mu-export-icon.indigo { background: rgba(59,91,219,.1); color: var(--cd-indigo); }
.mu-export-icon.green  { background: rgba(18,184,134,.1); color: var(--cd-green); }
.mu-export-title { font-size: 13px; font-weight: 700; color: #222; }
.mu-export-sub   { font-size: 11px; color: #999; margin-top: 2px; }

/* ── Avatar ─────────────────────────────────────────────────── */
.mu-avatar { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, var(--cd-indigo) 0%, #764ba2 100%); display: inline-flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; color: #fff; font-family: 'DM Sans', sans-serif; flex-shrink: 0; }
.mu-avatar-img { width: 34px; height: 34px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.mu-avatar-placeholder { width: 34px; height: 34px; border-radius: 50%; background: #f0f0f0; display: inline-flex; align-items: center; justify-content: center; font-size: 13px; color: #bbb; flex-shrink: 0; }

/* ── Filter panel ───────────────────────────────────────────── */
.mu-filter-panel { background: #fafafa; border-radius: 12px; border: 1px solid #f0f0f0; overflow: hidden; margin: 16px 20px; }
.mu-filter-head  { padding: 10px 16px; border-bottom: 1px solid #f0f0f0; display: flex; align-items: center; gap: 8px; font-size: 9.5px; font-weight: 700; letter-spacing: 1.4px; text-transform: uppercase; color: #aaa; }
.mu-filter-head i { color: var(--cd-indigo); font-size: 11px; }
.mu-filter-body  { padding: 16px; }
.mu-filter-count { background: var(--cd-indigo); color: #fff; border-radius: 20px; font-size: 9px; font-weight: 700; padding: 2px 7px; font-family: 'DM Sans', sans-serif; display: none; }

/* ── Input group with icon ──────────────────────────────────── */
.mu-input-group { position: relative; }
.mu-input-icon  { position: absolute; left: 11px; top: 50%; transform: translateY(-50%); color: #bbb; font-size: 12px; pointer-events: none; }
.mu-input-group .mu-form-control { padding-left: 32px; }

/* ── Detail card ─────────────────────────────────────────────── */
.mu-detail-card { background: #fff; border-radius: 12px; border: 1px solid #f0f0f0; padding: 16px; margin-bottom: 12px; }
.mu-detail-row  { padding: 8px 0; border-bottom: 1px solid #f5f5f5; }
.mu-detail-row:last-child { border-bottom: none; padding-bottom: 0; }
.mu-detail-key  { font-size: 10px; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; color: #bbb; margin-bottom: 3px; display: flex; align-items: center; gap: 5px; }
.mu-detail-key i { color: var(--cd-indigo); }
.mu-detail-val  { font-size: 13px; color: #333; }

/* ── Guide panel ─────────────────────────────────────────────── */
.mu-guide-panel  { background: #fff; border-radius: 14px; margin-top: 12px; border: 1px solid #ebebeb; padding: 18px 24px; }
.mu-guide-title  { font-family: 'DM Sans', sans-serif; font-size: 10px; font-weight: 700; letter-spacing: 1.2px; text-transform: uppercase; color: #aaa; margin-bottom: 16px; display: flex; align-items: center; gap: 8px; }
.mu-guide-title i { color: var(--cd-gold); }

/* ── Step items ─────────────────────────────────────────────── */
.mu-step       { display: flex; flex-direction: column; align-items: flex-start; gap: 6px; }
.mu-step-num   { width: 26px; height: 26px; background: var(--cd-gold-dim); border-radius: 7px; display: flex; align-items: center; justify-content: center; font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 700; color: #a87500; }
.mu-step-title { font-size: 12px; font-weight: 700; color: #333; }
.mu-step-desc  { font-size: 11px; color: #aaa; line-height: 1.5; }

/* ── Table row (event tables) ───────────────────────────────── */
.mu-table-row       { background: #fff; border: 1.5px solid #eee; border-radius: 10px; padding: 16px 20px; margin-bottom: 10px; transition: border-color .15s; }
.mu-table-row:hover { border-color: #d0d0d0; }
.mu-table-row-head  { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.mu-table-row-title { font-family: 'DM Sans', sans-serif; font-size: 11px; font-weight: 700; color: #555; display: flex; align-items: center; gap: 6px; }
.mu-table-row-title i { color: var(--cd-indigo); }

/* ── Remove button / link ───────────────────────────────────── */
.mu-btn-remove { display: inline-flex; align-items: center; gap: 5px; padding: 5px 10px; border-radius: 6px; font-size: 11px; font-weight: 700; border: 1.5px solid rgba(224,49,49,.25); background: rgba(224,49,49,.06); color: var(--cd-red); cursor: pointer; transition: all .15s; font-family: 'DM Sans', sans-serif; }
.mu-btn-remove:hover { background: rgba(224,49,49,.12); border-color: var(--cd-red); }
.mu-remove-link { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; color: var(--cd-red); text-decoration: none; padding: 3px 8px; border-radius: 6px; border: 1px solid rgba(224,49,49,.2); background: rgba(224,49,49,.05); transition: all .15s; }
.mu-remove-link:hover { background: rgba(224,49,49,.1); color: var(--cd-red); }

/* ── Event strip / heading / price ─────────────────────────── */
.mu-event-strip   { padding: 14px 20px; border-bottom: 1px solid #f0f0f0; display: flex; align-items: flex-end; gap: 12px; flex-wrap: wrap; background: #fafafa; }
.mu-event-heading { padding: 8px 20px 0; font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 700; color: var(--cd-text); display: none; }
.mu-event-heading.visible { display: block; }
.mu-price { font-family: 'DM Sans', sans-serif; font-size: 12px; font-weight: 700; color: var(--cd-indigo); background: rgba(59,91,219,.06); border: 1px solid rgba(59,91,219,.12); border-radius: 6px; padding: 2px 8px; display: inline-block; }

/* ── Danger icon ─────────────────────────────────────────────── */
.mu-danger-icon { width: 56px; height: 56px; border-radius: 50%; background: rgba(224,49,49,.08); border: 2px solid rgba(224,49,49,.18); display: flex; align-items: center; justify-content: center; font-size: 26px; color: var(--cd-red); margin: 0 auto 14px; }

/* ── Upload card ─────────────────────────────────────────────── */
.mu-upload-card { border: 2px dashed #e8e8e8; border-radius: 12px; padding: 20px; background: #fafafa; transition: border-color .2s, background .2s; cursor: pointer; display: block; }
.mu-upload-card:hover { border-color: var(--cd-indigo); background: #f6f8ff; }
.mu-upload-card-icon { width: 44px; height: 44px; border-radius: 12px; background: rgba(59,91,219,.08); border: 1px solid rgba(59,91,219,.14); display: flex; align-items: center; justify-content: center; font-size: 20px; color: var(--cd-indigo); margin-bottom: 10px; }
.mu-upload-title { font-size: 13px; font-weight: 700; color: #333; margin-bottom: 3px; }
.mu-upload-sub   { font-size: 11px; color: #bbb; }

/* ── Misc helpers ────────────────────────────────────────────── */
.sc-page, .ds-page { font-family: 'DM Sans', sans-serif; }
.sc-page *, .ds-page * { box-sizing: border-box; }

.mu-group-icon { width: 32px; height: 32px; border-radius: 8px; background: rgba(59,91,219,.1); display: inline-flex; align-items: center; justify-content: center; font-size: 13px; color: var(--cd-indigo); flex-shrink: 0; }

/* ── Stat cards ─────────────────────────────────────────────── */
.mu-stat-cards { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 14px; }
.mu-stat-card  { flex: 1; min-width: 140px; background: #fff; border: 1px solid #ebebeb; border-radius: 12px; padding: 14px 16px; display: flex; align-items: center; gap: 12px; transition: border-color .15s; }
.mu-stat-card:hover { border-color: #d0d0d0; }
.mu-stat-card-icon { width: 36px; height: 36px; border-radius: 9px; display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; }
.mu-stat-card-icon.admin    { background: rgba(224,49,49,.12);  color: var(--cd-red); }
.mu-stat-card-icon.subadmin { background: rgba(245,197,24,.12); color: var(--cd-gold); }
.mu-stat-card-icon.staff    { background: rgba(59,91,219,.12);  color: var(--cd-indigo); }
.mu-stat-card-icon.total    { background: rgba(18,184,134,.12); color: var(--cd-green); }
.mu-stat-card-count { font-family: 'DM Sans', sans-serif; font-size: 22px; font-weight: 700; color: var(--cd-text); line-height: 1; }
.mu-stat-card-label { font-size: 10px; color: #aaa; letter-spacing: .5px; margin-top: 3px; }

/* ── Permission chip / grid / group ─────────────────────────── */
.mu-perm-chip { display: inline-flex; align-items: center; padding: 2px 8px; border-radius: 20px; font-size: 10px; font-weight: 600; background: rgba(59,91,219,.07); color: #3451c7; border: 1px solid rgba(59,91,219,.12); }
.mu-perm-group { margin-bottom: 18px; }
.mu-perm-group-head { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.mu-perm-group-head label { font-size: 10px; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; color: #888; cursor: pointer; margin: 0; }
.mu-perm-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 4px; }
.mu-perm-item { display: flex; align-items: center; gap: 7px; padding: 5px 8px; border-radius: 7px; background: #fff; border: 1px solid #f0f0f0; transition: border-color .12s; cursor: pointer; }
.mu-perm-item:hover { border-color: #d0d8ff; }
.mu-perm-item label { font-size: 11.5px; color: #444; cursor: pointer; margin: 0; }
.mu-perm-item input[type="checkbox"] { accent-color: var(--cd-indigo); flex-shrink: 0; }

/* ── Selected user / outline edit / search results ───────────── */
.mu-selected-user { background: rgba(59,91,219,.06); border: 1.5px solid rgba(59,91,219,.2); border-radius: 10px; padding: 12px 14px; display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.mu-btn-outline-edit { display: inline-flex; align-items: center; gap: 5px; padding: 4px 11px; border-radius: 6px; font-size: 11px; font-weight: 600; border: 1.5px solid #e0e0e0; color: #555; background: transparent; cursor: pointer; transition: all .15s; text-decoration: none; font-family: 'DM Sans', sans-serif; }
.mu-btn-outline-edit:hover { border-color: var(--cd-indigo); color: var(--cd-indigo); background: rgba(59,91,219,.05); }
.mu-search-results { border-radius: 10px; overflow: hidden; box-shadow: 0 8px 24px rgba(0,0,0,.12); border: 1.5px solid #e8e8e8; }
.mu-search-results .list-group-item { border: none; border-bottom: 1px solid #f5f5f5; padding: 10px 14px; font-size: 12.5px; transition: background .1s; }
.mu-search-results .list-group-item:last-child { border-bottom: none; }
.mu-search-results .list-group-item:hover { background: #f8f9ff; }


/* ═══════════════════════════════════════════════════════════════
   SIDEBAR — HOSTINGER STYLE
   Solid filled active background, white text/icon on active,
   light gray hover, clean minimal look.
═══════════════════════════════════════════════════════════════ */

/* ── Shell ── */
.sidebar.sidebar-default,
.sidebar.sidebar-default.sidebar-white,
.sidebar.sidebar-default.sidebar-base,
.sidebar.sidebar-default.sidebar-white.sidebar-base {
    background: #ffffff !important;
    border-right: 1px solid #ebebeb !important;
    box-shadow: none !important;
    font-family: 'DM Sans', sans-serif !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
}

/* ── Sidebar header ── */
.sidebar .sidebar-header {
    height: var(--sb-height) !important;
    min-height: var(--sb-height) !important;
    background: #ffffff !important;
    border-bottom: 1px solid #f0f0f0 !important;
    padding: 0 18px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-shrink: 0 !important;
}

/* ── Sidebar body — single native scroll ── */
.sidebar .sidebar-body {
    flex: 1 1 0 !important;
    height: 0 !important;               /* flex child: grows to fill remaining space */
    overflow-y: auto !important;
    overflow-x: hidden !important;
    scrollbar-width: thin !important;
    scrollbar-color: rgba(0,0,0,.09) transparent !important;
}
.sidebar .sidebar-body::-webkit-scrollbar { width: 3px !important; }
.sidebar .sidebar-body::-webkit-scrollbar-thumb { background: rgba(0,0,0,.1) !important; border-radius: 4px !important; }

/* ── Toggle button ── */
.sidebar .sidebar-toggle { color: #bbb !important; transition: color .18s !important; }
.sidebar .sidebar-toggle:hover { color: var(--cd-indigo) !important; }

/* ── Section labels (ADMINISTRATION, EVENTS, PERSONALIZATION) ── */
.sidebar .nav-item.static-item .nav-link.static-item span.default-icon,
.sidebar .nav-item.static-item .nav-link span.default-icon {
    font-family: 'DM Sans', sans-serif !important;
    font-size: 10px !important;
    font-weight: 600 !important;
    letter-spacing: .5px !important;
    text-transform: uppercase !important;
    color: #9ca3af !important;
    padding: 18px 14px 5px !important;
    display: block !important;
}

/* ── Bootstrap Icon wrapper ── */
.sb-icon {
    width: 18px; height: 18px; flex-shrink: 0;
    font-size: 15px; line-height: 1;
    display: inline-flex; align-items: center; justify-content: center;
    transition: color .15s;
    color: #9ca3af;
}

/* ── Nav link base ── */
.sidebar .navbar-nav .nav-item .nav-link,
.sidebar .nav-link {
    font-family: 'DM Sans', sans-serif !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    color: #374151 !important;
    border-radius: 8px !important;
    margin: 1px 8px !important;
    padding: 9px 12px !important;
    transition: background .14s, color .14s !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    border: none !important;
    text-decoration: none !important;
    background: transparent !important;
}

/* ── Hover — light gray, text darkens slightly ── */
.sidebar .navbar-nav .nav-item .nav-link:hover,
.sidebar .nav-link:hover {
    background: #f3f4f6 !important;
    color: #111827 !important;
}
.sidebar .nav-link:hover .sb-icon { color: #6b7280 !important; }

/* ── ACTIVE — solid filled indigo, white text & icon (Hostinger style) ── */
.sidebar .navbar-nav .nav-item .nav-link.active,
.sidebar .nav-link.active {
    background: var(--cd-indigo) !important;
    color: #ffffff !important;
    border: none !important;
    font-weight: 600 !important;
}
.sidebar .nav-link.active .sb-icon { color: #ffffff !important; }
.sidebar .nav-link.active .item-name { color: #ffffff !important; }
.sidebar .nav-link.active .right-icon { color: rgba(255,255,255,.7) !important; }

/* ── Neutralise bg-soft-primary ── */
.sidebar .nav-link.bg-soft-primary {
    background: transparent !important;
    color: #374151 !important;
    border: none !important;
    font-weight: 500 !important;
}
.sidebar .nav-link.bg-soft-primary .sb-icon,
.sidebar .nav-link.bg-soft-primary .item-name { color: #9ca3af !important; }

/* ── Chevron ── */
.sidebar .right-icon {
    margin-left: auto !important;
    font-size: 11px !important;
    color: #d1d5db !important;
    transition: transform .2s, color .15s !important;
    flex-shrink: 0 !important;
}
.sidebar .nav-link[aria-expanded="true"] .right-icon {
    transform: rotate(90deg) !important;
    color: #6b7280 !important;
}

/* ── Sub-nav ── */
.sidebar .sub-nav {
    background: transparent !important;
    padding: 2px 0 4px 0 !important;
    margin-left: 28px !important;
    border-left: 2px solid #f3f4f6 !important;
}
.sidebar .sub-nav .nav-item .nav-link,
.sidebar .sub-nav .nav-link {
    font-size: 13px !important;
    font-weight: 400 !important;
    padding: 7px 12px 7px 14px !important;
    margin: 1px 8px 1px 4px !important;
    color: #6b7280 !important;
    border-radius: 7px !important;
    border: none !important;
    background: transparent !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}
.sidebar .sub-nav .nav-link i {
    font-size: 11px !important;
    color: #d1d5db !important;
    flex-shrink: 0 !important;
    width: 14px;
    text-align: center;
}
.sidebar .sub-nav .nav-link:hover {
    background: #f3f4f6 !important;
    color: #111827 !important;
}
.sidebar .sub-nav .nav-link:hover i { color: #6b7280 !important; }

/* Sub-nav active — bold indigo text, no filled background (Hostinger style) */
.sidebar .sub-nav .nav-link.active {
    background: transparent !important;
    color: var(--cd-indigo) !important;
    font-weight: 600 !important;
    border: none !important;
}
.sidebar .sub-nav .nav-link.active i { color: var(--cd-indigo) !important; }

/* ── Sidebar footer ── */
.sidebar .sidebar-footer {
    background: #ffffff !important;
    border-top: 1px solid #f3f4f6 !important;
    flex-shrink: 0 !important;
}

/* ── Mini sidebar — centered icons, no text ── */
.sidebar-mini .sidebar .navbar-nav .nav-item .nav-link,
.sidebar-mini .sidebar .nav-link {
    margin: 3px 8px !important;
    padding: 10px 6px !important;
    justify-content: center !important;
    gap: 0 !important;
}
.sidebar-mini .sidebar .item-name,
.sidebar-mini .sidebar .right-icon { display: none !important; }
.sidebar-mini .sidebar .sb-icon {
    width: 20px !important;
    height: 20px !important;
    font-size: 17px !important;
    color: #9ca3af !important;
}
.sidebar-mini .sidebar .nav-link.active .sb-icon { color: #ffffff !important; }
.sidebar-mini .sidebar .nav-link:hover .sb-icon  { color: #6b7280 !important; }
.sidebar-mini .sidebar .sub-nav { display: none !important; }
.sidebar-mini .sidebar .nav-item.static-item { display: none !important; }

/* ── Mobile: dvh for iOS accuracy ── */
@media (max-width: 1199px) {
    .sidebar .sidebar-body {
        height: calc(100dvh - var(--sb-height)) !important;
        max-height: calc(100dvh - var(--sb-height)) !important;
        flex: none !important;
        -webkit-overflow-scrolling: touch !important;
    }
}


/* ═══════════════════════════════════════════════════════════════
   TOP NAVBAR
═══════════════════════════════════════════════════════════════ */
.iq-navbar {
    height: var(--sb-height) !important;
    background: #fff !important;
    border-bottom: 1px solid rgba(0,0,0,.06) !important;
    box-shadow: 0 2px 14px rgba(0,0,0,.05) !important;
    font-family: 'DM Sans', sans-serif !important;
    display: flex !important;
    align-items: center !important;
}
.iq-navbar .navbar-brand { display: flex; align-items: center; }
.iq-navbar .container-fluid { height: 100%; }

/* ── Navbar user caption ── */
.caption-title     { font-family: 'DM Sans', sans-serif !important; font-size: 13px !important; font-weight: 700 !important; color: #1a1a2e !important; }
.caption-sub-title { font-family: 'DM Sans', sans-serif !important; font-size: 9px !important; color: #aaa !important; letter-spacing: .5px; }

/* ── View Page button ── */
.iq-navbar .btn-primary,
.navbar .btn-primary {
    background: var(--cd-indigo) !important;
    border-color: var(--cd-indigo) !important;
    font-family: 'DM Sans', sans-serif !important;
    font-size: 12px !important;
    font-weight: 700 !important;
}

/* ── Notification dot ── */
.navbar .dots { background: var(--cd-gold) !important; }

/* ── Header banner ── */
.iq-navbar-header.header-block {
    background: linear-gradient(135deg, #1a2fa0 0%, #0d1b6e 100%) !important;
    border-bottom-left-radius: 20px !important;
    border-bottom-right-radius: 20px !important;
}
.iq-navbar-header h1 { font-family: 'DM Sans', sans-serif !important; font-weight: 800 !important; color: #fff !important; font-size: 1.55rem !important; }
.iq-navbar-header h5 { font-family: 'DM Sans', sans-serif !important; color: rgba(255,255,255,.65) !important; font-size: 0.82rem !important; }

/* ── Footer ── */
footer.footer, .footer {
    font-family: 'DM Sans', sans-serif !important;
    font-size: 12px !important;
    color: #bbb !important;
    border-top: 1px solid #f0f0f0 !important;
}

/* ── Global body font ───────────────────────────────────────── */
body {
    font-family: 'DM Sans', sans-serif;
}

/* ── Sidebar: fix long-text / icon clipping ─────────────────── */
.sidebar .navbar-nav .nav-item .nav-link,
.sidebar .nav-link {
    min-width: 0 !important;   /* allow flex children to shrink */
    overflow: visible !important;
}
.sidebar .item-name {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}
.sidebar .sb-icon {
    flex-shrink: 0 !important;  /* icon never collapses */
}
.sidebar .right-icon {
    flex-shrink: 0 !important;
}
/* Give sidebar body horizontal room so active bg doesn't clip */
.sidebar.sidebar-default {
    z-index: 1080 !important;
    overflow: visible !important;
}
.sidebar .sidebar-body {
    overflow-x: hidden !important;
}

.att-scan-mode-btn {
    /* ensure it stacks vertically if not already */
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
}

.att-scan-mode-label {
    font-weight: 600;
    font-size: 0.85rem;
    line-height: 1.2;
}

.att-scan-mode-desc {
    font-size: 0.7rem;
    font-weight: 400;
    opacity: 0.65;
    line-height: 1.3;
    text-align: center;
}

/* ── Event Status Banners ── */
.att-status-banner {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 14px 18px;
    border-radius: 12px;
    font-family: 'DM Sans', sans-serif;
}
.att-status-banner.ended {
    background: rgba(224,49,49,.06);
    border: 1px solid rgba(224,49,49,.2);
}
.att-status-banner.soon {
    background: rgba(245,197,24,.07);
    border: 1px solid rgba(245,197,24,.28);
}
.att-status-banner-icon {
    width: 36px; height: 36px;
    border-radius: 9px;
    display: flex; align-items: center; justify-content: center;
    font-size: 17px; flex-shrink: 0;
}
.att-status-banner.ended  .att-status-banner-icon { background:rgba(224,49,49,.1);  color:#e03131; }
.att-status-banner.soon   .att-status-banner-icon { background:rgba(245,197,24,.14); color:#a87500; }
.att-status-banner-body { flex: 1; min-width: 0; }
.att-status-banner-title {
    font-size: 12.5px; font-weight: 700;
    margin-bottom: 3px;
}
.att-status-banner.ended  .att-status-banner-title { color: #c92a2a; }
.att-status-banner.soon   .att-status-banner-title { color: #a87500; }
.att-status-banner-desc { font-size: 11.5px; color: #777; line-height: 1.55; }

.vt-pos-body {
    overflow: hidden;
    max-height: 1000px;
    opacity: 1;
    transition: max-height .35s ease, opacity .25s ease, padding .25s ease;
}
.vt-pos-body.collapsed {
    max-height: 0 !important;
    opacity: 0;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}
.vt-chevron.rotated {
    transform: rotate(180deg);
}