html {
    height: 100%;
}

body.habitech-app,
body.habitech-login-page,
body.habitech-admin-page {
    min-width: 0;
}

body.habitech-app {
    background-color: #f8f9fa;
    line-height: 1.4;
    margin: 0;
    min-height: 100%;
}

body.habitech-app .container-fluid {
    margin: 0;
    padding: 0 16px 24px;
    background-color: #f8f9fa;
}

body.habitech-app .container-full-width {
    width: 100%;
}

body.habitech-app .introimage {
    width: 100%;
    height: auto;
}

body.habitech-app .accordion {
    margin-top: 1rem !important;
}

body.habitech-app .accordion .card {
    border: none;
    border-bottom: 1px solid #ddd;
}

body.habitech-app .card-header {
    cursor: pointer;
    padding: 0;
}

body.habitech-app .accordion .card-header {
    background-color: #111910;
    color: #fff;
}

body.habitech-app .nav-tabs {
    flex-wrap: wrap;
    row-gap: 0.35rem;
}

body.habitech-app .nav-tabs .nav-link {
    margin-bottom: 0;
    white-space: normal;
}

body.habitech-app .data-table,
body.habitech-app .table-responsive {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

body.habitech-app .data-table table,
body.habitech-app #device-table {
    min-width: 760px;
}

body.habitech-app #plants-upload-file,
body.habitech-app #mushrooms-upload-file {
    max-width: 100%;
}

body.habitech-app #plants-table,
body.habitech-app #mushrooms-table {
    min-width: 0;
}

body.habitech-app .chart-frame {
    height: 320px;
}

body.habitech-app .chart-frame--short {
    height: 220px;
}

body.habitech-app .panel-action-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

body.habitech-app .panel-action-bar .btn,
body.habitech-app .panel-action-bar input[type="file"] {
    margin: 0;
}

body.habitech-app .hidden {
    display: none;
}

body.habitech-app .live-relay-indicator {
    box-shadow: inset 0 0 0 2px #28a745;
}

body.habitech-app div.dataTables_wrapper {
    width: 100%;
}

body.habitech-app div.dataTables_wrapper .dataTables_filter input,
body.habitech-app div.dataTables_wrapper .dataTables_length select {
    max-width: 100%;
}

body.habitech-app #online-indicator {
    font-weight: 600;
    min-width: 88px;
    text-align: center;
    padding: 6px 12px;
    border-radius: 999px;
    border: 1px solid transparent;
    transition: all 0.2s ease;
}

body.habitech-app #online-indicator.online {
    color: #fff;
    background: #2d8a3d;
    border-color: #2d8a3d;
}

body.habitech-app #online-indicator.offline {
    color: #fff;
    background: #8a2d2d;
    border-color: #8a2d2d;
}

body.habitech-app #online-indicator.checking {
    background: #fff3cd;
    color: #856404;
    border-color: #ffeeba;
}

.site-header {
    background-color: #1c7110;
    color: #fff;
    padding: 12px 16px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    flex-wrap: wrap;
    border-radius: 12px;
}

.site-header__identity {
    display: flex;
    align-items: center;
    gap: 16px;
    flex: 1 1 420px;
    min-width: 0;
}

.site-header__logo {
    width: 100px;
    height: auto;
    flex: 0 0 auto;
}

.site-header__copy {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-width: 0;
    flex: 1 1 auto;
}

.site-header__eyebrow {
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.78);
}

.site-header__title {
    margin: 0;
    font-size: 1.6rem;
    line-height: 1.15;
    word-break: break-word;
}

.site-header__meta {
    margin-bottom: 0.35rem;
    font-size: 0.8rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.82);
}

.site-header__selector-block {
    width: min(100%, 360px);
    max-width: 100%;
}

.site-header__selector {
    width: min(100%, 340px);
    max-width: 100%;
}

.site-header__help {
    margin-top: 0.45rem;
    font-size: 0.82rem;
    line-height: 1.35;
    color: rgba(255, 255, 255, 0.78);
}

.site-header__actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    flex: 0 1 auto;
    flex-wrap: wrap;
    min-width: 0;
}

.site-header__logout {
    white-space: nowrap;
}

