/* ==========================
   Global Typography System
   ========================== */

body {
  font-family: 'Inter', sans-serif; /* modern + clean */
  color: #2f3a45;
  font-size: clamp(13px, 0.9vw, 15px);
}

h1, h2, h3, h4 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
  letter-spacing: 0.2px;
}

/* Unified primary blue */
:root {
  --primary-blue: #1678a8;
}

/* Apply unified blue */
.dl-header-div .dl-subheader,
#dl_table th,
.dl-ref-title,
#dl_maps_modal_title,
#dl_contact_modal_title,
#exampleModalLongTitle {
  color: var(--primary-blue);
}

.dl-national-name {
  background-color: var(--primary-blue);
}


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

    to {
        transform: rotate(360deg);
    }
}

/* -------------------------------------------- SHORTCODE: [blackinton-dealer-locator] ----------------------------------------------- */

.dl-header {
    font-size: clamp(20px, 2vw, 28px);
    text-align: center;
    font-family: 'Open Sans';
    font-weight: 700;
    font-style: normal;
}

.dl-header-div .dl-subheader {
    text-align: center;
    color: #007cba;
}

#dl_dealer_list_container {
    padding-bottom: 25px;
    text-align: center;
    padding: 0px 0px 25px 0px;
}

#dl_btn_search {
    margin-top: 15px;
    background-color: #007cba;
    width: 72px;
    height: 37px;
}

#dl_btn_search:hover {
    background-color: #2196F3;
}

#dl_btn_search_again {
    display: none;
    position: absolute;
    margin-top: -45px;
    margin-left: 15px;
    background-color: #007cba;
}

#dl_btn_search_again:hover {
    background-color: #2196F3;
}

.dl-empty-html {
    text-align: center;
    width: 100%;
    position: absolute;
}

.dl-card-header {
    font-weight: 700 !important;
    font-size: clamp(13px, 0.9vw, 15px) !important;
}

.dl-filter-row .list-group-item {
    font-size: clamp(13px, 0.9vw, 15px);
}

.dl-filter-row .active {
    background-color: #007cba !important;
    border-color: #007cba !important;
}

.dealer-locator-form-h2 {
    color: #007cba;
    font-weight: 500;
    margin-bottom: 0px;
    font-size: clamp(16px, 1.2vw, 20px);
}

.dl-location-error {
    color: #e96a59;
    margin: 5px 0px -15px;
    visibility: hidden;
}

.dl-filter-icons {
    font-size: large;
}

.dl-filter-row .list-group-item {
    line-height: normal;
    padding: 12px 20px;
}

.dl-filter-row .list-group {
    border-radius: 0;
}

#dl_table_length {
    float: left;
}

#dl_table_length select option:last-child {
    display: none;
}

#dl_table_filter {
    float: right;
}

#dl_table_paginate {
    float: right;
    margin-bottom: 15px;
}

.dl-national-dealers-div {
    width: 100%;
    margin-bottom: 15px;
}

.dl-national-name>h4 {
    color: white;
    font-weight: 600;
    margin-bottom: 0px;
    font-size: clamp(14px, 1vw, 18px);

}

.dl-national-info .contact-span {
    margin-left: 10px;
}

.dl-table-contact-div .contact-span {
    margin-left: 15px;
}

.contact-span.phone {
    margin-left: 15px;
}

.dl-table-contact-div .contact-email-span {
    word-break: break-all;
    margin-left: 10%;
}

.dl-table-contact-email-li {
    width: 140px;
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
}

#dl_table th {
    color: #007cba;
    border: none;
    border-bottom: 2px solid #007cba;
}

#dl_table th:last-child {
    text-align: left !important;
}

.dl-table-contact-div ul {
    padding: 0px;
}

#dl_table ul {
    margin-bottom: 0px;
}

#dl_table td {
    vertical-align: top;
    font-size: clamp(12px, 0.9vw, 16px);
    font-weight: 400;
      line-height: 1.45;

}

#dl_table {
    text-align: left;
}

