/* Distriglass CSS - version nettoyée avant prod DAT V2.
   Nettoyage: commentaires morts supprimés, bloc badge corrigé, comportement V2 conservé. */

body {
    background-image: url("/static/images/filigrane.9e6594a2c05f.svg");
    background-repeat: repeat;
    background-attachment: fixed;
    padding-top: 110px;
}
.bg-home {
    background: linear-gradient(90deg, rgba(24, 136, 211, 0.7), rgba(10, 71, 128, 0.7)), url("/static/images/v2/background_pb.ad655701e9f8.webp") center/cover;
    color: #fff;
    font-size: 0.9rem;
}
.icon-box {
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: background-color 0.3s ease, transform 0.3s ease;
}
.bg-light-home {
    background-color: #E5E7EB;
}
html {
    scroll-behavior: smooth !important;
}
html {
    overflow-y: scroll;
}

.card-body {
    padding: 1rem 1.5rem;
}

.card {
    border-radius: 8px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    background: #fff;
}

.card-custom {
    border-radius: 16px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    background: linear-gradient(135deg, #f5f7fa, #ffffff);
}

.card-custom:hover,
.card-custom:focus {
    transform: translateY(-4px);
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.15);
    outline: none;
}
.dist-card:hover .btn-overlay {
    opacity: 1;
    visibility: visible;
}
.dist-card {
    position: relative;
    overflow: hidden;
    border-radius: 8px;
    transition: transform 0.3s ease;
    background-color: white;
}

.dist-card:hover {
    transform: translateY(-5px);
}

#scrollTopBtn {
    display: block;
    position: fixed;
    bottom: 20px;
    right: 30px;
    z-index: 99;
}
#toggleSearchBtn {
    margin-bottom: 20px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}
.btn-overlay {
    opacity: 0;
    visibility: hidden;
    margin-top: 1rem;
    padding: 5px 10px;
    border: none;
    border-radius: 5px;
    color: #fff;
    cursor: pointer;
    text-align: center;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.btn-dt, .btn {
    font-size: 0.875rem;
    padding: 0.25rem 0.5rem;
    border-radius: 0.95rem;

}
.btn-warning {
    color: #212529;
    background-color: #ffc107;
    border-color: #ffc107;
}

.btn-primary {
    color: #fff;
    background-color: #007bff;
    border-color: #007bff;
}
.btn-main {
    opacity: 0;
    transition: opacity 0.3s ease;
    margin-top: 1rem;
}
.btn-secondary {
    background-color: #6c757d;
    border-color: #6c757d;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.btn-secondary:hover {
    background-color: #5a6268;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}
.btn-cart {
    color: #212529;
    background-color: var(--distri-yellow);
    border-color: var(--distri-yellow);
}

.btn-cart:hover {
    color: #ffffff;
    background-color: var(--distri-yellow);
    border-color: var(--distri-yellow);
}
.btn-custom {
    width: 99%;
    margin: 0 auto;
    display: block;
}
.btn-sm {
    font-size: 0.875rem;
    border-radius: 1rem;
}

.btn-info {
    color: #fff;
    background-color: #17a2b8;
    border-color: #17a2b8;
}

.btn-info i, .btn-warning i, .btn-primary i {
    margin-right: 0;
}
.dt-btn-outline {
    color: #000000;
    background-color: transparent;
    border-color: #6c757d;
}
.dt-btn-outline:hover {
    color: #000000;
    background-color: rgba(0, 0, 0, 0.2);
    border-color: #545b62;
}

.navbar .badge {
    font-size: 0.75rem;
    padding: 0.3em 0.5em;
}
.navbar {
    position: fixed;
    top: 40px;
    width: 100%;
    z-index: 1020;
    margin: 0;
    padding: 0;
}
.navbar-nav .nav-link:hover {
    color: rgb(14, 96, 151) !important;
    border-bottom: 2px solid rgb(14, 96, 151);
}
.navbar .dropdown-menu {
    min-width: 220px;
}

.navbar .nav-link {
    display: flex;
    align-items: center;
}
.navbar .nav-link i {
    margin-right: 5px;
}
.navbar-collapse.collapse {
    transition: height 0.3s ease;
}

.main-container {
    background-color: #ffffff;
    border-radius: 15px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

.base-container {
    margin: 20px auto;
    background-color: #f9f9f9;
    padding: 30px;
    border-radius: 10px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.container-alert {
    width: 98%;
    margin: 0 auto;
}
#alertContainer {
    position: fixed;
    bottom: 0;
    right: 0;
    z-index: 9999;
    transition: all 1s ease;
}
.top-bar {
    background: linear-gradient(90deg, rgba(24, 136, 211, 0.7), rgba(10, 71, 128, 0.7)), url("/static/images/v2/background_pb.ad655701e9f8.webp") center/cover;
    color: #fff;
    position: fixed;
    top: 0;
    height: 40px;
    width: 100%;
    z-index: 1050;
    font-size: 0.9rem;
    height: 40px;
    line-height: 40px;
    padding: 0;
    margin: 0;
    display: flex;
    align-items: center;
}

.bottom-bar {
    background-color: rgb(14, 96, 151);
    color: #fff;
    font-size: 0.9rem;
    height: 40px;
    line-height: 40px;
    padding: 0;
    margin: 0;
    display: flex;
    align-items: center;
}

.block-page-title {

    color: #1a6185;
    padding: 10px;
}
#advancedSearchContainer, #vitrageIframeContainer {
    padding: 20px;
    background-color: #f8f9fa;
    border-radius: 10px;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    margin-bottom: 20px;
}

.iframe-container {
    width: 100%;
    max-width: 250px;
    margin: 0 auto;
    position: relative;
    padding-bottom: 28%;
    height: 0;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

#vitrageIframe {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    height: 100%;
    border: none;
    border-radius: 10px;
}
.table {
    margin-top: 20px;
    background-color: #ffffff;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    overflow: hidden;
}

.table th {
    background-color: #f8f9fa;
    color: #333;

    font-weight: bold;
}

.table td {
    vertical-align: middle;

}

#vehicle-info {
    background-color: #e9ecef;
    padding: 20px;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    margin-bottom: 30px;
    margin-left: 0px;
    margin-right: 0px;
}

#vehicle-info h4 {
    margin-bottom: 10px;
    color: #343a40;
    font-weight: bold;
}
.hero-section h1 {
    font-family: 'Poppins', sans-serif;
    font-size: 2rem;
    font-weight: 700;
    color: #ffffffe1;
    text-shadow: 1px 1px 10px rgba(0, 0, 0, 0.3);
}

.hero-section p {
    font-family: 'Poppins', sans-serif;
    font-size: 1.25rem;
    color: #ffffffe1;
}

h2#typeRechercheTitle {
    margin-bottom: 20px;
    font-weight: bold;
    color: #343a40;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.1);
}
.form-label {
    font-weight: bold;
    margin-bottom: 8px;
    color: #555;
}
.dist-title {
    font-weight: 600;
}

.dist-description {
    color: #555;
    margin-bottom: 1rem;
}

.dist-image-wrapper {
    position: relative;
}

.dist-image {
    width: 20%;
    height: auto;
    border-radius: 8px;
    transition: opacity 0.3s ease;
}

.vehicle-image, .brand-image {
    max-width: 100%;
    border-radius: 8px;
    box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.2);
}
.img-thumbnail {
    max-width: 80px;
    height: auto;
    border-radius: 5px;
    margin: 0 auto;
    display: block;
}

#cart-preview .dropdown-item img {
    border-radius: 4px;
    border: 1px solid #ddd;
    width: 40px;
    height: 40px;
    object-fit: cover;
}
#cart-preview {
    min-width: 300px;
    max-width: 400px;
    left: auto !important;
    right: 0 !important;
    max-height: 400px;
    overflow-y: auto;
    padding: 10px;

}

.view-images {
    cursor: pointer;
}

.badge {
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
}

.badge-distri {
    --distri-badge-padding-x: 0.711111em;
    --distri-badge-padding-y: 0.355555em;
    --distri-badge-font-size: 0.875rem;
    --distri-badge-font-weight: 600;
    --distri-badge-border-radius: 0.25rem;
    display: inline-block;
    padding: var(--distri-badge-padding-y) var(--distri-badge-padding-x);
    font-size: var(--distri-badge-font-size);
    font-weight: var(--distri-badge-font-weight);
    line-height: 1;
    color: var(--distri-badge-color);
    border-radius: var(--distri-badge-border-radius);
    padding: 4px 8px;
    background-color: var(--distri-badge-bg);
    color: var(--distri-badge-color);
    border: 1px solid var(--distri-badge-border-color)
}

.badge-distri .badge-label {
    display: inline-block;
    -webkit-transform: translateY(0.0875rem);
    -ms-transform: translateY(0.0875rem);
    transform: translateY(0.0875rem)
}

.badge-distri[href]:hover,.badge-distri[href]:focus {
    text-decoration: none
}

.badge-distri-primary {
    --distri-badge-bg: var(--distri-primary-bg-subtle);
    --distri-badge-color: var(--distri-primary-text-emphasis);
    --distri-badge-border-color: var(--distri-primary-border-subtle);
}

.badge-distri-secondary {
    --distri-badge-bg: var(--distri-secondary-bg-subtle);
    --distri-badge-color: var(--distri-secondary-text-emphasis);
    --distri-badge-border-color: var(--distri-secondary-border-subtle)
}

.badge-distri-success {
    --distri-badge-bg: var(--distri-success-bg-subtle);
    --distri-badge-color: var(--distri-success-text-emphasis);
    --distri-badge-border-color: var(--distri-success-border-subtle)
}

.badge-distri-info {
    --distri-badge-bg: var(--distri-info-bg-subtle);
    --distri-badge-color: var(--distri-info-text-emphasis);
    --distri-badge-border-color: var(--distri-info-border-subtle)
}

