﻿@import url('Content/Css/style.css');

* {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

:root {
    /*light theme*/
    --top-logo-maxwidth: 100px;
    --bg: #f7f7f7;
    --bg-container: white;
    --bg-border: var(--primary-color);
    --item-fill: lightgrey;
    --bolt-color: black;
    --header-text-color: #fff;
    --primary-text: rgb(13, 31, 46);
    --tab-color: #010101;
    --text-almost-black: #010101;
    --secondary-text: rgba(13, 31, 46, 0.7);
    --light-text: rgba(13, 31, 46, 0.5);
    --text-primary-dark: rgb(13, 31, 46);
    --active: #FFF7E6;
    --hover: rgba(0,0,0,0.05);
    --color-white-rgb: 255 255 255;
    --color-black-rgb: 0 0 0;
    --link: #0d6efd;
    --indicator-hover: #A0A5AA;
    --sidebar-bg: 255,255,255;
    --border-default: #D8D5D1;
    --surface-input: #FFFEFE;
    --text-label: #333;
    --text-inactive: #666;
    --color-grey-light: #c0c0c0;
    --color-soft-grey: #F5F4F2;
    --border-bottom-top-bar: #e1e1e1;
    --rz-base-background-color: var(--bg-container) !important;
    --rz-primary: var(--bbt-dark) !important;
    --rz-primary-light: var(--bbt-light-hex) !important;
    --rz-on-primary-lighter: var(--bbt-dark) !important;
    --rz-primary-lighter: rgba(255, 71, 26, 0.12) !important;
    --rz-primary-dark: #cb3d42 !important;
    --rz-border-radius: 8px !important;
    --rz-profile-menu-toggle-button-color: rgb(13, 31, 46) !important;
    --rz-navigation-item-text: rgb(13, 31, 46) !important;
    --rz-chart-axis-font-size: 0.75rem !important;
    --rz-input-font-size: 0.9rem !important;
    --rz-dropdown-open-background-color: var(--bg-container) !important;
    --rz-tabs-tab-selected-color: var(--bbt-dark) !important;
    /* Font Family */
    --primary-font-family: 'Primary-Regular-Graphik';
    --secondary-font-family: 'Secondary-Regular-PPFraktion';
    --chart-font-family: 'Primary-Regular-Inter';
    /* TopRow */
    --toprow-padding: 24px;
    --toprow-height: 70px;
    --toprow-border-color: var(--primary-color);
    --toprow-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
    --border-light: #E9E9E9;
    --pill-height: 32px;
    --pill-padding: 10px 15px;
    --pill-border-radius: 16px;
    --pill-gap: 17px;
    --mobile-bottom-nav-height: 80px;
    --dropdown-shadow: drop-shadow(0 0 4px rgba(0, 0, 0, 0.10));
    --dropdown-max-height: 258px;
    --dropdown-border-radius: 5px;
    --font-size-xs: 11px;
    --font-size-sm: 12px;
    --font-size-md: 14px;
    --font-size-subtitle: 18px;
    /* Icon Path */
    --icon-base-path: '_content/BatteryApp.Library/Content/Icons';
    --nav-font-family: var(--secondary-font-family);
    --nav-font-size: 12px;
    --nav-font-weight: 400;
    --nav-font-weight-active: 500;
    --nav-line-height: 120%;
    --nav-text-transform: uppercase;
    --nav-color: var(--secondary-text);
    --active-text: #FFF4EF;
    /* Spacing*/
    --spacing-xs: 4px;
    --spacing-sm: 8px;
    --spacing-md: 12px;
    --spacing-lg: 16px;
    --spacing-xl: 20px;
    --spacing-2xl: 24px;
    --spacing-3xl: 32px;
    --spacing-4xl: 40px;
    --spacing-5xl: 48px;
    --spacing-6xl: 60px;
    --spacing-7xl: 80px;
    --spacing-8xl: 96px;
    --spacing-9xl: 120px;
    --font-weight-semibold: 600;
    --opacity-disabled: 0.3;
    --shadow-power-data: 0 4px 4px 0 rgba(0, 0, 0, 0.10);
    --transition-medium: 300ms ease;
    --transition-transform: 420ms cubic-bezier(.2,.9,.2,1);
    --transition-pagination: 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    --z-index-base: 1;
    --z-index-overlay: 2;
    --z-index-elevated: 3;
    --z-index-top: 10;
    --animation-duration-base: 1s;
    --width-65-percent: 65%;
    --charge-level: 0.48;
    --border-radius-sm: 5px;
    --border-radius-md: 8px;
    --border-radius-lg: 10px;
    --border-radius-pill: 16px;
    --border-radius-full: 50%;
    --input-height: 56px;
    --button-height: 54px;
    /* Font Sizes*/
    --font-size-base: 14px;
    --font-size-lg: 16px;
    --font-size-xl: 20px;
    --font-size-2xl: 24px;
    --font-size-3xl: 28px;
    --font-size-4xl: 32px;
    /* Padding */
    --input-padding-vertical: 16px;
    --input-padding-horizontal: 20px;
    --button-padding-vertical: 10px;
    --button-padding-horizontal: 20px;
    --card-padding: 37px;
    --card-padding-sm: 20px;
    /* Modal */
    --modal-padding-top: 60px;
    --modal-padding-horizontal: 60px;
    --modal-padding-bottom: 50px;
    --modal-content-width: 500px;
    --modal-content-min-height: 550px;
    --modal-field-gap: 20px;
    --modal-button-margin-top: 30px;
    /* Shadows */
    --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.1);
    --shadow-md: 0 4px 16px rgba(0, 0, 0, 0.15);
    --shadow-lg: 0 10px 40px rgba(0, 0, 0, 0.3);
    /* Z-Index */
    --z-index-sticky: 100;
    --z-index-modal: 500;
    --z-index-tooltip: 1500;
    /* Transitions */
    --transition-fast: 0.15s ease;
    --transition-base: 0.2s ease;
    --transition-slow: 0.3s ease;
    --color-yellow: #FFC52D;
    --color-red: #FF1F45;
    --color-dynamic-red: #F32749;
    --color-yellow-light: rgba(255, 197, 45, 0.50);
    --color-red-light: rgba(255, 31, 69, 0.50);
    /* Phase Colors - L1, L2, L3 */
    --color-solar-mist: rgba(255, 230, 179, 0.80);
    --color-solar-dust: #FFC52D;
    --color-soft-blue: rgba(214, 228, 241, 0.80);
    --color-sky-blue: #0041B0;
    --color-mist-green: rgba(199, 234, 204, 0.80);
    --color-ever-green: #28A864;
    --font-size-5xl: 36px;
    --border-radius-17: 17.5px;
    --border-radius-16: 16.5px;
    --border-radius-15: 15px;
    --height-35: 35px;
    --font-weight-bold: 700;
    --font-weight-normal: 400;
    --width-200: 200px;
    --width-300: 300px;
    --width-315: 315px;
    --width-364: 364px;
    --min-height-500: 500px;
    --height-600: 600px;
    --stroke-neutral: #D8D5D1;
    --indicator-default: #D8D5D1;
    --indicator-hover: #A0A5AA;
    --text-inactive: #768187;
    --font-size-10px: 10px;
    --shadow-power-box: 0 0 4px 0 rgba(70, 70, 70, 0.05);
    --placeholder-text: #999;
    --line-height-120: 120%;
    --line-height-130: 130%;
    --line-height-1-2: 1.2;
    --sidebar-width-expanded: 225px;
    --sidebar-width-collapsed: 100px;
    --rz-tooltip-background-color: var(--bg-container) !important;
    --rz-tooltip-color: var(--primary-font-color) !important;
    --rz-tooltip-font-family: var(--primary-font-family) !important;
    --rz-tooltip-padding: 16px 14px !important;
    --tooltip-border-color: var(--primary-color);
    --tooltip-border-width: 1px;
    --tooltip-arrow-size: 8px;
}

