        :root {
            --mobile-nav-height: 74px;
            --mobile-bottom-bar-height: 76px;
            --mobile-side-gap: 18px;
            --tap-target: 48px;
        }

        html {
            scroll-behavior: smooth;
            scroll-padding-top: 86px;
        }

        body {
            -webkit-text-size-adjust: 100%;
            text-rendering: optimizeLegibility;
        }

        a,
        button,
        .btn,
        .filter-btn,
        .map-cat-item,
        .tenant-details-toggle {
            -webkit-tap-highlight-color: transparent;
        }

        .btn,
        .iceberg-btn,
        .filter-btn,
        .navbar-toggler {
            touch-action: manipulation;
        }

        .btn-primary-custom,
        .btn-outline-custom,
        .iceberg-btn {
            min-height: var(--tap-target);
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
        }

        .mobile-bottom-bar {
            display: none;
        }

        @media (prefers-reduced-motion: reduce) {
            *,
            *::before,
            *::after {
                scroll-behavior: auto !important;
                animation-duration: 0.01ms !important;
                animation-iteration-count: 1 !important;
                transition-duration: 0.01ms !important;
            }
        }

        @media (max-width: 991.98px) {
            html {
                scroll-padding-top: 82px;
            }

            body {
                padding-bottom: calc(var(--mobile-bottom-bar-height) + env(safe-area-inset-bottom));
                overflow-x: hidden;
            }

            body.mobile-menu-open {
                overflow: hidden;
            }

            .container {
                padding-left: var(--mobile-side-gap);
                padding-right: var(--mobile-side-gap);
            }

            .navbar {
                padding: 10px 0;
                transition: background-color .25s ease, box-shadow .25s ease, backdrop-filter .25s ease;
            }

            .navbar .container {
                position: relative;
            }

            .navbar-brand {
                max-width: 210px;
                padding: 0;
            }

            .navbar-brand img {
                width: auto;
                max-width: 190px;
                max-height: 48px;
                object-fit: contain;
                transition: transform .2s ease, max-height .2s ease;
            }

            .navbar.scrolled .navbar-brand img {
                max-height: 44px;
            }

            .navbar-toggler {
                width: 50px;
                height: 50px;
                border: 0;
                border-radius: 18px;
                background: rgba(255,255,255,.92);
                box-shadow: 0 12px 34px rgba(0,0,0,.12);
                color: #121212;
                padding: 0;
            }

            .navbar-toggler:focus {
                box-shadow: 0 0 0 4px rgba(250,69,0,.2);
            }

            .navbar-collapse {
                position: absolute;
                top: calc(100% + 10px);
                left: var(--mobile-side-gap);
                right: var(--mobile-side-gap);
                background: rgba(255,255,255,.96);
                border: 1px solid rgba(18,18,18,.08);
                border-radius: 26px;
                box-shadow: 0 28px 80px rgba(0,0,0,.22);
                backdrop-filter: blur(20px);
                -webkit-backdrop-filter: blur(20px);
                padding: 12px;
                max-height: calc((var(--vh, 1vh) * 100) - 96px);
                overflow-y: auto;
            }

            .navbar-nav {
                gap: 4px;
                margin-bottom: 10px !important;
            }

            .navbar-nav .nav-link {
                min-height: 50px;
                display: flex;
                align-items: center;
                border-radius: 16px;
                padding: 14px 16px !important;
                color: #171717 !important;
                font-weight: 800;
                letter-spacing: -.01em;
                background: rgba(0,0,0,.025);
            }

            .navbar-nav .nav-link:active,
            .navbar-nav .nav-link:hover {
                background: rgba(250,69,0,.09);
                color: #FA4500 !important;
            }

            .navbar-collapse .d-flex {
                display: block !important;
            }

            .nav-cta-btn {
                width: 100%;
                min-height: 54px;
                border-radius: 18px;
                font-weight: 800;
            }

            .hero {
                min-height: calc(var(--vh, 1vh) * 100);
                padding-top: 102px;
                padding-bottom: 42px;
                display: flex;
                align-items: flex-end;
            }

            .hero-content {
                width: 100%;
                padding-bottom: 36px;
            }

            .hero-subtitle {
                font-size: clamp(34px, 10vw, 58px);
                line-height: .98;
                letter-spacing: -.055em;
                margin-bottom: 18px;
                max-width: 96%;
            }

            .hero-text {
                font-size: 16px;
                line-height: 1.55;
                margin-bottom: 24px;
                max-width: 96%;
            }

            .hero-actions {
                flex-direction: column;
                align-items: stretch;
                gap: 12px !important;
            }

            .hero-actions .btn {
                width: 100%;
                min-height: 56px;
                border-radius: 18px;
                font-size: 16px;
                font-weight: 800;
            }

            .quick-nav {
                position: relative;
                z-index: 4;
                margin-top: -34px;
                padding-bottom: 6px;
            }

            .quick-nav .row {
                display: flex;
                flex-wrap: nowrap;
                justify-content: flex-start !important;
                overflow-x: auto;
                gap: 10px;
                margin-left: 0;
                margin-right: calc(var(--mobile-side-gap) * -1);
                padding: 2px var(--mobile-side-gap) 10px 0;
                scroll-snap-type: x mandatory;
                -webkit-overflow-scrolling: touch;
                scrollbar-width: none;
            }

            .quick-nav .row::-webkit-scrollbar,
            #tenantFilters::-webkit-scrollbar,
            .map-cat-list::-webkit-scrollbar,
            .iceberg-scroll-mobile::-webkit-scrollbar {
                display: none;
            }

            .quick-nav .row > [class*="col-"] {
                flex: 0 0 132px;
                width: 132px;
                max-width: 132px;
                padding-left: 0;
                padding-right: 0;
                scroll-snap-align: start;
            }

            .quick-card {
                min-height: 104px;
                border-radius: 24px;
                padding: 18px 14px;
                box-shadow: 0 18px 45px rgba(0,0,0,.11);
            }

            .quick-card i {
                font-size: 26px;
                margin-bottom: 10px;
            }

            .quick-card span {
                font-size: 14px;
                font-weight: 800;
            }

            .iceberg-section,
            .about-section,
            .promo-section,
            .tenants-section,
            .b2b-section,
            .contacts-section,
            .map-section {
                padding-top: 58px !important;
                padding-bottom: 58px !important;
            }

            .display-4,
            .display-5,
            .iceberg-title,
            .about-section h2,
            .promo-section h2,
            .tenants-section h2,
            .b2b-section h2,
            .contacts-section h2,
            .map-section h2 {
                font-size: clamp(28px, 8.4vw, 42px) !important;
                line-height: 1.08;
                letter-spacing: -.035em;
            }

            .fs-5,
            .promo-section p,
            .map-section p,
            .b2b-section p {
                font-size: 16px !important;
                line-height: 1.55;
            }

            .iceberg-stats-item {
                min-height: 132px;
                padding: 22px 12px;
            }

            .iceberg-stats-num {
                font-size: clamp(30px, 9vw, 44px);
            }

            .iceberg-stats-text {
                font-size: 13px;
                line-height: 1.3;
            }

            .advantage-item {
                align-items: flex-start;
                gap: 14px;
                padding: 16px;
                border-radius: 22px;
                background: #fff;
                box-shadow: 0 14px 36px rgba(0,0,0,.06);
                margin-bottom: 14px;
            }

            .advantage-icon {
                width: 46px;
                height: 46px;
                flex: 0 0 46px;
            }

            .about-images {
                min-height: auto;
                margin-top: 10px;
            }

            .about-img-main,
            .about-img-sub {
                position: relative !important;
                inset: auto !important;
                width: 100% !important;
                height: auto !important;
                border-radius: 28px;
            }

            .about-img-main {
                aspect-ratio: 4 / 3;
                object-fit: cover;
            }

            .about-img-sub {
                display: none;
            }

            #cinema.iceberg-section.container {
                padding-left: var(--mobile-side-gap);
                padding-right: var(--mobile-side-gap);
            }

            .iceberg-cinema-block {
                min-height: 540px;
                border-radius: 30px;
                overflow: hidden;
            }

            .iceberg-cinema-content {
                padding: 34px 22px;
            }

            .iceberg-cinema-content .d-flex {
                flex-direction: column;
                align-items: stretch;
                gap: 12px !important;
            }

            .iceberg-cinema-content .iceberg-btn {
                width: 100%;
                min-height: 54px;
            }

            #promo .row.g-4,
            .iceberg-scroll-mobile {
                display: flex;
                flex-wrap: nowrap;
                overflow-x: auto;
                gap: 14px;
                margin-left: 0;
                margin-right: calc(var(--mobile-side-gap) * -1);
                padding-right: var(--mobile-side-gap);
                scroll-snap-type: x mandatory;
                -webkit-overflow-scrolling: touch;
                scrollbar-width: none;
            }

            #promo .row.g-4 > [class*="col-"],
            .iceberg-scroll-mobile > [class*="col-"] {
                flex: 0 0 84vw;
                width: 84vw;
                max-width: 84vw;
                padding-left: 0;
                padding-right: 0;
                scroll-snap-align: start;
            }

            .promo-card,
            .iceberg-news-card {
                height: 100%;
                border-radius: 28px;
                overflow: hidden;
            }

            .promo-img-wrap,
            .iceberg-news-img {
                aspect-ratio: 4 / 3;
            }

            .promo-img,
            .iceberg-news-img img {
                width: 100%;
                height: 100%;
                object-fit: cover;
            }

            .promo-content,
            .iceberg-news-body {
                padding: 18px;
            }

            .map-section .row.align-items-center {
                margin-bottom: 22px !important;
            }

            .map-section .btn {
                width: 100%;
                min-height: 54px;
                border-radius: 18px;
            }

            .interactive-map-wrapper {
                border-radius: 28px;
                overflow: hidden;
            }

            .map-sidebar {
                border-right: 0 !important;
                border-bottom: 1px solid rgba(0,0,0,.06);
            }

            .map-cat-list {
                display: flex;
                overflow-x: auto;
                gap: 10px;
                padding: 14px;
                scroll-snap-type: x mandatory;
                -webkit-overflow-scrolling: touch;
                scrollbar-width: none;
            }

            .map-cat-item {
                flex: 0 0 238px;
                min-height: 82px;
                border-radius: 22px;
                scroll-snap-align: start;
                background: rgba(0,0,0,.025);
            }

            .map-cat-item .bi-chevron-right {
                display: none;
            }

            .map-visual-area {
                min-height: 300px;
                padding: 14px;
            }

            .map-blueprint {
                min-height: 280px;
                border-radius: 24px;
                overflow: hidden;
            }

            .map-zone span {
                font-size: 12px;
                line-height: 1.2;
                text-align: center;
            }

            #tenantFilters {
                position: sticky;
                top: 70px;
                z-index: 6;
                display: flex !important;
                flex-wrap: nowrap !important;
                justify-content: flex-start !important;
                gap: 8px !important;
                overflow-x: auto;
                margin-left: calc(var(--mobile-side-gap) * -1);
                margin-right: calc(var(--mobile-side-gap) * -1);
                padding: 8px var(--mobile-side-gap) 12px;
                background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.86));
                backdrop-filter: blur(16px);
                -webkit-backdrop-filter: blur(16px);
                scroll-snap-type: x proximity;
                scrollbar-width: none;
            }

            .filter-btn {
                flex: 0 0 auto;
                min-height: 44px;
                border-radius: 999px;
                padding: 0 17px;
                white-space: nowrap;
                scroll-snap-align: start;
                font-size: 14px;
                font-weight: 800;
            }

            #tenantGrid {
                row-gap: 14px !important;
                margin-bottom: 28px !important;
            }

            #tenantGrid .tenant-item {
                flex: 0 0 100%;
                width: 100%;
                max-width: 100%;
            }

            .tenant-card-pro {
                min-height: auto;
                height: auto;
                padding: 18px;
                border-radius: 26px;
            }

            .tenant-logo-ph {
                width: 52px;
                height: 52px;
                flex: 0 0 52px;
                border-radius: 17px;
            }

            .tenant-title {
                font-size: 20px;
                line-height: 1.18;
                letter-spacing: -.02em;
            }

            .tenant-cat-label {
                font-size: 11px;
                line-height: 1.2;
            }

            .tenant-short-desc {
                font-size: 14px;
                line-height: 1.5;
                margin-bottom: 16px;
            }

            .tenant-details-toggle {
                min-height: 48px;
                border-radius: 16px;
                font-weight: 800;
            }

            .tenant-contacts-reveal {
                margin-top: 14px;
            }

            .contact-line {
                font-size: 14px;
                line-height: 1.35;
            }

            #allTenantsAction .btn,
            .tenants-section > .container > .text-center.fade-up .btn {
                width: 100%;
                min-height: 54px;
                border-radius: 18px;
            }

            .b2b-content {
                gap: 8px;
            }

            .b2b-list {
                margin-bottom: 22px;
                padding-left: 0;
            }

            .b2b-list li {
                display: flex;
                align-items: flex-start;
                gap: 10px;
                font-size: 15px;
                line-height: 1.45;
                margin-bottom: 13px;
            }

            .b2b-section .btn,
            .contacts-section .btn {
                width: 100%;
                min-height: 54px;
                border-radius: 18px;
            }

            .area-block {
                padding: 16px 0;
            }

            .area-val {
                font-size: 28px;
            }

            .contacts-section .row {
                gap: 8px;
            }

            .contact-item {
                margin-bottom: 20px;
            }

            .contact-val {
                font-size: 18px;
                line-height: 1.35;
            }

            .contact-iframe-wrapper {
                min-height: 320px;
                border-radius: 28px;
                overflow: hidden;
            }

            .footer {
                padding-bottom: 42px;
            }

            .footer-bottom {
                gap: 8px;
                flex-direction: column;
                align-items: flex-start;
            }

            .modal-dialog {
                min-height: 100%;
                margin: 0;
                display: flex;
                align-items: flex-end;
            }

            .rent-modal .modal-content {
                width: 100%;
                max-height: 92vh;
                border-radius: 30px 30px 0 0;
                overflow: hidden;
            }

            .rent-modal .modal-header {
                align-items: flex-start;
                padding: 22px 20px 14px;
            }

            .rent-modal .modal-title {
                font-size: 24px;
                line-height: 1.1;
            }

            .rent-modal .modal-subtitle {
                font-size: 14px;
                line-height: 1.45;
                margin: 8px 0 0;
            }

            .rent-modal .modal-body {
                max-height: calc(92vh - 118px);
                overflow-y: auto;
                padding: 0 20px calc(24px + env(safe-area-inset-bottom));
            }

            .rent-form .form-label {
                font-size: 13px;
                font-weight: 800;
                margin-bottom: 6px;
            }

            .rent-form .form-control,
            .rent-form .form-select {
                min-height: 52px;
                border-radius: 16px;
                font-size: 16px;
            }

            .rent-form textarea.form-control {
                min-height: 118px;
            }

            .rent-submit-row .btn {
                width: 100%;
                min-height: 56px;
                border-radius: 18px;
                font-weight: 800;
            }

            .mobile-bottom-bar {
                position: fixed;
                left: 10px;
                right: 10px;
                bottom: calc(10px + env(safe-area-inset-bottom));
                z-index: 1040;
                height: var(--mobile-bottom-bar-height);
                display: grid;
                grid-template-columns: 1fr 1fr 1.12fr;
                gap: 8px;
                padding: 8px;
                border: 1px solid rgba(18,18,18,.08);
                border-radius: 24px;
                background: rgba(255,255,255,.94);
                box-shadow: 0 18px 60px rgba(0,0,0,.18);
                backdrop-filter: blur(18px);
                -webkit-backdrop-filter: blur(18px);
            }

            .mobile-bottom-bar a,
            .mobile-bottom-bar button {
                min-width: 0;
                min-height: 58px;
                display: flex;
                flex-direction: column;
                align-items: center;
                justify-content: center;
                gap: 3px;
                border: 0;
                border-radius: 18px;
                background: rgba(0,0,0,.035);
                color: #151515;
                text-decoration: none;
                font-size: 11px;
                font-weight: 900;
                line-height: 1.1;
            }

            .mobile-bottom-bar i {
                font-size: 20px;
                line-height: 1;
            }

            .mobile-bottom-bar .mobile-bottom-primary {
                background: #FA4500;
                color: #fff;
                box-shadow: 0 10px 26px rgba(250,69,0,.34);
            }
        }

        @media (max-width: 575.98px) {
            .navbar-brand img {
                max-width: 172px;
            }

            .hero-subtitle br {
                display: none;
            }

            .hero-text {
                font-size: 15px;
            }

            #promo .row.g-4 > [class*="col-"],
            .iceberg-scroll-mobile > [class*="col-"] {
                flex-basis: 86vw;
                width: 86vw;
                max-width: 86vw;
            }

            .map-cat-item {
                flex-basis: 226px;
            }
        }


        /* Tenant cards click modal */
        .tenant-card-pro {
            position: relative;
            cursor: pointer;
            transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
        }

        .tenant-card-pro:hover {
            transform: translateY(-4px);
        }

        .tenant-card-pro:focus-visible {
            outline: 3px solid rgba(250, 69, 0, .28);
            outline-offset: 4px;
        }

        .tenant-card-pro[data-tenant-photos]::after {
            content: "Есть фото";
            position: absolute;
            right: 16px;
            bottom: 14px;
            display: inline-flex;
            align-items: center;
            min-height: 28px;
            padding: 0 11px;
            border-radius: 999px;
            background: rgba(250, 69, 0, .1);
            color: #FA4500;
            font-size: 11px;
            font-weight: 900;
            letter-spacing: .02em;
            text-transform: uppercase;
        }

        .tenant-detail-modal .modal-content {
            border: 0;
            border-radius: 32px;
            overflow: hidden;
            box-shadow: 0 28px 90px rgba(0,0,0,.22);
        }

        .tenant-detail-modal .modal-header {
            align-items: flex-start;
            border-bottom: 1px solid rgba(17,24,39,.08);
            padding: 24px 26px 18px;
        }

        .tenant-detail-modal .modal-title {
            margin: 0;
            font-size: clamp(28px, 4vw, 46px);
            line-height: .98;
            font-weight: 900;
            letter-spacing: -.05em;
        }

        .tenant-modal-category {
            display: inline-flex;
            align-items: center;
            min-height: 30px;
            margin-bottom: 10px;
            padding: 0 12px;
            border-radius: 999px;
            background: rgba(250, 69, 0, .1);
            color: #FA4500;
            font-size: 12px;
            font-weight: 900;
            text-transform: uppercase;
            letter-spacing: .08em;
        }

        .tenant-detail-modal .modal-body {
            padding: 24px 26px 28px;
        }

        .tenant-modal-gallery {
            display: grid;
            grid-template-columns: minmax(0, 1.45fr) minmax(150px, .75fr);
            gap: 12px;
            margin-bottom: 22px;
        }

        .tenant-modal-gallery.is-empty {
            display: block;
        }

        .tenant-modal-photo {
            position: relative;
            min-height: 148px;
            border-radius: 24px;
            overflow: hidden;
            background: #f3f4f6;
        }

        .tenant-modal-photo:first-child {
            min-height: 312px;
            grid-row: span 2;
        }

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

        .tenant-modal-empty-photo {
            min-height: 250px;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 12px;
            border-radius: 26px;
            background: linear-gradient(135deg, rgba(250,69,0,.08), rgba(17,24,39,.05));
            color: #6b7280;
            text-align: center;
            padding: 24px;
        }

        .tenant-modal-empty-photo i {
            width: 56px;
            height: 56px;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            border-radius: 18px;
            background: #fff;
            color: #FA4500;
            font-size: 26px;
            box-shadow: 0 14px 35px rgba(0,0,0,.08);
        }

        .tenant-modal-desc {
            margin: 0;
            color: #4b5563;
            font-size: 17px;
            line-height: 1.65;
        }

        .tenant-modal-meta {
            display: flex;
            flex-wrap: wrap;
            gap: 10px;
            margin-top: 18px;
        }

        .tenant-modal-meta span {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            min-height: 38px;
            padding: 0 14px;
            border-radius: 999px;
            background: #f3f4f6;
            color: #111827;
            font-size: 14px;
            font-weight: 800;
        }

        @media (max-width: 767.98px) {
            .tenant-card-pro[data-tenant-photos]::after {
                right: 14px;
                bottom: 12px;
                font-size: 10px;
            }

            .tenant-detail-modal .modal-content {
                width: 100%;
                max-height: 92vh;
                border-radius: 30px 30px 0 0;
            }

            .tenant-detail-modal .modal-header {
                padding: 20px 20px 14px;
            }

            .tenant-detail-modal .modal-title {
                font-size: 30px;
            }

            .tenant-detail-modal .modal-body {
                max-height: calc(92vh - 108px);
                overflow-y: auto;
                padding: 18px 20px calc(24px + env(safe-area-inset-bottom));
            }

            .tenant-modal-gallery {
                grid-template-columns: 1fr;
                gap: 10px;
                margin-bottom: 18px;
            }

            .tenant-modal-photo,
            .tenant-modal-photo:first-child {
                min-height: 186px;
                grid-row: auto;
                border-radius: 22px;
            }

            .tenant-modal-photo:nth-child(n+3) {
                display: none;
            }

            .tenant-modal-desc {
                font-size: 15px;
                line-height: 1.55;
            }
        }
