﻿/*
 * Apartment detail page and apartment CTA sections
 * Extracted from lamer-public.css lines 1627-4247.
 */

@media (prefers-reduced-motion: reduce) {
    .apartment-card,
    .apartment-image img,
    .apartment-link,
    .apartment-contact-link,
    .apartment-tour-link,
    .apartment-mini-spec,
    .apartment-link svg,
    .apartment-contact-link svg,
    .apartment-tour-link svg {
        animation: none !important;
        transition: none !important;
    }
}

@keyframes apartmentFadeUp {
    from {
        opacity: 0;
        transform: translateY(22px);
        filter: blur(5px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
        filter: blur(0);
    }
}

@keyframes apartmentMediaIn {
    from {
        opacity: 0;
        transform: translateY(18px) scale(.985);
        filter: blur(4px) saturate(.9);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
        filter: blur(0) saturate(1);
    }
}

html.apartment-motion-ready .apartment-reveal {
    opacity: 0;
    transform: translateY(24px);
    filter: blur(5px);
    transition:
        opacity .58s ease,
        transform .58s cubic-bezier(.18,.84,.28,1),
        filter .58s ease;
    transition-delay: var(--reveal-delay, 0s);
    will-change: opacity, transform, filter;
}

html.apartment-motion-ready .apartment-reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
}

