/* ==========================================================================
   КТ Довідник — Custom Styles
   Business catalog for Комфорт Таун residential complex, Kyiv
   Color palette: warm coral/orange primary, soft backgrounds, dark text
   ========================================================================== */

/* --------------------------------------------------------------------------
   CSS Custom Properties (Design Tokens)
   -------------------------------------------------------------------------- */
:root {
    --kt-primary: #E8764B;
    --kt-primary-hover: #D4623A;
    --kt-primary-light: #FFF0EB;
    --kt-primary-rgb: 232, 118, 75;
    --kt-secondary: #5B8C7B;
    --kt-secondary-light: #EBF5F0;
    --kt-dark: #2D2D2D;
    --kt-text: #3A3A3A;
    --kt-text-muted: #7A7A7A;
    --kt-bg-warm: #FDF8F5;
    --kt-bg-light: #F9F6F3;
    --kt-border-radius: 12px;
    --kt-border-radius-lg: 16px;
    --kt-shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.06);
    --kt-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
    --kt-shadow-lg: 0 8px 32px rgba(0, 0, 0, 0.1);
    --kt-transition: 0.25s ease;

    --kt-card-bg: #fff;
    --kt-navbar-bg: #fff;
    --kt-border-color: #f0ebe7;
    --kt-border-color-light: #f7f3ef;
    --kt-border-color-muted: #eee;
    --kt-map-border: #eee;
    --kt-surface-dark: #2D2D2D;
}

/* --------------------------------------------------------------------------
   Dark Mode Overrides
   -------------------------------------------------------------------------- */
[data-bs-theme="dark"] {
    --kt-primary: #F09070;
    --kt-primary-hover: #E87A58;
    --kt-primary-light: #3D2A22;
    --kt-primary-rgb: 240, 144, 112;
    --kt-secondary: #6FA693;
    --kt-secondary-light: #1E2E28;
    --kt-dark: #E8E0DA;
    --kt-text: #D4CCC6;
    --kt-text-muted: #9A928C;
    --kt-bg-warm: #1A1614;
    --kt-bg-light: #231F1D;
    --kt-shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.2);
    --kt-shadow: 0 4px 16px rgba(0, 0, 0, 0.25);
    --kt-shadow-lg: 0 8px 32px rgba(0, 0, 0, 0.3);

    --kt-card-bg: #231F1D;
    --kt-navbar-bg: #1A1614;
    --kt-border-color: #3A3430;
    --kt-border-color-light: #2E2A27;
    --kt-border-color-muted: #3A3430;
    --kt-map-border: #3A3430;
    --kt-surface-dark: #1A1614;
}

/* --------------------------------------------------------------------------
   Bootstrap Overrides
   -------------------------------------------------------------------------- */
.btn-primary {
    --bs-btn-bg: var(--kt-primary);
    --bs-btn-border-color: var(--kt-primary);
    --bs-btn-hover-bg: var(--kt-primary-hover);
    --bs-btn-hover-border-color: var(--kt-primary-hover);
    --bs-btn-active-bg: var(--kt-primary-hover);
    --bs-btn-active-border-color: var(--kt-primary-hover);
    --bs-btn-disabled-bg: #b0b0b0;
    --bs-btn-disabled-border-color: #b0b0b0;
    --bs-btn-disabled-opacity: 0.65;
}

.btn-outline-primary {
    --bs-btn-color: var(--kt-primary);
    --bs-btn-border-color: var(--kt-primary);
    --bs-btn-hover-bg: var(--kt-primary);
    --bs-btn-hover-border-color: var(--kt-primary);
    --bs-btn-active-bg: var(--kt-primary-hover);
    --bs-btn-active-border-color: var(--kt-primary-hover);
}

.text-primary {
    color: var(--kt-primary) !important;
}

a {
    color: var(--kt-primary);
    transition: color var(--kt-transition);
}

a:hover {
    color: var(--kt-primary-hover);
}

.badge.bg-primary {
    background-color: var(--kt-primary) !important;
}

.form-control:focus {
    border-color: var(--kt-primary);
    box-shadow: 0 0 0 0.2rem rgba(var(--kt-primary-rgb), 0.25);
}