body.habitech-login-page {
    margin: 0;
    padding: 24px 16px;
    min-height: 100vh;
    min-height: 100svh;
    display: flex;
    justify-content: center;
    align-items: center;
    background:
        linear-gradient(160deg, rgba(9, 48, 18, 0.84), rgba(56, 142, 60, 0.88)),
        radial-gradient(circle at top, rgba(255, 255, 255, 0.14), transparent 42%);
}

body.habitech-login-page .login-shell {
    width: min(100%, 420px);
}

body.habitech-login-page .login-container {
    width: 100%;
    max-width: 420px;
    margin: 0 auto;
}

body.habitech-login-page .login-button {
    width: 100%;
}

body.habitech-admin-page {
    font-family: Arial, sans-serif;
    margin: 20px;
    background: #f4f6f8;
    color: #1f2933;
}

body.habitech-admin-page .admin-page-shell {
    max-width: 1440px;
    margin: 0 auto;
}

body.habitech-admin-page .admin-page-card {
    border: 1px solid #d8dde3;
    border-radius: 14px;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

body.habitech-admin-page .admin-page-card .card-body {
    padding: 1.25rem;
}

body.habitech-admin-page .admin-page-section-head {
    margin-bottom: 0.9rem;
}

body.habitech-admin-page .admin-page-toolbar {
    gap: 0.75rem;
}

body.habitech-admin-page .admin-page-table {
    width: 100%;
}

body.habitech-admin-page .admin-page-console {
    max-height: 240px;
    overflow: auto;
    background: #f8f9fa;
    border: 1px solid #dee2e6;
    border-radius: 10px;
    padding: 12px;
    margin: 0;
}

body.habitech-admin-page .admin-page-console--tall {
    max-height: 320px;
}

body.habitech-admin-page .admin-page-inline-head {
    gap: 0.75rem;
}

body.habitech-admin-page .admin-page-tab-buttons {
    gap: 0.75rem;
}

body.habitech-admin-page .tab {
    display: none;
}

body.habitech-admin-page .tab.active {
    display: block;
}

body.habitech-admin-page .tab-buttons button.active {
    color: #fff;
    background: #0b6b3a;
    border-color: #0b6b3a;
}

body.habitech-admin-page #crash-json-panel,
body.habitech-admin-page #crash-maintenance {
    margin-top: 0;
}

body.habitech-admin-page #maintenance-output,
body.habitech-admin-page #crash-json-content {
    margin-top: 0.75rem;
}

body.habitech-admin-page .maintenance-actions .btn {
    margin-right: 0;
    margin-bottom: 0;
}

body.habitech-admin-page .badge-warning {
    color: #212529;
}

body.habitech-admin-page .habitech-page-header {
    gap: 12px;
}

body.habitech-admin-page .filters {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: flex-end;
}

body.habitech-admin-page .filters .form-group {
    flex: 1 1 180px;
    min-width: 180px;
}

body.habitech-admin-page .controls,
body.habitech-admin-page .tab-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

body.habitech-admin-page .controls button,
body.habitech-admin-page .controls input[type="file"],
body.habitech-admin-page .tab-buttons button {
    margin: 0;
}

body.habitech-admin-page #crash-table,
body.habitech-admin-page #wifi-log-table,
body.habitech-admin-page #plants-table,
body.habitech-admin-page #mushrooms-table {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

body.habitech-admin-page .tabulator {
    max-width: 100%;
}

body.habitech-admin-page .path-link {
    white-space: nowrap;
}

