/* ===========================
   Case Apimo – Modern UI
   Split layout · Bigger cards · Agent · Contact · Carousel
   =========================== */
:root {
    --ca-accent: #2563eb;
    --ca-accent-dark: #1d4ed8;
    --ca-gray-900: #111827;
    --ca-gray-700: #374151;
    --ca-gray-500: #6b7280;
    --ca-gray-300: #d1d5db;
    --ca-gray-100: #f3f4f6;
    --ca-gray-50:  #f9fafb;
    --ca-radius: 0px;
    --ca-radius-sm: 0px;
    --ca-shadow: 0 2px 12px rgba(0,0,0,.08);
    --ca-shadow-lg: 0 10px 30px rgba(0,0,0,.12);
    --ca-font: 'Lato', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

/* ===========================
   CSS ISOLATION / RESET
   Prevents Avada & other themes from overriding plugin styles
   =========================== */

/* Base box-sizing for all elements */
.ca,
.ca *,
.ca *::before,
.ca *::after,
.ca-carousel,
.ca-carousel *,
.ca-carousel *::before,
.ca-carousel *::after,
.ca-modal,
.ca-modal *,
.ca-modal *::before,
.ca-modal *::after {
    box-sizing: border-box !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Reset typography - Avada often overrides these */
.ca h1, .ca h2, .ca h3, .ca h4, .ca h5, .ca h6,
.ca-carousel h1, .ca-carousel h2, .ca-carousel h3, .ca-carousel h4, .ca-carousel h5, .ca-carousel h6,
.ca-modal h1, .ca-modal h2, .ca-modal h3, .ca-modal h4, .ca-modal h5, .ca-modal h6 {
    font-family: var(--ca-font) !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    letter-spacing: normal !important;
    text-transform: none !important;
    color: inherit;
}

.ca p, .ca span, .ca a, .ca div, .ca label,
.ca-carousel p, .ca-carousel span, .ca-carousel a, .ca-carousel div, .ca-carousel label,
.ca-modal p, .ca-modal span, .ca-modal a, .ca-modal div, .ca-modal label {
    font-family: var(--ca-font) !important;
    line-height: 1.5 !important;
    letter-spacing: normal !important;
    text-transform: none !important;
}

/* Reset links - Avada applies aggressive link styles */
.ca a,
.ca-carousel a,
.ca-modal a {
    color: inherit;
    text-decoration: none !important;
    border-bottom: none !important;
    box-shadow: none !important;
    background-image: none !important;
}

.ca a:hover,
.ca-carousel a:hover,
.ca-modal a:hover {
    text-decoration: none !important;
    border-bottom: none !important;
}

/* Reset form elements - prevent Avada overrides */
.ca button,
.ca input,
.ca select,
.ca textarea,
.ca-carousel button,
.ca-carousel input,
.ca-carousel select,
.ca-carousel textarea,
.ca-modal button,
.ca-modal input,
.ca-modal select,
.ca-modal textarea {
    font-family: var(--ca-font) !important;
    line-height: 1.5 !important;
    border-radius: 0 !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
}

/* Reset images - prevent Avada border/shadow */
.ca img,
.ca-carousel img,
.ca-modal img {
    max-width: 100%;
    height: auto;
    border: none !important;
    box-shadow: none !important;
}

/* Prevent Avada column/row wrappers from affecting layout */
.fusion-builder-row .ca,
.fusion-column-wrapper .ca,
.fusion-layout-column .ca,
.fusion-builder-row .ca-carousel,
.fusion-column-wrapper .ca-carousel,
.fusion-layout-column .ca-carousel {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: auto !important;
    margin-right: auto !important;
    float: none !important;
}

/* Override Avada flex containers */
.fusion-flex-container .ca,
.fusion-flex-container .ca-carousel {
    flex: 0 0 100% !important;
    max-width: 100% !important;
}

/* ===========================
   App wrapper
   =========================== */
.ca {
    max-width: 1440px;
    margin: 0 auto;
    padding: 24px 16px;
    font-family: var(--ca-font) !important;
    color: var(--ca-gray-700);
    line-height: 1.5;
    background: transparent;
}

/* ===========================
   Search / Filter Bar
   =========================== */
.ca .ca-search {
    background: #fff !important;
    border-radius: var(--ca-radius) !important;
    box-shadow: var(--ca-shadow) !important;
    padding: 0 !important;
    margin-bottom: 20px !important;
    overflow: hidden !important;
}

/* -- Top row: search + pill selects -- */
.ca .ca-search__top {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    align-items: center !important;
    padding: 16px 20px !important;
}

.ca .ca-search__field {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
}
.ca .ca-search__field--grow { flex: 1 !important; min-width: 220px !important; }

.ca .ca-search__icon {
    position: absolute !important;
    left: 14px !important;
    width: 18px !important;
    height: 18px !important;
    color: var(--ca-gray-500) !important;
    pointer-events: none !important;
}

.ca .ca-search__field .ca-search__input {
    padding-left: 40px !important;
}

.ca .ca-search__input {
    width: 100% !important;
    padding: 11px 16px !important;
    border: 1.5px solid var(--ca-gray-300) !important;
    border-radius: var(--ca-radius-sm) !important;
    font-size: 14px !important;
    outline: none !important;
    transition: border-color .2s, box-shadow .2s !important;
    background: var(--ca-gray-50) !important;
    font-family: var(--ca-font) !important;
}
.ca .ca-search__input:focus {
    border-color: var(--ca-accent) !important;
    box-shadow: 0 0 0 3px rgba(37,99,235,.1) !important;
    background: #fff !important;
}

/* Pill-style select wrappers */
.ca .ca-search__pill {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 0 4px 0 12px !important;
    border: 1.5px solid var(--ca-gray-300) !important;
    border-radius: var(--ca-radius-sm) !important;
    background: var(--ca-gray-50) !important;
    transition: border-color .2s !important;
    cursor: pointer !important;
}
.ca .ca-search__pill:focus-within {
    border-color: var(--ca-accent) !important;
}
.ca .ca-search__pill svg {
    flex-shrink: 0 !important;
    color: var(--ca-gray-500) !important;
}
.ca .ca-search__pill .ca-search__select {
    border: none !important;
    background: transparent !important;
    padding: 11px 10px 11px 4px !important;
    min-width: 100px !important;
    font-size: 14px !important;
}

.ca-search__select {
    padding: 11px 14px;
    border: 1.5px solid var(--ca-gray-300);
    border-radius: var(--ca-radius-sm);
    font-size: 14px;
    font-family: var(--ca-font);
    background: var(--ca-gray-50);
    outline: none;
    min-width: 100%;
    cursor: pointer;
    transition: border-color .2s;
    color: var(--ca-gray-700);
}
.ca-search__select:focus { border-color: var(--ca-accent); }

/* -- Filters row -- */
.ca-search__filters {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: stretch;
    padding: 16px 20px;
    background: var(--ca-gray-50);
    border-top: 1px solid var(--ca-gray-100);
}

/* Filter cards */
.ca-filter-card {
    flex: 1 1 220px;
    min-width: 200px;
    background: #fff;
    border: 1px solid var(--ca-gray-200, #e5e7eb);
    border-radius: var(--ca-radius);
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    transition: border-color .2s, box-shadow .2s;
}
.ca-filter-card:hover,
.ca-filter-card:focus-within {
    border-color: var(--ca-accent);
    box-shadow: 0 0 0 3px rgba(37,99,235,.06);
}
.ca-filter-card--compact {
    flex: 0 1 150px;
    min-width: 130px;
}

.ca-filter-card__head {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 700;
    color: var(--ca-gray-500);
    text-transform: uppercase;
    letter-spacing: .04em;
}
.ca-filter-card__head svg {
    flex-shrink: 0;
    color: var(--ca-accent);
    opacity: .8;
}

.ca-filter-card .ca-search__select {
    border: 1.5px solid var(--ca-gray-200, #e5e7eb);
    border-radius: 0;
    padding: 9px 12px;
    background: var(--ca-gray-50);
}

/* ----- Range Slider ----- */
.ca-range-slider {
    width: 100%;
}
.ca-range-slider__values {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 13px;
    font-weight: 600;
    color: var(--ca-gray-700);
    margin-bottom: 4px;
    gap: 6px;
}
.ca-range-slider__dash { color: var(--ca-gray-300); font-weight: 400; }
.ca-range-slider__track-wrap {
    position: relative;
    height: 28px;
    display: flex;
    align-items: center;
}
.ca-range-slider__track {
    position: absolute;
    left: 0; right: 0;
    height: 4px;
    background: var(--ca-gray-200, #e5e7eb);
    border-radius: 0;
    pointer-events: none;
}
.ca-range-slider__fill {
    position: absolute;
    height: 100%;
    background: var(--ca-accent);
    border-radius: 0;
}
.ca-range-slider__input {
    -webkit-appearance: none;
    appearance: none;
    position: absolute;
    width: 100%;
    height: 28px;
    background: none;
    pointer-events: none;
    margin: 0;
    padding: 0;
}
.ca-range-slider__input::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--ca-accent);
    border: 2.5px solid #fff;
    box-shadow: 0 1px 4px rgba(0,0,0,.2);
    cursor: pointer;
    pointer-events: auto;
    position: relative;
    z-index: 2;
    margin-top: -7px;
    transition: transform .15s;
}
.ca-range-slider__input::-webkit-slider-thumb:hover {
    transform: scale(1.15);
}
.ca-range-slider__input::-moz-range-thumb {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--ca-accent);
    border: 2.5px solid #fff;
    box-shadow: 0 1px 4px rgba(0,0,0,.2);
    cursor: pointer;
    pointer-events: auto;
}
.ca-range-slider__input::-webkit-slider-runnable-track {
    background: transparent;
    height: 4px;
    cursor: pointer;
}
.ca-range-slider__input::-moz-range-track {
    background: transparent;
    height: 4px;
    border: none;
    cursor: pointer;
}

/* Reset button */
.ca-search__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 20px;
    border: none;
    border-radius: var(--ca-radius-sm);
    font-size: 13px;
    font-weight: 600;
    font-family: var(--ca-font);
    cursor: pointer;
    transition: background .2s, color .2s, box-shadow .2s;
    white-space: nowrap;
    align-self: flex-end;
}
.ca-search__btn svg { flex-shrink: 0; }
.ca-search__btn--reset {
    background: #fff;
    color: var(--ca-gray-600, #4b5563);
    border: 1.5px solid var(--ca-gray-300);
}
.ca-search__btn--reset:hover {
    background: var(--ca-gray-100);
    border-color: var(--ca-gray-400, #9ca3af);
}

/* ===========================
   LAYOUT – Map left / List right
   =========================== */
.ca-layout {
    display: flex;
    gap: 20px;
    min-height: 75vh;
}

.ca-layout__map {
    flex: 0 0 50%;
    position: sticky;
    top: 80px;
    height: calc(100vh - 100px);
    border-radius: var(--ca-radius);
    overflow: hidden;
    box-shadow: var(--ca-shadow);
}

.ca-map {
    width: 100%;
    height: 100%;
    z-index: 1;
}

.ca-layout__list {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
}

/* Results bar */
.ca-results-bar {
    font-size: 14px;
    color: var(--ca-gray-500);
    margin-bottom: 12px;
}
.ca-results-bar__count span { font-weight: 700; color: var(--ca-gray-900); }

/* ===========================
   Grid (inside list panel) – 1 per row
   =========================== */
.ca-grid {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* ===========================
   CARD – Horizontal layout, big image
   =========================== */
.ca .ca-card {
    background: #fff !important;
    border-radius: var(--ca-radius) !important;
    box-shadow: var(--ca-shadow) !important;
    overflow: hidden !important;
    transition: transform .25s ease, box-shadow .25s ease !important;
    cursor: pointer !important;
    display: flex !important;
    flex-direction: row !important;
    border: none !important;
}
.ca .ca-card:hover {
    transform: translateY(-3px) !important;
    box-shadow: var(--ca-shadow-lg) !important;
}

.ca .ca-card__img {
    position: relative !important;
    flex: 0 0 45% !important;
    min-height: 240px !important;
    overflow: hidden !important;
}
.ca .ca-card__img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    transition: transform .4s ease !important;
    border-radius: 0 !important;
}
.ca .ca-card:hover .ca-card__img img {
    transform: scale(1.05) !important;
}
.ca .ca-card__img--empty {
    background: var(--ca-gray-100) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: var(--ca-gray-500) !important;
    font-size: 14px !important;
}

.ca .ca-card__badge {
    position: absolute !important;
    top: 12px !important;
    left: 12px !important;
    background: var(--ca-accent) !important;
    color: #fff !important;
    padding: 4px 14px !important;
    border-radius: var(--ca-radius-sm) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .5px !important;
}

.ca .ca-card__body {
    padding: 22px 24px !important;
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    background: #fff !important;
}

.ca .ca-card__label {
    display: inline-block !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    color: var(--ca-gray-500) !important;
    text-transform: uppercase !important;
    letter-spacing: .5px !important;
    margin-bottom: 4px !important;
}

.ca .ca-card__title {
    font-size: 17px !important;
    font-weight: 700 !important;
    color: var(--ca-gray-900) !important;
    margin: 0 0 4px !important;
    line-height: 1.3 !important;
}

.ca .ca-card__location {
    font-size: 13px !important;
    color: var(--ca-gray-500) !important;
    margin: 0 0 10px !important;
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
}
.ca .ca-card__location svg { flex-shrink: 0 !important; }

.ca .ca-card__price {
    font-size: 24px !important;
    font-weight: 800 !important;
    color: var(--ca-accent) !important;
    margin-bottom: 14px !important;
}

.ca .ca-card__meta {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 14px !important;
    padding-top: 12px !important;
    border-top: 1px solid var(--ca-gray-100) !important;
    font-size: 13px !important;
    color: var(--ca-gray-500) !important;
}
.ca .ca-card__meta strong {
    color: var(--ca-gray-900) !important;
}

/* ===========================
   MODAL
   =========================== */
.ca-modal {
    position: fixed;
    inset: 0;
    z-index: 100000;
    display: flex;
    align-items: center;
    justify-content: center;
}

.ca-modal__overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.55);
    backdrop-filter: blur(6px);
}

.ca-modal__panel {
    position: relative;
    background: #fff;
    border-radius: var(--ca-radius);
    max-width: 1200px;
    width: 98vw;
    max-height: 96vh;
    overflow-y: auto;
    overflow-x: hidden;
    z-index: 1;
    box-shadow: 0 24px 64px rgba(0,0,0,.25);
}

.ca-modal__close {
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 2;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: none;
    background: rgba(0,0,0,.5);
    color: #fff;
    font-size: 24px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .2s;
    line-height: 1;
}
.ca-modal__close:hover { background: rgba(0,0,0,.8); }

.ca-modal__body {
    overflow: hidden;
}

/* ===========================
   DETAIL – Inside modal
   =========================== */
.ca-detail__gallery {
    margin-bottom: 0;
    position: relative;
}

.ca-detail__main-image {
    width: 100%;
    height: 440px;
    overflow: hidden;
    border-radius: var(--ca-radius) var(--ca-radius) 0 0;
    position: relative;
}
.ca-detail__main-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: opacity .25s;
}