/* --------------------------------------------------------------------------
   Global / Base Styles
   -------------------------------------------------------------------------- */
body {
    font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
    color: var(--kt-text);
    background-color: var(--kt-bg-warm);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

main {
    flex: 1;
}

/* --------------------------------------------------------------------------
   Navbar
   -------------------------------------------------------------------------- */
.navbar {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    background-color: var(--kt-navbar-bg);
    transition: box-shadow var(--kt-transition), background-color var(--kt-transition);
}

.navbar-brand {
    font-size: 1.35rem;
    letter-spacing: -0.02em;
}

.navbar-brand-icon {
    height: 1.5em;
    width: 1.5em;
    vertical-align: middle;
    margin-right: 0.35rem;
}

.navbar-brand .text-primary {
    font-weight: 800;
}

.nav-link {
    font-weight: 500;
    color: var(--kt-text) !important;
    transition: color var(--kt-transition);
    padding: 0.5rem 1rem !important;
}

.nav-link:hover {
    color: var(--kt-primary) !important;
}

.dropdown-menu {
    border: none;
    border-radius: var(--kt-border-radius);
    box-shadow: var(--kt-shadow);
    padding: 0.5rem;
}

.dropdown-item {
    border-radius: 8px;
    padding: 0.5rem 1rem;
    transition: background-color var(--kt-transition);
}

.dropdown-item:hover {
    background-color: var(--kt-primary-light);
    color: var(--kt-primary);
}

/* --------------------------------------------------------------------------
   Hero Search Section
   -------------------------------------------------------------------------- */
.hero-search {
    background: linear-gradient(135deg, #E8764B 0%, #F4A574 50%, #F9C89B 100%);
    padding: 4rem 0;
    text-align: center;
    color: #fff;
    position: relative;
    overflow: hidden;
}

.hero-search::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.08) 0%, transparent 60%);
    pointer-events: none;
}

.hero-search h1 {
    font-size: 2.25rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
    position: relative;
}

.hero-search p {
    font-size: 1.15rem;
    opacity: 0.92;
    margin-bottom: 1.75rem;
    position: relative;
}

.hero-search .search-form {
    max-width: 560px;
    margin: 0 auto;
    position: relative;
}

.hero-search .form-control {
    border: none;
    border-radius: 50px;
    padding: 0.85rem 1.5rem;
    font-size: 1.05rem;
    box-shadow: var(--kt-shadow-lg);
}

.hero-search .form-control:focus {
    box-shadow: var(--kt-shadow-lg), 0 0 0 0.2rem rgba(255, 255, 255, 0.3);
}

.hero-search .btn {
    border-radius: 50px;
    padding: 0.85rem 2rem;
    font-weight: 600;
    box-shadow: var(--kt-shadow-sm);
}

/* --------------------------------------------------------------------------
   Category Cards
   -------------------------------------------------------------------------- */
.category-card {
    background: var(--kt-card-bg);
    border: none;
    border-radius: var(--kt-border-radius-lg);
    box-shadow: var(--kt-shadow-sm);
    padding: 1.75rem 1.25rem;
    text-align: center;
    transition: transform var(--kt-transition), box-shadow var(--kt-transition);
    cursor: pointer;
    text-decoration: none;
    color: var(--kt-text);
    display: block;
}

.category-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--kt-shadow);
    color: var(--kt-primary);
}

.category-card .category-icon {
    font-size: 2.75rem;
    display: block;
    margin-bottom: 0.75rem;
    line-height: 1;
}

.category-card .card-title {
    font-weight: 600;
    font-size: 0.95rem;
    margin-bottom: 0.25rem;
    word-break: keep-all;
    overflow-wrap: break-word;
    hyphens: none;
}

.category-card .category-count {
    font-size: 0.8rem;
    color: var(--kt-text-muted);
}

/* --------------------------------------------------------------------------
   Business Cards
   -------------------------------------------------------------------------- */
.business-card {
    background: var(--kt-card-bg);
    border: none;
    border-radius: var(--kt-border-radius-lg);
    box-shadow: var(--kt-shadow-sm);
    padding: 1.5rem;
    margin-bottom: 1rem;
    transition: transform var(--kt-transition), box-shadow var(--kt-transition);
    display: block;
    text-decoration: none;
    color: var(--kt-text);
    position: relative;
    overflow: hidden;
}