body.habitech-role-user .site-header {
    background:
        linear-gradient(135deg, #175d0d, #2a8740),
        #1c7110;
}

body.habitech-role-user .user-panel-note {
    padding: 0.8rem 1rem;
    border: 1px solid #d8dde3;
    border-radius: 12px;
    background: #f7fbf7;
    color: #34513c;
}

body.habitech-role-user .user-section-intro {
    padding: 1rem 1.1rem;
    border: 1px solid #d8dde3;
    border-radius: 14px;
    background: linear-gradient(180deg, #ffffff, #f8fbf8);
}

body.habitech-role-user .user-profile-summary {
    padding: 0.9rem 1rem;
    border: 1px solid #d8dde3;
    border-radius: 12px;
    background: #fff;
    color: #4c5965;
}

body.habitech-role-user .user-control-grid {
    row-gap: 1rem;
}

body.habitech-role-user .user-control-card {
    border: 1px solid #d8dde3;
    border-radius: 14px;
    background: #fff;
    height: 100%;
}

body.habitech-role-user .user-control-card .card-body {
    padding: 1rem;
}

body.habitech-role-user .user-control-card h3 {
    margin: 0;
    font-size: 1rem;
}

body.habitech-role-user .user-control-summary {
    margin-top: 0.2rem;
    font-size: 0.85rem;
    line-height: 1.35;
    color: #5c6670;
    min-height: 2.4rem;
}

body.habitech-role-user .user-control-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 86px;
    padding: 0.35rem 0.7rem;
    border-radius: 999px;
    background: #edf5ee;
    color: #1c7110;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

body.habitech-role-user .user-control-mode-group {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.5rem;
}

body.habitech-role-user .user-control-mode-btn {
    width: 100%;
}

body.habitech-role-user .user-control-mode-btn.is-active {
    background: #1c7110;
    border-color: #1c7110;
    color: #fff;
}

body.habitech-role-user .user-advanced-details {
    border: 1px solid #d8dde3;
    border-radius: 14px;
    background: #fff;
    padding: 0.9rem 1rem;
}

body.habitech-role-user .user-advanced-details[open] {
    padding-bottom: 1rem;
}

body.habitech-role-user .user-advanced-details summary {
    cursor: pointer;
    font-weight: 700;
    list-style: none;
}

body.habitech-role-user .user-advanced-details summary::-webkit-details-marker {
    display: none;
}

body.habitech-role-user .user-advanced-details summary::after {
    content: "Show";
    float: right;
    font-size: 0.8rem;
    font-weight: 600;
    color: #1c7110;
}

body.habitech-role-user .user-advanced-details[open] summary::after {
    content: "Hide";
}

body.habitech-role-user #dataGraphTab .nav-item {
    flex: 1 1 0;
}

body.habitech-role-user #dataGraphTab .nav-link {
    text-align: center;
}

body.habitech-app .admin-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 0.75rem;
}

body.habitech-app .admin-toolbar__group {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 0.75rem;
    min-width: 0;
}

body.habitech-app .admin-toolbar__group--fields {
    flex: 1 1 420px;
}

body.habitech-app .admin-toolbar__group--actions {
    flex: 0 1 auto;
}

body.habitech-app .admin-toolbar__field {
    flex: 1 1 180px;
    min-width: 160px;
    margin-bottom: 0;
}

body.habitech-app .admin-toolbar__meta {
    margin: 0;
}

body.habitech-app .admin-form-panel {
    border-color: #d8dde3 !important;
}

body.habitech-app .admin-section-head {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

body.habitech-app .admin-section-head__copy {
    flex: 1 1 320px;
    min-width: 0;
}

body.habitech-app .admin-section-head__copy h1,
body.habitech-app .admin-section-head__copy h2,
body.habitech-app .admin-section-head__copy h3,
body.habitech-app .admin-section-head__copy h4,
body.habitech-app .admin-section-head__copy h5 {
    margin-bottom: 0.35rem;
}

body.habitech-app .admin-section-head__copy p {
    color: #5c6670;
}

body.habitech-app .admin-section-head__actions {
    flex: 0 1 auto;
    justify-content: flex-end;
}

body.habitech-app .admin-section-head--compact {
    margin-bottom: 0.75rem;
}

body.habitech-app .admin-device-table-wrap {
    border: 1px solid #d8dde3;
    border-radius: 10px;
    background: #fff;
}

body.habitech-app .admin-device-table {
    margin-bottom: 0;
}

body.habitech-app .admin-device-table th,
body.habitech-app .admin-device-table td {
    vertical-align: middle;
}

body.habitech-app .admin-target-device-list {
    min-height: 14rem;
}

body.habitech-app .admin-control-grid {
    row-gap: 1rem;
}

body.habitech-app .admin-control-card {
    border-radius: 12px;
}

body.habitech-app .admin-control-card h2 {
    font-size: 1.05rem;
    margin-bottom: 0.75rem;
}

body.habitech-app .admin-override-group {
    display: flex;
    width: 100%;
    margin-bottom: 1rem;
}

body.habitech-app .admin-override-group .btn {
    flex: 1 1 0;
}

body.habitech-app .admin-schedule-block {
    background: #fbfcfd;
}

body.habitech-app .intro-pan-frame {
    position: relative;
    width: 100%;
    height: 300px;
    overflow: hidden;
}

body.habitech-app .intro-pan-image {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 112%;
    height: 112%;
    max-width: none;
    object-fit: cover;
    transform: translate(-50%, -50%);
    transition: transform 80ms linear;
    will-change: transform;
    user-select: none;
    pointer-events: none;
}

body.habitech-app .analysis-capture-gallery-scroll {
    max-height: 560px;
    overflow-y: auto;
}

body.habitech-app .analysis-capture-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(var(--analysis-thumb-size, 150px), 1fr));
    gap: 12px;
}

