/* /Components/DesignPrinciples.razor.rz.scp.css */
.principles[b-f3yowdb1hb] {
    padding-block: var(--sp-24);
    background: var(--color-soil);
    color: var(--color-straw);
}

/* Override section-header colours for dark background */
.principles__header .section-eyebrow[b-f3yowdb1hb] { color: var(--color-amber-light); }
.principles__header .section-title[b-f3yowdb1hb]   { color: var(--color-straw); }

/* ── List ─────────────────────────────────────────────────────── */

.principles__list[b-f3yowdb1hb] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: var(--sp-8) var(--sp-10);
    counter-reset: none;
    list-style: none;
}

/* ── Individual principle ─────────────────────────────────────── */

.principle[b-f3yowdb1hb] {
    display: flex;
    gap: var(--sp-5);
    align-items: flex-start;
    padding-top: var(--sp-6);
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.principle__number[b-f3yowdb1hb] {
    font-family: var(--font-display);
    font-size: var(--text-3xl);
    font-weight: 300;
    color: var(--color-amber);
    opacity: 0.7;
    line-height: 1;
    flex-shrink: 0;
    user-select: none;
    /* Slight top offset so the number aligns with the title cap-height */
    margin-top: -0.1em;
}

.principle__content[b-f3yowdb1hb] {
    flex: 1;
}

.principle__title[b-f3yowdb1hb] {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: 500;
    color: var(--color-straw);
    margin-bottom: var(--sp-3);
    line-height: var(--leading-snug);
}

.principle__body[b-f3yowdb1hb] {
    font-family: var(--font-body);
    font-size: var(--text-sm);
    line-height: var(--leading-loose);
    color: var(--color-earth);
}

/* ── Responsive ────────────────────────────────────────────────── */

@media (max-width: 640px) {
    .principles__list[b-f3yowdb1hb] { grid-template-columns: 1fr; gap: var(--sp-6); }
}
/* /Components/Footer.razor.rz.scp.css */
.footer[b-bubwun0l25] {
    background: var(--color-soil);
    color: var(--color-tan);
    padding-block: var(--sp-12) var(--sp-8);
    margin-top: var(--sp-20);
}

.footer__inner[b-bubwun0l25] {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: var(--sp-8) var(--sp-16);
    align-items: start;
}

/* ── Brand ────────────────────────────────────────────────────── */

.footer__wordmark[b-bubwun0l25] {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: 400;
    color: var(--color-straw);
    display: block;
    margin-bottom: var(--sp-3);
    letter-spacing: var(--tracking-tight);
}

.footer__wordmark em[b-bubwun0l25] {
    font-style: italic;
    font-weight: 300;
    color: var(--color-amber-light);
}

.footer__tagline[b-bubwun0l25] {
    font-size: var(--text-sm);
    color: var(--color-earth);
    line-height: var(--leading-normal);
    max-width: 34ch;
}

/* ── Nav ──────────────────────────────────────────────────────── */

.footer__nav ul[b-bubwun0l25] {
    display: flex;
    flex-direction: column;
    gap: var(--sp-3);
}

.footer__nav a[b-bubwun0l25] {
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: 500;
    letter-spacing: var(--tracking-wide);
    text-transform: uppercase;
    color: var(--color-clay);
    transition: color var(--t-fast);
}

.footer__nav a:hover[b-bubwun0l25] { color: var(--color-straw); }

/* ── Legal ────────────────────────────────────────────────────── */

.footer__legal[b-bubwun0l25] {
    font-size: var(--text-xs);
    color: var(--color-earth);
    letter-spacing: var(--tracking-wide);
    grid-column: 1 / -1;
    padding-top: var(--sp-6);
    border-top: 1px solid rgba(255, 255, 255, 0.06);
    line-height: 1;
}

/* ── Responsive ────────────────────────────────────────────────── */

@media (max-width: 640px) {
    .footer__inner[b-bubwun0l25] {
        grid-template-columns: 1fr;
        gap: var(--sp-8);
    }

    .footer__nav ul[b-bubwun0l25] { flex-direction: row; flex-wrap: wrap; gap: var(--sp-4) var(--sp-6); }
}
/* /Components/HeroSection.razor.rz.scp.css */
.hero[b-61k69l9fmn] {
    position: relative;
    height: 100svh;
    min-height: 560px;
    display: flex;
    align-items: center;
    overflow: hidden; /* contains the parallax bg */
    background: var(--color-soil);
}

/* ── Background layers ────────────────────────────────────────── */

.hero__bg-clip[b-61k69l9fmn] {
    position: absolute;
    inset: -20%; /* extra space so parallax translate doesn't reveal edges */
    overflow: hidden;
}

.hero__bg[b-61k69l9fmn] {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center 40%;
    background-repeat: no-repeat;
    /* Muted, desaturated aerial — feels documentary, not glossy */
    filter: brightness(0.72) saturate(0.85);
    will-change: transform; /* promote to compositor layer for smooth parallax */
}

/* Gradient overlay: dark at bottom to ensure text legibility */
.hero__overlay[b-61k69l9fmn] {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(
            to bottom,
            rgba(30, 19, 12, 0.25) 0%,
            rgba(30, 19, 12, 0.10) 40%,
            rgba(30, 19, 12, 0.65) 100%
        ),
        linear-gradient(
            to right,
            rgba(30, 19, 12, 0.35) 0%,
            transparent 60%
        );
}

/* Subtle grain texture using SVG feTurbulence via data URI */
.hero__grain[b-61k69l9fmn] {
    position: absolute;
    inset: 0;
    opacity: 0.055;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    background-size: 300px 300px;
    pointer-events: none;
}

/* ── Text content ─────────────────────────────────────────────── */

.hero__content[b-61k69l9fmn] {
    position: relative;
    z-index: 2;
    max-width: var(--container-xl);
    padding-top: var(--nav-height);
}

.hero__eyebrow[b-61k69l9fmn] {
    font-family: var(--font-body);
    font-size: var(--text-xs);
    font-weight: 600;
    letter-spacing: var(--tracking-widest);
    text-transform: uppercase;
    color: var(--color-amber-light);
    margin-bottom: var(--sp-5);
}

.hero__headline[b-61k69l9fmn] {
    font-family: var(--font-display);
    font-size: var(--text-6xl);
    font-weight: 300;
    line-height: 1.05;
    color: #fff;
    letter-spacing: var(--tracking-tight);
    margin-bottom: var(--sp-6);
    max-width: 14ch;
}

.hero__headline-line[b-61k69l9fmn] {
    display: block;
}

/* Second line slightly indented to break grid rhythm */
.hero__headline-line:nth-child(2)[b-61k69l9fmn] {
    padding-left: clamp(1rem, 4vw, 3.5rem);
    font-style: italic;
    font-weight: 400;
}

.hero__subhead[b-61k69l9fmn] {
    font-family: var(--font-body);
    font-size: var(--text-lg);
    font-weight: 300;
    line-height: var(--leading-loose);
    color: rgba(255, 255, 255, 0.78);
    max-width: 48ch;
    margin-bottom: var(--sp-10);
}

.hero__cta[b-61k69l9fmn] {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-3);
}

