:root {
    --color-primary-400: #78a9d4;
    --color-primary-500: #315f8b;
    --color-primary-700: #183a59;
    --color-secondary-500: #bb7b38;
    --color-accent-500: #1d8f78;
    --color-neutral-0: #ffffff;
    --color-neutral-50: #f7f2ea;
    --color-neutral-100: #eee5d8;
    --color-neutral-200: #d8ccb9;
    --color-neutral-300: #bbad98;
    --color-neutral-500: #7d7163;
    --color-neutral-700: #2d2722;
    --color-neutral-900: #15120f;
    --text-base: var(--color-neutral-700);
    --text-strong: var(--color-neutral-900);
    --text-muted: var(--color-neutral-500);
    --text-disabled: #a19484;
    --text-link: var(--color-primary-700);
    --text-link-hover: #0e2740;
    --text-inverse: var(--color-neutral-0);
    --text-accent: var(--color-accent-500);
    --color-success: #1b8f72;
    --color-warning: #b46a1f;
    --color-error: #a33232;
    --color-info: #315f8b;
    --color-debug: #7349b7;
    --surface-base: #f3ecdf;
    --surface-subtle: rgba(255, 252, 247, 0.78);
    --surface-elevated: rgba(255, 255, 255, 0.88);
    --surface-inverse: #14181c;
    --surface-overlay: rgba(20, 24, 28, 0.72);
    --button-primary-bg: var(--color-primary-500);
    --button-primary-hover: var(--color-primary-700);
    --button-secondary-bg: #ece3d5;
    --button-secondary-hover: #dccdb9;
    --button-ghost: transparent;
    --button-danger: var(--color-error);
    --button-disabled: #cbc0b0;
    --button-text: var(--text-inverse);
    --border-base: rgba(45, 39, 34, 0.14);
    --border-strong: rgba(45, 39, 34, 0.28);
    --border-subtle: rgba(45, 39, 34, 0.08);
    --border-focus: rgba(49, 95, 139, 0.45);
    --border-error: rgba(163, 50, 50, 0.42);
    --badge-neutral: rgba(45, 39, 34, 0.07);
    --badge-primary: rgba(49, 95, 139, 0.13);
    --badge-success: rgba(27, 143, 114, 0.14);
    --badge-warning: rgba(180, 106, 31, 0.16);
    --badge-error: rgba(163, 50, 50, 0.14);
    --space-2xs: 0.375rem;
    --space-xs: 0.5rem;
    --space-sm: 0.75rem;
    --space-md: 1rem;
    --space-lg: 1.5rem;
    --space-xl: 2rem;
    --space-2xl: 3rem;
    --radius-sm: 0.75rem;
    --radius-md: 1rem;
    --radius-lg: 1.5rem;
    --radius-xl: 2rem;
    --shadow-xs: 0 2px 5px rgba(21, 18, 15, 0.09);
    --shadow-sm: 0 18px 45px rgba(21, 18, 15, 0.08);
    --shadow-md: 0 30px 70px rgba(21, 18, 15, 0.12);
    --font-sans: "Public Sans", "Segoe UI", sans-serif;
    --font-display: "Fraunces", Georgia, serif;
    --transition-base: 180ms ease;
    --z-base: 1;
    --z-sticky: 50;
}

[data-theme="dark"] {
    --text-base: #ddd6cc;
    --text-strong: #f8f4ef;
    --text-muted: #a6998c;
    --text-link: #9bc4eb;
    --text-link-hover: #d8ecff;
    --surface-base: #131619;
    --surface-subtle: rgba(23, 27, 31, 0.86);
    --surface-elevated: rgba(31, 37, 43, 0.92);
    --surface-inverse: #f8f4ef;
    --surface-overlay: rgba(10, 12, 14, 0.72);
    --button-secondary-bg: #232a30;
    --button-secondary-hover: #2b343c;
    --border-base: rgba(248, 244, 239, 0.16);
    --border-strong: rgba(248, 244, 239, 0.55);
    --border-subtle: rgba(248, 244, 239, 0.30);
    --badge-neutral: rgba(248, 244, 239, 0.08);
    --badge-primary: rgba(155, 196, 235, 0.18);
    --badge-success: rgba(61, 201, 166, 0.17);
    --badge-warning: rgba(230, 167, 93, 0.18);
    --badge-error: rgba(222, 96, 96, 0.18);
    --shadow-xs: 0 2px 5px rgba(0, 0, 0, 0.32);
    --shadow-sm: 0 18px 45px rgba(0, 0, 0, 0.35);
    --shadow-md: 0 32px 76px rgba(0, 0, 0, 0.46);
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    color: var(--text-base);
    background: var(--surface-base);
    font-family: var(--font-sans);
    text-rendering: optimizeLegibility;
}

