/*
 Theme Name:   Bricks Child Theme
 Theme URI:    https://bricksbuilder.io/
 Description:  Use this child theme to extend Bricks.
 Author:       Bricks
 Author URI:   https://bricksbuilder.io/
 Template:     bricks
 Version:      1.1
 Text Domain:  bricks
*/

:root {
    --page-max-width: 1600px;
    --video-crop-x: 30%;
    --hero-title: #e3e7bf;
    --text-dark: #000000;
    /* Glass card — mapped from Figma: light -45° @ 80%, refraction 80, depth 20, dispersion 50, frost 25, splay 0 */
    --glass-frost-blur: 10px;
    --glass-bg: rgba(236, 236, 223, 0.45);
    --glass-border: rgba(255, 255, 255, 0.42);
    --glass-light-angle: 135deg; /* -45° light → highlight top-left, ~80% intensity */
    --glass-depth-y: 10px;
    --glass-depth-blur: 28px;
    --glass-depth-alpha: 0.16;
}

@font-face {
    font-family: "PP Neue Montreal";
    src: url("./agent/assets/fonts/original-font/PPNeueMontreal-Book.woff2") format("woff2"),
        url("./agent/assets/fonts/original-font/PPNeueMontreal-Book.woff") format("woff");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "PP Neue Montreal";
    src: url("./agent/assets/fonts/original-font/PPNeueMontreal-Medium.woff2") format("woff2"),
        url("./agent/assets/fonts/original-font/PPNeueMontreal-Medium.woff") format("woff");
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "PP Neue Montreal";
    src: url("./agent/assets/fonts/original-font/PPNeueMontreal-SemiBold.woff2") format("woff2"),
        url("./agent/assets/fonts/original-font/PPNeueMontreal-SemiBold.woff") format("woff");
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

* {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    padding: 0;
    min-height: 100%;
}

body {
    font-family: "PP Neue Montreal", "Neue Montreal", "Helvetica Neue", Arial, sans-serif;
    background: #ffffff;
    color: var(--text-dark);
}

.page {
    width: 100%;
    /* max-width: var(--page-max-width);
    margin: 0 auto; */
}

.section-contained {
    max-width: var(--page-max-width);
    margin: 0 auto;
}

.hero {
    position: relative;
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    height: calc(100vh + 100px);
    min-height: calc(100vh + 100px);
    min-height: calc(100dvh + 100px);
    overflow: hidden;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 40px 20px 14px;
}

.hero-video {
    position: absolute;
    top: 0;
    left: calc(-1 * var(--video-crop-x));
    width: calc(100% + (2 * var(--video-crop-x)));
    height: 100%;
    object-fit: cover;
    object-position: center center;
    transform: scale(1.02);
    z-index: 0;
}

.hero-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(
        to bottom,
        rgba(8, 14, 8, 0.16) 0%,
        rgba(8, 14, 8, 0.04) 40%,
        rgba(8, 14, 8, 0.18) 100%
    );
}

.hero-content {
    width: 100%;
    position: relative;
    z-index: 2;
}

.hero-logo {
    display: block;
    width: calc(100% - 100px);
    margin: 0 30px;
    height: auto;
}

.glass-card {
    position: relative;
    margin: -58px auto 0;
    width: min(100%, 1246px);
    height: 644px;
    min-height: 644px;
    border-radius: 20px;
    padding: 52px 64px;
    isolation: isolate;
    overflow: hidden;
    border: 1px solid var(--glass-border);
    background: var(--glass-bg);
    /* Frost 25: lighter blur; Refraction 80: slight clarity via contrast */
    backdrop-filter: blur(var(--glass-frost-blur)) saturate(118%) contrast(1.06);
    -webkit-backdrop-filter: blur(var(--glass-frost-blur)) saturate(118%) contrast(1.06);
    /* Depth 20, Splay 0: tight shadow, no wide glow */
    box-shadow:
        inset 1px 1px 0 rgba(255, 255, 255, 0.55),
        inset 0 -1px 0 rgba(0, 0, 0, 0.04),
        0 var(--glass-depth-y) var(--glass-depth-blur) rgba(0, 0, 0, var(--glass-depth-alpha));
}

/* Light -45° @ 80% + dispersion 50 approximated as soft specular + subtle chroma fringe */
.glass-card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    z-index: 0;
    background: linear-gradient(
        var(--glass-light-angle),
        rgba(255, 255, 255, 0.44) 0%,
        rgba(255, 255, 255, 0) 42%
    );
    mix-blend-mode: soft-light;
}

.glass-card::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    z-index: 0;
    opacity: 0.35;
    box-shadow:
        inset 0 0 0 1px rgba(200, 220, 255, 0.12),
        inset 0 0 48px rgba(255, 245, 230, 0.06);
}

.chip {
    position: absolute;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    gap: 30px;
    font-size: 50px;
    line-height: 1;
    font-weight: 500;
    color: #000;
    letter-spacing: 0.005em;
}

.dot {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: #000;
    flex: 0 0 30px;
}

.chip-time {
    top: 93px;
    left: 120px;
}

.chip-well {
    top: 298px;
    right: 250px;
}

.chip-invested {
    top: 419px;
    left: 423px;
}

.card-caption {
    position: absolute;
    z-index: 1;
    left: 44px;
    bottom: 24px;
    margin: 0;
    font-size: 22px;
    line-height: 1.1;
    color: #000;
}

.download-btn {
    display: block;
    margin: 28px auto 0;
    border: none;
    border-radius: 12px;
    transition: background-color 0.5s ease-in-out, color 0.5s ease-in-out;
    background: #d8dac1;
    color: #000000;
    font-size: clamp(16px, 1vw, 20px);
    letter-spacing: 0.02em;
    padding: 14px 38px;
    font-family: inherit;
    font-weight: 500;
    cursor: pointer;
}

.download-btn:hover {
    background: #000000;
    color: #ffffff;
}

body.hero-intro .hero-logo,
body.hero-intro .glass-card,
body.hero-intro .chip,
body.hero-intro .card-caption,
body.hero-intro .download-btn {
    animation-play-state: paused;
}

body.hero-intro.hero-intro-play .hero-logo,
body.hero-intro.hero-intro-play .glass-card,
body.hero-intro.hero-intro-play .chip,
body.hero-intro.hero-intro-play .card-caption,
body.hero-intro.hero-intro-play .download-btn {
    animation-play-state: running;
}

body.hero-intro .hero-logo {
    opacity: 0;
    transform: translateY(18px);
    animation: heroLogoIn 0.8s ease-out 0.5s forwards;
}

body.hero-intro .glass-card {
    transform: translateY(72vh);
    opacity: 0;
    visibility: hidden;
}

body.hero-intro.hero-intro-play .glass-card {
    visibility: visible;
    animation: heroCardRise 1.15s cubic-bezier(0.22, 1, 0.36, 1) 1.3s forwards;
}

body.hero-intro .chip,
body.hero-intro .card-caption,
body.hero-intro .download-btn {
    opacity: 0;
    transform: translateY(16px);
    animation: heroTextIn 0.75s ease-out 2.45s forwards;
}