.page-hero {
    padding: 160px min(5vw, 70px) 70px;
    background: linear-gradient(135deg, #07100e, #13231f);
    color: #fff;
}
.page-hero-inner { width: min(1160px, 100%); margin: 0 auto; }
.page-hero p { max-width: 680px; color: rgba(255,255,255,.72); font-size: 20px; line-height: 1.6; }

.filter-bar {
    width: min(1160px, 100%);
    margin: 0 auto 28px;
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
.filter-bar select, .filter-bar button, .filter-bar a {
    min-height: 46px;
    border: 1px solid var(--line);
    background: #fff;
    padding: 0 16px;
    font: inherit;
}
.filter-bar button { background: var(--deep); color: #fff; font-weight: 700; }

.apartments-index-hero {
    padding: 168px min(5vw, 70px) 74px;
    color: #fff;
    background:
        linear-gradient(90deg, rgba(5,9,8,.9), rgba(5,9,8,.64) 52%, rgba(5,9,8,.22)),
        var(--apartments-hero-image) center/cover no-repeat,
        linear-gradient(135deg, #07100e 0%, #13231f 58%, #080d0b 100%);
}
.apartments-index-hero-inner {
    width: min(1160px, 100%);
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 390px;
    gap: 48px;
    align-items: end;
}
.apartments-index-copy h1 {
    max-width: 800px;
    margin: 0;
    color: #fff;
    font-family: "Roboto", system-ui, sans-serif;
    font-size: clamp(44px, 5.4vw, 78px);
    line-height: .96;
    letter-spacing: 0;
}
.apartments-index-copy p {
    max-width: 680px;
    margin: 24px 0 0;
    color: rgba(255,255,255,.82);
    font-size: 18px;
    line-height: 1.68;
}
.apartments-index-proof {
    display: grid;
    grid-template-columns: 1fr;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.16);
    border-radius: 8px;
    background: rgba(7,16,14,.56);
    box-shadow: 0 24px 70px rgba(0,0,0,.24);
    backdrop-filter: blur(12px);
}
.apartments-index-proof article {
    display: grid;
    grid-template-columns: 90px 1fr;
    gap: 18px;
    align-items: center;
    padding: 22px 24px;
    border-bottom: 1px solid rgba(255,255,255,.1);
}
.apartments-index-proof article:last-child {
    border-bottom: 0;
}
.apartments-index-proof strong {
    color: var(--accent);
    font-size: 40px;
    line-height: 1;
}
.apartments-index-proof span {
    color: rgba(255,255,255,.72);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .1em;
}
.apartments-index-section {
    background: #fbfaf8;
}
.apartments-index-toolbar {
    width: min(1160px, 100%);
    margin: 0 auto 22px;
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 24px;
}
.apartments-index-toolbar h2 {
    margin: 0;
    color: var(--ink);
    font-family: "Roboto", system-ui, sans-serif;
    font-size: clamp(30px, 3vw, 44px);
    line-height: 1.04;
}
.apartments-reset-link {
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 16px;
    border: 1px solid rgba(15,23,42,.12);
    border-radius: 8px;
    color: var(--ink);
    background: #fff;
    font-weight: 900;
    text-decoration: none;
}
.apartments-filter-bar {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr)) auto;
    gap: 12px;
    align-items: end;
    padding: 16px;
    border: 1px solid rgba(15,23,42,.08);
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 14px 34px rgba(15,23,42,.06);
}
.apartments-filter-bar label {
    display: grid;
    gap: 7px;
}
.apartments-filter-bar label span {
    color: #667085;
    font-size: 11px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .08em;
}
.apartments-filter-bar select,
.apartments-filter-bar button {
    width: 100%;
    border-radius: 6px;
}
.apartments-filter-bar button {
    min-width: 138px;
    border-color: var(--deep);
}
.apartments-seo-strip {
    width: min(1160px, 100%);
    margin: 0 auto 30px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.apartments-seo-strip article {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 4px 14px;
    align-items: start;
    padding: 20px;
    background: #fff;
    border: 1px solid rgba(15,23,42,.08);
    border-radius: 8px;
    box-shadow: 0 16px 40px rgba(15,23,42,.06);
}
.apartments-seo-strip span {
    grid-row: span 2;
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    color: #8f7436;
    background: rgba(183,154,88,.11);
    border: 1px solid rgba(183,154,88,.22);
    border-radius: 999px;
    font-size: 12px;
    font-weight: 900;
}
.apartments-seo-strip strong {
    color: var(--ink);
    font-size: 17px;
    line-height: 1.15;
}
.apartments-seo-strip p {
    grid-column: 2;
    margin: 0;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.5;
}
.apartments-availability-strip {
    margin-bottom: 30px;
}
.apartments-pagination {
    width: min(1160px, 100%);
    margin: 32px auto 0;
}
.apartments-seo-content {
    width: min(1160px, 100%);
    margin: clamp(34px, 5vw, 62px) auto 0;
    padding-top: clamp(30px, 4vw, 48px);
    border-top: 1px solid rgba(15,23,42,.08);
}
.apartments-seo-content-head {
    display: grid;
    gap: 12px;
    max-width: 900px;
}
.apartments-seo-content-head h2 {
    margin: 0;
    color: var(--ink);
    font-size: clamp(30px, 3vw, 44px);
    line-height: 1.06;
    letter-spacing: 0;
}
.apartments-seo-content-head p {
    margin: 0;
    color: var(--muted);
    font-size: 17px;
    line-height: 1.65;
}
.apartments-empty-state {
    grid-column: 1 / -1;
    padding: 42px;
    border: 1px solid rgba(15,23,42,.08);
    border-radius: 8px;
    background: #fff;
    text-align: center;
    box-shadow: 0 18px 44px rgba(15,23,42,.06);
}
.apartments-empty-state h2 {
    margin: 0;
    color: var(--ink);
    font-size: 30px;
}
.apartments-empty-state p {
    max-width: 620px;
    margin: 12px auto 22px;
    color: var(--muted);
    line-height: 1.6;
}

.availability-strip {
    width: min(1160px, 100%);
    margin: 0 auto 28px;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
}
.availability-strip article {
    background: #fff;
    border: 1px solid var(--line);
    padding: 20px;
}
.availability-strip strong { display: block; font-size: 18px; }
.availability-strip span {
    display: block;
    margin: 5px 0 14px;
    color: var(--muted);
    font-size: 13px;
}
.availability-strip div {
    display: grid;
    gap: 6px;
    color: var(--muted);
}
.availability-strip b {
    color: var(--accent-2);
    margin-right: 6px;
}

.detail-layout {
    width: min(1160px, 100%);
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 36px;
}
.detail-media img { width: 100%; max-height: 620px; object-fit: cover; }
.spec-box { background: #fff; border: 1px solid var(--line); padding: 28px; position: sticky; top: 92px; }
.spec-row { display: flex; justify-content: space-between; gap: 18px; padding: 14px 0; border-bottom: 1px solid var(--line); }
.spec-row:last-child { border-bottom: 0; }
.content-copy { font-size: 18px; line-height: 1.75; color: #344054; }

.apartment-detail-shell {
    width: min(1160px, 100%);
    margin: 0 auto;
}

.apartment-detail-hero {
    position: relative;
    overflow: hidden;
    padding: 136px min(5vw, 70px) 58px;
    background:
        radial-gradient(circle at 18% 18%, rgba(183,154,88,.22), transparent 34%),
        linear-gradient(135deg, #07100e 0%, #13211c 58%, #080d0b 100%);
    color: #fff;
}

.apartment-detail-hero::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 1px;
    background: rgba(255,255,255,.14);
}

.apartment-detail-hero .apartment-detail-shell {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, .95fr) minmax(360px, 1.05fr);
    gap: clamp(28px, 5vw, 58px);
    align-items: end;
}

.apartment-detail-copy,
.apartment-detail-copy .apartment-detail-kicker,
.apartment-detail-copy h1,
.apartment-detail-copy > p:not(.apartment-detail-kicker),
.apartment-detail-actions {
    animation: apartmentFadeUp .62s ease both;
}

.apartment-detail-copy {
    position: relative;
    z-index: 3;
    animation-duration: .68s;
}
.apartment-detail-copy .apartment-detail-kicker { animation-delay: .05s; }
.apartment-detail-copy h1 { animation-delay: .11s; }
.apartment-detail-copy > p:not(.apartment-detail-kicker) { animation-delay: .17s; }
.apartment-detail-actions { animation-delay: .23s; }

.apartment-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin-bottom: 24px;
    color: rgba(255,255,255,.62);
    font-size: 13px;
    font-weight: 800;
}

.apartment-breadcrumb a {
    color: rgba(255,255,255,.78);
}

.apartment-breadcrumb a:hover,
.apartment-breadcrumb strong {
    color: #fff;
}

.apartment-detail-kicker {
    margin: 0 0 12px;
    color: #d7be72;
    font-size: 13px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.apartment-detail-copy h1 {
    max-width: 780px;
    margin: 0;
    color: #fff;
    font-family: "Roboto", system-ui, sans-serif;
    font-size: clamp(46px, 5.7vw, 86px);
    line-height: .96;
}

.apartment-detail-copy > p:not(.apartment-detail-kicker) {
    max-width: 640px;
    margin: 24px 0 0;
    color: rgba(255,255,255,.76);
    font-size: 18px;
    line-height: 1.7;
}

.apartment-detail-actions {
    position: relative;
    z-index: 4;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 30px;
}

.apartment-detail-actions .btn-primary,
.apartment-detail-actions .btn-outline {
    min-height: 52px;
    padding: 0 22px;
    border-radius: 8px;
}

.apartment-detail-actions .btn-primary {
    color: #fff;
    background: linear-gradient(135deg, #b79a58, #8f7436);
}

.apartment-detail-actions .btn-outline {
    color: #fff;
    border-color: rgba(255,255,255,.32);
    background: rgba(255,255,255,.06);
}

.apartment-detail-actions .apartment-detail-tour-link {
    background: rgba(8,17,15,.72);
    border-color: rgba(255,255,255,.28);
}

.apartment-detail-media {
    position: relative;
    min-height: clamp(480px, 48vw, 660px);
    overflow: hidden;
    background: #0b1411;
    box-shadow: 0 32px 80px rgba(0,0,0,.32);
    animation: apartmentMediaIn .76s .14s ease both;
}

.apartment-hero-slider {
    position: absolute;
    inset: 0;
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
}

.apartment-hero-slider::-webkit-scrollbar {
    display: none;
}

.apartment-hero-slider figure {
    position: relative;
    flex: 0 0 100%;
    height: 100%;
    margin: 0;
    scroll-snap-align: start;
}

.apartment-detail-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.apartment-hero-controls {
    position: absolute;
    right: 18px;
    top: 18px;
    z-index: 2;
    display: flex;
    gap: 8px;
}

.apartment-hero-controls button {
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
    padding: 0;
    color: #fff;
    background: rgba(7,16,14,.62);
    border: 1px solid rgba(255,255,255,.18);
    backdrop-filter: blur(16px);
    cursor: pointer;
    transition: transform .22s ease, background .22s ease;
}

.apartment-hero-controls button:hover {
    transform: translateY(-2px);
    background: rgba(183,154,88,.88);
}

.apartment-hero-controls svg {
    width: 22px;
    height: 22px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2.4;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.apartment-detail-status {
    position: absolute;
    left: 18px;
    right: 18px;
    bottom: 18px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 16px 18px;
    color: #fff;
    background: rgba(7,16,14,.82);
    border: 1px solid rgba(255,255,255,.15);
    backdrop-filter: blur(18px);
}

.apartment-detail-status span {
    color: #d7be72;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.apartment-detail-status strong {
    font-size: 20px;
}

@media (min-width: 641px) {
    .apartment-detail-hero {
        min-height: clamp(650px, 82vh, 860px);
        padding: 0;
        background: #07100e;
    }

    .apartment-detail-hero::before {
        content: "";
        position: absolute;
        inset: 0;
        z-index: 1;
        pointer-events: none;
        background:
            linear-gradient(90deg, rgba(7,16,14,.76) 0%, rgba(7,16,14,.48) 42%, rgba(7,16,14,.18) 74%, rgba(7,16,14,.1) 100%),
            linear-gradient(180deg, rgba(7,16,14,.38) 0%, rgba(7,16,14,.08) 46%, rgba(7,16,14,.62) 100%);
    }

    .apartment-detail-hero::after {
        z-index: 3;
    }

    .apartment-detail-hero .apartment-detail-shell {
        width: 100%;
        max-width: none;
        min-height: inherit;
        padding: 136px min(5vw, 70px) 70px;
        grid-template-columns: minmax(0, 690px);
        gap: 0;
        align-items: end;
    }

    .apartment-detail-copy {
        width: min(620px, 100%);
        padding: 30px 32px 32px;
        background: rgba(3, 8, 7, .68);
        border: 1px solid rgba(255,255,255,.13);
        border-radius: 8px;
        box-shadow: 0 24px 70px rgba(0,0,0,.24);
        backdrop-filter: blur(14px);
    }

    .apartment-breadcrumb {
        margin-bottom: 18px;
    }

    .apartment-detail-kicker {
        margin-bottom: 10px;
        font-size: 12px;
    }

    .apartment-detail-copy h1 {
        max-width: 560px;
        font-size: clamp(38px, 4vw, 62px);
        line-height: 1;
    }

    .apartment-detail-copy > p:not(.apartment-detail-kicker) {
        max-width: 540px;
        margin-top: 18px;
        font-size: 16px;
        line-height: 1.62;
    }

    .apartment-detail-actions {
        margin-top: 24px;
    }

    .apartment-detail-actions .btn-primary,
    .apartment-detail-actions .btn-outline {
        min-height: 48px;
        padding: 0 18px;
    }

    .apartment-detail-media {
        position: absolute;
        inset: 0;
        z-index: 0;
        width: 100%;
        height: 100%;
        min-height: 100%;
        box-shadow: none;
        animation-duration: .82s;
    }

    .apartment-detail-media img {
        transform: scale(1.015);
    }

    .apartment-hero-controls {
        top: auto;
        right: min(5vw, 70px);
        bottom: 34px;
    }

    .apartment-detail-status {
        display: none;
    }
}

.apartment-detail-section {
    padding: clamp(58px, 7vw, 96px) min(5vw, 70px);
    background: #fbfaf8;
    color: var(--ink);
}

.apartment-compartment-section {
    padding-bottom: 24px;
}

.apartment-story-section {
    padding-top: 24px;
}

.apartment-decision-section {
    padding-top: 0;
    padding-bottom: 22px;
}

.apartment-decision-section + .apartment-compartment-section {
    padding-top: 22px;
}

.apartment-location-section {
    padding-bottom: 26px;
}

.apartment-location-section + .section {
    padding-top: 28px;
}

.apartment-location-section + .apartment-final-cta-section,
.section + .apartment-final-cta-section {
    padding-top: 30px;
}

.apartment-detail-soft {
    background: #f4f0e8;
}

.apartment-detail-summary-section {
    padding-top: 22px;
    padding-bottom: 22px;
    background:
        radial-gradient(circle at 12% 0%, rgba(183,154,88,.13), transparent 30%),
        linear-gradient(180deg, #fbfaf8 0%, #f6f1e7 100%);
}

@media (min-width: 981px) {
    .apartment-detail-section {
        padding-top: clamp(34px, 4vw, 54px);
        padding-bottom: clamp(34px, 4vw, 54px);
    }

    .apartment-detail-summary-section {
        padding-top: 16px;
        padding-bottom: 14px;
    }

    .apartment-compartment-section {
        padding-top: 24px;
        padding-bottom: 12px;
    }

    .apartment-story-section {
        padding-top: 12px;
        padding-bottom: 26px;
    }

    .apartment-inline-gallery-section {
        padding-top: 0;
        padding-bottom: 32px;
    }

    .apartment-detail-soft {
        padding-top: 34px;
        padding-bottom: 34px;
    }

    .apartment-location-section {
        padding-top: 32px;
        padding-bottom: 14px;
    }

    .apartment-location-section + .section {
        padding-top: 26px;
        padding-bottom: 34px;
    }

    .apartment-location-section + .apartment-final-cta-section,
    .section + .apartment-final-cta-section {
        padding-top: 22px;
    }

    .apartment-compartment-card {
        padding: 28px;
        border-radius: 8px;
        background: #fff;
        box-shadow: none;
    }

    .apartment-compartment-card-head {
        margin-bottom: 18px;
        padding-bottom: 14px;
    }

    .apartment-compartment-rows {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 10px;
    }

    .apartment-compartment-rows article {
        min-height: 126px;
        grid-template-columns: 1fr;
        gap: 12px;
        align-content: space-between;
        padding: 18px;
        border-color: rgba(15,23,42,.08);
        border-radius: 8px;
        background: #fbfaf8;
        box-shadow: none;
    }

    .apartment-compartment-rows article::before {
        display: none;
    }

    .apartment-compartment-rows article > div {
        display: grid;
        gap: 10px;
    }

    .apartment-compartment-icon {
        width: 42px;
        height: 42px;
        color: #8f7436;
        background: transparent;
        border: 1px solid rgba(143,116,54,.32);
        border-radius: 999px;
        box-shadow: none;
    }

    .apartment-compartment-rows article strong {
        font-size: 16px;
    }

    .apartment-compartment-rows article b {
        font-size: 20px;
    }

    .apartment-compartment-rows article:hover {
        transform: translateY(-2px);
        border-color: rgba(143,116,54,.28);
        background: #fff;
        box-shadow: none;
    }

    .apartment-compartment-rows article:hover .apartment-compartment-icon {
        transform: none;
        color: #07100e;
        background: rgba(183,154,88,.16);
    }
}

.apartment-summary-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    overflow: visible;
    background: transparent;
    border: 0;
    box-shadow: none;
}

.apartment-summary-grid article {
    position: relative;
    overflow: hidden;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-areas:
        "icon"
        "label"
        "value";
    justify-items: center;
    align-items: start;
    align-content: center;
    row-gap: 8px;
    min-height: 132px;
    padding: 20px 16px 18px;
    text-align: center;
    font-family: "Roboto", system-ui, sans-serif;
    background:
        linear-gradient(145deg, rgba(255,255,255,.98), rgba(255,255,255,.86)),
        radial-gradient(circle at 100% 0%, rgba(183,154,88,.12), transparent 38%);
    border: 1px solid rgba(15,23,42,.075);
    border-radius: 6px;
    box-shadow: 0 14px 32px rgba(15,23,42,.055);
    transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease, background .22s ease;
}

.apartment-summary-grid article::before {
    display: none;
}

.apartment-summary-grid article > * {
    position: relative;
    z-index: 1;
}

.apartment-summary-grid article:first-child {
    background:
        linear-gradient(145deg, rgba(255,252,246,.98), rgba(255,255,255,.86)),
        radial-gradient(circle at 100% 0%, rgba(183,154,88,.16), transparent 38%);
}

.apartment-summary-grid article:hover {
    transform: translateY(-3px);
    border-color: rgba(183,154,88,.28);
    box-shadow: 0 18px 40px rgba(15,23,42,.085);
    background:
        linear-gradient(145deg, rgba(255,255,255,1), rgba(255,252,246,.9)),
        radial-gradient(circle at 100% 0%, rgba(183,154,88,.18), transparent 38%);
}

.apartment-summary-grid article:hover::before {
    opacity: 1;
}

.apartment-summary-icon {
    grid-area: icon;
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
    color: #8f7436;
    background: #fff;
    border: 1px solid rgba(183,154,88,.28);
    border-radius: 999px;
    box-shadow: 0 8px 18px rgba(143,116,54,.08);
    transition: transform .24s ease, background .24s ease, color .24s ease;
}

.apartment-summary-icon svg {
    width: 22px;
    height: 22px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.apartment-summary-grid article:hover .apartment-summary-icon {
    transform: translateY(-2px) scale(1.03);
    color: #fff;
    background: #8f7436;
}

.apartment-summary-grid article > span:not(.apartment-summary-icon) {
    grid-area: label;
    display: block;
    align-self: auto;
    color: #8f7436;
    font-family: "Roboto", system-ui, sans-serif;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .04em;
}

.apartment-summary-grid strong {
    grid-area: value;
    display: block;
    align-self: auto;
    color: var(--ink);
    font-family: "Roboto", system-ui, sans-serif;
    font-size: clamp(18px, 1.35vw, 22px);
    font-weight: 800;
    line-height: 1.12;
    min-height: 2.25em;
    max-width: 170px;
}

.apartment-section-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 30px;
    margin-bottom: 28px;
}

.apartment-section-head h2 {
    max-width: 640px;
    margin: 0;
    color: var(--ink);
    font-family: "Roboto", system-ui, sans-serif;
    font-size: clamp(30px, 4vw, 54px);
    line-height: 1.02;
}

.apartment-section-head p {
    max-width: 520px;
    margin: 0;
    color: var(--muted);
    font-size: 16px;
    line-height: 1.65;
}

.apartment-gallery-frame {
    position: relative;
}

.apartment-detail-gallery {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding-bottom: 6px;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
}

.apartment-detail-gallery::-webkit-scrollbar {
    display: none;
}

.apartment-detail-gallery a {
    position: relative;
    overflow: hidden;
    flex: 0 0 min(420px, 38vw);
    height: 440px;
    background: #ddd;
    scroll-snap-align: start;
}

.apartment-detail-gallery a:nth-child(3n + 1) {
    flex-basis: min(520px, 46vw);
}

.apartment-detail-gallery img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .45s ease;
}

.apartment-detail-gallery a:hover img {
    transform: scale(1.04);
}

.apartment-floor-layout {
    display: grid;
    grid-template-columns: .78fr 1.22fr;
    gap: 34px;
    align-items: stretch;
}

.apartment-floor-copy,
.apartment-floor-card {
    background: #fff;
    border: 1px solid rgba(15,23,42,.08);
    box-shadow: 0 18px 54px rgba(15,23,42,.07);
}

.apartment-floor-copy {
    display: grid;
    align-content: space-between;
    gap: 24px;
    padding: clamp(26px, 4vw, 42px);
}

.apartment-floor-copy > span {
    color: var(--accent-2);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.apartment-floor-copy h2 {
    margin: 0;
    color: var(--ink);
    font-family: "Roboto", system-ui, sans-serif;
    font-size: clamp(30px, 4vw, 52px);
    line-height: 1.04;
}

.apartment-floor-copy p {
    margin: 0;
    color: var(--muted);
    font-size: 17px;
    line-height: 1.68;
}

.apartment-floor-copy div {
    padding-top: 20px;
    border-top: 1px solid rgba(15,23,42,.08);
}

.apartment-floor-copy strong {
    display: block;
    margin-bottom: 8px;
    color: var(--ink);
    font-size: 15px;
}

.apartment-floor-copy div p {
    font-size: 15px;
    font-weight: 800;
}

.apartment-floor-card {
    padding: 26px;
}

.apartment-floor-card-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 18px;
    padding-bottom: 18px;
    border-bottom: 1px solid rgba(15,23,42,.08);
}

.apartment-floor-card-head strong {
    color: var(--ink);
    font-size: 24px;
}

.apartment-floor-card-head span {
    color: var(--muted);
    font-size: 13px;
    font-weight: 800;
}

.apartment-floor-map {
    position: relative;
    display: grid;
    grid-template-columns: 86px minmax(0, 1fr);
    gap: 18px;
    min-height: 360px;
    padding: 18px;
    overflow: hidden;
    background:
        linear-gradient(rgba(15,23,42,.045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(15,23,42,.045) 1px, transparent 1px),
        #fbfaf8;
    background-size: 42px 42px;
    border: 1px solid rgba(15,23,42,.08);
}

.apartment-floor-corridor {
    display: grid;
    place-items: center;
    color: rgba(7,16,14,.58);
    background: linear-gradient(180deg, #eee6d8, #f7f0e4);
    border: 1px dashed rgba(15,23,42,.18);
}

.apartment-floor-corridor span {
    max-width: 70px;
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .08em;
    line-height: 1.25;
    text-align: center;
    text-transform: uppercase;
    writing-mode: vertical-rl;
    transform: rotate(180deg);
}

.apartment-floor-units {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 14px;
    align-content: center;
}

.apartment-floor-units a {
    position: relative;
    min-height: 142px;
    display: grid;
    align-content: space-between;
    gap: 10px;
    padding: 18px;
    color: var(--ink);
    background: #fff;
    border: 1px solid rgba(15,23,42,.1);
    box-shadow: 0 16px 38px rgba(15,23,42,.07);
    transition: transform .24s ease, border-color .24s ease, box-shadow .24s ease;
}

.apartment-floor-units a::after {
    content: "";
    position: absolute;
    left: 0;
    right: calc(100% - var(--unit-width));
    bottom: 0;
    height: 4px;
    background: linear-gradient(90deg, #b79a58, #d9c47c);
    transition: right .24s ease, height .24s ease;
}

.apartment-floor-units a:hover {
    transform: translateY(-4px);
    border-color: rgba(183,154,88,.34);
    box-shadow: 0 24px 60px rgba(15,23,42,.12);
}

.apartment-floor-units a:hover::after {
    right: 0;
    height: 6px;
}

.apartment-floor-units a.is-current {
    color: #fff;
    background: linear-gradient(135deg, #101a17, #07100e);
    border-color: rgba(183,154,88,.38);
}

.apartment-floor-units a span {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    color: #07100e;
    background: rgba(183,154,88,.18);
    border: 1px solid rgba(183,154,88,.22);
    font-size: 13px;
    font-weight: 900;
}

.apartment-floor-units a.is-current span {
    background: #d9c47c;
}

.apartment-floor-units a strong {
    display: block;
    font-size: 18px;
}

.apartment-floor-units a small {
    color: var(--muted);
    font-size: 13px;
    font-weight: 800;
}

.apartment-floor-units a.is-current small {
    color: rgba(255,255,255,.68);
}

.apartment-floor-card > p {
    margin: 18px 0 0;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.55;
}

.apartment-gallery-controls {
    position: absolute;
    right: 16px;
    bottom: 18px;
    z-index: 2;
    display: flex;
    gap: 8px;
}

.apartment-gallery-controls button {
    width: 44px;
    height: 44px;
    display: grid;
    place-items: center;
    padding: 0;
    color: #fff;
    background: rgba(7,16,14,.7);
    border: 1px solid rgba(255,255,255,.18);
    backdrop-filter: blur(16px);
    cursor: pointer;
    transition: transform .22s ease, background .22s ease;
}

.apartment-gallery-controls button:hover {
    transform: translateY(-2px);
    background: rgba(183,154,88,.9);
}

.apartment-gallery-controls svg {
    width: 22px;
    height: 22px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2.4;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.apartment-story-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 360px;
    gap: 36px;
    align-items: start;
}

.apartment-data-layout {
    display: block;
}

.apartment-data-layout .apartment-compartment-card {
    width: 100%;
}

.apartment-story-shell {
    background: #fff;
    border: 1px solid rgba(15,23,42,.08);
    border-radius: 8px;
    padding: clamp(28px, 4.2vw, 48px);
    box-shadow: none;
}

.apartment-story {
    max-width: 1040px;
}

.apartment-story > span {
    display: block;
    margin-bottom: 14px;
    color: var(--accent-2);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.apartment-story h2 {
    max-width: 960px;
    margin: 0 0 26px;
    color: var(--ink);
    font-family: "Roboto", system-ui, sans-serif;
    font-size: clamp(28px, 3.4vw, 46px);
    line-height: 1.06;
}

.apartment-story .content-copy {
    max-width: 980px;
    color: #344054;
    background: transparent;
    border: 0;
    border-radius: 0;
    padding: 0;
    box-shadow: none;
}

.apartment-inline-gallery-section {
    padding-top: 18px;
    background: #fbfaf8;
}

.apartment-story-section + .apartment-inline-gallery-section {
    padding-top: 0;
}

.apartment-decision-strip {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1px;
    overflow: hidden;
    border: 1px solid rgba(15,23,42,.08);
    border-radius: 8px;
    background: rgba(15,23,42,.08);
    box-shadow: 0 18px 44px rgba(15,23,42,.06);
}

.apartment-decision-item {
    min-height: 116px;
    padding: 18px 18px 16px;
    background: #fff;
    color: inherit;
    text-decoration: none;
    display: grid;
    grid-template-columns: minmax(0, 1fr) 34px;
    gap: 12px;
    align-items: center;
    cursor: pointer;
    transition: transform .2s ease, background .2s ease, box-shadow .2s ease;
}

.apartment-decision-item:hover {
    transform: translateY(-3px);
    background: #fffdf8;
    box-shadow: 0 16px 34px rgba(15,23,42,.08);
}

.apartment-decision-arrow {
    width: 38px;
    height: 38px;
    display: grid;
    place-items: center;
    color: #8f7436;
    background: rgba(183,154,88,.12);
    border: 1px solid rgba(183,154,88,.2);
    border-radius: 999px;
    transition: transform .2s ease, background .2s ease, color .2s ease;
}

.apartment-decision-arrow svg {
    width: 19px;
    height: 19px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.apartment-decision-item:hover .apartment-decision-arrow {
    transform: translateY(-2px) scale(1.04);
    color: #fff;
    background: #8f7436;
}

.apartment-decision-strip strong {
    display: block;
    color: var(--ink);
    font-size: 16px;
    line-height: 1.2;
}

.apartment-decision-strip p {
    margin: 8px 0 0;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.45;
}

.apartment-inline-gallery-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 430px);
    gap: 26px;
    align-items: end;
    margin-bottom: 22px;
}

.apartment-inline-gallery-head span {
    display: block;
    margin-bottom: 10px;
    color: var(--accent-2);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.apartment-inline-gallery-head h2 {
    max-width: 660px;
    margin: 0;
    color: var(--ink);
    font-family: "Roboto", system-ui, sans-serif;
    font-size: clamp(30px, 3.4vw, 48px);
    line-height: 1.04;
}

.apartment-inline-gallery-head p {
    margin: 0;
    color: var(--muted);
    font-size: 15px;
    line-height: 1.6;
}

.apartment-inline-gallery-grid {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: 12px;
}

.apartment-inline-gallery-grid a {
    position: relative;
    min-height: 230px;
    overflow: hidden;
    background: #e9e4da;
    border-radius: 6px;
    box-shadow: 0 18px 48px rgba(15,23,42,.08);
}

.apartment-inline-gallery-grid a:nth-child(1) {
    grid-column: span 6;
    grid-row: span 2;
    min-height: 472px;
}

.apartment-inline-gallery-grid a:nth-child(2),
.apartment-inline-gallery-grid a:nth-child(3),
.apartment-inline-gallery-grid a:nth-child(n + 4) {
    grid-column: span 3;
}

.apartment-inline-gallery-grid img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    transition: transform .38s ease, filter .38s ease;
}

.apartment-inline-gallery-grid a:hover img {
    filter: saturate(1.04) contrast(1.03);
    transform: scale(1.035);
}

.apartment-technical-card {
    position: sticky;
    top: 96px;
    padding: 26px;
    color: var(--ink);
    background: #fff;
    border: 1px solid rgba(15,23,42,.08);
    box-shadow: 0 18px 54px rgba(15,23,42,.08);
}

.apartment-technical-card > strong {
    display: block;
    margin-bottom: 12px;
    color: var(--ink);
    font-size: 22px;
}

.apartment-technical-card div {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 16px;
    padding: 13px 0;
    border-bottom: 1px solid rgba(15,23,42,.08);
}

.apartment-technical-card span {
    color: var(--muted);
    font-size: 13px;
}

.apartment-technical-card b {
    text-align: right;
    font-size: 14px;
}

.apartment-technical-card a {
    min-height: 46px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 20px;
    color: #fff;
    background: linear-gradient(135deg, #b79a58, #8f7436);
    font-size: 14px;
    font-weight: 900;
}

.apartment-breakdown-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    background: #fff;
    border: 1px solid rgba(15,23,42,.08);
}

.apartment-breakdown-grid article {
    min-height: 168px;
    display: grid;
    align-content: space-between;
    gap: 18px;
    padding: 24px;
    border-right: 1px solid rgba(15,23,42,.08);
}

.apartment-breakdown-grid article:last-child {
    border-right: 0;
}

.apartment-breakdown-grid span {
    color: var(--accent-2);
    font-size: 13px;
    font-weight: 900;
}

.apartment-breakdown-grid strong {
    display: block;
    margin-bottom: 7px;
    color: var(--ink);
    font-size: 18px;
}

.apartment-breakdown-grid p {
    margin: 0;
    color: var(--muted);
    font-size: 15px;
}

.apartment-compartment-layout {
    display: grid;
    grid-template-columns: .9fr 1.1fr;
    gap: 34px;
    align-items: stretch;
}

.apartment-compartment-intro,
.apartment-compartment-card {
    background: #fff;
    border: 1px solid rgba(15,23,42,.08);
    box-shadow: 0 18px 54px rgba(15,23,42,.07);
}

.apartment-compartment-intro {
    display: grid;
    align-content: space-between;
    gap: 26px;
    padding: clamp(26px, 4vw, 42px);
}

.apartment-compartment-intro > span {
    color: var(--accent-2);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.apartment-compartment-intro h2 {
    margin: 0;
    color: var(--ink);
    font-family: "Roboto", system-ui, sans-serif;
    font-size: clamp(30px, 4vw, 50px);
    line-height: 1.04;
}

.apartment-compartment-intro p {
    max-width: 540px;
    margin: 0;
    color: var(--muted);
    font-size: 17px;
    line-height: 1.68;
}

.apartment-compartment-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    border-top: 1px solid rgba(15,23,42,.08);
}

.apartment-compartment-stats div {
    padding: 18px 14px 0 0;
    border-right: 1px solid rgba(15,23,42,.08);
}

.apartment-compartment-stats div:last-child {
    border-right: 0;
}

.apartment-compartment-stats span {
    display: block;
    margin-bottom: 8px;
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .05em;
    text-transform: uppercase;
}

.apartment-compartment-stats strong {
    color: var(--ink);
    font-size: 20px;
}

.apartment-compartment-card {
    position: relative;
    padding: clamp(20px, 3vw, 30px);
    border-radius: 4px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.9)),
        #fff;
    box-shadow: 0 18px 56px rgba(15,23,42,.08);
}

.apartment-compartment-card-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 22px;
    padding-bottom: 18px;
    border-bottom: 1px solid rgba(15,23,42,.08);
}

.apartment-compartment-card-head strong {
    color: var(--ink);
    font-size: 24px;
}

.apartment-compartment-card-head span {
    color: var(--muted);
    font-size: 13px;
    font-weight: 800;
}

.apartment-compartment-rows {
    display: grid;
    gap: 14px;
}

.apartment-compartment-rows article {
    position: relative;
    overflow: hidden;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 14px;
    align-items: center;
    min-height: 78px;
    padding: 17px 18px;
    background: #fff;
    border: 1px solid rgba(15,23,42,.07);
    border-radius: 4px;
    box-shadow: 0 10px 26px rgba(15,23,42,.045);
    transform: translateY(0);
    transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease, background .24s ease;
    animation: compartmentRowIn .42s ease both;
}

.apartment-compartment-rows article::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(183,154,88,.1), transparent 48%);
    opacity: 0;
    transition: opacity .24s ease;
}

.apartment-compartment-rows article:nth-child(2) { animation-delay: .04s; }
.apartment-compartment-rows article:nth-child(3) { animation-delay: .08s; }
.apartment-compartment-rows article:nth-child(4) { animation-delay: .12s; }
.apartment-compartment-rows article:nth-child(5) { animation-delay: .16s; }
.apartment-compartment-rows article:nth-child(6) { animation-delay: .2s; }

.apartment-compartment-rows article > div {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
}

.apartment-compartment-icon {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    flex: 0 0 auto;
    color: #6f5a28;
    background:
        linear-gradient(145deg, rgba(255,255,255,.9), rgba(237,228,202,.95)),
        #efe5c7;
    border: 1px solid rgba(183,154,88,.22);
    border-radius: 4px;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.72), 0 8px 18px rgba(143,116,54,.1);
    transition: transform .28s ease, background .28s ease, color .28s ease;
}

.apartment-compartment-icon svg {
    width: 18px;
    height: 18px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.apartment-compartment-rows article:hover {
    transform: translateY(-4px);
    border-color: rgba(183,154,88,.26);
    box-shadow: 0 18px 42px rgba(15,23,42,.1);
}

.apartment-compartment-rows article:hover::before {
    opacity: 1;
}

.apartment-compartment-rows article:hover .apartment-compartment-icon {
    transform: translateY(-3px) scale(1.04);
    background: var(--accent);
    color: #07100e;
}

.apartment-compartment-rows article:hover .apartment-compartment-icon svg {
    animation: compartmentIconMove .48s ease;
}

.apartment-compartment-rows article strong {
    color: var(--ink);
    font-size: 17px;
    line-height: 1.2;
}

.apartment-compartment-rows article b {
    position: relative;
    z-index: 1;
    color: var(--ink);
    font-size: 18px;
    font-weight: 900;
    white-space: nowrap;
}

.apartment-compartment-rows article i {
    display: none;
}

.apartment-compartment-rows article:hover i {
    display: none;
}

@keyframes compartmentRowIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes compartmentIconMove {
    0% { transform: translateY(0) rotate(0); }
    45% { transform: translateY(-2px) rotate(-4deg); }
    100% { transform: translateY(0) rotate(0); }
}

@media (prefers-reduced-motion: reduce) {
    .apartment-compartment-rows article,
    .apartment-compartment-rows article:hover .apartment-compartment-icon svg,
    .apartment-final-cta,
    .apartment-reveal,
    .apartment-detail-copy,
    .apartment-detail-copy .apartment-detail-kicker,
    .apartment-detail-copy h1,
    .apartment-detail-copy > p:not(.apartment-detail-kicker),
    .apartment-detail-actions,
    .apartment-detail-media,
    .apartment-final-primary:hover svg,
    .apartment-final-secondary:hover svg,
    .apartment-final-cta-points article:hover svg {
        animation: none !important;
        transition: none !important;
        transform: none !important;
        opacity: 1 !important;
        filter: none !important;
    }
}

.apartment-compartment-card > p {
    margin: 18px 0 0;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.55;
}

@media (min-width: 641px) {
    .apartment-compartment-rows {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 12px;
    }

    .apartment-compartment-rows article {
        min-height: 128px;
        grid-template-columns: 1fr;
        justify-items: start;
        align-content: start;
        gap: 10px;
        padding: 16px;
    }

    .apartment-compartment-rows article > div {
        display: flex;
        align-items: center;
        gap: 10px;
    }

    .apartment-compartment-rows article strong {
        order: 2;
        font-size: 18px;
    }

    .apartment-compartment-icon {
        order: 1;
        width: 42px;
        height: 42px;
    }

    .apartment-compartment-icon svg {
        width: 18px;
        height: 18px;
    }

    .apartment-compartment-rows article b {
        margin-top: auto;
        font-size: 20px;
    }
}

@media (min-width: 981px) {
    .apartment-compartment-card {
        padding: 28px;
        border-radius: 8px;
        background: #fff;
        box-shadow: none;
    }

    .apartment-compartment-card-head {
        margin-bottom: 18px;
        padding-bottom: 14px;
    }

    .apartment-compartment-rows {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 10px;
    }

    .apartment-compartment-rows article {
        min-height: 126px;
        grid-template-columns: 1fr;
        gap: 12px;
        align-content: space-between;
        padding: 18px;
        border-color: rgba(15,23,42,.08);
        border-radius: 8px;
        background: #fbfaf8;
        box-shadow: none;
    }

    .apartment-compartment-rows article::before {
        display: none;
    }

    .apartment-compartment-rows article > div {
        display: grid;
        gap: 10px;
    }

    .apartment-compartment-icon {
        width: 42px;
        height: 42px;
        color: #8f7436;
        background: transparent;
        border: 1px solid rgba(143,116,54,.32);
        border-radius: 999px;
        box-shadow: none;
    }

    .apartment-compartment-rows article strong {
        font-size: 16px;
    }

    .apartment-compartment-rows article b {
        font-size: 20px;
    }

    .apartment-compartment-rows article:hover {
        transform: translateY(-2px);
        border-color: rgba(143,116,54,.28);
        background: #fff;
        box-shadow: none;
    }

    .apartment-compartment-rows article:hover .apartment-compartment-icon {
        transform: none;
        color: #07100e;
        background: rgba(183,154,88,.16);
    }
}

@media (min-width: 981px) {
    .apartment-compartment-rows {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 14px;
    }

    .apartment-compartment-rows article {
        flex: 0 1 calc((100% - 28px) / 3);
        min-height: 154px;
        display: grid;
        grid-template-columns: 1fr;
        justify-items: center;
        align-content: center;
        gap: 12px;
        padding: 22px 18px;
        text-align: center;
        border: 1px solid rgba(143,116,54,.16);
        border-radius: 8px;
        background: #fff;
        box-shadow: inset 0 1px 0 rgba(255,255,255,.86);
    }

    .apartment-compartment-rows article > div {
        display: grid;
        justify-items: center;
        gap: 10px;
    }

    .apartment-compartment-icon {
        width: 60px;
        height: 60px;
        color: #8f7436;
        background: #fff;
        border: 1px solid rgba(143,116,54,.28);
        box-shadow: inset 0 0 0 6px rgba(255,255,255,.58);
    }

    .apartment-compartment-icon svg {
        width: 26px;
        height: 26px;
    }

    .apartment-compartment-rows article strong {
        max-width: 100%;
        color: #1f2937;
        font-size: 13px;
        font-weight: 900;
        line-height: 1.18;
        text-transform: uppercase;
        letter-spacing: .035em;
    }

    .apartment-compartment-rows article b {
        color: #07100e;
        font-size: 24px;
        line-height: 1;
        letter-spacing: 0;
    }

    .apartment-compartment-rows article:hover {
        transform: translateY(-3px);
        border-color: rgba(143,116,54,.32);
        background: #fff;
        box-shadow: 0 16px 34px rgba(15,23,42,.075);
    }

    .apartment-compartment-rows article:hover .apartment-compartment-icon {
        color: #fff;
        background: #8f7436;
        border-color: #8f7436;
        box-shadow: inset 0 0 0 6px rgba(255,255,255,.12);
    }
}

.apartment-plan-layout {
    display: grid;
    grid-template-columns: .85fr 1.15fr;
    gap: 36px;
    align-items: center;
}

.apartment-plan-layout-simple {
    display: block;
    max-width: 760px;
}

.apartment-plan-link {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    margin-top: 18px;
    padding: 0 18px;
    color: #fff;
    background: #07100e;
    border: 1px solid rgba(7,16,14,.12);
    font-size: 14px;
    font-weight: 500;
    box-shadow: 0 14px 34px rgba(7,16,14,.12);
    transition: transform .22s ease, background .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.apartment-plan-link svg {
    width: 18px;
    height: 18px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.apartment-plan-link:hover {
    transform: translateY(-2px);
    background: #14231d;
    border-color: rgba(183,154,88,.36);
    box-shadow: 0 18px 44px rgba(7,16,14,.16);
}

.apartment-plan-figure {
    margin: 0;
    padding: 18px;
    background: #fff;
    border: 1px solid rgba(15,23,42,.08);
    box-shadow: 0 18px 54px rgba(15,23,42,.08);
}

.apartment-plan-figure img {
    width: 100%;
    max-height: 620px;
    object-fit: contain;
}

.apartment-plan-figure iframe {
    width: 100%;
    min-height: 640px;
    display: block;
    border: 0;
    background: #fff;
}

.apartment-benefits-head {
    display: grid;
    grid-template-columns: minmax(0, .9fr) minmax(320px, .72fr);
    gap: 34px;
    align-items: end;
    margin-bottom: 28px;
}

.apartment-benefits-head span {
    display: block;
    margin-bottom: 12px;
    color: var(--accent-2);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.apartment-benefits-head h2 {
    margin: 0;
    color: var(--ink);
    font-family: "Roboto", system-ui, sans-serif;
    font-size: clamp(34px, 4.8vw, 64px);
    line-height: 1.01;
}

.apartment-benefits-head p {
    margin: 0;
    color: var(--muted);
    font-size: 17px;
    line-height: 1.68;
}

.apartment-benefits-side {
    display: grid;
    justify-items: start;
    gap: 16px;
}

.apartment-benefits-side .apartment-plan-link {
    margin-top: 0;
}

.apartment-benefits-list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.apartment-benefits-list article {
    position: relative;
    overflow: hidden;
    min-height: 238px;
    display: grid;
    align-content: start;
    gap: 18px;
    padding: 26px;
    background: #fff;
    border: 1px solid rgba(15,23,42,.08);
    box-shadow: 0 18px 54px rgba(15,23,42,.07);
    transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.apartment-benefits-list article::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 4px;
    background: linear-gradient(90deg, #b79a58, #d9c47c);
    transform: scaleX(.28);
    transform-origin: left;
    transition: transform .28s ease;
}

.apartment-benefits-list article:hover {
    transform: translateY(-4px);
    border-color: rgba(183,154,88,.34);
    box-shadow: 0 28px 70px rgba(15,23,42,.12);
}

.apartment-benefits-list article:hover::after {
    transform: scaleX(1);
}

.apartment-benefits-list article.featured {
    grid-column: span 2;
    min-height: 238px;
    color: #fff;
    background:
        linear-gradient(135deg, rgba(7,16,14,.94), rgba(20,35,29,.92)),
        radial-gradient(circle at 82% 12%, rgba(183,154,88,.38), transparent 34%);
}

.apartment-benefits-list article.featured strong,
.apartment-benefits-list article.featured p {
    color: #fff;
}

.apartment-benefit-icon {
    width: 52px;
    height: 52px;
    display: grid;
    place-items: center;
    color: #07100e;
    background: rgba(183,154,88,.18);
    border: 1px solid rgba(183,154,88,.22);
    transition: transform .28s ease, background .28s ease;
}

.apartment-benefits-list article:hover .apartment-benefit-icon {
    transform: translateY(-3px) rotate(-2deg);
    background: var(--accent);
}

.apartment-benefit-icon svg {
    width: 24px;
    height: 24px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.apartment-benefits-list article.featured .apartment-benefit-icon {
    color: #07100e;
    background: #d9c47c;
    border-color: rgba(255,255,255,.18);
}

.apartment-benefits-list strong {
    display: block;
    margin-bottom: 10px;
    color: var(--ink);
    font-size: 19px;
    line-height: 1.2;
}

.apartment-benefits-list p {
    margin: 0;
    color: var(--ink);
    font-size: 16px;
    line-height: 1.55;
}

.apartment-benefits-action {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    margin-top: 14px;
    padding: 22px 24px;
    background: #fff;
    border: 1px solid rgba(15,23,42,.08);
    box-shadow: 0 18px 54px rgba(15,23,42,.06);
}

.apartment-benefits-action p {
    max-width: 680px;
    margin: 0;
    color: var(--muted);
    line-height: 1.6;
}

.apartment-benefits-action a {
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    padding: 0 18px;
    color: #fff;
    background: linear-gradient(135deg, #b79a58, #8f7436);
    font-size: 14px;
    font-weight: 900;
}

.apartment-location-layout {
    display: grid;
    grid-template-columns: .78fr 1.22fr;
    gap: 34px;
    align-items: stretch;
}

.apartment-location-copy,
.apartment-location-map {
    background: #fff;
    border: 1px solid rgba(15,23,42,.08);
    box-shadow: 0 18px 54px rgba(15,23,42,.07);
}

.apartment-location-copy {
    display: grid;
    align-content: space-between;
    gap: 24px;
    padding: clamp(26px, 4vw, 42px);
}

.apartment-location-copy > span {
    color: var(--accent-2);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.apartment-location-copy h2 {
    margin: 0;
    color: var(--ink);
    font-family: "Roboto", system-ui, sans-serif;
    font-size: clamp(30px, 4vw, 52px);
    line-height: 1.04;
}

.apartment-location-copy p {
    margin: 0;
    color: var(--muted);
    font-size: 17px;
    line-height: 1.68;
}

.apartment-location-points {
    display: grid;
    gap: 12px;
    padding-top: 20px;
    border-top: 1px solid rgba(15,23,42,.08);
}

.apartment-location-points article {
    padding: 0;
    border: 0;
}

.apartment-location-points strong {
    display: block;
    margin-bottom: 5px;
    color: var(--ink);
    font-size: 15px;
}

.apartment-location-points p {
    margin: 0;
    font-size: 14px;
    line-height: 1.5;
}

.apartment-location-map {
    position: relative;
    min-height: 520px;
    overflow: hidden;
    background:
        linear-gradient(135deg, rgba(7,16,14,.12), rgba(183,154,88,.1)),
        #e7e3d8;
    isolation: isolate;
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    transition: none !important;
}

.apartment-location-map::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    background:
        linear-gradient(90deg, transparent 0 70%, rgba(67,135,162,.18) 70% 100%),
        linear-gradient(rgba(15,23,42,.055) 1px, transparent 1px),
        linear-gradient(90deg, rgba(15,23,42,.055) 1px, transparent 1px),
        linear-gradient(135deg, #f3ead9, #e4dccf);
    background-size: auto, 58px 58px, 58px 58px, auto;
}

.apartment-location-map iframe {
    position: absolute;
    inset: 0;
    z-index: 1;
    width: 100%;
    height: 100%;
    min-height: 520px;
    display: block;
    border: 0;
    filter: saturate(.96) contrast(1.02);
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
    animation: none !important;
}

.apartment-map-fallback {
    position: absolute;
    inset: 0;
    z-index: 0;
    display: grid;
    place-items: center;
    align-content: center;
    gap: 6px;
    padding: 34px;
    color: #07100e;
    text-align: center;
}

.apartment-map-fallback::before {
    content: "";
    width: 58px;
    height: 58px;
    margin-bottom: 6px;
    border-radius: 50%;
    background:
        radial-gradient(circle at center, #b79a58 0 8px, rgba(183,154,88,.22) 9px 100%),
        #fff;
    border: 1px solid rgba(183,154,88,.32);
    box-shadow: 0 18px 42px rgba(15,23,42,.16);
}

.apartment-map-fallback span {
    color: var(--accent-2);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.apartment-map-fallback strong {
    font-family: "Roboto", system-ui, sans-serif;
    font-size: clamp(26px, 4vw, 42px);
    font-weight: 500;
    line-height: 1;
}

.apartment-map-fallback small {
    color: rgba(7,16,14,.68);
    font-size: 14px;
    font-weight: 800;
}

.apartment-final-cta-section {
    background: #fbfaf8;
    color: var(--ink);
}

.apartment-final-cta {
    position: relative;
    overflow: hidden;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(340px, 430px);
    gap: 34px;
    padding: clamp(34px, 5vw, 58px);
    background:
        radial-gradient(circle at 88% 18%, rgba(183,154,88,.22), transparent 28%),
        linear-gradient(135deg, #fff, #f4efe3);
    border: 1px solid rgba(15,23,42,.08);
    box-shadow: 0 24px 70px rgba(15,23,42,.09);
    animation: finalCtaIn .5s ease both;
}

.apartment-final-cta::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 4px;
    background: linear-gradient(90deg, #b79a58, #d9c47c);
}

.apartment-final-cta-copy,
.apartment-final-cta-actions,
.apartment-final-form,
.apartment-final-cta-points {
    position: relative;
    z-index: 1;
}

.apartment-final-cta-copy span {
    display: block;
    margin-bottom: 12px;
    color: var(--accent-2);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.apartment-final-cta-copy h2 {
    max-width: 760px;
    margin: 0;
    color: var(--ink);
    font-family: "Roboto", system-ui, sans-serif;
    font-size: clamp(34px, 4.8vw, 64px);
    line-height: 1.02;
}

.apartment-final-cta-copy p {
    max-width: 720px;
    margin: 20px 0 0;
    color: var(--muted);
    font-size: 17px;
    line-height: 1.68;
}

.apartment-final-alert,
.apartment-final-error {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    margin-top: 20px;
    padding: 12px 14px;
    color: #065f46;
    background: rgba(16,185,129,.11);
    border: 1px solid rgba(16,185,129,.22);
    font-size: 14px;
    line-height: 1.4;
}

.apartment-final-alert svg {
    width: 18px;
    height: 18px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2.4;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.apartment-final-error {
    margin-top: 0;
    color: #991b1b;
    background: rgba(239,68,68,.1);
    border-color: rgba(239,68,68,.2);
}

.apartment-final-form {
    display: grid;
    gap: 16px;
    align-self: start;
    padding: 22px;
    background: rgba(255,255,255,.86);
    border: 1px solid rgba(15,23,42,.1);
    box-shadow: 0 20px 54px rgba(15,23,42,.1);
    backdrop-filter: blur(16px);
}

.apartment-final-form-head {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 14px;
    padding-bottom: 14px;
    border-bottom: 1px solid rgba(15,23,42,.08);
}

.apartment-final-form-head strong {
    color: var(--ink);
    font-size: 19px;
    font-weight: 500;
    line-height: 1.15;
}

.apartment-final-form-head span {
    max-width: 170px;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.35;
    text-align: right;
}

.apartment-final-fields {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.apartment-final-fields label {
    display: grid;
    gap: 7px;
    color: var(--ink);
    font-size: 13px;
    font-weight: 500;
    transition: transform .2s ease, color .2s ease;
}

.apartment-final-fields label:last-child {
    grid-column: 1 / -1;
}

.apartment-final-fields label:focus-within {
    color: var(--accent-2);
    transform: translateY(-1px);
}

.apartment-final-fields input,
.apartment-final-fields textarea {
    width: 100%;
    min-height: 46px;
    padding: 12px 13px;
    color: var(--ink);
    background: #fff;
    border: 1px solid rgba(15,23,42,.12);
    border-radius: 0;
    font-family: "Roboto", system-ui, sans-serif;
    font-size: 14px;
    font-weight: 400;
    outline: 0;
    transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.apartment-final-fields textarea {
    min-height: 104px;
    resize: vertical;
}

.apartment-final-fields input:focus,
.apartment-final-fields textarea:focus {
    border-color: rgba(183,154,88,.7);
    box-shadow: 0 0 0 3px rgba(183,154,88,.14);
}

.apartment-final-submit {
    min-height: 52px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    width: 100%;
    padding: 0 20px;
    color: #fff;
    background: linear-gradient(135deg, #b79a58, #8f7436);
    border: 0;
    font-family: "Roboto", system-ui, sans-serif;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    box-shadow: 0 16px 34px rgba(143,116,54,.18);
    transition: transform .22s ease, box-shadow .22s ease, filter .22s ease;
}

.apartment-final-submit svg {
    width: 18px;
    height: 18px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.apartment-final-submit:hover {
    transform: translateY(-2px);
    filter: brightness(1.04);
    box-shadow: 0 20px 42px rgba(143,116,54,.24);
}

.apartment-final-cta-actions {
    display: grid;
    align-content: start;
    gap: 12px;
    min-width: 270px;
}

.apartment-final-primary,
.apartment-final-secondary {
    min-height: 52px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    padding: 0 20px;
    font-size: 14px;
    font-weight: 900;
    text-align: center;
    transition: transform .22s ease, background .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.apartment-final-primary svg,
.apartment-final-secondary svg,
.apartment-final-cta-points svg {
    width: 18px;
    height: 18px;
    flex: 0 0 auto;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.apartment-final-primary {
    color: #fff;
    background: linear-gradient(135deg, #b79a58, #8f7436);
    box-shadow: 0 16px 34px rgba(143,116,54,.18);
}

.apartment-final-secondary {
    color: var(--ink);
    background: #fff;
    border: 1px solid rgba(15,23,42,.12);
}

.apartment-final-primary:hover,
.apartment-final-secondary:hover {
    transform: translateY(-3px);
}

.apartment-final-primary:hover svg,
.apartment-final-secondary:hover svg,
.apartment-final-cta-points article:hover svg {
    animation: finalIconMove .45s ease;
}

.apartment-final-cta-points {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    margin-top: 4px;
}

.apartment-final-cta-points article {
    position: relative;
    overflow: hidden;
    display: grid;
    gap: 12px;
    padding: 22px;
    background: #fff;
    border: 1px solid rgba(15,23,42,.08);
    transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}

.apartment-final-cta-points article:hover {
    transform: translateY(-3px);
    border-color: rgba(183,154,88,.32);
    box-shadow: 0 18px 44px rgba(15,23,42,.08);
}

.apartment-final-cta-points article > span {
    width: 42px;
    height: 42px;
    display: grid;
    place-items: center;
    color: #07100e;
    background: rgba(183,154,88,.18);
    border: 1px solid rgba(183,154,88,.22);
    transition: background .22s ease, color .22s ease, transform .22s ease;
}

.apartment-final-cta-points article:hover > span {
    color: #fff;
    background: #07100e;
    transform: translateY(-2px);
}

.apartment-final-cta-points strong {
    display: block;
    color: var(--ink);
    font-size: 16px;
}

.apartment-final-cta-points p {
    margin: 0;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.5;
}

.apartment-final-cta-points p a {
    display: inline-block;
    margin-top: 5px;
    color: var(--accent-2);
    font-weight: 900;
    text-decoration: none;
}

.apartment-final-cta-points p a:hover {
    color: #07100e;
}

@media (min-width: 981px) {
    .apartment-final-cta {
        grid-template-columns: minmax(0, 1fr) minmax(360px, 420px);
        grid-template-areas:
            "copy form"
            "points form";
        align-items: start;
        gap: 24px 42px;
        padding: 44px;
        background: #fff;
        border: 1px solid rgba(15,23,42,.08);
        border-radius: 8px;
        box-shadow: 0 18px 56px rgba(15,23,42,.07);
    }

    .apartment-final-cta::after {
        display: none;
    }

    .apartment-final-cta-copy {
        grid-area: copy;
        max-width: 680px;
    }

    .apartment-final-cta-copy h2 {
        max-width: 600px;
        font-size: clamp(32px, 3.2vw, 46px);
        line-height: 1.05;
    }

    .apartment-final-cta-copy p {
        max-width: 620px;
        margin-top: 16px;
        font-size: 16px;
        line-height: 1.62;
    }

    .apartment-final-form {
        grid-area: form;
        gap: 14px;
        padding: 24px;
        background: #fbfaf8;
        border-radius: 8px;
        border-color: rgba(15,23,42,.09);
        box-shadow: 0 16px 44px rgba(15,23,42,.08);
        backdrop-filter: none;
    }

    .apartment-final-form-head {
        display: grid;
        gap: 5px;
    }

    .apartment-final-form-head span {
        max-width: none;
        text-align: left;
    }

    .apartment-final-fields {
        gap: 10px;
    }

    .apartment-final-fields input,
    .apartment-final-fields textarea {
        min-height: 44px;
        border-radius: 6px;
    }

    .apartment-final-fields textarea {
        min-height: 92px;
    }

    .apartment-final-cta-points {
        grid-area: points;
        grid-column: auto;
        grid-template-columns: 1fr;
        gap: 10px;
        margin-top: 0;
    }

    .apartment-final-cta-points article {
        grid-template-columns: 38px minmax(0, 1fr);
        gap: 4px 12px;
        align-items: start;
        padding: 0 0 13px;
        background: transparent;
        border: 0;
        border-bottom: 1px solid rgba(15,23,42,.08);
        box-shadow: none;
    }

    .apartment-final-cta-points article:last-child {
        padding-bottom: 0;
        border-bottom: 0;
    }

    .apartment-final-cta-points article:hover {
        transform: none;
        border-color: rgba(15,23,42,.08);
        box-shadow: none;
    }

    .apartment-final-cta-points article > span {
        grid-row: span 2;
        width: 38px;
        height: 38px;
        border-radius: 50%;
        background: rgba(183,154,88,.14);
    }

    .apartment-final-cta-points article:hover > span {
        color: #07100e;
        background: rgba(183,154,88,.18);
        transform: none;
    }

    .apartment-final-cta-points strong {
        font-size: 15px;
        line-height: 1.25;
    }

    .apartment-final-cta-points p {
        font-size: 13px;
        line-height: 1.5;
    }

}

@keyframes finalCtaIn {
    from { opacity: 0; transform: translateY(14px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes finalIconMove {
    0% { transform: translateX(0) rotate(0); }
    45% { transform: translateX(2px) rotate(-4deg); }
    100% { transform: translateX(0) rotate(0); }
}

.apartment-map-visual {
    position: relative;
    min-height: 520px;
    overflow: hidden;
    isolation: isolate;
    background:
        linear-gradient(90deg, transparent 0 72%, rgba(60,120,150,.16) 72% 100%),
        linear-gradient(135deg, #f6f1e7, #e8dfcf);
}

.apartment-map-visual::before,
.apartment-map-visual::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(15,23,42,.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(15,23,42,.05) 1px, transparent 1px);
    background-size: 64px 64px;
    opacity: .7;
    z-index: -1;
}

.apartment-map-visual::after {
    background:
        radial-gradient(circle at 28% 34%, rgba(183,154,88,.16), transparent 22%),
        radial-gradient(circle at 78% 52%, rgba(69,137,162,.18), transparent 24%);
    opacity: 1;
}

.map-sea {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 28%;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding-bottom: 34px;
    color: #315b68;
    background: linear-gradient(180deg, rgba(93,164,190,.42), rgba(48,115,142,.48));
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    writing-mode: vertical-rl;
}

.map-road {
    position: absolute;
    display: block;
    background: #fffaf0;
    border: 1px solid rgba(15,23,42,.09);
    box-shadow: 0 10px 28px rgba(15,23,42,.08);
}

.map-road-main {
    left: -8%;
    top: 47%;
    width: 82%;
    height: 24px;
    transform: rotate(-8deg);
}

.map-road-secondary {
    left: 22%;
    top: 6%;
    width: 22px;
    height: 72%;
    transform: rotate(18deg);
}

.map-road-third {
    left: 3%;
    top: 70%;
    width: 66%;
    height: 18px;
    transform: rotate(9deg);
    opacity: .88;
}

.map-label {
    position: absolute;
    padding: 8px 10px;
    color: #07100e;
    background: rgba(255,255,255,.78);
    border: 1px solid rgba(15,23,42,.08);
    box-shadow: 0 12px 28px rgba(15,23,42,.08);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .04em;
    backdrop-filter: blur(10px);
}

.map-label-d18 {
    left: 23%;
    top: 41%;
    transform: rotate(-8deg);
}

.map-label-beach {
    right: 18%;
    top: 20%;
}

.map-pin {
    position: absolute;
    left: 48%;
    top: 42%;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    color: #fff;
    background: #07100e;
    border: 1px solid rgba(255,255,255,.14);
    box-shadow: 0 24px 54px rgba(7,16,14,.28);
    transform: translate(-50%, -50%);
    animation: mapPinPulse 2.4s ease infinite;
}

.map-pin svg {
    width: 22px;
    height: 22px;
    flex: 0 0 auto;
    fill: none;
    stroke: #d9c47c;
    stroke-width: 2.2;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.map-pin strong {
    white-space: nowrap;
    font-size: 14px;
}

.apartment-map-link {
    position: absolute;
    left: 18px;
    bottom: 18px;
    z-index: 2;
    min-height: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 18px;
    color: #fff;
    background: linear-gradient(135deg, #b79a58, #8f7436);
    font-size: 14px;
    font-weight: 900;
    box-shadow: 0 18px 42px rgba(15,23,42,.18);
}

@keyframes mapPinPulse {
    0%, 100% { box-shadow: 0 24px 54px rgba(7,16,14,.28), 0 0 0 0 rgba(183,154,88,.42); }
    55% { box-shadow: 0 24px 54px rgba(7,16,14,.28), 0 0 0 12px rgba(183,154,88,0); }
}

.apartment-map-visual {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 190px;
}

.map-land {
    position: relative;
    min-height: 520px;
}

.map-coast {
    position: relative;
    display: grid;
    align-content: center;
    justify-items: center;
    gap: 16px;
    min-height: 520px;
    color: #17495a;
    background: linear-gradient(180deg, #9dd6e7, #5dacc6);
}

.map-coast::before {
    content: "";
    position: absolute;
    left: -28px;
    top: 0;
    bottom: 0;
    width: 52px;
    background: linear-gradient(90deg, #d8bd77, #f5e4ad);
    box-shadow: 14px 0 40px rgba(183,154,88,.28);
}

.map-coast span {
    position: relative;
    z-index: 1;
    padding: 8px 12px;
    color: #07100e;
    background: rgba(255,255,255,.72);
    border: 1px solid rgba(255,255,255,.42);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.map-coast strong {
    position: relative;
    z-index: 1;
    max-width: 120px;
    color: #0c3f50;
    font-size: 20px;
    line-height: 1.1;
    text-align: center;
}

.map-area-label {
    position: absolute;
    top: 24px;
    left: 24px;
    color: rgba(7,16,14,.68);
    font-size: 13px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.map-road-main {
    left: 8%;
    right: 8%;
    top: 48%;
    width: auto;
    height: 34px;
    transform: rotate(-5deg);
    border-radius: 999px;
    z-index: 1;
}

.map-road-name {
    position: absolute;
    left: 24%;
    top: 39%;
    z-index: 2;
    padding: 8px 12px;
    color: #07100e;
    background: rgba(255,255,255,.82);
    border: 1px solid rgba(15,23,42,.08);
    box-shadow: 0 12px 28px rgba(15,23,42,.08);
    font-size: 12px;
    font-weight: 900;
}