/* Gallery arrows */
.ca-gallery__arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 3;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: none;
    background: rgba(255,255,255,.85);
    color: var(--ca-gray-900);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 8px rgba(0,0,0,.18);
    transition: background .2s, transform .2s;
    backdrop-filter: blur(4px);
}
.ca-gallery__arrow svg { width: 20px; height: 20px; }
.ca-gallery__arrow:hover {
    background: #fff;
    transform: translateY(-50%) scale(1.08);
}
.ca-gallery__arrow--prev { left: 14px; }
.ca-gallery__arrow--next { right: 14px; }

/* Gallery counter */
.ca-gallery__counter {
    position: absolute;
    bottom: 14px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
    background: rgba(0,0,0,.55);
    color: #fff;
    padding: 4px 14px;
    border-radius: var(--ca-radius-sm);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: .5px;
    backdrop-filter: blur(4px);
}

.ca-detail__thumbs {
    display: flex;
    gap: 8px;
    padding: 12px 24px;
    overflow-x: auto;
}
.ca-detail__thumb {
    width: 76px;
    height: 56px;
    object-fit: cover;
    border-radius: 0;
    cursor: pointer;
    opacity: .55;
    transition: opacity .2s, outline .2s;
    flex-shrink: 0;
}
.ca-detail__thumb:hover,
.ca-detail__thumb--active {
    opacity: 1;
    outline: 2px solid var(--ca-accent);
    outline-offset: 2px;
}