#dl_table_info {
    float: left;
    padding-top: 0px;
}

.dl-table-addr-div li {
    list-style: none;
    text-align: left;
    line-height: 1.5em;
}

.dl-dealer-list-col {
    padding: 0px;
    width: 100%;
}

.dl-results-row {
    padding-top: 50px;
}

.dl-results {
    display: none;
}

#dl_table_length {
    display: none;
}

.fw-700 {
    font-weight: 700;
}

.dl-table-name {
    width: 27%;
}

.dl-table-addr {
    width: 27%;
}

.dl-table-addr-div ul {
    padding-left: 0px;
}

.dl-table-distance {
    width: 21%;
}

.dl-table-contact {
    width: 27%;
}

.dl-table-contact-div {
    display: block;
    margin: 0 auto;
}

.dl-table-contact-div li {
    list-style: none;
    text-align: left;
}

.dl-table-ecomm-link {
    text-decoration: none;
}

.dl-table-ecomm-link:hover {
    color: black;
    text-decoration: none;
}

.dl-national-email {
    /* white-space:pre; */
    overflow: hidden;
    text-overflow: ellipsis;
}

.dl-national-email>a>span:hover {
    text-decoration: underline;
}

.dl-table-map-link {
    color: #ec4646;
    text-decoration: none;
    cursor: pointer;
}

.dl-table-map-link:hover {
    text-decoration: none;
    color: #ff7b7b;
}

.dl-national-info .ecomm {
    font-size: clamp(12px, 0.9vw, 14px);
}

.dl-btn-search-div {
    position: relative;
}

.dl-btn-search-div.cover-spin INPUT[TYPE=button] {
    color: transparent;
}

.dl-error-div {
    min-height: 25px;
    visibility: hidden;
}

.dealer-locator-form-error {
    color: #e96a59;
}

#modal_inner_div {
    min-height: 300px;
}

.modal-spinner {
    display: block;
    position: absolute;
    left: calc(50% - 50px);
    top: calc(50% - 50px);
    width: 100px;
    height: 100px;
    border-color: #007cba;
    border-style: solid;
    border-top-color: transparent;
    border-width: 6px;
    border-radius: 50%;
    animation: spin .8s linear infinite;
}

#exampleModalLongTitle {
    color: #007cba;
    font-size: clamp(16px, 1.1vw, 20px);
}

#dl_btn_contact_submit {
    background-color: #007cba;
}

input#dl_btn_contact_submit {
    width: 75px;
    bottom: 0;
    right: 0;
    position: absolute;
}

#dl_contact_modal .modal-header span {
    text-overflow: ellipsis;
    color: black;
    font-size: clamp(16px, 1.1vw, 20px);
}

#dl_contact_modal {
    padding-right: 0px !important;
}

#dl_maps_modal_title,
#dl_contact_modal_title {
    color: #007cba;
    font-weight: 600;
    font-size: clamp(16px, 1.1vw, 20px);
}

.dl-error-div {
    min-height: 25px;
    visibility: hidden;
}

.dealer-locator-form-error {
    color: #e96a59;
}

#modal_inner_div {
    min-height: 300px;
}

.modal-spinner {
    display: block;
    position: absolute;
    left: calc(50% - 50px);
    top: calc(50% - 50px);
    width: 100px;
    height: 100px;
    border-color: #007cba;
    border-style: solid;
    border-top-color: transparent;
    border-width: 6px;
    border-radius: 50%;
    animation: spin .8s linear infinite;
}

#dl_contact_modal_body {
    padding-top: 0px;
}

#dl_contact_modal_body .wpcf7-response-output {
    display: none !important;
}

#dl_contact_modal_body .wpcf7-form-control-wrap {
    display: inline-block;
    padding-top: 5px;
    width: 100%;
}

#dl_contact_modal input,
#dl_contact_modal textarea,
#dl_contact_modal label {
    width: 100%;
}

#dl_contact_modal textarea {
    max-height: 140px;
    min-height: 40px;
    height: 140px;
}

