/* Rentgalov Theme - Production CSS */
/* Mobile-first, Performance-optimized */
/* Brand Colors: Logo-driven (Red/Orange/Blue) - Villasepeti Premium Feel */

:root {
    /* Brand Colors - Logo-Derived Design System */
    --rg-primary: #C62828;           /* Rent - Warm Red */
    --rg-primary-hover: #B71C1C;
    --rg-primary-light: #FFEBEE;
    --rg-accent: #E65100;            /* Ga - Warm Orange */
    --rg-secondary: #1565C0;         /* Lov - Cool Blue */
    --rg-ink: #1A1A2E;               /* Deep Navy - Headlines */
    --rg-bg: #F7F7F8;                /* Off-white background */
    
    /* Legacy mappings for compatibility */
    --brand-primary: var(--rg-primary);
    --brand-primary-hover: var(--rg-primary-hover);
    --brand-primary-light: #EF5350;
    --brand-dark: var(--rg-ink);
    --brand-light: var(--rg-bg);
    --brand-white: #FFFFFF;
    --brand-whatsapp: #25D366;
    --brand-amber: #F59E0B;

    /* Semantic Colors - Mapped to Brand */
    --color-primary: var(--rg-primary);
    --color-primary-dark: var(--rg-primary-hover);
    --color-primary-light: var(--rg-primary-light);
    --color-whatsapp: var(--brand-whatsapp);
    --color-amber: var(--brand-amber);
    --color-text: var(--rg-ink);
    --color-text-light: #64748B;
    --color-text-muted: #94A3B8;
    --color-border: #E2E8F0;
    --color-border-light: #F1F5F9;
    --color-bg: var(--brand-white);
    --color-bg-alt: var(--rg-bg);
    --color-bg-dark: var(--rg-ink);

    /* Typography */
    --font-family: 'Inter', system-ui, -apple-system, sans-serif;
    --line-height-tight: 1.3;
    --line-height-normal: 1.6;
    --line-height-relaxed: 1.8;

    /* Spacing */
    --space-xs: 4px;
    --space-sm: 8px;
    --space-md: 16px;
    --space-lg: 24px;
    --space-xl: 32px;
    --space-2xl: 48px;

    /* Radius */
    --radius-sm: 6px;
    --radius-md: 10px;
    --radius-lg: 14px;
    --radius-xl: 20px;
    --radius-full: 9999px;

    /* Shadows - Refined */
    --shadow-sm: 0 1px 3px rgba(26,26,46,0.06);
    --shadow-md: 0 4px 12px rgba(26,26,46,0.08);
    --shadow-lg: 0 8px 24px rgba(26,26,46,0.1);
    --shadow-xl: 0 16px 40px rgba(26,26,46,0.12);
    --shadow-card: 0 2px 8px rgba(26,26,46,0.06), 0 1px 2px rgba(26,26,46,0.04);
    --shadow-card-hover: 0 8px 24px rgba(26,26,46,0.1), 0 4px 8px rgba(26,26,46,0.06);

    --transition: 0.2s ease;
    --transition-fast: 0.15s ease;
    --container-max: 1280px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; overflow-x: hidden; margin: 0 !important; padding: 0 !important; }
body { margin: 0 !important; padding: 0 !important; font-family: var(--font-family); font-size: 15px; line-height: var(--line-height-normal); color: var(--color-text); background: var(--color-bg-alt); overflow-x: hidden; }
/* Force remove any top spacing */
body::before, html::before { display: none !important; }
#wpadminbar { display: none !important; }
.admin-bar body { margin-top: 0 !important; padding-top: 0 !important; }
/* Remove any WordPress default spacing */
#page, #main, .site, .site-content { margin: 0 !important; padding: 0 !important; }
/* Remove any theme wrapper spacing */
.site-wrapper, .page-wrapper, .content-wrapper { margin: 0 !important; padding: 0 !important; }
img { max-width: 100%; height: auto; display: block; }

/* Homepage specific - Light gray background */
.home { background: var(--color-bg-alt); }
a { color: var(--color-primary); text-decoration: none; transition: var(--transition); }
a:hover { color: var(--color-primary-dark); }
button { font-family: inherit; }

/* Focus States - Accessibility */
:focus-visible { outline: 2px solid var(--brand-primary); outline-offset: 2px; }
button:focus-visible, a:focus-visible { outline: 2px solid var(--brand-primary); outline-offset: 2px; }

.container { width: 100%; max-width: var(--container-max); margin: 0 auto; padding: 0 var(--space-md); }
@media (min-width: 768px) { .container { padding: 0 var(--space-lg); } }

/* Typography Hierarchy */
h1, h2, h3, h4, h5, h6 { line-height: var(--line-height-tight); font-weight: 700; color: var(--color-text); }
h1 { font-size: clamp(28px, 5vw, 42px); letter-spacing: -0.02em; }
h2 { font-size: clamp(24px, 4vw, 32px); letter-spacing: -0.01em; }
h3 { font-size: clamp(18px, 3vw, 22px); }