/* ── Scroll indicator ─────────────────────────────────────────── */

.hero__scroll[b-61k69l9fmn] {
    position: absolute;
    bottom: var(--sp-8);
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sp-2);
    animation: heroScrollBounce-b-61k69l9fmn 2.4s ease-in-out infinite;
}

.hero__scroll-line[b-61k69l9fmn] {
    display: block;
    width: 1px;
    height: 40px;
    background: linear-gradient(to bottom, transparent, rgba(255,255,255,0.5));
}

.hero__scroll-label[b-61k69l9fmn] {
    font-family: var(--font-body);
    font-size: var(--text-xs);
    font-weight: 600;
    letter-spacing: var(--tracking-widest);
    text-transform: uppercase;
    color: rgba(255,255,255,0.45);
}

@keyframes heroScrollBounce-b-61k69l9fmn {
    0%, 100% { transform: translateX(-50%) translateY(0); opacity: 1; }
    50%       { transform: translateX(-50%) translateY(6px); opacity: 0.6; }
}

/* ── Responsive ───────────────────────────────────────────────── */

@media (max-width: 768px) {
    .hero__headline[b-61k69l9fmn] { font-size: clamp(2.8rem, 10vw, var(--text-6xl)); }
    .hero__headline-line:nth-child(2)[b-61k69l9fmn] { padding-left: 1rem; }
    .hero__subhead[b-61k69l9fmn] { font-size: var(--text-base); }
    .hero__scroll[b-61k69l9fmn]  { display: none; }
}
/* /Components/JournalEntryCard.razor.rz.scp.css */
.entry-card[b-kay916p11q] {
    padding: var(--sp-8);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background: var(--color-surface-raised);
    position: relative;
    transition: border-color var(--t-base), box-shadow var(--t-base);
}

