/* ===== MOBILE RESPONSIVE STYLES ===== */
@media (max-width: 768px) {

/* ===== LOGIN MODULE ===== */

    .gradient-bg {
        display: none !important;
    }

    .adalogo {
        display: none !important;
    }

    .container {
        -ms-grid-columns: 1fr !important;
        grid-template-columns: 1fr !important;
        grid-gap: 0 !important;
        padding: 0 !important;
    }

    .img {
        display: none !important;
    }

    .login-content {
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        padding: 20px !important;
        background-color: rgb(248,248,255) !important;
        display: -webkit-box !important;
        display: -ms-flexbox !important;
        display: flex !important;
        -webkit-box-align: center !important;
            -ms-flex-align: center !important;
                align-items: center !important;
        -webkit-box-pack: center !important;
            -ms-flex-pack: center !important;
                justify-content: center !important;
        min-height: 100vh !important;
    }

  .login-form {
    font-family: 'Poppins', sans-serif !important;
    width: 100% !important;
    max-width: 360px !important;
    padding: 20px !important;
    margin: 0 auto !important;
    background: #fff !important;
    border-radius: 10px !important;
    -webkit-box-shadow: 0 2px 10px rgba(0,0,0,0.1) !important;
            box-shadow: 0 2px 10px rgba(0,0,0,0.1) !important;
  }

  .reset-password-form {
    font-family: 'Poppins', sans-serif !important;
    width: 100% !important;
    max-width: 360px !important;
    padding: 20px !important;
    margin: 0 auto !important;
    background: #fff !important;
    border-radius: 10px !important;
    -webkit-box-shadow: 0 2px 10px rgba(0,0,0,0.1) !important;
            box-shadow: 0 2px 10px rgba(0,0,0,0.1) !important;
  }

  .logo-container {
    text-align: center !important;
    margin-bottom: 1.5rem !important;
    margin-top: -10px !important;
  }

  .logo-container img {
    display: block !important;
    height: auto !important;
    width: 100% !important;
    margin: 0 auto !important;
  }

  .login-logo {
    display: block !important;
    height: auto !important;
    margin: 0 auto !important;
  }

    .login-header {
        display: none !important;
    }

  .login-title {
    display: none !important;
  }

  .input-div {
    width: 100% !important;
  }

  .input-div input {
    font-size: 16px !important; 
  }

  .input-div .i {
    padding: 10px !important;
  }

  .btn {
    width: 100% !important;
    margin: 1.5rem 0 1rem !important;
    height: 45px !important;
    font-size: 16px !important;
  }

  h2 {
    font-size: 1.5rem !important;
    text-align: center !important;
    margin-bottom: 1.5rem !important;
  }

  .alert {
    margin-bottom: 1.5rem !important;
    font-size: 14px !important;
    border-radius: 8px !important;
  }

  .return-login {
    font-size: 14px !important;
    display: block !important;
    text-align: center !important;
    margin-top: 1rem !important;
  }

  .fa-eye, .fa-eye-slash {
    padding: 10px !important;
    font-size: 1.2rem !important;
    right: 5px !important;
  }

  /* ===== MENU MODULE ===== */

  header .navbar{
    width: 100%;
    gap: 1rem;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }

  /* section {
    padding-top: 80px !important;
  } */

  .desktop-logout-link{ display: -webkit-box !important; display: -ms-flexbox !important; display: flex !important; }
  .mobile-logout-link{
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    margin: .8rem 0 0 0;
    padding: .8rem 1.2rem;
    border: .2rem solid var(--brand);
    background: #fff;
    color: var(--color-primary);
    text-align: right;
    font-weight: 700;
    border-radius: .5rem;
  }

  header .navbar a[href*="login"],
  .login-btn{
    display: -webkit-inline-box !important;
    display: -ms-inline-flexbox !important;
    display: inline-flex !important;
  }

  .welcome-text{ display: none !important; }

  header .navbar a:has(i.bx-log-out){ display: none; }

  /* Navbar becomes stacked and scrollable if it grows */
  header .navbar{
    width: 100%;
    gap: 1rem;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }

  /* Hide the desktop variant of auth link on mobile,
     show the mobile-specific one. These classes already
     exist in your file — reuse them for LOGIN on mobile. */
  .desktop-logout-link{ display: -webkit-box !important; display: -ms-flexbox !important; display: flex !important; }
  .mobile-logout-link{
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    margin: .8rem 0 0 0;
    padding: .8rem 1.2rem;
    border: .2rem solid var(--brand);
    background: #fff;
    color: #333;
    text-align: right;
    font-weight: 700;
    border-radius: .5rem;
  }

  /* NEW: keep the Login button visible even if markup
     doesn't use the above classes (targets /login links & .login-btn) */
  header .navbar a[href*="login"],
  .login-btn{
    display: -webkit-inline-box !important;
    display: -ms-inline-flexbox !important;
    display: inline-flex !important;
  }

  /* NEW: hide the "Welcome, User" text on mobile */
  .welcome-text{ display: none !important; }

  /* Optional: if your old CSS tried to hide a logout item by icon */
  header .navbar a:has(i.bx-log-out){ display: none; }

    /* ===== SINGLE DEVICE ASSET MANAGEMENT DASHBOARD SECTION ===== */
    .dashContainer {
        min-width: 100% !important;
        margin-top: 0 !important;
        padding-top: 180px !important;
        padding-right: 10px !important;
        /* padding-left: 10px !important; */
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        grid-template-rows: auto auto !important;
        /* gap: 10px !important; */
        border: none !important;
        outline: none !important;
    }

    .left-panel {
        width: 100% !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
        grid-column: 1 !important;
        grid-row: 1 !important;
        border: none !important;
        outline: none !important;
    }

    .center-panel {
        grid-column: 1 / -1 !important;
        grid-row: 2 !important;
        width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
        border: none !important;
        outline: none !important;
    }

    .right-panel {
        width: 100% !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
        grid-column: 2 !important;
        grid-row: 1 !important;
        padding: 0 !important;
        border: none !important;
        outline: none !important;
    }

    .DashStat {
        padding: 19px 60px !important;
        margin: 0 !important;
        border-radius: 8px !important;
        text-align: center !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        min-width: 0 !important;
        width: 100% !important;
        box-sizing: border-box !important;
        font-size: 0.9rem !important;
        gap: 6px !important;
        border: none !important;
        outline: none !important;
    }

    .DashStat2 {
        padding: 15px 60px !important;
        margin: 0 !important;
        border-radius: 8px !important;
        text-align: center !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        min-width: 0 !important;
        width: 100% !important;
        box-sizing: border-box !important;
        font-size: 0.9rem !important;
        gap: 6px !important;
        border: none !important;
        outline: none !important;
    }

    .DashValue {
        font-size: 1.5rem !important;
    }

    .DashSub-label {
        font-size: 0.8rem !important;
    }

    .DashChart {
        margin: 0 !important;
        padding: 0 !important;
        overflow: visible !important;
        width: 100% !important;
    }

    #summChartSec,
    #tempChartSec,
    [id^="summChartSec"],
    [id^="tempChartSec"] {
        width: 100% !important;
        max-width: 100% !important;
        min-height: 450px !important;
        height: auto !important;
        padding: 0 !important;
        overflow: visible !important;
    }

    #sumgraphCont,
    #TempCont,
    [id^="sumgraphCont"],
    [id^="TempCont"] {
        width: 100% !important;
        max-width: 100% !important;
        height: auto !important;
        overflow: visible !important;
    }

    [id^="summChart"],
    [id^="TempContChart"] {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
    }

    .DashChart .apexcharts-canvas,
    .DashChart svg,
    .DashChart canvas {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        height: auto !important;
        display: block !important;
        box-sizing: border-box !important;
        /* overflow: visible !important; */
    }

    .DashChart .apexcharts-wrapper {
        width: 100% !important;
        max-width: 100% !important;
    }

    /* Make center panel full width and hide side panels on mobile */
    .center-panel {
        width: 100% !important;
        flex: 0 0 100% !important;
        max-width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding: 0 !important;
    }

    .left-panel,
    .right-panel {
        display: flex !important;
        flex-direction: column !important;
        gap: 10px !important;
        width: 100% !important;
        flex: 1 1 0 !important;
    }

    .tabDash, .tabAlarm {
        padding: 8px 12px !important;
        font-size: 11px !important;
    }

    .select_single {
        width: 100% !important;
        margin: 32px 0 15px 0 !important; 
        padding: 10px !important;
        box-sizing: border-box !important;
        display: block !important;
        position: relative !important;
        z-index: 1 !important;
    }

    /* Hide last 2 filters on mobile (Data Correlation) */
    #select3,
    #select4,
    [id*="select3"],
    [id*="select4"] {
        display: none !important;
    }

    .center-panel.mobile-padding {
        padding-top: 10%;
    }

    .mobileChartSec {
        width: 100% !important;
        height: 300px !important;
    }


    /* ===== ASSET MANAGEMENT REPORTS SECTION ===== */
    .reportsContainer,
    .AlertsContainer,
    .DevMngtContainer,
    .ConReportsContainer {
        margin-left: 0 !important;
        min-width: 100% !important;
        width: 100% !important;
        padding: 10px !important;
        padding-top: 180px !important;
    }

    .reportsSection {
        margin-top: 5px !important;
    }

    .dt-buttons {
        margin-bottom: 10px !important;
        display: -webkit-box !important;
        display: -ms-flexbox !important;
        display: flex !important;
        -ms-flex-wrap: wrap !important;
            flex-wrap: wrap !important;
        gap: 5px !important;
        width: 100% !important;
    }

    .dt-button {
        -webkit-box-flex: 1 !important;
            -ms-flex: 1 1 calc(50% - 5px) !important;
                flex: 1 1 calc(50% - 5px) !important;
        padding: 10px !important;
        font-size: 11px !important;
        text-align: center !important;
    }

    .dt-button-collection {
        width: 95vw !important;
        left: 2.5vw !important;
        top: 10% !important;
        -webkit-transform: none !important;
            -ms-transform: none !important;
                transform: none !important;
        max-height: 70vh !important;
    }


    /* ===== SIDEBAR NAVIGATION ===== */
    .alertsSection,
    .enerConSection {
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
        gap: 15px !important;
        padding-top: 50px !important;
    }

    .alarmDetClass {
        max-height: 300px !important;
        font-size: 11px !important;
    }

    .alerts-header-cell {
        font-size: 10px !important;
    }

    /* ===== SINGLE DEVICE SYSTEM LOSS MANAGEMENT ENERGY CONSUMPTION SECTION ===== */
    .EnerConTable {
        font-size: 10px !important;
    }

    /* ===== SYSTEM LOSS TAB MOBILE ===== */
    .SysLoss-tab-content {
        padding: 0 !important;
    }

    .SysLoss-tab-content .tab-pane {
        padding: 10px !important;
    }

    .SysLoss-tab-content .nav-tabs,
    .SysLoss-tab-content .spec-nav-tabs {
        display: -webkit-box !important;
        display: -ms-flexbox !important;
        display: flex !important;
        -ms-flex-wrap: nowrap !important;
            flex-wrap: nowrap !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
        padding: 0 !important;
        margin: 0 !important;
        width: 100% !important;
    }

    .SysLoss-tab-content .nav-link {
        padding: 10px 15px !important;
        font-size: 11px !important;
        white-space: nowrap !important;
        -ms-flex-negative: 0 !important;
            flex-shrink: 0 !important;
    }

    .SysLoss-tab-content .row {
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
    }

    .SysLoss-tab-content [class*="col-"] {
        width: 100% !important;
        max-width: 100% !important;
        -webkit-box-flex: 0 !important;
            -ms-flex: 0 0 100% !important;
                flex: 0 0 100% !important;
        padding: 5px 0 !important;
    }

    .SysLoss-tab-content canvas {
        width: 100% !important;
        height: auto !important;
        min-height: 200px !important;
    }

    .SysLoss-tab-content table {
        display: block !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
        font-size: 10px !important;
    }

    .SysLoss-tab-content input,
    .SysLoss-tab-content select,
    .SysLoss-tab-content textarea {
        width: 100% !important;
        padding: 12px !important;
        font-size: 14px !important;
        margin: 5px 0 !important;
    }

    .SysLoss-tab-content button,
    .SysLoss-tab-content .btn {
        width: 100% !important;
        padding: 12px !important;
        margin: 5px 0 !important;
        min-height: 44px !important;
    }

    /* ===== SINGLE DEVIVCE DEVICE MANAGEMENT TAB ===== */
    .DevMngtContainer {
        padding: 10px !important;
    }

    .mainDetDevMngmt {
        margin-left: 0 !important;
        padding: 10px !important;
    }

    .devMngmt-input-container {
        margin-bottom: 8px !important;
    }

    .devMngmt-input-container input,
    .devMngmt-input-container select {
        padding: 10px 8px !important;
        font-size: 13px !important;
        width: 100% !important;
        box-sizing: border-box !important;
    }

    .devMngmt-input-container label {
        font-size: 11px !important;
    }

    .grayedButton {
        width: 100% !important;
        padding: 12px 20px !important;
        margin-bottom: 10px !important;
    }

    .devHistoryCol {
        width: 100% !important;
        margin-top: 15px !important;
    }

    .devHistory {
        padding: 10px !important;
        font-size: 12px !important;
    }

    .devHistCont {
        min-height: 200px !important;
        max-height: 300px !important;
    }

    .devHistoryEntry {
        font-size: 11px !important;
        padding: 8px !important;
    }

    .devHistSearch {
        width: 100% !important;
        height: 40px !important;
        font-size: 14px !important;
    }

    .confirmTextDevMngt {
        width: 100% !important;
        height: 150px !important;
        padding: 15px !important;
        font-size: 12px !important;
    }

    .form-check {
        padding-left: 0 !important;
        padding-top: 10px !important;
    }

    .form-switch .form-check-input {
        width: 2.5rem !important;
        height: 1.25rem !important;
    }

    .form-check-label {
        margin-left: 50px !important;
        font-size: 12px !important;
    }

    /* ===== MULTIPLE DEVICE VIEW ===== */

    .goToDevClass {
        margin-top: 10px !important;
    }

    .goToDevSel {
        width: 100% !important;
        padding: 12px !important;
        font-size: 14px !important;
    }

    .goToDevBtn {
        width: 100% !important;
        padding: 12px !important;
        margin-top: 15px !important;
    }

    .searchMulDev {
        width: 100% !important;
        padding: 10px !important;
        font-size: 14px !important;
    }

    /* .editDeviceModal {
        padding: 15px !important;
    } */

    .editDev-title {
        font-size: 1rem !important;
    }

    .confirmTextMulDev {
        width: 100% !important;
        height: 80px !important;
    }

    .popupOverlay {
        width: 100vw !important;
        height: 100vh !important;
    }

    /* Show maximize buttons on mobile for charts */
    .maximize-btn-mul, .minimize-btn-mul {
        display: inline-block !important;
    }

    .chart-header-compact {
        flex-wrap: wrap;
    }

    .chart-maximized-overlay {
        padding: 15px !important;
    }

    .chart-maximized {
        width: 85vw !important;
        max-width: 85vw !important;
        height: 55vh !important;
        max-height: 55vh !important;
        padding: 15px !important;
        border-radius: 12px !important;
        display: flex !important;
        flex-direction: column !important;
    }

    .chart-maximized .chart-header-compact {
        margin-bottom: 12px !important;
        padding-bottom: 10px !important;
        flex-shrink: 0 !important;
    }

    .chart-maximized .chart-header-compact .MultDevTitle {
        font-size: 16px !important;
    }

    .chart-maximized .loadingValue {
        flex: 1 !important;
        overflow: auto !important;
        min-height: 300px !important;
    }

    .chart-maximized .apexcharts-canvas {
        width: 100% !important;
        height: auto !important;
        min-height: 300px !important;
    }

    .chart-maximized svg,
    .chart-maximized canvas {
        width: 100% !important;
    }

    .close-chart-btn{
        color: var(--color-primary) !important;
    }

    .chart-maximized .close-chart-btn {
        font-size: 18px !important;
        color: var(--color-primary) !important;
        padding: 0 5px !important;
    }

    .loadPopUpGoToDevice {
        width: 90vw !important;
        left: 5vw !important;
        top: 30% !important;
        -webkit-transform: none !important;
            -ms-transform: none !important;
                transform: none !important;
        padding: 20px !important;
    }

    .nav-tabs {
    margin-left: -12px;
    background-color: #f9fbfa;
    border-bottom: 1px solid #dee2e6;
    padding: 0;
    width: calc(100% + 24px); 
    }

    .nav-link {
        border: none !important;
        color: var(--color-primary) !important; 
        padding-top: 12px !important;
        padding-bottom: 6px !important; 
        -webkit-transition: none !important; 
        -o-transition: none !important; 
        transition: none !important;
    }

    /* Remove all opacity */
    .nav-link:not(.active),
    .nav-link:not(.active):hover,
    .nav-link:not(.active):focus,
    .nav-link:not(.active):visited {
        color: var(--color-primary) !important;
        opacity: 1 !important;
    }

    .nav-link.active {
        opacity: 1;
        background-color: white !important; 
        color: var(--color-primary) !important;
        border: 1px solid #dee2e6 !important; 
        border-bottom: none !important; 
        border-top: 4px solid var(--color-secondary) !important; 
    }

    /* make image icons gray */
    .nav-link:not(.active) img { 
        opacity: 0.5;
    }


    /* ===== TABLES MOBILE ===== */
    table.dataTable {
        display: block !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
    }

    table.dataTable thead th {
        font-size: 10px !important;
        padding: 8px 5px !important;
        white-space: nowrap !important;
    }

    table.dataTable tbody td {
        font-size: 9px !important;
        padding: 6px 5px !important;
        white-space: nowrap !important;
    }

    .dataTables_wrapper {
        width: 100% !important;
        overflow-x: auto !important;
    }

    .dataTables_filter {
        width: 100% !important;
        margin-bottom: 10px !important;
    }

    .dataTables_filter input {
        width: 100% !important;
        max-width: none !important;
        padding: 10px !important;
        font-size: 14px !important;
    }

    .dataTables_length {
        margin-bottom: 10px !important;
    }

    .dataTables_length select {
        padding: 8px !important;
    }

    .dataTables_info {
        font-size: 11px !important;
        margin-top: 10px !important;
    }

    .dataTables_paginate {
        margin-top: 10px !important;
    }

    .dataTables_paginate .paginate_button {
        padding: 8px 12px !important;
        font-size: 11px !important;
    }

    .noData, .noDataSmall {
        padding-top: 20px !important;
        font-size: 1rem !important;
        margin-top: 20% !important;
    }

    .noData img, .noData i {
        height: 60px !important;
        font-size: 60px !important;
    }

    .noDataSmall {
        font-size: 0.8rem !important;
        margin-top: 30% !important;
    }

    .noDataSmall img {
        height: 40px !important;
    }

    .loadingOverlay {
        font-size: 1rem !important;
    }

    .spinner {
        width: 30px !important;
        height: 30px !important;
    }

    .maximized {
        min-width: 95vw !important;
        min-height: 80vh !important;
        padding: 15px !important;
    }

/* ===== MULTIPLE DEVICE MANAGE DEVICE MODAL ===== */

    .DevMngt-tab-content .tab-pane {
        padding: 10px !important;
    }

    .mainDetDevMngmt {
        background: white;
        border-radius: 8px;
        border: 1px solid var(--color-primary);
        margin: 5px 0 !important;
        padding: 5px !important;
        gap: 0 !important;
    }

    .DevMngtContainer .row {
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        gap: 0 !important;
    }

    .DevMngtContainer [class*="col-"] {
        width: 100% !important;
        max-width: 100% !important;
        -webkit-box-flex: 0 !important;
            -ms-flex: 0 0 100% !important;
                flex: 0 0 100% !important;
        padding: 0 !important;
    }

    .devMngmt-input-container {
        background: transparent;
        border-radius: 5px;
        padding: 0 !important;
        margin-bottom: 20px !important;
    }

    .devMngmt-input-container input,
    .devMngmt-input-container select {
        background: white !important;
        border: 1px solid var(--color-secondary) !important;
        border-radius: 5px !important;
        padding: 10px 8px !important;
        width: 100% !important;
        font-size: 13px !important;
    }

    .devMngmt-input-container input:focus,
    .devMngmt-input-container select:focus {
        border-color: var(--color-secondary) !important;
        outline: none !important;
    }

    .DevMngtContainer button,
    .DevMngtContainer .btn {
        width: 100% !important;
        margin: 8px 0 0 0 !important;
        min-height: 40px !important;
        padding: 10px !important;
    }

    .devHistoryCol {
        background: #f9f9f9;
        border-radius: 8px;
        border: 1px solid #e0e0e0;
        padding: 10px !important;
        margin-top: 10px !important;
    }

    .devHistory {
        background: transparent;
        border-radius: 0;
        padding: 8px 0 !important;
        margin-bottom: 10px !important;
        border-bottom: 2px solid #f7dc6f;
    }

    .devHistCont {
        background: white;
        border-radius: 5px;
        padding: 10px;
        min-height: 200px !important;
        max-height: 400px !important;
    }

    .devHistoryEntry {
        background: white;
        border: 1px solid #e0e0e0;
        border-left: 3px solid var(--color-secondary);
        border-radius: 5px;
        padding: 10px !important;
        margin-bottom: 10px !important;
        font-size: 11px !important;
    }

/* ===== ASSET MANAGEMENT TAB ===== */

    .space-items {
        padding-top: 200px !important;
    }

    .infoDateRange,
    [class*="infoDateRange"] {
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
        height: auto !important;
        padding: 15px !important;
        gap: 15px !important;
        width: 100% !important;
        margin: 10px 0 !important;
    }

    .infoDateRange .leftInfo,
    [class*="infoDateRange"] .leftInfo {
        width: 100% !important;
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
        -webkit-box-align: start !important;
            -ms-flex-align: start !important;
                align-items: flex-start !important;
        gap: 10px !important;
    }

    .infoDateRange .dateRange,
    [class*="infoDateRange"] .dateRange {
        width: 100% !important;
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
        gap: 10px !important;
        margin: 0 !important;
    }

    .infoDateRange p {
        font-size: 12px !important;
    }

    .innerTabContent,
    [class*="innerTabContent"] {
        margin: 10px 0 !important;
        padding: 0 !important;
        height: auto !important;
    }

    .innerTabContent canvas,
    .innerTabContent img,
    [class*="CorrelationContImage"] {
        width: 100% !important;
        height: auto !important;
        min-height: 200px !important;
        margin: 0 !important;
    }

    .SelectButtons {
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
        width: 100% !important;
        gap: 10px !important;
        margin: 10px 0 !important;
    }

    .buttAsset,
    .buttSysLoss {
        width: 100% !important;
        height: 44px !important;
        padding: 12px 15px !important;
        font-size: 13px !important;
        -webkit-box-pack: center !important;
            -ms-flex-pack: center !important;
                justify-content: center !important;
    }

    .objSize,
    .SubObjSize {
        width: 100% !important;
        height: 44px !important;
        padding: 10px 15px !important;
        font-size: 14px !important;
        margin: 5px 0 !important;
    }

/* ===== ACCOUNT MANAGEMENT ===== */

    #addAccBtn {
        width: 100% !important;
        margin-bottom: 15px !important;
    }

    .edit-btn,
    .del-btn {
        display: block !important;
        width: 100% !important;
        margin: 3px 0 !important;
        padding: 8px !important;
    }

