/* ============================================================
   GG Search — Main Stylesheet
   Glassmorphism, mobile-first, dark accents
   ============================================================ */

/* --- Custom Properties ------------------------------------ */
:root {
    --bg-primary: #ffffff;
    --glass-bg: rgba(255, 255, 255, 0.25);
    --glass-border: rgba(255, 255, 255, 0.35);
    --text-primary: #263238;
    --text-secondary: #78909c;
    --accent-blue: #1a237e;
    --accent-red: #d32f2f;
    --shadow-sm: 0 4px 20px rgba(0, 0, 0, 0.04);
    --shadow-md: 0 8px 32px rgba(0, 0, 0, 0.07);
    --shadow-lg: 0 16px 48px rgba(0, 0, 0, 0.1);
    --radius-sm: 12px;
    --radius-md: 20px;
    --radius-lg: 56px;
    --header-h: 64px;
    --safe-bottom: env(safe-area-inset-bottom, 0px);
}

/* --- Reset & Base ---------------------------------------- */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
    scroll-behavior: smooth;
    height: 100%;
}

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    background: var(--bg-primary);
    color: var(--text-primary);
    min-height: 100vh;
    min-height: -webkit-fill-available;
    height: 100%;
    line-height: 1.5;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

#app {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.main {
    flex: 1;
    display: flex;
    flex-direction: column;
}

/* Subtle noise texture overlay */
body::before {
    content: '';
    position: fixed;
    inset: 0;
    z-index: -3;
    background: var(--bg-primary);
}

/* GG backdrop — огромные чёрные заблюренные буквы */
.gg-backdrop-text {
    position: fixed;
    inset: 0;
    z-index: -2;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    overflow: hidden;
}

.gg-backdrop-text::after {
    content: 'GG';
    font-family: 'Playfair Display', Georgia, serif;
    font-weight: 700;
    font-size: min(60vw, 600px);
    line-height: 1;
    color: rgba(0, 0, 0, 0.15);
    user-select: none;
    letter-spacing: -0.05em;
    filter: blur(8px);
}

[data-theme="dark"] .gg-backdrop-text::after {
    color: rgba(255, 255, 255, 0.035);
}

/* --- Logo ------------------------------------------------- */
.logo-text {
    font-family: 'Playfair Display', Georgia, serif;
    font-weight: 700;
    user-select: none;
}

.logo-link {
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 4px;
    transition: opacity 0.3s;
}

.logo-link .logo-text {
    font-size: 28px;
    line-height: 1;
    background: linear-gradient(135deg, #1a237e, #0d47a1);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

[data-theme="dark"] .logo-link .logo-text {
    background: linear-gradient(135deg, #5c6bc0, #42a5f5);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* --- Header ---------------------------------------------- */
.header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: var(--header-h);
    z-index: 100;
    background: rgba(248, 249, 250, 0.85);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid rgba(0,0,0,0.04);
    transform: translateY(-100%);
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.header.visible {
    transform: translateY(0);
}

.header-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 16px;
    height: 100%;
    display: flex;
    align-items: center;
    gap: 12px;
}

.search-header-wrapper {
    flex: 1;
    max-width: 600px;
}

/* --- Search Box ------------------------------------------ */
.search-box {
    display: flex;
    align-items: center;
    background: rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid rgba(255, 255, 255, 0.4);
    border-radius: var(--radius-lg);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04), inset 0 1px 0 rgba(255, 255, 255, 0.6);
    padding: 0 20px;
    transition: box-shadow 0.3s, border-color 0.3s, background 0.3s;
    width: 100%;
}

.search-box:focus-within {
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.06), inset 0 1px 0 rgba(255, 255, 255, 0.6);
    border-color: rgba(255, 255, 255, 0.6);
    background: rgba(255, 255, 255, 0.3);
}

/* Glass glow when voice listening */
.search-box--listening {
    border-color: rgba(211, 47, 47, 0.35) !important;
    box-shadow: 0 0 24px rgba(211, 47, 47, 0.12), 0 8px 32px rgba(0, 0, 0, 0.06), inset 0 1px 0 rgba(255, 255, 255, 0.6) !important;
    background: rgba(255, 255, 255, 0.25) !important;
}

.search-box--compact {
    padding: 0 16px;
    height: 44px;
}

.search-box--compact .search-input {
    font-size: 0.9rem;
}

.search-icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    color: var(--text-secondary);
    opacity: 0.6;
}

.search-input {
    flex: 1;
    border: none;
    background: transparent;
    padding: 16px 12px;
    font-size: 1rem;
    font-family: inherit;
    color: var(--text-primary);
    outline: none;
    min-height: 44px;
}

.search-input::placeholder {
    color: var(--text-secondary);
    opacity: 0.6;
}

.voice-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    flex-shrink: 0;
    background: transparent;
    border: none;
    cursor: pointer;
    color: var(--text-secondary);
    border-radius: 50%;
    transition: background 0.2s, color 0.2s;
    position: relative;
}

.voice-btn svg {
    width: 22px;
    height: 22px;
}

.voice-btn:hover {
    background: rgba(26, 35, 126, 0.06);
    color: var(--accent-blue);
}

.voice-btn:focus-visible {
    outline: 2px solid var(--accent-blue);
    outline-offset: 2px;
}

.voice-btn--listening {
    color: #d32f2f;
    background: rgba(211, 47, 47, 0.08);
    animation: pulseMic 1s ease-in-out infinite;
}

.voice-btn--listening:hover {
    color: #d32f2f;
    background: rgba(211, 47, 47, 0.14);
}

@keyframes pulseMic {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(1.12); }
}

.voice-btn--processing .voice-btn-spinner,
.voice-btn--requesting .voice-btn-spinner {
    display: block;
}

.voice-btn--requesting svg {
    display: none;
}

.voice-btn-spinner {
    display: none;
    width: 20px;
    height: 20px;
    border: 2px solid rgba(0,0,0,0.08);
    border-top-color: var(--accent-blue);
    border-radius: 50%;
    animation: spin 0.6s linear infinite;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

.voice-btn--listening .voice-btn-spinner,
.voice-btn--processing svg {
    display: none;
}

.voice-btn--listening svg {
    display: block;
    animation: micBounce 0.8s ease-in-out infinite;
}

@keyframes micBounce {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(1.2); }
}

.voice-btn--listening .voice-btn-spinner {
    display: none;
}

/* --- Voice Waveform -------------------------------------- */
.voice-waveform {
    display: none;
    align-items: center;
    justify-content: center;
    gap: 5px;
    height: 32px;
    margin: 4px 0 0;
}

.voice-waveform.active {
    display: flex;
}

.voice-waveform span {
    width: 4px;
    height: 16px;
    background: var(--accent-red);
    border-radius: 2px;
    animation: waveform 1s ease-in-out infinite;
}

.voice-waveform span:nth-child(1) { animation-delay: 0s; }
.voice-waveform span:nth-child(2) { animation-delay: 0.15s; }
.voice-waveform span:nth-child(3) { animation-delay: 0.3s; }
.voice-waveform span:nth-child(4) { animation-delay: 0.45s; }
.voice-waveform span:nth-child(5) { animation-delay: 0.6s; }

@keyframes waveform {
    0%, 100% { transform: scaleY(0.4); opacity: 0.4; }
    25% { transform: scaleY(1.2); opacity: 1; }
    50% { transform: scaleY(0.6); opacity: 0.7; }
    75% { transform: scaleY(1.5); opacity: 1; }
}

/* --- Hero Section ---------------------------------------- */
.hero {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1;
    padding: 40px 20px;
    transition: flex 0.5s ease, padding 0.5s ease;
}

#aiSearchSection {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    width: 100%;
}

.hero-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 32px;
    width: 100%;
    max-width: 560px;
    transition: transform 0.5s ease, gap 0.5s ease;
}

.hero-tagline {
    font-size: 1.05rem;
    font-weight: 500;
    color: var(--text-secondary);
    text-align: center;
    margin: 0;
    line-height: 1.4;
}