.entry-card:hover[b-kay916p11q] {
    border-color: var(--color-border-strong);
    box-shadow: var(--shadow-sm);
}

/* Left accent line — evokes a physical journal ruled margin */
.entry-card[b-kay916p11q]::before {
    content: '';
    position: absolute;
    left: 0;
    top: var(--sp-6);
    bottom: var(--sp-6);
    width: 2px;
    background: var(--color-amber);
    border-radius: 0 2px 2px 0;
    opacity: 0;
    transition: opacity var(--t-base);
}

.entry-card:hover[b-kay916p11q]::before { opacity: 1; }

/* ── Meta row ─────────────────────────────────────────────────── */

.entry-card__meta[b-kay916p11q] {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--sp-3);
    margin-bottom: var(--sp-4);
}

.entry-card__date[b-kay916p11q] {
    font-family: var(--font-body);
    font-size: var(--text-xs);
    font-weight: 600;
    letter-spacing: var(--tracking-wide);
    color: var(--color-text-faint);
    text-transform: uppercase;
}

.entry-card__zone-link[b-kay916p11q] {
    font-family: var(--font-body);
    font-size: var(--text-xs);
    font-weight: 500;
    color: var(--color-accent);
    letter-spacing: var(--tracking-wide);
    text-transform: uppercase;
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-color: transparent;
    transition: text-decoration-color var(--t-fast), color var(--t-fast);
}

.entry-card__zone-link:hover[b-kay916p11q] {
    text-decoration-color: var(--color-accent);
}

/* ── Title ─────────────────────────────────────────────────────── */

.entry-card__title[b-kay916p11q] {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 400;
    color: var(--color-text);
    line-height: var(--leading-snug);
    margin-bottom: var(--sp-4);
}

/* ── Body ──────────────────────────────────────────────────────── */

.entry-card__body[b-kay916p11q] {
    font-family: var(--font-body);
    font-size: var(--text-base);
    line-height: var(--leading-loose);
    color: var(--color-text-secondary);
}
/* /Components/NavMenu.razor.rz.scp.css */
.nav[b-pzwvjc7dxi] {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 200;
    background: rgba(250, 246, 239, 0.90);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-bottom: 1px solid transparent;
    transition:
        border-color 300ms ease,
        box-shadow 300ms ease,
        background 300ms ease;
}

/* Elevated state added by initNavScroll() once user scrolls past 24px */
.nav.is-scrolled[b-pzwvjc7dxi] {
    border-bottom-color: var(--color-border);
    box-shadow: 0 1px 16px rgba(30, 19, 12, 0.06);
    background: rgba(250, 246, 239, 0.97);
}

/* ── Inner row ─────────────────────────────────────────────────────────── */

.nav__inner[b-pzwvjc7dxi] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: var(--nav-height);
    max-width: var(--container-2xl);
    margin-inline: auto;
    padding-inline: var(--sp-6);
}

/* ── Brand / wordmark ──────────────────────────────────────────────────── */

.nav__brand[b-pzwvjc7dxi] {
    display: flex;
    align-items: baseline;
    gap: 0.35em;
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: 500;
    color: var(--color-text);
    letter-spacing: var(--tracking-tight);
    text-decoration: none;
    transition: color var(--t-fast);
}

.nav__brand:hover[b-pzwvjc7dxi] { color: var(--color-accent); }