.ca-detail__content {
    padding: 28px;
    overflow: hidden;
    box-sizing: border-box;
    max-width: 100%;
}

.ca-detail__info { margin-bottom: 24px; }

/* Header: tags + reference */
.ca-detail__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}

.ca-detail__tags {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.ca-detail__badge {
    display: inline-block;
    background: var(--ca-accent);
    color: #fff;
    padding: 4px 14px;
    border-radius: var(--ca-radius-sm);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
}

.ca-detail__type-tag {
    display: inline-block;
    background: var(--ca-gray-100);
    color: var(--ca-gray-700);
    padding: 4px 14px;
    border-radius: var(--ca-radius-sm);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
}

.ca-detail__title {
    font-size: 26px;
    font-weight: 800;
    color: var(--ca-gray-900);
    margin: 0 0 6px;
    line-height: 1.25;
}

.ca-detail__share {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0 0 12px;
    flex-wrap: wrap;
}

.ca-detail__share-btn {
    appearance: none;
    border: 1px solid var(--ca-gray-300);
    background: #fff;
    color: var(--ca-gray-800);
    border-radius: var(--ca-radius-sm);
    padding: 8px 12px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .3px;
    cursor: pointer;
    transition: border-color .15s, color .15s, background .15s;
}

.ca-detail__share-btn:hover {
    border-color: var(--ca-accent);
    color: var(--ca-accent);
    background: var(--ca-gray-50);
}

.ca-detail__share-status {
    font-size: 12px;
    color: #15803d;
    min-height: 1em;
}

.ca-detail__share-status--error {
    color: #dc2626;
}

/* Reference number */
.ca-detail__ref {
    font-size: 12px;
    color: var(--ca-gray-500);
    font-weight: 600;
    white-space: nowrap;
    background: var(--ca-gray-50);
    padding: 4px 10px;
    border-radius: 0;
    letter-spacing: .3px;
}

/* Location (city · district · zip) */
.ca-detail__location {
    font-size: 14px;
    color: var(--ca-gray-500);
    margin: 0 0 14px;
    display: flex;
    align-items: center;
    gap: 5px;
}
.ca-detail__location svg { flex-shrink: 0; }

.ca-detail__city {
    font-size: 14px;
    color: var(--ca-gray-500);
    margin: 0 0 12px;
    display: flex;
    align-items: center;
    gap: 5px;
}
.ca-detail__city svg { flex-shrink: 0; }

/* Price section */
.ca-detail__price-section {
    margin-bottom: 18px;
}

.ca-detail__price {
    font-size: 30px;
    font-weight: 800;
    color: var(--ca-accent);
    margin-bottom: 4px;
}

/* Price details (fees, commission, deposit) */
.ca-detail__pd {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 16px;
    margin-top: 4px;
}
.ca-detail__pd-item {
    font-size: 13px;
    color: var(--ca-gray-600);
}
.ca-detail__pd-item strong {
    font-weight: 600;
    color: var(--ca-gray-700);
}

.ca-detail__specs {
    display: flex;
    gap: 20px;
    margin-bottom: 20px;
    padding: 18px 0;
    border-top: 1px solid var(--ca-gray-100);
    border-bottom: 1px solid var(--ca-gray-100);
    flex-wrap: wrap;
}
.ca-detail__spec {
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 80px;
    gap: 4px;
}
.ca-detail__spec-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: var(--ca-radius);
    background: var(--ca-gray-50);
    color: var(--ca-accent);
    margin-bottom: 2px;
}
.ca-detail__spec-icon svg {
    stroke: var(--ca-accent);
}
.ca-detail__spec-val {
    display: block;
    font-size: 20px;
    font-weight: 700;
    color: var(--ca-gray-900);
    line-height: 1.2;
}
.ca-detail__spec-val small {
    font-size: 13px;
    font-weight: 500;
    color: var(--ca-gray-500);
}
.ca-detail__spec-lbl {
    display: block;
    font-size: 11px;
    color: var(--ca-gray-500);
    text-transform: uppercase;
    letter-spacing: .5px;
}

