/* =============================================================================
   Meeting Rooms · Clean Saudi Government SaaS Dashboard
   Inspired by Vision 2030 digital services · MOT green accent
   ============================================================================= */

:root {
    /* Primary — clean Saudi green (matches mockup) */
    --mo-primary-900: #063d20;
    --mo-primary-800: #084e29;
    --mo-primary-700: #0a6132;
    --mo-primary:     #0c6b3c;
    --mo-primary-600: #14834a;
    --mo-primary-500: #1e9a5c;
    --mo-primary-400: #4bb483;
    --mo-primary-300: #85cbad;
    --mo-primary-200: #b9e0cc;
    --mo-primary-100: #d9eee2;
    --mo-primary-50:  #eaf5ef;

    /* Accent greens / reds / blues for status chips */
    --mo-red:    #dc3545;
    --mo-red-50: #fdecee;
    --mo-blue:   #1d6ac7;
    --mo-blue-50: #e8f0fb;
    --mo-amber:  #d99321;
    --mo-amber-50: #fbf3e2;
    --mo-purple: #7c4dbe;
    --mo-purple-50: #efe8fa;

    /* Neutrals — clean slate */
    --mo-ink-900: #0f172a;
    --mo-ink-800: #1e293b;
    --mo-ink-700: #334155;
    --mo-ink-600: #475569;
    --mo-ink-500: #64748b;
    --mo-ink-400: #94a3b8;
    --mo-ink-300: #cbd5e1;
    --mo-ink-200: #e2e8f0;
    --mo-ink-100: #f1f5f9;
    --mo-ink-50:  #f8fafc;

    /* Canvas */
    --mo-canvas:  #f5f7fa;
    --mo-card:    #ffffff;
    --mo-line:    #e8ebf0;
    --mo-line-strong: #d6dbe3;

    /* Type */
    --mo-font: 'Cairo', 'IBM Plex Sans Arabic', 'Segoe UI', Tahoma, Arial, sans-serif;
    --mo-font-num: 'Cairo', 'Inter', 'Segoe UI', system-ui, sans-serif;

    /* Geometry */
    --mo-radius-sm: 6px;
    --mo-radius:    10px;
    --mo-radius-lg: 14px;
    --mo-radius-xl: 20px;

    --mo-shadow-sm: 0 1px 2px rgba(15, 23, 42, 0.04);
    --mo-shadow:    0 2px 6px -1px rgba(15, 23, 42, 0.06), 0 1px 3px rgba(15, 23, 42, 0.04);
    --mo-shadow-lg: 0 12px 32px -10px rgba(15, 23, 42, 0.14), 0 4px 10px -2px rgba(15, 23, 42, 0.06);

    --mo-transition: 180ms cubic-bezier(.4, 0, .2, 1);

    /* Layout */
    --mo-topbar-h: 64px;
    --mo-drawer-w: 250px;
}

/* =============================================================================
   Reset
   ============================================================================= */

html, body {
    font-family: var(--mo-font);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    background: var(--mo-canvas);
    color: var(--mo-ink-800);
    margin: 0;
    padding: 0;
}

body {
    direction: rtl;
    text-align: right;
    min-height: 100vh;
}

h1, h2, h3, h4, h5, h6 {
    font-weight: 700;
    color: var(--mo-ink-900);
    margin: 0;
}

.mo-mono {
    font-family: var(--mo-font-num);
    font-variant-numeric: tabular-nums;
}

/* =============================================================================
   TOP BAR
   ============================================================================= */

.mo-topbar {
    height: var(--mo-topbar-h);
    background: var(--mo-primary);
    color: #fff;
    position: sticky;
    top: 0;
    z-index: 1200;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
}

.mo-topbar__inner {
    display: flex;
    align-items: center;
    height: 100%;
    padding: 0 1.25rem;
    gap: 1rem;
}

.mo-topbar__right {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex: 1;
}

.mo-topbar__left {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-inline-start: auto;
}

