/* ==========================================
   PRAXIS CLOUD CSS - ORGANIZED AND CLEANED
   ==========================================
   This file has been reorganized alphabetically by selector name.
   Related styles are kept together in logical groups.
   Duplicate definitions have been removed.
   ========================================== */

/* ==========================================
   BASE ELEMENT STYLES
   ========================================== */

a.product-info {
    display: none;
}

body, html {
    background-color: #ffffff;
    color: #000000;
    font-family: Arial, Helvetica, sans-serif;
    font-size: medium;
    height: 98%;
    margin: 0;
    text-align: left;
}

img.more-info {
    width: 500px;
}

/* All labels should be bold */
label {
    font-size: 12px;
    font-family: Arial, Helvetica, sans-serif;
    padding-right: 10px;
    font-weight: bold;
}

/* Standard select/dropdown - use for ALL select elements */
select {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    padding: 4px;
    border: 1px solid #ccc;
    background-color: white;
    min-width: 150px;
}

/* Allow explicit width classes to override the default select min-width */
select.w-50px { min-width: 50px; }

/* Standard textarea - use for ALL textarea elements */
textarea {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    padding: 4px;
    border: 1px solid #ccc;
    background-color: white;
}

/* ==========================================
   FORM ELEMENT STYLES
   ========================================== */

/* Standard input field - use for ALL text/number/date inputs */
input[type="text"],
input[type="number"],
input[type="date"],
input[type="email"],
input[type="tel"],
input[type="password"] {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    padding: 4px;
    border: 1px solid #ccc;
}

/* All checkboxes should display in bold */
input[type="checkbox"] {
    font-weight: bold;
}

/* Checkbox labels should be bold */
input[type="checkbox"] + label,
label:has(input[type="checkbox"]) {
    font-weight: bold;
}

/* ==========================================
   ID SELECTORS (ALPHABETICAL)
   ========================================== */

#BOTTOM {
    background-color: #ffffff;
    height: 9px;
    width: 98%;
}

#CONTENT {
    padding: 20px 20px 2px 40px;
    text-decoration: none;
}

#FOOTER {
    background-color: #ffffff;
    background-repeat: repeat;
    border-top: 1px solid #ffffff;
    color: #ffffff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 8pt;
    height: 0px;
    padding-top: 0px;
    width: 98%;
}

#FOOTER .divider3 {
    color: #999999;
    margin: 0 7px 0 7px;
}

#FOOTER a:link {
    color: #0759ab;
    text-decoration: none;
}

#FOOTER a:visited {
    color: #666666;
    text-decoration: none;
}

#GridView td {
    height: 12px;
}

#iged_clr0_id td {
    font-size: 1px !important;
    line-height: 1px !important;
}

#MAIN {
    background-color: #ffffff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 10pt;
    font-weight: bold;
    height: 100%;
    line-height: 19px;
    padding: 10px;
    width: 98%;
}

#MAIN #CONTENT td {
    font-size: 12px;
    line-height: 1.3em;
    text-decoration: none;
}

#MAIN #CONTENT td ul {
    list-style-type: circle;
    text-decoration: none;
}

#MAIN #CONTENT td ul li {
    list-style-type: circle;
    margin-bottom: 5px;
    text-decoration: none;
}

#MainContent {
    background-color: #ffffff;
    color: Black;
    font-family: Arial, Helvetica, sans-serif;
}

#TOP {
    background-color: #ffffff;
    border-bottom: 0px solid #d3d3d3;
    font-size: xx-small;
    margin-top: 0px;
    width: 98%;
}

/* ==========================================
   CLASS SELECTORS (ALPHABETICAL)
   ========================================== */

/* --- A --- */

.accordion-button {
    background-color: #2cace2;
    color: #000000;
    font-weight: bold;
    padding-left: 10px;
}

.accordion-button:focus {
    background-color: #2cace2;
    color: #000000;
}

.accordion-button:hover {
    background-color: #1a9ad1;
    cursor: pointer;
    color: #000000;
}

.accordion-button:not(.collapsed) {
    background-color: #2cace2;
    color: #000000;
}

.accordionHeader,
.accordionheader {
    border: 1px solid #000000;
    color: #000000;
    background-color: #bfdbff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: bold;
    padding: 5px;
    margin-top: 5px;
    cursor: pointer;
}

.accordionHeader:hover {
}

.accordionHeaderCompanyDocuments {
    background-color: #bfdbff;
    border: 1px solid #000000;
    color: #000000;
    cursor: pointer;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: bold;
    margin-top: 5px;
    padding: 5px;
    text-align: left;
    width: 50%;
}

.accordionHeaderProfitPredictor {
    background-color: #bfdbff;
    border: 1px solid #000000;
    color: #228B22;
    cursor: pointer;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: bold;
    margin-left: 10px;
    margin-top: 5px;
    padding-left: 20px;
    padding: 5px;
    text-align: left;
    width: 90%;
}

