nt-face {
            font-family: 'Trajan Pro 3';
            src: url('fonts/trajanpro3-semibold-webfont.woff2') format('woff2'),
                 url('fonts/trajanpro3-semibold-webfont.woff') format('woff');
            font-weight: 600;
            font-style: normal;
            font-display: swap;
        }
        @font-face {
            font-family: 'Trajan Pro 3';
            src: url('fonts/trajanpro3-bold-webfont.woff2') format('woff2'),
                 url('fonts/trajanpro3-bold-webfont.woff') format('woff');
            font-weight: 700;
            font-style: normal;
            font-display: swap;
        }
        @font-face {
            font-family: 'Trajan Pro 3';
            src: url('fonts/trajanpro3-black-webfont.woff2') format('woff2'),
                 url('fonts/trajanpro3-black-webfont.woff') format('woff');
            font-weight: 900;
            font-style: normal;
            font-display: swap;
        }

        /* ── @font-face: Proza ─────────────────── */
        @font-face {
            font-family: 'Proza';
            src: url('fonts/prozalight-webfont.woff2') format('woff2'),
                 url('fonts/prozalight-webfont.woff') format('woff');
            font-weight: 300;
            font-style: normal;
            font-display: swap;
        }
        @font-face {
            font-family: 'Proza';
            src: url('fonts/prozalightitalic-webfont.woff2') format('woff2'),
                 url('fonts/prozalightitalic-webfont.woff') format('woff');
            font-weight: 300;
            font-style: italic;
            font-display: swap;
        }
        @font-face {
            font-family: 'Proza';
            src: url('fonts/prozaregular-webfont.woff2') format('woff2'),
                 url('fonts/prozaregular-webfont.woff') format('woff');
            font-weight: 400;
            font-style: normal;
            font-display: swap;
        }
/* 
        @font-face {
            font-family: 'Proza';
            src: url('fonts/prozaregularitalic-webfont.woff2') format('woff2'),
                 url('fonts/prozaregularitalic-webfont.woff') format('woff');
            font-weight: 400;
            font-style: italic;
            font-display: swap;
        }
 */
        @font-face {
            font-family: 'Proza';
            src: url('fonts/prozasemibold-webfont.woff2') format('woff2'),
                 url('fonts/prozasemibold-webfont.woff') format('woff');
            font-weight: 600;
            font-style: normal;
            font-display: swap;
        }
/* 
        @font-face {
            font-family: 'Proza';
            src: url('fonts/prozasemibolditalic-webfont.woff2') format('woff2'),
                 url('fonts/prozasemibolditalic-webfont.woff') format('woff');
            font-weight: 600;
            font-style: italic;
            font-display: swap;
        }
 */
/* 
        @font-face {
            font-family: 'Proza';
            src: url('fonts/prozabold-webfont.woff2') format('woff2'),
                 url('fonts/prozabold-webfont.woff') format('woff');
            font-weight: 700;
            font-style: normal;
            font-display: swap;
        }
        @font-face {
            font-family: 'Proza';
            src: url('fonts/prozabolditalic-webfont.woff2') format('woff2'),
                 url('fonts/prozabolditalic-webfont.woff') format('woff');
            font-weight: 700;
            font-style: italic;
            font-display: swap;
        }
 */
/* 
        @font-face {
            font-family: 'Proza';
            src: url('fonts/prozaextrabold-webfont.woff2') format('woff2'),
                 url('fonts/prozaextrabold-webfont.woff') format('woff');
            font-weight: 800;
            font-style: normal;
            font-display: swap;
        }
        @font-face {
            font-family: 'Proza';
            src: url('fonts/prozaextrabolditalic-webfont.woff2') format('woff2'),
                 url('fonts/prozaextrabolditalic-webfont.woff') format('woff');
            font-weight: 800;
            font-style: italic;
            font-display: swap;
        }
 */