.nav__brand-amp[b-pzwvjc7dxi] {
    font-style: italic;
    font-weight: 300;
    color: var(--color-text-faint);
    font-size: 0.9em;
}

/* ── Desktop links ─────────────────────────────────────────────────────── */

.nav__links[b-pzwvjc7dxi] {
    display: flex;
    align-items: center;
    gap: var(--sp-8);
}

.nav__links a[b-pzwvjc7dxi] {
    font-family: var(--font-body);
    font-size: var(--text-sm);
    font-weight: 500;
    letter-spacing: var(--tracking-wide);
    text-transform: uppercase;
    color: var(--color-text-muted);
    position: relative;
    padding-bottom: 2px;
    transition: color var(--t-fast);
}

.nav__links a[b-pzwvjc7dxi]::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    right: 0;
    height: 1px;
    background: var(--color-accent);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform var(--t-base);
}

.nav__links a:hover[b-pzwvjc7dxi],
.nav__links a.active[b-pzwvjc7dxi] {
    color: var(--color-text);
}

.nav__links a.active[b-pzwvjc7dxi]::after,
.nav__links a:hover[b-pzwvjc7dxi]::after {
    transform: scaleX(1);
}

/* ── Hamburger ─────────────────────────────────────────────────────────── */

.nav__burger[b-pzwvjc7dxi] {
    display: none;
    flex-direction: column;
    gap: 5px;
    padding: var(--sp-2);
    background: none;
    border: none;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
}

.nav__burger-bar[b-pzwvjc7dxi] {
    display: block;
    width: 22px;
    height: 1.5px;
    background: var(--color-text-secondary);
    transition: transform var(--t-base), opacity var(--t-base), width var(--t-base);
    transform-origin: center;
}

.nav__burger.is-open .nav__burger-bar:nth-child(1)[b-pzwvjc7dxi] {
    transform: translateY(6.5px) rotate(45deg);
}
.nav__burger.is-open .nav__burger-bar:nth-child(2)[b-pzwvjc7dxi] {
    opacity: 0;
    width: 0;
}
.nav__burger.is-open .nav__burger-bar:nth-child(3)[b-pzwvjc7dxi] {
    transform: translateY(-6.5px) rotate(-45deg);
}

/* ── Mobile menu ───────────────────────────────────────────────────────── */

.nav__mobile[b-pzwvjc7dxi] {
    background: rgba(250, 246, 239, 0.98);
    border-top: 1px solid var(--color-border);
    padding: var(--sp-6) var(--sp-6) var(--sp-8);
    animation: slideDown-b-pzwvjc7dxi 0.2s var(--ease-out);
}

.nav__mobile ul[b-pzwvjc7dxi] {
    display: flex;
    flex-direction: column;
    gap: var(--sp-5);
}

.nav__mobile a[b-pzwvjc7dxi] {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 400;
    color: var(--color-text);
    display: block;
}

.nav__mobile a.active[b-pzwvjc7dxi] { color: var(--color-accent); }

@keyframes slideDown-b-pzwvjc7dxi {
    from { transform: translateY(-8px); opacity: 0; }
    to   { transform: none; opacity: 1; }
}

/* ── Responsive ────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    .nav__links[b-pzwvjc7dxi]  { display: none; }
    .nav__burger[b-pzwvjc7dxi] { display: flex; }
}
/* /Components/PhotoGallery.razor.rz.scp.css */
.gallery-grid[b-600y5l3i1u] {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-auto-rows: 260px;
    gap: var(--sp-3);
}

/* ── Individual photo ──────────────────────────────────────────── */

.gallery-item[b-600y5l3i1u] {
    overflow: hidden;
    border-radius: var(--radius-md);
    position: relative;
    background: var(--color-surface);
}

/* Every 5th photo spans two columns for asymmetric editorial rhythm */
.gallery-item--wide[b-600y5l3i1u] {
    grid-column: span 2;
}

.gallery-item__link[b-600y5l3i1u] {
    display: block;
    width: 100%;
    height: 100%;
    position: relative;
    overflow: hidden;
}

