.alarmflow-ui :is(.af-panel, .af-dev-card, .af-dev-sidebar, .af-dev-inspector, .af-inspector, .af-rule-drawer, .af-media-library-panel, .af-media-inspector, .af-rule-main-panel, .af-rule-wizard-summary, .af-rule-wizard-step-panel, .af-trace-card, .af-timeline-step, .af-trace-summary-card, .af-inspector-card, .af-media-row, .af-device-card, .af-rule-card, .af-runtime-row, .af-event-row, .af-trace-events-row) {
    border: 1px solid var(--af-control-border);
    border-radius: var(--af-card-radius);
    background: var(--af-control-bg);
    box-shadow: var(--af-panel-shadow);
}

.alarmflow-ui :is(.af-panel-header, .af-panel-footer, .af-selected-summary, .af-trace-toolbar, .af-event-filters, .af-advanced-filters, .af-dev-tabs-row, .af-timeline-header, .af-trace-section-head, .af-trace-debug-header, .af-trace-story-header, .af-trace-events-table, .af-inspector-body, .af-inspector-card, .af-rule-wizard-labelbar, .af-rule-wizard-summary, .af-rule-drawer-header, .af-media-page-head, .af-media-inspector-head, .af-media-toolbar, .af-filterbar, .af-filterbar-actions, .af-quickbar) {
    background: var(--af-control-bg);
}

.alarmflow-ui .af-panel-header,
.alarmflow-ui .af-dev-panel-head,
.alarmflow-ui .af-inspector-tabs,
.alarmflow-ui .af-rule-drawer-header,
.alarmflow-ui .af-media-page-head,
.alarmflow-ui .af-media-inspector-head {
    border-bottom: 1px solid var(--af-control-border);
}

.alarmflow-ui .af-panel-footer {
    border-top: 1px solid var(--af-control-border);
}

.alarmflow-ui .af-panel-header,
.alarmflow-ui .af-panel-footer {
    padding: 0.68rem 0.9rem;
}

.alarmflow-ui .af-panel-title {
    color: var(--af-navy);
    font-size: 0.96rem;
    font-weight: 700;
    line-height: 1.2;
}

.alarmflow-ui .af-panel-subtitle {
    margin-top: 0.12rem;
    color: var(--af-muted);
    font-size: 0.74rem;
}

.alarmflow-ui .af-status-strip {
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--af-control-border) 78%, var(--af-navy));
    border-radius: var(--af-card-radius);
    background: color-mix(in srgb, #eef4fb 28%, white);
    box-shadow: var(--af-panel-shadow-soft);
}

.alarmflow-ui .af-status-item {
    border-right: 1px solid var(--af-control-border);
    padding: 0.62rem 0.84rem;
}

.alarmflow-ui .af-status-item:last-child {
    border-right: 0;
}

.alarmflow-ui .af-dashboard-stack,
.alarmflow-ui .af-io-stack,
.alarmflow-ui .af-media-grid,
.alarmflow-ui .af-rule-layout,
.alarmflow-ui .af-dev-layout {
    align-items: start;
}

.alarmflow-ui .af-io-layout,
.alarmflow-ui .af-media-grid,
.alarmflow-ui .af-rule-layout {
    display: grid;
    gap: 1rem;
}

.alarmflow-ui .af-rule-wizard-stepper {
    border-bottom: 1px solid var(--af-control-border);
    padding-bottom: 0.25rem;
}

.alarmflow-ui .af-rule-wizard-main {
    align-items: start;
}

.alarmflow-ui .af-rule-wizard-labelbar,
.alarmflow-ui .af-rule-wizard-summary {
    border: 1px solid var(--af-control-border);
    border-radius: var(--af-card-radius);
    background: var(--af-control-bg);
    box-shadow: var(--af-panel-shadow-soft);
}

.alarmflow-ui .af-rule-wizard-footer {
    border-top: 1px solid var(--af-control-border);
    padding-top: 0.75rem;
}

.alarmflow-ui .af-io-layout {
    grid-template-columns: minmax(0, 1.6fr) minmax(20rem, 25rem);
}

.alarmflow-ui .af-inputs-layout {
    grid-template-columns: minmax(0, 1.6fr) minmax(20rem, 30rem);
}

.alarmflow-ui .af-media-grid {
    grid-template-columns: minmax(0, 1.55fr) minmax(20rem, 26rem);
}

.alarmflow-ui .af-rule-layout {
    grid-template-columns: minmax(0, 1.65fr) minmax(20rem, 25rem);
}

.alarmflow-ui .af-dev-layout {
    display: grid;
    grid-template-columns: minmax(15.5rem, 17.9rem) minmax(38rem, 1fr) minmax(20.5rem, 25rem);
    gap: 1rem;
}

.alarmflow-ui .af-dev-layout > * {
    min-width: 0;
}

.alarmflow-ui .af-dev-sidebar,
.alarmflow-ui .af-dev-inspector {
    position: sticky;
    top: 1rem;
    max-height: calc(100vh - 2rem);
    overflow: auto;
}

.alarmflow-ui .af-inspector {
    display: grid;
    grid-template-rows: auto auto minmax(0, 1fr);
}

.alarmflow-ui .af-inspector-body {
    display: grid;
    gap: 0.72rem;
    background: var(--af-surface-muted);
    padding: 0.72rem;
}

.alarmflow-ui .af-inspector-card {
    padding: 0.72rem;
    box-shadow: var(--af-panel-shadow-soft);
}

.alarmflow-ui .af-inspector-card h3,
.alarmflow-ui .af-rule-drawer-header h3,
.alarmflow-ui .af-media-drawer-head h3 {
    margin: 0;
    color: var(--af-navy);
    font-size: 0.78rem;
    font-weight: 820;
}

.alarmflow-ui .af-inspector-dl {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem 0.85rem;
}

.alarmflow-ui .af-inspector-dl dt {
    color: var(--af-muted);
    font-size: 0.64rem;
    font-weight: 780;
}

.alarmflow-ui .af-inspector-dl dd {
    overflow: hidden;
    color: var(--af-navy);
    font-size: 0.72rem;
    font-weight: 760;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-inspector-live {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.72rem;
    border: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    border-radius: var(--af-control-radius);
    padding: 0.72rem;
}

.alarmflow-ui .sr-only {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
}

.alarmflow-ui.af-mobile-mode {
    background: #fff;
}

.alarmflow-ui.af-mobile-mode .af-app-sidebar,
.alarmflow-ui.af-mobile-mode .af-sidebar-backdrop,
.alarmflow-ui.af-mobile-mode .af-app-topbar {
    display: none;
}

.alarmflow-ui.af-mobile-mode .af-app-shell,
.alarmflow-ui.af-mobile-mode .af-app-shell.is-sidebar-collapsed,
.af-sidebar-collapsed-preload .alarmflow-ui.af-mobile-mode .af-app-shell {
    display: block;
}

.alarmflow-ui.af-mobile-mode .af-app-workspace {
    min-height: 100dvh;
    background: #fff;
}

.alarmflow-ui.af-mobile-mode .af-main-content.af-page-frame {
    max-width: none;
    padding: 0;
}

.alarmflow-ui .af-mobile-preview-shell,
.alarmflow-ui .af-mobile-device-frame {
    min-height: 100dvh;
}

.alarmflow-ui .af-mobile-preview-toolbar {
    display: none;
}

.alarmflow-ui .af-mobile-operator {
    --af-mobile-tabbar-clearance: 4.9rem;
    min-height: 100dvh;
    background: #fff;
    color: var(--af-navy);
}

.alarmflow-ui .af-mobile-appbar {
    position: sticky;
    top: 0;
    z-index: 50;
    display: flex;
    min-height: 3.55rem;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border-bottom: 1px solid var(--af-control-border);
    background: rgba(255, 255, 255, 0.98);
    padding: 0.52rem 1rem;
}

.alarmflow-ui .af-mobile-brand {
    display: inline-flex;
    min-width: 0;
    align-items: center;
    gap: 0.48rem;
    color: var(--af-navy);
    font-size: 1.06rem;
    font-weight: 820;
}

.alarmflow-ui .af-mobile-brand img {
    width: 1.72rem;
    height: 1.72rem;
}

.alarmflow-ui .af-mobile-bell {
    position: relative;
    display: inline-flex;
    width: 2.25rem;
    height: 2.25rem;
    align-items: center;
    justify-content: center;
    border: 0;
    background: transparent;
    color: var(--af-navy);
}

.alarmflow-ui .af-mobile-appbar-actions {
    display: inline-flex;
    align-items: center;
    gap: 0.42rem;
}

.alarmflow-ui .af-mobile-bell-dot {
    position: absolute;
    top: 0.26rem;
    right: 0.32rem;
    width: 0.46rem;
    height: 0.46rem;
    border: 2px solid #fff;
    border-radius: 999px;
    background: var(--af-danger);
}

.alarmflow-ui .af-mobile-install,
.alarmflow-ui .af-pwa-install {
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
}

.alarmflow-ui .af-mobile-install[hidden],
.alarmflow-ui .af-pwa-install[hidden],
.alarmflow-ui .af-pwa-status[hidden],
.alarmflow-ui .af-mobile-pwa-status[hidden],
.alarmflow-ui .af-mobile-camera-preview[hidden],
.alarmflow-ui .af-mobile-live-frame[hidden],
.alarmflow-ui .af-mobile-mini-button[hidden],
.alarmflow-ui .af-mobile-response-sheet[hidden] {
    display: none;
}

.alarmflow-ui .af-mobile-install-button,
.alarmflow-ui .af-mobile-install-dismiss {
    display: inline-flex;
    width: 2.25rem;
    height: 2.25rem;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--af-control-border);
    border-radius: 8px;
    background: #fff;
    color: var(--af-navy);
}

.alarmflow-ui .af-mobile-install-dismiss,
.alarmflow-ui .af-pwa-dismiss {
    color: var(--af-muted);
}

.alarmflow-ui .af-mobile-screen {
    display: grid;
    gap: 0.68rem;
    padding: 0.72rem 1rem calc(var(--af-mobile-tabbar-clearance) + env(safe-area-inset-bottom) + 0.7rem);
    scroll-padding-bottom: calc(var(--af-mobile-tabbar-clearance) + env(safe-area-inset-bottom) + 0.7rem);
}

.alarmflow-ui .af-mobile-screen-cameras {
    gap: 0.58rem;
}

.alarmflow-ui .af-mobile-screen-today {
    gap: 0.62rem;
}

.alarmflow-ui .af-mobile-screen-more {
    gap: 0.58rem;
    padding-bottom: calc(var(--af-mobile-tabbar-clearance) + env(safe-area-inset-bottom) + 3rem);
    scroll-padding-bottom: calc(var(--af-mobile-tabbar-clearance) + env(safe-area-inset-bottom) + 3rem);
}

.alarmflow-ui .af-mobile-screen-schedule-edit {
    padding-bottom: calc(1rem + env(safe-area-inset-bottom));
    scroll-padding-bottom: calc(1rem + env(safe-area-inset-bottom));
}

.alarmflow-ui .af-mobile-screen-schedule-edit ~ .af-mobile-tabbar {
    display: none;
}

.alarmflow-ui .af-mobile-site-menu {
    position: relative;
    width: max-content;
    max-width: 100%;
}

.alarmflow-ui .af-mobile-site-select {
    display: inline-flex;
    min-width: 0;
    width: max-content;
    max-width: 100%;
    align-items: center;
    gap: 0.58rem;
    border: 0;
    background: transparent;
    padding: 0;
    color: var(--af-navy);
    font-size: 0.96rem;
    font-weight: 760;
    text-align: left;
}

.alarmflow-ui .af-mobile-site-select strong {
    overflow: hidden;
    max-width: 14rem;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 1.04rem;
    font-weight: 820;
}

.alarmflow-ui .af-mobile-site-panel {
    position: absolute;
    top: calc(100% + 0.45rem);
    left: 0;
    z-index: 55;
    width: min(21rem, calc(100vw - 2.7rem));
    overflow: hidden;
    border: 1px solid var(--af-control-border);
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 18px 48px rgba(16, 35, 61, 0.16);
}

.alarmflow-ui .af-mobile-site-search {
    display: block;
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    padding: 0.62rem;
}

.alarmflow-ui .af-mobile-site-search input {
    width: 100%;
    border: 1px solid var(--af-control-border);
    border-radius: 8px;
    background: #fff;
    padding: 0.5rem 0.62rem;
    color: var(--af-navy);
    font-size: 0.86rem;
    font-weight: 680;
}

.alarmflow-ui .af-mobile-site-list {
    display: grid;
    max-height: min(21rem, 58vh);
    overflow-y: auto;
}

.alarmflow-ui .af-mobile-site-option {
    display: grid;
    grid-template-columns: 2rem minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.62rem;
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    padding: 0.72rem 0.75rem;
    color: var(--af-navy);
    text-decoration: none;
}

.alarmflow-ui .af-mobile-site-option.is-active {
    background: color-mix(in srgb, var(--af-info) 7%, white);
}

.alarmflow-ui .af-mobile-site-option > span {
    display: inline-flex;
    width: 2rem;
    height: 2rem;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: color-mix(in srgb, var(--af-info) 9%, white);
    color: color-mix(in srgb, var(--af-info) 72%, var(--af-navy));
    font-size: 0.76rem;
    font-weight: 860;
}

.alarmflow-ui .af-mobile-site-option strong {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 0.86rem;
    font-weight: 820;
}

.alarmflow-ui .af-mobile-site-option small {
    grid-column: 2 / 3;
    color: var(--af-muted);
    font-size: 0.74rem;
    font-weight: 650;
}

.alarmflow-ui .af-mobile-site-option > .af-inline-icon {
    grid-column: 3;
    grid-row: 1 / span 2;
    width: 1.12rem;
    height: 1.12rem;
    color: var(--af-success);
}

.alarmflow-ui .af-mobile-site-footer {
    display: flex;
    justify-content: space-between;
    gap: 0.6rem;
    border-top: 1px solid var(--af-control-border);
    padding: 0.62rem 0.75rem;
}

.alarmflow-ui .af-mobile-site-footer a {
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
    color: color-mix(in srgb, var(--af-info) 72%, black);
    font-size: 0.76rem;
    font-weight: 760;
}

.alarmflow-ui .af-mobile-site-footer .af-inline-icon {
    width: 0.95rem;
    height: 0.95rem;
}

.alarmflow-ui .af-mobile-pwa-status,
.alarmflow-ui .af-pwa-status {
    border: 1px solid color-mix(in srgb, var(--af-warning) 36%, white);
    border-radius: 8px;
    background: color-mix(in srgb, var(--af-warning) 8%, white);
    color: color-mix(in srgb, var(--af-warning) 54%, var(--af-navy));
    font-size: 0.78rem;
    font-weight: 800;
    line-height: 1.25;
}

.alarmflow-ui .af-mobile-pwa-status {
    padding: 0.58rem 0.72rem;
}

.alarmflow-ui .af-pwa-status {
    display: inline-flex;
    min-height: 2.35rem;
    align-items: center;
    padding: 0 0.7rem;
}

.alarmflow-ui .af-mobile-pwa-status.is-offline,
.alarmflow-ui .af-pwa-status.is-offline {
    border-color: color-mix(in srgb, var(--af-danger) 34%, white);
    background: color-mix(in srgb, var(--af-danger) 7%, white);
    color: color-mix(in srgb, var(--af-danger) 58%, var(--af-navy));
}

.alarmflow-ui .af-mobile-status-card {
    display: grid;
    min-height: 5.55rem;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.75rem;
    border: 1px solid color-mix(in srgb, var(--af-success) 36%, white);
    border-radius: 8px;
    background: color-mix(in srgb, var(--af-success) 8%, white);
    padding: 0.84rem 0.86rem;
}

.alarmflow-ui .af-mobile-status-card.is-fault {
    border-color: color-mix(in srgb, var(--af-danger) 38%, white);
    background: color-mix(in srgb, var(--af-danger) 7%, white);
}

.alarmflow-ui .af-mobile-status-card.is-warning {
    border-color: color-mix(in srgb, var(--af-warning) 42%, white);
    background: color-mix(in srgb, var(--af-warning) 8%, white);
}

.alarmflow-ui .af-mobile-status-card.is-inactive {
    border-color: var(--af-control-border);
    background: color-mix(in srgb, var(--af-surface) 62%, white);
}

.alarmflow-ui .af-mobile-status-icon {
    display: inline-flex;
    width: 3.15rem;
    height: 3.15rem;
    align-items: center;
    justify-content: center;
    color: var(--af-success);
}

.alarmflow-ui .af-mobile-status-icon .af-inline-icon {
    width: 3.15rem;
    height: 3.15rem;
}

.alarmflow-ui .af-mobile-status-card.is-fault .af-mobile-status-icon,
.alarmflow-ui .af-mobile-status-card.is-fault h1,
.alarmflow-ui .af-mobile-event.is-fault .af-mobile-event-icon {
    color: var(--af-danger);
}

.alarmflow-ui .af-mobile-status-card.is-warning .af-mobile-status-icon,
.alarmflow-ui .af-mobile-status-card.is-warning h1,
.alarmflow-ui .af-mobile-event.is-warning .af-mobile-event-icon {
    color: var(--af-warning);
}

.alarmflow-ui .af-mobile-status-card.is-inactive .af-mobile-status-icon,
.alarmflow-ui .af-mobile-status-card.is-inactive h1 {
    color: var(--af-muted);
}

.alarmflow-ui .af-mobile-status-card h1 {
    color: color-mix(in srgb, var(--af-success) 72%, black);
    font-size: 1.18rem;
    font-weight: 820;
    line-height: 1.05;
}

.alarmflow-ui .af-mobile-status-card p {
    margin-top: 0.2rem;
    color: var(--af-navy);
    font-size: 0.84rem;
    font-weight: 680;
}

.alarmflow-ui .af-mobile-status-card div > span {
    display: block;
    margin-top: 0.18rem;
    color: var(--af-muted);
    font-size: 0.8rem;
    font-weight: 620;
}

.alarmflow-ui .af-mobile-status-dot {
    width: 0.72rem;
    height: 0.72rem;
    border-radius: 999px;
    background: var(--af-success);
}

.alarmflow-ui .af-mobile-status-card.is-fault .af-mobile-status-dot {
    background: var(--af-danger);
}

.alarmflow-ui .af-mobile-status-card.is-warning .af-mobile-status-dot {
    background: var(--af-warning);
}

.alarmflow-ui .af-mobile-status-card.is-inactive .af-mobile-status-dot {
    background: var(--af-muted);
}

.alarmflow-ui .af-mobile-quick-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.5rem;
}

.alarmflow-ui .af-mobile-action-tile {
    display: grid;
    width: 100%;
    min-height: 3.35rem;
    align-content: center;
    justify-items: center;
    gap: 0.2rem;
    border: 1px solid var(--af-control-border);
    border-radius: 8px;
    background: #fff;
    padding: 0.48rem 0.42rem;
    color: var(--af-navy);
    text-align: center;
    box-shadow: 0 8px 22px rgba(16, 35, 61, 0.045);
}

.alarmflow-ui .af-mobile-action-tile:hover {
    border-color: color-mix(in srgb, var(--af-info) 35%, white);
    background: color-mix(in srgb, var(--af-info) 4%, white);
}

.alarmflow-ui .af-mobile-action-tile:disabled {
    cursor: not-allowed;
    opacity: 0.5;
}

.alarmflow-ui .is-pwa-disabled,
.alarmflow-ui.af-pwa-offline button[type="submit"],
.alarmflow-ui.af-pwa-offline input[type="submit"] {
    cursor: not-allowed;
    opacity: 0.48;
}

.alarmflow-ui .af-mobile-action-tile > span {
    display: inline-flex;
    width: 1.65rem;
    height: 1.65rem;
    align-items: center;
    justify-content: center;
}

.alarmflow-ui .af-mobile-action-tile .af-inline-icon {
    width: 1.52rem;
    height: 1.52rem;
}

.alarmflow-ui .af-mobile-action-tile strong {
    max-width: 100%;
    overflow-wrap: anywhere;
    font-size: 0.78rem;
    font-weight: 820;
    line-height: 1.15;
}

.alarmflow-ui .af-mobile-action-tile.is-blue > span {
    color: color-mix(in srgb, var(--af-info) 76%, black);
}

.alarmflow-ui .af-mobile-action-tile.is-orange > span {
    color: #ea580c;
}

.alarmflow-ui .af-mobile-action-tile.is-teal > span,
.alarmflow-ui .af-mobile-event.is-info .af-mobile-event-icon {
    color: #0f9ca5;
}

.alarmflow-ui .af-mobile-card {
    overflow: hidden;
    border: 1px solid var(--af-control-border);
    border-radius: 8px;
    background: #fff;
}

.alarmflow-ui .af-mobile-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    border-bottom: 1px solid var(--af-control-border);
    padding: 0.66rem 0.78rem;
}

.alarmflow-ui .af-mobile-card-head h2 {
    min-width: 0;
    color: var(--af-navy);
    font-size: 0.96rem;
    font-weight: 820;
}

.alarmflow-ui .af-mobile-card-head-actions {
    display: inline-flex;
    flex: 0 0 auto;
    min-width: 0;
    align-items: center;
    justify-content: flex-end;
    gap: 0.48rem;
}

.alarmflow-ui .af-mobile-live-head {
    align-items: center;
}

.alarmflow-ui .af-mobile-view-toggle {
    display: inline-grid;
    grid-template-columns: repeat(2, minmax(0, auto));
    overflow: hidden;
    border: 1px solid var(--af-control-border);
    border-radius: 8px;
    background: #fff;
}

.alarmflow-ui .af-mobile-view-toggle button {
    min-height: 2.18rem;
    border: 0;
    border-right: 1px solid var(--af-control-border);
    background: transparent;
    padding: 0 0.55rem;
    color: var(--af-muted);
    font-size: 0.72rem;
    font-weight: 820;
}

.alarmflow-ui .af-mobile-card-head a.af-mobile-icon-link {
    width: 2.18rem;
    height: 2.18rem;
    flex: 0 0 auto;
    justify-content: center;
    gap: 0;
    border: 1px solid transparent;
    border-radius: 8px;
}

.alarmflow-ui .af-mobile-view-toggle button:last-child {
    border-right: 0;
}

.alarmflow-ui .af-mobile-view-toggle button[aria-pressed="true"] {
    background: color-mix(in srgb, var(--af-info) 8%, white);
    color: color-mix(in srgb, var(--af-info) 72%, black);
}

.alarmflow-ui .af-mobile-card-head a {
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
    color: color-mix(in srgb, var(--af-info) 72%, black);
    font-size: 0.82rem;
    font-weight: 720;
}

.alarmflow-ui .af-mobile-card-head > span {
    color: var(--af-muted);
    font-size: 0.78rem;
    font-weight: 760;
}

.alarmflow-ui .af-mobile-card-head .af-inline-icon {
    width: 1rem;
    height: 1rem;
}

.alarmflow-ui .af-mobile-filterbar {
    display: flex;
    gap: 0.42rem;
    overflow-x: auto;
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    padding: 0.62rem 0.95rem;
}

.alarmflow-ui .af-mobile-filterbar a {
    flex: 0 0 auto;
    border: 1px solid var(--af-control-border);
    border-radius: 999px;
    background: #fff;
    padding: 0.4rem 0.62rem;
    color: var(--af-muted);
    font-size: 0.74rem;
    font-weight: 800;
}

.alarmflow-ui .af-mobile-filterbar a.is-active {
    border-color: color-mix(in srgb, var(--af-info) 36%, var(--af-control-border));
    background: color-mix(in srgb, var(--af-info) 7%, white);
    color: color-mix(in srgb, var(--af-info) 66%, var(--af-navy));
}

.alarmflow-ui .af-mobile-refresh-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
    border-top: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    padding: 0.58rem 0.95rem;
    color: var(--af-muted);
    font-size: 0.72rem;
    font-weight: 760;
}

.alarmflow-ui .af-mobile-refresh-meta time {
    color: var(--af-navy);
    font-weight: 820;
}

.alarmflow-ui .af-mobile-event-list {
    display: grid;
}

.alarmflow-ui .af-mobile-event {
    display: grid;
    min-width: 0;
    grid-template-columns: 4.65rem minmax(0, 1fr) auto;
    align-items: start;
    column-gap: 0.78rem;
    row-gap: 0.36rem;
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    padding: 0.72rem 0.95rem;
    color: inherit;
    text-decoration: none;
}

.alarmflow-ui .af-mobile-event:last-child {
    border-bottom: 0;
}

.alarmflow-ui .af-mobile-event-icon {
    display: inline-flex;
    width: 2.2rem;
    height: 2.2rem;
    justify-self: center;
    align-items: center;
    justify-content: center;
    color: var(--af-info);
}

.alarmflow-ui .af-mobile-event-icon .af-inline-icon {
    width: 1.72rem;
    height: 1.72rem;
}

.alarmflow-ui .af-mobile-event p {
    overflow: hidden;
    color: var(--af-navy);
    font-size: 0.88rem;
    font-weight: 820;
    line-height: 1.18;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-mobile-event-title-link {
    color: inherit;
    text-decoration: none;
}

.alarmflow-ui .af-mobile-event:hover p,
.alarmflow-ui .af-mobile-event:focus-visible p,
.alarmflow-ui .af-mobile-event-title-link:hover,
.alarmflow-ui .af-mobile-event-title-link:focus-visible {
    color: color-mix(in srgb, var(--af-info) 72%, black);
}

.alarmflow-ui .af-mobile-event span,
.alarmflow-ui .af-mobile-event time,
.alarmflow-ui .af-mobile-event small,
.alarmflow-ui .af-mobile-empty,
.alarmflow-ui .af-mobile-io-summary {
    color: var(--af-muted);
    font-size: 0.8rem;
    font-weight: 620;
}

.alarmflow-ui .af-mobile-event small {
    grid-column: 2 / -1;
    overflow-wrap: anywhere;
}

.alarmflow-ui .af-mobile-empty {
    padding: 0.95rem;
}

.alarmflow-ui .af-mobile-health-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    align-items: center;
    padding: 1.05rem 0.95rem 0.9rem;
}

.alarmflow-ui .af-mobile-health-stat {
    display: grid;
    grid-template-columns: auto auto;
    justify-content: center;
    align-items: center;
    gap: 0.2rem 0.7rem;
    min-width: 0;
}