.mo-burger {
    width: 38px;
    height: 38px;
    border-radius: 8px;
    border: none;
    background: transparent;
    color: #fff;
    cursor: pointer;
    display: grid;
    place-items: center;
    transition: var(--mo-transition);
}
.mo-burger:hover { background: rgba(255, 255, 255, 0.12); }

.mo-topbar__title {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    color: #fff;
}
.mo-topbar__emblem {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    background: #fff;
    border-radius: 10px;
    padding: 4px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
    flex: 0 0 auto;
}
.mo-topbar__emblem img { width: 100%; height: 100%; object-fit: contain; }

.mo-topbar__titles { line-height: 1.1; min-width: 0; }
.mo-topbar__product {
    font-size: 1.02rem;
    font-weight: 700;
    color: #fff;
    white-space: nowrap;
}
.mo-topbar__ministry {
    font-size: 0.7rem;
    color: rgba(255, 255, 255, 0.78);
    margin-top: 3px;
    font-weight: 500;
    white-space: nowrap;
}

@media (max-width: 680px) {
    .mo-topbar__ministry { display: none; }
    .mo-topbar__product { font-size: 0.88rem; white-space: normal; }
}

.mo-iconbtn {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: none;
    background: transparent;
    color: #fff;
    cursor: pointer;
    display: grid;
    place-items: center;
    position: relative;
    transition: var(--mo-transition);
}
.mo-iconbtn:hover { background: rgba(255, 255, 255, 0.12); }

.mo-iconbtn__badge {
    position: absolute;
    top: 6px;
    inset-inline-end: 6px;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    border-radius: 8px;
    background: var(--mo-red);
    color: #fff;
    font-size: 0.62rem;
    font-weight: 700;
    display: grid;
    place-items: center;
    border: 2px solid var(--mo-primary);
    line-height: 1;
}

