/*
 * CormackCoreWeb 2.0 - Custom Stylesheet
 * Author: Charlie - Cormack Advertising
 *
 * STRUCTURE:
 * 1. CSS Custom Properties (Design Tokens)
 * 2. Global Font Styles
 * 3. Reusable Components (cards, sections, typography, UI)
 * 4. Page-Specific Sections (header, hero, intro, footer)
 * 5. Responsive Breakpoints (1440, 1280, 1024, 768, 480)
 */

/* ========================================
   1. CSS Custom Properties (Design Tokens)
   ======================================== */

:root {
    /* Colors */
    --c-dark:       #0F1F21;
    --c-dark-teal:  #142B2E;
    --c-green:      #2E5849;
    --c-teal:       #86C2CC;
    --c-cream:      #F2E5CC;
    --c-beige:      #F3ECDE;
    --c-light-blue: #E0F2F5;
    --c-blush:      #F8EAEA;

    /* Spacing — fluid scale */
    --sp-section:   60px;
    --sp-card:      60px;
    --sp-gap:       24px;

    /* Typography scale */
    --fs-display:   72px;
    --lh-display:   75px;
    --fs-heading:   56px;
    --lh-heading:   60px;
    --fs-heading-sm: 48px;
    --lh-heading-sm: 52px;
    --fs-subline:   16px;
    --fs-body:      16px;

    /* Transitions */
    --ease-default: 0.4s ease;
    --ease-zoom:    0.8s ease;
}

/* ========================================
   2. Global Font Styles
   ======================================== */

h1, h2, h3 {
    font-family: "freight-display-pro", serif;
    font-weight: 700;
    font-style: normal;
}

body,
p,
a,
span,
li,
label,
input,
textarea,
select,
button {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-style: normal;
}

a {
    font-family: "sweet-sans-pro", sans-serif;
}

.icon-label,
[class*="icon-label"] {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-style: normal;
}

/* ========================================
   3. Reusable Components
   ======================================== */

/* --- Section wrapper (padded background) --- */
.edge-section {
    padding: var(--sp-section);
}

/* --- Image card: hover-zoom container --- */
.edge-card {
    position: relative;
    width: 100%;
    overflow: hidden;
    cursor: pointer;
}

.edge-card--16x9    { aspect-ratio: 16 / 9; }
.edge-card--4x3     { aspect-ratio: 4 / 3; }
.edge-card--fill    { aspect-ratio: auto; }
.edge-card--capped  { max-height: calc(100vh - 120px); }

/* Card background layer */
.edge-card__bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.edge-card__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1);
    transition: transform var(--ease-zoom);
}

.edge-card:hover .edge-card__img {
    transform: scale(1.08);
}

/* Card as link */
a.edge-card--link,
a.edge-fullbleed--link {
    display: block;
    text-decoration: none;
    color: inherit;
}

/* Card gradient overlay for text contrast */
.edge-card__bg::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 60%;
    background: linear-gradient(0deg, rgba(15, 31, 33, 0.7) 0%, rgba(15, 31, 33, 0) 100%);
    z-index: 1;
    pointer-events: none;
}

/* Card content overlay */
.edge-card__content {
    position: absolute;
    bottom: 0;
    padding: var(--sp-card);
    z-index: 2;
}

.edge-card__content--left   { left: 0; text-align: left; }
.edge-card__content--right  { right: 0; text-align: right; }
.edge-card__content--center { left: 0; width: 100%; text-align: center; }

/* --- Fullbleed section (no outer padding, fixed height) --- */
.edge-fullbleed {
    position: relative;
    width: 100%;
    overflow: hidden;
    cursor: pointer;
}

.edge-fullbleed__bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/* Fullbleed gradient overlay for text contrast */
.edge-fullbleed__bg::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 60%;
    background: linear-gradient(0deg, rgba(15, 31, 33, 0.65) 0%, rgba(15, 31, 33, 0) 100%);
    z-index: 1;
    pointer-events: none;
}

.edge-fullbleed__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1);
    transition: transform var(--ease-zoom);
}

.edge-fullbleed:hover .edge-fullbleed__img {
    transform: scale(1.08);
}

.edge-fullbleed__content {
    position: absolute;
    bottom: 0;
    padding: var(--sp-card);
    z-index: 2;
}

.edge-fullbleed__content--left  { left: 0; }
.edge-fullbleed__content--right { right: 0; text-align: right; }

/* --- Arrow icon --- */
.edge-arrow {
    margin-bottom: 16px;
}

.edge-arrow--right {
    display: flex;
    justify-content: flex-end;
}

.edge-arrow img {
    width: 36px;
    height: 36px;
    filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.25));
}

/* --- Headline (large serif) --- */
.edge-headline {
    font-family: "freightbigcmp-pro", serif;
    font-weight: 500;
    font-style: normal;
    font-size: var(--fs-heading);
    line-height: var(--lh-heading);
    letter-spacing: 0;
    margin: 0 0 12px;
}

.edge-headline--display {
    font-size: var(--fs-display);
    line-height: var(--lh-display);
}

.edge-headline--sm {
    font-size: var(--fs-heading-sm);
    line-height: var(--lh-heading-sm);
}

/* --- Subline (uppercase sans) --- */
.edge-subline {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 500;
    font-style: normal;
    font-size: var(--fs-subline);
    line-height: 140%;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-variant-numeric: lining-nums tabular-nums;
}

/* --- Color utilities --- */
.u-color-dark       { color: var(--c-dark); }
.u-color-dark-teal  { color: var(--c-dark-teal); }
.u-color-green      { color: var(--c-green); }
.u-color-teal       { color: var(--c-teal); }
.u-color-cream      { color: var(--c-cream); }
.u-color-beige      { color: var(--c-beige); }

.u-bg-dark          { background-color: var(--c-dark); }
.u-bg-dark-teal     { background-color: var(--c-dark-teal); }
.u-bg-cream         { background-color: var(--c-beige); }
.u-bg-light-blue    { background-color: var(--c-light-blue); }

/* --- Text alignment --- */
.u-text-left   { text-align: left; }
.u-text-right  { text-align: right; }
.u-text-center { text-align: center; }

/* --- Grid layout --- */
.edge-grid {
    display: grid;
    gap: var(--sp-gap);
}

.edge-grid--2col { grid-template-columns: 1fr 1fr; }
.edge-grid--3col { grid-template-columns: 1fr 1fr 1fr; }

/* ========================================
   4. Page-Specific Sections
   ======================================== */

/* --- Header --- */
.site-header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
    padding: 24px 0;
    background: transparent;
    transition: background var(--ease-default), padding var(--ease-default);
}

.site-header.scrolled {
    background: rgba(15, 31, 33, 0.92);
    backdrop-filter: blur(10px);
    padding: 16px 0;
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 var(--sp-section);
}

.header-logo a { display: block; }

.header-logo img {
    width: 60px;
    height: auto;
    transition: width var(--ease-default);
}

.site-header.scrolled .header-logo img { width: 50px; }

/* Hamburger */
.nav-toggle {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    z-index: 1001;
    flex-direction: column;
    gap: 5px;
}

.nav-toggle-bar {
    display: block;
    width: 28px;
    height: 2px;
    background: #fff;
    transition: transform 0.3s ease, opacity 0.3s ease;
}

.nav-toggle.active .nav-toggle-bar:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
}
.nav-toggle.active .nav-toggle-bar:nth-child(2) { opacity: 0; }
.nav-toggle.active .nav-toggle-bar:nth-child(3) {
    transform: rotate(-45deg) translate(5px, -5px);
}