.alarmflow-ui .af-mobile-health-stat + .af-mobile-health-stat {
    border-left: 1px solid var(--af-control-border);
}

.alarmflow-ui .af-mobile-health-stat span {
    grid-row: span 2;
    display: inline-flex;
    width: 3rem;
    height: 3rem;
    align-items: center;
    justify-content: center;
}

.alarmflow-ui .af-mobile-health-stat .af-inline-icon {
    width: 2.7rem;
    height: 2.7rem;
}

.alarmflow-ui .af-mobile-health-stat.is-online span {
    color: var(--af-success);
}

.alarmflow-ui .af-mobile-health-stat.is-offline span {
    color: var(--af-danger);
}

.alarmflow-ui .af-mobile-health-stat strong {
    color: var(--af-navy);
    font-size: 1.3rem;
    font-weight: 820;
    line-height: 1;
}

.alarmflow-ui .af-mobile-health-stat p {
    color: var(--af-muted);
    font-size: 0.8rem;
    font-weight: 620;
}

.alarmflow-ui .af-mobile-io-summary {
    border-top: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    padding: 0.72rem 0.95rem;
}

.alarmflow-ui .af-mobile-utility-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.42rem;
}

.alarmflow-ui .af-mobile-utility-links a {
    border: 1px solid var(--af-control-border);
    border-radius: 999px;
    background: #fff;
    padding: 0.36rem 0.58rem;
    color: var(--af-muted);
    font-size: 0.72rem;
    font-weight: 720;
}

.alarmflow-ui .af-mobile-control-list,
.alarmflow-ui .af-mobile-node-list,
.alarmflow-ui .af-mobile-settings-list,
.alarmflow-ui .af-mobile-rule-list,
.alarmflow-ui .af-mobile-media-list,
.alarmflow-ui .af-mobile-member-list {
    display: grid;
}

.alarmflow-ui .af-mobile-control-row,
.alarmflow-ui .af-mobile-node-row,
.alarmflow-ui .af-mobile-settings-list a,
.alarmflow-ui .af-mobile-settings-list button {
    display: grid;
    min-width: 0;
    align-items: center;
    gap: 0.72rem;
    border: 0;
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    background: #fff;
    color: var(--af-navy);
    padding: 0.82rem 0.95rem;
    text-align: left;
}

.alarmflow-ui .af-mobile-control-row,
.alarmflow-ui .af-mobile-node-row {
    grid-template-columns: 2.2rem minmax(0, 1fr) auto;
    text-decoration: none;
}

.alarmflow-ui .af-mobile-settings-list a,
.alarmflow-ui .af-mobile-settings-list button {
    width: 100%;
    grid-template-columns: 2.2rem minmax(0, 1fr);
    text-decoration: none;
}

.alarmflow-ui .af-mobile-control-row:last-child,
.alarmflow-ui .af-mobile-node-row:last-child,
.alarmflow-ui .af-mobile-settings-list a:last-child,
.alarmflow-ui .af-mobile-settings-list form:last-child button {
    border-bottom: 0;
}

.alarmflow-ui .af-mobile-settings-list form {
    margin: 0;
}

.alarmflow-ui .af-mobile-settings-form {
    display: grid;
    gap: 0.7rem;
    border-top: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    padding: 0.82rem 0.95rem;
}

.alarmflow-ui .af-mobile-settings-form:first-child,
.alarmflow-ui .af-mobile-card-head + .af-mobile-settings-form {
    border-top: 0;
}

.alarmflow-ui .af-mobile-settings-form-bordered {
    border-top: 1px solid var(--af-control-border);
}

.alarmflow-ui .af-mobile-settings-form label {
    display: grid;
    gap: 0.34rem;
}

.alarmflow-ui .af-mobile-settings-form label > span,
.alarmflow-ui .af-mobile-settings-form p {
    color: var(--af-muted);
    font-size: 0.78rem;
    font-weight: 700;
}

.alarmflow-ui .af-mobile-settings-form input,
.alarmflow-ui .af-mobile-settings-form select {
    min-height: 2.55rem;
    width: 100%;
    min-width: 0;
    border: 1px solid var(--af-control-border);
    border-radius: 8px;
    background: #fff;
    color: var(--af-navy);
    padding: 0 0.68rem;
    font-size: 0.9rem;
    font-weight: 760;
}

.alarmflow-ui .af-mobile-claim-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.58rem;
    align-items: end;
    padding: 0.72rem 0.78rem 0.78rem;
}

.alarmflow-ui .af-mobile-claim-form p {
    grid-column: 1 / -1;
    margin: 0;
    color: var(--af-muted);
    font-size: 0.8rem;
    font-weight: 680;
    line-height: 1.32;
}

.alarmflow-ui .af-mobile-claim-form label {
    display: grid;
    gap: 0.26rem;
    min-width: 0;
}

.alarmflow-ui .af-mobile-claim-form label > span {
    color: var(--af-muted);
    font-size: 0.72rem;
    font-weight: 800;
}

.alarmflow-ui .af-mobile-claim-form input {
    width: 100%;
    min-width: 0;
    min-height: 2.45rem;
    border: 1px solid var(--af-control-border);
    border-radius: 8px;
    background: #fff;
    color: var(--af-navy);
    padding: 0 0.68rem;
    font-size: 0.86rem;
    font-weight: 760;
}

.alarmflow-ui .af-mobile-primary-button {
    display: inline-flex;
    min-height: 2.45rem;
    align-items: center;
    justify-content: center;
    border: 1px solid color-mix(in srgb, var(--af-info) 40%, var(--af-control-border));
    border-radius: 8px;
    background: color-mix(in srgb, var(--af-info) 9%, white);
    color: color-mix(in srgb, var(--af-info) 68%, var(--af-navy));
    padding: 0 0.78rem;
    font-size: 0.78rem;
    font-weight: 850;
    white-space: nowrap;
}

@media (max-width: 360px) {
    .alarmflow-ui .af-mobile-claim-form {
        grid-template-columns: 1fr;
    }

    .alarmflow-ui .af-mobile-primary-button {
        width: 100%;
    }
}

.alarmflow-ui .af-mobile-share-list {
    display: grid;
}

.alarmflow-ui .af-mobile-share-row {
    display: grid;
    grid-template-columns: 5.2rem minmax(0, 1fr);
    gap: 0.75rem;
    border-top: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    padding: 0.85rem 0.95rem;
}

.alarmflow-ui .af-mobile-share-row img {
    width: 5.2rem;
    height: 5.2rem;
    border: 1px solid var(--af-control-border);
    border-radius: 8px;
    background: #fff;
    padding: 0.2rem;
}

.alarmflow-ui .af-mobile-share-qr-button {
    width: 5.2rem;
    height: 5.2rem;
    border: 0;
    border-radius: 8px;
    background: transparent;
    padding: 0;
}

.alarmflow-ui .af-mobile-share-qr-button:focus-visible {
    outline: 3px solid color-mix(in srgb, var(--af-info) 42%, white);
    outline-offset: 2px;
}

.alarmflow-ui .af-mobile-share-qr-button img {
    display: block;
}

.alarmflow-ui .af-mobile-share-row p {
    overflow: hidden;
    color: var(--af-navy);
    font-size: 0.9rem;
    font-weight: 820;
    line-height: 1.18;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-mobile-share-row small {
    color: var(--af-muted);
    font-size: 0.78rem;
    font-weight: 620;
}

.alarmflow-ui .af-mobile-schedule-card {
    overflow: hidden;
}

.alarmflow-ui .af-mobile-schedule-status {
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--af-success) 10%, white);
    color: color-mix(in srgb, var(--af-success) 68%, black);
    padding: 0.22rem 0.52rem;
    font-size: 0.68rem;
    font-weight: 850;
}

.alarmflow-ui .af-mobile-schedule-status span {
    width: 0.42rem;
    height: 0.42rem;
    border-radius: 999px;
    background: currentColor;
}

.alarmflow-ui .af-mobile-schedule-status.is-inactive {
    background: color-mix(in srgb, var(--af-muted) 11%, white);
    color: var(--af-muted);
}

.alarmflow-ui .af-mobile-schedule-mode {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.2rem;
    margin: 0 0.95rem 0.75rem;
    border: 1px solid var(--af-control-border);
    border-radius: 8px;
    background: color-mix(in srgb, var(--af-surface) 74%, white);
    padding: 0.2rem;
}

.alarmflow-ui .af-mobile-schedule-mode > span,
.alarmflow-ui .af-mobile-schedule-mode label {
    min-width: 0;
    border-radius: 6px;
    color: var(--af-muted);
    padding: 0.45rem 0.35rem;
    font-size: 0.78rem;
    font-weight: 800;
    text-align: center;
}

.alarmflow-ui .af-mobile-schedule-mode label {
    cursor: pointer;
}

.alarmflow-ui .af-mobile-schedule-mode label span {
    padding: 0;
}

.alarmflow-ui .af-mobile-schedule-mode > span.is-active,
.alarmflow-ui .af-mobile-schedule-mode label.is-active {
    background: #fff;
    color: var(--af-navy);
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.1);
}

.alarmflow-ui .af-mobile-schedule-editor {
    display: grid;
    gap: 0.7rem;
    margin: 0 0.95rem 0.85rem;
}

.alarmflow-ui .af-mobile-schedule-period {
    display: grid;
    gap: 0.62rem;
    border: 1px solid color-mix(in srgb, var(--af-control-border) 75%, white);
    border-radius: 8px;
    background: color-mix(in srgb, var(--af-surface) 48%, white);
    padding: 0.72rem;
}

.alarmflow-ui .af-mobile-schedule-period-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
}

.alarmflow-ui .af-mobile-schedule-period-head strong {
    min-width: 0;
    color: var(--af-navy);
    font-size: 0.86rem;
    font-weight: 860;
}

.alarmflow-ui .af-mobile-schedule-period-head .af-mobile-mini-button {
    min-height: 2.05rem;
}

.alarmflow-ui .af-mobile-schedule-days {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 0.25rem;
}

.alarmflow-ui .af-mobile-schedule-days label {
    min-width: 0;
    border: 1px solid var(--af-control-border);
    border-radius: 7px;
    background: #fff;
    color: var(--af-muted);
    padding: 0.42rem 0.12rem;
    font-size: 0.68rem;
    font-weight: 850;
    text-align: center;
}

.alarmflow-ui .af-mobile-schedule-days label.is-selected {
    border-color: color-mix(in srgb, var(--af-info) 45%, var(--af-control-border));
    background: color-mix(in srgb, var(--af-info) 10%, white);
    color: color-mix(in srgb, var(--af-info) 62%, var(--af-navy));
}

.alarmflow-ui .af-mobile-schedule-all-day {
    display: inline-flex;
    width: max-content;
    align-items: center;
    gap: 0.4rem;
    color: var(--af-navy);
    font-size: 0.8rem;
    font-weight: 820;
}

.alarmflow-ui .af-mobile-schedule-all-day input {
    width: 1rem;
    height: 1rem;
    accent-color: var(--af-info);
}

.alarmflow-ui .af-mobile-schedule-time-inputs {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.58rem;
}

.alarmflow-ui .af-mobile-schedule-time-inputs label {
    display: grid;
    gap: 0.25rem;
}

.alarmflow-ui .af-mobile-schedule-time-inputs span {
    color: var(--af-muted);
    font-size: 0.7rem;
    font-weight: 780;
}

.alarmflow-ui .af-mobile-schedule-time-inputs input {
    min-height: 2.35rem;
    width: 100%;
    min-width: 0;
    border: 1px solid var(--af-control-border);
    border-radius: 8px;
    background: #fff;
    color: var(--af-navy);
    padding: 0 0.45rem;
    font-size: 0.82rem;
    font-weight: 760;
}

.alarmflow-ui .af-mobile-schedule-period-preview {
    color: var(--af-muted);
    font-size: 0.76rem;
    font-weight: 680;
}

.alarmflow-ui .af-mobile-schedule-save {
    display: grid;
    gap: 0.55rem;
    margin: 0 0.95rem 0.85rem;
    border: 1px solid color-mix(in srgb, var(--af-warning) 30%, var(--af-control-border));
    border-radius: 8px;
    background: color-mix(in srgb, var(--af-warning) 8%, white);
    padding: 0.68rem;
}

.alarmflow-ui .af-mobile-schedule-save p {
    color: color-mix(in srgb, var(--af-warning) 64%, var(--af-navy));
    font-size: 0.82rem;
    font-weight: 850;
}