[data-bs-theme="dark"] {
    --bg: #1e1e1e;
    --bg-container: #2d2d30;
    --item-fill: #3e3e42;
    --primary-color: #ea555a;
    --secondary-color: #ea555a;
    --header-text-color: #000;
    --bolt-color: #ea555a;
    --primary-text: white;
    --secondary-text: rgba(255,255,255,0.7);
    --light-text: rgba(255, 255, 255, 0.5);
    --active: rgba(255,255,255,0.15);
    --hover: rgba(255,255,255,0.05);
    --custom-bg: 0,0,0;
    --custom-color: 255,255,255;
    --link: #409ce2;
    --bbt: #ffffff;
    --bbt-dark: 30,30,30;
    --bbt-dark2: 234,85,90;
    --bbt-light: 45,45,48;
    --bbt-dark-light: 236,156,151;
    --sidebar-bg: 45,45,48;
    --border-bottom-top-bar: #1e1e1e;
    --rz-base-background-color: var(--bg-container) !important;
    --rz-profile-menu-background-color: var(--item-fill) !important;
    --rz-menu-item-color: var(--secondary-text) !important;
    --rz-profile-menu-item-hover-background-color: var(--item-fill) !important;
    --rz-menu-item-hover-color: var(--primary-text) !important;
    --rz-dropdown-open-background-color: var(--bg-container) !important;
    --bs-body-color: var(--primary-text) !important;
    --bs-body-bg: var(--bg) !important;
    --rz-tabs-tab-hover-background-color: var(--item-fill) !important;
    --rz-tabs-tab-color: var(--light-text) !important;
    --rz-border-base-300: var(--light-text) !important;
    --rz-fieldset-border: var(--light-text) !important;
    --rz-navigation-item-text: rgb(255, 255, 255) !important;
    --rz-switch-background-color: var(--bg) !important;
}