body.habitech-app .analysis-capture-card {
    border: 1px solid #d8dde3;
    border-radius: 8px;
    background: #f8f9fa;
    overflow: hidden;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

body.habitech-app .analysis-capture-card.is-selected {
    border-color: #1c7c36;
    box-shadow: 0 0 0 2px rgba(28, 124, 54, 0.18);
    transform: translateY(-1px);
}

body.habitech-app .analysis-capture-select {
    display: block;
    width: 100%;
    padding: 0;
    border: 0;
    background: transparent;
    text-align: left;
    cursor: pointer;
}

body.habitech-app .analysis-capture-thumb {
    display: block;
    aspect-ratio: 4 / 3;
    background: #eef2f5;
    overflow: hidden;
    border-bottom: 1px solid #d8dde3;
}

body.habitech-app .analysis-capture-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

body.habitech-app .analysis-capture-card-body {
    padding: 8px 10px 10px;
}

body.habitech-app .analysis-capture-name {
    font-size: 0.82rem;
    font-weight: 600;
    line-height: 1.2;
    word-break: break-word;
    margin-bottom: 4px;
}

body.habitech-app .analysis-capture-meta {
    font-size: 0.76rem;
    line-height: 1.25;
    color: #5c6670;
}

body.habitech-app .analysis-capture-summary {
    margin-top: 6px;
    font-size: 0.74rem;
    line-height: 1.25;
    color: #6c757d;
    max-height: 3.7em;
    overflow: hidden;
}

body.habitech-app .analysis-capture-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-top: 8px;
    padding: 0 10px 10px;
}

body.habitech-app .analysis-capture-open-link {
    font-size: 0.74rem;
    font-weight: 600;
    white-space: nowrap;
}