.add-color-btn {
    width: 44px;
    height: 44px;
    border: 2px dashed #dee2e6;
    border-radius: 6px;
    background: transparent;
    color: #6c757d;
    cursor: pointer;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.add-color-btn:hover {
    border-color: #2cace2;
    color: #2cace2;
}

.align-middle {
    vertical-align: middle;
}

.align-top {
    vertical-align: top;
}

.AlternateTable {
    border: thin solid #000000;
}

.amount-input {
    width: 120px;
    text-align: right;
}

.AsLowAs {
    color: #0000cc;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14px;
    font-weight: bold;
}

.authenticating-message {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 20px;
    font-style: bold;
    color: green;
}

.authenticating-text {
    font-family: Arial, sans-serif;
    font-size: 14px;
    color: #333;
}

.autocomplete-container {
    position: relative;
    display: inline-block;
}

.autocomplete-dropdown {
    position: absolute;
    z-index: 1000;
    background: white;
    border: 1px solid #ccc;
    max-height: 200px;
    overflow-y: auto;
    width: 100%;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
}

.autocomplete-item,
.autocomplete-item-base {
    padding: 5px 10px;
    cursor: pointer;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
}

.autocomplete-item:hover {
    background-color: #f8f9fa !important;
}

.autocomplete-item-selected {
    background-color: #e9ecef;
}

/* --- B --- */

.badge-sm-normal {
    font-size: 0.7rem;
    font-weight: normal;
}

.bg-green {
    background-color: #ADD8E6;
}

.bg-group-header {
    background-color: #7eb3ff !important;
    font-weight: bold;
}

.bg-group-header-blue {
    background-color: #cce5ff;
}

.bg-light-blue {
    background-color: #9ec5ff;
}

.bg-light-gray {
    background-color: #f0f0f0;
}

.bg-modal-overlay {
    background-color: rgba(0,0,0,0.5);
}

.bg-overlay {
    background-color: rgba(0,0,0,0.5);
}

.bg-price-discount {
    background-color: #FFFF99;
}

.bg-row-white {
    background-color: white;
}

.bg-very-light-gray {
    background-color: #f9f9f9;
}

.bg-white {
    background-color: white;
}

.bg-yellow-bold {
    background-color: #FFFF99;
    font-weight: bold;
}

.bg-yellow-bold-center {
    font-weight: bold;
    background-color: #FFFF99;
    text-align: center;
}

.bg-yellow-highlight {
    background-color: #FFFF99;
}

.blank-content {
    flex: 1;
    padding: 20px;
    background-color: white;
}

.blank-header {
    background-color: white;
    border-bottom: 1px solid #ddd;
}

.blank-layout {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.blink_text {
    -moz-animation-duration: 1s;
    -moz-animation-iteration-count: infinite;
    -moz-animation-name: blinker;
    -moz-animation-timing-function: linear;
    -webkit-animation-duration: 1s;
    -webkit-animation-iteration-count: infinite;
    -webkit-animation-name: blinker;
    -webkit-animation-timing-function: linear;
    animation-duration: 1s;
    animation-iteration-count: infinite;
    animation-name: blinker;
    animation-timing-function: linear;
    color: red;
}

.BlueLabelLargeCenter {
    color: blue;
    font-family: Arial, Helvetica, sans-serif;
    font-size: large;
    font-weight: bold;
    text-align: center;
}

.BlueLabelLargeLeft {
    color: blue;
    font-family: Arial, Helvetica, sans-serif;
    font-size: large;
    font-weight: bold;
    text-align: left;
}

.border-1 {
    border: 1px solid #ccc;
}

.border-1-black {
    border: 1px solid black;
}

.border-1-black-center {
    border: 1px solid black;
    text-align: center;
}

.border-1-ccc {
    border: 1px solid #ccc;
}

.border-1-ccc-bg-light {
    border: 1px solid #ccc;
    background-color: #f9f9f9;
}

.border-1-ccc-p-5 {
    border: 1px solid #ccc;
    padding: 5px;
}

.border-1-ddd {
    border: 1px solid #ddd;
}

.border-black {
    border: 1px solid black;
}

.border-collapse {
    border-collapse: collapse;
}

.border-warning-box {
    border: 1px solid black;
    padding: 10px;
}

.Bottom {
    width: 100%;
}

/* --- C --- */

.category-editor-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1060;
}

.category-editor-content {
    flex: 1;
    padding: 24px;
    overflow-y: auto;
}

.category-editor-footer {
    padding: 16px 24px;
    background: #f8f9fa;
    border-top: 1px solid #dee2e6;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.category-editor-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 24px;
    background: linear-gradient(135deg, #6f42c1 0%, #563d7c 100%);
    color: white;
    flex-shrink: 0;
}

.category-editor-header h5 {
    margin: 0;
    font-weight: 600;
}

.category-editor-panel {
    position: fixed;
    top: 0;
    right: -500px;
    width: 500px;
    max-width: 95vw;
    height: 100vh;
    background: #fff;
    box-shadow: -5px 0 25px rgba(0, 0, 0, 0.2);
    z-index: 1070;
    display: flex;
    flex-direction: column;
    transition: right 0.3s ease;
}

.category-editor-panel.open {
    right: 0;
}

.centered-max-w-500 {
    max-width: 500px;
    margin: 0 auto;
}

.centered-message {
    text-align: center;
    padding: 40px;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14px;
}

.centered-w-75pct {
    width: 75%;
    margin: 0 auto;
}

.checkbox-description-entry {
    min-width: 293px;
}

/* Column percentage width classes for table layouts */
.col-2pct { width: 2%; }
.col-5pct { width: 5%; }
.col-10pct { width: 10%; }
.col-15pct { width: 15%; }
.col-20pct { width: 20%; }
.col-25pct { width: 25%; }
.col-30pct { width: 30%; }
.col-35pct { width: 35%; }
.col-40pct { width: 40%; }
.col-50pct { width: 50%; }
.col-60pct { width: 60%; }
.col-65pct { width: 65%; }
.col-70pct { width: 70%; }

.col-group-name { width: 210px; }

.collapsible-content {
    padding: 15px;
    border: 1px solid #1a9ad1;
    border-top: none;
}

.collapsible-content-blue {
    padding: 0;
    border: 1px solid #bee5eb;
    border-top: none;
    position: relative;
}

.collapsible-content-custom {
    padding: 10px;
    border: 1px solid #ddd;
    border-top: none;
}

.collapsible-content-green {
    padding: 15px;
    border: 1px solid #c3e6cb;
    border-top: none;
}

.collapsible-content-no-border {
    padding: 15px;
    border: none;
}

.collapsible-content-yellow {
    padding: 0;
    border: 1px solid #ffeeba;
    border-top: none;
    position: relative;
}

.collapsible-group {
    margin-bottom: 10px;
}

.collapsible-group-content {
    padding: 15px;
    border: 1px solid #1a9ad1;
    border-top: none;
}

.collapsible-group-content-info {
    padding: 0;
    border: 1px solid #bee5eb;
    border-top: none;
    position: relative;
}

.collapsible-group-content-success {
    padding: 15px;
    border: 1px solid #c3e6cb;
    border-top: none;
}

.collapsible-group-content-warning {
    padding: 0;
    border: 1px solid #ffeeba;
    border-top: none;
    position: relative;
}

.collapsible-group-header {
    background-color: #2cace2;
    color: white;
    padding: 10px;
    font-weight: bold;
    cursor: pointer;
    position: sticky;
    top: 0;
    z-index: 2;
    border-radius: 4px;
    text-align: left;
    border: 1px solid #1a9ad1;
}

.collapsible-group-header:hover {
    background-color: #1a9ad1;
}

.collapsible-group-header-info {
    background-color: #17a2b8;
    color: white;
    padding: 10px;
    font-weight: bold;
    cursor: pointer;
    border: 1px solid #117a8b;
    border-radius: 4px;
}

.collapsible-group-header-info:hover {
    background-color: #117a8b;
}

.collapsible-group-header-success {
    background-color: #20c997;
    color: white;
    padding: 10px;
    font-weight: bold;
    cursor: pointer;
    border: 1px solid #17a87a;
    border-radius: 4px;
}

.collapsible-group-header-success:hover {
    background-color: #17a87a;
}

.collapsible-group-header-warning {
    background-color: #ffc107;
    color: #000;
    padding: 10px;
    font-weight: bold;
    cursor: pointer;
    border: 1px solid #e0a800;
    border-radius: 4px;
}

.collapsible-group-header-warning:hover {
    background-color: #e0a800;
}

.collapsible-header {
    border: 1px solid #000000;
    color: #000000;
    background-color: #bfdbff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: bold;
    padding: 5px;
    margin-top: 5px;
    cursor: pointer;
}

.collapsible-header:hover {
    background-color: #1a9ad1;
}

.collapsible-header-custom {
    text-align: left;
    cursor: pointer;
    background-color: #f0f0f0;
    padding: 10px;
    font-weight: bold;
    border: 1px solid #ddd;
}

.collapsible-header-green {
    border: 1px solid #000000;
    color: #000000;
    background-color: green;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: bold;
    padding: 5px;
    margin-top: 5px;
    cursor: pointer;
}

.collapsible-header-green:hover {
    background-color: lightgreen;
}

.collapsible-header-no-border {
    border: none;
    color: #000000;
    background-color: #bfdbff;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: bold;
    padding: 5px;
    margin-top: 5px;
    cursor: pointer;
}

.collapsible-header-no-border:hover {
    background-color: #1a9ad1;
}

.collapsible-toggle {
    cursor: pointer;
    padding: 8px;
    background-color: #f5f5f5;
    border: 1px solid #ccc;
    border-radius: 4px;
}

.color-black {
    color: black;
}

.color-blue {
    color: blue;
}

.color-chip {
    position: relative;
    width: 44px;
    height: 44px;
    border-radius: 6px;
    overflow: hidden;
    border: 2px solid #dee2e6;
    transition: all 0.2s ease;
}

.color-chip:hover {
    border-color: #2cace2;
    transform: scale(1.05);
}

.color-chip:hover .remove-btn {
    display: flex;
}

.color-chip .remove-btn {
    position: absolute;
    top: -6px;
    right: -6px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #dc3545;
    color: white;
    border: 2px solid white;
    font-size: 10px;
    cursor: pointer;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 0;
    line-height: 1;
}

.color-chip input[type="color"] {
    width: 100%;
    height: 100%;
    border: none;
    cursor: pointer;
    padding: 0;
    background: none;
}

.color-chip input[type="color"]::-webkit-color-swatch {
    border: none;
    border-radius: 4px;
}

.color-chip input[type="color"]::-webkit-color-swatch-wrapper {
    padding: 0;
}

.color-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 8px;
    background: #f8f9fa;
    border-radius: 6px;
}

.color-green {
    color: green;
}

.color-hex-input {
    width: 76px;
    font-family: monospace;
    font-size: 0.75rem;
    text-transform: uppercase;
    text-align: center;
}

.color-hex-list {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}

.color-indicator {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 2px;
    margin-right: 8px;
    vertical-align: middle;
}

.color-picker-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.color-red {
    color: red;
}

.ColorDropDownList {
    text-align: center;
    width: 95%;
}

.ColorInput {
    width: 190px;
}

.ColorInputColumn {
    padding-left: 2%;
    text-align: center;
    width: 200px;
}

.ColorResetButton {
    padding-left: 125px;
}

.column-config-container {
    overflow-x: auto;
    margin-bottom: 8px;
}

.column-config-table {
    width: 100%;
    border-collapse: collapse;
}

.column-config-table td {
    padding: 8px 4px;
    vertical-align: middle;
    border-bottom: 1px solid #f0f0f0;
}

.column-config-table th {
    font-size: 0.75rem;
    font-weight: 600;
    color: #6c757d;
    text-transform: uppercase;
    padding: 8px 4px;
    border-bottom: 2px solid #dee2e6;
}

.CommonMaterialDefaultsScrollableDiv {
    -moz-border-radius: 8px;
    -webkit-border-radius: 8px;
    border-radius: 8px;
    height: 425px;
    overflow-y: auto;
    word-break: normal;
}

.CompanyDocumentHeaderLabel {
    -moz-border-radius: 8px;
    -webkit-border-radius: 8px;
    background-color: #20c997;
    border-radius: 8px;
    border: 1px solid black;
    color: Black;
    display: block;
    float: none;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14pt;
    font-weight: bold;
    margin-left: auto;
    margin-right: auto;
    min-height: 20px;
    overflow: hidden;
    padding: 2px;
    text-align: center;
    width: 80%;
}

/* Prevent responsive wrapping - viewport meta tag handles scaling */
.container, .container-fluid, .row {
    flex-wrap: nowrap !important;
}

.container-full-h-100 {
    width: 100%;
    height: 100px;
}

.container-full-viewport {
    width: calc(100% + 30px);
    height: calc(100vh - 180px);
    margin: -15px;
    padding: 0;
    overflow: hidden;
}

.Copyright {
    color: #211651;
    font-size: x-small;
    text-align: center;
    vertical-align: bottom;
}

.copyright-footer {
    color: #666;
    font-size: 10px;
}

.copyright-small {
    color: #666;
    font-size: 9px;
    white-space: nowrap;
}

.cursor-default {
    cursor: default;
}

.cursor-pointer {
    cursor: pointer;
}

.customer-search-results {
    max-height: 150px;
    overflow-y: auto;
    border: 1px solid #ccc;
}

.customer-search-row {
    cursor: pointer;
}

.customer-search-row:hover {
    background-color: #f0f0f0;
}

.CustomDocumentAccordionHeader {
    text-align: left;
    width: 80%;
}

.CustSearchTable {
    border: thin solid #000000;
    padding: 0px;
    font-size: 11px;
}

.CustSearchTable td {
    padding: 4px;
    border: 1px solid #ddd;
    color: black;
}

.CustSearchTable tbody tr:nth-child(odd),
.CustSearchTable tbody tr:nth-child(even) {
    background-color: white;
}

.CustSearchTable tbody tr:hover {
    background-color: #e3f2fd !important;
}

.CustSearchTable tbody tr:hover td {
    background-color: #e3f2fd !important;
    color: black !important;
}

/* --- D --- */

.d-block {
    display: block;
}

.d-flex {
    display: flex;
}

.d-flex-align-center-gap-4 {
    display: flex;
    align-items: center;
    gap: 4px;
}

.d-flex-align-center-gap-8 {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}

.d-flex-center {
    display: flex;
    justify-content: center;
    align-items: center;
}

.d-flex-center-gap-10 {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
}

.d-flex-gap-5-align-center {
    display: flex;
    gap: 5px;
    align-items: center;
}

.d-flex-wrap-gap-2-mw-400 {
    display: flex;
    flex-wrap: wrap;
    gap: 2px;
    max-width: 400px;
}

.d-inline-block {
    display: inline-block;
}

.d-inline-flex-center-gap-10 {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.d-none {
    display: none;
}

/* Data label - for labels describing data values */
.data-label {
    font-weight: bold !important;
    font-size: 12px;
    font-family: Arial, Helvetica, sans-serif;
}

/* Read-only data rows (display only, cannot be changed) */
.data-readonly, td.readonly-data {
    font-weight: bold !important;
    font-size: 12px;
    font-family: Arial, Helvetica, sans-serif;
}

.defaults-header-bar {
    text-align: center;
    margin-top: -1rem;
    margin-left: -1rem;
    margin-right: -1rem;
    margin-bottom: 15px;
    padding: 10px 10px 10px 10px;
    background-color: #f0f0f0;
    border-radius: 0 0 5px 5px;
    position: sticky;
    top: -1rem;
    z-index: 100;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.DefaultsScrollableDiv {
    -moz-border-radius: 8px;
    -webkit-border-radius: 8px;
    border-radius: 8px;
    overflow-y: auto;
    word-break: normal;
}

.DefaultsScrollableDivFullHeight {
    -moz-border-radius: 8px;
    -webkit-border-radius: 8px;
    border-radius: 8px;
    height: 750px;
    overflow-y: auto;
    word-break: normal;
}

.dialog-form-control {
    width: 100%;
    padding: 8px;
    border: 1px solid #ccc;
    border-radius: 4px;
}

.dialog-form-control:focus {
    outline: none;
    border-color: #1976d2;
    box-shadow: 0 0 0 2px rgba(25, 118, 210, 0.1);
}

.dialog-form-group {
    margin-bottom: 16px;
}

.dialog-form-group label {
    display: block;
    margin-bottom: 4px;
    font-weight: bold;
    font-size: 14px;
}

.DisabledItem {
    color: #999999;
}

.disableWin {
    pointer-events: none;
}

.display-block {
    display: block;
}

.display-none {
    display: none;
}

/* Display value - for read-only data display */
.display-value {
    font-weight: bold !important;
}

.divWaiting {
    background-color: #ffffff;
    height: 1200px;
    left: 0;
    opacity: 0.0;
    overflow: hidden;
    position: fixed;
    text-align: center;
    top: 0;
    width: 4096px;
    z-index: 2147483647 !important;
}

.divWaitingImage {
    background-color: white;
    border: medium outset #0000ff;
    color: Blue;
    font-size: 14px;
    left: 45%;
    padding-bottom: 10px;
    padding-left: 30px;
    padding-right: 30px;
    padding-top: 10px;
    position: fixed;
    text-align: center;
    top: 45%;
    vertical-align: middle;
    width: 85px;
    z-index: 21474836478 !important;
}

.documents-dialog-wide {
    max-width: 1040px;
    width: 95%;
}

.documents-grid-container {
    max-height: 350px;
    overflow-y: auto;
}

.DocumentSignedLabel {
    color: #0000cc;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: bold;
    text-align: left;
}

/* Dollar green color for profit amounts */
.dollar-green {
    color: #228B22;
}

.drag-handle {
    color: #adb5bd;
}

.drag-handle .btn-link {
    color: #adb5bd;
}

.drag-handle .btn-link:hover:not(:disabled) {
    color: #2cace2;
}

/* Pointer cursor for chart elements when drill-down is enabled */
.drilldown-enabled .apexcharts-bar-area {
    cursor: pointer;
}

.drilldown-enabled .apexcharts-xaxis-label {
    cursor: pointer;
}


.drilldown-row {
    cursor: pointer;
    transition: background-color 0.15s ease;
}

.drilldown-row:hover {
    background-color: rgba(0, 123, 255, 0.1);
}

.drilldown-row td {
    padding: 6px 10px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.drilldown-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.85rem;
}

.drilldown-table .percent-column {
    text-align: right;
    width: 50px;
    color: #6c757d;
}

.drilldown-table .value-column {
    text-align: right;
    width: 70px;
}

.drilldown-table thead th {
    background-color: #f8f9fa;
    padding: 6px 10px;
    text-align: left;
    font-weight: 600;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
    position: sticky;
    top: 0;
    z-index: 1;
}

.drilldown-table-container {
    margin-top: 12px;
    height: 100%;
    overflow-y: auto;
}

/* --- E --- */

.equipImageContainer {
    display: block;
    max-height: 90px;
    max-width: 90px;
    overflow: hidden;
    position: relative;
}

.equipImageContainer img {
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
}

.equipment-thumbnail {
    max-width: 80px;
    max-height: 80px;
    object-fit: contain;
}

.equipmentCostGrid {
    width: 600px;
}

/* --- F --- */

.features-textarea {
    width: 100%;
    height: 200px;
    font-size: 8pt;
    resize: none;
    border: 1px solid #ccc;
    background-color: white;
}

/* Field label - for form field labels */
.field-label {
    font-weight: bold !important;
    font-size: 12px;
    font-family: Arial, Helvetica, sans-serif;
}

.financing-summary {
    background-color: #f5f5f5;
    border: 1px solid #ddd;
}

.fit-content-centered-700 {
    width: fit-content;
    min-width: 700px;
    margin: 0 auto;
}

.flex-inline-center {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.flex-wrap {
    flex-wrap: wrap;
}

.font-10px {
    font-size: 10px;
}

.font-12px {
    font-size: 12px;
}

.font-14 {
    font-size: 14px;
}

.font-16px {
    font-size: 16px;
}

.font-20 {
    font-size: 20px;
}

.font-8pt {
    font-size: 8pt;
}

.font-medium {
    font-size: medium;
}

.font-medium-bold {
    font-size: medium;
    font-weight: bold;
}

.font-small {
    font-size: small;
}

.footer-actions {
    display: flex;
    gap: 12px;
}

.forgot-password-link {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    color: #0000EE;
    text-decoration: underline;
    cursor: pointer;
}

.form-group {
    margin-bottom: 16px;
}

.form-label {
    font-weight: bold;
    color: #495057;
    margin-bottom: 6px;
}

.form-row-height-sm {
    height: 30px;
}

.form-section {
    margin-bottom: 24px;
}

.form-section-title {
    font-weight: 600;
    color: #495057;
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 1px solid #e9ecef;
}

.fs-10pt {
    font-size: 10pt;
}

.fs-12 {
    font-size: 12px;
}

.fw-bold {
    font-weight: bold;
}

/* --- G --- */

.gap-2 {
    gap: 2px;
}

.gauge-preview {
    position: relative;
    width: 120px;
}

.gauge-preview-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 16px;
    background: #fff;
    border-radius: 8px;
}

.gauge-preview-info {
    margin-top: 8px;
}

.gauge-preview-value {
    position: absolute;
    bottom: 5px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 1.25rem;
    font-weight: 600;
    color: #495057;
}

.gauge-svg {
    width: 100%;
    height: auto;
}

.Grid {
    border-collapse: collapse;
    border: 0px none;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    width: 100%;
}

.Grid td {
    border: thin solid #000000;
    padding: 4px;
}

.Grid th {
    background-color: #262261;
    border: thin solid #000000;
    color: White;
    font-weight: bold;
    text-align: center;
}

.grid-group-header-cell {
    background-color: #cce5ff;
    font-weight: bold;
    vertical-align: top;
}

.grid-size-selector {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 4px;
    max-width: 400px;
}

.GridAlternatingRowStyle {
    background-color: #bfdbff !important;
}

.GridDiv {
    -moz-border-radius: 8px;
    -webkit-border-radius: 8px;
    border-radius: 8px;
    border: 1px solid black;
    margin: 3px;
    overflow: hidden;
    text-align: left;
    word-break: normal;
}

.GridDiv60 {
    -moz-border-radius: 8px;
    -webkit-border-radius: 8px;
    border-radius: 8px;
    border: 1px solid black;
    display: block;
    float: none;
    margin-left: auto;
    margin-right: auto;
    overflow: hidden;
    text-align: left;
    width: 60%;
}

.GridDiv80 {
    -moz-border-radius: 8px;
    -webkit-border-radius: 8px;
    border-radius: 8px;
    border: 1px solid black;
    display: block;
    float: none;
    margin-left: auto;
    margin-right: auto;
    overflow: hidden;
    text-align: left;
    width: 80%;
}

.GridDivCustomers {
    -moz-border-radius: 8px;
    -webkit-border-radius: 8px;
    border-radius: 8px;
    border: 1px solid black;
    height: 350px;
    margin: 3px;
    overflow-y: auto;
    text-align: left;
    word-break: normal;
}

.GridDivCustomers .sticky-header th {
    position: sticky;
    top: 0;
    background-color: #2cace2;
    color: white;
    z-index: 1;
}

.GridDivCustomers table {
    border-collapse: collapse;
}

.GridDivCustomers td,
.GridDivCustomers th {
    border: 1px solid #ddd;
    padding: 8px;
    text-align: left;
}

.GridDivNotes {
    -moz-border-radius: 8px;
    -webkit-border-radius: 8px;
    border-radius: 8px;
    border: 1px solid black;
    display: block;
    float: none;
    margin-left: auto;
    margin-right: auto;
    overflow: hidden;
    text-align: left;
    width: 40%;
}

.GridDivTemplates {
    text-align: center;
    width: 50%;
}

.GridDivUsers {
    -moz-border-radius: 8px;
    -webkit-border-radius: 8px;
    border-radius: 8px;
    border: 1px solid black;
    display: block;
    float: none;
    margin-left: auto;
    margin-right: auto;
    overflow: hidden;
    text-align: left;
    width: 40%;
}

.GridEditRowStyle {
    background-color: #2461bf;
    color: White;
}

.GridEmptyDataRowStyle {
    color: Red;
    text-align: center;
}

.GridFooterStyle {
    background-color: #507cd1;
    color: #ffffff;
    font-weight: bold;
    height: 100%;
}

.GridHeaderStyle {
    background-color: #262261;
    border: thin solid #000000;
    color: White;
    font-weight: bold;
    margin: 5px;
    padding-left: 10px;
    padding-right: 10px;
    text-align: center;
}

.GridHeaderStyle a {
    background-color: #262261;
    color: White;
    font-weight: bold;
    margin: 0px;
    padding-left: 10px;
    padding-right: 10px;
    text-align: center;
}

.GridHeaderStyle link {
    background-color: #262261;
    border: thin solid #000000;
    color: White;
    font-weight: bold;
    text-align: center;
}

.GridHeaderStyle th {
    background-color: #262261;
    border: thin solid #000000;
    color: White;
    font-weight: bold;
    margin: 0px;
    padding-left: 10px;
    padding-right: 10px;
    text-align: center;
}

.GridHiddenColumn {
    display: none;
}

.GridPagerStyle {
    background-color: #2461bf;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
}

.GridRowStyle {
    background-color: white !important;
}

.GridRowstyle {
    background-color: White !important;
    height: 12px;
}

.GridSelectedRowStyle {
    background-color: #BCD7F1 !important;
    color: #333333;
    font-weight: bold;
}

.GridSelectStyle {
    text-align: center;
}

.group-header-style {
    background-color: #cce5ff;
    font-weight: bold;
    vertical-align: top;
}

/* --- H --- */

.h-20 {
    height: 20px;
}

.h-22 {
    height: 22px;
}

.h-24 {
    height: 24px;
}

.h-25 {
    height: 25px;
}

.h-30 {
    height: 30px;
}

.h-78 {
    height: 78px;
}

.h-80 {
    height: 80px;
}

.h-90 {
    height: 90px;
}

.h-100 {
    height: 100px;
}

.h-115 {
    height: 115px;
}

.h-150 {
    height: 150px;
}

.h-200 {
    height: 200px;
}

.h-300 {
    height: 300px;
}

.h-750 {
    height: 750px;
}

.h-100vh {
    height: 100vh;
}

.header-large {
    font-size: large;
}

.header-logo {
    vertical-align: middle;
    text-align: left;
    height: 90px;
    padding: 0px 0px 0px 0px;
}

.help-icon {
    max-height: 30px;
}

.horizontal-scroll {
    overflow-x: auto;
}

/* --- I --- */

.icon-picker {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 12px;
    background: #f8f9fa;
    border-radius: 8px;
}

.icon-picker-btn {
    width: 48px;
    height: 48px;
    border: 2px solid #dee2e6;
    border-radius: 8px;
    background: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    color: #6c757d;
    transition: all 0.2s ease;
}

.icon-picker-btn:hover {
    border-color: #6f42c1;
    color: #6f42c1;
    transform: translateY(-2px);
}

.icon-picker-btn.selected {
    border-color: #6f42c1;
    background: #f3f0f9;
    color: #6f42c1;
}

.icon-small-faded {
    font-size: 0.75rem;
    opacity: 0.8;
}

.iframe-full {
    width: 100%;
    height: 100%;
    border: none;
}

.iframe-full-no-margin {
    width: 100%;
    height: 100%;
    border: none;
    margin: 0;
    padding: 0;
}

.iframe-terms {
    width: 100%;
    height: 400px;
    border: none;
}

.img-company-logo {
    max-height: 90px;
    max-width: 225px;
    border: 2px solid black;
}

.img-proposal-header {
    max-height: 180px;
    max-width: 810px;
    border: 2px solid black;
}

.industry-standard-cell {
    background-color: #FFFF99;
    padding-right: 20px;
}

.InfoMessage12 {
    color: #ff0000;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: bold;
    text-align: center;
}

.InfoMessage14 {
    color: #ff0000;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14px;
    font-weight: bold;
    text-align: center;
}

.InfoMessage16 {
    color: #ff0000;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 16px;
    font-weight: bold;
    text-align: center;
}

.input-calculator {
    width: 55px;
    height: 25px;
    box-sizing: border-box;
}

.input-number {
    text-align: right;
}

/* Required field styling - adds red border to indicate required input */
.input-required {
    border: 2px solid #dc3545 !important;
    box-shadow: 0 0 3px rgba(220, 53, 69, 0.3);
}

.input-required:focus {
    border-color: #dc3545 !important;
    box-shadow: 0 0 5px rgba(220, 53, 69, 0.5);
    outline: none;
}

/* Required field container styling for components like CustomerSearch */
.input-required-container input {
    border: 2px solid #dc3545 !important;
    box-shadow: 0 0 3px rgba(220, 53, 69, 0.3);
}

.input-required-container input:focus {
    border-color: #dc3545 !important;
    box-shadow: 0 0 5px rgba(220, 53, 69, 0.5);
    outline: none;
}

.InputEntry {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    text-align: left;
}

.InputEntryBorder {
    border: 1px solid #000000;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    text-align: left;
}

.InputEntryCenter {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14px;
    font-weight: bold;
    text-align: center;
    width: 100%;
}

.InputEntryLargeBold {
    border: solid 2px black;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14px;
    font-weight: bold;
    text-align: center;
    width: 100%;
}

.InputEntrySmall {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 10px;
    text-align: left;
    width: 70%;
}

.InputEntryUpperCase {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    text-align: left;
    text-transform: uppercase;
    width: 70%;
}

.InputLabel {
    font-size: 12px;
    font-family: Arial, Helvetica, sans-serif;
    padding-right: 10px;
    font-weight: bold;
    text-align: right;
}

.InputLabelGreen {
    color: green;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: bold;
    padding-right: 10px;
    text-align: right;
}

.InputLabelLeft {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: bold;
    padding-right: 10px;
    text-align: left;
}

.InputLabelRed {
    color: red;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: bold;
    padding-right: 10px;
    text-align: right;
}

.InputLabelSmall {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 10px;
    font-weight: bold;
    padding-right: 10px;
    text-align: right;
}

/* --- J --- */

.jc-currency-display {
    display: inline-block;
    width: 100px;
}

.jc-textarea-reference {
    width: 620px;
    height: 30px;
    resize: none;
}

.jc-textarea-subcontractor {
    width: 730px;
    resize: none;
}

/* --- K --- */

.kpi-icon-picker {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 12px;
    background: #f8f9fa;
    border-radius: 6px;
    margin-bottom: 8px;
}

.kpi-icon-picker-btn {
    width: 40px;
    height: 40px;
    border: 2px solid #dee2e6;
    border-radius: 6px;
    background: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: #6c757d;
    transition: all 0.2s ease;
}

.kpi-icon-picker-btn:hover {
    border-color: #2cace2;
    color: #2cace2;
}

.kpi-icon-picker-btn.selected {
    border-color: #2cace2;
    background: #e3f5fc;
    color: #2cace2;
}

/* --- L --- */

.LabelCenter {
    color: Black;
    font-size: medium;
    font-weight: bold;
    text-align: center;
    vertical-align: top;
}

.largetext {
    color: #000000;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14px;
    font-weight: bolder;
}

.LeftHeaderImage {
    height: 90px;
    padding: 0px 0px 0px 0px;
    text-align: left;
    vertical-align: middle;
}

.level-panel {
    border: 2px solid #000;
    min-width: 280px;
    background-color: #f9f9f9;
}

.level-panel-border {
    min-width: 250px;
    margin: 0 8px;
}

.level-panel-header {
    border: 1px solid black;
    border-radius: 8px;
    padding: 10px;
    text-align: center;
}

.level-panel-section {
    padding: 10px;
}

.level-subtitle {
    font-size: small;
}

.level-title {
    font-size: medium;
    font-weight: bold;
}

.link-danger {
    color: red;
    text-decoration: underline;
    cursor: pointer;
}

.link-primary {
    color: blue;
    text-decoration: underline;
    cursor: pointer;
}

.loading-img-2rem {
    width: 2rem;
    height: 2rem;
}

.loading-indicator-position {
    position: absolute;
    right: 5px;
    top: 5px;
    height: 20px;
}

.loading-overlay-backdrop {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: transparent;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: wait;
}

.loading-overlay-content {
    text-align: center;
    padding: 30px;
    background: white;
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.loading-overlay-message {
    margin-top: 12px;
    font-family: Arial, sans-serif;
    font-size: 14px;
    color: #333;
}

.loading-overlay-spinner {
    width: 3rem;
    height: 3rem;
}

.LoginEntry {
    font-size: 12px;
    font-family: Arial, Helvetica, sans-serif;
    text-align: left;
}

.LoginErrorText {
    color: red;
    font-size: 12px;
    font-weight: bold;
}

.LoginForm {
    background-color: #cccccc;
    border: thin solid #211651;
    height: 300px;
    text-align: center;
    width: 350px;
}

.LoginLabel {
    display: block;
    font-size: 12px;
    font-family: Arial, Helvetica, sans-serif;
    font-weight: bold;
    padding-right: 10px;
    text-align: right;
}

.LoginPagePanel {
    background: url(/Images/background.png) no-repeat;
    background-size: 100% 100%;
    -moz-background-size: 100% 100%;
}

.logout-link {
    color: #0066cc;
    font-size: 12px;
    text-decoration: none;
}

.logout-link:hover {
    text-decoration: underline;
}

/* --- M --- */

.m-0 {
    margin: 0;
}

.m-auto {
    margin: 0 auto;
}

.MainTable {
    border: 0px;
    height: 100%;
    padding: 0px;
    width: 98%;
}

.marketing-doc-item-padding {
    padding: 3px 0 3px 15px;
}

.marketing-documents-list-container {
    border: 1px solid #ccc;
    border-top: none;
    padding: 10px;
    max-height: 200px;
    overflow-y: auto;
}

.marketing-group-header-text {
    font-weight: bold;
    color: #333;
    margin-bottom: 5px;
}

.MarketingDocumentGridDiv {
    width: 50%;
}

.max-h-60 {
    max-height: 60px;
}

.max-h-80 {
    max-height: 80px;
}

.max-h-200-scroll {
    max-height: 200px;
    overflow-y: auto;
}

.max-h-300-scroll {
    max-height: 300px;
    overflow-y: auto;
}

.max-h-500-scroll {
    max-height: 500px;
    overflow-y: auto;
}

.max-w-50p {
    max-width: 50%;
}

.max-w-80 {
    max-width: 80px;
}

.max-w-90 {
    max-width: 90px;
}

.max-w-95pct {
    max-width: 95%;
}

.max-w-110 {
    max-width: 110px;
}

.max-w-120 {
    max-width: 120px;
}

.max-w-150 {
    max-width: 150px;
}

.max-w-280 {
    max-width: 280px;
}

.max-w-400 {
    max-width: 400px;
}

.max-w-500 {
    max-width: 500px;
}

.max-w-600 {
    max-width: 600px;
}

.mb-2 {
    margin-bottom: 2px;
}

.mb-5 {
    margin-bottom: 5px;
}

.mb-10 {
    margin-bottom: 10px;
}

.mb-15 {
    margin-bottom: 15px;
}

.mb-20 {
    margin-bottom: 20px;
}

.MenuBackground {
    background-color: #28abe2;
    border: 1px solid #000000;
    width: 100%;
}

.min-h-100 {
    min-height: 100px;
}

.min-h-200 {
    min-height: 200px;
}

.min-w-125 {
    min-width: 125px;
}

.min-w-250 {
    min-width: 250px;
}

.min-w-280 {
    min-width: 280px;
}

.min-w-370 {
    min-width: 370px;
}

.ml-10 {
    margin-left: 10px;
}

.ml-15 {
    margin-left: 15px;
}

.ml-neg-50pct {
    margin-left: -50%;
}

.modal .modal-content {
    background-color: white !important;
}

.modal-backdrop.show {
    opacity: 0.5;
}

.modal-body {
    background-color: white;
    padding: 1rem;
}

.modal-body-300 {
    max-height: 300px;
    overflow-y: auto;
}

.modal-body-500 {
    max-height: 500px;
    overflow: auto;
}

.modal-body-600 {
    max-height: 600px;
    overflow: auto;
}

.modal-body-625 {
    max-height: 625px;
    overflow-x: hidden;
    overflow-y: auto;
    contain: paint;
}

.modal-body-scrollable {
    max-height: 600px;
    overflow-y: auto;
    padding: 15px;
    position: relative;
}

.modal-body-scrollable-500 {
    max-height: 500px;
    overflow-y: auto;
    padding: 15px;
}

.modal-centered {
    margin: 1.75rem auto;
}

.modal-content {
    background-color: white !important;
    border-radius: 5px;
    box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5);
    border: 1px solid #dee2e6;
}

.modal-content-standard {
    background-color: white;
    border-radius: 5px;
    box-shadow: 0 3px 9px rgba(0, 0, 0, 0.5);
}

.modal-dialog-50 {
    max-width: 50%;
    margin: 1.75rem auto;
}

.modal-dialog-50pct {
    max-width: 50%;
    margin: 1.75rem auto;
}

.modal-dialog-600 {
    max-width: 600px;
    margin: 1.75rem auto;
}

.modal-dialog-70pct {
    max-width: 70%;
    margin: 1.75rem auto;
}

.modal-dialog-med {
    min-width: 65%;
}

.modal-dialog-standard {
    position: relative;
    margin: 1.75rem auto;
    max-width: 800px;
}

.modal-dialog-xl {
    max-width: 95%;
}

.modal-display-block {
    display: block;
    background-color: rgba(0, 0, 0, 0.5);
}

.modal-footer {
    background-color: white;
    border-top: 1px solid #dee2e6;
    padding: 1rem;
}

.modal-header {
    background-color: white;
    border-bottom: 1px solid #dee2e6;
    padding: 1rem;
    position: relative;
    z-index: 200;
}

.modal-header-danger {
    background-color: #dc3545 !important;
    color: white !important;
}

.modal-header-light {
    background-color: #f8f9fa;
    border-bottom: 1px solid #dee2e6;
}

.modal-header-lightblue {
    background-color: lightblue;
    color: black;
}

.modal-header-primary {
    background-color: #2cace2 !important;
    color: white !important;
}

.modal-header-search {
    background-color: #fff3cd;
    color: black;
    border-bottom: 1px solid #ffc107;
}

/* Search/Template dialog table styling - consistent column widths */
.search-dialog-table {
    width: 100%;
}

.search-dialog-table th,
.search-dialog-table td {
    padding: 4px 8px;
}

/* Search table columns: Load (10%), Document # (10%), Date (10%), Reference (remaining) */
.search-col-action { width: 10%; text-align: center; }
.search-col-docnum { width: 10%; text-align: center; }
.search-col-date { width: 10%; }
.search-col-reference { }

/* Template table columns: Load (10%), Template # (10%), Reference (remaining) */
.template-col-action { width: 10%; text-align: center; }
.template-col-templatenum { width: 10%; text-align: center; }
.template-col-reference { }

/* Fix sticky header - ensure rows scroll behind header */
.search-dialog-table {
    border-collapse: separate;
    border-spacing: 0;
}

.search-dialog-table thead {
    position: sticky;
    top: 0;
    z-index: 100;
}

.search-dialog-table thead th.sticky-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background-color: #262261 !important;
    color: white !important;
    font-weight: bold;
}

.search-dialog-table tbody tr {
    position: relative;
    z-index: 1;
}

.search-dialog-table tbody tr.GridRowStyle td {
    background-color: white;
}

.search-dialog-table tbody tr.GridAlternatingRowStyle td {
    background-color: #bfdbff;
}

/* Ensure modal body with scrolling clips content behind sticky header */
.modal-body-625,
.scrollable-container-500,
.scrollable-container-400 {
    position: relative;
}

/* Modal label - for labels in modals */
.modal-label {
    font-weight: bold !important;
}

.modal-medium {
    max-width: 50%;
}

.modal-medium-centered {
    max-width: 50%;
    margin: 1.75rem auto;
}

.modal-overlay {
    background-color: rgba(0,0,0,0.5);
}

.modal-small {
    max-width: 40%;
}

.modal-title-small {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    color: Black;
}

.modal-wide {
    max-width: 70%;
}

.modal-wide-xl {
    max-width: 1368px;
}

.modal.fade.show {
    display: block !important;
    background-color: rgba(0, 0, 0, 0.5);
}

.modal.show {
    display: block;
}

.modalBackground {
    background-color: Black;
    filter: alpha(opacity=60);
    opacity: 0.6;
}

.modalPopup {
    background-color: #ffffff;
    border-radius: 12px;
    border: 3px solid #0da9d0;
    padding: 0;
    width: 300px;
}

.modalPopup .body {
    font-weight: bold;
    min-height: 50px;
    padding: 10px;
    text-align: center;
}

.modalPopup .footer {
    padding: 6px;
}

.modalPopup .header {
    background-color: #2fbdf1;
    border-top-left-radius: 6px;
    border-top-right-radius: 6px;
    color: White;
    font-weight: bold;
    height: 30px;
    line-height: 30px;
    text-align: center;
}

.modalPopup .no {
    background-color: #9f9f9f;
    border: 1px solid #5c5c5c;
}

.modalPopup .no, .modalPopup .yes {
    border-radius: 4px;
    color: White;
    cursor: pointer;
    font-weight: bold;
    height: 23px;
    line-height: 23px;
    padding-top: 0 !important;
    text-align: center;
}

.modalPopup .yes {
    background-color: #2fbdf1;
    border: 1px solid #0da9d0;
}

.mr-8 {
    margin-right: 8px;
}

.mt-5 {
    margin-top: 5px;
}

.mt-10 {
    margin-top: 10px;
}

.mt-20 {
    margin-top: 20px;
}

.mt-20-mw-1400 {
    margin-top: 20px;
    max-width: 1400px;
}

.mt-40 {
    margin-top: 40px;
}

.mx-15 {
    margin-left: 15px;
    margin-right: 15px;
}

/* --- N --- */

.NormalLabel {
    color: Black;
    font-size: medium;
    font-weight: bold;
    text-align: right;
    vertical-align: top;
}

/* --- O --- */

.order-btn {
    background: none;
    border: 1px solid #ccc;
    border-radius: 3px;
    padding: 2px 6px;
    margin: 0 1px;
    cursor: pointer;
    font-size: 10px;
    color: #666;
    transition: all 0.2s;
}

.order-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

.order-btn:hover:not(:disabled) {
    background-color: #2196F3;
    border-color: #2196F3;
    color: white;
}

.order-buttons {
    display: inline-block;
    margin-left: 5px;
}

.order-cell {
    text-align: center;
    white-space: nowrap;
}

.order-help-text {
    margin-top: 10px;
    padding: 8px 12px;
    background-color: #e8f4fd;
    border-radius: 4px;
    font-size: 0.85em;
    color: #1565c0;
}

.order-help-text i {
    margin-right: 5px;
}

.order-number {
    display: inline-block;
    min-width: 20px;
    font-weight: bold;
    color: #2196F3;
}

.overflow-auto {
    overflow: auto;
}

.overflow-hidden {
    overflow: hidden;
}

.overflow-x-auto {
    overflow-x: auto;
}

/* --- P --- */

.p-2 {
    padding: 2px;
}

.p-3-flex-left {
    padding: 3px;
    display: flex;
    align-items: left;
}

.p-3-italic-gray {
    padding: 3px;
    font-style: italic;
    color: #888;
}

.p-4 {
    padding: 4px;
}

.p-5-10 {
    padding: 5px 10px;
}

.p-8 {
    padding: 8px;
}

.p-10 {
    padding: 10px;
}

.p-20 {
    padding: 20px;
}

.PageHeaderLabel {
    -moz-border-radius: 8px;
    -webkit-border-radius: 8px;
    background-color: #20c997;
    border-radius: 8px;
    border: 1px solid black;
    color: Black;
    display: block;
    float: none;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14pt;
    font-weight: bold;
    margin-left: auto;
    margin-right: auto;
    overflow: hidden;
    padding: 2px;
    text-align: center;
    width: 60%;
}

.PageHeaderLabelMedium {
    -moz-border-radius: 8px;
    -webkit-border-radius: 8px;
    background-color: #20c997;
    border-radius: 8px;
    border: 1px solid black;
    color: Black;
    display: block;
    float: none;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12pt;
    font-weight: bold;
    margin-left: auto;
    margin-right: auto;
    overflow: hidden;
    padding: 2px;
    text-align: center;
    width: 60%;
}

.PageHeaderLabelNoColor {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14pt;
    font-weight: bold;
    text-align: center;
}

.palette-btn {
    display: flex;
    gap: 2px;
    padding: 6px 8px;
    border: 2px solid #dee2e6;
    border-radius: 6px;
    background: #fff;
    cursor: pointer;
    transition: all 0.2s ease;
}

.palette-btn:hover {
    border-color: #2cace2;
    transform: translateY(-1px);
}

.palette-color {
    width: 16px;
    height: 16px;
    border-radius: 3px;
}

.palette-presets {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.password-toggle {
    cursor: pointer;
    padding: 5px;
    margin-left: 5px;
}

.password-toggle:hover {
    opacity: 0.8;
}

.password-toggle-btn {
    cursor: pointer;
    display: flex;
    align-items: center;
}

.password-toggle.hidden {
    color: #dc3545;
}

.password-toggle.visible {
    color: #28a745;
}

.PdfViewer {
    border: medium solid #211651;
    height: 100%;
    text-align: center;
    width: 100%;
}

.pl-15-bl-1-ml-10 {
    padding-left: 15px;
    border-left: 1px solid #ccc;
    margin-left: 10px;
}

.pl-20 {
    padding-left: 20px;
}

.pos-relative {
    position: relative;
}

.position-relative {
    position: relative;
}

.position-sticky-top {
    position: sticky;
    top: 0;
}

.pr-20 {
    padding-right: 20px;
}

.praxis-process {
    max-height: 40px;
}

.PraxisProcessImage {
    padding: 0px 0px 0px 0px;
    text-align: center;
    vertical-align: middle;
}

.praxis-table {
    border-collapse: collapse;
    width: 100%;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
}

.praxis-table tbody td {
    padding: 4px;
    border: 1px solid #ccc;
}

.praxis-table tbody tr:hover {
    background-color: #f5f5f5;
}

.praxis-table thead th {
    background-color: #262261;
    color: white;
    font-weight: bold;
    text-align: center;
    padding: 8px;
    border: 1px solid #000;
}

.praxis-table-fixed {
    table-layout: fixed;
}

.preview-box {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 16px 24px;
    background: #fff;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.preview-icon {
    font-size: 2rem;
    color: #6f42c1;
}

.preview-name {
    font-size: 1.125rem;
    font-weight: 600;
    color: #495057;
}

/* Profit Protector money green color */
.profit-amount,
.profit-percent,
.profit-protector-header,
.ProfitAmount,
.ProfitPercent {
    color: #228B22;
    font-weight: bold;
}

.profit-predictor-content {
    border: 1px solid #c3e6cb;
    border-top: none;
}

.profit-predictor-header {
    cursor: pointer;
    border: 1px solid #c3e6cb;
    border-radius: 5px;
}

.profit-predictor-panel {
    margin-bottom: 20px;
}

.proposal-other-input {
    width: 225px;
}

/* --- R --- */

/* Read-only value - for non-editable display values */
.readonly-value {
    font-weight: bold !important;
}

.ReportDescriptionTable {
    border: thin solid black;
    text-align: center;
    width: 50%;
}

.ReportDescriptionText {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: normal;
    text-align: left;
}

.resize-none {
    resize: none;
}

.resize-vertical {
    resize: vertical;
}

.RightHeader {
    font-size: xx-small;
    margin: 0px;
    text-align: center;
    vertical-align: bottom;
    width: 20%;
}

.RightHeaderImage {
    padding: 0px 0px 0px 0px;
    text-align: center;
    vertical-align: middle;
}

.rounded {
    border-radius: 4px;
}

.rounded-5 {
    border-radius: 5px;
}

.rounded-corners {
    -moz-border-radius: 10px;
    -webkit-border-radius: 10px;
    border-radius: 10px;
    border: 1px solid black;
    overflow: hidden;
}

/* --- S --- */

.scrollable-200 {
    max-height: 200px;
    overflow-y: auto;
}

.scrollable-container-300 {
    max-height: 300px;
    overflow-y: auto;
}

.scrollable-container-400 {
    max-height: 400px;
    overflow-y: auto;
}

.scrollable-container-425 {
    max-height: 425px;
    overflow-y: auto;
}

.scrollable-container-500 {
    max-height: 500px;
    overflow-y: auto;
}

.scrollable-container-700 {
    max-height: 700px;
    overflow-y: auto;
}

.scrollable-container-750 {
    max-height: 750px;
    overflow-y: auto;
}

.scrollable-container-800 {
    max-height: 800px;
    overflow-y: auto;
}

.scrollable-container-bordered {
    border: 1px solid #ccc;
    border-radius: 4px;
}

.search-container {
    position: relative;
    display: inline-block;
}

.search-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 1000;
    background: white;
    border: 1px solid #ccc;
    width: 600px;
    max-height: 400px;
    overflow-y: auto;
    box-shadow: 0 4px 8px rgba(0,0,0,0.2);
}

.search-result-row {
    cursor: pointer;
    color: black;
}

.search-result-row:hover {
    background-color: #e3f2fd !important;
}

.search-result-row:hover td {
    background-color: #e3f2fd !important;
    color: black !important;
}

.SearchBox {
    background-color: #ffff99;
    background-image: url('../Images/find.jpg');
    background-repeat: no-repeat;
    border: 1px solid #ccc;
    height: 22px;
    padding-left: 30px;
    width: 700px;
}

/* Section header - for section titles */
.section-header {
    font-weight: bold !important;
}

.selected-icon-preview {
    margin-top: 16px;
    text-align: center;
}

.selected-row {
    background-color: #e3f2fd !important;
}

.series-item {
    display: flex;
    gap: 8px;
    align-items: center;
}

.series-item .form-control {
    flex: 1;
}

.series-item .form-control-color {
    width: 50px;
    flex: none;
    padding: 2px;
}

.series-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 12px;
    background: #f8f9fa;
    border-radius: 6px;
}

.Signature {
    font-family: Segoe Script, cursive;
    font-size: x-large;
    text-align: left;
}

.signature-box {
    border: 1px solid #ddd;
    border-radius: 4px;
    padding: 15px;
    background-color: #f9f9f9;
}

.signature-canvas {
    border: 1px solid #ccc;
    border-radius: 4px;
    background-color: #fffef0;
    cursor: crosshair;
    touch-action: none;
    max-width: 600px;
    height: 200px;
}

.signature-inline {
    border: none;
    background: none;
    padding: 0;
}

.signature-placeholder {
    color: #999;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14px;
}

.signature-preview {
    font-family: 'Dancing Script', cursive;
    font-size: 36px;
    color: #000080;
    padding: 10px;
    border-bottom: 2px solid #333;
    min-height: 50px;
    background-color: #fffef0;
}

.sortable-header {
    cursor: pointer;
    user-select: none;
}

.sortable-header:hover {
    background-color: rgba(255, 255, 255, 0.2);
}

.staticPos {
    position: static !important;
}

.status-message-container {
    opacity: 1;
    transition: opacity 1.5s ease-out;
}

.status-message-container.fade-out {
    opacity: 0 !important;
}

.sticky-header {
    position: sticky;
    top: 0;
    z-index: 10;
    background-color: #262261 !important;
    color: white !important;
}

.sticky-header-table {
    position: relative;
}

.sticky-header-table .sticky-header {
    background-color: #262261 !important;
    color: white !important;
}

.sticky-header-table thead {
    position: sticky;
    top: 0;
    z-index: 10;
}

.sticky-table-container {
    border: 1px solid #ccc;
    overflow-y: auto;
    position: relative;
}

.sticky-toolbar {
    position: sticky;
    top: 0;
    background-color: white;
    z-index: 100;
    padding-bottom: 10px;
}

.sticky-top-10 {
    position: sticky;
    top: 10px;
}

.success-message {
    color: green;
    font-weight: bold;
}

.system-message-box {
    border: thin solid #211651;
    width: 60%;
}

.system-message-text {
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14px;
    color: #FF0000;
    font-weight: bold;
    text-align: center;
}

/* --- T --- */

.tabInTableFix {
    width: 1000%;
}

/* Table group level headers */
.table-group-header, th.group-header {
    background-color: #BFDBFF;
    font-weight: bold !important;
    text-align: center;
    font-size: 12px;
    font-family: Arial, Helvetica, sans-serif;
}

.table-layout-fixed {
    table-layout: fixed;
}

.table-preview {
    border: 1px solid #dee2e6;
    border-radius: 6px;
    overflow: hidden;
}

.table-preview .table {
    font-size: 0.875rem;
}

.tableborder {
    border: 1px solid black;
}

.TableHeader {
    background-color: #BFDBFF;
    font-weight: bold;
    text-align: center;
    font-size: 12px;
    font-family: Arial, Helvetica, sans-serif;
}

/* All tables should have alternating row colors - except .Grid tables which use class-based alternation */
table:not(.Grid) tbody tr:nth-child(odd) {
    background-color: white;
}

table:not(.Grid) tbody tr:nth-child(even) {
    background-color: #bfdbff;
}

/* Disable zebra striping for specific tables */
table.no-zebra tbody tr:nth-child(odd),
table.no-zebra tbody tr:nth-child(even) {
    background-color: white;
}

/* Table cell alignment classes */
.td-align-center {
    text-align: center;
}

.td-align-left {
    text-align: left;
}

.td-align-right {
    text-align: right;
}

.td-valign-middle {
    vertical-align: middle;
}

.td-valign-top {
    vertical-align: top;
}

.text-12 {
    font-size: 12px;
}

.text-14 {
    font-size: 14px;
}

.text-blue-link {
    color: #0000EE;
}

.text-center {
    text-align: center;
}

.text-center-mb-10 {
    text-align: center;
    margin-bottom: 10px;
}

.text-center-mt-10 {
    text-align: center;
    margin-top: 10px;
}

.text-center-p-20 {
    text-align: center;
    padding: 20px;
}

.text-emphasis-red {
    color: red;
}

.text-green {
    color: green;
}

.text-left {
    text-align: left;
}

.text-lowercase {
    text-transform: lowercase;
}

.text-red {
    color: #FF0000;
}

.text-red-solid {
    color: red;
    opacity: 1;
}

.text-right {
    text-align: right;
}

.text-right-bold {
    font-weight: bold;
    display: block;
    text-align: right;
}

.text-sm {
    font-size: small;
}

.text-underline {
    text-decoration: underline;
}

.text-uppercase {
    text-transform: uppercase;
}

.text-xs {
    font-size: 10px;
}

.textarea-370-100 {
    width: 370px;
    height: 100px;
    resize: none;
}

.textarea-490-150 {
    width: 490px;
    height: 150px;
}

.textarea-620-80 {
    width: 620px;
    height: 80px;
    resize: none;
}

.textarea-620-115 {
    width: 620px;
    height: 115px;
    resize: none;
}

.textarea-650-60 {
    width: 650px;
    height: 60px;
    resize: none;
}

.textarea-650-180 {
    width: 650px;
    height: 180px;
    resize: none;
}

.textarea-702-100 {
    width: 702px;
    height: 100px;
    resize: none;
}

.textarea-715-200 {
    width: 715px;
    height: 200px;
}

.textarea-monospace {
    font-family: monospace;
}

.textarea-no-resize {
    resize: none;
    overflow: auto;
}

.textarea-readonly {
    width: 100%;
    height: 200px;
    font-size: 8pt;
    resize: none;
    border: 1px solid #ccc;
    background-color: white;
}

.threshold-color {
    width: 50px;
    padding: 2px;
}

.threshold-item {
    display: flex;
    align-items: center;
    gap: 8px;
}

.threshold-label {
    font-size: 0.875rem;
    color: #6c757d;
    white-space: nowrap;
}

.threshold-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 12px;
    background: #f8f9fa;
    border-radius: 6px;
}

