﻿/* ===================================================================
   DSB Design System — Global Component Styles
   ===================================================================
   Reusable components shared across all pages in the DSB platform.
   Loaded globally via _Layout.cshtml (after theme-defaults.css).
   All rules use the dsb- prefix to avoid conflicts with legacy styles.

   Based on the DSB Design Guide (docs/design-guide.html).
   Components: Buttons, Plate Input, VIN Input, Country Dropdown,
               Pills, Alerts, Tables, Pager, Tabs, Cards, Navigation.
   =================================================================== */

/* ===== Design system variables (non-theme) ===== */
:root {
    --dsb-text-color:        #1D2D49;
    --dsb-text-muted:        #6b6b6b;
    --dsb-text-light:        #9aa0a8;
    --dsb-border-color:      #d6dae0;
    --dsb-border-light:      #e6e9ee;
    --dsb-placeholder-color: #b3b8c2;
    --dsb-bg-subtle:         #eef1f5;
    --dsb-bg-page:           #f5f7fa;
    --dsb-link-color:        #2D6BC4;
    --dsb-radius:            6px;
    --dsb-radius-lg:         8px;

    /* Alert palette */
    --dsb-alert-success-text:   #328559;
    --dsb-alert-success-bg:     #dff2e3;
    --dsb-alert-success-border: #a8d9b8;
    --dsb-alert-warning-text:   #9c7d22;
    --dsb-alert-warning-bg:     #f8f4df;
    --dsb-alert-warning-border: #e7dca9;
    --dsb-alert-danger-text:    #934041;
    --dsb-alert-danger-bg:      #f8ecec;
    --dsb-alert-danger-border:  #dcb4b4;
    --dsb-alert-info-text:      #2c5f8a;
    --dsb-alert-info-bg:        #e6f0fb;
    --dsb-alert-info-border:    #a8c8ef;

    /* Pill palette */
    --dsb-pill-searching-text: #4a7bbf;
    --dsb-pill-searching-bg:   #e6eff9;
    --dsb-pill-updated-text:   #2e8a4f;
    --dsb-pill-updated-bg:     #dff2e3;

    /* Table action button */
    --dsb-table-action:      #376DA4;
    --dsb-table-action-dark: #2d5a88;
}

/* =============================================
   BUTTONS
   =============================================
   !important is used because vendor.css and Site.css apply styles
   to generic selectors (input[type="submit"], .btn, .form-control)
   that override our component styles. Remove !important once
   legacy stylesheets are cleaned up.
   ============================================= */
.dsb-btn {
    all: unset;
    box-sizing: border-box !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 44px;
    padding: 0 24px !important;
    border-radius: var(--dsb-radius) !important;
    font-family: inherit;
    font-size: 15px !important;
    font-weight: 600 !important;
    cursor: pointer;
    text-decoration: none !important;
    transition: background-color .2s, opacity .2s;
    line-height: 1 !important;
    text-align: center !important;
    white-space: nowrap;
}
.dsb-btn--primary {
    background: var(--theme-action) !important;
    color: #fff !important;
    border: 1.5px solid var(--theme-action) !important;
}
.dsb-btn--primary:hover { background: var(--theme-action-dark) !important; border-color: var(--theme-action-dark) !important; }