/* Buttons - Refined */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: var(--space-sm);
    padding: 12px 24px; font-size: 14px; font-weight: 600; border: none;
    border-radius: var(--radius-md); cursor: pointer; transition: var(--transition);
    text-decoration: none; min-height: 44px;
}
.btn:active { transform: scale(0.98); }
.btn--primary { background: var(--color-primary); color: #fff; box-shadow: 0 2px 8px rgba(196,30,58,0.25); }
.btn--primary:hover { background: var(--color-primary-dark); color: #fff; transform: translateY(-2px); box-shadow: 0 4px 12px rgba(196,30,58,0.3); }
.btn--white { background: #fff; color: var(--color-primary); box-shadow: var(--shadow-md); }
.btn--white:hover { background: #fff; color: var(--color-primary-dark); transform: translateY(-2px); box-shadow: var(--shadow-lg); }
.btn--outline { background: transparent; border: 2px solid var(--color-primary); color: var(--color-primary); }
.btn--outline:hover { background: var(--color-primary); color: #fff; }
.btn--lg { padding: 16px 32px; font-size: 16px; }

/* ========== HEADER ========== */
.site-header { 
    position: relative;
    z-index: 1000; 
    background: var(--color-bg); 
    margin: 0 !important; 
    padding: 0 !important;
    border-top: none !important;
}
/* Force header to top */
body > .site-header:first-child { margin-top: 0 !important; }
.site-header::before { display: none !important; }

/* Single property: blend header/footer with page background */
.single-property-page {
    background: var(--color-bg-alt);
}
.single-property-page .site-header,
.single-property-page .main-header,
.single-property-page .mobile-menu {
    background: var(--color-bg);
    border-bottom: 1px solid var(--color-border-light);
    box-shadow: none;
}
.single-property-page .site-footer {
    margin-top: 0;
    background: var(--color-bg-dark);
}
.single-property-page .top-bar {
    background: var(--color-bg-dark);
}

.top-bar { background: var(--color-bg-dark); color: #fff; font-size: 13px; padding: 8px 0; display: none; margin: 0; }
@media (min-width: 768px) { .top-bar { display: block; } }
.top-bar__inner { display: flex; justify-content: space-between; align-items: center; }
.top-bar__left { display: flex; gap: 24px; }
.top-bar__item { display: flex; align-items: center; gap: 6px; color: rgba(255,255,255,0.85); }
.top-bar__item:hover { color: #fff; }
.top-bar__right { display: flex; align-items: center; gap: 16px; }
.lang-switcher { display: flex; gap: 8px; }
.lang-switcher__item { color: rgba(255,255,255,0.6); font-weight: 500; font-size: 12px; }
.lang-switcher__item--active { color: #fff; }

.main-header { 
    position: relative;
    background: var(--color-bg);
    border-bottom: 1px solid var(--color-border);
    margin: 0;
    padding: 0;
    transition: all 0.3s ease;
    z-index: 100;
}
/* When scrolled, main-header becomes fixed */
.main-header.is-fixed {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
}
/* Placeholder to prevent content jump when header becomes fixed */
.header-placeholder {
    display: none;
    height: 70px;
}
.header-placeholder.is-active {
    display: block;
}
.main-header__inner { display: flex; align-items: center; justify-content: space-between; height: 70px; }
.site-logo__text { font-size: 24px; font-weight: 700; color: var(--color-text); }
.site-logo__text span { color: var(--color-primary); }

.main-nav { display: none; }
@media (min-width: 1024px) { .main-nav { display: block; } }

/* Logo - sabit boyut, kalite korumalı */
.site-logo__image { 
    height: 45px; 
    width: auto;
    max-width: 180px;
    object-fit: contain;
}
.main-nav__list { display: flex; gap: 32px; list-style: none; margin: 0; padding: 0; }
.main-nav__list li a { color: var(--color-text); font-weight: 500; font-size: 14px; padding: 8px 0; position: relative; }
.main-nav__list li a:hover { color: var(--color-primary); }
.main-nav__list li a::after { content: ''; position: absolute; bottom: 0; left: 0; width: 0; height: 2px; background: var(--color-primary); transition: var(--transition); }
.main-nav__list li a:hover::after { width: 100%; }

.header-actions { display: flex; align-items: center; gap: 12px; }
.header-whatsapp {
    display: flex; align-items: center; gap: 8px; padding: 10px 20px;
    background: var(--color-whatsapp); color: #fff; border-radius: var(--radius-md);
    font-weight: 600; font-size: 14px;
}
.header-whatsapp:hover { background: #1fb855; color: #fff; transform: translateY(-1px); }
.header-whatsapp span { display: none; }
@media (min-width: 640px) { .header-whatsapp span { display: inline; } }

.mobile-toggle { display: flex; flex-direction: column; gap: 5px; padding: 8px; background: none; border: none; cursor: pointer; }
.mobile-toggle span { width: 24px; height: 2px; background: var(--color-text); transition: var(--transition); }
@media (min-width: 1024px) { .mobile-toggle { display: none; } }

/* Mobile Menu - Full screen overlay */
.mobile-menu { 
    display: none; 
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--color-bg); 
    border-top: 1px solid var(--color-border-light); 
    padding: 16px 0;
    box-shadow: 0 10px 30px rgba(0,0,0,0.1);
    max-height: calc(100vh - 70px);
    overflow-y: auto;
    z-index: 100;
}
.mobile-menu.is-open { 
    display: block; 
}
.mobile-menu__list { list-style: none; margin: 0; padding: 0; }
.mobile-menu__list li { border-bottom: 1px solid var(--color-border-light); }
.mobile-menu__list li:last-child { border: none; }
.mobile-menu__list li a { display: block; padding: 16px 0; color: var(--color-text); font-weight: 500; font-size: 16px; }
.mobile-menu__list li a:hover { color: var(--brand-primary); }

/* Mobile toggle active state - hamburger to X animation */
.mobile-toggle.is-active span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.mobile-toggle.is-active span:nth-child(2) { opacity: 0; }
.mobile-toggle.is-active span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

/* Hide mobile menu on desktop */
@media (min-width: 1024px) { .mobile-menu { display: none !important; } }

/* ========== HERO ========== */
.hero { position: relative; padding: 60px 0 80px; min-height: 400px; display: flex; align-items: center; }
@media (min-width: 768px) { .hero { padding: 100px 0 160px; min-height: 560px; } }
.hero__bg { position: absolute; inset: 0; z-index: -1; }
.hero__bg img { width: 100%; height: 100%; object-fit: cover; }
/* Softer gradient overlay for better readability */
.hero__overlay { 
    position: absolute; inset: 0; 
    background: linear-gradient(135deg, rgba(198,40,40,0.8) 0%, rgba(15,23,42,0.88) 100%); 
}

/* Hero Content - Centered & Balanced */
.hero__content { text-align: center; color: #fff; margin-bottom: 32px; max-width: 640px; margin-left: auto; margin-right: auto; }
@media (min-width: 768px) { .hero__content { margin-bottom: 40px; } }
.hero__badge { 
    display: inline-block; padding: 8px 16px; 
    background: rgba(255,255,255,0.15); 
    border-radius: var(--radius-full); 
    font-size: 11px; font-weight: 600; 
    margin-bottom: 20px; 
    backdrop-filter: blur(10px); 
    border: 1px solid rgba(255,255,255,0.12);
    text-transform: uppercase;
    letter-spacing: 0.75px;
}
@media (min-width: 768px) { .hero__badge { font-size: 12px; padding: 10px 20px; margin-bottom: 24px; } }
.hero__title { font-size: 24px; font-weight: 700; margin: 0 0 12px; line-height: 1.1; letter-spacing: -0.5px; color: #fff; white-space: normal; }
@media (min-width: 768px) { .hero__title { font-size: 40px; letter-spacing: -1px; margin: 0 0 16px; white-space: nowrap; } }
@media (min-width: 1024px) { .hero__title { font-size: 48px; letter-spacing: -1.5px; } }
.hero__subtitle { font-size: 14px; margin: 0 auto; opacity: 0.92; max-width: 500px; line-height: 1.6; }
@media (min-width: 768px) { .hero__subtitle { font-size: 18px; line-height: 1.7; } }

/* Hero Search - Clean & Aligned */
.hero-search {
    background: var(--color-bg); 
    border-radius: var(--radius-lg); 
    padding: 16px;
    box-shadow: 0 20px 60px rgba(15,23,42,0.18), 0 8px 20px rgba(15,23,42,0.1);
    max-width: 1100px; 
    margin: 0 auto;
    position: relative; z-index: 10; 
    border: 1px solid rgba(255,255,255,0.1);
}
@media (min-width: 768px) { .hero-search { padding: 24px; border-radius: 24px; } }
@media (min-width: 1200px) { .hero-search { padding: 28px; } }
.hero-search__row { display: grid; gap: 12px; }
@media (min-width: 640px) { .hero-search__row { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .hero-search__row { grid-template-columns: 1fr 1fr 1fr 1fr auto; gap: 10px; align-items: end; } }
@media (min-width: 1200px) { .hero-search__row { grid-template-columns: 1.2fr 1fr 1fr 1fr auto; gap: 12px; } }

.hero-search__field { display: flex; flex-direction: column; gap: 5px; }
.hero-search__field label { font-size: 10px; font-weight: 600; color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.5px; }
@media (min-width: 1200px) { .hero-search__field label { font-size: 11px; } }
.hero-search__select-wrap,
.hero-search__input-wrap {
    display: flex; align-items: center; gap: 8px; padding: 10px 12px;
    border: 1px solid var(--color-border-light); border-radius: var(--radius-md);
    background: var(--color-bg); transition: var(--transition);
    min-height: 44px;
}
@media (min-width: 768px) {
    .hero-search__select-wrap,
    .hero-search__input-wrap {
        padding: 11px 12px;
        min-height: 48px;
    }
}
.hero-search__select-wrap:focus-within,
.hero-search__input-wrap:focus-within { border-color: var(--color-primary); background: var(--color-bg); }
.hero-search__select-wrap svg,
.hero-search__input-wrap svg { color: var(--color-text-muted); flex-shrink: 0; width: 18px; height: 18px; }
.hero-search__select-wrap select,
.hero-search__input-wrap input {
    flex: 1; border: none; background: none; font-size: 13px; color: var(--color-text);
    outline: none; min-width: 0; font-family: inherit;
}
@media (min-width: 1200px) {
    .hero-search__select-wrap select,
    .hero-search__input-wrap input { font-size: 14px; }
}
.hero-search__btn {
    display: flex; align-items: center; justify-content: center; gap: 8px;
    padding: 12px 20px; background: var(--color-primary); color: #fff;
    border: none; border-radius: var(--radius-md); font-size: 14px; font-weight: 600;
    cursor: pointer; transition: var(--transition); white-space: nowrap;
    min-height: 44px; height: 44px;
    box-shadow: 0 4px 12px rgba(198,40,40,0.25);
}
@media (min-width: 768px) {
    .hero-search__btn {
        padding: 14px 20px;
        min-height: 48px; 
        height: 48px;
    }
}
.hero-search__btn:hover { background: var(--color-primary-dark); transform: translateY(-2px); box-shadow: 0 6px 16px rgba(198,40,40,0.3); }
.hero-search__btn svg { width: 18px; height: 18px; }
@media (max-width: 1023px) { .hero-search__btn { grid-column: 1 / -1; padding: 14px 28px; } }
@media (min-width: 1024px) { .hero-search__btn { padding: 14px 16px; } }
@media (min-width: 1200px) { .hero-search__btn { padding: 14px 24px; } }

/* ========== QUICK FILTERS ========== */
.quick-filters { padding: 24px 0; border-bottom: 1px solid var(--color-border-light); background: var(--color-bg); margin-top: -60px; position: relative; z-index: 5; }
@media (min-width: 768px) { .quick-filters { margin-top: -80px; padding: 32px 0; } }
.quick-filters__list { display: flex; gap: 10px; overflow-x: auto; padding-bottom: 8px; -webkit-overflow-scrolling: touch; }
.quick-filters__list::-webkit-scrollbar { display: none; }
.quick-filter {
    display: flex; align-items: center; gap: 8px; padding: 10px 18px;
    background: var(--color-bg); border: 1px solid var(--color-border);
    border-radius: var(--radius-full); white-space: nowrap; font-size: 14px; font-weight: 500;
    color: var(--color-text); transition: var(--transition);
    box-shadow: var(--shadow-sm);
}
.quick-filter:hover { border-color: var(--brand-primary); color: var(--brand-primary); background: rgba(198,40,40,0.04); box-shadow: var(--shadow-md); }
.quick-filter__icon { font-size: 16px; }

/* ========== SECTIONS ========== */
.section { 
    padding: 40px 0; 
    background: var(--color-bg-alt); 
}
@media (min-width: 768px) { 
    .section { 
        padding: 56px 0; 
    } 
}
@media (min-width: 1024px) { 
    .section { 
        padding: 72px 0; 
    } 
}
.section--alt { background: var(--color-bg); }
.section--white { background: var(--color-bg); }
.section--featured { background: var(--color-bg); }
.section--property-type { background: var(--color-bg-alt); }
.section--property-type:nth-of-type(even) { background: var(--color-bg); }

.section-header { 
    margin-bottom: 36px; 
    display: flex; 
    justify-content: space-between; 
    align-items: flex-start; 
    gap: 24px; 
}
@media (max-width: 767px) { 
    .section-header { 
        flex-direction: column; 
        align-items: flex-start; 
        gap: 16px; 
    } 
}
.section-header--center { 
    text-align: center; 
    flex-direction: column; 
    align-items: center; 
    gap: 12px; 
}

/* Section Header Content - Groups title and description */
.section-header__content {
    flex: 1;
    min-width: 0;
}

.section-header__badge { 
    display: inline-block; 
    padding: 8px 16px; 
    background: var(--color-primary-light); 
    color: var(--color-primary); 
    font-size: 12px; 
    font-weight: 600; 
    border-radius: var(--radius-full); 
    text-transform: uppercase; 
    letter-spacing: 0.5px; 
    margin-bottom: 8px; 
}
.section-header__badge--amber { 
    background: rgba(245,158,11,0.1); 
    color: var(--brand-amber); 
}
.section-header__title { 
    font-size: clamp(24px, 4vw, 32px); 
    font-weight: 700; 
    color: var(--color-text); 
    margin: 0 0 8px 0; 
    line-height: 1.2; 
}
.section-header__desc { 
    font-size: 15px; 
    color: var(--color-text-light); 
    margin: 0; 
    max-width: 65%; 
    line-height: 1.5;
}
.section-header--center .section-header__desc { 
    margin: 8px auto 0; 
    max-width: 600px;
    text-align: center;
}
.section-header__link { 
    display: inline-flex; 
    align-items: center; 
    gap: 8px; 
    padding: 10px 16px; 
    background: var(--color-primary); 
    color: #fff; 
    font-size: 13px; 
    font-weight: 600; 
    border-radius: var(--radius-md); 
    transition: var(--transition); 
    white-space: nowrap; 
    flex-shrink: 0;
    align-self: flex-start;
}
@media (min-width: 768px) {
    .section-header__link {
        padding: 12px 20px;
        font-size: 14px;
    }
}
@media (max-width: 767px) { 
    .section-header__link {
        width: 100%;
        justify-content: center;
        margin-top: 8px;
    }
}
.section-header__link:hover { 
    background: var(--color-primary-dark); 
    color: #fff; 
    transform: translateY(-2px); 
}
.section-header__link svg { 
    width: 16px; 
    height: 16px; 
    transition: var(--transition); 
}
.section-header__link:hover svg { 
    transform: translateX(2px); 
}

/* ========== PROPERTY GRID ========== */
.property-grid { 
    display: grid; 
    gap: 20px; 
    justify-content: center; 
    margin-top: 32px;
}
@media (min-width: 640px) { 
    .property-grid { 
        gap: 24px; 
    } 
}
.property-grid--3 { 
    grid-template-columns: 1fr; 
}
@media (min-width: 640px) { 
    .property-grid--3 { 
        grid-template-columns: repeat(2, 1fr); 
    } 
}
@media (min-width: 1024px) { 
    .property-grid--3 { 
        grid-template-columns: repeat(3, 1fr); 
    } 
}

.property-grid--4 { 
    grid-template-columns: 1fr; 
}
@media (min-width: 640px) { 
    .property-grid--4 { 
        grid-template-columns: repeat(2, 1fr); 
    } 
}
@media (min-width: 1024px) { 
    .property-grid--4 { 
        grid-template-columns: repeat(4, 1fr); 
    } 
}

/* Center single card - works when only 1 property exists */
.property-grid--3:has(.property-card:only-child),
.property-grid--4:has(.property-card:only-child) { 
    max-width: 380px; 
    margin: 0 auto; 
    grid-template-columns: 1fr; 
}
/* Center 2 cards on desktop */
@media (min-width: 1024px) {
    .property-grid--3:has(.property-card:nth-child(2):last-child) { 
        max-width: 780px; 
        margin: 0 auto; 
        grid-template-columns: repeat(2, 1fr); 
    }
}

/* ========== PROPERTY CARD - PREMIUM CLARITY ========== */
.property-card { 
    display: flex;
    flex-direction: column;
    height: 100%;
    background: var(--color-bg); 
    border-radius: var(--radius-lg); 
    overflow: hidden; 
    box-shadow: 0 2px 8px rgba(15,23,42,0.06), 0 1px 3px rgba(15,23,42,0.04); 
    transition: all 0.25s ease; 
    border: 1px solid var(--color-border-light); 
}
.property-card:hover { 
    box-shadow: 0 16px 40px rgba(15,23,42,0.12), 0 6px 12px rgba(15,23,42,0.06); 
    transform: translateY(-6px); 
    border-color: transparent; 
}
.property-card__link { 
    display: flex;
    flex-direction: column;
    height: 100%;
    color: inherit; 
}

/* Card Image - Consistent 16:10 ratio */
.property-card__media { 
    position: relative; 
    aspect-ratio: 16/10; 
    overflow: hidden; 
    background: linear-gradient(135deg, var(--color-bg-alt) 0%, var(--color-border) 100%);
}
.property-card__media img { 
    width: 100%; 
    height: 100%; 
    object-fit: cover; 
    transition: transform 0.4s ease; 
}
.property-card:hover .property-card__media img { 
    transform: scale(1.03); 
}

/* Default Cover Images - Type-based gradients with icons */
.property-card__placeholder { 
    width: 100%; 
    height: 100%; 
    display: flex; 
    flex-direction: column;
    align-items: center; 
    justify-content: center; 
    gap: 12px;
    position: relative;
    overflow: hidden;
}

/* Bungalov default */
.property-card__placeholder--bungalov { 
    background: linear-gradient(135deg, #C62828 0%, #B71C1C 100%); 
}
@media (max-width: 767px) {
    .property-card__placeholder--bungalov { 
        background: linear-gradient(135deg, #D32F2F 0%, #C62828 100%); 
    }
}
.property-card__placeholder--bungalov::before {
    content: '🏡';
    font-size: 64px;
    opacity: 0.9;
    filter: drop-shadow(0 4px 8px rgba(0,0,0,0.2));
}

/* Villa default */
.property-card__placeholder--villa { 
    background: linear-gradient(135deg, #1565C0 0%, #0D47A1 100%); 
}
@media (max-width: 767px) {
    .property-card__placeholder--villa { 
        background: linear-gradient(135deg, #1976D2 0%, #1565C0 100%); 
    }
}
.property-card__placeholder--villa::before {
    content: '🏰';
    font-size: 64px;
    opacity: 0.9;
    filter: drop-shadow(0 4px 8px rgba(0,0,0,0.2));
}

/* Tiny House default */
.property-card__placeholder--tiny-house { 
    background: linear-gradient(135deg, #E65100 0%, #BF360C 100%); 
}
@media (max-width: 767px) {
    .property-card__placeholder--tiny-house { 
        background: linear-gradient(135deg, #F57C00 0%, #E65100 100%); 
    }
}
.property-card__placeholder--tiny-house::before {
    content: '🏠';
    font-size: 64px;
    opacity: 0.9;
    filter: drop-shadow(0 4px 8px rgba(0,0,0,0.2));
}

/* Glamping default */
.property-card__placeholder--glamping { 
    background: linear-gradient(135deg, #2E7D32 0%, #1B5E20 100%); 
}
@media (max-width: 767px) {
    .property-card__placeholder--glamping { 
        background: linear-gradient(135deg, #388E3C 0%, #2E7D32 100%); 
    }
}
.property-card__placeholder--glamping::before {
    content: '⛺';
    font-size: 64px;
    opacity: 0.9;
    filter: drop-shadow(0 4px 8px rgba(0,0,0,0.2));
}

/* Generic fallback */
.property-card__placeholder--default { 
    background: linear-gradient(135deg, #455A64 0%, #263238 100%); 
}
.property-card__placeholder--default::before {
    content: '🏘️';
    font-size: 64px;
    opacity: 0.9;
    filter: drop-shadow(0 4px 8px rgba(0,0,0,0.2));
}

/* Badges - Readable */
.property-card__badges { position: absolute; top: 12px; left: 12px; display: flex; gap: 6px; flex-wrap: wrap; }
.property-card__badge { 
    padding: 6px 12px; 
    background: rgba(15,23,42,0.8); 
    color: #fff; 
    font-size: 10px; 
    font-weight: 600; 
    border-radius: var(--radius-sm); 
    text-transform: uppercase; 
    letter-spacing: 0.5px;
    backdrop-filter: blur(8px);
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.property-card__badge--accent { background: var(--brand-amber); box-shadow: 0 2px 8px rgba(245,158,11,0.3); }
.property-card__badge--populer { background: #F59E0B; }
.property-card__badge--one-cikan { background: var(--brand-primary); }
.property-card__badge--yeni { background: #10B981; }
.property-card__badge--firsat { background: #8B5CF6; }
.property-card__badge--son-dakika { background: #EF4444; }
.property-card__badge--cok-satan { background: #3B82F6; }

/* Favorite Button - Subtle */
.property-card__favorite { 
    position: absolute; top: 12px; right: 12px; 
    width: 36px; height: 36px; 
    background: rgba(255,255,255,0.9); 
    border: none; border-radius: 50%; 
    cursor: pointer; 
    display: flex; align-items: center; justify-content: center; 
    transition: var(--transition); 
    opacity: 0;
}
.property-card:hover .property-card__favorite { opacity: 1; }
.property-card__favorite:hover { background: #fff; transform: scale(1.1); }
.property-card__favorite.is-active { opacity: 1; }
.property-card__favorite.is-active svg { fill: var(--brand-primary); color: var(--brand-primary); }
.property-card__favorite svg { width: 16px; height: 16px; color: var(--color-text-muted); transition: var(--transition); }

@keyframes favorite-pop {
    0% { transform: scale(1); }
    50% { transform: scale(1.3); }
    100% { transform: scale(1); }
}

/* Card Body */
.property-card__body { 
    padding: 16px 18px 18px; 
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

/* Location - Small & Muted */
.property-card__header { margin-bottom: 8px; }
.property-card__location { 
    display: inline-flex; align-items: center; gap: 4px; 
    font-size: 12px; color: var(--color-text-muted); 
}
.property-card__location svg { width: 12px; height: 12px; color: var(--color-text-muted); }

/* Title - Larger & Darker */
.property-card__title { 
    font-size: 17px; 
    font-weight: 700; 
    margin: 0 0 12px; 
    line-height: 1.35; 
    color: var(--color-text);
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
    letter-spacing: -0.25px;
}
@media (min-width: 768px) { .property-card__title { font-size: 18px; } }

/* Specs - Simplified with consistent 16px icons */
.property-card__specs { display: flex; gap: 16px; margin-bottom: 14px; flex-wrap: wrap; }
.property-card__spec { 
    display: flex; align-items: center; gap: 6px; 
    font-size: 13px; font-weight: 500;
    color: var(--color-text-light); 
}
.property-card__spec svg { width: 16px; height: 16px; color: var(--color-text-muted); stroke-width: 1.5; flex-shrink: 0; }
.property-card__spec--oda-plani { 
    font-weight: 600; 
    color: var(--brand-primary); 
}
.property-card__spec--oda-plani svg { color: var(--brand-primary); }

/* Features */
.property-card__features { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
.property-card__feature { 
    display: flex; align-items: center; gap: 6px;
    padding: 6px 12px; 
    background: var(--color-bg-alt); 
    font-size: 12px; font-weight: 500; 
    border-radius: var(--radius-md); 
    color: var(--color-text); 
    border: 1px solid var(--color-border-light);
    transition: var(--transition);
}
.property-card__feature:hover {
    background: rgba(198,40,40,0.05);
    border-color: var(--color-primary);
}
.property-card__feature svg,
.property-card__feature .feature-icon-svg,
.property-card__feature .feature-icon-fa { 
    width: 16px; height: 16px; 
    color: var(--color-primary); 
    flex-shrink: 0; 
    font-size: 16px;
}
.property-card__feature .feature-icon-svg {
    object-fit: contain;
}
.property-card__feature--more { 
    background: var(--color-primary); 
    color: #fff; 
    border-color: var(--color-primary);
}

/* Footer - Clean Price */
.property-card__footer { 
    display: flex; justify-content: space-between; align-items: center; 
    padding-top: 14px; border-top: 1px solid var(--color-border-light); 
    margin-top: auto;
}
.property-card__price { display: flex; align-items: baseline; gap: 4px; }
.property-card__price-value { font-size: 22px; font-weight: 700; color: var(--color-primary); letter-spacing: -0.5px; }
.property-card__price-period { font-size: 13px; color: var(--color-text-muted); font-weight: 500; }
.property-card__price-inquiry { font-size: 14px; font-weight: 600; color: var(--color-text-light); }

/* CTA Button - More Prominent */
.property-card__cta { 
    display: inline-flex; 
    align-items: center; 
    gap: 6px; 
    padding: 10px 16px;
    background: var(--color-primary);
    color: #fff;
    border-radius: var(--radius-md);
    font-size: 13px; 
    font-weight: 600; 
    transition: var(--transition);
    box-shadow: 0 2px 8px rgba(198,40,40,0.2);
}
.property-card__cta:hover { 
    background: var(--color-primary-dark); 
    color: #fff;
    transform: translateY(-2px); 
    box-shadow: 0 4px 12px rgba(198,40,40,0.3);
}
.property-card__cta svg { 
    width: 14px; 
    height: 14px; 
    transition: var(--transition); 
}
.property-card__cta:hover svg { 
    transform: translateX(2px); 
}

/* ========== HIGHLIGHT CARD ========== */
.highlight-card { display: grid; gap: 32px; background: var(--color-bg); border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-lg); }
@media (min-width: 768px) { .highlight-card { grid-template-columns: 1fr 1fr; } }
.highlight-card__image { position: relative; aspect-ratio: 4/3; }
@media (min-width: 768px) { .highlight-card__image { aspect-ratio: auto; min-height: 400px; } }
.highlight-card__image img { width: 100%; height: 100%; object-fit: cover; }
.highlight-card__badge { position: absolute; top: 20px; left: 20px; padding: 8px 16px; background: var(--brand-amber); color: #fff; font-size: 12px; font-weight: 600; border-radius: var(--radius-sm); }
.highlight-card__content { padding: 24px; display: flex; flex-direction: column; justify-content: center; }
@media (min-width: 768px) { .highlight-card__content { padding: 40px; } }
.highlight-card__label { font-size: 12px; font-weight: 600; color: var(--color-primary); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 8px; }
.highlight-card__title { font-size: 28px; font-weight: 700; margin: 0 0 12px; }
@media (min-width: 768px) { .highlight-card__title { font-size: 32px; } }
.highlight-card__location { display: flex; align-items: center; gap: 6px; font-size: 14px; color: var(--color-text-light); margin: 0 0 16px; }
.highlight-card__specs { display: flex; gap: 20px; margin-bottom: 16px; }
.highlight-card__specs span { display: flex; align-items: center; gap: 6px; font-size: 14px; color: var(--color-text-light); }
.highlight-card__specs svg { color: var(--color-primary); }
.highlight-card__desc { font-size: 15px; color: var(--color-text-light); line-height: 1.7; margin: 0 0 24px; }
.highlight-card__footer { display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.highlight-card__price-label { font-size: 12px; color: var(--color-text-light); display: block; }
.highlight-card__price-value { font-size: 28px; font-weight: 700; color: var(--color-primary); }





/* ========== VACATION TYPES - REDESIGNED ========== */
.section--vacation-types { background: var(--color-bg); }
.vacation-grid { 
    display: grid; 
    gap: 16px; 
    margin-top: 32px;
}
@media (min-width: 480px) { 
    .vacation-grid { 
        grid-template-columns: repeat(2, 1fr); 
        gap: 20px;
    } 
}
@media (min-width: 768px) { 
    .vacation-grid { 
        gap: 24px;
    } 
}
@media (min-width: 1024px) { 
    .vacation-grid { 
        grid-template-columns: repeat(3, 1fr); 
    } 
}

.vacation-card { 
    display: block;
    background: var(--color-bg); 
    border: 1px solid var(--color-border-light); 
    border-radius: var(--radius-lg); 
    overflow: hidden;
    transition: all 0.25s ease; 
    box-shadow: var(--shadow-sm);
    height: 100%;
}
.vacation-card:hover { 
    border-color: var(--color-primary); 
    box-shadow: var(--shadow-lg); 
    transform: translateY(-4px); 
}

.vacation-card__image { 
    position: relative;
    aspect-ratio: 16/10; 
    overflow: hidden; 
    background: linear-gradient(135deg, var(--color-bg-alt) 0%, var(--color-border-light) 100%);
}
.vacation-card__image img { 
    width: 100%; 
    height: 100%; 
    object-fit: cover; 
    transition: transform 0.3s ease;
}
.vacation-card:hover .vacation-card__image img { 
    transform: scale(1.05); 
}

/* Default vacation image */
.vacation-card__image--default {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
}
.vacation-card__image--default::before {
    content: '🏖️';
    font-size: 48px;
    opacity: 0.9;
    filter: drop-shadow(0 2px 4px rgba(0,0,0,0.2));
}

.vacation-card__content { 
    padding: 20px; 
    text-align: center;
}
.vacation-card__title { 
    font-size: 18px; 
    font-weight: 700; 
    margin: 0 0 8px; 
    color: var(--color-text); 
    line-height: 1.3;
}
.vacation-card__desc { 
    font-size: 14px; 
    color: var(--color-text-light); 
    margin: 0; 
    line-height: 1.5; 
    display: -webkit-box; 
    -webkit-line-clamp: 1; 
    -webkit-box-orient: vertical; 
    overflow: hidden;
}

/* ========== LOCATIONS GRID ========== */
.section--locations { background: var(--color-bg-alt); }
.locations-grid { display: grid; gap: 20px; }
@media (min-width: 640px) { .locations-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 768px) { .locations-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .locations-grid { grid-template-columns: repeat(4, 1fr); } }

.location-card { 
    display: block; 
    background: var(--color-bg); 
    border: 1px solid var(--color-border-light); 
    border-radius: var(--radius-lg); 
    overflow: hidden; 
    transition: all 0.25s ease; 
    box-shadow: var(--shadow-sm);
}
.location-card:hover { border-color: var(--color-primary); box-shadow: var(--shadow-lg); transform: translateY(-4px); }
.location-card__image { position: relative; aspect-ratio: 4/3; overflow: hidden; background: var(--color-bg-alt); }
.location-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s ease; }
.location-card:hover .location-card__image img { transform: scale(1.05); }

/* Location Placeholder with Icon Pattern */
.location-card__placeholder { 
    width: 100%; height: 100%; 
    background: linear-gradient(135deg, var(--color-bg-alt) 0%, var(--color-border-light) 100%); 
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 8px;
    position: relative;
}
.location-card__placeholder::before { 
    content: ''; 
    width: 56px; height: 56px;
    background: var(--color-bg);
    border-radius: 50%;
    box-shadow: var(--shadow-sm);
}
.location-card__placeholder::after { 
    content: '📍'; 
    font-size: 28px; 
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.location-card__content { padding: 16px; text-align: center; background: var(--color-bg); }
.location-card__name { font-size: 16px; font-weight: 700; color: var(--color-text); margin: 0 0 4px; }
.location-card__count { font-size: 13px; color: var(--color-text-muted); font-weight: 500; }

/* ========== TESTIMONIALS ========== */
.section--testimonials { background: var(--color-bg); }
.testimonials-grid { 
    display: grid; 
    gap: 20px; 
    margin-top: 32px; 
    margin-bottom: 48px; 
}
@media (max-width: 767px) {
    .testimonials-grid {
        display: flex;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        gap: 16px;
        padding-bottom: 8px;
    }
    .testimonials-grid::-webkit-scrollbar {
        height: 4px;
    }
    .testimonials-grid::-webkit-scrollbar-track {
        background: var(--color-border-light);
        border-radius: 2px;
    }
    .testimonials-grid::-webkit-scrollbar-thumb {
        background: var(--color-primary);
        border-radius: 2px;
    }
}
@media (min-width: 768px) { 
    .testimonials-grid { 
        grid-template-columns: repeat(3, 1fr); 
        gap: 28px; 
    } 
}

.testimonial-card { 
    background: var(--color-bg); 
    padding: 24px; 
    border-radius: var(--radius-lg); 
    border: 1px solid var(--color-border-light);
    transition: var(--transition);
    height: 100%;
    display: flex;
    flex-direction: column;
}
@media (max-width: 767px) {
    .testimonial-card {
        flex-shrink: 0;
        width: 280px;
        scroll-snap-align: start;
        padding: 20px;
    }
}
@media (min-width: 480px) and (max-width: 767px) {
    .testimonial-card {
        width: 320px;
    }
}
.testimonial-card:hover { border-color: var(--color-border); box-shadow: var(--shadow-md); transform: translateY(-2px); }

.testimonial-card__stars { color: var(--brand-amber); font-size: 16px; margin-bottom: 16px; letter-spacing: 2px; }
.testimonial-card__text { font-size: 15px; line-height: 1.75; color: var(--color-text); margin: 0 0 20px; font-style: italic; flex-grow: 1; }
.testimonial-card__author { display: flex; align-items: center; gap: 12px; }
.testimonial-card__avatar { 
    width: 48px; height: 48px; 
    background: linear-gradient(135deg, var(--color-bg-alt) 0%, var(--color-border-light) 100%); 
    color: var(--color-text); 
    border-radius: 50%; 
    display: flex; align-items: center; justify-content: center; 
    font-size: 15px; font-weight: 700; 
    border: 2px solid var(--color-bg);
    box-shadow: var(--shadow-sm);
    flex-shrink: 0;
}
.testimonial-card__info { display: flex; flex-direction: column; gap: 2px; }
.testimonial-card__name { font-size: 14px; font-weight: 600; color: var(--color-text); }
.testimonial-card__date { font-size: 12px; color: var(--color-text-muted); }

/* Trust Badges - Consistent Icons */
.trust-badges { 
    display: flex; flex-wrap: wrap; justify-content: center; gap: 24px;
    padding: 32px 20px;
    background: var(--color-bg-alt);
    border-radius: var(--radius-xl);
    border: 1px solid var(--color-border-light);
}
@media (min-width: 768px) { 
    .trust-badges { 
        gap: 56px; 
        padding: 44px 56px; 
    } 
}
@media (max-width: 479px) {
    .trust-badges {
        gap: 16px;
        padding: 24px 16px;
        grid-template-columns: repeat(2, 1fr);
        display: grid;
    }
}

.trust-badge { display: flex; flex-direction: column; align-items: center; gap: 12px; text-align: center; }
.trust-badge__icon {
    width: 56px; height: 56px;
    background: var(--color-bg);
    border-radius: var(--radius-lg);
    display: flex; align-items: center; justify-content: center;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border-light);
}
.trust-badge__icon svg, .trust-badge svg { width: 24px; height: 24px; color: var(--color-primary); stroke-width: 1.5; }
.trust-badge span { font-size: 13px; font-weight: 600; color: var(--color-text); max-width: 110px; line-height: 1.4; }

/* ========== WHY SECTION ========== */
.section--why { background: var(--color-bg); }
.why-grid { display: grid; gap: 24px; }
@media (min-width: 640px) { .why-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .why-grid--3 { grid-template-columns: repeat(3, 1fr); } }

/* Why Card - Equal Height, Tighter */
.why-card { 
    text-align: center; 
    padding: 36px 28px; 
    background: var(--color-bg); 
    border: 1px solid var(--color-border-light); 
    border-radius: var(--radius-lg); 
    transition: var(--transition);
    display: flex;
    flex-direction: column;
    align-items: center;
    height: 100%;
}
.why-card:hover { border-color: var(--color-primary); box-shadow: var(--shadow-md); transform: translateY(-3px); }

/* Icon Badge - Consistent 28px icon in 64px container */
.why-card__icon { 
    width: 68px; height: 68px; 
    margin: 0 auto 24px; 
    background: rgba(198,40,40,0.08); 
    border-radius: var(--radius-xl); 
    display: flex; align-items: center; justify-content: center; 
}
.why-card__icon svg { width: 28px; height: 28px; color: var(--color-primary); stroke-width: 1.5; }

.why-card__title { font-size: 18px; font-weight: 700; margin: 0 0 12px; color: var(--color-text); }
.why-card__text { font-size: 14px; color: var(--color-text-light); margin: 0; line-height: 1.65; flex-grow: 1; max-width: 280px; }

/* ========== FINAL CTA (ONLY section with wave) ========== */
.section--final-cta { padding: 0; margin-top: 48px; }
.final-cta { 
    position: relative; 
    padding: 100px 0 120px; 
    background: linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-primary-hover) 60%, var(--brand-dark) 100%); 
    color: #fff; 
    text-align: center; 
    overflow: hidden; 
}
.final-cta * { color: #fff; }
.final-cta__wave { position: absolute; left: 0; right: 0; height: 40px; background: var(--color-bg-alt); }
.final-cta__wave--top { top: 0; border-radius: 0 0 50% 50%; }
.final-cta__wave--bottom { bottom: 0; border-radius: 50% 50% 0 0; background: var(--color-bg-dark); }
.final-cta__content { position: relative; z-index: 1; max-width: 560px; margin: 0 auto; }
.final-cta__badge { 
    display: inline-block; padding: 10px 20px; 
    background: rgba(255,255,255,0.18); 
    border-radius: var(--radius-full); 
    font-size: 12px; font-weight: 600; 
    margin-bottom: 24px; 
    backdrop-filter: blur(10px); 
    border: 1px solid rgba(255,255,255,0.12);
    text-transform: uppercase;
    letter-spacing: 0.75px;
}
.final-cta__title { font-size: 26px; font-weight: 700; margin: 0 0 18px; line-height: 1.25; color: #fff; }
@media (min-width: 768px) { .final-cta__title { font-size: 36px; } }
.final-cta__text { font-size: 16px; opacity: 0.92; margin: 0 0 32px; line-height: 1.7; max-width: 480px; margin-left: auto; margin-right: auto; }
.final-cta__list { list-style: none; padding: 0; margin: 0 0 36px; display: flex; flex-wrap: wrap; justify-content: center; gap: 24px; }
@media (min-width: 768px) { .final-cta__list { gap: 32px; } }
.final-cta__list li { display: flex; align-items: center; gap: 10px; font-size: 14px; font-weight: 500; }
.final-cta__list svg { color: rgba(255,255,255,0.9); flex-shrink: 0; width: 18px; height: 18px; }

/* ========== FOOTER ========== */
.site-footer { 
    background: var(--color-bg-dark); 
    color: #fff; 
    margin-top: 0;
    overflow: hidden;
    position: relative;
    z-index: 1;
}
.footer-main { 
    padding: 48px 0 32px; 
}
@media (min-width: 768px) { 
    .footer-main { 
        padding: 64px 0 40px; 
    } 
}

.footer-grid { 
    display: grid; 
    gap: 32px; 
    max-width: 100%;
}
@media (min-width: 768px) { 
    .footer-grid { 
        grid-template-columns: 2fr 1fr 1fr 1fr; 
        gap: 40px; 
    } 
}
@media (min-width: 1024px) { 
    .footer-grid { 
        gap: 48px; 
    } 
}

/* Brand Column - Enhanced */
.footer-brand { 
    display: flex; 
    flex-direction: column; 
    gap: 20px; 
}
.footer-logo { 
    display: inline-block; 
}
.footer-logo__image { 
    height: 40px; 
    width: auto; 
    max-width: 160px; 
    object-fit: contain; 
}
.footer-logo__text { 
    font-size: 24px; 
    font-weight: 700; 
    color: #fff; 
}
.footer-logo__text span { 
    color: var(--color-primary-light); 
}
.footer-tagline { 
    font-size: 15px; 
    color: rgba(255,255,255,0.8); 
    margin: 0; 
    line-height: 1.6; 
    max-width: 280px; 
}

/* Social Links */
.footer-social { 
    display: flex; 
    gap: 12px; 
    margin-top: 4px;
}
.footer-social a { 
    width: 40px; 
    height: 40px; 
    background: rgba(255,255,255,0.1); 
    border-radius: 50%; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    color: rgba(255,255,255,0.8); 
    transition: var(--transition); 
    border: 1px solid rgba(255,255,255,0.1);
}
.footer-social a:hover { 
    background: var(--color-primary); 
    color: #fff;
    border-color: var(--color-primary);
    transform: translateY(-2px);
}

/* Footer Columns */
.footer-col { 
    display: flex; 
    flex-direction: column; 
    gap: 16px; 
}
.footer-col__title { 
    font-size: 16px; 
    font-weight: 700; 
    margin: 0; 
    color: #fff;
    padding-bottom: 8px;
    border-bottom: 2px solid var(--color-primary);
    max-width: fit-content;
}
.footer-links { 
    list-style: none; 
    padding: 0; 
    margin: 0; 
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.footer-links li { 
    margin: 0; 
}
.footer-links a { 
    color: rgba(255,255,255,0.75); 
    font-size: 14px; 
    font-weight: 400;
    transition: var(--transition);
    display: inline-block;
    padding: 4px 0;
}
.footer-links a:hover { 
    color: #fff; 
    padding-left: 8px;
}

/* Contact Links */
.footer-contact { 
    list-style: none; 
    padding: 0; 
    margin: 0; 
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.footer-contact li { 
    display: flex; 
    align-items: flex-start; 
    gap: 10px; 
    font-size: 14px; 
    color: rgba(255,255,255,0.75); 
    line-height: 1.5;
}
.footer-contact svg { 
    color: var(--color-primary-light); 
    flex-shrink: 0; 
    margin-top: 2px; 
}
.footer-contact a { 
    color: rgba(255,255,255,0.75); 
    transition: var(--transition);
}
.footer-contact a:hover { 
    color: #fff; 
}

/* Footer Bottom */
.footer-bottom { 
    padding: 20px 0; 
    border-top: 1px solid rgba(255,255,255,0.1); 
    margin-top: 16px;
}
@media (min-width: 768px) { 
    .footer-bottom { 
        padding: 24px 0; 
    } 
}
.footer-bottom__inner { 
    display: flex; 
    flex-direction: column; 
    gap: 16px; 
    text-align: center; 
}
@media (min-width: 768px) { 
    .footer-bottom__inner { 
        flex-direction: row; 
        justify-content: space-between; 
        align-items: center; 
        text-align: left; 
    } 
}
.footer-copyright { 
    font-size: 13px; 
    color: rgba(255,255,255,0.6); 
    margin: 0; 
}
.footer-legal { 
    display: flex; 
    gap: 20px; 
    list-style: none; 
    padding: 0; 
    margin: 0; 
    justify-content: center; 
    flex-wrap: wrap;
}
@media (min-width: 768px) { 
    .footer-legal { 
        justify-content: flex-end; 
    } 
}
.footer-legal a { 
    font-size: 13px; 
    color: rgba(255,255,255,0.6); 
    transition: var(--transition);
}
.footer-legal a:hover { 
    color: #fff; 
}

/* Mobile Footer Optimization */
@media (max-width: 767px) {
    .footer-main {
        padding: 40px 0 24px;
    }
    
    .footer-grid {
        gap: 28px;
    }
    
    .footer-brand {
        text-align: center;
        align-items: center;
        gap: 16px;
    }
    
    .footer-tagline {
        text-align: center;
        max-width: 100%;
    }
    
    .footer-whatsapp-btn {
        align-self: center;
    }
    
    .footer-social {
        justify-content: center;
    }
    
    .footer-col {
        text-align: center;
        gap: 12px;
    }
    
    .footer-col__title {
        align-self: center;
    }
    
    .footer-links a:hover {
        padding-left: 0;
        color: var(--color-primary-light);
    }
    
    .footer-contact li {
        justify-content: center;
        text-align: center;
    }
    
    .footer-legal {
        gap: 16px;
    }
}

/* ========== WHATSAPP FLOAT ========== */
.whatsapp-float {
    position: fixed; 
    bottom: 24px; 
    right: 24px; 
    z-index: 1000;
    width: 60px; 
    height: 60px; 
    background: var(--color-whatsapp);
    border-radius: 50%; 
    display: flex; 
    align-items: center; 
    justify-content: center;
    color: #fff; 
    box-shadow: 0 4px 20px rgba(37,211,102,0.4);
    transition: var(--transition);
    text-decoration: none;
}
.whatsapp-float:hover { 
    transform: scale(1.1); 
    color: #fff; 
    box-shadow: 0 6px 24px rgba(37,211,102,0.5); 
}
[dir="rtl"] .whatsapp-float { 
    right: auto; 
    left: 24px; 
}

/* Hide WhatsApp float on mobile for single property (sticky bar is used instead) */
@media (max-width: 1023px) {
    .single-property-page .whatsapp-float { 
        display: none; 
    }
}

/* Ensure WhatsApp float doesn't interfere with footer */
@media (min-height: 600px) {
    .whatsapp-float {
        bottom: 32px;
    }
}

/* ========== ARCHIVE PAGE ========== */
.archive-header { 
    position: relative;
    padding: 56px 0 48px; 
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 60%, var(--brand-dark) 100%); 
    color: #fff; 
    text-align: center;
    overflow: hidden;
}
@media (min-width: 768px) { .archive-header { padding: 72px 0 56px; } }
.archive-header::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.1);
    pointer-events: none;
}
.archive-header .container { position: relative; z-index: 1; max-width: 800px; }
.archive-header__title { 
    font-size: 32px; 
    font-weight: 700; 
    margin: 0 0 12px; 
    color: #fff;
    text-shadow: 0 2px 12px rgba(0,0,0,0.2);
    letter-spacing: -0.5px;
    line-height: 1.2;
}
@media (min-width: 768px) { .archive-header__title { font-size: 42px; letter-spacing: -1px; } }
.archive-header__desc { 
    font-size: 16px; 
    color: rgba(255,255,255,0.9); 
    margin: 0 0 20px; 
    line-height: 1.7;
    max-width: 560px;
    margin-left: auto;
    margin-right: auto;
}
.archive-header__count { 
    display: inline-flex;
    align-items: center;
    padding: 8px 20px;
    background: rgba(255,255,255,0.15);
    border: 1px solid rgba(255,255,255,0.25);
    border-radius: var(--radius-full);
    font-size: 14px; 
    color: #fff;
    font-weight: 500;
    margin: 0;
    backdrop-filter: blur(4px);
}

.archive-content { padding: 40px 0 80px; background: var(--color-bg-alt); }
.archive-layout { display: grid; gap: 32px; }
@media (min-width: 1024px) { .archive-layout { grid-template-columns: 280px 1fr; gap: 40px; } }

.archive-toolbar { display: flex; flex-wrap: wrap; gap: 16px; justify-content: space-between; align-items: center; margin-bottom: 24px; padding-bottom: 24px; border-bottom: 1px solid var(--color-border); }
.archive-toolbar__count { font-size: 14px; color: var(--color-text-light); }
.archive-toolbar__sort { display: flex; align-items: center; gap: 8px; }
.archive-toolbar__sort label { font-size: 13px; color: var(--color-text-light); }
.archive-toolbar__sort select { padding: 8px 12px; border: 1px solid var(--color-border); border-radius: var(--radius-sm); font-size: 13px; }

/* ========== ARCHIVE LAYOUT & FILTERS ========== */
.archive-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 40px;
    align-items: start;
}

@media (max-width: 1023px) {
    .archive-layout {
        grid-template-columns: 1fr;
        gap: 0;
    }
}

/* Desktop Filters */
.archive-filters {
    display: block;
}

@media (max-width: 1023px) {
    .archive-filters {
        display: none;
    }
}

.filter-panel {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 24px;
    position: sticky;
    top: 100px;
    box-shadow: var(--shadow-card);
    width: 100%;
    display: block;
}

.filter-panel__title {
    font-size: 18px;
    font-weight: 600;
    margin: 0 0 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--color-border);
    color: var(--color-text);
}

.filter-group {
    margin-bottom: 24px;
    width: 100%;
    display: block;
}

.filter-group:last-child {
    margin-bottom: 0;
}

.filter-group__title {
    font-size: 14px;
    font-weight: 600;
    margin: 0 0 12px;
    color: var(--color-text);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.filter-checkbox {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 0;
    cursor: pointer;
    font-size: 14px;
    width: 100%;
}

.filter-checkbox input[type="checkbox"] {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

.filter-checkbox__count {
    margin-left: auto;
    color: var(--color-text-light);
    font-size: 12px;
}

.filter-select {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 14px;
    background: var(--color-white);
}

/* CRITICAL: Price Range - MUST stay stacked vertically */
.price-range {
    display: flex;
    flex-direction: column;
    gap: 8px;
    width: 100%;
}

.price-range input {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 14px;
    box-sizing: border-box;
}

.price-range span {
    display: none; /* Hide the dash separator */
}

.filter-actions {
    margin-top: 24px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.filter-actions .btn {
    width: 100%;
    justify-content: center;
}

/* Mobile Filter Bar */
.mobile-filter-bar {
    display: none;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    padding: 16px;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-card);
}

@media (max-width: 1023px) {
    .mobile-filter-bar {
        display: flex;
    }
}

.mobile-filter-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    background: var(--brand-primary);
    color: white;
    border: none;
    border-radius: var(--radius-sm);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
}

.mobile-sort-select {
    padding: 8px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 13px;
    background: var(--color-white);
}

/* Mobile Filter Modal */
.mobile-filter-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9999;
    display: none;
}

.mobile-filter-modal.is-open {
    display: block;
}

.mobile-filter-modal__backdrop {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
}

.mobile-filter-modal__content {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    max-width: 400px;
    background: var(--color-white);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.mobile-filter-modal__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px;
    border-bottom: 1px solid var(--color-border);
    flex-shrink: 0;
}

.mobile-filter-modal__header h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
}

.mobile-filter-modal__close {
    background: none;
    border: none;
    padding: 4px;
    cursor: pointer;
    color: var(--color-text-light);
}

.mobile-filter-form {
    flex: 1;
    overflow-y: auto;
    padding: 20px;
    padding-bottom: 100px; /* Space for sticky actions */
}

.mobile-filter-group {
    margin-bottom: 24px;
}

.mobile-filter-group__title {
    font-size: 16px;
    font-weight: 600;
    margin: 0 0 12px;
    color: var(--color-text);
}

.mobile-filter-options {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.mobile-filter-checkbox {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    background: var(--color-bg-alt);
    border-radius: var(--radius-sm);
    cursor: pointer;
}

.mobile-filter-checkbox input[type="checkbox"] {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

.mobile-filter-checkbox__text {
    flex: 1;
    font-size: 14px;
}

.mobile-filter-checkbox__count {
    color: var(--color-text-light);
    font-size: 12px;
}

.mobile-filter-select {
    width: 100%;
    padding: 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 14px;
    background: var(--color-white);
}

/* CRITICAL: Mobile Price Range - MUST be stacked */
.mobile-price-range {
    display: flex;
    flex-direction: column;
    gap: 12px;
    width: 100%;
}

.mobile-price-input {
    width: 100%;
    padding: 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 14px;
    box-sizing: border-box;
}

.mobile-filter-actions {
    position: sticky;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 20px;
    background: var(--color-white);
    border-top: 1px solid var(--color-border);
    display: flex;
    gap: 12px;
    flex-shrink: 0;
}

.mobile-filter-actions .btn {
    flex: 1;
}

/* Property Grid - Mobile Responsive */
.property-grid {
    display: grid;
    gap: 24px;
}

.property-grid--3 {
    grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 1023px) {
    .property-grid--3 {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }
}

@media (max-width: 767px) {
    .property-grid--3 {
        grid-template-columns: 1fr;
        gap: 16px;
    }
}

/* Prevent horizontal scroll */
body {
    overflow-x: hidden;
}

.archive-results {
    min-width: 0; /* Prevent flex item from overflowing */
}
.filter-group { margin-bottom: 24px; }
.filter-group:last-child { margin-bottom: 0; }
.filter-group__title { font-size: 13px; font-weight: 600; margin: 0 0 12px; color: var(--color-text-light); text-transform: uppercase; letter-spacing: 0.5px; }
.filter-checkbox { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; cursor: pointer; font-size: 14px; transition: var(--transition); }
.filter-checkbox:hover { color: var(--brand-primary); }
.filter-checkbox input { width: 18px; height: 18px; accent-color: var(--brand-primary); cursor: pointer; }
.filter-checkbox input:focus-visible { outline: 2px solid var(--brand-primary); outline-offset: 2px; }
.filter-checkbox span { color: var(--color-text); }
.filter-checkbox__count { color: var(--color-text-muted); font-size: 12px; margin-left: auto; }
/* Active state for selected feature */
.filter-checkbox--active { 
    background: rgba(198,40,40,0.08); 
    border-radius: var(--radius-md); 
    padding: 8px 12px; 
    margin: -8px -12px 2px -12px; 
    border: 1px solid rgba(198,40,40,0.2); 
}
.filter-checkbox--active span { 
    color: var(--color-primary); 
    font-weight: 600; 
}
.filter-checkbox--active input[type="checkbox"] { 
    accent-color: var(--color-primary); 
    cursor: not-allowed; 
}
.filter-actions { display: flex; gap: 12px; margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--color-border); }
.filter-actions .btn { flex: 1; padding: 12px; font-size: 13px; }
.filter-actions .btn--primary { background: var(--brand-primary); }
.filter-actions .btn--primary:hover { background: var(--brand-primary-hover); }

/* Pagination */
.pagination { display: flex; justify-content: center; gap: 8px; margin-top: 48px; }
.page-numbers {
    display: flex; align-items: center; justify-content: center;
    min-width: 44px; height: 44px; padding: 0 14px;
    background: var(--color-bg); border: 1px solid var(--color-border);
    border-radius: var(--radius-md); font-size: 14px; font-weight: 500;
    color: var(--color-text); transition: var(--transition);
}
.page-numbers:hover { border-color: var(--color-primary); color: var(--color-primary); }
.page-numbers.current { background: var(--color-primary); border-color: var(--color-primary); color: #fff; }

/* ========== SINGLE PROPERTY ========== */
.single-property { padding: 32px 0 100px; }
.single-property__layout { display: grid; gap: 32px; }
@media (min-width: 1024px) { .single-property__layout { grid-template-columns: 1fr 400px; } }

.single-property__header { margin-bottom: 24px; }
.single-property__title { font-size: 28px; font-weight: 700; margin: 0 0 12px; }
@media (min-width: 768px) { .single-property__title { font-size: 36px; } }
.single-property__meta { display: flex; flex-wrap: wrap; gap: 16px; align-items: center; }
.single-property__location { display: flex; align-items: center; gap: 6px; font-size: 15px; color: var(--color-text-light); }
.single-property__location svg { color: var(--color-primary); }
.single-property__type { padding: 4px 12px; background: var(--color-primary); color: #fff; font-size: 12px; font-weight: 600; border-radius: var(--radius-sm); }

.single-property__specs { display: flex; flex-wrap: wrap; gap: 24px; padding: 20px 0; border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); margin-bottom: 32px; }
.spec-item { display: flex; align-items: center; gap: 10px; }
.spec-item__icon { width: 44px; height: 44px; background: rgba(198,40,40,0.1); border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; }
.spec-item__icon svg { color: var(--color-primary); }
.spec-item__text { font-size: 14px; }
.spec-item__value { font-weight: 600; display: block; }
.spec-item__label { color: var(--color-text-light); font-size: 12px; }

.single-property__section { margin-bottom: 40px; }
.single-property__section h2 { font-size: 20px; font-weight: 600; margin: 0 0 16px; padding-bottom: 12px; border-bottom: 1px solid var(--color-border); }
.single-property__content { font-size: 15px; line-height: 1.8; color: var(--color-text); }
.single-property__content p { margin: 0 0 16px; }

.feature-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
@media (min-width: 640px) { .feature-list { grid-template-columns: repeat(2, 1fr); } }
.feature-list__item { display: flex; align-items: center; gap: 12px; padding: 12px 16px; background: var(--color-bg-alt); border-radius: var(--radius-md); }
.feature-list__item svg,
.feature-list__item .feature-icon-svg,
.feature-list__item .feature-icon-fa { color: var(--color-primary); flex-shrink: 0; width: 24px; height: 24px; object-fit: contain; font-size: 20px; }

/* Font Awesome icons - ensure red color */
.feature-icon-fa,
i.feature-icon-fa,
.fas.feature-icon-fa,
.far.feature-icon-fa { 
    color: var(--color-primary) !important; 
}

.check-times { display: grid; gap: 16px; }
@media (min-width: 480px) { .check-times { grid-template-columns: repeat(2, 1fr); } }
.check-time { padding: 16px; background: var(--color-bg-alt); border-radius: var(--radius-md); }
.check-time__label { font-size: 12px; color: var(--color-text-light); margin-bottom: 4px; }
.check-time__value { font-size: 18px; font-weight: 600; }

.house-rules { white-space: pre-line; font-size: 14px; color: var(--color-text-light); line-height: 1.8; }

.property-map { border-radius: var(--radius-lg); overflow: hidden; }
.property-map iframe { width: 100%; height: 300px; border: 0; }

/* ========== GALLERY SLIDER ========== */
.gallery-slider { margin-bottom: 24px; }
.gallery-slider__main { position: relative; aspect-ratio: 16/10; border-radius: var(--radius-lg); overflow: hidden; background: var(--color-bg-alt); }
.gallery-slider__main img { width: 100%; height: 100%; object-fit: cover; }
.gallery-slider__nav {
    position: absolute; top: 50%; transform: translateY(-50%);
    width: 44px; height: 44px; background: rgba(255,255,255,0.95);
    border: none; border-radius: 50%; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    box-shadow: var(--shadow-md); transition: var(--transition);
}
.gallery-slider__nav:hover { background: #fff; transform: translateY(-50%) scale(1.05); }
.gallery-slider__nav--prev { left: 16px; }
.gallery-slider__nav--next { right: 16px; }
.gallery-slider__thumbs { display: flex; gap: 8px; margin-top: 12px; overflow-x: auto; padding-bottom: 8px; }
.gallery-slider__thumb {
    flex-shrink: 0; width: 80px; height: 60px;
    border: 2px solid transparent; border-radius: var(--radius-sm);
    overflow: hidden; cursor: pointer; padding: 0; background: none;
    transition: var(--transition);
}
.gallery-slider__thumb--active { border-color: var(--color-primary); }
.gallery-slider__thumb img { width: 100%; height: 100%; object-fit: cover; }
.gallery-slider__counter { text-align: center; font-size: 13px; color: var(--color-text-light); margin-top: 8px; }

/* ========== PRICE BOX (SIDEBAR) ========== */
.single-property__sidebar { position: relative; }
@media (min-width: 1024px) { .single-property__sidebar { position: sticky; top: 100px; align-self: start; } }

.price-box { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-xl); padding: 24px; box-shadow: var(--shadow-lg); }
.price-box__header { margin-bottom: 24px; padding-bottom: 20px; border-bottom: 1px solid var(--color-border); }
.price-box__price { display: flex; align-items: baseline; gap: 6px; margin-bottom: 4px; }
.price-box__amount { font-size: 32px; font-weight: 700; color: var(--color-primary); }
.price-box__period { font-size: 15px; color: var(--color-text-light); }
.price-box__note { font-size: 12px; color: var(--color-text-muted); }
.price-box__details { display: flex; gap: 20px; margin-top: 16px; padding-top: 16px; border-top: 1px dashed var(--color-border); }
.price-box__detail { font-size: 13px; }
.price-box__detail span { color: var(--color-text-light); }
.price-box__detail strong { color: var(--color-text); display: block; margin-top: 2px; }

.price-box__form { display: grid; gap: 16px; }
.price-box__field { display: flex; flex-direction: column; gap: 6px; }
.price-box__field label { font-size: 12px; font-weight: 600; color: var(--color-text-light); }
.price-box__field input,
.price-box__field select,
.price-box__field textarea {
    width: 100%; padding: 12px 14px;
    border: 1px solid var(--color-border); border-radius: var(--radius-md);
    font-size: 14px; font-family: inherit; transition: var(--transition);
}
.price-box__field input:focus,
.price-box__field select:focus,
.price-box__field textarea:focus { border-color: var(--color-primary); outline: none; }
.price-box__field textarea { resize: vertical; min-height: 80px; }
.price-box__row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

.price-box__divider { text-align: center; margin: 20px 0; color: var(--color-text-muted); font-size: 13px; position: relative; }
.price-box__divider::before,
.price-box__divider::after { content: ''; position: absolute; top: 50%; width: calc(50% - 20px); height: 1px; background: var(--color-border); }
.price-box__divider::before { left: 0; }
.price-box__divider::after { right: 0; }

.btn--whatsapp { background: var(--color-whatsapp); color: #fff; width: 100%; padding: 14px; font-size: 15px; }
.btn--whatsapp:hover { background: #1fb855; color: #fff; }

.price-box__min-nights { text-align: center; font-size: 12px; color: var(--color-text-muted); margin-top: 16px; }

/* Mobile Sticky CTA */
.whatsapp-sticky { display: none; }
@media (max-width: 1023px) {
    .single-property-page .whatsapp-sticky {
        display: block; position: fixed; bottom: 0; left: 0; right: 0; z-index: 100;
        padding: 12px 16px; background: var(--color-bg); border-top: 1px solid var(--color-border);
        box-shadow: 0 -4px 20px rgba(0,0,0,0.1);
    }
    .whatsapp-sticky__btn {
        display: flex; align-items: center; justify-content: center; gap: 10px;
        width: 100%; padding: 14px; background: var(--color-whatsapp); color: #fff;
        border-radius: var(--radius-md); font-weight: 600; font-size: 15px;
    }
    .whatsapp-sticky__price { margin-left: auto; font-size: 14px; opacity: 0.9; }
}

/* ========== FORM MESSAGES ========== */
.rentgalov-form-message { padding: 14px 16px; border-radius: var(--radius-md); font-size: 14px; margin-bottom: 16px; }
.rentgalov-form-message--success { background: #d1fae5; color: #065f46; border: 1px solid #a7f3d0; }
.rentgalov-form-message--error { background: #fee2e2; color: #991b1b; border: 1px solid #fecaca; }

/* ========== UTILITIES ========== */
.text-center { text-align: center; }
.visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

/* ========== NO RESULTS ========== */
.no-results { text-align: center; padding: 60px 20px; }
.no-results p { font-size: 16px; color: var(--color-text-light); margin: 0 0 24px; }

/* ========== PAGE TEMPLATE ========== */
.page-header { margin-bottom: 32px; }
.page-header h1 { font-size: 36px; font-weight: 700; margin: 0; }
.page-content { font-size: 16px; line-height: 1.8; }
.page-content p { margin: 0 0 20px; }
.page-content h2 { font-size: 24px; margin: 32px 0 16px; }
.page-content h3 { font-size: 20px; margin: 28px 0 12px; }
.page-content ul, .page-content ol { margin: 0 0 20px; padding-left: 24px; }
.page-content li { margin-bottom: 8px; }

/* ========== 404 PAGE ========== */
.error-404 { text-align: center; padding: 80px 20px; }
.error-404 h1 { font-size: 120px; font-weight: 700; color: var(--color-primary); margin: 0; line-height: 1; }
.error-404 h2 { font-size: 28px; margin: 16px 0; }
.error-404 p { font-size: 16px; color: var(--color-text-light); margin: 0 0 32px; }

/* ========== TAXONOMY HEADER ========== */
.taxonomy-header { padding: 48px 0; background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%); color: #fff; text-align: center; }
.taxonomy-header__title { font-size: 32px; font-weight: 700; margin: 0 0 12px; }
@media (min-width: 768px) { .taxonomy-header__title { font-size: 40px; } }
.taxonomy-header__desc { font-size: 16px; opacity: 0.9; margin: 0 0 12px; max-width: 600px; margin-left: auto; margin-right: auto; }
.taxonomy-header__count { font-size: 14px; opacity: 0.8; margin: 0; }

/* ========== RESPONSIVE ADJUSTMENTS ========== */
@media (max-width: 639px) {
    .highlight-card__specs { flex-wrap: wrap; gap: 12px; }
    .vacation-card { flex-direction: column; }
    .vacation-card__image { width: 100%; height: 160px; }
}

/* ========== PRINT STYLES ========== */
@media print {
    .site-header, .site-footer, .whatsapp-float, .whatsapp-sticky, .price-box { display: none; }
    .single-property__layout { display: block; }
    .single-property__sidebar { display: none; }
}


/* ========================================
   SINGLE PROPERTY PAGE - REFINED UI
   ======================================== */

/* Breadcrumb */
.sp-breadcrumb { padding: 6px 0; background: var(--color-bg-alt); border-bottom: 1px solid var(--color-border-light); overflow: hidden; }
.breadcrumb { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; font-size: 13px; max-width: 100%; }
.breadcrumb__current { max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.breadcrumb a { color: var(--color-text-light); }
.breadcrumb a:hover { color: var(--color-primary); }
.breadcrumb__sep { color: var(--color-text-muted); }
.breadcrumb__current { color: var(--color-text); font-weight: 500; }

/* Single Property Page - Prevent Overflow */
.single-property-page { overflow-x: hidden; max-width: 100vw; }

/* Hero Section - Above the Fold */
.sp-hero { padding: 12px 0 0; overflow: hidden; }
.sp-hero__grid { display: grid; gap: 24px; }
@media (min-width: 1024px) {
    .sp-hero__grid { 
        grid-template-columns: 1fr 380px; 
        gap: 32px; 
        align-items: start; 
    }
}

/* Gallery */
.sp-gallery { position: relative; max-width: 100%; overflow: hidden; }
.sp-gallery__main {
    position: relative; aspect-ratio: 16/10; border-radius: var(--radius-xl); max-width: 100%;
    overflow: hidden; background: var(--color-bg-alt);
}
.sp-gallery__main img { width: 100%; height: 100%; object-fit: cover; transition: opacity 0.3s ease; }
.sp-gallery__placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, var(--color-bg-alt) 0%, var(--color-border) 100%); }

.sp-gallery__badges { position: absolute; top: 16px; left: 16px; display: flex; gap: 8px; flex-wrap: wrap; }
.sp-gallery__badge {
    padding: 6px 14px; background: var(--brand-primary); color: #fff;
    font-size: 12px; font-weight: 600; border-radius: var(--radius-full);
    box-shadow: 0 2px 8px rgba(196,30,58,0.3);
}
.sp-gallery__badge--amber { background: var(--brand-amber); box-shadow: 0 2px 8px rgba(245,158,11,0.3); }
.sp-gallery__badge--populer { background: #F59E0B; box-shadow: 0 2px 8px rgba(245,158,11,0.3); }
.sp-gallery__badge--one-cikan { background: var(--brand-primary); box-shadow: 0 2px 8px rgba(196,30,58,0.3); }
.sp-gallery__badge--yeni { background: #10B981; box-shadow: 0 2px 8px rgba(16,185,129,0.3); }
.sp-gallery__badge--firsat { background: #8B5CF6; box-shadow: 0 2px 8px rgba(139,92,246,0.3); }
.sp-gallery__badge--son-dakika { background: #EF4444; box-shadow: 0 2px 8px rgba(239,68,68,0.3); }
.sp-gallery__badge--cok-satan { background: #3B82F6; box-shadow: 0 2px 8px rgba(59,130,246,0.3); }

.sp-gallery__nav {
    position: absolute; top: 50%; transform: translateY(-50%);
    width: 48px; height: 48px; background: rgba(255,255,255,0.95);
    border: none; border-radius: 50%; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    box-shadow: var(--shadow-lg); transition: var(--transition);
    opacity: 0;
}
.sp-gallery:hover .sp-gallery__nav { opacity: 1; }
.sp-gallery__nav:hover { background: #fff; transform: translateY(-50%) scale(1.05); }
.sp-gallery__nav--prev { left: 16px; }
.sp-gallery__nav--next { right: 16px; }

.sp-gallery__counter {
    position: absolute; bottom: 16px; left: 16px;
    padding: 6px 14px; background: rgba(0,0,0,0.7); color: #fff;
    font-size: 13px; font-weight: 500; border-radius: 20px;
}

.sp-gallery__video {
    position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
    width: 72px; height: 72px; background: rgba(0,0,0,0.6);
    border: none; border-radius: 50%; color: #fff; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: var(--transition);
}
.sp-gallery__video:hover { background: rgba(0,0,0,0.8); transform: translate(-50%, -50%) scale(1.1); }

.sp-gallery__fullscreen {
    position: absolute; bottom: 16px; right: 16px;
    width: 40px; height: 40px; background: rgba(255,255,255,0.95);
    border: none; border-radius: var(--radius-sm); cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    box-shadow: var(--shadow-md);
}
.sp-gallery__fullscreen:hover { background: #fff; }

.sp-gallery__thumbs {
    display: flex; gap: 10px; margin-top: 12px;
    overflow-x: auto; padding-bottom: 8px;
    -webkit-overflow-scrolling: touch;
}
.sp-gallery__thumbs::-webkit-scrollbar { height: 4px; }
.sp-gallery__thumbs::-webkit-scrollbar-track { background: var(--color-border-light); border-radius: 2px; }
.sp-gallery__thumbs::-webkit-scrollbar-thumb { background: var(--color-primary); border-radius: 2px; }

.sp-gallery__thumb {
    flex-shrink: 0; width: 88px; height: 66px;
    border: 3px solid transparent; border-radius: var(--radius-md);
    overflow: hidden; cursor: pointer; padding: 0; background: none;
    transition: var(--transition);
}
.sp-gallery__thumb:hover { border-color: var(--color-border); }
.sp-gallery__thumb--active { border-color: var(--color-primary); }
.sp-gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }

/* CTA Box - Sticky Sidebar */
.sp-hero__sidebar { position: relative; }
@media (min-width: 1024px) {
    .sp-hero__sidebar { position: sticky; top: 90px; }
}

.sp-cta-box {
    background: var(--color-bg); border: 1px solid var(--color-border);
    border-radius: var(--radius-xl); padding: 24px;
    box-shadow: var(--shadow-xl);
}

.sp-cta-box__header { margin-bottom: 16px; }
.sp-cta-box__title { font-size: 18px; font-weight: 700; margin: 0 0 6px; line-height: 1.3; }
.sp-cta-box__location {
    display: flex; align-items: center; gap: 6px;
    font-size: 13px; color: var(--color-text-light); margin: 0;
}

.sp-cta-box__price { margin-bottom: 20px; }
.sp-cta-box__price-main { display: flex; align-items: baseline; gap: 6px; margin-bottom: 4px; }
.sp-cta-box__price-amount { font-size: 32px; font-weight: 700; color: var(--color-primary); }
.sp-cta-box__price-period { font-size: 15px; color: var(--color-text-light); }
.sp-cta-box__price-note { font-size: 12px; color: var(--color-text-muted); margin: 0; }
.sp-cta-box__price-details { display: flex; gap: 20px; margin-top: 12px; padding-top: 12px; border-top: 1px dashed var(--color-border); }
.sp-cta-box__price-detail { font-size: 13px; }
.sp-cta-box__price-detail span { color: var(--color-text-light); display: block; }
.sp-cta-box__price-detail strong { color: var(--color-text); }

.sp-cta-box__divider { height: 1px; background: var(--color-border); margin: 20px 0; }

.sp-cta-box__form { margin-bottom: 20px; }
/* Date fields - responsive grid: 2 cols desktop, stacked mobile */
.sp-cta-box__dates { 
    display: grid; 
    grid-template-columns: 1fr; 
    gap: 12px; 
    margin-bottom: 12px; 
}
@media (min-width: 400px) {
    .sp-cta-box__dates { grid-template-columns: 1fr 1fr; }
}
.sp-cta-box__field { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.sp-cta-box__field label { font-size: 11px; font-weight: 600; color: var(--color-text-light); text-transform: uppercase; letter-spacing: 0.5px; }
.sp-cta-box__input {
    display: flex; align-items: center; gap: 8px;
    padding: 10px 12px; border: 1px solid var(--color-border);
    border-radius: var(--radius-md); background: var(--color-bg-alt);
    transition: var(--transition);
    overflow: hidden;
}
.sp-cta-box__input:focus-within { border-color: var(--color-primary); background: var(--color-bg); }
.sp-cta-box__input svg { color: var(--color-text-muted); flex-shrink: 0; width: 16px; height: 16px; }
.sp-cta-box__input input,
.sp-cta-box__input select {
    flex: 1; border: none; background: none; font-size: 13px;
    color: var(--color-text); outline: none; min-width: 0; font-family: inherit;
    width: 100%; max-width: 100%;
}
.sp-cta-box__input input[type="date"] {
    -webkit-appearance: none; appearance: none;
}

.sp-cta-box__btn {
    display: flex; align-items: center; justify-content: center; gap: 10px;
    width: 100%; padding: 16px; border: none; border-radius: var(--radius-md);
    font-size: 15px; font-weight: 600; cursor: pointer; transition: var(--transition);
    text-decoration: none;
}
.sp-cta-box__btn--primary {
    background: var(--color-whatsapp); color: #fff; margin-bottom: 12px;
}
.sp-cta-box__btn--primary:hover { background: #1fb855; color: #fff; transform: translateY(-2px); box-shadow: 0 4px 12px rgba(37,211,102,0.3); }
.sp-cta-box__btn--secondary {
    background: var(--color-bg-alt); color: var(--color-text); border: 1px solid var(--color-border);
}
.sp-cta-box__btn--secondary:hover { border-color: var(--color-primary); color: var(--color-primary); }

.sp-cta-box__trust {
    display: flex; align-items: center; justify-content: center; gap: 8px;
    margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--color-border-light);
    font-size: 12px; color: var(--color-text-light);
}
.sp-cta-box__trust svg { color: var(--color-primary); }

.sp-cta-box__min-nights {
    display: flex; align-items: center; justify-content: center; gap: 6px;
    margin-top: 12px; font-size: 12px; color: var(--color-text-muted);
}

/* Content Sections */
.sp-content { padding: 0; overflow: hidden; max-width: 100%; margin: 0; }
.sp-content__grid { max-width: 800px; margin: 0; padding: 0; }
.sp-content__main { 
    max-width: 100%; 
    overflow: hidden; 
    display: flex;
    flex-direction: column;
    margin: 0;
    padding: 0;
}
@media (min-width: 1024px) { .sp-content__main { max-width: 700px; } }

.sp-section { padding: 0; border-bottom: 1px solid var(--color-border-light); overflow: hidden; max-width: 100%; margin: 0; }
.sp-section:last-of-type { border-bottom: none; }
.sp-section__title { font-size: 22px; font-weight: 700; margin: 0 0 24px; color: var(--color-text); line-height: 1.3; word-wrap: break-word; }
.sp-section__subtitle { font-size: 15px; color: var(--color-text-light); margin: -16px 0 24px; line-height: 1.5; }

/* About Section */
.sp-about { border-bottom: none; padding: 0; margin-top: 0; }
.sp-title { font-size: 28px; font-weight: 700; margin: 0; line-height: 1.3; }
@media (min-width: 768px) { .sp-title { font-size: 32px; } }
.sp-meta { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; margin-bottom: 0; }
.sp-meta__location { display: flex; align-items: center; gap: 6px; font-size: 14px; color: var(--color-text-light); }
.sp-meta__location svg { color: var(--color-primary); }
.sp-meta__type { padding: 4px 12px; background: var(--color-primary); color: #fff; font-size: 12px; font-weight: 600; border-radius: var(--radius-sm); }

/* About section layout */
.sp-about { 
    order: -1;
    margin: 0;
    padding: 0;
}

/* Short description - visible above full description */
.sp-about__text {
    display: block;
    margin: 4px 0 8px;
}
.sp-about__text p {
    margin: 0;
    font-size: 15px;
    line-height: 1.7;
    color: var(--color-text);
    font-weight: 400;
}

/* Full description - collapsed by default */
.sp-about__full {
    display: block;
    position: relative;
    max-height: 100px;
    overflow: hidden;
    margin: 0;
}
.sp-about__full::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 40px;
    background: linear-gradient(transparent, var(--color-bg));
    pointer-events: none;
}
.sp-about__full.is-expanded {
    max-height: none;
    overflow: visible;
}
.sp-about__full.is-expanded::after {
    display: none;
}
.sp-about__full p { 
    margin: 0 0 16px; 
    font-size: 15px; 
    line-height: 1.8; 
    max-width: 100%; 
    overflow-wrap: break-word; 
    word-wrap: break-word; 
    color: var(--color-text); 
}
.sp-about__full p:first-child { margin-top: 0; }
.sp-about__full p:last-child { margin-bottom: 0; }

/* Toggle button - visible */
.sp-about__toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: none;
    padding: 8px 0;
    font-size: 14px;
    font-weight: 600;
    color: var(--color-primary);
    cursor: pointer;
    margin-top: 8px;
}
.sp-about__toggle:hover {
    text-decoration: underline;
}
.sp-about__toggle .show-less { display: none; }
.sp-about__toggle.is-expanded .show-more { display: none; }
.sp-about__toggle.is-expanded .show-less { display: inline; }
.sp-about__toggle svg { transition: transform 0.2s ease; }
.sp-about__toggle.is-expanded svg { transform: rotate(180deg); }

/* Highlights - Kompakt tasarım */
.sp-highlights {
    margin-top: 16px !important;
}
.sp-highlights__grid {
    display: grid; 
    grid-template-columns: repeat(2, 1fr); 
    gap: 12px; 
    margin-bottom: 20px;
}
@media (min-width: 640px) { 
    .sp-highlights__grid { grid-template-columns: repeat(4, 1fr); gap: 14px; } 
}
@media (min-width: 1024px) { 
    .sp-highlights__grid { grid-template-columns: repeat(4, 1fr); gap: 16px; } 
}

.sp-highlight {
    display: flex; 
    flex-direction: column; 
    align-items: center; 
    text-align: center;
    padding: 14px 12px;
    background: var(--color-bg-alt);
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border-light);
    transition: var(--transition);
}
.sp-highlight:hover {
    background: rgba(198,40,40,0.05);
    border-color: var(--color-primary);
    transform: translateY(-2px);
}

.sp-highlight__icon {
    width: 40px; 
    height: 40px;
    background: rgba(198,40,40,0.1);
    border-radius: var(--radius-md);
    display: flex; 
    align-items: center; 
    justify-content: center;
    margin-bottom: 8px;
}
.sp-highlight__icon svg,
.sp-highlight__icon .feature-icon-fa,
.sp-highlight__icon .feature-icon-svg {
    width: 20px; 
    height: 20px; 
    color: var(--color-primary);
    font-size: 18px;
}

.sp-highlight__name {
    font-size: 12px; 
    font-weight: 600; 
    color: var(--color-text);
    line-height: 1.3;
}

/* Oda Seçenekleri (Bungalov Multi-Unit) - Premium Card Grid */
.sp-units__list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}

@media (min-width: 640px) {
    .sp-units__list {
        grid-template-columns: repeat(2, 1fr);
    }
}

.sp-unit {
    display: flex;
    flex-direction: column;
    padding: 20px;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    transition: var(--transition);
    box-shadow: var(--shadow-card);
}

.sp-unit:hover {
    border-color: var(--brand-primary);
    box-shadow: var(--shadow-card-hover);
    transform: translateY(-2px);
}

.sp-unit__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--color-border-light);
}

.sp-unit__name {
    font-size: 16px;
    font-weight: 700;
    color: var(--color-text);
}

.sp-unit__plan {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    background: var(--brand-primary);
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    border-radius: var(--radius-full);
    letter-spacing: 0.02em;
}

.sp-unit__specs {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

.sp-unit__spec {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    background: var(--color-bg-alt);
    border-radius: var(--radius-sm);
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text);
}

.sp-unit__spec svg {
    color: var(--brand-primary);
    flex-shrink: 0;
    width: 16px;
    height: 16px;
}

.sp-unit__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: auto;
    padding-top: 16px;
    border-top: 1px solid var(--color-border-light);
}

.sp-unit__price {
    font-size: 18px;
    font-weight: 700;
    color: var(--brand-primary);
}

.sp-unit__price small {
    font-size: 13px;
    font-weight: 400;
    color: var(--color-text-light);
}

.sp-unit__price--inquiry {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-light);
}

.sp-unit__cta {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: var(--color-whatsapp);
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    border-radius: var(--radius-sm);
    text-decoration: none;
    transition: var(--transition);
}

.sp-unit__cta:hover {
    background: #1DA851;
    color: #fff;
}

.sp-unit__cta svg {
    color: #fff;
    width: 16px;
    height: 16px;
}
    
    .sp-unit__specs {
        flex: 1;
        justify-content: flex-start;
    }
}

/* Specs - Kompakt tasarım */
.sp-specs__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
@media (min-width: 640px) { .sp-specs__grid { grid-template-columns: repeat(3, 1fr); gap: 14px; } }
@media (min-width: 1024px) { .sp-specs__grid { grid-template-columns: repeat(5, 1fr); gap: 12px; } }
.sp-spec {
    display: flex; align-items: center; gap: 10px;
    padding: 12px 14px; background: var(--color-bg-alt);
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border-light);
}
.sp-spec__icon {
    width: 36px; height: 36px; background: rgba(198,40,40,0.1);
    border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.sp-spec__icon svg { color: var(--color-primary); width: 18px; height: 18px; }
.sp-spec__label { font-size: 11px; color: var(--color-text-light); display: block; }
.sp-spec__value { font-size: 14px; font-weight: 600; color: var(--color-text); }

/* Amenities - Kompakt tasarım */
.sp-amenities__list {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px;
    list-style: none; padding: 0; margin: 0;
}
@media (min-width: 640px) { .sp-amenities__list { grid-template-columns: repeat(3, 1fr); gap: 10px; } }
@media (min-width: 1024px) { .sp-amenities__list { grid-template-columns: repeat(4, 1fr); } }
.sp-amenities__item {
    display: flex; align-items: center; gap: 8px;
    padding: 8px 12px;
    background: var(--color-bg-alt);
    border-radius: var(--radius-sm);
    font-size: 13px; color: var(--color-text);
    border: 1px solid var(--color-border-light);
    transition: var(--transition);
}
.sp-amenities__item:hover {
    background: rgba(198,40,40,0.05);
    border-color: var(--color-primary);
}
.sp-amenities__item svg { 
    color: var(--color-primary); 
    flex-shrink: 0; 
    width: 18px; 
    height: 18px; 
}

/* Calendar */
.sp-calendar__wrap {
    background: var(--color-bg); border: 1px solid var(--color-border);
    border-radius: var(--radius-lg); padding: 24px; max-width: 400px;
}
.sp-calendar__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.sp-calendar__month { font-size: 16px; font-weight: 600; }
.sp-calendar__nav {
    width: 36px; height: 36px; background: var(--color-bg-alt);
    border: none; border-radius: var(--radius-sm); cursor: pointer;
    display: flex; align-items: center; justify-content: center;
}
.sp-calendar__nav:hover { background: var(--color-border); }
.sp-calendar__grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; text-align: center; }
.sp-calendar__day-name { font-size: 11px; font-weight: 600; color: var(--color-text-light); padding: 8px 0; }
.sp-calendar__day { padding: 10px 0; font-size: 13px; border-radius: var(--radius-sm); }
.sp-calendar__day--empty { background: none; }
.sp-calendar__day--past { color: var(--color-text-muted); }
.sp-calendar__day--today { background: var(--color-primary); color: #fff; font-weight: 600; }
.sp-calendar__day--available { background: rgba(196,30,58,0.1); color: var(--brand-primary); }
.sp-calendar__day--booked { background: var(--color-bg-alt); color: var(--color-text-muted); text-decoration: line-through; }
.sp-calendar__legend { display: flex; justify-content: center; gap: 24px; margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--color-border-light); }
.sp-calendar__legend-item { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--color-text-light); }
.sp-calendar__dot { width: 12px; height: 12px; border-radius: 50%; }
.sp-calendar__dot--available { background: var(--color-primary); }
.sp-calendar__dot--booked { background: var(--color-text-muted); }
.sp-calendar__note {
    display: flex; align-items: center; gap: 8px;
    margin-top: 16px; font-size: 13px; color: var(--color-text-light);
}
.sp-calendar__note svg { color: var(--color-primary); flex-shrink: 0; }

/* Location */
.sp-location__address {
    display: flex; align-items: center; gap: 10px;
    font-size: 16px; color: var(--color-text); margin: 0 0 20px;
    font-weight: 500;
}
.sp-location__address svg { color: var(--brand-primary); }
.sp-location__map { border-radius: var(--radius-lg); overflow: hidden; background: var(--color-bg-alt); box-shadow: var(--shadow-sm); }
.sp-location__placeholder {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 20px; padding: 60px 24px; text-align: center;
}
.sp-location__placeholder svg { color: var(--color-text-muted); }
.sp-location__placeholder .btn {
    margin-top: 8px; padding: 12px 24px;
}
.sp-location__embed iframe { width: 100%; height: 320px; border: 0; }

/* Rules */
.sp-rules__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-bottom: 24px; }
@media (min-width: 640px) { .sp-rules__grid { grid-template-columns: repeat(3, 1fr); } }
.sp-rules__card {
    display: flex; align-items: center; gap: 14px;
    padding: 16px; background: var(--color-bg-alt);
    border-radius: var(--radius-md);
}
.sp-rules__card--checkin { background: rgba(198,40,40,0.08); }
.sp-rules__card--checkout { background: rgba(245,158,11,0.08); }
.sp-rules__icon { flex-shrink: 0; }
.sp-rules__card--checkin .sp-rules__icon svg { color: var(--brand-primary); }
.sp-rules__card--checkout .sp-rules__icon svg { color: var(--brand-amber); }
.sp-rules__label { font-size: 12px; color: var(--color-text-light); display: block; }
.sp-rules__value { font-size: 16px; font-weight: 600; color: var(--color-text); }
.sp-rules__notes { padding: 20px; background: #fffbeb; border: 1px solid #fef3c7; border-radius: var(--radius-md); }
.sp-rules__notes h3 { font-size: 14px; font-weight: 600; margin: 0 0 12px; color: #92400e; }
.sp-rules__text { font-size: 14px; line-height: 1.7; color: #78350f; white-space: pre-line; }

/* Reviews */
.sp-reviews__header { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 16px; margin-bottom: 24px; }
.sp-reviews__rating { display: flex; align-items: center; gap: 8px; }
.sp-reviews__stars { color: var(--brand-amber); font-size: 16px; letter-spacing: 2px; }
.sp-reviews__score { font-size: 18px; font-weight: 700; color: var(--color-text); }
.sp-reviews__count { font-size: 14px; color: var(--color-text-light); }

.sp-reviews__list { display: grid; gap: 20px; margin-bottom: 20px; }
.sp-review { padding: 20px; background: var(--color-bg-alt); border-radius: var(--radius-lg); }
.sp-review__header { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.sp-review__avatar {
    width: 44px; height: 44px; background: var(--color-primary);
    color: #fff; border-radius: 50%; display: flex; align-items: center;
    justify-content: center; font-size: 14px; font-weight: 600; flex-shrink: 0;
}
.sp-review__meta { flex: 1; }
.sp-review__name { font-size: 14px; font-weight: 600; color: var(--color-text); display: block; }
.sp-review__date { font-size: 12px; color: var(--color-text-light); }
.sp-review__stars { color: var(--color-secondary); font-size: 12px; letter-spacing: 1px; }
.sp-review__text { font-size: 14px; line-height: 1.7; color: var(--color-text); margin: 0; font-style: italic; }

.sp-reviews__more {
    display: inline-flex; align-items: center; gap: 6px;
    background: none; border: none; padding: 0;
    font-size: 14px; font-weight: 600; color: var(--color-primary);
    cursor: pointer;
}
.sp-reviews__more:hover { text-decoration: underline; }

/* Trust Elements */
.sp-trust {
    display: flex; flex-wrap: wrap; justify-content: center; gap: 24px;
    padding: 24px; background: var(--color-bg-alt); border-radius: var(--radius-lg);
    margin-top: 32px;
}
.sp-trust__item { display: flex; align-items: center; gap: 10px; font-size: 14px; font-weight: 500; color: var(--color-text); }
.sp-trust__item svg { color: var(--color-primary); }

/* Final CTA Band */
.sp-cta-band {
    padding: 60px 0; background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
    color: #fff; text-align: center;
}
.sp-cta-band__title { font-size: 28px; font-weight: 700; margin: 0 0 12px; }
@media (min-width: 768px) { .sp-cta-band__title { font-size: 32px; } }
.sp-cta-band__text { font-size: 16px; opacity: 0.9; margin: 0 0 24px; max-width: 500px; margin-left: auto; margin-right: auto; }

/* Mobile Sticky CTA - Single Property */
@media (max-width: 1023px) {
    .single-property-page .whatsapp-sticky {
        display: block; position: fixed; bottom: 0; left: 0; right: 0; z-index: 100;
        padding: 12px 16px; background: var(--color-bg);
        border-top: 1px solid var(--color-border); box-shadow: 0 -4px 20px rgba(0,0,0,0.1);
    }
    .whatsapp-sticky__btn {
        display: flex; align-items: center; justify-content: center; gap: 10px;
        width: 100%; padding: 14px; background: var(--color-whatsapp); color: #fff;
        border-radius: var(--radius-md); font-weight: 600; font-size: 15px;
    }
    .whatsapp-sticky__price { margin-left: auto; font-size: 14px; opacity: 0.9; }
    
    .sp-content { padding-bottom: 100px; }
}

/* Hide desktop CTA box on mobile, show inline instead */
@media (max-width: 1023px) {
    .sp-hero__sidebar { display: none; }
    .sp-hero__grid { grid-template-columns: 1fr; }
}

/* Mobile inline CTA - HIDDEN (sticky bar is used instead) */
.sp-mobile-cta { display: none !important; }


/* ========== VIDEO MODAL ========== */
.sp-video-modal {
    position: fixed; inset: 0; z-index: 10000;
    display: flex; align-items: center; justify-content: center;
}
.sp-video-modal__overlay {
    position: absolute; inset: 0;
    background: rgba(0,0,0,0.9);
}
.sp-video-modal__content {
    position: relative; width: 90%; max-width: 900px;
    aspect-ratio: 16/9; background: #000; border-radius: var(--radius-lg);
    overflow: hidden;
}
.sp-video-modal__content iframe {
    width: 100%; height: 100%; border: 0;
}
.sp-video-modal__close {
    position: absolute; top: -48px; right: 0;
    width: 40px; height: 40px; background: rgba(255,255,255,0.1);
    border: none; border-radius: 50%; color: #fff; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: var(--transition);
}
.sp-video-modal__close:hover { background: rgba(255,255,255,0.2); }

/* ========== MOBILE STICKY CTA - ENHANCED ========== */
.whatsapp-sticky { display: none; }

@media (max-width: 1023px) {
    .single-property-page .whatsapp-sticky {
        display: block; position: fixed; bottom: 0; left: 0; right: 0; z-index: 100;
        background: var(--color-bg); border-top: 1px solid var(--color-border);
        box-shadow: 0 -4px 20px rgba(0,0,0,0.1);
    }
    .whatsapp-sticky__inner {
        display: flex; align-items: center; gap: 16px;
        padding: 12px 16px; max-width: var(--container-max); margin: 0 auto;
    }
    .whatsapp-sticky__info { flex-shrink: 0; }
    .whatsapp-sticky__price-label {
        display: block; font-size: 11px; color: var(--color-text-light);
        text-transform: uppercase; letter-spacing: 0.5px;
    }
    .whatsapp-sticky__price-value {
        font-size: 20px; font-weight: 700; color: var(--color-primary);
    }
    .whatsapp-sticky__btn {
        flex: 1; display: flex; align-items: center; justify-content: center; gap: 10px;
        padding: 14px 20px; background: var(--color-whatsapp); color: #fff;
        border-radius: var(--radius-md); font-weight: 600; font-size: 15px;
        text-decoration: none; transition: var(--transition);
    }
    .whatsapp-sticky__btn:hover { background: #1fb855; color: #fff; }
}

/* RTL adjustments for single property */
[dir="rtl"] .sp-gallery__nav--prev { left: auto; right: 16px; }
[dir="rtl"] .sp-gallery__nav--next { right: auto; left: 16px; }
[dir="rtl"] .sp-gallery__counter { left: auto; right: 16px; }
[dir="rtl"] .sp-gallery__fullscreen { right: auto; left: 16px; }
[dir="rtl"] .sp-gallery__badges { left: auto; right: 16px; }
[dir="rtl"] .breadcrumb__sep { transform: scaleX(-1); }
[dir="rtl"] .sp-about__toggle svg { transform: scaleX(-1); }
[dir="rtl"] .sp-about__toggle.is-expanded svg { transform: scaleX(-1) rotate(180deg); }
[dir="rtl"] .sp-cta-box__price-details { flex-direction: row-reverse; }
[dir="rtl"] .sp-rules__card { flex-direction: row-reverse; }
[dir="rtl"] .sp-spec { flex-direction: row-reverse; }
[dir="rtl"] .sp-highlight { text-align: center; }
[dir="rtl"] .sp-review__header { flex-direction: row-reverse; }
[dir="rtl"] .sp-review__stars { margin-right: auto; margin-left: 0; }
[dir="rtl"] .whatsapp-sticky__inner { flex-direction: row-reverse; }


/* Mobile Inline CTA - Specs */
.sp-mobile-cta__specs {
    display: flex; flex-wrap: wrap; gap: 16px;
    padding-top: 12px; border-top: 1px solid var(--color-border-light);
}
.sp-mobile-cta__specs span {
    display: flex; align-items: center; gap: 6px;
    font-size: 14px; color: var(--color-text-light);
}
.sp-mobile-cta__specs svg { color: var(--color-primary); }

/* RTL for mobile CTA specs */
[dir="rtl"] .sp-mobile-cta__specs { flex-direction: row-reverse; }
[dir="rtl"] .sp-mobile-cta__specs span { flex-direction: row-reverse; }
[dir="rtl"] .sp-mobile-cta__price { flex-direction: row-reverse; }


/* ========================================
   SINGLE PROPERTY - PREMIUM POLISH
   Visual dominance, emotional impact, sales psychology
   ======================================== */

/* Gallery - Premium Feel */
.sp-gallery--premium .sp-gallery__main {
    aspect-ratio: 16/9;
    min-height: 400px;
}
@media (min-width: 768px) {
    .sp-gallery--premium .sp-gallery__main { min-height: 480px; }
}
@media (min-width: 1024px) {
    .sp-gallery--premium .sp-gallery__main { min-height: 520px; }
}

.sp-gallery__overlay {
    position: absolute; inset: 0; pointer-events: none;
    background: linear-gradient(
        180deg,
        rgba(0,0,0,0.15) 0%,
        transparent 30%,
        transparent 70%,
        rgba(0,0,0,0.25) 100%
    );
}

.sp-gallery__popularity {
    position: absolute; top: 16px; right: 16px;
    display: flex; align-items: center; gap: 6px;
    padding: 8px 14px; background: var(--color-secondary);
    color: #fff; font-size: 12px; font-weight: 600;
    border-radius: 20px; box-shadow: 0 2px 8px rgba(245,166,35,0.4);
}
.sp-gallery__popularity svg { color: #fff; }

/* CTA Box - Elevated & Dominant */
.sp-cta-box--elevated {
    box-shadow: 0 8px 40px rgba(0,0,0,0.12), 0 4px 12px rgba(0,0,0,0.08);
    border: none;
}

.sp-cta-box__price-inquiry {
    padding: 16px; background: rgba(196,30,58,0.08);
    border-radius: var(--radius-md); text-align: center;
}
.sp-cta-box__price-inquiry-text {
    font-size: 15px; font-weight: 600; color: var(--color-primary);
}

.sp-cta-box__btn--xl {
    padding: 18px 24px; font-size: 16px;
    box-shadow: 0 4px 16px rgba(37,211,102,0.35);
}
.sp-cta-box__btn--xl:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 24px rgba(37,211,102,0.45);
}

.sp-cta-box__urgency {
    display: flex; align-items: center; justify-content: center; gap: 6px;
    margin: 12px 0 16px; padding: 10px;
    background: rgba(196,30,58,0.06); border-radius: var(--radius-md);
    font-size: 13px; color: var(--brand-primary); font-weight: 500;
}
.sp-cta-box__urgency svg { color: var(--color-primary); }

.sp-cta-box__trust-bar {
    display: flex; justify-content: center; gap: 24px;
    margin-top: 20px; padding-top: 20px;
    border-top: 1px solid var(--color-border-light);
}
.sp-cta-box__trust-item {
    display: flex; align-items: center; gap: 6px;
    font-size: 12px; color: var(--color-text-light); font-weight: 500;
}
.sp-cta-box__trust-item svg { color: var(--color-primary); }

/* Content Sections - Kompakt tasarım */
.sp-section { padding: 16px 0; }
@media (min-width: 768px) { .sp-section { padding: 20px 0; } }

.sp-section__title {
    font-size: 20px; margin-bottom: 16px;
}
@media (min-width: 768px) { .sp-section__title { font-size: 22px; margin-bottom: 20px; } }

/* About - Stronger Typography */
.sp-title { font-size: 30px; }
@media (min-width: 768px) { .sp-title { font-size: 36px; } }

.sp-about__text { font-size: 16px; line-height: 1.9; }
.sp-about__toggle {
    margin-top: 12px; padding: 10px 16px;
    background: var(--color-bg-alt); border-radius: var(--radius-md);
    transition: var(--transition);
}
.sp-about__toggle:hover { background: var(--color-border-light); }

/* Highlights - REMOVED (section hidden) */

/* Reviews - Prominent Placement */
.sp-reviews--prominent {
    background: var(--color-bg-alt);
    margin: 0 -16px; padding: 40px 16px;
    border-radius: 0;
}
@media (min-width: 768px) {
    .sp-reviews--prominent {
        margin: 0 -24px; padding: 48px 24px;
        border-radius: var(--radius-xl);
    }
}

.sp-reviews__header { margin-bottom: 28px; }
.sp-reviews__header-left { flex: 1; }
.sp-reviews__trust-note {
    display: flex; align-items: center; gap: 6px;
    margin-top: 8px; font-size: 13px; color: var(--color-primary);
}
.sp-reviews__trust-note svg { color: var(--color-primary); }

.sp-reviews__rating--large .sp-reviews__stars { font-size: 20px; }
.sp-reviews__rating--large .sp-reviews__score { font-size: 24px; }

.sp-review { background: var(--color-bg); }

/* Final CTA Band - Premium & Emotional */
.sp-cta-band--premium {
    padding: 80px 0;
    background: linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-primary-hover) 50%, var(--brand-dark) 100%);
    position: relative; overflow: hidden;
}
.sp-cta-band--premium::before {
    content: ''; position: absolute; inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    opacity: 0.5;
}

.sp-cta-band__content { position: relative; z-index: 1; }

.sp-cta-band__icon {
    display: flex; align-items: center; justify-content: center;
    width: 80px; height: 80px; margin: 0 auto 24px;
    background: rgba(255,255,255,0.15); border-radius: 50%;
}
.sp-cta-band__icon svg { color: #fff; }

.sp-cta-band--premium .sp-cta-band__title {
    font-size: 32px; margin-bottom: 16px;
}
@media (min-width: 768px) {
    .sp-cta-band--premium .sp-cta-band__title { font-size: 40px; }
}

.sp-cta-band--premium .sp-cta-band__text {
    font-size: 17px; max-width: 550px; margin-bottom: 32px;
}

.sp-cta-band__btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 12px;
    padding: 20px 40px; background: #fff; color: var(--color-primary);
    font-size: 18px; font-weight: 700; border-radius: var(--radius-lg);
    text-decoration: none; transition: var(--transition);
    box-shadow: 0 4px 20px rgba(0,0,0,0.2);
}
.sp-cta-band__btn:hover {
    transform: translateY(-3px) scale(1.02);
    box-shadow: 0 8px 30px rgba(0,0,0,0.25);
    color: var(--color-primary-dark);
}

.sp-cta-band__response {
    margin-top: 20px; font-size: 14px; opacity: 0.85;
}

/* Mobile Sticky CTA - Enhanced */
@media (max-width: 1023px) {
    .whatsapp-sticky__btn {
        padding: 16px 24px; font-size: 16px;
        box-shadow: 0 2px 12px rgba(37,211,102,0.3);
    }
}

/* RTL for new elements */
[dir="rtl"] .sp-gallery__popularity { right: auto; left: 16px; }
[dir="rtl"] .sp-cta-box__urgency { flex-direction: row-reverse; }
[dir="rtl"] .sp-cta-box__trust-bar { flex-direction: row-reverse; }
[dir="rtl"] .sp-cta-box__trust-item { flex-direction: row-reverse; }
[dir="rtl"] .sp-reviews__trust-note { flex-direction: row-reverse; }
[dir="rtl"] .sp-cta-band__btn { flex-direction: row-reverse; }


/* Mobile Sticky - Price Variant */
.whatsapp-sticky__price-value--small {
    font-size: 16px;
}


/* Mobile Inline CTA - REMOVED (using sticky bar instead) */

/* RTL for mobile inline CTA */
[dir="rtl"] .sp-mobile-cta__header { flex-direction: row-reverse; }
[dir="rtl"] .sp-mobile-cta__rating { flex-direction: row-reverse; }


/* Gallery Branded Placeholder */
.sp-gallery__placeholder {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: 16px; width: 100%; height: 100%; min-height: 300px;
    background: linear-gradient(135deg, var(--color-bg-alt) 0%, var(--color-border-light) 100%);
    color: var(--color-text-muted); text-align: center;
}
.sp-gallery__placeholder svg { opacity: 0.4; }
.sp-gallery__placeholder span { font-size: 14px; font-weight: 500; }


/* Property Card - Price Inquiry Fallback */
.property-card__price-inquiry {
    font-size: 14px; font-weight: 600; color: var(--color-primary);
}


/* ========== RELATED PROPERTIES SECTION ========== */
.sp-related {
    padding: 60px 0 80px;
    background: var(--color-bg-alt);
}
@media (min-width: 768px) {
    .sp-related { padding: 80px 0 100px; }
}

/* RTL support for related section */
[dir="rtl"] .sp-related .section-header__link svg {
    transform: scaleX(-1);
}


/* ========== WHATSAPP INFO BAND ========== */
.whatsapp-info-band {
    padding: 40px 0;
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    border-top: 1px solid var(--color-border-light);
    border-bottom: 1px solid var(--color-border-light);
}

.whatsapp-info__content {
    display: flex; flex-direction: column; align-items: center;
    text-align: center; gap: 24px;
}
@media (min-width: 768px) {
    .whatsapp-info__content { flex-direction: row; text-align: left; justify-content: space-between; }
}

.whatsapp-info__header {
    display: flex; align-items: center; gap: 16px;
}
@media (min-width: 768px) {
    .whatsapp-info__header { flex-direction: column; align-items: flex-start; gap: 8px; }
}

.whatsapp-info__icon {
    width: 48px; height: 48px; background: var(--color-whatsapp);
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    color: #fff; flex-shrink: 0;
}

.whatsapp-info__title {
    font-size: 18px; font-weight: 700; margin: 0;
    color: var(--color-text);
}
@media (min-width: 768px) {
    .whatsapp-info__title { font-size: 20px; }
}

.whatsapp-info__features {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px;
}
@media (min-width: 640px) {
    .whatsapp-info__features { grid-template-columns: repeat(4, 1fr); gap: 24px; }
}

.whatsapp-info__feature {
    display: flex; align-items: center; gap: 8px;
    font-size: 14px; font-weight: 500; color: var(--color-text);
}
.whatsapp-info__feature svg {
    color: var(--brand-primary); flex-shrink: 0;
}

/* RTL support for WhatsApp info band */
[dir="rtl"] .whatsapp-info__content { flex-direction: row-reverse; }
[dir="rtl"] .whatsapp-info__header { flex-direction: row-reverse; }
[dir="rtl"] .whatsapp-info__feature { flex-direction: row-reverse; }

/* ========== WORDPRESS COMMENTS - SINGLE PROPERTY ========== */
.sp-comments--prominent {
    background: var(--color-bg-alt);
    margin: 0 -16px; padding: 40px 16px;
    border-radius: 0;
}
@media (min-width: 768px) {
    .sp-comments--prominent {
        margin: 0 -24px; padding: 48px 24px;
        border-radius: var(--radius-xl);
    }
}

.sp-comments__header {
    display: flex; flex-wrap: wrap; justify-content: space-between; 
    align-items: flex-start; gap: 16px; margin-bottom: 32px;
}

.sp-comments__header-left { flex: 1; }

.sp-comments__trust-note {
    display: flex; align-items: center; gap: 6px;
    margin-top: 8px; font-size: 13px; color: var(--brand-primary);
    font-weight: 500;
}
.sp-comments__trust-note svg { color: var(--brand-primary); flex-shrink: 0; }

.sp-comments__count {
    display: flex; align-items: center; gap: 8px;
    padding: 12px 20px; background: var(--color-bg);
    border-radius: var(--radius-md); box-shadow: var(--shadow-sm);
}
.sp-comments__total {
    font-size: 24px; font-weight: 700; color: var(--brand-primary);
}
.sp-comments__label {
    font-size: 14px; color: var(--color-text-light);
}

/* Comments List */
.sp-comments__list { margin-bottom: 32px; }

.sp-comment {
    background: var(--color-bg); border-radius: var(--radius-lg);
    padding: 20px; margin-bottom: 16px; box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border-light);
}
.sp-comment:last-child { margin-bottom: 0; }

.sp-comment__content { width: 100%; }

.sp-comment__header {
    display: flex; align-items: flex-start; gap: 12px; margin-bottom: 12px;
}

.sp-comment__avatar {
    width: 44px; height: 44px; border-radius: 50%; overflow: hidden;
    flex-shrink: 0; background: var(--color-bg-alt);
}
.sp-comment__avatar img {
    width: 100%; height: 100%; object-fit: cover;
}
.sp-comment__avatar-fallback {
    width: 44px; height: 44px; background: var(--brand-primary);
    color: #fff; border-radius: 50%; display: flex;
    align-items: center; justify-content: center;
    font-size: 14px; font-weight: 600;
}

.sp-comment__meta { flex: 1; }

.sp-comment__author {
    font-size: 15px; font-weight: 600; color: var(--color-text);
    margin-bottom: 2px;
}

.sp-comment__date a {
    font-size: 13px; color: var(--color-text-light);
    text-decoration: none;
}
.sp-comment__date a:hover { color: var(--brand-primary); }

.sp-comment__moderation {
    padding: 6px 12px; background: rgba(245,158,11,0.1);
    color: var(--brand-amber); font-size: 12px; font-weight: 500;
    border-radius: var(--radius-sm); margin-top: 8px;
}

.sp-comment__text {
    font-size: 15px; line-height: 1.7; color: var(--color-text);
    margin-bottom: 12px;
}
.sp-comment__text p { margin: 0 0 12px; }
.sp-comment__text p:last-child { margin-bottom: 0; }

.sp-comment__reply .reply a {
    font-size: 13px; font-weight: 600; color: var(--brand-primary);
    text-decoration: none; display: inline-flex; align-items: center; gap: 4px;
}
.sp-comment__reply .reply a:hover { text-decoration: underline; }

/* Nested Comments */
.children { margin-top: 16px; padding-left: 20px; border-left: 2px solid var(--color-border-light); }
.children .sp-comment { margin-left: 0; }

/* Comments Navigation */
.sp-comments__navigation {
    display: flex; justify-content: center; margin: 24px 0;
}
.sp-comments__nav-links {
    display: flex; gap: 16px;
}
.sp-comments__nav-prev a,
.sp-comments__nav-next a {
    padding: 10px 16px; background: var(--color-bg);
    border: 1px solid var(--color-border); border-radius: var(--radius-md);
    font-size: 14px; font-weight: 500; color: var(--color-text);
    text-decoration: none; transition: var(--transition);
}
.sp-comments__nav-prev a:hover,
.sp-comments__nav-next a:hover {
    border-color: var(--brand-primary); color: var(--brand-primary);
}

/* Empty State */
.sp-comments__empty {
    text-align: center; padding: 48px 24px;
    background: var(--color-bg); border-radius: var(--radius-lg);
    border: 1px solid var(--color-border-light);
}
.sp-comments__empty svg {
    color: var(--color-text-muted); margin-bottom: 16px;
}
.sp-comments__empty p {
    font-size: 16px; color: var(--color-text-light); margin: 0;
}

/* Comment Form */
.sp-comments__form {
    background: var(--color-bg); border-radius: var(--radius-lg);
    padding: 24px; border: 1px solid var(--color-border-light);
    margin-top: 24px;
}

.sp-comments__form-title {
    font-size: 18px; font-weight: 700; margin: 0 0 20px;
    color: var(--color-text);
}

.comment-form p { margin-bottom: 16px; }
.comment-form p:last-child { margin-bottom: 0; }

.comment-form label {
    display: block; font-size: 14px; font-weight: 600;
    color: var(--color-text); margin-bottom: 6px;
}
.comment-form .required { color: var(--brand-primary); }

.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form textarea {
    width: 100%; padding: 12px 14px;
    border: 1px solid var(--color-border); border-radius: var(--radius-md);
    font-size: 14px; font-family: inherit; background: var(--color-bg-alt);
    transition: var(--transition);
}
.comment-form input[type="text"]:focus,
.comment-form input[type="email"]:focus,
.comment-form textarea:focus {
    border-color: var(--brand-primary); background: var(--color-bg);
    outline: none;
}

.comment-form textarea {
    resize: vertical; min-height: 120px;
}

.comment-notes {
    font-size: 13px; color: var(--color-text-light);
    margin-bottom: 16px;
}

.comment-reply-title {
    font-size: 16px; font-weight: 600; margin: 0 0 16px;
    color: var(--color-text);
}

/* RTL Support for Comments */
[dir="rtl"] .sp-comments__header { flex-direction: row-reverse; }
[dir="rtl"] .sp-comment__header { flex-direction: row-reverse; }
[dir="rtl"] .children { padding-left: 0; padding-right: 20px; border-left: none; border-right: 2px solid var(--color-border-light); }
[dir="rtl"] .sp-comments__nav-links { flex-direction: row-reverse; }


/* ========== CALENDAR UI POLISH ========== */
.sp-calendar__header-section {
    display: flex; flex-wrap: wrap; justify-content: space-between;
    align-items: flex-start; gap: 16px; margin-bottom: 24px;
}

.sp-calendar__title-area { flex: 1; }

.sp-calendar__label {
    font-size: 13px; color: var(--color-text-muted);
    margin: -8px 0 0; font-style: italic;
}

.sp-calendar__cta { flex-shrink: 0; }

.sp-calendar__whatsapp-btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 16px; background: var(--color-whatsapp); color: #fff;
    border-radius: var(--radius-md); font-size: 14px; font-weight: 600;
    text-decoration: none; transition: var(--transition);
}
.sp-calendar__whatsapp-btn:hover {
    background: #1fb855; color: #fff; transform: translateY(-1px);
}

.sp-calendar__container {
    display: flex; justify-content: center; margin-bottom: 20px;
}

.sp-calendar__wrap {
    background: var(--color-bg); border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg); padding: 20px; max-width: 400px; width: 100%;
    box-shadow: var(--shadow-sm);
}

.sp-calendar__header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 16px;
}

.sp-calendar__month {
    font-size: 16px; font-weight: 600; color: var(--color-text);
}

.sp-calendar__nav {
    width: 32px; height: 32px; background: var(--color-bg-alt);
    border: none; border-radius: var(--radius-sm); cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: var(--transition);
}
.sp-calendar__nav:hover {
    background: var(--color-border); color: var(--brand-primary);
}

.sp-calendar__grid {
    display: grid; grid-template-columns: repeat(7, 1fr);
    gap: 2px; text-align: center; margin-bottom: 16px;
}

.sp-calendar__day-name {
    font-size: 11px; font-weight: 600; color: var(--color-text-light);
    padding: 8px 0; text-transform: uppercase; letter-spacing: 0.5px;
}

.sp-calendar__day {
    padding: 8px 4px; font-size: 13px; border-radius: var(--radius-sm);
    transition: var(--transition); cursor: default;
}

.sp-calendar__day--empty { background: none; }

.sp-calendar__day--past {
    color: var(--color-text-muted); background: var(--color-bg-alt);
}

.sp-calendar__day--today {
    background: var(--brand-primary); color: #fff; font-weight: 600;
}

.sp-calendar__day--available {
    background: rgba(198,40,40,0.08); color: var(--brand-primary);
    cursor: pointer;
}
.sp-calendar__day--available:hover {
    background: rgba(198,40,40,0.15);
}

.sp-calendar__day--booked {
    background: var(--color-bg-alt); color: var(--color-text-muted);
    position: relative;
}
.sp-calendar__day--booked::after {
    content: ''; position: absolute; top: 50%; left: 10%; right: 10%;
    height: 1px; background: var(--color-text-muted);
}

.sp-calendar__legend {
    display: flex; justify-content: center; gap: 16px; flex-wrap: wrap;
    padding-top: 12px; border-top: 1px solid var(--color-border-light);
}

.sp-calendar__legend-item {
    display: flex; align-items: center; gap: 6px;
    font-size: 12px; color: var(--color-text-light);
}

.sp-calendar__dot {
    width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0;
}
.sp-calendar__dot--available { background: rgba(198,40,40,0.2); border: 2px solid var(--brand-primary); }
.sp-calendar__dot--booked { background: var(--color-text-muted); }
.sp-calendar__dot--today { background: var(--brand-primary); }

.sp-calendar__footer {
    text-align: center; margin-top: 16px;
}

.sp-calendar__helper {
    display: flex; align-items: center; justify-content: center; gap: 8px;
    font-size: 13px; color: var(--color-text-light); margin: 0;
    padding: 12px 16px; background: var(--color-bg-alt);
    border-radius: var(--radius-md);
}
.sp-calendar__helper svg { color: var(--brand-primary); flex-shrink: 0; }

/* RTL Support for Calendar */
[dir="rtl"] .sp-calendar__header-section { flex-direction: row-reverse; }
[dir="rtl"] .sp-calendar__whatsapp-btn { flex-direction: row-reverse; }
[dir="rtl"] .sp-calendar__helper { flex-direction: row-reverse; }


/* ========== SINGLE PROPERTY PAGE - VILLASEPETI STYLE REBUILD ========== */

/* Hero Info Section (Under Gallery) */
.sp-hero__info {
    margin-top: 12px;
    padding-bottom: 0;
    max-width: 100%;
    overflow: hidden;
    border-bottom: none;
}

.sp-hero__title {
    font-size: 24px;
    font-weight: 700;
    margin: 0 0 12px;
    line-height: 1.3;
    color: var(--color-text);
}
@media (min-width: 768px) {
    .sp-hero__title { font-size: 32px; }
}

.sp-hero__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
    margin-bottom: 0;
}

.sp-hero__location {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 15px;
    color: var(--color-text-light);
}
.sp-hero__location svg { color: var(--brand-primary); }

.sp-hero__type {
    padding: 4px 12px;
    background: var(--brand-primary);
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    border-radius: var(--radius-sm);
}

/* Above-the-fold Specs (Oda Planı + Key Info) */
.sp-hero__specs {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: center;
    margin: 12px 0 16px;
    padding: 12px 16px;
    background: var(--color-bg-alt);
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border-light);
}

.sp-hero__spec {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text);
    white-space: nowrap;
}

.sp-hero__spec svg {
    color: var(--brand-primary);
    flex-shrink: 0;
}

.sp-hero__spec--oda-plani {
    font-weight: 600;
    color: var(--brand-primary);
}

.sp-hero__spec--oda-plani svg {
    color: var(--brand-primary);
}

/* Separator between specs */
.sp-hero__spec:not(:last-child)::after {
    content: '•';
    margin-left: 16px;
    color: var(--color-border);
}

@media (max-width: 640px) {
    .sp-hero__specs {
        gap: 10px;
        padding: 10px 12px;
    }
    .sp-hero__spec {
        font-size: 13px;
    }
    .sp-hero__spec:not(:last-child)::after {
        margin-left: 10px;
    }
}

/* Oda Planı in Specs Section */
.sp-spec--oda-plani {
    background: var(--color-bg-alt);
    border-radius: var(--radius-sm);
    padding: 4px 8px;
}

.sp-spec--oda-plani .sp-spec__value {
    font-weight: 600;
    color: var(--brand-primary);
}

/* sp-hero__summary removed - field deleted */

/* Mobile CTA - HIDDEN (sticky bar at bottom is used instead) */

/* CTA Box Enhancements */
.sp-cta-box--elevated {
    box-shadow: var(--shadow-xl);
    border: 1px solid var(--color-border-light);
}

.sp-cta-box__btn--xl {
    padding: 18px 24px;
    font-size: 16px;
}

.sp-cta-box__urgency {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin: 12px 0 16px;
    font-size: 13px;
    color: var(--color-text-light);
}
.sp-cta-box__urgency svg { color: var(--brand-primary); }

.sp-cta-box__price-inquiry {
    padding: 16px;
    background: rgba(198,40,40,0.05);
    border-radius: var(--radius-md);
    text-align: center;
}

.sp-cta-box__price-inquiry-text {
    font-size: 15px;
    font-weight: 600;
    color: var(--brand-primary);
}

.sp-cta-box__trust-bar {
    display: flex;
    justify-content: center;
    gap: 24px;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--color-border-light);
}

.sp-cta-box__trust-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--color-text-light);
}
.sp-cta-box__trust-item svg { color: var(--brand-primary); }

/* OpenStreetMap / Leaflet */
.sp-location__osm {
    width: 100%;
    height: 320px;
    border-radius: var(--radius-lg);
    background: var(--color-bg-alt);
    z-index: 1;
}

.sp-location__external {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 12px;
    font-size: 14px;
    font-weight: 500;
    color: var(--brand-primary);
}
.sp-location__external:hover {
    text-decoration: underline;
}

/* Final CTA Band */
.sp-cta-band {
    padding: 60px 0;
    background: linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-primary-hover) 50%, var(--brand-dark) 100%);
    color: #fff;
    text-align: center;
}

.sp-cta-band__content {
    max-width: 600px;
    margin: 0 auto;
}

.sp-cta-band__icon {
    margin-bottom: 20px;
}
.sp-cta-band__icon svg {
    color: rgba(255,255,255,0.9);
}

.sp-cta-band__title {
    font-size: 24px;
    font-weight: 700;
    margin: 0 0 12px;
}
@media (min-width: 768px) {
    .sp-cta-band__title { font-size: 32px; }
}

.sp-cta-band__text {
    font-size: 16px;
    opacity: 0.9;
    margin: 0 0 24px;
    line-height: 1.6;
}

.sp-cta-band__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 16px 32px;
    background: var(--brand-whatsapp);
    color: #fff;
    border-radius: var(--radius-md);
    font-size: 16px;
    font-weight: 600;
    text-decoration: none;
    transition: var(--transition);
    box-shadow: 0 4px 12px rgba(37,211,102,0.3);
}
.sp-cta-band__btn:hover {
    background: #1fb855;
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(37,211,102,0.4);
}

.sp-cta-band__response {
    margin: 16px 0 0;
    font-size: 14px;
    opacity: 0.8;
}

/* Gallery Premium Overlay */
.sp-gallery__overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 120px;
    background: linear-gradient(to top, rgba(0,0,0,0.4) 0%, transparent 100%);
    pointer-events: none;
}

/* Gallery Popularity Badge */
.sp-gallery__popularity {
    position: absolute;
    top: 16px;
    right: 16px;
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: var(--brand-amber);
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    border-radius: var(--radius-full);
    box-shadow: 0 2px 8px rgba(245,158,11,0.3);
}

/* RTL Support for new elements */
[dir="rtl"] .sp-hero__meta { flex-direction: row-reverse; }
[dir="rtl"] .sp-hero__location { flex-direction: row-reverse; }
[dir="rtl"] .sp-mobile-cta__header { flex-direction: row-reverse; }
[dir="rtl"] .sp-mobile-cta__btn { flex-direction: row-reverse; }
[dir="rtl"] .sp-cta-box__trust-bar { flex-direction: row-reverse; }
[dir="rtl"] .sp-cta-box__trust-item { flex-direction: row-reverse; }
[dir="rtl"] .sp-cta-box__urgency { flex-direction: row-reverse; }
[dir="rtl"] .sp-cta-band__btn { flex-direction: row-reverse; }
[dir="rtl"] .sp-location__external { flex-direction: row-reverse; }
[dir="rtl"] .sp-gallery__popularity { right: auto; left: 16px; flex-direction: row-reverse; }


/* Leaflet Map Custom Marker */
.sp-map-marker {
    background: none !important;
    border: none !important;
}

/* Video Modal */
.sp-video-modal {
    position: fixed;
    inset: 0;
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sp-video-modal__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.9);
}

.sp-video-modal__content {
    position: relative;
    width: 90%;
    max-width: 900px;
    aspect-ratio: 16/9;
}

.sp-video-modal__content iframe {
    width: 100%;
    height: 100%;
    border-radius: var(--radius-lg);
}

.sp-video-modal__close {
    position: absolute;
    top: -48px;
    right: 0;
    width: 40px;
    height: 40px;
    background: rgba(255,255,255,0.1);
    border: none;
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--transition);
}
.sp-video-modal__close:hover {
    background: rgba(255,255,255,0.2);
}


/* ========== LOCATION FALLBACK (D2) ========== */
.sp-location__fallback {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 48px 24px;
    background: var(--color-bg-alt);
    border-radius: var(--radius-lg);
    text-align: center;
}
.sp-location__fallback svg {
    color: var(--color-text-muted);
}
.sp-location__fallback-text {
    font-size: 16px;
    font-weight: 500;
    color: var(--color-text);
    margin: 0;
}

/* Title under gallery (A1) */
.sp-hero__gallery { max-width: 100%; overflow: hidden; }
.sp-hero__gallery .sp-hero__info {
    margin-top: 20px;
    padding-top: 0;
    border-top: none;
}

.sp-title {
    font-size: 24px;
    font-weight: 700;
    margin: 0 0 12px;
    line-height: 1.3;
    color: var(--color-text);
    word-wrap: break-word;
    overflow-wrap: break-word;
    max-width: 100%;
}
@media (min-width: 768px) {
    .sp-title { font-size: 28px; }
}

/* Comments count inline */
.sp-comments__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
}
.sp-comments__count {
    font-size: 14px;
    color: var(--color-text-light);
}


/* ========== PREMIUM UI POLISH - VILLASEPETI STYLE ========== */

/* Header/Footer - Deep Navy Refinements */
.site-header {
    background: var(--color-bg);
    border-bottom: 1px solid var(--color-border-light);
}

.top-bar {
    background: var(--rg-ink);
}

.site-footer {
    background: var(--rg-ink);
}

/* Single Property Page - Seamless Background */
.single-property-page .site-header {
    background: var(--color-bg-alt);
}

.single-property-page .site-footer {
    background: var(--rg-ink);
    margin-top: 0;
}

/* Calendar - Premium Card Styling */
.sp-calendar {
    padding: 32px 0;
}

.sp-calendar__wrap {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: 24px;
    max-width: 420px;
    width: 100%;
    box-shadow: var(--shadow-card);
    transition: var(--transition);
}

.sp-calendar__wrap:hover {
    box-shadow: var(--shadow-card-hover);
}

/* Map - Premium Styling */
.sp-location__map {
    border-radius: var(--radius-xl);
    overflow: hidden;
    background: var(--color-bg-alt);
    box-shadow: var(--shadow-card);
    border: 1px solid var(--color-border-light);
}

.sp-location__osm {
    width: 100%;
    height: 320px;
    border-radius: var(--radius-xl);
}

@media (min-width: 768px) {
    .sp-location__osm {
        height: 400px;
    }
}

.sp-location__external {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 12px;
    padding: 10px 16px;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text);
    text-decoration: none;
    transition: var(--transition);
}

.sp-location__external:hover {
    border-color: var(--brand-primary);
    color: var(--brand-primary);
}

/* Map Fallback - Premium Styling */
.sp-location__fallback {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 20px;
    padding: 60px 24px;
    background: linear-gradient(135deg, var(--color-bg-alt) 0%, var(--color-border-light) 100%);
    border-radius: var(--radius-xl);
    text-align: center;
    border: 1px solid var(--color-border-light);
}

.sp-location__fallback svg {
    color: var(--brand-primary);
    opacity: 0.6;
}

.sp-location__fallback-text {
    font-size: 18px;
    font-weight: 600;
    color: var(--color-text);
    margin: 0;
}

.sp-location__fallback .btn {
    margin-top: 8px;
    padding: 14px 28px;
    font-size: 15px;
}

/* Comments Section - Premium Card Styling */
.sp-comments {
    padding: 32px 0;
}

.sp-comments__list {
    display: grid;
    gap: 16px;
    margin-bottom: 24px;
}

.comment {
    background: var(--color-bg);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    padding: 20px;
    box-shadow: var(--shadow-sm);
    transition: var(--transition);
}

.comment:hover {
    box-shadow: var(--shadow-md);
    border-color: var(--color-border);
}

.comment .comment-author {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
}

.comment .comment-author .avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    object-fit: cover;
}

.comment .comment-author .fn {
    font-size: 15px;
    font-weight: 600;
    color: var(--color-text);
}

.comment .comment-meta {
    font-size: 13px;
    color: var(--color-text-light);
}

.comment .comment-content {
    font-size: 15px;
    line-height: 1.7;
    color: var(--color-text);
}

.comment .comment-content p {
    margin: 0 0 12px;
}

.comment .comment-content p:last-child {
    margin-bottom: 0;
}

/* Comment Form - Premium Styling */
.sp-comments__form {
    background: var(--color-bg);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-xl);
    padding: 28px;
    box-shadow: var(--shadow-card);
}

.sp-comments__form .comment-reply-title {
    font-size: 18px;
    font-weight: 700;
    margin: 0 0 20px;
    color: var(--color-text);
}

.sp-comments__form .comment-form-comment label,
.sp-comments__form .comment-form-author label,
.sp-comments__form .comment-form-email label {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 8px;
}

.sp-comments__form textarea,
.sp-comments__form input[type="text"],
.sp-comments__form input[type="email"] {
    width: 100%;
    padding: 14px 16px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: 15px;
    font-family: inherit;
    background: var(--color-bg-alt);
    transition: var(--transition);
}

.sp-comments__form textarea:focus,
.sp-comments__form input[type="text"]:focus,
.sp-comments__form input[type="email"]:focus {
    border-color: var(--brand-primary);
    background: var(--color-bg);
    outline: none;
    box-shadow: 0 0 0 3px rgba(198,40,40,0.1);
}

.sp-comments__form textarea {
    min-height: 140px;
    resize: vertical;
}

.sp-comments__form .form-submit input[type="submit"] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 14px 28px;
    background: var(--brand-primary);
    color: #fff;
    border: none;
    border-radius: var(--radius-md);
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: var(--transition);
}

.sp-comments__form .form-submit input[type="submit"]:hover {
    background: var(--brand-primary-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(198,40,40,0.25);
}

/* Empty Comments State */
.sp-comments__empty {
    text-align: center;
    padding: 48px 24px;
    background: var(--color-bg);
    border: 1px dashed var(--color-border);
    border-radius: var(--radius-xl);
}

.sp-comments__empty p {
    font-size: 16px;
    color: var(--color-text-light);
    margin: 0;
}

/* Oda Seçenekleri - RTL Support */
[dir="rtl"] .sp-unit__footer {
    flex-direction: row-reverse;
}

[dir="rtl"] .sp-unit__cta {
    flex-direction: row-reverse;
}

[dir="rtl"] .sp-unit__header {
    flex-direction: row-reverse;
}

[dir="rtl"] .sp-unit__specs {
    flex-direction: row-reverse;
}

[dir="rtl"] .sp-unit__spec {
    flex-direction: row-reverse;
}

[dir="rtl"] .sp-unit__price {
    margin-left: 0;
    margin-right: auto;
}

/* Calendar RTL Support */
[dir="rtl"] .sp-calendar__header {
    flex-direction: row-reverse;
}

[dir="rtl"] .sp-calendar__nav--prev svg {
    transform: scaleX(-1);
}

[dir="rtl"] .sp-calendar__nav--next svg {
    transform: scaleX(-1);
}

[dir="rtl"] .sp-calendar__legend {
    flex-direction: row-reverse;
}

[dir="rtl"] .sp-calendar__legend-item {
    flex-direction: row-reverse;
}

/* Location RTL Support */
[dir="rtl"] .sp-location__address {
    flex-direction: row-reverse;
}

[dir="rtl"] .sp-location__fallback {
    text-align: center;
}

/* Comments RTL Support */
[dir="rtl"] .sp-comments__header {
    flex-direction: row-reverse;
}

[dir="rtl"] .comment .comment-author {
    flex-direction: row-reverse;
}

[dir="rtl"] .sp-comments__form {
    text-align: right;
}

/* Hero Specs - Premium Styling */
.sp-hero__specs {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    margin-top: 12px;
}

.sp-hero__spec {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: var(--color-bg-alt);
    border-radius: var(--radius-full);
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text);
    border: 1px solid var(--color-border-light);
}

.sp-hero__spec svg {
    color: var(--brand-primary);
    flex-shrink: 0;
}

.sp-hero__spec--oda-plani {
    background: rgba(198,40,40,0.08);
    border-color: rgba(198,40,40,0.2);
    color: var(--brand-primary);
    font-weight: 600;
}

.sp-hero__specs--multi .sp-hero__spec {
    background: var(--color-bg);
    border-color: var(--color-border);
}

/* Hero Meta - Premium Styling */
.sp-hero__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    margin-top: 16px;
}

.sp-hero__location {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    color: var(--color-text-light);
}

.sp-hero__location svg {
    color: var(--brand-primary);
}

.sp-hero__type {
    display: inline-flex;
    padding: 4px 12px;
    background: var(--brand-primary);
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    border-radius: var(--radius-sm);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* RTL for Hero */
[dir="rtl"] .sp-hero__specs {
    flex-direction: row-reverse;
}

[dir="rtl"] .sp-hero__spec {
    flex-direction: row-reverse;
}
/* ========================================
   NO RESULTS - Shared Component
   ======================================== */
.no-results {
    text-align: center;
    padding: 64px 24px;
    background: var(--color-bg);
    border-radius: var(--radius-xl);
    border: 1px dashed var(--color-border);
}

.no-results svg {
    color: var(--color-text-muted);
    margin-bottom: 16px;
}

.no-results h2 {
    font-size: 20px;
    font-weight: 600;
    color: var(--color-text);
    margin: 0 0 8px;
}

.no-results p {
    font-size: 15px;
    color: var(--color-text-light);
    margin: 0 0 24px;
}

/* ========================================
   SINGLE PROPERTY - FINAL MASTER POLISH
   Production-ready UI/UX refinements
   ======================================== */

/* 1️⃣ ABOVE THE FOLD - Property Title & Meta */
.sp-title {
    font-size: 32px;
    font-weight: 700;
    line-height: 1.2;
    margin: 16px 0 8px;
    color: var(--color-text);
}
@media (min-width: 768px) {
    .sp-title { font-size: 38px; margin: 20px 0 12px; }
}

.sp-hero__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    margin-bottom: 0;
}

.sp-hero__location {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 15px;
    color: var(--color-text-light);
    font-weight: 500;
}

.sp-hero__location svg {
    color: var(--brand-primary);
    width: 14px;
    height: 14px;
}

.sp-hero__type {
    padding: 6px 14px;
    background: var(--color-bg-alt);
    color: var(--color-text);
    font-size: 13px;
    font-weight: 600;
    border-radius: var(--radius-full);
    border: 1px solid var(--color-border);
}

/* 2️⃣ PRICE BOX - Better Starting Price Logic */
.sp-cta-box__price-note {
    font-size: 13px;
    color: var(--color-text-muted);
    margin: 4px 0 0;
    font-weight: 500;
}

/* 3️⃣ GALLERY - Improved Visual Rhythm */
.sp-gallery__main {
    aspect-ratio: 16/9.5;
    min-height: 420px;
}
@media (min-width: 768px) {
    .sp-gallery__main { min-height: 480px; }
}

.sp-gallery__thumbs {
    gap: 12px;
    margin-top: 16px;
}

.sp-gallery__thumb {
    width: 92px;
    height: 68px;
    border-radius: var(--radius-lg);
}

/* 4️⃣ DESCRIPTION - Better Read More */
.sp-about__full {
    max-height: 120px;
    transition: max-height 0.3s ease;
}

.sp-about__full.is-expanded {
    max-height: none;
}

.sp-about__toggle {
    margin-top: 16px;
    padding: 12px 20px;
    background: var(--color-bg-alt);
    border-radius: var(--radius-lg);
    font-weight: 600;
    transition: all 0.2s ease;
}

.sp-about__toggle:hover {
    background: var(--color-border);
    transform: translateY(-1px);
}

/* 5️⃣ ÖNE ÇIKAN ÖZELLİKLER - Icon Fix */
.sp-highlights__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
    margin-bottom: 0;
}
@media (min-width: 640px) {
    .sp-highlights__grid { grid-template-columns: repeat(4, 1fr); gap: 16px; }
}

.sp-highlight {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 18px 16px;
    background: var(--color-bg);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: all 0.2s ease;
}

.sp-highlight:hover {
    background: rgba(198,40,40,0.04);
    border-color: rgba(198,40,40,0.2);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}

.sp-highlight__icon {
    width: 44px;
    height: 44px;
    background: rgba(198,40,40,0.1);
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 12px;
}

.sp-highlight__icon svg,
.sp-highlight__icon .feature-icon-fa,
.sp-highlight__icon .feature-icon-svg {
    width: 22px;
    height: 22px;
    color: var(--brand-primary);
    font-size: 20px;
}

.sp-highlight__name {
    font-size: 13px;
    font-weight: 600;
    color: var(--color-text);
    line-height: 1.3;
}

/* Oda Seçenekleri (Bungalov Multi-Unit) - Premium Card Grid */
.sp-units__list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}

@media (min-width: 640px) {
    .sp-units__list {
        grid-template-columns: repeat(2, 1fr);
    }
}

.sp-unit {
    display: flex;
    flex-direction: column;
    padding: 20px;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    transition: var(--transition);
    box-shadow: var(--shadow-card);
}

.sp-unit:hover {
    border-color: var(--brand-primary);
    box-shadow: var(--shadow-card-hover);
    transform: translateY(-2px);
}

.sp-unit__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--color-border-light);
}

.sp-unit__name {
    font-size: 16px;
    font-weight: 700;
    color: var(--color-text);
}

.sp-unit__plan {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    background: var(--brand-primary);
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    border-radius: var(--radius-full);
    letter-spacing: 0.02em;
}

.sp-unit__specs {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

.sp-unit__spec {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 10px;
    background: var(--color-bg-alt);
    border-radius: var(--radius-sm);
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text);
}

.sp-unit__spec svg {
    color: var(--brand-primary);
    flex-shrink: 0;
    width: 16px;
    height: 16px;
}

.sp-unit__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: auto;
    padding-top: 16px;
    border-top: 1px solid var(--color-border-light);
}

.sp-unit__price {
    font-size: 18px;
    font-weight: 700;
    color: var(--brand-primary);
}

.sp-unit__price small {
    font-size: 13px;
    font-weight: 400;
    color: var(--color-text-light);
}

.sp-unit__price--inquiry {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-light);
}

.sp-unit__cta {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: var(--color-whatsapp);
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    border-radius: var(--radius-sm);
    text-decoration: none;
    transition: var(--transition);
}

.sp-unit__cta:hover {
    background: #1DA851;
    color: #fff;
}

.sp-unit__cta svg {
    color: #fff;
    width: 16px;
    height: 16px;
}

/* 7️⃣ MÜSAİTLİK TAKVİMİ - Centered & Clean */
.sp-calendar__header-section {
    text-align: center;
    margin-bottom: 32px;
}

.sp-calendar__title-area {
    margin-bottom: 16px;
}

.sp-calendar__subtitle {
    font-size: 14px;
    color: var(--color-text-light);
    margin: 8px 0 0;
}

.sp-calendar__container {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
}

.sp-calendar__content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
}