/* ===== REGISTER DEVICE ===== */

    #regDevMngtCont {
        width: 100vw !important;
        max-width: 100vw !important;
        min-width: 0 !important;
        margin: 0 !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        box-sizing: border-box !important;
        overflow-x: hidden !important;
    }
    #regDevMngtCont .devMngmt-input-container {
        width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        box-sizing: border-box !important;
        overflow-x: visible !important;
    }
    #regDevMngtCont .devMngmt-input-container input,
    #regDevMngtCont .devMngmt-input-container select {
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        overflow-x: visible !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    body, html {
        overflow-x: hidden !important;
    }
  
    #regDevMngtCont .form-check,
    #regDevMngtCont .form-switch {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        box-sizing: border-box !important;
        overflow-x: visible !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
    }
    #regDevMngtCont .form-check-input,
    #regDevMngtCont .form-switch .form-check-input {
        min-width: 40px !important;
        max-width: 60px !important;
        height: 24px !important;
        min-height: 24px !important;
        max-height: 32px !important;
        box-sizing: border-box !important;
        margin: 0 10px 0 0 !important;
        display: inline-block !important;
        vertical-align: middle !important;
    }
    #regDevMngtCont .form-check-label {
        font-size: 13px !important;
        padding-left: 20px !important;
        white-space: normal !important;
        width: auto !important;
        flex: 1 1 0%;
    }


