/* =============================================================================
   Vaunt project taxonomy archive
   ============================================================================= */

.project-archive {
    background: var(--color-surface);
    color: var(--color-ink);
}

.project-archive .btn {
    min-height: 46px;
}

.project-breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 14px;
    font-family: var(--font-body);
    font-size: 13px;
    line-height: 1.3;
    color: var(--color-text-muted);
}

.project-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 18px;
    color: var(--color-ink);
}

.project-eyebrow span {
    width: 52px;
    height: 1px;
    background: currentColor;
    flex-shrink: 0;
}

.project-section-grid {
    display: grid;
    grid-template-columns: minmax(250px, 400px) minmax(0, 1fr);
    gap: clamp(28px, 7vw, 118px);
    align-items: start;
}

.project-section-title {
    font-size: clamp(30px, 3vw, 44px);
    font-weight: var(--fw-regular);
    line-height: 1.04;
    letter-spacing: -3%;
	padding-top: 15px;
}

/* ---- Intro / hero ------------------------------------------------------ */
.project-intro {
    padding-block: 28px 0;
}

.project-intro__top {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 28px;
}

.project-intro__title {
    max-width: 80%;
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(30px, 3vw, 46px);
    font-weight: var(--fw-regular);
    line-height: 1.04;
    letter-spacing: -3%;
}

.project-intro__cta {
    flex-shrink: 0;
}

.project-intro__hero {
    position: relative;
    min-height: clamp(320px, 40vw, 620px);
    background: var(--color-surface-muted);
    overflow: hidden;
}

.project-intro__hero > img {
    width: 100%;
    height: clamp(320px, 40vw, 620px);
    object-fit: cover;
}

/* Flex row anchored bottom-right; container shrinks to its contents, so 1 or
   2 thumbs still sit flush right instead of stretching across a 3-col grid. */
.project-intro__thumbs {
    position: absolute;
    right: 24px;
    bottom: 24px;
    display: flex;
    gap: 8px;
}

.project-intro__thumb {
    width: 100px;
    height: 72px;
    padding: 0;
    background: transparent;
    border: 2px solid var(--color-surface);
    cursor: pointer;
    overflow: hidden;
    transition: transform var(--transition-fast), border-color var(--transition-fast);
}

.project-intro__thumb:hover,
.project-intro__thumb:focus-visible {
    transform: translateY(-2px);
    border-color: var(--color-brand);
    outline: none;
}

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

/* ---- Facts ------------------------------------------------------------- */
.project-facts {
    padding-block: clamp(60px, 7vw, 110px);
}

/* Two stacked rows inside .project-facts, each with [eyebrow | content]. */
.project-facts__grid {
    display: grid;
    grid-template-columns: minmax(160px, 280px) minmax(0, 1fr);
    gap: clamp(28px, 7vw, 118px);
    align-items: start;
}

.project-facts__grid + .project-facts__grid {
    margin-top: clamp(48px, 6vw, 88px);
}

.project-facts__stats {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 34px 44px;
}

.project-fact {
    min-width: 0;
}

.project-fact strong {
    display: block;
    margin-bottom: 6px;
    font-family: var(--font-display);
    font-size: clamp(30px, 3vw, 44px);
    font-weight: var(--fw-regular);
    line-height: 1;
    letter-spacing: 0;
}

.project-fact span {
    display: block;
    font-family: var(--font-body);
    font-size: 13px;
    line-height: 1.3;
    color: var(--color-text-muted);
}

.project-facts__description {
    max-width: 560px;
    font-family: var(--font-body);
    font-size: 15px;
    line-height: 1.65;
    color: var(--color-text-muted);
}

.project-facts__description p + p {
    margin-top: 18px;
}

/* ---- Green availability band ----------------------------------------- */
.project-availability {
    background: var(--color-sage);
    color: var(--color-surface);
    padding-block: clamp(56px, 7vw, 96px);
}

.project-availability__inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: clamp(32px, 5vw, 80px);
    align-items: center;
}

.project-availability__heading {
    display: flex;
    flex-direction: column;
    gap: clamp(18px, 2vw, 28px);
}

/* Section-eyebrow renders white on the sage band. */
.project-availability .section-eyebrow,
.project-availability .section-eyebrow__label {
    color: var(--color-white);
}
.project-availability .section-eyebrow__line {
    background: var(--color-white);
}