.mo-user-chip {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.35rem 0.65rem 0.35rem 0.85rem;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 999px;
    cursor: pointer;
    transition: var(--mo-transition);
}
.mo-user-chip:hover { background: rgba(255, 255, 255, 0.15); }
.mo-user-chip__avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #fff;
    color: var(--mo-primary);
    display: grid;
    place-items: center;
    font-size: 0.82rem;
    font-weight: 700;
    overflow: hidden;
}
.mo-user-chip__avatar img { width: 100%; height: 100%; object-fit: cover; }
.mo-user-chip__text { line-height: 1.1; text-align: start; }
.mo-user-chip__name { color: #fff; font-size: 0.85rem; font-weight: 600; }
.mo-user-chip__role { color: rgba(255, 255, 255, 0.75); font-size: 0.7rem; margin-top: 2px; }

/* =============================================================================
   SHELL
   ============================================================================= */

.mo-shell {
    display: flex;
    min-height: calc(100vh - var(--mo-topbar-h));
}

.mo-shell__aside {
    width: var(--mo-drawer-w);
    flex: 0 0 auto;
    position: sticky;
    top: var(--mo-topbar-h);
    height: calc(100vh - var(--mo-topbar-h));
    background: #fff;
    border-inline-start: 1px solid var(--mo-line);
    overflow-y: auto;
    display: flex;
    flex-direction: column;
}

.mo-shell__main {
    flex: 1;
    min-width: 0;
    padding: 1.75rem 1.5rem 3rem;
}

.mo-shell__content {
    max-width: 1400px;
    margin: 0 auto;
}

@media (max-width: 980px) {
    .mo-shell__aside { display: none; }
    .mo-shell__main { padding: 1rem 1rem 2rem; }
}

/* =============================================================================
   NAV MENU (sidebar)
   ============================================================================= */

.mo-nav {
    padding: 1rem 0.6rem;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.mo-navlink {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.65rem 0.85rem;
    border-radius: 8px;
    color: var(--mo-ink-700);
    font-size: 0.92rem;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    transition: var(--mo-transition);
    position: relative;
}
.mo-navlink:hover {
    background: var(--mo-ink-50);
    color: var(--mo-primary);
}
.mo-navlink--active {
    background: var(--mo-primary-50);
    color: var(--mo-primary);
    font-weight: 700;
}
.mo-navlink--active::before {
    content: '';
    position: absolute;
    inset-inline-end: -6px;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 22px;
    background: var(--mo-primary);
    border-radius: 3px 0 0 3px;
}
.mo-navlink .mud-icon-root { font-size: 1.15rem !important; }

.mo-nav__sub {
    padding-inline-start: 1rem;
    margin-top: 2px;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.mo-nav__sub .mo-navlink { font-size: 0.86rem; font-weight: 400; padding: 0.5rem 0.85rem; }
.mo-nav__sub .mo-navlink--active { font-weight: 600; }

.mo-nav__footer {
    padding: 1rem 0.6rem;
    border-top: 1px solid var(--mo-line);
}
.mo-nav__help {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.6rem 1rem;
    background: var(--mo-ink-50);
    color: var(--mo-ink-700);
    border: 1px solid var(--mo-line);
    border-radius: 8px;
    font-family: var(--mo-font);
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
    transition: var(--mo-transition);
}
.mo-nav__help:hover { background: var(--mo-primary-50); color: var(--mo-primary); border-color: var(--mo-primary-200); }

/* =============================================================================
   PAGE HEAD
   ============================================================================= */

.mo-page-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1.5rem;
    margin-bottom: 1.5rem;
    flex-wrap: wrap;
}

.mo-page-head__title {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--mo-ink-900);
    margin-bottom: 0.25rem;
}
.mo-page-head__title strong { color: var(--mo-primary); }
.mo-page-head__title-icon {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: var(--mo-primary-50);
    color: var(--mo-primary);
    display: grid;
    place-items: center;
}
.mo-page-head__sub {
    font-size: 0.88rem;
    color: var(--mo-ink-500);
}

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

.mo-card {
    background: var(--mo-card);
    border: 1px solid var(--mo-line);
    border-radius: var(--mo-radius-lg);
    padding: 1.25rem;
    box-shadow: var(--mo-shadow-sm);
}

.mo-card--pad-lg { padding: 1.75rem; }
.mo-card--flat { border: 1px solid var(--mo-line); box-shadow: none; }

/* =============================================================================
   KPI CARDS
   ============================================================================= */

.mo-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
    margin-bottom: 1.75rem;
}

.mo-kpi {
    background: var(--mo-card);
    border: 1px solid var(--mo-line);
    border-radius: var(--mo-radius-lg);
    padding: 1.25rem;
    box-shadow: var(--mo-shadow-sm);
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    transition: var(--mo-transition);
}
.mo-kpi:hover { box-shadow: var(--mo-shadow); transform: translateY(-1px); }

.mo-kpi__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.mo-kpi__title {
    font-size: 0.85rem;
    color: var(--mo-ink-600);
    font-weight: 500;
}

.mo-kpi__icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    display: grid;
    place-items: center;
    flex: 0 0 auto;
}
.mo-kpi__icon .mud-icon-root { font-size: 1.3rem !important; }