/* =====  DEVICE MANAGEMENT TAB DEVICE HISTORY SECTION ===== */

    .DevMngt-tab-content .devHistoryCol {
        display: none !important;
    }

.custReg-input-container {
    position: relative;
    margin-bottom: 15px;
}

.custReg-input-container input,
.custReg-input-container select {
    width: 100%;
    padding: 10px; 
    padding-bottom: 50px;
    border: 2px solid #ccc;
    border-radius: 5px;
    outline: none;
    -webkit-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
}

.custReg-input-container label {
    position: absolute;
    top: 25%;
    left: 10px;
    background: white;
    -webkit-transform: translateY(-45%);
        -ms-transform: translateY(-45%);
            transform: translateY(-45%);
    min-width: 90%;
    padding: 0 5px;
    font-size: 12px;
    color: var(--color-primary);
    -webkit-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
    pointer-events: none;
}

.custReg-input-container input:not(:-moz-placeholder-shown), .custReg-input-container select:not(:-moz-placeholder-shown) {
    border-color: var(--color-secondary);
}

.custReg-input-container input:not(:-ms-input-placeholder), .custReg-input-container select:not(:-ms-input-placeholder) {
    border-color: var(--color-secondary);
}

.custReg-input-container input:focus,
.custReg-input-container input:not(:placeholder-shown),
.custReg-input-container select:focus,
.custReg-input-container select:not(:placeholder-shown) {
    border-color: var(--color-secondary);
}

.custReg-input-container input:not(:-moz-placeholder-shown) + label, .custReg-input-container select:not(:-moz-placeholder-shown) + label {
    top: -10%;
    min-width: 0%;
    color: var(--color-secondary);
}

.custReg-input-container input:not(:-ms-input-placeholder) + label, .custReg-input-container select:not(:-ms-input-placeholder) + label {
    top: -10%;
    min-width: 0%;
    color: var(--color-secondary);
}