.sp-calendar__wrap {
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: 28px;
    max-width: 420px;
    box-shadow: 0 4px 16px rgba(0,0,0,0.06);
}

.sp-calendar__legend {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid var(--color-border-light);
}

.sp-calendar__legend-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--color-text-light);
    font-weight: 500;
}

.sp-calendar__dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
}

.sp-calendar__dot--available {
    background: var(--brand-primary);
}

.sp-calendar__dot--booked {
    background: var(--color-text-muted);
}

.sp-calendar__dot--today {
    background: var(--brand-primary);
    box-shadow: 0 0 0 2px rgba(198,40,40,0.3);
}

.sp-calendar__whatsapp-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 16px 28px;
    background: var(--color-whatsapp);
    color: #fff;
    font-size: 15px;
    font-weight: 600;
    border-radius: var(--radius-lg);
    text-decoration: none;
    transition: all 0.2s ease;
    box-shadow: 0 4px 16px rgba(37,211,102,0.25);
}

.sp-calendar__whatsapp-btn:hover {
    background: #1DA851;
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(37,211,102,0.35);
}

.sp-calendar__whatsapp-btn svg {
    color: #fff;
    width: 18px;
    height: 18px;
}

/* 8️⃣ KONUM - Rounded & Centered */
.sp-location__map {
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: 0 4px 16px rgba(0,0,0,0.08);
    margin-bottom: 20px;
}