.badge-distri-warning {
    --distri-badge-bg: var(--distri-warning-bg-subtle);
    --distri-badge-color: var(--distri-warning-text-emphasis);
    --distri-badge-border-color: var(--distri-warning-border-subtle)
}

.badge-distri-danger {
    --distri-badge-bg: var(--distri-danger-bg-subtle);
    --distri-badge-color: var(--distri-danger-text-emphasis);
    --distri-badge-border-color: var(--distri-danger-border-subtle)
}

.badge-distri-light {
    --distri-badge-bg: var(--distri-light-bg-subtle);
    --distri-badge-color: var(--distri-light-text-emphasis);
    --distri-badge-border-color: var(--distri-light-border-subtle)
}

.badge-distri-dark {
    --distri-badge-bg: var(--distri-dark-bg-subtle);
    --distri-badge-color: var(--distri-dark-text-emphasis);
    --distri-badge-border-color: var(--distri-dark-border-subtle)
}

.badge-distri-primary[href]:hover,.badge-distri-primary[href]:focus {
    color: #85a9ff
}

.badge-distri-success[href]:hover,.badge-distri-success[href]:focus {
    color: #90d67f
}

.badge-distri-info[href]:hover,.badge-distri-info[href]:focus {
    color: #60c6ff
}

.badge-distri-warning[href]:hover,.badge-distri-warning[href]:focus {
    color: #ffcc85
}

.badge-distri-danger[href]:hover,.badge-distri-danger[href]:focus {
    color: #f48270
}

.badge-distri-warning img {
    height: 10px
}

.badge-tag {
    background-color: var(--distri-secondary-bg);
    color: var(--distri-body-highlight-color);
    font-weight: 700;
    font-size: .64rem;
    padding: .25rem .5rem;
    text-transform: uppercase
}

.badge-tag:hover,.badge-tag:focus {
    background-color: var(--distri-tertiary-bg)
}

.modal-body .input-group-text {
    background-color: #f8f9fa;
    border-right: none;
}

.modal-body .form-control {
    border-left: none;
}

.alert-danger {
    border-radius: 0.5rem;
}

 .d-none {
    display: none;
}
th, td {
    padding: 8px;
}

.gap-2 {
    gap: .5rem !important;
}
#cart-badge {
    font-size: 0.75rem;
    padding: 0.2em 0.4em;
}
.slide-entering,.slide-exiting,.slide-exited {
    transform: translateY(100%);
    opacity: 0;
}
.slide-entered {
    transform: translateY(0);
    opacity: 1;
}

.position-relative .badge {
    font-size: 0.75rem;
    padding: 0.3em 0.5em;
    border-radius: 30%;
}

.input-group {
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
#advancedSearchButtons {
    margin-top: 20px;
}

 @media (max-width: 768px) {
    #alertContainer {
        position: fixed;
        bottom: 0;
        right: 0;
        z-index: 9999;
        transition: all 1s ease;
    }
    .card-body {
        text-align: center;
    }

    .view-images {
        max-width: 100px;
    }

    .d-grid.gap-2 {
        gap: 0.5rem;
    }
    #vitrageIframeContainer {
        padding-bottom: 350px;
    }
    #vitrageIframe {
        left: 0;
        transform: none;
    }

    .iframe-container {
        max-width: 100%;
    }

    #cart-preview {
        max-width: 90vw;
        left: 10px !important;
        right: auto !important;
    }

        .btn-overlay {
            opacity: 1;
            visibility: visible;

    }
}

:root
	{
    --distri-blue: #3874ff;
    --distri-indigo: #6610f2;
    --distri-purple: #6f42c1;
    --distri-pink: #d63384;
    --distri-red: #fa3b1d;
    --distri-orange: #e5780b;
    --distri-yellow: #ffc107;
    --distri-green: #25b003;
    --distri-teal: #20c997;
    --distri-cyan: #0097eb;
    --distri-black: #000000;
    --distri-white: #fff;
    --distri-gray: #6e7891;
    --distri-gray-dark: #141824;
    --distri-gray-50: #f5f7fa;
    --distri-gray-100: #eff2f6;
    --distri-gray-200: #e3e6ed;
    --distri-gray-300: #cbd0dd;
    --distri-gray-400: #9fa6bc;
    --distri-gray-500: #8a94ad;
    --distri-gray-600: #6e7891;
    --distri-gray-700: #525b75;
    --distri-gray-800: #3e465b;
    --distri-gray-900: #31374a;
    --distri-gray-1000: #222834;
    --distri-gray-1100: #141824;
    --distri-primary: #3874ff;
    --distri-secondary: #31374a;
    --distri-success: #25b003;
    --distri-info: #0097eb;
    --distri-warning: #e5780b;
    --distri-danger: #fa3b1d;
    --distri-light: #eff2f6;
    --distri-dark: #141824;
    --distri-primary-rgb: 56, 116, 255;
    --distri-secondary-rgb: 49, 55, 74;
    --distri-success-rgb: 37, 176, 3;
    --distri-info-rgb: 0, 151, 235;
    --distri-warning-rgb: 229, 120, 11;
    --distri-danger-rgb: 250, 59, 29;
    --distri-light-rgb: 239, 242, 246;
    --distri-dark-rgb: 20, 24, 36;
    --distri-primary-text-emphasis: #003cc7;
    --distri-secondary-text-emphasis: #525b75;
    --distri-success-text-emphasis: #1c6c09;
    --distri-info-text-emphasis: #005585;
    --distri-warning-text-emphasis: #bc3803;
    --distri-danger-text-emphasis: #b81800;
    --distri-light-text-emphasis: #141824;
    --distri-dark-text-emphasis: #fff;
    --distri-primary-bg-subtle: #e5edff;
    --distri-secondary-bg-subtle: #eff2f6;
    --distri-success-bg-subtle: #d9fbd0;
    --distri-info-bg-subtle: #c7ebff;
    --distri-warning-bg-subtle: #ffefca;
    --distri-danger-bg-subtle: #ffe0db;
    --distri-light-bg-subtle: #f7f9fb;
    --distri-dark-bg-subtle: #9fa6bc;
    --distri-primary-border-subtle: #85a9ff;
    --distri-secondary-border-subtle: #cbd0dd;
    --distri-success-border-subtle: #90d67f;
    --distri-info-border-subtle: #60c6ff;
    --distri-warning-border-subtle: #ffcc85;
    --distri-danger-border-subtle: #f48270;
    --distri-light-border-subtle: #eff2f6;
    --distri-dark-border-subtle: #8a94ad;
    --distri-white-rgb: 255, 255, 255;
    --distri-black-rgb: 0, 0, 0;
    --distri-font-sans-serif: "Nunito Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
    --distri-font-monospace: "SFMono-Regular", Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    --distri-gradient: linear-gradient(180deg, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0));
    --distri-body-font-family: var(--distri-font-sans-serif);
    --distri-body-font-size: 1rem;
    --distri-body-font-weight: 400;
    --distri-body-line-height: 1.49;
    --distri-body-color: #31374a;
    --distri-body-color-rgb: 49, 55, 74;
    --distri-body-bg: #f5f7fa;
    --distri-body-bg-rgb: 245, 247, 250;
    --distri-emphasis-color: #141824;
    --distri-emphasis-color-rgb: 20, 24, 36;
    --distri-secondary-color: #3e465b;
    --distri-secondary-color-rgb: 62, 70, 91;
    --distri-secondary-bg: #e3e6ed;
    --distri-secondary-bg-rgb: 227, 230, 237;
    --distri-tertiary-color: #525b75;
    --distri-tertiary-color-rgb: 82, 91, 117;
    --distri-tertiary-bg: #cbd0dd;
    --distri-tertiary-bg-rgb: 203, 208, 221;
    --distri-heading-color: var(--distri-emphasis-color);
    --distri-link-color: #3874ff;
    --distri-link-color-rgb: 56, 116, 255;
    --distri-link-decoration: none;
    --distri-link-hover-color: #003cc7;
    --distri-link-hover-color-rgb: 0, 60, 199;
    --distri-link-hover-decoration: underline;
    --distri-code-color: #d63384;
    --distri-highlight-color: #31374a;
    --distri-highlight-bg: #fff3cd;
    --distri-border-width: 1px;
    --distri-border-style: solid;
    --distri-border-color: #cbd0dd;
    --distri-border-color-translucent: rgba(203, 208, 221, 0.54);
    --distri-border-radius: 0.375rem;
    --distri-border-radius-sm: 0.25rem;
    --distri-border-radius-lg: 0.5rem;
    --distri-border-radius-xl: 1rem;
    --distri-border-radius-xxl: 2rem;
    --distri-border-radius-2xl: var(--distri-border-radius-xxl);
    --distri-border-radius-pill: 50rem;
    --distri-box-shadow: 0px 2px 4px -2px rgba(36, 40, 46, 0.08);
    --distri-box-shadow-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
    --distri-box-shadow-lg: 0 1rem 3rem rgba(0, 0, 0, 0.175);
    --distri-box-shadow-inset: inset 0 1px 2px rgba(0, 0, 0, 0.075);
    --distri-focus-ring-width: 0.25rem;
    --distri-focus-ring-opacity: 0.25;
    --distri-focus-ring-color: rgba(56, 116, 255, 0.25);
    --distri-form-valid-color: #25b003;
    --distri-form-valid-border-color: #25b003;
    --distri-form-invalid-color: #fa3b1d;
    --distri-form-invalid-border-color: #fa3b1d;
}
.solde-positive {
    color: green;
}

.solde-negative {
    color: red;
}

td.solde-column {
    color: green;
}