.threshold-value {
    width: 100px;
}

.titlebar {
    margin-bottom: 20px;
    text-align: center;
}

.titlebar h2 {
    color: #222;
    font-size: 40px;
    font-weight: 400;
    text-transform: uppercase;
}

.titlebar h2.no-underline:after {
    background: none !important;
}

.titlebar h2:after {
    background: #80bd01;
    content: "";
    display: block;
    height: 2px;
    margin: 15px auto;
    position: relative;
    width: 200px;
}

.titlebar h3 {
    color: #222;
    font-size: 24px;
    font-weight: 300;
    letter-spacing: 1px;
    margin-bottom: 10px;
    text-transform: uppercase;
}

.toolbar {
    position: fixed;
}

.toolbar-button {
    background: none;
    border: none;
    cursor: pointer;
    padding: 2px;
}

.toolbar-button:disabled {
    cursor: not-allowed;
    opacity: 0.6;
}

.toolbar-button:hover {
    background-color: #bcd7f1;
}

.toolbar-container {
    display: flex;
    flex-wrap: wrap;
    gap: 2px;
    max-width: 400px;
    position: relative;
    z-index: 100;
}

.toolbuttoncell {
    border: 0px;
    padding: 20px;
    text-align: center;
    width: 33%;
}

.TrainingVideo {
    border: medium solid #211651;
    text-align: center;
    width: 50%;
}