.sp-location__osm {
    height: 320px;
    width: 100%;
}

.sp-location__external {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 20px;
    background: var(--color-bg-alt);
    color: var(--color-text);
    font-size: 14px;
    font-weight: 600;
    border-radius: var(--radius-lg);
    text-decoration: none;
    transition: all 0.2s ease;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    max-width: 200px;
}

.sp-location__external:hover {
    background: var(--color-border);
    color: var(--brand-primary);
    transform: translateY(-1px);
}

.sp-location__external svg {
    color: var(--brand-primary);
    width: 14px;
    height: 14px;
}

.sp-location__fallback {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 20px;
    padding: 60px 24px;
    text-align: center;
    background: var(--color-bg-alt);
    border-radius: var(--radius-xl);
}

.sp-location__fallback svg {
    color: var(--color-text-muted);
}

.sp-location__fallback-text {
    font-size: 16px;
    font-weight: 500;
    color: var(--color-text);
    margin: 0;
}

/* 9️⃣ EK BİLGİLER & KURALLAR - Clean Cards */
.sp-rules__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    margin-bottom: 24px;
}
@media (min-width: 640px) {
    .sp-rules__grid { grid-template-columns: repeat(3, 1fr); }
}

.sp-rules__card {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px;
    background: var(--color-bg);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: all 0.2s ease;
}