/* Search mode tabs (hero) */
.search-mode-tabs {
    display: flex;
    gap: 4px;
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 3px;
    margin-bottom: 4px;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
.search-mode-tab {
    padding: 8px 20px;
    border: none;
    background: transparent;
    border-radius: 9px;
    font-size: .9rem;
    font-weight: 500;
    cursor: pointer;
    color: var(--text-secondary);
    transition: all .2s;
    white-space: nowrap;
}
.search-mode-tab:hover {
    background: var(--hover-bg);
    color: var(--text);
}
.search-mode-tab.active {
    background: rgba(26,35,126,0.12);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    color: #1a237e;
    font-weight: 600;
}
[data-theme="dark"] .search-mode-tab.active {
    background: rgba(92,107,192,0.2);
    color: #5c6bc0;
}

/* Header mode tabs */
.header-mode-tabs {
    display: flex;
    gap: 2px;
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 2px;
    flex-shrink: 0;
    box-shadow: 0 1px 6px rgba(0,0,0,0.06);
}
.header-mode-tab {
    padding: 5px 12px;
    border: none;
    background: transparent;
    border-radius: 6px;
    font-size: .8rem;
    font-weight: 500;
    cursor: pointer;
    color: var(--text-secondary);
    transition: all .2s;
    white-space: nowrap;
}
.header-mode-tab:hover {
    background: var(--hover-bg);
    color: var(--text);
}
.header-mode-tab.active {
    background: rgba(26,35,126,0.12);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    color: #1a237e;
    font-weight: 600;
}
[data-theme="dark"] .header-mode-tab.active {
    background: rgba(92,107,192,0.2);
    color: #5c6bc0;
}

.hero--shrunk .hero-tagline {
    display: none;
}

.hero--shrunk .hero-content {
    gap: 0;
}

.hero--shrunk {
    flex: 0;
    padding: 0;
}

.hero--shrunk .hero-rotating {
    display: none;
}

.hero--shrunk .hero-theme-toggle,
.hero--shrunk .search-mode-tabs {
    display: none;
}

.hero--shrunk #aiSearchSection,
.hero--shrunk #classicSearchSection {
    display: none;
}

/* Rotating phrases */
.hero-rotating {
    height: 1.5em;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    margin-top: 4px;
}

.rotating-word {
    position: absolute;
    font-size: 1rem;
    font-weight: 500;
    color: var(--text-secondary);
    opacity: 0;
    transform: translateY(12px);
    animation: wordFade 8s ease-in-out infinite;
    white-space: nowrap;
}

.rotating-word:nth-child(1) { animation-delay: 0s; }
.rotating-word:nth-child(2) { animation-delay: 2s; }
.rotating-word:nth-child(3) { animation-delay: 4s; }
.rotating-word:nth-child(4) { animation-delay: 6s; }

@keyframes wordFade {
    0%   { opacity: 0; transform: translateY(12px); }
    8%   { opacity: 1; transform: translateY(0); }
    20%  { opacity: 1; transform: translateY(0); }
    28%  { opacity: 0; transform: translateY(-12px); }
    100% { opacity: 0; transform: translateY(-12px); }
}

[data-theme="dark"] .rotating-word {
    color: var(--text-secondary);
}

/* --- Results Section ------------------------------------- */
.results {
    max-width: 1200px;
    margin: 0 auto;
    padding: calc(var(--header-h) + 12px) 16px calc(40px + var(--safe-bottom));
}

/* --- Results Grid / Cards ---------------------------------- */
.results-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}

.card {
    position: relative;
    display: flex;
    background: rgba(255,255,255,0.7);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,0.25);
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: box-shadow 0.3s, transform 0.2s;
    cursor: pointer;
}

.card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.card:active {
    transform: translateY(0);
}

.card-img-wrap {
    width: 140px;
    min-width: 140px;
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
}

.card-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.card-img-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0,0,0,0.03);
    color: #ccc;
}

[data-theme="dark"] .card-img-placeholder {
    background: rgba(255,255,255,0.03);
}

.card-body {
    flex: 1;
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.card-title {
    font-weight: 600;
    font-size: 1rem;
    color: var(--text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.card-district {
    font-size: 0.8rem;
    color: var(--text-secondary);
    opacity: 0.75;
}

.card-address {
    font-size: 0.85rem;
    color: var(--text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.card-meta {
    display: flex;
    gap: 8px;
    margin-top: 4px;
    flex-wrap: wrap;
}

.card-meta-item {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.card-meta-item svg {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}

.card-price {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--accent-blue);
    margin-top: auto;
    padding-top: 4px;
}

.card-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 6px;
    flex-wrap: wrap;
}

.card-share-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    background: transparent;
    border: 1px solid rgba(0,0,0,0.06);
    border-radius: 16px;
    font-family: inherit;
    font-size: 0.75rem;
    cursor: pointer;
    color: var(--text-secondary);
    transition: background 0.2s;
}

.card-share-btn:hover {
    background: rgba(0,0,0,0.04);
}

.card-phone {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--accent-blue);
}

.card-phone svg {
    width: 14px;
    height: 14px;
}

.fav-btn {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 32px;
    height: 32px;
    border: none;
    background: rgba(255,255,255,0.85);
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #c62828;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    transition: transform 0.2s;
}

.fav-btn:hover {
    transform: scale(1.1);
}

.fav-btn svg {
    width: 16px;
    height: 16px;
}

/* Card selection checkbox */
.card-checkbox {
    position: absolute;
    top: 8px;
    left: 8px;
    z-index: 5;
    width: 22px;
    height: 22px;
    margin: 0;
    cursor: pointer;
    accent-color: var(--accent-blue);
    opacity: 0;
    transition: opacity 0.2s;
}
.card:hover .card-checkbox,
.card-checkbox:checked {
    opacity: 1;
}
@media (hover: none) {
    .card-checkbox {
        opacity: 1;
    }
}

/* Collection remove button on card */
.card-remove-btn {
    position: absolute;
    top: 8px;
    right: 8px;
    z-index: 5;
    width: 22px;
    height: 22px;
    border: none;
    background: rgba(198,40,40,0.85);
    color: #fff;
    border-radius: 50%;
    cursor: pointer;
    font-size: .7rem;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.2s;
}
.card:hover .card-remove-btn {
    opacity: 1;
}
@media (hover: none) {
    .card-remove-btn {
        opacity: 1;
    }
}
.card--selected {
    outline: 2px solid var(--accent-blue);
    outline-offset: -2px;
    border-radius: 12px;
}

/* Dark theme cards */
[data-theme="dark"] .card {
    background: rgba(30, 30, 30, 0.7);
    border-color: rgba(255,255,255,0.06);
}

[data-theme="dark"] .card-price {
    color: var(--accent-blue);
}

[data-theme="dark"] .card-share-btn {
    border-color: rgba(255,255,255,0.08);
    color: var(--text-secondary);
}

[data-theme="dark"] .fav-btn {
    background: rgba(0,0,0,0.6);
}

/* --- Results states -------------------------------------- */
.results-loader {
    display: flex;
    justify-content: center;
    padding: 40px 0;
}

.results-empty {
    text-align: center;
    padding: 60px 20px;
    color: var(--text-secondary);
}

.error-state, .offline-state {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 60vh;
    padding: 20px;
}

.error-state-content, .offline-state-content {
    text-align: center;
    max-width: 360px;
    color: var(--text-secondary);
}

.error-state-content h2, .offline-state-content h2 {
    font-size: 1.3rem;
    margin: 16px 0 8px;
    color: var(--text-primary);
}

.error-state-content svg, .offline-state-content svg {
    color: var(--text-secondary);
    opacity: 0.4;
}

.btn {
    display: inline-block;
    margin-top: 20px;
    padding: 12px 32px;
    background: var(--accent-blue);
    color: #fff;
    border: none;
    border-radius: var(--radius-lg);
    font-family: inherit;
    font-size: 0.95rem;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.2s, transform 0.1s;
    min-height: 44px;
}

.btn:hover {
    background: #283593;
}

.btn:active {
    transform: scale(0.97);
}

/* --- Spinner --------------------------------------------- */
.spinner {
    width: 32px;
    height: 32px;
    border: 3px solid rgba(26, 35, 126, 0.12);
    border-top-color: var(--accent-blue);
    border-radius: 50%;
    animation: spin 0.7s linear infinite;
}

.spinner--large {
    width: 48px;
    height: 48px;
    border-width: 4px;
}

.page-loader {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 200;
    background: var(--bg-primary);
}

/* --- Modal ----------------------------------------------- */
.copy-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: transparent;
    border: 1px solid rgba(26, 35, 126, 0.2);
    border-radius: var(--radius-lg);
    font-family: inherit;
    font-size: 0.85rem;
    cursor: pointer;
    color: var(--accent-blue);
    transition: background 0.2s;
    min-height: 36px;
}

.copy-btn:hover {
    background: rgba(26, 35, 126, 0.06);
}

.copy-btn svg {
    width: 16px;
    height: 16px;
}

.toast {
    position: fixed;
    bottom: calc(20px + var(--safe-bottom));
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0,0,0,0.8);
    color: #fff;
    padding: 10px 24px;
    border-radius: var(--radius-lg);
    font-size: 0.9rem;
    z-index: 400;
    animation: toastIn 0.3s ease;
    pointer-events: none;
}

@keyframes toastIn {
    from { opacity: 0; transform: translateX(-50%) translateY(20px); }
    to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}

/* --- Utilities ------------------------------------------- */
.hidden {
    display: none !important;
}

