/**
 * OpsBrief — Materialize extensions + Clinical Concierge (uiux/stitch) tokens.
 */

:root {
    /* —— Clinical Concierge / MD3-derived (see uiux/stitch/DESIGN.md) —— */
    --cc-primary: #091426;
    --cc-primary-container: #1e293b;
    --cc-on-primary: #ffffff;
    --cc-surface: #f9f9ff;
    --cc-surface-dim: #cfdaf2;
    --cc-surface-low: #f0f3ff;
    --cc-surface-container: #e7eeff;
    --cc-surface-high: #dee8ff;
    --cc-surface-highest: #d8e3fb;
    --cc-surface-lowest: #ffffff;
    --cc-on-surface: #111c2d;
    --cc-on-surface-variant: #45474c;
    --cc-outline-variant: #c5c6cd;
    --cc-surface-tint: #545f73;
    --cc-secondary: #006e2f;
    --cc-secondary-container: #6bff8f;
    --cc-on-secondary-container: #007432;
    --cc-tertiary-fixed: #ffddb8;
    --cc-on-tertiary-container: #c88000;
    --cc-on-tertiary-fixed: #2a1700;
    --cc-error: #ba1a1a;
    --cc-error-container: #ffdad6;
    --cc-on-error-container: #93000a;
    --cc-ambient-shadow: rgba(9, 20, 38, 0.06);
    /* Cards / large surfaces */
    --cc-radius: 1rem;
    --cc-radius-lg: 2rem;
    /* Buttons, chips, compact controls — rounded square (not full pill) */
    --cc-radius-sq: 0.7rem;
    /* Caps for progress bars, true pills when explicitly needed */
    --cc-pill: 3rem;

    /* Legacy aliases (existing components) */
    --ob-primary: var(--cc-primary);
    --ob-secondary: #ff8f00;
    --ob-success: var(--cc-secondary);
    --ob-warning: #f57f17;
    --ob-danger: var(--cc-error);
    --ob-info: #0277bd;
    --ob-priority-low: #4caf50;
    --ob-priority-medium: #ff9800;
    --ob-priority-high: #f44336;
    --ob-priority-critical: #b71c1c;
    /* Aligns with Materialize large breakpoint (list ↔ card toggle) */
    --ob-list-table-min: 993px;
    /* Fixed sidenav width (Materialize default); keep navbar + main inset in sync */
    --ob-sidenav-width: 300px;
    /* Horizontal breathing room between drawer and page content (desktop) */
    --ob-main-gutter: 1.5rem;
}

/* ——— Layout ——— */
@media only screen and (min-width: 993px) {
    /*
     * Materialize: .navbar-fixed nav { position: fixed } — the nav spans the full viewport.
     * Fixed .sidenav is z-index 999 vs nav 997, so the drawer paints over the bar unless we
     * inset the nav to the right of the drawer (same width as main padding).
     */
    .navbar-fixed.ob-navbar-fixed > nav {
        left: var(--ob-sidenav-width);
        width: calc(100% - var(--ob-sidenav-width));
    }

    main.ob-main,
    footer.ob-footer {
        padding-left: var(--ob-sidenav-width);
    }
}

.ob-topnav .nav-wrapper {
    padding-left: 1rem;
    padding-right: 1rem;
}

.ob-brand-logo {
    font-weight: 600;
    left: 3rem !important;
    transform: none !important;
}

@media only screen and (min-width: 993px) {
    .ob-brand-logo {
        left: 1rem !important;
        margin-left: 0;
    }
}

.ob-topnav__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    max-width: 70%;
}

.ob-topnav__actions li {
    float: none;
}

.ob-property-form {
    margin: 0;
    display: inline-block;
}

.ob-property-select {
    max-width: 14rem;
    height: 2.25rem;
    border: 1px solid #e0e0e0;
    border-radius: 4px;
    padding: 0 0.5rem;
    font-size: 0.9rem;
}

.ob-property-mobile .ob-property-field {
    margin: 0;
}

.ob-user-pill {
    font-size: 0.9rem;
    white-space: nowrap;
}

.ob-role-badge {
    display: inline-block;
    margin-left: 0.35rem;
    padding: 0.1rem 0.45rem;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    border-radius: 4px;
    background: var(--cc-surface-highest);
    color: var(--cc-primary);
}

.ob-sidenav .collapsible-header,
.ob-sidenav li > a {
    color: #424242;
}

.ob-sidenav li > a.active,
.ob-sidenav .collapsible-body li > a.active {
    background-color: var(--cc-surface-highest);
    border-left: none;
    padding-left: 16px;
}

.ob-sidenav .collapsible-body li > a {
    padding-left: 1.5rem;
}

.ob-sidenav__toolbar-wrap {
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.ob-sidenav-toolbar {
    display: flex;
    gap: 0.35rem;
    padding: 0.4rem 0.65rem 0.55rem;
    align-items: center;
}

.ob-sidenav-toolbar__btn {
    flex: 1;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--cc-on-surface-variant);
    border-radius: var(--cc-radius);
    line-height: 1.2;
    padding: 0.4rem 0.35rem;
    text-align: center;
}

.ob-sidenav-toolbar__btn:hover {
    background: rgba(9, 20, 38, 0.06);
}

.ob-side-collapsible .collapsible-header {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.ob-collapsible-header__main {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    flex: 1;
    min-width: 0;
}

.ob-collapsible-header__chevron {
    flex-shrink: 0;
    transition: transform 0.2s ease;
    color: var(--cc-on-surface-variant);
    font-size: 1.35rem !important;
}

.ob-side-collapsible li.active > .collapsible-header .ob-collapsible-header__chevron {
    transform: rotate(180deg);
}

/* Materialize default header chevron — we use .ob-collapsible-header__chevron */
.ob-side-collapsible .collapsible-header::after {
    display: none !important;
}

/* Materialize: global `nav { background-color: #ee6e73; height: 56px; … }` — drawer menu is also a <nav>. */
nav.ob-mobile-nav {
    background: transparent !important;
    background-color: transparent !important;
    color: inherit;
    height: auto !important;
    line-height: normal !important;
    width: auto;
    max-width: none;
    box-shadow: none !important;
}

@media only screen and (max-width: 992px) {
    /* Full-width app menu (not a narrow rail) */
    #ob-sidenav.sidenav {
        width: 100% !important;
        max-width: 100%;
        overflow-y: auto;
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
        padding-bottom: max(2rem, env(safe-area-inset-bottom, 0px));
    }

    .sidenav.ob-sidenav {
        padding: 0;
    }

    .ob-sidenav-mobile {
        height: auto !important;
    }

    .ob-mobile-nav {
        padding: 0.5rem 1.5rem 1.75rem 2rem;
    }

    @media only screen and (min-width: 480px) {
        .ob-mobile-nav {
            padding-left: 2rem;
            padding-right: 1.75rem;
        }
    }

    .ob-mobile-nav-section {
        margin-bottom: 2.5rem;
    }

    .ob-mobile-nav-section:last-child {
        margin-bottom: 0;
    }

    .ob-mobile-nav-section__title {
        font-size: 0.625rem;
        font-weight: 700;
        letter-spacing: 0.12em;
        text-transform: uppercase;
        color: var(--cc-on-surface-variant);
        margin: 0 0 1rem 0.25rem;
        padding: 0;
        border: none;
    }

    .ob-mobile-nav-section__row-gap {
        margin-top: 1rem;
    }

    .ob-mobile-nav-hero-card {
        border-radius: var(--cc-radius);
        overflow: hidden;
        background: linear-gradient(145deg, var(--cc-primary), var(--cc-primary-container));
        box-shadow: 0 4px 20px rgba(9, 20, 38, 0.18);
        transition: box-shadow 0.12s ease;
    }

    .ob-mobile-nav-hero-card:hover {
        box-shadow: 0 6px 24px rgba(9, 20, 38, 0.22);
    }

    .ob-mobile-nav-hero {
        display: flex !important;
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        min-height: 5.5rem;
        padding: 1.75rem 1.5rem !important;
        margin: 0 !important;
        border-radius: 0;
        text-decoration: none;
        color: var(--cc-on-primary);
        background: transparent;
        box-shadow: none;
        transition: transform 0.12s ease, opacity 0.12s ease;
    }

    .ob-mobile-nav-hero:hover {
        color: var(--cc-on-primary);
        opacity: 0.96;
    }

    .ob-mobile-nav-hero:active {
        transform: scale(0.995);
    }

    .ob-mobile-nav-hero-card--has-kpis .ob-mobile-nav-hero {
        border-bottom: 1px solid rgba(255, 255, 255, 0.14);
    }

    .ob-mobile-nav-hero__main {
        display: flex;
        align-items: center;
        gap: 1.25rem;
        min-width: 0;
    }

    .ob-mobile-nav-hero__icon-wrap {
        flex-shrink: 0;
        width: 4rem;
        height: 4rem;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        background: rgba(255, 255, 255, 0.12);
    }

    .ob-mobile-nav-hero__icon-wrap .material-icons {
        font-size: 2.25rem !important;
        color: var(--cc-on-primary);
    }

    .ob-mobile-nav-hero__text {
        display: flex;
        flex-direction: column;
        gap: 0.2rem;
        min-width: 0;
    }

    .ob-mobile-nav-hero__title {
        font-size: 1.5rem;
        font-weight: 700;
        letter-spacing: -0.02em;
        line-height: 1.15;
        color: var(--cc-on-primary);
    }

    .ob-mobile-nav-hero__sub {
        font-size: 0.8125rem;
        line-height: 1.35;
        color: rgba(255, 255, 255, 0.72);
    }

    .ob-mobile-nav-hero__chevron {
        flex-shrink: 0;
        font-size: 1.5rem !important;
        color: rgba(255, 255, 255, 0.45);
        transition: transform 0.15s ease;
    }

    .ob-mobile-nav-hero:hover .ob-mobile-nav-hero__chevron {
        transform: translateX(3px);
        color: rgba(255, 255, 255, 0.65);
    }

    .ob-mobile-nav-hero-card--active {
        box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.45), 0 4px 20px rgba(9, 20, 38, 0.22);
    }

    .ob-mobile-nav-hero__kpis {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.5rem;
        padding: 0.75rem 0.75rem 0.85rem;
    }

    .ob-mobile-nav-hero__kpis--single {
        grid-template-columns: 1fr;
    }

    .ob-mobile-nav-hero__kpi {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 0.2rem;
        min-height: 3.25rem;
        padding: 0.5rem 0.65rem;
        border-radius: calc(var(--cc-radius) * 0.85);
        text-decoration: none;
        color: var(--cc-on-primary);
        background: rgba(255, 255, 255, 0.12);
        border: 1px solid rgba(255, 255, 255, 0.18);
        font-weight: 600;
        transition: background 0.12s ease, transform 0.12s ease;
    }

    .ob-mobile-nav-hero__kpi:hover {
        background: rgba(255, 255, 255, 0.2);
        color: var(--cc-on-primary);
    }

    .ob-mobile-nav-hero__kpi:active {
        transform: scale(0.98);
    }

    .ob-mobile-nav-hero__kpi-label {
        font-size: 0.6875rem;
        font-weight: 600;
        letter-spacing: 0.04em;
        text-transform: uppercase;
        opacity: 0.88;
        text-align: center;
        line-height: 1.2;
    }

    .ob-mobile-nav-hero__kpi-value {
        font-size: 1.375rem;
        font-weight: 800;
        letter-spacing: -0.02em;
        line-height: 1;
    }

    .ob-mobile-nav-row {
        display: flex !important;
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        padding: 1.25rem 1.25rem !important;
        margin: 0 !important;
        border-radius: var(--cc-radius);
        text-decoration: none;
        color: var(--cc-on-surface);
        background: var(--cc-surface-low);
        border: 1px solid rgba(9, 20, 38, 0.06);
        box-shadow: 0 1px 3px rgba(9, 20, 38, 0.05);
        transition: transform 0.12s ease, box-shadow 0.12s ease;
    }

    .ob-mobile-nav-row:hover {
        box-shadow: 0 3px 12px rgba(9, 20, 38, 0.08);
    }

    .ob-mobile-nav-row:active {
        transform: scale(0.99);
    }

    .ob-mobile-nav-row__main {
        display: flex;
        align-items: center;
        gap: 1rem;
        min-width: 0;
    }

    .ob-mobile-nav-row__icon-wrap {
        flex-shrink: 0;
        width: 3rem;
        height: 3rem;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        background: var(--cc-error-container);
        color: var(--cc-on-error-container);
    }

    .ob-mobile-nav-row__icon-wrap .material-icons {
        font-size: 1.35rem !important;
    }

    .ob-mobile-nav-row__label {
        font-size: 1.125rem;
        font-weight: 700;
        letter-spacing: -0.01em;
        line-height: 1.25;
    }

    .ob-mobile-nav-row__chevron {
        flex-shrink: 0;
        font-size: 1.25rem !important;
        color: var(--cc-outline-variant);
        transition: transform 0.15s ease;
    }

    .ob-mobile-nav-row:hover .ob-mobile-nav-row__chevron {
        transform: translateX(3px);
        color: var(--cc-surface-tint);
    }

    .ob-mobile-nav-row--active {
        box-shadow: inset 0 0 0 2px var(--cc-primary), 0 2px 10px rgba(9, 20, 38, 0.06);
    }

    .ob-mobile-nav-section__grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.75rem;
    }

    @media only screen and (min-width: 480px) {
        .ob-mobile-nav-section__grid:not(.ob-mobile-nav-section__grid--menu) {
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: 0.85rem;
        }
    }

    .ob-mobile-nav-section__grid--menu {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 1rem;
    }

    .ob-mobile-nav-tile {
        display: flex !important;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        text-align: center;
        min-height: 6.35rem;
        padding: 1rem 0.5rem !important;
        margin: 0 !important;
        border-radius: var(--cc-radius);
        color: var(--cc-on-surface);
        text-decoration: none;
        font-weight: 700;
        font-size: 1.125rem;
        line-height: 1.25;
        letter-spacing: -0.01em;
        text-transform: none;
        border: 1px solid transparent;
        box-shadow: 0 1px 3px rgba(9, 20, 38, 0.06);
        transition: transform 0.12s ease, box-shadow 0.12s ease, border-color 0.12s ease;
    }

    .ob-mobile-nav-section__grid--menu .ob-mobile-nav-tile:not(.ob-mobile-nav-tile--brief) {
        align-items: flex-start;
        justify-content: space-between;
        text-align: left;
        min-height: 11.5rem;
        padding: 1.5rem !important;
    }

    .ob-mobile-nav-section__grid--menu .ob-mobile-nav-tile:not(.ob-mobile-nav-tile--brief) .ob-mobile-nav-tile__icon {
        margin-bottom: 0;
    }

    .ob-mobile-nav-section__grid--menu .ob-mobile-nav-tile:not(.ob-mobile-nav-tile--brief) .ob-mobile-nav-tile__label {
        margin-top: auto;
        padding-top: 0.75rem;
    }

    .ob-mobile-nav-tile--brief {
        min-height: 8rem;
        padding: 1.25rem 1.25rem !important;
    }

    .ob-mobile-nav-section__grid--menu .ob-mobile-nav-tile--brief {
        align-items: flex-start;
        justify-content: space-between;
        text-align: left;
    }

    .ob-mobile-nav-tile--skin-br-today .ob-mobile-nav-tile__label,
    .ob-mobile-nav-tile--skin-br-archive .ob-mobile-nav-tile__label {
        font-size: 0.8125rem;
        font-weight: 700;
        letter-spacing: 0.08em;
        text-transform: uppercase;
    }

    .ob-mobile-nav-tile--skin-br-generate.ob-mobile-nav-tile--brief .ob-mobile-nav-tile__label {
        font-size: 1rem;
        font-weight: 700;
        letter-spacing: -0.01em;
        text-transform: none;
    }

    .ob-mobile-nav-tile:hover {
        box-shadow: 0 4px 14px rgba(9, 20, 38, 0.1);
    }

    .ob-mobile-nav-tile:active {
        transform: scale(0.98);
    }

    .ob-mobile-nav-tile__icon {
        display: flex;
        align-items: center;
        justify-content: center;
        margin-bottom: 0.5rem;
    }

    .ob-mobile-nav-tile__icon .material-icons {
        font-size: 2.45rem !important;
    }

    .ob-mobile-nav-section__grid--menu .ob-mobile-nav-tile:not(.ob-mobile-nav-tile--brief) .ob-mobile-nav-tile__icon .material-icons {
        font-size: 3.75rem !important;
    }

    .ob-mobile-nav-tile--brief .ob-mobile-nav-tile__icon .material-icons {
        font-size: 3rem !important;
    }

    /* Reference palette — Operations */
    .ob-mobile-nav-tile--skin-ops-issues {
        background: #e3f2fd;
        border-color: rgba(25, 118, 210, 0.12);
    }

    .ob-mobile-nav-tile--skin-ops-issues .ob-mobile-nav-tile__icon .material-icons {
        color: #1976d2;
    }

    .ob-mobile-nav-tile--skin-ops-issues .ob-mobile-nav-tile__label {
        color: #0d47a1;
    }

    .ob-mobile-nav-tile--skin-ops-new {
        background: #fff3e0;
        border-color: rgba(251, 140, 0, 0.15);
    }

    .ob-mobile-nav-tile--skin-ops-new .ob-mobile-nav-tile__icon .material-icons {
        color: #fb8c00;
    }

    .ob-mobile-nav-tile--skin-ops-new .ob-mobile-nav-tile__label {
        color: #e65100;
    }

    .ob-mobile-nav-tile--skin-ops-inspections {
        background: #f3e5f5;
        border-color: rgba(142, 36, 170, 0.12);
    }

    .ob-mobile-nav-tile--skin-ops-inspections .ob-mobile-nav-tile__icon .material-icons {
        color: #8e24aa;
    }

    .ob-mobile-nav-tile--skin-ops-inspections .ob-mobile-nav-tile__label {
        color: #4a148c;
    }

    .ob-mobile-nav-tile--skin-ops-start {
        background: #e8f5e9;
        border-color: rgba(67, 160, 71, 0.15);
    }

    .ob-mobile-nav-tile--skin-ops-start .ob-mobile-nav-tile__icon .material-icons {
        color: #43a047;
    }

    .ob-mobile-nav-tile--skin-ops-start .ob-mobile-nav-tile__label {
        color: #1b5e20;
    }

    .ob-mobile-nav-tile--skin-ops-templates {
        background: #eceff1;
        border-color: rgba(38, 50, 56, 0.1);
    }

    .ob-mobile-nav-tile--skin-ops-templates .ob-mobile-nav-tile__icon .material-icons {
        color: #37474f;
    }

    .ob-mobile-nav-tile--skin-ops-templates .ob-mobile-nav-tile__label {
        color: #263238;
    }

    /* Guest experience */
    .ob-mobile-nav-tile--skin-gx-complaints {
        background: #ffebee;
        border-color: rgba(229, 57, 53, 0.12);
    }

    .ob-mobile-nav-tile--skin-gx-complaints .ob-mobile-nav-tile__icon .material-icons {
        color: #e53935;
    }

    .ob-mobile-nav-tile--skin-gx-complaints .ob-mobile-nav-tile__label {
        color: #b71c1c;
    }

    .ob-mobile-nav-tile--skin-gx-analytics {
        background: #e0f7fa;
        border-color: rgba(0, 172, 193, 0.15);
    }

    .ob-mobile-nav-tile--skin-gx-analytics .ob-mobile-nav-tile__icon .material-icons {
        color: #00acc1;
    }

    .ob-mobile-nav-tile--skin-gx-analytics .ob-mobile-nav-tile__label {
        color: #006064;
    }

    /* Briefings (compact) */
    .ob-mobile-nav-tile--skin-br-today {
        background: #f1f8e9;
        border: 2px solid rgba(174, 213, 129, 0.35);
    }

    .ob-mobile-nav-tile--skin-br-today .ob-mobile-nav-tile__icon .material-icons {
        color: #7cb342;
    }

    .ob-mobile-nav-tile--skin-br-today .ob-mobile-nav-tile__label {
        color: #33691e;
    }

    .ob-mobile-nav-tile--skin-br-archive {
        background: #fafafa;
        border: 2px solid #e0e0e0;
    }

    .ob-mobile-nav-tile--skin-br-archive .ob-mobile-nav-tile__icon .material-icons {
        color: #9e9e9e;
    }

    .ob-mobile-nav-tile--skin-br-archive .ob-mobile-nav-tile__label {
        color: #757575;
    }

    .ob-mobile-nav-tile--skin-br-generate {
        background: var(--cc-surface-container);
        border-color: rgba(9, 20, 38, 0.08);
    }

    .ob-mobile-nav-tile--skin-br-generate .ob-mobile-nav-tile__icon .material-icons {
        color: var(--cc-primary);
    }

    .ob-mobile-nav-tile--skin-br-generate .ob-mobile-nav-tile__label {
        color: var(--cc-on-surface);
    }

    /* Default tiles (housekeeping, property, account) */
    .ob-mobile-nav-tile--skin-neutral {
        background: var(--cc-surface-low);
        border-color: rgba(9, 20, 38, 0.08);
        font-size: 0.78rem;
        font-weight: 600;
    }

    .ob-mobile-nav-tile--skin-neutral .ob-mobile-nav-tile__icon .material-icons {
        color: var(--cc-primary);
    }

    .ob-mobile-nav-tile--skin-neutral .ob-mobile-nav-tile__label {
        color: var(--cc-on-surface);
    }

    .ob-mobile-nav-tile--active {
        box-shadow: inset 0 0 0 2px var(--cc-primary), 0 2px 10px rgba(9, 20, 38, 0.06);
    }

    /* Desktop sidebar list (hidden on small screens via hide-on-med-and-down) */
    .ob-sidenav li > a.waves-effect:not(.ob-sidenav-toolbar__btn):not(.ob-mobile-nav-tile):not(.ob-mobile-nav-hero):not(.ob-mobile-nav-row) {
        margin: 0.4rem 0.9rem;
        border-radius: var(--cc-radius);
        min-height: 3.35rem;
        line-height: 1.25;
        display: flex !important;
        align-items: center;
        padding: 0.65rem 1rem !important;
    }

    .ob-sidenav li > a.waves-effect:not(.ob-sidenav-toolbar__btn):not(.ob-mobile-nav-tile):not(.ob-mobile-nav-hero):not(.ob-mobile-nav-row) .material-icons:first-child {
        margin-right: 0.85rem;
    }

    .ob-sidenav .ob-side-collapsible {
        margin-left: 0.65rem;
        margin-right: 0.65rem;
        margin-bottom: 0.4rem;
    }

    .ob-sidenav .ob-side-collapsible .collapsible-header {
        border-radius: var(--cc-radius);
        min-height: 3.35rem;
        padding-left: 1rem !important;
        padding-right: 0.75rem !important;
    }

    .ob-sidenav .ob-side-collapsible .collapsible-body {
        border-radius: 0 0 var(--cc-radius) var(--cc-radius);
        background: rgba(9, 20, 38, 0.03);
    }

    .ob-sidenav__toolbar-wrap {
        margin: 0 0.5rem 0.35rem;
        border-radius: var(--cc-radius);
        overflow: hidden;
        border: 1px solid rgba(0, 0, 0, 0.06);
    }

    .ob-sidenav-toolbar {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        justify-content: center;
        gap: 0.25rem;
        padding: 0.5rem;
    }

    .ob-sidenav-toolbar__btn--icon-only {
        min-width: 2.5rem !important;
        padding: 0 0.35rem !important;
    }

    .ob-sidenav-toolbar__btn--icon-only .material-icons {
        margin: 0 !important;
        font-size: 1.35rem !important;
    }

    .ob-sidenav .ob-side-collapsible .collapsible-body li > a {
        display: flex !important;
        align-items: center;
        gap: 0.65rem;
        margin: 0.25rem 0.5rem;
        border-radius: calc(var(--cc-radius) * 0.85);
        padding-left: 0.85rem !important;
        padding-right: 0.85rem !important;
        line-height: 1.25 !important;
        min-height: 2.75rem;
    }

    .ob-sidenav-sub__icon {
        flex-shrink: 0;
        font-size: 1.25rem !important;
        width: 1.5rem;
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        color: var(--cc-surface-tint);
    }

    .ob-sidenav .collapsible-body li > a.active .ob-sidenav-sub__icon {
        color: var(--cc-primary);
    }

    .ob-sidenav-sub__label {
        flex: 1;
        min-width: 0;
    }
}