.business-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--kt-shadow);
    color: var(--kt-text);
}

.business-card .business-name {
    font-size: 1.15rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
    color: var(--kt-dark);
}

.business-card .business-category {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.business-card .business-category .badge {
    font-weight: 500;
    font-size: 0.78rem;
    padding: 0.35em 0.7em;
    border-radius: 50px;
    background-color: var(--kt-primary-light) !important;
    color: var(--kt-primary) !important;
}

.business-card .business-info {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 0.75rem;
    font-size: 0.9rem;
    color: var(--kt-text-muted);
}

.business-card .business-info i {
    color: var(--kt-primary);
    margin-right: 0.25rem;
}

.business-card .delivery-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--kt-secondary);
    background-color: var(--kt-secondary-light);
    padding: 0.25em 0.65em;
    border-radius: 50px;
}

.business-card .delivery-badge i {
    color: var(--kt-secondary);
}

/* Tier: Business card */
.business-card.tier-business {
    border-left: 4px solid var(--kt-primary);
    box-shadow: var(--kt-shadow-sm), inset 0 0 0 1px rgba(var(--kt-primary-rgb), 0.08);
    background: linear-gradient(135deg, var(--kt-card-bg) 0%, var(--kt-primary-light) 100%);
}

.business-card.tier-business::after {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 60px;
    height: 60px;
    background: radial-gradient(circle at top right, rgba(var(--kt-primary-rgb), 0.06), transparent 70%);
    pointer-events: none;
}

/* Tier badge: Infrastructure */
.badge-tier-infra {
    background-color: #6c757d;
    color: #fff;
}

/* Tier: Neighbor card */
.business-card.tier-neighbor {
    border-left: 4px solid var(--kt-secondary);
    box-shadow: var(--kt-shadow-sm), inset 0 0 0 1px rgba(91, 140, 123, 0.08);
    background: linear-gradient(135deg, var(--kt-card-bg) 0%, var(--kt-secondary-light) 100%);
}

/* --------------------------------------------------------------------------
   Business Detail Page
   -------------------------------------------------------------------------- */
.business-detail {
    background: var(--kt-card-bg);
    border-radius: var(--kt-border-radius-lg);
    box-shadow: var(--kt-shadow);
    padding: 2rem;
}

.business-detail .business-header {
    border-bottom: 1px solid var(--kt-border-color);
    padding-bottom: 1.5rem;
    margin-bottom: 1.5rem;
}

.business-detail .business-header h1 {
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--kt-dark);
    margin-bottom: 0.5rem;
}

.business-detail .info-row {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--kt-border-color-light);
}

.business-detail .info-row:last-child {
    border-bottom: none;
}

.business-detail .info-row i {
    color: var(--kt-primary);
    font-size: 1.1rem;
    flex-shrink: 0;
    margin-top: 0.15rem;
}

.business-detail .info-label {
    font-weight: 600;
    font-size: 0.85rem;
    color: var(--kt-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    margin-bottom: 0.15rem;
}

.business-detail .info-value {
    font-size: 1rem;
    color: var(--kt-text);
}

.business-detail .services-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.business-detail .services-list li {
    background-color: var(--kt-bg-light);
    padding: 0.3em 0.75em;
    border-radius: 50px;
    font-size: 0.88rem;
    font-weight: 500;
}

/* --------------------------------------------------------------------------
   Business Detail — Contacts Section (inside main card)
   -------------------------------------------------------------------------- */
.business-contacts-section {
    border-left: 2px solid var(--kt-border-color);
    padding-left: 1.5rem;
}

@media (max-width: 767.98px) {
    .business-contacts-section {
        border-left: none;
        border-top: 2px solid var(--kt-border-color);
        padding-left: 0;
        padding-top: 1rem;
        margin-top: 0.5rem;
    }
    /* Дозволяємо модалці скролитись природньо */
    #addRentalModal.modal.fade.show {
        display: block !important;
        overflow-y: auto !important;
    }

    #addRentalModal .modal-dialog {
        margin: 0;
        min-height: 100%;
        display: flex;
        flex-direction: column;
    }

    #addRentalModal .modal-content {
        flex: 1;
        border-radius: 0;
        border: none;
        display: flex;
        flex-direction: column;
    }

    #addRentalModal .modal-body {
        flex: 1 0 auto; /* Дозволяє тілу розтягуватись */
        padding-bottom: 50px !important; /* Базовий відступ */
    }

    /* ФУТЕР БІЛЬШЕ НЕ ПЛАВАЄ ПОВЕРХ ПОЛІВ */
    #addRentalModal .modal-footer {
        position: relative !important;
        bottom: auto !important;
        background: var(--kt-bg-warm);
        padding: 20px 15px 40px 15px !important; /* Великий відступ знизу для пальців */
        border-top: 1px solid var(--kt-border-color);
    }
}