/* Desktop nav */
.main-navigation .nav-menu {
    display: flex;
    align-items: center;
    gap: 40px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.main-navigation .nav-menu li a {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 500;
    font-style: normal;
    font-size: 11px;
    line-height: 100%;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-align: center;
    color: #fff;
    text-decoration: none;
    transition: opacity 0.3s ease;
}

.main-navigation .nav-menu li a:hover { opacity: 0.7; }

/* Mobile nav */
@media (max-width: 900px) {
    .nav-toggle { display: flex; }

    .main-navigation {
        position: fixed;
        top: 0;
        right: -100%;
        width: 100%;
        height: 100vh;
        background: rgba(15, 31, 33, 0.97);
        backdrop-filter: blur(20px);
        display: flex;
        align-items: center;
        justify-content: center;
        transition: right var(--ease-default);
        z-index: 1000;
    }

    .main-navigation.open { right: 0; }

    .main-navigation .nav-menu {
        flex-direction: column;
        gap: 32px;
        text-align: center;
    }

    .main-navigation .nav-menu li a {
        font-size: 18px;
        letter-spacing: 0.12em;
    }
}

@media (max-width: 480px) {
    .main-navigation .nav-menu { gap: 28px; }
    .main-navigation .nav-menu li a {
        font-size: 16px;
        letter-spacing: 0.1em;
    }
}

/* --- Hero --- */
.hero {
    position: relative;
    width: 100%;
    height: 90vh;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--c-dark);
}

.hero-bg {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    z-index: 1;
}

.hero-bg-img {
    width: 100%; height: 100%;
    object-fit: cover;
    transform: scale(1.15);
    animation: heroZoomOut 8s ease-out forwards;
}

@keyframes heroZoomOut {
    0%   { transform: scale(1.15); }
    100% { transform: scale(1); }
}

.hero-bg::before,
.hero-bg::after {
    content: '';
    position: absolute;
    left: 0; width: 100%;
    height: 30%;
    z-index: 2;
    pointer-events: none;
}

.hero-bg::before {
    top: 0;
    background: linear-gradient(180deg, rgba(20, 43, 46, 0.9) 0%, rgba(20, 43, 46, 0) 100%);
}

.hero-bg::after {
    bottom: 0;
    background: linear-gradient(0deg, rgba(20, 43, 46, 0.9) 0%, rgba(20, 43, 46, 0) 60%);
    height: 40%;
}

.hero-content {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    z-index: 3;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hero-logo { width: 50vw; }
.hero-logo img { width: 100%; height: auto; }

.hero-address {
    position: absolute;
    bottom: 60px;
    left: 0; width: 100%;
    text-align: center;
    z-index: 3;
}

.hero-address p {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 500;
    font-size: 21px;
    line-height: 100%;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-align: center;
    color: var(--c-cream);
    font-variant-numeric: lining-nums tabular-nums;
}

/* --- Intro --- */
.intro-section {
    background: var(--c-dark-teal);
    padding: 80px var(--sp-section);
}

.intro-inner {
    max-width: 900px;
    margin: 0 auto;
    text-align: center;
}

.intro-headline {
    font-family: "freightbigcmp-pro", serif;
    font-weight: 500;
    font-size: var(--fs-display);
    line-height: var(--lh-display);
    letter-spacing: 0;
    text-align: center;
    color: var(--c-teal);
    margin: 0 0 32px;
}

.intro-subline {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 500;
    font-size: 21px;
    line-height: 100%;
    letter-spacing: 0.1em;
    text-align: center;
    text-transform: uppercase;
    color: var(--c-cream);
    font-variant-numeric: lining-nums tabular-nums;
}

/* --- Page Hero (reusable inner-page hero) --- */
.page-hero {
    position: relative;
    width: 100%;
    height: 90vh;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--c-dark);
}

.page-hero__bg {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    z-index: 1;
}

.page-hero__img {
    width: 100%; height: 100%;
    object-fit: cover;
    transform: scale(1.15);
    animation: heroZoomOut 8s ease-out forwards;
}

.page-hero__bg::before,
.page-hero__bg::after {
    content: '';
    position: absolute;
    left: 0; width: 100%;
    height: 30%;
    z-index: 2;
    pointer-events: none;
}

.page-hero__bg::before {
    top: 0;
    background: linear-gradient(180deg, rgba(20, 43, 46, 0.9) 0%, rgba(20, 43, 46, 0) 100%);
}

.page-hero__bg::after {
    bottom: 0;
    background: linear-gradient(0deg, rgba(20, 43, 46, 0.6) 0%, rgba(20, 43, 46, 0) 60%);
    height: 50%;
}

.page-hero__content {
    position: absolute;
    bottom: 0; left: 0;
    width: 100%;
    text-align: center;
    padding: var(--sp-card) var(--sp-section) calc(var(--sp-card) + 20px);
    z-index: 3;
}

.page-hero__content .edge-headline {
    margin-bottom: 16px;
}

.edge-headline--hero {
    font-family: "freightbigcmp-pro", serif;
    font-weight: 500;
    font-style: normal;
    font-size: 172px;
    line-height: 0.95;
    letter-spacing: 0;
    text-align: center;
    margin-bottom: 24px;
}

/* --- Page Sub-Navigation Bar --- */
.page-subnav {
    background: var(--c-light-blue);
    width: 100%;
    z-index: 900;
    position: fixed;
    bottom: 0;
    left: 0;
    transition: box-shadow 0.3s ease;
}

.page-subnav.is-stuck {
    box-shadow: 0 -2px 12px rgba(0, 0, 0, 0.08);
}

.page-subnav__inner {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 48px;
    max-width: 1400px;
    margin: 0 auto;
    padding: 20px var(--sp-section);
}

.page-subnav__link {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 500;
    font-style: normal;
    font-size: 14px;
    line-height: 100%;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-align: center;
    color: var(--c-dark-teal);
    text-decoration: none;
    transition: opacity 0.3s ease;
    white-space: nowrap;
}

.page-subnav__link:hover {
    opacity: 0.6;
}

.page-subnav__link.is-active {
    opacity: 0.6;
}

@media (max-width: 768px) {
    .page-subnav {
        display: none;
    }
}

/* --- Text Block Section --- */
.edge-text-block {
    padding-top: 80px;
    padding-bottom: 80px;
}

.edge-text-block__inner {
    max-width: 1100px;
    margin: 0 auto;
    text-align: center;
}

.edge-text-block__inner .edge-headline {
    margin-bottom: 32px;
}

.edge-text-block__body {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: var(--fs-body);
    line-height: 160%;
    letter-spacing: 0;
    text-align: center;
    max-width: 560px;
    margin: 0 auto;
}

@media (max-width: 1024px) {
    .edge-text-block { padding-top: 60px; padding-bottom: 60px; }
}

@media (max-width: 768px) {
    .edge-text-block { padding-top: 40px; padding-bottom: 40px; }
}

/* --- Building Schedule Section --- */
.building-schedule {
    background-color: var(--c-green);
    padding: var(--sp-section);
    overflow: hidden;
}

.building-schedule__grid {
    display: grid;
    grid-template-columns: 3fr 2fr;
    gap: 60px;
    align-items: center;
    max-width: 1400px;
    margin: 0 auto;
}

/* Left: Image with hotspots */
.building-schedule__image-wrap {
    position: relative;
    width: 100%;
}

.building-schedule__mockup {
    width: 100%;
    height: auto;
    display: block;
}

/* Hotspot buttons */
.hotspot {
    position: absolute;
    transform: translate(-50%, -50%);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    z-index: 5;
}

.hotspot__icon {
    width: 40px;
    height: 40px;
    display: block;
}

/* Tooltip — frosted glass */
.hotspot__tooltip {
    position: absolute;
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.25);
    color: #fff;
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: 13px;
    line-height: 150%;
    letter-spacing: 0.02em;
    padding: 14px 18px;
    border-radius: 8px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.25s ease, transform 0.25s ease;
    z-index: 10;
}

/* Position: LT — tooltip opens from left-top corner of hotspot */
.hotspot__tooltip--lt {
    bottom: 50%;
    right: 50%;
    transform: translateY(4px);
}

/* Position: RT — tooltip opens from right-top corner of hotspot */
.hotspot__tooltip--rt {
    bottom: 50%;
    left: 50%;
    transform: translateY(4px);
}

/* Position: LB — tooltip opens from left-bottom corner of hotspot */
.hotspot__tooltip--lb {
    top: 50%;
    right: 50%;
    transform: translateY(-4px);
}

/* Position: RB — tooltip opens from right-bottom corner of hotspot */
.hotspot__tooltip--rb {
    top: 50%;
    left: 50%;
    transform: translateY(-4px);
}