/* --- V --- */

.valign-top {
    vertical-align: top;
}

.validation-error {
    color: #dc3545;
    font-size: 0.875rem;
    margin-top: 4px;
}

.ValidationLabel {
    color: #ff0000;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: bold;
    text-align: left;
}

.ValidationLabelCenter {
    color: #ff0000;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 12px;
    font-weight: bold;
    text-align: center;
}

.ValidationLabelLarge {
    color: #ff0000;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14px;
    font-weight: bold;
    text-align: left;
}

.ValidationLabelLargeBlack {
    color: black;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14px;
    font-weight: bold;
    text-align: left;
}

.ValidationLabelLargeCenter {
    color: #ff0000;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14px;
    font-weight: bold;
    text-align: center;
}

.ValidationLabelSmall {
    color: #ff0000;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 10px;
    font-weight: bold;
    text-align: left;
}

/* --- W --- */

.w-5pct { width: 5%; }
.w-8pct { width: 8%; }
.w-10pct { width: 10%; }
.w-12pct { width: 12%; }
.w-13pct { width: 13%; }
.w-15pct { width: 15%; }
.w-16pct { width: 16%; }
.w-17pct { width: 17%; }
.w-20pct { width: 20%; }
.w-25pct { width: 25%; }
.w-27pct { width: 27%; }
.w-28pct { width: 28%; }
.w-30pct { width: 30%; }
.w-32pct { width: 32%; }
.w-35pct { width: 35%; }
.w-36pct { width: 36%; }
.w-40pct { width: 40%; }
.w-44pct { width: 44%; }
.w-45pct { width: 45%; }
.w-50pct { width: 50%; }
.w-60pct { width: 60%; }
.w-65pct { width: 65%; }
.w-70pct { width: 70%; }
.w-75pct { width: 75%; }
.w-80pct { width: 80%; }
.w-85pct { width: 85%; }
.w-90pct { width: 90%; }
.w-100pct { width: 100%; }