span.solde-positive {
    color: green;
}
span.solde-negative {
    color: red;
}
.bg-light-home {
    background-color: #E5E7EB;
}
.bg-success-menu {
    background-color: #22C55E;
}
.bg-warning-menu {
    background-color: #FB923C;
}
.bg-info-menu {
    background-color: #F87171;
}
.bg-primary-menu {
    background-color: #60A5FA;
}
.bg-secondary-menu {
    background-color: #6B7280;
}
.bg-warning2-menu {
    background-color: #EAB308;
}
.bg-secondary2-menu {
    background-color: #9CA3AF;
}
.bg-primary2-menu {
    background-color: #A855F7;
}
.bg-primary3-menu {
    background-color: #417690;
}
.bg-hs-menu {
    background-color: var(--distri-code-color);
}
.bg-prod-menu {
    background-color: var(--distri-teal);
}
.order-link {
    color: var(--distri-secondary-text-emphasis);
}
.delivery-link {
    color: var(--distri-info-text-emphasis);
}
.invoice-link {
    color: var(--distri-success-text-emphasis);
}

#dashboardCarousel .carousel-item {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    height: auto;
}

.carousel-image {
    width: 100%;
    height: auto;
    object-fit: contain;
    object-position: center;
    border-radius: 0.5rem;
    transition: transform 0.5s ease-in-out;

    max-height: 250px;
}

.carousel-item img:hover {
    transform: scale(1.03);
    transition: transform 0.4s ease-in-out;
}

.carousel-item.active .carousel-image {
    transform: scale(1.02);
}

.carousel-caption-custom {
    background: rgba(49, 49, 49, 0.6);

    padding: 0.75rem 1.5rem;
    border-radius: 0.5rem;
    display: inline-block;
    max-width: 70%;
    margin: auto;
    position: absolute;

    bottom: 10%;
    left: 50%;
    transform: translate(-50%, 0);
    text-align: center;
}

.carousel-item.active .carousel-caption-custom {
    animation: fadeInUp 0.5s ease-in-out;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translate(-50%, 20%);
    }
    to {
        opacity: 1;
        transform: translate(-50%, 0%);
    }
}

.carousel-title {

    font-size: 1.5rem;
    color: white;
    font-weight: 700;
}

.carousel-subtitle {

    font-size: 1rem;
    color: #f8f9fa;
}

.carousel-caption-custom a.btn {
    font-size: 1.1rem;
    font-weight: 600;
    padding: 0.75rem 1.5rem;
    border-radius: 30px;
    background-color: #ffc107;
    color: #212529;
    text-decoration: none;
}

.carousel-caption-custom a.btn:hover {
    background-color: #e0a800;
    color: white;
}

.carousel-background {
    background-color: #f8f9fa;
    padding: 20px;
    border-radius: 15px;
    margin-bottom: 30px;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
}

.carousel-control-prev-icon,
.carousel-control-next-icon {
    background-color: rgba(0, 0, 0, 0.5);
    border-radius: 50%;
    width: 40px;
    height: 40px;
    background-size: 60%;
}

.carousel-control-prev-icon:hover,
.carousel-control-next-icon:hover {
    background-color: rgba(0, 0, 0, 0.8);
}

.carousel-control-prev,
.carousel-control-next {
    opacity: 0.8;
    transition: opacity 0.3s ease;
}

.carousel-control-prev:hover,
.carousel-control-next:hover {
    opacity: 1;
}

@media (max-width: 768px) {
    .carousel-image {
        max-height: 300px;
    }

    .carousel-caption-custom {
        padding: 0.5rem 1rem;
    }

    .carousel-title {
        font-size: 1.4rem;
    }

    .carousel-subtitle {
        font-size: 1rem;
    }
}

@media (max-width: 576px) {
    .carousel-title {
        font-size: 1.2rem;
    }

    .carousel-subtitle {
        font-size: 0.9rem;
    }

    .carousel-caption-custom a.btn {
        padding: 0.5rem 1rem;
        font-size: 1rem;
    }
}

.carousel-caption-custom a.btn {
    font-size: 1rem;
    padding: 0.5rem 1rem;
}

.container-carousel-narrow {
    max-width: 1140px;
    margin: 0 auto;
}

.carousel-caption-custom {
    background: rgba(49, 49, 49, 0.4);
    padding: 0.75rem 1.5rem;
    border-radius: 10px;
    max-width: 65%;
    bottom: 10%;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
}
.carousel-title {
    font-size: 1.4rem;
}
.carousel-subtitle {
    font-size: 0.95rem;
    margin-top: 0.2rem;
}
.carousel-caption-custom a.btn {
    font-size: 0.9rem;
    padding: 0.5rem 1rem;
    border-radius: 25px;
}

.alert-container {
    max-width: 400px;
    width: auto;
    pointer-events: none;
}

.alert-container .alert {
    pointer-events: auto;
    min-width: 250px;
    opacity: 0.95;
    transition: opacity 0.5s ease;
}

.mini-cart-drawer {
    position: fixed;
    z-index: 1050;
    background: #fff;
    padding: 1rem;
    width: 100%;
    max-width: 350px;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    transition: transform 0.3s ease, opacity 0.3s ease;
    border-radius: 1rem 1rem 0 0;
}

@media (min-width: 768px) {
    .mini-cart-drawer {
        top: 1rem;
        right: 1rem;
        left: auto;
        bottom: auto;
        transform: none;
        border-radius: 0.5rem;
    }
}

.mini-cart-drawer.show {
    display: block !important;
    opacity: 1;
}

.mini-cart-drawer .mini-cart-content {
    display: flex;
    flex-direction: column;
}

@media (max-width: 991.98px) {

    .navbar-collapse {
        max-height: calc(100vh - 80px);
        overflow-y: auto;
        overflow-x: hidden;
        background: #fff;
        padding-bottom: 1rem;
    }

    .navbar-nav {
        width: 100%;
    }

    .nav-item {
        width: 100%;
    }

    .nav-link {
        width: 100%;
        padding: 0.75rem 1rem;
    }

    .dropdown-menu {
        position: static !important;
        transform: none !important;
        float: none;
        width: 100%;
        margin-top: 0;
        border: none;
        box-shadow: none;
        background: #f8f9fa;
    }

    .dropdown-item {
        padding-left: 1.5rem;
        white-space: normal;
    }
}
.choices {
    width: 100%;
}

.choices__inner {
    min-height: 38px !important;
    padding: 0.375rem 0.75rem !important;
    border-radius: 0.375rem !important;
    box-sizing: border-box !important;
}

.choices[data-type*="select-one"] .choices__inner {
    padding-bottom: 0.375rem !important;
}

.choices[data-type*="select-one"] .choices__input,
.choices[data-type*="select-one"] .choices__input--cloned {
    width: 100% !important;
    box-sizing: border-box !important;
    margin: 0 !important;
    padding: 6px 0 !important;
    border: 0 !important;
    background: transparent !important;
    text-indent: 0 !important;
    line-height: 1.5 !important;
    min-height: auto !important;
    left: 0 !important;
    position: relative !important;
}

.choices__list--dropdown,
.choices__list[aria-expanded] {
    box-sizing: border-box !important;
}

.choices__list--dropdown .choices__input--cloned,
.choices__list[aria-expanded] .choices__input--cloned {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 0 6px 0 !important;
    padding: 8px 12px !important;
    border: none !important;
    border-bottom: 1px solid #007bff !important;
    border-radius: 0 !important;
    background: #fff !important;
    text-indent: 0 !important;
    box-sizing: border-box !important;
}
.choices__item--selectable.is-highlighted {
    background-color: #007bff !important;
    color: #fff !important;
    border-radius: 4px;
}
.z-9999 {
    z-index: 9999;
}

:root {
    --dg-primary: #0A4780;
    --dg-primary-soft: #EAF3FB;
    --dg-primary-dark: #073761;
    --dg-accent: #FFC107;
    --dg-accent-dark: #E0A800;
    --dg-bg: #F6F8FB;
    --dg-surface: #FFFFFF;
    --dg-border: #E5EAF1;
    --dg-text: #172033;
    --dg-muted: #667085;
    --dg-radius: 18px;
    --dg-shadow-sm: 0 2px 10px rgba(16, 24, 40, 0.06);
    --dg-shadow-md: 0 10px 28px rgba(16, 24, 40, 0.10);
}

body.dg-body,
body {
    background-image: none !important;
    background-color: var(--dg-bg) !important;
    color: var(--dg-text);
    font-family: "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    padding-top: 96px;
}

.dg-container-wide {
    max-width: 1640px;
    margin-left: auto;
    margin-right: auto;
    padding-left: clamp(1rem, 2vw, 2rem);
    padding-right: clamp(1rem, 2vw, 2rem);
}

.dg-top-bar,
.top-bar {
    height: 34px;
    line-height: 34px;
    background: var(--dg-primary-dark) !important;
    font-size: 0.82rem;
    box-shadow: none;
}

.dg-top-bar .contact-info {
    opacity: .92;
}

.dg-navbar,
.navbar {
    top: 34px;
    min-height: 66px;
    padding: .35rem 0 !important;
    background: rgba(255,255,255,.96) !important;
    backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--dg-border);
}

.navbar-brand img {
    height: 46px !important;
}

.dg-navbar .nav-link,
.navbar .nav-link {
    color: var(--dg-text) !important;
    font-weight: 500;
    font-size: .92rem;
    border-radius: 999px;
    padding: .5rem .75rem !important;
    margin: 0 .08rem;
    border-bottom: 0 !important;
}

.dg-navbar .nav-link:hover,
.dg-navbar .nav-link:focus,
.navbar-nav .nav-link:hover {
    color: var(--dg-primary) !important;
    background: var(--dg-primary-soft);
    border-bottom: 0 !important;
    font-weight: 600;
}

.dg-nav-label {
    margin-left: .25rem;
}

#cart-badge {
    border-radius: 999px;
    transform: translateY(-1px);
}

.dg-hero,
.hero-section {
    background: linear-gradient(120deg, rgba(7,55,97,.96), rgba(10,71,128,.90)), url("/static/images/v2/background_pb.ad655701e9f8.webp") center/cover !important;
    border-bottom: 1px solid rgba(255,255,255,.18);
    margin-bottom: 1.25rem !important;
}