/* Active / hover states */
.hotspot:hover .hotspot__tooltip--lt,
.hotspot:focus .hotspot__tooltip--lt,
.hotspot.is-active .hotspot__tooltip--lt,
.hotspot:hover .hotspot__tooltip--rt,
.hotspot:focus .hotspot__tooltip--rt,
.hotspot.is-active .hotspot__tooltip--rt,
.hotspot:hover .hotspot__tooltip--lb,
.hotspot:focus .hotspot__tooltip--lb,
.hotspot.is-active .hotspot__tooltip--lb,
.hotspot:hover .hotspot__tooltip--rb,
.hotspot:focus .hotspot__tooltip--rb,
.hotspot.is-active .hotspot__tooltip--rb {
    opacity: 1;
    transform: translateY(0);
}

/* Tooltip with image — two-column 50/50 layout */
.hotspot__tooltip--has-image {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 0 !important;
    padding: 0 !important;
    white-space: normal !important;
    width: 360px !important;
    min-width: 300px !important;
    max-width: 420px !important;
    overflow: hidden !important;
}

.hotspot__tooltip--has-image .hotspot__tooltip-img {
    flex: 0 0 50% !important;
    width: 50% !important;
    padding: 4%;
    max-width: 200px !important;
    line-height: 0 !important;
    overflow: hidden !important;
}

.hotspot__tooltip--has-image .hotspot__tooltip-img img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    border-radius: 0 !important;
}

.hotspot__tooltip--has-image .hotspot__tooltip-text {
    flex: 1 1 50% !important;
    display: flex !important;
    align-items: center !important;
    text-align: left !important;
    padding: 14px 18px !important;
    min-width: 0 !important;
}

/* Text-only tooltip */
.hotspot__tooltip-text {
    display: block;
    color: #fff;
    text-align: left;
}

.hotspot__tooltip-text svg {
    display: inline-block;
    vertical-align: middle;
    width: auto;
    height: 1.2em;
    fill: currentColor;
    margin-right: 6px;
}

/* Right: Schedule info */
.building-schedule__info {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    min-width: 0;
    overflow: hidden;
}

.building-schedule__intro {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: var(--fs-body);
    line-height: 160%;
    color: var(--c-cream);
    margin: 0 0 24px;
    max-width: 320px;
}

.building-schedule__btn {
    display: inline-block;
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 500;
    font-size: 13px;
    line-height: 100%;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--c-green);
    text-decoration: none;
    background: #fff;
    border: none;
    border-radius: 4px;
    padding: 14px 28px;
    transition: opacity var(--ease-default);
    margin-bottom: 40px;
}

.building-schedule__btn:hover {
    opacity: 0.85;
}

/* Schedule table */
.building-schedule__table {
    width: 100%;
    border-collapse: collapse;
    font-family: "sweet-sans-pro", sans-serif;
    font-variant-numeric: lining-nums tabular-nums;
}

.building-schedule__table th,
.building-schedule__table td {
    padding: 10px 12px;
    font-size: 14px;
    line-height: 130%;
    text-align: center;
    color: var(--c-cream);
    border-bottom: 1px solid var(--c-teal);
}

/* Column 1 (Floor) - left aligned */
.building-schedule__table th:first-child,
.building-schedule__table td:first-child {
    text-align: left;
}

/* Column 5 (External Sq M) - right aligned */
.building-schedule__table th:last-child,
.building-schedule__table td:last-child {
    text-align: right;
}

/* Columns 3 and 5 (Internal Sq M, External Sq M) - muted color */
.building-schedule__table th:nth-child(3),
.building-schedule__table td:nth-child(3),
.building-schedule__table th:nth-child(5),
.building-schedule__table td:nth-child(5) {
    color: #7A958C;
}

.building-schedule__table th {
    font-weight: 500;
    font-size: 12px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--c-teal);
}

.building-schedule__table td {
    font-weight: 400;
}

.building-schedule__table td strong {
    font-weight: 700;
}

.building-schedule__table tfoot td {
    font-weight: 600;
    border-bottom: none;
    border-top: 1px solid var(--c-teal);
    padding-top: 14px;
}

/* --- Explore Building (fullbleed height override) --- */
.explore-building-section {
    height: 90vh;
}

/* --- Footer --- */
.site-footer {
    background-color: var(--c-dark);
    color: var(--c-cream);
    position: relative;
    overflow: hidden;
    margin-top: 0;
    padding: 0;
}

.footer-green-bar {
    height: 13px;
    background-color: var(--c-green);
    width: 100%;
}

.footer-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    max-width: 1400px;
    margin: 0 auto;
    padding: 48px var(--sp-section) 32px;
    position: relative;
    min-height: 460px;
}

.footer-left {
    display: flex;
    flex-direction: column;
    gap: 30px;
    z-index: 2;
}

.footer-headline {
    font-family: "freightbigcmp-pro", serif;
    font-weight: 500;
    font-size: var(--fs-display);
    line-height: 82px;
    letter-spacing: 0;
    color: var(--c-teal);
    margin: 0;
    padding-bottom: 40px;
}

.footer-address {
    text-align: center;
    padding: 40px var(--sp-section) 0;
    max-width: 1400px;
    margin: 0 auto;
}

.footer-address p {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 500;
    font-size: var(--fs-body);
    line-height: 100%;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    text-align: center;
    color: var(--c-cream);
    font-variant-numeric: lining-nums tabular-nums;
}

.footer-hanover-logo { margin-top: 10px; }
.footer-hanover-logo img { width: 220px; height: auto; }

.footer-contacts { display: flex; gap: 60px; }

.footer-contact .contact-name {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: var(--fs-body);
    line-height: 100%;
    font-variant: small-caps;
    font-variant-numeric: lining-nums tabular-nums;
    color: var(--c-cream);
    margin-bottom: 6px;
    text-transform: uppercase;
}

.footer-contact .contact-details {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: var(--fs-body);
    line-height: 150%;
    font-variant-numeric: lining-nums tabular-nums;
    color: var(--c-cream);
}

.footer-contact .contact-details a {
    color: var(--c-cream);
    text-decoration: none;
    transition: opacity 0.3s ease;
}

.footer-contact .contact-details a:hover { opacity: 0.7; }

.footer-disclaimer { max-width: 560px; }

.footer-disclaimer p {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: 8px;
    line-height: 140%;
    font-variant-numeric: lining-nums tabular-nums;
    color: var(--c-cream);
    opacity: 0.8;
}

.footer-right {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: flex-end;
    z-index: 2;
}

.footer-watermark {
    position: absolute;
    top: -20px;
    right: -20px;
    width: 100%;
    max-width: 500px;
    opacity: 0.3;
    z-index: 1;
}

.footer-watermark img { width: 100%; height: auto; }

.footer-rpg {
    text-align: right;
    z-index: 2;
    position: relative;
}

.footer-rpg-label {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 500;
    font-size: 14px;
    line-height: 100%;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--c-cream);
    margin-bottom: 12px;
}

.footer-rpg-logo { width: 160px; height: auto; }

/* --- Brochure Banner --- */
.brochure-banner {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: #ffffff;
    padding: 12px 0;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    position: relative;
    z-index: 100;
}

.brochure-banner-inner {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 15px;
}

.brochure-banner-label {
    font-weight: 600;
    font-size: 14px;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    margin-right: 10px;
}

.brochure-links {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}

.brochure-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: rgba(255, 255, 255, 0.2);
    color: #ffffff;
    text-decoration: none;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.3s ease;
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.3);
}

.brochure-link:hover {
    background: rgba(255, 255, 255, 0.3);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.brochure-link svg { flex-shrink: 0; }

/* --- Building Floor Plate Hero --- */
.building-floorplate {
    position: relative;
    width: 100%;
    height: 70vh;
    min-height: 500px;
    overflow: hidden;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}

.building-floorplate__bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}

.building-floorplate__bg::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 60%;
    background: linear-gradient(0deg, rgba(15, 31, 33, 0.7) 0%, rgba(15, 31, 33, 0) 100%);
    z-index: 2;
    pointer-events: none;
}