/* Desktop: hide fixed drawer + reclaim horizontal space (toggle restores) */
@media only screen and (min-width: 993px) {
    .ob-desktop-sidenav-reopen {
        display: none !important;
    }

    html.ob-sidenav-desktop-hidden .ob-desktop-sidenav-reopen {
        display: inline-flex !important;
    }

    html.ob-sidenav-desktop-hidden .sidenav.sidenav-fixed#ob-sidenav {
        transform: translateX(-105%) !important;
        visibility: hidden;
        pointer-events: none;
    }

    html.ob-sidenav-desktop-hidden main.ob-main,
    html.ob-sidenav-desktop-hidden footer.ob-footer {
        padding-left: 0 !important;
    }

    html.ob-sidenav-desktop-hidden .navbar-fixed.ob-navbar-fixed > nav {
        left: 0 !important;
        width: 100% !important;
    }
}

.ob-navbar-fixed ~ main.ob-main {
    padding-top: 4rem;
}

.ob-main__inner {
    padding-top: 1.5rem;
    padding-bottom: 2rem;
    max-width: 100%;
    overflow-x: auto;
}

@media only screen and (min-width: 993px) {
    main.ob-main .ob-main__inner {
        padding-left: var(--ob-main-gutter);
        padding-right: var(--ob-main-gutter);
    }
}

@media only screen and (max-width: 992px) {
    main.ob-main .container {
        padding-left: 1.15rem;
        padding-right: 1.15rem;
    }
}

/* ——— Flash ——— */
.ob-flash {
    margin-bottom: 1rem;
}

.ob-flash__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.75rem 1rem !important;
}

.ob-flash--success {
    background: #ecfdf5;
}

.ob-flash--error {
    background: var(--cc-error-container);
}

.ob-flash--warning {
    background: var(--cc-tertiary-fixed);
}

.ob-flash--info {
    background: var(--cc-surface-high);
}

.ob-flash__close {
    font-size: 1.5rem;
    line-height: 1;
    color: #757575;
}

.ob-flash.ob-flash--hidden {
    display: none;
}

/* ——— BEM components ——— */
.ob-card {
    background: #fff;
    border-radius: 4px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.06);
    margin-bottom: 1rem;
}

.ob-card__header {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid #eee;
    font-weight: 600;
}

.ob-card__body {
    padding: 1rem 1.25rem;
}