.w-10 { width: 10px; }
.w-15 { width: 15px; }
.w-25 { width: 25px; }
.w-30 { width: 30px; }
.w-40 { width: 40px; }
.w-45 { width: 45px; }
.w-48 { width: 48px; }
.w-50 { width: 50px; }
.w-50px {
    width: 50px;
}
.w-55 { width: 55px; }
.w-60 { width: 60px; }
.w-65 { width: 65px; }
.w-70 { width: 70px; }
.w-75 { width: 75px; }
.w-80 { width: 80px; }
.w-88 { width: 88px; }
.w-90 { width: 90px; }
.w-100 { width: 100px; }
.w-115 { width: 115px; }
.w-120 { width: 120px; }
.w-125 { width: 125px; }
.w-131 { width: 131px; }
.w-150 { width: 150px; }
.w-160 { width: 160px; }
.w-169 { width: 169px; }
.w-171 { width: 171px; }
.w-175 { width: 175px; }
.w-180 { width: 180px; }
.w-190 { width: 190px; }
.w-200 { width: 200px; }
.w-210 { width: 210px; }
.w-225 { width: 225px; }
.w-240 { width: 240px; }
.w-250 { width: 250px; }
.w-287 { width: 287px; }
.w-300 { width: 300px; }
.w-330 { width: 330px; }
.w-350 { width: 350px; }
.w-370 { width: 370px; }
.w-400 { width: 400px; }
.w-450 { width: 450px; }
.w-480 { width: 480px; }
.w-490 { width: 490px; }
.w-500 { width: 500px; }
.w-600 { width: 600px; }
.w-620 { width: 620px; }
.w-700 { width: 700px; }
.w-702 { width: 702px; }
.w-715 { width: 715px; }
.w-730 { width: 730px; }
.w-800 { width: 800px; }
.w-auto { width: auto; }