.alarmflow-ui .af-mobile-schedule-save > div {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.alarmflow-ui .af-mobile-schedule-hero {
    margin: 0 0.95rem 0.8rem;
    border-radius: 8px;
    background: color-mix(in srgb, var(--af-info) 8%, white);
    padding: 0.72rem;
}

.alarmflow-ui .af-mobile-schedule-hero > div:first-child {
    display: grid;
    grid-template-columns: 1.6rem minmax(0, 1fr) 1.6rem;
    align-items: center;
    gap: 0.5rem;
    border-radius: 999px;
    background: linear-gradient(90deg, #315d8a, #0f2440 58%, #f4c7d5);
    color: #fff;
    padding: 0.28rem 0.48rem;
}

.alarmflow-ui .af-mobile-schedule-hero > div:first-child span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.alarmflow-ui .af-mobile-schedule-hero > div:first-child strong {
    overflow: hidden;
    font-size: 0.76rem;
    font-weight: 860;
    text-align: center;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-mobile-schedule-hero > p {
    margin-top: 0.55rem;
    color: var(--af-navy);
    font-size: 0.82rem;
    font-weight: 760;
}

.alarmflow-ui .af-mobile-schedule-hero dl {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem;
    margin-top: 0.62rem;
}

.alarmflow-ui .af-mobile-schedule-hero dt {
    color: var(--af-muted);
    font-size: 0.66rem;
    font-weight: 780;
    text-transform: uppercase;
}

.alarmflow-ui .af-mobile-schedule-hero dd {
    color: var(--af-navy);
    font-size: 0.95rem;
    font-weight: 860;
}

.alarmflow-ui .af-mobile-schedule-summary,
.alarmflow-ui .af-mobile-schedule-next {
    margin: 0 0.95rem;
    color: var(--af-muted);
    font-size: 0.8rem;
    font-weight: 650;
}

.alarmflow-ui .af-mobile-schedule-next {
    margin-top: 0.35rem;
}

.alarmflow-ui .af-mobile-schedule-week {
    display: grid;
    gap: 0.42rem;
    margin: 0.82rem 0.95rem 0;
}

.alarmflow-ui .af-mobile-schedule-day {
    display: grid;
    grid-template-columns: 2.2rem minmax(0, 1fr) 7.7rem;
    align-items: center;
    gap: 0.48rem;
}

.alarmflow-ui .af-mobile-schedule-day strong {
    color: var(--af-navy);
    font-size: 0.78rem;
    font-weight: 850;
}

.alarmflow-ui .af-mobile-schedule-day-track {
    position: relative;
    height: 0.58rem;
    overflow: hidden;
    border-radius: 999px;
    background: color-mix(in srgb, var(--af-muted) 13%, white);
}

.alarmflow-ui .af-mobile-schedule-day-track span {
    position: absolute;
    top: 0;
    bottom: 0;
    min-width: 0.35rem;
    border-radius: inherit;
    background: color-mix(in srgb, var(--af-success) 72%, var(--af-info));
}

.alarmflow-ui .af-mobile-schedule-day.is-inactive .af-mobile-schedule-day-track span {
    display: none;
}

.alarmflow-ui .af-mobile-schedule-day.is-overnight .af-mobile-schedule-day-track span {
    background: color-mix(in srgb, var(--af-muted) 42%, var(--af-navy));
}

.alarmflow-ui .af-mobile-schedule-day small {
    display: inline-flex;
    min-width: 0;
    align-items: center;
    justify-content: flex-end;
    gap: 0.28rem;
    color: var(--af-muted);
    font-size: 0.72rem;
    font-weight: 760;
    text-align: right;
}

.alarmflow-ui .af-mobile-schedule-day small .af-inline-icon {
    width: 0.9rem;
    height: 0.9rem;
    flex: 0 0 auto;
}

.alarmflow-ui .af-mobile-schedule-list {
    display: grid;
    margin-top: 0.8rem;
    border-top: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
}

.alarmflow-ui .af-mobile-schedule-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.7rem;
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    padding: 0.78rem 0.95rem;
}

.alarmflow-ui .af-mobile-schedule-row p {
    overflow: hidden;
    color: var(--af-navy);
    font-size: 0.88rem;
    font-weight: 850;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-mobile-schedule-row small {
    color: var(--af-muted);
    font-size: 0.76rem;
    font-weight: 640;
}

.alarmflow-ui .af-mobile-schedule-row-meta {
    display: grid;
    justify-items: end;
    gap: 0.25rem;
}

.alarmflow-ui .af-mobile-schedule-row-meta strong,
.alarmflow-ui .af-mobile-schedule-row-meta span {
    border-radius: 999px;
    background: color-mix(in srgb, var(--af-info) 8%, white);
    color: color-mix(in srgb, var(--af-info) 70%, var(--af-navy));
    padding: 0.2rem 0.48rem;
    font-size: 0.68rem;
    font-weight: 850;
}

.alarmflow-ui .af-mobile-schedule-row-meta span {
    background: color-mix(in srgb, var(--af-warning) 12%, white);
    color: color-mix(in srgb, var(--af-warning) 68%, black);
}

.alarmflow-ui .af-mobile-settings-form input[readonly] {
    background: color-mix(in srgb, var(--af-surface) 78%, white);
    color: var(--af-muted);
}

.alarmflow-ui .af-mobile-settings-form .af-mobile-mini-button {
    width: max-content;
}

.alarmflow-ui .af-mobile-screen-more .af-mobile-card-head {
    padding: 0.58rem 0.76rem;
}

.alarmflow-ui .af-mobile-screen-more .af-mobile-detail-list div {
    grid-template-columns: minmax(4.8rem, 0.42fr) minmax(0, 1fr);
    padding: 0.62rem 0.82rem;
}

.alarmflow-ui .af-mobile-screen-more .af-mobile-settings-list a,
.alarmflow-ui .af-mobile-screen-more .af-mobile-settings-list button {
    padding: 0.72rem 0.82rem;
}

.alarmflow-ui .af-mobile-screen-more .af-mobile-settings-form {
    gap: 0.6rem;
    padding: 0.72rem 0.82rem;
}

.alarmflow-ui .af-mobile-member-row {
    display: grid;
    min-width: 0;
    grid-template-columns: 2.2rem minmax(0, 1fr);
    align-items: center;
    gap: 0.72rem;
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    padding: 0.82rem 0.95rem;
}

.alarmflow-ui .af-mobile-screen-more .af-mobile-member-row {
    gap: 0.62rem;
    padding: 0.72rem 0.82rem;
}

.alarmflow-ui .af-mobile-member-row > span {
    display: inline-flex;
    width: 2.2rem;
    height: 2.2rem;
    align-items: center;
    justify-content: center;
    color: var(--af-info);
}

.alarmflow-ui .af-mobile-member-row > div {
    min-width: 0;
}

.alarmflow-ui .af-mobile-member-row p {
    overflow: hidden;
    color: var(--af-navy);
    font-size: 0.9rem;
    font-weight: 820;
    line-height: 1.18;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-mobile-member-row small {
    color: var(--af-muted);
    font-size: 0.78rem;
    font-weight: 620;
}

.alarmflow-ui .af-mobile-member-note {
    display: block;
    margin-top: 0.28rem;
    line-height: 1.3;
}

.alarmflow-ui .af-mobile-member-row form {
    grid-column: 2;
    margin: 0;
}

.alarmflow-ui .af-mobile-control-icon,
.alarmflow-ui .af-mobile-node-icon,
.alarmflow-ui .af-mobile-settings-list a > span,
.alarmflow-ui .af-mobile-settings-list button > span {
    display: inline-flex;
    width: 2.2rem;
    height: 2.2rem;
    align-items: center;
    justify-content: center;
    color: var(--af-info);
}

.alarmflow-ui .af-mobile-control-row p,
.alarmflow-ui .af-mobile-node-row p,
.alarmflow-ui .af-mobile-settings-list strong {
    overflow: hidden;
    color: var(--af-navy);
    font-size: 0.9rem;
    font-weight: 820;
    line-height: 1.18;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-mobile-control-row span,
.alarmflow-ui .af-mobile-node-row span,
.alarmflow-ui .af-mobile-node-row small {
    color: var(--af-muted);
    font-size: 0.78rem;
    font-weight: 620;
}

.alarmflow-ui .af-mobile-control-row.is-active .af-mobile-control-icon,
.alarmflow-ui .af-mobile-node-row.is-active .af-mobile-node-icon {
    color: var(--af-success);
}

.alarmflow-ui .af-mobile-control-row.is-disabled,
.alarmflow-ui .af-mobile-node-row.is-fault {
    background: color-mix(in srgb, var(--af-danger) 4%, white);
}

.alarmflow-ui .af-mobile-node-row.is-warning {
    background: color-mix(in srgb, var(--af-warning) 5%, white);
}

.alarmflow-ui .af-mobile-node-row.is-fault .af-mobile-node-icon {
    color: var(--af-danger);
}

.alarmflow-ui .af-mobile-control-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.35rem;
}

.alarmflow-ui .af-mobile-mini-button,
.alarmflow-ui .af-mobile-control-state,
.alarmflow-ui .af-mobile-node-row > strong {
    display: inline-flex;
    min-height: 2.75rem;
    align-items: center;
    justify-content: center;
    border: 1px solid color-mix(in srgb, var(--af-info) 28%, var(--af-control-border));
    border-radius: 8px;
    background: color-mix(in srgb, var(--af-info) 6%, white);
    color: color-mix(in srgb, var(--af-info) 66%, var(--af-navy));
    padding: 0 0.62rem;
    font-size: 0.72rem;
    font-weight: 850;
}

.alarmflow-ui .af-mobile-mini-button.is-secondary {
    border-color: color-mix(in srgb, var(--af-warning) 30%, var(--af-control-border));
    background: color-mix(in srgb, var(--af-warning) 7%, white);
    color: color-mix(in srgb, var(--af-warning) 58%, var(--af-navy));
}

.alarmflow-ui .af-mobile-mini-button.is-danger {
    border-color: color-mix(in srgb, var(--af-danger) 30%, var(--af-control-border));
    background: color-mix(in srgb, var(--af-danger) 7%, white);
    color: color-mix(in srgb, var(--af-danger) 58%, var(--af-navy));
}

.alarmflow-ui .af-mobile-mini-button .af-inline-icon {
    width: 0.95rem;
    height: 0.95rem;
    margin-right: 0.24rem;
}

.alarmflow-ui .af-mobile-mini-button:disabled {
    cursor: not-allowed;
    opacity: 0.48;
}

.alarmflow-ui .af-mobile-rule-card {
    display: grid;
    gap: 0.58rem;
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    padding: 0.82rem 0.95rem;
}

.alarmflow-ui .af-mobile-rule-card:last-child {
    border-bottom: 0;
}

.alarmflow-ui .af-mobile-rule-card.is-disabled {
    background: color-mix(in srgb, var(--af-muted) 5%, white);
}

.alarmflow-ui .af-mobile-rule-title {
    display: grid;
    min-width: 0;
    grid-template-columns: 2.2rem minmax(0, 1fr);
    align-items: center;
    gap: 0.72rem;
}

.alarmflow-ui .af-mobile-rule-title > span {
    display: inline-flex;
    width: 2.2rem;
    height: 2.2rem;
    align-items: center;
    justify-content: center;
    color: var(--af-info);
}

.alarmflow-ui .af-mobile-rule-title p {
    overflow: hidden;
    color: var(--af-navy);
    font-size: 0.9rem;
    font-weight: 820;
    line-height: 1.18;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-mobile-rule-title small,
.alarmflow-ui .af-mobile-rule-description,
.alarmflow-ui .af-mobile-rule-counts {
    color: var(--af-muted);
    font-size: 0.78rem;
    font-weight: 620;
}

.alarmflow-ui .af-mobile-rule-flow {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    align-items: center;
    gap: 0.45rem;
}

.alarmflow-ui .af-mobile-rule-flow span {
    min-width: 0;
    border: 1px solid var(--af-control-border);
    border-radius: 8px;
    background: color-mix(in srgb, var(--af-surface) 70%, white);
    padding: 0.45rem 0.52rem;
    color: var(--af-navy);
    font-size: 0.74rem;
    font-weight: 760;
    overflow-wrap: anywhere;
}

.alarmflow-ui .af-mobile-rule-flow span:nth-child(2) {
    border: 0;
    background: transparent;
    color: var(--af-muted);
    padding: 0;
}

.alarmflow-ui .af-mobile-media-card {
    display: grid;
    gap: 0.72rem;
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    padding: 0.82rem 0.95rem;
}

.alarmflow-ui .af-mobile-media-card:last-child {
    border-bottom: 0;
}

.alarmflow-ui .af-mobile-media-card.is-default,
.alarmflow-ui .af-mobile-media-card.is-warning {
    background: color-mix(in srgb, var(--af-warning) 5%, white);
}

.alarmflow-ui .af-mobile-media-card.is-fault {
    background: color-mix(in srgb, var(--af-danger) 4%, white);
}

.alarmflow-ui .af-mobile-media-head {
    display: grid;
    min-width: 0;
    grid-template-columns: 2.2rem minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.72rem;
}

.alarmflow-ui .af-mobile-media-icon {
    display: inline-flex;
    width: 2.2rem;
    height: 2.2rem;
    align-items: center;
    justify-content: center;
    color: var(--af-info);
}

.alarmflow-ui .af-mobile-media-card.is-default .af-mobile-media-icon {
    color: var(--af-warning);
}

.alarmflow-ui .af-mobile-media-head p {
    overflow: hidden;
    color: var(--af-navy);
    font-size: 0.9rem;
    font-weight: 820;
    line-height: 1.18;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-mobile-media-head small,
.alarmflow-ui .af-mobile-media-detail {
    color: var(--af-muted);
    font-size: 0.78rem;
    font-weight: 620;
    overflow-wrap: anywhere;
}

.alarmflow-ui .af-mobile-media-head form {
    margin: 0;
}

.alarmflow-ui .af-mobile-media-head > strong {
    display: inline-flex;
    min-height: 2rem;
    align-items: center;
    justify-content: center;
    border: 1px solid color-mix(in srgb, var(--af-warning) 30%, var(--af-control-border));
    border-radius: 8px;
    background: color-mix(in srgb, var(--af-warning) 8%, white);
    color: color-mix(in srgb, var(--af-warning) 58%, var(--af-navy));
    padding: 0 0.55rem;
    font-size: 0.72rem;
    font-weight: 850;
}

.alarmflow-ui .af-mobile-media-head > strong .af-inline-icon {
    width: 0.95rem;
    height: 0.95rem;
    margin-right: 0.24rem;
}

.alarmflow-ui .af-mobile-media-player {
    width: 100%;
    min-width: 0;
}

.alarmflow-ui .af-mobile-media-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.alarmflow-ui .af-mobile-media-meta span {
    border: 1px solid color-mix(in srgb, var(--af-control-border) 82%, white);
    border-radius: 999px;
    background: color-mix(in srgb, var(--af-surface) 74%, white);
    color: var(--af-muted);
    padding: 0.24rem 0.45rem;
    font-size: 0.7rem;
    font-weight: 760;
}

.alarmflow-ui .af-mobile-event-expanded p {
    white-space: normal;
}

.alarmflow-ui .af-mobile-event-detail-thumb {
    display: block;
    width: calc(100% - 1.24rem);
    margin: 0.62rem;
    aspect-ratio: 16 / 9;
    border-radius: 8px;
    object-fit: cover;
}

.alarmflow-ui .af-mobile-event-player,
.alarmflow-ui .af-mobile-event-playback {
    display: grid;
    gap: 0.62rem;
    padding: 0.62rem;
}

.alarmflow-ui .af-mobile-event-playback.af-mobile-incident-preview {
    position: relative;
    display: block;
    margin: 0.62rem;
    overflow: hidden;
    border-radius: 8px;
    background: #020617;
    padding: 0;
}

.alarmflow-ui .af-mobile-event-player video,
.alarmflow-ui .af-mobile-event-playback video {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    border-radius: 8px;
    background: #020617;
    object-fit: fill;
}

.alarmflow-ui .af-mobile-event-playback .af-mobile-live-frame {
    margin: 0;
    border-radius: 0;
}

.alarmflow-ui .af-mobile-event-playback-placeholder {
    position: relative;
    display: grid;
    aspect-ratio: 16 / 9;
    min-height: 0;
    align-content: center;
    justify-items: center;
    gap: 0.5rem;
    border-radius: 0;
    background: #020617;
    color: #fff;
}

.alarmflow-ui .af-mobile-event-playback-placeholder > span {
    display: inline-flex;
    width: 3rem;
    height: 3rem;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255, 255, 255, 0.52);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.14);
}

.alarmflow-ui .af-mobile-event-playback-placeholder strong {
    font-size: 0.88rem;
    font-weight: 820;
}

.alarmflow-ui .af-mobile-event-playback-placeholder small {
    color: rgba(255, 255, 255, 0.68);
    font-size: 0.72rem;
    font-weight: 700;
}

.alarmflow-ui .af-mobile-event-playback-controls {
    position: absolute;
    left: 0.72rem;
    bottom: 0.72rem;
    z-index: 3;
    display: inline-flex;
    gap: 0.42rem;
}

.alarmflow-ui .af-mobile-event-playback-controls .af-mobile-mini-button {
    min-height: 2.35rem;
    border-color: rgba(255, 255, 255, 0.14);
    background: rgba(0, 0, 0, 0.55);
    color: #fff;
    backdrop-filter: blur(8px);
}

.alarmflow-ui .af-mobile-event-playback-controls .af-mobile-mini-button.is-secondary {
    background: linear-gradient(180deg, var(--afm-orange-2), var(--afm-orange));
}

.alarmflow-ui .af-mobile-event-playback .af-mobile-action-result-slot {
    position: absolute;
    right: 0.72rem;
    bottom: 0.72rem;
    left: 6.2rem;
    z-index: 3;
}

.alarmflow-ui .af-mobile-event-playback .af-mobile-action-result {
    margin: 0;
    border-color: rgba(255, 255, 255, 0.14);
    background: rgba(0, 0, 0, 0.58);
    color: #fff;
    font-size: 0.72rem;
}

.alarmflow-ui .af-mobile-event-detail-message {
    border-top: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    padding: 0.78rem 0.95rem;
    color: var(--af-muted);
    font-size: 0.82rem;
    font-weight: 680;
    line-height: 1.45;
    overflow-wrap: anywhere;
}

.alarmflow-ui .af-mobile-action-result-slot {
    min-height: 0;
}

.alarmflow-ui .af-mobile-action-result-slot .af-mobile-action-result {
    position: fixed;
    right: 1rem;
    bottom: calc(var(--af-mobile-tabbar-clearance, 5.9rem) + env(safe-area-inset-bottom) + 0.75rem);
    left: 1rem;
    z-index: 90;
    max-width: 28rem;
    margin: 0 auto;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.16);
}

.alarmflow-ui .af-mobile-action-result {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 0.55rem;
    border: 1px solid var(--af-control-border);
    border-radius: 8px;
    padding: 0.72rem 0.82rem;
    font-size: 0.78rem;
    font-weight: 760;
}

.alarmflow-ui .af-mobile-action-result strong,
.alarmflow-ui .af-mobile-action-result small {
    display: block;
}

.alarmflow-ui .af-mobile-action-result small {
    margin-top: 0.18rem;
    opacity: 0.78;
}

.alarmflow-ui .af-mobile-backlink {
    display: inline-flex;
    width: max-content;
    align-items: center;
    gap: 0.35rem;
    color: var(--af-muted);
    font-size: 0.82rem;
    font-weight: 800;
}

.alarmflow-ui .af-mobile-backlink .af-inline-icon {
    width: 1rem;
    height: 1rem;
    transform: rotate(180deg);
}

.alarmflow-ui .af-mobile-screen-cameras > .af-mobile-backlink {
    margin-top: -0.18rem;
    margin-bottom: -0.28rem;
}

.alarmflow-ui .af-mobile-detail-hero {
    display: grid;
    grid-template-columns: 3rem minmax(0, 1fr);
    align-items: center;
    gap: 0.8rem;
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    padding: 0.95rem;
}

.alarmflow-ui .af-mobile-detail-hero > span {
    display: inline-flex;
    width: 3rem;
    height: 3rem;
    align-items: center;
    justify-content: center;
    color: var(--af-success);
}

.alarmflow-ui .af-mobile-detail-hero.is-warning > span {
    color: var(--af-warning);
}

.alarmflow-ui .af-mobile-detail-hero.is-fault > span {
    color: var(--af-danger);
}

.alarmflow-ui .af-mobile-detail-hero strong {
    color: var(--af-navy);
    font-size: 0.98rem;
    font-weight: 860;
}

.alarmflow-ui .af-mobile-detail-hero small {
    display: block;
    margin-top: 0.22rem;
    color: var(--af-muted);
    font-size: 0.78rem;
    font-weight: 620;
    overflow-wrap: anywhere;
}

.alarmflow-ui .af-mobile-detail-list {
    display: grid;
}

.alarmflow-ui .af-mobile-detail-list div {
    display: grid;
    grid-template-columns: minmax(6.2rem, 0.45fr) minmax(0, 1fr);
    gap: 0.62rem;
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    padding: 0.7rem 0.95rem;
}

.alarmflow-ui .af-mobile-detail-list div:last-child {
    border-bottom: 0;
}

.alarmflow-ui .af-mobile-detail-list dt {
    color: var(--af-muted);
    font-size: 0.76rem;
    font-weight: 800;
}

.alarmflow-ui .af-mobile-detail-list dd {
    min-width: 0;
    color: var(--af-navy);
    font-size: 0.8rem;
    font-weight: 700;
    overflow-wrap: anywhere;
    text-align: right;
}

.alarmflow-ui .af-mobile-node-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    border-top: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    padding: 0.82rem 0.95rem;
}

.alarmflow-ui .af-mobile-action-result.is-success {
    border-color: color-mix(in srgb, var(--af-success) 38%, white);
    background: color-mix(in srgb, var(--af-success) 8%, white);
    color: color-mix(in srgb, var(--af-success) 58%, black);
}

.alarmflow-ui .af-mobile-action-result.is-danger {
    border-color: color-mix(in srgb, var(--af-danger) 38%, white);
    background: color-mix(in srgb, var(--af-danger) 8%, white);
    color: color-mix(in srgb, var(--af-danger) 58%, black);
}

.alarmflow-ui .af-mobile-tabbar {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 60;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    max-width: 30rem;
    margin: 0 auto;
    border-top: 1px solid var(--af-control-border);
    background: rgba(255, 255, 255, 0.98);
    padding: 0.42rem 0.35rem calc(0.4rem + env(safe-area-inset-bottom));
}

.alarmflow-ui .af-mobile-tabbar a {
    display: grid;
    justify-items: center;
    gap: 0.22rem;
    min-width: 0;
    color: var(--af-muted);
    font-size: 0.68rem;
    font-weight: 680;
}

.alarmflow-ui .af-mobile-tabbar .af-inline-icon {
    width: 1.45rem;
    height: 1.45rem;
}

.alarmflow-ui .af-mobile-tabbar a.is-active {
    color: color-mix(in srgb, var(--af-warning) 78%, black);
}

.alarmflow-ui .af-mobile-today-hero {
    min-height: 5.45rem;
}

.alarmflow-ui .af-mobile-today-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.54rem;
}

.alarmflow-ui .af-mobile-today-grid .af-mobile-health-stat {
    min-width: 0;
    border: 1px solid var(--af-control-border);
    border-radius: 8px;
    background: #fff;
    padding: 0.72rem 0.52rem;
    text-align: center;
    text-decoration: none;
}

.alarmflow-ui .af-mobile-today-grid .af-mobile-health-stat + .af-mobile-health-stat {
    border-left: 1px solid var(--af-control-border);
}

.alarmflow-ui .af-mobile-today-schedule {
    display: grid;
    gap: 0.24rem;
    padding: 0.85rem 0.95rem 0.95rem;
}

.alarmflow-ui .af-mobile-today-schedule strong {
    color: var(--af-navy);
    font-size: 0.96rem;
    font-weight: 850;
}

.alarmflow-ui .af-mobile-today-schedule p,
.alarmflow-ui .af-mobile-today-schedule small {
    color: var(--af-muted);
    font-size: 0.78rem;
    font-weight: 680;
    line-height: 1.35;
}

.alarmflow-ui .af-mobile-camera-strip {
    display: grid;
    grid-auto-columns: minmax(7.2rem, 42%);
    grid-auto-flow: column;
    gap: 0.62rem;
    overflow-x: auto;
    padding: 0.78rem 0.85rem 0.92rem;
    scroll-snap-type: x proximity;
}

.alarmflow-ui .af-mobile-camera-strip-item {
    display: grid;
    min-width: 0;
    gap: 0.28rem;
    color: var(--af-navy);
    text-decoration: none;
    scroll-snap-align: start;
}

.alarmflow-ui .af-mobile-camera-strip-thumb {
    display: grid;
    aspect-ratio: 4 / 3;
    place-items: center;
    overflow: hidden;
    border-radius: 8px;
    background: #0f172a;
    color: #fff;
}

.alarmflow-ui .af-mobile-camera-strip-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.alarmflow-ui .af-mobile-camera-strip-item strong,
.alarmflow-ui .af-mobile-camera-strip-item small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-mobile-camera-strip-item strong {
    font-size: 0.8rem;
    font-weight: 840;
}

.alarmflow-ui .af-mobile-camera-strip-item small {
    color: var(--af-muted);
    font-size: 0.68rem;
    font-weight: 700;
}

.alarmflow-ui .af-mobile-status-compact {
    margin-bottom: -0.2rem;
    min-height: 4.75rem;
    padding: 0.66rem 0.8rem;
}

.alarmflow-ui .af-mobile-live-card {
    overflow: hidden;
}

.alarmflow-ui .af-mobile-camera-list,
.alarmflow-ui .af-mobile-action-row-list {
    display: grid;
}

.alarmflow-ui .af-mobile-camera-card {
    display: grid;
    gap: 0.58rem;
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    background: #fff;
    padding: 0.64rem;
}

.alarmflow-ui .af-mobile-camera-card:last-child {
    border-bottom: 0;
}

.alarmflow-ui .af-mobile-camera-preview {
    position: relative;
    display: flex;
    min-height: 7.1rem;
    aspect-ratio: 16 / 9;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    border-radius: 8px;
    background: #0f172a;
    color: #fff;
    text-decoration: none;
}

.alarmflow-ui .af-mobile-camera-preview-large {
    margin: 0 0.85rem 0.85rem;
}

.alarmflow-ui .af-mobile-camera-detail-card .af-mobile-card-head {
    padding: 0.58rem 0.68rem;
}

.alarmflow-ui .af-mobile-camera-detail-card .af-mobile-camera-preview-large,
.alarmflow-ui .af-mobile-camera-detail-card .af-mobile-live-frame {
    margin: 0 0.62rem 0.55rem;
}

.alarmflow-ui .af-mobile-camera-detail-card .af-mobile-camera-preview-large {
    min-height: 0;
}

.alarmflow-ui .af-mobile-camera-detail-card .af-mobile-camera-actions-detail {
    margin-top: 0;
    padding: 0 0.62rem 0.58rem;
}

.alarmflow-ui .af-mobile-camera-detail-card .af-mobile-camera-actions-detail .af-mobile-mini-button {
    min-height: 2.42rem;
    padding: 0 0.56rem;
}

.alarmflow-ui .af-mobile-camera-detail-section .af-mobile-card-head {
    padding: 0.58rem 0.68rem;
}

.alarmflow-ui .af-mobile-camera-detail-section .af-mobile-card-head h2 {
    font-size: 0.92rem;
}

.alarmflow-ui .af-mobile-camera-detail-section .af-mobile-empty {
    padding: 0.74rem 0.78rem;
}

.alarmflow-ui .af-mobile-camera-detail-section .af-mobile-event {
    padding: 0.62rem 0.78rem;
}

.alarmflow-ui .af-mobile-camera-detail-section .af-mobile-detail-list div {
    grid-template-columns: minmax(5.4rem, 0.4fr) minmax(0, 1fr);
    padding: 0.58rem 0.78rem;
}

.alarmflow-ui .af-mobile-live-frame {
    margin: 0 0.85rem 0.85rem;
    overflow: hidden;
    border-radius: 8px;
    background: #020617;
}

.alarmflow-ui .af-mobile-live-frame video {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    background: #020617;
    object-fit: fill;
}

.alarmflow-ui .af-mobile-camera-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.alarmflow-ui .af-mobile-camera-preview video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    background: #020617;
    object-fit: fill;
}

.alarmflow-ui .af-mobile-camera-preview.is-live video {
    display: block;
}

.alarmflow-ui .af-mobile-camera-placeholder {
    display: inline-flex;
    width: 2.45rem;
    height: 2.45rem;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.12);
}

.alarmflow-ui .af-mobile-camera-play {
    position: absolute;
    inset: 50% auto auto 50%;
    display: inline-flex;
    width: 2.85rem;
    height: 2.85rem;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255, 255, 255, 0.52);
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.72);
    color: #fff;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.34);
    transform: translate(-50%, -50%);
}

.alarmflow-ui .af-mobile-camera-play .af-inline-icon {
    --af-icon-size: 1.08rem;
    margin-left: 0.08rem;
}

.alarmflow-ui .af-mobile-camera-preview:hover .af-mobile-camera-play,
.alarmflow-ui .af-mobile-camera-preview:focus-visible .af-mobile-camera-play {
    background: rgba(37, 99, 235, 0.88);
}

.alarmflow-ui .af-mobile-camera-preview strong {
    position: absolute;
    top: 0.42rem;
    right: 0.42rem;
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.72);
    padding: 0.22rem 0.52rem;
    font-size: 0.7rem;
    font-weight: 850;
}

.alarmflow-ui .af-mobile-camera-preview em {
    position: absolute;
    right: 0.52rem;
    bottom: 0.52rem;
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.72);
    color: #fff;
    padding: 0.24rem 0.55rem;
    font-size: 0.72rem;
    font-style: normal;
    font-weight: 780;
}

.alarmflow-ui .af-mobile-camera-title {
    display: flex;
    min-width: 0;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.52rem;
}

.alarmflow-ui .af-mobile-camera-title h2 {
    overflow: hidden;
    color: var(--af-navy);
    font-size: 0.94rem;
    font-weight: 850;
    line-height: 1.15;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-mobile-camera-title p {
    margin-top: 0.1rem;
    color: var(--af-muted);
    font-size: 0.74rem;
    font-weight: 650;
}

.alarmflow-ui .af-mobile-camera-detail-head p {
    margin-top: 0.1rem;
    color: var(--af-muted);
    font-size: 0.78rem;
    font-weight: 680;
}

.alarmflow-ui .af-mobile-camera-pill {
    flex: 0 0 auto;
    border-radius: 999px;
    background: color-mix(in srgb, var(--af-success) 9%, white);
    color: color-mix(in srgb, var(--af-success) 68%, black);
    padding: 0.2rem 0.48rem;
    font-size: 0.68rem;
    font-weight: 850;
}

.alarmflow-ui .af-mobile-camera-pill.is-offline,
.alarmflow-ui .af-mobile-camera-pill.is-unknown {
    background: color-mix(in srgb, var(--af-danger) 8%, white);
    color: color-mix(in srgb, var(--af-danger) 70%, black);
}

.alarmflow-ui .af-mobile-camera-pill.is-motion,
.alarmflow-ui .af-mobile-camera-pill.is-recording {
    background: color-mix(in srgb, var(--af-warning) 10%, white);
    color: color-mix(in srgb, var(--af-warning) 68%, black);
}

.alarmflow-ui .af-mobile-camera-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.34rem;
    margin-top: 0.46rem;
}

.alarmflow-ui .af-mobile-camera-actions form {
    margin: 0;
}

.alarmflow-ui .af-mobile-camera-empty p {
    margin-bottom: 0.75rem;
}

.alarmflow-ui .af-mobile-live-card.is-compact .af-mobile-camera-card {
    grid-template-columns: minmax(5.8rem, 7rem) minmax(0, 1fr);
    align-items: center;
    gap: 0.6rem;
    padding: 0.56rem 0.64rem;
}

.alarmflow-ui .af-mobile-live-card.is-compact .af-mobile-camera-preview {
    min-height: 4.45rem;
    aspect-ratio: 4 / 3;
}

.alarmflow-ui .af-mobile-live-card.is-compact .af-mobile-camera-placeholder {
    width: 2rem;
    height: 2rem;
}

.alarmflow-ui .af-mobile-live-card.is-compact .af-mobile-camera-play {
    width: 2.18rem;
    height: 2.18rem;
}

.alarmflow-ui .af-mobile-live-card.is-compact .af-mobile-camera-play .af-inline-icon {
    --af-icon-size: 0.88rem;
}

.alarmflow-ui .af-mobile-live-card.is-compact .af-mobile-camera-preview strong {
    top: 0.28rem;
    right: 0.28rem;
    padding: 0.14rem 0.36rem;
    font-size: 0.62rem;
}

.alarmflow-ui .af-mobile-live-card.is-compact .af-mobile-camera-title {
    align-items: center;
}

.alarmflow-ui .af-mobile-live-card.is-compact .af-mobile-camera-title h2 {
    font-size: 0.9rem;
}

.alarmflow-ui .af-mobile-live-card.is-compact .af-mobile-camera-title p {
    display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
}

.alarmflow-ui .af-mobile-live-card.is-compact .af-mobile-camera-actions {
    margin-top: 0.34rem;
}

.alarmflow-ui .af-mobile-focus-actions {
    display: none;
}

.alarmflow-ui .af-mobile-live-card.is-compact .af-mobile-compact-actions {
    flex-wrap: nowrap;
}

.alarmflow-ui .af-mobile-live-card.is-focus .af-mobile-compact-actions {
    display: none;
}

.alarmflow-ui .af-mobile-live-card.is-focus .af-mobile-focus-actions {
    display: flex;
}

.alarmflow-ui .af-mobile-response-sheet {
    position: fixed;
    inset: 0;
    z-index: 100;
    display: grid;
    align-items: end;
    justify-items: center;
}

.alarmflow-ui.af-mobile-response-open {
    overflow: hidden;
}

.alarmflow-ui .af-mobile-response-backdrop {
    position: absolute;
    inset: 0;
    border: 0;
    background: rgba(15, 23, 42, 0.42);
}

.alarmflow-ui .af-mobile-response-panel {
    position: relative;
    z-index: 1;
    width: min(100%, 30rem);
    max-height: min(82dvh, 36rem);
    overflow-y: auto;
    border: 1px solid color-mix(in srgb, var(--af-control-border) 76%, white);
    border-radius: 18px 18px 0 0;
    background: #fff;
    box-shadow: 0 -20px 48px rgba(15, 23, 42, 0.22);
    padding: 0.95rem 1rem calc(1rem + env(safe-area-inset-bottom));
    scroll-padding-bottom: calc(1rem + env(safe-area-inset-bottom));
}

.alarmflow-ui .af-mobile-response-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.8rem;
    margin-bottom: 0.82rem;
}

.alarmflow-ui .af-mobile-response-head h2 {
    color: var(--af-navy);
    font-size: 1.02rem;
    font-weight: 860;
    line-height: 1.2;
}

.alarmflow-ui .af-mobile-response-head p {
    margin-top: 0.18rem;
    color: var(--af-muted);
    font-size: 0.78rem;
    font-weight: 680;
}

.alarmflow-ui .af-mobile-response-close {
    display: inline-flex;
    width: 2.35rem;
    height: 2.35rem;
    flex: 0 0 auto;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--af-control-border);
    border-radius: 999px;
    background: #fff;
    color: var(--af-navy);
}

.alarmflow-ui .af-mobile-qr-viewer .af-mobile-response-panel {
    align-self: center;
    width: min(calc(100% - 1.5rem), 24rem);
    border-radius: 16px;
    padding-bottom: 1rem;
    box-shadow: 0 24px 58px rgba(15, 23, 42, 0.26);
}

.alarmflow-ui .af-mobile-qr-frame {
    display: grid;
    place-items: center;
    border: 1px solid var(--af-control-border);
    border-radius: 8px;
    background: #fff;
    padding: 0.8rem;
}

.alarmflow-ui .af-mobile-qr-frame img {
    width: min(100%, 17rem);
    aspect-ratio: 1 / 1;
    object-fit: contain;
}

.alarmflow-ui .af-mobile-response-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.52rem;
}

.alarmflow-ui .af-mobile-response-actions form {
    margin: 0;
}

.alarmflow-ui .af-mobile-response-action {
    display: grid;
    width: 100%;
    min-height: 4.45rem;
    grid-template-columns: 2rem minmax(0, 1fr);
    align-items: center;
    gap: 0.56rem;
    border: 1px solid color-mix(in srgb, var(--af-info) 42%, white);
    border-radius: 10px;
    background: color-mix(in srgb, var(--af-info) 6%, white);
    color: color-mix(in srgb, var(--af-info) 70%, black);
    padding: 0.62rem;
    text-align: left;
    text-decoration: none;
}

.alarmflow-ui .af-mobile-response-action.is-amber {
    border-color: color-mix(in srgb, var(--af-warning) 42%, white);
    background: color-mix(in srgb, var(--af-warning) 8%, white);
    color: color-mix(in srgb, var(--af-warning) 58%, black);
}

.alarmflow-ui .af-mobile-response-action:disabled {
    border-color: var(--af-control-border);
    background: color-mix(in srgb, var(--af-control-border) 18%, white);
    color: var(--af-muted);
    cursor: not-allowed;
}

.alarmflow-ui .af-mobile-response-action > span {
    display: inline-flex;
    width: 2rem;
    height: 2rem;
    grid-row: 1 / span 2;
    align-items: center;
    justify-content: center;
}

.alarmflow-ui .af-mobile-response-action strong,
.alarmflow-ui .af-mobile-response-action small {
    display: block;
    grid-column: 2;
    min-width: 0;
}

.alarmflow-ui .af-mobile-response-action strong {
    color: var(--af-navy);
    font-size: 0.86rem;
    font-weight: 840;
}