html, body {
    overscroll-behavior: none;
    -webkit-overflow-scrolling: auto;
    margin: 0;
    padding: 0;
    width: 100%;
    min-height: 100vh;
    color: var(--text-almost-black);
}

    body:not(.phone) {
        position: relative;
        height: 100vh;
        overflow: hidden;
    }
    body.phone {
        position: relative;
        height: auto;
        min-height: 100vh;
        overflow-y: auto;
        overflow-x: hidden;
    }
main {
    font-family: var(--primary-font-family);
}
    main:not(.phone main) {
        overflow-y: auto;
        overflow-x: hidden;
        height: calc(100vh - var(--toprow-height));
    }
body.modal-open {
    overflow: hidden !important;
}

.fontfamily {
    font-family: var(--primary-font-family);
}

.bolt {
    color: var(--bolt-color);
}

.logo {
    margin-left: var(--logo-left-margin);
    width: var(--logo-width);
}

.logo-welcome {
    width: var(--logo-width-welcome);
}

.login-button {
    margin-top: var(--logo-margin-login-button);
    height: var(--logo-height-login-button);
    width: var(--logo-width-login-button);
}

h1:focus {
    outline: none;
}

a, .btn-link {
    color: #0071c1;
}

.tab-top-padding {
    padding-top: 45px;
}

.bg {
    background-color: var(--bg);
}

.bg-container {
    background-color: var(--bg-container);
}

.secondary-title {
    color: var(--secondary-text);
    font-size: 0.9rem;
}

.light-title {
    color: var(--light-text);
    font-size: 0.8rem;
}

.container-title {
    color: var(--secondary-text);
    font-size: 0.8rem;
}

.container-title-bold {
    color: var(--secondary-text);
    font-size: 0.8rem;
    font-weight: bold;
}

.init-dialog-container {
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: hidden !important;
    padding: 0px !important;
}

.init-dialog-content-container {
    padding: var(--rz-dialog-content-padding);
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    overflow-y: auto;
}

.init-dialog-content {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
}

.init-dialog-prog-bar-container {
    flex-shrink: 0;
}

.init-dialog-footer {
    padding: var(--rz-dialog-content-padding);
    flex-shrink: 0;
}

.rz-legend-item {
    border: 1px solid #ccc;
    border-radius: var(--spacing-xs);
    padding: calc(var(--spacing-xs) / 2) calc(var(--spacing-xs) + var(--spacing-xs) / 2);
    margin: calc(var(--spacing-xs) / 2);
    cursor: pointer;
    transition: background-color 0.2s;
}

    .rz-legend-item:hover {
        background-color: var(--secondary-color);
    }

.rz-dropdown-label {
    align-content: center;
}

.rz-button.rz-variant-text.rz-primary:hover {
    background-color: var(--secondary-color) !important;
}

.rz-button.rz-variant-outlined.rz-danger:hover {
    background-color: var(--secondary-color) !important;
    color: var(--primary-color) !important;
}

#popup-gridconnection > .rz-dropdown-items-wrapper {
    max-height: 250px !important;
}

    #popup-gridconnection > .rz-dropdown-items-wrapper > ul.rz-dropdown-items > li.rz-dropdown-item {
        color: var(--secondary-text);
        cursor: pointer;
    }

        #popup-gridconnection > .rz-dropdown-items-wrapper > ul.rz-dropdown-items > li.rz-dropdown-item:hover {
            background-color: rgba(var(--custom-color),0.05);
            color: var(--primary-text);
        }

    #popup-gridconnection > .rz-dropdown-items-wrapper > ul.rz-dropdown-items > li.rz-state-highlight {
        background-color: rgba(var(--custom-color),0.15) !important;
        font-family: var(--primary-font-family-bold);
        color: var(--primary-text);
    }

    #popup-gridconnection > .rz-dropdown-items-wrapper > ul.rz-dropdown-items > li.rz-state-disabled {
        padding: var(--spacing-xs) calc(var(--spacing-sm) + var(--spacing-xs) / 2);
        opacity: 0.4;
    }

        #popup-gridconnection > .rz-dropdown-items-wrapper > ul.rz-dropdown-items > li.rz-state-disabled:hover {
            background-color: var(--bg-container) !important;
            color: var(--secondary-text) !important;
            cursor: default;
        }

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid red;
}

.rz-form-field-content > .rz-numeric > .rz-numeric-input {
    outline: none !important;
}

.rz-switch.rz-switch-checked .rz-switch-circle:before {
    background: rgb(var(--bbt-dark-orange)) !important;
}

.rz-switch.rz-switch-checked .rz-switch-circle {
    background-color: rgba(var(--bbt-dark-orange), 0.12) !important;
}

.rz-tabview-panel {
    padding-left: 0 !important;
    padding-right: 0 !important;
    padding-top: 0.5rem !important;
}

.rz-tabview-nav {
    justify-content: space-evenly !important;
}

.rz-tabview.rz-tabview-top > .rz-tabview-nav .rz-tabview-selected {
    border-bottom: calc(var(--spacing-xs) / 2) solid var(--primary-color) !important;
}