.sp-rules__card:hover {
    border-color: var(--color-border);
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

.sp-rules__card--checkin {
    background: rgba(198,40,40,0.04);
    border-color: rgba(198,40,40,0.15);
}

.sp-rules__card--checkout {
    background: rgba(245,158,11,0.04);
    border-color: rgba(245,158,11,0.15);
}

.sp-rules__icon {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(198,40,40,0.1);
    border-radius: var(--radius-lg);
}

.sp-rules__card--checkin .sp-rules__icon svg {
    color: var(--brand-primary);
}

.sp-rules__card--checkout .sp-rules__icon svg {
    color: var(--brand-amber);
}

.sp-rules__info {
    flex: 1;
}

.sp-rules__label {
    font-size: 12px;
    color: var(--color-text-light);
    display: block;
    margin-bottom: 4px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 600;
}

.sp-rules__value {
    font-size: 16px;
    font-weight: 700;
    color: var(--color-text);
}

.sp-rules__notes {
    padding: 24px;
    background: #fffbeb;
    border: 1px solid #fef3c7;
    border-radius: var(--radius-lg);
    margin-top: 20px;
}

.sp-rules__notes h3 {
    font-size: 16px;
    font-weight: 700;
    margin: 0 0 16px;
    color: #92400e;
}

.sp-rules__text {
    font-size: 15px;
    line-height: 1.7;
    color: #78350f;
    white-space: pre-line;
    margin: 0;
}

/* 🔟 YORUMLAR - Better Form Layout */
.sp-comments__form {
    margin-top: 32px;
    padding: 28px;
    background: var(--color-bg-alt);
    border-radius: var(--radius-xl);
}

.sp-comments__form .comment-form-comment textarea,
.sp-comments__form .comment-form-author input,
.sp-comments__form .comment-form-email input,
.sp-comments__form .comment-form-url input {
    width: 100%;
    padding: 14px 16px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    font-size: 15px;
    font-family: inherit;
    background: var(--color-bg);
    transition: border-color 0.2s ease;
}

.sp-comments__form .comment-form-comment textarea:focus,
.sp-comments__form .comment-form-author input:focus,
.sp-comments__form .comment-form-email input:focus,
.sp-comments__form .comment-form-url input:focus {
    border-color: var(--brand-primary);
    outline: none;
}

.sp-comments__form .form-submit input {
    padding: 14px 28px;
    background: var(--brand-primary);
    color: #fff;
    border: none;
    border-radius: var(--radius-lg);
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

.sp-comments__form .form-submit input:hover {
    background: var(--brand-primary-hover);
    transform: translateY(-1px);
}

/* 1️⃣1️⃣ CTA BLOCK - Polished Red Section */
.sp-cta-band {
    padding: 64px 0;
    background: linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-primary-hover) 100%);
    text-align: center;
    position: relative;
    overflow: hidden;
}