.mo-kpi--green .mo-kpi__icon {
    background: linear-gradient(135deg, #b9e0cc, #4bb483);
    color: var(--mo-primary-800);
}
.mo-kpi--blue .mo-kpi__icon {
    background: linear-gradient(135deg, #cfe0f7, #7fa7de);
    color: var(--mo-blue);
}
.mo-kpi--purple .mo-kpi__icon {
    background: linear-gradient(135deg, #dccbf5, #a98ed8);
    color: var(--mo-purple);
}
.mo-kpi--amber .mo-kpi__icon {
    background: linear-gradient(135deg, #f7e3b4, #e6bb6b);
    color: var(--mo-amber);
}

.mo-kpi__value {
    font-family: var(--mo-font-num);
    font-size: 2rem;
    font-weight: 800;
    color: var(--mo-ink-900);
    line-height: 1.1;
    font-variant-numeric: tabular-nums;
}
.mo-kpi__value small {
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--mo-ink-500);
    margin-inline-start: 0.35rem;
}

.mo-kpi__sub {
    font-size: 0.78rem;
    color: var(--mo-ink-500);
    display: flex;
    align-items: center;
    gap: 0.35rem;
}
.mo-kpi__sub--up { color: var(--mo-primary); font-weight: 600; }

/* =============================================================================
   BUTTONS
   ============================================================================= */

.mo-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.6rem 1.1rem;
    border-radius: 8px;
    font-family: var(--mo-font);
    font-size: 0.9rem;
    font-weight: 600;
    cursor: pointer;
    transition: var(--mo-transition);
    border: 1px solid transparent;
    text-decoration: none;
    white-space: nowrap;
}

.mo-btn--primary {
    background: var(--mo-primary);
    color: #fff;
    border-color: var(--mo-primary-800);
    box-shadow: 0 1px 2px rgba(12, 107, 60, 0.22);
}
.mo-btn--primary:hover { background: var(--mo-primary-600); }

.mo-btn--ghost {
    background: #fff;
    color: var(--mo-ink-700);
    border-color: var(--mo-line-strong);
}
.mo-btn--ghost:hover { background: var(--mo-ink-50); border-color: var(--mo-primary-300); color: var(--mo-primary); }

.mo-btn--danger-ghost {
    background: #fff;
    color: var(--mo-red);
    border-color: #f2c4c8;
}
.mo-btn--danger-ghost:hover { background: var(--mo-red-50); border-color: var(--mo-red); }

.mo-btn--sm { padding: 0.4rem 0.85rem; font-size: 0.82rem; }

.mo-btn--icon {
    width: 38px;
    height: 38px;
    padding: 0;
    border-radius: 8px;
}

/* =============================================================================
   CHIPS
   ============================================================================= */

.mo-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    padding: 0.22rem 0.65rem;
    font-size: 0.72rem;
    font-weight: 600;
    border-radius: 999px;
    border: 1px solid transparent;
    white-space: nowrap;
}
.mo-chip--green  { background: var(--mo-primary-50); color: var(--mo-primary); border-color: var(--mo-primary-200); }
.mo-chip--blue   { background: var(--mo-blue-50); color: var(--mo-blue); border-color: #c3d8f3; }
.mo-chip--amber  { background: var(--mo-amber-50); color: var(--mo-amber); border-color: #f0dba4; }
.mo-chip--red    { background: var(--mo-red-50); color: var(--mo-red); border-color: #f2c4c8; }
.mo-chip--purple { background: var(--mo-purple-50); color: var(--mo-purple); border-color: #d5c3ec; }
.mo-chip--slate  { background: var(--mo-ink-100); color: var(--mo-ink-700); border-color: var(--mo-ink-200); }

/* aliases */
.mo-chip--active   { background: var(--mo-primary-50); color: var(--mo-primary); border-color: var(--mo-primary-200); }
.mo-chip--pending  { background: var(--mo-amber-50); color: var(--mo-amber); border-color: #f0dba4; }
.mo-chip--approved { background: var(--mo-primary-50); color: var(--mo-primary); border-color: var(--mo-primary-200); }
.mo-chip--rejected { background: var(--mo-red-50); color: var(--mo-red); border-color: #f2c4c8; }
.mo-chip--draft    { background: var(--mo-ink-100); color: var(--mo-ink-700); border-color: var(--mo-ink-200); }

/* =============================================================================
   SCHEDULE GRID (today's schedule on dashboard)
   ============================================================================= */

.mo-schedule {
    background: var(--mo-card);
    border: 1px solid var(--mo-line);
    border-radius: var(--mo-radius-lg);
    box-shadow: var(--mo-shadow-sm);
    overflow: hidden;
}
.mo-schedule__head {
    padding: 1.1rem 1.25rem;
    border-bottom: 1px solid var(--mo-line);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
}
.mo-schedule__title {
    font-size: 1rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--mo-ink-900);
}
.mo-schedule__nav {
    display: flex;
    align-items: center;
    gap: 0.4rem;
}
.mo-schedule__date {
    padding: 0.3rem 0.85rem;
    background: var(--mo-ink-50);
    border: 1px solid var(--mo-line);
    border-radius: 6px;
    font-size: 0.82rem;
    color: var(--mo-ink-700);
}

.mo-schedule__grid {
    display: grid;
    overflow-x: auto;
    max-height: 500px;
    overflow-y: auto;
}

.mo-schedule__rooms {
    display: grid;
    border-bottom: 1px solid var(--mo-line);
    background: var(--mo-ink-50);
    position: sticky;
    top: 0;
    z-index: 2;
}
.mo-schedule__room {
    padding: 0.7rem 0.85rem;
    border-inline-end: 1px solid var(--mo-line);
    text-align: center;
}
.mo-schedule__room:last-child { border-inline-end: none; }
.mo-schedule__room-name {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--mo-ink-800);
    margin-bottom: 2px;
}
.mo-schedule__room-cap {
    font-size: 0.7rem;
    color: var(--mo-ink-500);
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}

.mo-schedule__body {
    display: grid;
    position: relative;
}

.mo-schedule__hours {
    display: flex;
    flex-direction: column;
}
.mo-schedule__hour {
    height: 48px;
    padding: 0.35rem 0.65rem;
    font-size: 0.72rem;
    color: var(--mo-ink-500);
    border-bottom: 1px dashed var(--mo-line);
    border-inline-end: 1px solid var(--mo-line);
    font-variant-numeric: tabular-nums;
    text-align: center;
}

.mo-schedule__col {
    position: relative;
    border-inline-end: 1px solid var(--mo-line);
}
.mo-schedule__col:last-child { border-inline-end: none; }
.mo-schedule__col::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: repeating-linear-gradient(to bottom, transparent 0 47px, var(--mo-line) 47px 48px);
    pointer-events: none;
}

.mo-schedule__event {
    position: absolute;
    inset-inline-start: 4px;
    inset-inline-end: 4px;
    border-radius: 6px;
    padding: 0.4rem 0.65rem;
    font-size: 0.78rem;
    cursor: pointer;
    line-height: 1.3;
    overflow: hidden;
    transition: var(--mo-transition);
    border: 1px solid transparent;
}
.mo-schedule__event:hover { transform: translateY(-1px); box-shadow: var(--mo-shadow); }
.mo-schedule__event-title { font-weight: 700; margin-bottom: 2px; }
.mo-schedule__event-time { font-size: 0.7rem; opacity: 0.85; }

.mo-schedule__event.is-green  { background: #dcf2e5; color: #085830; border-color: #b9e0cc; }
.mo-schedule__event.is-blue   { background: #e1ecf9; color: #144a8e; border-color: #c3d8f3; }
.mo-schedule__event.is-amber  { background: #fdf3de; color: #8a5c15; border-color: #f0dba4; }
.mo-schedule__event.is-purple { background: #ece1f8; color: #532e90; border-color: #d5c3ec; }

/* =============================================================================
   LIST PANELS (today bookings, popular rooms)
   ============================================================================= */

.mo-panel {
    background: var(--mo-card);
    border: 1px solid var(--mo-line);
    border-radius: var(--mo-radius-lg);
    box-shadow: var(--mo-shadow-sm);
    overflow: hidden;
}
.mo-panel__head {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--mo-line);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
}
.mo-panel__title {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--mo-ink-900);
    display: flex;
    align-items: center;
    gap: 0.45rem;
}
.mo-panel__link {
    font-size: 0.8rem;
    color: var(--mo-primary);
    text-decoration: none;
    font-weight: 500;
}
.mo-panel__link:hover { text-decoration: underline; }
.mo-panel__body { padding: 0.75rem 1.25rem; }

/* Today's bookings list */
.mo-tb-item {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 0.85rem;
    align-items: center;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--mo-ink-100);
}
.mo-tb-item:last-child { border-bottom: none; }
.mo-tb-item__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
}
.mo-tb-item__dot.is-green  { background: var(--mo-primary); }
.mo-tb-item__dot.is-blue   { background: var(--mo-blue); }
.mo-tb-item__dot.is-amber  { background: var(--mo-amber); }
.mo-tb-item__dot.is-purple { background: var(--mo-purple); }

.mo-tb-item__title {
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--mo-ink-900);
    margin-bottom: 2px;
}
.mo-tb-item__room { font-size: 0.75rem; color: var(--mo-ink-500); }

.mo-tb-item__time {
    padding: 0.3rem 0.7rem;
    background: var(--mo-primary-50);
    color: var(--mo-primary);
    border-radius: 6px;
    font-family: var(--mo-font-num);
    font-size: 0.75rem;
    font-weight: 600;
    text-align: center;
    line-height: 1.3;
    font-variant-numeric: tabular-nums;
}

/* Popular rooms list */
.mo-pr-item {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 0.85rem;
    align-items: center;
    padding: 0.75rem 0;
}
.mo-pr-item__icon {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    background: var(--mo-primary-50);
    color: var(--mo-primary);
    display: grid;
    place-items: center;
}
.mo-pr-item__info { min-width: 0; }
.mo-pr-item__name {
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--mo-ink-900);
    margin-bottom: 5px;
}
.mo-pr-item__bar {
    height: 6px;
    background: var(--mo-ink-100);
    border-radius: 3px;
    overflow: hidden;
}
.mo-pr-item__bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--mo-primary-500), var(--mo-primary));
    border-radius: 3px;
    transition: width 500ms ease-out;
}
.mo-pr-item__pct {
    font-family: var(--mo-font-num);
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--mo-primary);
    min-width: 46px;
    text-align: end;
    font-variant-numeric: tabular-nums;
}