.rz-tabview-nav .rz-tabview-selected a {
    color: var(--primary-color) !important;
    font-weight: bold !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.rz-dialog {
    color: var(--primary-text) !important;
}

.rz-dropdown {
    background-color: var(--bg-container);
    color: var(--primary-text);
}

.validation-message {
    color: red;
}

#blazor-error-ui {
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA9NS43MDI2IDE5MSA5Ni4yNzg1IDI5MSA5OC4yNjI0IDI5MSA5OS41NTIgMjkwLjYxNyA1MS4xNjQ3IDI5MC4yMzcgOTIuNDcxMyAyOTAuNTIzIDkyLjkzNjggMjkwLjYxNyA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

.loading-progress {
    position: relative;
    display: block;
    width: 8rem;
    height: 8rem;
    margin: 42vh auto 1rem auto;
}

    .loading-progress circle {
        fill: none;
        stroke: var(--primary-color);
        stroke-width: 0.6rem;
        transform-origin: 50% 50%;
        transform: rotate(-90deg);
    }

        .loading-progress circle:last-child {
            stroke: var(--primary-color);
            stroke-dasharray: calc(3.141 * var(--blazor-load-percentage, 0%) * 0.8), 500%;
            transition: stroke-dasharray 0.05s ease-in-out;
        }

.loading-progress-text {
    position: absolute;
    text-align: center;
    font-weight: bold;
    inset: calc(42vh + 3.25rem) 0 auto 0.2rem;
}

    .loading-progress-text:after {
        content: var(--blazor-load-percentage-text, "Loading");
    }

*, *::before, *::after {
    box-sizing: border-box !important;
}

.btn-primary {
    text-transform: uppercase;
    font-family: var(--secondary-font-family);
    background-color: var(--primary-color);
    border-color: var(--primary-color);
    color: white;
}

.btn-secondary {
    text-transform: uppercase;
    font-family: var(--secondary-font-family);
    color: var(--primary-text);
    border: 1px solid var(--border-light);
}

.pill-button {
    display: inline-flex;
    height: var(--pill-height);
    padding: var(--pill-padding);
    align-items: center;
    gap: var(--pill-gap);
    border-radius: var(--pill-border-radius);
    border: 1px solid var(--border-light);
    background: var(--bg-container);
    cursor: pointer;
    transition: all 0.2s ease;
    color: var(--primary-text);
    font-size: var(--font-size-md);
    font-weight: 500;
}

    .pill-button:hover {
        background-color: var(--hover);
    }

    .pill-button:disabled {
        opacity: 0.5;
        cursor: not-allowed;
    }

.dropdown-menu {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    width: 100%;
    display: flex;
    flex-direction: column;
    background: var(--bg-container);
    filter: var(--dropdown-shadow);
    border-radius: var(--dropdown-border-radius);
    padding: 0;
    overflow: hidden;
}

.dropdown-search {
    display: flex;
    height: var(--pill-height);
    padding: var(--pill-padding);
    align-items: center;
    gap: calc(var(--spacing-sm) + var(--spacing-xs) / 2);
    border: 1px solid var(--border-light);
    background: var(--bg-container);
    border-radius: var(--dropdown-border-radius) var(--dropdown-border-radius) 0 0;
    flex-shrink: 0;
}

.dropdown-search-input {
    flex: 1;
    border: none;
    outline: none;
    font-size: var(--font-size-sm);
    background: transparent;
    color: var(--primary-text);
    text-transform: uppercase;
    min-width: 0;
    width: 100%;
}

    .dropdown-search-input::placeholder {
        color: var(--light-text);
    }

.dropdown-list {
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    overflow-x: hidden; /* Prevent horizontal scroll */
    max-height: 320px;
}

    .dropdown-list::-webkit-scrollbar {
        width: 6px;
    }

    .dropdown-list::-webkit-scrollbar-track {
        background: transparent;
    }

    .dropdown-list::-webkit-scrollbar-thumb {
        background: #d1d5db;
        border-radius: 3px;
    }

.dropdown-item {
    display: flex;
    flex-direction: column;
    min-height: var(--pill-height);
    height: auto;
    padding: var(--pill-padding);
    align-items: flex-start;
    justify-content: center;
    gap: var(--spacing-xs);
    border: 1px solid var(--border-light);
    border-top: none;
    background: var(--bg-container);
    cursor: pointer;
    transition: background-color 0.15s ease;
    flex-shrink: 0;
    font-family: var(--secondary-font-family);
    font-size: var(--font-size-md);
    text-transform: uppercase;
}

    .dropdown-item:first-child {
        border-top: 1px solid var(--border-light);
    }

    .dropdown-item:last-child {
        border-radius: 0 0 var(--dropdown-border-radius) var(--dropdown-border-radius);
    }

    .dropdown-item:hover {
        background-color: var(--hover);
    }

    .dropdown-item.active {
        background-color: var(--active-text);        
        font-weight: 600;
    }

.client-name {
    font-size: var(--font-size-md);
    white-space: normal;
    color: var(--text-inactive);
}

.location-name {
    font-size: var(--font-size-md);
    white-space: normal;
}

.dropdown-item.active .client-name {
    color: #283035;
}

.dropdown-item.active .location-name {
    color: var(--primary-color);
}

.phone .dropdown-menu {
    max-width: 90vw;
}

.phone .dropdown-list {
    max-height: 280px;
}

.phone {
    --toprow-padding: var(--spacing-lg);
    --gap-xl: var(--spacing-md);
    --input-height: 52px;
    --input-padding-vertical: calc(var(--spacing-lg) - var(--spacing-xs) / 2);
    --input-padding-horizontal: calc(var(--spacing-xl) - var(--spacing-xs) / 2);
    --font-size-base: 13px;
    --font-size-3xl: 24px;
}

    .phone .logo {
        margin-left: var(--spacing-xl);
        width: calc(var(--spacing-5xl) + var(--spacing-xs) / 2);
    }

    .phone .logo-welcome {
        width: var(--spacing-4xl);
    }

    .phone .secondary-title {
        font-size: 0.85rem;
    }

    .phone .container-title,
    .phone .container-title-bold {
        font-size: 0.75rem;
    }

    .phone .btn-primary {
        min-height: 44px;
        padding: var(--spacing-md) var(--spacing-lg);
    }

    .phone .init-dialog-content-container {
        padding: var(--spacing-lg);
    }

.edit-title {
    margin: 0 0 var(--spacing-sm) 0;
    align-self: stretch;
    color: var(--primary-text);
    font-family: var(--h2-font-family);
    font-size: var(--font-size-3xl);
    font-style: normal;
    font-weight: var(--h2-font-weight);
    line-height: 1.3;
}

.edit-description {
    margin: 0 0 var(--spacing-xl) 0;
    align-self: stretch;
    color: var(--text-muted);
    font-family: var(--primary-font-family);
    font-size: var(--font-size-base);
    font-style: normal;
    font-weight: 400;
    line-height: 1.6;
}

.edit-field-wrapper {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    gap: var(--spacing-sm);
    align-self: stretch;
    width: 100%;
    margin-bottom: 1rem;
}

.edit-label {
    margin: 0;
    align-self: stretch;
    color: var(--primary-text);
    font-family: var(--primary-font-family);
    font-size: var(--font-size-base);
    font-style: normal;
    font-weight: 500;
    line-height: normal;
}

.edit-input {
    display: block;
    height: var(--input-height);
    padding: var(--input-padding-vertical) var(--input-padding-horizontal);
    width: 100%;
    margin: 0;
    border-radius: var(--border-radius-sm);
    border: 1px solid var(--text-muted);
    background: var(--surface-input);
    color: var(--primary-text);
    font-family: var(--primary-font-family);
    font-size: var(--font-size-base);
    font-style: normal;
    font-weight: 400;
    line-height: 1.5;
    outline: none;
    box-sizing: border-box;
    transition: border-color var(--transition-base);
}

    .edit-input:focus {
        border-color: var(--border-focus);
        box-shadow: 0 0 0 1px var(--border-focus, #0041B0);
    }

    .edit-input::placeholder {
        color: var(--text-muted);
        opacity: 0.6;
    }

.container-head {
    display: flex;
}

.chart-box {
    padding-top: var(--spacing-4xl);
    padding-bottom: calc(var(--spacing-7xl) - var(--spacing-xs));
    max-width: 1400px;
    margin: 0 auto;
    width: 100%;
    padding-left: var(--spacing-lg);
    padding-right: var(--spacing-lg);
}

.chart-header-div {
    background-color: var(--bg-container);
}

.chart-header {
    color: var(--primary-text);
    font-family: var(--primary-font-family);
    font-size: var(--font-size-3xl);
    font-style: normal;
    font-weight: 500;
    line-height: normal;
    padding-left: var(--spacing-6xl);
}

.chart-description {
    color: var(--text-muted);
    font-family: var(--primary-font-family);
    font-size: var(--font-size-lg);
    font-style: normal;
    font-weight: 400;
    line-height: var(--line-height-130);
    padding-left: -20px;
}

.chart-div {
    padding-left: var(--spacing-6xl);
}

.product-status-card {
    background-color: var(--bg-container);
    padding: 34px 44px;
    border-radius: var(--border-radius-lg);
    border: 1px solid var(--border-default);
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-direction: column;
    gap: var(--spacing-xl);
    align-self: stretch;
}

.heading-section {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    align-self: stretch;
}

.product-info {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    justify-content: space-between;
    align-items: flex-start;
    align-self: stretch;
    width: 100%;
}

    .product-info h1 {
        font-size: var(--font-size-3xl);
        font-weight: 600;
        margin-top: 0;
        margin-bottom: calc(var(--spacing-sm) + var(--spacing-xs) / 2);
        color: var(--text-dark);
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
        align-self: stretch;
    }

.data-points {
    gap: var(--spacing-7xl);
    margin-top: calc(var(--spacing-5xl) + var(--spacing-xs) / 2);
    display: grid;
    height: calc(var(--spacing-9xl) + var(--spacing-7xl) - var(--spacing-sm));
    row-gap: calc(var(--spacing-2xl) + var(--spacing-xs) / 2);
    column-gap: calc(var(--spacing-2xl) + var(--spacing-xs) / 2);
    align-self: stretch;
    grid-template-rows: repeat(2, minmax(0, 1fr));
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.data-item {
    display: flex;
    flex-direction: column;
}

    .data-item .label {
        color: var(--text-light);
        font-size: var(--font-size-base);
        margin-bottom: calc(var(--spacing-xs) + var(--spacing-xs) / 2);
    }

    .data-item .value {
        color: var(--text-dark);
        font-size: var(--font-size-2xl);
        font-weight: bold;
        display: flex;
        align-items: center;
        margin: 0;
    }

    .data-item .icon {
        margin-right: calc(var(--spacing-sm) + var(--spacing-xs) / 2);
        font-size: var(--font-size-2xl);
        line-height: 1;
    }

.product-icon-large svg {
    height: 100%;
    width: auto;
}

.product-icon-large {
    border: calc(var(--spacing-xs) + var(--spacing-xs) / 2) solid var(--text-dark);
    border-radius: var(--border-radius-15);
    position: relative;
    margin-top: -10px;
    height: var(--spacing-9xl);
    width: auto;
}

    .product-icon-large::before {
        content: '';
        position: absolute;
        top: -15px;
        left: 50%;
        transform: translateX(-50%);
        width: var(--spacing-6xl);
        height: calc(var(--spacing-sm) + var(--spacing-xs) / 2);
        background-color: var(--text-dark);
        border-top-left-radius: var(--border-radius-sm);
        border-top-right-radius: var(--border-radius-sm);
    }

    .product-icon-large::after {
        content: '';
        position: absolute;
        bottom: calc(var(--spacing-xs) + var(--spacing-xs) / 2);
        left: calc(var(--spacing-xs) + var(--spacing-xs) / 2);
        right: calc(var(--spacing-xs) + var(--spacing-xs) / 2);
        height: calc(150px * 0.48);
        background-color: var(--primary-orange);
        border-radius: var(--border-radius-md);
        transform-origin: bottom;
        animation: charge-fill 1s ease-out forwards;
    }

@keyframes charge-fill {
    0% {
        height: 0;
    }

    100% {
        height: calc(150px * 0.48);
    }
}

.power-data-container {
    width: 100%;
    border-radius: var(--border-radius-lg);
    border: 1px solid var(--border-default);
    background: var(--bg-container);
    padding: 34px 44px;
    margin: 0 auto;
    position: relative;
}

.power-data-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 30px;
    gap: var(--spacing-md);
}

.title-section {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xl);
    min-width: 0;
}

.power-data-title {
    font-family: var(--primary-font-family);
    font-size: var(--font-size-3xl);
    font-weight: 600;
    line-height: var(--line-height-130);
    color: var(--text-almost-black);
    margin: 0;
}

.power-data-subtitle {
    font-family: var(--primary-font-family);
    font-size: var(--font-size-base);
    font-weight: 400;
    line-height: var(--line-height-130);
    color: var(--text-inactive);
    word-break: break-word;
    margin-bottom: 0;
}

.info-icon {
    cursor: pointer;
    flex-shrink: 0;
}

.chart-controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-md);
    gap: var(--spacing-md);
}