.ob-badge {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    font-size: 0.75rem;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.ob-kpi-card {
    text-align: center;
    padding: 1.25rem;
}

.ob-kpi-card__value {
    font-size: 2rem;
    font-weight: 600;
    color: var(--ob-primary);
}

.ob-kpi-card__label {
    font-size: 0.85rem;
    color: #757575;
}

.ob-status-badge {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    font-size: 0.75rem;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.ob-status-badge--open {
    background: #e3f2fd;
    color: #1565c0;
}

.ob-status-badge--assigned {
    background: #fff3e0;
    color: #e65100;
}

.ob-status-badge--in-progress {
    background: #fff8e1;
    color: #f57f17;
}

.ob-status-badge--resolved {
    background: #e8f5e9;
    color: #2e7d32;
}

.ob-status-badge--closed {
    background: #eceff1;
    color: #546e7a;
}

.ob-status-badge--received {
    background: #e3f2fd;
    color: #1565c0;
}

.ob-status-badge--investigating {
    background: #fff3e0;
    color: #e65100;
}

.ob-status-badge--action-taken {
    background: #f3e5f5;
    color: #6a1b9a;
}

.ob-status-badge--draft {
    background: #eceff1;
    color: #455a64;
}

.ob-status-badge--submitted {
    background: #e8eaf6;
    color: #3949ab;
}

.ob-status-badge--approved {
    background: #e8f5e9;
    color: #2e7d32;
}

.ob-status-badge--completed {
    background: #e8f5e9;
    color: #2e7d32;
}

.ob-status-badge--cancelled {
    background: #ffebee;
    color: #c62828;
}

.ob-priority-badge {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    font-size: 0.75rem;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    color: #fff;
}

.ob-priority-badge--low {
    background: var(--ob-priority-low);
}

.ob-priority-badge--medium {
    background: var(--ob-priority-medium);
}

.ob-priority-badge--high {
    background: var(--ob-priority-high);
}

.ob-priority-badge--critical {
    background: var(--ob-priority-critical);
}

.ob-sla-indicator {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.8rem;
    font-weight: 600;
}

.ob-sla-indicator::before {
    content: '';
    width: 0.5rem;
    height: 0.5rem;
    border-radius: 50%;
}

.ob-sla-indicator--ok {
    color: var(--ob-success);
}

.ob-sla-indicator--ok::before {
    background: var(--ob-success);
}

.ob-sla-indicator--warn {
    color: var(--ob-warning);
}

.ob-sla-indicator--warn::before {
    background: var(--ob-warning);
}

.ob-sla-indicator--breach {
    color: var(--ob-danger);
}

.ob-sla-indicator--breach::before {
    background: var(--ob-danger);
}

/* ——— Responsive list ↔ card (Materialize large = 993px) ———
   Use with framework helpers:
   - Table block: .hide-on-med-and-down (visible when min-width 993px)
   - Card stack: .hide-on-large-only (visible when max-width 992px)
   Same breakpoint as main sidebar / .ob-main padding-left. */

.ob-responsive-card-stack.row {
    margin-bottom: 0;
}

.ob-responsive-card-stack.row > .col {
    margin-bottom: 0.75rem;
}

.ob-responsive-card-stack.row > .col:last-child {
    margin-bottom: 0;
}

.ob-responsive-card-stack .card .card-content p {
    margin-top: 0.35rem;
    margin-bottom: 0;
}

.ob-responsive-card-stack .card .card-content p:first-of-type {
    margin-top: 0.5rem;
}

/* ——— Tables / cards mobile ——— */
/*
 * Materialize .responsive-table uses display:block / float tricks so each data row
 * becomes a vertical “label column + value column” strip — confusing for real data tables.
 * Restore normal table semantics app-wide; use .ob-table-wrap for horizontal scroll.
 */
table.responsive-table {
    display: table !important;
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
    position: static;
}

table.responsive-table thead {
    display: table-header-group !important;
    float: none !important;
    border: 0 !important;
    border-right: 0 !important;
}

table.responsive-table tbody {
    display: table-row-group !important;
    width: auto !important;
    position: static !important;
    overflow-x: visible !important;
    white-space: normal !important;
}

table.responsive-table thead tr,
table.responsive-table tbody tr {
    display: table-row !important;
    vertical-align: middle !important;
    padding: 0 !important;
}

table.responsive-table tbody tr {
    border-bottom: none;
}

table.responsive-table th,
table.responsive-table td {
    display: table-cell !important;
    text-align: left;
    white-space: normal;
    vertical-align: middle;
    min-height: 0 !important;
}

table.responsive-table thead tr th::before {
    content: none !important;
}

/* Horizontal scroll for wide tables at any viewport (mobile + zoomed desktop) */
.ob-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
}

/* Settings list tables: app overrides Materialize responsive-table; scroll + compact meta on narrow viewports */
.card.ob-card-table--scroll .card-content {
    padding-top: 0.75rem;
}

.ob-table--settings-categories {
    min-width: 34rem;
}

.ob-table--settings-types {
    min-width: 28rem;
}

.ob-table-icon-cell {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    flex-wrap: wrap;
    vertical-align: middle;
}

@media only screen and (max-width: 992px) {
    .ob-table-wrap--settings .ob-table-actions {
        white-space: normal;
        vertical-align: top;
    }

    .ob-table-wrap--settings .ob-table-actions .btn-flat {
        margin-top: 0.2rem;
    }
}

.ob-room-table-wrap {
    margin-top: 0.75rem;
}

.ob-room-table {
    min-width: 32rem;
}

@media only screen and (max-width: 600px) {
    .ob-stack-mobile .col {
        width: 100% !important;
        margin-bottom: 1rem;
    }
}

/* ——— Clinical Concierge: global ——— */
body.ob-theme-cc {
    font-family: 'Inter', system-ui, sans-serif;
    background: var(--cc-surface) !important;
    color: var(--cc-on-surface);
}

body.ob-theme-cc .ob-sidenav {
    background: var(--cc-surface-lowest);
    box-shadow: none;
    border-right: none;
}

body.ob-theme-cc .ob-sidenav .collapsible-header,
body.ob-theme-cc .ob-sidenav li > a:not(.ob-mobile-nav-tile):not(.ob-mobile-nav-hero):not(.ob-mobile-nav-row) {
    color: var(--cc-on-surface-variant);
}

body.ob-theme-cc .ob-mobile-nav-tile {
    color: var(--cc-on-surface);
}

body.ob-theme-cc .ob-mobile-nav-row {
    color: var(--cc-on-surface);
}

body.ob-theme-cc .ob-sidenav li > a.active,
body.ob-theme-cc .ob-sidenav .collapsible-body li > a.active {
    color: var(--cc-primary);
    font-weight: 600;
}

body.ob-theme-cc .sidenav.z-depth-1,
body.ob-theme-cc .sidenav {
    box-shadow: none !important;
}

/* ——— Materialize → Clinical Concierge (uiux/stitch): surfaces, CTAs, no Material blue ——— */
body.ob-theme-cc .card {
    background: var(--cc-surface-lowest);
    border: none !important;
    border-radius: var(--cc-radius) !important;
    box-shadow: none !important;
}

body.ob-theme-cc .card.ob-flash {
    border-radius: var(--cc-radius) !important;
}

body.ob-theme-cc .card.ob-flash.ob-flash--success {
    background: #ecfdf5 !important;
}

body.ob-theme-cc .card.ob-flash.ob-flash--error {
    background: var(--cc-error-container) !important;
}

body.ob-theme-cc .card.ob-flash.ob-flash--warning {
    background: var(--cc-tertiary-fixed) !important;
}

body.ob-theme-cc .card.ob-flash.ob-flash--info {
    background: var(--cc-surface-high) !important;
}

body.ob-theme-cc .card.ob-card-filters,
body.ob-theme-cc .card.ob-card-table,
body.ob-theme-cc .card.ob-table-card,
body.ob-theme-cc .card.ob-sla-card {
    background: var(--cc-surface-low);
}

body.ob-theme-cc .card .card-action {
    border-top: none !important;
    background: transparent;
    padding: 0.75rem 1.25rem 1.25rem;
}

body.ob-theme-cc .card .card-title {
    color: var(--cc-primary);
    font-weight: 800;
    letter-spacing: -0.02em;
}

body.ob-theme-cc table.striped > tbody > tr:nth-child(odd) {
    background-color: rgba(240, 243, 255, 0.65);
}

body.ob-theme-cc table.highlight > tbody > tr:hover {
    background-color: var(--cc-surface-high);
}

/* Filled actions: same rounded-square radius app-wide */
body.ob-theme-cc .btn.waves-effect:not(.btn-flat):not(.btn-floating),
body.ob-theme-cc .btn-large.waves-effect:not(.btn-flat):not(.btn-floating) {
    border-radius: var(--cc-radius-sq) !important;
}

/* Vertical center: theme typography + Materialize line-height leaves labels top-heavy */
body.ob-theme-cc .btn:not(.btn-flat):not(.btn-floating):not(.btn-large):not(.btn-small) {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 1.3 !important;
    height: auto !important;
    min-height: 36px;
    box-sizing: border-box;
}

body.ob-theme-cc .btn.btn-large:not(.btn-flat):not(.btn-floating) {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 1.3 !important;
    height: auto !important;
    min-height: 54px;
    box-sizing: border-box;
}

/* Primary actions: liquid CTA (DESIGN.md §4) */
body.ob-theme-cc .btn.blue.darken-2,
body.ob-theme-cc .btn-large.blue.darken-2 {
    background: linear-gradient(145deg, var(--cc-primary), var(--cc-primary-container)) !important;
    color: var(--cc-on-primary) !important;
    font-weight: 800 !important;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-size: 0.8rem !important;
    box-shadow: 0 12px 28px -10px rgba(9, 20, 38, 0.45) !important;
    border: none !important;
}

body.ob-theme-cc .btn.blue.darken-2:hover,
body.ob-theme-cc .btn-large.blue.darken-2:hover {
    filter: brightness(1.05);
}

body.ob-theme-cc .btn-floating.btn-large.blue.darken-2 {
    background: linear-gradient(145deg, var(--cc-primary), var(--cc-primary-container)) !important;
    border-radius: 50% !important;
    box-shadow: 0 12px 28px -8px rgba(9, 20, 38, 0.4) !important;
}

body.ob-theme-cc .btn-floating.btn-large.blue.darken-2:hover {
    filter: brightness(1.06);
}

/* Full-bleed metric / hero cards that intentionally use .blue.darken-2 */
body.ob-theme-cc .card.blue.darken-2 {
    background: linear-gradient(145deg, var(--cc-primary), var(--cc-primary-container)) !important;
    color: var(--cc-on-primary) !important;
    box-shadow: 0 12px 28px -10px rgba(9, 20, 38, 0.35) !important;
}

body.ob-theme-cc .card.blue.darken-2 .card-title,
body.ob-theme-cc .card.blue.darken-2 .card-content {
    color: inherit;
}

/* Tertiary / cancel */
body.ob-theme-cc a.btn-flat:not(.modal-close) {
    color: var(--cc-surface-tint) !important;
    font-weight: 800 !important;
    font-size: 0.7rem !important;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

body.ob-theme-cc a.btn-flat:not(.modal-close):hover {
    background-color: rgba(9, 20, 38, 0.06) !important;
    color: var(--cc-primary) !important;
}

/* Modal footer primary */
body.ob-theme-cc .modal .modal-footer .btn.blue.darken-2 {
    margin: 0.35rem 0.5rem;
}

/* Legacy ob-card: tonal, no divider line */
body.ob-theme-cc .ob-card {
    background: var(--cc-surface-lowest);
    border-radius: var(--cc-radius);
    box-shadow: none;
    border: none;
}

body.ob-theme-cc .ob-card__header {
    border-bottom: none;
    padding-bottom: 0.85rem;
    margin-bottom: 0.25rem;
    color: var(--cc-primary);
}

/* Inspection conduct: replace grey borders with tonal panels */
body.ob-theme-cc .ob-conduct-cat-head {
    background: var(--cc-surface-lowest);
    border: none !important;
    border-radius: var(--cc-radius) !important;
    box-shadow: none;
}

body.ob-theme-cc .ob-conduct-item {
    border: none !important;
    border-radius: var(--cc-radius) !important;
    box-shadow: none !important;
    background: var(--cc-surface-lowest);
    border-left: 4px solid #90caf9 !important;
}

body.ob-theme-cc .ob-conduct-item--critical {
    background: var(--cc-error-container);
    border-left-color: var(--cc-error) !important;
}

body.ob-theme-cc .ob-insp-score-row {
    border: none !important;
    background: var(--cc-surface-low) !important;
    border-radius: var(--cc-radius) !important;
}

body.ob-theme-cc .ob-insp-score-row--fail {
    background: var(--cc-error-container) !important;
}

body.ob-theme-cc .btn-flat.grey.lighten-3 {
    background: var(--cc-surface-high) !important;
    color: var(--cc-on-surface-variant) !important;
    border-radius: var(--cc-radius-sq) !important;
}

/* Secondary / accent filled buttons (e.g. teal) — match primary geometry */
body.ob-theme-cc .btn.teal.darken-2,
body.ob-theme-cc .btn-large.teal.darken-2,
body.ob-theme-cc .btn.teal,
body.ob-theme-cc .btn.green,
body.ob-theme-cc .btn.red,
body.ob-theme-cc .btn.amber,
body.ob-theme-cc .btn.orange {
    font-weight: 800 !important;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-size: 0.8rem !important;
    border: none !important;
}

body.ob-theme-cc .btn.btn-small:not(.btn-flat):not(.btn-floating) {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 0.72rem !important;
    padding: 0 0.9rem !important;
    height: 28px !important;
    line-height: 1.2 !important;
    box-sizing: border-box;
}

/* Materialize chips: rounded square, not stadium */
body.ob-theme-cc .chip {
    border-radius: var(--cc-radius-sq) !important;
    height: auto !important;
    min-height: 28px;
    line-height: 1.2 !important;
    padding: 0.2rem 0.65rem !important;
    display: inline-flex !important;
    align-items: center;
}

body.ob-theme-cc .card-panel.ob-stat-tile {
    border-radius: var(--cc-radius) !important;
    box-shadow: none !important;
    border: 1px solid var(--cc-outline-variant);
    background: var(--cc-surface-lowest);
}

/* Stacked list rows (e.g. room HK history) — rounded squares, not flush Materialize list */
body.ob-theme-cc .collection.ob-collection-stack {
    border: none !important;
    background: transparent !important;
}

body.ob-theme-cc .collection.ob-collection-stack .collection-item {
    border-radius: var(--cc-radius-sq) !important;
    border: 1px solid var(--cc-outline-variant) !important;
    background: var(--cc-surface-lowest) !important;
    margin-bottom: 0.4rem !important;
}

body.ob-theme-cc .collection.ob-collection-stack .collection-item:last-child {
    margin-bottom: 0 !important;
}

body.ob-theme-cc .ob-sla-row.collection-item {
    border: none !important;
    background: var(--cc-surface-low) !important;
    border-radius: var(--cc-radius) !important;
}

.material-symbols-outlined.ob-ms {
    font-size: 24px;
    line-height: 1;
    vertical-align: middle;
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

.material-symbols-outlined.ob-ms--fill {
    font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

.ob-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* ——— Glass top bar (uiux prototypes) ——— */
.ob-topnav--clinical {
    background: rgba(249, 249, 255, 0.82) !important;
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    box-shadow: none !important;
    border-bottom: none;
}

.ob-topnav__shell {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0 1rem 0 0.5rem;
    min-height: 64px;
    max-width: 1400px;
    margin: 0 auto;
}

@media only screen and (min-width: 993px) {
    .ob-topnav__shell {
        padding-left: var(--ob-main-gutter);
        padding-right: var(--ob-main-gutter);
    }
}

.ob-topnav__shell .sidenav-trigger {
    float: none;
    display: inline-flex;
    margin: 0 0.25rem 0 0;
    color: var(--cc-primary) !important;
}

.ob-topnav__left {
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.ob-topnav__brand {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
    padding: 0 0.5rem;
}

.ob-topnav__brand-name {
    font-weight: 800;
    font-size: 1.125rem;
    letter-spacing: -0.02em;
    color: var(--cc-primary);
}

.ob-topnav__brand-sub {
    font-size: 0.65rem;
    color: var(--cc-on-surface-variant);
    margin-top: 0.1rem;
}

.ob-topnav__search {
    flex: 1;
    max-width: 22rem;
    position: relative;
    display: flex;
    align-items: center;
}

.ob-topnav__search-submit {
    position: absolute;
    right: 0.35rem;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0;
    padding: 0.25rem;
    border: none;
    background: transparent;
    border-radius: var(--cc-radius-sq);
    cursor: pointer;
    color: inherit;
}

.ob-topnav__search-submit:focus-visible {
    outline: 2px solid rgba(84, 95, 115, 0.45);
    outline-offset: 2px;
}

.ob-topnav__search-icon {
    position: static;
    color: var(--cc-surface-tint);
    font-size: 18px !important;
    pointer-events: none;
}

a.ob-search-hit {
    display: block;
    color: inherit;
}

a.ob-search-hit:hover .title {
    text-decoration: underline;
}

.ob-search-collection .collection-item {
    padding: 0;
}

.ob-search-collection .collection-item > a {
    padding: 0.75rem 1.25rem;
}

.ob-search-input {
    width: 100%;
    border: none;
    border-radius: var(--cc-radius-sq);
    background: var(--cc-surface-high);
    padding: 0.45rem 2.5rem 0.45rem 1rem;
    font-size: 0.8rem;
    color: var(--cc-on-surface);
    outline: none;
    transition: box-shadow 0.2s;
}

.ob-search-input:focus {
    box-shadow: 0 0 0 2px rgba(84, 95, 115, 0.25);
}

.ob-topnav__right {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0.5rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.ob-topnav__right > li {
    float: none;
}

.ob-property-select {
    border: none;
    border-radius: var(--cc-radius-sq);
    background: var(--cc-surface-high);
    padding: 0.35rem 0.75rem;
    font-size: 0.8rem;
    color: var(--cc-on-surface);
    max-width: 12rem;
}

.ob-property-single {
    font-size: 0.8rem;
    color: var(--cc-on-surface-variant);
    padding: 0 0.5rem;
}

.ob-icon-btn {
    position: relative;
    border: none;
    background: transparent;
    border-radius: 50%;
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: var(--cc-on-surface-variant);
    transition: background 0.15s;
}

.ob-icon-btn:hover {
    background: rgba(9, 20, 38, 0.06);
}

.ob-icon-btn__dot {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--cc-error);
    border: 2px solid var(--cc-surface-lowest);
}

.ob-topnav__user-block {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding-left: 0.5rem;
    margin-left: 0.25rem;
}

.ob-topnav__avatar-stack {
    position: relative;
    display: flex;
    align-items: center;
}

/* Materialize sets nav ul a { color: #fff }; do not inherit onto the tonal avatar. */
.ob-user-menu-trigger.ob-avatar {
    text-decoration: none;
    color: var(--cc-primary, #091426) !important;
    cursor: pointer;
}

.ob-user-menu-trigger.ob-avatar:hover,
.ob-user-menu-trigger.ob-avatar:focus {
    filter: brightness(0.97);
    outline: none;
}

.ob-user-menu-trigger.ob-avatar:focus-visible {
    box-shadow: 0 0 0 2px var(--cc-primary, #091426);
}

.ob-user-dropdown {
    min-width: 12rem;
    border-radius: var(--cc-radius);
    box-shadow: 0 10px 28px rgba(9, 20, 38, 0.14) !important;
    overflow: hidden;
    margin-top: 0.35rem !important;
}

.ob-user-dropdown li > a {
    color: var(--cc-on-surface);
    font-size: 0.95rem;
}

.ob-user-dropdown__logout-wrap {
    padding: 0 !important;
    line-height: normal !important;
    min-height: 0 !important;
}

.ob-user-dropdown__logout-form {
    margin: 0;
    padding: 0;
}

.ob-user-dropdown__logout {
    width: 100%;
    display: block;
    text-align: left;
    padding: 0.85rem 1.15rem;
    border: none;
    background: transparent;
    font-family: inherit;
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--cc-on-surface);
    cursor: pointer;
    line-height: 1.3;
}

.ob-user-dropdown__logout:hover,
.ob-user-dropdown__logout:focus {
    background: rgba(9, 20, 38, 0.06);
    outline: none;
}

.ob-topnav__user-text {
    text-align: right;
    line-height: 1.2;
}

.ob-topnav__user-name {
    display: block;
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--cc-on-surface);
}

.ob-topnav__user-role {
    display: block;
    margin-top: 0.1rem;
}

.ob-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--cc-surface-container);
    color: var(--cc-primary);
    font-weight: 800;
    font-size: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    box-shadow: 0 4px 16px var(--cc-ambient-shadow);
}

.ob-property-mobile {
    padding: 0.5rem 1rem;
    background: var(--cc-surface-lowest);
    border-bottom: 1px solid var(--cc-outline-variant);
}

/* Below fixed nav on small screens; was trapped under .navbar-fixed with zero in-flow height */
@media only screen and (max-width: 600px) {
    body.ob-has-mobile-property .ob-property-mobile {
        position: fixed;
        top: 64px;
        left: 0;
        right: 0;
        z-index: 996;
        padding: 0.45rem 1rem;
    }

    body.ob-has-mobile-property main.ob-main {
        padding-top: calc(4rem + 2.85rem);
    }
}

.ob-property-select--mobile {
    width: 100%;
    max-width: none;
    min-height: 2.5rem;
    font-size: 0.9rem;
}

/* ——— Typography scale ——— */
.ob-label {
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--cc-on-surface-variant);
}

.ob-display {
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: 900;
    letter-spacing: -0.03em;
    color: var(--cc-primary);
    margin: 0.15rem 0 0;
}

.ob-display-sm {
    font-size: clamp(1.5rem, 3vw, 1.85rem);
    font-weight: 900;
    letter-spacing: -0.02em;
    color: var(--cc-primary);
    margin: 0.25rem 0 0;
}

.ob-section-title {
    font-size: 0.8rem;
    font-weight: 900;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--cc-primary);
    margin: 0;
}

/* ——— Page header ——— */
.ob-page-header {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.75rem;
}

.ob-page-header__aside {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.75rem;
    max-width: 100%;
}

/* Materialize .btn uses fixed height/line-height — long labels wrap and clip in the header rail */
.ob-page-header__aside > .btn,
.ob-page-header__aside > a.btn,
.ob-page-header__aside .ob-page-header__aside-row .btn,
.ob-page-header__aside .ob-page-header__aside-row a.btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center;
    height: auto !important;
    min-height: 2.25rem;
    line-height: 1.35 !important;
    white-space: normal !important;
    max-width: 100%;
    box-sizing: border-box;
}