.custReg-input-container input:focus + label,
.custReg-input-container input:not(:placeholder-shown) + label,
.custReg-input-container select:focus + label,
.custReg-input-container select:not(:placeholder-shown) + label {
    top: -10%;
    min-width: 0%;
    color: var(--color-secondary);
}

    #nextAdminAccountModalFooter.btn-primary {
        background-color: var(--color-secondary) !important;
        border-color: var(--color-secondary) !important;
        color: #fff !important;
    }
    #nextAdminAccountModalFooter.btn-primary:hover,
    #nextAdminAccountModalFooter.btn-primary:focus {
        background-color: var(--color-secondary-muted) !important;
        border-color: var(--color-secondary-muted) !important;
    }
    .admin-modal-lg {
        max-width: 900px !important;
        width: 100vw !important;
    }
    #adminAccountModal .modal-content {
        font-size: 1.75rem;
        padding: 2rem 1.5rem;
    }
    #adminAccountModal .modal-header,
    #adminAccountModal .modal-footer {
        font-size: 2rem;
    }
    #adminAccountModal .modal-title {
        font-size: 2rem;
    }
    #adminAccountModal .form-control {
        font-size: 1.75rem;
        padding: 0.75rem 1rem;
    }
}

/* ===== MENU MODULE ===== */

@media (max-width: 768px){
  /* Navbar becomes stacked and scrollable if it grows */
  header .navbar{
    width: 100%;
    gap: 1rem;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }

  /* Hide the desktop variant of auth link on mobile,
     show the mobile-specific one. These classes already
     exist in your file — reuse them for LOGIN on mobile. */
  .desktop-logout-link{ display: -webkit-box !important; display: -ms-flexbox !important; display: flex !important; }
  .mobile-logout-link{
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    margin: .8rem 0 0 0;
    padding: .8rem 1.2rem;
    border: .2rem solid var(--brand);
    background: #fff;
    color: var(--color-primary);
    text-align: right;
    font-weight: 700;
    border-radius: .5rem;
  }

  /* NEW: keep the Login button visible even if markup
     doesn't use the above classes (targets /login links & .login-btn) */
  header .navbar a[href*="login"],
  .login-btn{
    display: -webkit-inline-box !important;
    display: -ms-inline-flexbox !important;
    display: inline-flex !important;
  }

  /* NEW: hide the "Welcome, User" text on mobile */
  .welcome-text{ display: none !important; }

  /* Optional: if your old CSS tried to hide a logout item by icon */
  header .navbar a:has(i.bx-log-out){ display: none; }
}


/* ===== HOME MODULE ===== */