.building-floorplate__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.building-floorplate__content {
    position: relative;
    z-index: 3;
    text-align: center;
    padding: var(--sp-section);
    padding-bottom: 80px;
    max-width: 900px;
}

.building-floorplate__headline {
    font-family: "freightbigcmp-pro", serif;
    font-weight: 500;
    font-style: normal;
    font-size: 72px;
    line-height: 82px;
    letter-spacing: 0;
    text-align: center;
    color: var(--c-cream);
    margin: 0;
}

/* --- Building Specification Section --- */
.building-spec {
    background-color: var(--c-light-blue);
    padding: 60px var(--sp-section);
}

.building-spec__inner {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 60px;
    max-width: 1400px;
    margin: 0 auto;
    align-items: start;
}

.building-spec__text {
    position: static;
}

.building-spec__text .edge-headline {
    margin-bottom: 24px;
}

.building-spec__body {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: var(--fs-body);
    line-height: 160%;
    color: var(--c-dark-teal);
    margin: 0 0 32px;
    max-width: 320px;
}

.building-spec__footnote {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: 11px;
    line-height: 150%;
    color: var(--c-dark-teal);
    opacity: 0.6;
    margin: 0;
    max-width: 320px;
}

.building-spec__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    overflow: hidden;
}

.building-spec__item {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 28px 24px;
    position: relative;
}

/* Vertical divider — every item gets a left border, inset top/bottom */
.building-spec__item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 16px;
    bottom: 16px;
    width: 1px;
    background: var(--c-teal);
}

/* Horizontal row dividers — between rows only (not after last row) */
.building-spec__item:nth-child(4n+1):nth-child(n+5)::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 400%;
    height: 1px;
    background: var(--c-teal);
}

.building-spec__icon {
    margin-bottom: 16px;
}

.building-spec__icon img {
    width: 44px;
    height: 44px;
    display: block;
}

.building-spec__label {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: 13px;
    line-height: 150%;
    color: var(--c-dark-teal);
    margin: 0;
}

/* --- Building Amenities Summary --- */
.building-amenities {
    background-color: var(--c-green);
    padding: 60px;
}

.building-amenities__card {
    display: grid;
    grid-template-columns: 1fr 1fr;
    background-color: var(--c-blush);
}

.building-amenities__image {
    overflow: hidden;
    padding: 30px;
}

.building-amenities__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.building-amenities__content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 60px;
}

.building-amenities__headline {
    font-family: "freightbigcmp-pro", serif;
    font-weight: 500;
    font-style: normal;
    font-size: 72px;
    line-height: 82px;
    letter-spacing: 0;
    color: var(--c-green);
    margin: 0 0 32px;
}

.building-amenities__body {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: 17px;
    line-height: 100%;
    letter-spacing: 0;
    color: var(--c-dark-teal);
    font-variant-numeric: lining-nums tabular-nums;
    margin: 0 0 32px;
    max-width: 420px;
}

.building-amenities__btn {
    display: inline-block;
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 500;
    font-size: 13px;
    line-height: 100%;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--c-green);
    text-decoration: none;
    background: #fff;
    border: none;
    border-radius: 4px;
    padding: 14px 28px;
    transition: opacity var(--ease-default);
    align-self: flex-start;
}

.building-amenities__btn:hover {
    opacity: 0.85;
}

/* --- Siteplans Slider --- */
.siteplans-slider {
    background-color: var(--c-cream);
    padding: 60px var(--sp-section);
    position: relative;
    overflow: hidden;
}

.siteplans-slider__track {
    position: relative;
    max-width: 1100px;
    margin: 0 auto;
    aspect-ratio: 16 / 10;
}

.siteplans-slider__slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.5s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--c-beige);
    border-radius: 4px;
}

.siteplans-slider__slide.is-active {
    opacity: 1;
    pointer-events: auto;
    position: relative;
}

.siteplans-slider__label {
    position: absolute;
    top: 40px;
    left: 40px;
    z-index: 2;
}

.siteplans-slider__floor {
    display: block;
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 500;
    font-size: 16px;
    line-height: 120%;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--c-green);
}

.siteplans-slider__size {
    display: block;
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 500;
    font-size: 28px;
    line-height: 120%;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--c-green);
    margin-top: 4px;
}

.siteplans-slider__img {
    display: block;
    max-width: 85%;
    max-height: 85%;
    width: auto;
    height: auto;
    object-fit: contain;
}

/* Arrows */
.siteplans-slider__arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    z-index: 10;
    transition: opacity 0.3s ease;
}

.siteplans-slider__arrow:hover {
    opacity: 0.7;
}

.siteplans-slider__arrow img {
    width: 48px;
    height: 48px;
    display: block;
}

.siteplans-slider__arrow--prev {
    left: var(--sp-section);
}

.siteplans-slider__arrow--next {
    right: var(--sp-section);
}

/* Dots */
.siteplans-slider__dots {
    display: flex;
    justify-content: center;
    gap: 12px;
    margin-top: 32px;
}

.siteplans-slider__dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border: none;
    background: var(--c-green);
    opacity: 0.3;
    cursor: pointer;
    padding: 0;
    transition: opacity 0.3s ease;
}

.siteplans-slider__dot.is-active {
    opacity: 1;
}

.siteplans-slider__dot:hover {
    opacity: 0.7;
}

/* --- Amenities: Page Hero override --- */
.page-template-page-amenities .page-hero__content .edge-headline,
.page-template-page-amenities .page-hero__content .edge-subline {
    color: var(--c-green);
}

/* --- Amenities: Arrive in Style --- */
.amenities-arrive {
    background-color: var(--c-blush);
    padding: 60px var(--sp-section) 48px;
}

.amenities-arrive__inner {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 60px;
    max-width: 1400px;
    margin: 0 auto;
    align-items: start;
}

.amenities-arrive__text {
    padding-top: 20px;
}

.amenities-arrive__text .edge-headline {
    margin-bottom: 40px;
}

.amenities-arrive__columns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
}

.amenities-arrive__body {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: var(--fs-body);
    line-height: 160%;
    color: var(--c-dark-teal);
    margin: 0;
}

.amenities-arrive__illustration {
    flex-shrink: 0;
}

.amenities-arrive__illustration img {
    display: block;
    width: 300px;
    height: auto;
}

/* --- Amenities: Icons Strip --- */
.amenities-icons {
    background-color: var(--c-dark-teal);
    padding: 48px var(--sp-section);
}

.amenities-icons__inner {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    max-width: 1200px;
    align-items: start;
    gap: 50px;
    margin: 0px auto;
}

.amenities-icons__item {
    display: flex;
    align-items: flex-start;
    gap: 20px;
}

.amenities-icons__icon {
    flex-shrink: 0;
}

.amenities-icons__icon img {
    width: 56px;
    height: 56px;
    display: block;
}

.amenities-icons__label {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 500;
    font-size: 14px;
    line-height: 150%;
    color: var(--c-cream);
    margin: 0;
}

/* --- Amenities: Wellbeing Section --- */
.amenities-wellbeing {
    background-color: var(--c-beige);
    padding-bottom: 0;
}

.amenities-wellbeing__intro {
    padding: 80px var(--sp-section) 48px;
    max-width: 1000px;
    margin: 0 auto;
}

.amenities-wellbeing__intro .edge-headline {
    margin-bottom: 24px;
}

.amenities-wellbeing__intro-body {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: var(--fs-body);
    line-height: 160%;
    color: var(--c-dark-teal);
    max-width: 640px;
    margin: 0 auto;
}

.amenities-wellbeing__card {
    display: grid;
    grid-template-columns: 2fr 1fr;
    max-width: 1400px;
    margin: 0 auto;
    min-height: 500px;
}

.amenities-wellbeing__image {
    overflow: hidden;
    position: relative;
}

.amenities-wellbeing__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.amenities-wellbeing__content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 60px;
}

.amenities-wellbeing__content .edge-subline {
    margin-bottom: 24px;
}

.amenities-wellbeing__body {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: var(--fs-body);
    line-height: 160%;
    color: var(--c-dark-teal);
    margin: 0 0 32px;
    max-width: 320px;
}

.amenities-wellbeing__icon img {
    width: 48px;
    height: 48px;
    display: block;
}

