/* ===================================================
   Snowminds Trip Listing – Frontend CSS v6
   Full isolation: all rules scoped to .sm-wrapper
   Explicit resets on every element to defeat theme CSS
   =================================================== */

/* ── Fonts ── */
@font-face {
    font-family: "DIN Next LT Pro";
    src: local("DIN Next LT Pro Bold"), local("DINNextLTPro-Bold"),
         url("https://booking.snowminds.com/fonts/DINNextLTPro-Bold.woff2") format("woff2"),
         url("https://booking.snowminds.com/fonts/DINNextLTPro-Bold.woff")  format("woff");
    font-weight: 700; font-style: normal; font-display: swap;
}
@font-face {
    font-family: "DIN Next LT Pro";
    src: local("DIN Next LT Pro Regular"), local("DINNextLTPro-Regular"),
         url("https://booking.snowminds.com/fonts/DINNextLTPro-Regular.woff2") format("woff2"),
         url("https://booking.snowminds.com/fonts/DINNextLTPro-Regular.woff")  format("woff");
    font-weight: 400; font-style: normal; font-display: swap;
}

/* ── Full reset inside wrapper ── */
.sm-wrapper,
.sm-wrapper *,
.sm-wrapper *::before,
.sm-wrapper *::after {
    box-sizing: border-box !important;
    -webkit-font-smoothing: antialiased;
}
.sm-wrapper {
    font-family: "DIN Next LT Pro", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
    font-size: 15px !important;
    line-height: 1.5 !important;
    color: #212529 !important;
    letter-spacing: normal !important;
    word-spacing: normal !important;
    text-transform: none !important;
    max-width: 1140px;
    margin: 0 auto;
}
.sm-wrapper h1,.sm-wrapper h2,.sm-wrapper h3,
.sm-wrapper h4,.sm-wrapper h5,.sm-wrapper h6 {
    font-family: "DIN Next LT Pro", sans-serif !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    margin: 0 !important;
    padding: 0 !important;
    letter-spacing: normal !important;
    word-spacing: normal !important;
    text-transform: none !important;
    color: #0e1925 !important;
}
.sm-wrapper p {
    font-family: "DIN Next LT Pro", sans-serif !important;
    margin: 0 !important;
    padding: 0 !important;
    letter-spacing: normal !important;
    word-spacing: normal !important;
    text-transform: none !important;
}
.sm-wrapper ul,.sm-wrapper li {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    letter-spacing: normal !important;
    columns: auto !important;
    column-count: 1 !important;
    -webkit-columns: auto !important;
}
.sm-wrapper figure,.sm-wrapper figcaption {
    margin: 0 !important;
    padding: 0 !important;
}
.sm-wrapper a {
    text-decoration: none !important;
    color: inherit !important;
}
.sm-wrapper img {
    max-width: 100% !important;
    height: auto !important;
    display: block !important;
}
.sm-wrapper span {
    letter-spacing: normal !important;
    word-spacing: normal !important;
    text-transform: none !important;
}