/* 
        @font-face {
            font-family: 'Proza';
            src: url('fonts/prozablack-webfont.woff2') format('woff2'),
                 url('fonts/prozablack-webfont.woff') format('woff');
            font-weight: 900;
            font-style: normal;
            font-display: swap;
        }
        @font-face {
            font-family: 'Proza';
            src: url('fonts/prozablackitalic-webfont.woff2') format('woff2'),
                 url('fonts/prozablackitalic-webfont.woff') format('woff');
            font-weight: 900;
            font-style: italic;
            font-display: swap;
        }
 */

        /* ── Variables ──────────────────────────── */
        :root {
            --color-bg: #f7f4ef;
            --color-text: #2c2825;
            --color-heading: #1a1714;
            --color-accent: #8b6914;
            --color-accent-light: #c9a84c;
            --color-muted: #7a7168;
            --color-line: #d4cfc6;
            --color-land: #d4cfc6;
            --color-land-stroke: #b8b0a4;
            --color-highlight: #c9a84c;
            --font-display: 'Trajan Pro 3', 'Trajan Pro', 'Cinzel', Georgia, serif;
            --font-body: 'Proza', 'Georgia', serif;
        }

        *, *::before, *::after {
            margin: 0; padding: 0; box-sizing: border-box;
        }

        html { scroll-behavior: smooth; }

        body {
            font-size: 18pt;
            font-family: var(--font-body);
            font-weight: 400;
            background: var(--color-bg);
            color: var(--color-text);
            line-height: 1.7;
            min-height: 100vh;
            display: flex;
            flex-direction: column;
        }

        /* ── Hero ───────────────────────────────── */
        .hero {
            position: relative;
            padding: 5rem 2rem 3rem;
            text-align: center;
            overflow: hidden;
        }

        .hero::before {
            content: '';
            position: absolute;
            inset: 0;
            background:
                radial-gradient(ellipse 80% 60% at 50% 0%, rgba(139,105,20,0.07), transparent),
                radial-gradient(ellipse 60% 50% at 20% 80%, rgba(139,105,20,0.04), transparent);
            pointer-events: none;
        }

        .hero-ornament {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 1rem;
            margin-bottom: 1.5rem;
            opacity: 0;
            animation: fadeDown .8s ease forwards .2s;
        }

        .hero-ornament span {
            display: block; width: 48px; height: 1px;
            background: var(--color-accent-light);
        }

        .hero-ornament svg {
            width: 18px; height: 18px;
            color: var(--color-accent);
            flex-shrink: 0;
        }

        .hero h1 {
            font-family: var(--font-display);
            font-size: clamp(1.8rem, 5.5vw, 2.0rem);
            font-weight: 900;
            font-style: italic;
            color: var(--color-heading);
            letter-spacing: 0.08em;
/*             text-transform: uppercase; */
            line-height: 1.5;
            margin-bottom: .4rem;
            opacity: 0;
            animation: fadeDown .8s ease forwards .4s;
        }

        /* ── Kicker ───────────────────────────────── */
        .kicker {
            position: relative;
            padding: 1.5rem;
            text-align: center;
            overflow: hidden;
        }

        .subtitle {
            font-family: var(--font-body);
            font-size: clamp(0.8rem, 2.5vw, 1.1rem);
            font-weight: 300;
            font-style: italic;
            color: var(--color-muted);
            letter-spacing: 0.03em;
            opacity: 0;
            animation: fadeDown .8s ease forwards .6s;
        }

        /* ── Map ────────────────────────────────── */
        .map-section {
/*             max-width: 860px; */
            width: 95%;
            margin: 0 auto;
            padding: 1rem 0;
            opacity: 0;
            animation: fadeUp .8s ease forwards .8s;
        }

        .world-map {
            width: 100%;
            height: auto;
            display: block;
        }

        .world-map path {
            fill: var(--color-land);
            stroke: var(--color-land-stroke);
            stroke-width: 0.5;
            fill-rule: evenodd;
            transition: fill .3s ease;
        }

        .world-map .other path {
            fill: var(--color-land);
            opacity: 0.5;
        }

        .world-map [data-region] path {
            cursor: pointer;
        }

        .world-map [data-region]:hover path,
        .world-map [data-region].active path {
            fill: var(--color-highlight);
        }

        /* ── Region Labels ──────────────────────── */
        .region-labels {
            display: flex;
            justify-content: center;
            gap: 2.5rem;
            padding: 1rem 1rem 1rem;
            flex-wrap: wrap;
            opacity: 0;
            animation: fadeUp .8s ease forwards 1s;
        }

        .region-label {
            font-family: var(--font-display);
            font-size: 0.85rem;
            font-weight: 600;
            color: var(--color-muted);
            letter-spacing: 0.12em;
            text-transform: uppercase;
            cursor: pointer;
            padding: 0.3rem 0;
            border-bottom: 2px solid transparent;
            transition: color .3s ease, border-color .3s ease;
            user-select: none;
        }

        .region-label:hover,
        .region-label.active {
            color: var(--color-accent);
            border-bottom-color: var(--color-accent-light);
        }

        /* ── Divider ────────────────────────────── */
        .divider {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 1rem;
            padding: 0 2rem;
            max-width: 460px;
            margin: 0 auto 2.5rem;
            opacity: 0;
            animation: fadeUp .8s ease forwards 1.1s;
        }

        .divider::before,
        .divider::after {
            content: '';
            flex: 1; height: 1px;
            background: var(--color-line);
        }

        .divider svg {
            width: 14px; height: 14px;
            color: var(--color-accent-light);
            flex-shrink: 0;
        }

        /* ── Message ────────────────────────────── */
        .message {
            max-width: 540px;
            margin: 0 auto;
            padding: 0 2rem 4rem;
            text-align: center;
            opacity: 0;
            animation: fadeUp .8s ease forwards 1.2s;
        }

        .message p {
            font-size: 1.05rem;
            font-weight: 400;
            color: var(--color-text);
            margin-bottom: 1rem;
        }

        .message p.lead {
            font-family: var(--font-body);
            font-size: clamp(1.2rem, 2.2vw, 1.5rem);
            font-weight: 600;
            color: var(--color-heading);
            letter-spacing: 0.04em;
            line-height: 1.8;
            margin-bottom: 1.5rem;
        }

        .message a {
            color: var(--color-accent);
            text-decoration: none;
            border-bottom: 1px solid var(--color-accent-light);
            padding-bottom: 1px;
            transition: border-color .2s ease, color .2s ease;
        }

        .message a:hover {
            color: var(--color-heading);
            border-color: var(--color-heading);
        }

        .signature { margin-top: 2.5rem; }

        .signature .closing {
            font-family: var(--font-body);
            font-style: italic;
            font-weight: 300;
            font-size: 1rem;
            color: var(--color-muted);
            margin-bottom: .25rem;
        }

        .signature .name {
            font-family: var(--font-display);
            font-size: 1.15rem;
            font-weight: 700;
            color: var(--color-heading);
            letter-spacing: 0.06em;
            text-transform: uppercase;
        }

        /* ── Footer ─────────────────────────────── */
        footer {
            margin-top: auto;
            padding: 2rem;
            text-align: center;
            font-family: var(--font-body);
            font-size: 0.8rem;
            font-weight: 300;
            color: var(--color-muted);
            letter-spacing: 0.04em;
        }

        /* ── Animations ─────────────────────────── */
        @keyframes fadeDown {
            from { opacity:0; transform:translateY(-12px); }
            to   { opacity:1; transform:translateY(0); }
        }
        @keyframes fadeUp {
            from { opacity:0; transform:translateY(16px); }
            to   { opacity:1; transform:translateY(0); }
        }

        /* ── Responsive ─────────────────────────── */
        @media (max-width: 600px) {
            .hero { padding: 3.5rem 1.5rem 2rem; }
            .region-labels { gap: 1.5rem; }
            .message { padding: 0 1.5rem 3rem; }
        }