@keyframes heroLogoIn {
    from {
        opacity: 0;
        transform: translateY(18px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes heroCardRise {
    from {
        opacity: 0;
        transform: translateY(72vh);
    }
    to {
        opacity: 0.96;
        transform: translateY(0);
    }
}

@keyframes heroTextIn {
    from {
        opacity: 0;
        transform: translateY(16px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* —— Single Text Section (shared widget) —— */
.single-text-section {
    --single-text-opacity: 0;
    --single-text-blur: 16px;
    --single-text-y: 108px;
    box-sizing: border-box;
    padding: 48px 20px 24px;
}

.single-text-section__inner {
    width: min(100%, 1410px);
    margin: 0;
}

.single-text-section__kicker {
    margin: 0;
    display: inline-flex;
    align-items: center;
    gap: 12px;
    font-size: 36px;
    font-weight: 500;
    line-height: 1.15;
    color: #000000;
}

.dot-text-label {
    margin: 0;
    display: inline-flex;
    align-items: center;
    gap: 12px;
    font-size: 20px;
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: 0.08em;
    color: #000000;
    white-space: nowrap;
}

.dot-text-label__dot {
    width: 11px;
    height: 11px;
    border-radius: 50%;
    background: #000000;
    flex-shrink: 0;
}

.single-text-section__dot {
    width: 11px;
    height: 11px;
    border-radius: 50%;
    background: #000000;
    flex-shrink: 0;
}

.single-text-section__text {
    margin: 0;
    margin-right: auto;
    max-width: 1120px;
    font-size: 37px;
    font-weight: 500;
    line-height: 1.1;
    letter-spacing: -0.01em;
    color: #000000;
    text-align: left;
    will-change: transform, filter, opacity;
    opacity: var(--single-text-opacity);
    transform: translateY(var(--single-text-y));
    filter: blur(var(--single-text-blur));
}

.single-text-section--thesis {
    height: 600px;
    min-height: 600px;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    background: #ffffff;
    padding: 170px 20px 24px;
}

.single-text-section--thesis .single-text-section__inner {
    width: min(100%, 1410px);
}

.single-text-section--thesis .single-text-section__text {
    max-width: 1100px;
}

.brand-intro-section {
    --brand-intro-opacity: 0;
    --brand-intro-blur: 14px;
    --brand-intro-y: 80px;
    position: relative;
    overflow: hidden;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.brand-intro-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 1;
    pointer-events: none;
}



.brand-intro-content {
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: 980px;
    margin: 0 auto;
    padding: 32px 24px;
    text-align: center;
    color: #FBFBC7;
    opacity: var(--brand-intro-opacity);
    transform: translateY(var(--brand-intro-y));
    filter: blur(var(--brand-intro-blur));
    will-change: transform, opacity, filter;
}

.brand-intro-kicker {
    margin: 0;
    font-size: 24px;
    line-height: 1;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.brand-intro-logo {
    margin: 42px auto 0;
    display: block;
    width: min(100%, 640px);
    height: auto;
}

.brand-intro-subtitle {
    margin: 80px 0 0;
    font-size: 24px;
    line-height: 1.22;
    font-weight: 500;
    letter-spacing: 0.01em;
}

.single-text-section--south {
    padding: 26px 20px 170px;
    min-height: 600px;
}

.single-text-section--south .single-text-section__text {
    margin-top: 120px;
}

/* —— Time Render Section —— */
.time-render-section {
    padding: 30px 20px 100px;
}

.time-render-wrap {
    width: 100%;
}

.time-render-title {
    margin: 0;
}

.time-render-dot {
    flex: 0 0 auto;
}

.time-render-grid {
    margin-top: 36px;
    display: grid;
    grid-template-columns: minmax(140px, 1fr) minmax(300px, 500px) minmax(140px, 1fr);
    align-items: center;
    column-gap: 24px;
}

.time-render-address,
.time-render-time {
    margin: 0;
    font-size: 14px;
    line-height: 1;
    font-weight: 400;
    letter-spacing: 0.02em;
    color: #000000;
    text-transform: uppercase;
}

.time-render-address {
    justify-self: center;
}

.time-render-time {
    justify-self: center;
    min-width: 86px;
    text-align: center;
}

.time-render-media {
    width: 100%;
}

.time-render-video {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 2 / 3;
    object-fit: cover;
}

/* —— Time Well Invested Glass Section —— */
.invested-glass-section {
    background: #d7cc79;
    padding: 45px 20px 40px 45px;
}

.invested-glass-wrap {
    position: relative;
}

.invested-glass-columns {
    display: grid;
    grid-template-columns: 1fr minmax(560px, 1.16fr);
    align-items: center;
    column-gap: 32px;
}

.invested-copy {
    position: relative;
    z-index: 2;
}

.invested-copy-lines {
    margin: 0;
    font-size: 180px;
    line-height: 0.92;
    letter-spacing: -0.03em;
    font-weight: 500;
    color: #000000;
}

.invested-copy-btn {
    margin-top: 78px;
    border: 1px solid rgba(255, 255, 255, 0.42);
    border-radius: 12px;
    transition: background-color 0.45s ease-in-out, color 0.45s ease-in-out;
    background: rgba(244, 241, 178, 0.45);
    color: #000000;
    font-size: 16px;
    letter-spacing: 0.01em;
    line-height: 1;
    text-transform: uppercase;
    padding: 16px 28px;
    font-family: inherit;
    font-weight: 500;
    cursor: pointer;
}

.invested-copy-btn:hover {
    background: #000000;
    color: #ffffff;
}

.invested-glass-card {
    position: relative;
    z-index: 2;
    justify-self: end;
    width: 65vw;
    max-width: 930px;
    border-radius: 20px;
    padding: 24px;
    border: 1px solid rgba(255, 255, 255, 0.46);
    background: rgba(246, 244, 210, 0.52);
    /* Glass refs: light -45° @80, refraction 72, depth 20, dispersion 31, frost 21, splay 0 */
    backdrop-filter: blur(9px) saturate(114%) contrast(1.05);
    -webkit-backdrop-filter: blur(9px) saturate(114%) contrast(1.05);
    box-shadow:
        inset 1px 1px 0 rgba(255, 255, 255, 0.56),
        inset 0 -1px 0 rgba(0, 0, 0, 0.04),
        0 10px 28px rgba(0, 0, 0, 0.14);
}

.invested-glass-card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.42) 0%, rgba(255, 255, 255, 0) 46%);
    mix-blend-mode: soft-light;
}

.invested-video-shell {
    position: relative;
    overflow: hidden;
    border-radius: 20px;
    width: 540px;
    height: 695px;
    min-height: 695px;
    max-width: 100%;
    margin-left: auto;
    background: #dfdbbb;
}

.invested-video {
    position: absolute;
    top: 0;
    left: -34%;
    width: 168%;
    height: 100%;
    object-fit: cover;
    object-position: 50% center;
    transform: scale(1.04);
}

.invested-video-logo {
    position: absolute;
    top: 40%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: min(80%, 470px);
    height: auto;
    z-index: 2;
}

.invested-blur-word {
    position: absolute;
    left: 38%;
    top: 66%;
    transform: translate(-50%, -50%);
    margin: 0;
    font-size: 120px;
    line-height: 1;
    font-weight: 500;
    letter-spacing: -0.02em;
    color: rgba(12, 20, 52, 0.42);
    filter: blur(6px);
    pointer-events: none;
    z-index: 3;
}

/* —— Brand line (SIXTY · PARK) —— */
.brand-line-section {
    background: #ffffff;
    padding: 40px 50px;
}

.brand-line {
    display: grid;
    grid-template-columns: auto 1fr auto 1fr auto;
    align-items: center;
    column-gap: clamp(24px, 4.5vw, 56px);
    width: 100%;
    max-width: var(--page-max-width);
    margin: 0 auto;
}

.brand-line-col {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 0;
}

.brand-line-col--sixty {
    justify-content: center;
}

.brand-line-col--park {
    justify-content: center;
}

.brand-line-logo {
    display: block;
    width: auto;
    max-width: 100%;
    height: auto;
    max-height: 38px;
}

.brand-line-dot {
    width: 11px;
    height: 11px;
    border-radius: 50%;
    background: #000000;
    flex-shrink: 0;
}

/* —— Proximity glass card (Figma Glass: light −45° / 80%, refraction 80, depth 10, dispersion 50, frost 6, splay 0; selection #000, #FFFFFF 60%) —— */
.proximity-glass-section {
    --proximity-opacity: 0;
    --proximity-blur: 14px;
    --proximity-y: 72px;
    position: relative;
    isolation: isolate;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    min-height: 100dvh;
    padding: clamp(48px, 7vw, 112px) 20px;
    overflow: hidden;
}

.proximity-glass-section__bg {
    position: absolute;
    inset: -4px;
    z-index: 0;
    width: calc(100% + 8px);
    height: calc(100% + 8px);
    object-fit: cover;
    object-position: center;
    pointer-events: none;
}

.proximity-glass-section__inner {
    position: relative;
    z-index: 1;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.proximity-glass-card {
    position: relative;
    width: 100%;
    max-width: 784px;
    margin: 0 auto;
    padding: 56px clamp(32px, 5.5vw, 60px);
    border-radius: 18px;
    text-align: center;
    color: #000000;
    /* Fill: #FFFFFF @ 60% */
    background: rgba(255, 255, 255, 0.6);
    border: 1px solid rgba(255, 255, 255, 0.35);
    box-shadow:
        0 22px 56px rgba(0, 0, 0, 0.16),
        inset 0 1px 0 rgba(255, 255, 255, 0.55),
        inset 0 -1px 0 rgba(0, 0, 0, 0.05);
    /* Frost 6, refraction 80, dispersion 50 (approx. via saturate), depth 10 (inset edge), splay 0 */
    backdrop-filter: blur(3px) saturate(1.8) contrast(1.04);
    -webkit-backdrop-filter: blur(6px) saturate(1.8) contrast(1.04);
}

.proximity-glass-card::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    border-radius: inherit;
    pointer-events: none;
    /* Light −45° (~135deg) @ high intensity */
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.55) 0%, rgba(255, 255, 255, 0) 50%);
    mix-blend-mode: soft-light;
}

.proximity-glass-card__text {
    position: relative;
    z-index: 1;
    margin: 0;
    font-size: 31px;
    line-height: 1.48;
    font-weight: 500;
    color: #000000;
    opacity: var(--proximity-opacity);
    transform: translateY(var(--proximity-y));
    filter: blur(var(--proximity-blur));
    will-change: transform, opacity, filter;
}

.proximity-glass-card__text::selection {
    background: rgba(0, 0, 0, 0.12);
    color: #000000;
}

/* —— Journey dual videos (from / to) —— */
.journey-dual-section {
    --journey-overlay-opacity: 0;
    --journey-overlay-blur: 12px;
    --journey-overlay-y: 44px;
    background: #ffffff;
    padding: 120px 137px 120px 20px;
}

.journey-dual-inner {
    width: 100%;
}

.journey-dual-grid {
    display: grid;
    grid-template-columns: minmax(0, 685fr) minmax(0, 466fr);
    align-items: center;
    column-gap: 132px;
    width: 100%;
}

.journey-dual-tile {
    margin: 0;
}

.journey-dual-split {
    position: relative;
    width: 100%;
}

/* Side captions: layout + text only on small screens (large view uses overlay row only). */
.journey-dual-caption {
    display: none;
    margin: 0;
}

.journey-dual-media {
    position: relative;
    width: 100%;
    overflow: hidden;
    background: #1a1a1a;
}

.journey-dual-tile--primary .journey-dual-media {
    aspect-ratio: 685 / 698;
}

.journey-dual-tile--secondary .journey-dual-media {
    aspect-ratio: 466 / 510;
}

.journey-dual-video {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.journey-dual-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    padding: 0 clamp(14px, 2.4vw, 40px);
    pointer-events: none;
    color: #ffffff;
    text-transform: uppercase;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0.08em;
    line-height: 1.15;
    text-align: left;
    text-shadow: 0 1px 12px rgba(0, 0, 0, 0.55);
    opacity: var(--journey-overlay-opacity);
    transform: translateY(var(--journey-overlay-y));
    filter: blur(var(--journey-overlay-blur));
    will-change: transform, opacity, filter;
}

.journey-dual-overlay__row {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: flex-start;
    gap: clamp(16px, 2.2vw, 40px);
}

.journey-dual-overlay__row > span {
    text-align: left;
}

.journey-dual-overlay__row > span:nth-child(-n + 2) {
    flex-shrink: 0;
}

.journey-dual-overlay__row > span:nth-child(3) {
    max-width: 18em;
    min-width: 0;
    line-height: 1.2;
}

/* —— Montage grid over fixed heading —— */
.montage-section {
    position: relative;
    padding: 0 20px 110px;
}

.montage-section__inner {
    position: relative;
}

.montage-section__heading {
    position: sticky;
    top: 12vh;
    z-index: 1;
    margin: 0;
    padding: 22vh 0 16vh;
    font-size: 135px;
    line-height: 1;
    font-weight: 500;
    letter-spacing: -0.03em;
    color: #000000;
    text-align: center;
    pointer-events: none;
}

.montage-section__heading-break {
    display: none;
}

.montage-grid {
    position: relative;
    z-index: 2;
    margin-top: 110px;
    transform: translateY(var(--montage-scroll-shift, 0px));
    will-change: transform;
    width: min(100%, 1377px);
    height: 1698px;
    margin-left: auto;
    margin-right: auto;
}

.montage-card {
    --card-parallax-speed: 0.16;
    position: absolute;
    margin: 0;
    border-radius: 20px;
    overflow: visible;
    transform: translateY(calc(var(--montage-scroll-shift, 0px) * var(--card-parallax-speed)));
    will-change: transform;
    transition: transform 0.12s linear;
    box-shadow: 0 20px 44px rgba(0, 0, 0, 0.1);
}

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

.montage-chip {
    position: absolute;
    left: 12px;
    bottom: 12px;
    z-index: 2;
    margin: 0;
    border-radius: 12px;
    border: 1px solid rgba(214, 214, 214, 0.44);
    background: rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(10px) saturate(112%) contrast(1.02);
    -webkit-backdrop-filter: blur(10px) saturate(112%) contrast(1.02);
    color: #ffffff;
    font-size: 16px;
    font-weight: 500;
    text-transform: uppercase;
    line-height: 100%;
    letter-spacing: 0.8px;
    padding: 12px 30px;
    min-width: 130px;
    white-space: nowrap;
    text-shadow: none;
}

.montage-card--garden .montage-chip {
    left: -20px;
    top: 20px;
    bottom: auto;
}

.montage-card--dining .montage-chip {
    left: 12px;
    bottom: 12px;
}

.montage-card--retail .montage-chip {
    left: -20px;
    bottom: 60px;
}

.montage-card--bars .montage-chip {
    left: 70%;
    transform: translateX(-50%);
    bottom: -10px;
}

.montage-card--sports .montage-chip {
    left: -20px;
    bottom: -12px;
}

.montage-card--hero .montage-chip {
    right: 10px;
    left: auto;
    bottom: -10px;
    text-align: center;
}

.montage-card--station .montage-chip {
    right: -15px;
    left: auto;
    bottom: -10px;
}

.montage-card--garden {
    --card-parallax-speed: 0.1;
    left: 52px;
    top: 407px;
    width: 379px;
    height: 356px;
    aspect-ratio: 379 / 356;
}

.montage-card--dining {
    --card-parallax-speed: 0.22;
    left: 530px;
    top: 139px;
    width: 372px;
    height: 350px;
    aspect-ratio: 372 / 350;
}

.montage-card--retail {
    --card-parallax-speed: 0.14;
    left: 1068px;
    top: 272px;
    width: 289px;
    height: 312px;
    aspect-ratio: 289 / 312;
}

.montage-card--bars {
    --card-parallax-speed: 0.08;
    left: 20px;
    top: 918px;
    width: 317px;
    height: 317px;
    aspect-ratio: 317 / 317;
}

.montage-card--sports {
    --card-parallax-speed: 0.28;
    left: 426px;
    top: 810px;
    width: 326px;
    height: 343px;
    aspect-ratio: 326 / 343;
}

.montage-card--hero {
    --card-parallax-speed: 0.2;
    left: 823px;
    top: 639px;
    width: 533px;
    height: 541px;
    aspect-ratio: 533 / 541;
}

.montage-card--station {
    --card-parallax-speed: 0.26;
    left: 333px;
    top: 1295px;
    width: 613px;
    height: 403px;
    aspect-ratio: 613 / 403;
}

/* —— Fullscreen map —— */
.map-fullscreen-section {
    width: 100%;
    height: 100vh;
    height: 100dvh;
    overflow: hidden;
    background: #e5e7dc;
    position: relative;
}

.map-fullscreen-image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    transform-origin: center center;
    will-change: transform;
    transition: transform 0.25s ease-out;
    user-select: none;
    -webkit-user-drag: none;
    pointer-events: none;
}

.map-fullscreen-section--dragging .map-fullscreen-image {
    transition: none;
}

.map-zoom-controls {
    position: absolute;
    right: 16px;
    bottom: 16px;
    display: none;
    grid-template-columns: 1fr;
    gap: 8px;
    z-index: 2;
}

.map-zoom-btn {
    width: 44px;
    height: 44px;
    border: 1px solid rgba(255, 255, 255, 0.68);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.85);
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.14);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    cursor: pointer;
}