.alarmflow-ui .af-mobile-response-action small {
    margin-top: 0.12rem;
    overflow: hidden;
    color: var(--af-muted);
    font-size: 0.68rem;
    font-weight: 650;
    line-height: 1.2;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-mobile-response-secondary {
    display: grid;
    margin-top: 0.72rem;
}

.alarmflow-ui .af-mobile-response-secondary a {
    display: inline-flex;
    min-height: 2.7rem;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    border: 1px solid var(--af-control-border);
    border-radius: 10px;
    background: #fff;
    color: var(--af-navy);
    font-size: 0.84rem;
    font-weight: 800;
    text-decoration: none;
}

.alarmflow-ui .af-mobile-action-row,
.alarmflow-ui .af-mobile-action-row-list form > button {
    display: grid;
    width: 100%;
    min-height: 3.1rem;
    grid-template-columns: 2.2rem minmax(0, 1fr);
    align-items: center;
    gap: 0.72rem;
    border: 0;
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
    background: #fff;
    color: var(--af-navy);
    padding: 0.82rem 0.95rem;
    text-align: left;
    text-decoration: none;
}

.alarmflow-ui .af-mobile-action-row span,
.alarmflow-ui .af-mobile-action-row-list form > button span {
    display: inline-flex;
    width: 2.2rem;
    height: 2.2rem;
    align-items: center;
    justify-content: center;
    color: var(--af-info);
}

.alarmflow-ui .af-mobile-action-row strong,
.alarmflow-ui .af-mobile-action-row-list form > button strong {
    overflow: hidden;
    font-size: 0.9rem;
    font-weight: 820;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-mobile-action-row-list form {
    margin: 0;
}

.alarmflow-ui .af-mobile-action-row-list form > button:disabled {
    cursor: not-allowed;
    opacity: 0.5;
}

.alarmflow-ui .af-mobile-event-thumb-wrap {
    position: relative;
    display: block;
    width: 4.65rem;
    height: 3.18rem;
    align-self: start;
    justify-self: center;
    margin-top: 0.05rem;
}

.alarmflow-ui .af-mobile-event-thumb {
    display: block;
    width: 100%;
    height: 100%;
    border: 1px solid color-mix(in srgb, var(--af-control-border) 78%, white);
    border-radius: 6px;
    background: #020617;
    object-fit: cover;
}

.alarmflow-ui .af-mobile-event-thumb-badge {
    position: absolute;
    right: 0.16rem;
    bottom: 0.16rem;
    display: inline-flex;
    width: 1rem;
    height: 1rem;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255, 255, 255, 0.72);
    border-radius: 4px;
    background: rgba(15, 23, 42, 0.82);
    color: #fff;
    box-shadow: 0 1px 4px rgba(2, 6, 23, 0.24);
}

.alarmflow-ui .af-mobile-event-thumb-badge .af-inline-icon {
    width: 0.66rem;
    height: 0.66rem;
}

.alarmflow-ui .af-mobile-event-actions {
    grid-column: 2 / -1;
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
}

.alarmflow-ui .af-mobile-event-actions a {
    border-radius: 999px;
    background: color-mix(in srgb, var(--af-info) 7%, white);
    color: color-mix(in srgb, var(--af-info) 68%, var(--af-navy));
    padding: 0.22rem 0.52rem;
    font-size: 0.7rem;
    font-weight: 820;
    text-decoration: none;
}

.alarmflow-ui .af-inspector-controls,
.alarmflow-ui .af-related-actions,
.alarmflow-ui .af-filterbar-actions,
.alarmflow-ui .af-dev-header-actions,
.alarmflow-ui .af-dev-tab-actions,
.alarmflow-ui .af-media-preview-actions,
.alarmflow-ui .af-upload-actions,
.alarmflow-ui .af-record-action-grid {
    display: flex;
    gap: 0.45rem;
    flex-wrap: wrap;
}

@media (max-width: 380px) {
    .alarmflow-ui .af-mobile-screen {
        padding-inline: 0.9rem;
    }

    .alarmflow-ui .af-mobile-appbar {
        padding-inline: 0.9rem;
    }

    .alarmflow-ui .af-mobile-status-card {
        grid-template-columns: minmax(0, 1fr) auto;
    }

    .alarmflow-ui .af-mobile-status-icon {
        display: none;
    }

    .alarmflow-ui .af-mobile-tabbar a {
        font-size: 0.62rem;
    }
}

.alarmflow-ui .af-inspector-danger-row {
    border-top: 1px solid color-mix(in srgb, var(--af-control-border) 76%, white);
    padding-top: 0.45rem;
}

.alarmflow-ui .af-inspector-overlay {
    background: rgba(8, 18, 36, 0.38);
}

.alarmflow-ui .af-rule-drawer,
.alarmflow-ui .af-media-inspector,
.alarmflow-ui .af-dev-tools-drawer {
    box-shadow: var(--af-panel-shadow-strong);
}

.alarmflow-ui .af-rule-drawer-header,
.alarmflow-ui .af-media-page-head,
.alarmflow-ui .af-media-inspector-head,
.alarmflow-ui .af-dev-panel-head,
.alarmflow-ui .af-trace-toolbar,
.alarmflow-ui .af-event-filters,
.alarmflow-ui .af-advanced-filters,
.alarmflow-ui .af-selected-summary,
.alarmflow-ui .af-timeline-header,
.alarmflow-ui .af-trace-section-head,
.alarmflow-ui .af-trace-debug-header {
    border-bottom: 1px solid var(--af-control-border);
}

.alarmflow-ui .af-panel-footer,
.alarmflow-ui .af-timeline-header,
.alarmflow-ui .af-trace-toolbar,
.alarmflow-ui .af-event-filters,
.alarmflow-ui .af-advanced-filters,
.alarmflow-ui .af-selected-summary,
.alarmflow-ui .af-media-toolbar,
.alarmflow-ui .af-rule-wizard-labelbar {
    background: var(--af-control-bg);
}

.alarmflow-ui .af-empty-state {
    border: 1px dashed color-mix(in srgb, var(--af-control-border) 84%, white);
    border-radius: var(--af-control-radius);
    background: var(--af-control-bg);
    color: var(--af-muted);
    padding: 0.95rem;
    font-size: 0.78rem;
    font-weight: 760;
}

.alarmflow-ui.af-sidebar-drawer-open {
    overflow: hidden;
}

.alarmflow-ui .af-app-shell {
    display: grid;
    grid-template-columns: var(--af-sidebar-width) minmax(0, 1fr);
    min-height: 100vh;
}

.alarmflow-ui .af-app-workspace {
    grid-column: 2;
    grid-row: 1;
    min-width: 0;
    background: linear-gradient(180deg, #f9fbfd 0%, var(--af-surface) 52%, #eef1f5 100%);
}

.alarmflow-ui .af-page-frame {
    box-sizing: border-box;
    width: 100%;
    max-width: calc(var(--af-page-max) + (var(--af-page-gutter) * 2));
    margin-inline: auto;
    padding-inline: var(--af-page-gutter);
}

.alarmflow-ui :is(.af-page-standard, .af-page-wide, .af-page-dashboard, .af-page-workspace, .af-page-controller-fleet) {
    --af-page-max: var(--af-page-global-max);
}

.alarmflow-ui .af-app-sidebar {
    position: sticky;
    grid-column: 1;
    grid-row: 1;
    top: 0;
    z-index: 90;
    display: grid;
    grid-template-rows: auto auto minmax(0, 1fr) auto;
    width: var(--af-sidebar-width);
    height: 100vh;
    overflow: hidden;
    border-right: 1px solid rgba(255, 255, 255, 0.08);
    background: linear-gradient(180deg, rgba(16, 35, 61, 0.94), rgba(8, 18, 36, 0.99)), var(--af-sidebar-bg);
    color: var(--af-sidebar-text);
    box-shadow: 8px 0 24px rgba(8, 18, 36, 0.14);
}

.alarmflow-ui .af-sidebar-header,
.alarmflow-ui .af-sidebar-footer {
    padding: 0.8rem;
}

.alarmflow-ui .af-sidebar-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.5rem;
}

.alarmflow-ui .af-sidebar-brand {
    display: inline-flex;
    min-height: 3.18rem;
    min-width: 0;
    align-items: center;
}

.alarmflow-ui .af-sidebar-logo-full {
    width: 11.8rem;
    height: 3.18rem;
    object-fit: contain;
}

.alarmflow-ui .af-sidebar-logo-compact {
    display: none;
    width: 2.35rem;
    height: 2.35rem;
    object-fit: contain;
}

.alarmflow-ui .af-sidebar-close {
    display: none;
}

.alarmflow-ui .af-sidebar-site-switcher {
    padding: 0 0.72rem 0.46rem;
}

.alarmflow-ui .af-sidebar-site-switcher .af-site-scope,
.alarmflow-ui .af-sidebar-site-switcher .af-site-control {
    width: 100%;
    min-width: 0;
}

.alarmflow-ui .af-sidebar-site-switcher .af-site-control {
    min-height: 2.72rem;
    gap: 0.52rem;
    border-color: rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.055);
    padding: 0.34rem 0.58rem;
    box-shadow: none;
    color: #fff;
}

.alarmflow-ui .af-sidebar-site-switcher .af-site-control:hover,
.alarmflow-ui .af-sidebar-site-switcher .af-site-scope-button[aria-expanded="true"] {
    border-color: rgba(255, 255, 255, 0.16);
    background: rgba(255, 255, 255, 0.09);
}

.alarmflow-ui .af-sidebar-site-switcher .af-site-control-kicker {
    color: color-mix(in srgb, var(--af-sidebar-muted) 86%, white);
    font-size: 0.58rem;
    line-height: 1;
}

.alarmflow-ui .af-sidebar-site-switcher .af-site-control-name {
    color: #fff;
    font-size: 0.78rem;
    line-height: 1.12;
}

.alarmflow-ui .af-sidebar-site-switcher .af-site-control-caret {
    color: color-mix(in srgb, var(--af-sidebar-muted) 86%, white);
}

.alarmflow-ui .af-sidebar-site-switcher .af-site-scope-badge {
    width: 1.8rem;
    height: 1.8rem;
    flex-basis: 1.8rem;
    border-color: rgba(255, 255, 255, 0.15);
    background: rgba(59, 130, 246, 0.18);
    color: #fff;
}

.alarmflow-ui .af-sidebar-site-switcher .af-site-scope-badge.is-all {
    background: rgba(255, 255, 255, 0.08);
    color: #fff;
}

.alarmflow-ui .af-sidebar-site-switcher .af-site-scope-panel {
    position: static;
    width: 100%;
    max-width: 100%;
    margin-top: 0.42rem;
    border-color: rgba(255, 255, 255, 0.1);
    border-radius: var(--af-radius-md);
    background: #fff;
    color: var(--af-navy);
    box-shadow: none;
}

.alarmflow-ui .af-sidebar-site-switcher .af-site-scope-header {
    padding: 0.62rem 0.72rem;
}

.alarmflow-ui .af-sidebar-site-switcher .af-site-scope-list {
    max-height: min(15rem, calc(100vh - 19rem));
}

.alarmflow-ui .af-sidebar-site-switcher .af-site-scope-row {
    min-height: 3.22rem;
}

.alarmflow-ui .af-sidebar-site-switcher .af-site-scope-footer {
    padding: 0.46rem;
}

.alarmflow-ui .af-sidebar-nav {
    display: flex;
    min-height: 0;
    flex-direction: column;
    gap: 0.16rem;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 0.12rem 0.72rem 0.8rem;
    scrollbar-color: rgba(145, 161, 182, 0.45) transparent;
}

.alarmflow-ui .af-sidebar-section-label {
    margin: 1.02rem 0 0.22rem;
    padding: 0 0.56rem;
    color: color-mix(in srgb, var(--af-sidebar-muted) 78%, transparent);
    font-size: 0.6rem;
    font-weight: 740;
    letter-spacing: 0;
    text-transform: uppercase;
}

.alarmflow-ui .af-sidebar-link,
.alarmflow-ui .af-sidebar-collapse,
.alarmflow-ui .af-sidebar-section-toggle {
    position: relative;
    display: flex;
    min-height: 2.38rem;
    width: 100%;
    align-items: center;
    gap: 0.64rem;
    border: 1px solid transparent;
    border-radius: var(--af-radius-md);
    padding: 0 0.68rem;
    color: var(--af-sidebar-text);
    font-size: 0.84rem;
    font-weight: 700;
    text-decoration: none;
}

.alarmflow-ui .af-sidebar-section-toggle {
    margin-top: 1rem;
    background: transparent;
    text-align: left;
}

.alarmflow-ui .af-sidebar-link:hover,
.alarmflow-ui .af-sidebar-link:focus-visible,
.alarmflow-ui .af-sidebar-collapse:hover,
.alarmflow-ui .af-sidebar-collapse:focus-visible,
.alarmflow-ui .af-sidebar-section-toggle:hover,
.alarmflow-ui .af-sidebar-section-toggle:focus-visible {
    background: var(--af-sidebar-hover);
    color: #fff;
}

.alarmflow-ui .af-sidebar-link:focus-visible,
.alarmflow-ui .af-sidebar-collapse:focus-visible,
.alarmflow-ui .af-sidebar-section-toggle:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--af-sidebar-active) 78%, white);
    outline-offset: 2px;
}

.alarmflow-ui .af-sidebar-link.is-active {
    border-color: rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.115);
    color: #fff;
    font-weight: 800;
    box-shadow: inset 3px 0 0 var(--af-sidebar-active);
}

.alarmflow-ui .af-sidebar-link.is-active::before {
    position: absolute;
    top: 0.54rem;
    bottom: 0.54rem;
    left: -0.72rem;
    width: 3px;
    border-radius: 999px;
    background: var(--af-sidebar-active);
    content: "";
}

.alarmflow-ui .af-sidebar-link-icon {
    display: inline-flex;
    width: 1.16rem;
    height: 1.16rem;
    flex: 0 0 1.16rem;
    align-items: center;
    justify-content: center;
    color: color-mix(in srgb, var(--af-sidebar-text) 88%, var(--af-sidebar-muted));
    transition: color var(--af-ease), opacity var(--af-ease);
}

.alarmflow-ui .af-sidebar-link-icon .af-inline-icon {
    --af-icon-size: 1.08rem;
}

.alarmflow-ui .af-sidebar-link:hover .af-sidebar-link-icon,
.alarmflow-ui .af-sidebar-link:focus-visible .af-sidebar-link-icon,
.alarmflow-ui .af-sidebar-collapse:hover .af-sidebar-link-icon,
.alarmflow-ui .af-sidebar-collapse:focus-visible .af-sidebar-link-icon,
.alarmflow-ui .af-sidebar-section-toggle:hover .af-sidebar-link-icon,
.alarmflow-ui .af-sidebar-section-toggle:focus-visible .af-sidebar-link-icon {
    color: #fff;
}

.alarmflow-ui .af-sidebar-link.is-active .af-sidebar-link-icon {
    color: var(--af-sidebar-active);
}

.alarmflow-ui .af-sidebar-collapsible-group {
    display: flex;
    flex-direction: column;
    gap: 0.16rem;
}

.alarmflow-ui .af-sidebar-section-caret {
    display: inline-flex;
    margin-left: auto;
    color: color-mix(in srgb, var(--af-sidebar-muted) 84%, white);
    transition: transform var(--af-ease), color var(--af-ease);
}

.alarmflow-ui .af-sidebar-section-caret .af-inline-icon {
    --af-icon-size: 0.86rem;
}

.alarmflow-ui .af-sidebar-section-caret.is-open {
    transform: rotate(180deg);
    color: #fff;
}

.alarmflow-ui .af-sidebar-link-label {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-sidebar-footer {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.03);
}

.alarmflow-ui .af-sidebar-version {
    margin: 0 0 0.42rem;
    padding: 0 0.56rem;
    color: color-mix(in srgb, var(--af-sidebar-muted) 72%, transparent);
    font-size: 0.66rem;
    font-weight: 620;
    line-height: 1;
}

.alarmflow-ui .af-sidebar-collapse {
    justify-content: flex-start;
    background: rgba(255, 255, 255, 0.035);
}

.alarmflow-ui .af-app-shell.is-sidebar-collapsed,
.af-sidebar-collapsed-preload .alarmflow-ui .af-app-shell {
    grid-template-columns: var(--af-sidebar-collapsed-width) minmax(0, 1fr);
}

.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-app-sidebar,
.af-sidebar-collapsed-preload .alarmflow-ui .af-app-sidebar {
    width: var(--af-sidebar-collapsed-width);
}

@media (min-width: 901px) {
    .alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-app-sidebar,
    .af-sidebar-collapsed-preload .alarmflow-ui .af-app-sidebar {
        overflow: visible;
    }
}

.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-logo-full,
.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-section-label,
.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-link-label,
.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-version,
.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-section-caret,
.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-site-switcher .af-site-control-copy,
.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-site-switcher .af-site-control-caret,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-logo-full,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-section-label,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-link-label,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-version,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-section-caret,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-site-switcher .af-site-control-copy,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-site-switcher .af-site-control-caret {
    display: none;
}

.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-logo-compact,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-logo-compact {
    display: block;
}

.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-brand,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-brand {
    min-height: 2.35rem;
}

.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-header,
.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-footer,
.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-site-switcher,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-header,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-footer,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-site-switcher {
    padding-inline: 0.62rem;
}

.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-site-switcher .af-site-control,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-site-switcher .af-site-control {
    min-height: 2.7rem;
    justify-content: center;
    padding-inline: 0;
}

.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-site-switcher .af-site-scope-panel,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-site-switcher .af-site-scope-panel {
    position: absolute;
    left: calc(100% + 0.5rem);
    top: 0;
    width: min(22rem, calc(100vw - 6rem));
    max-width: min(22rem, calc(100vw - 6rem));
    margin-top: 0;
    border-color: var(--af-control-border);
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.14);
}

.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-nav,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-nav {
    padding-inline: 0.54rem;
}

.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-link,
.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-collapse,
.alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-section-toggle,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-link,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-collapse,
.af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-section-toggle {
    justify-content: center;
    padding-inline: 0;
}

.alarmflow-ui .af-app-topbar {
    position: sticky;
    top: 0;
    z-index: 70;
    min-height: var(--af-topbar-height);
    border-bottom: 1px solid var(--af-control-border);
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(16px);
    box-shadow: 0 1px 0 rgba(16, 35, 61, 0.05), 0 10px 30px rgba(16, 35, 61, 0.035);
}

.alarmflow-ui .af-topbar-inner {
    display: flex;
    min-height: var(--af-topbar-height);
    align-items: center;
    justify-content: space-between;
    gap: 1.05rem;
    padding-block: 0.7rem;
}

@media (min-width: 901px) {
    .alarmflow-ui .af-app-topbar .af-topbar-inner.af-page-frame {
        max-width: none;
    }
}

.alarmflow-ui .af-topbar-left,
.alarmflow-ui .af-topbar-actions {
    display: flex;
    min-width: 0;
    align-items: center;
    gap: 0.74rem;
}

.alarmflow-ui .af-topbar-left {
    flex: 1 1 auto;
    max-width: min(48rem, 52vw);
}

.alarmflow-ui .af-topbar-actions {
    flex: 0 1 auto;
    justify-content: flex-end;
    margin-left: auto;
}

.alarmflow-ui .af-mobile-topbar-actions,
.alarmflow-ui .af-mobile-contextbar {
    display: none;
}

.alarmflow-ui .af-topbar-icon-button,
.alarmflow-ui .af-topbar-button,
.alarmflow-ui .af-site-control,
.alarmflow-ui .af-topbar-switch-site {
    display: inline-flex;
    min-height: 2.5rem;
    align-items: center;
    justify-content: center;
    border: 1px solid color-mix(in srgb, var(--af-control-border) 78%, white);
    border-radius: var(--af-radius-md);
    background: #fff;
    color: var(--af-navy);
    text-decoration: none;
    box-shadow: 0 1px 2px rgba(16, 35, 61, 0.035);
}

.alarmflow-ui .af-topbar-icon-button {
    width: 2.5rem;
    padding: 0;
}

.alarmflow-ui .af-topbar-menu-button {
    width: 3rem;
    min-height: 3rem;
    border-radius: 999px;
    color: var(--af-muted);
}

.alarmflow-ui .af-topbar-icon-button .af-inline-icon,
.alarmflow-ui .af-topbar-button .af-inline-icon,
.alarmflow-ui .af-site-control-icon .af-inline-icon {
    --af-icon-size: 1.04rem;
}

.alarmflow-ui .af-topbar-button {
    gap: 0.42rem;
    min-height: 2.85rem;
    padding: 0 0.84rem;
    font-size: 0.76rem;
    font-weight: 800;
}

.alarmflow-ui .af-system-status {
    position: relative;
    flex: 0 1 auto;
}