/* --- Tablet ---------------------------------------------- */
@media (min-width: 768px) {
    .results-grid {
        grid-template-columns: repeat(2, 1fr);
    }

}

/* --- Desktop --------------------------------------------- */
@media (min-width: 1024px) {
    .results-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .search-box {
        max-width: 600px;
    }

    .card .card-img-wrap .card-img,
    .card .card-img-wrap .card-img-placeholder {
        width: 160px;
        min-width: 160px;
    }

}

/* --- Reels Modal ----------------------------------------- */
/* --- Map ------------------------------------------------- */
.map-container {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: min(1200px, calc(100vw - 32px));
    height: min(800px, calc(100vh - 100px));
    overflow: hidden;
    z-index: 150;
    border-radius: 20px;
    box-shadow: 0 16px 48px rgba(0,0,0,0.25);
}

.map-container.hidden {
    display: none !important;
}

.map-close-btn {
    position: absolute;
    top: 12px;
    right: 12px;
    z-index: 1000;
    width: 36px;
    height: 36px;
    border: none;
    background: rgba(255,255,255,0.9);
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #333;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}

.map-close-btn:hover { background: #fff; }

.map-fs-btn {
    position: absolute;
    top: 12px;
    right: 56px;
    z-index: 1000;
    width: 36px;
    height: 36px;
    border: none;
    background: rgba(255,255,255,0.9);
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #333;
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.map-fs-btn:hover { background: #fff; }

[data-theme="dark"] .map-close-btn,
[data-theme="dark"] .map-fs-btn { background: rgba(50,50,50,0.9); color: #fff; }

.map-container:-webkit-full-screen { width:100vw; height:100vh; border-radius:0; }
.map-container:fullscreen { width:100vw; height:100vh; border-radius:0; }

.map-backdrop {
    position: fixed;
    inset: 0;
    z-index: 140;
    background: rgba(0,0,0,0.45);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.map-backdrop.hidden { display: none !important; }

#mapLoadingMsg { background: rgba(255,255,255,0.85); }
[data-theme="dark"] #mapLoadingMsg { background: rgba(18,18,18,0.85); color: #999; }

.toggle-view-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    background: transparent;
    border: 1px solid rgba(0,0,0,0.08);
    border-radius: 20px;
    font-family: inherit;
    font-size: 0.85rem;
    cursor: pointer;
    color: var(--text-secondary);
    transition: all 0.2s;
    white-space: nowrap;
}

.toggle-view-btn:hover {
    border-color: var(--accent-blue);
    color: var(--accent-blue);
}

.toggle-view-btn.active {
    background: var(--accent-blue);
    border-color: var(--accent-blue);
    color: #fff;
}

[data-theme="dark"] .toggle-view-btn {
    border-color: rgba(255,255,255,0.1);
    color: var(--text-secondary);
}

[data-theme="dark"] .toggle-view-btn:hover {
    border-color: var(--accent-blue);
    color: var(--accent-blue);
}

/* --- Reels Modal ----------------------------------------- */
.reels-overlay {
    position: fixed;
    inset: 0;
    z-index: 200;
    background: rgba(0,0,0,0.45);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    display: flex;
    align-items: center;
    justify-content: center;
    overscroll-behavior: contain;
}

.reels-overlay.hidden {
    display: none !important;
}

.reels-modal {
    width: 100%;
    height: 100%;
    background: #fff;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    position: relative;
    padding-bottom: env(safe-area-inset-bottom, 0px);
}

[data-theme="dark"] .reels-modal {
    background: #1a1a1a;
}

/* --- Reels Header (overlaid on gallery) ------------------ */
.reels-header {
    position: absolute;
    top: 0; left: 0; right: 0;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    padding-top: calc(12px + env(safe-area-inset-top, 0px));
    background: linear-gradient(to bottom, rgba(0,0,0,0.5), transparent);
    pointer-events: none;
}

.reels-header > * {
    pointer-events: auto;
}

.reels-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: none;
    background: rgba(255,255,255,0.2);
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
}

.reels-close svg {
    width: 20px;
    height: 20px;
}

.reels-counter {
    color: #fff;
    font-size: 0.9rem;
    font-weight: 500;
    font-family: 'Inter', sans-serif;
    text-shadow: 0 1px 4px rgba(0,0,0,0.5);
}

/* --- Reels Viewport (slide container) ------------------- */
.reels-viewport {
    flex: 1;
    position: relative;
    overflow: hidden;
}

.reels-slide {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    background: #fff;
}

[data-theme="dark"] .reels-slide {
    background: #1a1a1a;
}

/* --- Gallery -------------------------------------------- */
.reels-gallery {
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
    background: #111;
    aspect-ratio: 16 / 11;
    max-height: 55vh;
}

.reels-gallery-track {
    display: flex;
    height: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.reels-gallery-track::-webkit-scrollbar {
    display: none;
}

.reels-gallery-slide {
    flex: 0 0 100%;
    height: 100%;
    scroll-snap-align: start;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.reels-gallery-slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.gallery-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 5;
    width: 36px;
    height: 36px;
    border: none;
    background: rgba(0,0,0,0.25);
    border-radius: 50%;
    color: #fff;
    font-size: 1.3rem;
    cursor: pointer;
    display: none;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

.gallery-arrow:hover {
    background: rgba(0,0,0,0.45);
}

.gallery-arrow--prev { left: 8px; }
.gallery-arrow--next { right: 8px; }

@media (min-width: 768px) {
    .gallery-arrow {
        display: flex;
    }
}

.reels-gallery-dots {
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 5px;
    z-index: 2;
}

.reels-gallery-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    border: none;
    background: rgba(255,255,255,0.45);
    cursor: pointer;
    padding: 0;
    transition: background 0.2s, width 0.2s;
}

.reels-gallery-dot.active {
    background: #fff;
    width: 18px;
    border-radius: 3px;
}

.reels-placeholder {
    display: flex;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    width: 100%;
    aspect-ratio: 16 / 11;
    max-height: 55vh;
    color: #666;
}

/* --- Details (scrollable) ------------------------------- */
.reels-details {
    flex: 1;
    padding: 16px 20px;
    padding-bottom: calc(40px + env(safe-area-inset-bottom, 20px));
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.reels-details-price {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--accent-blue);
    margin-bottom: 12px;
}

[data-theme="dark"] .reels-details-price {
    color: #7c8cd1;
}

.reels-details-table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 16px;
}

.reels-details-table tr {
    border-bottom: 1px solid rgba(0,0,0,0.04);
}

[data-theme="dark"] .reels-details-table tr {
    border-bottom-color: rgba(255,255,255,0.06);
}

.reels-details-table td {
    padding: 8px 0;
    font-size: 0.9rem;
}

.reels-details-table td:first-child {
    color: var(--text-secondary);
    width: 40%;
    vertical-align: top;
}

.reels-details-table td:last-child {
    color: var(--text-primary);
    font-weight: 500;
}

.reels-details-contact {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    background: rgba(0,0,0,0.03);
    border-radius: 12px;
    border: 1px solid rgba(0,0,0,0.04);
}

[data-theme="dark"] .reels-details-contact {
    background: rgba(255,255,255,0.05);
    border-color: rgba(255,255,255,0.06);
}

.reels-contact-name {
    font-weight: 500;
    color: var(--text-primary);
    width: 100%;
    font-size: 0.9rem;
}

.reels-contact-phone {
    font-size: 1rem;
    font-weight: 600;
    color: var(--accent-blue);
    text-decoration: none;
}

[data-theme="dark"] .reels-contact-phone {
    color: #7c8cd1;
}

.reels-copy-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    background: transparent;
    border: 1px solid rgba(26, 35, 126, 0.2);
    border-radius: 20px;
    font-family: inherit;
    font-size: 0.8rem;
    cursor: pointer;
    color: var(--accent-blue);
    transition: background 0.2s;
}

.reels-copy-btn:hover {
    background: rgba(26, 35, 126, 0.06);
}

.reels-copy-btn svg {
    width: 14px;
    height: 14px;
}

[data-theme="dark"] .reels-copy-btn {
    border-color: rgba(124, 140, 209, 0.3);
    color: #7c8cd1;
}

/* --- Desktop modal --------------------------------------- */
@media (min-width: 768px) {
    .reels-modal {
        width: 100%;
        max-width: 560px;
        max-height: 90vh;
        border-radius: 20px;
        box-shadow: 0 16px 48px rgba(0,0,0,0.25);
    }
}

/* --- Mobile compact details ------------------------------ */
@media (max-width: 500px) {
    .reels-details {
        padding: 10px 14px;
        padding-bottom: calc(20px + env(safe-area-inset-bottom, 10px));
    }
    .reels-details-price {
        font-size: 1.1rem;
        margin-bottom: 8px;
    }
    .reels-details-table td {
        padding: 5px 0;
        font-size: 0.78rem;
    }
    .reels-details-table {
        margin-bottom: 10px;
    }
    .reels-details-contact {
        padding: 8px 10px;
        gap: 6px;
    }
    .reels-contact-name {
        font-size: 0.8rem;
    }
    .reels-contact-phone {
        font-size: 0.85rem;
    }
    .reels-copy-btn {
        padding: 4px 10px;
        font-size: 0.72rem;
    }
    .reels-copy-btn svg {
        width: 12px;
        height: 12px;
    }
    .reels-share-btn {
        margin-top: 10px;
        margin-bottom: 4px;
        padding: 10px;
        font-size: 0.82rem;
    }
    .reels-share-btn svg {
        width: 15px;
        height: 15px;
    }
    .reels-gallery {
        max-height: 45vh;
    }
    /* Floating button compact on mobile */
    .select-floating-btn {
        bottom: 16px;
        padding: 10px 18px;
        font-size: .85rem;
    }
    .hero-nav-row .coll-badge,
    .hero-nav-row .fav-badge-icon {
        display: none !important;
    }
}

/* --- Photo Viewer (full-screen lightbox) ----------------- */
.photo-viewer {
    position: fixed;
    inset: 0;
    z-index: 300;
    background: #000;
    display: flex;
    flex-direction: column;
}

.photo-viewer.hidden {
    display: none !important;
}

.photo-viewer-close {
    position: absolute;
    top: calc(12px + env(safe-area-inset-top, 0px));
    right: 16px;
    z-index: 10;
    width: 40px;
    height: 40px;
    border: none;
    background: rgba(255,255,255,0.15);
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

.photo-viewer-close svg {
    width: 24px;
    height: 24px;
}

.photo-viewer-track {
    flex: 1;
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.photo-viewer-track::-webkit-scrollbar {
    display: none;
}

.photo-viewer-track .pv-slide {
    flex: 0 0 100%;
    height: 100%;
    scroll-snap-align: start;
    display: flex;
    align-items: center;
    justify-content: center;
}

.photo-viewer-track .pv-slide img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.photo-viewer-dots {
    position: absolute;
    bottom: calc(16px + env(safe-area-inset-bottom, 0px));
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 8px;
    z-index: 2;
}

.pv-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 44px;
    height: 44px;
    border: none;
    background: rgba(255,255,255,0.1);
    border-radius: 50%;
    color: #fff;
    font-size: 1.8rem;
    cursor: pointer;
    display: none;
    align-items: center;
    justify-content: center;
    line-height: 1;
    transition: background 0.2s;
}

.pv-arrow:hover {
    background: rgba(255,255,255,0.2);
}

.pv-arrow--prev { left: 16px; }
.pv-arrow--next { right: 16px; }

@media (min-width: 768px) {
    .pv-arrow {
        display: flex;
    }
}

.photo-viewer-dots .pv-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    border: none;
    background: rgba(255,255,255,0.4);
    cursor: pointer;
    padding: 0;
    transition: background 0.2s;
}

.photo-viewer-dots .pv-dot.active {
    background: #fff;
}

.reels-loader {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
}

/* --- Theme toggle button ---------------------------------- */
.theme-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    flex-shrink: 0;
    background: transparent;
    border: 1px solid rgba(0,0,0,0.06);
    border-radius: 50%;
    cursor: pointer;
    color: var(--text-secondary);
    transition: background 0.2s, color 0.2s, border-color 0.2s;
    position: relative;
}

.theme-toggle svg {
    width: 20px;
    height: 20px;
}

.theme-toggle:hover {
    background: rgba(26, 35, 126, 0.06);
    color: var(--accent-blue);
    border-color: rgba(26, 35, 126, 0.15);
}

.theme-toggle:focus-visible {
    outline: 2px solid var(--accent-blue);
    outline-offset: 2px;
}

.theme-toggle .icon-sun {
    display: none;
}
.theme-toggle .icon-moon {
    display: block;
}

[data-theme="dark"] .theme-toggle .icon-sun {
    display: block;
}
[data-theme="dark"] .theme-toggle .icon-moon {
    display: none;
}

/* --- Dark theme (manual, data-theme attr) --------------- */
[data-theme="dark"] {
    --bg-primary: #0f0f0f;
    --glass-bg: rgba(30, 30, 30, 0.3);
    --glass-border: rgba(255, 255, 255, 0.06);
    --text-primary: #e0e0e0;
    --text-secondary: #888888;
    --accent-blue: #7c8cd1;
    --shadow-sm: 0 4px 20px rgba(0, 0, 0, 0.3);
    --shadow-md: 0 8px 32px rgba(0, 0, 0, 0.4);
    --shadow-lg: 0 16px 48px rgba(0, 0, 0, 0.5);
}

[data-theme="dark"] .search-box {
    background: rgba(30, 30, 30, 0.25);
    border-color: rgba(255, 255, 255, 0.08);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

[data-theme="dark"] .search-box:focus-within {
    border-color: rgba(255, 255, 255, 0.15);
    background: rgba(30, 30, 30, 0.35);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

[data-theme="dark"] .search-box--listening {
    border-color: rgba(211, 47, 47, 0.4) !important;
    box-shadow: 0 0 24px rgba(211, 47, 47, 0.15), 0 8px 32px rgba(0, 0, 0, 0.3) !important;
}

[data-theme="dark"] .card {
    background: rgba(30, 30, 30, 0.7);
}

[data-theme="dark"] .header {
    background: rgba(18, 18, 18, 0.85);
    border-bottom-color: rgba(255,255,255,0.04);
}

[data-theme="dark"] .theme-toggle {
    border-color: rgba(255,255,255,0.08);
    color: var(--text-secondary);
}

[data-theme="dark"] .theme-toggle:hover {
    background: rgba(92, 107, 192, 0.1);
    color: var(--accent-blue);
    border-color: rgba(92, 107, 192, 0.2);
}

[data-theme="dark"] .btn {
    background: var(--accent-blue);
}
[data-theme="dark"] .btn:hover {
    background: #7986cb;
}

.load-more {
    display: block;
    margin: 20px auto 0;
    padding: 12px 32px;
    background: transparent;
    border: 2px solid var(--accent-blue);
    border-radius: var(--radius-lg);
    font-family: inherit;
    font-size: 0.95rem;
    font-weight: 500;
    cursor: pointer;
    color: var(--accent-blue);
    transition: background 0.2s, color 0.2s;
}

.load-more:hover {
    background: var(--accent-blue);
    color: #fff;
}

.load-more.hidden {
    display: none !important;
}

[data-theme="dark"] .load-more {
    color: var(--accent-blue);
    border-color: var(--accent-blue);
}

[data-theme="dark"] .load-more:hover {
    background: var(--accent-blue);
    color: #fff;
}

[data-theme="dark"] .copy-btn {
    border-color: rgba(92, 107, 192, 0.2);
    color: var(--accent-blue);
}

[data-theme="dark"] .card-price {
    color: var(--accent-blue);
}

/* --- Card image wrapper (for fav button overlay) ----------- */
.card .card-img-wrap .card-img-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #e3f2fd, #f3e5f5);
    color: var(--text-secondary);
}

[data-theme="dark"] .card .card-img-wrap .card-img-placeholder {
    background: rgba(30,30,30,0.5);
    color: #444;
}

/* --- Favorite button (heart) ------------------------------ */
.fav-btn {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 36px;
    height: 36px;
    border: none;
    border-radius: 50%;
    background: rgba(0,0,0,0.35);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .2s;
    z-index: 2;
    padding: 0;
}

.fav-btn:hover {
    background: rgba(0,0,0,0.5);
    transform: scale(1.1);
}

.fav-btn svg {
    width: 18px;
    height: 18px;
}

.fav-btn--active {
    color: #ff4081;
    background: rgba(255,64,129,0.2);
}

.fav-btn--active:hover {
    background: rgba(255,64,129,0.3);
}

/* --- Favorites filter button in header -------------------- */
.results-header {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.results-header-row {
    display: flex;
    align-items: baseline;
    gap: 8px;
}
.results-header-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.res-action-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 12px;
    border: 1px solid rgba(0,0,0,0.08);
    border-radius: 8px;
    background: transparent;
    color: var(--text-secondary);
    font-size: .82rem;
    font-family: inherit;
    cursor: pointer;
    transition: all .2s;
    white-space: nowrap;
}
.res-action-btn:hover {
    background: rgba(0,0,0,0.04);
    border-color: rgba(0,0,0,0.15);
    color: var(--text-primary);
}
[data-theme="dark"] .res-action-btn {
    border-color: rgba(255,255,255,0.08);
    color: #888;
}
[data-theme="dark"] .res-action-btn:hover {
    background: rgba(255,255,255,0.06);
    border-color: rgba(255,255,255,0.15);
    color: #e0e0e0;
}
.fav-filter-btn {
    position: relative;
    width: 36px;
    height: 36px;
    border: 1px solid rgba(0,0,0,0.08);
    border-radius: 50%;
    background: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .2s;
    flex-shrink: 0;
    padding: 0;
    margin-left: auto;
}

.fav-filter-btn:hover {
    background: rgba(0,0,0,0.04);
    color: #ff4081;
    border-color: rgba(255,64,129,0.2);
}

[data-theme="dark"] .fav-filter-btn {
    border-color: rgba(255,255,255,0.08);
}

[data-theme="dark"] .fav-filter-btn:hover {
    background: rgba(255,64,129,0.08);
    border-color: rgba(255,64,129,0.2);
}

.fav-badge {
    position: absolute;
    top: -4px;
    right: -4px;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    background: #ff4081;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    line-height: 16px;
    text-align: center;
    border-radius: 10px;
    pointer-events: none;
}

/* --- Card share button ------------------------------------ */
.card-share-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    border: none;
    background: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    font-size: .78rem;
    font-family: inherit;
    padding: 4px 8px;
    border-radius: 6px;
    transition: all .2s;
}

.card-share-btn:hover {
    background: rgba(0,0,0,0.04);
    color: var(--accent-blue);
}

.card-share-btn svg {
    width: 14px;
    height: 14px;
}

[data-theme="dark"] .card-share-btn:hover {
    background: rgba(255,255,255,0.06);
}

.card-actions {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-top: 8px;
}

.card-phone {
    font-size: .82rem;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: 4px;
    flex: 1;
}

.card-phone svg {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}

/* --- Share button in reels -------------------------------- */
.reels-share-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    margin-top: 16px;
    margin-bottom: 8px;
    padding: 14px;
    border: 1px solid rgba(0,0,0,0.12);
    border-radius: 12px;
    background: rgba(0,0,0,0.03);
    color: var(--text-primary);
    font-size: .95rem;
    font-family: inherit;
    font-weight: 500;
    cursor: pointer;
    transition: all .25s;
}

.reels-share-btn:hover {
    background: rgba(0,0,0,0.06);
    border-color: var(--accent-blue);
    color: var(--accent-blue);
}

[data-theme="dark"] .reels-share-btn {
    border-color: rgba(255,255,255,0.15);
    background: rgba(255,255,255,0.05);
    color: #fff;
}

[data-theme="dark"] .reels-share-btn:hover {
    background: rgba(255,255,255,0.1);
    border-color: rgba(255,255,255,0.25);
    color: #fff;
}

.reels-share-btn svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

/* --- Add-to-collection button in reels -------------------- */
.reels-coll-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    margin-top: 8px;
    margin-bottom: 8px;
    padding: 12px;
    border: 1px solid rgba(0,0,0,0.12);
    border-radius: 12px;
    background: rgba(26,35,126,0.04);
    color: var(--accent-blue);
    font-size: .9rem;
    font-family: inherit;
    font-weight: 500;
    cursor: pointer;
    transition: all .25s;
}
.reels-coll-btn:hover {
    background: rgba(26,35,126,0.1);
    border-color: var(--accent-blue);
}
[data-theme="dark"] .reels-coll-btn {
    border-color: rgba(255,255,255,0.15);
    background: rgba(124,140,209,0.06);
    color: #7c8cd1;
}
[data-theme="dark"] .reels-coll-btn:hover {
    background: rgba(124,140,209,0.12);
    border-color: #7c8cd1;
}
.reels-coll-btn svg {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

/* Mobile compact */
@media (max-width: 500px) {
    .reels-coll-btn {
        margin-top: 6px;
        margin-bottom: 4px;
        padding: 10px;
        font-size: .82rem;
    }
    .reels-coll-btn svg {
        width: 14px;
        height: 14px;
    }
}

/* --- Share modal ------------------------------------------- */
.share-overlay {
    position: fixed;
    inset: 0;
    z-index: 260;
    background: rgba(0,0,0,0.4);
    backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    overscroll-behavior: contain;
}
.share-overlay.hidden { display: none !important; }
.share-modal {
    width: 90%;
    max-width: 440px;
    max-height: 80vh;
    background: #fff;
    border-radius: 16px;
    display: flex;
    flex-direction: column;
    box-shadow: 0 12px 40px rgba(0,0,0,0.2);
}
[data-theme="dark"] .share-modal {
    background: #1e1e1e;
    border: 1px solid rgba(255,255,255,0.08);
}
.share-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid rgba(0,0,0,0.06);
}
[data-theme="dark"] .share-header { border-color: rgba(255,255,255,0.06); }
.share-title { font-size: 1rem; font-weight: 600; }
.share-close {
    width: 28px; height: 28px; border: none; background: rgba(0,0,0,0.05);
    border-radius: 50%; cursor: pointer; font-size: .9rem;
    display: flex; align-items: center; justify-content: center; color: #666;
}
.share-body { padding: 16px 20px; overflow-y: auto; }
.share-field { margin-bottom: 12px; }
.share-field label {
    display: block; font-size: .82rem; color: #888; margin-bottom: 4px; font-weight: 500;
}
.share-input, .share-textarea {
    width: 100%; padding: 10px 12px; border: 1px solid rgba(0,0,0,0.12);
    border-radius: 8px; font-size: .9rem; font-family: inherit; outline: none;
    box-sizing: border-box; transition: border-color 0.2s;
}
.share-input:focus, .share-textarea:focus { border-color: var(--accent-blue); }
.share-textarea { resize: vertical; min-height: 50px; }
[data-theme="dark"] .share-input, [data-theme="dark"] .share-textarea {
    background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.12); color: #fff;
}
/* --- Share: per-object price list for collection -------- */
.share-price-list {
    margin-bottom: 12px; max-height: 240px; overflow-y: auto;
    border: 1px solid rgba(0,0,0,0.08); border-radius: 10px; padding: 8px 10px;
    background: rgba(0,0,0,0.02);
}
[data-theme="dark"] .share-price-list {
    background: rgba(255,255,255,0.03); border-color: rgba(255,255,255,0.08);
}
.share-price-list-title {
    font-size: .78rem; font-weight: 600; color: #888; margin-bottom: 6px;
    text-transform: uppercase; letter-spacing: .04em;
}
.share-price-item {
    display: flex; align-items: center; gap: 8px; margin-bottom: 6px;
}
.share-price-item:last-child { margin-bottom: 0; }
.share-price-item-label {
    flex-shrink: 0; font-size: .82rem; color: #555; width: 40%;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
[data-theme="dark"] .share-price-item-label { color: #aaa; }
.share-price-item-input {
    width: 60%; padding: 7px 10px; border: 1px solid rgba(0,0,0,0.12);
    border-radius: 6px; font-size: .85rem; font-family: inherit; outline: none;
    box-sizing: border-box; transition: border-color 0.2s;
}
.share-price-item-input:focus { border-color: var(--accent-blue); }
[data-theme="dark"] .share-price-item-input {
    background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.12); color: #fff;
}
.share-create-btn {
    width: 100%; padding: 12px; background: var(--accent-blue); color: #fff; border: none;
    border-radius: 10px; font-size: 1rem; font-weight: 600; cursor: pointer;
    transition: background 0.2s;
}
.share-create-btn:hover { background: #283593; }
.share-create-btn:disabled { opacity: .6; cursor: default; }
.share-result {
    margin-top: 12px; padding: 12px; background: rgba(26,35,126,0.04);
    border: 1px solid rgba(26,35,126,0.12); border-radius: 10px;
}
.share-result-url {
    word-break: break-all; font-size: .82rem; color: var(--accent-blue);
    margin-bottom: 8px; user-select: all;
}
.share-copy-btn {
    width: 100%; padding: 8px; background: rgba(26,35,126,0.06); border: 1px solid rgba(26,35,126,0.15);
    border-radius: 8px; cursor: pointer; font-size: .85rem; font-weight: 500; color: var(--accent-blue);
}
.share-copy-btn:hover { background: rgba(26,35,126,0.1); }
.share-error {
    margin-top: 12px; padding: 10px; background: #ffebee; border-radius: 8px;
    font-size: .85rem; color: #c62828;
}

/* --- Share-client button in reels -------------------------- */
.reels-share-client-btn {
    display: flex; align-items: center; justify-content: center; gap: 8px;
    width: 100%; margin-top: 8px; margin-bottom: 8px; padding: 12px;
    border: 1px solid rgba(0,0,0,0.12); border-radius: 12px;
    background: rgba(46,125,50,0.04); color: #2e7d32;
    font-size: .9rem; font-family: inherit; font-weight: 500; cursor: pointer;
    transition: all .25s;
}
.reels-share-client-btn:hover {
    background: rgba(46,125,50,0.1); border-color: #2e7d32;
}
[data-theme="dark"] .reels-share-client-btn {
    border-color: rgba(255,255,255,0.15); background: rgba(76,175,80,0.06); color: #66bb6a;
}
[data-theme="dark"] .reels-share-client-btn:hover {
    background: rgba(76,175,80,0.12); border-color: #66bb6a;
}
.reels-share-client-btn svg { width: 16px; height: 16px; flex-shrink: 0; }
@media (max-width: 500px) {
    .reels-share-client-btn { margin-top: 6px; padding: 10px; font-size: .82rem; }
    .reels-share-client-btn svg { width: 14px; height: 14px; }
}

/* --- Collection share + back buttons ----------------------- */
.collection-share-btn {
    width: 100%; margin-top: 10px; padding: 8px; border: 1px solid rgba(26,35,126,0.15);
    border-radius: 8px; background: rgba(26,35,126,0.03); color: var(--accent-blue);
    font-size: .82rem; font-family: inherit; cursor: pointer; font-weight: 500;
    transition: background 0.2s;
}
.collection-share-btn:hover { background: rgba(26,35,126,0.08); }
[data-theme="dark"] .collection-share-btn {
    border-color: rgba(124,140,209,0.2); color: #7c8cd1; background: rgba(124,140,209,0.04);
}
.coll-back-btn {
    padding: 6px 14px; border: 1px solid rgba(0,0,0,0.1); border-radius: 8px;
    background: none; cursor: pointer; font-size: .82rem; color: #666;
    margin-left: 8px; transition: background 0.2s;
}
.coll-back-btn:hover { background: rgba(0,0,0,0.04); }

/* --- Hero Features (Что умеет поиск?) ------------------- */
.hero-features {
    width: 100%;
    margin-top: 8px;
}

.features-toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: none;
    color: var(--text-secondary);
    font-size: .85rem;
    font-family: inherit;
    cursor: pointer;
    padding: 8px 16px;
    border-radius: 20px;
    transition: all .25s;
    opacity: .7;
    margin: 0 auto;
}

.features-toggle:hover {
    opacity: 1;
    background: rgba(0,0,0,.03);
    color: var(--text-primary);
}

[data-theme="dark"] .features-toggle:hover {
    background: rgba(255,255,255,.04);
}

.features-chevron {
    width: 16px;
    height: 16px;
    transition: transform .3s ease;
}

.features-chevron.open {
    transform: rotate(180deg);
}

.features-body {
    max-height: 0;
    overflow: hidden;
    transition: max-height .5s ease, opacity .4s ease, margin .4s ease;
    opacity: 0;
    margin-top: 0;
}

.features-body.open {
    max-height: 900px;
    opacity: 1;
    margin-top: 16px;
}

.features-intro {
    text-align: center;
    font-size: .9rem;
    color: var(--text-secondary);
    margin-bottom: 16px;
    line-height: 1.5;
}

.features-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

@media (max-width: 480px) {
    .features-grid {
        grid-template-columns: 1fr;
    }
}

.f-card {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 14px;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-sm);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    transition: background .2s;
}