.project-availability h2 {
    max-width: 720px;
    margin: 0;
    color: inherit;
    font-family: var(--font-display);
    font-size: clamp(28px, 3.2vw, 48px);
    font-weight: var(--fw-regular);
    line-height: 1.08;
    letter-spacing: -0.4px;
}

.project-availability__stats {
    display: flex;
    gap: clamp(26px, 5vw, 74px);
	height: 100%;
	width: 50%;
    align-items: end;
	justify-self: end;
}

.project-availability__stats strong {
    display: block;
    font-family: var(--font-display);
    font-size: clamp(28px, 3vw, 43px);
    font-weight: var(--fw-regular);
    line-height: 1;
}

.project-availability__stats span {
    display: block;
    margin-top: 6px;
    font-size: 13px;
    color: rgba(252, 252, 252, 0.78);
}

.project-wide-image img {
    width: 100%;
    height: clamp(330px, 42vw, 650px);
    object-fit: cover;
}

.project-wide-image > div,
.project-wide-image [id^="image-map-pro-"],
.project-wide-image .imp-container,
.project-wide-image .imp-ui-wrap,
.project-wide-image .imp-canvas-wrap {
    max-width: 100%;
}

/* ---- Apartment selector ----------------------------------------------- */
.project-apartments {
    padding-block: clamp(68px, 8vw, 126px);
    background: transparent;
}

.project-apartments__header {
    display: flex;
    flex-direction: column;
    gap: 18px;
    margin-bottom: 40px;
    max-width: 760px;
}

.project-apartments__title {
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(32px, 3.6vw, 56px);
    font-weight: var(--fw-regular);
    line-height: 1.05;
    letter-spacing: -1px;
    color: var(--color-ink);
}

.project-apartments__tabs {
    display: grid;
    gap: 28px;
}

/* Tab nav — 4 separated cream cards, active flips to white with a sage rail on top. */
.project-apartments__nav {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}

.project-apartments__tab {
    position: relative;
    min-height: 96px;
    padding: 22px 24px;
    background: #F4F5EB;
    border: 0;
    border-top: 2px solid transparent;
    color: var(--color-ink);
    font-family: var(--font-display);
    text-align: left;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    gap: 6px;
    transition: background var(--transition-fast), border-color var(--transition-fast);
}

.project-apartments__tab-lead {
    font-size: 18px;
    font-weight: var(--fw-regular);
    line-height: 1.1;
}

.project-apartments__tab-tail {
    font-size: 18px;
    font-weight: var(--fw-medium);
    line-height: 1.1;
}

.project-apartments__tab:hover {
    background: #E9EBD8;
}

.project-apartments__tab[aria-selected="true"] {
    background: #DFE1CC;
    border-top-color: var(--color-brand);
}

/* Panel grid — info card (cream) on the left, floor plan (white) on the right. */
.project-apartments__panel {
    display: grid;
    grid-template-columns: minmax(300px, 420px) minmax(0, 1fr);
    gap: 0;
}

.project-apartments__panel[hidden] {
    display: none;
}

.project-apartments__info {
    display: flex;
    flex-direction: column;
    padding: clamp(28px, 3.2vw, 44px);
    background: var(--color-brand-soft);
    color: var(--color-ink);
}

.project-apartments__name {
    margin: 0 0 28px;
    font-family: var(--font-display);
    font-size: clamp(24px, 2.4vw, 34px);
    font-weight: var(--fw-regular);
    line-height: 1.1;
    letter-spacing: -0.4px;
}

.project-apartments__facts {
    margin: 0 0 32px;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
}

.project-apartments__facts > li {
    display: grid;
    grid-template-columns: 22px 1fr auto;
    align-items: center;
    gap: 12px;
    padding: 14px 0;
    border-bottom: 1px solid var(--color-border-soft, rgba(0, 0, 0, 0.08));
    font-size: 15px;
}

.project-apartments__facts > li:last-child {
    border-bottom: 0;
}

.project-apartments__fact-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-ink);
}

.project-apartments__fact-icon svg {
    width: 18px;
    height: 18px;
}

.project-apartments__fact-label {
    color: var(--color-ink);
    font-family: var(--font-body);
}