.map-zoom-btn img {
    width: 18px;
    height: 18px;
    object-fit: contain;
    display: block;
}

/* —— Park modern: background + chart overlay (scroll reveal) —— */
.park-modern-section {
    --park-chart-opacity: 0;
    --park-chart-y: 62vh;
    --park-chart-vertical-gap: 485px;
    position: relative;
    box-sizing: border-box;
    width: 100%;
    min-height: 320vh;
    border-radius: 20px;
    padding-top:180px;
    padding-bottom:180px;
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.park-modern-section__sticky {
    position: sticky;
    top: 0;
    height: 100vh;
    height: 100dvh;
    width: 100%;
    box-sizing: border-box;
    padding: 20px;
    overflow: hidden;
    isolation: isolate;
}

.park-modern-section__bg {
    position: absolute;
    inset: 20px;
    border-radius: 20px;
    overflow: hidden;
}

.park-modern-section__bg-img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.park-modern-section__charts {
    position: absolute;
    top: 20px;
    bottom: 20px;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: min(calc(100% - 176px), var(--page-max-width));
    z-index: 1;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto var(--park-chart-vertical-gap) auto;
    height: 100%;
    box-sizing: border-box;
    pointer-events: none;
    will-change: transform, opacity;
    transform: translateY(var(--park-chart-y, 62vh));
    opacity: var(--park-chart-opacity, 0);
}

.park-chart {
    position: relative;
    width: min(100%, 555px);
    min-height: 320px;
    padding: 44px clamp(20px, 4vw, 40px) 36px;
    border-radius: 20px;
    background: rgba(161, 149, 77, 0.3);
    border: 1px solid rgba(255, 255, 255, 0.38);
    backdrop-filter: blur(38px) saturate(135%) contrast(1.04);
    -webkit-backdrop-filter: blur(38px) saturate(135%) contrast(1.04);
    box-shadow:
        0 8px 26px rgba(0, 0, 0, 0.14),
        inset 0 1px 1px rgba(255, 255, 255, 0.24),
        inset 0 -1px 0 rgba(0, 0, 0, 0.08);
    box-sizing: border-box;
    will-change: transform;

    
}

.park-chart::before {
    content: none;
}

.park-chart--transport {
    grid-column: 1;
    grid-row: 1;
    justify-self: start;
    align-self: start;
}

.park-chart--walking {
    grid-column: 2;
    grid-row: 3;
    justify-self: end;
    align-self: end;
}

.park-chart__title {
    margin: 0 auto 28px;
    max-width: 320px;
    font-size: 20px;
    line-height: 1.2;
    font-weight: 500;
    letter-spacing: 0.02em;
    color: #ffffff;
    text-align: center;
}

.park-chart--transport .park-chart__title {
    max-width: 340px;
}

.park-chart__columns {
    display: flex;
    justify-content: center;
    align-items: stretch;
    gap: clamp(32px, 6vw, 60px);
}

.park-chart__col {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 120px;
    flex: 0 0 auto;
}

.park-chart__value {
    margin: 0 0 12px;
    font-size: 50px;
    line-height: 1;
    font-weight: 500;
    letter-spacing: 0.02em;
    color: #ffffff;
    text-align: center;
}

.park-chart__col--muted .park-chart__value {
    color: rgba(255, 255, 255, 0.7);
}

.park-chart__track {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    width: 100%;
    height: 200px;
    margin-bottom: 12px;
}

.park-chart__bar {
    width: 100%;
    max-width: 114px;
    border-radius: 14px;
    background: #ffffff;
    height: calc(200px * var(--pct, 1) / var(--max, 1));
    min-height: 10px;
}

.park-chart__col--muted .park-chart__bar {
    background: rgba(255, 255, 255, 0.7);
}

.park-chart__label {
    margin: 0;
    font-size: 10px;
    line-height: 1;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: #ffffff;
    text-align: center;
}

.park-chart__col--muted .park-chart__label {
    color: rgba(255, 255, 255, 0.7);
}

/* —— Footer partners —— */
.site-footer-partners {
    background: #ffffff;
    border-top: 1px solid #D5D5D5;
}

.site-footer-partners__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    width: 100%;
}