.dg-hero h1,
.hero-section h1 {
    font-size: clamp(1.45rem, 2vw, 2.15rem);
    letter-spacing: -0.03em;
    margin-bottom: .25rem;
    text-shadow: none;
}

.dg-hero p,
.hero-section p {
    font-size: 1rem;
    margin-bottom: .7rem;
    opacity: .92;
}

.dg-page-title-card {
    position: relative;
    border: 1px solid var(--dg-border) !important;
    border-radius: var(--dg-radius) !important;
    box-shadow: var(--dg-shadow-sm) !important;
    overflow: hidden;
}

.dg-page-title-card::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: linear-gradient(
        to bottom,
        #D62D2D 0%,
        #D62D2D 5%,
        #D62D2D 100%
    );
}

.dg-page-title-card .card-header {
    background: var(--dg-surface) !important;
    border-bottom: 0 !important;
    padding: 1rem 1.25rem 1rem 1.5rem !important;
}

.card,
.dist-card,
.main-container,
.base-container {
    border: 1px solid var(--dg-border) !important;
    border-radius: var(--dg-radius) !important;
    box-shadow: var(--dg-shadow-sm) !important;
    background: var(--dg-surface) !important;
}

.card:hover,
.dist-card:hover {
    box-shadow: var(--dg-shadow-md) !important;
    transform: translateY(-2px);
}

.table {
    border-radius: var(--dg-radius);
    box-shadow: var(--dg-shadow-sm);
    border: 1px solid var(--dg-border);
    margin-top: 1rem;
}

.table th {
    background: #F8FAFC !important;
    color: var(--dg-muted);
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .04em;
    border-bottom: 1px solid var(--dg-border);
}

.table td {
    border-color: #EEF2F6;
}

.form-control,
.form-select,
.input-group-text,
.choices__inner {
    border-color: var(--dg-border) !important;
    border-radius: 12px !important;
}

.input-group {
    box-shadow: none !important;
}

.input-group .form-control {
    border-top-left-radius: 12px !important;
    border-bottom-left-radius: 12px !important;
}

.input-group .btn {
    border-top-right-radius: 12px !important;
    border-bottom-right-radius: 12px !important;
}

.btn,
.btn-dt {
    border-radius: 999px !important;
    font-weight: 600;
    padding: .45rem .85rem;
}

.btn-primary {
    background-color: var(--dg-primary) !important;
    border-color: var(--dg-primary) !important;
}

.btn-primary:hover {
    background-color: var(--dg-primary-dark) !important;
    border-color: var(--dg-primary-dark) !important;
}

.btn-warning,
.btn-cart {
    background-color: var(--dg-accent) !important;
    border-color: var(--dg-accent) !important;
    color: #1f2937 !important;
}

.btn-warning:hover,
.btn-cart:hover {
    background-color: var(--dg-accent-dark) !important;
    border-color: var(--dg-accent-dark) !important;
    color: #111827 !important;
}

.products-section,
.engagements-section,
.brands-section {
    padding-top: 2.5rem !important;
    padding-bottom: 2.5rem !important;
}

.products-section h2,
.engagements-section h2,
.brands-section h2 {
    font-weight: 700;
    letter-spacing: -0.03em;
}

.carousel-background {
    border: 1px solid var(--dg-border);
    border-radius: var(--dg-radius);
    box-shadow: var(--dg-shadow-sm);
    background: var(--dg-surface);
}

.accordion-item,
.accordion-button {
    border-radius: var(--dg-radius) !important;
}

.bottom-bar {
    height: auto;
    min-height: 44px;
    line-height: 1.4;
    background: var(--dg-primary-dark) !important;
    padding: .75rem 0;
}

footer.bg-light {
    background: #FFFFFF !important;
    border-top: 1px solid var(--dg-border);
}

.mini-cart-drawer {
    border: 1px solid var(--dg-border) !important;
    border-radius: var(--dg-radius) !important;
    box-shadow: var(--dg-shadow-md) !important;
}

@media (max-width: 991.98px) {
    body.dg-body,
    body {
        padding-top: 98px;
    }

    .dg-top-bar,
    .top-bar {
        display: flex !important;
        height: 34px;
        line-height: 34px;
        font-size: .75rem;
        z-index: 1050;
    }

    .dg-navbar,
    .navbar {
        top: 34px;
        min-height: 64px;
    }

    .dg-top-bar .dg-container-wide {
        padding-left: .75rem !important;
        padding-right: .75rem !important;
    }
}

@media (max-width: 575.98px) {
    .dg-container-wide {
        padding-left: .85rem;
        padding-right: .85rem;
    }

    .btn,
    .btn-dt {
        padding: .42rem .7rem;
    }
}

:root {
    --container-max-width: 1800px;
}

.container,
.container-sm,
.container-md,
.container-lg,
.container-xl,
.container-xxl {
    max-width: var(--container-max-width);
}

.dg-container-wide {
    max-width: 1640px;
    margin-left: auto;
    margin-right: auto;
    padding-left: clamp(1rem, 2vw, 2rem);
    padding-right: clamp(1rem, 2vw, 2rem);
}

.dg-hero {
    margin-bottom: 1.25rem !important;
}

.dg-hero-home {
    min-height: 150px;
}

.dg-hero-dashboard {
    min-height: 110px;
}

.dg-hero-compact {
    min-height: 72px;
}

.dg-hero-compact h1 {
    font-size: 1.35rem;
    margin-bottom: 0.15rem;
}

.dg-hero-compact p {
    font-size: 0.9rem;
    margin-bottom: 0;
}

@media (max-width: 991.98px) {
    .dg-hero-home {
        display: block !important;
        padding-top: 1rem !important;
        padding-bottom: 1rem !important;
        margin-bottom: 1rem !important;
    }

    .dg-hero-home h1 {
        font-size: 1.35rem;
        margin-bottom: .25rem;
    }

    .dg-hero-home p {
        font-size: .9rem;
        margin-bottom: 0;
    }

    .dg-hero-dashboard,
    .dg-hero-compact {
        display: block !important;
        min-height: 60px;
        padding: .5rem 0 !important;
    }

    .dg-hero-compact h1 {
        font-size: 1.1rem;
        margin-bottom: 0;
    }

    .dg-hero-compact p {
        display: none;
    }
}

.product-disponibilite,
.prod-dispo-gamme {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .45rem .75rem;
    border-radius: 999px;
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .02em;
    border: 1px solid transparent;
}

.badge-distri-success.product-disponibilite {
    background: #ecfdf3;
    color: #027a48;
    border-color: #abefc6;
}

.badge-distri-danger.product-disponibilite {
    background: #fef3f2;
    color: #b42318;
    border-color: #fecdca;
}

.badge-distri-warning.product-disponibilite {
    background: #fffaeb;
    color: #b54708;
    border-color: #fedf89;
}

.prod-dispo-gamme {
    background: #eff8ff;
    color: #175cd3;
    border-color: #b2ddff;
}

.dg-badge-availability {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .45rem .75rem;
    border-radius: 999px;
    font-size: .78rem;
    font-weight: 800;
    border: 1px solid transparent;
}

.dg-badge-availability-success {
    background: #ecfdf3;
    color: #027a48;
    border-color: #abefc6;
}

.dg-badge-availability-danger {
    background: #fef3f2;
    color: #b42318;
    border-color: #fecdca;
}

@media (max-width: 767.98px) {

    .catalogue-mobile-offer {
        display: flex;
        flex-direction: column;
        gap: .5rem;
    }

    .catalogue-mobile-offer .choices,
    .catalogue-mobile-offer .catalogue-variation-select {
        width: 100%;
        margin: 0;
    }

    .catalogue-mobile-offer .choices__inner {
        min-height: 36px !important;
        padding: .25rem .75rem !important;
    }

    .catalogue-mobile-offer .d-flex.flex-wrap {
        display: flex !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: .35rem !important;
        margin-top: .35rem !important;
    }

    .catalogue-mobile-offer .catalogue-price-badge,
    .catalogue-mobile-offer .catalogue-stock-badge {
        margin: 0 !important;
        max-width: 100%;
        white-space: nowrap;
    }
}

.catalogue-secondary-actions {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .35rem;
}

.catalogue-secondary-actions .btn {
    width: 38px;
    height: 38px;
    padding: 0 !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.catalogue-cart-cell {
    white-space: nowrap;
}

.catalogue-cart-btn {
    min-height: 38px;
    padding: .4rem .85rem !important;
    min-width: 104px;
    font-size: .82rem;
}

.catalogue-cart-btn i {
    margin-right: .3rem !important;
}

@media (max-width: 768px) {
    .card-body {
        text-align: inherit;
    }
}

.dg-info-panel,
.ecom-info-panel {
    background: #f8fbff;
    border: 1px solid #dbeafe;
    border-radius: 1rem;
}

.dg-form-panel,
.ecom-form-panel {
    background: #ffffff;
    border: 1px solid #cfd8e3;
    border-radius: 1rem;
    box-shadow: 0 .35rem 1rem rgba(15, 23, 42, .05);
}

.dg-muted-panel,
.ecom-muted-panel {
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 1rem;
}

.form-control,
.form-select,
.choices__inner {
    background-color: #ffffff !important;
    border: 1.5px solid #d8e2ee !important;
}

.form-control:focus,
.form-select:focus,
.choices.is-focused .choices__inner {
    border-color: var(--dg-primary, #0A4780) !important;
    box-shadow: 0 0 0 .18rem rgba(10, 71, 128, .12) !important;
}

@media (max-width: 575.98px) {
    .dg-container-wide,
    .container,
    .container-fluid {
        padding-left: .75rem !important;
        padding-right: .75rem !important;
    }

    .main-container,
    .base-container {
        padding: .75rem !important;
        border-radius: 1.1rem !important;
    }

    .card {
        border-radius: 1.1rem !important;
    }

    .card-body {
        padding: 1rem !important;
    }

    .card-header {
        padding: 1rem !important;
    }

    .btn,
    .btn-dt {
        min-height: 42px;
    }
}

@media (max-width: 575.98px) {
    h1, .h1 {
        font-size: 1.65rem;
        line-height: 1.15;
    }

    h2, .h2 {
        font-size: 1.45rem;
        line-height: 1.18;
    }

    h3, .h3 {
        font-size: 1.25rem;
    }

    .lead {
        font-size: 1rem;
    }
}

@media (max-width: 575.98px) {
    .dg-page-title-card .card-header {
        gap: .75rem;
    }

    .dg-page-title-card h4,
    .dg-page-title-card h5 {
        font-size: 1.35rem;
        line-height: 1.15;
    }

    .dg-page-title-card .text-muted {
        font-size: .9rem;
    }
}

@media (max-width: 575.98px) {
    #scrollTopBtn {
        width: 46px;
        height: 46px;
        right: 18px;
        bottom: 18px;
        padding: 0 !important;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }
}

@media (max-width: 575.98px) {
    .catalogue-search-card .card-body {
        padding: 1.15rem !important;
    }

    .catalogue-title {
        font-size: 1.65rem;
        text-align: center;
    }

    .catalogue-search-card p {
        font-size: .95rem;
        text-align: center;
    }

    #toggleSearchBtn {
        width: 100%;
        margin-bottom: .75rem;
        white-space: normal;
        line-height: 1.25;
    }

    #searchInfoBtn {
        display: block;
        width: 100%;
        text-align: center;
        font-size: .92rem;
    }

    .catalogue-search-input .input-group-text {
        padding-left: .85rem;
        padding-right: .85rem;
    }
}