/* --------------------------------------------------------------------------
   Contact Badges — Instagram
   -------------------------------------------------------------------------- */
.badge-instagram {
    background: linear-gradient(135deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888);
    color: #fff;
}

.btn-outline-instagram {
    color: #E1306C;
    border-color: #E1306C;
}

.btn-outline-instagram:hover,
.btn-outline-instagram:focus {
    background: linear-gradient(135deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888);
    border-color: #dc2743;
    color: #fff;
}

/* --------------------------------------------------------------------------
   Business Logo (inline on detail page)
   -------------------------------------------------------------------------- */
.business-logo-inline {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid #ffc107;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.15);
}

/* Logo badge on business cards */
.business-card-logo {
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 1;
}

.business-card-logo img {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid #ffc107;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
    background: var(--kt-card-bg);
}

/* Logo marker on category map */
.business-logo-marker img {
    border-radius: 50%;
    border: 2px solid #ffc107;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
}

/* --------------------------------------------------------------------------
   Business Map
   -------------------------------------------------------------------------- */
.business-map-container {
    height: 400px;
    border-radius: var(--kt-border-radius);
    border: 2px solid var(--kt-map-border);
    z-index: 0;
}

.category-map-container {
    height: 450px;
    border-radius: var(--kt-border-radius);
    border: 2px solid var(--kt-map-border);
    z-index: 0;
}

.map-page-container {
    height: calc(100vh - 120px);
    min-height: 60vh;
    border-radius: var(--kt-border-radius);
    border: 2px solid var(--kt-map-border);
    z-index: 0;
}

/* Map category sidebar — collapsible on mobile, always open on md+ */
#mapCategoryHeader {
    cursor: pointer;
}

.map-collapse-icon {
    transition: transform 0.3s;
}

#mapCategoryHeader[aria-expanded="true"] .map-collapse-icon {
    transform: rotate(180deg);
}

@media (min-width: 768px) {
    #mapCategoryHeader {
        cursor: default;
        pointer-events: none;
    }
    #mapCategoryBody {
        display: block !important;
    }
}

/* Perks category sidebar — collapsible on mobile, always open on md+ */
#perksCategoryHeader {
    cursor: pointer;
}

.perks-collapse-icon {
    transition: transform 0.3s;
}

#perksCategoryHeader[aria-expanded="true"] .perks-collapse-icon {
    transform: rotate(180deg);
}

@media (min-width: 768px) {
    #perksCategoryHeader {
        cursor: default;
        pointer-events: none;
    }
    #perksCategoryBody {
        display: block !important;
    }
}

/* --------------------------------------------------------------------------
   Map Thumbnail (Business Detail — right column)
   -------------------------------------------------------------------------- */
.map-thumbnail-container {
    height: 250px;
    border-radius: var(--kt-border-radius);
    cursor: pointer;
    position: relative;
    overflow: hidden;
    z-index: 0;
}

.map-thumbnail-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.5));
    color: #fff;
    padding: 1rem;
    text-align: center;
    z-index: 1000;
    pointer-events: none;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
}

.business-map-modal-container {
    height: 400px;
    border-radius: var(--kt-border-radius);
    z-index: 0;
}

/* --------------------------------------------------------------------------
   Breadcrumbs
   -------------------------------------------------------------------------- */
.breadcrumb {
    background: none;
    padding: 0.75rem 0;
    margin-bottom: 1.5rem;
    font-size: 0.88rem;
}