/* --- Amenities: Tiles (Changing Rooms / Coffee / Pause) --- */
.amenities-tiles {
    background-color: var(--c-beige);
}

.amenities-tiles__locker {
    width: 100%;
    overflow: hidden;
    line-height: 0;
}

.amenities-tiles__locker-img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

.amenities-tiles__grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 0;
    padding: 60px var(--sp-section);
    max-width: 1400px;
    margin: 0 auto;
}

.amenities-tiles__col {
    display: flex;
    flex-direction: column;
}

.amenities-tiles__col--left {
    padding-right: 40px;
}

.amenities-tiles__tile-image {
    overflow: hidden;
    margin-bottom: 32px;
}

.amenities-tiles__img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

.amenities-tiles__tile-icon {
    margin-bottom: 16px;
}

.amenities-tiles__tile-icon img {
    width: 40px;
    height: 40px;
    display: block;
}

.amenities-tiles__grid .edge-subline {
    margin-bottom: 16px;
}

.amenities-tiles__tile-body {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: var(--fs-body);
    line-height: 160%;
    color: var(--c-dark-teal);
    margin: 0;
}

.amenities-tiles__col--center {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    align-self: end;
    padding: 0 20px;
}

.amenities-tiles__tile-image--coffee {
    margin-bottom: 0;
    width: 80%;
}

.amenities-tiles__col--right {
    padding-left: 40px;
    align-self: end;
}

.amenities-tiles__tile-image--pause {
    position: relative;
    margin-bottom: 0;
    overflow: hidden;
}

.amenities-tiles__pause-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 32px;
}

.amenities-tiles__col--right .edge-subline {
    margin-top: 0;
}

/* --- Amenities: The Roof --- */
.amenities-roof__hero {
    position: relative;
    width: 100%;
    height: 80vh;
    min-height: 500px;
    overflow: hidden;
}

.amenities-roof__hero-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}

.amenities-roof__hero-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.amenities-roof__hero-content {
    position: absolute;
    bottom: 60px;
    left: var(--sp-section);
    z-index: 3;
}

.amenities-roof__hero-svg {
    display: block;
    height: 48px;
    width: auto;
}

.amenities-roof__intro {
    padding: 80px var(--sp-section) 48px;
    text-align: center;
}

.amenities-roof__intro .edge-headline {
    max-width: 1200px;
    margin: 0 auto 24px;
}

.amenities-roof__intro-body {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: var(--fs-body);
    line-height: 160%;
    color: var(--c-dark-teal);
    max-width: 640px;
    margin: 0 auto;
}

.amenities-roof__grid {
    padding: 0 var(--sp-section) 80px;
}

.amenities-roof__grid-inner {
    display: grid;
    grid-template-columns: 5fr 3fr;
    gap: 24px;
    max-width: 1400px;
    margin: 0 auto;
}

.amenities-roof__main-image {
    overflow: hidden;
}

.amenities-roof__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.amenities-roof__side {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.amenities-roof__side-image {
    overflow: hidden;
    flex: 1;
}

.amenities-roof__side-illustration {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.amenities-roof__side-illustration img {
    width: 280px;
    height: auto;
    display: block;
}

/* ========================================
   4b. Sustainability Page
   ======================================== */

/* --- Sustainability: Hero --- */
.sustainability-hero .page-hero__content {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.sustainability-hero__icon {
    margin-bottom: 24px;
}

.sustainability-hero__icon img {
    width: 100px;
    height: 100px;
    display: block;
}

/* --- Sustainability: Intro Section --- */
.sustainability-intro {
    background-color: var(--c-green);
    padding: 80px var(--sp-section) 48px;
}

.sustainability-intro__text {
    max-width: 900px;
    margin: 0 auto 60px;
}

.sustainability-intro__text .edge-headline {
    margin-bottom: 32px;
}

.sustainability-intro__body {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: var(--fs-body);
    line-height: 170%;
    margin: 0;
}

/* --- Sustainability: Icons Strip --- */
.sustainability-icons {
    background-color: var(--c-dark-teal);
    padding: 48px var(--sp-section);
}

.sustainability-icons__inner {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 50px;
    max-width: 1200px;
    margin: 0 auto;
    align-items: start;
}

.sustainability-icons__item {
    display: flex;
    align-items: flex-start;
    gap: 20px;
}

.sustainability-icons__icon {
    flex-shrink: 0;
}

.sustainability-icons__icon img {
    width: 56px;
    height: 56px;
    display: block;
}

.sustainability-icons__label {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 500;
    font-size: 14px;
    line-height: 150%;
    color: var(--c-cream);
    margin: 0;
}

/* --- Sustainability: Tiles Grid --- */
.sustainability-tiles {
    background-color: var(--c-beige);
    padding: 60px var(--sp-section);
}

.sustainability-tiles__grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 0;
    max-width: 1400px;
    margin: 0 auto;
}

.sustainability-tiles__col {
    display: flex;
    flex-direction: column;
}

.sustainability-tiles__col--left {
    padding-right: 40px;
}

.sustainability-tiles__col--center {
    padding: 0 20px;
    align-self: end;
}

.sustainability-tiles__col--right {
    padding-left: 40px;
}

.sustainability-tiles__image {
    overflow: hidden;
    margin-bottom: 0;
}

.sustainability-tiles__img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

.sustainability-tiles__col--left .sustainability-tiles__image {
    height: 100%;
}

.sustainability-tiles__col--left .sustainability-tiles__img {
    height: 100%;
    object-fit: cover;
}

.sustainability-tiles__info {
    padding-top: 24px;
}

.sustainability-tiles__col--center .sustainability-tiles__image {
    margin-bottom: 24px;
}

.sustainability-tiles__icon {
    margin-bottom: 16px;
}

.sustainability-tiles__icon img {
    width: 48px;
    height: 48px;
    display: block;
}

.sustainability-tiles__grid .edge-subline {
    margin-bottom: 16px;
}

.sustainability-tiles__body {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: var(--fs-body);
    line-height: 160%;
    color: var(--c-dark-teal);
    margin: 0;
}

.sustainability-tiles__col--right .sustainability-tiles__info {
    padding-top: 0;
    padding-bottom: 24px;
}

.sustainability-tiles__col--right .sustainability-tiles__image {
    flex: 1;
    overflow: hidden;
}

.sustainability-tiles__col--right .sustainability-tiles__img {
    height: 100%;
    object-fit: cover;
}

/* --- Sustainability: Solar Panels --- */
.sustainability-solar {
    position: relative;
    width: 100%;
    height: 80vh;
    min-height: 500px;
    overflow: hidden;
}

.sustainability-solar__bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.sustainability-solar__bg::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(20, 43, 46, 0.45);
}

.sustainability-solar__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.sustainability-solar__content {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    text-align: center;
    padding: var(--sp-card) var(--sp-section) calc(var(--sp-card) + 20px);
    z-index: 3;
}

.sustainability-solar__content .edge-headline {
    margin-bottom: 24px;
}

.sustainability-solar__body {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: var(--fs-body);
    line-height: 170%;
    margin: 0;
}

/* ========================================
   4c. Location Page
   ======================================== */

/* --- Location: Explore Section --- */
.location-explore {
    background-color: var(--c-dark-teal);
    padding: 80px var(--sp-section) 60px;
}

.location-explore__intro {
    max-width: 900px;
    margin: 0 auto 60px;
}

.location-explore__intro .edge-headline {
    color: var(--c-teal);
    margin-bottom: 32px;
}

.location-explore__body {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: var(--fs-body);
    line-height: 170%;
    color: var(--c-cream);
    margin: 0;
}

.location-explore__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    max-width: 1400px;
    margin: 0 auto;
}

.location-explore__card {
    position: relative;
    overflow: hidden;
    aspect-ratio: 4 / 5;
}

.location-explore__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.location-explore__overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(20, 43, 46, 0.82);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 48px 15%;
    opacity: 0;
    transition: opacity var(--ease-default);
}

.location-explore__card:hover .location-explore__overlay {
    opacity: 1;
}