@media (max-width: 575.98px) {
    .catalogue-advanced-card .card-header,
    .catalogue-glass-card .card-header {
        background: #f8fbff !important;
        border-bottom: 1px solid #dbeafe !important;
    }

    .catalogue-step-badge {
        width: 2.35rem;
        height: 2.35rem;
        font-size: 1rem;
    }

    .catalogue-advanced-card h5,
    .catalogue-glass-card h5 {
        font-size: 1.2rem;
        line-height: 1.2;
    }
}

@media (max-width: 575.98px) {
    .dashboard-card {
        min-height: auto !important;
    }

    .dashboard-card .card-body {
        padding: 1.2rem !important;
    }

    .dashboard-card .icon-box {
        width: 58px !important;
        height: 58px !important;
        border-radius: 1rem !important;
        margin-bottom: .85rem !important;
    }

    .dashboard-card .icon-box i {
        font-size: 1.55rem !important;
    }

    .dashboard-card .card-title {
        font-size: 1.1rem !important;
        margin-bottom: .45rem !important;
    }

    .dashboard-card .card-text {
        font-size: .92rem !important;
    }
}

@media (max-width: 575.98px) {
    .catalogue-mobile-card {
        margin-bottom: 1rem !important;
    }

    .catalogue-mobile-card .card-body {
        padding: .9rem !important;
    }

    .catalogue-mobile-topline {
        gap: .75rem !important;
    }

    .catalogue-mobile-img-wrap {
        width: 78px !important;
    }

    .catalogue-mobile-img {
        width: 78px !important;
        height: 72px !important;
        border-radius: .8rem !important;
    }

    .catalogue-mobile-sku {
        font-size: 1rem !important;
    }

    .catalogue-mobile-title {
        font-size: .92rem !important;
        line-height: 1.25 !important;
        margin-top: .35rem !important;
    }

    .catalogue-mobile-offer {
        margin-top: .75rem !important;
        padding: .65rem !important;
    }

    .catalogue-mobile-actions {
        margin-top: .75rem !important;
        gap: .5rem !important;
    }

    .catalogue-mobile-actions .btn-cart {
        min-height: 40px !important;
    }
}

.btn {
    border-radius: 999px;
    font-weight: 700;
    transition: all .2s ease;
    box-shadow: none !important;
}