[data-theme="dark"] .f-card {
    background: rgba(30, 30, 30, 0.4);
    border-color: rgba(255,255,255,0.04);
}

.f-card-icon {
    font-size: 1.3rem;
    flex-shrink: 0;
    margin-top: 2px;
    line-height: 1;
}

.f-card-text {
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
}

.f-card-text strong {
    font-size: .85rem;
    font-weight: 600;
    color: var(--text-primary);
}

.f-card-text span {
    font-size: .78rem;
    color: var(--text-secondary);
    line-height: 1.4;
}

.features-examples {
    margin-top: 16px;
    padding: 16px;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-sm);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

[data-theme="dark"] .features-examples {
    background: rgba(30, 30, 30, 0.4);
    border-color: rgba(255,255,255,0.04);
}

.features-examples strong {
    display: block;
    font-size: .82rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 10px;
}

.example-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.example-chip {
    padding: 6px 14px;
    font-size: .78rem;
    color: var(--accent-blue);
    background: rgba(26, 35, 126, 0.06);
    border: 1px solid rgba(26, 35, 126, 0.1);
    border-radius: 20px;
    cursor: pointer;
    transition: all .2s;
    white-space: nowrap;
}

.example-chip:hover {
    background: rgba(26, 35, 126, 0.1);
    border-color: rgba(26, 35, 126, 0.2);
    transform: translateY(-1px);
}