.ob-page-header__aside-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
}

/* Floating back-to-top (main layout) */
.ob-back-to-top {
    position: fixed;
    z-index: 940;
    right: max(1rem, env(safe-area-inset-right, 0px));
    bottom: max(1rem, env(safe-area-inset-bottom, 0px));
    width: 3rem;
    height: 3rem;
    padding: 0;
    margin: 0;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(145deg, var(--cc-primary), var(--cc-primary-container));
    color: var(--cc-on-primary);
    box-shadow: 0 10px 28px -10px rgba(9, 20, 38, 0.5);
    opacity: 0;
    visibility: hidden;
    transform: translateY(0.5rem);
    pointer-events: none;
    transition:
        opacity 0.22s ease,
        visibility 0.22s ease,
        transform 0.22s ease,
        filter 0.15s ease;
}

.ob-back-to-top--visible {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
}

.ob-back-to-top:hover {
    filter: brightness(1.06);
}

.ob-back-to-top:focus {
    outline: none;
}

.ob-back-to-top:focus-visible {
    outline: 2px solid var(--cc-primary);
    outline-offset: 3px;
}

.ob-back-to-top__triangle {
    width: 1.15rem;
    height: 1.15rem;
    display: block;
    margin-top: -0.12rem;
}

@media print {
    .ob-back-to-top {
        display: none !important;
    }
}

.ob-pill-live {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.5rem 1rem;
    border-radius: var(--cc-radius-sq);
    background: var(--cc-tertiary-fixed);
    color: var(--cc-on-tertiary-fixed);
    font-size: 0.8rem;
    font-weight: 700;
}

.ob-pill-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.55rem 1.25rem;
    border-radius: var(--cc-radius-sq);
    font-size: 0.65rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: opacity 0.15s, transform 0.1s;
}

.ob-pill-btn:hover {
    opacity: 0.92;
}

.ob-pill-btn:active {
    transform: scale(0.98);
}

.ob-pill-btn--on-attention {
    background: var(--cc-on-tertiary-container);
    color: var(--cc-on-primary);
}

.ob-pill-btn--compact {
    padding: 0.45rem 1rem;
}

.ob-pill-btn--ghost {
    background: var(--cc-surface-high);
    color: var(--cc-primary);
}

/* Hospitally handoff (top bar): same-tab navigation with exit fade via JS */
a.ob-hospitally-mark {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3.35rem;
    height: 3.35rem;
    border-radius: 50%;
    text-decoration: none;
    flex-shrink: 0;
    margin-inline-end: 0.15rem;
    background: var(--cc-primary);
    color: var(--cc-on-primary);
    box-shadow:
        0 1px 2px rgba(0, 0, 0, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.12);
    transition:
        transform 0.18s ease,
        box-shadow 0.18s ease;
}

a.ob-hospitally-mark:hover {
    transform: scale(1.04);
    box-shadow:
        0 4px 14px rgba(0, 0, 0, 0.14),
        inset 0 1px 0 rgba(255, 255, 255, 0.14);
}

a.ob-hospitally-mark:focus-visible {
    outline: 2px solid var(--cc-primary);
    outline-offset: 3px;
}

.ob-hospitally-mark__text {
    display: block;
    font-size: 0.5rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    line-height: 1.05;
    text-align: center;
    text-transform: uppercase;
    padding: 0 5px;
    max-width: 2.85rem;
    hyphens: none;
}

body.ob-hospitally-exit {
    opacity: 0;
    transition: opacity 0.22s ease-out;
}

@media (prefers-reduced-motion: reduce) {
    body.ob-hospitally-exit {
        transition: none;
    }

    a.ob-hospitally-mark {
        transition: none;
    }

    a.ob-hospitally-mark:hover {
        transform: none;
    }
}

/* ——— Status banner ——— */
.ob-status-banner {
    display: none;
}

/* ——— Department bento ——— */
.ob-bento {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.25rem;
    margin-bottom: 2rem;
}

.ob-bento__card {
    background: var(--cc-surface-low);
    border-radius: var(--cc-radius);
    padding: 1.35rem;
    transition: background 0.2s;
    border: none;
    box-shadow: none;
}

.ob-bento__card:hover {
    background: var(--cc-surface-container);
}

.ob-bento__card--attention {
    box-shadow: inset 4px 0 0 0 #ffb95f;
}

.ob-bento__card--clear {
    box-shadow: inset 4px 0 0 0 var(--cc-secondary);
}

.ob-bento__card--critical {
    box-shadow: inset 4px 0 0 0 var(--cc-error);
}

.ob-bento__top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1rem;
}

.ob-bento__icon-wrap {
    padding: 0.65rem;
    border-radius: 0.65rem;
    background: var(--cc-surface-highest);
    color: var(--cc-primary);
}

.ob-bento__label {
    margin-bottom: 0.35rem;
}

.ob-bento__metric {
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--cc-primary);
    margin: 0;
    letter-spacing: -0.02em;
}

.ob-bento__sub {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--cc-on-surface-variant);
    margin: 0.5rem 0 0;
}

.ob-bento__sub--emphasis {
    color: var(--cc-error);
}

.ob-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.2rem 0.55rem;
    border-radius: var(--cc-radius-sq);
    font-size: 0.6rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.ob-chip--attention {
    background: var(--cc-tertiary-fixed);
    color: var(--cc-on-tertiary-container);
}

.ob-chip--clear {
    background: var(--cc-secondary-container);
    color: var(--cc-on-secondary-container);
}

.ob-chip--critical {
    background: var(--cc-error-container);
    color: var(--cc-on-error-container);
}

.ob-chip--neutral {
    background: var(--cc-surface-highest);
    color: var(--cc-primary);
}

.ob-chip--pri-low {
    background: var(--ob-priority-low) !important;
    color: #fff !important;
}

.ob-chip--pri-medium {
    background: var(--ob-priority-medium) !important;
    color: #1a1a1a !important;
}

.ob-chip--pri-high {
    background: var(--ob-priority-high) !important;
    color: #fff !important;
}

.ob-chip--pri-critical {
    background: var(--ob-priority-critical) !important;
    color: #fff !important;
}

.ob-sla {
    display: inline-block;
    width: 0.6rem;
    height: 0.6rem;
    border-radius: 50%;
    vertical-align: middle;
}

.ob-sla--green,
.ob-sla--na {
    background: var(--ob-success);
}

.ob-sla--yellow {
    background: var(--ob-warning);
}

.ob-sla--red,
.ob-sla--overdue {
    background: var(--ob-danger);
}

/* ——— Dashboard split ——— */
.ob-main__inner--wide {
    max-width: 1280px;
    width: 100%;
}

.ob-dashboard-split {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    margin-bottom: 2rem;
}

@media only screen and (min-width: 993px) {
    .ob-dashboard-split {
        grid-template-columns: 1.15fr 0.85fr;
        align-items: start;
    }
}

/* ——— Attention queue ——— */
.ob-attention__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

.ob-attention__hint {
    color: rgba(69, 71, 76, 0.65);
}

.ob-attention__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.ob-attention__row {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.1rem;
    background: var(--cc-surface-lowest);
    border-radius: var(--cc-radius);
    text-decoration: none;
    color: inherit;
    transition: background 0.2s, transform 0.15s;
    box-shadow: 0 4px 20px -10px rgba(9, 20, 38, 0.12);
}

.ob-attention__row:hover {
    background: var(--cc-surface-high);
    transform: translateY(-1px);
}

.ob-attention__room {
    width: 3rem;
    height: 3rem;
    border-radius: 0.65rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: var(--cc-surface-high);
    flex-shrink: 0;
}

.ob-attention__room-sub {
    font-size: 0.55rem;
    font-weight: 700;
    color: var(--cc-on-surface-variant);
    text-transform: uppercase;
}

.ob-attention__room-num {
    font-size: 1.1rem;
    font-weight: 900;
    color: var(--cc-primary);
    line-height: 1;
}

.ob-attention__room.ob-tone-critical {
    background: var(--cc-error-container);
}

.ob-attention__room.ob-tone-attention {
    background: var(--cc-tertiary-fixed);
}

.ob-attention__room.ob-tone-neutral {
    background: var(--cc-surface-high);
}

.ob-attention__title {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--cc-primary);
    margin: 0 0 0.2rem;
}

.ob-attention__meta {
    font-size: 0.72rem;
    color: var(--cc-on-surface-variant);
    margin: 0;
    font-weight: 500;
}

.ob-attention__tail {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    flex-shrink: 0;
}

.ob-attention__chev {
    color: rgba(9, 20, 38, 0.25);
    font-size: 22px !important;
}

.ob-attention__row:hover .ob-attention__chev {
    color: var(--cc-primary);
}

.ob-attention__footer {
    margin: 1rem 0 0;
    text-align: right;
}

.ob-link-tertiary {
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--cc-surface-tint);
    text-decoration: none;
}

.ob-link-tertiary:hover {
    color: var(--cc-primary);
}

/* ——— Staff panel ——— */
.ob-staff-panel {
    position: relative;
    background: linear-gradient(145deg, var(--cc-primary) 0%, var(--cc-primary-container) 100%);
    color: var(--cc-on-primary);
    border-radius: var(--cc-radius);
    padding: 1.5rem;
    overflow: hidden;
    min-height: 280px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.ob-staff-panel__glow {
    position: absolute;
    right: -2.5rem;
    bottom: -2.5rem;
    width: 10rem;
    height: 10rem;
    background: rgba(255, 255, 255, 0.06);
    border-radius: 50%;
    filter: blur(40px);
    pointer-events: none;
}

.ob-staff-panel__title {
    color: rgba(255, 255, 255, 0.72);
    margin-bottom: 1rem;
    position: relative;
    z-index: 1;
}

.ob-staff-panel__bars {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.ob-staff-panel__bar-label {
    display: flex;
    justify-content: space-between;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin-bottom: 0.35rem;
}

.ob-staff-panel__accent {
    color: var(--cc-secondary-container);
}

.ob-staff-panel__accent-warm {
    color: #ffb95f;
}

.ob-progress {
    height: 6px;
    border-radius: 3px;
    background: rgba(0, 0, 0, 0.25);
    overflow: hidden;
}

.ob-progress__fill {
    height: 100%;
    border-radius: 3px;
}

.ob-progress__fill--efficiency {
    background: var(--cc-secondary-container);
}

.ob-progress__fill--response {
    background: #ffb95f;
}

.ob-staff-panel__shift {
    position: relative;
    z-index: 1;
    margin-top: 1.5rem;
    padding-top: 1rem;
}

.ob-staff-panel__shift-label {
    color: rgba(255, 255, 255, 0.55);
    margin-bottom: 0.35rem;
}

.ob-staff-panel__shift-name {
    font-size: 1.1rem;
    font-weight: 800;
    margin: 0;
}

.ob-staff-panel__shift-role {
    font-size: 0.75rem;
    opacity: 0.85;
    margin: 0.15rem 0 0;
}

/* ——— Quick log / Add issue ——— */
.ob-surface-section {
    background: var(--cc-surface-low);
    border-radius: var(--cc-radius-lg);
    padding: 1.75rem 1.5rem 2rem;
    margin-top: 1rem;
}

.ob-quick-log__eyebrow {
    margin-bottom: 0.15rem;
}

.ob-field-group {
    margin-bottom: 1.75rem;
}

.ob-field-group__head {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 0.65rem;
}

.ob-field-group__hint {
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--cc-surface-tint);
}

.ob-field-group__block-label {
    display: block;
    margin-bottom: 0.65rem;
}

.ob-room-scroller {
    display: flex;
    gap: 0.65rem;
    overflow-x: auto;
    padding-bottom: 0.35rem;
    scrollbar-width: none;
}

.ob-room-scroller::-webkit-scrollbar {
    display: none;
}

.ob-room-chip {
    flex: 0 0 5rem;
    height: 5rem;
    border: none;
    border-radius: var(--cc-radius);
    background: var(--cc-surface-low);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: transform 0.1s, background 0.15s;
}

.ob-room-chip:hover {
    background: var(--cc-surface-high);
}

.ob-room-chip:active {
    transform: scale(0.97);
}

.ob-room-chip--selected {
    background: var(--cc-surface-lowest);
    outline: 2px solid var(--cc-primary);
    outline-offset: 0;
}

.ob-room-chip__num {
    font-size: 1.35rem;
    font-weight: 900;
    color: var(--cc-primary);
    letter-spacing: -0.03em;
}

.ob-room-chip__type {
    font-size: 0.55rem;
    font-weight: 800;
    text-transform: uppercase;
    color: var(--cc-on-surface-variant);
    margin-top: 0.15rem;
}

.ob-room-chip--search {
    background: var(--cc-surface-high);
    outline: 2px dashed var(--cc-outline-variant);
    outline-offset: -2px;
    color: var(--cc-surface-tint);
}

.ob-type-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.75rem;
}