.ca-detail__desc { margin-top: 16px; }
.ca-detail__desc h3 {
    font-size: 16px;
    font-weight: 700;
    color: var(--ca-gray-900);
    margin: 0 0 8px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.ca-detail__desc h3 svg {
    flex-shrink: 0;
    stroke: var(--ca-accent);
}
.ca-detail__desc p {
    font-size: 14px;
    color: var(--ca-gray-700);
    line-height: 1.7;
    margin: 0 0 12px;
    word-wrap: break-word;
    overflow-wrap: break-word;
}
.ca-detail__desc p:last-child { margin-bottom: 0; }

/* Description header (title + lang selector) */
.ca-detail__desc-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}
.ca-detail__desc-header h3 { margin: 0; }

/* Description title (from comments) */
.ca-detail__desc-title {
    font-size: 15px;
    font-weight: 600;
    color: var(--ca-gray-900);
    margin-bottom: 8px;
}
.ca-detail__desc-title:empty { display: none; }

/* Language selector buttons */
#ca-lang-selector {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
}
.ca-lang-btn {
    display: inline-block;
    padding: 4px 10px;
    font-size: 12px;
    font-weight: 600;
    font-family: var(--ca-font);
    border: 1px solid var(--ca-gray-300);
    background: #fff;
    color: var(--ca-gray-600);
    cursor: pointer;
    transition: all .15s;
    text-transform: uppercase;
    letter-spacing: .3px;
}
.ca-lang-btn:hover {
    border-color: var(--ca-accent);
    color: var(--ca-accent);
}
.ca-lang-btn--active {
    background: var(--ca-accent);
    border-color: var(--ca-accent);
    color: #fff;
}
.ca-lang-btn--active:hover {
    color: #fff;
}

/* Regulations section */
.ca-detail__regs-section { margin-top: 20px; }
.ca-detail__regs-section h3 {
    font-size: 16px;
    font-weight: 700;
    color: var(--ca-gray-900);
    margin: 0 0 12px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.ca-detail__regs-section h3 svg {
    flex-shrink: 0;
    stroke: var(--ca-accent);
}
.ca-detail__regs-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 10px;
}
.ca-detail__reg-item {
    display: flex;
    flex-direction: column;
    padding: 12px 14px;
    background: var(--ca-gray-50);
    border: 1px solid var(--ca-gray-200);
}
.ca-detail__reg-name {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: var(--ca-gray-500);
    margin-bottom: 4px;
}
.ca-detail__reg-value {
    font-size: 16px;
    font-weight: 700;
    color: var(--ca-gray-900);
}
.ca-detail__reg-date {
    font-size: 11px;
    color: var(--ca-gray-400);
    margin-top: 2px;
}

/* APE badge (energy label) */
.ca-ape-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    height: 44px;
    font-size: 16px;
    font-weight: 700;
    color: #fff;
    background: var(--ca-accent);
    padding: 0 8px;
}

/* ===========================
   MODAL SECTIONS (buyer view)
   =========================== */