.site-footer-partners__cell {
    min-width: 0;
    min-height: 140px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 14px;
    text-align: center;
}

.site-footer-partners__cell + .site-footer-partners__cell {
    border-left: 1px solid #D5D5D5;
}

.site-footer-partners__label {
    margin: 0;
    font-size: 13px;
    font-weight: 300;
    line-height: 1;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #000000;
}

.site-footer-partners__logo {
    display: block;
    width: auto;
    height: auto;
    max-width: 100%;
}

.site-footer-partners__logo--dko {
    max-height: 34px;
}

.site-footer-partners__logo--tp {
    max-height: 33px;
}

/* —— Introduction —— */
.intro-section {
    --intro-copy-opacity: 0;
    --intro-copy-blur: 16px;
    --intro-copy-y: 108px;
    background: #ffffff;
    padding: 40px 20px 220px;
}

.intro-inner {
    width: 100%;
    max-width: none;
    margin: 0;
}

.intro-columns {
    display: grid;
    width: 100%;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    column-gap: 115px;
    align-items: stretch;
}

.intro-col--left {
    display: flex;
    flex-direction: column;
    gap: 0;
    min-width: 0;
}

.intro-col--right {
    display: flex;
    flex-direction: column;
    min-width: 0;
    padding-right: 117px;
}

.intro-head {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    margin-bottom: 120px;
}

.intro-divider {
    display: block;
    width: 100%;
    height: 1px;
    background: var(--text-dark);
    opacity: 0.28;
}

.intro-heading {
    margin: 0;
}

.intro-dot {
    flex-shrink: 0;
}

.intro-copy-wrap {
    align-self: stretch;
    margin-bottom: clamp(80px, 4vw, 48px);
}