.btn-primary,
.btn-success,
.btn-info,
.btn-secondary,
.btn-outline-primary,
.btn-outline-success,
.btn-outline-info,
.btn-outline-secondary {
    background: #eef8ff !important;
    border: 1px solid #0d6efd !important;
    color: #064f9e !important;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-success:hover,
.btn-success:focus,
.btn-info:hover,
.btn-info:focus,
.btn-secondary:hover,
.btn-secondary:focus,
.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-success:hover,
.btn-outline-success:focus,
.btn-outline-info:hover,
.btn-outline-info:focus,
.btn-outline-secondary:hover,
.btn-outline-secondary:focus {
    background: #dff2ff !important;
    border-color: #0a58ca !important;
    color: #063f7a !important;
    transform: translateY(-1px);
}

.btn-warning,
.btn-cart {
    background: #fff4cc !important;
    border: 1px solid #ffc107 !important;
    color: #6b4b00 !important;
}

.btn-warning:hover,
.btn-warning:focus,
.btn-cart:hover,
.btn-cart:focus {
    background: #ffe8a3 !important;
    border-color: #ffb300 !important;
    color: #3d2b00 !important;
    transform: translateY(-1px);
}

.btn-danger,
.btn-outline-danger {
    background: #fff0f2 !important;
    border: 1px solid #dc3545 !important;
    color: #b02a37 !important;
}

.btn-danger:hover,
.btn-danger:focus,
.btn-outline-danger:hover,
.btn-outline-danger:focus {
    background: #ffe1e6 !important;
    border-color: #bb2d3b !important;
    color: #842029 !important;
    transform: translateY(-1px);
}

.btn:disabled,
.btn.disabled {
    opacity: .55;
    transform: none !important;
    cursor: not-allowed;
}

.card .btn-primary,
.card .btn-success,
.card .btn-info,
.card .btn-secondary,
.card .btn-warning,
.card .btn-danger,
.card .btn-dark,
.card .btn-light,
.card .btn-outline-primary,
.card .btn-outline-success,
.card .btn-outline-info,
.card .btn-outline-secondary,
.dashboard-card .btn-primary,
.dashboard-card .btn-success,
.dashboard-card .btn-info,
.dashboard-card .btn-secondary,
.dashboard-card .btn-warning,
.dashboard-card .btn-danger,
.dashboard-card .btn-dark,
.dashboard-card .btn-light,
.dashboard-card .btn-outline-primary,
.dashboard-card .btn-outline-success,
.dashboard-card .btn-outline-info,
.dashboard-card .btn-outline-warning,
.dashboard-card .btn-outline-danger,
.dashboard-card .btn-outline-dark,
.dashboard-card .btn-outline-light,
.dashboard-card .btn-outline-secondary {
    background: #eef8ff !important;
    border: 1px solid #0d6efd !important;
    color: #064f9e !important;
    box-shadow: none !important;
}

.card .btn-primary:hover,
.card .btn-success:hover,
.card .btn-info:hover,
.card .btn-secondary:hover,
.card .btn-warning:hover,
.card .btn-danger:hover,
.card .btn-dark:hover,
.card .btn-light:hover,
.card .btn-outline-primary:hover,
.card .btn-outline-success:hover,
.card .btn-outline-info:hover,
.card .btn-outline-warning:hover,
.card .btn-outline-danger:hover,
.card .btn-outline-dark:hover,
.card .btn-outline-light:hover,
.card .btn-outline-secondary:hover,
.dashboard-card .btn-primary:hover,
.dashboard-card .btn-success:hover,
.dashboard-card .btn-info:hover,
.dashboard-card .btn-warning:hover,
.dashboard-card .btn-danger:hover,
.dashboard-card .btn-dark:hover,
.dashboard-card .btn-light:hover,
.dashboard-card .btn-secondary:hover,
.dashboard-card .btn-outline-primary:hover,
.dashboard-card .btn-outline-success:hover,
.dashboard-card .btn-outline-info:hover,
.dashboard-card .btn-outline-warning:hover,
.dashboard-card .btn-outline-danger:hover,
.dashboard-card .btn-outline-dark:hover,
.dashboard-card .btn-outline-light:hover,
.dashboard-card .btn-outline-secondary:hover {
    background: #dff2ff !important;
    border-color: #0a58ca !important;
    color: #063f7a !important;
}

.badge {
    border-radius: 999px;
    font-weight: 700;
    padding: .4em .7em;
    border: 1px solid transparent;
}

.badge.bg-primary {
    background-color: var(--bs-primary-bg-subtle) !important;
    color: var(--bs-primary-text-emphasis) !important;
    border-color: rgba(var(--bs-primary-rgb), .25);
}

.badge.bg-success {
    background-color: var(--bs-success-bg-subtle) !important;
    color: var(--bs-success-text-emphasis) !important;
    border-color: rgba(var(--bs-success-rgb), .25);
}

.badge.bg-info {
    background-color: var(--bs-info-bg-subtle) !important;
    color: var(--bs-info-text-emphasis) !important;
    border-color: rgba(var(--bs-info-rgb), .25);
}

.badge.bg-warning {
    background-color: var(--bs-warning-bg-subtle) !important;
    color: var(--bs-warning-text-emphasis) !important;
    border-color: rgba(var(--bs-warning-rgb), .35);
}

.badge.bg-danger {
    background-color: var(--bs-danger-bg-subtle) !important;
    color: var(--bs-danger-text-emphasis) !important;
    border-color: rgba(var(--bs-danger-rgb), .25);
}

.badge.bg-secondary {
    background-color: var(--bs-secondary-bg-subtle) !important;
    color: var(--bs-secondary-text-emphasis) !important;
    border-color: rgba(var(--bs-secondary-rgb), .25);
}

.badge.bg-dark {
    background-color: var(--bs-dark-bg-subtle) !important;
    color: var(--bs-dark-text-emphasis) !important;
    border-color: rgba(var(--bs-dark-rgb), .25);
}

.badge.bg-light {
    background-color: var(--bs-light-bg-subtle) !important;
    color: var(--bs-light-text-emphasis) !important;
    border-color: rgba(var(--bs-dark-rgb), .12);
}

.soft-success {
    background-color: var(--bs-success-bg-subtle);
    color: var(--bs-success-text-emphasis);
    border: 1px solid rgba(var(--bs-success-rgb), .20);
}

.soft-primary {
    background-color: var(--bs-primary-bg-subtle);
    color: var(--bs-primary-text-emphasis);
    border: 1px solid rgba(var(--bs-primary-rgb), .20);
}

.soft-info {
    background-color: var(--bs-info-bg-subtle);
    color: var(--bs-info-text-emphasis);
    border: 1px solid rgba(var(--bs-info-rgb), .20);
}

.soft-warning {
    background-color: var(--bs-warning-bg-subtle);
    color: var(--bs-warning-text-emphasis);
    border: 1px solid rgba(var(--bs-warning-rgb), .25);
}

.soft-danger {
    background-color: var(--bs-danger-bg-subtle);
    color: var(--bs-danger-text-emphasis);
    border: 1px solid rgba(var(--bs-danger-rgb), .20);
}

.dg-link {
    color: var(--bs-primary);
    font-weight: 700;
    text-decoration: none;
    transition: all .15s ease;
}

.dg-link:hover {
    color: var(--bs-primary-text-emphasis);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.dg-link-pill {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .2rem .55rem;
    border-radius: 999px;
    background: var(--bs-primary-bg-subtle);
    color: var(--bs-primary-text-emphasis);
    text-decoration: none;
    font-weight: 700;
    border: 1px solid rgba(var(--bs-primary-rgb), .20);
    transition: all .15s ease;
}

.dg-link-pill:hover {
    background: var(--bs-primary);
    color: #fff;
}

.order-number-link {
    color: var(--dg-primary, #0d5a99);
    font-weight: 900;
    text-decoration: none;
}

.catalogue-v2-container {
    width: 100%;
    max-width: 1640px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
}

@media (max-width: 767.98px) {
    .catalogue-v2-container {
        padding-left: 0;
        padding-right: 0;
        margin-top: .75rem !important;
    }

    .catalogue-search-card,
    .catalogue-advanced-card,
    .catalogue-glass-card {
        border-radius: 1rem;
    }
}

.cart-qty-group {
    display: inline-flex;
    align-items: center;
    flex-wrap: nowrap;
}

.cart-qty-group .btn-minus,
.cart-qty-group .btn-plus {
    width: 2rem;
    height: 2rem;
    padding: 0 !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    border-radius: 999px !important;
}

.cart-qty-group .quantity-input {
    width: 2.75rem;
    min-width: 2.75rem;
    height: 2rem;
    padding: 0 .25rem;
    line-height: 2rem;
    border-radius: .75rem !important;
}

a.btn,
.btn-custom {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1.2;
}

.catalogue-mobile-secondary-actions .btn {
    min-height: 2.35rem;
    white-space: nowrap;
    padding-inline: .65rem !important;
    font-size: .82rem;
}

.product-tabs .nav-link,
.product-detail-tabs .nav-link,
#productTabs .nav-link {
    white-space: nowrap;
    overflow: visible;
    text-overflow: unset;
    min-height: 2.2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

@media (max-width: 575.98px) {
    .product-tabs .nav-link,
    .product-detail-tabs .nav-link,
    #productTabs .nav-link {
        font-size: .78rem;
        padding: .35rem .55rem;
    }

    .product-tab-count {
        min-width: 1.05rem;
        height: 1.05rem;
        font-size: .68rem;
    }
}
.dg-img-fallback {
    object-fit: contain !important;
    background: #fff;
}
.catalogue-product-image,
.catalogue-mobile-img,
.product-detail-image,
.product-related-img {
    object-fit: contain;
}

img.dg-img-fallback {
    object-fit: contain !important;
    background: #fff !important;
}

.colored-btn-success {
    background: var(--bs-success-bg-subtle) !important;
    color: var(--bs-success-text-emphasis) !important;
    border: 1px solid rgba(var(--bs-success-rgb), .20) !important;
}

.colored-btn-info {
    background: var(--bs-info-bg-subtle) !important;
    color: var(--bs-info-text-emphasis) !important;
    border: 1px solid rgba(var(--bs-info-rgb), .20) !important;
}

.colored-btn-primary {
    background: var(--bs-primary-bg-subtle) !important;
    color: var(--bs-primary-text-emphasis) !important;
    border: 1px solid rgba(var(--bs-primary-rgb), .20) !important;
}

.colored-btn-warning {
    background: var(--bs-warning-bg-subtle) !important;
    color: var(--bs-warning-text-emphasis) !important;
    border: 1px solid rgba(var(--bs-warning-rgb), .20) !important;
}

.colored-btn-secondary {
    background: var(--bs-secondary-bg-subtle) !important;
    color: var(--bs-secondary-text-emphasis) !important;
    border: 1px solid rgba(var(--bs-secondary-rgb), .20) !important;
}

.colored-btn-danger {
    background: var(--bs-danger-bg-subtle) !important;
    color: var(--bs-danger-text-emphasis) !important;
    border: 1px solid rgba(var(--bs-danger-rgb), .20) !important;
}

.colored-btn-light {
    background: #eef8ff;
    color: #0A4780;
    border-color: rgba(10,71,128,.15);
}

.colored-btn-dark {
    background: #d9f5ff !important;
    color: #087990 !important;
    border: 1px solid rgba(13,202,240,.20) !important;
}

.dashboard-card:hover .colored {
    transform: translateY(-2px);
}

.dashboard-card:hover .colored-btn-success,
.dashboard-card:hover .colored-btn-info,
.dashboard-card:hover .colored-btn-primary,
.dashboard-card:hover .colored-btn-warning,
.dashboard-card:hover .colored-btn-secondary,
.dashboard-card:hover .colored-btn-danger,
.dashboard-card:hover .colored-btn-light,
.dashboard-card:hover .colored-btn-dark {
    filter: brightness(.90);
}

.hero-dashboard-link {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    padding: .35rem .85rem;
    border-radius: 999px;
    color: #fff;

    margin-top: .55rem;
    margin-bottom: .25rem;
    font-size: .9rem;
    font-weight: 600;
    text-decoration: none;
    background: rgba(255, 255, 255, .14);
    border: 1px solid rgba(255, 255, 255, .35);
    backdrop-filter: blur(6px);
    transition: all .18s ease-in-out;
}

.hero-dashboard-link:hover {
    color: #fff;
    background: rgba(255, 255, 255, .22);
    border-color: rgba(255, 255, 255, .55);
    transform: translateY(-1px);
}

.dashboard-alert {
    padding: .85rem 3rem .85rem 1rem;
    border-radius: .9rem;
    font-size: .95rem;
}

.dashboard-alert p {
    margin-bottom: .35rem;
}

.dashboard-alert p:last-of-type {
    margin-bottom: 0;
}

.dashboard-alert strong {
    font-weight: 700;
}

.dashboard-alert br {
    display: none;
}

@media (max-width: 767.98px) {

    .dg-hero-compact {
        padding-bottom: .65rem !important;
    }
}

@media (max-width: 767.98px) {
    .catalogue-mobile-secondary-actions {
        display: flex !important;
        width: 100%;
        gap: 0 !important;
    }

    .catalogue-mobile-secondary-actions .btn {
        flex: 1 1 0;
        border-radius: 999px !important;
        min-height: 40px;
    }

    .catalogue-mobile-secondary-actions .btn:only-child,
    .catalogue-mobile-secondary-actions:has(.btn:only-child) .btn {
        border-radius: 999px !important;
        width: 100%;
    }

    .catalogue-mobile-secondary-actions .btn:not(:only-child):first-child {
        border-top-right-radius: .75rem !important;
        border-bottom-right-radius: .75rem !important;
    }

    .catalogue-mobile-secondary-actions .btn:not(:only-child):last-child {
        border-top-left-radius: .75rem !important;
        border-bottom-left-radius: .75rem !important;
    }
}

.cart-qty-group {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    flex-wrap: nowrap;
    width: auto !important;
    max-width: none !important;
    background: #f8fbff;
    border: 1px solid rgba(13, 110, 253, .18);
    border-radius: 999px !important;
    padding: .2rem;
    gap: .25rem;
    box-shadow: none !important;
}

.cart-qty-group .btn-minus,
.cart-qty-group .btn-plus {
    width: 2.15rem;
    height: 2.15rem;
    min-height: 2.15rem;
    border-radius: 999px !important;
    padding: 0 !important;
    font-weight: 900;
    background: #eef8ff !important;
    border: 1px solid #0d6efd !important;
    color: #064f9e !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.cart-qty-group .quantity-input {
    width: 2.6rem !important;
    min-width: 2.6rem;
    max-width: 2.6rem !important;
    height: 2.15rem;
    min-height: 2.15rem;
    border: 0 !important;
    background: transparent !important;
    font-weight: 800;
    padding: 0 !important;
    box-shadow: none !important;
    text-align: center;
}

.cart-form[data-action-type="remove-item"] .btn-danger,
.catalogue-cart-table .btn-danger {
    width: 2.4rem;
    height: 2.4rem;
    min-height: 2.4rem;
    padding: 0 !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px !important;
}

.cart-form[data-action-type="remove-item"] .btn-danger i,
.catalogue-cart-table .btn-danger i {
    margin: 0 !important;
}

.cart-form[data-action-type="remove-item"] .btn-danger {
    background: #fff0f2 !important;
    border: 1px solid #dc3545 !important;
    color: #b02a37 !important;
}

.cart-form[data-action-type="remove-item"] .btn-danger:hover,
.cart-form[data-action-type="remove-item"] .btn-danger:focus {
    background: #ffe1e6 !important;
    border-color: #bb2d3b !important;
    color: #842029 !important;
}

#dashboardCarousel .carousel-caption-custom {
    position: absolute;
    left: 50%;
    bottom: .9rem;
    transform: translateX(-50%);
    width: auto;
    min-width: 230px;
    max-width: min(420px, 82%);
    background: rgba(255, 255, 255, .92);
    color: #172033;
    border: 1px solid rgba(15, 23, 42, .08);
    box-shadow: 0 .5rem 1.25rem rgba(15, 23, 42, .12);
    backdrop-filter: blur(8px);
    border-radius: 999px;
    padding: .45rem .65rem .45rem .9rem;

    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    text-align: left;
}

#dashboardCarousel .carousel-title {
    font-size: .9rem;
    font-weight: 900;
    color: #172033;
    margin: 0;
    line-height: 1.15;
}