/* =============================================================================
   GENERIC TABLES
   ============================================================================= */

.mo-table { width: 100%; border-collapse: collapse; }
.mo-table thead th {
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--mo-ink-500);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    text-align: start;
    padding: 0.7rem 1.25rem;
    background: var(--mo-ink-50);
    border-bottom: 1px solid var(--mo-line);
}
.mo-table tbody td {
    padding: 0.85rem 1.25rem;
    font-size: 0.88rem;
    color: var(--mo-ink-800);
    border-bottom: 1px solid var(--mo-ink-100);
}
.mo-table tbody tr:last-child td { border-bottom: none; }
.mo-table tbody tr:hover { background: var(--mo-ink-50); }

/* =============================================================================
   INPUTS (for login/forms)
   ============================================================================= */

.mo-input {
    width: 100%;
    padding: 0.7rem 0.9rem;
    background: #fff;
    border: 1px solid var(--mo-line-strong);
    border-radius: 8px;
    font-family: var(--mo-font);
    font-size: 0.9rem;
    color: var(--mo-ink-900);
    outline: none;
    transition: var(--mo-transition);
    box-sizing: border-box;
}
.mo-input::placeholder { color: var(--mo-ink-400); }
.mo-input:focus { border-color: var(--mo-primary); box-shadow: 0 0 0 3px rgba(12, 107, 60, 0.12); }