/* Section headings */
.ca-detail__section {
    margin-top: 24px;
    padding-top: 24px;
    border-top: 1px solid var(--ca-gray-100);
}
.ca-detail__section h3 {
    font-size: 16px;
    font-weight: 700;
    color: var(--ca-gray-900);
    margin: 0 0 14px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.ca-detail__section h3 svg {
    flex-shrink: 0;
    stroke: var(--ca-accent);
}

/* Property Details grid (2 columns) */
.ca-detail__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
}
.ca-detail__grid-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 14px;
    border-bottom: 1px solid var(--ca-gray-50);
}
.ca-detail__grid-item:nth-child(odd) {
    border-right: 1px solid var(--ca-gray-50);
}
.ca-detail__grid-label {
    font-size: 13px;
    color: var(--ca-gray-500);
    font-weight: 500;
}
.ca-detail__grid-value {
    font-size: 14px;
    color: var(--ca-gray-900);
    font-weight: 600;
    text-align: right;
}

/* "New" condition badge */
.ca-detail__new-badge {
    display: inline-block;
    background: #16a34a;
    color: #fff;
    padding: 2px 12px;
    border-radius: var(--ca-radius-sm);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
}

/* Energy Rating (DPE / GHG) */
.ca-detail__energy {
    display: flex;
    gap: 24px;
    flex-wrap: wrap;
}
.ca-detail__energy-item {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
    min-width: 200px;
    background: var(--ca-gray-50);
    padding: 14px 18px;
    border-radius: var(--ca-radius-sm);
}
.ca-detail__energy-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.ca-detail__energy-info strong {
    font-size: 13px;
    color: var(--ca-gray-700);
    text-transform: uppercase;
    letter-spacing: .5px;
}
.ca-detail__energy-info span {
    font-size: 12px;
    color: var(--ca-gray-500);
}