/* Pixel-based width with px suffix */
.w-40px { width: 40px; }
.w-50px { width: 50px; }
.w-60px { width: 60px; }
.w-66px { width: 66px; }
.w-70px { width: 70px; }
.w-75px { width: 75px; }
.w-80px { width: 80px; }
.w-88px { width: 88px; }
.w-90px { width: 90px; }
.w-100px { width: 100px; }
.w-110px { width: 110px; }
.w-210px { width: 210px; }
.w-480px { width: 480px; }

.w-17pct-pr-20 {
    width: 17%;
    padding-right: 20px;
}

.w-25pct-pr-20 {
    width: 25%;
    padding-right: 20px;
}

.w-80-text-center {
    width: 80px;
    text-align: center;
}

.w-90-pr-20 {
    width: 90px;
    padding-right: 20px;
}

.WebHeader {
    background-image: url('Images/WebHeading_Background.jpg');
    background-repeat: repeat-x;
    border: 1px solid #000000;
    text-align: center;
}

.whitespace-nowrap {
    white-space: nowrap;
}

.whitespace-preline {
    white-space: pre-line;
}

/* --- Z --- */

.z-index-1 {
    z-index: 1;
}

.z-index-2 {
    z-index: 2;
}

.z-index-10 {
    z-index: 10;
}