[data-theme="dark"] .example-chip {
    color: var(--accent-blue);
    background: rgba(124, 140, 209, 0.08);
    border-color: rgba(124, 140, 209, 0.15);
}

[data-theme="dark"] .example-chip:hover {
    background: rgba(124, 140, 209, 0.15);
    border-color: rgba(124, 140, 209, 0.25);
}

/* Hide features on search results mode */
.hero--shrunk .hero-features {
    display: none;
}

/* --- Hero favorites button --------------------------------- */
.hero-nav-row {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 4px;
    flex-wrap: wrap;
}

.hero-nav-btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: none;
    border: 1px solid rgba(0,0,0,0.08);
    color: var(--text-secondary);
    font-size: .82rem;
    font-family: inherit;
    cursor: pointer;
    padding: 7px 14px;
    border-radius: 20px;
    transition: all .25s;
    position: relative;
}

.hero-nav-btn:hover {
    background: rgba(0,0,0,0.04);
    border-color: var(--accent-blue);
    color: var(--accent-blue);
}

[data-theme="dark"] .hero-nav-btn {
    border-color: rgba(255,255,255,0.08);
}

[data-theme="dark"] .hero-nav-btn:hover {
    background: rgba(124,140,209,0.08);
    border-color: #7c8cd1;
    color: #7c8cd1;
}