.mo-label {
    display: block;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--mo-ink-700);
    margin-bottom: 0.45rem;
}

.mo-search {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.9rem;
    background: #fff;
    border: 1px solid var(--mo-line-strong);
    border-radius: 8px;
    min-width: 250px;
    transition: var(--mo-transition);
}
.mo-search:focus-within { border-color: var(--mo-primary); box-shadow: 0 0 0 3px rgba(12, 107, 60, 0.08); }
.mo-search input { border: none; outline: none; background: transparent; font-family: var(--mo-font); font-size: 0.88rem; flex: 1; }

/* Legacy aliases — keep pages that still use old class names working */
.mo-login__input,
.mo-search-box input,
textarea.mo-login__input,
select.mo-login__input {
    width: 100%;
    padding: 0.7rem 0.9rem;
    background: #fff;
    border: 1px solid var(--mo-line-strong);
    border-radius: 8px;
    font-family: var(--mo-font);
    font-size: 0.9rem;
    color: var(--mo-ink-900);
    outline: none;
    transition: var(--mo-transition);
    box-sizing: border-box;
    line-height: 1.5;
}
.mo-login__input::placeholder { color: var(--mo-ink-400); }
.mo-login__input:focus {
    border-color: var(--mo-primary);
    box-shadow: 0 0 0 3px rgba(12, 107, 60, 0.12);
}
textarea.mo-login__input { resize: vertical; min-height: 52px; font-family: var(--mo-font); }
select.mo-login__input { cursor: pointer; appearance: none; background-repeat: no-repeat; background-position: left 0.75rem center; padding-inline-start: 2rem; }