.location-explore__overlay::before {
    content: '';
    position: absolute;
    top: 16px;
    left: 16px;
    right: 16px;
    bottom: 16px;
    border: 1px solid var(--c-cream);
    pointer-events: none;
}

.location-explore__overlay .edge-subline {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 500;
    font-size: 21px;
    line-height: 100%;
    letter-spacing: 0.1em;
    text-align: center;
    font-variant-numeric: lining-nums tabular-nums;
    margin-bottom: 16px;
}

.location-explore__overlay-body {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: 14px;
    line-height: 160%;
    margin: 0 0 24px;
}

.location-explore__badge {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #EDCCCC;
    border: none;
    border-radius: 40px;
    padding: 10px 24px;
    color: var(--c-dark-teal);
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 500;
    font-size: 14px;
    text-decoration: none;
}

.location-explore__badge img {
    width: 13px;
    height: 22px;
}

/* --- Location: Transport Section --- */
.location-transport {
    background-color: var(--c-light-blue);
    padding: 80px var(--sp-section) 60px;
}

.location-transport__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 1400px;
    margin: 0 auto 60px;
    gap: 40px;
}

.location-transport__header .edge-headline {
    margin: 0;
}

.location-transport__illustration img {
    width: 268px;
    height: auto;
    display: block;
}

.location-transport__tables {
    max-width: 1400px;
    margin: 0 auto;
}

.location-transport__tables-img {
    width: 100%;
    height: auto;
    display: block;
}

/* --- Location: Station Walk Section --- */
.location-station {
    background-color: var(--c-dark-teal);
}

.location-station__banner {
    padding: 60px var(--sp-section);
    max-width: 1000px;
    margin: 0 auto;
}

.location-station__map {
    width: 100%;
    overflow: hidden;
}

.location-station__map-img {
    width: 100%;
    height: auto;
    display: block;
}

/* --- Location: Directory Section --- */
.location-directory {
    background-color: var(--c-green);
    padding: 60px var(--sp-section);
}

.location-directory__inner {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 60px;
    max-width: 1400px;
    margin: 0 auto;
    align-items: start;
}

.location-directory__headline .edge-headline {
    margin: 0;
}

.location-directory__lists {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
}

.location-directory__cat-title {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 700;
    font-size: var(--fs-body);
    color: inherit;
    margin: 0 0 16px;
}

.location-directory__list {
    list-style: none;
    padding: 0;
    margin: 0;
    counter-reset: directory;
}

.location-directory__item {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: 14px;
    line-height: 180%;
    color: inherit;
    counter-increment: directory;
}

.location-directory__item::before {
    content: counter(directory) ". ";
}

/* Per-column colors */
.location-directory__category--1 { color: #ECCDCB; }
.location-directory__category--2 { color: #82C0CC; }
.location-directory__category--3 { color: var(--c-cream); }

/* --- Location: M4 Section --- */
.location-m4 {
    background-color: var(--c-light-blue);
}

.location-m4__intro {
    padding: 80px var(--sp-section) 48px;
    max-width: 900px;
    margin: 0 auto;
}

.location-m4__intro .edge-headline {
    margin-bottom: 32px;
}

.location-m4__body {
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 400;
    font-size: var(--fs-body);
    line-height: 170%;
    color: var(--c-dark-teal);
    margin: 0;
}

.location-m4__map {
    width: 100%;
    overflow: hidden;
    padding: 0 var(--sp-section) var(--sp-section);
}

.location-m4__map .edge-gmap {
    width: 100%;
    min-height: 600px;
    display: block;
}

.location-m4__map-img {
    width: 100%;
    height: auto;
    display: block;
}

/* ========================================
   4d. Downloads Page
   ======================================== */

.downloads-content {
    background-color: var(--c-beige);
    padding: 60px var(--sp-section);
}

.downloads-content__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    max-width: 1200px;
    margin: 0 auto;
}

/* --- Card --- */
.downloads-card {
    background-color: var(--c-light-blue);
    border-radius: 0;
    padding: 48px;
}

.downloads-card .edge-headline {
    margin: 0 0 32px;
}

/* Preview image */
.downloads-card__preview {
    margin-bottom: 32px;
}

.downloads-card__preview-img {
    width: 100%;
    height: auto;
    display: block;
}

/* Button grid (floor plans = 2 cols) */
.downloads-card__buttons {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-bottom: 24px;
}

/* Download button */
.downloads-btn {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 16px;
    background: #fff;
    border: none;
    border-radius: 0;
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 500;
    font-size: 13px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--c-green);
    text-decoration: none;
    transition: background var(--ease-default), color var(--ease-default);
}

.downloads-btn:hover {
    background: var(--c-green);
    color: #fff;
}

.downloads-btn:hover .downloads-btn__icon {
    filter: brightness(0) invert(1);
}

.downloads-btn__icon {
    flex-shrink: 0;
    transition: filter var(--ease-default);
}

/* Download all link */
.downloads-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: "sweet-sans-pro", sans-serif;
    font-weight: 500;
    font-size: 13px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--c-green);
    text-decoration: none;
    transition: opacity var(--ease-default);
}

.downloads-link:hover {
    opacity: 0.7;
}

/* ========================================
   5. Responsive Breakpoints
   ======================================== */

/* --- XL: Large monitors (1440px+) --- */
@media (min-width: 1441px) {
    :root {
        --sp-section:    80px;
        --sp-card:       80px;
        --fs-display:    82px;
        --lh-display:    86px;
        --fs-heading:    64px;
        --lh-heading:    68px;
        --fs-heading-sm: 54px;
        --lh-heading-sm: 58px;
    }

    .header-inner { max-width: 1600px; }
    .footer-inner { max-width: 1600px; }

    .edge-headline--hero { font-size: 200px; }

    /* Amenities XL */
    .amenities-arrive__inner { max-width: 1600px; }
    .amenities-icons__inner { max-width: 1200px; }
    .amenities-wellbeing__card { max-width: 1600px; }
    .amenities-tiles__grid { max-width: 1600px; }
    .amenities-roof__grid-inner { max-width: 1600px; }

    /* Sustainability XL */
    .sustainability-tiles__grid { max-width: 1600px; }

    /* Location XL */
    .location-explore__grid { max-width: 1600px; }
    .location-transport__header { max-width: 1600px; }
    .location-transport__tables { max-width: 1600px; }
    .location-directory__inner { max-width: 1600px; }
}

/* --- L: Small laptops (1280px and below) --- */
@media (max-width: 1280px) {
    :root {
        --sp-section:    48px;
        --sp-card:       48px;
        --fs-display:    64px;
        --lh-display:    68px;
        --fs-heading:    50px;
        --lh-heading:    54px;
        --fs-heading-sm: 42px;
        --lh-heading-sm: 46px;
    }

    .edge-headline--hero { font-size: 140px; }
}