.intro-copy {
    text-align: left;
    max-width: 100%;
    will-change: transform, filter, opacity;
    opacity: var(--intro-copy-opacity);
    transform: translateY(var(--intro-copy-y));
    filter: blur(var(--intro-copy-blur));
}

.intro-copy p {
    margin: 0;
    font-size: 20px;
    line-height: 1.45;
    color: #000000;
}

.intro-copy p {
    font-weight: 500;
}

.intro-figure {
    margin: 0;
}

.intro-figure img {
    display: block;
    width: 100%;
    height: auto;
}

.intro-figure--portrait {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    margin: 0;
    min-height: 0;
    padding-top: 60px;
}

.intro-figure--portrait img {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 466 / 565;
    object-fit: cover;
    object-position: center;
}

.intro-figure--landscape {
    margin-top: 0;
}

.intro-figure--landscape img {
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 700 / 495;
    object-fit: cover;
    object-position: center;
}

.intro-figcaption {
    margin-top: 14px;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 0.02em;
    color: #000000;
    text-align: left;
}

/* —— Blur Image + Text —— */
.time-scarcity-section {
    --time-scarcity-opacity: 0;
    --time-scarcity-blur: 14px;
    --time-scarcity-y: 90px;
    position: relative;
    overflow: hidden;
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.time-scarcity-bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    z-index: 0;
    pointer-events: none;
}

.time-scarcity-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: rgba(161, 149, 77, calc(0.48 * var(--time-scarcity-opacity)));
    backdrop-filter: blur(calc(14px - var(--time-scarcity-blur)));
    -webkit-backdrop-filter: blur(calc(14px - var(--time-scarcity-blur)));
}

.time-scarcity-content {
    position: relative;
    z-index: 2;
    width: 100%;
    max-width: 920px;
    margin: 0 auto;
    padding: 0 24px;
}

.time-scarcity-content p {
    margin: 0;
    text-align: center;
    color: #ffffff;
    font-size: 37px;
    line-height: 1.3;
    font-weight: 400;
    letter-spacing: 2%;
    opacity: var(--time-scarcity-opacity);
    transform: translateY(var(--time-scarcity-y));
    will-change: transform, opacity;
}

/* —— Forecast Report Section —— */
.report-section {
    --report-opacity: 0;
    --report-blur: 16px;
    --report-y: 90px;
    background: #E5E7D9;
    padding: 26px 20px 36px;
}

.report-inner {
    width: 100%;
}

.report-head {
    margin-bottom: 62px;
}

.report-kicker {
    margin: 0;
}

.report-dot {
    flex-shrink: 0;
}

.report-intro {
    margin: 0 0 132px;
    margin-right: auto;
    max-width: 1100px;
    font-size: 37px;
    line-height: 1.1;
    font-weight: 500;
    letter-spacing: -0.01em;
    color: #000000;
    text-align: left;
    opacity: var(--report-opacity);
    transform: translateY(var(--report-y));
    filter: blur(var(--report-blur));
    will-change: transform, opacity, filter;
}

.report-chart {
    display: grid;
    gap: 24px;
}

.report-row {
    display: grid;
    grid-template-columns: 350px minmax(0, 1fr);
    align-items: center;
    column-gap: 18px;
}

.report-row--compact {
    margin-top: 22px;
}

.report-label {
    margin: 0;
    align-self: start;
    font-size: 20px;
    line-height: 1.05;
    font-weight: 500;
    color: #111111;
    max-width: 280px;
}

.report-bars {
    display: grid;
    /* gap: 8px; */
    max-width: 1000px;
    width: 100%;
    justify-items: start;
}

.report-bar-line {
    display: grid;
    grid-template-columns: auto auto;
    align-items: center;
    gap: 12px;
    width: auto;
    justify-content: start;
}

.report-bar {
    position: relative;
    border-radius: 15px;
    padding: 12px 22px 16px;
    display: grid;
    align-content: center;
    width: 100%;
    transform-origin: left center;
    /* Clip so bars grow in without squashing the counting figures (vs scaleX). */
    clip-path: inset(0 100% 0 0);
    opacity: 1;
    transition: clip-path 0.9s cubic-bezier(0.22, 1, 0.36, 1);
    will-change: clip-path;
}

/* Manual 1-10 scale utilities for report bars */
.report-len-1 { width: 10%; }
.report-len-2 { width: 20%; }
.report-len-3 { width: 30%; }
.report-len-4 { width: 40%; }
.report-len-5 { width: 50%; }
.report-len-6 { width: 60%; }
.report-len-7 { width: 70%; }
.report-len-8 { width: 80%; }
.report-len-9 { width: 90%; }
.report-len-10 { width: 100%; }

/* Bar width presets in px with responsive scaling (desktop/tablet). */
.report-bar--w1 { width: clamp(220px, 24vw, 520px); }
.report-bar--w2 { width: clamp(300px, 34vw, 740px); }
.report-bar--w3 { width: clamp(110px, 12.1vw, 264px); }
.report-bar--w4 { width: clamp(154px, 17.6vw, 363px); }

@media (min-width: 1025px) {
    /* Figma-aligned desktop chart lengths */
    .report-bar--w1 { width: 650px; max-width: 100%; }
    .report-bar--w2 { width: 810px; max-width: 100%; }
    .report-bar--w3 { width: 300px; max-width: 100%; }
    .report-bar--w4 { width: 400px; max-width: 100%; }
}

.report-bar--glass {
    border: 1px solid rgba(255, 255, 255, 0.52);
    background: rgba(234, 236, 223, 0.52);
    backdrop-filter: blur(4px) saturate(108%) contrast(1.04);
    -webkit-backdrop-filter: blur(4px) saturate(108%) contrast(1.04);
    box-shadow:
        inset 1px 1px 0 rgba(255, 255, 255, 0.55),
        0 8px 20px #D5D5D5;
}

.report-bar--solid {
    border: 1px solid rgba(255, 255, 255, 0.46);
    background: rgba(214, 211, 180, 0.62);
    backdrop-filter: blur(4px) saturate(112%) contrast(1.04);
    -webkit-backdrop-filter: blur(4px) saturate(112%) contrast(1.04);
    /* box-shadow:
        inset 1px 1px 0 rgba(255, 255, 255, 0.5),
        inset 0 -1px 0 rgba(0, 0, 0, 0.04),
        0 8px 20px #D5D5D5; */
}

.report-year {
    font-size: 16px;
    line-height: 1;
    color: #232323;
    font-weight: 500;
}

.report-value {
    font-size: 74px;
    line-height: 0.98;
    color: #000000;
    font-weight: 500;
    margin-top: 12px;
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.06em;
}

.report-growth {
    margin: 0;
    font-size: 50px;
    line-height: 1;
    font-weight: 500;
    color: #000000;
    white-space: nowrap;
    flex: 0 0 auto;
    opacity: 0;
    transform: translateX(-20px);
    transition:
        opacity 0.45s ease-out,
        transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}

.report-section.report-chart-in-view .report-bar {
    clip-path: inset(0 0 0 0);
}

.report-section.report-chart-in-view .report-growth {
    opacity: 1;
    transform: translateX(0);
}

.report-row:nth-child(1) .report-bar--glass { transition-delay: 0.08s; }
.report-row:nth-child(1) .report-bar--solid { transition-delay: 0.22s; }
.report-row:nth-child(1) .report-growth { transition-delay: 0.34s; }
.report-row:nth-child(2) .report-bar--glass { transition-delay: 0.44s; }
.report-row:nth-child(2) .report-bar--solid { transition-delay: 0.58s; }
.report-row:nth-child(2) .report-growth { transition-delay: 0.7s; }