.mo-login__label {
    display: block;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--mo-ink-700);
    margin-bottom: 0.45rem;
}

.mo-search-box {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.9rem;
    background: #fff;
    border: 1px solid var(--mo-line-strong);
    border-radius: 8px;
    min-width: 260px;
    transition: var(--mo-transition);
}
.mo-search-box:focus-within { border-color: var(--mo-primary); box-shadow: 0 0 0 3px rgba(12, 107, 60, 0.08); }
.mo-search-box input {
    border: none !important;
    outline: none !important;
    background: transparent !important;
    padding: 0 !important;
    flex: 1;
    box-shadow: none !important;
}

/* =============================================================================
   LOGIN HERO
   ============================================================================= */

.mo-login {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    background: var(--mo-canvas);
}
.mo-login__art {
    position: relative;
    background:
        radial-gradient(ellipse at top right, rgba(75, 180, 131, 0.25), transparent 55%),
        linear-gradient(160deg, var(--mo-primary-900) 0%, var(--mo-primary) 60%, var(--mo-primary-600) 100%);
    color: #fff;
    padding: 3rem 3.5rem;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    overflow: hidden;
}
.mo-login__art::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200' fill='none' stroke='%23ffffff' stroke-width='0.8' opacity='0.12'><g transform='translate(100 100)'><polygon points='0,-70 20,-20 70,0 20,20 0,70 -20,20 -70,0 -20,-20'/><polygon points='0,-70 20,-20 70,0 20,20 0,70 -20,20 -70,0 -20,-20' transform='rotate(22.5)'/><circle r='50'/></g></svg>");
    background-size: 280px 280px;
    animation: mo-drift 60s linear infinite;
}
@keyframes mo-drift { from { background-position: 0 0; } to { background-position: 280px 280px; } }

.mo-login__brand { display: flex; align-items: center; gap: 1rem; position: relative; z-index: 1; }
.mo-login__emblem-wrap {
    width: 72px;
    height: 72px;
    background: #fff;
    border-radius: 14px;
    padding: 8px;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25);
}
.mo-login__emblem { width: 100%; height: 100%; object-fit: contain; }
.mo-login__brand-ar { font-size: 1.1rem; font-weight: 700; }
.mo-login__brand-en { font-size: 0.7rem; letter-spacing: 0.1em; opacity: 0.8; margin-top: 4px; }

.mo-login__hero { margin-top: auto; margin-bottom: 2rem; max-width: 560px; position: relative; z-index: 1; }
.mo-login__headline {
    font-size: 2.5rem;
    font-weight: 800;
    line-height: 1.15;
    margin-bottom: 1rem;
}
.mo-login__sub { font-size: 0.95rem; line-height: 1.7; opacity: 0.85; }

.mo-login__form-wrap {
    display: flex; align-items: center; justify-content: center;
    padding: 3rem 2rem;
}
.mo-login__form { width: 100%; max-width: 400px; }
.mo-login__form-title { font-size: 1.6rem; font-weight: 700; margin-bottom: 0.4rem; color: var(--mo-ink-900); }
.mo-login__form-sub { font-size: 0.9rem; color: var(--mo-ink-500); margin-bottom: 2rem; }