@media screen and (max-width: 768px) {
    /* Show hamburger icon on mobile */
    .hamburger-icon {
        display: block !important;
    }

    /* Move hamburger when sidebar is open */
    body.sidebar-overlay-active .hamburger-icon {
        left: 295px;
    }

    /* Sidebar base styles for mobile */
    #NavSec.sidebar {
        position: fixed !important;
        left: 0;
        top: 0;
        width: 280px !important;
        min-width: 280px !important;
        max-width: 280px !important;
        height: 100vh !important;
        max-height: 100vh !important;
        min-height: 123vh !important;
        z-index: 1045;
        background-color: #f9fbfa;
        -webkit-transition: -webkit-transform 0.3s ease;
        transition: -webkit-transform 0.3s ease;
        -o-transition: transform 0.3s ease;
        transition: transform 0.3s ease;
        transition: transform 0.3s ease, -webkit-transform 0.3s ease;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        -webkit-transform: translateX(0);
            -ms-transform: translateX(0);
                transform: translateX(0);
    }

    /* Sidebar collapsed state */
    #NavSec.sidebar.sidebar-collapsed {
        -webkit-transform: translateX(-100%);
            -ms-transform: translateX(-100%);
                transform: translateX(-100%);
    }

    /* Sidebar open state */
    #NavSec.sidebar.sidebar-open {
        -webkit-transform: translateX(0);
            -ms-transform: translateX(0);
                transform: translateX(0);
    }

    /* Main content adjustments */
    .mainContent {
        margin-left: 0 !important;
        width: 100% !important;
    }

    /* Main row should not be column on mobile for layout */
    body > .row,
    .row:has(#NavSec) {
        -webkit-box-orient: horizontal !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: row !important;
                flex-direction: row !important;
    }

    /* Add padding to content to avoid hamburger overlap */
    .content {
        padding-top: 70px;
    }

    /* Fix ItemsNav for mobile sidebar */
    #NavSec.sidebar #ItemsNav {
        max-height: calc(100vh - 280px) !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        display: block !important;
    }

    /* IMPORTANT: Allow Sidenav-content to be shown/hidden by JavaScript */
    #NavSec.sidebar .Sidenav-content {
        display: none;
    }

    /* Ensure area-devices can also be toggled */
    #NavSec.sidebar .area-devices {
        display: none;
    }

    /* Mobile tabs - limit width and show only 2 */
    .nav-tabs {
        display: -webkit-box !important;
        display: -ms-flexbox !important;
        display: flex !important;
        -ms-flex-wrap: nowrap !important;
            flex-wrap: nowrap !important;
        /* overflow-x: auto !important; */
        -webkit-overflow-scrolling: touch;
    }

    .nav-tabs .nav-item {
        -ms-flex-negative: 0;
            flex-shrink: 0;
    }

    /* Ensure tabs are scrollable if needed */
    .nav-tabs::-webkit-scrollbar {
        height: 4px;
    }

    .nav-tabs::-webkit-scrollbar-thumb {
        background: #ccc;
        border-radius: 2px;
    }

    /* Mobile tab styles */
    .nav-link {
        padding: 8px 25px !important;
        font-size: 11px !important;
    }

    .nav-link .fa-xmark {
        margin-left: 5px !important;
        font-size: 10px;
    }

    /* Sidebar navigation items - make them more tappable */
    /* .Sidenav-item {
        padding: 10px 20px;
    } */

    .Sideitem-header {
        padding: 8px 0;
        font-size: 13px;
    }

    .area-header {
        padding: 8px 0;
        font-size: 12px;
    }

    .Sidenav-subitem {
        padding: 10px 0;
        font-size: 12px;
    }

    /* Improve touch targets */
    .Sideitem-header:hover,
    .area-header:hover,
    .Sidenav-subitem:hover {
        background-color: #e8edeb;
    }

    .mulDevManage {
        font-size: 900% !important;
    }

    /* ===== MANAGEMENT TABS MOBILE INTEGRATION ===== */
    /* Asset Management Tab */
    #accManage .tab-pane,
    #regDevice .tab-pane,
    #meterInv .tab-pane {
        padding: 10px !important;
    }

    /* All management tab rows stack vertically */
    #accManage .row,
    #regDevice .row,
    #meterInv .row,
    .DevMngtContainer .row,
    .SysLoss-tab-content .row {
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
    }

    /* All columns full width on mobile */
    #accManage [class*="col-"],
    #regDevice [class*="col-"],
    #meterInv [class*="col-"],
    .DevMngtContainer [class*="col-"],
    .SysLoss-tab-content [class*="col-"] {
        width: 100% !important;
        max-width: 100% !important;
        -webkit-box-flex: 0 !important;
            -ms-flex: 0 0 100% !important;
                flex: 0 0 100% !important;
        padding: 10px 3px !important;
    }

    /* Management tab forms */
    #accManage input,
    #accManage select,
    #accManage textarea,
    #regDevice input,
    #regDevice select,
    #regDevice textarea,
    #meterInv input,
    #meterInv select,
    #meterInv textarea {
        width: 100% !important;
        padding: 12px !important;
        font-size: 14px !important;
        margin: 5px 0 10px 0 !important;
    }

    /* Management tab buttons */
    #accManage button,
    #accManage .btn,
    #regDevice button,
    #regDevice .btn,
    #meterInv button,
    #meterInv .btn {
        width: 100% !important;
        padding: 12px !important;
        margin: 5px 0 !important;
        min-height: 44px !important;
    }

    /* Management tab tables */
    #accManage table,
    #regDevice table,
    #meterInv table {
        display: block !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
        font-size: 10px !important;
    }

    #accManage table th,
    #accManage table td,
    #regDevice table th,
    #regDevice table td,
    #meterInv table th,
    #meterInv table td {
        padding: 8px 5px !important;
        white-space: nowrap !important;
        font-size: 10px !important;
    }

    /* Improve touch targets */
    .Sideitem-header:hover,
    .area-header:hover,
    .Sidenav-subitem:hover {
        background-color: #e8edeb;
    }

    /* ===== FLEET OVERVIEW MOBILE ===== */ 
    html, body {
        min-width: auto;
        zoom: 1 !important;
    }

    /* Main layout adjustments */
    .container-fluid {
        padding: 0 !important;
        height: auto !important;
        overflow-y: auto !important;
    }

    .mainContent {
        height: auto;
        min-height: 100vh;
    }

    /* Remove the problematic #NavSec and #ItemsNav overrides for mobile */
    /* These were causing the sidebar content to not expand */

    /* Fleet layout - stack vertically */
    .fleetCont {
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
        height: auto !important;
    }

    .leftside, .rightside {
        width: 100% !important;
        height: auto !important;
        padding: 10px !important;
    }

    /* Fleet Map Mobile Styles */
    #fleetMap {
        width: 100% !important;
        height: 500px !important;
        min-height: 400px !important;
        max-height: 80vh !important;
        margin-top: 15px !important;
        border-radius: 8px !important;
        -webkit-box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
                box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
    }

    .leftrow {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        gap: 10px;
        margin: 0;
    }

    #totInstCont, #totPowCont {
        width: 100% !important;
        height: auto !important;
        min-height: 150px !important;
    }

    #popKVACont, #summProfile, #instStatistics {
        height: 48% !important;
        width: 100% !important;
        height: auto !important;
        min-height: 200px !important;
        margin: 10px 0 !important;
        margin-bottom:10px 
    }

    /* Summary Profile Mobile Styles */
    #summProfile .boxCont,
    #summaryprofile {
        padding: 15px !important;
        align-items: center !important;
        /* overflow-x: auto !important;
        overflow-y: visible !important; */
    }

    /* Summary profile table/content responsive */
    #summProfile table,
    #summaryprofile table {
        width: 100% !important;
        font-size: 11px !important;
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }

    #summProfile th,
    #summProfile td,
    #summaryprofile th,
    #summaryprofile td {
        padding: 8px 6px !important;
        white-space: nowrap;
        font-size: 10px !important;
    }

    /* Summary profile chart container */
    #summProfile canvas,
    #summaryprofile canvas,
    #summProfile .chart-container,
    #summaryprofile .chart-container {
        width: 100% !important;
        height: auto !important;
        min-height: 200px !important;
        max-height: 300px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        margin: 0 auto !important;
    }

    /* Installation Statistics Mobile */
    #instStatistics .boxCont {
        padding: 15px !important;
        overflow-x: auto !important;
    }

    #instStatistics canvas,
    #instStatistics .chart-container {
        width: 100% !important;
        height: auto !important;
        min-height: 250px !important;
    }

    /* Popular KVA Container Mobile */
    #popKVACont .boxCont {
        padding: 15px !important;
    }

    #popKVACont canvas,
    #popKVACont .chart-container {
        width: 100% !important;
        height: auto !important;
        min-height: 200px !important;
    }

    /* Total Installation and Power containers */
    #totInstCont .boxCont,
    #totPowCont .boxCont {
        padding: 15px !important;
        text-align: center;
    }

    #totInstCont .OVWCardValues,
    #totPowCont .OVWCardValues {
        font-size: 45px !important;
        margin-top: 10px !important;
    }

    /* Form styles */
    .tab-pane {
        padding: 15px !important;
    }

    /* Input fields - full width */
    input[type="text"],
    input[type="email"],
    input[type="password"],
    input[type="number"],
    input[type="date"],
    select,
    textarea {
        width: 100% !important;
        padding: 10px !important;
        font-size: 16px; /* Prevents zoom on iOS */
        -webkit-box-sizing: border-box;
                box-sizing: border-box;
    }

    .objSize {
        width: 100% !important;
        height: 40px !important;
        padding: 10px !important;
    }

    /* Button styles */
    .submitBtn, .submitMulBtn {
        width: 100% !important;
        padding: 12px 16px !important;
        height: 44px !important;
        margin: 10px 0 !important;
        font-size: 14px;
    }

    .goToDevBtn {
        width: 100% !important;
        padding: 10px !important;
        height: auto !important;
    }

    /* Modal responsive */
    .modal-content {
        width: 95vw !important;
        max-width: 95vw !important;
        border-radius: 8px;
    }

    .modal-header {
        padding: 12px 15px !important;
    }

    .modal-body {
        padding: 15px !important;
        max-height: 70vh;
        overflow-y: auto;
    }

    .modal-footer {
        padding: 10px 15px !important;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
    }

    .modal-footer button {
        width: 100% !important;
        margin: 5px 0 !important;
    }

    /* Date range container */
    #infoDateRange {
        width: 100% !important;
        margin: 10px 0 !important;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        height: auto;
        gap: 10px;
    }

    .leftInfo {
        width: 100%;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
    }

    .dateRange {
        width: 100%;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        margin-right: 0 !important;
    }

    input[type="date"] {
        width: 100% !important;
        height: 40px !important;
    }

    /* Select buttons */
    .SelectButtons {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        gap: 8px;
        margin-left: 0 !important;
    }

    .buttAsset, .buttSysLoss {
        width: 100% !important;
        height: auto;
        padding: 10px 12px !important;
    }

    /* Tabs */
    .nav-tabs {
        width: 100% !important;
        margin-left: 0 !important;
        /* overflow-x: auto; */
        -ms-flex-wrap: nowrap;
            flex-wrap: nowrap;
    }

    .nav-link {
        /* padding: 10px 12px !important; */
        font-size: 12px;
        white-space: nowrap;
    }

    /* Breadcrumb */
    .breadcrumb {
        font-size: 11px;
        margin-left: 0 !important;
    }

    .breadcrumb-item + .breadcrumb-item::before {
        margin: 0 3px;
    }

    /* Actions */
    .overview-actions {
        position: static;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        gap: 8px;
        width: 100%;
        margin-top: 10px;
    }

    .fleet-refresh-btn, 
    #mapButton button,
    .mapButton button {
        width: 100% !important;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        margin-top: 0 !important;
    }

    #mapButton, .mapButton {
        position: static;
        width: 100%;
    }

    /* Title navigation */
    #TitleNav {
        height: auto;
        padding: 10px;
        width: 100% !important;
        margin-left: 0 !important;
    }

    .title-wrapper {
        /* flex-direction: column; */
        gap: 8px;
    }

    #SubTitleNav {
        height: auto;
        padding: 10px !important;
        margin: 0 !important;
    }

    .icons-wrapper {
        margin-left: 0;
        -webkit-box-pack: end;
            -ms-flex-pack: end;
                justify-content: flex-end;
    }

    /* Search input */
    #searchInput {
        width: 100% !important;
        height: 40px;
        margin: 0 !important;
        padding: 8px 10px !important;
    }

    /* Content spacing */
    #innerTabContent, .innerTabContent {
        margin: 15px 0 !important;
        height: auto !important;
    }

    #CorrelationContImage, 
    [id^="CorrelationContImage"],
    #ReportsContImage,
    #AlertContImage {
        width: 100% !important;
        height: auto !important;
        margin-left: 0 !important;
    }

    /* Box containers */
    .boxCont {
        padding: 12px !important;
        margin-bottom: 10px !important;
    }

    .OVWCardTitle {
        font-size: large;
    }

    .OVWCardTitle2 {
        margin-left: 5px !important;
        font-size: 14px;
    }

    /* White area */
    #WhiteArea {
        height: 45px;
        padding: 10px;
    }

    #logoutIcon {
        font-size: 18px;
        margin-right: 10px;
    }

    /* Settings popup */
    .settings-popup {
        right: 10px;
        left: 10px;
        top: 50px;
        max-width: none;
    }

    /* Form group spacing */
    .form-group {
        margin-bottom: 12px !important;
    }

    /* Row adjustments */
    .row {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
    }

    .col-md-8, .col-md-4, .col-lg-4 {
        width: 100% !important;
        max-width: 100% !important;
        -webkit-box-flex: 0 !important;
            -ms-flex: 0 0 100% !important;
                flex: 0 0 100% !important;
    }
}

/* ===== CHARTS ===== */

@media screen and (max-width: 768px) {

/* ===== MULTIPLE DEVICES ===== */  
.overview-wrapper .col-md-8 .boxCont {
    min-height: 270px !important;
}

/* Ensure DashChart takes up the full height without overflow */
.maximized .DashChart {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            /* flex-grow: 1; */
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
}

}

/* ===== LANDSCAPE ORIENTATION STYLES ===== */