.sp-cta-band::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    opacity: 0.4;
}

.sp-cta-band__content {
    position: relative;
    z-index: 1;
}

.sp-cta-band__title {
    font-size: 28px;
    font-weight: 700;
    margin: 0 0 16px;
    color: #fff;
    line-height: 1.3;
}
@media (min-width: 768px) {
    .sp-cta-band__title { font-size: 36px; }
}

.sp-cta-band__text {
    font-size: 16px;
    opacity: 0.9;
    margin: 0 0 28px;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
    color: #fff;
    line-height: 1.6;
}

.sp-cta-band__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 18px 36px;
    background: #fff;
    color: var(--brand-primary);
    font-size: 17px;
    font-weight: 700;
    border-radius: var(--radius-lg);
    text-decoration: none;
    transition: all 0.3s ease;
    box-shadow: 0 4px 20px rgba(0,0,0,0.15);
}

.sp-cta-band__btn:hover {
    transform: translateY(-3px) scale(1.02);
    box-shadow: 0 8px 30px rgba(0,0,0,0.25);
    color: var(--brand-primary-hover);
}

.sp-cta-band__btn svg {
    color: var(--brand-primary);
    width: 24px;
    height: 24px;
}

/* 1️⃣2️⃣ BENZER TESİSLER - 3-Column Grid */
.sp-related {
    padding: 48px 0;
    background: var(--color-bg-alt);
}