.report-btn {
    display: block;
    margin: 62px auto 0;
    border: 1px solid rgba(255, 255, 255, 0.46);
    border-radius: 12px;
    background: rgba(251, 251, 199, 0.5);
    backdrop-filter: blur(4px) saturate(112%) contrast(1.04);
    -webkit-backdrop-filter: blur(4px) saturate(112%) contrast(1.04);
    box-shadow:
        inset 1px 1px 0 rgba(255, 255, 255, 0.52),
        inset 0 -1px 0 rgba(0, 0, 0, 0.05),
        0 8px 20px rgba(0, 0, 0, 0.09);
    color: #161616;
    font-size: 16px;
    letter-spacing: 0.01em;
    line-height: 1;
    text-transform: uppercase;
    text-align: center;
    padding: 14px 34px;
    font-family: inherit;
    font-weight: 500;
    transition: background-color 0.45s ease-in-out, color 0.45s ease-in-out;
    cursor: pointer;
}

.report-btn:hover {
    background: #000000;
    color: #ffffff;
}

@media (prefers-reduced-motion: reduce) {
    body.hero-intro .hero-logo,
    body.hero-intro .glass-card,
    body.hero-intro .chip,
    body.hero-intro .card-caption,
    body.hero-intro .download-btn {
        animation: none;
        opacity: 1;
        transform: none;
    }

    .single-text-section {
        --single-text-opacity: 1;
        --single-text-blur: 0px;
        --single-text-y: 0px;
    }

    .report-section {
        --report-opacity: 1;
        --report-blur: 0px;
        --report-y: 0px;
    }

    .proximity-glass-section {
        --proximity-opacity: 1;
        --proximity-blur: 0px;
        --proximity-y: 0px;
    }

    .journey-dual-section {
        --journey-overlay-opacity: 1;
        --journey-overlay-blur: 0px;
        --journey-overlay-y: 0px;
    }

    .report-bar,
    .report-growth {
        transition: none;
        transform: none;
        opacity: 1;
        clip-path: none;
    }

    .montage-card {
        box-shadow: none;
    }

    .park-modern-section {
        --park-chart-opacity: 1;
        --park-chart-y: 0px;
    }

    .time-scarcity-section {
        --time-scarcity-opacity: 1;
        --time-scarcity-blur: 0px;
        --time-scarcity-y: 0px;
    }

    .brand-intro-section {
        --brand-intro-opacity: 1;
        --brand-intro-blur: 0px;
        --brand-intro-y: 0px;
    }
}

/* Responsive bridge: prevent fixed desktop montage overlap on tablet/small laptop widths */
@media (max-width: 1200px) {
    .montage-section {
        padding: 0 20px 84px;
    }

    .montage-section__heading {
        top: 9vh;
        padding: 16vh 0 12vh;
        font-size: clamp(56px, 8.6vw, 104px);
        white-space: nowrap;
    }

    .montage-grid {
        margin-top: 84px;
        transform: translateY(var(--montage-scroll-shift, 0px));
        width: min(100%, 900px);
        height: auto;
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        grid-auto-rows: auto;
        gap: 18px;
    }

    .montage-card {
        position: relative;
        left: auto;
        top: auto;
        width: 100%;
        height: auto;
        border-radius: 14px;
        transform: translateY(calc(var(--montage-scroll-shift, 0px) * var(--card-parallax-speed)));
    }

    .montage-chip {
        font-size: 11px;
        padding: 8px 14px;
    }

    .montage-card--garden {
        grid-column: 1 / span 1;
        aspect-ratio: 300 / 236;
    }

    .montage-card--dining {
        grid-column: 2 / span 1;
        aspect-ratio: 280 / 332;
    }

    .montage-card--retail {
        grid-column: 2 / span 1;
        aspect-ratio: 260 / 236;
    }

    .montage-card--bars {
        grid-column: 1 / span 1;
        aspect-ratio: 230 / 220;
    }

    .montage-card--sports {
        grid-column: 1 / span 1;
        aspect-ratio: 250 / 320;
    }

    .montage-card--hero {
        grid-column: 2 / span 1;
        aspect-ratio: 450 / 385;
    }

    .montage-card--station {
        grid-column: 1 / span 2;
        aspect-ratio: 430 / 275;
    }
}