@media only screen and (max-width: 600px) {
    .ob-type-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

.ob-type-tile {
    aspect-ratio: 1;
    border: none;
    border-radius: var(--cc-radius);
    background: var(--cc-surface-low);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    cursor: pointer;
    transition: background 0.15s, transform 0.1s;
    color: var(--cc-primary);
}

.ob-type-tile:hover {
    background: var(--cc-surface-high);
}

.ob-type-tile:active {
    transform: scale(0.97);
}

.ob-type-tile--selected {
    background: var(--cc-primary);
    color: var(--cc-on-primary);
    box-shadow: 0 12px 28px -8px rgba(9, 20, 38, 0.35);
}

.ob-type-tile__label {
    font-size: 0.65rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.ob-seg-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    margin-bottom: 1rem;
}

@media only screen and (min-width: 601px) {
    .ob-seg-grid {
        grid-template-columns: 1fr 1fr;
    }
}

.ob-segmented {
    display: flex;
    background: var(--cc-surface-high);
    padding: 0.35rem;
    border-radius: var(--cc-radius-sq);
    gap: 0.2rem;
}

.ob-segmented__btn {
    flex: 1;
    border: none;
    background: transparent;
    border-radius: calc(var(--cc-radius-sq) * 0.65);
    padding: 0.65rem 0.35rem;
    font-size: 0.65rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--cc-on-surface-variant);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    transition: background 0.15s, color 0.15s;
}

.ob-segmented__btn--on {
    background: var(--cc-surface-lowest);
    color: var(--cc-on-surface);
    box-shadow: 0 2px 6px var(--cc-ambient-shadow);
}

.ob-segmented__btn--danger-dot.ob-segmented__btn--on {
    background: var(--cc-primary);
    color: var(--cc-on-primary);
    box-shadow: 0 8px 20px -6px rgba(9, 20, 38, 0.45);
}

.ob-pulse-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--cc-error);
    animation: ob-pulse 1.4s ease-in-out infinite;
}

@keyframes ob-pulse {
    0%,
    100% {
        opacity: 1;
    }
    50% {
        opacity: 0.45;
    }
}

.ob-input {
    width: 100%;
    border: none;
    border-radius: var(--cc-radius);
    background: var(--cc-surface-high);
    padding: 0.85rem 1rem;
    font-family: inherit;
    font-size: 0.9rem;
    color: var(--cc-on-surface);
    outline: none;
    transition: box-shadow 0.2s;
}

.ob-input:focus {
    box-shadow: 0 0 0 2px rgba(84, 95, 115, 0.35);
}

.ob-input--area {
    min-height: 5rem;
    resize: vertical;
}

.ob-quick-log__actions {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    margin-top: 0.5rem;
}

.ob-btn {
    border-radius: var(--cc-radius-sq) !important;
    font-weight: 800 !important;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-size: 0.8rem !important;
}

.ob-btn--primary {
    background: linear-gradient(145deg, var(--cc-primary), var(--cc-primary-container)) !important;
    color: var(--cc-on-primary) !important;
    box-shadow: 0 12px 28px -10px rgba(9, 20, 38, 0.45) !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 1rem 1.5rem !important;
    width: auto;
    border: none !important;
}

/* Teal / secondary filled CTAs: same geometry and type treatment as ob-btn--primary */
.ob-btn--accent {
    border-radius: var(--cc-radius-sq) !important;
    font-weight: 800 !important;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-size: 0.8rem !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 1rem 1.5rem !important;
    width: auto;
    border: none !important;
}

body.ob-theme-cc .btn.teal.darken-2.ob-btn--accent,
body.ob-theme-cc .btn.teal.ob-btn--accent {
    box-shadow: 0 10px 26px -10px rgba(0, 110, 47, 0.42) !important;
}

.ob-room-hk-status-card__cta {
    margin-top: 0.75rem;
}

@media only screen and (max-width: 600px) {
    .ob-room-hk-status-card__cta {
        width: 100%;
        box-sizing: border-box;
        justify-content: center;
    }
}

.ob-quick-log__actions .ob-btn--primary,
.ob-cc-issue-form .ob-btn--primary {
    width: 100%;
}

.ob-btn--tertiary {
    background: transparent !important;
    color: var(--cc-surface-tint) !important;
    box-shadow: none !important;
    border: none !important;
    font-size: 0.7rem !important;
    letter-spacing: 0.1em !important;
}

/* ——— Login (auth layout) ——— */
.ob-login-card {
    margin-top: 1rem;
    border-radius: var(--cc-radius);
    border: none;
    box-shadow: 0 8px 32px var(--cc-ambient-shadow) !important;
}

.ob-login-card__eyebrow {
    margin-bottom: 0.25rem;
}

.ob-login-card__title {
    margin-bottom: 0.5rem;
}

.ob-login-card__hint {
    font-size: 0.875rem;
    color: var(--cc-on-surface-variant);
    margin-bottom: 1.25rem;
}

.ob-login-form .ob-login-field {
    margin-bottom: 0.5rem;
}

.ob-login-submit {
    margin-top: 1.25rem !important;
    width: 100%;
}

.ob-logout-form {
    margin: 0;
    display: inline-flex;
}

/* ——— Auth / errors ——— */
.ob-auth-body {
    min-height: 100vh;
    display: flex;
    align-items: center;
}

.ob-auth-container {
    width: 100%;
    max-width: 520px;
    margin: auto;
    padding: 1.5rem;
}

.ob-error-card .card-title {
    font-size: 1.35rem;
}

/* ——— Briefing detail (sections) ——— */
/* Materialize: .card .card-title { font-size: 24px } and .card .card-content .card-title { line-height: 32px }
   beat .ob-briefing-block-title (0,1,0). Theme sets color on body.ob-theme-cc .card .card-title but not font-size.
   Scope to .ob-briefing-page so the sibling “Notes” card (outside .ob-briefing-card) is included. */
body.ob-theme-cc .ob-briefing-page .card .card-content .card-title {
    font-size: 1.05rem !important;
    font-weight: 800 !important;
    line-height: 1.35 !important;
    margin-bottom: 0.45rem !important;
    letter-spacing: -0.02em;
    color: var(--cc-primary);
}

.ob-briefing-block-title {
    letter-spacing: -0.02em;
    color: var(--cc-primary);
}

.ob-briefing-exec__body {
    margin: 0.5rem 0 0;
    white-space: pre-wrap;
    line-height: 1.5;
    color: var(--cc-on-surface);
}

.ob-briefing-section {
    margin-top: 1.35rem;
    padding-top: 0.1rem;
}

.ob-briefing-section__title {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    margin: 0 0 0.6rem;
    padding-bottom: 0.45rem;
    border-bottom: 2px solid var(--cc-surface-highest, #e8eaf0);
    letter-spacing: -0.02em;
    color: var(--cc-primary);
}

/* Materialize typography: h3 { font-size: 2.92rem } — needs explicit override */
body.ob-theme-cc .ob-briefing-page h3.ob-briefing-section__title {
    font-size: 1.05rem !important;
    font-weight: 800 !important;
    line-height: 1.3 !important;
    margin: 0 0 0.6rem !important;
}

.ob-briefing-section__icon {
    display: inline-flex;
    flex-shrink: 0;
    color: var(--cc-surface-tint, #546e7a);
    opacity: 0.95;
}

.ob-briefing-section__icon svg {
    display: block;
}

.ob-briefing-section__title-text {
    flex: 1;
    min-width: 0;
}

.ob-briefing-section__body {
    white-space: pre-wrap;
    font-size: 0.95rem;
    line-height: 1.55;
    color: var(--cc-on-surface);
}

/* ——— Print (briefings) ——— */
@media print {
    .navbar-fixed,
    .ob-navbar-fixed,
    .ob-topnav,
    .ob-sidenav,
    .ob-sidenav-trigger,
    .sidenav-overlay,
    .ob-flash,
    .ob-no-print {
        display: none !important;
    }

    main.ob-main,
    footer.ob-footer {
        padding-left: 0 !important;
        margin: 0 !important;
    }

    main.ob-main .ob-main__inner {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    .ob-printable,
    body.ob-app {
        background: #fff !important;
    }

    .ob-printable * {
        color: #000 !important;
        box-shadow: none !important;
    }
}

/* ——— Settings (categories, SLA) ——— */
.ob-color-swatch {
    display: inline-block;
    width: 1.25rem;
    height: 1.25rem;
    border-radius: 4px;
    vertical-align: middle;
    margin-right: 0.35rem;
    border: 1px solid rgba(0, 0, 0, 0.12);
}

.ob-badge--ok {
    background: #e8f5e9;
    color: #2e7d32;
}

.ob-badge--muted {
    background: #eceff1;
    color: #546e7a;
}

.ob-badge--high {
    background: #ffebee;
    color: #c62828;
    font-size: 0.65rem;
    font-weight: 700;
    padding: 0.15rem 0.45rem;
    border-radius: 4px;
}

.ob-badge--warn {
    background: #fff3e0;
    color: #e65100;
    font-size: 0.65rem;
    font-weight: 700;
    padding: 0.15rem 0.45rem;
    border-radius: 4px;
}

.ob-table-actions {
    white-space: nowrap;
}

.ob-table-actions .ob-inline-form {
    display: inline-block;
    vertical-align: middle;
    margin: 0;
}

/* Checklist templates (and similar): header CTA full width on small screens */
@media only screen and (max-width: 992px) {
    .ob-header-cta-btn {
        width: 100%;
        box-sizing: border-box;
        display: inline-flex !important;
        justify-content: center;
    }

    .ob-page-header:has(.ob-header-cta-btn) .ob-page-header__aside {
        width: 100%;
        flex: 1 1 100%;
    }

    .ob-page-header__aside-row {
        width: 100%;
        flex-direction: column;
        align-items: stretch;
        gap: 0.65rem;
    }

    .ob-page-header__aside-row > .ob-page-header__back {
        width: 100%;
        display: inline-flex !important;
        justify-content: center;
        margin-right: 0 !important;
    }

    .ob-checklist-templates-card {
        overflow-x: hidden;
    }

    .ob-checklist-templates-mobile {
        display: flex;
        flex-direction: column;
        gap: 0.85rem;
    }

    .ob-checklist-template-mobile-card {
        border: 1px solid var(--cc-outline-variant);
        border-radius: var(--cc-radius);
        margin: 0;
    }

    body.ob-theme-cc .ob-checklist-template-mobile-card {
        background: var(--cc-surface-container);
    }

    .ob-checklist-template-mobile-card .card-content {
        padding: 1rem 1.1rem !important;
    }

    .ob-checklist-template-mobile-card__name {
        font-weight: 700;
        font-size: 1rem;
        margin: 0 0 0.65rem;
        color: var(--cc-primary);
        line-height: 1.35;
    }

    .ob-checklist-template-mobile-card__meta {
        margin: 0 0 1rem;
        font-size: 0.875rem;
    }

    .ob-checklist-template-mobile-card__meta > div {
        display: flex;
        gap: 0.5rem 0.75rem;
        margin-bottom: 0.4rem;
        align-items: baseline;
    }

    .ob-checklist-template-mobile-card__meta dt {
        font-weight: 600;
        color: var(--cc-on-surface-variant);
        margin: 0;
        min-width: 7.25rem;
        flex-shrink: 0;
        font-size: 0.72rem;
        text-transform: uppercase;
        letter-spacing: 0.04em;
    }

    .ob-checklist-template-mobile-card__meta dd {
        margin: 0;
        color: var(--cc-on-surface);
        flex: 1;
        min-width: 0;
        word-break: break-word;
    }

    .ob-checklist-template-mobile-card__actions {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 0.25rem 0.35rem;
        padding-top: 0.85rem;
        border-top: 1px solid var(--cc-outline-variant);
    }

    .ob-checklist-template-mobile-card__actions .ob-inline-form {
        display: inline-flex;
        margin: 0;
    }

    .ob-checklist-template-mobile-card__actions .btn-flat {
        margin: 0;
    }
}

.ob-input-color {
    width: 3rem;
    height: 2.5rem;
    padding: 0;
    border: none;
    background: transparent;
    cursor: pointer;
}

.ob-color-row {
    margin-bottom: 0.5rem;
}

.ob-sla-collection {
    margin: 1.25rem 0;
    border: none;
}

.ob-sla-row.collection-item {
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    margin-bottom: 0.75rem;
}

.ob-sla-pill {
    display: inline-block;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    font-size: 0.85rem;
    font-weight: 600;
}

.ob-sla-hours-field {
    margin-top: 0;
    margin-bottom: 0;
}

/* ——— Complaints ——— */
.ob-chip--sev-minor {
    background: #2e7d32 !important;
}

.ob-chip--sev-mod {
    background: #1565c0 !important;
}

.ob-chip--sev-major {
    background: #ef6c00 !important;
}

.ob-chip--sev-critical {
    background: #b71c1c !important;
}

.ob-fab {
    bottom: 1.5rem;
    right: 1.5rem;
}

.ob-filter-form .ob-filter-actions {
    margin-top: 0.5rem;
}

@media only screen and (max-width: 992px) {
    .ob-filter-form.row,
    form.row.ob-filter-form,
    form.row.ob-filter-form.ob-form-row--tight {
        display: flex;
        flex-direction: column;
        row-gap: 1rem;
    }

    .ob-filter-form.row > [class*='col'],
    form.row.ob-filter-form > [class*='col'],
    form.row.ob-filter-form.ob-form-row--tight > [class*='col'] {
        width: 100% !important;
        float: none !important;
        left: auto !important;
        right: auto !important;
        margin-left: 0 !important;
        box-sizing: border-box;
    }

    /* Avoid collapsed stacks: Materialize .input-field margins fight flex; row-gap handles spacing. */
    .ob-filter-form .input-field {
        margin-top: 0 !important;
        margin-bottom: 0 !important;
    }

    .ob-filter-form .ob-filter-checkbox {
        padding: 0.15rem 0 0.1rem;
        align-self: flex-start;
    }

    .ob-filter-form .ob-filter-checkbox__label {
        display: inline-flex;
        align-items: center;
        gap: 0.65rem;
        cursor: pointer;
        font-size: 0.95rem;
        font-weight: 500;
        color: var(--cc-on-surface, #111c2d);
        margin: 0;
        user-select: none;
    }

    .ob-filter-form .ob-filter-checkbox__label input[type='checkbox'] {
        flex-shrink: 0;
    }

    .ob-filter-form .ob-filter-actions {
        clear: both;
        order: 99;
        width: 100%;
        margin-top: 0 !important;
        padding-top: 1.15rem !important;
        padding-bottom: 0.35rem !important;
        border-top: 1px solid var(--cc-outline-variant);
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 0.5rem 1rem;
        flex-shrink: 0;
    }

    .ob-card-filters__inner,
    .ob-insp-filters .ob-card-filters__inner {
        padding-bottom: 1.35rem !important;
    }

    .ob-filter-toggle {
        font-weight: 700;
    }

    .ob-list-toolbar {
        margin-top: 0.5rem;
    }
}

/* List pages: collapsible filter bar + sortable table headers */
.ob-list-filter-head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
}

.ob-list-toolbar {
    margin-bottom: 1rem;
}

.ob-list-toolbar .input-field label.active {
    transform: translateY(-100%) scale(0.85);
}

.ob-th-sort {
    white-space: nowrap;
}

.ob-th-sort a {
    color: inherit;
    display: inline-flex;
    align-items: center;
    gap: 0.15rem;
    text-decoration: none;
}

.ob-th-sort a:hover {
    text-decoration: underline;
}

.ob-th-sort--active a {
    font-weight: 600;
}

.ob-th-sort__icon {
    font-size: 1rem !important;
    width: 1rem !important;
    height: 1rem !important;
    opacity: 0.35;
}

.ob-th-sort--active .ob-th-sort__icon {
    opacity: 1;
}

.ob-severity-hint {
    display: block;
    font-size: 0.7rem;
    margin-top: 0.25rem;
}

.ob-severity-chip {
    margin-top: 0.25rem;
}

/*
 * Complaint severity: Materialize draws radio UI on the first span after <input type="radio">.
 * Our first span is the colored chip label — the fake radio circle stacks on the text (bad on mobile).
 * Visually hide the real input and strip pseudo-elements from the chip; selection = chip ring.
 */
.ob-severity-radios .col > p {
    margin: 0;
}

.ob-severity-option {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    cursor: pointer;
    padding: 0.35rem 0.2rem;
    margin: 0;
}

.ob-severity-option input[type="radio"] {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
    opacity: 0;
}

.ob-severity-option input[type="radio"] + .ob-severity-chip::before,
.ob-severity-option input[type="radio"] + .ob-severity-chip::after,
.ob-severity-option input[type="radio"] + span::before,
.ob-severity-option input[type="radio"] + span::after {
    content: none !important;
    display: none !important;
    border: none !important;
    background: transparent !important;
    transform: none !important;
    box-shadow: none !important;
}

.ob-severity-option input[type="radio"]:checked + .ob-severity-chip {
    box-shadow: 0 0 0 2px #fff, 0 0 0 4px var(--cc-primary);
}

.ob-severity-option input[type="radio"]:focus-visible + .ob-severity-chip {
    outline: 2px solid var(--cc-primary);
    outline-offset: 2px;
}

.ob-severity-option .ob-severity-chip {
    margin-top: 0;
}

.ob-preserve-whitespace {
    white-space: pre-wrap;
}

.ob-meta-json {
    font-size: 0.75rem;
    margin: 0.5rem 0 0;
    white-space: pre-wrap;
    word-break: break-word;
    background: #f5f5f5;
    padding: 0.5rem;
    border-radius: 4px;
}

.ob-status-btn-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
    margin-top: 0.75rem;
}

.ob-submit-primary {
    margin-top: 1rem;
}

.ob-chart-wrap--wide {
    max-width: 100%;
}

/* ——— Inspections (conduct + results) ——— */
.ob-conduct-sticky {
    position: sticky;
    top: 64px;
    z-index: 900;
    margin-bottom: 1rem;
}

@media only screen and (max-width: 992px) {
    .ob-conduct-sticky {
        top: 56px;
    }
}

.ob-conduct-toolbar__inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
    justify-content: space-between;
}

.ob-conduct-toolbar__collapsible-ctrl {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.15rem;
}

.ob-conduct-toolbar__ec-btn {
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    text-transform: none !important;
    padding: 0 0.5rem !important;
    min-height: 36px !important;
    color: var(--cc-primary, #091426) !important;
}

@media only screen and (max-width: 600px) {
    .ob-conduct-toolbar__inner {
        flex-direction: column;
        align-items: stretch;
    }

    .ob-conduct-toolbar__collapsible-ctrl {
        justify-content: center;
        order: 3;
        width: 100%;
        padding-top: 0.25rem;
        border-top: 1px solid rgba(9, 20, 38, 0.08);
    }

    .ob-conduct-toolbar__save-later {
        text-align: center;
        order: 2;
    }

    .ob-conduct-toolbar .ob-inline-form {
        order: 1;
        width: 100%;
    }

    .ob-conduct-toolbar .ob-inline-form .btn {
        width: 100%;
    }
}

.ob-conduct-collapsible {
    border: none;
    box-shadow: none;
}

.ob-conduct-cat-head {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    background: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    margin-bottom: 0.5rem;
}

.ob-conduct-cat-body {
    padding: 0.5rem 0 1rem !important;
}

.ob-conduct-item {
    margin-bottom: 1rem;
    border-radius: 10px !important;
    border-left: 4px solid #90caf9;
}

.ob-conduct-item--critical {
    border-left-color: var(--ob-danger);
    background: #fff8f8;
}

.ob-conduct-item__title {
    font-size: 1.1rem !important;
    line-height: 1.35;
}

.ob-conduct-item__title-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
}

.ob-conduct-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
}