.sp-related .property-grid--3 {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
}
@media (min-width: 640px) {
    .sp-related .property-grid--3 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
    .sp-related .property-grid--3 { grid-template-columns: repeat(3, 1fr); }
}

.sp-related .property-card {
    background: var(--color-bg);
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    transition: all 0.2s ease;
}

.sp-related .property-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.12);
}

.sp-related .property-card__image {
    aspect-ratio: 16/10;
    overflow: hidden;
}

.sp-related .property-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.sp-related .property-card:hover .property-card__image img {
    transform: scale(1.05);
}

/* 1️⃣3️⃣ GLOBAL UI CLEANUP */
.sp-section {
    margin-bottom: 0;
    padding: 24px 0;
    border-bottom: 1px solid var(--color-border-light);
}

.sp-section:last-of-type {
    border-bottom: none;
}

.sp-section__title {
    font-size: 22px;
    font-weight: 700;
    margin: 0 0 20px;
    color: var(--color-text);
    line-height: 1.3;
}

/* Remove unnecessary separators */
.sp-content__main > .sp-section + .sp-section {
    border-top: none;
}

/* Consistent heading hierarchy */
.sp-content h1 { font-size: 36px; font-weight: 700; }
.sp-content h2 { font-size: 22px; font-weight: 700; }
.sp-content h3 { font-size: 18px; font-weight: 600; }

/* Normalize margins between sections */
.sp-content__main {
    display: flex;
    flex-direction: column;
    gap: 0;
}

/* Mobile responsive improvements */
@media (max-width: 767px) {
    .sp-title { font-size: 28px; }
    .sp-section { padding: 20px 0; }
    .sp-section__title { font-size: 20px; margin-bottom: 16px; }
    .sp-units__list { gap: 16px; }
    .sp-unit { padding: 20px; }
    .sp-calendar__wrap { padding: 20px; }
    .sp-rules__grid { grid-template-columns: 1fr; gap: 12px; }
    .sp-cta-band { padding: 48px 0; }
    .sp-cta-band__title { font-size: 24px; }
}

/* Print styles */
@media print {
    .sp-cta-box,
    .sp-calendar__whatsapp-btn,
    .sp-unit__cta,
    .sp-cta-band,
    .whatsapp-sticky {
        display: none !important;
    }
    
    .sp-hero__grid {
        grid-template-columns: 1fr !important;
    }
    
    .sp-section {
        break-inside: avoid;
        page-break-inside: avoid;
    }
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    .sp-highlight,
    .sp-unit,
    .sp-calendar__wrap,
    .sp-rules__card {
        border-width: 2px;
    }
    
    .sp-highlight__icon,
    .sp-rules__icon {
        background: var(--color-text);
    }
    
    .sp-highlight__icon svg,
    .sp-rules__icon svg {
        color: var(--color-bg);
    }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
    .sp-unit,
    .sp-highlight,
    .sp-calendar__whatsapp-btn,
    .sp-cta-band__btn,
    .sp-about__toggle {
        transition: none;
    }
    
    .sp-unit:hover,
    .sp-highlight:hover,
    .sp-related .property-card:hover {
        transform: none;
    }
}
/* ========================================
   THEME TAXONOMY ARCHIVE PAGE
   ======================================== */

/* Page Header for Theme Archives */
.page-header--theme {
    background: linear-gradient(135deg, var(--color-bg-alt) 0%, var(--color-bg) 100%);
    padding: 60px 0 40px;
    border-bottom: 1px solid var(--color-border-light);
}

.page-header__content {
    text-align: center;
    max-width: 800px;
    margin: 0 auto;
}

.page-header__title {
    font-size: 32px;
    font-weight: 700;
    color: var(--color-text);
    margin: 16px 0;
    line-height: 1.3;
}
@media (min-width: 768px) {
    .page-header__title { font-size: 40px; }
}

.page-header__desc {
    font-size: 16px;
    color: var(--color-text-light);
    margin: 0 0 20px;
    line-height: 1.6;
}

.page-header__stats {
    display: inline-flex;
    align-items: center;
    padding: 8px 16px;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-full);
    font-size: 14px;
    font-weight: 600;
    color: var(--brand-primary);
}

/* Filter Bar */
.filter-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 32px;
    padding: 20px 0;
    border-bottom: 1px solid var(--color-border-light);
}
@media (max-width: 767px) {
    .filter-bar {
        flex-direction: column;
        align-items: stretch;
        gap: 16px;
    }
}

.filter-bar__results {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text);
}

.sort-dropdown {
    position: relative;
}

.sort-dropdown select {
    appearance: none;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 10px 40px 10px 16px;
    font-size: 14px;
    color: var(--color-text);
    cursor: pointer;
    min-width: 200px;
}

.sort-dropdown::after {
    content: '';
    position: absolute;
    top: 50%;
    right: 16px;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 4px solid var(--color-text-light);
    pointer-events: none;
}

/* Properties Grid for Archive */
.property-grid--archive {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
}
@media (min-width: 640px) {
    .property-grid--archive { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
    .property-grid--archive { grid-template-columns: repeat(3, 1fr); }
}

/* No Properties Found */
.no-properties {
    text-align: center;
    padding: 80px 20px;
    max-width: 500px;
    margin: 0 auto;
}

.no-properties__icon {
    margin-bottom: 24px;
}

.no-properties__icon svg {
    color: var(--color-text-muted);
}

.no-properties__title {
    font-size: 24px;
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 16px;
}

.no-properties__desc {
    font-size: 16px;
    color: var(--color-text-light);
    margin: 0 0 32px;
    line-height: 1.6;
}

/* Related Themes Section */
.section--related-themes {
    background: var(--color-bg-alt);
    padding: 60px 0;
}

.theme-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}
@media (min-width: 640px) {
    .theme-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
    .theme-grid { grid-template-columns: repeat(3, 1fr); }
}

.theme-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px;
    background: var(--color-bg);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    text-decoration: none;
    transition: all 0.2s ease;
}

.theme-card:hover {
    border-color: var(--brand-primary);
    box-shadow: 0 4px 16px rgba(0,0,0,0.08);
    transform: translateY(-2px);
}

.theme-card__content {
    flex: 1;
}

.theme-card__title {
    font-size: 18px;
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 4px;
    line-height: 1.3;
}

.theme-card__count {
    font-size: 14px;
    color: var(--color-text-light);
    margin: 0;
}

.theme-card__arrow {
    color: var(--brand-primary);
    transition: transform 0.2s ease;
}

.theme-card:hover .theme-card__arrow {
    transform: translateX(4px);
}

/* Pagination */
.pagination {
    margin-top: 48px;
}

.pagination__list {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    list-style: none;
    padding: 0;
    margin: 0;
}

.pagination__item a,
.pagination__item span {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    min-width: 44px;
    height: 44px;
    padding: 0 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text);
    text-decoration: none;
    transition: all 0.2s ease;
}

.pagination__item a:hover {
    border-color: var(--brand-primary);
    color: var(--brand-primary);
}

.pagination__item .current {
    background: var(--brand-primary);
    border-color: var(--brand-primary);
    color: #fff;
}

.pagination__item .prev,
.pagination__item .next {
    font-weight: 600;
}

.pagination__item svg {
    width: 16px;
    height: 16px;
}

/* Responsive adjustments */
@media (max-width: 767px) {
    .page-header--theme {
        padding: 40px 0 30px;
    }
    
    .page-header__title {
        font-size: 28px;
    }
    
    .theme-card {
        padding: 16px;
    }
    
    .theme-card__title {
        font-size: 16px;
    }
    
    .pagination__item a,
    .pagination__item span {
        min-width: 40px;
        height: 40px;
        font-size: 13px;
    }
}

/* ========== MOBILE UX OPTIMIZATIONS ========== */
@media (max-width: 767px) {
    /* Touch-friendly button sizing */
    .btn {
        min-height: 48px;
        padding: 14px 24px;
        font-size: 15px;
    }
    
    /* Property card touch optimization */
    .property-card {
        margin-bottom: 4px;
    }
    
    .property-card:active {
        transform: scale(0.98);
    }
    
    /* Section spacing optimization */
    .section {
        padding: 32px 0;
    }
    
    /* Hero content mobile spacing */
    .hero__content {
        margin-bottom: 24px;
    }
    
    /* Mobile-specific property grid spacing */
    .property-grid {
        margin-top: 24px;
    }
    
    /* Section header mobile optimization */
    .section-header {
        margin-bottom: 24px;
    }
    
    /* Trust badges mobile grid */
    .trust-badge {
        text-align: center;
        min-width: 0;
    }
    
    .trust-badge span {
        font-size: 12px;
        line-height: 1.3;
    }
    
    /* Mobile testimonial scroll indicator */
    .testimonials-grid::after {
        content: '';
        position: absolute;
        bottom: -20px;
        left: 50%;
        transform: translateX(-50%);
        width: 40px;
        height: 4px;
        background: var(--color-border-light);
        border-radius: 2px;
    }
    
    .section--testimonials {
        position: relative;
        padding-bottom: 56px;
    }
    
    /* Mobile vacation card optimization */
    .vacation-card__content {
        padding: 16px;
    }
    
    .vacation-card__title {
        font-size: 16px;
        margin-bottom: 6px;
    }
    
    .vacation-card__desc {
        font-size: 13px;
    }
    
    /* Mobile property card optimization */
    .property-card__body {
        padding: 14px 16px 16px;
    }
    
    .property-card__title {
        font-size: 16px;
        margin-bottom: 10px;
    }
    
    .property-card__specs {
        margin-bottom: 12px;
        gap: 12px;
    }
    
    .property-card__features {
        margin-bottom: 12px;
        gap: 4px;
    }
    
    .property-card__feature {
        padding: 4px 8px;
        font-size: 11px;
    }
    
    .property-card__footer {
        padding-top: 12px;
    }
    
    .property-card__price-value {
        font-size: 20px;
    }
    
    .property-card__cta {
        padding: 8px 14px;
        font-size: 12px;
    }
}

/* ========== MOBILE LANDSCAPE OPTIMIZATIONS ========== */
@media (max-width: 767px) and (orientation: landscape) {
    .hero {
        padding: 40px 0 60px;
        min-height: 320px;
    }
    
    .hero__title {
        font-size: 20px;
        margin-bottom: 8px;
    }
    
    .hero__subtitle {
        font-size: 13px;
    }
    
    .hero-search {
        padding: 14px;
    }
    
    .hero-search__row {
        gap: 8px;
    }
}

/* ========== MOBILE ACCESSIBILITY ========== */
@media (max-width: 767px) {
    /* Larger touch targets for mobile */
    .property-card__favorite {
        width: 44px;
        height: 44px;
        opacity: 1;
    }
    
    /* Better mobile focus states */
    .btn:focus-visible,
    .property-card:focus-visible {
        outline: 3px solid var(--brand-primary);
        outline-offset: 2px;
    }
    
    /* Mobile-friendly form elements */
    .hero-search__select-wrap select,
    .hero-search__input-wrap input {
        font-size: 16px; /* Prevents zoom on iOS */
    }
}
/* ========== FOOTER OVERFLOW FIXES ========== */
.site-footer {
    width: 100%;
    max-width: 100vw;
    box-sizing: border-box;
}

.site-footer * {
    box-sizing: border-box;
}

.footer-main .container {
    max-width: var(--container-max);
    width: 100%;
    padding-left: var(--space-md);
    padding-right: var(--space-md);
    margin: 0 auto;
}

@media (min-width: 768px) {
    .footer-main .container {
        padding-left: var(--space-lg);
        padding-right: var(--space-lg);
    }
}

/* Prevent text overflow in footer columns */
.footer-col {
    min-width: 0;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

.footer-links a,
.footer-contact a,
.footer-tagline {
    word-wrap: break-word;
    overflow-wrap: break-word;
    hyphens: auto;
}

/* Ensure footer doesn't interfere with body overflow */
body {
    overflow-x: hidden;
}

/* Footer spacing from content */
.site-footer {
    margin-top: 0;
}

/* Ensure proper z-index stacking */
.site-footer {
    position: relative;
    z-index: 1;
}

.whatsapp-float {
    z-index: 1000;
}

/* Mobile footer improvements */
@media (max-width: 767px) {
    .footer-main {
        padding: 32px 0 20px;
    }
    
    .footer-grid {
        gap: 24px;
    }
    
    .footer-brand {
        gap: 16px;
    }
    
    .footer-tagline {
        max-width: 100%;
        text-align: center;
    }
    
    .footer-col {
        gap: 12px;
    }
    
    .footer-links {
        gap: 6px;
    }
    
    .footer-contact {
        gap: 10px;
    }
    
    .footer-bottom {
        padding: 16px 0;
    }
    
    .footer-legal {
        gap: 12px;
        font-size: 12px;
    }
}
/* ==========================================================================
   ARCHIVE & LISTING ENHANCEMENTS
   ========================================================================== */

/* Enhanced Archive Layout */
.archive-layout {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 40px;
    align-items: start;
}

@media (max-width: 1023px) {
    .archive-layout {
        grid-template-columns: 1fr;
        gap: 0;
    }
}

/* Desktop Filters */
.archive-filters {
    display: block;
}

@media (max-width: 1023px) {
    .archive-filters {
        display: none;
    }
}

.filter-panel {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 24px;
    position: sticky;
    top: 100px;
    box-shadow: var(--shadow-card);
    width: 100%;
    display: block;
}

.filter-panel__title {
    font-size: 18px;
    font-weight: 600;
    margin: 0 0 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--color-border);
    color: var(--color-text);
}

.filter-group {
    margin-bottom: 24px;
    width: 100%;
    display: block;
}

.filter-group:last-child {
    margin-bottom: 0;
}

.filter-group__title {
    font-size: 14px;
    font-weight: 600;
    margin: 0 0 12px;
    color: var(--color-text);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.filter-checkbox {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 0;
    cursor: pointer;
    font-size: 14px;
    width: 100%;
}

.filter-checkbox input[type="checkbox"] {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

.filter-checkbox__count {
    margin-left: auto;
    color: var(--color-text-light);
    font-size: 12px;
}

.filter-select {
    width: 100%;
    padding: 10px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 14px;
    background: var(--color-white);
}

.filter-actions {
    margin-top: 24px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.filter-actions .btn {
    width: 100%;
    justify-content: center;
}


    padding: 24px;
    border-top: 1px solid var(--color-border);
    display: flex;
    gap: 12px;
    position: sticky;
    bottom: 0;
    background: var(--color-white);
}

.btn--full {
    width: 100%;
    justify-content: center;
}

/* Enhanced Archive Toolbar */
.archive-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 0;
    border-bottom: 1px solid var(--color-border);
    margin-bottom: 32px;
}

.archive-toolbar__count {
    font-size: 14px;
    color: var(--color-text-light);
    font-weight: 500;
}

.archive-toolbar__sort {
    display: flex;
    align-items: center;
    gap: 12px;
}

.archive-toolbar__sort label {
    font-size: 14px;
    color: var(--color-text);
    font-weight: 500;
}

.archive-toolbar__sort select {
    padding: 8px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    background: var(--color-white);
    font-size: 14px;
    min-width: 140px;
}

/* Enhanced Filter Panel */
.filter-panel {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 24px;
    position: sticky;
    top: 24px;
}

.filter-panel__title {
    font-size: 18px;
    font-weight: 600;
    margin: 0 0 24px 0;
    color: var(--color-text);
}

.filter-group {
    margin-bottom: 32px;
}

.filter-group:last-child {
    margin-bottom: 24px;
}

.filter-group__title {
    font-size: 15px;
    font-weight: 600;
    margin: 0 0 16px 0;
    color: var(--color-text);
}

.filter-checkbox {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 0;
    cursor: pointer;
    transition: all 0.2s ease;
}

.filter-checkbox:hover {
    color: var(--color-primary);
}

.filter-checkbox input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--color-primary);
}

.filter-checkbox__count {
    margin-left: auto;
    font-size: 13px;
    color: var(--color-text-light);
}

.filter-select {
    width: 100%;
    padding: 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-white);
    font-size: 14px;
}

.price-range {
    display: flex;
    align-items: center;
    gap: 8px;
}

.price-input {
    flex: 1;
    padding: 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    font-size: 14px;
}

.filter-actions {
    display: flex;
    gap: 12px;
}

.filter-actions .btn {
    flex: 1;
    justify-content: center;
}

/* Enhanced Property Grid */
.property-grid--3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}

/* Enhanced No Results */
.no-results {
    text-align: center;
    padding: 60px 20px;
    background: var(--color-gray-50);
    border-radius: var(--radius-lg);
}

.no-results p {
    font-size: 16px;
    color: var(--color-text-light);
    margin: 0 0 24px 0;
}

/* Enhanced Pagination */
.pagination {
    margin-top: 48px;
}

.pagination__list {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.pagination__item a,
.pagination__item span {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    height: 44px;
    padding: 0 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    text-decoration: none;
    color: var(--color-text);
    font-weight: 500;
    transition: all 0.2s ease;
}

.pagination__item a:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
}

.pagination__item .current {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-white);
}

/* Mobile Responsive */
@media (max-width: 1023px) {
    .mobile-filter-bar {
        display: flex;
    }

    .archive-filters {
        display: none;
    }

    .archive-layout {
        display: block;
    }

    .archive-results {
        width: 100%;
    }

    .archive-toolbar {
        display: none;
    }

    .property-grid--3 {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .archive-header {
        padding: 32px 0;
    }

    .archive-header__title {
        font-size: 24px;
        margin-bottom: 12px;
    }

    .archive-header__desc {
        font-size: 15px;
        margin-bottom: 8px;
    }

    .archive-header__count {
        font-size: 14px;
    }
}

@media (max-width: 480px) {
    .mobile-filter-actions {
        flex-direction: column;
    }

    .mobile-filter-actions .btn {
        width: 100%;
    }
}

/* Body scroll lock when modal is open */
body.modal-open {
    overflow: hidden;
}

/* ==========================================================================
   MOBILE FILTER COMPLETE IMPLEMENTATION
   ========================================================================== */

/* Mobile Filter Bar - Show only on mobile */
.mobile-filter-bar {
    display: none;
}

@media (max-width: 1023px) {
    .mobile-filter-bar {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 20px;
        padding: 16px;
        background: var(--color-white);
        border: 1px solid var(--color-border);
        border-radius: var(--radius-lg);
        box-shadow: var(--shadow-card);
    }
}

.mobile-filter-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    background: var(--brand-primary);
    color: white;
    border: none;
    border-radius: var(--radius-sm);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.mobile-filter-btn:hover {
    background: var(--brand-primary-hover);
    transform: translateY(-1px);
}

.mobile-sort-select {
    padding: 8px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 13px;
    background: var(--color-white);
    min-width: 120px;
}

/* Mobile Filter Modal - Bottom Sheet Style */
.mobile-filter-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9999;
    display: none;
}

.mobile-filter-modal.is-open {
    display: block;
}

.mobile-filter-modal__backdrop {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(4px);
}

.mobile-filter-modal__content {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: var(--color-white);
    border-radius: 16px 16px 0 0;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    transform: translateY(100%);
    transition: transform 0.3s ease;
}

.mobile-filter-modal.is-open .mobile-filter-modal__content {
    transform: translateY(0);
}

.mobile-filter-modal__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 24px;
    border-bottom: 1px solid var(--color-border);
    flex-shrink: 0;
    background: var(--color-white);
}

.mobile-filter-modal__header h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: var(--color-text);
}

.mobile-filter-modal__close {
    background: none;
    border: none;
    padding: 8px;
    cursor: pointer;
    color: var(--color-text-light);
    border-radius: var(--radius-sm);
    transition: all 0.2s ease;
}

.mobile-filter-modal__close:hover {
    background: var(--color-bg-alt);
    color: var(--color-text);
}

.mobile-filter-form {
    flex: 1;
    overflow-y: auto;
    padding: 24px;
    padding-bottom: 100px; /* Space for sticky actions */
}

.mobile-filter-group {
    margin-bottom: 32px;
}

.mobile-filter-group:last-child {
    margin-bottom: 0;
}

.mobile-filter-group__title {
    font-size: 16px;
    font-weight: 600;
    margin: 0 0 16px 0;
    color: var(--color-text);
}

.mobile-filter-options {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.mobile-filter-checkbox {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    background: var(--color-bg-alt);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all 0.2s ease;
}

.mobile-filter-checkbox:hover {
    background: rgba(198,40,40,0.05);
}

.mobile-filter-checkbox input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--color-primary);
    flex-shrink: 0;
}

.mobile-filter-checkbox__text {
    flex: 1;
    font-size: 14px;
    color: var(--color-text);
}

.mobile-filter-checkbox__count {
    color: var(--color-text-light);
    font-size: 12px;
}

/* Active state for selected feature in mobile */
.mobile-filter-checkbox--active {
    background: rgba(198,40,40,0.1) !important;
    border: 1px solid rgba(198,40,40,0.3);
    border-radius: var(--radius-md);
}

.mobile-filter-checkbox--active .mobile-filter-checkbox__text {
    color: var(--color-primary);
    font-weight: 600;
}

.mobile-filter-checkbox--active input[type="checkbox"] {
    cursor: not-allowed;
}

.mobile-filter-select {
    width: 100%;
    padding: 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 14px;
    background: var(--color-white);
    box-sizing: border-box;
}

/* Mobile Price Range - CRITICAL: Must be stacked vertically */
.mobile-price-range {
    display: flex;
    flex-direction: column;
    gap: 12px;
    width: 100%;
}

.mobile-price-input {
    width: 100%;
    padding: 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: 14px;
    box-sizing: border-box;
}

.mobile-filter-actions {
    position: sticky;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 20px 24px;
    background: var(--color-white);
    border-top: 1px solid var(--color-border);
    display: flex;
    gap: 12px;
    flex-shrink: 0;
}

.mobile-filter-actions .btn {
    flex: 1;
}

/* Body scroll lock when modal is open */
body.modal-open {
    overflow: hidden;
}

/* Desktop Filter Fixes */
@media (min-width: 1024px) {
    .mobile-filter-bar {
        display: none !important;
    }
    
    .archive-filters {
        display: block;
    }
    
    .archive-layout {
        display: grid;
        grid-template-columns: 280px 1fr;
        gap: 40px;
    }
}

/* Mobile Layout Fixes */
@media (max-width: 1023px) {
    .archive-filters {
        display: none !important;
    }
    
    .archive-layout {
        display: block;
    }
    
    .archive-results {
        width: 100%;
    }
    
    .archive-toolbar {
        display: none;
    }
    
    .property-grid--3 {
        grid-template-columns: 1fr;
        gap: 20px;
    }
}

/* Prevent horizontal scroll on all devices */
body {
    overflow-x: hidden;
}

.archive-results {
    min-width: 0;
    overflow-x: hidden;
}

/* Filter Panel Improvements */
.filter-panel {
    width: 100%;
    box-sizing: border-box;
}

.filter-group {
    width: 100%;
    box-sizing: border-box;
}

/* Price Range Desktop - CRITICAL: Must stay stacked */
.price-range {
    display: flex;
    flex-direction: column;
    gap: 8px;
    width: 100%;
}

.price-range input {
    width: 100%;
    box-sizing: border-box;
}

