﻿:root {
    --intelliscope-navy: #0B103E;
    --intelliscope-light: #EDF5FF;
    --intelliscope-gold: #B59410;
}

/* Laptop + tablet screens: zoom UI to 80% */
/* BUG FOUND - EPIC #1203 */
/*@media (min-width: 768px) and (max-width: 1440px) {
    html {
        zoom: 0.8;
    }
}*/

body {
    height: auto;
}

.navbar-nav .dropdown-menu {
    position: absolute !important;
    top: 100% !important;
    left: auto !important;
    right: 0; /* because you use dropdown-menu-end */
    transform: none !important;
    margin-top: 0.25rem; /* small gap below Actions */
    z-index: 1050; /* ensure it floats above */
}

@media(min-width:768px) {
    @supports((position:-webkit-sticky) or (position:sticky)) {
        .sticky-top-md-up {
            position: -webkit-sticky;
            position: sticky;
            top: 0;
            z-index: 1020;
        }
    }
}

@media(min-width:768px) {
    @supports((position:-webkit-sticky) or (position:sticky)) {
        .sticky-top-md-up-offset {
            position: -webkit-sticky;
            position: sticky;
            top: 55px;
            z-index: 1019;
        }
    }
}

.sidebar-company-logo-container {
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 0.5rem;
}

.sidebar-company-logo {
    max-height: 80px;
    max-width: 100%;
    height: auto;
    width: auto;
    object-fit: contain;
}

.order-company-logo-container {
    display: flex;
    align-items: center;
    padding-top: 0.5rem;
}

.order-company-logo {
    max-height: 50px;
    max-width: 100%;
    height: auto;
    width: auto;
    object-fit: contain;
}

.content-header {
    border-bottom: 1px solid var(--intelliscope-navy);
}

table td {
    vertical-align: middle !important;
}

table tbody tr td .form-group {
    margin-bottom: 0 !important;
}

table.dataTable th {
    white-space: nowrap;
    background-color: lightgray !important;
}

.bg-subtle-image {
    background-image: url('/img/bg-subtle-light-image.jpg');
}

.bg-success-light {
    background-color: #71c79b !important;
    color: #000;
}

.bg-secondary-light {
    background-color: #bfc4ca !important;
    color: #000;
}

.breadcrumb-item::before {
    content: none !important;
}

.text-is-navy {
    color: var(--intelliscope-navy) !important;
}

.text-is-light {
    color: var(--intelliscope-light) !important;
}

.text-is-gold {
    color: var(--intelliscope-gold) !important;
}

.bg-is-navy {
    background-color: var(--intelliscope-navy) !important;
}

.bg-is-light {
    background-color: var(--intelliscope-light) !important;
}

.bg-is-gold {
    background-color: var(--intelliscope-gold) !important;
}

.bg-dark-teal {
    background-color: #006666 !important;
    color: white;
}

.bg-light-teal {
    background-color: #66cccc !important;
    color: black;
}

.card.card-navy.card-tabs .nav-tabs .nav-link {
    color: white; /* Inactive tabs */
}

    .card.card-navy.card-tabs .nav-tabs .nav-link.active {
        background-color: white;
        color: #001f3f; /* Adjust this to match the navy theme */
    }

.f-16 {
    font-size: 16px;
}

.f-20 {
    font-size: 20px;
}

.f-24 {
    font-size: 24px;
}

.f-28 {
    font-size: 28px;
}

.f-32 {
    font-size: 32px;
}

.f-36 {
    font-size: 36px;
}

.f-48 {
    font-size: 48px;
}

.brand-text {
    font-family: 'Elsie', serif !important;
}

.index-list {
    padding-left: 25px;
}

.index-list-title {
    font-weight: bold;
}