body.habitech-app .analysis-capture-selected-pill {
    font-size: 0.68rem;
    font-weight: 700;
    color: #1c7c36;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

body.habitech-app .camera-grid-card {
    height: 100%;
    border: 1px solid #d8dde3;
    border-radius: 8px;
    padding: 1rem;
    background: #fff;
}

body.habitech-app .camera-grid-card.is-muted {
    background: #f8f9fa;
}

body.habitech-app .camera-preview-frame {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100%;
}

body.habitech-app .camera-preview-frame img {
    width: 100%;
    border: 1px solid #ddd;
    border-radius: 4px;
    background: #f7f7f7;
}

body.habitech-app .camera-linked-sections {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

body.habitech-app .camera-linked-section {
    display: flex;
    gap: 1rem;
    border: 1px solid #d8dde3;
    border-radius: 10px;
    padding: 1rem;
    background: #f8f9fa;
    align-items: stretch;
}

body.habitech-app .camera-linked-section.is-active {
    border-color: #007bff;
    box-shadow: 0 0 0 1px rgba(0, 123, 255, 0.12);
    background: #ffffff;
}

body.habitech-app .camera-linked-section-media {
    flex: 0 0 300px;
    width: 300px;
    min-width: 300px;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

body.habitech-app .camera-linked-section-preview {
    height: 220px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

body.habitech-app .camera-linked-section-preview img {
    width: 100%;
    height: 100%;
    border: 1px solid #ddd;
    border-radius: 6px;
    background: #f7f7f7;
    object-fit: cover;
}

body.habitech-app .camera-linked-section-scroll {
    flex: 1 1 auto;
    min-width: 0;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 0.35rem;
}

body.habitech-app .camera-linked-section-track {
    display: flex;
    gap: 0.75rem;
    min-width: max-content;
}

body.habitech-app .camera-linked-section-block {
    flex: 0 0 240px;
    width: 240px;
    border: 1px solid #d8dde3;
    border-radius: 8px;
    background: #ffffff;
    padding: 0.85rem;
}

body.habitech-app .camera-linked-section-block.is-medium {
    flex-basis: 320px;
    width: 320px;
}

body.habitech-app .camera-linked-section-block.is-wide {
    flex-basis: 420px;
    width: 420px;
}

body.habitech-app .camera-linked-section-block h6 {
    margin-bottom: 0.6rem;
}

body.habitech-app .camera-linked-section-scroll::-webkit-scrollbar {
    height: 8px;
}

body.habitech-app .camera-linked-section-scroll::-webkit-scrollbar-thumb {
    background: rgba(108, 117, 125, 0.45);
    border-radius: 999px;
}

body.habitech-app .camera-section-target {
    font-size: 0.82rem;
}

body.habitech-app .camera-layout-toolbar {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
}

body.habitech-app .camera-layout-toolbar-copy {
    flex: 1 1 auto;
    min-width: 0;
}

body.habitech-app .camera-layout-shell {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
}

body.habitech-app .camera-layout-main {
    flex: 1 1 auto;
    min-width: 0;
}

body.habitech-app .camera-assignment-drawer {
    flex: 0 0 0;
    width: 0;
    max-width: 0;
    opacity: 0;
    overflow: hidden;
    pointer-events: none;
    transition: flex-basis 0.25s ease, width 0.25s ease, max-width 0.25s ease, opacity 0.2s ease;
}

body.habitech-app .camera-layout-shell.is-assignment-open .camera-assignment-drawer {
    flex-basis: min(440px, 36vw);
    width: min(440px, 36vw);
    max-width: min(440px, 36vw);
    opacity: 1;
    pointer-events: auto;
}

body.habitech-app .camera-assignment-drawer-card {
    width: 100%;
}

@media (max-width: 991.98px) {
    body.habitech-app .admin-section-head {
        flex-direction: column;
        align-items: stretch;
    }

    body.habitech-app .admin-section-head__actions {
        justify-content: flex-start;
    }

    body.habitech-app .admin-toolbar__group--actions {
        flex: 1 1 100%;
    }

    body.habitech-app .camera-linked-section {
        flex-direction: column;
    }

    body.habitech-app .camera-linked-section-media {
        width: 100%;
        min-width: 0;
        flex-basis: auto;
    }

    body.habitech-app .camera-layout-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    body.habitech-app .camera-layout-shell {
        display: block;
    }

    body.habitech-app .camera-assignment-drawer {
        display: none;
        width: 100%;
        max-width: none;
        opacity: 1;
        overflow: visible;
        pointer-events: auto;
        transition: none;
    }

    body.habitech-app .camera-layout-shell.is-assignment-open .camera-assignment-drawer {
        display: block;
        width: 100%;
        max-width: none;
        margin-top: 1rem;
    }
}

@media (min-width: 768px) and (max-width: 991.98px) {
    body.habitech-app .container-fluid {
        padding: 0 14px 24px;
    }

    .site-header__identity {
        flex-basis: 100%;
    }

    .site-header__actions {
        width: 100%;
        justify-content: space-between;
    }

    body.habitech-app .chart-frame {
        height: 280px;
    }

    body.habitech-app .chart-frame--short {
        height: 200px;
    }

    body.habitech-role-user .user-control-card {
        height: 100%;
    }
}

@media (max-width: 767.98px) {
    body.habitech-app .container-fluid {
        padding: 0 12px 20px;
    }

    body.habitech-app .card-body {
        padding: 1rem;
    }

    body.habitech-app .accordion .card-header .btn {
        display: block;
        width: 100%;
        padding: 0.8rem 1rem;
        text-align: left;
        white-space: normal;
    }

    body.habitech-app .form-row {
        margin-left: 0;
        margin-right: 0;
    }

    body.habitech-app .form-row > [class*="col-"] {
        padding-left: 0;
        padding-right: 0;
    }

    body.habitech-app .data-table table,
    body.habitech-app #device-table {
        min-width: 720px;
    }

    body.habitech-app .chart-frame {
        height: 240px;
    }

    body.habitech-app .chart-frame--short {
        height: 180px;
    }

    body.habitech-app .intro-pan-frame {
        height: 210px;
    }

    body.habitech-app .camera-linked-section-block,
    body.habitech-app .camera-linked-section-block.is-medium,
    body.habitech-app .camera-linked-section-block.is-wide {
        width: min(82vw, 320px);
        flex-basis: min(82vw, 320px);
    }

    body.habitech-app .camera-linked-section-track {
        min-width: max-content;
    }

    body.habitech-app .tabulator {
        font-size: 0.8rem;
    }

    body.habitech-role-user .intro-pan-frame {
        height: 160px;
    }

    .site-header {
        margin-top: 0.75rem !important;
        padding: 12px;
        border-radius: 10px;
    }

    .site-header__identity {
        flex-direction: column;
        align-items: flex-start;
        gap: 12px;
        flex-basis: 100%;
    }

    .site-header__logo {
        width: 84px;
    }

    .site-header__copy {
        width: 100%;
    }

    .site-header__title {
        font-size: 1.2rem;
    }

    .site-header__selector {
        width: 100%;
    }

    .site-header__selector-block {
        width: 100%;
    }

    .site-header__help {
        width: 100%;
    }

    .site-header__actions {
        width: 100%;
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
    }

    .site-header__logout,
    body.habitech-app #online-indicator {
        width: 100%;
        margin-right: 0 !important;
    }

    body.habitech-app .admin-toolbar,
    body.habitech-app .admin-toolbar__group {
        flex-direction: column;
        align-items: stretch;
    }

    body.habitech-app .admin-toolbar__field,
    body.habitech-app .admin-toolbar .btn,
    body.habitech-app .admin-toolbar input[type="file"],
    body.habitech-app .panel-action-bar .btn,
    body.habitech-app .panel-action-bar input[type="file"] {
        width: 100%;
    }

    body.habitech-role-user .user-section-intro,
    body.habitech-role-user .user-profile-summary,
    body.habitech-role-user .user-panel-note,
    body.habitech-role-user .user-advanced-details {
        padding-left: 0.85rem;
        padding-right: 0.85rem;
    }

    body.habitech-role-user .user-control-summary {
        min-height: 0;
    }

    body.habitech-role-user .user-control-mode-group {
        grid-template-columns: 1fr;
    }

    body.habitech-role-user #dataGraphTab .nav-item {
        flex: 1 1 100%;
    }

    body.habitech-app .admin-target-device-list {
        min-height: 12rem;
    }

    body.habitech-app .admin-override-group {
        flex-direction: column;
    }

    body.habitech-app .admin-device-table,
    body.habitech-app .admin-device-table thead,
    body.habitech-app .admin-device-table tbody,
    body.habitech-app .admin-device-table th,
    body.habitech-app .admin-device-table td,
    body.habitech-app .admin-device-table tr {
        display: block;
    }

    body.habitech-app .admin-device-table thead {
        display: none;
    }

    body.habitech-app .admin-device-table tbody {
        padding: 0.5rem;
    }

    body.habitech-app .admin-device-table tr {
        border: 1px solid #d8dde3;
        border-radius: 10px;
        padding: 0.75rem;
        margin-bottom: 0.75rem;
        background: #fff;
    }

    body.habitech-app .admin-device-table td {
        border: 0;
        padding: 0.25rem 0;
        min-width: 0;
    }

    body.habitech-app .admin-device-table td::before {
        content: attr(data-label);
        display: block;
        margin-bottom: 0.15rem;
        font-size: 0.74rem;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.04em;
        color: #5c6670;
    }

    body.habitech-login-page {
        padding: 16px;
        align-items: flex-start;
    }

    body.habitech-login-page .login-shell {
        width: 100%;
        margin-top: 4vh;
    }

    body.habitech-login-page .login-container {
        padding: 1.5rem;
    }

    body.habitech-login-page .login-header img {
        width: 120px;
    }

    body.habitech-admin-page {
        margin: 12px;
    }

    body.habitech-admin-page .habitech-page-header {
        flex-direction: column;
        align-items: stretch !important;
    }

    body.habitech-admin-page .filters .form-group {
        flex-basis: 100%;
        min-width: 0;
    }

    body.habitech-admin-page .controls,
    body.habitech-admin-page .tab-buttons {
        align-items: stretch;
    }

    body.habitech-admin-page .controls > *,
    body.habitech-admin-page .tab-buttons > * {
        width: 100%;
    }

    body.habitech-admin-page .admin-page-card .card-body {
        padding: 1rem;
    }

    body.habitech-admin-page .admin-page-inline-head {
        flex-direction: column;
        align-items: stretch !important;
    }

    body.habitech-admin-page .path-link {
        white-space: normal;
        word-break: break-all;
    }
}