/* Ensure all inputs are properly sized */
.filter-select,
.price-input,
.mobile-filter-select,
.mobile-price-input {
    box-sizing: border-box;
}
/* ==========================================================================
   MOBILE FILTER MODAL - CLEAN REDESIGN
   ========================================================================== */

/* Override existing mobile filter modal with clean design */
.mobile-filter-modal {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    z-index: 9999 !important;
    display: none !important;
}

.mobile-filter-modal.is-open {
    display: flex !important;
}

.mobile-filter-modal__backdrop {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: rgba(0, 0, 0, 0.7) !important;
    backdrop-filter: blur(4px) !important;
}

.mobile-filter-modal__content {
    position: relative !important;
    width: 100% !important;
    height: 100% !important;
    background: var(--color-white) !important;
    display: flex !important;
    flex-direction: column !important;
    transform: translateX(100%) !important;
    transition: transform 0.3s ease !important;
    border-radius: 0 !important;
    max-height: none !important;
}

.mobile-filter-modal.is-open .mobile-filter-modal__content {
    transform: translateX(0) !important;
}

.mobile-filter-modal__header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 16px 20px !important;
    border-bottom: 1px solid var(--color-border) !important;
    flex-shrink: 0 !important;
    background: var(--color-white) !important;
    min-height: 60px !important;
    position: relative !important;
}

.mobile-filter-modal__header h3 {
    margin: 0 !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    color: var(--color-text) !important;
}

.mobile-filter-modal__close {
    background: none !important;
    border: none !important;
    padding: 8px !important;
    cursor: pointer !important;
    color: var(--color-text-light) !important;
    border-radius: var(--radius-sm) !important;
    transition: all 0.2s ease !important;
    width: 40px !important;
    height: 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.mobile-filter-modal__close:hover {
    background: var(--color-bg-alt) !important;
    color: var(--color-text) !important;
}

.mobile-filter-form {
    flex: 1 !important;
    overflow-y: auto !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    position: relative !important;
}

.mobile-filter-content {
    flex: 1 !important;
    padding: 20px !important;
    padding-bottom: 120px !important; /* Space for sticky actions */
}

.mobile-filter-group {
    margin-bottom: 28px !important;
}

.mobile-filter-group:last-child {
    margin-bottom: 0 !important;
}

.mobile-filter-group__title {
    font-size: 16px !important;
    font-weight: 600 !important;
    margin: 0 0 12px 0 !important;
    color: var(--color-text) !important;
    padding-bottom: 8px !important;
    border-bottom: 1px solid var(--color-border-light) !important;
}

.mobile-filter-options {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
}

.mobile-filter-checkbox {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 14px 0 !important;
    border-bottom: 1px solid var(--color-border-light) !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    background: transparent !important;
    border-radius: 0 !important;
}

.mobile-filter-checkbox:last-child {
    border-bottom: none !important;
}

.mobile-filter-checkbox:hover {
    background: rgba(198,40,40,0.02) !important;
}

.mobile-filter-checkbox input[type="checkbox"] {
    width: 20px !important;
    height: 20px !important;
    accent-color: var(--color-primary) !important;
    flex-shrink: 0 !important;
    margin: 0 !important;
}

.mobile-filter-checkbox__text {
    flex: 1 !important;
    font-size: 15px !important;
    color: var(--color-text) !important;
    font-weight: 500 !important;
}

.mobile-filter-checkbox__count {
    color: var(--color-text-light) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
}

.mobile-filter-select {
    width: 100% !important;
    padding: 14px 16px !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    font-size: 15px !important;
    background: var(--color-white) !important;
    box-sizing: border-box !important;
    margin-top: 8px !important;
}

/* Mobile Price Range - Clean vertical layout */
.mobile-price-range {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    width: 100% !important;
    margin-top: 8px !important;
}

.mobile-price-input {
    width: 100% !important;
    padding: 14px 16px !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    font-size: 15px !important;
    box-sizing: border-box !important;
}

.mobile-filter-actions {
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    padding: 16px 20px !important;
    background: var(--color-white) !important;
    border-top: 1px solid var(--color-border) !important;
    display: flex !important;
    gap: 12px !important;
    flex-shrink: 0 !important;
    box-shadow: 0 -4px 12px rgba(0,0,0,0.1) !important;
}

.mobile-filter-actions .btn {
    flex: 1 !important;
    padding: 14px 20px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    border-radius: var(--radius-md) !important;
    border: none !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
}

.mobile-filter-actions .btn--outline {
    background: transparent !important;
    border: 2px solid var(--color-border) !important;
    color: var(--color-text) !important;
}

.mobile-filter-actions .btn--outline:hover {
    background: var(--color-bg-alt) !important;
}

.mobile-filter-actions .btn--primary {
    background: var(--color-primary) !important;
    color: white !important;
}

.mobile-filter-actions .btn--primary:hover {
    background: var(--color-primary-dark) !important;
}

/* Ensure modal is always full screen on mobile */
@media (max-width: 1023px) {
    .mobile-filter-modal__content {
        width: 100vw !important;
        height: 100vh !important;
        max-width: none !important;
        max-height: none !important;
    }
}
/* Mobile Filter Button - Better styling */
.mobile-filter-btn {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 12px 16px !important;
    background: var(--brand-primary) !important;
    color: white !important;
    border: none !important;
    border-radius: var(--radius-md) !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    box-shadow: 0 2px 8px rgba(198,40,40,0.25) !important;
}

.mobile-filter-btn:hover {
    background: var(--brand-primary-hover) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(198,40,40,0.3) !important;
}

.mobile-filter-btn svg {
    width: 18px !important;
    height: 18px !important;
}

/* Mobile Filter Bar - Better spacing */
.mobile-filter-bar {
    display: none !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 20px !important;
    padding: 16px !important;
    background: var(--color-white) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-card) !important;
}

@media (max-width: 1023px) {
    .mobile-filter-bar {
        display: flex !important;
    }
}

.mobile-sort-select {
    padding: 10px 12px !important;
    border: 1px solid var(--color-border) !important;
    border-radius: var(--radius-md) !important;
    font-size: 14px !important;
    background: var(--color-white) !important;
    min-width: 120px !important;
}
/* Force full screen modal on mobile */
@media (max-width: 1023px) {
    .mobile-filter-modal {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        width: 100vw !important;
        height: 100vh !important;
        z-index: 9999 !important;
    }
    
    .mobile-filter-modal__content {
        position: absolute !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        width: 100% !important;
        height: 100% !important;
        max-width: none !important;
        max-height: none !important;
        border-radius: 0 !important;
        transform: translateX(100%) !important;
    }
    
    .mobile-filter-modal.is-open .mobile-filter-modal__content {
        transform: translateX(0) !important;
    }
    
    .mobile-filter-modal__backdrop {
        display: none !important; /* Hide backdrop on mobile for full screen */
    }
}

/* Body scroll lock when modal is open */
body.modal-open {
    overflow: hidden !important;
    position: fixed !important;
    width: 100% !important;
    height: 100% !important;
}

/* ===== PRICE BOX OPTIMIZATION - MOBILE UX IMPROVEMENTS ===== */

/* Simplified date range input - single field for mobile */
.sp-cta-box__input--date-range {
    cursor: pointer;
    transition: all 0.2s ease;
}
.sp-cta-box__input--date-range:hover {
    border-color: var(--color-primary);
    background: rgba(196,30,58,0.02);
}

.sp-cta-box__date-placeholder,
.sp-cta-box__guest-count {
    font-size: 14px;
    color: var(--color-text);
    font-weight: 500;
}

/* Mobile-optimized date fields */
@media (max-width: 480px) {
    .sp-cta-box__dates {
        grid-template-columns: 1fr;
        gap: 12px;
    }
    
    .sp-cta-box__field label {
        font-size: 12px;
        margin-bottom: 2px;
    }
    
    .sp-cta-box__input {
        padding: 12px 14px;
        border-radius: 8px;
    }
    
    .sp-cta-box__date-placeholder,
    .sp-cta-box__guest-count {
        font-size: 15px;
    }
}

/* Optimized primary button for mobile */
@media (max-width: 480px) {
    .sp-cta-box__btn--xl {
        padding: 16px 20px;
        font-size: 15px;
        font-weight: 600;
        border-radius: 12px;
    }
    
    .sp-cta-box__btn--xl svg {
        width: 18px;
        height: 18px;
    }
}

/* Minimal trust indicator - replaces cluttered trust bar */
.sp-cta-box__trust-minimal {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin-top: 12px;
    font-size: 12px;
    color: var(--color-text-light);
    font-weight: 500;
}

.sp-cta-box__trust-minimal svg {
    color: var(--color-primary);
    flex-shrink: 0;
}

/* Mobile spacing optimization */
@media (max-width: 480px) {
    .sp-cta-box {
        padding: 20px 16px;
        margin: 0 -16px;
        border-radius: 16px 16px 0 0;
        border-left: none;
        border-right: none;
    }
    
    .sp-cta-box__price {
        margin-bottom: 16px;
    }
    
    .sp-cta-box__form {
        margin-bottom: 16px;
    }
    
    .sp-cta-box__divider {
        margin: 16px 0;
    }
    
    .sp-cta-box__trust-minimal {
        margin-top: 8px;
        font-size: 11px;
    }
}

/* Price display optimization for mobile */
@media (max-width: 480px) {
    .sp-cta-box__price-amount {
        font-size: 28px;
    }
    
    .sp-cta-box__price-period {
        font-size: 14px;
    }
    
    .sp-cta-box__price-details {
        gap: 16px;
        margin-top: 10px;
        padding-top: 10px;
    }
    
    .sp-cta-box__price-detail {
        font-size: 12px;
    }
}

/* Hide redundant elements on mobile for cleaner UX */
@media (max-width: 480px) {
    .sp-cta-box__price-note {
        display: none;
    }
}

/* Enhanced elevated box shadow for mobile */
@media (max-width: 480px) {
    .sp-cta-box--elevated {
        box-shadow: 0 -4px 20px rgba(0,0,0,0.1), 0 -2px 8px rgba(0,0,0,0.06);
    }
}

/* RTL support for new elements */
[dir="rtl"] .sp-cta-box__trust-minimal {
    flex-direction: row-reverse;
}

[dir="rtl"] .sp-cta-box__input--date-range {
    flex-direction: row-reverse;
}
/* ===== MOBILE STICKY PRICE BOX (MODERN BOOKING UX) ===== */

@media (max-width: 768px) {
    /* Make price box sticky on mobile for better conversion */
    .single-property-page .sp-cta-box--elevated {
        position: sticky;
        bottom: 0;
        z-index: 100;
        margin: 16px -16px -16px -16px;
        border-radius: 16px 16px 0 0;
        box-shadow: 0 -8px 32px rgba(0,0,0,0.15), 0 -4px 16px rgba(0,0,0,0.1);
        background: var(--color-bg);
        backdrop-filter: blur(10px);
    }
    
    /* Ensure content doesn't get hidden behind sticky price box */
    .single-property-page .sp-content {
        padding-bottom: 120px;
    }
    
    /* Compact mobile layout */
    .single-property-page .sp-cta-box--elevated .sp-cta-box__price {
        margin-bottom: 12px;
    }
    
    .single-property-page .sp-cta-box--elevated .sp-cta-box__form {
        margin-bottom: 12px;
    }
    
    .single-property-page .sp-cta-box--elevated .sp-cta-box__divider {
        margin: 12px 0;
    }
    
    /* Hide price details on mobile sticky to save space */
    .single-property-page .sp-cta-box--elevated .sp-cta-box__price-details {
        display: none;
    }
    
    /* Compact trust indicator */
    .single-property-page .sp-cta-box--elevated .sp-cta-box__trust-minimal {
        margin-top: 6px;
        font-size: 10px;
    }
}

/* ===== TABLET OPTIMIZATION ===== */

@media (min-width: 481px) and (max-width: 768px) {
    .sp-cta-box {
        padding: 24px 20px;
    }
    
    .sp-cta-box__dates {
        grid-template-columns: 1fr 1fr;
        gap: 16px;
    }
    
    .sp-cta-box__btn--xl {
        padding: 18px 24px;
        font-size: 16px;
    }
}

/* ===== ACCESSIBILITY IMPROVEMENTS ===== */

/* Focus states for better keyboard navigation */
.sp-cta-box__input--date-range:focus-within,
.sp-cta-box__input:focus-within {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

.sp-cta-box__btn--primary:focus {
    outline: 2px solid var(--color-whatsapp);
    outline-offset: 2px;
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    .sp-cta-box {
        border: 2px solid var(--color-text);
    }
    
    .sp-cta-box__btn--primary {
        border: 2px solid var(--color-whatsapp);
    }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
    .sp-cta-box__input--date-range,
    .sp-cta-box__input,
    .sp-cta-box__btn--primary {
        transition: none;
    }
    
    .sp-cta-box--elevated {
        animation: none;
    }
}
/* ===== CALENDAR TITLE STYLING ===== */

.sp-cta-box__calendar-title {
    text-align: center;
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--color-border-light);
}

.sp-cta-box__calendar-title h3 {
    font-size: 20px;
    font-weight: 700;
    color: var(--color-text);
    margin: 0;
    letter-spacing: -0.02em;
    line-height: 1.2;
}

/* Mobile optimization for calendar title */
@media (max-width: 480px) {
    .sp-cta-box__calendar-title {
        margin-bottom: 16px;
        padding-bottom: 12px;
    }
    
    .sp-cta-box__calendar-title h3 {
        font-size: 18px;
        font-weight: 600;
    }
}

/* Tablet optimization */
@media (min-width: 481px) and (max-width: 768px) {
    .sp-cta-box__calendar-title h3 {
        font-size: 19px;
    }
}

/* RTL support for calendar title */
[dir="rtl"] .sp-cta-box__calendar-title h3 {
    font-family: inherit;
}
/* ===== FORCE CALENDAR TITLE VISIBILITY ===== */

/* Ensure calendar title is always visible and prominent */
.sp-cta-box .sp-cta-box__calendar-title {
    display: block !important;
    text-align: center !important;
    margin-bottom: 20px !important;
    padding-bottom: 16px !important;
    border-bottom: 1px solid #e5e7eb !important;
    background: transparent !important;
}

.sp-cta-box .sp-cta-box__calendar-title h3 {
    font-size: 20px !important;
    font-weight: 700 !important;
    color: #1f2937 !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1.2 !important;
    letter-spacing: -0.02em !important;
    text-transform: none !important;
}

/* Mobile specific styling with higher specificity */
@media (max-width: 480px) {
    .sp-cta-box .sp-cta-box__calendar-title {
        margin-bottom: 16px !important;
        padding-bottom: 12px !important;
    }
    
    .sp-cta-box .sp-cta-box__calendar-title h3 {
        font-size: 18px !important;
        font-weight: 600 !important;
    }
}
/* ===== CALENDAR WIDGET STYLING ===== */

.sp-cta-box__calendar-subtitle {
    font-size: 12px;
    color: #9ca3af;
    margin: 4px 0 0 0;
    font-weight: 400;
    font-style: italic;
}

.sp-calendar-widget {
    margin-bottom: 20px;
}

.sp-calendar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
    padding: 0 4px;
}

.sp-calendar-nav {
    background: none;
    border: none;
    padding: 8px;
    border-radius: 6px;
    cursor: pointer;
    color: var(--color-text-light);
    transition: all 0.2s ease;
}

.sp-calendar-nav:hover {
    background: var(--color-bg-alt);
    color: var(--color-primary);
}

.sp-calendar-month-name {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text);
}

.sp-calendar-grid {
    background: #fff;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--color-border-light);
}

.sp-calendar-weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    background: #f8fafc;
    border-bottom: 1px solid var(--color-border-light);
}

.sp-calendar-weekday {
    padding: 8px 4px;
    text-align: center;
    font-size: 11px;
    font-weight: 600;
    color: var(--color-text-light);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.sp-calendar-days {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
}

.sp-calendar-day {
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 500;
    border-right: 1px solid var(--color-border-light);
    border-bottom: 1px solid var(--color-border-light);
    cursor: pointer;
    transition: all 0.2s ease;
    position: relative;
}

.sp-calendar-day:nth-child(7n) {
    border-right: none;
}

.sp-calendar-day--other-month {
    color: #d1d5db;
    background: #fafafa;
}

.sp-calendar-day--today {
    background: var(--color-primary);
    color: white;
    font-weight: 600;
}

.sp-calendar-day--available {
    background: #f0fdf4;
    color: #16a34a;
}

.sp-calendar-day--available:hover {
    background: #dcfce7;
}

.sp-calendar-day--booked {
    background: #fef2f2;
    color: #dc2626;
    cursor: not-allowed;
}

.sp-calendar-day--selected {
    background: var(--color-primary);
    color: white;
}

.sp-calendar-legend {
    display: flex;
    justify-content: center;
    gap: 16px;
    margin-top: 12px;
    padding: 12px;
    background: #f8fafc;
    border-radius: 6px;
}

.sp-calendar-legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    color: var(--color-text-light);
}

.sp-calendar-legend-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

.sp-calendar-legend-dot--available {
    background: #16a34a;
}

.sp-calendar-legend-dot--booked {
    background: #dc2626;
}

.sp-calendar-legend-dot--today {
    background: var(--color-primary);
}

.sp-calendar-notice {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 12px;
    padding: 10px 12px;
    background: rgba(196,30,58,0.05);
    border-radius: 6px;
    font-size: 12px;
    color: var(--color-primary);
}

.sp-calendar-notice svg {
    flex-shrink: 0;
    color: var(--color-primary);
}

/* Bottom Price Display */
.sp-cta-box__bottom-price {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
    padding: 16px;
    background: #f8fafc;
    border-radius: 8px;
    border: 1px solid var(--color-border-light);
}

.sp-cta-box__price-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--color-text-light);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.sp-cta-box__price-amount-large {
    font-size: 24px;
    font-weight: 700;
    color: var(--color-primary);
}

.sp-cta-box__price-inquiry-large {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-primary);
    text-align: center;
    width: 100%;
}

/* Mobile Optimizations */
@media (max-width: 480px) {
    .sp-calendar-legend {
        gap: 12px;
        flex-wrap: wrap;
    }
    
    .sp-calendar-legend-item {
        font-size: 10px;
    }
    
    .sp-calendar-weekday {
        padding: 6px 2px;
        font-size: 10px;
    }
    
    .sp-calendar-day {
        font-size: 13px;
    }
    
    .sp-calendar-notice {
        font-size: 11px;
        padding: 8px 10px;
    }
    
    .sp-cta-box__bottom-price {
        padding: 12px;
        margin-bottom: 12px;
    }
    
    .sp-cta-box__price-amount-large {
        font-size: 20px;
    }
}

/* RTL Support */
[dir="rtl"] .sp-calendar-header {
    flex-direction: row-reverse;
}

[dir="rtl"] .sp-calendar-legend {
    flex-direction: row-reverse;
}

[dir="rtl"] .sp-calendar-notice {
    flex-direction: row-reverse;
}

/* ========================================
   MOBILE HOMEPAGE OPTIMIZATION - FINAL FIX
   ======================================== */

/* Hero Quick Jump - Simple anchor link */
.hero-quick-jump {
    text-align: center;
    margin-top: 16px;
}

.hero-quick-jump__link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    color: rgba(255,255,255,0.8);
    text-decoration: none;
    padding: 6px 12px;
    border-radius: var(--radius-sm);
    background: rgba(255,255,255,0.1);
    transition: var(--transition);
}

.hero-quick-jump__link:hover {
    color: #fff;
    background: rgba(255,255,255,0.15);
}

@media (min-width: 769px) {
    .hero-quick-jump {
        display: none;
    }
}

/* Mobile Section Ordering - NO CSS ORDER, DOM is correct */
/* Remove all previous order-based CSS - DOM order is now correct */

/* Mobile Category Sections - Standardized Pattern */
@media (max-width: 768px) {
    /* Section spacing standardization */
    .section--mobile-clean {
        padding: 20px 0;
    }
    
    /* Section headers - clean mobile pattern */
    .section-header--mobile-simple {
        margin-bottom: 12px;
    }
    
    .section-header--mobile-simple .section-header__title {
        font-size: 18px;
        font-weight: 700;
        margin: 0;
        text-align: left;
        line-height: 1.3;
    }
    
    /* Hide descriptions on mobile */
    .section-header__desc--mobile-hidden {
        display: none;
    }
    
    /* Hide desktop "Tümünü Gör" buttons */
    .section-header__link--desktop-only {
        display: none;
    }
    
    /* Property grid mobile - 2 cards only */
    .property-grid--mobile-limit .property-card:nth-child(n+3) {
        display: none;
    }
    
    .property-grid--4 {
        grid-template-columns: 1fr;
        gap: 12px;
    }
    
    /* Mobile "Tümünü Gör" button */
    .mobile-view-all {
        display: block;
        margin-top: 12px;
    }
    
    .btn--mobile-wide {
        width: 100%;
        min-height: 44px;
        padding: 12px 24px;
        font-size: 15px;
        font-weight: 600;
        justify-content: center;
        border-radius: var(--radius-lg);
        box-shadow: 0 2px 8px rgba(198,40,40,0.25);
    }
    
    .btn--mobile-wide:hover {
        transform: translateY(-1px);
        box-shadow: 0 4px 12px rgba(198,40,40,0.3);
    }
}

@media (min-width: 769px) {
    .mobile-view-all {
        display: none;
    }
}

/* Mobile Property Card Improvements */
@media (max-width: 768px) {
    .property-card__media {
        aspect-ratio: 16/10;
        border-radius: 16px;
        overflow: hidden;
    }
    
    .property-card__media img {
        object-fit: cover;
    }
    
    /* Placeholder improvements */
    .property-card__placeholder::before {
        font-size: 22px;
        opacity: 0.9;
    }
    
    .property-card {
        border-radius: 16px;
        box-shadow: 0 2px 8px rgba(15,23,42,0.06);
    }
    
    .property-card:hover {
        box-shadow: 0 8px 24px rgba(15,23,42,0.1);
    }
}

/* Mobile Footer Fix - Remove white strips */
@media (max-width: 768px) {
    .section--final-cta {
        margin-top: 0;
        margin-bottom: 0;
    }
    
    .site-footer {
        margin-top: 0;
    }
    
    /* Ensure no gaps between sections */
    .hp-why + .hp-list-your-home {
        margin-top: 0;
    }
    
    /* Fix final CTA to footer connection */
    .final-cta {
        margin-bottom: 0;
    }
    
    .final-cta__wave--bottom {
        bottom: -1px; /* Overlap by 1px to ensure no gap */
        background: var(--color-bg-dark);
    }
    
    /* Ensure footer connects seamlessly */
    .site-footer {
        position: relative;
        z-index: 2;
    }
}

/* Prevent horizontal scroll */
@media (max-width: 768px) {
    html, body {
        overflow-x: hidden;
    }
    
    .container {
        max-width: 100%;
        overflow-x: hidden;
    }
}

/* RTL Support */
[dir="rtl"] .section-header--mobile-simple .section-header__title {
    text-align: right;
}

[dir="rtl"] .hero-quick-jump__link {
    direction: rtl;
}

/* Ensure proper mobile section flow */
@media (max-width: 768px) {
    /* Hero always stays at top */
    .hp-hero {
        order: 1 !important;
        position: relative;
        z-index: 1;
    }
    
    /* Property type sections in correct order */
    .hp-bungalov { order: 2; }
    .hp-villa { order: 3; }
    .hp-tiny { order: 4; }
    .hp-glamping { order: 5; }
    .hp-themes { order: 6; }
    .hp-reviews { order: 7; }
    .hp-why { order: 8; }
    .hp-list-your-home { order: 9; }
    
    /* Only apply flexbox to body when needed */
    .home {
        display: flex;
        flex-direction: column;
    }
    
    .home > * {
        flex-shrink: 0;
    }
}
/* Additional Mobile Footer Gap Fix */
@media (max-width: 768px) {
    /* Remove any potential gaps around final CTA */
    .hp-list-your-home {
        margin-bottom: 0 !important;
    }
    
    .hp-list-your-home .section--final-cta {
        margin-bottom: 0 !important;
    }
    
    /* Ensure footer starts immediately after final CTA */
    .site-footer {
        margin-top: 0 !important;
        padding-top: 0;
    }
    
    /* Make sure the wave connects properly */
    .final-cta__wave--bottom {
        height: 41px; /* Slightly taller to ensure overlap */
        bottom: -1px;
        z-index: 1;
    }
    
    /* Remove any default section margins that might cause gaps */
    .section {
        margin-bottom: 0;
    }
    
    /* Specifically target the final CTA section */
    .section--final-cta {
        margin-bottom: 0 !important;
        padding-bottom: 0;
    }
    
    .final-cta {
        margin-bottom: 0 !important;
        padding-bottom: 120px; /* Keep internal padding but remove external margins */
    }
}