@media screen and (max-height: 500px) and (orientation: landscape) {
    /* Login Page Landscape */
    .login-content {
        width: 100% !important;
        padding: 10px !important;
        min-height: auto !important;
    }

    .login-form {
        width: 100% !important;
        max-width: 100% !important;
        padding: 15px !important;
        margin: 0 auto !important;
    }

    .login-logo {
        margin-top: 0 !important;
        width: 80px !important;
        height: 40px !important;
    }

    .login-title {
        font-size: 1.2rem !important;
        margin-bottom: 0.5rem !important;
    }

    .login-text {
        font-size: 12px !important;
        margin-bottom: 10px !important;
    }

    .input-div {
        margin-bottom: 10px !important;
    }

    .input-div input {
        font-size: 14px !important;
        height: 35px !important;
    }

    .btn {
        height: 40px !important;
        font-size: 14px !important;
        margin: 0.8rem 0 0.5rem !important;
    }

    h2 {
        font-size: 1.2rem !important;
        margin-bottom: 1rem !important;
    }

    .alert {
        font-size: 12px !important;
        margin-bottom: 1rem !important;
        padding: 8px !important;
    }

    /* Reset Password Landscape */
    .reset-password-form {
        width: 100% !important;
        max-width: 100% !important;
        padding: 15px !important;
        margin: 0 auto !important;
    }

    .reset-title {
        font-size: 1.2rem !important;
        margin-top: 0 !important;
    }

    /* Header Navigation Landscape */
    header .navbar {
        gap: 0.5rem !important;
        padding: 8px 0 !important;
    }

    /* Main Content Landscape */
    .mainContent {
        overflow-y: auto !important;
        max-height: calc(100vh - 60px) !important;
    }

    body, html {
        height: 100% !important;
        overflow: hidden !important;
    }

    /* Sidebar Landscape */
    #NavSec.sidebar {
        height: 100vh !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
    }

    /* Container adjustments for landscape */
    .container-fluid {
        height: 100vh !important;
        overflow-y: auto !important;
    }

    /* Dashboard Landscape */
    .dashContainer {
        flex-direction: column !important;
        gap: 0.5rem !important;
    }

    .DashStat {
        padding: 10px !important;
    }

    .DashStat2 {
        padding: 10px !important;
    }

    .DashValue {
        font-size: 1.2rem !important;
    }

    .DashSub-label {
        font-size: 11px !important;
    }

    /* Tabs Landscape */
    .nav-tabs {
        margin: 0 -12px !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        flex-wrap: nowrap !important;
        white-space: nowrap !important;
    }

    .nav-tabs .nav-item {
        flex-shrink: 0 !important;
        margin-right: 5px !important;
    }

    .nav-link {
        padding: 0.5rem 0.8rem !important;
        font-size: 12px !important;
    }

    /* Forms Landscape */
    input[type="text"],
    input[type="email"],
    input[type="password"],
    input[type="number"],
    input[type="date"],
    select,
    textarea {
        font-size: 14px !important;
        padding: 8px !important;
        height: auto !important;
    }

    .devMngmt-input-container input,
    .devMngmt-input-container select,
    .custReg-input-container input,
    .custReg-input-container select {
        padding: 8px !important;
        padding-bottom: 30px !important;
    }

    .devMngmt-input-container label,
    .custReg-input-container label {
        font-size: 11px !important;
    }

    /* Buttons Landscape */
    .btn, button {
        padding: 8px 12px !important;
        font-size: 13px !important;
        height: auto !important;
        min-height: 36px !important;
    }

    .submitBtn, .submitMulBtn {
        padding: 8px 15px !important;
        font-size: 13px !important;
    }

    /* Tables Landscape */
    table {
        font-size: 12px !important;
    }

    table th,
    table td {
        padding: 6px !important;
    }

    /* Modal Landscape */
    .modal-content {
        max-height: calc(100vh - 40px) !important;
        overflow-y: auto !important;
    }

    .modal-body {
        max-height: calc(100vh - 150px) !important;
        overflow-y: auto !important;
    }

    .modal-header {
        padding: 10px !important;
    }

    /* Charts and Images Landscape */
    canvas {
        max-height: 300px !important;
        max-width: 100% !important;
    }

    .chart-container {
        height: 250px !important;
    }

    /* Box containers Landscape */
    .boxCont {
        padding: 10px !important;
        margin-bottom: 10px !important;
    }

    .OVWCardTitle {
        font-size: 13px !important;
    }

    .OVWCardTitle2 {
        font-size: 12px !important;
    }

    /* Breadcrumb Landscape */
    .breadcrumb {
        font-size: 11px !important;
        padding: 0.3rem 0 !important;
    }

    /* Date Range Landscape */
    .infoDateRange,
    [class*="infoDateRange"] {
        flex-direction: column !important;
        gap: 0.5rem !important;
    }

    .dateRange {
        flex-direction: row !important;
        gap: 5px !important;
    }

    .dateRange input {
        font-size: 12px !important;
        padding: 6px !important;
    }

    /* Settings popup Landscape */
    .settings-popup {
        max-height: calc(100vh - 50px) !important;
        overflow-y: auto !important;
    }

    /* Asset and System Loss tables Landscape */
    .SysLoss-tab-content {
        overflow-y: auto !important;
        max-height: calc(100vh - 120px) !important;
    }

    .SysLoss-tab-content table {
        font-size: 12px !important;
    }

    /* Device history Landscape */
    .devHistCont {
        max-height: 200px !important;
        overflow-y: auto !important;
    }

    .devHistoryEntry {
        padding: 6px !important;
        font-size: 12px !important;
    }

    /* Ensure scrollbars are visible on demand */
    .mainContent::-webkit-scrollbar,
    #NavSec.sidebar::-webkit-scrollbar,
    .modal-body::-webkit-scrollbar,
    .SysLoss-tab-content::-webkit-scrollbar,
    .devHistCont::-webkit-scrollbar {
        width: 6px !important;
    }

    .mainContent::-webkit-scrollbar-track,
    #NavSec.sidebar::-webkit-scrollbar-track,
    .modal-body::-webkit-scrollbar-track,
    .SysLoss-tab-content::-webkit-scrollbar-track,
    .devHistCont::-webkit-scrollbar-track {
        background: #f1f1f1 !important;
    }

    .mainContent::-webkit-scrollbar-thumb,
    #NavSec.sidebar::-webkit-scrollbar-thumb,
    .modal-body::-webkit-scrollbar-thumb,
    .SysLoss-tab-content::-webkit-scrollbar-thumb,
    .devHistCont::-webkit-scrollbar-thumb {
        background: var(--color-primary) !important;
        border-radius: 3px !important;
    }

    .mainContent::-webkit-scrollbar-thumb:hover,
    #NavSec.sidebar::-webkit-scrollbar-thumb:hover,
    .modal-body::-webkit-scrollbar-thumb:hover,
    .SysLoss-tab-content::-webkit-scrollbar-thumb:hover,
    .devHistCont::-webkit-scrollbar-thumb:hover {
        background: var(--color-primary-muted) !important;
    }

}

/* ===== DEVICE MANAGEMENT MOBILE MODAL ===== */
/* Updated: Remove modal styling, keep as scrollable page */
@media (max-width: 768px) {
    .DevMngt-tab-content .tab-pane {
        padding: 10px !important;
    }

    /* Device details section - simple card layout */
    .mainDetDevMngmt {
        background: white;
        border-radius: 8px;
        border: 1px solid #e0e0e0;
        margin: 10px 0 !important;
        padding: 15px !important;
    }

    /* Device management rows - stack vertically */
    .DevMngtContainer .row {
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
    }

    .DevMngtContainer [class*="col-"] {
        width: 100% !important;
        max-width: 100% !important;
        -webkit-box-flex: 0 !important;
            -ms-flex: 0 0 100% !important;
                flex: 0 0 100% !important;
        padding: 10px 0 !important;
    }

    /* Device info input containers - standard mobile form */
    .devMngmt-input-container {
        background: transparent;
        border-radius: 5px;
        padding: 6px 0 !important;
        margin-bottom: 10px !important;
    }

    /* .devMngmt-input-container label {
        position: static !important;
        -webkit-transform: none !important;
            -ms-transform: none !important;
                transform: none !important;
        display: block !important;
        margin-bottom: 5px !important;
        font-weight: 500 !important;
        color: #333 !important;
        background: transparent !important;
        font-size: 13px !important;
    } */

    .devMngmt-input-container input,
    .devMngmt-input-container select {
        background: white !important;
        border: 1px solid #ccc !important;
        border-radius: 5px !important;
        padding: 10px 10px !important;
        width: 100% !important;
        font-size: 14px !important;
    }

    .devMngmt-input-container input:focus,
    .devMngmt-input-container select:focus {
        border-color: var(--color-primary) !important;
        outline: none !important;
    }

    /* When a field has value or is focused, show green cue on label and border */
    .devMngmt-input-container input:not(:placeholder-shown),
    .devMngmt-input-container input[value]:not([value=""]),
    .devMngmt-input-container select:valid {
        border-color: var(--color-primary) !important;
    }

    .devMngmt-input-container input:not(:placeholder-shown) + label,
    .devMngmt-input-container input[value]:not([value=""]) + label,
    .devMngmt-input-container input:focus + label,
    .devMngmt-input-container select:valid + label,
    .devMngmt-input-container select:focus + label {
        color: var(--color-primary) !important;
    }

    /* Action buttons in device management */
    .DevMngtContainer button,
    .DevMngtContainer .btn {
        width: 100% !important;
        margin: 5px 0 !important;
        min-height: 44px !important;
        padding: 12px !important;
    }

    /* Device history section - collapsible card */
    .devHistoryCol {
        background: #f9f9f9;
        border-radius: 8px;
        border: 1px solid #e0e0e0;
        padding: 15px !important;
        margin-top: 20px !important;
    }

    .devHistory {
        background: transparent;
        border-radius: 0;
        padding: 10px 0 !important;
        margin-bottom: 10px !important;
        border-bottom: 2px solid #f7dc6f;
    }

    .devHistCont {
        background: white;
        border-radius: 5px;
        padding: 10px;
        min-height: 200px !important;
        max-height: 400px !important;
    }

    .devHistoryEntry {
        background: white;
        border: 1px solid #e0e0e0;
        border-left: 3px solid var(--color-primary);
        border-radius: 5px;
        padding: 10px !important;
        margin-bottom: 10px !important;
        font-size: 11px !important;
    }
}