.btn-is-navy {
    color: #fff; /* White text for contrast */
    background-color: var(--intelliscope-navy);
    border-color: var(--intelliscope-navy);
    transition: all 0.15s ease-in-out;
}

    .btn-is-navy:hover {
        color: #fff; /* Maintain white text */
        background-color: var(--intelliscope-navy-hover, #004080); /* Adjust for a darker navy on hover */
        border-color: var(--intelliscope-navy-hover, #004080);
    }

    .btn-is-navy:focus,
    .btn-is-navy.focus {
        box-shadow: 0 0 0 0.2rem rgba(var(--intelliscope-navy-rgb), 0.5);
    }

    .btn-is-navy:disabled,
    .btn-is-navy.disabled {
        color: #fff; /* Keep text visible */
        background-color: var(--intelliscope-navy);
        border-color: var(--intelliscope-navy);
        opacity: 0.65;
    }

.btn-is-outline-navy {
    color: var(--intelliscope-navy);
    border-color: var(--intelliscope-navy);
    background-color: transparent;
    transition: all 0.15s ease-in-out;
}

    .btn-is-outline-navy:hover {
        color: #fff; /* Adjust for contrast */
        background-color: var(--intelliscope-navy);
        border-color: var(--intelliscope-navy);
    }

    .btn-is-outline-navy:focus,
    .btn-is-outline-navy.focus {
        box-shadow: 0 0 0 0.2rem rgba(var(--intelliscope-navy-rgb), 0.5);
    }

    .btn-is-outline-navy:disabled,
    .btn-is-outline-navy.disabled {
        color: var(--intelliscope-navy);
        background-color: transparent;
        border-color: var(--intelliscope-navy);
        opacity: 0.65;
    }

.btn-is-gold {
    color: #fff; /* White text for contrast */
    background-color: var(--intelliscope-gold);
    border-color: var(--intelliscope-gold);
    transition: all 0.15s ease-in-out;
}

    .btn-is-gold:hover {
        color: #fff; /* Maintain white text */
        background-color: var(--intelliscope-gold-hover, #004080); /* Adjust for a darker gold on hover */
        border-color: var(--intelliscope-gold-hover, #004080);
    }

    .btn-is-gold:focus,
    .btn-is-gold.focus {
        box-shadow: 0 0 0 0.2rem rgba(var(--intelliscope-gold-rgb), 0.5);
    }

    .btn-is-gold:disabled,
    .btn-is-gold.disabled {
        color: #fff; /* Keep text visible */
        background-color: var(--intelliscope-gold);
        border-color: var(--intelliscope-gold);
        opacity: 0.65;
    }

.btn-is-outline-gold {
    color: var(--intelliscope-gold);
    border-color: var(--intelliscope-gold);
    background-color: transparent;
    transition: all 0.15s ease-in-out;
}

    .btn-is-outline-gold:hover {
        color: #fff; /* Adjust for contrast */
        background-color: var(--intelliscope-gold);
        border-color: var(--intelliscope-gold);
    }

    .btn-is-outline-gold:focus,
    .btn-is-outline-gold.focus {
        box-shadow: 0 0 0 0.2rem rgba(var(--intelliscope-gold-rgb), 0.5);
    }

    .btn-is-outline-gold:disabled,
    .btn-is-outline-gold.disabled {
        color: var(--intelliscope-gold);
        background-color: transparent;
        border-color: var(--intelliscope-gold);
        opacity: 0.65;
    }

.page-title-wrapper {
    max-height: 50px;
    padding: 0 15px;
}

@media (max-width: 768px) {
    .page-title-wrapper {
        padding: 0;
    }
}

.icon-wrapper {
    font-size: 50px;
    max-height: 50px;
    max-width: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--intelliscope-navy);
}

.title-breadcrumbs {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100%;
}

.page-title-heading {
    flex: 0 0 60%;
    font-size: 1.8rem !important;
    margin-bottom: 0;
}

@media (max-width: 576px) {
    .page-title-heading {
        font-size: 1.2rem !important;
    }
}

.page-title-breadcrumbs {
    flex: 0 0 40%;
    font-size: 0.875rem; /* Adjust size as needed */
    color: #6c757d;
}

.button-group {
    align-items: flex-end; /* Align buttons at the bottom */
    display: flex;
    margin-top: auto; /* Push buttons to the bottom of the container */
    gap: 7px;
}

.label-wrapper {
    display: flex;
    align-items: flex-start;
}

/* Apply float: right only on medium screens and up (≥768px) */
@media (min-width: 768px) {
    .label-wrapper {
        float: right;
    }
}

.dropdown-menu.notification-dropdown {
    position: fixed !important;
    right: 0 !important;
    left: auto !important;
    top: unset !important;
    min-width: 500px;
}

.col-form-label.required:before {
    content: "* ";
    color: #820101;
    font-weight: bold;
}

.form-check-label.required:before {
    content: "* ";
    color: #820101;
    font-weight: bold;
}

.has-treeview a {
    margin: 0 !important;
}

.submenu-item {
    background-color: #1A205A;
    padding: 0;
}

    .submenu-item a {
        display: flex;
        align-items: center;
        padding-left: 25px;
        color: inherit;
        text-decoration: none;
        margin: 0 !important;
    }

        .submenu-item a i {
            margin-right: 10px;
        }

.sidebar {
    position: relative; /* Ensure the sidebar's position allows overlays */
    overflow-y: scroll !important;
    scrollbar-width: thin !important; /* Thin scrollbar for Firefox */
    scrollbar-color: rgba(255, 255, 255, 0.3) transparent !important; /* Light thumb over transparent track for Firefox */
}

    .sidebar::-webkit-scrollbar {
        width: 8px !important; /* Thin scrollbar width */
        background: transparent !important; /* Transparent background */
    }

    .sidebar::-webkit-scrollbar-thumb {
        background-color: rgba(255, 255, 255, 0.3) !important; /* Light-colored thumb */
        border-radius: 4px !important; /* Rounded edges for the thumb */
    }

        .sidebar::-webkit-scrollbar-thumb:hover {
            background-color: rgba(255, 255, 255, 0.5) !important; /* Slightly darker thumb on hover */
        }

    .sidebar::-webkit-scrollbar-track {
        background: transparent !important; /* Transparent track */
    }

.slide-in {
    opacity: 0;
    transform: translateX(0); /* Default to no horizontal shift */
    transition: transform 0.8s ease, opacity 0.8s ease;
}

    .slide-in.left {
        transform: translateX(-100%); /* Slide in from the left */
    }

    .slide-in.right {
        transform: translateX(100%); /* Slide in from the right */
    }

    .slide-in.bottom {
        transform: translateY(100%); /* Slide in from the bottom */
    }

    .slide-in.show {
        opacity: 1;
        transform: translateX(0) translateY(0); /* Move to the original position */
    }

.dt-container .dt-search input {
    background-color: white !important;
}

.dt-container .dt-paging .dt-paging-button.current {
    background-color: var(--intelliscope-gold) !important;
}

.dt-button {
    border: 1px solid #6c757d !important;
    background-color: #6c757d !important;
    font-size: 0.875rem !important; /* Matches .btn-sm */
    padding: 0.25rem 0.5rem !important; /* Matches .btn-sm */
    line-height: 1.5 !important;
    border-radius: 0.25rem !important;
    transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out !important;
}

    .dt-button:hover {
        color: #fff !important;
        background-color: var(--intelliscope-gold) !important;
        border-color: #6c757d !important;
    }

    .dt-button:focus,
    .dt-button.focus {
        box-shadow: 0 0 0 0.25rem rgba(130,138,145,0.5) !important;
    }

    .dt-button:disabled,
    .dt-button.disabled {
        color: #6c757d !important;
        background-color: transparent !important;
        border-color: #6c757d !important;
        opacity: 0.65 !important;
    }

button.dt-button.processing {
    pointer-events: auto !important; /* keep clickable */
    opacity: 1 !important;
    position: relative;
}

    button.dt-button.processing::after {
        display: none !important;
    }

.card-intelliscope {
    border: 1px solid #001f3f;
}

    .card-intelliscope > .card-header {
        border-bottom: 7px solid #001f3f !important;
    }

    .card-intelliscope .nav-tabs {
        background-color: white;
        margin-bottom: 0px;
    }

        .card-intelliscope .nav-tabs .nav-link {
            background-color: white;
            color: #001f3f;
            border: 1px solid transparent;
            border-top-left-radius: 1rem !important;
            border-top-right-radius: 1rem !important;
            margin-bottom: -1px;
        }

            .card-intelliscope .nav-tabs .nav-link.active {
                background-color: #001f3f;
                color: white;
            }

.select2-dropdown-wider {
    min-width: 300px !important;
}

.select2-container .select2-search--inline .select2-search__field {
    vertical-align: unset !important;
    margin-top: 2px !important;
}

.select2-container--default.select2-container--focus .select2-selection--multiple {
    border: 1px solid #ced4da !important;
}

.select2-container .select2-search--inline .select2-search__field {
    margin-top: 0 !important;
}

/* Match height and padding of Bootstrap's form-select */
.select2-container--default .select2-selection--multiple,
.select2-container--default .select2-selection--single {
    height: calc(2.375rem + 2px); /* Default Bootstrap 5 height for .form-select */
    padding: 0.375rem 0.75rem;
    font-size: 1rem;
    line-height: 1.5;
    border: 1px solid #ced4da;
    border-radius: 0.375rem;
    box-shadow: inset 0 0 0 transparent;
    background-color: #fff;
    display: flex;
    align-items: center;
    position: relative; /* Added for positioning clear button */
}

    .select2-container--default .select2-selection--multiple .select2-selection__choice__display {
        cursor: default;
        padding-left: 8px;
        padding-right: 8px;
    }

    /* Remove unnecessary Select2 styling quirks */
    .select2-container--default .select2-selection--multiple .select2-selection__choice {
        vertical-align: middle !important;
        margin-top: 0 !important;
    }

    .select2-container--default .select2-selection--multiple .select2-selection__rendered,
    .select2-container--default .select2-selection--single .select2-selection__rendered {
        line-height: 1.5;
        padding-left: 0;
        /*padding-right: 0;*/
        margin-bottom: 0;
    }

    .select2-container--default .select2-selection--multiple .select2-selection__arrow,
    .select2-container--default .select2-selection--single .select2-selection__arrow {
        height: 100%;
        top: 0;
        right: 0.75rem;
        width: 2rem;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    /* Clear button styled and floated right */
    .select2-container--default .select2-selection--multiple .select2-selection__clear,
    .select2-container--default .select2-selection--single .select2-selection__clear {
        position: absolute;
        right: 2.25rem; /* Positioned just before the dropdown arrow */
        transform: translateY(-50%);
        background-color: #6c757d !important;
        color: white;
        border-radius: 0.375rem;
        padding: 0 0.5rem !important;
        font-size: 13px !important;
        font-weight: normal !important;
        height: auto !important;
        line-height: 1.5;
        cursor: pointer;
    }

    .select2-container--default .select2-selection--single .select2-selection__clear {
        top: 50%;
    }

    .select2-container--default .select2-selection--multiple .select2-selection__clear {
        top: 40%;
    }

.select2-selection__clear::after {
    content: ' Clear';
    display: inline;
}

.select2-selection__clear::before {
    content: '';
}

.select2-container--default.select2-container--focus .select2-selection--multiple,
.select2-container--default .select2-selection--multiple {
    min-height: auto;
    height: auto;
    overflow-y: auto;
    padding-bottom: 5px;
}

    .select2-container--default .select2-selection--multiple .select2-selection__rendered {
        display: flex;
        flex-wrap: wrap;
        max-height: none;
        overflow: visible;
    }

    .select2-container--default .select2-selection--multiple .select2-selection__choice {
        margin-top: 5px;
    }

a:hover .info-box {
    transform: scale(1.02);
    opacity: 0.95;
    transition: transform 0.2s ease, opacity 0.2s ease;
}

.info-box {
    transition: transform 0.2s ease, opacity 0.2s ease;
}

.fc-col-header-cell-cushion,
.fc-daygrid-day-number {
    color: navy !important;
}

@media (max-width: 575.98px) {
    #page-buttons a,
    #page-buttons button {
        font-size: 0; /* hide text */
        padding: 0.25rem 0.5rem; /* btn-sm padding */
        line-height: 1.5;
        border-radius: 0.2rem;
    }

        #page-buttons a i,
        #page-buttons button i {
            font-size: 1rem; /* icon size */
            margin-right: 0; /* remove icon spacing */
        }
}

.intelliscope-table-text-xs {
    width: 100%;
}

    .intelliscope-table-text-xs,
    .intelliscope-table-text-xs td,
    .intelliscope-table-text-xs th,
    .intelliscope-table-text-xs label,
    .intelliscope-table-text-xs input,
    .intelliscope-table-text-xs select,
    .intelliscope-table-text-xs textarea,
    .intelliscope-table-text-xs button,
    .intelliscope-table-text-xs span,
    .intelliscope-table-text-xs div {
        font-size: 0.75rem;
    }

        /* Allow smooth resizing grips on table headers */
        .intelliscope-table-text-xs th {
            position: relative;
            user-select: none;
            overflow: hidden;
        }

            .intelliscope-table-text-xs th .th-resizer {
                position: absolute;
                top: 0;
                right: 0;
                width: 6px;
                height: 100%;
                cursor: col-resize;
                user-select: none;
                z-index: 2;
                background: transparent;
                transition: background-color 0.2s ease;
            }

                .intelliscope-table-text-xs th .th-resizer:hover {
                    background-color: rgba(0, 0, 0, 0.15);
                }


/* Kill the default 3 dots */
div.dt-processing > div {
    display: none !important;
}

/* Grey out the table body while loading */
table.dataTable.loading {
    position: relative !important;
}

    table.dataTable.loading::after {
        content: "" !important;
        position: absolute !important;
        top: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: 100% !important;
        background: rgba(200, 200, 200, 0.4) !important;
        z-index: 10 !important;
    }

/* Floating loader panel centered on screen */
div.dt-processing {
    position: fixed !important;
    top: 50% !important;
    left: 60% !important;
    transform: translate(-50%, -50%) !important; /* true centering */
    width: auto !important;
    height: auto !important;
    padding: 1rem 2rem !important;
    background: rgba(255,255,255,0.9) !important; /* solid panel */
    border-radius: 0.5rem;
    box-shadow: 0 0 10px rgba(0,0,0,0.2);
    text-align: center !important;
    z-index: 3000 !important;
}

    /* Emphasize loader */
    div.dt-processing .fa-sync-alt {
        font-size: 3rem !important;
        color: #28a745 !important;
    }

    div.dt-processing .f-24 {
        font-size: 1.5rem !important;
        font-weight: bold !important;
        color: #28a745 !important;
    }

.is-calculated {
    background-color: #e6ffe6 !important; /* light green glow */
    transition: background-color 0.5s ease-in-out;
}

.bg-item-detail {
    background-color: #e0e0e0 !important;
    color: #212529 !important;
}

.datafilter-width {
    display: inline-block;
    padding: 0.25rem !important;
}

    /* Fix the button width */
    .datafilter-width .btn {
        width: 250px; /* Set desired fixed width */
        max-width: 250px;
        min-width: 250px;
        display: inline-block;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis; /* Prevent stretching */
        text-align: left !important;
        padding-left: 0.75rem; /* optional: add some consistent left padding */
    }

    /* Fix dropdown menu width to match button */
    .datafilter-width .dropdown-menu {
        width: 250px;
        max-width: 250px;
    }

    /* Optional: long enum names inside menu don’t stretch it */
    .datafilter-width .form-check-label {
        white-space: nowrap;
        text-overflow: ellipsis;
        overflow: hidden;
    }

.th-datafilter-width {
    font-weight: normal;
    width: 100% !important;
}

    .th-datafilter-width .dropdown-toggle {
        width: 100% !important;
    }

@media (max-width: 991.98px) {
    .main-footer {
        position: unset !important;
    }
}

.item-col-row-number {
    min-width: 40px;
    max-width: 50px;
    width: 50px;
    text-align: center;
}

.item-col-product {
    min-width: 250px;
}

.item-col-description {
    min-width: 400px;
}

.item-col-unit-cost {
    min-width: 180px;
    text-align: right;
    white-space: nowrap;
}

.item-col-quantity {
    min-width: 160px;
    text-align: right;
    white-space: nowrap;
}

.item-col-taxcode {
    min-width: 200px;
}

.item-col-serialnumber {
    min-width: 220px;
}

.item-col-account {
    min-width: 220px;
}

.item-col-total {
    width: 100px;
    min-width: 100px;
    text-align: right;
    white-space: nowrap;
}

.item-col-actions {
    width: 100px;
    min-width: 100px;
    text-align: center;
}

/* ==========================================================
   Product Selection Select2
   ========================================================== */

.product-selection-select-list {
    --product-grid-columns: 0.5fr 0.5fr 2.5fr 0.5fr 0.5fr;
    min-width: 1000px;
    max-width: 1000px;
    width: auto !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

@media (min-width: 768px) and (max-width: 1440px) {
    .product-selection-select-list {
        min-width: 800px;
        max-width: 800px;
    }
}

    .product-selection-select-list .select2-results__group {
        display: grid !important;
        grid-template-columns: var(--product-grid-columns);
        gap: 8px;
        padding: 6px 8px;
        font-weight: 600;
        font-size: 0.8rem;
        background-color: #343a40;
        color: #ffffff;
        border-bottom: 1px solid #495057;
    }

    .product-selection-select-list .select2-product-row {
        display: grid;
        grid-template-columns: var(--product-grid-columns);
        gap: 8px;
        font-size: 0.85rem;
        padding: 4px 8px;
    }

    .product-selection-select-list .select2-results__options {
        max-height: 40vh !important;
    }

.modal .select2-dropdown,
.modal .select2-selection--single {
    text-align: left;
}