/* ── Results bar ── */
.sm-wrapper .sm-results-bar {
    font-family: "DIN Next LT Pro", sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #0e1925 !important;
    letter-spacing: normal !important;
    text-transform: none !important;
    margin-bottom: 16px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid #dee2e6 !important;
    display: block !important;
    width: 100%;
    line-height: 1.4 !important;
}
.sm-wrapper .sm-count-num { color: #0e1925 !important; font-weight: 700 !important; }

/* ── Filter bar ── */
.sm-wrapper .sm-filter-bar {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
    align-items: flex-end !important;
    background: #fff !important;
    border: 1px solid rgba(0,0,0,.05) !important;
    box-shadow: 2px 8px 12px 0 rgba(0,0,0,.04) !important;
    padding: 18px 20px !important;
    margin-bottom: 20px !important;
    border-radius: 2px !important;
}
.sm-wrapper .sm-filter-col {
    display: flex !important; flex-direction: column !important;
    gap: 5px !important; flex: 1 1 140px !important; min-width: 120px !important;
}
.sm-wrapper .sm-filter-label {
    font-family: "DIN Next LT Pro", sans-serif !important;
    font-size: 11px !important; font-weight: 700 !important;
    letter-spacing: .07em !important; text-transform: uppercase !important;
    color: #727374 !important; display: block !important;
}
.sm-wrapper .sm-select-wrap { position: relative !important; }
.sm-wrapper .sm-select {
    width: 100% !important; height: 42px !important;
    padding: 0 32px 0 10px !important;
    border: 1px solid #d2d2d2 !important; border-radius: 2px !important;
    font-family: "DIN Next LT Pro", sans-serif !important;
    font-size: 13px !important; color: #0e1925 !important;
    background: #fff !important;
    appearance: none !important; -webkit-appearance: none !important;
    cursor: pointer !important; letter-spacing: normal !important;
}
.sm-wrapper .sm-select:focus { outline: none !important; border-color: #ee9846 !important; }
.sm-wrapper .sm-chevron {
    position: absolute !important; right: 8px !important;
    top: 50% !important; transform: translateY(-50%) !important;
    width: 20px !important; height: 20px !important;
    pointer-events: none !important; fill: #ee9846 !important;
}

/* ── Grid ── */
.sm-wrapper .sm-grid { display: flex !important; flex-direction: column !important; gap: 0 !important; }
.sm-wrapper .sm-cols-2 { display: grid !important; grid-template-columns: repeat(2,1fr) !important; gap: 15px !important; }
.sm-wrapper .sm-cols-3 { display: grid !important; grid-template-columns: repeat(3,1fr) !important; gap: 15px !important; }
@media (max-width: 900px) { .sm-wrapper .sm-cols-3 { grid-template-columns: repeat(2,1fr) !important; } }
@media (max-width: 600px) {
    .sm-wrapper .sm-cols-2, .sm-wrapper .sm-cols-3 { grid-template-columns: 1fr !important; }
}

/* ── Card shell ── */
.sm-wrapper .cards {
    margin: 10px 0 !important; border-radius: 2px !important;
    box-shadow: 2px 8px 12px 0 rgba(0,0,0,.06) !important;
    background-color: #fff !important; display: block !important;
    width: 100% !important; position: relative !important;
    overflow: hidden !important; float: none !important;
}
.sm-wrapper .sm-cols-2 .cards,
.sm-wrapper .sm-cols-3 .cards { margin: 0 !important; }

.sm-wrapper .cards-wrapper { display: block !important; width: 100% !important; float: none !important; }

/* Figure direction */
.sm-wrapper .sm-grid .cards-wrapper figure {
    display: flex !important; flex-direction: row !important;
    flex-wrap: nowrap !important; align-items: stretch !important;
}
.sm-wrapper .sm-cols-2 .cards-wrapper figure,
.sm-wrapper .sm-cols-3 .cards-wrapper figure {
    display: flex !important; flex-direction: column !important; flex-wrap: nowrap !important;
}

/* ── Image ── */
.sm-wrapper .card-image {
    position: relative !important; overflow: hidden !important;
    flex-shrink: 0 !important; background: #e8e8e8 !important; display: block !important;
}
/* 1-col: fixed min-height */
.sm-wrapper .sm-grid .card-image {
    width: 29% !important; min-width: 29% !important; min-height: 260px !important; height: auto !important;
}
/* multi-col: padding-top trick = reliable aspect ratio regardless of theme */
.sm-wrapper .sm-cols-2 .card-image,
.sm-wrapper .sm-cols-3 .card-image {
    width: 100% !important; min-width: 0 !important;
    height: 0 !important; min-height: 0 !important; padding-top: 56% !important;
}
.sm-wrapper .image-for-card {
    position: absolute !important;
    top: 0 !important; right: 0 !important; bottom: 0 !important; left: 0 !important;
    width: 100% !important; height: 100% !important;
    background-repeat: no-repeat !important; background-size: cover !important;
    background-position: center !important; background-color: #e8e8e8 !important;
    transition: transform .8s ease !important; display: block !important;
}
.sm-wrapper .cards:hover .image-for-card { transform: scale(1.03) !important; }

@media (max-width: 991px) {
    .sm-wrapper .sm-grid .cards-wrapper figure { flex-direction: column !important; }
    .sm-wrapper .sm-grid .card-image {
        width: 100% !important; min-width: 0 !important;
        min-height: 0 !important; height: 0 !important; padding-top: 56% !important;
    }
}

/* ── Figcaption ── */
.sm-wrapper figcaption {
    display: flex !important; flex-direction: column !important;
    flex: 1 !important; min-width: 0 !important;
    padding: 20px 22px !important; background: #fff !important;
}
.sm-wrapper .sm-grid figcaption { max-width: 71% !important; }
.sm-wrapper .sm-cols-2 figcaption,
.sm-wrapper .sm-cols-3 figcaption { max-width: 100% !important; padding: 16px !important; }
@media (max-width: 991px) { .sm-wrapper .sm-grid figcaption { max-width: 100% !important; } }

/* ── Card content ── */
.sm-wrapper .card-content { display: block !important; width: 100% !important; float: none !important; }
.sm-wrapper .grouped-item { display: block !important; width: 100% !important; float: none !important; }

/* ── Card head ── */
.sm-wrapper .card-head {
    display: flex !important; align-items: flex-start !important;
    gap: 8px !important; margin-bottom: 10px !important; float: none !important;
}
.sm-wrapper .sm-grid .card-head { flex-direction: row !important; flex-wrap: nowrap !important; }
.sm-wrapper .sm-grid .card-head .heading {
    flex: 1 !important; min-width: 0 !important;
    max-width: 55% !important; float: none !important; padding-right: 8px !important;
}
.sm-wrapper .sm-grid .price-wrapper {
    flex-shrink: 0 !important; max-width: 45% !important;
    text-align: right !important; float: none !important;
}
.sm-wrapper .sm-cols-2 .card-head,
.sm-wrapper .sm-cols-3 .card-head { flex-direction: column !important; gap: 4px !important; }
.sm-wrapper .sm-cols-2 .card-head .heading,
.sm-wrapper .sm-cols-3 .card-head .heading { max-width: 100% !important; padding-right: 0 !important; float: none !important; }
.sm-wrapper .sm-cols-2 .price-wrapper,
.sm-wrapper .sm-cols-3 .price-wrapper { max-width: 100% !important; text-align: left !important; float: none !important; }
@media (max-width: 991px) {
    .sm-wrapper .sm-grid .card-head { flex-direction: column !important; }
    .sm-wrapper .sm-grid .card-head .heading { max-width: 100% !important; padding-right: 0 !important; }
    .sm-wrapper .sm-grid .price-wrapper { max-width: 100% !important; text-align: left !important; }
}

/* Destination + title */
.sm-wrapper .card-head .heading p {
    font-family: "DIN Next LT Pro", sans-serif !important;
    font-size: 13px !important; font-weight: 600 !important;
    color: #0e1925 !important; text-transform: none !important;
    letter-spacing: normal !important; margin-bottom: 4px !important;
    line-height: 1.3 !important; display: block !important;
}
.sm-wrapper .card-head .heading h2 {
    font-family: "DIN Next LT Pro", sans-serif !important;
    font-size: 17px !important; font-weight: 700 !important;
    color: #0e1925 !important; text-transform: none !important;
    letter-spacing: normal !important; word-spacing: normal !important;
    line-height: 1.25 !important; margin: 0 !important;
}
.sm-wrapper .sm-cols-2 .card-head .heading h2,
.sm-wrapper .sm-cols-3 .card-head .heading h2 { font-size: 15px !important; }

/* ── Price block ── */
.sm-wrapper .price-wrapper { display: block !important; float: none !important; }
.sm-wrapper .price-wrapper .price { display: block !important; float: none !important; }

.sm-wrapper .text-string-field { display: block !important; margin-bottom: 2px !important; }
.sm-wrapper .sm-grid .text-string-field { text-align: right !important; }
.sm-wrapper .sm-cols-2 .text-string-field,
.sm-wrapper .sm-cols-3 .text-string-field { text-align: left !important; }
.sm-wrapper .text-string-field p {
    font-family: "DIN Next LT Pro", sans-serif !important;
    font-size: 13px !important; font-weight: 700 !important;
    color: #0e1925 !important; text-transform: none !important;
    letter-spacing: normal !important; line-height: 1.3 !important;
    display: block !important; margin: 0 !important;
}
.sm-wrapper .pricelabelyellow {
    font-family: "DIN Next LT Pro", sans-serif !important;
    font-size: 24px !important; font-weight: 700 !important;
    color: #ee9846 !important; text-transform: none !important;
    letter-spacing: normal !important; word-spacing: normal !important;
    line-height: 1.1 !important; margin: 2px 0 4px !important;
    padding: 0 !important; display: block !important;
}
.sm-wrapper .price-wrapper .price > span {
    font-family: "DIN Next LT Pro", sans-serif !important;
    font-size: 12px !important; font-weight: 400 !important;
    color: #727374 !important; text-transform: none !important;
    letter-spacing: normal !important; display: block !important;
}

/* ── Card body ── */
.sm-wrapper .card-body {
    display: block !important; width: 100% !important;
    float: none !important; clear: both !important; margin-bottom: 10px !important;
}

/* ── Badges ── */
.sm-wrapper .catogoty-tag-wrapper {
    display: flex !important; flex-wrap: wrap !important;
    gap: 6px !important; width: 100% !important;
    margin-bottom: 10px !important; float: none !important;
}
.sm-wrapper .cateogry-tag {
    font-family: "DIN Next LT Pro", sans-serif !important;
    font-size: 12px !important; font-weight: 500 !important;
    color: #fff !important; padding: 5px 10px !important;
    display: inline-block !important; float: none !important;
    border: none !important; line-height: 1.3 !important;
    letter-spacing: normal !important; text-transform: none !important;
    margin: 0 !important; border-radius: 1px !important;
}

/* ── Facts list ── */
.sm-wrapper .description { display: block !important; float: none !important; clear: both !important; }
.sm-wrapper .list-details { margin-top: 8px !important; float: none !important; clear: both !important; }
.sm-wrapper .list-details ul {
    list-style: none !important; padding: 0 0 0 32px !important;
    margin: 0 !important; float: none !important;
    columns: 1 !important; column-count: 1 !important; -webkit-columns: 1 !important;
    display: block !important;
}
.sm-wrapper .list-details ul li {
    font-family: "DIN Next LT Pro", sans-serif !important;
    font-size: 14px !important; font-weight: 400 !important;
    color: #727374 !important; position: relative !important;
    margin-bottom: 9px !important; padding-left: 0 !important;
    line-height: 1.4 !important; letter-spacing: normal !important;
    text-transform: none !important; display: block !important;
    float: none !important; word-spacing: normal !important;
    columns: auto !important; column-count: auto !important;
}
.sm-wrapper .list-details ul li::before {
    content: "" !important; display: block !important;
    position: absolute !important; left: -32px !important; top: 2px !important;
    width: 20px !important; height: 20px !important;
    border-radius: 50% !important; background-color: #ee9846 !important;
    border: none !important;
}
.sm-wrapper .list-details ul li::after {
    content: "" !important; display: block !important;
    position: absolute !important; left: -25px !important; top: 7px !important;
    width: 5px !important; height: 9px !important;
    border: solid #fff !important; border-width: 0 2px 2px 0 !important;
    transform: rotate(45deg) !important; background: transparent !important;
}

/* ── Card footer ── */
.sm-wrapper .card-footer {
    display: block !important; width: 100% !important;
    float: none !important; clear: both !important;
    margin-top: auto !important; padding-top: 12px !important;
    border-top: 1px solid rgba(0,0,0,.08) !important;
}
.sm-wrapper .selected-wrappers {
    display: flex !important; justify-content: flex-end !important;
    width: 100% !important; float: none !important;
}
.sm-wrapper .content-block.card-btn { float: none !important; width: auto !important; padding: 0 !important; margin: 0 !important; }

/* CTA button */
.sm-wrapper .custom-btn {
    display: inline-block !important; padding: 12px 24px !important;
    background-color: #ee9846 !important;
    font-family: "DIN Next LT Pro", sans-serif !important;
    font-size: 14px !important; font-weight: 700 !important;
    color: #fff !important; text-decoration: none !important;
    text-transform: none !important; letter-spacing: normal !important;
    border-radius: 0 !important; border: none !important;
    box-shadow: 2px 5px 8px 0 rgba(255,153,51,.15) !important;
    cursor: pointer !important; float: none !important;
    min-width: 190px !important; text-align: center !important;
    transition: background-color .3s ease !important; line-height: 1.4 !important;
}
.sm-wrapper .sm-cols-2 .custom-btn,
.sm-wrapper .sm-cols-3 .custom-btn { width: 100% !important; min-width: 0 !important; }
.sm-wrapper .custom-btn:hover { background-color: #cf8b4b !important; color: #fff !important; }
.sm-wrapper .custom-btn span {
    position: relative !important; z-index: 1 !important;
    text-transform: none !important; letter-spacing: normal !important;
}

/* ── Loader ── */
.sm-wrapper .sm-loader {
    display: flex !important; flex-direction: column !important;
    align-items: center !important; gap: 10px !important;
    padding: 40px !important;
    font-family: "DIN Next LT Pro", sans-serif !important;
    font-size: 15px !important; color: #727374 !important; letter-spacing: normal !important;
}
.sm-wrapper .sm-spinner {
    width: 36px !important; height: 36px !important;
    border: 3px solid #e8e8e8 !important; border-top-color: #ee9846 !important;
    border-radius: 50% !important; animation: smSpin .8s linear infinite !important;
    flex-shrink: 0 !important;
}
@keyframes smSpin { to { transform: rotate(360deg); } }

/* ── Status ── */
.sm-wrapper .sm-no-results,
.sm-wrapper .sm-error {
    padding: 20px !important;
    font-family: "DIN Next LT Pro", sans-serif !important;
    font-size: 15px !important; color: #727374 !important;
    text-align: center !important; letter-spacing: normal !important;
}
.sm-wrapper .sm-error { color: #dc2828 !important; }