#dashboardCarousel .carousel-subtitle {
    display: none;
}

#dashboardCarousel .carousel-cta {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 30px;
    padding: .3rem .7rem;
    border-radius: 999px;
    background: #fff4cc;
    border: 1px solid #ffc107;
    color: #6b4b00;
    font-size: .76rem;
    font-weight: 900;
    line-height: 1.1;
    text-decoration: none;
    white-space: nowrap;
}

@media (max-width: 767.98px) {
    #dashboardCarousel .carousel-caption-custom {
        bottom: .75rem;
        min-width: 0;
        width: calc(100% - 2rem);
        max-width: calc(100% - 2rem);
        border-radius: 1rem;
        padding: .55rem .65rem;
        gap: .5rem;
    }

    #dashboardCarousel .carousel-title {
        font-size: .82rem;
    }

    #dashboardCarousel .carousel-cta {
        font-size: .72rem;
        padding: .28rem .55rem;
        white-space: normal;
        text-align: center;
    }
}

.dg-carousel-wrap {
    max-width: 980px;
}

@media (max-width: 991.98px) {
    .dg-carousel-wrap {
        max-width: 100%;
    }
}

.carousel-image {
    max-height: 280px;
}

.carousel-slide-card {
    max-width: 340px;
}

.mobile-nav-icon {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    margin-right: .2rem;
    border-radius: 999px;
    text-decoration: none;
    color: var(--dg-primary);
    background: #eef8ff;
    border: 1px solid rgba(13,110,253,.15);
}

.mobile-nav-icon i {
    font-size: 1.05rem;
}

.mobile-cart-badge {
    position: absolute;
    top: -3px;
    right: -3px;
    font-size: .60rem;
    min-width: 16px;
    height: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}

@media (max-width: 380px) {
    .navbar-brand img {
        height: 35px !important;
    }
}

@media (max-width: 991.98px) {
    .dg-navbar {
        background: #e2e8ef !important;
        box-shadow: 0 4px 12px rgba(13,110,253,.08);
    }
}

.dg-profile-toggle {
    gap: .45rem;
    padding: .35rem .75rem !important;
    border-radius: 999px;
    background: rgba(13, 110, 253, .08);
    border: 1px solid rgba(13, 110, 253, .10);
}

.dg-profile-toggle:hover,
.dg-profile-toggle:focus {
    background: rgba(13, 110, 253, .13);
}

.dg-profile-avatar,
.dg-profile-header-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: #e8f2ff;
    color: #0d6efd;
    flex: 0 0 auto;
}

.dg-profile-avatar {
    width: 1.7rem;
    height: 1.7rem;
    font-size: .95rem;
}

.dg-profile-header-avatar {
    width: 2.4rem;
    height: 2.4rem;
    font-size: 1.2rem;
}

.dg-profile-name {
    max-width: 180px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-weight: 600;
}

.dg-profile-dropdown {
    width: 310px;
    padding: .65rem;
    border: 0;
    border-radius: 1rem;
    box-shadow: 0 1rem 2.5rem rgba(15, 23, 42, .16);
}

.dg-profile-header {
    padding: .65rem .65rem .8rem;
}

.dg-profile-header-name {
    font-weight: 600;
    color: #111827;
    line-height: 1.15;
}

.dg-profile-header-username {
    font-size: .8rem;
    color: #6b7280;
}

.dg-profile-credit-card {
    display: flex;
    align-items: center;
    gap: .45rem;
    padding: .55rem .7rem;
    border-radius: .85rem;
    background: #d7f1ff;
    color: #005b89;
    font-size: .85rem;
    font-weight: 700;
}

.dg-profile-item {
    display: flex;
    align-items: center;
    gap: .6rem;
    padding: .65rem .7rem;
    border-radius: .75rem;
    font-weight: 600;
}

.dg-profile-item:hover {
    background: #f1f7ff;
}

.dg-profile-logout {
    color: #dc3545;
}

.dg-profile-logout:hover {
    background: #fff5f5;
}

.dg-profile-login {
    color: var(--dg-primary, #0d5a99);
}

@media (max-width: 991.98px) {

    .dg-profile-name {
        display: none !important;
    }

    .dg-profile-toggle {
        padding: .35rem .55rem !important;
        min-width: auto;
    }

    .dg-profile-avatar {
        margin-right: 0;
    }

    .dg-profile-dropdown {
        width: 280px;
        min-width: 280px;
        max-width: calc(100vw - 20px);

        border-radius: .85rem;
        margin-top: .35rem;

        box-shadow: 0 .75rem 2rem rgba(15, 23, 42, .12);
    }
}

.floating-badge-container {
    position: fixed;
    right: 0;
    top: 45%;
    z-index: 1050;

    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: flex-end;
}

.dg-floating-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;

    padding: .4rem .6rem;

    writing-mode: vertical-rl;
    transform: rotate(180deg);

    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .05em;

    color: #fff;
    text-decoration: none;

    border-radius: .5rem 0 0 .5rem;
    box-shadow: 0 4px 12px rgba(0,0,0,.15);
}

.dg-floating-badge-preprod {
    background: #f0ad4e;
}

.dg-floating-badge-dat {
    background: #6c757d;
}

.dg-floating-badge-success {
    background: #198754;
}

.dg-floating-badge-danger {
    background: #dc3545;
}

@media (max-width: 575.98px) {
    #glassDatAccordion .accordion-button {
        padding-top: .75rem !important;
        padding-bottom: .75rem !important;
        min-height: 52px;
    }

    .dat-mobile-title {
        font-size: .78rem;
        max-width: calc(100% - 72px);
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .dat-mobile-credits {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex: 0 0 auto;
        min-width: 58px;
        padding: .35rem .6rem;
        border-radius: 999px;
        background: #d7f1ff;
        color: #005b89;
        font-size: .82rem;
        font-weight: 900;
        white-space: nowrap;
    }
}
.dg-page-icon {
    width: 36px;
    height: 36px;
    min-width: 36px;
    border-radius: 10px;
    background: rgba(13, 110, 253, 0.08);
    color: var(--bs-primary);

    display: flex;
    align-items: center;
    justify-content: center;

    margin-right: .75rem;
    font-size: .95rem;
}

@media (max-width: 767.98px) {

    .dg-page-title-card .card-header {
        padding-top: .85rem !important;
        padding-bottom: .85rem !important;
    }

    .dg-page-icon {
        width: 32px;
        height: 32px;
        min-width: 32px;
        margin-right: .6rem;
        font-size: .85rem;
    }

    .dg-page-title-card h5 {
        font-size: 1.15rem;
    }

    .dg-back-link {
        font-size: .9rem;
    }
}

.dg-link {
    color: #0b3d7a;
    text-decoration: none;
    font-weight: 500;
    transition: color .15s ease-in-out;
}

.dg-link:hover,
.dg-link:focus {
    color: #0d6efd;
    text-decoration: none;
}

.dg-link-muted {
    color: #475467;
    text-decoration: none;
    transition: color .15s ease-in-out;
}

.dg-link-muted:hover,
.dg-link-muted:focus {
    color: #0d6efd;
    text-decoration: none;
}

.dg-link-danger {
    color: #dc3545;
    text-decoration: none;
}

.dg-link-danger:hover,
.dg-link-danger:focus {
    color: #bb2d3b;
}

.dg-link-success {
    color: #198754;
    text-decoration: none;
}

.dg-link-success:hover,
.dg-link-success:focus {
    color: #157347;
}

.dg-card {
    border: 0;
    border-radius: 1.15rem;
    box-shadow: 0 .75rem 1.75rem rgba(15,23,42,.07);
    background: #fff;
}

.dg-card-hover {
    transition: transform .18s ease,
                box-shadow .18s ease;
}

.dg-card-hover:hover {
    transform: translateY(-3px);
    box-shadow: 0 1rem 2rem rgba(15,23,42,.10);
}

.dg-icon-box {
    width: 52px;
    height: 52px;
    display: flex;
    align-items: center;
    justify-content: center;

    border-radius: 1rem;

    background: #eef8ff;
    border: 1px solid rgba(13,110,253,.15);

    color: #0d6efd;
}

.dg-icon-box i {
    font-size: 1.55rem;
    line-height: 1;
}

.dg-section-title {
    font-weight: 800;
    letter-spacing: -.02em;
}

.dg-muted {
    color: #667085;
}

.dg-pill {
    border-radius: 999px;
}

.dg-badge-soft-primary {
    background: #eef8ff;
    color: #0d6efd;
    border: 1px solid rgba(13,110,253,.15);
}

.dg-badge-soft-success {
    background: #e8f8ef;
    color: #198754;
}

.dg-badge-soft-warning {
    background: #fff7e6;
    color: #b7791f;
}

.dg-badge-soft-danger {
    background: #fdecec;
    color: #dc3545;
}

.dg-hero {
    position: relative;
    overflow: hidden;

    border-radius: 1.35rem;

    background:
        linear-gradient(
            135deg,
            #0d6efd 0%,
            #0b2f63 58%,
            #dc3545 100%
        );

    color: #fff;

    box-shadow:
        0 1rem 2.5rem rgba(13,110,253,.18);
}

