body {
            font-family: var(--primary-font);
            background-color: var(--bg-color);
            color: var(--text-color);
            line-height: 1.6;
            font-weight: var(--body-weight);
        }

        h1, h2, h3, h4, h5, h6 {
            font-family: var(--heading-font);
            font-weight: var(--heading-weight);
        }

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

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

        a:visited {
            color: var(--visited-link-color);
        }

        .container {
            max-width: var(--container-width, 1200px);
            margin: 0 auto;
            padding: 0 2rem;
        }

        header {
            background-color: var(--header-bg-color);
            padding: var(--header-top-padding, 0) 0 2rem;
        }

        /* Base header styles (default - left layout) */
        .header-flex {
            display: flex;
            justify-content: space-between;
            align-items: center;
            gap: 2rem;
        }

        .header-left {
            flex: 1;
            min-width: 0;
        }

        .header-right {
            flex-shrink: 0;
        }

        .logo {
            max-height: var(--logo-height);
	    vertical-align: bottom;
        }

        .site-name {
            font-family: var(--heading-font);
            font-size: var(--site-name-font-size);
            font-weight: var(--site-name-font-weight);
            letter-spacing: var(--site-name-letter-spacing);
            color: var(--site-name-color);
            margin-bottom: 0.25rem;
            line-height: 1.1;
        }

        .site-name a {
            color: inherit;
            text-decoration: none;
        }

        .site-name a:hover {
            color: var(--hover-link-color);
        }

        .site-subheader {
            font-family: var(--primary-font);
            font-size: var(--site-subheader-font-size);
            font-weight: var(--site-subheader-font-weight);
            letter-spacing: var(--site-subheader-letter-spacing);
            color: var(--site-subheader-color);
            line-height: 1.2;
            margin-top: 0.25rem;
        }

        nav .main-menu,
        .main-menu {
            list-style: none;
            display: flex;
            justify-content: left;
            align-items: center;
            flex-wrap: wrap;
            margin: 0;
            padding: 0;
        }

        .header-center .main-menu {
            justify-content: center;
        }

        nav .main-menu > li,
        .main-menu > li {
            margin: 0;
            display: list-item;
        }
        nav .main-menu > li:not(.menu-separator):not(.menu-space),
        .main-menu > li:not(.menu-separator):not(.menu-space) {
            display: list-item;
        }

        nav .menu-item,
        .menu-item {
            position: relative;
        }

        nav .main-menu > li.menu-separator,
        nav .main-menu > li.menu-space,
        .main-menu > li.menu-separator,
        .main-menu > li.menu-space {
            display: flex;
            align-items: center;
        }

        .menu-separator {
            position: relative;
            list-style: none;
            padding: 0 0.75rem;
            margin: 0;
            line-height: 1;
            color: var(--menu-color);
        }

        .menu-separator::before {
            display: none;
        }

        .menu-separator-text {
            display: inline-block;
        }

        .menu-toggle {
            display: none;
            border: none;
            background: transparent;
            color: var(--menu-color);
            cursor: pointer;
            padding: 0.4rem;
        }

        .menu-toggle:focus {
            outline: 2px solid var(--menu-color);
            outline-offset: 2px;
        }

        nav.header-right {
            position: relative;
            display: flex;
            align-items: center;
            gap: 1.5rem;
        }

        nav.header-right .main-menu {
            display: flex;
            align-items: center;
        }

        /* Header layout variations for center and right alignments */
        .header-flex.header-right.layout-reversed {
            justify-content: space-between;
        }

        .header-flex.header-right.layout-reversed .header-left {
            flex-shrink: 0;
        }

        .header-flex.header-right.layout-reversed .header-right {
            flex-shrink: 0;
            text-align: right;
        }

        .header-flex.header-center {
            justify-content: center;
            align-items: var(--center-menu-align, flex-end);
            gap: 4rem;
        }

        .header-center .header-left-menu {
            flex: 1;
            display: flex;
            justify-content: flex-end;
            align-items: flex-end;
        }

        .header-center .header-right-menu {
            flex: 1;
            display: flex;
            justify-content: flex-start;
            align-items: flex-end;
        }

        .header-center .header-center-logo {
            flex-shrink: 0;
	    text-align: center;
        }

        .header-center .header-left-menu .main-menu {
            justify-content: flex-end;
            align-items: flex-end;
	    margin-bottom: -2px;
        }

        .header-center .header-right-menu .main-menu {
            justify-content: flex-start;
            align-items: flex-end;
	    margin-bottom: -2px;
        }

        .header-center .center-desktop-menu .menu-link,
        .header-center .center-desktop-menu .menu-label {
            padding-top: 0;
            padding-bottom: 0;
            line-height: 1.25;
            display: inline-flex !important;
            align-items: flex-end;
        }

        .mobile-nav-container {
            display: none;
            width: auto;
        }

        .mobile-nav-container nav {
            width: auto;
        }

        .center-desktop-menu {
            display: none;
        }

        @media (min-width: 901px) {
            .header-center .mobile-nav-container {
                display: none;
            }

            .header-center .header-left-menu,
            .header-center .header-right-menu {
                display: flex;
            }

            .header-center .center-desktop-menu {
                display: flex;
            }
        }

        @media (max-width: 900px) {
            .header-flex {
                align-items: center;
            }

            .header-flex.header-center {
                justify-content: space-between;
                align-items: center;
                gap: 2rem;
            }

            .header-center .header-center-logo {
                flex: 1 1 auto;
                text-align: left;
                min-width: 0;
            }

            .header-center .header-left-menu,
            .header-center .header-right-menu {
                display: none;
            }

            .header-center .mobile-nav-container {
                display: flex;
                align-items: center;
                justify-content: flex-end;
                margin-left: auto;
                flex: 0 0 auto;
                min-width: 0;
            }

            .header-center .mobile-nav-container nav {
                display: flex;
                align-items: center;
                justify-content: flex-end;
                width: auto;
                position: relative;
            }

            .header-center .mobile-nav-container nav .menu-toggle {
                margin-left: auto;
            }

            .header-center .mobile-nav-container nav .main-menu {
                left: auto;
                right: 0;
            }

            .header-center .center-desktop-menu {
                display: none !important;
            }
        }

        @media (max-width: 900px) {
            .menu-toggle {
                display: inline-flex;
                margin-left: auto;
            }

            nav.header-right .main-menu,
            nav.header-nav .main-menu,
            .main-menu {
                display: none;
                flex-direction: column;
                align-items: stretch;
                gap: 0;
                position: absolute;
                top: calc(100% + 0.75rem);
                right: 0;
                background: var(--bg-surface);
                border: 1px solid var(--border-color);
                border-radius: 12px;
                box-shadow: 0 12px 24px rgba(15, 23, 42, 0.12);
                padding: 0.75rem 0;
                min-width: 220px;
                z-index: 100;
            }

            /* Hide desktop-only menus in center layout on mobile */
            .header-center .center-desktop-menu {
                display: none !important;
            }

            nav.header-right .main-menu a,
            nav.header-nav .main-menu a,
            .mobile-nav-container .main-menu a {
                text-decoration: none !important;
            }

            .menu-separator {
                width: 100%;
                padding: 0;
                margin: 0.5rem 0;
                line-height: 0;
                font-size: 0;
                opacity: 1;
            }

            .menu-separator::before {
                content: "";
                display: block;
                width: 100%;
                border-top: 1px solid var(--border-color);
                opacity: 0.65;
            }

            .menu-separator-text {
                display: none;
            }

            nav.header-right.nav-open .main-menu,
            nav.header-nav.nav-open .main-menu {
                display: flex;
            }

            .header-flex.header-right.layout-reversed .header-right {
                order: 1;
                text-align: left;
            }

            .header-flex.header-right.layout-reversed .header-left {
                order: 2;
                margin-left: auto;
                display: flex;
                justify-content: flex-end;
            }

            .header-flex.header-right.layout-reversed nav.header-nav {
                display: flex;
                align-items: center;
                justify-content: flex-end;
                width: auto;
                position: relative;
            }
        }

        nav .menu-link,
        nav .menu-label,
        .menu-link,
        .menu-label {
            color: var(--menu-color);
            text-decoration: none;
            padding: 0.5rem 0.75rem;
            display: inline-block;
            cursor: pointer;
            font-family: var(--menu-font-family);
            font-size: var(--menu-font-size);
            font-weight: var(--menu-font-weight);
            letter-spacing: var(--menu-letter-spacing);
        }

        nav a:hover, nav .menu-label:hover,
        a:hover, .menu-label:hover {
            color: var(--hover-link-color);
        }

        main {
            min-height: 60vh;
        }

        footer {
            text-align: center;
            padding: 2rem 0;
            color: var(--secondary-text-color);
        }

        /* Footer Social Icons Styling */
        .footer-social {
            text-align: center;
            margin-bottom: 0px;
        }

        .footer-social-icons {
            display: flex;
            justify-content: center;
            align-items: center;
            gap: normal;
            flex-wrap: wrap;
        }

        .footer-social-link {
            color: #404040;
            background-color: transparent;
            font-family: var(--primary-font);
            font-size: 15.2px;
            text-decoration: none;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
            padding: 12px 16px;
            border-radius: 6px;
            transition: all 0.2s ease-in-out;
            opacity: 0.8;
        }

        .footer-social-link:hover {
            color: #000000;
            background-color: #f5f5f5;
            opacity: 1;
            transform: translateY(-1px);
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
        }

        .footer-social-link:focus {
            outline: 2px solid #f5f5f5;
            outline-offset: 2px;
        }

        .footer-social-link i {
            font-size: 1.2rem;
            width: 1.2rem;
            height: 1.2rem;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .footer-social-label {
            color: #404040;
            font-size: 14px;
        }

        .footer-social-link:hover .footer-social-label {
            color: #000000;
        }

        /* Small screens */
        @media (max-width: 768px) {
            .footer-social-link {
                padding: 0.5rem 0.75rem;
                font-size: 0.85rem;
            }

            .footer-social-link i {
                font-size: 1rem;
                width: 1rem;
                height: 1rem;
            }

            .footer-social-label {
                font-size: 0.8rem;
            }
        }

        .gallery-title {
            text-align: center;
        }

        .gallery {
            margin-top: var(--gallery-top-padding, 0);
        }

        @media (max-width: 768px) {
            .gallery {
                margin-top: 0;
            }
        }

        /* Footer Credit Styling */
        .footer-credit {
            text-align: center;
            padding: 1rem 0;
            color: var(--secondary-text-color);
            font-size: 0.875rem;
        }

        .footer-social .container,
        .footer-credit .container {
            max-width: none;
            margin: 0 auto;
            padding: 0 2rem;
        }

        .footer-credit p {
            margin: 0;
        }

        .footer-credit a {
            color: #404040;
            text-decoration: none;
            font-weight: var(--font-weight-medium);
        }

        .footer-credit a:hover {
            color: #000000;
            text-decoration: underline;
        }

        .sr-only {
            position: absolute;
            width: 1px;
            height: 1px;
            padding: 0;
            margin: -1px;
            overflow: hidden;
            clip: rect(0, 0, 0, 0);
            white-space: nowrap;
            border: 0;
        }

        /* Dropdown Menu Styles */
        @media (min-width: 901px) {
            nav .has-dropdown {
                position: relative;
            }

            nav .dropdown {
                display: none;
                position: absolute;
                top: 100%;
                background-color: var(--accent-color);
                min-width: 200px;
                box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
                border: 1px solid var(--border-color);
                z-index: 1000;
                list-style: none;
                padding: 0.5rem 0;
                margin: 0;
            }

            nav .has-dropdown:hover > .dropdown {
                display: block;
            }

            nav .dropdown li {
                display: block;
                list-style: none;
                margin: 0;
                padding: 0;
            }

            nav .dropdown a,
            nav .dropdown .menu-label {
                display: block;
                padding: 0.75rem 1rem;
                white-space: nowrap;
                color: var(--menu-color);
                text-decoration: none;
                list-style: none;
                font-family: var(--menu-font-family);
                font-size: var(--menu-font-size);
                font-weight: var(--menu-font-weight);
                letter-spacing: var(--menu-letter-spacing);
            }

            nav .dropdown a:hover, nav .dropdown .menu-label:hover {
                color: var(--hover-link-color);
                background-color: rgba(0, 0, 0, 0.05);
            }

            nav .dropdown .has-dropdown {
                position: relative;
            }

            nav .dropdown .has-dropdown > .dropdown {
                top: 0;
            }

            /* Submenu link styles */
            nav .submenu-link,
            nav .submenu-label {
                text-decoration: none;
                color: var(--menu-color);
                font-family: var(--menu-font-family);
                font-size: var(--menu-font-size);
                font-weight: var(--menu-font-weight);
                letter-spacing: var(--menu-letter-spacing);
            }

            nav .submenu-link:hover,
            nav .submenu-label:hover {
                color: var(--hover-link-color);
                background-color: rgba(0, 0, 0, 0.05);
            }

            /* Social menu items in dropdowns */
            nav .social-menu-item {
                text-decoration: none;
            }

            nav .dropdown-menu .dropdown .dropdown {
                top: 0;
            }
        }

        /* Mobile dropdown styles */
        @media (max-width: 900px) {
            /* Hide dropdown children by default on mobile */
            nav .menu-item .absolute,
            nav .submenu-item .absolute {
                position: static;
                opacity: 0;
                visibility: hidden;
                max-height: 0;
                overflow: hidden;
                transform: none;
                box-shadow: none;
                border: none !important;
                background: transparent;
                padding: 0;
                margin: 0;
                transition: max-height 0.3s ease, opacity 0.2s ease, visibility 0.2s ease;
            }

            /* Show children when parent is expanded */
            nav .menu-item.mobile-expanded > .absolute,
            nav .submenu-item.mobile-expanded > .absolute {
                opacity: 1;
                visibility: visible;
                max-height: 2000px;
            }

            /* Mobile dropdown indentation */
            nav .menu-item .submenu-link,
            nav .menu-item .submenu-label {
                padding-left: 1.5rem;
                background: var(--bg-surface);
            }

            nav .menu-item .submenu-item .submenu-link,
            nav .menu-item .submenu-item .submenu-label {
                padding-left: 2.5rem;
                background: var(--bg-surface);
            }

            nav .menu-item .submenu-item .submenu-item .submenu-link,
            nav .menu-item .submenu-item .submenu-item .submenu-label {
                padding-left: 3.5rem;
                background: var(--bg-surface);
            }

            /* Rotate arrow when parent is expanded on mobile */
            nav .menu-item.mobile-expanded > .menu-link .menu-arrow,
            nav .menu-item.mobile-expanded > .menu-label .menu-arrow,
            nav .submenu-item.mobile-expanded > .submenu-link .w-3,
            nav .submenu-item.mobile-expanded > .submenu-label .w-3 {
                transform: rotate(180deg);
            }
        }

        /* Menu arrow styling */
        nav .menu-arrow {
            width: 0.75rem;
            height: 0.75rem;
            flex-shrink: 0;
            transition: transform 0.2s ease;
        }

        nav .menu-arrow path {
            stroke: currentColor;
            stroke-width: 2;
            stroke-linecap: round;
            stroke-linejoin: round;
            fill: none;
        }

        /* Flex utilities */
        .flex {
            display: flex;
        }

        .items-center {
            align-items: center;
        }

        .justify-between {
            justify-content: space-between;
        }

        .gap-1 {
            gap: 0.25rem;
        }

        .gap-2 {
            gap: 0.5rem;
        }

        /* Spacing utilities */
        .p-2 {
            padding: 0.5rem;
        }

        .px-3 {
            padding-left: 0.75rem;
            padding-right: 0.75rem;
        }

        .px-4 {
            padding-left: 1rem;
            padding-right: 1rem;
        }

        .py-2 {
            padding-top: 0.5rem;
            padding-bottom: 0.5rem;
        }

        .pl-4 {
            padding-left: 1rem;
        }

        .ml-2 {
            margin-left: 0.5rem;
        }

        /* Display utilities */
        .block {
            display: block;
        }

        .relative {
            position: relative;
        }

        .absolute {
            position: absolute;
        }

        .right-0 {
            right: 0;
            left: auto;
        }

        .right-full {
            right: 100%;
            left: auto;
        }

        .left-0 {
            left: 0;
            right: auto;
        }

        .left-full {
            left: 100%;
            right: auto;
        }

        .top-0 {
            top: 0;
        }

        .mt-2 {
            margin-top: 0.5rem;
        }

        .mr-1 {
            margin-right: 0.25rem;
        }

        .mb-2 {
            margin-bottom: 0.5rem;
        }

        .w-4 {
            width: 1rem;
        }

        .h-4 {
            height: 1rem;
        }

        .w-3 {
            width: 0.75rem;
        }

        .h-3 {
            height: 0.75rem;
        }

        .w-48 {
            width: 12rem;
        }

        .w-full {
            width: 100%;
        }

        .min-w-0 {
            min-width: 0;
        }

        /* Transition utilities */
        .transition-colors {
            transition-property: color, background-color, border-color;
            transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
            transition-duration: 150ms;
        }

        .transition-transform {
            transition-property: transform;
            transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
            transition-duration: 150ms;
        }

        .duration-200 {
            transition-duration: 200ms;
        }

        /* Font utilities */
        .font-bold {
            font-weight: 700;
        }

        .text-xs {
            font-size: 0.75rem;
            line-height: 1rem;
        }

        /* Interactive utilities */
        .hover\:opacity-75:hover {
            opacity: 0.75;
        }

        .cursor-default {
            cursor: default;
        }

        /* Rotation utilities */
        .rotate-180 {
            transform: rotate(180deg);
        }

        .rotate-90 {
            transform: rotate(90deg);
        }

        .-rotate-90 {
            transform: rotate(-90deg);
        }

        .rounded-lg {
            border-radius: 0.5rem;
        }

        .shadow-xl {
            box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
        }

        .border {
            border-width: 1px;
            border-style: solid;
        }

        .border-opacity-50 {
            --tw-border-opacity: 0.5;
        }

        .z-50 {
            z-index: 50;
        }

        .opacity-100 {
            opacity: 1;
        }

        .visible {
            visibility: visible;
        }

        /* Group hover utilities for dropdowns */
        .group:hover .group-hover\:opacity-100 {
            opacity: 1;
        }

        .group:hover .group-hover\:visible {
            visibility: visible;
        }

        .group\/submenu:hover .group-hover\/submenu\:rotate-180 {
            transform: rotate(180deg);
        }

        .group\/submenu:hover .group-hover\/submenu\:opacity-100 {
            opacity: 1;
        }

        .group\/submenu:hover .group-hover\/submenu\:visible {
            visibility: visible;
        }

        /* Dropdown menu utilities */
        .dropdown-menu {
            list-style: none !important;
            margin: 0 !important;
            padding: 0.5rem 0 !important;
            border: 1px solid var(--border-color) !important;
        }

        .invisible {
            visibility: hidden;
        }

        .opacity-0 {
            opacity: 0;
        }

        /* Dynamic color utilities */
        .dynamic-text {
            color: var(--menu-color);
        }

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

        .dynamic-accent {
            background-color: var(--bg-surface) !important;
        }

        .dynamic-border {
            border-color: var(--border-color) !important;
        }