.breadcrumb-item + .breadcrumb-item::before {
    content: '\203A';
    color: var(--kt-text-muted);
}

.breadcrumb-item a {
    color: var(--kt-text-muted);
    text-decoration: none;
    transition: color var(--kt-transition);
}

.breadcrumb-item a:hover {
    color: var(--kt-primary);
}

.breadcrumb-item.active {
    color: var(--kt-text);
    font-weight: 500;
}

/* --------------------------------------------------------------------------
   Footer
   -------------------------------------------------------------------------- */
.footer {
    background-color: var(--kt-surface-dark) !important;
    margin-top: auto;
}

.footer p {
    margin-bottom: 0;
}

.footer .text-muted {
    color: #9a9a9a !important;
}

.footer-links {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-links li {
    margin-bottom: 0.25rem;
}

.footer-links a {
    color: #ccc;
    text-decoration: none;
    font-size: 0.9rem;
    transition: color var(--kt-transition);
}

.footer-links a:hover {
    color: #fff;
}

.footer-payment-icons {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.payment-icon {
    width: 40px;
    height: 26px;
}

/* --------------------------------------------------------------------------
   Legal Pages
   -------------------------------------------------------------------------- */
.legal-content h2 {
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--kt-dark);
    margin-bottom: 0.75rem;
}

.legal-content p {
    color: var(--kt-text);
    line-height: 1.7;
}

.legal-content .card {
    border: 1px solid var(--kt-border-color);
    border-radius: var(--kt-border-radius);
    box-shadow: var(--kt-shadow-sm);
}

/* --------------------------------------------------------------------------
   Section Headings
   -------------------------------------------------------------------------- */
.section-title {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--kt-dark);
    margin-bottom: 1.25rem;
    position: relative;
}

.section-title::after {
    content: '';
    display: block;
    width: 40px;
    height: 3px;
    background-color: var(--kt-primary);
    border-radius: 3px;
    margin-top: 0.5rem;
}

/* --------------------------------------------------------------------------
   Search Results
   -------------------------------------------------------------------------- */
.search-results-info {
    font-size: 0.95rem;
    color: var(--kt-text-muted);
    margin-bottom: 1.25rem;
}

.no-results {
    text-align: center;
    padding: 3rem 1rem;
}

.no-results i {
    font-size: 3rem;
    color: var(--kt-text-muted);
    margin-bottom: 1rem;
    display: block;
}

.no-results h3 {
    font-weight: 600;
    color: var(--kt-dark);
}

.no-results p {
    color: var(--kt-text-muted);
}

/* --------------------------------------------------------------------------
   Error Pages
   -------------------------------------------------------------------------- */
.error-page {
    text-align: center;
    padding: 5rem 1rem;
}

.error-page .error-code {
    font-size: 5rem;
    font-weight: 800;
    color: var(--kt-primary);
    line-height: 1;
    margin-bottom: 0.5rem;
}

.error-page h2 {
    font-weight: 700;
    color: var(--kt-dark);
    margin-bottom: 0.75rem;
}

.error-page p {
    color: var(--kt-text-muted);
    margin-bottom: 1.5rem;
}

/* --------------------------------------------------------------------------
   Pricing Page
   -------------------------------------------------------------------------- */
.pricing-toggle .btn {
    border-radius: 50px;
    padding: 0.5rem 1.5rem;
    font-weight: 600;
    transition: all var(--kt-transition);
}

.pricing-toggle .btn.active {
    background-color: var(--kt-primary);
    border-color: var(--kt-primary);
    color: #fff;
}

.pricing-card {
    background: var(--kt-card-bg);
    border: 2px solid var(--kt-border-color);
    border-radius: var(--kt-border-radius-lg);
    box-shadow: var(--kt-shadow-sm);
    transition: transform var(--kt-transition), box-shadow var(--kt-transition);
}

.pricing-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--kt-shadow);
}

.pricing-card.pricing-popular {
    border-color: var(--kt-secondary);
    box-shadow: var(--kt-shadow), 0 0 0 1px var(--kt-secondary);
}

.pricing-card .pricing-price {
    font-size: 2rem;
    font-weight: 800;
    color: var(--kt-dark);
}