.gallery-item__img[b-600y5l3i1u] {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.65s var(--ease-out), filter 0.4s ease;
    filter: saturate(0.9) brightness(0.95);
}

.gallery-item:hover .gallery-item__img[b-600y5l3i1u] {
    transform: scale(1.05);
    filter: saturate(1) brightness(1);
}

/* Hover overlay */
.gallery-item__overlay[b-600y5l3i1u] {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to top,
        rgba(30, 19, 12, 0.55) 0%,
        transparent 50%
    );
    opacity: 0;
    transition: opacity var(--t-base);
    display: flex;
    align-items: flex-end;
    padding: var(--sp-4);
}

.gallery-item:hover .gallery-item__overlay[b-600y5l3i1u] { opacity: 1; }

.gallery-item__zone[b-600y5l3i1u] {
    font-family: var(--font-body);
    font-size: var(--text-xs);
    font-weight: 600;
    letter-spacing: var(--tracking-wider);
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.85);
    background: rgba(30, 19, 12, 0.45);
    padding: 0.2em 0.65em;
    border-radius: var(--radius-sm);
}

.gallery-item__caption[b-600y5l3i1u] {
    font-family: var(--font-body);
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    padding: var(--sp-2) var(--sp-1);
    line-height: var(--leading-snug);
}

.gallery__empty[b-600y5l3i1u] {
    font-family: var(--font-body);
    font-size: var(--text-base);
    color: var(--color-text-muted);
    text-align: center;
    padding-block: var(--sp-16);
    font-style: italic;
}

/* ── Responsive ────────────────────────────────────────────────── */

@media (max-width: 768px) {
    .gallery-grid[b-600y5l3i1u] {
        grid-template-columns: repeat(2, 1fr);
        grid-auto-rows: 200px;
    }
    .gallery-item--wide[b-600y5l3i1u] { grid-column: span 2; }
}

@media (max-width: 480px) {
    .gallery-grid[b-600y5l3i1u] {
        grid-template-columns: 1fr;
        grid-auto-rows: 240px;
    }
    .gallery-item--wide[b-600y5l3i1u] { grid-column: span 1; }
}
/* /Components/PropertyStats.razor.rz.scp.css */
.stats[b-ps1vhqhf3f] {
    background: var(--color-surface);
    border-bottom: 1px solid var(--color-border);
    padding-block: var(--sp-8);
}

.stats__inner[b-ps1vhqhf3f] {
    container-type: inline-size;
}

.stats__grid[b-ps1vhqhf3f] {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0;
}

/* ── Stat cell ──────────────────────────────────────────────────── */

.stats__item[b-ps1vhqhf3f] {
    flex: 1 0 140px;
    max-width: 220px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--sp-6) var(--sp-8);
    gap: var(--sp-1);
}

.stats__label[b-ps1vhqhf3f] {
    font-family: var(--font-body);
    font-size: var(--text-xs);
    font-weight: 700;
    letter-spacing: var(--tracking-widest);
    text-transform: uppercase;
    color: var(--color-text-faint);
    order: 0;
}

.stats__value[b-ps1vhqhf3f] {
    font-family: var(--font-display);
    font-size: clamp(2.4rem, 4vw, 3.5rem);
    font-weight: 300;
    line-height: 1;
    color: var(--color-text);
    order: 1;
}

/* For text values that don't need large numerals */
.stats__value--text[b-ps1vhqhf3f] {
    font-size: var(--text-2xl);
}

.stats__unit[b-ps1vhqhf3f] {
    font-family: var(--font-body);
    font-size: var(--text-xs);
    color: var(--color-text-faint);
    letter-spacing: var(--tracking-wide);
    order: 2;
}

/* ── Vertical dividers ──────────────────────────────────────────── */

.stats__divider[b-ps1vhqhf3f] {
    width: 1px;
    height: 40px;
    background: var(--color-border);
    align-self: center;
    flex-shrink: 0;
}

/* ── Responsive ─────────────────────────────────────────────────── */