.coll-badge {
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    background: #ff4081;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    line-height: 16px;
    text-align: center;
    border-radius: 10px;
    display: inline-block;
    pointer-events: none;
}
.fav-badge-icon {
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    background: #ff4081;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    line-height: 16px;
    text-align: center;
    border-radius: 10px;
    display: inline-block;
    pointer-events: none;
}

.hero--shrunk .hero-nav-row {
    display: none;
}

/* --- Floating selection button ------------------------------- */
.select-floating-btn {
    position: fixed;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%) translateY(80px);
    z-index: 190;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 24px;
    background: var(--accent-blue);
    color: #fff;
    font-size: .95rem;
    font-weight: 600;
    border: none;
    border-radius: 28px;
    box-shadow: 0 4px 20px rgba(26,35,126,0.3);
    cursor: pointer;
    transition: transform 0.35s cubic-bezier(0.4,0,0.2,1), opacity 0.35s;
    opacity: 0;
    pointer-events: none;
}
.select-floating-btn.visible {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
    pointer-events: auto;
}
.select-floating-btn:hover {
    box-shadow: 0 6px 28px rgba(26,35,126,0.4);
}
.select-floating-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 24px;
    height: 24px;
    padding: 0 6px;
    background: rgba(255,255,255,0.25);
    border-radius: 12px;
    font-size: .82rem;
    font-weight: 700;
}

/* --- Collections modal --------------------------------------- */
.collect-overlay {
    position: fixed;
    inset: 0;
    z-index: 250;
    background: rgba(0,0,0,0.4);
    backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    overscroll-behavior: contain;
}
.collect-overlay.hidden { display: none !important; }
.collect-modal {
    width: 90%;
    max-width: 420px;
    max-height: 70vh;
    background: #fff;
    border-radius: 16px;
    display: flex;
    flex-direction: column;
    box-shadow: 0 12px 40px rgba(0,0,0,0.2);
}
[data-theme="dark"] .collect-modal {
    background: #1e1e1e;
    border: 1px solid rgba(255,255,255,0.08);
}
.collect-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid rgba(0,0,0,0.06);
}
[data-theme="dark"] .collect-header {
    border-color: rgba(255,255,255,0.06);
}
.collect-title {
    font-size: 1rem;
    font-weight: 600;
}
.collect-close {
    width: 28px;
    height: 28px;
    border: none;
    background: rgba(0,0,0,0.05);
    border-radius: 50%;
    cursor: pointer;
    font-size: .9rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #666;
}
.collect-body {
    padding: 16px 20px;
    overflow-y: auto;
}
.collect-item {
    display: block;
    width: 100%;
    padding: 10px 14px;
    margin-bottom: 6px;
    border: 1px solid rgba(0,0,0,0.08);
    border-radius: 10px;
    background: rgba(0,0,0,0.02);
    cursor: pointer;
    font-size: .9rem;
    font-family: inherit;
    text-align: left;
    transition: background 0.2s;
}
.collect-item:hover {
    background: rgba(26,35,126,0.06);
    border-color: var(--accent-blue);
}
[data-theme="dark"] .collect-item {
    border-color: rgba(255,255,255,0.1);
    background: rgba(255,255,255,0.03);
}
[data-theme="dark"] .collect-item:hover {
    background: rgba(124,140,209,0.1);
}
.collect-input {
    flex: 1;
    padding: 9px 12px;
    border: 1px solid rgba(0,0,0,0.12);
    border-radius: 8px;
    font-size: .9rem;
    font-family: inherit;
    outline: none;
}
.collect-input:focus {
    border-color: var(--accent-blue);
}
.collect-create-btn {
    padding: 9px 18px;
    background: var(--accent-blue);
    color: #fff;
    border: none;
    border-radius: 8px;
    font-size: .9rem;
    font-weight: 500;
    cursor: pointer;
    white-space: nowrap;
}