/* --- M: Tablets (1024px and below) --- */
@media (max-width: 1024px) {
    :root {
        --sp-section:    40px;
        --sp-card:       40px;
        --fs-display:    56px;
        --lh-display:    60px;
        --fs-heading:    44px;
        --lh-heading:    48px;
        --fs-heading-sm: 38px;
        --lh-heading-sm: 42px;
    }

    .main-navigation .nav-menu { gap: 24px; }
    .hero-logo { width: 70vw; }

    .edge-headline--hero { font-size: 110px; }

    .intro-section { padding: 60px var(--sp-section); }

    .building-schedule__grid { gap: 40px; }

    .building-floorplate { height: 55vh; min-height: 380px; }
    .building-floorplate__content { padding-bottom: 48px; }

    .building-spec { padding: 48px var(--sp-section); }
    .building-spec__inner { gap: 32px; }
    .building-spec__grid { grid-template-columns: repeat(3, 1fr); }
    .building-spec__item::after { display: none; }
    .building-spec__item:nth-child(3n+1):nth-child(n+4)::after { content: ''; display: block; position: absolute; top: 0; left: 0; width: 300%; height: 1px; background: var(--c-teal); }

    .building-amenities__content { padding: 40px; }
    .building-amenities__headline { font-size: 56px; line-height: 64px; }

    /* Amenities 1024 */
    .amenities-arrive { padding: 48px var(--sp-section) 0; }
    .amenities-arrive__inner { gap: 32px; }
    .amenities-arrive__columns { gap: 24px; }
    .amenities-arrive__illustration img { width: 280px; }

    .amenities-icons__inner { grid-template-columns: repeat(2, 1fr); gap: 32px; }

    .amenities-wellbeing__intro { padding: 60px var(--sp-section) 40px; }
    .amenities-wellbeing__content { padding: 40px; }

    .amenities-tiles__grid { padding: 40px var(--sp-section); }
    .amenities-tiles__col--left { padding-right: 24px; }
    .amenities-tiles__col--right { padding-left: 24px; }

    .amenities-roof__hero { height: 55vh; min-height: 380px; }
    .amenities-roof__intro { padding: 60px var(--sp-section) 40px; }
    .amenities-roof__grid { padding: 0 var(--sp-section) 48px; }
    .amenities-roof__side-illustration img { width: 220px; }

    /* Sustainability 1024 */
    .sustainability-intro { padding: 60px var(--sp-section) 0; }
    .sustainability-icons__inner { grid-template-columns: repeat(2, 1fr); gap: 32px; }
    .sustainability-tiles { padding: 40px var(--sp-section); }
    .sustainability-tiles__col--left { padding-right: 24px; }
    .sustainability-tiles__col--center { padding: 0 16px; }
    .sustainability-tiles__col--right { padding-left: 24px; }
    .sustainability-solar { height: 55vh; }

    /* Location 1024 */
    .location-explore { padding: 60px var(--sp-section) 48px; }
    .location-explore__grid { gap: 16px; }
    .location-transport { padding: 60px var(--sp-section) 48px; }
    .location-transport__illustration img { width: 200px; }
    .location-station__banner { padding: 48px var(--sp-section); }
    .location-directory { padding: 48px var(--sp-section); }
    .location-directory__inner { gap: 32px; }
    .location-directory__lists { gap: 20px; }
    .location-m4__intro { padding: 60px var(--sp-section) 40px; }

    .downloads-content { padding: 48px var(--sp-section); }
    .downloads-card { padding: 36px; }

    .siteplans-slider { padding: 48px var(--sp-section); }
    .siteplans-slider__label { top: 24px; left: 24px; }
    .siteplans-slider__size { font-size: 24px; }

    .footer-inner { padding: 40px 40px 24px; }
    .footer-headline { font-size: 52px; line-height: 60px; }
    .footer-watermark { max-width: 360px; }

    .page-subnav__inner { gap: 32px; padding: 16px var(--sp-section); }
    .page-subnav__link { font-size: 12px; }
}