@media (max-width: 640px) {
    .stats__divider[b-ps1vhqhf3f] { display: none; }
    .stats__grid[b-ps1vhqhf3f]    { gap: var(--sp-2); }
    .stats__item[b-ps1vhqhf3f]    { flex-basis: 40%; }
}
/* /Components/ZoneCard.razor.rz.scp.css */
.zone-card[b-y548kiysow] {
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--color-surface-raised);
    border: 1px solid var(--color-border);
    transition:
        transform var(--t-base),
        box-shadow var(--t-base),
        border-color var(--t-base);
}

.zone-card:hover[b-y548kiysow] {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    border-color: var(--color-border-strong);
}

.zone-card__link[b-y548kiysow] {
    display: flex;
    flex-direction: column;
    height: 100%;
    text-decoration: none;
    color: inherit;
}

/* ── Image / placeholder ─────────────────────────────────────── */

.zone-card__image-wrap[b-y548kiysow] {
    aspect-ratio: 16 / 10;
    overflow: hidden;
    background: var(--color-surface);
    flex-shrink: 0;
}

.zone-card__image[b-y548kiysow] {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s var(--ease-out);
}

.zone-card:hover .zone-card__image[b-y548kiysow] {
    transform: scale(1.04);
}

.zone-card__placeholder[b-y548kiysow] {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(
        135deg,
        var(--color-surface) 0%,
        var(--color-linen) 100%
    );
}

.zone-card__zone-num[b-y548kiysow] {
    font-family: var(--font-display);
    font-size: 4rem;
    font-weight: 300;
    color: var(--color-border-strong);
    opacity: 0.7;
    user-select: none;
}

/* ── Body ─────────────────────────────────────────────────────── */

.zone-card__body[b-y548kiysow] {
    padding: var(--sp-5) var(--sp-6) var(--sp-6);
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: var(--sp-3);
}

.zone-card__meta[b-y548kiysow] {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
}

.zone-card__num-label[b-y548kiysow] {
    font-family: var(--font-body);
    font-size: var(--text-xs);
    font-weight: 500;
    letter-spacing: var(--tracking-wide);
    text-transform: uppercase;
    color: var(--color-text-faint);
}

.zone-card__name[b-y548kiysow] {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 400;
    color: var(--color-text);
    line-height: var(--leading-snug);
}

.zone-card__desc[b-y548kiysow] {
    font-family: var(--font-body);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    line-height: var(--leading-loose);
    flex: 1;
    /* Clamp to 3 lines to keep cards uniform height */
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
}

.zone-card__arrow[b-y548kiysow] {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
    font-family: var(--font-body);
    font-size: var(--text-xs);
    font-weight: 700;
    letter-spacing: var(--tracking-wider);
    text-transform: uppercase;
    color: var(--color-accent);
    margin-top: var(--sp-2);
    transition: gap var(--t-fast);
}

.zone-card:hover .zone-card__arrow[b-y548kiysow] {
    gap: var(--sp-3);
}
/* /Components/ZoneGrid.razor.rz.scp.css */
.zone-grid[b-97n8h7768v] {
    display: grid;
    /* Auto-fill columns: min 280px, max 1fr — naturally responsive */
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--sp-6);
    align-items: start;
}