.dsb-btn--secondary {
    background: #fff !important;
    color: var(--theme-action) !important;
    border: 2px solid var(--theme-action) !important;
}
.dsb-btn--secondary:hover { background: #f5f9f7 !important; }
/* Vehicle already selected — button is fully greyed out and disabled */
.dsb-btn--secondary.is-selected {
    border-color: #d4d8dd !important;
    color: #b0b5bc !important;
    background: #f5f6f7 !important;
    cursor: not-allowed !important;
    opacity: 0.7;
}
.dsb-btn--secondary.is-selected:hover {
    background: #f5f6f7 !important;
}

.dsb-btn--blue {
    background: var(--theme-primary);
    color: #fff;
    border: 1.5px solid var(--theme-primary);
}
.dsb-btn--blue:hover { background: var(--theme-primary-dark); border-color: var(--theme-primary-dark); }

.dsb-btn--danger {
    background: #934041;
    color: #fff;
    border: 1.5px solid #934041;
}
.dsb-btn--danger:hover { background: #7a3435; }

.dsb-btn--danger-text {
    background: transparent;
    color: #934041;
    border: 1.5px solid transparent;
}
.dsb-btn--danger-text:hover { color: #7a3435; }

.dsb-btn--warning {
    background: #e8a13a;
    color: #fff;
    border: 1.5px solid #e8a13a;
}
.dsb-btn--warning:hover { background: #cc8c2f; }

.dsb-btn--ghost {
    background: transparent;
    color: var(--dsb-text-color);
    border: 1.5px solid var(--dsb-border-color);
}
.dsb-btn--ghost:hover { background: var(--dsb-bg-page); }

.dsb-btn--table {
    background: var(--dsb-table-action) !important;
    color: #fff !important;
    border: 1.5px solid var(--dsb-table-action) !important;
}
.dsb-btn--table:hover { background: var(--dsb-table-action-dark) !important; border-color: var(--dsb-table-action-dark) !important; }

.dsb-btn--disabled,
.dsb-btn[disabled] {
    background: var(--theme-action-dark) !important;
    border-color: var(--theme-action-dark) !important;
    color: #fff !important;
    opacity: 0.45 !important;
    cursor: not-allowed !important;
}

.dsb-btn--sm { height: 34px !important; font-size: 13px !important; padding: 0 16px !important; }
.dsb-btn--lg { height: 50px !important; font-size: 18px !important; padding: 0 32px !important; }

/* =============================================
   PLATE INPUT (country flag + registration)
   =============================================
   !important is used throughout this section because vendor.css
   applies conflicting styles via .hero__input__plate-graphics-custom
   with !important. Once vendor.css legacy styles are removed,
   these !important declarations can be cleaned up.
   ============================================= */
.dsb-plate-input {
    display: flex !important;
    align-items: stretch !important;
    height: 50px !important;
    background: var(--theme-secondary) !important;
    border: 2px solid var(--theme-secondary) !important;
    border-radius: var(--dsb-radius) !important;
    overflow: visible;
}
.dsb-plate-input__flag {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0 !important;
    padding: 9px 10px 6px !important;
    background: var(--theme-secondary) !important;
    color: #fff !important;
    min-width: 46px !important;
    width: 46px !important;
    height: auto !important;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .5px;
    border-radius: 0 !important;
    border-top-left-radius: 4px !important;
    border-bottom-left-radius: 4px !important;
    cursor: pointer;
    position: relative !important;
    top: auto !important;
    left: auto !important;
    user-select: none;
    overflow: visible;
}
/* Override legacy absolute positioning from vendor.css */
.dsb-plate-input__flag.hero__input__plate-graphics-custom {
    position: relative !important;
    width: 46px !important;
    height: auto !important;
    top: auto !important;
    left: auto !important;
}
.dsb-plate-input__flag .current-country-flag {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    width: auto !important;
    height: auto !important;
    text-align: center !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}
.dsb-plate-input__flag .current-country {
    position: relative !important;
    bottom: auto !important;
    width: auto !important;
    display: block !important;
    text-align: center !important;
    font-size: 11px !important;
    color: #fff !important;
    margin-top: 2px;
}
.dsb-plate-input__flag .iti__flag {
    display: inline-block !important;
    width: 20px !important;
    margin-top: 0 !important;
    max-height: 15px !important;
}
.dsb-plate-input__flag-emoji .iti__flag,
.dsb-plate-input__flag-emoji .fi {
    display: inline-block !important;
    margin: 0 auto !important;
    font-size: 16px;
    line-height: 1;
    margin-top: 0 !important;
    max-height: none !important;
}
.dsb-plate-input__flag-code {
    color: #fff !important;
    font-size: 11px !important;
    font-weight: 600;
    letter-spacing: .5px;
    line-height: 1;
    margin-top: 2px;
    position: relative !important;
    bottom: auto !important;
    width: auto !important;
}
.dsb-plate-input__field {
    flex: 1 !important;
    border: none !important;
    border-left: 2px solid var(--theme-secondary) !important;
    border-radius: 0 !important;
    outline: none !important;
    font-family: inherit;
    font-size: 16px !important;
    font-weight: 600 !important;
    text-transform: uppercase;
    text-align: center !important;
    color: var(--dsb-text-color) !important;
    padding: 0 12px !important;
    background: #fff !important;
    height: 100% !important;
    box-shadow: none !important;
    width: 100% !important;
    margin: 0 !important;
}
.dsb-plate-input__field::placeholder {
    color: var(--dsb-placeholder-color) !important;
    font-weight: 600;
    letter-spacing: .5px;
}
.dsb-plate-input:focus-within {
    box-shadow: 0 2px 8px rgba(0,0,0,.14);
}
.dsb-plate-input__field:focus-visible { outline: none !important; }

/* =============================================
   VIN INPUT
   =============================================
   !important is used because vendor.css applies styles to
   generic input selectors that override our component styles.
   Remove !important once legacy stylesheets are cleaned up.
   ============================================= */
.dsb-vin-input {
    width: 100% !important;
    height: 50px !important;
    padding: 0 12px !important;
    border: 2px solid var(--theme-secondary) !important;
    border-radius: var(--dsb-radius) !important;
    background: #fff !important;
    font-family: inherit;
    font-size: 16px !important;
    font-weight: 600 !important;
    text-transform: uppercase;
    text-align: center !important;
    color: var(--dsb-text-color) !important;
    outline: none !important;
    box-shadow: none !important;
    margin: 0 !important;
}
.dsb-vin-input::placeholder {
    color: var(--dsb-placeholder-color) !important;
    font-weight: 600;
    letter-spacing: .5px;
}
.dsb-vin-input:focus-visible {
    border-color: var(--theme-secondary) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.14);
    outline: none !important;
}

/* =============================================
   COUNTRY DROPDOWN
   ============================================= */
/* Legacy country-list (from _SearchCountryList partial) — hidden by default */
.dsb-plate-input__flag .country-list,
.dsb-grid-search__plate .country-list {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    margin: 2px 0 0 0;
    padding: 4px 0;
    background: #fff;
    color: var(--dsb-text-color);
    border: 1px solid var(--dsb-border-color);
    border-radius: 4px;
    list-style: none;
    min-width: 220px;
    max-height: 320px;
    overflow-y: auto;
    z-index: 50;
    box-shadow: 0 4px 14px rgba(0,0,0,.08);
}
.dsb-plate-input__flag .country-list .country-list__item,
.dsb-grid-search__plate .country-list .country-list__item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
    cursor: pointer;
}
.dsb-plate-input__flag .country-list .country-list__item:hover,
.dsb-grid-search__plate .country-list .country-list__item:hover {
    background: #f5f9fc;
}

/* New-style dsb-country-dropdown (for future migration) */
.dsb-country-dropdown {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    margin: 2px 0 0 0;
    padding: 4px 0;
    background: #fff;
    color: var(--dsb-text-color);
    border: 1px solid var(--dsb-border-color);
    border-radius: 4px;
    list-style: none;
    min-width: 220px;
    max-height: 320px;
    overflow-y: auto;
    z-index: 50;
    box-shadow: 0 4px 14px rgba(0,0,0,.08);
}
.dsb-country-dropdown.is-open,
.dsb-country-dropdown.dsb-is-open { display: block; }
.dsb-country-dropdown__item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 14px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    transition: background .1s;
}
.dsb-country-dropdown__item:hover { background: #f5f9fc; }
.dsb-country-dropdown__item.is-selected {
    background: #e6f0fb;
    font-weight: 600;
}
.dsb-country-dropdown__flag {
    display: inline-block;
    width: 24px;
    text-align: center;
}
.dsb-country-dropdown__flag .iti__flag,
.dsb-country-dropdown__flag .fi {
    font-size: 18px;
    line-height: 1;
}
.dsb-country-dropdown__scrollbar {
    scrollbar-width: thin;
    scrollbar-color: #ccc transparent;
}
.dsb-country-dropdown__scrollbar::-webkit-scrollbar { width: 6px; }
.dsb-country-dropdown__scrollbar::-webkit-scrollbar-thumb { background: #ccc; border-radius: 3px; }

/* =============================================
   PILLS (status indicators)
   ============================================= */
.dsb-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 14px 5px 10px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 500;
    line-height: 1;
    white-space: nowrap;
}
.dsb-pill i { font-size: 14px; }
.dsb-pill--searching { color: var(--dsb-pill-searching-text); background-color: var(--dsb-pill-searching-bg); }
.dsb-pill--searching i { color: var(--dsb-pill-searching-text); }
.dsb-pill--updated { color: var(--dsb-pill-updated-text); background-color: var(--dsb-pill-updated-bg); }
.dsb-pill--updated i { color: var(--dsb-pill-updated-text); }
.dsb-pill--danger { color: var(--dsb-alert-danger-text); background-color: var(--dsb-alert-danger-bg); }
.dsb-pill--warning { color: #b8860b; background-color: var(--dsb-alert-warning-bg); }
.dsb-pill--info { color: var(--dsb-alert-info-text); background-color: var(--dsb-alert-info-bg); }
.dsb-pill--neutral { color: var(--dsb-text-light); background-color: var(--dsb-bg-subtle); }

/* =============================================
   ALERTS
   ============================================= */
.dsb-alert {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 18px;
    border: 1px solid transparent;
    border-radius: var(--dsb-radius);
    font-size: 14px;
    margin-bottom: 12px;
}
.dsb-alert i { font-size: 1.1em; }
.dsb-alert--success { color: var(--dsb-alert-success-text); background: var(--dsb-alert-success-bg); border-color: var(--dsb-alert-success-border); }
.dsb-alert--warning { color: var(--dsb-alert-warning-text); background: var(--dsb-alert-warning-bg); border-color: var(--dsb-alert-warning-border); }
.dsb-alert--danger  { color: var(--dsb-alert-danger-text);  background: var(--dsb-alert-danger-bg);  border-color: var(--dsb-alert-danger-border); }
.dsb-alert--info    { color: var(--dsb-alert-info-text);    background: var(--dsb-alert-info-bg);    border-color: var(--dsb-alert-info-border); }

/* =============================================
   WARNING ICON
   ============================================= */
.dsb-warning {
    color: #e8a13a;
    font-size: 14px;
    cursor: help;
}

/* =============================================
   TABLES
   ============================================= */
.dsb-table-wrapper {
    border-radius: var(--dsb-radius);
    overflow: hidden;
    border: 1px solid var(--dsb-border-light);
}
/* Multi-line cell for combined columns (e.g. Brand/Model, Reg/VIN) */
.dsb-cell-multiline {
    display: flex;
    flex-direction: column;
    line-height: 1.3;
    padding: 2px 0;
}
.dsb-cell-multiline__primary {
    font-weight: 600;
    font-size: 13px;
}
.dsb-cell-multiline__secondary {
    font-size: 11px;
    color: var(--dsb-text-muted);
}
/* Car match badge - shown when search matches a VIN/registration */
.dsb-car-match {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
}
.dsb-car-match__count {
    font-weight: 600;
}
.dsb-car-match__badge {
    font-size: 11px;
    background: var(--dsb-bg-subtle, #f0fdf4);
    color: var(--dsb-success, #16a34a);
    border: 1px solid var(--dsb-success, #16a34a);
    border-radius: 12px;
    padding: 2px 8px;
    white-space: nowrap;
}
.dsb-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}
.dsb-table thead th {
    background: var(--theme-secondary);
    color: #fff;
    font-weight: 600;
    font-size: 13px;
    padding: 12px 18px;
    text-align: left;
    border: none;
}
.dsb-table tbody td {
    padding: 11px 18px;
    border-bottom: 1px solid var(--dsb-bg-subtle);
    background: #fff;
    vertical-align: middle;
}
.dsb-table tbody tr:last-child td { border-bottom: none; }
.dsb-table tbody tr:nth-child(even) td { background: var(--theme-row-alt-bg); }
.dsb-table a { color: var(--dsb-link-color); text-decoration: none; }
.dsb-table a:hover { text-decoration: underline; }

/* =============================================
   PAGER
   ============================================= */
.dsb-pager {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 18px;
    font-size: 13px;
    color: var(--dsb-text-light);
    background: #fff;
    border-top: 1px solid var(--dsb-border-light);
}
.dsb-pager__nav {
    display: flex;
    align-items: center;
    gap: 2px;
}
.dsb-pager__btn {
    all: unset;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: 1px solid var(--dsb-border-color);
    border-radius: 4px;
    cursor: pointer;
    font-size: 13px;
    color: var(--dsb-text-color);
}
.dsb-pager__btn:hover { background: var(--dsb-bg-page); }
.dsb-pager__btn--disabled { color: #ccc; cursor: default; pointer-events: none; }
.dsb-pager__page-input {
    width: 32px;
    height: 32px;
    border: 1px solid var(--dsb-border-color);
    border-radius: 4px;
    text-align: center;
    font-family: inherit;
    font-size: 13px;
    color: var(--dsb-text-color);
    padding: 0;
    -moz-appearance: textfield;
    box-sizing: content-box;
}
.dsb-pager__page-input::-webkit-outer-spin-button,
.dsb-pager__page-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.dsb-pager__page-input:focus { outline: none; border-color: var(--theme-secondary); box-shadow: 0 0 0 2px rgba(29,45,73,.15); }
.dsb-pager__nav-label { font-size: 13px; color: var(--dsb-text-color); }
.dsb-pager__size {
    display: flex;
    align-items: center;
    gap: 6px;
}
.dsb-pager__size-label {
    font-size: 13px;
    color: var(--dsb-text-muted);
    white-space: nowrap;
}
.dsb-pager__size select {
    height: 32px;
    border: 1px solid var(--dsb-border-color);
    border-radius: 4px;
    padding: 0 28px 0 8px;
    font-family: inherit;
    font-size: 13px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5' viewBox='0 0 8 5'%3E%3Cpath d='M0 0l4 5 4-5z' fill='%23666'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 8px center;
    cursor: pointer;
}
.dsb-pager__size select:focus {
    outline: none;
    border-color: var(--dsb-text-muted);
    box-shadow: 0 2px 8px rgba(0,0,0,.14);
}

/* =============================================
   TABS
   ============================================= */
.dsb-tabs {
    display: flex;
    gap: 0;
}
.dsb-tab {
    all: unset;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 40px;
    padding: 0 20px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    background: var(--theme-tab-bg);
    color: #fff;
    transition: background .15s;
}
.dsb-tab:hover { background: var(--theme-primary); }
.dsb-tab--active { background: var(--theme-tab-active); }
.dsb-tab:first-child { border-radius: var(--dsb-radius) 0 0 var(--dsb-radius); }
.dsb-tab:last-child { border-radius: 0 var(--dsb-radius) var(--dsb-radius) 0; }

/* =============================================
   CARDS
   ============================================= */
.dsb-card {
    background: #fff;
    border: 1px solid var(--dsb-border-light);
    border-radius: var(--dsb-radius-lg);
    overflow: hidden;
}
.dsb-card__header {
    background: var(--theme-secondary);
    color: #fff;
    padding: 14px 18px;
    font-weight: 600;
    font-size: 15px;
}
.dsb-card__header--action { background: var(--theme-action); }
.dsb-card__header--primary { background: var(--theme-primary); }
.dsb-card__body {
    padding: 18px;
}

/* =============================================
   SEARCH BOX
   ============================================= */
.dsb-search-box {
    position: relative;
    display: flex;
    align-items: stretch;
    height: 36px;
    background: #fff;
    border: 1px solid var(--dsb-border-color);
    border-radius: var(--dsb-radius);
    overflow: hidden;
}
.dsb-search-box__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    color: var(--dsb-text-light);
    flex: 0 0 36px;
    font-size: 13px;
}
.dsb-search-box__input {
    flex: 1;
    border: none;
    outline: none;
    font-family: inherit;
    font-size: 13px;
    color: var(--dsb-text-color);
    padding: 0 12px 0 0;
    background: transparent;
}
.dsb-search-box__input::placeholder { color: var(--dsb-placeholder-color); font-weight: 500; }
.dsb-search-box--lg { height: 50px; }
.dsb-search-box--lg .dsb-search-box__icon { width: 48px; flex: 0 0 48px; font-size: 15px; }
.dsb-search-box--lg .dsb-search-box__input { font-size: 15px; }
.dsb-search-box:focus-within {
    border-color: var(--dsb-text-muted);
    box-shadow: 0 2px 8px rgba(0,0,0,.14);
}

/* =============================================
   FORM INPUTS
   ============================================= */
.dsb-form-section {
    margin-bottom: 20px;
}
.dsb-form-section__label {
    display: block;
    margin-bottom: 2px;
    font-weight: 600;
}
.dsb-form-section__hint {
    margin: 0 0 4px;
    font-size: 13px;
    color: var(--dsb-text-muted, #64748b);
}
.dsb-form-section__description {
    margin: 0 0 16px;
    font-size: 14px;
    color: var(--dsb-text, #1e293b);
}
.dsb-form-row {
    display: flex;
    gap: 12px;
}
.dsb-form-row__col {
    flex: 1;
    min-width: 0;
}
.dsb-form-validation {
    display: none;
    font-size: 12px;
}
.dsb-form-error {
    display: none;
    margin-bottom: 12px;
    font-size: 13px;
}
.dsb-form-alert {
    display: none;
    flex-wrap: wrap;
    margin-bottom: 12px;
}
.dsb-form-alert .dsb-btn {
    margin-top: 8px;
}
.dsb-form-group { margin-bottom: 16px; }
.dsb-form-label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--dsb-text-color);
    margin-bottom: 6px;
}
.dsb-form-input {
    width: 100%;
    height: 44px;
    padding: 0 12px;
    border: 1px solid var(--dsb-border-color);
    border-radius: var(--dsb-radius);
    font-family: inherit;
    font-size: 14px;
    color: var(--dsb-text-color);
    background: #fff;
    outline: none;
    transition: border-color .2s;
}
.dsb-form-input:focus-visible {
    border-color: var(--dsb-text-muted);
    box-shadow: 0 2px 8px rgba(0,0,0,.14);
}
.dsb-form-input::placeholder {
    color: var(--dsb-placeholder-color);
    font-weight: 500;
}
.dsb-form-input--error { border-color: #934041; }
.dsb-form-input--success { border-color: #328559; }
.dsb-form-input--error:focus-visible   { border-color: #934041;  box-shadow: 0 2px 8px rgba(0,0,0,.14); }
.dsb-form-input--success:focus-visible { border-color: #328559; box-shadow: 0 2px 8px rgba(0,0,0,.14); }

.dsb-form-textarea {
    min-height: 100px;
    padding: 10px 12px;
    resize: vertical;
}

.dsb-form-select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%239aa0a8'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 36px;
}

/* Checkbox & Radio */
.dsb-form-check {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 8px;
    cursor: pointer;
}
.dsb-form-check:has(input:disabled) { cursor: not-allowed; }
.dsb-form-check input[type="checkbox"],
.dsb-form-check input[type="radio"] {
    accent-color: var(--theme-action);
    width: 18px;
    height: 18px;
    cursor: pointer;
}
.dsb-form-check input[type="checkbox"]:disabled,
.dsb-form-check input[type="radio"]:disabled { cursor: not-allowed; }
.dsb-form-check__label {
    font-size: 14px;
    cursor: pointer;
}
.dsb-form-check:has(input:disabled) .dsb-form-check__label { cursor: not-allowed; }

/* Toggle switch */
.dsb-toggle {
    position: relative;
    width: 44px;
    height: 24px;
    display: inline-block;
}
.dsb-toggle input { opacity: 0; width: 0; height: 0; }
.dsb-toggle__slider {
    position: absolute;
    inset: 0;
    background: #ccc;
    border-radius: 24px;
    cursor: pointer;
    transition: background .2s;
}
.dsb-toggle__slider::before {
    content: '';
    position: absolute;
    left: 3px;
    top: 3px;
    width: 18px;
    height: 18px;
    background: #fff;
    border-radius: 50%;
    transition: transform .2s;
}
.dsb-toggle input:checked + .dsb-toggle__slider { background: var(--theme-action); }
.dsb-toggle input:checked + .dsb-toggle__slider::before { transform: translateX(20px); }

/* =============================================
   BADGES
   ============================================= */
.dsb-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    padding: 0 8px;
    border-radius: 12px;
    font-size: 11px;
    font-weight: 700;
    line-height: 1;
}
.dsb-badge--primary   { background: var(--theme-primary); color: #fff; }
.dsb-badge--action    { background: var(--theme-action);  color: #fff; }
.dsb-badge--secondary { background: var(--theme-secondary); color: #fff; }
.dsb-badge--danger    { background: #934041; color: #fff; }
.dsb-badge--warning   { background: #e8a13a; color: #fff; }

/* =============================================
   NAVBAR
   ============================================= */
.dsb-navbar {
    display: flex;
    align-items: center;
    gap: 0;
    padding: 0 24px;
    height: 56px;
    color: #fff;
    max-width: 1400px;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
}

/* Fixed header bar — full-width background, contains the constrained navbar */
header.header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1030;
    background: var(--theme-nav-bg);
    margin-bottom: 0 !important;
    transition: transform .25s ease;
}
.dsb-navbar__brand {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 17px;
    font-weight: 700;
    color: #fff;
    text-decoration: none;
    margin-right: 24px;
}
.dsb-navbar__brand i { font-size: 22px; color: var(--theme-action); }
.dsb-navbar__links {
    display: flex;
    flex: 1;
    align-items: center;
    gap: 0;
    list-style: none;
    margin: 0;
    padding: 0;
}
.dsb-navbar__link {
    display: flex;
    align-items: center;
    height: 56px;
    padding: 0 16px;
    color: var(--theme-nav-text) !important;
    text-decoration: none !important;
    font-size: 14px;
    font-weight: 500;
    border-bottom: 2px solid transparent;
    transition: color .15s, background .15s, border-color .15s;
}
.dsb-navbar__link:hover {
    color: var(--theme-nav-text-hover) !important;
    background: rgba(255,255,255,.06);
    border-bottom-color: var(--theme-action);
}
.dsb-navbar__link--active {
    color: var(--theme-nav-text-hover) !important;
    background: rgba(255,255,255,.08);
    border-bottom-color: var(--theme-action);
}

/* Brand logo inside dsb-navbar */
.dsb-navbar__brand-logo {
    display: block;
    max-height: 34px;
    width: auto;
}

/* =============================================
   7b. NAVBAR LANGUAGE SWITCHER (design-guide v1.9.5)
   ============================================= */
.dsb-nav-lang {
    position: relative;
    margin-left: auto;
    flex-shrink: 0;
    z-index: 2;
}
.dsb-nav-lang__btn {
    appearance: none;
    border: none;
    background: none;
    box-sizing: border-box;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 0 12px;
    height: 36px;
    border-radius: 6px;
    color: var(--theme-nav-text);
    font-size: 13px;
    font-weight: 600;
    transition: background .15s, color .15s;
}
.dsb-nav-lang__btn:hover { background: rgba(255,255,255,.08); color: #fff; }
.dsb-nav-lang__btn .fi,
.dsb-nav-lang__option .fi {
    width: 22px;
    height: 16px;
    border-radius: 2px;
    flex-shrink: 0;
    background-size: cover;
}
.dsb-nav-lang__chevron {
    font-size: 9px;
    transition: transform .2s;
    opacity: .7;
}
.dsb-nav-lang.dsb-lang-open .dsb-nav-lang__chevron { transform: rotate(180deg); opacity: 1; }
.dsb-nav-lang__dropdown {
    display: none;
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 6px;
    box-shadow: 0 6px 20px rgba(0,0,0,.13);
    min-width: 168px;
    padding: 4px 0;
    z-index: 1050;
    list-style: none;
    margin: 0;
}
.dsb-nav-lang.dsb-lang-open .dsb-nav-lang__dropdown { display: block; }
.dsb-nav-lang__option {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 14px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
    color: #333;
    text-decoration: none !important;
    transition: background .12s;
}
.dsb-nav-lang__option:hover { background: #f3f4f6; }
.dsb-nav-lang__option.dsb-lang-selected {
    color: var(--theme-primary, #3a7ee1);
    font-weight: 700;
    background: #eef4ff;
}

/* =============================================
   7c. MOBILE NAVBAR (design-guide v1.9.4)
   ============================================= */
.dsb-navbar-mob-wrap {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1030;
    transition: transform .25s ease;
}
.dsb-navbar-mob {
    background: var(--theme-nav-bg);
    padding: 0 20px;
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: #fff;
}
.dsb-navbar-mob__brand {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 17px;
    font-weight: 700;
    color: #fff !important;
    text-decoration: none !important;
}
.dsb-navbar-mob__brand-logo {
    display: block;
    max-height: 30px;
    width: auto;
}
.dsb-navbar-mob__burger {
    all: unset;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    gap: 5px;
    padding: 8px;
    border-radius: 6px;
    transition: background .15s;
}
.dsb-navbar-mob__burger:hover { background: rgba(255,255,255,.08); }
.dsb-navbar-mob__burger span {
    display: block;
    width: 22px;
    height: 2px;
    background: #fff;
    border-radius: 2px;
    transition: transform .25s, opacity .2s;
    transform-origin: center;
}
.dsb-navbar-mob-wrap.dsb-mob-open .dsb-navbar-mob__burger span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}
.dsb-navbar-mob-wrap.dsb-mob-open .dsb-navbar-mob__burger span:nth-child(2) {
    opacity: 0;
    transform: scaleX(0);
}
.dsb-navbar-mob-wrap.dsb-mob-open .dsb-navbar-mob__burger span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}
.dsb-navbar-mob__menu {
    list-style: none;
    margin: 0;
    padding: 0;
    max-height: 0;
    overflow: hidden;
    background: var(--theme-nav-bg);
    transition: max-height .3s ease;
}
.dsb-navbar-mob-wrap.dsb-mob-open .dsb-navbar-mob__menu {
    max-height: 480px;
    border-top: 1px solid rgba(255,255,255,.08);
}
.dsb-navbar-mob__menu li { list-style: none; }
.dsb-navbar-mob__menu-link {
    display: flex;
    align-items: center;
    padding: 13px 24px;
    color: var(--theme-nav-text) !important;
    text-decoration: none !important;
    font-size: 14px;
    font-weight: 500;
    border-left: 3px solid transparent;
    transition: color .15s, background .15s, border-color .15s;
}
.dsb-navbar-mob__menu-link:hover {
    color: var(--theme-nav-text-hover) !important;
    background: rgba(255,255,255,.06);
}
.dsb-navbar-mob__menu-link--active {
    color: var(--theme-nav-text-hover) !important;
    background: rgba(255,255,255,.08);
    border-left-color: var(--theme-action);
}

/* Mobile language strip (bottom of burger menu) */
.dsb-navbar-mob__lang-row {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 24px 14px;
    border-top: 1px solid rgba(255,255,255,.08);
}
.dsb-navbar-mob__lang-label {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: rgba(255,255,255,.4);
    flex-shrink: 0;
}
.dsb-navbar-mob__lang-flags { display: flex; gap: 5px; flex-wrap: wrap; }
.dsb-navbar-mob__lang-btn {
    all: unset;
    box-sizing: border-box;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 8px;
    border-radius: 6px;
    color: rgba(255,255,255,.55) !important;
    font-size: 12px;
    font-weight: 700;
    border: 1px solid transparent;
    transition: background .15s, color .15s, border-color .15s;
}
.dsb-navbar-mob__lang-btn:hover { background: rgba(255,255,255,.08); color: #fff !important; }
.dsb-navbar-mob__lang-btn.dsb-lang-mob-active {
    background: rgba(255,255,255,.1);
    border-color: var(--theme-action);
    color: #fff !important;
}
.dsb-navbar-mob__lang-btn .fi {
    width: 20px;
    height: 14px;
    border-radius: 2px;
    flex-shrink: 0;
    background-size: cover;
}

/* =============================================
   SPACING: gap between fixed navbar and page content
   ============================================= */
.dsb-page-content-spacer {
    padding-top: 80px;
}

/* =============================================
   LEGACY OVERRIDES — .rect__* components
   =============================================
   Temporary overrides for the legacy .rect layout system
   (defined in assets/sass/app.scss, bundled into vendor.css).
   These reduce excessive padding/spacing globally until each
   page is individually migrated to .dsb-* classes.

   TODO: Remove these overrides once all pages have been
   migrated away from .rect__* to .dsb-* components.
   ============================================= */
.rect__body {
    padding: 16px !important;
    padding-bottom: 24px !important;
}
.rect__heading {
    padding: 16px !important;
    border-bottom: none !important;
}

/* Responsive container: reduce side whitespace at smaller widths */
@media (max-width: 1199px) {
    .container {
        width: auto !important;
        max-width: 100% !important;
        padding-left: 12px !important;
        padding-right: 12px !important;
    }
    .rect__body {
        padding: 8px !important;
        padding-bottom: 16px !important;
    }
    .rect__heading {
        padding: 8px !important;
    }
}

/* =============================================
   PAGE HERO — title + subtitle + CTA
   =============================================
   Design-guide section 15.1. Used as the page header
   on migrated pages (replaces rect__heading).
   ============================================= */
.dsb-page-hero {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 24px 0 20px;
}
.dsb-page-hero__titles {
    flex: 1 1 auto;
    min-width: 0;
}
.dsb-page-hero__title {
    margin: 0 0 4px;
    font-size: 22px;
    font-weight: 600;
    color: var(--dsb-text-color, #1e293b);
}
.dsb-page-hero__subtitle {
    margin: 0;
    font-size: 13px;
    font-weight: 600;
    color: var(--dsb-text-muted, #6b6b6b);
}
.dsb-page-hero__action {
    flex-shrink: 0;
}
.dsb-page-hero__stats {
    display: flex;
    align-items: center;
    gap: 10px;
}
.dsb-stat-pill {
    display: inline-flex;
    align-items: baseline;
    gap: 3px;
    background: var(--dsb-bg-subtle);
    border: 1px solid var(--dsb-border-color);
    padding: 1px 7px;
    border-radius: 4px;
}
.dsb-stat-pill__value {
    font-size: 11px;
    font-weight: 700;
    color: var(--dsb-text-color);
    line-height: 1;
}
.dsb-stat-pill__label {
    font-size: 10px;
    font-weight: 500;
    color: var(--dsb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}
.dsb-page-hero + hr {
    border: none;
    border-top: 1px solid var(--dsb-border-light, #e2e8f0);
    margin: 0 0 20px;
}

@media (max-width: 576px) {
    .dsb-page-hero {
        flex-direction: column;
        padding: 16px 0 12px;
    }
    .dsb-page-hero__action {
        align-self: stretch;
    }
    .dsb-page-hero__action .dsb-btn {
        width: 100%;
    }
}

/* Hide dsb-navbar links when rendered inside the offcanvas (mobile slide-out) — legacy fallback */
.offcanvas .dsb-navbar__links {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    padding: 16px 0;
}
.offcanvas .dsb-navbar__link {
    height: auto;
    padding: 12px 20px;
    border-bottom: none;
    font-size: 15px;
}
.offcanvas .dsb-nav-lang {
    margin-left: 0;
    padding: 8px 20px;
}

/* =============================================
   MODAL / POPUP
   ============================================= */
.dsb-modal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .4);
    z-index: 2000;
    justify-content: center;
    align-items: center;
    padding: 16px;
}
.dsb-modal-overlay.dsb-modal-open {
    display: flex;
}
/* Ensure DevExtreme dropdowns (TagBox, SelectBox etc.) rendered inside
   a dsb-modal appear above the overlay, not behind it */
.dx-overlay-wrapper.dx-dropdowneditor-overlay {
    z-index: 2100 !important;
}
.dx-popup-wrapper.dx-dropdowneditor-overlay > .dx-overlay-content {
    z-index: 2100 !important;
}
.dsb-modal {
    background: #fff;
    border-radius: var(--dsb-radius-lg);
    box-shadow: 0 8px 32px rgba(0,0,0,.15);
    max-width: 520px;
    width: 100%;
    overflow: hidden;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
}
.dsb-modal--md {
    max-width: 800px;
    width: 800px;
    overflow: visible;
}
.dsb-modal--md .dsb-modal__body {
    overflow: visible;
}
.dsb-modal--md .dsb-modal__body .form-control {
    height: 50px !important;
    border: 2px solid var(--theme-secondary) !important;
    border-radius: var(--dsb-radius) !important;
    font-size: 16px !important;
    padding: 0 12px !important;
}
.dsb-modal--md .dsb-modal__body .iti {
    width: 100% !important;
}
.dsb-modal--md .dsb-modal__body .iti input {
    height: 50px !important;
    border: 2px solid var(--theme-secondary) !important;
    border-radius: var(--dsb-radius) !important;
    font-size: 16px !important;
    padding-left: 52px !important;
}
.dsb-modal__body .dsb-modal__footer {
    margin: 20px -20px -20px;
}
.dsb-modal--lg {
    max-width: 80vw;
    width: 80vw;
}
.dsb-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--dsb-border-light);
    font-weight: 600;
    font-size: 16px;
    flex-shrink: 0;
}
.dsb-modal__close {
    border: none;
    background: none;
    cursor: pointer;
    font-size: 22px;
    line-height: 1;
    color: var(--dsb-text-muted, #6b6b6b);
    padding: 4px 8px;
}
.dsb-modal__close:hover {
    color: var(--dsb-text-color, #1e293b);
}
.dsb-modal__close:focus {
    outline: 2px solid var(--dsb-action, #22b14c);
    outline-offset: 2px;
}
.dsb-modal__body {
    padding: 20px;
    overflow-y: auto;
    overflow-x: hidden;
    flex: 1 1 auto;
    min-width: 0;
}
/* Constrain tables and grids inside modal body */
.dsb-modal__body .dsb-table-wrapper,
.dsb-modal__body .dsb-dx-grid {
    max-width: 100%;
    overflow-x: auto;
}
.dsb-modal__body .dx-datagrid {
    max-width: 100%;
}
.dsb-modal__body .dx-datagrid-rowsview,
.dsb-modal__body .dx-datagrid-headers {
    overflow: hidden;
}
.dsb-modal__body .dx-datagrid-table {
    width: 100% !important;
}
.dsb-modal__footer {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    padding: 14px 20px;
    border-top: 1px solid var(--dsb-border-light);
    flex-shrink: 0;
}

@media (max-width: 576px) {
    .dsb-modal {
        max-width: 100%;
        max-height: 100vh;
        border-radius: 0;
    }
    .dsb-modal__footer {
        flex-direction: column;
    }
    .dsb-modal__footer .dsb-btn {
        width: 100%;
    }
}

/* =============================================
   SPINNER (loading indicators)
   ============================================= */
.dsb-spinner {
    display: inline-block;
    width: 24px;
    height: 24px;
    border: 3px solid var(--dsb-border-light);
    border-top-color: var(--theme-primary);
    border-radius: 50%;
    animation: dsb-spin 0.8s linear infinite;
}
.dsb-spinner--action { border-top-color: var(--theme-action); }
.dsb-spinner--sm { width: 16px; height: 16px; border-width: 2px; }
.dsb-spinner--lg { width: 36px; height: 36px; border-width: 4px; }

/* =============================================
   TOOLTIPS
   ============================================= */
.dsb-table-tooltip {
    position: relative;
    display: inline-flex;
    align-items: center;
    margin-left: 10px;
    cursor: default;
    vertical-align: middle;
    top: -2px;
}
.dsb-table-tooltip__content {
    display: none;
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    background: #fff;
    color: var(--dsb-text-color);
    padding: 6px 12px;
    border-radius: 4px;
    font-size: 12px;
    white-space: nowrap;
    pointer-events: none;
    z-index: 100;
    box-shadow: 0 2px 8px rgba(0,0,0,.15), 0 0 0 1px rgba(0,0,0,.06);
}
.dsb-table-tooltip__content::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-top-color: #fff;
}
.dsb-table-tooltip:hover .dsb-table-tooltip__content { display: block; }

/* =============================================
   BREADCRUMBS
   ============================================= */
.dsb-breadcrumbs {
    display: flex;
    align-items: center;
    gap: 0;
    list-style: none;
    margin: 0;
    padding: 0;
    font-size: 13px;
}
.dsb-breadcrumbs li { display: flex; align-items: center; }
.dsb-breadcrumbs li + li::before {
    content: '/';
    margin: 0 8px;
    color: var(--dsb-text-light);
}
.dsb-breadcrumbs a { color: var(--dsb-link-color); text-decoration: none; }
.dsb-breadcrumbs a:hover { text-decoration: underline; }
.dsb-breadcrumbs .dsb-current { color: var(--dsb-text-muted); font-weight: 600; }

/* =============================================
   PROGRESS BAR
   ============================================= */
.dsb-progress { height: 8px; background: var(--dsb-bg-subtle); border-radius: 4px; overflow: hidden; }
.dsb-progress__bar { height: 100%; border-radius: 4px; transition: width .3s ease; }
.dsb-progress__bar--action { background: var(--theme-action); }
.dsb-progress__bar--primary { background: var(--theme-primary); }
.dsb-progress__bar--danger { background: #934041; }
.dsb-progress__bar--warning { background: #e8a13a; }

/* =============================================
   UTILITY: spinner
   ============================================= */
.dsb-spin {
    animation: dsb-spin 1s linear infinite;
}
@keyframes dsb-spin {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}

/* =============================================
   PAGE WRAPPER — neutralize legacy rect/heading styles
   =============================================
   Use .dsb-page on pages migrated to the design system.
   It resets legacy .rect, .rect__heading, .rect__body
   so they don't interfere with component styles.
   ============================================= */
.dsb-page {
    font-family: inherit;
    color: var(--dsb-text-color);
}
.dsb-page .rect__heading--search-car,
.rect__heading--search-car {
    background: transparent !important;
    padding: 0 !important;
    margin: 0 !important;
    border: none !important;
}
.dsb-page .rect__body {
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
}
.dsb-page .rect {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* =============================================
   LEGACY ALERT OVERRIDES
   =============================================
   Makes legacy Bootstrap .alert elements match the design system
   when used inside a .dsb-page wrapper.
   ============================================= */
.dsb-page .alert {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    margin: 0 0 10px 0;
    padding: 8px 14px;
    font-size: 14px;
    border: 1px solid transparent;
    border-radius: 6px;
    text-align: center;
}
.dsb-page .alert i { font-size: 1.1em; }
.dsb-page .alert.alert-warning { color: #9c7d22; background: #f8f4df; border-color: #e7dca9; }
.dsb-page .alert.alert-danger  { color: #934041; background: #f8ecec; border-color: #dcb4b4; }
.dsb-page .alert.alert-success { color: #2e8a4f; background: #dff2e3; border-color: #a8d9b8; }
.dsb-page .alert.alert-info    { color: #2c5f8a; background: #e6f0fb; border-color: #a8c8ef; }

/* =============================================
   DEVEXTREME DATAGRID OVERRIDES
   =============================================
   Standard styling for DevExtreme DataGrid widgets when wrapped
   with the .dsb-dx-grid class inside a .dsb-page.
   ============================================= */
.dsb-table-wrapper {
    margin-top: 24px;
    border: 1px solid var(--dsb-border-light);
    border-radius: var(--dsb-radius);
    overflow: hidden;
}
.dsb-dx-grid,
.dsb-dx-grid .dx-datagrid {
    font-family: inherit;
    color: var(--dsb-text-color);
    border-radius: var(--dsb-radius-lg);
    overflow: hidden;
    background: #fff !important;
}
.dsb-dx-grid .dx-datagrid-headers,
.dsb-dx-grid .dx-datagrid-headers .dx-datagrid-table,
.dsb-dx-grid .dx-datagrid-headers td {
    background: var(--theme-secondary) !important;
    color: #fff !important;
    border: none !important;
}
.dsb-dx-grid .dx-datagrid-headers .dx-row > td {
    padding: 0 18px !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    border-bottom: none !important;
    line-height: 1.2 !important;
    height: 42px !important;
    vertical-align: middle !important;
}
.dsb-dx-grid .dx-datagrid .dx-datagrid-text-content {
    padding: 0 !important;
    margin: 0 !important;
}
.dsb-dx-grid .dx-datagrid-rowsview .dx-row > td {
    padding: 0 18px !important;
    border-top: none !important;
    border-bottom: 1px solid #eef0f3 !important;
    background: #ffffff !important;
    color: var(--dsb-text-color);
    font-size: 13px;
    height: 44px !important;
    vertical-align: middle !important;
}
.dsb-dx-grid .dx-datagrid-rowsview .dx-row.dx-row-alt > td {
    background: var(--theme-row-alt-bg) !important;
}
.dsb-dx-grid .dx-datagrid-rowsview .dx-data-row:last-child > td {
    border-bottom: none !important;
}
.dsb-dx-grid .dx-datagrid-pager {
    padding: 6px 18px !important;
}
/* Hide the "Page X of Y (N items)" info text */
.dsb-dx-grid .dx-info {
    display: none !important;
}
/* "Rows per page" label next to page size selector */
.dsb-dx-grid .dx-page-sizes {
    display: inline-flex !important;
    align-items: center !important;
    flex-direction: row !important;
}
.dsb-dx-grid .dx-page-sizes::after {
    content: "Rows per page";
    font-size: 13px;
    color: var(--dsb-text-light, #9aa0a8);
    margin-left: 8px;
    white-space: nowrap;
    order: 99;
}
/* Sort indicator — use a proper down-arrow triangle */
.dsb-dx-grid .dx-sort-up::before,
.dsb-dx-grid .dx-sort-down::before {
    content: " \25BC" !important;
    font-size: 9px !important;
    margin-left: 4px;
}
.dsb-dx-grid .dx-sort-up::before {
    content: " \25B2" !important;
}
/* Hide the default DevExtreme sort/filter icons (replaced by ::before pseudo-elements) */
.dsb-dx-grid .dx-datagrid-headers .dx-header-filter {
    font-size: 0 !important;
}
.dsb-dx-grid .dx-datagrid-headers .dx-column-indicators .dx-sort {
    font-size: 0 !important;
}
.dsb-dx-grid .dx-sort.dx-sort-none {
    display: none !important;
}
.dsb-dx-grid .dx-datagrid-rowsview .dx-row a {
    color: var(--dsb-link-color);
    text-decoration: none;
}
.dsb-dx-grid .dx-datagrid-rowsview .dx-row a:hover {
    text-decoration: underline;
}
/* Remove the outer border/frame that DevExtreme adds around the widget */
.dsb-dx-grid.dx-widget {
    border: none !important;
}
.dsb-dx-grid .dx-datagrid-borders > .dx-datagrid-headers,
.dsb-dx-grid .dx-datagrid-borders > .dx-datagrid-rowsview,
.dsb-dx-grid .dx-datagrid-borders > .dx-datagrid-pager,
.dsb-dx-grid .dx-datagrid-borders > .dx-datagrid-header-panel {
    border: none !important;
}
.dsb-dx-grid .dx-datagrid-search-panel {
    border: 1px solid var(--dsb-border-color, #d6dae0) !important;
    border-radius: var(--dsb-radius) !important;
    box-shadow: none !important;
}
/* Command column buttons styled as plain text links (not buttons) */
.dsb-grid-link-btn.dx-link {
    background: none !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 8px !important;
    color: var(--dsb-text-muted, #6b6b6b) !important;
    font-size: 13px !important;
    text-decoration: none !important;
}
.dsb-grid-link-btn.dx-link:hover {
    text-decoration: underline !important;
    color: var(--dsb-text-color, #1e293b) !important;
}
.dsb-grid-link-btn--primary.dx-link {
    color: var(--dsb-link-color, #2D6BC4) !important;
    font-weight: 600 !important;
}

/* Vertically center the action button anchor inside DevExtreme command cells.
   The button is an inline-flex anchor whose intrinsic baseline + the cell's font
   line-height leaves it sitting above the row's visual mid-line. We force the line
   box to span the full cell height via a zero-width ghost pseudo-element, so
   vertical-align: middle on the button actually centers against the cell. */
.dsb-dx-grid .dx-command-edit::before {
    content: "";
    display: inline-block;
    width: 0;
    height: 100%;
    vertical-align: middle;
}
.dsb-dx-grid .dx-command-edit .dsb-btn.dx-link {
    vertical-align: middle !important;
}
.dsb-dx-grid .dx-datagrid-content .dx-datagrid-table .dx-row .dx-command-edit {
    padding-right: 14px !important;
}

/* Status cell — used for pill + warning icon layout in grid cells */
.dsb-dx-grid .dsb-status-cell {
    padding-right: 24px !important;
    white-space: nowrap;
    overflow: visible !important;
    text-overflow: clip !important;
}
.dsb-dx-grid .dsb-status-cell .dx-datagrid-text-content,
.dsb-dx-grid .dsb-status-cell > .dx-datagrid-text-content {
    overflow: visible !important;
    text-overflow: clip !important;
    max-width: none !important;
    white-space: nowrap !important;
}
.dsb-status-inner {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    justify-content: flex-end;
}
.dsb-warning-slot {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    flex: 0 0 18px;
}

/* =============================================
   POPUP HELPERS (Magnific Popup)
   ============================================= */
.mfp-hide { display: none; }
.white-popup {
    position: relative;
    background: #FFF;
    padding: 20px;
    width: 850px;
    max-width: 850px;
    margin: 20px auto;
}

/* =============================================
   RESPONSIVE: DataGrid + components on mobile
   ============================================= */
@media (max-width: 600px) {
    .dsb-dx-grid .dx-datagrid-headers .dx-row > td,
    .dsb-dx-grid .dx-datagrid-rowsview .dx-row > td {
        padding: 0 10px !important;
        font-size: 12px !important;
    }
    .dsb-pill {
        padding: 5px 10px 5px 8px;
        font-size: 12px;
    }
    .dsb-alert {
        font-size: 13px;
        padding: 8px 10px;
    }
}

/* ===== Search Grid Layout (.dsb-grid-search) =====
   Standard 4-column search grid used on pages with plate/vin/action inputs.
   Default columns: plate(4fr) | vin(4fr) | action(2fr) | cta(2fr)
   ============================================================= */
.dsb-grid-search {
    display: grid !important;
    grid-template-columns: 4fr 4fr 2fr 2fr;
    column-gap: 10px;
    row-gap: 0;
    align-items: center;
    margin: 0 !important;
    padding: 0 !important;
}
.dsb-grid-search__plate    { grid-column: 1; position: relative; }
.dsb-grid-search__vin      { grid-column: 2; }
.dsb-grid-search__action   { grid-column: 3; }
.dsb-grid-search__cta      { grid-column: 4; display: contents; }

/* Forms inside the grid use display:contents to flatten into grid */
.dsb-grid-search > form,
.dsb-grid-search > div > form { display: contents !important; }

/* Full-width button sizing for grid cells */
.dsb-grid-search .dsb-btn {
    width: 100%;
    white-space: nowrap;
}

/* CTA wrapper — full-width flex container for action buttons */
.dsb-cta-wrapper {
    width: 100%;
    grid-column: 4;
    display: flex;
    align-items: center;
}
.dsb-cta-wrapper .dsb-btn {
    width: 100%;
}

/* ===== Search Grid Meta Items ===== */
.dsb-grid-search__vehicle-label {
    grid-column: 1 / -1;
    margin: 6px 0 0 0;
    font-size: 13px;
    color: var(--dsb-text-muted);
    line-height: 1.4;
}
.dsb-grid-search__vehicle-label strong { font-weight: 600; }

.dsb-grid-search__counter {
    grid-column: 3 / -1;
    margin: 4px 0 0 0;
    font-size: 12px;
    color: var(--dsb-text-light);
    text-align: right;
}
.dsb-grid-search__counter.is-empty { color: #8f2b2b; font-weight: 600; }

/* Response time / status notice */
.dsb-grid-search__notice {
    grid-column: 1 / -1;
    display: block;
    margin: 14px 0 0 0;
    line-height: 1.4;
}
.dsb-grid-search__notice strong {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: var(--dsb-text-color);
}
.dsb-grid-search__notice small {
    display: block;
    font-size: 13px;
    color: var(--dsb-text-muted);
    margin-top: 2px;
}

/* Alerts area below grid */
.dsb-grid-search__alerts {
    grid-column: 1 / -1;
    margin-top: 10px;
}

/* ===== Search Grid Responsive ===== */

/* Tablet: 2-column layout */
@media (max-width: 991px) {
    .dsb-grid-search {
        grid-template-columns: 1fr 1fr;
        row-gap: 10px;
    }
    .dsb-grid-search__plate  { grid-column: 1; grid-row: 1; }
    .dsb-grid-search__vin    { grid-column: 2; grid-row: 1; }
    .dsb-grid-search__action { grid-column: 1; grid-row: 2; }
    .dsb-cta-wrapper         { grid-column: 2; grid-row: 2; }

    .dsb-grid-search__vehicle-label,
    .dsb-grid-search__notice,
    .dsb-grid-search__alerts,
    .dsb-grid-search__counter {
        grid-column: 1 / -1;
    }
}

/* Mobile: single column */
@media (max-width: 600px) {
    .dsb-grid-search__notice { margin-bottom: 10px; }
    .dsb-grid-search__notice strong { font-size: 15px; }
    .dsb-grid-search__notice small  { font-size: 12px; }

    .dsb-grid-search {
        grid-template-columns: 1fr;
        row-gap: 8px;
    }
    .dsb-grid-search__plate,
    .dsb-grid-search__vin,
    .dsb-grid-search__action,
    .dsb-cta-wrapper {
        grid-column: 1;
    }
    .dsb-grid-search__plate  { grid-row: 1; }
    .dsb-grid-search__vin    { grid-row: 2; }
    .dsb-grid-search__action { grid-row: 3; }
    .dsb-cta-wrapper         { grid-row: 4; }

    .dsb-grid-search .dsb-plate-input,
    .dsb-grid-search .dsb-vin-input,
    .dsb-grid-search .dsb-btn {
        height: 46px !important;
    }
    .dsb-grid-search .dsb-plate-input__field,
    .dsb-grid-search .dsb-vin-input {
        font-size: 15px;
    }
    .dsb-grid-search .dsb-btn {
        font-size: 16px;
    }
}

/* Very small phones */
@media (max-width: 380px) {
    .dsb-plate-input__flag {
        min-width: 44px;
        padding: 4px 6px;
    }
}

/* ─── Contact Card ─── */
.dsb-contact-card {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 24px;
    margin-bottom: 24px;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 16px;
}

.dsb-contact-card__row {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.dsb-contact-card__label {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    color: #6b7280;
    letter-spacing: 0.05em;
}

.dsb-contact-card__value {
    font-size: 14px;
    color: #1f2937;
}

.dsb-contact-card__value a {
    color: rgb(0, 137, 208) !important;
    text-decoration: none;
}

.dsb-contact-card__value a:hover {
    text-decoration: underline;
}