.phone .chart-controls {
    flex-direction: column;
    align-items: stretch;
}

.phone .power-data-container {
    padding: 20px 15px;
}

.phone .power-data-title {
    font-size: var(--spacing-xl);
    line-height: normal;
}

.phone .power-data-subtitle {
    font-size: var(--font-size-sm);
    font-weight: var(--nav-font-weight);
    line-height: var(--line-height-130);
}

.phone .chart-wrapper {
    margin-top: var(--spacing-lg);
    margin-right: -15px;
}
/* Tab Container */
.app-tabs {
    display: flex;
    gap: var(--spacing-7xl);
    border: 1px solid var(--border-default);
    padding-bottom: 0;
    padding-left: var(--spacing-6xl);
    background-color: var(--surface-input);
    position: sticky;
    top: 0;
    width: 100%;
    z-index: var(--z-index-sticky);
    box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.10);
    padding-top: 10px;
}

.app-tabs__btn {
    background: none;
    border: none;
    padding: var(--spacing-md) 0;
    font-family: var(--secondary-font-family);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-normal);
    line-height: var(--line-height-120);
    text-transform: uppercase;
    color: var(--text-inactive);
    cursor: pointer;
    position: relative;
    transition: color var(--transition-base);
    letter-spacing: 0.5px;
}

    .app-tabs__btn:hover {
        color: var(--primary-text);
    }