/* Keep all cards in a row the same height */
.zone-grid > [role="listitem"][b-97n8h7768v] {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.zone-grid > [role="listitem"] > .zone-card[b-97n8h7768v] {
    flex: 1;
}

.zone-grid__empty[b-97n8h7768v] {
    font-family: var(--font-body);
    font-size: var(--text-base);
    color: var(--color-text-muted);
    padding-block: var(--sp-12);
    text-align: center;
    width: 100%;
    font-style: italic;
}

@media (max-width: 480px) {
    .zone-grid[b-97n8h7768v] { grid-template-columns: 1fr; }
}
/* /Layout/MainLayout.razor.rz.scp.css */
.layout[b-xer5na8uly] {
    display: flex;
    flex-direction: column;
    min-height: 100dvh;
}

.layout__main[b-xer5na8uly] {
    flex: 1 0 auto;
}
/* /Pages/Gallery.razor.rz.scp.css */
.gallery-page[b-txo8rx4zwk] {
    padding-block: var(--sp-16) var(--sp-24);
}
/* /Pages/Home.razor.rz.scp.css */
.home-zones[b-t8vk7vnagx] {
    padding-block: var(--sp-24);
    background: var(--color-bg);
}

.home-journal[b-t8vk7vnagx] {
    padding-block: var(--sp-24);
    background: var(--color-surface);
    border-top: 1px solid var(--color-border);
}
/* /Pages/Journal.razor.rz.scp.css */
.journal-page[b-y5su16hond] {
    padding-block: var(--sp-16) var(--sp-24);
}

.journal-timeline[b-y5su16hond] {
    display: flex;
    flex-direction: column;
    gap: var(--sp-5);
    list-style: none;
}

.journal-empty[b-y5su16hond] {
    font-family: var(--font-body);
    font-size: var(--text-base);
    font-style: italic;
    color: var(--color-text-muted);
    text-align: center;
    padding-block: var(--sp-12);
}
/* /Pages/ZoneDetail.razor.rz.scp.css */
.zone-detail-loading[b-khngm07l3l] {
    display: flex;
    justify-content: center;
    padding-top: calc(var(--nav-height) + var(--sp-24));
}

/* ── Hero ─────────────────────────────────────────────────────── */

.zone-detail-hero[b-khngm07l3l] {
    position: relative;
    padding-top: calc(var(--nav-height) + var(--sp-20));
    padding-bottom: var(--sp-16);
    background: var(--color-soil);
    overflow: hidden;
}

.zone-detail-hero__image[b-khngm07l3l] {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    filter: brightness(0.55) saturate(0.75);
}

.zone-detail-hero__overlay[b-khngm07l3l] {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to right,
        rgba(30, 19, 12, 0.65) 0%,
        rgba(30, 19, 12, 0.25) 100%
    );
}

.zone-detail-hero__content[b-khngm07l3l] {
    position: relative;
    z-index: 2;
}

.zone-detail-hero__meta[b-khngm07l3l] {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--sp-4);
    margin-bottom: var(--sp-5);
}

.zone-detail-back[b-khngm07l3l] {
    font-family: var(--font-body);
    font-size: var(--text-xs);
    font-weight: 600;
    letter-spacing: var(--tracking-wide);
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.6);
    transition: color var(--t-fast);
}

.zone-detail-back:hover[b-khngm07l3l] { color: rgba(255, 255, 255, 0.9); }

.zone-detail-num[b-khngm07l3l] {
    font-family: var(--font-body);
    font-size: var(--text-xs);
    font-weight: 500;
    color: rgba(255, 255, 255, 0.45);
    letter-spacing: var(--tracking-wider);
    text-transform: uppercase;
}

.zone-detail-title[b-khngm07l3l] {
    font-family: var(--font-display);
    font-size: var(--text-5xl);
    font-weight: 400;
    color: #fff;
    max-width: 16ch;
    line-height: var(--leading-snug);
}

/* ── Body ─────────────────────────────────────────────────────── */

.zone-detail-body[b-khngm07l3l] {
    padding-block: var(--sp-16) var(--sp-24);
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-16);
    max-width: var(--container-md);
}

.zone-detail-description p[b-khngm07l3l] {
    font-family: var(--font-body);
    font-size: var(--text-lg);
    line-height: var(--leading-loose);
    color: var(--color-text-secondary);
}

.zone-detail-journal-heading[b-khngm07l3l] {
    font-family: var(--font-display);
    font-size: var(--text-3xl);
    font-weight: 400;
    color: var(--color-text);
    margin-bottom: var(--sp-8);
    padding-bottom: var(--sp-4);
    border-bottom: 1px solid var(--color-border);
}

.zone-detail-journal-link[b-khngm07l3l] {
    margin-top: var(--sp-6);
}

.zone-detail-no-entries[b-khngm07l3l] {
    font-style: italic;
    color: var(--color-text-faint);
    font-size: var(--text-sm);
}
/* /Pages/Zones.razor.rz.scp.css */
.zones-page[b-fokrtb6qdj] {
    padding-block: var(--sp-16) var(--sp-24);
}