.pricing-card .pricing-period {
    font-size: 0.9rem;
    color: var(--kt-text-muted);
}

.pricing-card .pricing-promo {
    font-size: 0.8rem;
    color: var(--kt-primary);
    font-weight: 600;
}

.pricing-feature-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.pricing-feature-list li {
    padding: 0.4rem 0;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.95rem;
}

.pricing-feature-list .feature-yes {
    color: var(--kt-secondary);
}

.pricing-feature-list .feature-no {
    color: #ccc;
}

.pricing-feature-list .feature-text-no {
    color: var(--kt-text-muted);
}

/* --------------------------------------------------------------------------
   Theme Toggle
   -------------------------------------------------------------------------- */
.theme-toggle {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--kt-text);
    font-size: 1.1rem;
    padding: 0.5rem;
    line-height: 1;
    transition: color var(--kt-transition);
}

.theme-toggle:hover {
    color: var(--kt-primary);
}

/* --------------------------------------------------------------------------
   Utilities
   -------------------------------------------------------------------------- */
.card-rounded {
    border-radius: var(--kt-border-radius-lg);
}

.shadow-warm {
    box-shadow: var(--kt-shadow);
}

/* --------------------------------------------------------------------------
   Responsive Adjustments
   -------------------------------------------------------------------------- */
@media (max-width: 768px) {
    .hero-search {
        padding: 2.5rem 0;
    }

    .hero-search h1 {
        font-size: 1.65rem;
    }

    .hero-search p {
        font-size: 1rem;
    }

    .category-card {
        padding: 1.25rem 1rem;
    }

    .category-card .category-icon {
        font-size: 2.25rem;
    }

    .category-card .card-title {
        font-size: 0.85rem;
    }

    .business-detail {
        padding: 1.25rem;
    }

    .business-detail .business-header h1 {
        font-size: 1.35rem;
    }

    .section-title {
        font-size: 1.25rem;
    }

    .category-map-container {
        height: 350px;
    }

    .map-page-container {
        height: calc(100vh - 100px);
        min-height: 50vh;
    }

    .map-thumbnail-container {
        height: 200px;
    }

    .business-map-modal-container {
        height: 300px;
    }
}

@media (max-width: 576px) {
    .hero-search {
        padding: 2rem 0;
    }

    .hero-search h1 {
        font-size: 1.4rem;
    }

    .business-card {
        padding: 1.15rem;
    }

    .business-card .business-info {
        gap: 0.5rem;
        flex-direction: column;
    }

    /* Banner mobile adjustments */
    .home-banner .card-title {
        font-size: 1rem !important;
    }

    .home-banner .card-body {
        padding: 10px !important;
    }

    /* Дозволяємо всьому документу скролитись, коли модалка відкрита */
    body.modal-open {
        overflow: auto !important;
        position: relative !important;
    }

    #addRentalModal .modal-dialog {
        margin: 0 !important;
        padding: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        transform: none !important;
    }

    #addRentalModal .modal-content {
        border: none !important;
        border-radius: 0 !important;
        min-height: 100vh !important;
        height: auto !important; /* Дозволяємо контенту розтягувати контейнер */
        display: block !important; /* Скасовуємо Flexbox, він часто блокує скрол */
    }

    #addRentalModal .modal-body {
        overflow: visible !important; /* Тіло модалки не має власного скролу */
        padding: 15px !important;
    }

    #addRentalModal .modal-footer {
        display: flex !important;
        flex-direction: column !important;
        gap: 10px;
        padding: 20px 15px 60px 15px !important;
        border-top: 1px solid var(--kt-border-color);
        background: var(--kt-bg-warm);
    }
}

/* Tab validation error indicator */
.nav-link.tab-has-error {
    color: #dc3545 !important;
}

.business-tab-content .tab-pane {
    padding-top: 1rem;
}