#dl_contact_modal .wpcf7-form .submit-wrapper {
    position: relative;
    border: 2px solid #025faf;
}

#dl_contact_modal .wpcf7-form .submit-wrapper INPUT {
    border: 0px;
}

#dl_contact_modal .wpcf7-form.submitting INPUT,
.wpcf7-form.submitting INPUT:hover {
    color: transparent;
    background: transparent;
}

#dl_contact_modal .wpcf7-form .submit-wrapper.cover-spin::after {
    content: '';
    display: none !important;
    position: absolute;
    top: calc(50% - 12px);
    left: calc(50% - 12px);
    width: 24px;
    height: 24px;
    border-color: #025faf;
    border-style: solid;
    border-top-color: transparent;
    border-width: 3px;
    border-radius: 50%;
    -webkit-animation: spin .8s linear infinite;
    animation: spin .8s linear infinite;
}

#dl_contact_modal .wpcf7-form.submitting .submit-wrapper.cover-spin::after {
    display: block !important;
}

#dl_contact_modal .dl_sent_success,
#dl_contact_modal .dl_sent_error {
    text-align: center;
    color: green;
    font-size: 1.1rem;
    padding: 25px 10px 10px 10px;
}

#dl_contact_modal .dl_sent_error {
    color: red;
}

span.wpcf7-list-item {
    display: block;
}

.wpcf7-form input[type=radio] {
    width: unset !important;
}

.dl-ref-title {
    text-align: center;
    padding: 0px 20px 20px 20px;
    text-transform: uppercase;
    font-size: clamp(16px, 1.3vw, 22px);
    color: #007cba;
}

.dl-left-col {
    padding-right: 30px;
}

.dl-right-col {
    padding-left: 30px;
}

@media (min-width: 992px) {

    /* keep national dealers visible while scrolling */
    .dl-right-col #dl_national_dealer_list_container {
        position: sticky;
        top: 20px;
    }
}

#dl_national_dealer_list_container {
    display: block !important;
    padding: 10px !important;
}

@media (min-width: 768px) {
    #dl_national_dealer_list_container {
        position: sticky;
        top: 90px;
    }
}

.dl-layout .dealer-locator-form {
    margin-bottom: 15px;
}

.pcs-full-width {
    width: 80%;
}

#dl_national_dealer_list_container>h4 {
    margin-top: 0px !important;
}

/* ==============================
   National Dealers – font sizes (clamp)
   ONLY font-size changes
   ============================== */

/* "National Dealers" title */
#dl_national_dealer_list_container > .dl-national-title{
  font-size: clamp(16px, 1.4vw, 20px);
  line-height: 1.2;
}

/* Dealer name inside blue bar */
#dl_national_dealer_list_container .dl-national-name > h4{
  font-size: clamp(13px, 1.1vw, 16px);
  line-height: 1.2;
}

/* All content text inside each dealer card */
#dl_national_dealer_list_container .dl-national-info,
#dl_national_dealer_list_container .dl-national-info p,
#dl_national_dealer_list_container .dl-national-info span,
#dl_national_dealer_list_container .dl-national-info a{
  font-size: clamp(12px, 1vw, 14px);
  line-height: 1.45;
}

/* "Address" label (fw-700) slightly stronger but not huge */
#dl_national_dealer_list_container .dl-national-info .fw-700{
  font-size: clamp(12px, 1vw, 13px);
}

/* Icons sometimes inherit bigger font, clamp them too */
#dl_national_dealer_list_container .dl-national-info i{
  font-size: clamp(12px, 1vw, 14px);
}

/* Improve table dealer name hierarchy */
#dl_table td:first-child {
  font-weight: 500;
}
#dl_national_dealer_list_container .dl-national-info {
  font-weight: 400;
}

/* Slightly soften table row separators */
#dl_table tr {
  border-color: rgba(0,0,0,0.06);
}

/* Slightly reduce intensity of card blue */
.dl-national-name {
  background-color: #176f98;
}