a {
    color: var(--text-link);
    transition:
        color var(--transition-base),
        border-color var(--transition-base),
        background-color var(--transition-base);
}

a:hover {
    color: var(--text-link-hover);
}

img {
    display: block;
    max-width: 100%;
}

@media (prefers-reduced-motion: reduce) {
    html {
        scroll-behavior: auto;
    }

    *,
    *::before,
    *::after {
        animation-duration: 0s !important;
        transition-duration: 0s !important;
        scroll-behavior: auto !important;
    }
}


html.has-site-nav-open,
html.has-site-nav-open body {
    overflow: hidden;
}

body {
    min-height: 100vh;
}

.site-header {
    position: sticky;
    top: 0;
    z-index: var(--z-sticky);
    background:
        linear-gradient(180deg, rgba(243, 236, 223, 0.96) 0%, rgba(243, 236, 223, 0.92) 100%);
    border-bottom: 1px solid var(--border-subtle);
    box-shadow: var(--shadow-xs);
    backdrop-filter: blur(18px);
}

.site-header__inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: var(--space-md);
    min-height: 4.1rem;
}

.site-header__brand {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    color: var(--text-strong);
    text-decoration: none;
}

.site-header__brand:hover {
    color: var(--text-strong);
}

.site-header__brand-mark {
    display: block;
    flex: 0 0 auto;
    width: auto;
    height: clamp(2.6rem, 5vw, 3.15rem);
    max-width: 2.75rem;
    object-fit: contain;
}

.site-header__brand-copy {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    line-height: 1.1;
}

.site-header__brand-copy strong {
    font-family: var(--font-display);
    font-size: 1.1rem;
    font-weight: 600;
}

.site-header__brand-copy span {
    color: var(--text-muted);
    font-size: 0.78rem;
}

.site-header__nav {
    display: none;
}

.site-header__tools {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: var(--space-sm);
}

.site-header__nav-list,
.site-footer__nav-list,
.site-nav-drawer__list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.site-header__menu-toggle {
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.28rem;
    width: 3rem;
    height: 3rem;
    padding: 0;
    border: 1px solid var(--border-base);
    border-radius: var(--radius-md);
    background: var(--surface-elevated);
    box-shadow: var(--shadow-xs);
}

.site-header__menu-line {
    width: 1.2rem;
    height: 2px;
    margin: 0 auto;
    border-radius: 999px;
    background: var(--text-strong);
}

.site-header__locale {
    display: none;
    position: relative;
}

.site-header__locale-summary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 3rem;
    min-height: 3rem;
    padding: 0 var(--space-sm);
    border: 1px solid var(--border-base);
    border-radius: var(--radius-md);
    background: var(--surface-elevated);
    color: var(--text-strong);
    box-shadow: var(--shadow-xs);
    cursor: pointer;
    list-style: none;
}

.site-header__locale-summary::-webkit-details-marker {
    display: none;
}

.site-header__locale-summary::after {
    content: "▾";
    margin-inline-start: 0.45rem;
    color: var(--text-muted);
    font-size: 0.72rem;
}

.site-header__locale[open] .site-header__locale-summary {
    border-color: var(--border-focus);
}