.app-tabs__btn--active {
    color: var(--primary-text);
    font-weight: var(--font-weight-bold);
}

.app-tabs__indicator {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 3px;
    background-color: var(--primary-color);
    transition: left 0.3s cubic-bezier(0.4, 0, 0.2, 1), width 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    will-change: left, width;
    pointer-events: none;
    z-index: 1;
}

.phone .app-tabs {
    gap: var(--spacing-xl);
    padding-left: var(--spacing-lg);
    padding-right: var(--spacing-lg);
    top: 0;
}

.phone .app-tabs__btn {
    font-size: var(--font-size-base);
    padding: var(--spacing-md) 0;
    min-height: 44px;
    display: flex;
    align-items: center;
}

.phone .app-tabs__btn--active::after {
    height: calc(var(--spacing-xs) / 2);
}

.db-ctn {
    display: flex;
    flex-direction: column;
    gap: 40px;
    margin: 0 auto;
    padding: 40px 36px;
    width: 100%;
    max-width: 1400px;
}

.phone .db-ctn {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 0 14px;
    width: 100%;
    -webkit-align-items: inherit;
    align-items: inherit;
    justify-content: flex-start;
    margin-top: 20px;
}
/*settings section */

.settings-page {
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    min-height: 100vh;
    background: var(--bg, #FFFEFE);
    padding: clamp(var(--spacing-lg), 4vw, var(--spacing-6xl));
    overflow-y: auto;
}

.settings-container {
    width: 100%;
}

.settings-heading {
    font-family: var(--h2-font-family);
    font-size: clamp(var(--font-size-2xl), 3vw, var(--h2-font-size));
    font-weight: var(--h2-font-weight);
    line-height: var(--h2-line-height);
    font-style: var(--h2-font-style);
    color: var(--primary-text);
    margin: 0 0 clamp(var(--spacing-lg), 2vw, var(--spacing-xl)) 0;
}

.settings-details-card {
    display: flex;
    padding: clamp(20px, 5vw, 40px) clamp(24px, 5vw, 50px);
    flex-direction: column;
    align-items: flex-start;
    gap: clamp(var(--spacing-lg), 2vw, var(--spacing-xl));
    border-radius: var(--border-radius-lg);
    border: 0.5px solid var(--border-light, #E9E9E9);
    background: var(--bg-container, #FFFEFE);
}

.settings-details-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    align-self: stretch;
    flex-wrap: wrap;
    gap: var(--gap-md);
}

.settings-details-title {
    color: var(--text-almost-black);
    font-family: var(--primary-font-family);
    font-size: 32px;
    font-weight: 600;
    margin: 0;
}

.settings-info-section {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: clamp(var(--spacing-lg), 2vw, var(--spacing-xl));
    width: 100%;
    max-width: 300px;
}

.settings-info-row {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    width: 100%;
}

.info-label {
    font-family: var(--body-12-font-family);
    font-size: var(--body-12-font-size);
    font-weight: var(--body-12-font-weight);
    line-height: var(--body-12-line-height);
    color: var(--text-almost-black);
}

.info-value {
    font-family: var(--body-12-font-family);
    font-size: var(--body-12-font-size);
    font-weight: var(--body-12-font-weight);
    line-height: var(--body-12-line-height);
    color: var(--text-muted);
    word-break: break-word;
}

.info-value-with-action {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.edit-button {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-lg);
    border: none;
    background: transparent;
    cursor: pointer;
    transition: all var(--transition-base);
    font-family: var(--button-14-font-family);
    font-size: var(--button-14-font-size);
    font-weight: var(--button-14-font-weight);
    line-height: var(--button-14-line-height);
    text-transform: var(--button-14-text-transform);
    color: var(--primary-text);
    white-space: nowrap;
}

    .edit-button:hover {
        background: var(--hover);
    }

    .edit-button span {
        display: inline;
    }

.phone .edit-button span {
    display: none;
}

.phone .edit-button {
    padding: var(--spacing-sm);
    min-width: 36px;
    justify-content: center;
    border: none;
}

.rz-tooltip-content {
    /* Add the border to the main box */
    border: var(--tooltip-border-width) solid var(--tooltip-border-color) !important;

    /* Ensure the arrow can stick out of the box */
    overflow: visible !important;
}

    .rz-tooltip-content::after {
        /* Ensure arrow background matches tooltip to "mask" the connecting border */
        background-color: var(--rz-tooltip-background-color) !important;
        /* Set border style, but color matches the main box */
        border-style: solid !important;
        border-color: var(--tooltip-border-color) !important;
        border-width: var(--tooltip-border-width) !important;

        /* Reset borders initially (we toggle specific sides below) */
        border: none !important;
        z-index: 1; /* Ensure it sits on top of the main box border */
    }

/* --- Specific Orientations --- */

/* TOP Tooltip -> Arrow points DOWN */
.rz-top-tooltip-content::after {
    /* Arrow V shape: Bottom and Right borders */
    border-bottom: var(--tooltip-border-width) solid var(--tooltip-border-color) !important;
    border-right: var(--tooltip-border-width) solid var(--tooltip-border-color) !important;
}

/* BOTTOM Tooltip -> Arrow points UP */
.rz-bottom-tooltip-content::after {
    /* Arrow ^ shape: Top and Left borders */
    border-top: var(--tooltip-border-width) solid var(--tooltip-border-color) !important;
    border-left: var(--tooltip-border-width) solid var(--tooltip-border-color) !important;
}

/* LEFT Tooltip -> Arrow points RIGHT */
.rz-left-tooltip-content::after {
    /* Arrow > shape: Top and Right borders */
    border-top: var(--tooltip-border-width) solid var(--tooltip-border-color) !important;
    border-right: var(--tooltip-border-width) solid var(--tooltip-border-color) !important;
}

/* RIGHT Tooltip -> Arrow points LEFT */
.rz-right-tooltip-content::after {
    /* Arrow < shape: Bottom and Left borders */
    border-bottom: var(--tooltip-border-width) solid var(--tooltip-border-color) !important;
    border-left: var(--tooltip-border-width) solid var(--tooltip-border-color) !important;
}

/* Mobile Navigation Active State - SVG Icon Colors */
.phone .mobile-bottom-nav .mobile-nav-item.active svg path {
    fill: var(--primary-color) !important;
}

.phone .mobile-bottom-nav .mobile-nav-item.active svg g path {
    fill: var(--primary-color) !important;
}

.phone .mobile-bottom-nav .mobile-nav-item.active svg [fill]:not([fill="none"]) {
    fill: var(--primary-color) !important;
}

.phone .mobile-bottom-nav .mobile-nav-item.active svg [stroke] {
    stroke: var(--primary-color) !important;
}

/* Additional specificity for nested SVG structures */
.mobile-bottom-nav .mobile-nav-item.active svg path,
.mobile-bottom-nav .mobile-nav-item.active svg g path,
.mobile-bottom-nav .mobile-nav-item.active svg g g path {
    fill: var(--primary-color) !important;
}

/* Spinning Loader Animation */
.spinning-loader {
    animation: spin 2s linear infinite;
    transform-origin: center;
}

@keyframes spin {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}


    .apexcharts-tooltip {
        padding: 12px !important;
        border: 1px solid var(--primary-color) !important;
        border-radius: 10px !important;
        background: var(--bg-container) !important;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1) !important;
    }

    .apexcharts-xaxistooltip {
        border: 1px solid var(--primary-color) !important;
        border-radius: 10px !important;
        background: var(--bg-container) !important;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1) !important;
    }

    .apexcharts-xaxistooltip-text {
        font-family: var(--secondary-font-family) !important;
    }

    .apexcharts-xaxistooltip::before,
    .apexcharts-xaxistooltip::after {
        border-bottom-color: var(--primary-color) !important;
    }

    .apexcharts-legend {
        padding: 0 !important;
        top: -2px !important;
    }

    .apexcharts-legend-text {
        font-family: var(--secondary-font-family) !important;
        text-transform: uppercase !important;
    }

    .apexcharts-legend-series {
        display: flex !important;
        height: 32px !important;
        padding: 10px 15px !important;
        align-items: center !important;
        gap: 5px !important;
        border-radius: 5px !important;
        border: 1px solid #E9E9E9 !important;
        background: #FFFEFE !important;
        margin: 2px 4px !important;
        transition: all 0.2s ease !important;
    }

        .apexcharts-legend-series:hover {
            border-color: var(--primary-color) !important;
            background-color: var(--btn-hover-bg) !important;
        }

        .apexcharts-legend-series.apexcharts-inactive-legend {
            opacity: 0.5 !important;
            border-color: #d0d0d0 !important;
            background: #f8f8f8 !important;
        }

        .apexcharts-legend-series.apexcharts-active-legend {
            border: 1px solid var(--primary-color) !important;
            background: #FFF7E6 !important;
        }

    .apexcharts-legend-marker {
        width: 5px !important;
        height: 20px !important;
        border-radius: 2px !important;
        margin-right: 5px !important;
    }

    .apexcharts-gridlines-vertical line {
        display: none !important;
    }

    .apexcharts-gridlines-horizontal line {
        stroke: #F3F4F6 !important;
        stroke-width: 1 !important;
    }

    .apexcharts-xcrosshairs {
        stroke: var(--primary-color) !important;
        stroke-width: 2 !important;
    }

    .phone .chart-wrapper {
        margin-top: var(--spacing-lg);
    }

        .phone .chart-wrapper > * {
            max-width: 100%;            
        }

    .phone .apexcharts-legend {
        margin-bottom: 12px !important;
    }

    .phone .apexcharts-legend-series {
        height: 24px !important;
        padding: 6px 8px !important;
        margin: 2px 2px !important;
        gap: 3px !important;
        font-size: 11px !important;
    }

    .phone .apexcharts-legend-marker {
        width: 4px !important;
        height: 16px !important;
        margin-right: 3px !important;
    }

    .phone .apexcharts-legend-text {
        font-size: 11px !important;
        line-height: 1.2 !important;
    }

    .phone .apexcharts-legend.apx-legend-position-top,
    .phone .apexcharts-legend.apx-legend-position-bottom {
        flex-wrap: wrap !important;
        max-width: 100% !important;
    }