.ob-conduct-actions .btn {
    min-height: 44px;
    flex: 1 1 auto;
    max-width: 8rem;
}

.ob-conduct-notes,
.ob-conduct-photo {
    margin-top: 0.5rem;
}

.ob-conduct-thumb {
    max-height: 200px;
    width: auto;
    border-radius: 8px;
    margin-top: 0.5rem;
}

.ob-score-pill {
    display: inline-block;
    font-size: 2.5rem;
    font-weight: 800;
    line-height: 1;
    padding: 0.75rem 1.25rem;
    border-radius: 12px;
}

.ob-score-pill--good {
    background: #e8f5e9;
    color: #1b5e20;
}

.ob-score-pill--mid {
    background: #fff8e1;
    color: #f57f17;
}

.ob-score-pill--bad {
    background: #ffebee;
    color: #b71c1c;
}

.ob-score-pill--muted {
    background: #eceff1;
    color: #546e7a;
}

.ob-insp-facts {
    list-style: none;
    margin: 0;
    padding: 0;
}

.ob-insp-facts li {
    margin-bottom: 0.5rem;
}

.ob-insp-facts__room {
    margin-bottom: 0.85rem !important;
}

.ob-location-kicker {
    display: block;
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--cc-on-surface-variant, #546e7a);
    margin: 0 0 0.2rem;
}

.ob-room-name-prominent {
    display: block;
    font-size: clamp(1.25rem, 3.8vw, 1.65rem);
    font-weight: 800;
    line-height: 1.2;
    letter-spacing: -0.02em;
    color: var(--cc-primary, #1565c0);
}

.ob-room-name-prominent--inline {
    font-size: clamp(1.05rem, 2.4vw, 1.28rem);
}

.ob-room-name-meta {
    display: block;
    margin-top: 0.35rem;
    font-size: 0.88rem;
    line-height: 1.35;
}

.ob-location-room-block {
    margin: 0.65rem 0 0.5rem;
}

.ob-issue-room-col {
    margin-bottom: 0.65rem;
}

.ob-insp-score-list {
    border: none !important;
    margin-top: 0.75rem;
}

.ob-insp-score-row {
    border-radius: 8px !important;
    margin-bottom: 0.35rem;
    border: 1px solid #eee !important;
}

.ob-insp-score-row--fail {
    background: #fff5f5;
    border-color: #ffcdd2 !important;
}

.ob-insp-score-ic {
    vertical-align: top;
    margin-right: 0.5rem;
}

.ob-insp-score-notes {
    margin: 0.35rem 0 0 2rem !important;
    font-size: 0.9rem;
}

.ob-timeline__item {
    margin-bottom: 0.75rem;
}

.ob-timeline__head {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 0.75rem;
}

.ob-timeline__title {
    font-weight: 700;
}

.ob-timeline__sub {
    margin: 0.15rem 0 0;
    font-size: 0.85rem;
}

.ob-timeline__score {
    margin-left: auto;
    font-size: 1.1rem;
}

.ob-score-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    margin-top: 0.35rem;
    flex-shrink: 0;
}

.ob-score-dot--good {
    background: var(--ob-success);
}

.ob-score-dot--mid {
    background: var(--ob-warning);
}

.ob-score-dot--bad {
    background: var(--ob-danger);
}

.ob-score-dot--muted {
    background: #bdbdbd;
}

.ob-checklist-sort .collection-item {
    padding-left: 3.5rem !important;
}

.ob-drag-handle {
    cursor: grab;
}

.cursor-move {
    cursor: grab;
}

/* ——— Operations dashboard (TODO-12) ——— */
.ob-dash-header-meta {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.85rem;
}

.ob-dash-header-meta__icon {
    font-size: 1rem !important;
    width: 1rem;
    height: 1rem;
}

.ob-dash-header-meta__utc {
    opacity: 0.75;
}