.project-apartments__fact-value {
    color: var(--color-ink);
    font-family: var(--font-display);
    font-weight: var(--fw-medium);
    text-align: right;
}

.project-apartments__actions {
    margin-top: auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

.project-apartments__cta,
.project-apartments__cta-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 48px;
    padding-inline: 18px;
    font-family: var(--font-display);
    font-size: 15px;
    font-weight: var(--fw-medium);
    line-height: 1;
    letter-spacing: var(--ls-snug);
    border: 1px solid var(--color-brand);
    transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}

.project-apartments__cta {
    background: var(--color-brand);
    color: var(--color-white);
}

.project-apartments__cta:hover,
.project-apartments__cta:focus-visible {
    background: var(--color-ink);
    border-color: var(--color-ink);
    color: var(--color-white);
}

.project-apartments__cta-secondary {
    background: transparent;
    color: var(--color-brand);
}

.project-apartments__cta-secondary:hover,
.project-apartments__cta-secondary:focus-visible {
    background: var(--color-brand);
    color: var(--color-white);
}

.project-apartments__plan {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 0;
    padding: clamp(20px, 4vw, 54px);
    background: var(--color-white);
}

.project-apartments__plan img {
    width: 100%;
    max-height: 480px;
    object-fit: contain;
}

@media (max-width: 520px) {
    .project-apartments__nav { grid-template-columns: 1fr; }
    .project-apartments__actions { grid-template-columns: 1fr; }
}

/* ---- Timeline ---------------------------------------------------------- */
/* Timeline rules moved to assets/css/sections/timeline.css — shared across templates. */

/* ---- Transaction steps ------------------------------------------------- */
.project-transaction {
    padding-block: clamp(74px, 8vw, 128px);
    background: var(--color-surface);
}

/* Left column: intro at top, CTA pinned to the bottom of the column,
   matching the height of the right-side step list. */
.project-transaction__intro {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: clamp(32px, 6vw, 80px);
    align-self: stretch; /* counter .project-section-grid's align-items: start */
}

.project-transaction__intro-top { display: flex; flex-direction: column; gap: 18px; }

.project-transaction__lede {
    max-width: 360px;
    margin: 0;
    font-family: var(--font-body);
    font-size: 15px;
    line-height: 1.45;
    color: var(--color-text-muted);
}

.project-transaction__cta {
    display: flex;
    flex-direction: column;
    gap: 18px;
    max-width: 360px;
}

.project-transaction__cta-title {
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(26px, 2.4vw, 34px);
    font-weight: var(--fw-regular);
    line-height: 1.1;
    letter-spacing: -0.4px;
    color: var(--color-ink);
}

.project-transaction__cta-text {
    margin: 0;
    font-family: var(--font-body);
    font-size: 15px;
    line-height: 1.45;
    color: var(--color-text-muted);
}

.project-transaction__cta .btn { align-self: flex-start; }

.project-transaction__steps {
    display: grid;
    gap: 20px;
}

.project-transaction__steps li {
    display: grid;
    grid-template-columns: 86px minmax(0, 1fr);
    gap: 34px;
    align-items: center;
    min-height: 132px;
    padding: 26px 34px;
    background: var(--color-surface-muted);
    border: 1px solid var(--color-border-soft);
}

.project-transaction__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 82px;
    height: 82px;
    background: var(--color-surface);
}

.project-transaction__icon img {
    width: 52px;
    height: 52px;
    object-fit: contain;
}

.project-transaction__icon > span {
    width: 42px;
    height: 42px;
    border: 1.5px solid var(--color-brand);
    border-radius: 50%;
}