/* ===== SYSTEM LOSS TAB MOBILE ===== */
@media (max-width: 768px) {
    .SysLoss-tab-content {
        padding: 0 !important;
    }

    .SysLoss-tab-content .tab-pane {
        padding: 10px !important;
    }

    /* System loss navigation tabs */
    .SysLoss-tab-content .nav-tabs,
    .SysLoss-tab-content .spec-nav-tabs {
        display: -webkit-box !important;
        display: -ms-flexbox !important;
        display: flex !important;
        -ms-flex-wrap: nowrap !important;
            flex-wrap: nowrap !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
        padding: 0 !important;
        margin: 0 !important;
        width: 100% !important;
    }

    .SysLoss-tab-content .nav-link {
        padding: 10px 15px !important;
        font-size: 11px !important;
        white-space: nowrap !important;
        -ms-flex-negative: 0 !important;
            flex-shrink: 0 !important;
    }

    /* System loss content areas */
    .SysLoss-tab-content .row {
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
    }

    .SysLoss-tab-content [class*="col-"] {
        width: 100% !important;
        max-width: 100% !important;
        -webkit-box-flex: 0 !important;
            -ms-flex: 0 0 100% !important;
                flex: 0 0 100% !important;
        padding: 5px 0 !important;
    }

    /* System loss charts */
    .SysLoss-tab-content canvas {
        width: 100% !important;
        height: auto !important;
        min-height: 200px !important;
    }

    /* System loss tables */
    .SysLoss-tab-content table {
        display: block !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
        font-size: 10px !important;
    }

    /* System loss forms */
    .SysLoss-tab-content input,
    .SysLoss-tab-content select,
    .SysLoss-tab-content textarea {
        width: 100% !important;
        padding: 12px !important;
        font-size: 14px !important;
        margin: 5px 0 !important;
    }

    .SysLoss-tab-content button,
    .SysLoss-tab-content .btn {
        width: 100% !important;
        padding: 12px !important;
        margin: 5px 0 !important;
        min-height: 44px !important;
    }
}

/* ===== ASSET MANAGEMENT TAB MOBILE ===== */
@media (max-width: 768px) {
    /* Asset info container */
    .infoDateRange,
    [class*="infoDateRange"] {
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
        height: auto !important;
        padding: 15px !important;
        gap: 15px !important;
        width: 100% !important;
        margin: 10px 0 !important;
    }

    .infoDateRange .leftInfo,
    [class*="infoDateRange"] .leftInfo {
        width: 100% !important;
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
        -webkit-box-align: start !important;
            -ms-flex-align: start !important;
                align-items: flex-start !important;
        gap: 10px !important;
    }

    .infoDateRange .dateRange,
    [class*="infoDateRange"] .dateRange {
        width: 100% !important;
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
        gap: 10px !important;
        margin: 0 !important;
    }

    .infoDateRange p {
        font-size: 12px !important;
    }

    /* Asset inner tab content */
    .innerTabContent,
    [class*="innerTabContent"] {
        margin: 10px 0 !important;
        padding: 0 !important;
        height: auto !important;
    }

    /* Asset charts and images */
    .innerTabContent canvas,
    .innerTabContent img,
    [class*="CorrelationContImage"] {
        width: 100% !important;
        height: auto !important;
        min-height: 200px !important;
        margin: 0 !important;
    }

    /* Asset select buttons */
    .SelectButtons {
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
        width: 100% !important;
        gap: 10px !important;
        margin: 10px 0 !important;
    }

    .buttAsset,
    .buttSysLoss {
        width: 100% !important;
        height: 44px !important;
        padding: 12px 15px !important;
        font-size: 13px !important;
        -webkit-box-pack: center !important;
            -ms-flex-pack: center !important;
                justify-content: center !important;
    }

    /* Asset dropdown/select */
    .objSize,
    .SubObjSize {
        width: 100% !important;
        height: 44px !important;
        padding: 10px 15px !important;
        font-size: 14px !important;
        margin: 5px 0 !important;
    }
}

/* ===== ACCOUNT MANAGEMENT MOBILE ===== */
@media (max-width: 768px) {
    #addAccBtn {
        width: 100% !important;
        margin-bottom: 15px !important;
    }

    /* Account table actions */
    .edit-btn,
    .del-btn {
        display: block !important;
        width: 100% !important;
        margin: 3px 0 !important;
        padding: 8px !important;
    }
}

/* Fix cutoff textboxes in register device tab on mobile */
@media (max-width: 768px) {
    #regDevMngtCont {
        width: 100vw !important;
        max-width: 100vw !important;
        min-width: 0 !important;
        margin: 0 !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        box-sizing: border-box !important;
        overflow-x: hidden !important;
    }
    #regDevMngtCont .devMngmt-input-container {
        width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        box-sizing: border-box !important;
        overflow-x: visible !important;
    }
    #regDevMngtCont .devMngmt-input-container input,
    #regDevMngtCont .devMngmt-input-container select {
        width: 100% !important;
        min-width: 0 !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        overflow-x: visible !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    /* Also ensure no horizontal scroll on body for mobile */
    body, html {
        overflow-x: hidden !important;
    }
    /* Fix toggle button cutoff in register device tab */
    #regDevMngtCont .form-check,
    #regDevMngtCont .form-switch {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        box-sizing: border-box !important;
        overflow-x: visible !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
    }
    #regDevMngtCont .form-check-input,
    #regDevMngtCont .form-switch .form-check-input {
        /* width: 40px !important; */
        min-width: 40px !important;
        max-width: 60px !important;
        height: 24px !important;
        min-height: 24px !important;
        max-height: 32px !important;
        box-sizing: border-box !important;
        margin: 0 10px 0 0 !important;
        display: inline-block !important;
        vertical-align: middle !important;
    }
    #regDevMngtCont .form-check-label {
        font-size: 13px !important;
        padding-left: 20px !important;
        /* margin-left: 0 !important; */
        white-space: normal !important;
        width: auto !important;
        flex: 1 1 0%;
    }
}

@media (max-width: 768px) {
    /* Hide device history section on device management tab for mobile */
    .DevMngt-tab-content .devHistoryCol {
        display: none !important;
    }
}

.custReg-input-container {
    position: relative;
    margin-bottom: 15px;
}

.custReg-input-container input,
.custReg-input-container select {
    width: 100%;
    padding: 10px; 
    padding-bottom: 50px;
    border: 2px solid #ccc;
    border-radius: 5px;
    outline: none;
    -webkit-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
}

.custReg-input-container label {
    position: absolute;
    top: 25%;
    left: 10px;
    background: white;
    -webkit-transform: translateY(-45%);
        -ms-transform: translateY(-45%);
            transform: translateY(-45%);
    min-width: 90%;
    padding: 0 5px;
    font-size: 12px;
    color: #777;
    -webkit-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
    pointer-events: none;
}

.custReg-input-container input:not(:-moz-placeholder-shown), .custReg-input-container select:not(:-moz-placeholder-shown) {
    border-color: var(--color-primary);
}

.custReg-input-container input:not(:-ms-input-placeholder), .custReg-input-container select:not(:-ms-input-placeholder) {
    border-color: var(--color-primary);
}

.custReg-input-container input:focus,
.custReg-input-container input:not(:placeholder-shown),
.custReg-input-container select:focus,
.custReg-input-container select:not(:placeholder-shown) {
    border-color: var(--color-primary);
}

.custReg-input-container input:not(:-moz-placeholder-shown) + label, .custReg-input-container select:not(:-moz-placeholder-shown) + label {
    top: -10%;
    min-width: 0%;
    color: var(--color-primary);
}

.custReg-input-container input:not(:-ms-input-placeholder) + label, .custReg-input-container select:not(:-ms-input-placeholder) + label {
    top: -10%;
    min-width: 0%;
    color: var(--color-primary);
}

.custReg-input-container input:focus + label,
.custReg-input-container input:not(:placeholder-shown) + label,
.custReg-input-container select:focus + label,
.custReg-input-container select:not(:placeholder-shown) + label {
    top: -10%;
    min-width: 0%;
    color: var(--color-primary);
}