.site-header__locale-code {
    font-size: 0.88rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.site-header__locale-menu {
    position: absolute;
    top: calc(100% + 0.45rem);
    right: 0;
    min-width: 14rem;
    padding: var(--space-xs);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    background: var(--surface-elevated);
    box-shadow: var(--shadow-sm);
}

.site-header__locale-list,
.site-nav-drawer__locale-list {
    margin: 0;
    padding: 0;
    list-style: none;
}

.site-header__locale-list {
    display: grid;
    gap: 0.2rem;
}

.site-header__locale-link,
.site-nav-drawer__locale-link {
    display: block;
    padding: 0.65rem 0.8rem;
    border: 1px solid transparent;
    border-radius: var(--radius-sm);
    color: var(--text-strong);
    font-size: 0.94rem;
    font-weight: 600;
    text-decoration: none;
}

.site-header__locale-link:hover,
.site-nav-drawer__locale-link:hover {
    background: var(--badge-primary);
    border-color: var(--border-subtle);
}

.site-header__locale-link.is-active,
.site-nav-drawer__locale-link.is-active {
    color: var(--text-inverse);
    background: var(--button-primary-bg);
    border-color: var(--button-primary-bg);
}

.site-nav-drawer {
    width: min(24rem, calc(100vw - 1.5rem));
    max-width: none;
    height: 100vh;
    margin: 0 0 0 auto;
    padding: 0;
    border: none;
    background: transparent;
}

.site-nav-drawer::backdrop {
    background: rgba(20, 24, 28, 0.42);
    backdrop-filter: blur(4px);
}

.site-nav-drawer__panel {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: var(--space-lg);
    background: var(--surface-elevated);
    border-left: 1px solid var(--border-subtle);
    box-shadow: var(--shadow-md);
}

.site-nav-drawer__header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: var(--space-sm);
    align-items: start;
    margin-bottom: var(--space-xl);
}

.site-nav-drawer__eyebrow {
    grid-column: 1 / -1;
    margin: 0;
    color: var(--text-accent);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.site-nav-drawer__title {
    margin: 0;
    color: var(--text-strong);
    font-family: var(--font-display);
    font-size: clamp(1.5rem, 3.5vw, 2rem);
}

.site-nav-drawer__close {
    width: 2.75rem;
    height: 2.75rem;
    padding: 0;
    border: 1px solid var(--border-base);
    border-radius: 999px;
    background: var(--surface-base);
    color: var(--text-strong);
    font-size: 1.6rem;
    line-height: 1;
}

.site-nav-drawer__nav {
    flex: 1;
}

.site-nav-drawer__list {
    display: grid;
    gap: var(--space-xs);
}

.site-nav-drawer__locale {
    margin-top: var(--space-lg);
    padding-top: var(--space-lg);
    border-top: 1px solid var(--border-subtle);
}

.site-nav-drawer__section-title {
    margin: 0 0 var(--space-sm);
    color: var(--text-strong);
    font-size: 1rem;
    font-weight: 700;
}

.site-nav-drawer__locale-list {
    display: grid;
    gap: var(--space-xs);
}

.site-nav-drawer__link {
    display: block;
    padding: var(--space-md) var(--space-lg);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    background: var(--surface-subtle);
    color: var(--text-strong);
    font-size: 1.02rem;
    font-weight: 600;
    text-decoration: none;
    box-shadow: var(--shadow-xs);
}

.site-nav-drawer__link.is-active,
.site-header__nav-link.is-active {
    color: var(--text-inverse);
    background: var(--button-primary-bg);
    border-color: var(--button-primary-bg);
}

.site-footer {
    margin-top: var(--space-2xl);
    border-top: 1px solid var(--border-subtle);
    background: linear-gradient(180deg, rgba(255, 252, 247, 0.72) 0%, rgba(238, 229, 216, 0.92) 100%);
}

.site-footer__inner {
    display: grid;
    gap: var(--space-sm);
    padding-top: var(--space-xl);
    padding-bottom: var(--space-xl);
    text-align: center;
}

.site-footer__nav-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--space-xs) var(--space-md);
}

.site-footer__nav a {
    color: var(--text-muted);
    font-size: 0.94rem;
    text-decoration: none;
}

.site-footer__copy {
    margin: 0;
    color: var(--text-muted);
    font-size: 0.88rem;
}

@media (min-width: 992px) {
    .site-header__inner {
        grid-template-columns: auto minmax(0, 1fr);
    }

    .site-header__nav {
        display: flex;
        justify-content: flex-end;
    }

    .site-header__nav-list {
        display: flex;
        align-items: center;
        justify-content: flex-end;
        gap: var(--space-xs);
        margin: 0;
        padding: 0;
        list-style: none;
    }

    .site-header__nav-link {
        display: inline-flex;
        align-items: center;
        min-height: 2.75rem;
        padding: 0 var(--space-md);
        border: 1px solid transparent;
        border-radius: 999px;
        color: var(--text-strong);
        font-size: 0.94rem;
        font-weight: 600;
        text-decoration: none;
    }

    .site-header__nav-link:hover {
        background: var(--badge-primary);
        border-color: var(--border-subtle);
    }

    .site-header__locale {
        display: block;
    }

    .site-header__menu-toggle,
    .site-nav-drawer {
        display: none;
    }
}