.alarmflow-ui .af-system-status-button {
    display: inline-flex;
    min-width: 12.5rem;
    max-width: 17rem;
    min-height: 2.85rem;
    align-items: center;
    gap: 0.5rem;
    border: 1px solid color-mix(in srgb, var(--af-info) 24%, var(--af-control-border));
    border-radius: var(--af-radius-md);
    background: color-mix(in srgb, var(--af-info) 6%, #fff);
    color: var(--af-navy);
    padding: 0 0.62rem;
    font-size: 0.76rem;
    font-weight: 840;
    box-shadow: 0 1px 2px rgba(16, 35, 61, 0.035);
}

.alarmflow-ui .af-system-status-button.is-live {
    border-color: color-mix(in srgb, var(--af-success) 28%, var(--af-control-border));
    background: color-mix(in srgb, var(--af-success) 8%, #fff);
}

.alarmflow-ui .af-system-status-button.is-warning {
    border-color: color-mix(in srgb, var(--af-warning) 42%, var(--af-control-border));
    background: color-mix(in srgb, var(--af-warning) 11%, #fff);
    color: color-mix(in srgb, var(--af-warning) 72%, var(--af-navy));
}

.alarmflow-ui .af-system-status-button.is-fault {
    border-color: color-mix(in srgb, var(--af-danger) 42%, var(--af-control-border));
    background: color-mix(in srgb, var(--af-danger) 8%, #fff);
    color: var(--af-danger);
}

.alarmflow-ui .af-system-status-button.is-open {
    box-shadow: 0 0 0 3px color-mix(in srgb, currentColor 10%, transparent);
}

.alarmflow-ui .af-system-status-icon,
.alarmflow-ui .af-system-status-caret {
    display: inline-flex;
    flex: 0 0 auto;
}

.alarmflow-ui .af-system-status-icon .af-inline-icon {
    --af-icon-size: 1.04rem;
}

.alarmflow-ui .af-system-status-caret {
    margin-left: auto;
    color: color-mix(in srgb, currentColor 58%, white);
}

.alarmflow-ui .af-system-status-caret .af-inline-icon {
    --af-icon-size: 0.88rem;
}

.alarmflow-ui .af-system-status-text {
    display: inline-flex;
    min-width: 0;
    align-items: baseline;
    gap: 0.28rem;
}

.alarmflow-ui .af-system-status-name,
.alarmflow-ui .af-system-status-value {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-system-status-name {
    color: var(--af-navy);
}

.alarmflow-ui .af-system-status-value {
    color: currentColor;
}

.alarmflow-ui .af-system-status-panel {
    position: absolute;
    top: calc(100% + 0.55rem);
    right: 0;
    z-index: 98;
    width: min(24rem, calc(100vw - 1.5rem));
    overflow: hidden;
    border: 1px solid var(--af-control-border);
    border-radius: var(--af-card-radius);
    background: var(--af-control-bg);
    color: var(--af-navy);
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.16);
}

.alarmflow-ui .af-system-status-section {
    padding: 0.86rem 0.92rem;
}

.alarmflow-ui .af-system-status-section + .af-system-status-section {
    border-top: 1px solid color-mix(in srgb, var(--af-control-border) 76%, white);
}

.alarmflow-ui .af-system-status-section-title {
    display: flex;
    align-items: center;
    gap: 0.42rem;
    margin-bottom: 0.62rem;
}

.alarmflow-ui .af-system-status-section-title h2 {
    margin: 0;
    font-size: 0.82rem;
    font-weight: 880;
}

.alarmflow-ui .af-system-status-section-title .af-inline-icon {
    --af-icon-size: 1rem;
    color: var(--af-info);
}

.alarmflow-ui .af-system-status-list {
    display: grid;
    gap: 0.46rem;
    margin: 0;
}

.alarmflow-ui .af-system-status-list div {
    display: grid;
    grid-template-columns: minmax(6.4rem, 0.72fr) minmax(0, 1fr);
    align-items: center;
    gap: 0.74rem;
}

.alarmflow-ui .af-system-status-list dt {
    color: var(--af-muted);
    font-size: 0.7rem;
    font-weight: 790;
}

.alarmflow-ui .af-system-status-list dd {
    min-width: 0;
    margin: 0;
    overflow: hidden;
    color: var(--af-navy);
    font-size: 0.76rem;
    font-weight: 820;
    text-align: right;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-system-status-dd-pill {
    justify-self: end;
    border-radius: 999px;
    padding: 0.14rem 0.48rem;
}

.alarmflow-ui .af-system-status-dd-pill.is-live {
    background: color-mix(in srgb, var(--af-success) 10%, #fff);
    color: color-mix(in srgb, var(--af-success) 62%, black);
}

.alarmflow-ui .af-system-status-dd-pill.is-fault {
    background: color-mix(in srgb, var(--af-danger) 8%, #fff);
    color: var(--af-danger);
}

.alarmflow-ui .af-system-status-deployment {
    background: color-mix(in srgb, var(--af-warning) 5%, #fff);
}

.alarmflow-ui .af-system-status-progress {
    display: grid;
    gap: 0.4rem;
    margin-bottom: 0.62rem;
}

.alarmflow-ui .af-system-status-progress-heading {
    display: flex;
    min-width: 0;
    align-items: center;
    justify-content: space-between;
    gap: 0.7rem;
    color: var(--af-navy);
    font-size: 0.76rem;
    font-weight: 840;
}

.alarmflow-ui .af-system-status-progress-heading > span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-system-status-progress-heading > strong {
    flex: 0 0 auto;
    color: color-mix(in srgb, var(--af-warning) 72%, var(--af-navy));
    font-size: 0.74rem;
}

.alarmflow-ui .af-system-status-progress-track {
    height: 0.42rem;
    overflow: hidden;
    border-radius: 999px;
    background: color-mix(in srgb, var(--af-control-border) 72%, white);
}

.alarmflow-ui .af-system-status-progress-track > span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: color-mix(in srgb, var(--af-info) 78%, var(--af-warning));
    transition: width 180ms ease;
}

.alarmflow-ui .af-system-status-progress p {
    margin: 0;
    overflow: hidden;
    color: var(--af-muted);
    font-size: 0.72rem;
    font-weight: 780;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-system-status-note {
    margin: 0.7rem 0 0;
    border-top: 1px solid color-mix(in srgb, var(--af-control-border) 70%, white);
    padding-top: 0.62rem;
    color: var(--af-muted);
    font-size: 0.72rem;
    line-height: 1.4;
}

.alarmflow-ui .af-system-status-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.46rem;
    border-top: 1px solid color-mix(in srgb, var(--af-control-border) 76%, white);
    padding: 0.62rem 0.72rem;
}

.alarmflow-ui .af-system-status-result {
    margin-right: auto;
    color: var(--af-muted);
    font-size: 0.72rem;
    font-weight: 780;
}

.alarmflow-ui .af-system-status-link {
    min-height: 2.12rem;
    padding-inline: 0.62rem;
    font-size: 0.7rem;
    text-decoration: none;
}

.alarmflow-ui .af-topbar-runtime-owner {
    display: flex;
    min-width: 13rem;
    max-width: min(45rem, 44vw);
    min-height: 3rem;
    flex: 1 1 27rem;
    align-items: center;
    gap: 0.52rem;
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--af-info) 18%, var(--af-control-border));
    border-radius: var(--af-radius-md);
    background: color-mix(in srgb, var(--af-info) 5%, #fff);
    padding: 0.34rem 0.46rem 0.34rem 0.58rem;
    color: var(--af-navy);
}

.alarmflow-ui .af-topbar-runtime-owner.is-active {
    border-color: color-mix(in srgb, var(--af-success) 24%, var(--af-control-border));
    background: color-mix(in srgb, var(--af-success) 7%, #fff);
}

.alarmflow-ui .af-topbar-runtime-owner.is-warning {
    border-color: color-mix(in srgb, var(--af-warning) 38%, var(--af-control-border));
    background: color-mix(in srgb, var(--af-warning) 10%, #fff);
}

.alarmflow-ui .af-topbar-runtime-owner.is-fault {
    border-color: color-mix(in srgb, var(--af-danger) 36%, var(--af-control-border));
    background: color-mix(in srgb, var(--af-danger) 8%, #fff);
}

.alarmflow-ui .af-topbar-runtime-icon {
    display: inline-flex;
    width: 2rem;
    height: 2rem;
    flex: 0 0 2rem;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: #fff;
    color: var(--af-info);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, currentColor 16%, transparent);
}

.alarmflow-ui .af-topbar-runtime-owner.is-active .af-topbar-runtime-icon {
    color: color-mix(in srgb, var(--af-success) 72%, black);
}

.alarmflow-ui .af-topbar-runtime-owner.is-warning .af-topbar-runtime-icon {
    color: color-mix(in srgb, var(--af-warning) 78%, black);
}

.alarmflow-ui .af-topbar-runtime-owner.is-fault .af-topbar-runtime-icon {
    color: var(--af-danger);
}

.alarmflow-ui .af-topbar-runtime-copy {
    display: grid;
    min-width: 6.5rem;
    max-width: 14rem;
    gap: 0.04rem;
}

.alarmflow-ui .af-topbar-runtime-kicker {
    color: var(--af-muted);
    font-size: 0.62rem;
    font-weight: 820;
    line-height: 1;
    text-transform: uppercase;
}

.alarmflow-ui .af-topbar-runtime-copy strong {
    overflow: hidden;
    color: var(--af-navy);
    font-size: 0.78rem;
    font-weight: 860;
    line-height: 1.15;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-topbar-runtime-chips,
.alarmflow-ui .af-topbar-runtime-actions {
    display: inline-flex;
    min-width: 0;
    align-items: center;
    gap: 0.38rem;
}

.alarmflow-ui .af-topbar-runtime-chips {
    flex: 1 1 auto;
    overflow: hidden;
}

.alarmflow-ui .af-topbar-runtime-chips .af-status-pill {
    flex: 0 1 auto;
    min-width: 0;
}

.alarmflow-ui .af-topbar-runtime-chips .af-status-pill span:last-child {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-runtime-mini-chip {
    display: inline-flex;
    min-height: 1.72rem;
    flex: 0 0 auto;
    align-items: center;
    border: 1px solid color-mix(in srgb, var(--af-control-border) 82%, white);
    border-radius: 999px;
    background: #fff;
    color: color-mix(in srgb, var(--af-muted) 78%, var(--af-navy));
    padding: 0 0.52rem;
    font-size: 0.68rem;
    font-weight: 820;
    white-space: nowrap;
}

.alarmflow-ui .af-runtime-mini-chip.is-success {
    border-color: color-mix(in srgb, var(--af-success) 24%, white);
    color: color-mix(in srgb, var(--af-success) 62%, black);
}

.alarmflow-ui .af-runtime-mini-chip.is-warning {
    border-color: color-mix(in srgb, var(--af-warning) 34%, white);
    color: color-mix(in srgb, var(--af-warning) 72%, black);
}

.alarmflow-ui .af-topbar-runtime-actions {
    flex: 0 0 auto;
}

.alarmflow-ui .af-runtime-check-button,
.alarmflow-ui .af-runtime-use-button {
    min-height: 2.12rem;
    padding-inline: 0.56rem;
    font-size: 0.7rem;
}

.alarmflow-ui .af-topbar-runtime-actions .af-runtime-owner-selector select {
    min-height: 2.12rem;
    max-width: 9.5rem;
    font-size: 0.7rem;
}

.alarmflow-ui .af-topbar-mobile-operator {
    width: 2.5rem;
    min-height: 2.5rem;
    border: 0;
    background: transparent;
    box-shadow: none;
    color: color-mix(in srgb, var(--af-info) 72%, var(--af-navy));
    padding: 0;
}

.alarmflow-ui .af-topbar-mobile-operator:hover {
    border: 0;
    background: transparent;
    color: color-mix(in srgb, var(--af-info) 86%, black);
}

.alarmflow-ui .af-topbar-mobile-operator .af-inline-icon {
    --af-icon-size: 1.22rem;
}

.alarmflow-ui .af-topbar-button strong {
    color: color-mix(in srgb, var(--af-success) 70%, black);
    font-weight: 850;
    text-transform: uppercase;
}

.alarmflow-ui .af-topbar-devmode {
    gap: 0.62rem;
    min-width: 8rem;
    border-color: color-mix(in srgb, var(--af-success) 24%, var(--af-control-border));
    color: color-mix(in srgb, var(--af-success) 52%, var(--af-navy));
}

.alarmflow-ui .af-topbar-devmode strong {
    display: inline-flex;
    min-width: 2.1rem;
    min-height: 1.5rem;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: color-mix(in srgb, var(--af-muted) 18%, white);
    color: var(--af-muted);
    font-size: 0.67rem;
}

.alarmflow-ui .af-topbar-devmode.is-on {
    border-color: color-mix(in srgb, var(--af-success) 38%, white);
    background: color-mix(in srgb, var(--af-success) 9%, white);
}

.alarmflow-ui .af-topbar-devmode.is-on strong {
    background: var(--af-success);
    color: #fff;
}

.alarmflow-ui .af-floating-devmode {
    position: fixed;
    right: calc(1rem + env(safe-area-inset-right));
    bottom: calc(1rem + env(safe-area-inset-bottom));
    z-index: 185;
    display: inline-flex;
    min-height: 2.85rem;
    align-items: center;
    justify-content: center;
    gap: 0.62rem;
    border: 1px solid color-mix(in srgb, var(--af-success) 24%, var(--af-control-border));
    border-radius: var(--af-radius-md);
    background: rgba(255, 255, 255, 0.96);
    color: color-mix(in srgb, var(--af-success) 52%, var(--af-navy));
    padding: 0 0.84rem;
    font-size: 0.76rem;
    font-weight: 800;
    text-decoration: none;
    box-shadow: 0 16px 38px rgba(16, 35, 61, 0.16);
    backdrop-filter: blur(16px);
}

.alarmflow-ui .af-floating-devmode:hover {
    border-color: color-mix(in srgb, var(--af-success) 36%, white);
    background: #fff;
}

.alarmflow-ui .af-floating-devmode:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--af-success) 58%, white);
    outline-offset: 3px;
}

.alarmflow-ui .af-floating-devmode .af-inline-icon {
    --af-icon-size: 1.04rem;
}

.alarmflow-ui .af-floating-devmode strong {
    display: inline-flex;
    min-width: 2.1rem;
    min-height: 1.5rem;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: color-mix(in srgb, var(--af-muted) 18%, white);
    color: var(--af-muted);
    font-size: 0.67rem;
    font-weight: 850;
    text-transform: uppercase;
}

.alarmflow-ui .af-floating-devmode.is-on {
    border-color: color-mix(in srgb, var(--af-success) 38%, white);
    background: color-mix(in srgb, var(--af-success) 9%, white);
}

.alarmflow-ui .af-floating-devmode.is-on strong {
    background: var(--af-success);
    color: #fff;
}

.alarmflow-ui .af-topbar-stop {
    min-width: 5.4rem;
    border-color: color-mix(in srgb, var(--af-danger) 68%, white);
    color: var(--af-danger);
    box-shadow: none;
}

.alarmflow-ui .af-topbar-stop.is-active {
    background: var(--af-danger);
    color: #fff;
}

.alarmflow-ui .af-site-control {
    gap: 0.68rem;
    width: clamp(13.75rem, 18vw, 15.6rem);
    min-height: 3rem;
    justify-content: flex-start;
    padding: 0.42rem 0.72rem;
}

.alarmflow-ui .af-site-control:focus-visible,
.alarmflow-ui .af-site-scope-row:focus-visible,
.alarmflow-ui .af-site-scope-footer a:focus-visible,
.alarmflow-ui .af-site-scope-search input:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--af-info) 62%, white);
    outline-offset: 2px;
}

.alarmflow-ui .af-site-control:hover,
.alarmflow-ui .af-topbar-icon-button:hover,
.alarmflow-ui .af-topbar-button:hover,
.alarmflow-ui .af-topbar-switch-site:hover {
    border-color: color-mix(in srgb, var(--af-info) 22%, var(--af-control-border));
    background: color-mix(in srgb, var(--af-surface) 44%, white);
}

.alarmflow-ui .af-site-scope {
    position: relative;
    flex: 0 0 auto;
}

.js .alarmflow-ui .af-site-scope-fallback,
.no-js .alarmflow-ui .af-site-scope {
    display: none;
}

.alarmflow-ui .af-site-scope-button[aria-expanded="true"] {
    border-color: color-mix(in srgb, var(--af-info) 34%, white);
    background: color-mix(in srgb, var(--af-info) 5%, white);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--af-info) 10%, transparent);
}

.alarmflow-ui .af-site-scope-badge {
    display: inline-flex;
    width: 2rem;
    height: 2rem;
    flex: 0 0 2rem;
    align-items: center;
    justify-content: center;
    border: 1px solid color-mix(in srgb, var(--af-info) 16%, white);
    border-radius: 999px;
    background: color-mix(in srgb, var(--af-info) 8%, white);
    color: color-mix(in srgb, var(--af-info) 62%, var(--af-navy));
    font-size: 0.68rem;
    font-weight: 900;
}

.alarmflow-ui .af-site-scope-badge.is-all {
    background: color-mix(in srgb, var(--af-surface) 62%, white);
    color: color-mix(in srgb, var(--af-muted) 78%, var(--af-navy));
}

.alarmflow-ui .af-site-scope-badge .af-inline-icon {
    --af-icon-size: 1.04rem;
}

.alarmflow-ui .af-site-scope-panel {
    position: absolute;
    top: calc(100% + 0.5rem);
    left: 0;
    z-index: 95;
    width: min(23rem, calc(100vw - 2rem));
    overflow: hidden;
    border: 1px solid var(--af-control-border);
    border-radius: var(--af-card-radius);
    background: var(--af-control-bg);
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.14);
}

.alarmflow-ui .af-site-scope-header {
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 76%, white);
    padding: 0.72rem 0.82rem;
}

.alarmflow-ui .af-site-scope-header h2 {
    margin: 0;
    color: var(--af-navy);
    font-size: 0.82rem;
    font-weight: 850;
}

.alarmflow-ui .af-site-scope-search {
    display: block;
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 76%, white);
    padding: 0.62rem 0.72rem;
}

.alarmflow-ui .af-site-scope-search input {
    width: 100%;
    min-height: 2.25rem;
    padding-inline: 0.68rem;
    font-size: 0.76rem;
}

.alarmflow-ui .af-site-scope-list {
    max-height: min(22rem, calc(100vh - 13rem));
    overflow: auto;
    padding: 0.34rem;
}

.alarmflow-ui .af-site-scope-row {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) 1.25rem;
    align-items: center;
    gap: 0.62rem;
    min-height: 3.62rem;
    border-radius: var(--af-control-radius);
    padding: 0.48rem 0.5rem;
    color: var(--af-navy);
    text-decoration: none;
}

.alarmflow-ui .af-site-scope-row:hover {
    background: color-mix(in srgb, var(--af-surface) 62%, white);
}

.alarmflow-ui .af-site-scope-row.is-active {
    background: color-mix(in srgb, var(--af-info) 7%, white);
}

.alarmflow-ui .af-site-scope-row-copy {
    display: grid;
    min-width: 0;
    gap: 0.1rem;
}

.alarmflow-ui .af-site-scope-row-title {
    overflow: hidden;
    font-size: 0.82rem;
    font-weight: 820;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-site-scope-row-meta {
    overflow: hidden;
    color: var(--af-muted);
    font-size: 0.7rem;
    font-weight: 700;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-site-scope-check {
    display: inline-flex;
    justify-content: center;
    color: color-mix(in srgb, var(--af-info) 72%, black);
}

.alarmflow-ui .af-site-scope-check .af-inline-icon {
    --af-icon-size: 1rem;
}

.alarmflow-ui .af-site-scope-footer {
    display: flex;
    justify-content: space-between;
    gap: 0.4rem;
    border-top: 1px solid color-mix(in srgb, var(--af-control-border) 76%, white);
    padding: 0.52rem;
}

.alarmflow-ui .af-site-scope-footer a {
    display: inline-flex;
    min-height: 2.18rem;
    align-items: center;
    gap: 0.34rem;
    border-radius: var(--af-control-radius);
    padding: 0 0.48rem;
    color: var(--af-muted);
    font-size: 0.72rem;
    font-weight: 800;
    text-decoration: none;
}

.alarmflow-ui .af-site-scope-footer a:hover {
    background: color-mix(in srgb, var(--af-surface) 62%, white);
    color: var(--af-navy);
}

.alarmflow-ui .af-site-scope-footer .af-inline-icon {
    --af-icon-size: 0.95rem;
}

.alarmflow-ui .af-site-control-icon {
    display: inline-flex;
    width: 2rem;
    height: 2rem;
    flex: 0 0 2rem;
    align-items: center;
    justify-content: center;
    border: 1px solid color-mix(in srgb, var(--af-info) 18%, white);
    border-radius: 999px;
    background: color-mix(in srgb, var(--af-info) 8%, white);
    color: color-mix(in srgb, var(--af-muted) 78%, var(--af-navy));
}

.alarmflow-ui .af-site-control-caret {
    display: inline-flex;
    margin-left: auto;
    color: var(--af-muted);
}

.alarmflow-ui .af-site-control-caret .af-inline-icon,
.alarmflow-ui .af-topbar-user-caret .af-inline-icon {
    --af-icon-size: 0.9rem;
}

.alarmflow-ui .af-site-control-copy {
    display: grid;
    min-width: 0;
    gap: 0.04rem;
}

.alarmflow-ui .af-site-control-kicker {
    color: var(--af-muted);
    font-size: 0.66rem;
    font-weight: 760;
}

.alarmflow-ui .af-site-control-name {
    overflow: hidden;
    color: var(--af-navy);
    font-size: 0.88rem;
    font-weight: 850;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-topbar-switch-site {
    padding: 0 0.7rem;
    color: var(--af-muted);
    font-size: 0.74rem;
    font-weight: 800;
}

.alarmflow-ui .af-topbar-breadcrumbs {
    min-width: 0;
    border-left: 1px solid var(--af-control-border);
    padding-left: 0.75rem;
}

.alarmflow-ui .af-topbar-breadcrumbs ol {
    display: flex;
    min-width: 0;
    align-items: center;
    gap: 0.32rem;
    margin: 0;
    padding: 0;
    list-style: none;
}

.alarmflow-ui .af-topbar-breadcrumbs li {
    display: inline-flex;
    min-width: 0;
    align-items: center;
    color: var(--af-muted);
    font-size: 0.84rem;
    font-weight: 760;
}

.alarmflow-ui .af-topbar-breadcrumbs li + li::before {
    content: "/";
    margin-right: 0.32rem;
    color: color-mix(in srgb, var(--af-muted) 46%, white);
    font-weight: 700;
}

.alarmflow-ui .af-topbar-breadcrumbs a,
.alarmflow-ui .af-topbar-breadcrumbs li > span {
    display: inline-flex;
    min-width: 0;
    max-width: 13.5rem;
    min-height: 2rem;
    align-items: center;
    gap: 0.28rem;
    border-radius: var(--af-radius-sm);
    padding: 0 0.34rem;
    color: inherit;
    text-decoration: none;
}

.alarmflow-ui .af-topbar-breadcrumbs a:hover {
    background: color-mix(in srgb, var(--af-surface) 60%, white);
    color: var(--af-navy);
}

.alarmflow-ui .af-topbar-breadcrumbs a:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--af-info) 62%, white);
    outline-offset: 2px;
}

.alarmflow-ui .af-topbar-breadcrumbs .af-inline-icon {
    --af-icon-size: 0.92rem;
    flex: 0 0 auto;
}

.alarmflow-ui .af-topbar-breadcrumbs span span,
.alarmflow-ui .af-topbar-breadcrumbs a span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-topbar-breadcrumbs li.is-current {
    flex: 1 1 auto;
    color: var(--af-navy);
    font-weight: 860;
}

.alarmflow-ui .af-topbar-separator {
    width: 1px;
    height: 2rem;
    background: var(--af-control-border);
}

.alarmflow-ui .af-topbar-metric {
    display: inline-flex;
    min-height: 3rem;
    align-items: center;
    gap: 0.52rem;
    color: var(--af-navy);
}

.alarmflow-ui .af-topbar-metric-icon {
    display: inline-flex;
    width: var(--af-icon-chip-sm-size);
    height: var(--af-icon-chip-sm-size);
    flex: 0 0 var(--af-icon-chip-sm-size);
    align-items: center;
    justify-content: center;
    border: 1px solid color-mix(in srgb, var(--af-info) 26%, white);
    border-radius: 999px;
    background: color-mix(in srgb, var(--af-info) 8%, white);
    color: var(--af-info);
}

.alarmflow-ui .af-topbar-metric-icon .af-inline-icon {
    --af-icon-size: 1rem;
}

.alarmflow-ui .af-topbar-metric-icon.is-success {
    border-color: color-mix(in srgb, var(--af-success) 30%, white);
    background: color-mix(in srgb, var(--af-success) 10%, white);
    color: color-mix(in srgb, var(--af-success) 72%, black);
}

.alarmflow-ui .af-topbar-metric-copy {
    display: grid;
    min-width: 0;
    gap: 0.04rem;
}

.alarmflow-ui .af-topbar-metric-label {
    color: var(--af-muted);
    font-size: 0.66rem;
    font-weight: 760;
}

.alarmflow-ui .af-topbar-metric strong {
    color: color-mix(in srgb, var(--af-success) 58%, var(--af-navy));
    font-size: 0.8rem;
    font-weight: 850;
    white-space: nowrap;
}

.alarmflow-ui .af-topbar-user {
    display: inline-flex;
    min-width: 0;
    max-width: 15rem;
    min-height: 2.85rem;
    align-items: center;
    gap: 0.42rem;
    border: 1px solid color-mix(in srgb, var(--af-control-border) 78%, white);
    border-radius: var(--af-radius-md);
    background: #fff;
    padding: 0.2rem 0.52rem 0.2rem 0.24rem;
    color: var(--af-navy);
    cursor: pointer;
    box-shadow: 0 1px 2px rgba(16, 35, 61, 0.035);
}

.alarmflow-ui .af-topbar-avatar {
    display: inline-flex;
    width: 2.35rem;
    height: 2.35rem;
    flex: 0 0 2.35rem;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: var(--af-navy);
    color: #fff;
    font-size: 0.78rem;
    font-weight: 850;
}

.alarmflow-ui .af-topbar-user-caret {
    display: inline-flex;
    color: var(--af-muted);
}

.alarmflow-ui .af-topbar-user-label {
    overflow: hidden;
    color: var(--af-muted);
    font-size: 0.76rem;
    font-weight: 760;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-account-menu {
    position: relative;
}

.alarmflow-ui .af-topbar-user:hover,
.alarmflow-ui .af-topbar-user[aria-expanded="true"] {
    border-color: color-mix(in srgb, var(--af-info) 22%, var(--af-control-border));
    background: color-mix(in srgb, var(--af-surface) 44%, white);
}

.alarmflow-ui .af-topbar-user:focus-visible {
    outline: 2px solid color-mix(in srgb, var(--af-info) 62%, white);
    outline-offset: 2px;
}

.alarmflow-ui .af-topbar-user[aria-expanded="true"] .af-topbar-user-caret {
    transform: rotate(180deg);
}

.alarmflow-ui .af-account-menu-panel {
    position: absolute;
    top: calc(100% + 0.52rem);
    right: 0;
    z-index: 96;
    width: min(20.5rem, calc(100vw - 1rem));
    overflow: hidden;
    border: 1px solid var(--af-control-border);
    border-radius: var(--af-card-radius);
    background: var(--af-control-bg);
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.16);
}

.alarmflow-ui .af-account-menu-identity {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 0.62rem;
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 76%, white);
    padding: 0.78rem;
}

.alarmflow-ui .af-account-menu-copy {
    display: grid;
    min-width: 0;
    gap: 0.06rem;
}

.alarmflow-ui .af-account-menu-copy strong,
.alarmflow-ui .af-account-menu-copy small,
.alarmflow-ui .af-account-menu-site strong,
.alarmflow-ui .af-account-menu-site small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-account-menu-copy strong,
.alarmflow-ui .af-account-menu-site strong {
    color: var(--af-navy);
    font-size: 0.84rem;
    font-weight: 860;
}

.alarmflow-ui .af-account-menu-copy small,
.alarmflow-ui .af-account-menu-site small {
    color: var(--af-muted);
    font-size: 0.7rem;
    font-weight: 760;
}

.alarmflow-ui .af-account-role-list {
    grid-column: 1 / -1;
    display: flex;
    flex-wrap: wrap;
    gap: 0.28rem;
}

.alarmflow-ui .af-account-role-badge {
    display: inline-flex;
    min-height: 1.35rem;
    align-items: center;
    border-radius: 999px;
    background: color-mix(in srgb, var(--af-info) 8%, white);
    color: color-mix(in srgb, var(--af-info) 62%, var(--af-navy));
    padding: 0 0.48rem;
    font-size: 0.64rem;
    font-weight: 850;
}

.alarmflow-ui .af-account-menu-site {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 0.54rem;
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 76%, white);
    padding: 0.62rem 0.78rem;
}

.alarmflow-ui .af-account-menu-site > span:first-child {
    display: inline-flex;
    width: 2rem;
    height: 2rem;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: color-mix(in srgb, var(--af-surface) 72%, white);
    color: var(--af-muted);
}

.alarmflow-ui .af-account-menu-section {
    padding: 0.32rem;
}

.alarmflow-ui .af-account-menu-section + .af-account-menu-section {
    border-top: 1px solid color-mix(in srgb, var(--af-control-border) 76%, white);
}

.alarmflow-ui .af-account-menu-item {
    display: flex;
    width: 100%;
    min-height: 2.55rem;
    align-items: center;
    gap: 0.56rem;
    border: 0;
    border-radius: var(--af-control-radius);
    background: transparent;
    color: var(--af-navy);
    padding: 0 0.58rem;
    font-size: 0.8rem;
    font-weight: 800;
    text-align: left;
    text-decoration: none;
}

.alarmflow-ui .af-account-menu-item:hover,
.alarmflow-ui .af-account-menu-item:focus-visible {
    background: color-mix(in srgb, var(--af-surface) 62%, white);
    color: var(--af-navy);
    outline: none;
}

.alarmflow-ui .af-account-menu-item:focus-visible {
    box-shadow: inset 3px 0 0 var(--af-info);
}

.alarmflow-ui .af-account-menu-item .af-inline-icon {
    --af-icon-size: 1rem;
    flex: 0 0 auto;
    color: var(--af-muted);
}

.alarmflow-ui .af-mobile-overflow {
    position: relative;
}

.alarmflow-ui .af-mobile-overflow-menu {
    position: absolute;
    top: calc(100% + 0.5rem);
    right: 0;
    z-index: 96;
    width: min(18rem, calc(100vw - 1rem));
    overflow: hidden;
    border: 1px solid var(--af-control-border);
    border-radius: var(--af-card-radius);
    background: var(--af-control-bg);
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.16);
}

.alarmflow-ui .af-mobile-overflow-account {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 0.62rem;
    border-bottom: 1px solid color-mix(in srgb, var(--af-control-border) 76%, white);
    padding: 0.72rem;
}

.alarmflow-ui .af-mobile-overflow-account span:last-child {
    display: grid;
    min-width: 0;
    gap: 0.05rem;
}

.alarmflow-ui .af-mobile-overflow-account strong,
.alarmflow-ui .af-mobile-overflow-account small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-mobile-overflow-account strong {
    color: var(--af-navy);
    font-size: 0.82rem;
    font-weight: 850;
}

.alarmflow-ui .af-mobile-overflow-account small {
    color: var(--af-muted);
    font-size: 0.68rem;
    font-weight: 760;
}

.alarmflow-ui .af-mobile-overflow-item {
    display: flex;
    width: 100%;
    min-height: 2.75rem;
    align-items: center;
    gap: 0.58rem;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: var(--af-navy);
    padding: 0 0.82rem;
    font-size: 0.82rem;
    font-weight: 800;
    text-align: left;
    text-decoration: none;
}

.alarmflow-ui .af-mobile-overflow-item:hover,
.alarmflow-ui .af-mobile-overflow-item:focus-visible {
    background: color-mix(in srgb, var(--af-surface) 62%, white);
    color: var(--af-navy);
    outline: none;
}

.alarmflow-ui .af-mobile-overflow-item:focus-visible {
    box-shadow: inset 3px 0 0 var(--af-info);
}

.alarmflow-ui .af-mobile-overflow-item .af-inline-icon {
    width: 1.02rem;
    height: 1.02rem;
    flex: 0 0 1.02rem;
    color: var(--af-muted);
}

.alarmflow-ui .af-mobile-overflow-danger {
    color: var(--af-danger);
}

.alarmflow-ui .af-mobile-overflow-danger .af-inline-icon {
    color: var(--af-danger);
}

.alarmflow-ui .af-shell-alert {
    display: grid;
    gap: 0.55rem;
    padding-top: 0.75rem;
}

.alarmflow-ui .af-main-content,
.alarmflow-ui .af-public-main {
    min-width: 0;
    padding-top: var(--af-page-space-top);
    padding-bottom: var(--af-page-space-bottom);
}

.alarmflow-ui .af-sidebar-backdrop {
    position: fixed;
    inset: 0;
    z-index: 80;
    display: none;
    border: 0;
    background: rgba(8, 18, 36, 0.52);
}