.ob-muted {
    color: var(--cc-on-surface-variant, #45474c);
}

.ob-dash-kpi-row {
    margin-bottom: 0.25rem;
}

a.ob-dash-kpi-link {
    display: block;
    color: inherit;
    text-decoration: none;
    border-radius: var(--cc-radius, 1rem);
}

a.ob-dash-kpi-link:focus {
    outline: none;
}

a.ob-dash-kpi-link .ob-dash-kpi {
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

a.ob-dash-kpi-link:hover .ob-dash-kpi,
a.ob-dash-kpi-link:focus-visible .ob-dash-kpi {
    transform: translateY(-2px);
}

a.ob-dash-kpi-link:focus-visible .ob-dash-kpi {
    box-shadow: 0 0 0 2px var(--cc-primary, #1976d2), 0 4px 5px 0 rgba(0, 0, 0, 0.14);
}

.ob-dash-kpi {
    border-radius: var(--cc-radius, 1rem);
    min-height: 5.5rem;
}

.ob-dash-kpi .card-content {
    padding: 0.85rem 1rem !important;
}

.ob-dash-kpi__label {
    display: block;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--cc-on-surface-variant, #45474c);
    font-weight: 600;
}

.ob-dash-kpi__value {
    font-size: 1.65rem;
    font-weight: 800;
    line-height: 1.15;
    margin: 0.2rem 0 0;
    color: var(--cc-on-surface, #111c2d);
}

.ob-dash-kpi__value--danger {
    color: var(--ob-danger);
}

.ob-dash-kpi__sub {
    font-size: 0.75rem;
    margin: 0.25rem 0 0;
}

.ob-dash-kpi__sub--danger {
    color: var(--ob-danger);
    font-weight: 600;
}

.ob-dash-kpi--critical-open {
    box-shadow: inset 0 0 0 2px var(--ob-priority-critical);
}

.ob-dash-kpi--overdue {
    box-shadow: inset 0 0 0 2px rgba(186, 26, 26, 0.35);
}

.ob-dash-kpi--good .ob-dash-kpi__value {
    color: var(--ob-success);
}

.ob-dash-kpi--warn .ob-dash-kpi__value {
    color: var(--ob-warning);
}

.ob-dash-kpi--bad .ob-dash-kpi__value {
    color: var(--ob-danger);
}

.ob-dash-kpi--muted .ob-dash-kpi__value {
    color: var(--cc-on-surface-variant, #45474c);
}

.ob-dash-charts-row {
    margin-bottom: 0.25rem;
}

.ob-dash-chart-card .card-content {
    padding-bottom: 1rem !important;
}

.ob-dash-chart-title {
    font-size: 1.05rem !important;
    line-height: 1.3 !important;
}

.ob-dash-chart-sub {
    font-size: 0.8rem;
    margin: 0 0 0.5rem;
}

.ob-dash-chart-canvas-wrap {
    position: relative;
    height: 200px;
    max-height: 28vh;
}

.ob-dash-chart-canvas-wrap--donut {
    height: 220px;
    max-height: 30vh;
}

.ob-dash-chart-empty {
    margin: 0.5rem 0 0;
    font-size: 0.9rem;
}

.ob-dash-heatmap {
    border-radius: var(--cc-radius, 1rem);
    margin-bottom: 0.75rem;
}

.ob-dash-heatmap-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 0.5rem;
}

.ob-dash-heatmap-table th,
.ob-dash-heatmap-table td {
    padding: 0.45rem 0.35rem;
    text-align: left;
    border-bottom: 1px solid var(--cc-outline-variant, #c5c6cd);
}

.ob-dash-heatmap-count {
    font-weight: 700;
    white-space: nowrap;
    width: 4rem;
}

.ob-dash-heatmap-bar-cell {
    width: 55%;
    vertical-align: middle;
}

.ob-dash-heatmap-bar {
    height: 8px;
    border-radius: 4px;
    background: linear-gradient(90deg, var(--ob-info), var(--ob-primary));
    min-width: 4px;
    max-width: 100%;
}

.ob-dash-room-link {
    font-weight: 600;
}

.ob-dash-actions {
    border-radius: var(--cc-radius, 1rem);
    margin-bottom: 1rem;
}

.ob-dash-actions__row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.5rem;
}

.ob-dash-action-btn {
    text-transform: none !important;
    border-radius: 999px !important;
}

/* ——— Housekeeping: My rooms (staff list) ——— */
.ob-hk-my-rooms {
    display: flex;
    flex-direction: column;
    gap: 0.9rem;
    margin: 0;
    padding: 0;
}

.ob-hk-my-room.card {
    margin: 0;
    border-radius: var(--cc-radius, 1rem);
    border: 1px solid rgba(9, 20, 38, 0.08);
    overflow: hidden;
}

.ob-hk-my-room .card-content {
    padding: 1.15rem 1.2rem 1.2rem !important;
}

.ob-hk-my-room__header {
    margin: 0;
}

.ob-hk-my-room__title-row {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.5rem 0.75rem;
}

.ob-hk-my-room__name {
    margin: 0;
    font-size: clamp(1.85rem, 6vw, 2.35rem);
    font-weight: 800;
    letter-spacing: -0.035em;
    line-height: 1.05;
    color: var(--cc-on-surface, #111c2d);
}

.ob-hk-my-room__assign {
    font-size: 0.62rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 0.35rem 0.55rem;
    border-radius: 999px;
    white-space: nowrap;
}

.ob-hk-my-room__assign--pending {
    background: rgba(9, 20, 38, 0.06);
    color: var(--cc-on-surface-variant, #45474c);
}

.ob-hk-my-room__assign--progress {
    background: rgba(230, 126, 34, 0.15);
    color: #c2410c;
}

.ob-hk-my-room__assign--done {
    background: rgba(46, 125, 50, 0.12);
    color: #2e7d32;
}

.ob-hk-my-room__location {
    margin: 0.35rem 0 0;
    font-size: 0.8rem;
    color: var(--cc-on-surface-variant, #5c5f66);
    line-height: 1.35;
}

.ob-hk-my-room__chip-row {
    margin: 0.65rem 0 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem 0.6rem;
}

.ob-hk-my-room__chip-hint {
    font-size: 0.65rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--cc-on-surface-variant, #757575);
}

.ob-hk-my-room__chip {
    display: inline-flex;
    align-items: center;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 0.28rem 0.65rem;
    border-radius: var(--cc-radius-sq, 10px);
}

.ob-hk-my-room__chip--dirty {
    background: rgba(198, 40, 40, 0.12);
    color: #b71c1c;
}

.ob-hk-my-room__chip--cleaning {
    background: rgba(239, 108, 0, 0.14);
    color: #e65100;
}

.ob-hk-my-room__chip--clean {
    background: rgba(25, 118, 210, 0.12);
    color: #1565c0;
}

.ob-hk-my-room__chip--inspected {
    background: rgba(245, 127, 23, 0.16);
    color: #e65100;
}

.ob-hk-my-room__chip--ready {
    background: rgba(46, 125, 50, 0.14);
    color: #2e7d32;
}

.ob-hk-my-room__chip--muted {
    background: rgba(9, 20, 38, 0.06);
    color: var(--cc-on-surface-variant, #5c5f66);
}

.ob-hk-my-room__actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.55rem;
    margin-top: 1.05rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(9, 20, 38, 0.08);
}

.ob-hk-my-room__form {
    margin: 0;
}

.ob-hk-my-room__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    width: 100%;
    min-height: 2.85rem;
    padding: 0.5rem 0.65rem;
    border: none;
    border-radius: var(--cc-radius-sq, 12px);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    text-decoration: none;
    cursor: pointer;
    box-sizing: border-box;
    transition: transform 0.12s ease, box-shadow 0.12s ease, filter 0.12s ease;
    line-height: 1.2;
    text-align: center;
}

.ob-hk-my-room__btn:focus-visible {
    outline: 2px solid var(--cc-primary, #091426);
    outline-offset: 2px;
}

.ob-hk-my-room__btn:active {
    transform: scale(0.98);
}

.ob-hk-my-room__btn-ic {
    display: flex;
    flex-shrink: 0;
}

.ob-hk-my-room__svg {
    width: 1.35rem;
    height: 1.35rem;
    display: block;
}

.ob-hk-my-room__btn-tx {
    text-align: left;
}

.ob-hk-my-room__btn--start {
    background: linear-gradient(160deg, #ff8a50 0%, #f4511e 100%);
    color: #fff;
    box-shadow: 0 2px 8px rgba(244, 81, 30, 0.35);
}

.ob-hk-my-room__btn--start:hover {
    filter: brightness(1.05);
    box-shadow: 0 4px 14px rgba(244, 81, 30, 0.4);
}

.ob-hk-my-room__btn--clean {
    background: linear-gradient(160deg, #42a5f5 0%, #1e88e5 100%);
    color: #fff;
    box-shadow: 0 2px 8px rgba(30, 136, 229, 0.32);
}

.ob-hk-my-room__btn--clean:hover {
    filter: brightness(1.05);
    box-shadow: 0 4px 14px rgba(30, 136, 229, 0.38);
}

.ob-hk-my-room__btn--detail {
    grid-column: 1 / -1;
    background: var(--cc-surface-high, #f3f5fb);
    color: var(--cc-on-surface, #111c2d);
    border: 1px solid rgba(9, 20, 38, 0.12);
    box-shadow: none;
}

.ob-hk-my-room__btn--detail:hover {
    background: var(--cc-surface-container, #e7eeff);
    border-color: rgba(9, 20, 38, 0.18);
}

.ob-hk-my-room--empty {
    border: 1px dashed rgba(9, 20, 38, 0.14);
    background: var(--cc-surface-lowest, #fff);
}

.ob-hk-my-room__empty-icon {
    color: var(--cc-on-surface-variant, #9e9e9e);
    margin-bottom: 0.5rem;
}

.ob-hk-my-room__empty-title {
    font-size: 1.05rem;
    font-weight: 700;
    margin: 0 0 0.35rem;
    color: var(--cc-on-surface, #111c2d);
}

@media only screen and (min-width: 601px) {
    .ob-hk-my-room__actions {
        grid-template-columns: 1fr 1fr 1.1fr;
    }

    .ob-hk-my-room__btn--detail {
        grid-column: auto;
    }
}

/* Clean / Inspected / Ready: only Room detail */
.ob-hk-my-room__actions--detail-only {
    grid-template-columns: 1fr !important;
}

.ob-hk-my-room__actions--detail-only .ob-hk-my-room__btn--detail {
    grid-column: 1 / -1;
}

/* Cleaning (no Start): Mark clean + Room detail side by side */
.ob-hk-my-room__actions--mark-and-detail {
    grid-template-columns: 1fr 1fr;
}

.ob-hk-my-room__actions--mark-and-detail .ob-hk-my-room__btn--detail {
    grid-column: auto;
}

@media only screen and (min-width: 601px) {
    .ob-hk-my-room__actions--mark-and-detail {
        grid-template-columns: 1fr 1.1fr;
    }
}

/* ——— Housekeeping metrics (dashboard + HK index) ——— */
.ob-hk-stat-grid {
    display: grid;
    gap: 0.65rem;
}

.ob-hk-stat-grid--page {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media only screen and (min-width: 601px) {
    .ob-hk-stat-grid--page {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media only screen and (min-width: 993px) {
    .ob-hk-stat-grid--page {
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }
}

.ob-hk-stat-grid--dash {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    margin: 0.5rem 0 0.85rem;
}

@media only screen and (min-width: 601px) {
    .ob-hk-stat-grid--dash {
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }
}

a.ob-hk-stat-tile {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
    text-decoration: none;
    color: inherit;
    background: var(--cc-surface-lowest, #fff);
    border: 1px solid rgba(9, 20, 38, 0.1);
    border-radius: var(--cc-radius, 1rem);
    padding: 0.75rem 0.65rem 0.85rem;
    min-height: 5.75rem;
    box-shadow: 0 1px 3px rgba(9, 20, 38, 0.06);
    transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

a.ob-hk-stat-tile:hover,
a.ob-hk-stat-tile:focus-visible {
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(9, 20, 38, 0.1);
    border-color: rgba(9, 20, 38, 0.16);
}

a.ob-hk-stat-tile:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px var(--cc-primary), 0 6px 18px rgba(9, 20, 38, 0.1);
}

.ob-hk-stat-tile__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.35rem;
    height: 2.35rem;
    border-radius: 0.65rem;
    margin-bottom: 0.45rem;
    background: var(--cc-surface-container, #e7eeff);
    color: var(--cc-primary, #091426);
}

.ob-hk-stat-tile__icon .material-icons {
    font-size: 1.35rem !important;
}

.ob-hk-stat-tile__label {
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--cc-on-surface-variant, #45474c);
    line-height: 1.2;
}

.ob-hk-stat-tile__value {
    font-size: 1.5rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--cc-on-surface, #111c2d);
    margin-top: auto;
    line-height: 1.1;
}

.ob-hk-stat-tile--watch {
    box-shadow: inset 0 0 0 1px rgba(186, 26, 26, 0.22);
}

.ob-hk-stat-tile--watch .ob-hk-stat-tile__value {
    color: var(--cc-error, #ba1a1a);
}

a.ob-hk-stat-tile--active {
    border-color: var(--cc-primary, #091426);
    box-shadow: 0 0 0 2px rgba(84, 95, 115, 0.28), 0 1px 3px rgba(9, 20, 38, 0.06);
    background: var(--cc-surface-high, #eef2fb);
}

.ob-hk-stat-tile--urgent .ob-hk-stat-tile__icon {
    background: rgba(9, 20, 38, 0.08);
}

.ob-hk-page-metrics {
    margin-bottom: 0.5rem;
}

.ob-hk-dash-card {
    border-radius: var(--cc-radius, 1rem);
    overflow: hidden;
}

.ob-hk-dash-card .card-content {
    padding: 1.1rem 1.15rem 1.15rem !important;
}

.ob-hk-dash-card__head {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    margin-bottom: 0.35rem;
}

.ob-hk-dash-card__icon {
    flex-shrink: 0;
    width: 3rem;
    height: 3rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.85rem;
    background: linear-gradient(145deg, var(--cc-primary), var(--cc-primary-container));
    color: var(--cc-on-primary, #fff);
}

.ob-hk-dash-card__icon .material-icons {
    font-size: 1.65rem !important;
}

.ob-hk-dash-card__head-text {
    min-width: 0;
}

.ob-hk-dash-card__overline {
    display: block;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--cc-on-surface-variant, #45474c);
}

.ob-hk-dash-card__title {
    display: block;
    font-size: 1.35rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    color: var(--cc-on-surface, #111c2d);
    line-height: 1.2;
    margin: 0.15rem 0 0.25rem;
}

.ob-hk-dash-card__lede {
    font-size: 0.8rem;
    line-height: 1.4;
    margin: 0;
}

.ob-hk-dash-assignments {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin: 0 0 1rem;
    padding: 0.75rem 0.85rem;
    border-radius: var(--cc-radius, 1rem);
    text-decoration: none;
    color: inherit;
    background: var(--cc-surface-low, #f0f3ff);
    border: 1px solid rgba(9, 20, 38, 0.08);
    transition: background 0.15s ease, transform 0.15s ease;
}

.ob-hk-dash-assignments:hover,
.ob-hk-dash-assignments:focus-visible {
    background: var(--cc-surface-container, #e7eeff);
}

.ob-hk-dash-assignments:active {
    transform: scale(0.99);
}

.ob-hk-dash-assignments__icon {
    flex-shrink: 0;
    font-size: 1.5rem !important;
    color: var(--cc-primary, #091426);
}

.ob-hk-dash-assignments__text {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
}

.ob-hk-dash-assignments__label {
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--cc-on-surface-variant, #45474c);
}

.ob-hk-dash-assignments__meta {
    font-size: 1rem;
    font-weight: 700;
    color: var(--cc-on-surface, #111c2d);
}

.ob-hk-dash-assignments__chevron {
    flex-shrink: 0;
    color: var(--cc-outline-variant, #c5c6cd);
    font-size: 1.35rem !important;
}

.ob-hk-dash-card__cta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.ob-hk-dash-card__btn {
    text-transform: none !important;
    border-radius: 999px !important;
}

.ob-hk-dash-card__btn-secondary {
    text-transform: none !important;
    color: var(--cc-primary, #091426) !important;
}

.ob-hk-board-filter {
    margin-bottom: 1rem;
    border-radius: var(--cc-radius, 1rem);
    border: 1px solid rgba(9, 20, 38, 0.1);
    background: var(--cc-surface-low, #f0f3ff);
}

.ob-hk-board-filter .card-content {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.65rem 1rem;
    padding: 0.85rem 1rem !important;
}

.ob-hk-board-filter__label {
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--cc-on-surface-variant, #45474c);
}

.ob-hk-board-filter__chip {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.65rem;
    border-radius: 999px;
    font-size: 0.8rem;
    font-weight: 700;
    background: var(--cc-surface-lowest, #fff);
    border: 1px solid rgba(9, 20, 38, 0.12);
    color: var(--cc-on-surface, #111c2d);
}

.ob-hk-board-filter__clear {
    margin-left: auto;
    font-size: 0.8rem !important;
    font-weight: 600;
    color: var(--cc-primary, #091426) !important;
}

/* Housekeeping room status board — room title links to HK room detail */
.ob-hk-board__hint strong {
    color: var(--cc-on-surface, #111c2d);
    font-weight: 700;
}

.ob-hk-board-card__title-link {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 0.35rem;
    color: var(--cc-primary, #091426) !important;
    text-decoration: none;
    font-weight: 600;
    line-height: 1.35;
    border-radius: 0.35rem;
    margin: 0 -0.25rem;
    padding: 0.15rem 0.25rem;
    transition: background-color 0.15s ease, color 0.15s ease;
}

.ob-hk-board-card__title-link:hover,
.ob-hk-board-card__title-link:focus-visible {
    background-color: rgba(9, 20, 38, 0.06);
    text-decoration: none;
}

.ob-hk-board-card__title-link:focus-visible {
    outline: 2px solid var(--cc-primary, #091426);
    outline-offset: 2px;
}

.ob-hk-board-card__title-chevron {
    flex-shrink: 0;
    display: inline-flex;
    opacity: 0.55;
}

.ob-hk-board-card__title-chevron .material-icons {
    font-size: 1.35rem;
}

/* No .input-field here — Materialize absolutely positions labels and overlaps browser-default selects */
.ob-hk-board-card__field {
    margin-top: 0;
    padding-top: 0.25rem;
}

.ob-hk-board-card__label {
    position: static;
    display: block;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--cc-on-surface-variant, #45474c);
    margin: 0 0 0.4rem;
    transform: none;
    pointer-events: auto;
}

.ob-hk-board-card__select {
    width: 100%;
    box-sizing: border-box;
}

.ob-hk-board-card__form-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 0.5rem;
    margin-top: 0.25rem;
}

.ob-hk-board-card__detail-link {
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    text-transform: none !important;
    min-height: auto !important;
    padding: 0 0.5rem !important;
    color: var(--cc-primary, #091426) !important;
}

.ob-hk-board-card__detail-btn {
    text-transform: none !important;
    width: 100%;
}

.ob-room-dir-layout-ctrl {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem;
    margin-top: 1rem;
    padding-top: 0.85rem;
    border-top: 1px solid rgba(9, 20, 38, 0.08);
}

.ob-room-dir-layout-ctrl__btn {
    font-size: 0.8rem !important;
    font-weight: 600 !important;
    text-transform: none !important;
    min-height: 36px !important;
    color: var(--cc-primary, #091426) !important;
}

/* Room directory — nested floors / areas (collapsible <details>) */
.ob-room-dir-branch--collapsible {
    display: block;
    margin-top: 0.85rem;
    padding-left: 0;
    border-left: 2px solid rgba(9, 20, 38, 0.08);
}

.ob-room-dir-branch--depth-1.ob-room-dir-branch--collapsible {
    padding-left: 0.5rem;
    margin-left: 0;
    border-left-color: rgba(9, 20, 38, 0.12);
}

.ob-room-dir-branch--depth-2.ob-room-dir-branch--collapsible {
    padding-left: 0.85rem;
    margin-left: 0.35rem;
    border-left-color: rgba(9, 20, 38, 0.1);
}

.ob-room-dir-branch--depth-3.ob-room-dir-branch--collapsible {
    padding-left: 1.1rem;
    margin-left: 0.5rem;
    border-left-color: rgba(9, 20, 38, 0.08);
}

.ob-room-dir-branch--depth-4.ob-room-dir-branch--collapsible,
.ob-room-dir-branch--depth-5.ob-room-dir-branch--collapsible,
.ob-room-dir-branch--depth-6.ob-room-dir-branch--collapsible,
.ob-room-dir-branch--depth-7.ob-room-dir-branch--collapsible,
.ob-room-dir-branch--depth-8.ob-room-dir-branch--collapsible {
    padding-left: 1.25rem;
    margin-left: 0.65rem;
    border-left-color: rgba(9, 20, 38, 0.06);
}

.ob-room-dir-branch__summary {
    list-style: none;
    cursor: pointer;
    margin: 0 0 0.25rem;
    padding: 0.4rem 0.35rem 0.35rem 0;
    border-radius: 0.35rem;
    transition: background-color 0.15s ease;
}

.ob-room-dir-branch__summary::-webkit-details-marker,
.ob-room-dir-branch__summary::marker {
    display: none;
}

.ob-room-dir-branch__summary:hover {
    background-color: rgba(9, 20, 38, 0.05);
}

.ob-room-dir-branch__summary:focus-visible {
    outline: 2px solid var(--cc-primary, #091426);
    outline-offset: 2px;
}

.ob-room-dir-branch__summary-inner {
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.ob-room-dir-branch__chevron {
    font-size: 1.4rem !important;
    width: 1.4rem;
    height: 1.4rem;
    color: var(--cc-on-surface-variant, #45474c);
    transition: transform 0.2s ease;
    flex-shrink: 0;
}

.ob-room-dir-branch--collapsible:not([open]) .ob-room-dir-branch__chevron {
    transform: rotate(-90deg);
}

.ob-room-dir-branch__title-text {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: var(--cc-on-surface-variant, #45474c);
}

.ob-room-dir-branch--depth-1 .ob-room-dir-branch__title-text {
    font-size: 0.78rem;
    letter-spacing: 0.06em;
    color: var(--cc-on-surface, #1a1c1e);
}

.ob-room-dir-branch--depth-2 .ob-room-dir-branch__title-text {
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    opacity: 0.92;
}

.ob-room-dir-branch--depth-3 .ob-room-dir-branch__title-text,
.ob-room-dir-branch--depth-4 .ob-room-dir-branch__title-text,
.ob-room-dir-branch--depth-5 .ob-room-dir-branch__title-text,
.ob-room-dir-branch--depth-6 .ob-room-dir-branch__title-text,
.ob-room-dir-branch--depth-7 .ob-room-dir-branch__title-text,
.ob-room-dir-branch--depth-8 .ob-room-dir-branch__title-text {
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    opacity: 0.88;
}

.ob-room-dir-branch__panel {
    padding: 0 0 0.15rem;
}

.ob-room-card__location-line {
    line-height: 1.35;
}

.ob-room-card__hk {
    margin-top: 0.5rem;
}

.ob-room-card__hk-chip {
    height: 22px;
    line-height: 22px;
    font-size: 0.7rem;
    padding: 0 8px;
    margin: 0;
}

/* Room detail: stat tiles that jump to a section (scroll) or tab */
.card-panel.ob-stat-tile.ob-stat-tile--tab-link,
.card-panel.ob-stat-tile.ob-stat-tile--scroll {
    cursor: pointer;
    user-select: none;
    transition: box-shadow 0.15s ease, border-color 0.15s ease, transform 0.1s ease;
}

.card-panel.ob-stat-tile.ob-stat-tile--tab-link:hover,
.card-panel.ob-stat-tile.ob-stat-tile--scroll:hover {
    box-shadow: 0 2px 10px var(--cc-ambient-shadow);
}

.card-panel.ob-stat-tile.ob-stat-tile--tab-link:focus,
.card-panel.ob-stat-tile.ob-stat-tile--scroll:focus {
    outline: none;
}

.card-panel.ob-stat-tile.ob-stat-tile--tab-link:focus-visible,
.card-panel.ob-stat-tile.ob-stat-tile--scroll:focus-visible {
    outline: 2px solid var(--cc-primary);
    outline-offset: 2px;
}

.card-panel.ob-stat-tile.ob-stat-tile--tab-link:active,
.card-panel.ob-stat-tile.ob-stat-tile--scroll:active {
    transform: scale(0.99);
}

/* Room detail: segmented tab bar (clearer than default underline-only tabs) */
.ob-room-tabs-card .ob-room-detail-tabs.tabs {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    align-items: stretch;
    padding: 0.5rem;
    margin: 0 0 0.75rem;
    height: auto !important;
    line-height: 1.2 !important;
    overflow: visible !important;
    background: var(--cc-surface-container);
    border-radius: var(--cc-radius-sq);
    border: 1px solid var(--cc-outline-variant);
}

.ob-room-tabs-card .ob-room-detail-tabs.tabs .indicator {
    display: none !important;
}

.ob-room-tabs-card .ob-room-detail-tabs.tabs .tab {
    flex: 1 1 0;
    min-width: 5.25rem;
    max-width: none;
    width: auto !important;
    height: auto !important;
    line-height: 1.25 !important;
    letter-spacing: 0.01em;
    text-transform: none;
    float: none;
}

.ob-room-tabs-card .ob-room-detail-tabs.tabs .tab a {
    display: block;
    padding: 0.55rem 0.45rem !important;
    font-size: 0.78rem !important;
    font-weight: 600;
    color: var(--cc-on-surface-variant) !important;
    border-radius: calc(var(--cc-radius-sq) - 2px);
    transition: background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.ob-room-tabs-card .ob-room-detail-tabs.tabs .tab a:hover,
.ob-room-tabs-card .ob-room-detail-tabs.tabs .tab a:focus {
    background: var(--cc-surface-high);
    color: var(--cc-on-surface) !important;
}

.ob-room-tabs-card .ob-room-detail-tabs.tabs .tab a.active,
.ob-room-tabs-card .ob-room-detail-tabs.tabs .tab a.active:focus {
    color: var(--cc-primary) !important;
    background: var(--cc-surface-lowest);
    box-shadow: 0 1px 0 rgba(9, 20, 38, 0.06), 0 1px 4px var(--cc-ambient-shadow);
}

/* ——— Room detail: dashboard-style layout (hero + split + stacked sections) ——— */
.ob-room-detail-page {
    margin-bottom: 2rem;
}

.ob-room-detail-hero {
    margin-bottom: 1.25rem;
    border-radius: var(--cc-radius);
    overflow: hidden;
    background: linear-gradient(135deg, var(--cc-surface-lowest) 0%, var(--cc-surface-container) 100%);
    border: 1px solid var(--cc-outline-variant);
}

.ob-room-detail-hero .card-content {
    padding: 1.25rem 1.35rem 1.35rem;
}

.ob-room-detail-hero__eyebrow {
    margin: 0;
    font-size: 0.65rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--cc-surface-tint);
}

.ob-room-detail-hero__location {
    margin: 0.2rem 0 0;
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--cc-primary);
    letter-spacing: -0.02em;
}

.ob-room-detail-hero__status-block {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.65rem 1rem;
    margin-top: 1rem;
}

.ob-room-detail-hero__meta {
    font-size: 0.8rem;
}

.ob-room-detail-hero__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.45rem 1rem;
    border-radius: var(--cc-pill);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    box-shadow: 0 4px 14px var(--cc-ambient-shadow);
}

.ob-room-detail-hero__badge::before {
    content: '';
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: currentColor;
    opacity: 0.95;
}

.ob-room-detail-hero__badge--ready {
    background: linear-gradient(145deg, #1b5e20, #2e7d32);
    color: #fff;
}

.ob-room-detail-hero__badge--dirty {
    background: linear-gradient(145deg, #b71c1c, #e53935);
    color: #fff;
}

.ob-room-detail-hero__badge--cleaning {
    background: linear-gradient(145deg, #e65100, #fb8c00);
    color: #fff;
}

.ob-room-detail-hero__badge--clean,
.ob-room-detail-hero__badge--inspected {
    background: linear-gradient(145deg, #0d47a1, #1976d2);
    color: #fff;
}

.ob-room-detail-hero__badge--other {
    background: var(--cc-surface-high);
    color: var(--cc-on-surface);
    box-shadow: none;
    border: 1px solid var(--cc-outline-variant);
}

.ob-room-detail-split {
    margin-bottom: 0;
}

/* Let wide tables scroll inside the card instead of expanding the flex column past the viewport */
.ob-room-detail-split .ob-room-detail-main {
    min-width: 0;
}

.ob-room-panel__title {
    font-size: 1.15rem !important;
    font-weight: 800 !important;
    color: var(--cc-primary) !important;
}

.ob-room-panel__lede {
    font-size: 0.88rem;
    line-height: 1.4;
    max-width: 42rem;
}

.ob-room-panel--issues-critical {
    border-left: 4px solid var(--cc-error);
    box-shadow: 0 2px 12px rgba(186, 26, 26, 0.12);
}

.ob-room-issue-list .collection-item.ob-room-issue-list__item {
    border-radius: var(--cc-radius-sq) !important;
    border: 1px solid var(--cc-outline-variant) !important;
    margin-bottom: 0.5rem !important;
}

.ob-room-issue-list__row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.ob-room-issue-list__title {
    font-weight: 600;
    color: var(--cc-on-surface);
}

.ob-room-rail-card__title {
    font-size: 1rem !important;
    font-weight: 800 !important;
}

.ob-room-rail-facts {
    margin-top: 0.5rem;
}

.ob-room-asset-preview {
    list-style: none;
    padding: 0;
    margin: 0.65rem 0 0;
}

.ob-room-asset-preview__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    padding: 0.45rem 0;
    border-bottom: 1px solid var(--cc-outline-variant);
    font-size: 0.88rem;
}

.ob-room-asset-preview__row:last-child {
    border-bottom: none;
}

.ob-room-asset-preview__name {
    font-weight: 600;
    color: var(--cc-on-surface);
    min-width: 0;
    flex: 1;
}

.ob-room-asset-pill {
    flex-shrink: 0;
    font-size: 0.62rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    padding: 0.2rem 0.45rem;
    border-radius: var(--cc-radius-sq);
    max-width: 48%;
    text-align: right;
    line-height: 1.2;
}

.ob-room-asset-pill--ok {
    background: rgba(0, 110, 47, 0.12);
    color: var(--cc-secondary);
}

.ob-room-asset-pill--warn {
    background: rgba(245, 127, 23, 0.15);
    color: #e65100;
}

.ob-room-asset-pill--bad {
    background: var(--cc-error-container);
    color: var(--cc-on-error-container);
}

.ob-room-asset-pill--neutral {
    background: var(--cc-surface-high);
    color: var(--cc-on-surface-variant);
}

.ob-room-floorplan-map {
    height: 420px;
    width: 100%;
    border-radius: var(--cc-radius-sq);
    overflow: hidden;
    background: #eceff1;
    margin-top: 0.75rem;
}

.ob-room-scroll-flash {
    animation: ob-room-scroll-flash 1.2s ease-out;
}

@keyframes ob-room-scroll-flash {
    0% {
        box-shadow: 0 0 0 0 rgba(9, 20, 38, 0.35);
    }
    35% {
        box-shadow: 0 0 0 6px rgba(9, 20, 38, 0.12);
    }
    100% {
        box-shadow: none;
    }
}

/* Room detail: inline SVG icons */
.ob-room-svg {
    display: inline-block;
    vertical-align: middle;
    flex-shrink: 0;
}

.ob-room-detail-hero__eyebrow {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    margin: 0;
}

.ob-room-svg--hero-eyebrow {
    width: 14px;
    height: 14px;
    color: var(--cc-surface-tint);
}

.ob-room-detail-hero__badge {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.ob-room-svg--hero-badge {
    width: 1rem;
    height: 1rem;
    opacity: 0.95;
}

.ob-room-detail-hero__badge-text {
    line-height: 1.2;
}

.ob-stat-tile__icon {
    display: block;
    margin: 0 auto 0.4rem;
    line-height: 0;
}

.ob-room-svg--stat {
    width: 1.85rem;
    height: 1.85rem;
    color: var(--cc-primary);
    transition: transform 0.2s ease, color 0.2s ease;
}

.card-panel.ob-stat-tile--scroll:hover .ob-room-svg--stat,
.card-panel.ob-stat-tile--tab-link:hover .ob-room-svg--stat {
    transform: scale(1.08);
    color: var(--cc-secondary);
}

.ob-stat-tile__label {
    display: block;
    font-size: 0.8rem;
}

.ob-stat-tile__value {
    display: block;
    margin: 0;
}

.ob-stat-tile__value--date {
    font-size: 1.1rem;
    font-weight: 700;
}

.ob-room-panel__title-inner,
.ob-room-rail-card__title-inner {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.ob-room-svg--panel {
    width: 1.35rem;
    height: 1.35rem;
    color: var(--cc-secondary);
}

.ob-room-panel--issues-critical .ob-room-panel__title-inner .ob-room-svg--panel {
    color: var(--cc-error);
}

.ob-room-svg--rail {
    width: 1.15rem;
    height: 1.15rem;
    color: var(--cc-surface-tint);
}

.ob-room-rail-card__hint {
    margin-top: 0.35rem;
    font-size: 0.85rem;
}

.ob-room-jump-link {
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    font-weight: 600;
}

.ob-room-svg--inline-chev {
    width: 0.72rem;
    height: 0.72rem;
}

.ob-room-issue-list__row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
}

.ob-room-svg--issue-row {
    width: 1rem;
    height: 1rem;
    color: var(--cc-on-surface-variant);
}

.ob-room-text-link {
    display: inline-flex !important;
    align-items: center;
    gap: 0.25rem;
}

.ob-room-svg--link-chev {
    width: 0.82rem;
    height: 0.82rem;
}

.ob-room-asset-preview__name {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    min-width: 0;
}

.ob-room-asset-preview__dot {
    display: flex;
    line-height: 0;
    opacity: 0.55;
}

.ob-room-svg--asset-dot {
    width: 0.78rem;
    height: 0.78rem;
}

.ob-room-hk-status-card__cta.ob-btn {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
}

.ob-room-svg--btn {
    width: 1rem;
    height: 1rem;
}

.ob-room-timeline__avatar.circle {
    display: flex !important;
    align-items: center;
    justify-content: center;
    line-height: 0;
}

.ob-room-timeline__avatar .ob-room-svg--timeline {
    width: 1.15rem;
    height: 1.15rem;
    color: #fff;
}

/* Room inspections list: score is a badge, not the hero-sized pill; keep out of document flow overlap */
.ob-room-timeline.collection .collection-item.avatar .secondary-content {
    position: static !important;
    top: auto !important;
    right: auto !important;
    transform: none;
    float: none !important;
    margin-top: 0.35rem;
}

.ob-room-timeline .ob-score-pill {
    font-size: 0.8125rem;
    font-weight: 800;
    line-height: 1.2;
    padding: 0.35rem 0.65rem;
    border-radius: 10px;
    letter-spacing: 0.02em;
}

body.ob-theme-cc .ob-room-timeline .ob-score-pill {
    border-radius: var(--cc-radius-sq) !important;
}

/* Room detail: complaints / assets as tappable cards (tablet & phone) */
.ob-room-data-cards {
    margin-top: 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.card.ob-room-data-card {
    margin: 0 !important;
    border-radius: var(--cc-radius) !important;
    background: var(--cc-surface-lowest);
    border: 1px solid var(--cc-outline-variant);
    box-shadow: none !important;
}

a.card.ob-room-data-card {
    display: block;
    text-decoration: none;
    color: inherit;
    transition: background-color 0.15s ease, border-color 0.15s ease;
}

a.card.ob-room-data-card:hover {
    background: var(--cc-surface-high);
    border-color: var(--cc-outline);
}

a.card.ob-room-data-card:focus {
    outline: 2px solid var(--cc-primary);
    outline-offset: 2px;
}

.ob-room-data-card .card-content {
    padding: 0.9rem 1rem !important;
}

.ob-room-data-card__kicker {
    margin: 0;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--cc-on-surface-variant);
}

.ob-room-data-card__title {
    margin: 0.2rem 0 0;
    font-size: 1.03rem;
    font-weight: 800;
    color: var(--cc-primary);
    line-height: 1.3;
}

.ob-room-data-card__guest {
    margin: 0.4rem 0 0;
    font-size: 0.9rem;
    color: var(--cc-on-surface);
    line-height: 1.35;
}

.ob-room-data-card__fine {
    margin: 0.35rem 0 0;
    font-size: 0.82rem;
    line-height: 1.35;
}

.ob-room-data-card__tags {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
    margin-top: 0.5rem;
}

.ob-room-data-card__status {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--cc-on-surface-variant);
}

.ob-room-data-card__mono {
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    color: var(--cc-on-surface-variant);
    font-variant-numeric: tabular-nums;
}

.ob-room-data-card__foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-top: 0.55rem;
    padding-top: 0.55rem;
    border-top: 1px solid var(--cc-outline-variant);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--cc-primary);
}

.ob-room-svg--data-card-chev {
    width: 1rem;
    height: 1rem;
    flex-shrink: 0;
    opacity: 0.85;
}