/* Make Next button green */
    #nextAdminAccountModalFooter.btn-primary {
        background-color: var(--color-primary) !important;
        border-color: var(--color-primary) !important;
        color: #fff !important;
    }
    #nextAdminAccountModalFooter.btn-primary:hover,
    #nextAdminAccountModalFooter.btn-primary:focus {
        background-color: #5a8e00 !important;
        border-color: #5a8e00 !important;
    }
    /* Make Admin Account Details Modal bigger */
    .admin-modal-lg {
        max-width: 900px !important;
        width: 100vw !important;
    }
    #adminAccountModal .modal-content {
        font-size: 1.75rem;
        padding: 2rem 1.5rem;
    }
    #adminAccountModal .modal-header,
    #adminAccountModal .modal-footer {
        font-size: 2rem;
    }
    #adminAccountModal .modal-title {
        font-size: 2rem;
    }
    #adminAccountModal .form-control {
        font-size: 1.75rem;
        padding: 0.75rem 1rem;
    }

    /* ===== MOBILE RESPONSIVE STYLES FOR MANAGEMENT TABS ===== */
@media (max-width: 768px) {
    /* ===== DASHBOARD TAB MOBILE ===== */
    .dashContainer {
        min-width: 100% !important;
        margin-left: 0 !important;
        /* padding: 10px !important; */
    }

    .left-panel {
        margin-left: 0 !important;
        width: 100% !important;
    }

    .DashStat {
        width: 10px !important;
        /* padding: 20px 15px !important;
        margin-bottom: 15px !important; */
    }

    .DashValue {
        font-size: 1.5rem !important;
    }

    .DashSub-label {
        font-size: 0.8rem !important;
    }

    .DashChart {
        margin-top: 15px !important;
    }

    .chart-header {
        -ms-flex-wrap: wrap !important;
            flex-wrap: wrap !important;
        gap: 10px !important;
    }

    .tabDash, .tabAlarm {
        padding: 8px 12px !important;
        font-size: 11px !important;
    }

    .select_single {
        width: 100% !important;
        margin: 5px 0 !important;
        padding: 10px !important;
    }

    /* ===== REPORTS CONTAINER MOBILE ===== */
    .reportsContainer,
    .AlertsContainer,
    .DevMngtContainer,
    .ConReportsContainer {
        margin-left: 0 !important;
        min-width: 100% !important;
        width: 100% !important;
        /* padding: 10px !important; */
    }

    .reportsSection {
        margin-top: 5px !important;
    }

    /* DataTables buttons mobile */
    .dt-buttons {
        margin-bottom: 10px !important;
        display: -webkit-box !important;
        display: -ms-flexbox !important;
        display: flex !important;
        -ms-flex-wrap: wrap !important;
            flex-wrap: wrap !important;
        gap: 5px !important;
        width: 100% !important;
    }

    .dt-button {
        -webkit-box-flex: 1 !important;
            -ms-flex: 1 1 calc(50% - 5px) !important;
                flex: 1 1 calc(50% - 5px) !important;
        padding: 10px !important;
        font-size: 11px !important;
        text-align: center !important;
    }

    .dt-button-collection {
        width: 95vw !important;
        left: 2.5vw !important;
        top: 10% !important;
        -webkit-transform: none !important;
            -ms-transform: none !important;
                transform: none !important;
        max-height: 70vh !important;
    }

    /* Reports table: keep header aligned with body while scrolling on mobile */
    [id^="ReportsCont"] .dataTables_wrapper {
        position: relative !important;
    }

    [id^="ReportsCont"] .dataTables_scrollHead {
        position: sticky !important;
        top: 0 !important;
        z-index: 4 !important;
        background: #fff !important;
        overflow: hidden !important;
    }

    [id^="ReportsCont"] .dataTables_scrollHeadInner,
    [id^="ReportsCont"] .dataTables_scrollHeadInner table,
    [id^="ReportsCont"] .dataTables_scrollBody,
    [id^="ReportsCont"] .dataTables_scrollBody table {
        width: 100% !important;
    }

    [id^="ReportsCont"] .dataTables_scrollHeadInner table {
        margin-bottom: 0 !important;
    }

    [id^="ReportsCont"] .dataTables_scrollBody {
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
    }

    /* ===== ALERTS SECTION MOBILE ===== */
    .alertsSection,
    .enerConSection {
        -webkit-box-orient: vertical !important;
        -webkit-box-direction: normal !important;
            -ms-flex-direction: column !important;
                flex-direction: column !important;
        gap: 15px !important;
    }

    .alarmDetClass {
        max-height: 300px !important;
        font-size: 11px !important;
    }

    .alerts-header-cell {
        font-size: 10px !important;
    }

    /* ===== ENERGY CONSUMPTION MOBILE ===== */
    .EnerConTable {
        font-size: 10px !important;
    }

    /* ===== DEVICE MANAGEMENT TAB MOBILE ===== */
    .DevMngtContainer {
        padding: 10px !important;
    }

    .mainDetDevMngmt {
        margin-left: 0 !important;
        padding: 10px !important;
    }

    .devMngmt-input-container {
        margin-bottom: 20px !important;
    }

    .devMngmt-input-container input,
    .devMngmt-input-container select {
        padding: 8px 8px !important;
        font-size: 13px !important;
        width: 100% !important;
        box-sizing: border-box !important;
    }

    .devMngmt-input-container label {
        font-size: 11px !important;
    }

    .grayedButton {
        width: 100% !important;
        padding: 12px 20px !important;
        margin-bottom: 10px !important;
    }

    /* Device History Column Mobile */
    .devHistoryCol {
        width: 100% !important;
        margin-top: 15px !important;
    }

    .devHistory {
        padding: 10px !important;
        font-size: 12px !important;
    }

    .devHistCont {
        min-height: 200px !important;
        max-height: 300px !important;
    }

    .devHistoryEntry {
        font-size: 11px !important;
        padding: 8px !important;
    }

    .devHistSearch {
        width: 100% !important;
        height: 40px !important;
        font-size: 14px !important;
    }

    .confirmTextDevMngt {
        width: 100% !important;
        height: 150px !important;
        padding: 15px !important;
        font-size: 12px !important;
    }

    /* Form switches mobile */
    .form-check {
        padding-left: 0 !important;
        padding-top: 10px !important;
    }

    .form-switch .form-check-input {
        width: 2.5rem !important;
        height: 1.25rem !important;
    }

    .form-check-label {
        margin-left: 50px !important;
        font-size: 12px !important;
    }

    /* ===== MULTIPLE DEVICE VIEW MOBILE ===== */
    .MultDevTitle {
        font-size: 20px !important;
    }

    .mulDevManage {
        font-size: 900% !important;
    }

    .goToDevClass {
        margin-top: 10px !important;
    }

    .goToDevSel {
        width: 100% !important;
        padding: 12px !important;
        font-size: 14px !important;
    }

    .goToDevBtn {
        width: 100% !important;
        padding: 12px !important;
        margin-top: 15px !important;
    }

    .searchMulDev {
        width: 100% !important;
        padding: 10px !important;
        font-size: 14px !important;
    }

    .editDeviceModal {
        padding: 15px !important;
    }

    .editDev-title {
        font-size: 1rem !important;
    }

    .confirmTextMulDev {
        width: 100% !important;
        height: 80px !important;
    }

    /* Popup overlay mobile */
    .popupOverlay {
        width: 100vw !important;
        height: 100vh !important;
    }

    .loadPopUpGoToDevice {
        width: 90vw !important;
        left: 5vw !important;
        top: 30% !important;
        -webkit-transform: none !important;
            -ms-transform: none !important;
                transform: none !important;
        padding: 20px !important;
    }

    /* ===== TABLES MOBILE ===== */
    table.dataTable {
        display: block !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
    }

    table.dataTable thead th {
        font-size: 10px !important;
        padding: 8px 5px !important;
        white-space: nowrap !important;
    }

    table.dataTable tbody td {
        font-size: 9px !important;
        padding: 6px 5px !important;
        white-space: nowrap !important;
    }

    /* DataTables wrapper mobile */
    .dataTables_wrapper {
        width: 100% !important;
        overflow-x: auto !important;
    }

    .dataTables_filter {
        width: 100% !important;
        margin-bottom: 10px !important;
    }

    .dataTables_filter input {
        width: 100% !important;
        max-width: none !important;
        padding: 10px !important;
        font-size: 14px !important;
    }

    .dataTables_length {
        margin-bottom: 10px !important;
    }

    .dataTables_length select {
        padding: 8px !important;
    }

    .dataTables_info {
        font-size: 11px !important;
        margin-top: 10px !important;
    }

    .dataTables_paginate {
        margin-top: 10px !important;
    }

    .dataTables_paginate .paginate_button {
        padding: 8px 12px !important;
        font-size: 11px !important;
    }

    /* No data message mobile */
    .noData, .noDataSmall {
        font-size: 1rem !important;
        margin-top: 20% !important;
    }

    .noData img, .noData i {
        height: 60px !important;
        font-size: 60px !important;
    }

    .noDataSmall {
        font-size: 0.8rem !important;
        margin-top: 30% !important;
    }

    .noDataSmall img {
        height: 40px !important;
    }

    /* Loading overlay mobile */
    .loadingOverlay {
        font-size: 1rem !important;
    }

    .spinner {
        width: 30px !important;
        height: 30px !important;
    }

    /* Maximized chart mobile */
    .maximized {
        min-width: 95vw !important;
        min-height: 80vh !important;
        padding: 15px !important;
    }
}