/* --- Collections view ---------------------------------------- */
.collection-card {
    background: #fff;
    border: 1px solid rgba(0,0,0,0.06);
    border-radius: 12px;
    padding: 14px 16px;
    margin-bottom: 10px;
    cursor: pointer;
    transition: box-shadow 0.2s;
}
.collection-card:hover {
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}
[data-theme="dark"] .collection-card {
    background: rgba(30,30,30,0.7);
    border-color: rgba(255,255,255,0.06);
}
.collection-card-header {
    display: flex;
    align-items: center;
    gap: 8px;
}
.collection-card-name {
    font-size: 1rem;
    font-weight: 600;
    flex: 1;
}
.collection-card-count {
    font-size: .8rem;
    color: #999;
}
.collection-del-btn {
    width: 26px;
    height: 26px;
    border: none;
    background: rgba(0,0,0,0.04);
    border-radius: 50%;
    cursor: pointer;
    font-size: .75rem;
    color: #999;
    display: flex;
    align-items: center;
    justify-content: center;
}
.collection-del-btn:hover {
    background: rgba(198,40,40,0.1);
    color: #c62828;
}
.collection-ids {
    margin-top: 8px;
    font-size: .78rem;
    color: #999;
    line-height: 1.6;
}
.collections-empty {
    text-align: center;
    padding: 40px 20px;
    color: #888;
}

/* --- Save search button ------------------------------------- */
.save-search-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: none;
    border: 1px solid rgba(0,0,0,0.08);
    color: var(--text-secondary);
    font-size: .78rem;
    font-family: inherit;
    cursor: pointer;
    padding: 6px 12px;
    border-radius: 8px;
    transition: all .2s;
    white-space: nowrap;
}

.save-search-btn:hover {
    background: rgba(0,0,0,0.03);
    border-color: rgba(0,0,0,0.15);
    color: var(--text-primary);
}

.save-search-btn--saved {
    color: var(--accent-blue);
    border-color: rgba(26,35,126,0.15);
    background: rgba(26,35,126,0.04);
}

.save-search-btn--saved:hover {
    background: rgba(26,35,126,0.08);
    border-color: rgba(26,35,126,0.25);
}

[data-theme="dark"] .save-search-btn {
    border-color: rgba(255,255,255,0.08);
}

[data-theme="dark"] .save-search-btn:hover {
    background: rgba(255,255,255,0.04);
}

[data-theme="dark"] .save-search-btn--saved {
    color: var(--accent-blue);
    border-color: rgba(124,140,209,0.2);
    background: rgba(124,140,209,0.06);
}

/* --- Favorites view (two sections) -------------------------- */
.fav-container {
    display: flex;
    flex-direction: column;
    gap: 24px;
    grid-column: 1 / -1;
}

.fav-section-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 12px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.fav-section-count {
    font-size: .78rem;
    font-weight: 500;
    color: var(--text-secondary);
    background: rgba(0,0,0,0.04);
    padding: 2px 8px;
    border-radius: 10px;
}

[data-theme="dark"] .fav-section-count {
    background: rgba(255,255,255,0.06);
}

.fav-objects-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}

@media (min-width: 768px) {
    .fav-objects-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
    .fav-objects-grid { grid-template-columns: repeat(3, 1fr); }
}

.saved-searches-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.saved-search-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 16px;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    font-size: .85rem;
    font-family: inherit;
    color: var(--text-primary);
    cursor: pointer;
    transition: all .2s;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.saved-search-chip:hover {
    background: rgba(26,35,126,0.04);
    border-color: rgba(26,35,126,0.15);
    transform: translateY(-2px);
    box-shadow: var(--shadow-sm);
}

[data-theme="dark"] .saved-search-chip {
    background: rgba(30,30,30,0.4);
    border-color: rgba(255,255,255,0.04);
}

[data-theme="dark"] .saved-search-chip:hover {
    background: rgba(124,140,209,0.06);
    border-color: rgba(124,140,209,0.15);
}

.saved-search-chip svg {
    flex-shrink: 0;
    color: var(--accent-blue);
}

.saved-search-del {
    margin-left: 6px;
    color: #999;
    font-size: 1.1rem;
    line-height: 1;
    cursor: pointer;
    transition: color .15s;
    padding: 0 2px;
}

.saved-search-del:hover {
    color: #c62828;
}

.fav-empty {
    text-align: center;
    padding: 60px 20px;
    color: var(--text-secondary);
    font-size: .95rem;
    line-height: 1.6;
}

/* --- Price prompt modal ------------------------------------ */
.price-prompt-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 500;
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
}

.price-prompt-modal {
    background: rgba(255, 255, 255, 0.767);
    border-radius: 20px;
    padding: 32px 28px 28px;
    width: 340px;
    max-width: 90vw;
    box-shadow: 0 20px 60px rgba(0,0,0,0.15);
    text-align: center;
}

[data-theme="dark"] .price-prompt-modal {
    background: rgba(0,0,0, 0.45);
    border: 1px solid rgba(255,255,255,0.08);
}

.price-prompt-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 24px;
}

.price-prompt-btns {
    display: flex;
    gap: 12px;
    justify-content: center;
}

.price-prompt-btn {
    padding: 12px 32px;
    border-radius: 12px;
    font-size: .95rem;
    font-family: inherit;
    font-weight: 500;
    cursor: pointer;
    border: none;
    transition: all .2s;
}

.price-prompt-btn--no {
    background: rgba(0,0,0,0.05);
    color: var(--text-secondary);
}

.price-prompt-btn--no:hover {
    background: rgba(0,0,0,0.1);
}

.price-prompt-btn--yes {
    background: var(--accent-blue);
    color: #fff;
}

.price-prompt-btn--yes:hover {
    opacity: .9;
}

[data-theme="dark"] .price-prompt-btn--no {
    background: rgba(255,255,255,0.08);
    color: rgba(255,255,255,0.6);
}

[data-theme="dark"] .price-prompt-btn--no:hover {
    background: rgba(255,255,255,0.12);
}

.price-prompt-input-area {
    margin-top: 20px;
}

.price-prompt-input {
    width: 100%;
    padding: 14px 16px;
    border: 2px solid rgba(0,0,0,0.1);
    border-radius: 12px;
    font-size: 1.1rem;
    font-family: inherit;
    text-align: center;
    outline: none;
    transition: border-color .2s;
    margin-bottom: 16px;
    box-sizing: border-box;
}

.price-prompt-input:focus {
    border-color: var(--accent-blue);
}

[data-theme="dark"] .price-prompt-input {
    background: rgba(255,255,255,0.05);
    border-color: rgba(255,255,255,0.15);
    color: #fff;
}

[data-theme="dark"] .price-prompt-input:focus {
    border-color: rgba(124,140,209,0.6);
}

.price-prompt-btn--go {
    background: var(--accent-blue);
    color: #fff;
    width: 100%;
}

.price-prompt-btn--go:hover {
    opacity: .9;
}

/* --- Classic Toggle Button (results header) ----------------- */
.classic-toggle-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 0 14px;
    height: 36px;
    border: 1px solid rgba(0,0,0,0.08);
    background: var(--card-bg);
    color: var(--text);
    font-size: .9rem;
    cursor: pointer;
    white-space: nowrap;
    transition: all .15s;
    border-radius: 10px;
    margin: 8px 0;
}
.classic-toggle-btn:hover {
    background: rgba(0,0,0,0.04);
}
[data-theme="dark"] .classic-toggle-btn {
    border-color: rgba(255,255,255,0.1);
}
[data-theme="dark"] .classic-toggle-btn:hover {
    background: rgba(255,255,255,0.06);
}
.classic-toggle-btn .ct-arrow {
    transition: transform .2s ease;
}
.classic-toggle-btn.active .ct-arrow {
    transform: rotate(180deg);
}