.mo-login__row {
    display: flex; align-items: center; justify-content: space-between;
    margin: 0.5rem 0 1.5rem;
}
.mo-login__checkbox { display: flex; align-items: center; gap: 0.45rem; font-size: 0.85rem; color: var(--mo-ink-700); cursor: pointer; }
.mo-login__link { font-size: 0.85rem; color: var(--mo-primary); text-decoration: none; font-weight: 500; }
.mo-login__link:hover { text-decoration: underline; }

.mo-login__divider {
    margin: 1.5rem 0;
    display: flex; align-items: center; gap: 1rem;
    color: var(--mo-ink-400); font-size: 0.75rem;
}
.mo-login__divider::before, .mo-login__divider::after { content: ''; flex: 1; height: 1px; background: var(--mo-line); }

.mo-login__legal { margin-top: 2rem; font-size: 0.72rem; color: var(--mo-ink-500); text-align: center; line-height: 1.7; }

@media (max-width: 900px) {
    .mo-login { grid-template-columns: 1fr; }
    .mo-login__art { min-height: 35vh; padding: 2rem; }
    .mo-login__headline { font-size: 1.8rem; }
}

/* =============================================================================
   EMPTY STATE
   ============================================================================= */

.mo-empty {
    background: #fff;
    border: 1px dashed var(--mo-line-strong);
    border-radius: var(--mo-radius-lg);
    padding: 3rem 2rem;
    text-align: center;
}
.mo-empty__icon {
    width: 64px; height: 64px;
    border-radius: 50%;
    background: var(--mo-ink-50);
    display: inline-grid; place-items: center;
    margin-bottom: 1rem;
    border: 1px solid var(--mo-line);
}
.mo-empty__icon .mud-icon-root { font-size: 1.65rem !important; color: var(--mo-ink-400); }
.mo-empty__title { font-size: 1rem; font-weight: 700; color: var(--mo-ink-800); margin: 0 0 0.4rem; }
.mo-empty__desc { font-size: 0.88rem; color: var(--mo-ink-500); max-width: 420px; margin: 0 auto; }

/* =============================================================================
   UTILITIES
   ============================================================================= */

.mo-flex { display: flex; }
.mo-flex-col { display: flex; flex-direction: column; }
.mo-items-center { align-items: center; }
.mo-justify-between { justify-content: space-between; }
.mo-gap-2 { gap: 0.5rem; }
.mo-gap-3 { gap: 0.75rem; }
.mo-gap-4 { gap: 1rem; }
.mo-gap-6 { gap: 1.5rem; }
.mo-wrap { flex-wrap: wrap; }
.mo-text-muted { color: var(--mo-ink-500); }

/* =============================================================================
   MudBlazor overrides
   ============================================================================= */

.mud-layout, .mud-main-content { background: transparent !important; }
.mud-drawer { background: transparent !important; border: none !important; }
.mud-appbar { background: var(--mo-primary) !important; }
.mud-button-filled.mud-button-filled-primary {
    background: var(--mo-primary);
    color: #fff;
    font-family: var(--mo-font);
}
.mud-table-root { font-family: var(--mo-font); }

/* =============================================================================
   Animations
   ============================================================================= */

@keyframes mo-rise {
    from { opacity: 0; transform: translateY(6px); }
    to { opacity: 1; transform: translateY(0); }
}
.mo-animate-rise { animation: mo-rise 420ms cubic-bezier(.2, .7, .3, 1) both; }

/* =============================================================================
   Scrollbar
   ============================================================================= */

::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--mo-ink-300); border-radius: 10px; border: 2px solid transparent; background-clip: content-box; }
::-webkit-scrollbar-thumb:hover { background: var(--mo-ink-400); background-clip: content-box; }

::selection { background: var(--mo-primary-100); color: var(--mo-ink-900); }