@media (max-width: 1180px) {
    .alarmflow-ui .af-topbar-inner {
        gap: 0.62rem;
    }

    .alarmflow-ui .af-topbar-left {
        flex-basis: 18rem;
        max-width: 42vw;
    }

    .alarmflow-ui .af-topbar-runtime-owner {
        flex-basis: 19rem;
        max-width: 38vw;
    }

    .alarmflow-ui .af-topbar-runtime-copy {
        max-width: 9rem;
    }

    .alarmflow-ui .af-topbar-runtime-chips .af-status-pill {
        max-width: 8.5rem;
    }

    .alarmflow-ui .af-topbar-mobile-operator span,
    .alarmflow-ui .af-topbar-devmode > span,
    .alarmflow-ui .af-topbar-user-label,
    .alarmflow-ui .af-topbar-user-caret,
    .alarmflow-ui .af-runtime-check-button span,
    .alarmflow-ui .af-runtime-use-button span {
        display: none;
    }

    .alarmflow-ui .af-system-status-button {
        min-width: 9.6rem;
        max-width: 11.5rem;
    }

    .alarmflow-ui .af-system-status-name {
        display: none;
    }

    .alarmflow-ui .af-system-status-text::before {
        content: "Status";
        color: var(--af-navy);
    }
}

@media (min-width: 901px) {
    .alarmflow-ui .af-topbar-left > .af-topbar-icon-button {
        display: none;
    }

    .alarmflow-ui.af-mobile-mode {
        background: var(--af-surface);
    }

    .alarmflow-ui.af-mobile-mode .af-app-workspace {
        background:
            linear-gradient(180deg, rgba(245, 245, 245, 0.96), rgba(238, 241, 245, 0.96));
    }

    .alarmflow-ui.af-mobile-mode .af-mobile-preview-shell {
        display: flex;
        min-height: 100dvh;
        flex-direction: column;
        align-items: center;
        gap: 1rem;
        padding: 1.25rem;
    }

    .alarmflow-ui.af-mobile-mode .af-mobile-preview-toolbar {
        display: flex;
        width: min(30rem, 100%);
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        color: var(--af-navy);
    }

    .alarmflow-ui.af-mobile-mode .af-mobile-preview-toolbar div {
        display: grid;
        gap: 0.12rem;
        min-width: 0;
    }

    .alarmflow-ui.af-mobile-mode .af-mobile-preview-toolbar div > span {
        color: var(--af-muted);
        font-size: 0.72rem;
        font-weight: 850;
        text-transform: uppercase;
    }

    .alarmflow-ui.af-mobile-mode .af-mobile-preview-toolbar strong {
        overflow: hidden;
        font-size: 1rem;
        font-weight: 850;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .alarmflow-ui.af-mobile-mode .af-mobile-preview-toolbar a {
        display: inline-flex;
        min-height: 2.45rem;
        flex: 0 0 auto;
        align-items: center;
        gap: 0.42rem;
        border: 1px solid var(--af-control-border);
        border-radius: var(--af-radius-md);
        background: #fff;
        padding: 0 0.72rem;
        color: var(--af-navy);
        font-size: 0.74rem;
        font-weight: 820;
        text-decoration: none;
    }

    .alarmflow-ui.af-mobile-mode .af-mobile-device-frame {
        width: min(30rem, 100%);
        min-height: auto;
        overflow: hidden;
        border: 1px solid color-mix(in srgb, var(--af-control-border) 82%, white);
        border-radius: 1.35rem;
        background: #fff;
        box-shadow: 0 24px 80px rgba(16, 35, 61, 0.18);
    }

}

@media (max-width: 900px) {
    .alarmflow-ui .af-site-scope-panel {
        width: min(23rem, calc(100vw - 1rem));
    }

    .alarmflow-ui .af-app-shell,
    .alarmflow-ui .af-app-shell.is-sidebar-collapsed,
    .af-sidebar-collapsed-preload .alarmflow-ui .af-app-shell {
        display: block;
    }

    .alarmflow-ui .af-app-sidebar,
    .alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-app-sidebar,
    .af-sidebar-collapsed-preload .alarmflow-ui .af-app-sidebar {
        position: fixed;
        top: 0;
        bottom: 0;
        left: 0;
        z-index: 100;
        width: min(19rem, calc(100vw - 2rem));
        height: 100dvh;
        transform: translateX(-105%);
        transition: transform 180ms ease;
    }

    .alarmflow-ui .af-app-sidebar.is-mobile-open {
        transform: translateX(0);
    }

    .alarmflow-ui .af-sidebar-backdrop {
        display: block;
    }

    .alarmflow-ui .af-sidebar-close {
        display: inline-flex;
        width: 2.35rem;
        height: 2.35rem;
        align-items: center;
        justify-content: center;
        border: 1px solid rgba(255, 255, 255, 0.14);
        border-radius: var(--af-radius-md);
        background: rgba(255, 255, 255, 0.06);
        color: #fff;
    }

    .alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-logo-full,
    .af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-logo-full {
        display: block;
    }

    .alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-logo-compact,
    .af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-logo-compact {
        display: none;
    }

    .alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-section-label,
    .alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-link-label,
    .af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-section-label,
    .af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-link-label {
        display: block;
    }

    .alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-section-caret,
    .af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-section-caret {
        display: inline-flex;
    }

    .alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-site-switcher .af-site-control-copy,
    .af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-site-switcher .af-site-control-copy {
        display: grid;
    }

    .alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-site-switcher .af-site-control-caret,
    .af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-site-switcher .af-site-control-caret {
        display: inline-flex;
    }

    .alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-link,
    .alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-collapse,
    .alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-section-toggle,
    .alarmflow-ui .af-app-shell.is-sidebar-collapsed .af-sidebar-site-switcher .af-site-control,
    .af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-link,
    .af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-collapse,
    .af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-section-toggle,
    .af-sidebar-collapsed-preload .alarmflow-ui .af-sidebar-site-switcher .af-site-control {
        justify-content: flex-start;
        padding-inline: 0.72rem;
    }

    .alarmflow-ui .af-app-topbar {
        min-height: auto;
    }

    .alarmflow-ui .af-topbar-inner {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        grid-template-areas:
            "primary mobile-actions"
            "context context";
        align-items: center;
        justify-content: stretch;
        gap: 0.48rem 0.5rem;
        min-height: auto;
        padding-block: 0.46rem 0.42rem;
    }

    .alarmflow-ui .af-topbar-left {
        grid-area: primary;
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        align-items: center;
        gap: 0.5rem;
        width: auto;
        overflow: hidden;
    }

    .alarmflow-ui .af-topbar-runtime-owner {
        display: none;
    }

    .alarmflow-ui .af-mobile-topbar-actions {
        display: flex;
        grid-area: mobile-actions;
        align-items: center;
        justify-content: flex-end;
        gap: 0.35rem;
    }

    .alarmflow-ui .af-mobile-contextbar {
        display: grid;
        grid-area: context;
        grid-template-columns: minmax(0, 1fr) auto auto;
        align-items: center;
        gap: 0.46rem;
        border-top: 1px solid color-mix(in srgb, var(--af-control-border) 72%, white);
        padding-top: 0.42rem;
    }

    .alarmflow-ui .af-mobile-page-title {
        overflow: hidden;
        color: var(--af-navy);
        font-size: 0.94rem;
        font-weight: 850;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .alarmflow-ui .af-mobile-runtime-status {
        display: inline-flex;
        min-height: 2rem;
        align-items: center;
        gap: 0.36rem;
        color: var(--af-muted);
        font-size: 0.76rem;
        font-weight: 850;
        white-space: nowrap;
    }

    .alarmflow-ui .af-system-status--mobile .af-system-status-button {
        min-width: 0;
        max-width: 11rem;
        min-height: 2rem;
        border-radius: 999px;
        padding: 0 0.48rem;
        font-size: 0.7rem;
    }

    .alarmflow-ui .af-system-status--mobile .af-system-status-name,
    .alarmflow-ui .af-system-status--mobile .af-system-status-caret {
        display: none;
    }

    .alarmflow-ui .af-system-status--mobile .af-system-status-text::before {
        content: "Status";
        color: var(--af-navy);
    }

    .alarmflow-ui .af-system-status--mobile .af-system-status-value {
        max-width: 6.8rem;
    }

    .alarmflow-ui .af-system-status--mobile .af-system-status-panel {
        right: 0;
        width: min(22rem, calc(100vw - 1rem));
    }

    .alarmflow-ui .af-mobile-site-pill,
    .alarmflow-ui .af-mobile-owner-chip {
        display: inline-flex;
        min-width: 0;
        min-height: 2rem;
        align-items: center;
        gap: 0.34rem;
        border: 1px solid color-mix(in srgb, var(--af-control-border) 78%, white);
        border-radius: 999px;
        background: #fff;
        color: var(--af-muted);
        padding: 0 0.48rem 0 0.2rem;
        font-size: 0.7rem;
        font-weight: 820;
        white-space: nowrap;
    }

    .alarmflow-ui .af-mobile-site-pill span:last-child {
        overflow: hidden;
        max-width: 9rem;
        text-overflow: ellipsis;
    }

    .alarmflow-ui .af-mobile-site-pill .af-site-scope-badge {
        width: 1.46rem;
        height: 1.46rem;
        flex-basis: 1.46rem;
        font-size: 0.56rem;
    }

    .alarmflow-ui .af-mobile-owner-chip {
        padding: 0 0.48rem;
    }

    .alarmflow-ui .af-mobile-owner-chip.is-active {
        border-color: color-mix(in srgb, var(--af-success) 26%, white);
        color: color-mix(in srgb, var(--af-success) 62%, black);
    }

    .alarmflow-ui .af-mobile-owner-chip.is-warning {
        border-color: color-mix(in srgb, var(--af-warning) 34%, white);
        background: color-mix(in srgb, var(--af-warning) 8%, #fff);
        color: color-mix(in srgb, var(--af-warning) 72%, black);
    }

    .alarmflow-ui .af-mobile-owner-chip.is-fault {
        border-color: color-mix(in srgb, var(--af-danger) 30%, white);
        background: color-mix(in srgb, var(--af-danger) 7%, #fff);
        color: var(--af-danger);
    }

    .alarmflow-ui .af-mobile-runtime-status.is-live {
        color: color-mix(in srgb, var(--af-success) 58%, var(--af-navy));
    }

    .alarmflow-ui .af-mobile-runtime-status.is-offline {
        color: color-mix(in srgb, var(--af-muted) 78%, var(--af-navy));
    }

    .alarmflow-ui .af-mobile-runtime-dot {
        width: 0.48rem;
        height: 0.48rem;
        flex: 0 0 0.48rem;
        border-radius: 999px;
        background: currentColor;
    }

    .alarmflow-ui .af-topbar-menu-button,
    .alarmflow-ui .af-mobile-topbar-actions .af-topbar-icon-button {
        width: 2.5rem;
        min-height: 2.5rem;
        border-radius: var(--af-radius-md);
    }

    .alarmflow-ui .af-mobile-alert-button {
        display: inline-flex;
    }

    .alarmflow-ui .af-site-scope,
    .alarmflow-ui .af-site-control {
        min-width: 0;
        width: 100%;
    }

    .alarmflow-ui .af-site-control {
        gap: 0.5rem;
        min-height: 2.5rem;
        padding: 0.32rem 0.5rem;
    }

    .alarmflow-ui .af-site-control-kicker {
        display: none;
    }

    .alarmflow-ui .af-site-scope-badge {
        width: 1.75rem;
        height: 1.75rem;
        flex-basis: 1.75rem;
        font-size: 0.62rem;
    }

    .alarmflow-ui .af-site-control-name {
        font-size: 0.78rem;
        line-height: 1.15;
    }

    .alarmflow-ui .af-site-control-caret {
        flex: 0 0 auto;
    }

    .alarmflow-ui .af-topbar-breadcrumbs {
        display: none;
    }

    .alarmflow-ui .af-topbar-actions {
        display: none;
    }
}

@media (max-width: 760px) {
    .alarmflow-ui .af-page-controller-fleet {
        max-width: 100%;
    }
}

@media (max-width: 520px) {
    .alarmflow-ui .af-page-frame {
        padding-inline: 0.75rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .alarmflow-ui .af-app-sidebar {
        transition: none;
    }
}

@media (max-width: 900px) {
    .no-js .alarmflow-ui .af-app-shell {
        display: block;
    }

    .no-js .alarmflow-ui .af-app-sidebar {
        position: static;
        width: auto;
        height: auto;
        max-height: none;
        transform: none;
    }

    .no-js .alarmflow-ui .af-app-workspace {
        min-height: 100vh;
    }
}

/* Perfected Sites mobile PWA visual pass: scoped to the mobile operator shell. */
.alarmflow-ui .af-mobile-operator {
    --afm-bg: #080a0d;
    --afm-surface: #12161b;
    --afm-surface-2: #191e24;
    --afm-surface-3: #20262d;
    --afm-border: rgba(255, 255, 255, 0.08);
    --afm-border-strong: rgba(255, 255, 255, 0.14);
    --afm-text: #f5f7fa;
    --afm-muted: #9ba4af;
    --afm-muted-2: #707a85;
    --afm-orange: #ff6a00;
    --afm-orange-2: #ff7a1a;
    --afm-green: #35d268;
    --afm-blue: #45a0ff;
    --afm-purple: #9868ff;
    --af-mobile-tabbar-clearance: 5.2rem;
    background: var(--afm-bg);
    color: var(--afm-text);
    overflow-x: hidden;
}

.alarmflow-ui.af-mobile-mode,
.alarmflow-ui.af-mobile-mode .af-app-workspace,
.alarmflow-ui .af-mobile-device-frame,
.alarmflow-ui .af-mobile-preview-shell {
    background: var(--afm-bg, #080a0d);
}

.alarmflow-ui .af-mobile-appbar {
    border-bottom-color: var(--afm-border);
    background: rgba(8, 10, 13, 0.96);
}

.alarmflow-ui .af-mobile-operator .af-mobile-appbar {
    position: absolute;
    inset: calc(env(safe-area-inset-top) + 0.55rem) 0.85rem auto auto;
    min-height: 2.35rem;
    border: 0;
    background: transparent;
    padding: 0;
    pointer-events: none;
}

.alarmflow-ui .af-mobile-operator .af-mobile-brand,
.alarmflow-ui .af-mobile-operator .af-mobile-bell[data-pwa-refresh] {
    display: none;
}

.alarmflow-ui .af-mobile-operator .af-mobile-appbar-actions {
    pointer-events: auto;
}

.alarmflow-ui .af-mobile-operator .af-mobile-bell {
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
}

.alarmflow-ui .af-mobile-brand,
.alarmflow-ui .af-mobile-bell,
.alarmflow-ui .af-mobile-site-select,
.alarmflow-ui .af-mobile-site-select strong {
    color: var(--afm-text);
}

.alarmflow-ui .af-mobile-brand span {
    max-width: 12rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-mobile-site-select {
    width: 100%;
    border: 0;
    border-radius: 0;
    background: transparent;
    padding: 0.42rem 0;
    font-size: 1.45rem;
}

.alarmflow-ui .af-mobile-site-select span {
    display: none;
}

.alarmflow-ui .af-mobile-site-select strong {
    font-size: 1.48rem;
    font-weight: 900;
}

.alarmflow-ui .af-mobile-site-select .af-inline-icon {
    color: var(--afm-muted);
}

.alarmflow-ui .af-mobile-operator .af-mobile-site-menu {
    width: 100%;
    max-width: 100%;
}

.alarmflow-ui .af-mobile-operator .af-mobile-site-select {
    min-height: 2.45rem;
    gap: 0.42rem;
    padding-right: 3.35rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-site-select strong {
    max-width: min(100%, 18rem);
    line-height: 1.08;
}

.alarmflow-ui .af-mobile-operator .af-mobile-site-select .af-inline-icon {
    width: 1rem;
    height: 1rem;
    flex: 0 0 auto;
    opacity: 0.72;
}

.alarmflow-ui .af-mobile-operator .af-mobile-site-panel {
    top: calc(100% + 0.38rem);
    width: 100%;
    min-width: 0;
    max-width: calc(100vw - 2rem);
    border-color: var(--afm-border-strong);
    border-radius: 8px;
    background: #0e1217;
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.48);
}

.alarmflow-ui .af-mobile-operator .af-mobile-site-list {
    max-height: min(17rem, 45vh);
}

.alarmflow-ui .af-mobile-operator .af-mobile-site-option {
    grid-template-columns: 2.15rem minmax(0, 1fr) 1.25rem;
    gap: 0.6rem;
    min-height: 4.1rem;
    border-bottom-color: var(--afm-border);
    background: transparent;
    padding: 0.66rem 0.72rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-site-option.is-active {
    background: color-mix(in srgb, var(--afm-orange) 8%, #0e1217);
    box-shadow: inset 3px 0 0 var(--afm-orange);
}

.alarmflow-ui .af-mobile-operator .af-mobile-site-option > span {
    width: 2.15rem;
    height: 2.15rem;
    border-radius: 8px;
    background: #f1f5fb;
    color: #1f5fbf;
    font-size: 0.72rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-site-option strong {
    color: var(--afm-text);
    font-size: 0.86rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-site-option small {
    color: var(--afm-muted);
}

.alarmflow-ui .af-mobile-operator .af-mobile-site-option > .af-inline-icon {
    width: 1.1rem;
    height: 1.1rem;
    align-self: center;
    justify-self: center;
    color: var(--afm-green);
}

.alarmflow-ui .af-mobile-operator .af-mobile-site-footer {
    border-top-color: var(--afm-border);
    background: #0b0e12;
    padding: 0.62rem 0.72rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-site-footer a {
    color: var(--afm-muted);
}

.alarmflow-ui .af-mobile-site-select span,
.alarmflow-ui .af-mobile-site-option small,
.alarmflow-ui .af-mobile-site-footer a,
.alarmflow-ui .af-mobile-pwa-status {
    color: var(--afm-muted);
}

.alarmflow-ui .af-mobile-site-panel {
    border-color: var(--afm-border-strong);
    background: #0d1014;
    box-shadow: 0 20px 44px rgba(0, 0, 0, 0.42);
}

.alarmflow-ui .af-mobile-site-search input,
.alarmflow-ui .af-mobile-search-field input,
.alarmflow-ui .af-mobile-settings-form input,
.alarmflow-ui .af-mobile-settings-form select,
.alarmflow-ui .af-mobile-schedule-time-inputs input,
.alarmflow-ui .af-mobile-claim-form input {
    border-color: var(--afm-border);
    background: var(--afm-surface-2);
    color: var(--afm-text);
}

.alarmflow-ui .af-mobile-site-search input::placeholder,
.alarmflow-ui .af-mobile-search-field input::placeholder,
.alarmflow-ui .af-mobile-settings-form input::placeholder {
    color: var(--afm-muted-2);
}

.alarmflow-ui .af-mobile-site-option,
.alarmflow-ui .af-mobile-site-footer {
    border-color: var(--afm-border);
}

.alarmflow-ui .af-mobile-site-option.is-active {
    background: color-mix(in srgb, var(--afm-orange) 16%, var(--afm-surface-2));
}

.alarmflow-ui .af-mobile-screen {
    gap: 0.72rem;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0) 11rem),
        var(--afm-bg);
}

.alarmflow-ui .af-mobile-card,
.alarmflow-ui .af-mobile-action-tile,
.alarmflow-ui .af-mobile-status-card {
    border-color: var(--afm-border);
    background: var(--afm-surface);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.24);
}

.alarmflow-ui .af-mobile-card-head {
    border-bottom-color: var(--afm-border);
}

.alarmflow-ui .af-mobile-card-head h2,
.alarmflow-ui .af-mobile-section-title,
.alarmflow-ui .af-mobile-status-card p,
.alarmflow-ui .af-mobile-today-schedule strong,
.alarmflow-ui .af-mobile-camera-strip-item strong,
.alarmflow-ui .af-mobile-event p,
.alarmflow-ui .af-mobile-control-row p,
.alarmflow-ui .af-mobile-node-row p,
.alarmflow-ui .af-mobile-settings-list strong,
.alarmflow-ui .af-mobile-member-row p,
.alarmflow-ui .af-mobile-schedule-period-head strong,
.alarmflow-ui .af-mobile-schedule-hero > p,
.alarmflow-ui .af-mobile-schedule-hero dd,
.alarmflow-ui .af-mobile-schedule-row p,
.alarmflow-ui .af-mobile-camera-title h2,
.alarmflow-ui .af-mobile-share-row p,
.alarmflow-ui .af-mobile-detail-list dd,
.alarmflow-ui .af-mobile-detail-hero strong {
    color: var(--afm-text);
}

.alarmflow-ui .af-mobile-page-head h2,
.alarmflow-ui .af-mobile-camera-detail-head h2 {
    font-size: 1.28rem;
    line-height: 1.1;
}

.alarmflow-ui .af-mobile-icon-link,
.alarmflow-ui button.af-mobile-icon-link {
    display: inline-flex;
    width: 2.25rem;
    height: 2.25rem;
    align-items: center;
    justify-content: center;
    border: 0;
    border-radius: 8px;
    background: transparent;
    color: var(--afm-text);
}

.alarmflow-ui .af-mobile-section-title {
    margin: 0.78rem 0.82rem 0.4rem;
    color: var(--afm-text);
    font-size: 0.88rem;
    font-weight: 850;
}

.alarmflow-ui .af-mobile-card-head a,
.alarmflow-ui .af-mobile-card-head a.af-mobile-icon-link,
.alarmflow-ui .af-mobile-card-head .af-inline-icon,
.alarmflow-ui .af-mobile-filterbar a.is-active {
    color: var(--afm-orange);
}

.alarmflow-ui .af-mobile-card-head > span,
.alarmflow-ui .af-mobile-status-card div > span,
.alarmflow-ui .af-mobile-today-schedule p,
.alarmflow-ui .af-mobile-today-schedule small,
.alarmflow-ui .af-mobile-camera-strip-item small,
.alarmflow-ui .af-mobile-event span,
.alarmflow-ui .af-mobile-event time,
.alarmflow-ui .af-mobile-event small,
.alarmflow-ui .af-mobile-empty,
.alarmflow-ui .af-mobile-io-summary,
.alarmflow-ui .af-mobile-member-row small,
.alarmflow-ui .af-mobile-settings-form label > span,
.alarmflow-ui .af-mobile-settings-form p,
.alarmflow-ui .af-mobile-schedule-summary,
.alarmflow-ui .af-mobile-schedule-next,
.alarmflow-ui .af-mobile-schedule-period-preview,
.alarmflow-ui .af-mobile-schedule-row small,
.alarmflow-ui .af-mobile-camera-title p,
.alarmflow-ui .af-mobile-camera-detail-head p,
.alarmflow-ui .af-mobile-share-row small,
.alarmflow-ui .af-mobile-detail-list dt,
.alarmflow-ui .af-mobile-detail-hero small {
    color: var(--afm-muted);
}

.alarmflow-ui .af-mobile-status-card {
    border-color: color-mix(in srgb, var(--afm-green) 22%, var(--afm-border));
    background: linear-gradient(135deg, rgba(53, 210, 104, 0.13), rgba(18, 22, 27, 0.98) 48%);
}

.alarmflow-ui .af-mobile-status-card.is-warning {
    border-color: color-mix(in srgb, var(--afm-orange) 34%, var(--afm-border));
    background: linear-gradient(135deg, rgba(255, 106, 0, 0.14), rgba(18, 22, 27, 0.98) 48%);
}

.alarmflow-ui .af-mobile-status-card.is-fault {
    border-color: color-mix(in srgb, var(--af-danger) 42%, var(--afm-border));
    background: linear-gradient(135deg, rgba(239, 68, 68, 0.14), rgba(18, 22, 27, 0.98) 48%);
}

.alarmflow-ui .af-mobile-status-card.is-inactive {
    border-color: var(--afm-border);
    background: var(--afm-surface);
}

.alarmflow-ui .af-mobile-status-card h1 {
    color: var(--afm-text);
    font-size: 1.42rem;
}

.alarmflow-ui .af-mobile-status-icon,
.alarmflow-ui .af-mobile-status-dot {
    color: var(--afm-green);
}

.alarmflow-ui .af-mobile-status-dot {
    background: currentColor;
    box-shadow: 0 0 0 4px color-mix(in srgb, currentColor 16%, transparent);
}

.alarmflow-ui .af-mobile-today-grid .af-mobile-health-stat {
    border-color: var(--afm-border);
    background: var(--afm-surface-2);
    grid-template-columns: minmax(0, 1fr);
    justify-items: start;
    text-align: left;
    gap: 0.28rem;
    padding: 0.62rem 0.5rem;
}

.alarmflow-ui .af-mobile-today-grid .af-mobile-health-stat + .af-mobile-health-stat {
    border-left-color: var(--afm-border);
}

.alarmflow-ui .af-mobile-health-stat span,
.alarmflow-ui .af-mobile-today-grid .af-mobile-health-stat span,
.alarmflow-ui .af-mobile-control-icon,
.alarmflow-ui .af-mobile-node-icon,
.alarmflow-ui .af-mobile-settings-list a > span,
.alarmflow-ui .af-mobile-settings-list button > span {
    color: var(--afm-orange);
}

.alarmflow-ui .af-mobile-today-grid .af-mobile-health-stat span {
    grid-row: auto;
    width: 1.55rem;
    height: 1.55rem;
}

.alarmflow-ui .af-mobile-today-grid .af-mobile-health-stat .af-inline-icon {
    width: 1.35rem;
    height: 1.35rem;
}

.alarmflow-ui .af-mobile-health-stat.is-online span,
.alarmflow-ui .af-mobile-today-grid .af-mobile-health-stat.is-online span,
.alarmflow-ui .af-mobile-control-row.is-active .af-mobile-control-icon,
.alarmflow-ui .af-mobile-node-row.is-active .af-mobile-node-icon {
    color: var(--afm-green);
}

.alarmflow-ui .af-mobile-health-stat strong,
.alarmflow-ui .af-mobile-today-grid .af-mobile-health-stat strong {
    color: var(--afm-text);
}

.alarmflow-ui .af-mobile-today-grid .af-mobile-health-stat strong {
    max-width: 100%;
    overflow-wrap: anywhere;
    font-size: 0.8rem;
    line-height: 1.08;
}

.alarmflow-ui .af-mobile-today-activity .af-mobile-event {
    grid-template-columns: 2.25rem minmax(0, 1fr) 4.6rem;
    align-items: center;
    column-gap: 0.55rem;
    padding: 0.5rem 0.72rem;
}

.alarmflow-ui .af-mobile-today-activity .af-mobile-event-icon {
    width: 1.9rem;
    height: 1.9rem;
}

.alarmflow-ui .af-mobile-today-activity .af-mobile-event p {
    font-size: 0.82rem;
}

.alarmflow-ui .af-mobile-today-activity .af-mobile-event small {
    display: none;
}

.alarmflow-ui .af-mobile-screen-today .af-mobile-camera-strip-thumb {
    max-height: 3.8rem;
}

.alarmflow-ui .af-mobile-screen-today .af-mobile-settings-list a {
    min-height: 3.15rem;
    padding-top: 0.46rem;
    padding-bottom: 0.46rem;
}

.alarmflow-ui .af-mobile-health-stat p,
.alarmflow-ui .af-mobile-today-grid .af-mobile-health-stat p {
    color: var(--afm-muted);
}

.alarmflow-ui .af-mobile-settings-list a,
.alarmflow-ui .af-mobile-settings-list button,
.alarmflow-ui .af-mobile-control-row,
.alarmflow-ui .af-mobile-node-row,
.alarmflow-ui .af-mobile-camera-card,
.alarmflow-ui .af-mobile-event,
.alarmflow-ui .af-mobile-share-row,
.alarmflow-ui .af-mobile-member-row,
.alarmflow-ui .af-mobile-schedule-row,
.alarmflow-ui .af-mobile-media-card,
.alarmflow-ui .af-mobile-rule-card {
    border-bottom-color: var(--afm-border);
    background: var(--afm-surface);
}

.alarmflow-ui .af-mobile-settings-list a,
.alarmflow-ui .af-mobile-settings-list button {
    grid-template-columns: 2.25rem minmax(0, 1fr) auto;
}

.alarmflow-ui .af-mobile-settings-list strong small {
    display: block;
    margin-top: 0.12rem;
    color: var(--afm-muted);
    font-size: 0.72rem;
    font-weight: 650;
}

.alarmflow-ui .af-mobile-settings-list a::after,
.alarmflow-ui .af-mobile-settings-list button::after {
    content: ">";
    color: var(--afm-muted-2);
    font-weight: 900;
}

.alarmflow-ui .af-mobile-settings-list form button::after,
.alarmflow-ui .af-mobile-action-row-list form > button::after {
    content: none;
}

.alarmflow-ui .af-mobile-grouped-list {
    gap: 0;
}

.alarmflow-ui .af-mobile-list-kicker {
    margin: 0;
    border-bottom: 1px solid var(--afm-border);
    background: #0d1014;
    color: var(--afm-muted);
    padding: 0.55rem 0.82rem 0.38rem;
    font-size: 0.72rem;
    font-weight: 850;
    text-transform: uppercase;
}

.alarmflow-ui .af-mobile-camera-strip {
    gap: 0.52rem;
    grid-auto-columns: minmax(5.8rem, 31%);
}

.alarmflow-ui .af-mobile-camera-strip-item {
    flex: 0 0 min(31%, 7rem);
    min-width: 5.8rem;
    color: var(--afm-text);
}

.alarmflow-ui .af-mobile-camera-strip-thumb {
    aspect-ratio: 16 / 9;
}

.alarmflow-ui .af-mobile-camera-strip-thumb,
.alarmflow-ui .af-mobile-camera-preview,
.alarmflow-ui .af-mobile-live-frame,
.alarmflow-ui .af-mobile-event-player,
.alarmflow-ui .af-mobile-event-playback {
    background: #05070a;
}

.alarmflow-ui .af-mobile-camera-card {
    grid-template-columns: minmax(7.4rem, 42%) minmax(0, 1fr);
    align-items: center;
    padding: 0.72rem;
}

.alarmflow-ui .af-mobile-camera-card.is-offline,
.alarmflow-ui .af-mobile-camera-card.is-unknown {
    opacity: 0.72;
}

.alarmflow-ui .af-mobile-camera-card.is-offline .af-mobile-camera-preview,
.alarmflow-ui .af-mobile-camera-card.is-unknown .af-mobile-camera-preview {
    filter: grayscale(1);
}

.alarmflow-ui .af-mobile-camera-preview {
    min-height: 5.8rem;
}

.alarmflow-ui .af-mobile-camera-pill,
.alarmflow-ui .af-mobile-schedule-status,
.alarmflow-ui .af-mobile-role-badge {
    border: 1px solid color-mix(in srgb, var(--afm-green) 28%, transparent);
    background: color-mix(in srgb, var(--afm-green) 13%, transparent);
    color: var(--afm-green);
}

.alarmflow-ui .af-mobile-camera-pill.is-offline,
.alarmflow-ui .af-mobile-camera-pill.is-unknown,
.alarmflow-ui .af-mobile-schedule-status.is-inactive {
    border-color: var(--afm-border);
    background: var(--afm-surface-3);
    color: var(--afm-muted);
}

.alarmflow-ui .af-mobile-mini-button,
.alarmflow-ui .af-mobile-control-state,
.alarmflow-ui .af-mobile-node-row > strong {
    border-color: var(--afm-border);
    background: var(--afm-surface-3);
    color: var(--afm-text);
}

.alarmflow-ui .af-mobile-mini-button.is-secondary,
.alarmflow-ui .af-mobile-primary-button {
    border-color: color-mix(in srgb, var(--afm-orange) 62%, transparent);
    background: linear-gradient(180deg, var(--afm-orange-2), var(--afm-orange));
    color: #fff;
}

.alarmflow-ui .af-mobile-camera-actions .af-mobile-mini-button.is-secondary {
    box-shadow: 0 8px 18px color-mix(in srgb, var(--afm-orange) 18%, transparent);
}

.alarmflow-ui .af-mobile-mini-button.is-danger {
    border-color: color-mix(in srgb, var(--af-danger) 42%, transparent);
    background: color-mix(in srgb, var(--af-danger) 18%, var(--afm-surface-2));
    color: #ffb4b4;
}

.alarmflow-ui .af-mobile-primary-button {
    width: 100%;
    min-height: 3rem;
    gap: 0.42rem;
    font-size: 0.9rem;
}

.alarmflow-ui .af-mobile-settings-form {
    border-top-color: var(--afm-border);
}

.alarmflow-ui .af-mobile-choice-stack {
    display: grid;
    gap: 0.5rem;
    min-width: 0;
    margin: 0;
    border: 0;
    padding: 0;
}

.alarmflow-ui .af-mobile-choice-stack legend {
    margin-bottom: 0.1rem;
    color: var(--afm-text);
    font-size: 0.92rem;
    font-weight: 850;
}

.alarmflow-ui .af-mobile-choice-card {
    display: grid;
    min-width: 0;
    grid-template-columns: 2.65rem minmax(0, 1fr) 1.25rem;
    align-items: center;
    column-gap: 0.72rem;
    row-gap: 0.14rem;
    border: 1px solid var(--afm-border);
    border-radius: 8px;
    background: var(--afm-surface-2);
    padding: 0.78rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-choice-card {
    padding: 0.66rem;
}

.alarmflow-ui .af-mobile-choice-card > span {
    display: inline-flex;
    width: 2.65rem;
    height: 2.65rem;
    grid-row: 1 / span 2;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: color-mix(in srgb, var(--afm-orange) 16%, transparent);
    color: var(--afm-orange);
}

.alarmflow-ui .af-mobile-choice-card strong {
    color: var(--afm-text);
    font-size: 0.9rem;
    font-weight: 850;
}

.alarmflow-ui .af-mobile-choice-card small {
    color: var(--afm-muted);
    font-size: 0.78rem;
    line-height: 1.25;
}

.alarmflow-ui .af-mobile-choice-card::after {
    content: "";
    width: 0.9rem;
    height: 0.9rem;
    grid-column: 3;
    grid-row: 1 / span 2;
    border: 2px solid var(--afm-muted-2);
    border-radius: 999px;
}

.alarmflow-ui .af-mobile-choice-card.is-selected,
.alarmflow-ui .af-mobile-choice-card:has(input:checked) {
    border-color: var(--afm-orange);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--afm-orange) 35%, transparent);
}

.alarmflow-ui .af-mobile-choice-card.is-disabled {
    opacity: 0.58;
}

.alarmflow-ui .af-mobile-choice-card.is-selected::after,
.alarmflow-ui .af-mobile-choice-card:has(input:checked)::after {
    border-color: var(--afm-orange);
    background: radial-gradient(circle at center, var(--afm-orange) 42%, transparent 48%);
}

.alarmflow-ui .af-mobile-segmented {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.18rem;
    border: 1px solid var(--afm-border);
    border-radius: 8px;
    background: #0d1014;
    padding: 0.18rem;
}

.alarmflow-ui .af-mobile-segmented span {
    min-height: 2.35rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 7px;
    color: var(--afm-muted);
    font-size: 0.82rem;
    font-weight: 820;
}

.alarmflow-ui .af-mobile-segmented .is-active {
    background: color-mix(in srgb, var(--afm-orange) 18%, var(--afm-surface-3));
    color: var(--afm-orange);
}

.alarmflow-ui .af-mobile-search-field {
    display: grid;
    grid-template-columns: 1.3rem minmax(0, 1fr);
    align-items: center;
    gap: 0.48rem;
    margin: 0.78rem 0.82rem 0.2rem;
    border: 1px solid var(--afm-border);
    border-radius: 8px;
    background: var(--afm-surface-2);
    padding: 0 0.72rem;
}

.alarmflow-ui .af-mobile-search-field > span {
    color: var(--afm-muted);
}

.alarmflow-ui .af-mobile-search-field input {
    min-height: 2.55rem;
    border: 0;
    background: transparent;
    padding: 0;
}

.alarmflow-ui .af-mobile-member-row {
    grid-template-columns: 2.5rem minmax(0, 1fr) auto;
}

.alarmflow-ui .af-mobile-member-avatar {
    display: inline-flex;
    width: 2.5rem;
    height: 2.5rem;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: linear-gradient(135deg, rgba(255, 106, 0, 0.8), rgba(69, 160, 255, 0.52));
    color: #fff;
    font-size: 0.9rem;
    font-weight: 900;
}

.alarmflow-ui .af-mobile-role-badge {
    border-radius: 999px;
    padding: 0.22rem 0.5rem;
    font-size: 0.66rem;
    font-weight: 850;
    white-space: nowrap;
}

.alarmflow-ui .af-mobile-online-dot {
    color: var(--afm-green) !important;
}

.alarmflow-ui .af-mobile-member-row form {
    grid-column: 2 / -1;
}

.alarmflow-ui .af-mobile-share-icon {
    display: inline-flex;
    width: 2.35rem;
    height: 2.35rem;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: color-mix(in srgb, var(--afm-orange) 14%, transparent);
    color: var(--afm-orange);
}

.alarmflow-ui .af-mobile-cta-pad {
    padding: 0.82rem;
}

.alarmflow-ui .af-mobile-schedule-mode {
    border-color: var(--afm-border);
    background: #0d1014;
}

.alarmflow-ui .af-mobile-schedule-mode > span,
.alarmflow-ui .af-mobile-schedule-mode label {
    color: var(--afm-muted);
}

.alarmflow-ui .af-mobile-schedule-mode > span.is-active,
.alarmflow-ui .af-mobile-schedule-mode label.is-active {
    background: var(--afm-surface-3);
    color: var(--afm-text);
    box-shadow: none;
}

.alarmflow-ui .af-mobile-schedule-hero,
.alarmflow-ui .af-mobile-schedule-period,
.alarmflow-ui .af-mobile-schedule-save {
    border-color: var(--afm-border);
    background: var(--afm-surface-2);
}

.alarmflow-ui .af-mobile-schedule-hero > div:first-child {
    background: linear-gradient(90deg, rgba(53, 210, 104, 0.86), rgba(53, 210, 104, 0.22));
}

.alarmflow-ui .af-mobile-schedule-next-card,
.alarmflow-ui .af-mobile-today-schedule-row {
    display: grid;
    grid-template-columns: 2.35rem minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.68rem;
    padding: 0.85rem;
    color: inherit;
    text-decoration: none;
}

.alarmflow-ui .af-mobile-schedule-next-card > span,
.alarmflow-ui .af-mobile-today-schedule-row > span:first-child {
    display: inline-flex;
    width: 2.35rem;
    height: 2.35rem;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: color-mix(in srgb, var(--afm-orange) 15%, transparent);
    color: var(--afm-orange);
}

.alarmflow-ui .af-mobile-schedule-next-card strong,
.alarmflow-ui .af-mobile-today-schedule-row strong {
    color: var(--afm-text);
    font-size: 0.94rem;
}

.alarmflow-ui .af-mobile-schedule-next-card p,
.alarmflow-ui .af-mobile-today-schedule-row p,
.alarmflow-ui .af-mobile-override-helper,
.alarmflow-ui .af-mobile-invite-helper {
    margin: 0.15rem 0 0;
    color: var(--afm-muted);
    font-size: 0.76rem;
}

.alarmflow-ui .af-mobile-schedule-actions form:nth-child(1) button,
.alarmflow-ui .af-mobile-schedule-actions form:nth-child(2) button {
    background: linear-gradient(180deg, var(--afm-orange-2), var(--afm-orange));
}

.alarmflow-ui .af-mobile-schedule-actions form:nth-child(3) button {
    background: linear-gradient(180deg, #35d268, #1f9c45);
}

.alarmflow-ui .af-mobile-schedule-list {
    border-top-color: var(--afm-border);
}

.alarmflow-ui .af-mobile-schedule-day strong {
    color: var(--afm-text);
}

.alarmflow-ui .af-mobile-schedule-day-track {
    background: var(--afm-surface-3);
}

.alarmflow-ui .af-mobile-schedule-day-track span {
    background: var(--afm-green);
}

.alarmflow-ui .af-mobile-schedule-day.is-overnight .af-mobile-schedule-day-track span {
    background: color-mix(in srgb, var(--afm-muted) 34%, var(--afm-surface-3));
}

.alarmflow-ui .af-mobile-schedule-day small {
    color: var(--afm-muted);
}

.alarmflow-ui .af-mobile-schedule-day.is-all_day small .af-inline-icon,
.alarmflow-ui .af-mobile-schedule-day.is-daytime small .af-inline-icon {
    color: var(--afm-orange);
}

.alarmflow-ui .af-mobile-schedule-row-meta strong,
.alarmflow-ui .af-mobile-schedule-row-meta span {
    background: color-mix(in srgb, var(--afm-orange) 13%, transparent);
    color: var(--afm-orange);
}

.alarmflow-ui .af-mobile-schedule-days label {
    border-color: var(--afm-border);
    background: var(--afm-surface-3);
    color: var(--afm-muted);
}

.alarmflow-ui .af-mobile-schedule-days label.is-selected {
    border-color: var(--afm-orange);
    background: color-mix(in srgb, var(--afm-orange) 18%, var(--afm-surface-2));
    color: var(--afm-orange);
}

.alarmflow-ui .af-mobile-filterbar {
    border-bottom-color: var(--afm-border);
}

.alarmflow-ui .af-mobile-camera-filterbar {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    overflow: hidden;
    border-bottom: 1px solid var(--afm-border);
    background: #0d1014;
    padding: 0.22rem;
}

.alarmflow-ui .af-mobile-filterbar a,
.alarmflow-ui .af-mobile-view-toggle,
.alarmflow-ui .af-mobile-view-toggle button {
    border-color: var(--afm-border);
    background: var(--afm-surface-2);
}

.alarmflow-ui .af-mobile-view-toggle button[aria-pressed="true"],
.alarmflow-ui .af-mobile-filterbar a.is-active {
    background: color-mix(in srgb, var(--afm-orange) 16%, var(--afm-surface-2));
    color: var(--afm-orange);
}

.alarmflow-ui .af-mobile-camera-filterbar a {
    justify-content: center;
    border-radius: 7px;
    text-align: center;
}

.alarmflow-ui .af-mobile-inbox-line,
.alarmflow-ui .af-mobile-all-reviewed-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.8rem;
    border-bottom: 1px solid var(--afm-border);
    padding: 0.72rem 0.95rem;
    color: var(--afm-muted);
    font-size: 0.78rem;
    text-decoration: none;
}

.alarmflow-ui .af-mobile-inbox-line strong,
.alarmflow-ui .af-mobile-all-reviewed-row span {
    color: var(--afm-text);
}

.alarmflow-ui #mobile-event-list .af-mobile-event-expanded {
    grid-template-columns: 6.1rem minmax(0, 1fr);
    margin: 0.62rem;
    border: 1px solid var(--afm-border);
    border-radius: 8px;
    padding: 0.56rem;
}

.alarmflow-ui #mobile-event-list .af-mobile-event-expanded time {
    display: none;
}

.alarmflow-ui .af-mobile-review-badge {
    display: inline-flex;
    width: max-content;
    margin-top: 0.28rem;
    border: 1px solid color-mix(in srgb, var(--afm-orange) 42%, transparent);
    border-radius: 6px;
    background: color-mix(in srgb, var(--afm-orange) 12%, transparent);
    color: var(--afm-orange);
    padding: 0.12rem 0.4rem;
    font-size: 0.64rem;
    font-weight: 850;
}

.alarmflow-ui .af-mobile-event-actions {
    display: grid;
    grid-column: 1 / -1;
    grid-template-columns: 1fr 0.82fr;
    gap: 0.48rem;
}

.alarmflow-ui .af-mobile-event-actions a {
    display: inline-flex;
    min-height: 2.35rem;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    border-radius: 8px;
    background: var(--afm-surface-3);
    color: var(--afm-text);
    font-size: 0.78rem;
    font-weight: 850;
    text-decoration: none;
}

.alarmflow-ui .af-mobile-event-actions a.is-primary {
    background: linear-gradient(180deg, var(--afm-orange-2), var(--afm-orange));
    color: #fff;
}

.alarmflow-ui .af-mobile-event-thumb-wrap,
.alarmflow-ui .af-mobile-event-thumb,
.alarmflow-ui .af-mobile-share-row img {
    background: #05070a;
}

.alarmflow-ui .af-mobile-response-backdrop {
    background: rgba(0, 0, 0, 0.68);
}

.alarmflow-ui .af-mobile-response-panel {
    border-color: var(--afm-border-strong);
    background: #101419;
}

.alarmflow-ui .af-mobile-response-panel {
    border-radius: 22px 22px 0 0;
}

.alarmflow-ui .af-mobile-sheet-handle {
    position: absolute;
    top: 0.72rem;
    left: 50%;
    width: 3.2rem;
    height: 0.26rem;
    transform: translateX(-50%);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.42);
}

.alarmflow-ui .af-mobile-response-head,
.alarmflow-ui .af-mobile-response-action {
    border-color: var(--afm-border);
}

.alarmflow-ui .af-mobile-response-action {
    background: var(--afm-surface-2);
    color: var(--afm-orange);
    text-decoration: none;
}

.alarmflow-ui .af-mobile-response-action.is-amber {
    border-color: color-mix(in srgb, var(--afm-orange) 45%, var(--afm-border));
    background: color-mix(in srgb, var(--afm-orange) 10%, var(--afm-surface-2));
    color: var(--afm-orange);
}

.alarmflow-ui .af-mobile-response-action:disabled {
    border-color: var(--afm-border);
    background: var(--afm-surface-2);
    color: var(--afm-muted-2);
}

.alarmflow-ui .af-mobile-response-head h2,
.alarmflow-ui .af-mobile-response-action strong {
    color: var(--afm-text);
}

.alarmflow-ui .af-mobile-response-head p,
.alarmflow-ui .af-mobile-response-action small {
    color: var(--afm-muted);
}

.alarmflow-ui .af-mobile-backlink {
    color: var(--afm-text);
}

.alarmflow-ui .af-mobile-backlink .af-inline-icon {
    transform: rotate(180deg);
}

.alarmflow-ui .af-mobile-camera-detail-top {
    display: grid;
    grid-template-columns: 2.45rem minmax(0, 1fr);
    align-items: center;
    gap: 0.42rem;
}

.alarmflow-ui .af-mobile-camera-detail-head {
    display: flex;
    min-width: 0;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
}

.alarmflow-ui .af-mobile-camera-detail-head p {
    margin: 0.1rem 0 0;
}

.alarmflow-ui .af-mobile-camera-preview-large {
    position: relative;
    min-height: 14.5rem;
    border-radius: 8px;
}

.alarmflow-ui .af-mobile-viewer-badge,
.alarmflow-ui .af-mobile-duration-badge,
.alarmflow-ui .af-mobile-viewer-fullscreen {
    position: absolute;
    z-index: 2;
    border: 1px solid var(--afm-border-strong);
    border-radius: 7px;
    background: rgba(0, 0, 0, 0.58);
    color: var(--afm-text);
    padding: 0.24rem 0.4rem;
    font-size: 0.72rem;
    font-weight: 850;
}

.alarmflow-ui .af-mobile-viewer-badge {
    top: 0.72rem;
    left: 0.72rem;
}

.alarmflow-ui .af-mobile-duration-badge,
.alarmflow-ui .af-mobile-viewer-fullscreen {
    right: 0.72rem;
    bottom: 0.72rem;
}

.alarmflow-ui .af-mobile-viewer-fullscreen {
    top: 0.72rem;
    bottom: auto;
}

.alarmflow-ui .af-mobile-carousel-dots {
    display: flex;
    justify-content: center;
    gap: 0.32rem;
    padding: 0.62rem 0 0.48rem;
}

.alarmflow-ui .af-mobile-carousel-dots span {
    width: 0.42rem;
    height: 0.42rem;
    border-radius: 999px;
    background: var(--afm-muted-2);
}

.alarmflow-ui .af-mobile-carousel-dots span.is-active {
    background: var(--afm-orange);
}

.alarmflow-ui .af-mobile-clip-strip {
    display: grid;
    grid-auto-columns: minmax(4.9rem, 1fr);
    grid-auto-flow: column;
    gap: 0.48rem;
    overflow-x: auto;
    padding: 0.25rem 0.72rem 0.72rem;
}

.alarmflow-ui .af-mobile-clip-strip a {
    min-width: 0;
    color: var(--afm-text);
    text-align: center;
    text-decoration: none;
}

.alarmflow-ui .af-mobile-clip-strip span {
    display: block;
    overflow: hidden;
    aspect-ratio: 16 / 10;
    border: 1px solid var(--afm-border);
    border-radius: 7px;
    background: #05070a;
}

.alarmflow-ui .af-mobile-clip-strip img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.alarmflow-ui .af-mobile-clip-strip .is-active span {
    border-color: var(--afm-orange);
}

.alarmflow-ui .af-mobile-clip-strip strong {
    display: block;
    margin-top: 0.28rem;
    overflow: hidden;
    color: var(--afm-text);
    font-size: 0.68rem;
    font-weight: 760;
    line-height: 1.15;
}

.alarmflow-ui .af-mobile-action-tiles {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    padding: 0.72rem;
}

.alarmflow-ui .af-mobile-action-tiles form {
    min-width: 0;
}

.alarmflow-ui .af-mobile-action-tiles .af-mobile-mini-button {
    width: 100%;
    min-height: 4.6rem;
    flex-direction: column;
    gap: 0.35rem;
}

.alarmflow-ui .af-mobile-timeline,
.alarmflow-ui .af-mobile-notes,
.alarmflow-ui .af-mobile-related-strip {
    border-top: 1px solid var(--afm-border);
    padding: 0.78rem;
}

.alarmflow-ui .af-mobile-timeline h2,
.alarmflow-ui .af-mobile-notes h2 {
    margin: 0 0 0.55rem;
    color: var(--afm-text);
    font-size: 0.86rem;
}

.alarmflow-ui .af-mobile-timeline div {
    display: grid;
    grid-template-columns: 3.8rem minmax(0, 1fr);
    gap: 0.45rem;
    color: var(--afm-muted);
    font-size: 0.75rem;
}

.alarmflow-ui .af-mobile-timeline strong {
    color: var(--afm-text);
}

.alarmflow-ui .af-mobile-timeline small {
    grid-column: 2;
}

.alarmflow-ui .af-mobile-notes p {
    margin: 0;
    color: var(--afm-muted);
    font-size: 0.78rem;
}

.alarmflow-ui .af-mobile-incident-bottom-bar {
    position: sticky;
    bottom: calc(var(--af-mobile-tabbar-clearance) + env(safe-area-inset-bottom));
    z-index: 10;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.48rem;
    padding: 0.2rem 0 0.4rem;
}

.alarmflow-ui .af-mobile-invite-helper {
    display: flex;
    gap: 0.45rem;
    align-items: flex-start;
}

.alarmflow-ui .af-mobile-tabbar {
    border-top-color: var(--afm-border);
    background: rgba(13, 16, 20, 0.96);
    box-shadow: 0 -16px 32px rgba(0, 0, 0, 0.24);
}

.alarmflow-ui .af-mobile-tabbar a {
    color: var(--afm-muted);
    text-decoration: none;
}

.alarmflow-ui .af-mobile-tabbar a.is-active {
    color: var(--afm-orange);
}

.alarmflow-ui .af-mobile-backlink .af-mobile-no-rotate {
    transform: none;
}

.alarmflow-ui .af-mobile-screen-schedule .af-mobile-card,
.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-card {
    box-shadow: none;
}

.alarmflow-ui .af-mobile-screen-schedule .af-mobile-schedule-card {
    padding-bottom: 0.7rem;
}

.alarmflow-ui .af-mobile-screen-schedule .af-mobile-page-head,
.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-camera-detail-top {
    margin-bottom: 0.2rem;
}

.alarmflow-ui .af-mobile-screen-schedule-edit {
    gap: 0.58rem;
    padding: 0 calc(0.82rem + env(safe-area-inset-right)) calc(var(--af-mobile-tabbar-clearance) + env(safe-area-inset-bottom) + 0.66rem) calc(0.82rem + env(safe-area-inset-left));
    background:
        radial-gradient(circle at 50% -8rem, rgba(255, 255, 255, 0.07), transparent 13rem),
        linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0) 11rem),
        var(--afm-bg);
    scroll-padding-bottom: calc(var(--af-mobile-tabbar-clearance) + env(safe-area-inset-bottom) + 0.66rem);
}

.alarmflow-ui .af-mobile-screen-schedule-edit ~ .af-mobile-tabbar {
    display: grid;
}

.alarmflow-ui .af-mobile-operator-schedule-edit .af-mobile-appbar,
.alarmflow-ui .af-mobile-screen-schedule-edit > .af-mobile-site-select,
.alarmflow-ui .af-mobile-screen-schedule-edit > .af-mobile-site-menu,
.alarmflow-ui .af-mobile-screen-schedule-edit > .af-mobile-pwa-status {
    display: none;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-camera-detail-top {
    position: sticky;
    top: 0;
    z-index: 12;
    grid-template-columns: 2.35rem minmax(0, 1fr);
    min-height: 3.35rem;
    margin: 0 calc(-0.82rem - env(safe-area-inset-right)) 0.12rem calc(-0.82rem - env(safe-area-inset-left));
    border-bottom: 1px solid rgba(255, 255, 255, 0.055);
    background: rgba(8, 10, 13, 0.86);
    padding: calc(env(safe-area-inset-top) + 0.4rem) calc(0.82rem + env(safe-area-inset-right)) 0.48rem calc(0.82rem + env(safe-area-inset-left));
    backdrop-filter: blur(18px);
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-backlink {
    width: 2.35rem;
    height: 2.35rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-camera-detail-head {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 0.34rem;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-camera-detail-head > div {
    grid-column: 2;
    min-width: 0;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-camera-detail-head h2 {
    margin: 0;
    font-size: 1rem;
    line-height: 1.1;
    text-align: center;
}

.alarmflow-ui .af-mobile-save-link {
    border: 0;
    background: transparent;
    color: var(--afm-orange);
    justify-self: end;
    padding: 0.2rem 0;
    font-size: 0.82rem;
    font-weight: 850;
}

.alarmflow-ui .af-mobile-schedule-hero {
    display: grid;
    gap: 0.52rem;
    margin: 0.66rem 0.82rem 0.62rem;
    border: 1px solid var(--afm-border);
    border-radius: 8px;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.01));
    padding: 0.72rem;
}

.alarmflow-ui .af-mobile-schedule-hero > small,
.alarmflow-ui .af-mobile-schedule-next-card > small {
    color: var(--afm-muted);
    font-size: 0.68rem;
    font-weight: 760;
}

.alarmflow-ui .af-mobile-schedule-hero > div:first-child {
    grid-template-columns: 2.15rem minmax(0, 1fr);
    border-radius: 0;
    background: transparent;
    padding: 0;
}

.alarmflow-ui .af-mobile-schedule-hero > div:first-child span {
    width: 2.15rem;
    height: 2.15rem;
    border-radius: 8px;
    background: color-mix(in srgb, var(--afm-green) 22%, transparent);
    color: var(--afm-green);
}

.alarmflow-ui .af-mobile-schedule-hero.is-inactive > div:first-child span {
    background: color-mix(in srgb, var(--afm-muted) 15%, transparent);
    color: var(--afm-muted);
}

.alarmflow-ui .af-mobile-schedule-hero > div:first-child strong {
    color: var(--afm-green);
    font-size: 1rem;
    text-align: left;
}

.alarmflow-ui .af-mobile-schedule-hero.is-inactive > div:first-child strong {
    color: var(--afm-muted);
}

.alarmflow-ui .af-mobile-schedule-hero > p {
    margin: 0;
    font-size: 0.78rem;
    line-height: 1.32;
}

.alarmflow-ui .af-mobile-schedule-next-card {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.45rem;
    margin: 0 0.82rem 0.86rem;
    border: 1px solid var(--afm-border);
    border-radius: 8px;
    background: var(--afm-surface-2);
    padding: 0.7rem;
}

.alarmflow-ui .af-mobile-schedule-next-card > div {
    display: grid;
    grid-template-columns: 2.15rem minmax(0, 1fr);
    align-items: center;
    gap: 0.58rem;
}

.alarmflow-ui .af-mobile-schedule-next-card > div > span {
    display: inline-flex;
    width: 2.15rem;
    height: 2.15rem;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: color-mix(in srgb, var(--afm-orange) 16%, transparent);
    color: var(--afm-orange);
}

.alarmflow-ui .af-mobile-schedule-next-card strong {
    color: var(--afm-orange);
    font-size: 0.92rem;
}

.alarmflow-ui .af-mobile-schedule-next-card p {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    line-height: 1.28;
}

.alarmflow-ui .af-mobile-schedule-week {
    gap: 0.34rem;
    margin: 0.72rem 0.82rem 0;
}

.alarmflow-ui .af-mobile-schedule-day {
    grid-template-columns: 2.15rem minmax(0, 1fr) auto;
    gap: 0.48rem;
}

.alarmflow-ui .af-mobile-schedule-day-track {
    height: 0.48rem;
}

.alarmflow-ui .af-mobile-schedule-day small {
    max-width: 7.35rem;
    font-size: 0.68rem;
    line-height: 1.05;
    white-space: nowrap;
}

.alarmflow-ui .af-mobile-schedule-actions {
    display: grid;
    gap: 0.36rem;
    overflow: visible;
    margin: 0.82rem;
    border: 0;
    border-radius: 0;
    background: transparent;
}

.alarmflow-ui .af-mobile-schedule-actions form,
.alarmflow-ui .af-mobile-schedule-actions > button {
    min-width: 0;
}

.alarmflow-ui .af-mobile-schedule-actions button {
    min-height: 2.95rem;
    border: 0;
    border-radius: 8px;
    padding: 0 0.9rem;
}

.alarmflow-ui .af-mobile-schedule-actions button:disabled {
    opacity: 1;
}

.alarmflow-ui .af-mobile-schedule-actions > button,
.alarmflow-ui .af-mobile-schedule-actions form:nth-child(4) button {
    background: linear-gradient(180deg, #22272e, #171b20);
}

.alarmflow-ui .af-mobile-schedule-actions > button::after {
    content: none;
}

.alarmflow-ui .af-mobile-schedule-actions button strong {
    font-size: 0.86rem;
}

.alarmflow-ui .af-mobile-schedule-form-panel {
    margin-top: 0.68rem;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-schedule-card {
    border: 0;
    background: transparent;
    padding: 0;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-settings-form {
    gap: 0.54rem;
    border-top: 0;
    padding: 0;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-schedule-period {
    gap: 0.54rem;
    border: 0;
    background: transparent;
    padding: 0;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-schedule-period-head {
    display: block;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-schedule-period-head .af-mobile-schedule-status {
    display: none;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-schedule-period-head strong,
.alarmflow-ui .af-mobile-preset-grid legend {
    color: var(--afm-text);
    font-size: 0.78rem;
    font-weight: 780;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-schedule-days {
    display: flex;
    gap: 0.22rem;
    overflow-x: auto;
    padding-bottom: 0.02rem;
    scrollbar-width: none;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-schedule-days::-webkit-scrollbar {
    display: none;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-schedule-days label {
    flex: 1 0 0;
    min-width: 2.1rem;
    border-radius: 8px;
    padding: 0.48rem 0;
    font-size: 0.68rem;
    font-weight: 850;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-schedule-days label.is-selected {
    border-color: var(--afm-orange);
    background: linear-gradient(180deg, var(--afm-orange-2), var(--afm-orange));
    color: #fff;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-schedule-all-day {
    display: none;
}

.alarmflow-ui .af-mobile-schedule-wheel-fields {
    display: grid;
    gap: 0.52rem;
}

.alarmflow-ui .af-mobile-time-wheel-field {
    position: relative;
    display: grid;
    gap: 0.28rem;
}

.alarmflow-ui .af-mobile-time-wheel-field > span,
.alarmflow-ui .af-mobile-duration-wheel-field > span {
    color: var(--afm-text);
    font-size: 0.78rem;
    font-weight: 780;
}

.alarmflow-ui .af-mobile-time-wheel-field input.af-mobile-time-native {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

.alarmflow-ui .af-mobile-time-wheel,
.alarmflow-ui .af-mobile-duration-wheel {
    position: relative;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: center;
    row-gap: 0.18rem;
    overflow: hidden;
    border: 1px solid var(--afm-border);
    border-radius: 8px;
    background: linear-gradient(180deg, #12161b, #0d1014);
    min-height: 5.45rem;
    padding: 0.38rem 0.42rem;
    text-align: center;
}

.alarmflow-ui .af-mobile-time-barrel {
    --barrel-row-height: 1.55rem;
    isolation: isolate;
    touch-action: pan-y;
}

.alarmflow-ui .af-mobile-time-wheel::before,
.alarmflow-ui .af-mobile-duration-wheel::before {
    content: "";
    position: absolute;
    right: 0.42rem;
    left: 0.42rem;
    top: 50%;
    height: 1.86rem;
    transform: translateY(-50%);
    border-radius: 7px;
    background: rgba(255, 255, 255, 0.065);
}

.alarmflow-ui .af-mobile-time-barrel::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    background: linear-gradient(180deg, rgba(13, 16, 20, 0.88), transparent 32%, transparent 68%, rgba(13, 16, 20, 0.88));
}

.alarmflow-ui .af-mobile-time-barrel-column {
    position: relative;
    z-index: 3;
    height: 5.45rem;
    overflow-y: auto;
    overscroll-behavior: contain;
    padding-block: calc((5.45rem - var(--barrel-row-height)) / 2);
    scroll-snap-type: y mandatory;
    scrollbar-width: none;
    -webkit-mask-image: linear-gradient(transparent, #000 24%, #000 76%, transparent);
    mask-image: linear-gradient(transparent, #000 24%, #000 76%, transparent);
}

.alarmflow-ui .af-mobile-time-barrel-column::-webkit-scrollbar {
    display: none;
}

.alarmflow-ui .af-mobile-time-barrel-column button {
    display: flex;
    width: 100%;
    height: var(--barrel-row-height);
    align-items: center;
    justify-content: center;
    border: 0;
    background: transparent;
    color: var(--afm-muted);
    padding: 0;
    font: inherit;
    font-size: 0.86rem;
    line-height: 1;
    scroll-snap-align: center;
    transition: color 120ms ease, font-size 120ms ease, opacity 120ms ease;
}

.alarmflow-ui .af-mobile-time-barrel-column button.is-selected {
    color: var(--afm-text);
    font-size: 1rem;
    font-weight: 760;
    opacity: 1;
}

.alarmflow-ui .af-mobile-time-wheel span,
.alarmflow-ui .af-mobile-duration-wheel span {
    position: relative;
    color: var(--afm-muted);
    font-size: 0.86rem;
    line-height: 1.42;
}

.alarmflow-ui .af-mobile-time-wheel strong,
.alarmflow-ui .af-mobile-duration-wheel strong {
    position: relative;
    color: var(--afm-text);
    font-size: 1rem;
    font-weight: 760;
    line-height: 1.56;
}

.alarmflow-ui .af-mobile-preset-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.28rem;
}

.alarmflow-ui .af-mobile-preset-grid legend {
    grid-column: 1 / -1;
    margin-bottom: 0.08rem;
}

.alarmflow-ui .af-mobile-preset-grid .af-mobile-choice-card {
    grid-template-columns: 1fr;
    justify-items: center;
    align-content: center;
    gap: 0.16rem;
    min-height: 4.82rem;
    padding: 0.42rem 0.24rem;
    text-align: center;
}

.alarmflow-ui .af-mobile-preset-grid .af-mobile-choice-card::after {
    width: 0.88rem;
    height: 0.88rem;
    position: absolute;
    top: 0.22rem;
    right: 0.22rem;
    grid-column: auto;
    grid-row: auto;
    border-width: 0;
    background: transparent;
}

.alarmflow-ui .af-mobile-preset-grid .af-mobile-choice-card > span {
    grid-row: auto;
    width: 1.55rem;
    height: 1.55rem;
    border-radius: 999px;
}

.alarmflow-ui .af-mobile-preset-grid .af-mobile-choice-card.is-preset-business > span,
.alarmflow-ui .af-mobile-preset-grid .af-mobile-choice-card.is-preset-weekends > span {
    background: rgba(255, 255, 255, 0.075);
    color: color-mix(in srgb, var(--afm-text) 78%, var(--afm-muted));
}

.alarmflow-ui .af-mobile-preset-grid .af-mobile-choice-card.is-preset-always > span {
    background: color-mix(in srgb, var(--afm-green) 18%, transparent);
    color: var(--afm-green);
}

.alarmflow-ui .af-mobile-preset-grid .af-mobile-choice-card.is-selected::after,
.alarmflow-ui .af-mobile-preset-grid .af-mobile-choice-card:has(input:checked)::after {
    content: "";
    border-radius: 999px;
    background:
        linear-gradient(135deg, transparent 45%, var(--afm-orange) 46%),
        var(--afm-orange);
}

.alarmflow-ui .af-mobile-preset-grid .af-mobile-choice-card:has(input:checked) {
    border-color: var(--afm-orange);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--afm-orange) 45%, transparent);
}

.alarmflow-ui .af-mobile-preset-grid .af-mobile-choice-card strong {
    max-width: 100%;
    overflow-wrap: anywhere;
    font-size: 0.58rem;
    line-height: 1.08;
}

.alarmflow-ui .af-mobile-preset-grid .af-mobile-choice-card small {
    font-size: 0.56rem;
    line-height: 1.1;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-schedule-save {
    margin: 0;
    border-color: var(--afm-border);
    background: var(--afm-surface-2);
    padding: 0.58rem 0.68rem;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-schedule-save p {
    font-size: 0.7rem;
    line-height: 1.3;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-schedule-save strong {
    color: var(--afm-text);
    font-size: 0.78rem;
}

.alarmflow-ui .af-mobile-screen-schedule-edit .af-mobile-schedule-save > div {
    display: none;
}

.alarmflow-ui .af-mobile-override-state-card .af-mobile-today-schedule {
    display: grid;
    grid-template-columns: 2.15rem minmax(0, 1fr);
    gap: 0.62rem;
}

.alarmflow-ui .af-mobile-override-state-card .af-mobile-today-schedule > span {
    display: inline-flex;
    width: 2.15rem;
    height: 2.15rem;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: color-mix(in srgb, var(--afm-green) 20%, transparent);
    color: var(--afm-green);
}

.alarmflow-ui .af-mobile-override-state-card .af-mobile-today-schedule > small {
    grid-column: 2;
}

.alarmflow-ui .af-mobile-duration-wheel-field {
    position: relative;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.42rem;
}

.alarmflow-ui .af-mobile-duration-wheel-field > strong {
    color: var(--afm-orange);
    font-size: 0.9rem;
}

.alarmflow-ui .af-mobile-duration-wheel-field select {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
}

.alarmflow-ui .af-mobile-duration-wheel {
    grid-column: 1 / -1;
    grid-template-columns: 1fr;
}

@media (max-width: 380px) {
    .alarmflow-ui .af-mobile-camera-card {
        grid-template-columns: 1fr;
    }

    .alarmflow-ui .af-mobile-member-row {
        grid-template-columns: 2.5rem minmax(0, 1fr);
    }

    .alarmflow-ui .af-mobile-role-badge {
        grid-column: 2;
        width: max-content;
    }
}

/* Mobile operator visual polish pass. Keep this scoped and late so it refines the PWA shell without disturbing desktop. */
.alarmflow-ui .af-mobile-operator {
    --afm-bg: #07090c;
    --afm-surface: #12171d;
    --afm-surface-2: #171d24;
    --afm-surface-3: #202832;
    --afm-border: rgba(191, 205, 222, 0.12);
    --afm-border-strong: rgba(220, 230, 242, 0.2);
    --afm-text: #f7f8fb;
    --afm-muted: #a7b0bc;
    --afm-muted-2: #76818e;
    --afm-orange: #ff6b0a;
    --afm-orange-2: #ff8126;
    --afm-green: #2fd46a;
    --afm-blue: #58a8ff;
    background:
        radial-gradient(circle at 50% -10%, rgba(88, 168, 255, 0.12), transparent 24rem),
        linear-gradient(180deg, #0a0d11 0%, var(--afm-bg) 22rem);
}

.alarmflow-ui .af-mobile-operator .af-mobile-screen {
    gap: 0.78rem;
    background: transparent;
    padding-top: 0.86rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-site-select {
    min-height: 2.72rem;
    border: 1px solid transparent;
    border-radius: 8px;
    background: transparent;
    box-shadow: none;
    outline: 0;
    padding: 0.1rem 3.35rem 0.25rem 0;
}

.alarmflow-ui .af-mobile-operator .af-mobile-site-select:focus-visible {
    border-color: color-mix(in srgb, var(--afm-orange) 38%, transparent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--afm-orange) 14%, transparent);
}

.alarmflow-ui .af-mobile-operator .af-mobile-site-select strong {
    max-width: calc(100vw - 6.2rem);
    letter-spacing: 0;
}

.alarmflow-ui .af-mobile-operator .af-mobile-bell {
    border: 1px solid rgba(255, 255, 255, 0.06);
    background: rgba(255, 255, 255, 0.075);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.alarmflow-ui .af-mobile-operator .af-mobile-card,
.alarmflow-ui .af-mobile-operator .af-mobile-today-grid .af-mobile-health-stat,
.alarmflow-ui .af-mobile-operator .af-mobile-settings-list a,
.alarmflow-ui .af-mobile-operator .af-mobile-settings-list button,
.alarmflow-ui .af-mobile-operator .af-mobile-camera-card,
.alarmflow-ui .af-mobile-operator .af-mobile-event {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.025), rgba(255, 255, 255, 0)),
        var(--afm-surface);
}

.alarmflow-ui .af-mobile-operator .af-mobile-card {
    border-color: var(--afm-border-strong);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.26);
}

.alarmflow-ui .af-mobile-operator .af-mobile-card-head {
    min-height: 3.15rem;
    padding: 0.7rem 0.82rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-card-head h2 {
    font-size: 1rem;
    letter-spacing: 0;
}

.alarmflow-ui .af-mobile-operator .af-mobile-card-head a {
    color: var(--afm-orange);
    font-weight: 850;
}

.alarmflow-ui .af-mobile-operator .af-mobile-today-grid {
    gap: 0.58rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-today-grid .af-mobile-health-stat {
    min-height: 5.2rem;
    align-content: start;
    border-color: var(--afm-border-strong);
    padding: 0.7rem 0.62rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-today-grid .af-mobile-health-stat span {
    width: 1.7rem;
    height: 1.7rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-today-grid .af-mobile-health-stat strong {
    font-size: 0.86rem;
    line-height: 1.12;
}

.alarmflow-ui .af-mobile-operator .af-mobile-today-grid .af-mobile-health-stat p {
    font-size: 0.74rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-camera-filterbar {
    margin: 0 0.7rem 0.58rem;
    overflow: hidden;
    border: 1px solid var(--afm-border);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.045);
    padding: 0.22rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-camera-filterbar a {
    min-height: 2.05rem;
    border: 0;
    background: transparent;
    color: var(--afm-muted);
    padding: 0 0.45rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-camera-filterbar a.is-active {
    background: color-mix(in srgb, var(--afm-orange) 25%, rgba(255, 255, 255, 0.06));
    color: var(--afm-orange);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--afm-orange) 40%, transparent);
}

.alarmflow-ui .af-mobile-operator .af-mobile-camera-body,
.alarmflow-ui .af-mobile-operator .af-mobile-camera-title > div {
    min-width: 0;
}

.alarmflow-ui .af-mobile-operator .af-mobile-live-card.is-compact .af-mobile-camera-card,
.alarmflow-ui .af-mobile-operator .af-mobile-camera-console-card.is-compact .af-mobile-camera-card {
    grid-template-columns: 9rem minmax(0, 1fr);
    gap: 0.72rem;
    padding: 0.7rem 0.72rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-live-card.is-compact .af-mobile-camera-preview,
.alarmflow-ui .af-mobile-operator .af-mobile-camera-console-card.is-compact .af-mobile-camera-preview {
    min-height: 5.1rem;
    border: 1px solid rgba(255, 255, 255, 0.055);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.025);
}

.alarmflow-ui .af-mobile-operator .af-mobile-live-card.is-compact .af-mobile-camera-title,
.alarmflow-ui .af-mobile-operator .af-mobile-camera-console-card.is-compact .af-mobile-camera-title {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 0.48rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-live-card.is-compact .af-mobile-camera-title h2,
.alarmflow-ui .af-mobile-operator .af-mobile-camera-console-card.is-compact .af-mobile-camera-title h2 {
    font-size: 0.98rem;
    line-height: 1.1;
}

.alarmflow-ui .af-mobile-operator .af-mobile-live-card.is-compact .af-mobile-camera-title p,
.alarmflow-ui .af-mobile-operator .af-mobile-camera-console-card.is-compact .af-mobile-camera-title p {
    margin-top: 0.16rem;
    font-size: 0.76rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-camera-pill {
    border-radius: 999px;
    padding: 0.22rem 0.52rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-camera-actions {
    gap: 0.42rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-live-card.is-compact .af-mobile-compact-actions,
.alarmflow-ui .af-mobile-operator .af-mobile-camera-console-card.is-compact .af-mobile-compact-actions {
    display: grid;
    grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr);
}

.alarmflow-ui .af-mobile-operator .af-mobile-mini-button {
    min-width: 0;
    min-height: 2.58rem;
    gap: 0.28rem;
    border-color: var(--afm-border-strong);
    background: #202832;
    box-shadow: none;
    text-decoration: none;
}

.alarmflow-ui .af-mobile-operator .af-mobile-mini-button .af-inline-icon {
    flex: 0 0 auto;
    margin-right: 0;
}

.alarmflow-ui .af-mobile-operator .af-mobile-mini-button.is-secondary,
.alarmflow-ui .af-mobile-operator .af-mobile-primary-button,
.alarmflow-ui .af-mobile-operator .af-mobile-event-actions a.is-primary {
    border-color: color-mix(in srgb, var(--afm-orange) 70%, transparent);
    background: linear-gradient(180deg, var(--afm-orange-2), var(--afm-orange));
    box-shadow: 0 10px 24px rgba(255, 107, 10, 0.22);
}

.alarmflow-ui .af-mobile-operator .af-mobile-event {
    grid-template-columns: 4.9rem minmax(0, 1fr) auto;
    padding: 0.72rem 0.82rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-event p {
    font-size: 0.86rem;
    line-height: 1.2;
}

.alarmflow-ui .af-mobile-operator .af-mobile-today-activity .af-mobile-event {
    grid-template-columns: 2.2rem minmax(0, 1fr) 4.65rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-event-thumb {
    border-color: rgba(255, 255, 255, 0.2);
}

.alarmflow-ui .af-mobile-operator .af-mobile-camera-strip {
    grid-auto-columns: minmax(6.55rem, 32%);
    padding-inline: 0.82rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-camera-strip-thumb {
    border: 1px solid rgba(255, 255, 255, 0.055);
}

.alarmflow-ui .af-mobile-operator .af-mobile-camera-detail-top {
    grid-template-columns: 2rem minmax(0, 1fr);
    padding-top: 0.1rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-camera-detail-head h2 {
    overflow: hidden;
    max-width: 100%;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.alarmflow-ui .af-mobile-operator .af-mobile-camera-detail-card {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.025), transparent), #101419;
}

.alarmflow-ui .af-mobile-operator .af-mobile-camera-detail-card .af-mobile-camera-preview-large,
.alarmflow-ui .af-mobile-operator .af-mobile-camera-detail-card .af-mobile-live-frame {
    margin: 0 0.62rem 0.45rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-camera-preview-large {
    min-height: 0;
    border: 1px solid rgba(255, 255, 255, 0.07);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.28);
}

.alarmflow-ui .af-mobile-operator .af-mobile-carousel-dots {
    padding-top: 0.52rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-clip-strip {
    grid-auto-columns: minmax(4.7rem, 5.6rem);
    padding-inline: 0.62rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-clip-strip span {
    border-color: rgba(255, 255, 255, 0.12);
}

.alarmflow-ui .af-mobile-operator .af-mobile-clip-strip .is-active span {
    border-color: var(--afm-orange);
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--afm-orange) 48%, transparent);
}

.alarmflow-ui .af-mobile-operator .af-mobile-action-tiles {
    gap: 0.45rem;
    padding: 0.68rem 0.62rem 0.72rem;
}

.alarmflow-ui .af-mobile-operator .af-mobile-action-tiles .af-mobile-mini-button {
    min-height: 3.45rem;
    padding: 0.38rem 0.24rem;
    font-size: 0.72rem;
    line-height: 1.05;
}

.alarmflow-ui .af-mobile-operator .af-mobile-tabbar {
    border-top-color: rgba(255, 255, 255, 0.09);
    background: rgba(8, 10, 13, 0.94);
    box-shadow: 0 -18px 36px rgba(0, 0, 0, 0.34);
    backdrop-filter: blur(16px);
}

.alarmflow-ui .af-mobile-operator .af-mobile-tabbar a {
    min-height: 3.1rem;
    align-content: center;
    border-radius: 8px;
}

.alarmflow-ui .af-mobile-operator .af-mobile-tabbar a.is-active {
    background: color-mix(in srgb, var(--afm-orange) 10%, transparent);
}

@media (max-width: 380px) {
    .alarmflow-ui .af-mobile-operator .af-mobile-screen {
        padding-inline: 0.86rem;
    }

    .alarmflow-ui .af-mobile-operator .af-mobile-site-select strong {
        font-size: 1.28rem;
    }

    .alarmflow-ui .af-mobile-operator .af-mobile-live-card.is-compact .af-mobile-camera-card,
    .alarmflow-ui .af-mobile-operator .af-mobile-camera-console-card.is-compact .af-mobile-camera-card {
        grid-template-columns: 7.9rem minmax(0, 1fr);
        gap: 0.58rem;
    }

    .alarmflow-ui .af-mobile-operator .af-mobile-live-card.is-compact .af-mobile-camera-preview,
    .alarmflow-ui .af-mobile-operator .af-mobile-camera-console-card.is-compact .af-mobile-camera-preview {
        min-height: 4.55rem;
    }

    .alarmflow-ui .af-mobile-operator .af-mobile-live-card.is-compact .af-mobile-camera-title,
    .alarmflow-ui .af-mobile-operator .af-mobile-camera-console-card.is-compact .af-mobile-camera-title {
        grid-template-columns: minmax(0, 1fr);
    }

    .alarmflow-ui .af-mobile-operator .af-mobile-camera-pill {
        width: max-content;
    }

    .alarmflow-ui .af-mobile-operator .af-mobile-action-tiles {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