/* --- S: Mobile landscape / large phones (768px and below) --- */
@media (max-width: 768px) {
    :root {
        --sp-section:    20px;
        --sp-card:       20px;
        --sp-gap:        12px;
        --fs-display:    38px;
        --lh-display:    42px;
        --fs-heading:    34px;
        --lh-heading:    38px;
        --fs-heading-sm: 30px;
        --lh-heading-sm: 34px;
        --fs-subline:    13px;
    }

    .header-inner { padding: 0 20px; }
    .site-header { padding: 16px 0; }
    .site-header.scrolled { padding: 12px 0; }
    .header-logo img { width: 48px; }
    .site-header.scrolled .header-logo img { width: 40px; }

    .hero { height: 85vh; }
    .hero-logo { width: 85vw; }
    .hero-address { bottom: 32px; }
    .hero-address p { font-size: 14px; }

    .page-hero { height: 75vh; }

    .edge-headline--hero { font-size: 64px; }

    .intro-section { padding: 48px var(--sp-section); }
    .intro-headline { margin-bottom: 24px; }
    .intro-subline { font-size: 14px; }

    /* Cards go portrait on mobile */
    .edge-card--16x9 { aspect-ratio: 3 / 4; }

    /* Grids stack */
    .edge-grid--2col { grid-template-columns: 1fr; }
    .edge-grid--3col { grid-template-columns: 1fr; }

    /* Floor plate hero mobile */
    .building-floorplate { height: 45vh; min-height: 320px; }
    .building-floorplate__content { padding: 24px; padding-bottom: 32px; }

    /* Specification mobile */
    .building-spec { padding: 36px var(--sp-section); }
    .building-spec__inner {
        grid-template-columns: 1fr;
        gap: 28px;
    }
    .building-spec__body { max-width: none; }
    .building-spec__footnote { max-width: none; }
    .building-spec__grid { grid-template-columns: repeat(2, 1fr); }
    .building-spec__item::after { display: none !important; }
    .building-spec__item:nth-child(2n+1):nth-child(n+3)::after { display: block !important; content: ''; position: absolute; top: 0; left: 0; width: 200%; height: 1px; background: var(--c-teal); }
    .building-spec__item::before { width: 1px; }
    .building-spec__item { padding: 16px; }
    .building-spec__icon img { width: 32px; height: 32px; }
    .building-spec__label { font-size: 12px; }

    /* Building Amenities Summary mobile */
    .building-amenities { padding: var(--sp-section); }
    .building-amenities__card { grid-template-columns: 1fr; }
    .building-amenities__content { padding: 28px; }
    .building-amenities__headline { font-size: 36px; line-height: 40px; margin-bottom: 20px; }
    .building-amenities__body { font-size: 14px; line-height: 160%; margin-bottom: 20px; }

    /* Amenities page mobile */
    .amenities-arrive { padding: 36px var(--sp-section) 0; }
    .amenities-arrive__inner {
        grid-template-columns: 1fr;
        gap: 24px;
    }
    .amenities-arrive__text .edge-headline { margin-bottom: 28px; }
    .amenities-arrive__columns {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    .amenities-arrive__body { font-size: 15px; }
    .amenities-arrive__illustration {
        display: flex;
        justify-content: center;
    }
    .amenities-arrive__illustration img { width: 220px; }

    .amenities-icons { padding: 28px var(--sp-section); }
    .amenities-icons__inner {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    .amenities-icons__icon img { width: 48px; height: 48px; }

    .amenities-wellbeing__intro { padding: 48px var(--sp-section) 32px; }
    .amenities-wellbeing__card {
        grid-template-columns: 1fr;
        min-height: auto;
    }
    .amenities-wellbeing__image { min-height: 260px; }
    .amenities-wellbeing__content { padding: 28px; }
    .amenities-wellbeing__body { font-size: 15px; }

    .amenities-tiles__grid {
        grid-template-columns: 1fr;
        padding: 28px var(--sp-section);
        gap: 32px;
    }
    .amenities-tiles__col--left { padding-right: 0; }
    .amenities-tiles__col--center {
        align-items: center;
        justify-content: center;
    }
    .amenities-tiles__tile-image--coffee { width: 60%; }
    .amenities-tiles__col--right { padding-left: 0; }
    .amenities-tiles__tile-body { font-size: 15px; }

    .amenities-roof__hero { height: 45vh; min-height: 320px; }
    .amenities-roof__hero-svg { height: 32px; }
    .amenities-roof__intro { padding: 48px var(--sp-section) 32px; }
    .amenities-roof__grid { padding: 0 var(--sp-section) 36px; }
    .amenities-roof__grid-inner {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    .amenities-roof__main-image { min-height: 260px; }
    .amenities-roof__side {
        flex-direction: row;
        gap: 20px;
    }
    .amenities-roof__side-image { flex: 1; min-height: 180px; }
    .amenities-roof__side-illustration { flex: 0 0 auto; }
    .amenities-roof__side-illustration img { width: 160px; }

    /* Sustainability mobile */
    .sustainability-hero__icon img { width: 64px; height: 64px; }
    .sustainability-intro { padding: 48px var(--sp-section) 0; }
    .sustainability-intro__text { margin-bottom: 32px; }
    .sustainability-intro__body { font-size: 15px; }
    .sustainability-icons { padding: 28px var(--sp-section); }
    .sustainability-icons__inner {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    .sustainability-tiles { padding: 28px var(--sp-section); }
    .sustainability-tiles__grid {
        grid-template-columns: 1fr;
        gap: 32px;
    }
    .sustainability-tiles__col--left { padding-right: 0; }
    .sustainability-tiles__col--center { padding: 0; }
    .sustainability-tiles__col--right { padding-left: 0; }
    .sustainability-tiles__col--left .sustainability-tiles__img { height: auto; }
    .sustainability-tiles__body { font-size: 15px; }
    .sustainability-solar { height: 45vh; min-height: 320px; }

    /* Location mobile */
    .location-explore { padding: 48px var(--sp-section) 36px; }
    .location-explore__intro { margin-bottom: 32px; }
    .location-explore__grid {
        grid-template-columns: 1fr;
        gap: 12px;
    }
    .location-explore__card { aspect-ratio: 3 / 4; }
    .location-explore__overlay { padding: 32px 12%; }
    .location-explore__overlay .edge-subline { font-size: 18px; }
    .location-explore__overlay-body { font-size: 13px; }

    .location-transport { padding: 48px var(--sp-section) 36px; }
    .location-transport__header {
        flex-direction: column;
        text-align: center;
        margin-bottom: 32px;
        gap: 24px;
    }
    .location-transport__header .edge-headline { text-align: center; }
    .location-transport__illustration img { width: 160px; }
    .location-station__banner { padding: 36px var(--sp-section); }
    .location-directory { padding: 36px var(--sp-section); }
    .location-directory__inner {
        grid-template-columns: 1fr;
        gap: 24px;
    }
    .location-directory__lists {
        grid-template-columns: 1fr;
        gap: 24px;
    }
    .location-m4__intro { padding: 48px var(--sp-section) 32px; }
    .location-m4__map { padding: 0 var(--sp-section) var(--sp-section); }
    .location-m4__map .edge-gmap { min-height: 400px; }

    .downloads-content { padding: 36px var(--sp-section); }
    .downloads-content__inner { grid-template-columns: 1fr; gap: 24px; }
    .downloads-card { padding: 28px; }
    .downloads-card .edge-headline { margin-bottom: 24px; }
    .downloads-btn { padding: 10px 14px; font-size: 12px; }

    /* Siteplans slider mobile */
    .siteplans-slider { padding: 32px var(--sp-section); }
    .siteplans-slider__track { aspect-ratio: 4 / 3; }
    .siteplans-slider__label { top: 16px; left: 16px; }
    .siteplans-slider__floor { font-size: 12px; }
    .siteplans-slider__size { font-size: 18px; }
    .siteplans-slider__arrow img { width: 32px; height: 32px; }
    .siteplans-slider__dots { margin-top: 20px; gap: 8px; }
    .siteplans-slider__dot { width: 8px; height: 8px; }

    /* Building schedule stacks on mobile */
    .building-schedule__grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .building-schedule__info { align-items: stretch; }

    .hotspot__icon { width: 28px; height: 28px; }

    .hotspot__tooltip { font-size: 11px; padding: 8px 12px; }

    .building-schedule__table th,
    .building-schedule__table td {
        padding: 7px 6px;
        font-size: 13px;
    }

    .building-schedule__table th { font-size: 11px; }

    .footer-address { padding: 36px 20px 0; }
    .footer-address p { font-size: 14px; }
    .footer-inner {
        grid-template-columns: 1fr;
        padding: 32px 20px 24px;
        gap: 32px;
        min-height: auto;
    }
    .footer-headline { font-size: 40px; line-height: 48px; padding-bottom: 32px; }
    .footer-contacts { flex-direction: column; gap: 20px; }
    .footer-contact .contact-name { font-size: 14px; }
    .footer-contact .contact-details { font-size: 14px; }
    .footer-right { align-items: flex-start; }
    .footer-watermark {
        position: relative;
        top: 0; right: 0;
        max-width: 260px;
        opacity: 0.2;
    }
    .footer-rpg { text-align: left; }
    .footer-rpg-label { font-size: 12px; }
    .footer-rpg-logo { width: 120px; }
    .footer-hanover-logo img { width: 180px; }

    .brochure-banner-inner { flex-direction: column; text-align: center; }
    .brochure-banner-label { margin-right: 0; margin-bottom: 5px; }
    .brochure-links { justify-content: center; }
    .brochure-link { font-size: 12px; padding: 6px 10px; }

    /* Page hero content tighter */
    .page-hero__content { padding: var(--sp-card) var(--sp-section) calc(var(--sp-card) + 12px); }
}

/* --- XS: Small phones (480px and below) --- */
@media (max-width: 480px) {
    :root {
        --sp-section:    14px;
        --sp-card:       14px;
        --fs-display:    30px;
        --lh-display:    34px;
        --fs-heading:    26px;
        --lh-heading:    30px;
        --fs-heading-sm: 24px;
        --lh-heading-sm: 28px;
        --fs-subline:    11px;
        --fs-body:       15px;
    }

    .hero { height: 80vh; }
    .page-hero { height: 70vh; }

    .edge-arrow img { width: 28px; height: 28px; }
    .edge-headline--hero { font-size: 44px; }
    .hero-logo { width: 92vw; }
    .hero-address { bottom: 24px; }
    .hero-address p { font-size: 12px; letter-spacing: 0.08em; }

    .intro-section { padding: 36px var(--sp-section); }
    .intro-subline { font-size: 13px; }

    .hotspot__icon { width: 22px; height: 22px; }

    .building-floorplate { height: 40vh; min-height: 280px; }
    .building-floorplate__content { padding: 16px; padding-bottom: 24px; }

    .building-schedule__table th,
    .building-schedule__table td {
        padding: 5px 3px;
        font-size: 11px;
    }
    .building-schedule__table th { font-size: 10px; }

    .building-amenities__content { padding: 24px; }
    .building-amenities__headline { font-size: 32px; line-height: 36px; }
    .building-amenities__body { font-size: 14px; }
    .building-amenities__btn { font-size: 12px; padding: 12px 24px; }

    .building-spec__item { padding: 12px; }
    .building-spec__icon img { width: 28px; height: 28px; }
    .building-spec__label { font-size: 11px; }

    /* Amenities XS */
    .amenities-arrive__illustration img { width: 180px; }
    .amenities-arrive__body { font-size: 14px; }
    .amenities-icons__icon img { width: 40px; height: 40px; }
    .amenities-icons__label { font-size: 12px; }
    .amenities-wellbeing__image { min-height: 220px; }
    .amenities-wellbeing__body { font-size: 14px; }
    .amenities-tiles__tile-image--coffee { width: 80%; }
    .amenities-tiles__tile-body { font-size: 14px; }
    .amenities-roof__hero { height: 38vh; min-height: 280px; }
    .amenities-roof__hero-svg { height: 24px; }
    .amenities-roof__hero-content { bottom: 32px; }
    .amenities-roof__side { flex-direction: column; }
    .amenities-roof__side-illustration img { width: 140px; }

    /* Sustainability XS */
    .sustainability-hero__icon img { width: 52px; height: 52px; }
    .sustainability-icons__icon img { width: 40px; height: 40px; }
    .sustainability-icons__label { font-size: 12px; }
    .sustainability-tiles__body { font-size: 14px; }
    .sustainability-solar { height: 38vh; min-height: 280px; }

    /* Location XS */
    .location-explore__badge { padding: 8px 14px; font-size: 12px; }
    .location-explore__overlay .edge-subline { font-size: 16px; }
    .location-explore__overlay-body { font-size: 12px; }
    .location-transport__illustration img { width: 120px; }
    .location-directory__cat-title { font-size: 14px; }
    .location-directory__item { font-size: 12px; }

    /* Downloads XS */
    .downloads-card { padding: 24px; }
    .downloads-btn { padding: 8px 12px; font-size: 11px; }
    .downloads-card__buttons { gap: 8px; }

    /* Footer XS */
    .footer-address p { font-size: 12px; }
    .footer-headline { font-size: 36px; line-height: 42px; padding-bottom: 24px; }
    .footer-contacts { gap: 16px; }
    .footer-contact .contact-name { font-size: 13px; }
    .footer-contact .contact-details { font-size: 13px; line-height: 140%; }
    .footer-hanover-logo img { width: 150px; }
    .footer-rpg-logo { width: 100px; }
    .footer-disclaimer p { font-size: 7px; }
}