.project-transaction__step-copy {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.project-transaction__step-copy p {
    font-family: var(--font-display);
    font-size: clamp(20px, 2vw, 24px);
    font-weight: var(--fw-regular);
    line-height: 1;
    letter-spacing: -3%;
	margin: 0;
}

.project-transaction__step-copy small {
    font-size: clamp(14px, 1.2vw, 16px);
    line-height: 1.2;
    color: var(--color-ink);
}

/* ---- Visual tour ------------------------------------------------------- */
.project-visual-tour {
    position: relative;
    min-height: clamp(420px, 52vw, 780px);
    padding-block: 80px;
    color: var(--color-surface);
    background:
        linear-gradient(90deg, rgba(3, 28, 25, 0.62), rgba(3, 28, 25, 0.08)),
        var(--project-tour-image) center / cover no-repeat;
    overflow: hidden;
}

.project-visual-tour .project-eyebrow,
.project-visual-tour h2 {
    color: var(--color-surface);
}

.project-visual-tour h2 {
    margin-top: 24px;
    font-size: clamp(32px, 4vw, 44px);
    font-weight: var(--fw-regular);
    line-height: 1.2;
    letter-spacing: -3%;
}

/* Inner wrap is a 2-column grid: copy on the left, framed icons on the right. */
.project-visual-tour__inner {
    position: relative;
    display: grid;
    grid-template-columns: 40% 60%;
    min-height: clamp(420px, 52vw, 666px);
}

.project-visual-tour__copy {
    position: relative;
    z-index: 2;
    max-width: 560px;
}

.project-visual-tour__visual {
    position: relative;
    align-self: stretch;
}

.project-visual-tour__markers,
.project-visual-tour__frames {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

.project-visual-tour__frame {
    position: absolute;
    border: 1px solid rgba(255, 255, 255, 0.6);
}

.project-visual-tour__marker {
    position: absolute;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    background: #FFEC8E; /* facility tile yellow */
    color: var(--color-ink);
    transform: translate(-50%, -50%);
}

.project-visual-tour__marker svg {
    width: 26px;
    height: 26px;
}

.project-visual-tour__marker--main {
    width: 110px;
    height: 110px;
    background: var(--color-brand);
    color: var(--color-white);
}

.project-visual-tour__marker--main svg {
    width: 56px;
    height: 56px;
}

/* ---- Zone map ---------------------------------------------------------- */
.project-zone {
    padding-block: clamp(72px, 8vw, 124px);
    background: var(--color-surface);
}

.project-zone__address {
    margin: 0 0 18px;
    color: var(--color-text-muted);
}

.project-zone__map {
    width: 100%;
    height: clamp(340px, 38vw, 560px);
    border: 1px solid var(--color-border-soft);
    background: var(--color-brand-soft);
}

.project-zone__map > p {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    margin: 0;
    color: var(--color-text-muted);
}

.project-zone__marker {
    background: transparent;
    border: 0;
}

.project-zone__marker span {
    display: block;
    width: 34px;
    height: 34px;
    background: var(--color-brand);
    border: 2px solid var(--color-surface);
    transform: rotate(45deg);
}

.project-zone__marker span::after {
    content: "";
    display: block;
    width: 10px;
    height: 10px;
    margin: 10px;
    background: var(--color-surface);
}

.project-zone__legend {
    display: flex;
    flex-wrap: wrap;
    gap: 16px 28px;
    margin-top: 18px;
    font-size: 13px;
    color: var(--color-text-muted);
}

.project-zone__legend li {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.project-zone__legend span {
    width: 14px;
    height: 14px;
    background: var(--color-brand);
}

.project-zone__legend li:nth-child(2) span {
    background: var(--color-accent);
}

.project-zone__legend li:nth-child(3) span {
    background: var(--color-sage);
}

.project-empty {
    max-width: 760px;
    padding: var(--space-7);
    background: var(--color-brand-soft);
}

.project-empty h2 {
    margin-bottom: 12px;
    font-size: 28px;
    letter-spacing: 0;
}

.project-empty p {
    color: var(--color-text-muted);
}

@media (max-width: 1180px) {
    .project-section-grid {
        grid-template-columns: 1fr;
    }

    .project-facts__grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 900px) {
    .project-intro__top,
    .project-availability__inner,
    .project-timeline__head {
        align-items: flex-start;
        flex-direction: column;
    }

    .project-intro__cta {
        width: 100%;
    }

    .project-apartments__panel {
        grid-template-columns: 1fr;
    }

    .project-facts__stats,
    .project-timeline[data-slider="false"] .project-timeline__items {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .project-timeline__rail-wrap {
        padding-left: 32px;
    }

    .project-timeline__details {
        grid-template-columns: 1fr;
        gap: 24px;
        padding-left: 0;
    }

    .project-apartments__nav {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .project-availability__stats {
        width: 100%;
        justify-content: space-between;
    }
}

@media (max-width: 640px) {
    .project-intro {
        padding-top: 20px;
    }

    .project-intro__thumbs {
        position: static;
        justify-content: flex-end;
        flex-wrap: wrap;
        gap: 6px;
        margin-top: 6px;
    }

    .project-intro__thumb {
        height: 68px;
        border: 0;
    }

    .project-facts__stats,
    .project-timeline[data-slider="false"] .project-timeline__items,
    .project-apartments__nav {
        grid-template-columns: 1fr;
    }

    .project-availability__stats {
        flex-direction: column;
        gap: 20px;
    }

    .project-timeline__rail-wrap {
        padding-left: 16px;
    }

    .project-timeline__head {
        gap: 18px;
    }

    .project-timeline__nav {
        gap: 10px;
    }

    .project-timeline__arrow {
        width: 48px;
        height: 48px;
    }

    .project-timeline__slide {
        min-height: 160px;
    }

    .project-timeline__cube {
        width: 132px;
        height: 132px;
        transform: none !important;
    }

    .project-timeline__cube::after {
        width: 42px;
        height: 42px;
        left: -12px;
    }

    .project-timeline__date {
        gap: 14px;
    }

    .project-transaction__steps li {
        grid-template-columns: 1fr;
        gap: 12px;
    }
}

/* ---- Project taxonomy mobile pass ---------------------------------------- */
@media (max-width: 700px) {
    body.tax-vaunt_sync_project {
        --header-height: 56px;
    }

    body.tax-vaunt_sync_project .site-header {
        padding-block: 0;
    }

    body.tax-vaunt_sync_project .site-header__inner {
        min-height: var(--header-height);
    }

    body.tax-vaunt_sync_project .site-header__logo img,
    body.tax-vaunt_sync_project .site-header__logo svg {
        height: 36px;
    }

    body.tax-vaunt_sync_project .menu-toggle {
        width: 40px;
        height: 40px;
        border: 0;
    }

    .project-archive .btn {
        min-height: 42px;
        height: auto;
        padding-inline: var(--space-4);
        font-size: var(--fs-sm);
        line-height: 1.1;
        letter-spacing: 0;
    }

    .project-breadcrumb {
        gap: 6px;
        margin-bottom: var(--space-3);
        font-size: var(--fs-xs);
        line-height: 1.4;
        flex-wrap: wrap;
    }

    .project-eyebrow {
        gap: var(--space-3);
    }

    .project-eyebrow span {
        width: 36px;
    }

    .project-section-grid,
    .project-facts__grid,
    .project-apartments__panel {
        grid-template-columns: 1fr;
    }

    .project-section-title {
        font-size: 1.875rem;
        line-height: 1.08;
    }

    .project-intro {
        padding-top: var(--space-4);
    }

    .project-intro__top {
        align-items: flex-start;
        gap: var(--space-4);
        margin-bottom: var(--space-4);
    }

    .project-intro__title {
        max-width: none;
        font-size: 1.875rem;
        line-height: 1.08;
    }

    .project-intro__cta {
        width: auto;
        align-self: flex-start;
    }

    .project-intro__hero {
        min-height: 0;
    }

    .project-intro__hero-img {
        height: clamp(240px, 78vw, 340px);
    }

    .project-intro__thumbs {
        position: static;
        justify-content: flex-end;
        flex-wrap: wrap;
        gap: 6px;
        margin-top: 6px;
    }

    .project-intro__thumb {
        height: clamp(64px, 19vw, 86px);
        border: 0;
    }

    .project-facts {
        padding-block: var(--space-7);
    }

    .project-facts__grid {
        gap: var(--space-5);
    }

    .project-facts__stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: var(--space-5) var(--space-4);
    }

    .project-fact strong {
        margin-bottom: var(--space-1);
        font-size: 2rem;
    }

    .project-fact span {
        font-size: var(--fs-xs);
        line-height: 1.35;
    }

    .project-facts__description {
        max-width: none;
        font-size: var(--fs-sm);
        line-height: 1.55;
    }

    .project-availability__inner {
        grid-template-columns: 1fr;
        gap: var(--space-5);
        min-height: 0;
        padding-block: var(--space-7);
    }

    .project-availability h2 {
        max-width: none;
        font-size: 1.75rem;
        line-height: 1.08;
    }

    .project-availability__stats {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: var(--space-4);
        width: 100%;
    }

    .project-availability__stats strong {
        font-size: 2rem;
    }

    .project-availability__stats span {
        font-size: var(--fs-xs);
        line-height: 1.25;
    }

    .project-wide-image {
        overflow: hidden;
        background: var(--color-surface-muted);
    }

    .project-wide-image img,
    .project-wide-image canvas,
    .project-wide-image iframe {
        display: block;
        max-width: 100%;
    }

    .project-wide-image > div,
    .project-wide-image [id^="image-map-pro-"],
    .project-wide-image .imp-container,
    .project-wide-image .imp-ui-wrap,
    .project-wide-image .imp-canvas-wrap {
        overflow: hidden;
    }

    .project-wide-image img {
        height: clamp(260px, 78vw, 360px);
    }

    .project-apartments {
        padding-block: var(--space-7);
    }

    .project-apartments__header {
        gap: var(--space-4);
        margin-bottom: var(--space-5);
    }

    .project-apartments__header .section-eyebrow {
        gap: var(--space-3);
        margin-bottom: 0;
    }

    .project-apartments__header .section-eyebrow__line {
        width: 36px;
    }

    .project-apartments__title {
        font-size: 2rem;
        line-height: 1.08;
        letter-spacing: 0;
    }

    .project-apartments__tabs {
        gap: var(--space-4);
    }

    .project-apartments__nav {
        grid-template-columns: 1fr;
        gap: var(--space-2);
    }

    .project-apartments__tab {
        min-height: 0;
        padding: 16px 18px;
        gap: 2px;
    }

    .project-apartments__tab-lead,
    .project-apartments__tab-tail {
        font-size: var(--fs-base);
        line-height: 1.2;
    }

    .project-apartments__info {
        padding: var(--space-5);
    }

    .project-apartments__name {
        margin-bottom: var(--space-4);
        font-size: var(--fs-xl);
        line-height: 1.15;
        letter-spacing: 0;
    }

    .project-apartments__facts {
        margin-bottom: var(--space-5);
    }

    .project-apartments__facts > li {
        grid-template-columns: 20px minmax(0, 1fr) auto;
        gap: var(--space-3);
        padding: 11px 0;
        font-size: var(--fs-sm);
    }

    .project-apartments__fact-value {
        white-space: nowrap;
    }

    .project-apartments__actions {
        grid-template-columns: 1fr;
    }

    .project-apartments__cta,
    .project-apartments__cta-secondary {
        height: 44px;
        font-size: var(--fs-sm);
        letter-spacing: 0;
    }

    .project-apartments__plan {
        padding: var(--space-4);
    }

    .project-apartments__plan img {
        max-height: 300px;
    }

    .project-archive .premium-materials {
        padding-block: var(--space-8);
    }

    .project-archive .premium-materials__header {
        margin-bottom: var(--space-6);
    }

    .project-archive .premium-materials__eyebrow {
        margin-bottom: var(--space-4);
    }

    .project-archive .premium-materials__title {
        font-size: 2rem;
        line-height: 1.08;
    }

    .project-archive .premium-materials__grid {
        grid-template-columns: 1fr;
        gap: var(--space-6);
    }

    .project-archive .premium-material {
        grid-template-columns: 30px minmax(0, 1fr);
        gap: var(--space-4);
    }

    .project-archive .premium-material__icon {
        width: 30px;
        height: 30px;
    }

    .project-archive .premium-material__body h3 {
        margin-bottom: var(--space-2);
        font-size: var(--fs-lg);
        line-height: 1.2;
    }

    .project-archive .premium-material__body p {
        font-size: var(--fs-sm);
        line-height: 1.45;
    }

    .project-archive .cta-section {
        min-height: 540px;
        padding-block: var(--space-7);
    }

    .project-archive .cta-section__inner {
        min-height: 420px;
        gap: var(--space-7);
        justify-content: space-between;
    }

    .project-archive .cta-section__feature {
        gap: var(--space-6);
    }

    .project-archive .cta-feature-card {
        max-width: none;
        padding: 32px 24px 24px;
    }

    .project-archive .cta-feature-card__badge {
        left: 24px;
        height: 40px;
        font-size: var(--fs-base);
        letter-spacing: 0;
    }

    .project-archive .cta-feature-card__list {
        gap: 20px;
    }

    .project-archive .cta-feature-card__list li {
        font-size: var(--fs-base);
        line-height: 1.25;
        letter-spacing: 0;
    }

    .project-archive .cta-feature-card__list li + li {
        padding-top: 20px;
    }

    .project-archive .cta-section__action {
        width: 100%;
        min-height: 52px;
        letter-spacing: 0;
    }

    .project-archive .project-timeline {
        padding-block: var(--space-8);
    }

    .project-archive .project-timeline__head {
        gap: var(--space-4);
        margin-bottom: var(--space-6);
    }

    .project-archive .project-timeline__nav {
        gap: var(--space-2);
    }

    .project-archive .project-timeline__arrow {
        width: 46px;
        height: 46px;
    }

    .project-archive .project-timeline__rail-wrap {
        padding-inline: 0;
    }

    .project-archive .project-timeline[data-slider="false"] .project-timeline__items {
        grid-template-columns: 1fr;
        gap: var(--space-5);
    }

    .project-archive .project-timeline__slide {
        min-height: 136px;
    }

    .project-archive .project-timeline__cube {
        width: 120px;
        height: 120px;
        margin-bottom: var(--space-4);
        padding: var(--space-4);
        font-size: var(--fs-base);
        transform: none !important;
    }

    .project-archive .project-timeline__cube::after {
        left: -10px;
        bottom: -14px;
        width: 36px;
        height: 36px;
    }

    .project-archive .project-timeline__details {
        grid-template-columns: 1fr;
        gap: var(--space-4);
        padding-top: var(--space-5);
        padding-left: 0;
    }

    .project-archive .project-timeline__date {
        grid-template-columns: 14px minmax(0, 1fr);
        gap: var(--space-3);
    }

    .project-archive .project-timeline__date span {
        width: 14px;
        height: 14px;
        margin-top: 7px;
    }

    .project-archive .project-timeline__date strong {
        font-size: 2rem;
        line-height: 1.04;
    }

    .project-archive .project-timeline__copy h2 {
        margin-bottom: var(--space-3);
        font-size: var(--fs-xl);
        line-height: 1.16;
    }

    .project-archive .project-timeline__copy p {
        font-size: var(--fs-sm);
        line-height: 1.55;
    }

    .project-transaction {
        padding-block: var(--space-8);
    }

    .project-transaction .project-section-grid {
        gap: var(--space-6);
    }

    .project-transaction p {
        margin: var(--space-4) 0 var(--space-5);
        font-size: var(--fs-sm);
        line-height: 1.55;
    }

    .project-transaction__steps {
        gap: var(--space-4);
    }

    .project-transaction__steps li {
        grid-template-columns: 52px minmax(0, 1fr);
        gap: var(--space-4);
        min-height: 0;
        padding: var(--space-4);
    }

    .project-transaction__icon {
        width: 52px;
        height: 52px;
    }

    .project-transaction__icon img {
        width: 32px;
        height: 32px;
    }

    .project-transaction__icon > span {
        width: 28px;
        height: 28px;
    }

    .project-transaction__step-copy {
        gap: var(--space-2);
    }

    .project-transaction__step-copy strong {
        font-size: var(--fs-lg);
        line-height: 1.18;
    }

    .project-transaction__step-copy small {
        font-size: var(--fs-sm);
        line-height: 1.4;
    }

    .project-visual-tour {
        min-height: 520px;
        padding-block: var(--space-7);
        background-position: center;
    }

    .project-visual-tour h2 {
        max-width: 320px;
        margin-top: var(--space-4);
        font-size: 2rem;
        line-height: 1.08;
    }

    .project-visual-tour__marker {
        width: 40px;
        height: 40px;
    }
    .project-visual-tour__marker svg { width: 22px; height: 22px; }

    .project-visual-tour__marker--main {
        width: 80px;
        height: 80px;
    }
    .project-visual-tour__marker--main svg { width: 42px; height: 42px; }

    .project-zone {
        padding-block: var(--space-8);
    }

    .project-zone__address {
        font-size: var(--fs-sm);
        line-height: 1.45;
    }

    .project-zone__map {
        height: 340px;
    }

    .project-zone__legend {
        display: grid;
        grid-template-columns: 1fr;
        gap: var(--space-3);
        font-size: var(--fs-xs);
        line-height: 1.35;
    }

    .project-archive .tunari-area {
        padding-top: var(--space-8);
    }

    .project-archive .tunari-area__header {
        margin-bottom: var(--space-6);
    }

    .project-archive .tunari-area__eyebrow {
        margin-bottom: var(--space-4);
    }

    .project-archive .tunari-area__title-row h3 {
        font-size: 2rem;
        line-height: 1.08;
    }

    .project-archive .tunari-area__title-row > p {
        font-size: var(--fs-sm);
        line-height: 1.4;
        padding-right: 0;
    }

    .project-archive .tunari-area__map {
        overflow: hidden;
    }

    .project-archive .tunari-area__map img {
        width: 100%;
        min-height: 280px;
        object-fit: cover;
    }

    .project-archive .tunari-area__legend-title,
    .project-archive .tunari-area__legend-list {
        padding: var(--space-5);
    }

    .project-archive .tunari-area__legend-title p {
        margin-bottom: var(--space-5);
        font-size: var(--fs-base);
        line-height: 1.2;
    }

    .project-archive .tunari-area__legend-item {
        gap: var(--space-3);
        min-height: 40px;
    }

    .project-archive .tunari-area__legend-icon {
        width: 40px;
        height: 40px;
        flex-basis: 40px;
    }

    .project-archive .contact-section {
        padding-block: var(--space-7);
    }

    .project-archive .contact-section__inner {
        gap: var(--space-6);
    }

    .project-archive .section-eyebrow {
        gap: var(--space-3);
        margin-bottom: var(--space-4);
    }

    .project-archive .section-eyebrow__line {
        width: 36px;
    }

    .project-archive .section-headline {
        font-size: 1.875rem;
        line-height: 1.08;
        letter-spacing: 0;
    }

    .project-archive .contact-section__intro .section-headline {
        margin-bottom: var(--space-6);
    }

    .project-archive .contact-section__office-title {
        margin-bottom: var(--space-4);
        font-size: var(--fs-lg);
        letter-spacing: 0;
    }

    .project-archive .contact-info {
        gap: var(--space-4);
        align-items: flex-start;
    }

    .project-archive .contact-info__icon {
        width: 48px;
        height: 48px;
    }

    .project-archive .contact-info__icon svg {
        width: 26px;
        height: 26px;
    }

    .project-archive .contact-info__primary {
        font-size: var(--fs-base);
        letter-spacing: 0;
        overflow-wrap: anywhere;
    }

    .project-archive .contact-info__secondary {
        font-size: var(--fs-sm);
        line-height: 1.35;
        letter-spacing: 0;
    }

    .project-archive .contact-form {
        gap: var(--space-4);
    }

    .project-archive .contact-form input[type="text"],
    .project-archive .contact-form input[type="email"],
    .project-archive .contact-form input[type="tel"],
    .project-archive .contact-form select,
    .project-archive .contact-form textarea {
        padding: 13px 16px;
        font-size: var(--fs-sm);
        letter-spacing: 0;
    }

    .project-archive .contact-form select {
        background-position: right 16px center;
        padding-right: 44px;
    }

    .project-archive .contact-form__check {
        gap: var(--space-3);
    }

    .project-archive .contact-form__submit {
        height: 52px;
        font-size: var(--fs-base);
        letter-spacing: 0;
    }

    .project-archive .project-apartments__header .section-eyebrow {
        gap: var(--space-3);
        margin-bottom: 0;
    }

    .project-archive .project-apartments__header .section-eyebrow__line {
        width: 36px;
    }
}

@media (max-width: 420px) {
    .project-intro__title,
    .project-section-title,
    .project-archive .section-headline {
        font-size: 1.625rem;
    }

    .project-apartments__title,
    .project-archive .premium-materials__title,
    .project-visual-tour h2,
    .project-archive .tunari-area__title-row h3 {
        font-size: 1.75rem;
    }

    .project-availability h2 {
        font-size: 1.5rem;
    }

    .project-fact strong,
    .project-availability__stats strong {
        font-size: 1.75rem;
    }

    .project-transaction__steps li {
        grid-template-columns: 1fr;
    }
}