@media (max-width: 1024px) {
    .hero {
        height: 100vh;
        height: 100dvh;
        min-height: 0;
        max-height: 100vh;
        max-height: 100dvh;
        padding: 20px 15px;
        align-items: center;
        justify-content: center;
    }

    .hero-content {
        width: 100%;
        max-width: none;
        margin: 0 auto;
    }

    .hero-logo {
        width: 100%;
        max-width: 100%;
        height: auto;
        position: relative;
        z-index: 0;
        margin: 0 auto -18px;
    }

    .glass-card {
        margin: 0 auto;
        width: 100%;
        max-width: 100%;
        height: 70vh;
        height: 70dvh;
        min-height: 0;
        padding: 34px 30px 30px;
    }

    .dot {
        width: 14px;
        height: 14px;
        flex-basis: 14px;
    }

    .chip {
        gap: 12px;
        font-size: 28px;
    }

    .chip-time {
        top: 14%;
        left: 12%;
    }

    .chip-well {
        top: 39%;
        right: 18%;
    }

    .chip-invested {
        top: 62%;
        left: 18%;
    }

    .card-caption {
        left: 30px;
        bottom: 20px;
        font-size: 18px;
    }

    .single-text-section--thesis {
        height: 430px;
        min-height: 430px;
        padding: 15px 15px;
    }

    .single-text-section--thesis .single-text-section__text {
        font-size: 26px;
    }

    .intro-section {
        padding: 15px 15px 75px;
    }

    .intro-columns {
        display: flex;
        flex-direction: column;
        row-gap: 0px;
        column-gap: 0;
    }

    .intro-col--right {
        margin-bottom: 60px;
    }

    .intro-figure--portrait {
        padding-top: 0;
    }

    .intro-col--right {
        min-height: 0;
        padding-right: 0;
        order: 2;
    }

    .intro-col--left,
    .intro-col--right {
        width: 100%;
    }

    /* Mobile stack order: text -> portrait image -> landscape image */
    .intro-col--left {
        display: contents;
    }

    .intro-head {
        order: 0;
    }

    .intro-copy-wrap {
        order: 1;
    }

    .intro-figure--landscape {
        order: 3;
    }

    .intro-figure,
    .intro-figure img,
    .intro-figure--portrait img,
    .intro-figure--landscape img {
        width: 100%;
        max-width: 100%;
    }

    .intro-head {
        margin-bottom: 60px;
    }

    .intro-copy p {
        font-size: 20px;
    }

    .intro-figcaption {
        font-size: 16px;
    }

    .time-scarcity-section {
        min-height: 100vh;
        min-height: 100dvh;
    }

    .time-scarcity-content {
        padding: 0 15px;
    }

    .time-scarcity-content p {
        font-size: 31px;
        line-height: 1.22;
        text-align: center;
    }

    /* Figma mobile: full-viewport background, centered stack, logo 350×42 */
    .brand-intro-section {
        min-height: 100vh;
        min-height: 100dvh;
        display: flex;
        flex-direction: column;
        align-items: stretch;
    }

    .brand-intro-bg {
        width: 100%;
        height: 100%;
        min-width: 100%;
        min-height: 100%;
        object-fit: cover;
        object-position: center;
    }

    .brand-intro-content {
        flex: 1;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        width: 100%;
        max-width: 980px;
        margin: 0 auto;
        padding: 32px 15px;
        box-sizing: border-box;
    }

    .brand-intro-kicker {
        font-size: 20px;
    }

    .brand-intro-logo {
        margin-top: 26px;
        width: 350px;
        max-width: 100%;
        height: 42px;
        object-fit: contain;
    }

    .brand-intro-subtitle {
        font-size: 16px;
        margin-top: 48px;
    }

    .dot-text-label {
        font-size: clamp(20px, 3.2vw, 30px);
    }

    .report-intro {
        font-size: clamp(28px, 4.8vw, 53px);
        margin-bottom: 64px;
    }

    .report-row {
        grid-template-columns: 1fr;
        gap: 14px;
    }

    .report-bar-line {
        grid-template-columns: auto auto;
        justify-content: start;
        width: auto;
    }

    .report-label {
        font-size: 16px;
    }

    .report-growth {
        font-size: 20px;
    }

    .report-year {
        font-size: 14px;
    }

    .report-value {
        font-size: 24px;
        letter-spacing: -0.04em;
    }

    .report-bar {
        height: 80px;
    }

    .report-bar--w1 {
        width: 220px;
    }

    .report-bar--w2 {
        width: 300px;
    }

    .report-bar--w3 {
        width: 120px;
    }

    .report-bar--w4 {
        width: 140px;
    }

    .report-btn {
        font-size: clamp(16px, 2.8vw, 22px);
        padding: 14px 28px;
    }

    .single-text-section__kicker {
        font-size: clamp(20px, 3.2vw, 30px);
    }

    .single-text-section--south .single-text-section__text {
        margin-top: 0;
        font-size: 26px;
        line-height: 1.08;
    }

    /* Mobile: vertically center single-text content blocks */
    .single-text-section--thesis,
    .single-text-section--south {
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .single-text-section--thesis .single-text-section__inner,
    .single-text-section--south .single-text-section__inner {
        display: flex;
        align-items: center;
        width: 100%;
    }

    .time-render-section {
        padding: 30px 15px 72px;
    }

    /* Figma mobile: header → full-width render → one row: address (left) + time (right) */
    .time-render-grid {
        margin-top: 100px;
        display: grid;
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto auto;
        row-gap: 12px;
        column-gap: 16px;
        align-items: center;
        padding-left: 55px;
        padding-right: 55px;
        box-sizing: border-box;
    }

    .time-render-media {
        grid-column: 1 / -1;
        grid-row: 1;
        width: 100%;
        max-width: none;
    }

    .time-render-address,
    .time-render-time {
        font-size: 14px;
        letter-spacing: 0.12em;
        min-width: 0;
    }

    .time-render-address {
        grid-column: 1;
        grid-row: 2;
        justify-self: start;
        text-align: left;
        font-weight: 500;
    }

    .time-render-time {
        grid-column: 2;
        grid-row: 2;
        justify-self: end;
        text-align: right;
        font-weight: 400;
        font-variant-numeric: tabular-nums;
    }

    .invested-glass-section {
        padding: 28px 20px 32px;
    }

    .invested-glass-columns {
        grid-template-columns: 1fr;
        row-gap: 24px;
    }

    .invested-glass-card {
        justify-self: start;
        width: 100%;
        max-width: 100%;
    }

    .invested-copy-lines {
        font-size: clamp(82px, 17vw, 180px);
    }

    .invested-copy-btn {
        margin-top: 34px;
        font-size: clamp(14px, 2.8vw, 28px);
        padding: 12px 18px;
    }

    .invested-video-shell {
        width: min(100%, 540px);
        height: auto;
        min-height: 0;
        aspect-ratio: 540 / 695;
    }

    .invested-video-logo {
        width: min(76%, 420px);
    }

    .invested-blur-word {
        left: 50%;
        top: 60%;
        font-size: clamp(56px, 13vw, 120px);
        filter: blur(4px);
    }

    .proximity-glass-section {
        min-height: unset;
        height: 520px;
        max-height: none;
        padding: 32px 15px;
        box-sizing: border-box;
        overflow-y: auto;
    }

    .proximity-glass-card {
        width: 360px;
        max-width: 100%;
        height: 302px;
        box-sizing: border-box;
        margin-left: auto;
        margin-right: auto;
        padding: 0 15px;
        border-radius: 16px;
        display: flex;
        align-items: center;
        justify-content: center;
        text-align: center;
        overflow-y: auto;
    }

    .proximity-glass-card__text {
        font-size: 22px;
        line-height: 1.45;
        text-align: center;
    }

    .journey-dual-section {
        padding: 30px 15px 30px 15px;
    }

    .journey-dual-grid {
        grid-template-columns: 1fr;
        row-gap: 15px;
        column-gap: 0;
        max-width: 100%;
        margin: 0;
    }

    /* Figma mobile: row 1 — 68% media | 32% caption; row 2 — 32% caption | 68% media */
    .journey-dual-tile--primary .journey-dual-split {
        display: grid;
        grid-template-columns: minmax(0, 68fr) minmax(0, 32fr);
        align-items: center;
        column-gap: 0;
    }

    .journey-dual-tile--secondary .journey-dual-split {
        display: grid;
        grid-template-columns: minmax(0, 32fr) minmax(0, 68fr);
        align-items: center;
        column-gap: 0;
    }

    .journey-dual-caption {
        display: block;
        position: static;
        transform: none;
        color: #000000;
        text-shadow: none;
        pointer-events: auto;
        font-size: 14px;
        font-weight: 400;
        letter-spacing: 0.08em;
        line-height: 1.2;
        text-transform: uppercase;
    }

    .journey-dual-tile--primary .journey-dual-overlay__row > span:nth-child(3) {
        display: none;
    }

    .journey-dual-tile--secondary .journey-dual-overlay__row > span:first-child {
        display: none;
    }

    .journey-dual-overlay__row {
        flex: 1 1 auto;
        align-items: flex-start;
        justify-content: space-between;
        min-width: 0;
        width: 100%;
    }

    .journey-dual-overlay__row > span {
        line-height: 1.15;
    }

    .journey-dual-overlay__row > span:nth-child(3) {
        line-height: 1.15;
    }

    .journey-dual-tile--secondary .journey-dual-overlay__row > span:nth-child(3) {
        text-align: right;
    }

    .journey-dual-tile--primary .journey-dual-caption {
        right: auto;
        left: auto;
        max-width: none;
        text-align: left;
        padding: 32px 12px 12px 20px;
        box-sizing: border-box;
        /* margin-top: 20px; */
    }

    .journey-dual-tile--secondary .journey-dual-caption {
        left: auto;
        right: auto;
        text-align: right;
        padding: 0px 20px 12px 12px;
        box-sizing: border-box;
    }

    .journey-dual-tile--primary .journey-dual-media,
    .journey-dual-tile--secondary .journey-dual-media {
        aspect-ratio: 1 / 1;
    }

    .journey-dual-overlay {
        align-items: center;
        padding: 0 clamp(12px, 4vw, 24px);
        font-size: 14px;
    }

    .journey-dual-overlay__row {
        gap: 8px;
    }

    .journey-dual-tile--secondary .journey-dual-overlay__row > span:nth-child(3) {
        max-width: min(18em, 100%);
    }

    .brand-line-section {
        padding: 15px 15px;
    }

    .brand-line {
        column-gap: clamp(16px, 3vw, 32px);
    }
    
    .park-modern-section__sticky {
        padding: 0;
    }

    .park-modern-section {
        padding-bottom: 0;
    }

    .single-text-section--south {
        height: 400px;
        min-height: 400px;
        padding: 15px 15px;
        display: flex;
        align-items: flex-start;
        justify-content: flex-start;
    }

    .single-text-section--south .single-text-section__inner {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start;
        width: 100%;
    }

    .single-text-section--south .report-kicker {
        margin: 0;
    }

    .single-text-section--south .single-text-section__text {
        margin-top: 72px;
        width: 100%;
        max-width: none;
        margin-right: 0;
        text-align: left;
        line-height: 1.12;
    }

    .brand-line-logo {
        height: 15px;
        width: auto;
        max-height: none;
    }

    .montage-section {
        padding: 0 15px 72px 15px;
    }

    .montage-section__heading {
        top: 8vh;
        padding: 18vh 0 14vh;
        font-size: 48px;
        line-height: 1.08;
        white-space: normal;
    }

    .montage-section__heading-break {
        display: inline;
    }

    /*
     * Mobile montage: asymmetric stagger (ref comp): uneven columns, nudged cards,
     * bars low / retail high; parallax = same translateY factor via translate(x, y).
     */
    .montage-grid {
        margin-top: clamp(28px, 9vw, 72px);
        transform: translateY(var(--montage-scroll-shift, 0px));
        will-change: transform;
        display: grid;
        /* Equal tracks so row-3 cells can hold 160×160 (uneven fr was shrinking col 1 < 160px) */
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        grid-auto-rows: auto;
        row-gap: 40px;
        column-gap: 20px;
        width: 100%;
        max-width: min(100%, 420px);
        height: auto;
        margin-left: auto;
        margin-right: auto;
        justify-items: stretch;
        box-sizing: border-box;
        padding-inline: 0;
        padding-top: 20px;
        overflow-x: hidden;
        overflow-y: visible;
    }

    .montage-card {
        position: relative;
        left: auto;
        top: auto;
        right: auto;
        bottom: auto;
        min-width: 0;
        max-width: 100%;
        border-radius: 18px;
        overflow: visible;
        box-sizing: border-box;
        display: block;
        transform: translateY(calc(var(--montage-scroll-shift, 0px) * var(--card-parallax-speed)));
        box-shadow: none;
    }

    .montage-card img {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        margin: 0;
        border-radius: inherit;
        object-fit: cover;
        display: block;
        z-index: 0;
    }

    .montage-chip {
        font-size: 14px;
        font-weight: 400;
        line-height: 1.2;
        padding: 12px 15px;
        white-space: normal;
        overflow-wrap: break-word;
        max-width: calc(100% - 14px);
    }

    /* Explicit Figma sizes; max-width keeps within grid; height tracks width via ratio */
    /* Row 1: Yarra — nudge into right column */
    .montage-card--dining {
        grid-row: 1;
        grid-column: 2;
        align-self: start;
        justify-self: end;
        width: min(100%, 180px);
        aspect-ratio: 180 / 196;
        height: auto;
        transform: translateY(calc(var(--montage-scroll-shift, 0px) * var(--card-parallax-speed)));
    }

    /* Row 2: RBG — full row so 241×226 is not capped by narrow 42% column */
    .montage-card--garden {
        grid-row: 2;
        grid-column: 1 / -1;
        align-self: start;
        justify-self: start;
        width: min(241px, 100%);
        max-width: 100%;
        aspect-ratio: 241 / 226;
        height: auto;
        margin-bottom: 40px;
        transform: translateY(calc(var(--montage-scroll-shift, 0px) * var(--card-parallax-speed)));
    }

    /* Row 3: Local Bars & Local Retail — 160×160 each (square) */
    .montage-card--bars {
        grid-row: 3;
        grid-column: 1;
        align-self: end;
        justify-self: start;
        width: min(160px, 100%);
        max-width: 100%;
        aspect-ratio: 1 / 1;
        height: auto;
        margin-bottom: 40px;
        transform: translateY(calc(var(--montage-scroll-shift, 0px) * var(--card-parallax-speed)));
    }

    .montage-card--retail {
        grid-row: 3;
        grid-column: 2;
        align-self: start;
        justify-self: end;
        width: min(160px, 100%);
        max-width: 100%;
        aspect-ratio: 1 / 1;
        height: auto;
        transform: translateY(calc(var(--montage-scroll-shift, 0px) * var(--card-parallax-speed)));
    }

    /* Row 4: MCG — full row + right align so 240×254 is not capped by half-width column */
    .montage-card--sports {
        grid-row: 4;
        grid-column: 1 / -1;
        align-self: start;
        justify-self: end;
        width: min(240px, 100%);
        max-width: 100%;
        aspect-ratio: 240 / 254;
        height: auto;
        transform: translateY(calc(var(--montage-scroll-shift, 0px) * var(--card-parallax-speed)));
    }

    /* Row 5: Shrine — full row + left align so 301×305 is not capped by half-width column */
    .montage-card--hero {
        grid-row: 5;
        grid-column: 1 / -1;
        align-self: start;
        justify-self: start;
        width: min(301px, 100%);
        max-width: 100%;
        aspect-ratio: 301 / 305;
        height: auto;
        margin-bottom: 40px;
        transform: translateY(calc(var(--montage-scroll-shift, 0px) * var(--card-parallax-speed)));
    }

    /* Row 6: Anzac — centered, 361×237 (full row width so size isn’t capped) */
    .montage-card--station {
        grid-row: 6;
        grid-column: 1 / -1;
        align-self: start;
        justify-self: center;
        width: min(361px, 100%);
        max-width: 100%;
        aspect-ratio: 361 / 237;
        height: auto;
        transform: translateY(calc(var(--montage-scroll-shift, 0px) * var(--card-parallax-speed)));
    }

    .montage-card--station .montage-chip {
        right: 6px;
    }

    .montage-card--garden .montage-chip {
        left: 20px;
    }

    .map-fullscreen-section {
        height: 100vh;
        height: 100dvh;
    }

    .map-zoom-controls {
        display: grid;
    }

    .map-fullscreen-section--pannable .map-fullscreen-image {
        pointer-events: auto;
        touch-action: none;
        cursor: grab;
    }

    .map-fullscreen-section--pannable.map-fullscreen-section--dragging .map-fullscreen-image {
        cursor: grabbing;
    }

    .map-fullscreen-image {
        /* Match Figma framing on phones before interaction. */
        object-position: 43% 53%;
    }

    .site-footer-partners__cell {
        min-height: 120px;
        padding: 16px 12px;
    }

    /* Stack charts in the sticky frame; parallax vars stay on .park-modern-section (JS). */
    .park-modern-section {
        min-height: 240vh;
        padding-bottom: 0;
        padding-top: 0;
        
    }

    .park-modern-section__charts {
        display: flex;
        flex-direction: column;
        justify-content: flex-start;
        align-items: stretch;
        height: auto;
        min-height: 100%;
        gap: clamp(40px, 10vh, 80px);
        padding: 15px 15px;
        width: min(calc(100% - 40px), var(--page-max-width));
    }

    .park-chart {
        width: 100%;
        max-width: 360px;
        min-height: 0;
        margin: 0 auto;
        padding: 22px 18px 20px;
        border-radius: 18px;
    }

    .park-chart--transport {
        align-self: flex-start;
    }

    .park-chart--walking {
        align-self: flex-end;
        margin-top: auto;
    }

    .park-chart__title {
        margin: 0 auto 18px;
        font-size: 16px;
        line-height: 1.25;
        max-width: 280px;
    }

    .park-chart--transport .park-chart__title {
        max-width: 300px;
    }

    .park-chart__columns {
        gap: 28px;
    }

    .park-chart__value {
        margin: 0 0 8px;
        font-size: 38px;
    }

    .park-chart__track {
        height: 132px;
        margin-bottom: 10px;
    }

    .park-chart__bar {
        height: calc(132px * var(--pct, 1) / var(--max, 1));
        border-radius: 12px;
        max-width: 88px;
    }

    .park-chart__label {
        font-size: 9px;
    }

}