.z-index-1060 {
    z-index: 1060;
}

.z-index-1070 {
    z-index: 1070;
}

.z-1000-mw-500 {
    z-index: 1000;
    max-width: 500px;
}

.z-1000-scroll-h-300 {
    z-index: 1000;
    max-height: 300px;
    overflow-y: auto;
}

.zone-color {
    width: 50px;
    padding: 2px;
}

.zone-item {
    display: flex;
    align-items: center;
    gap: 8px;
}

.zone-label {
    font-size: 0.875rem;
    color: #6c757d;
    white-space: nowrap;
}

.zone-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 12px;
    background: #f8f9fa;
    border-radius: 6px;
}

.zone-value {
    width: 80px;
}

/* ==========================================
   ATTRIBUTE SELECTORS
   ========================================== */

/* Prevent Bootstrap responsive column stacking */
[class*="col-"] {
    flex: 0 0 auto;
    max-width: none;
}

/* ==========================================
   KEYFRAMES ANIMATIONS
   ========================================== */

@-moz-keyframes blinker {
    0% {
        opacity: 1.0;
    }
    50% {
        opacity: 0.0;
    }
    100% {
        opacity: 1.0;
    }
}

@-webkit-keyframes blinker {
    0% {
        opacity: 1.0;
    }
    50% {
        opacity: 0.0;
    }
    100% {
        opacity: 1.0;
    }
}

@keyframes blinker {
    0% {
        opacity: 1.0;
    }
    50% {
        opacity: 0.0;
    }
    100% {
        opacity: 1.0;
    }
}