/* --- Property type tabs ------------------------------------ */
.cs-ptabs {
    display: flex;
    gap: 4px;
    margin-bottom: 12px;
    background: rgba(0,0,0,0.04);
    border-radius: 10px;
    padding: 3px;
}
[data-theme="dark"] .cs-ptabs {
    background: rgba(255,255,255,0.06);
}
.cs-ptab {
    flex: 1;
    padding: 8px 4px;
    border: none;
    border-radius: 8px;
    background: transparent;
    color: var(--text-secondary);
    font-size: .82rem;
    font-weight: 600;
    cursor: pointer;
    transition: all .15s;
    font-family: inherit;
}
.cs-ptab.active {
    background: var(--card-bg);
    color: var(--text);
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}
.cs-ptab:hover:not(.active) {
    color: var(--text);
}
.cs-query-row {
    margin-bottom: 14px;
}
.cs-query-row .cs-input {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--border);
    border-radius: 10px;
    font-size: .9rem;
    font-family: inherit;
    background: var(--card-bg);
    color: var(--text);
    outline: none;
    transition: border-color .2s;
}
.cs-query-row .cs-input:focus {
    border-color: var(--accent);
}

/* --- Dynamic field visibility ------------------------------- */
.cs-dyn--hidden {
    display: none !important;
}

/* --- Classic Search Form ----------------------------------- */
.classic-search-section {
    width: 100%;
    max-width: 780px;
    background: rgba(255,255,255,0.45);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid rgba(255,255,255,0.5);
    border-radius: 16px;
    padding: 28px;
    box-shadow: 0 8px 40px rgba(0,0,0,0.08);
}
[data-theme="dark"] .classic-search-section {
    background: rgba(30,30,50,0.7);
    border-color: rgba(255,255,255,0.08);
}
.classic-search-form {
    display: flex;
    flex-direction: column;
    gap: 18px;
}
.cs-section {
    background: rgba(255,255,255,0.5);
    border: 1px solid rgba(255,255,255,0.5);
    border-radius: 12px;
    padding: 16px 18px;
}
[data-theme="dark"] .cs-section {
    background: rgba(255,255,255,0.04);
    border-color: rgba(255,255,255,0.05);
}
.cs-section-header {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: .8rem;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: 10px;
    opacity: .75;
}
.cs-section-header svg {
    opacity: .6;
    flex-shrink: 0;
}
.cs-row {
    display: flex;
    gap: 10px;
}
.cs-field {
    flex: 1;
    min-width: 0;
}
.cs-field--wide {
    flex: 2;
}
.cs-label {
    display: block;
    font-size: .75rem;
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 3px;
    text-transform: uppercase;
    letter-spacing: .03em;
}
.cs-input,
.cs-select {
    width: 100%;
    padding: 10px 14px;
    border: 2px solid var(--border);
    border-radius: 10px;
    font-size: .9rem;
    font-family: inherit;
    background: var(--card-bg);
    color: var(--text);
    outline: none;
    transition: border-color .2s, box-shadow .2s;
}
.cs-input:focus,
.cs-select:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(26,35,126,0.1);
}
[data-theme="dark"] .cs-input:focus,
[data-theme="dark"] .cs-select:focus {
    box-shadow: 0 0 0 3px rgba(92,107,192,0.2);
}
.cs-input--sm {
    padding: 9px 12px;
    font-size: .88rem;
}
.cs-range {
    display: flex;
    align-items: center;
    gap: 6px;
}
.cs-range-sep {
    color: var(--text-secondary);
    font-size: .85rem;
    flex-shrink: 0;
}
.cs-submit {
    width: 100%;
    padding: 14px;
    background: linear-gradient(135deg, #1a237e, #283593);
    color: #fff;
    border: none;
    border-radius: 12px;
    font-size: 1.05rem;
    font-weight: 700;
    cursor: pointer;
    transition: opacity .2s, transform .15s, box-shadow .2s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    box-shadow: 0 4px 16px rgba(26,35,126,0.25);
    letter-spacing: .02em;
}
.cs-submit:hover {
    opacity: .95;
    transform: translateY(-1px);
    box-shadow: 0 6px 24px rgba(26,35,126,0.35);
}
.cs-submit:active {
    transform: translateY(0);
    box-shadow: 0 2px 8px rgba(26,35,126,0.2);
}
[data-theme="dark"] .cs-submit {
    background: linear-gradient(135deg, #5c6bc0, #3949ab);
    box-shadow: 0 4px 16px rgba(92,107,192,0.25);
}
[data-theme="dark"] .cs-submit:hover {
    box-shadow: 0 6px 24px rgba(92,107,192,0.35);
}
.cs-submit svg {
    flex-shrink: 0;
}

/* --- Tablet / small desktop ------------------------------- */
@media (max-width: 820px) {
    .classic-search-section {
        max-width: 100%;
        padding: 20px;
    }
    .classic-dropdown-inner {
        max-width: 100%;
        margin-left: 8px;
        margin-right: 8px;
        padding: 18px;
    }
    .hero-content {
        max-width: 100%;
        padding: 0 8px;
        gap: 28px;
    }
    .hero { padding: 32px 16px; }
}

/* --- Mobile: phones -------------------------------------- */
@media (max-width: 500px) {
    /* Header */
    .header-mode-tabs { display: none; }
    .search-header-wrapper { max-width: 100%; min-width: 0; }
    .search-box--compact { max-width: 100%; min-width: 0; }
    .header .theme-toggle { width: 34px; height: 34px; flex-shrink: 0; }
    .header-inner { gap: 6px; padding: 0 8px; }
    .classic-toggle-btn { font-size: .78rem; padding: 5px 8px; }

    /* Hero */
    .hero { padding: 24px 12px; }
    .hero-content { gap: 24px; }
    .hero-tagline { font-size: .9rem; }

    /* Theme toggle — above tabs, centered */
    .hero .hero-theme-toggle {
        position: static;
        width: 36px;
        height: 36px;
        margin-bottom: 0;
    }

    /* Search mode tabs — full width, stretched */
    .hero .search-mode-tabs {
        width: 100%;
        padding-right: 0;
        align-self: auto;
    }
    .hero .search-mode-tab {
        flex: 1;
        text-align: center;
        padding: 8px 8px;
        font-size: .85rem;
    }

    /* Classic form */
    .classic-search-section {
        max-width: 100%;
        padding: 14px;
        border-radius: 12px;
    }
    .classic-search-form { gap: 12px; }
    .cs-section { padding: 10px 12px; }
    .cs-row {
        flex-direction: column;
        gap: 10px;
    }
    .cs-row .cs-field {
        min-width: 100%;
    }

    /* Property tabs */
    .cs-ptab {
        font-size: .75rem;
        padding: 6px 2px;
    }

    /* Dropdown */
    .classic-dropdown-inner {
        max-width: 100%;
        margin-left: 4px;
        margin-right: 4px;
        padding: 14px;
        border-radius: 12px;
    }
}

/* --- Mobile: very small phones ---------------------------- */
@media (max-width: 380px) {
    .cs-ptab {
        font-size: .7rem;
        padding: 5px 1px;
    }
    .hero .search-mode-tab {
        padding: 5px 6px;
        font-size: .72rem;
    }
}

/* --- Classic Dropdown (results view) ------------------------- */
.classic-dropdown {
    position: fixed;
    top: var(--header-h);
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 99;
    background: rgba(0,0,0,0.25);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}
.classic-dropdown-inner {
    max-width: 580px;
    margin: 12px auto calc(40px + env(safe-area-inset-bottom));
    background: rgba(248,249,250,0.92);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid rgba(255,255,255,0.5);
    border-radius: 16px;
    padding: 24px;
    box-shadow: 0 12px 48px rgba(0,0,0,0.12);
    position: relative;
}
[data-theme="dark"] .classic-dropdown {
    background: rgba(0,0,0,0.45);
}
[data-theme="dark"] .classic-dropdown-inner {
    background: rgba(25,25,40,0.92);
    border-color: rgba(255,255,255,0.08);
}
.classic-dropdown .cs-drop-close {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 32px;
    height: 32px;
    border: none;
    background: transparent;
    border-radius: 50%;
    font-size: 1.1rem;
    cursor: pointer;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .15s;
}
.classic-dropdown .cs-drop-close:hover {
    background: rgba(0,0,0,0.06);
}
[data-theme="dark"] .classic-dropdown .cs-drop-close:hover {
    background: rgba(255,255,255,0.08);
}
.classic-dropdown.hidden {
    display: none;
}

/* --- Number format input ----------------------------------- */
.cs-num {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

/* --- Hero theme toggle ------------------------------------- */
.hero-theme-toggle {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 36px;
    height: 36px;
    border: 1px solid var(--border);
    border-radius: 50%;
    background: var(--card-bg);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    color: var(--text-secondary);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .2s;
    z-index: 10;
}
.hero-theme-toggle:hover {
    background: var(--hover-bg);
    color: var(--text);
}
.hero-content {
    position: relative;
}

/* --- Results spacing --------------------------------------- */
.results-grid {
    margin-top: 16px;
}
