:root {
    /* Typography */
    --font-willow: "Willow W01", serif;
    --font-body: 'Montserrat', sans-serif;
    --font-serif: var(--font-willow); /* Mapping old var to new main font for compatibility if needed, or just replace usage */
    --font-sans: var(--font-body);

    /* Palette */
    --color-black: #0a0a0a;
    --color-ivory: #f5f2eb;
    --color-gold: #c5a059;

    /* Legacy Palette Mappings (to prevent breaking other pages temporarily) */
    --color-clay-base: var(--color-ivory);
    --color-clay-light: #fff; /* Approximation */
    --color-clay-dark: var(--color-gold);
    --color-rust: var(--color-gold);
    --color-charcoal: var(--color-black);
    --color-stone: var(--color-ivory);

    /* Spacing */
    --spacing-large: 6rem;
    --spacing-medium: 3rem;
    --spacing-small: 1.5rem;
    --safe-padding: clamp(1.5rem, 5vw, 4rem);

    /* Shared Section Title Styling */
    --section-title-font: var(--font-willow);
    --section-title-size: 2.5rem;
    --section-title-border-width: 5px;
    --section-title-border-color: var(--color-gold);
    --section-title-padding-left: 1rem;
    --section-title-margin-bottom: 2rem;
}

.accent-title {
    font-family: var(--section-title-font);
    font-size: var(--section-title-size);
    font-weight: normal;
    text-transform: uppercase;
    line-height: 1.1;
    color: var(--color-black);
    padding-left: var(--section-title-padding-left);
    border-left: var(--section-title-border-width) solid var(--section-title-border-color);
    margin-bottom: var(--section-title-margin-bottom);
}

/* --- Page Header (Shared) --- */
.page-container {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: var(--safe-padding);
    padding-top: 8rem;
    min-height: 100vh;
}

.page-header {
    text-align: center;
    margin-bottom: 2rem;
    width: 100%;
}

.page-title {
    font-family: var(--font-willow);
    font-size: clamp(3.5rem, 8vw, 6rem);
    margin-bottom: 1rem;
    line-height: 1.1;
    font-weight: normal;
    color: var(--color-black);
}

.page-subtitle {
    font-size: 1.1rem;
    color: #666; /* Or use a theme variable if available */
    max-width: 600px;
    margin: 0 auto;
}

/* Global Resets and Base Styles */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    background-color: var(--color-ivory);
    color: var(--color-black);
    font-family: var(--font-body);
    line-height: 1.6;
    font-size: 18px;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

/* Base Component: Buttons */
.btn-primary {
    display: inline-block;
    background-color: var(--color-black);
    color: var(--color-ivory);
    padding: 1rem 2.5rem;
    text-decoration: none;
    font-family: var(--font-body);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-size: 0.9rem;
    border: 1px solid var(--color-black);
    transition: all 0.3s ease;
}

.btn-primary:hover {
    background-color: transparent;
    color: var(--color-black);
    transform: translateY(-2px);
}

/* Animations */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.animate-in {
    animation: fadeInUp 1s ease forwards;
    opacity: 0;
}

.delay-1 { animation-delay: 0.2s; }
.delay-2 { animation-delay: 0.4s; }
.delay-3 { animation-delay: 0.6s; }

@font-face {
    font-family: "Willow W01";
    src: url("https://db.onlinewebfonts.com/t/8b20b096128a04aaee7f46bf30b18945.eot");
    src: url("https://db.onlinewebfonts.com/t/8b20b096128a04aaee7f46bf30b18945.eot?#iefix")format("embedded-opentype"),
    url("https://db.onlinewebfonts.com/t/8b20b096128a04aaee7f46bf30b18945.woff2")format("woff2"),
    url("https://db.onlinewebfonts.com/t/8b20b096128a04aaee7f46bf30b18945.woff")format("woff"),
    url("https://db.onlinewebfonts.com/t/8b20b096128a04aaee7f46bf30b18945.ttf")format("truetype"),
    url("https://db.onlinewebfonts.com/t/8b20b096128a04aaee7f46bf30b18945.svg#Willow W01")format("svg");
}

@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-VariableFont_wght.ttf') format('truetype');
    font-weight: 100 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Montserrat';
    src: url('../fonts/Montserrat-Italic-VariableFont_wght.ttf') format('truetype');
    font-weight: 100 900;
    font-style: italic;
    font-display: swap;
}