.dg-hero::before {
    content: "";
    position: absolute;
    inset: 0;

    background:
        radial-gradient(
            circle at top right,
            rgba(255,255,255,.22),
            transparent 36%
        ),
        radial-gradient(
            circle at bottom left,
            rgba(255,255,255,.12),
            transparent 42%
        );

    pointer-events: none;
}

.dg-hero > * {
    position: relative;
    z-index: 1;
}

.dg-hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .45rem;

    padding: .35rem .75rem;

    border-radius: 999px;

    background: rgba(255,255,255,.14);
    border: 1px solid rgba(255,255,255,.25);

    font-size: .85rem;
    font-weight: 700;
}

@media (max-width: 767.98px) {

    .dg-hero {
        border-radius: 1rem;
    }

    .dg-card {
        border-radius: 1rem;
    }

    .dg-icon-box {
        width: 48px;
        height: 48px;
    }

    .dg-icon-box i {
        font-size: 1.35rem;
    }
}

.dg-page-header-v2 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;

    border-left: 4px solid #dc3545;
    border-radius: 1.15rem;

    padding: 1rem 1rem;

    box-shadow: 0 .75rem 1.75rem rgba(15, 23, 42, .06);
}

.dg-page-title {
    font-weight: 600;
    color: #172033;
}

.dg-page-subtitle {
    color: #667085;
    font-size: .92rem;
    margin-top: .15rem;
}

.dg-back-link {
    color: #667085;
    font-weight: 600;
    white-space: nowrap;
    text-decoration: none;
}

.dg-back-link:hover {
    color: #0d6efd;
}

@media (max-width: 767.98px) {
    .dg-page-header-v2 {
        padding: .85rem 1rem;
        border-radius: 1rem;
        align-items: flex-start;
    }

    .dg-page-title {
        font-size: 1rem;
    }

    .dg-page-subtitle {
        font-size: .82rem;
    }

    .dg-back-link {
        font-size: .85rem;
    }
}

.dg-global-hero {
    margin: 0 0 1.25rem;
    padding: .85rem 1rem;
    min-height: 72px;

    display: flex;
    align-items: center;
    justify-content: center;

    background: var(--dg-primary, #0A4780);
    background-image: inherit;
    border-radius: 0;

    box-shadow: 0 .35rem 1rem rgba(15, 23, 42, .08);
}

.dg-global-hero h1 {
    margin: 0;
    font-size: 1.75rem;
    font-weight: 800;
    line-height: 1.15;
}

.dg-global-hero p {
    margin: .2rem 0 0;
    font-size: .95rem;
    opacity: .92;
}

@media (max-width: 767.98px) {
    .dg-global-hero {
        min-height: 58px;
        padding: .65rem .75rem;
    }

    .dg-global-hero h1 {
        font-size: 1.25rem;
    }

    .dg-global-hero p {
        font-size: .8rem;
    }
}

.dg-support-hero {
    display: none !important;
}

.dg-page-title {
    font-size: 1.35rem;
    font-weight: 500;
    line-height: 1.2;
    color: #1f2d3d;
}

.dg-page-subtitle {
    margin-top: .15rem;
    color: #6c757d;
    font-size: .85rem;
}

@media (max-width: 768px) {
    .dg-page-title {
        font-size: 1.25rem;
    }

    .dg-page-subtitle {
        font-size: .85rem;
    }
}

#cart-preview .dropdown-item:active,
#cart-preview .dropdown-item.active,
#cart-preview .dropdown-item:focus {
    background-color: #fff !important;
    color: inherit !important;
}

#cart-preview .btn:focus,
#cart-preview .btn:active {
    box-shadow: none !important;
}

#cart-preview a:focus,
#cart-preview a:active {
    background-color: transparent !important;
    color: inherit !important;
}

/* ==========================================================
   UX V2 - Polish input-group catalogue + login
   ========================================================== */

/* Bouton recherche dans les input-group */
.input-group .btn[type="submit"],
.catalogue-search-card .input-group .btn,
.catalogue-quick-search-card .input-group .btn {
    border-radius: 999px !important;
    min-width: 150px;
    margin-left: .45rem;
    background: #eef8ff !important;
    border: 1px solid #0d6efd !important;
    color: #064f9e !important;
    font-weight: 800;
}

.input-group .btn[type="submit"]:hover,
.catalogue-search-card .input-group .btn:hover,
.catalogue-quick-search-card .input-group .btn:hover {
    background: #dff2ff !important;
    color: #063f7a !important;
    transform: translateY(-1px);
}

/* Champ avant bouton : arrondi complet */
.input-group .form-control:has(+ .btn[type="submit"]),
.catalogue-search-card .input-group .form-control,
.catalogue-quick-search-card .input-group .form-control {
    border-top-right-radius: 12px !important;
    border-bottom-right-radius: 12px !important;
}

/* Bouton œil login */
#toggle-password {
    min-width: 44px;
    border-radius: 999px !important;
    margin-left: .35rem;
    background: #eef8ff !important;
    border: 1px solid #d8e2ee !important;
    color: #064f9e !important;
}

#toggle-password:hover,
#toggle-password:focus {
    background: #dff2ff !important;
    border-color: #0d6efd !important;
    color: #063f7a !important;
    transform: none;
}

/* ==========================================================
   UX V2 - Mobile polish recherche + login
   ========================================================== */

@media (max-width: 575.98px) {

    /* Recherche rapide : bouton plus compact */
    .catalogue-search-card .input-group .btn,
    .catalogue-quick-search-card .input-group .btn {
        min-width: 84px;
        margin-left: .35rem;
        padding-inline: .7rem !important;
        font-size: .82rem;
    }

    /* Si tu gardes "Rechercher", éviter qu'il prenne trop de place */
    .catalogue-search-card .input-group .btn[type="submit"],
    .catalogue-quick-search-card .input-group .btn[type="submit"] {
        white-space: nowrap;
    }

    /* Icône recherche plus compacte */
    .catalogue-search-card .input-group-text,
    .catalogue-quick-search-card .input-group-text {
        padding-left: .75rem;
        padding-right: .75rem;
    }

    /* Champ mobile plus équilibré */
    .catalogue-search-card .form-control,
    .catalogue-quick-search-card .form-control {
        font-size: .92rem;
        min-width: 0;
    }

    /* Bouton œil login plus discret sur mobile */
    #toggle-password {
        min-width: 38px;
        width: 38px;
        height: 38px;
        min-height: 38px;
        padding: 0 !important;
        margin-left: .3rem;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    #toggle-password i {
        font-size: .85rem;
        margin: 0 !important;
    }
}

/* ==========================================================
   UX V2 - Alertes session + badge flottant
   ========================================================== */

.floating-badge-container-alerts {
    left: 0;
    right: auto;
    top: 52%;
    align-items: flex-start;
}

.dg-floating-badge-alert {
    background: #0A4780;
    border: 0;
    cursor: pointer;
}

.dg-floating-badge-alert:hover {
    background: #073761;
}

.dg-alerts-modal {
    border: 0;
    border-radius: 1.25rem;
    box-shadow: 0 1rem 3rem rgba(15, 23, 42, .22);
}

.dg-alerts-modal .dashboard-alert {
    border-radius: 1rem;
    padding: 1rem 1.15rem;
}

@media (max-width: 575.98px) {
    .floating-badge-container-alerts {
        top: 58%;
    }

    .dg-floating-badge-alert {
        font-size: .68rem;
        padding: .35rem .5rem;
    }
}

.dg-alert-card {
    background: #fff8e8;
    border: 1px solid #ffe29a;
    border-radius: 1rem;
    padding: .85rem 1rem;
}

.dg-alert-card-warning {
    background: linear-gradient(
        180deg,
        #fffdf5 0%,
        #fff8e6 100%
    );
}

.dg-alert-title {
    font-weight: 700;
    color: #8a6500;
    margin-bottom: .5rem;
}

.dg-alert-message {
    color: #5c4a16;
    line-height: 1.6;
}

.dg-alerts-modal .modal-content {
    border: 0;
    border-radius: 1.25rem;
    box-shadow: 0 1rem 3rem rgba(15,23,42,.18);
}
.dg-alerts-modal-minimal {
    border: 0;
    background: transparent;
    box-shadow: none;
}

.dg-alerts-modal-minimal .modal-body {
    background: transparent;
}

.dg-alert-close {
    position: absolute;
    top: .85rem;
    right: .85rem;
    z-index: 2;
}

.dg-alert-card {
    box-shadow: 0 1rem 2.5rem rgba(15, 23, 42, .18);
}

.dg-alerts-modal-minimal .modal-dialog {
    max-width: 520px;
}

@media (max-width: 575.98px) {
    .dg-alerts-modal-minimal .modal-dialog {
        margin: 1rem;
    }

    .dg-alert-card {
        font-size: .9rem;
    }
}

/* INFO */
.dg-alert-card-info {
    background: linear-gradient(
        180deg,
        #f4faff 0%,
        #eef8ff 100%
    );
    border: 1px solid #b7d7ff;
}

.dg-alert-card-info .dg-alert-title {
    color: #0A4780;
}

/* WARNING */
.dg-alert-card-warning {
    background: linear-gradient(
        180deg,
        #fffdf5 0%,
        #fff8e6 100%
    );
    border: 1px solid #ffe29a;
}

.dg-alert-card-warning .dg-alert-title {
    color: #8a6500;
}

/* SUCCESS */
.dg-alert-card-success {
    background: linear-gradient(
        180deg,
        #f7fff8 0%,
        #effcf2 100%
    );
    border: 1px solid #b8e6c1;
}

.dg-alert-card-success .dg-alert-title {
    color: #146c43;
}

/* DANGER */
.dg-alert-card-danger {
    background: linear-gradient(
        180deg,
        #fff7f7 0%,
        #fff1f1 100%
    );
    border: 1px solid #ffbcbc;
}

.dg-alert-card-danger .dg-alert-title {
    color: #b02a37;
}