/* Map markers */
.marker-base {
    border-radius: 50%;
    border: 2px solid #ddd;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
    display: flex;
    align-items: center;
    justify-content: center;
}
.marker-emoji {
    background: #fff;
    width: 28px;
    height: 28px;
    font-size: 16px;
}
.marker-emoji-free {
    background: #dbe9ef;
    border-color: #ccc;
    width: 24px;
    height: 24px;
    font-size: 13px;
    filter: saturate(0.3);
}
.marker-dot {
    background: #999;
    width: 14px;
    height: 14px;
    border-color: #fff;
}
.marker-gate {
    background: #5B8C7B;
    width: 14px;
    height: 14px;
    border-color: #fff;
}
.marker-gate-sm {
    background: #5B8C7B;
    width: 12px;
    height: 12px;
    border-color: #fff;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}

/* Markdown description */
.business-description p:last-child { margin-bottom: 0; }
.business-description h1, .business-description h2, .business-description h3 { font-size: 1.1rem; font-weight: 600; }
.business-description ul, .business-description ol { padding-left: 1.25rem; }

/* Price List */
.price-item {
    padding: 0.65rem 0;
    border-bottom: 1px solid var(--bs-border-color-translucent);
}
.price-item:last-child { border-bottom: none; }
.price-name { font-size: 1rem; font-weight: 500; }
.price-value { font-size: 1rem; font-weight: 700; color: var(--bs-emphasis-color); white-space: nowrap; }
.price-value.price-free { color: var(--bs-success); font-size: 0.85rem; text-transform: uppercase; }
.price-category-title {
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--bs-secondary-color);
    border-bottom: 2px solid var(--bs-border-color);
    padding-bottom: 4px;
}

/* Service / Product category tags — matches Ghost .post-card-tag style */
.service-tag {
    font-size: 0.78rem;
    font-weight: 500;
    padding: 0.35em 0.7em;
    border-radius: 50px;
    background-color: var(--kt-primary-light) !important;
    color: var(--kt-primary) !important;
    border: none !important;
    transition: transform 0.15s, filter 0.15s;
}
.service-tag:hover {
    transform: translateY(-1px);
    filter: brightness(0.95);
    color: var(--kt-primary) !important;
}

/* Rental card hover */
.transition-hover {
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}
.transition-hover:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.1) !important;
}

/* EasyMDE Dark Theme */
[data-bs-theme="dark"] .EasyMDEContainer .CodeMirror {
    background-color: var(--kt-card-bg);
    color: var(--kt-dark);
    border-color: var(--kt-border-color);
}
[data-bs-theme="dark"] .EasyMDEContainer .CodeMirror-cursor { border-left-color: var(--kt-dark); }
[data-bs-theme="dark"] .EasyMDEContainer .editor-toolbar {
    background-color: var(--kt-bg-warm);
    border-color: var(--kt-border-color);
}
[data-bs-theme="dark"] .EasyMDEContainer .editor-toolbar button { color: var(--kt-dark); }
[data-bs-theme="dark"] .EasyMDEContainer .editor-toolbar button:hover,
[data-bs-theme="dark"] .EasyMDEContainer .editor-toolbar button.active {
    background-color: var(--kt-border-color);
    color: #fff;
}
[data-bs-theme="dark"] .EasyMDEContainer .editor-toolbar i.separator {
    border-left-color: var(--kt-border-color);
    border-right-color: var(--kt-border-color);
}
[data-bs-theme="dark"] .EasyMDEContainer .editor-preview {
    background-color: var(--kt-card-bg);
    color: var(--kt-dark);
}
[data-bs-theme="dark"] .EasyMDEContainer .CodeMirror .CodeMirror-selected { background: rgba(255, 255, 255, 0.15); }

/* Banner carousel */
.banner-carousel-section {
    background: var(--bs-body-bg);
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}
[data-bs-theme="dark"] .banner-carousel-section {
    border-bottom-color: rgba(255, 255, 255, 0.06);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}
.banner-carousel {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 2px 0;
}
.banner-carousel::-webkit-scrollbar { display: none; }
.banner-slide {
    flex: 0 0 calc(50% - 6px);
    scroll-snap-align: start;
    min-width: 0;
}
@media (max-width: 767.98px) {
    .banner-slide {
        flex: 0 0 100%;
    }
}
.banner-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    border: none;
    background: var(--bs-body-bg);
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
    border-radius: 50%;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    opacity: 0.8;
    transition: opacity 0.2s;
}
.banner-arrow:hover { opacity: 1; }
.banner-arrow-left { left: -8px; }
.banner-arrow-right { right: -8px; }