/* DPE / GHG badges */
.ca-dpe-badge,
.ca-ghg-badge {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: var(--ca-radius);
    font-size: 20px;
    font-weight: 800;
    color: #fff;
    background: var(--ca-gray-400);
    flex-shrink: 0;
}
/* DPE color scale */
.ca-dpe--a { background: #319834; }
.ca-dpe--b { background: #33cc31; }
.ca-dpe--c { background: #cbfc34; color: #333; }
.ca-dpe--d { background: #fbfe06; color: #333; }
.ca-dpe--e { background: #fbcc04; color: #333; }
.ca-dpe--f { background: #eb8235; }
.ca-dpe--g { background: #d8001d; }
/* GHG color scale */
.ca-ghg--a { background: #f2e6ff; color: #6b21a8; }
.ca-ghg--b { background: #dfc2f7; color: #6b21a8; }
.ca-ghg--c { background: #c39de8; color: #fff; }
.ca-ghg--d { background: #a678d8; color: #fff; }
.ca-ghg--e { background: #8b55c7; color: #fff; }
.ca-ghg--f { background: #7030b0; color: #fff; }
.ca-ghg--g { background: #4c1d95; color: #fff; }

/* Room counts grid */
.ca-detail__room-counts {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}
.ca-detail__room-count-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 80px;
    padding: 14px 18px;
    background: var(--ca-gray-50);
    border-radius: var(--ca-radius-sm);
    gap: 4px;
    text-align: center;
}
.ca-detail__room-count-val {
    font-size: 22px;
    font-weight: 700;
    color: var(--ca-accent);
    line-height: 1;
}
.ca-detail__room-count-lbl {
    font-size: 12px;
    color: var(--ca-gray-600);
    font-weight: 500;
    text-transform: capitalize;
}

/* Feature chips */
.ca-detail__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.ca-detail__chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 14px;
    background: var(--ca-gray-50);
    color: var(--ca-gray-700);
    border-radius: var(--ca-radius-sm);
    font-size: 13px;
    font-weight: 500;
    border: 1px solid var(--ca-gray-100);
    transition: background .15s;
}
.ca-detail__chip:hover {
    background: var(--ca-gray-100);
}

/* Property Info Grid */
.ca-detail__info-grid {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid var(--ca-gray-100);
}
.ca-detail__info-grid-title {
    font-size: 16px;
    font-weight: 700;
    color: var(--ca-gray-900);
    margin: 0 0 14px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.ca-detail__info-grid-title svg {
    stroke: var(--ca-accent);
}
.ca-detail__info-items {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
}
.ca-detail__info-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--ca-gray-50);
    border-radius: var(--ca-radius-sm);
    border: 1px solid var(--ca-gray-100);
}
.ca-detail__info-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: var(--ca-radius-sm);
    background: #fff;
    color: var(--ca-accent);
    flex-shrink: 0;
    border: 1px solid var(--ca-gray-100);
}
.ca-detail__info-icon svg {
    stroke: var(--ca-accent);
}
.ca-detail__info-text {
    display: flex;
    flex-direction: column;
    gap: 1px;
    min-width: 0;
}
.ca-detail__info-label {
    font-size: 11px;
    color: var(--ca-gray-500);
    text-transform: uppercase;
    letter-spacing: .4px;
    font-weight: 500;
}
.ca-detail__info-value {
    font-size: 14px;
    font-weight: 600;
    color: var(--ca-gray-900);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Agent + Contact wrapper */
.ca-detail__agent-contact-wrapper {
    margin-top: 24px;
    padding-top: 24px;
    border-top: 1px solid var(--ca-gray-100);
    background: var(--ca-gray-50);
    border-radius: var(--ca-radius);
    padding: 20px;
    display: grid;
    gap: 20px;
}

/* Agent */
.ca-detail__agent {
    margin-bottom: 0;
}
.ca-detail__agent h3 {
    font-size: 16px;
    font-weight: 700;
    color: var(--ca-gray-900);
    margin: 0 0 14px;
    display: flex;
    align-items: center;
    gap: 6px;
}
.ca-detail__agent h3 svg {
    stroke: var(--ca-accent);
}

.ca-detail__agent-card {
    display: flex;
    gap: 18px;
    align-items: flex-start;
    background: #fff;
    border-radius: var(--ca-radius-sm);
    padding: 18px;
    border: 1px solid var(--ca-gray-100);
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.05);
}
.ca-detail__agent-pic {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    display: block;
    object-fit: cover;
    object-position: center center;
    flex-shrink: 0;
    border: 3px solid var(--ca-accent);
    box-shadow: 0 2px 8px rgba(0,0,0,.08);
}
.ca-detail__agent-pic--placeholder {
    background: var(--ca-gray-100);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    width: 72px;
    height: 72px;
    border: 3px solid var(--ca-gray-200);
}
.ca-detail__agent-pic--placeholder svg {
    width: 32px;
    height: 32px;
    stroke: var(--ca-gray-500);
}
.ca-detail__agent-info {
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex: 1;
    min-width: 0;
}
.ca-detail__agent-info strong {
    font-size: 16px;
    color: var(--ca-gray-900);
    line-height: 1.25;
}
.ca-detail__agent-role {
    font-size: 12px;
    color: var(--ca-gray-500);
    text-transform: capitalize;
}
.ca-detail__agent-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 6px;
}
.ca-detail__agent-link {
    font-size: 13px;
    color: var(--ca-accent);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    max-width: 100%;
    padding: 8px 10px;
    border: 1px solid var(--ca-gray-200);
    border-radius: var(--ca-radius-sm);
    background: var(--ca-gray-50);
    transition: color .15s, border-color .15s, background .15s;
    overflow-wrap: anywhere;
}
.ca-detail__agent-link:hover {
    color: var(--ca-accent-dark);
    border-color: var(--ca-accent);
    background: #fff;
    text-decoration: none;
}
.ca-detail__agent-link svg {
    flex-shrink: 0;
}
/* Legacy compat */
.ca-detail__agent-phone,
.ca-detail__agent-email {
    font-size: 13px;
    color: var(--ca-accent);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 5px;
}
.ca-detail__agent-phone:hover,
.ca-detail__agent-email:hover {
    text-decoration: underline;
}

/* Contact form */
.ca-detail__contact {
    padding-top: 20px;
    border-top: 1px solid var(--ca-gray-200);
}
.ca-detail__contact h3 {
    font-size: 15px;
    font-weight: 700;
    color: var(--ca-gray-900);
    margin: 0 0 12px;
}
.ca-contact-form {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.ca-contact-form__row {
    display: flex;
    gap: 8px;
}

.ca-contact-form__input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--ca-gray-300);
    border-radius: var(--ca-radius-sm);
    font-size: 13px;
    outline: none;
    transition: border-color .2s, box-shadow .2s;
    font-family: var(--ca-font);
    box-sizing: border-box;
}
.ca-contact-form__input:focus {
    border-color: var(--ca-accent);
    box-shadow: 0 0 0 3px rgba(37,99,235,.1);
}

.ca-contact-form__textarea {
    resize: vertical;
    min-height: 60px;
    max-height: 120px;
}

.ca-contact-form__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 10px 24px;
    background: var(--ca-accent);
    color: #fff;
    border: none;
    border-radius: var(--ca-radius-sm);
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: background .2s;
}
.ca-contact-form__btn:hover { background: var(--ca-accent-dark); }
.ca-contact-form__btn:disabled { opacity: .6; cursor: not-allowed; }

.ca-contact-form__status {
    margin-top: 4px;
    font-size: 13px;
}
.ca-contact-form__status--ok { color: #16a34a; }
.ca-contact-form__status--err { color: #dc2626; }

/* Mini-map inside modal */
.ca-detail__map {
    height: 240px;
    border-radius: var(--ca-radius-sm);
    margin-top: 24px;
    overflow: hidden;
}

/* Custom map marker – modern black dot */
.ca-marker {
    background: transparent !important;
    border: none !important;
}
.ca-marker__dot {
    width: 14px;
    height: 14px;
    background: #1a1a1a;
    border-radius: 50%;
    border: 2.5px solid #fff;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.35), 0 0 0 1px rgba(0, 0, 0, 0.1);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.ca-marker:hover .ca-marker__dot {
    transform: translate(-50%, -50%) scale(1.2);
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.45), 0 0 0 1px rgba(0, 0, 0, 0.15);
}

/* Map popup */
.ca-popup {
    font-family: var(--ca-font);
    font-size: 13px;
    line-height: 1.4;
}
.ca-popup__img {
    width: 100%;
    height: 100px;
    object-fit: cover;
    border-radius: 0;
    margin-bottom: 6px;
    display: block;
}
.ca-popup__price { color: var(--ca-accent); }

.ca-popup-detail {
    color: var(--ca-accent);
    text-decoration: none;
    font-weight: 600;
    font-size: 12px;
}
.ca-popup-detail:hover { text-decoration: underline; }

/* ===========================
   CAROUSEL
   =========================== */
/* ===========================
   CAROUSEL – One slide at a time, hover reveals info
   =========================== */
.ca-carousel {
    max-width: 1440px !important;
    margin: 0 auto !important;
    padding: 40px 16px !important;
    font-family: var(--ca-font) !important;
    background: transparent !important;
}

.ca-carousel--empty {
    text-align: center !important;
    color: var(--ca-gray-500) !important;
    padding: 40px 0 !important;
}

.ca-carousel .ca-carousel__header {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    margin-bottom: 24px !important;
}
.ca-carousel .ca-carousel__title {
    font-size: 28px !important;
    font-weight: 700 !important;
    color: var(--ca-gray-900) !important;
    margin: 0 !important;
    text-align: center !important;
    width: 100% !important;
    line-height: 1.3 !important;
    letter-spacing: normal !important;
    text-transform: none !important;
}
.ca-carousel .ca-carousel__footer {
    display: flex !important;
    justify-content: flex-end !important;
    margin-top: 20px !important;
}
.ca-carousel .ca-carousel__footer-actions {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
}
.ca-carousel .ca-carousel__header-actions {
    display: flex !important;
    align-items: center !important;
    gap: 16px !important;
}
.ca-carousel .ca-carousel__view-all {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 10px 22px !important;
    background: var(--ca-accent) !important;
    color: #fff !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    text-transform: uppercase !important;
    letter-spacing: .5px !important;
    transition: background .2s !important;
    border: none !important;
}
.ca-carousel .ca-carousel__view-all:hover {
    background: var(--ca-accent-dark) !important;
    color: #fff !important;
}
.ca-carousel .ca-carousel__view-all--disabled {
    opacity: .4 !important;
    pointer-events: none !important;
    cursor: default !important;
}
.ca-carousel .ca-carousel__nav {
    display: flex !important;
    gap: 8px !important;
}
.ca-carousel .ca-carousel__arrow {
    width: 42px !important;
    height: 42px !important;
    border: 1px solid var(--ca-gray-300) !important;
    background: #fff !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background .2s, border-color .2s !important;
    border-radius: 0 !important;
}
.ca-carousel .ca-carousel__arrow svg { width: 20px !important; height: 20px !important; }
.ca-carousel .ca-carousel__arrow:hover {
    background: var(--ca-gray-100) !important;
    border-color: var(--ca-gray-500) !important;
}

.ca-carousel .ca-carousel__track-wrap {
    overflow: hidden !important;
}
.ca-carousel .ca-carousel__track {
    display: flex !important;
    transition: transform .5s cubic-bezier(.25,.8,.25,1);
    gap: 16px !important;
    will-change: transform;
}
.ca-carousel .ca-carousel__slide {
    flex: 0 0 70% !important;
    box-sizing: border-box !important;
    cursor: pointer !important;
    opacity: 1 !important;
    transform: scale(0.95) !important;
    transition: transform .4s ease, filter .4s ease !important;
    filter: blur(3px) !important;
}
.ca-carousel .ca-carousel__slide--active {
    opacity: 1 !important;
    transform: scale(1) !important;
    filter: blur(0) !important;
}

/* Responsive: smaller screens show more of active slide */
@media (max-width: 1024px) {
    .ca-carousel .ca-carousel__slide {
        flex: 0 0 80% !important;
    }
}
@media (max-width: 768px) {
    .ca-carousel .ca-carousel__slide {
        flex: 0 0 85% !important;
    }
}

.ca-carousel .ca-carousel__card {
    position: relative !important;
    overflow: hidden !important;
    background: #000 !important;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.3) !important;
    border: none !important;
    border-radius: 0 !important;
}
.ca-carousel .ca-carousel__slide--active .ca-carousel__card {
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.45) !important;
}

.ca-carousel .ca-carousel__img {
    position: relative !important;
    width: 100% !important;
    height: 520px !important;
    overflow: hidden !important;
}
.ca-carousel .ca-carousel__img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    transition: transform .6s ease, filter .4s ease !important;
    border: none !important;
    border-radius: 0 !important;
}
.ca-carousel .ca-carousel__card:hover .ca-carousel__img img {
    transform: scale(1.03) !important;
    filter: brightness(.65) !important;
}
.ca-carousel .ca-carousel__img--empty {
    background: var(--ca-gray-100) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: var(--ca-gray-500) !important;
    font-size: 14px !important;
}

/* Info overlay – slides up on hover */
.ca-carousel .ca-carousel__info {
    position: absolute !important;
    inset: 0 !important;
    display: flex !important;
    align-items: flex-end !important;
    pointer-events: none !important;
    z-index: 2 !important;
}
.ca-carousel .ca-carousel__info-inner {
    width: 100% !important;
    padding: 40px 32px 32px !important;
    background: linear-gradient(transparent, rgba(0,0,0,.75)) !important;
    transform: translateY(60px) !important;
    opacity: 0 !important;
    transition: transform .4s ease, opacity .35s ease !important;
}
.ca-carousel .ca-carousel__card:hover .ca-carousel__info-inner {
    transform: translateY(0) !important;
    opacity: 1 !important;
}

/* Only show hover effects on active slide */
.ca-carousel .ca-carousel__slide:not(.ca-carousel__slide--active) .ca-carousel__card:hover .ca-carousel__info-inner {
    transform: translateY(60px) !important;
    opacity: 0 !important;
}
.ca-carousel .ca-carousel__slide:not(.ca-carousel__slide--active) .ca-carousel__card:hover .ca-carousel__img img {
    transform: none !important;
    filter: none !important;
}

.ca-carousel .ca-carousel__name {
    font-size: 24px !important;
    font-weight: 800 !important;
    color: #fff !important;
    margin: 0 0 6px !important;
    line-height: 1.3 !important;
}
.ca-carousel .ca-carousel__city {
    font-size: 14px !important;
    color: rgba(255,255,255,.85) !important;
    margin: 0 0 10px !important;
    display: flex !important;
    align-items: center !important;
    gap: 5px !important;
}
.ca-carousel .ca-carousel__city svg {
    flex-shrink: 0 !important;
    stroke: rgba(255,255,255,.85) !important;
}

.ca-carousel .ca-carousel__specs {
    display: flex !important;
    gap: 16px !important;
    margin-bottom: 12px !important;
}
.ca-carousel .ca-carousel__spec {
    font-size: 13px !important;
    color: rgba(255,255,255,.8) !important;
    font-weight: 600 !important;
}
.ca-carousel .ca-carousel__spec + .ca-carousel__spec {
    padding-left: 16px !important;
    border-left: 1px solid rgba(255,255,255,.3) !important;
}

.ca-carousel .ca-carousel__price {
    font-size: 28px !important;
    font-weight: 900 !important;
    color: #fff !important;
    margin-bottom: 8px !important;
}

.ca-carousel .ca-carousel__cta {
    display: inline-block !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    color: #fff !important;
    border: 1.5px solid #fff !important;
    padding: 6px 16px !important;
    text-transform: uppercase !important;
    letter-spacing: .5px !important;
    transition: background .2s, color .2s !important;
    background: transparent !important;
}
.ca-carousel .ca-carousel__cta:hover {
    background: #fff !important;
    color: var(--ca-gray-900) !important;
}

/* Dots */
.ca-carousel__dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 20px;
}
.ca-carousel__dot {
    width: 32px;
    height: 4px;
    border: none;
    background: var(--ca-gray-300);
    cursor: pointer;
    transition: background .2s, width .2s;
    padding: 0;
}
.ca-carousel__dot--active,
.ca-carousel__dot:hover {
    background: var(--ca-accent);
    width: 48px;
}

/* ===========================
   Error / Empty
   =========================== */
.case-apimo-error {
    background: #fef2f2;
    color: #991b1b;
    padding: 16px 20px;
    border-radius: var(--ca-radius-sm);
    border: 1px solid #fecaca;
    font-size: 14px;
}
.case-apimo-empty {
    text-align: center;
    padding: 60px 20px;
    color: var(--ca-gray-500);
    font-size: 16px;
}

/* ===========================
   RESPONSIVE
   =========================== */

/* ≤ 1280px — reduce fixed widths */
@media (max-width: 1280px) {
    .ca {
        padding: 20px 16px;
    }
    .ca-layout {
        gap: 16px;
    }
    .ca .ca-card__img {
        flex: 0 0 38% !important;
        min-height: 200px !important;
    }
    .ca-carousel .ca-carousel__img {
        height: 440px !important;
    }
}

/* ≤ 1024px — stack layout, map on top */
@media (max-width: 1024px) {
    .ca-layout {
        flex-direction: column;
    }
    .ca-layout__map {
        flex: none;
        position: relative;
        top: auto;
        height: 50vh;
        min-height: 320px;
        width: 100%;
    }
    .ca-layout__list {
        width: 100%;
    }
    .ca .ca-card__img {
        flex: 0 0 40% !important;
        min-height: 200px !important;
    }
    .ca-filter-card {
        flex: 1 1 180px;
        min-width: 160px;
    }
    .ca-filter-card--compact {
        flex: 1 1 130px;
        min-width: 110px;
    }
    .ca-carousel .ca-carousel__slide {
        flex: 0 0 80% !important;
    }
    .ca-carousel .ca-carousel__img {
        height: 400px !important;
    }
    .ca-modal__panel {
        width: 95vw;
    }
    .ca-detail__grid {
        grid-template-columns: 1fr 1fr;
    }
}

/* ≤ 768px — mobile layout */
@media (max-width: 768px) {
    .ca {
        padding: 16px 12px;
    }

    /* Search bar */
    .ca-search__top,
    .ca .ca-search__top {
        flex-direction: column !important;
        padding: 14px 14px !important;
    }
    .ca .ca-search__field--grow { min-width: 100% !important; width: 100% !important; }
    .ca .ca-search__pill { width: 100% !important; }
    .ca .ca-search__pill .ca-search__select { flex: 1 !important; width: 100% !important; }

    .ca-search__filters {
        flex-direction: column;
        gap: 10px;
        padding: 12px 14px;
    }
    .ca-filter-card,
    .ca-filter-card--compact {
        flex: none !important;
        width: 100% !important;
        min-width: 0 !important;
    }
    .ca-search__btn { width: 100%; justify-content: center; }

    /* Map */
    .ca-layout__map { height: 40vh; min-height: 240px; }

    /* Cards */
    .ca .ca-card {
        flex-direction: column !important;
    }
    .ca .ca-card__img {
        flex: none !important;
        width: 100% !important;
        min-height: 200px !important;
        height: 200px !important;
    }
    .ca .ca-card__body {
        padding: 16px !important;
    }
    .ca .ca-card__price { font-size: 20px !important; }
    .ca .ca-card__title { font-size: 16px !important; }

    .ca-grid { gap: 14px; }

    /* Modal */
    .ca-modal__panel {
        width: 98vw;
        max-height: 98vh;
    }
    .ca-detail__main-image { height: 240px; }
    .ca-detail__specs { flex-wrap: wrap; gap: 12px; }
    .ca-detail__price { font-size: 22px; }
    .ca-detail__title { font-size: 20px; }
    .ca-detail__map { height: 180px; }
    .ca-detail__grid { grid-template-columns: 1fr; }
    .ca-detail__grid-item:nth-child(odd) { border-right: none; }
    .ca-detail__energy { flex-direction: column; gap: 10px; }
    .ca-detail__header { flex-direction: column; }
    .ca-detail__share { margin-bottom: 10px; }
    .ca-detail__info-items { grid-template-columns: 1fr; }
    .ca-detail__agent-card { flex-direction: column; text-align: center; align-items: center; }
    .ca-detail__agent-links { justify-content: center; }
    .ca-contact-form__row { flex-direction: column; }

    /* Carousel */
    .ca-carousel .ca-carousel__slide { flex: 0 0 88% !important; }
    .ca-carousel .ca-carousel__title { font-size: 22px !important; }
    .ca-carousel .ca-carousel__img { height: 320px !important; }
    .ca-carousel .ca-carousel__name { font-size: 18px !important; }
    .ca-carousel .ca-carousel__price { font-size: 22px !important; }
    .ca-carousel .ca-carousel__specs { flex-wrap: wrap; gap: 8px; }
    .ca-carousel .ca-carousel__header { flex-direction: column; gap: 12px; align-items: center; }
    .ca-carousel .ca-carousel__header-actions { width: 100%; justify-content: space-between; }
    .ca-carousel .ca-carousel__arrow { width: 36px !important; height: 36px !important; }
}

/* ≤ 480px — small mobile */
@media (max-width: 480px) {
    .ca { padding: 12px 10px; }

    .ca-search__filters {
        padding: 10px 10px;
    }

    /* Cards */
    .ca .ca-card__img {
        min-height: 180px !important;
        height: 180px !important;
    }
    .ca .ca-card__body { padding: 12px 14px !important; }
    .ca .ca-card__title { font-size: 15px !important; }
    .ca .ca-card__price { font-size: 18px !important; }

    /* Modal */
    .ca-detail__content { padding: 16px; }
    .ca-detail__main-image { height: 200px; }

    /* Carousel */
    .ca-carousel { padding: 20px 8px !important; }
    .ca-carousel .ca-carousel__slide { flex: 0 0 92% !important; }
    .ca-carousel .ca-carousel__img { height: 240px !important; }
    .ca-carousel .ca-carousel__info-inner { padding: 20px 14px 18px !important; }
    .ca-carousel .ca-carousel__title { font-size: 20px !important; }
    .ca-carousel .ca-carousel__price { font-size: 20px !important; }
    .ca-carousel .ca-carousel__name { font-size: 16px !important; }
    .ca-carousel .ca-carousel__header-actions { flex-direction: column; gap: 10px; align-items: center; }
}
