/* Minification failed. Returning unminified contents.
(2,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(3,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(4,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(5,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(6,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(7,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(8,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(9,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(10,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(11,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(12,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(13,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(14,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(15,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(16,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(17,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(18,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(19,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(21,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(22,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(23,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(25,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(26,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(27,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(28,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(30,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(32,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(33,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(34,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(35,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(36,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(37,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(38,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(66,23): run-time error CSS1039: Token not allowed after unary operator: '-font-sans'
(67,21): run-time error CSS1039: Token not allowed after unary operator: '-text-base'
(69,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text'
(70,55): run-time error CSS1039: Token not allowed after unary operator: '-color-bg'
(106,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text'
(108,25): run-time error CSS1039: Token not allowed after unary operator: '-radius-pill'
(109,22): run-time error CSS1039: Token not allowed after unary operator: '-shadow-sm'
(120,22): run-time error CSS1039: Token not allowed after unary operator: '-color-primary-900'
(123,21): run-time error CSS1039: Token not allowed after unary operator: '-text-sm'
(182,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary-700'
(187,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text-soft'
(208,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text'
(218,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary'
(229,45): run-time error CSS1039: Token not allowed after unary operator: '-color-primary'
(229,67): run-time error CSS1039: Token not allowed after unary operator: '-color-danger'
(254,25): run-time error CSS1039: Token not allowed after unary operator: '-radius-pill'
(258,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(259,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(260,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(261,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(262,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(263,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(267,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(268,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(269,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(270,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(274,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(275,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(276,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(277,5): run-time error CSS1062: Expected semicolon or closing curly-brace, found '-'
(307,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text'
(316,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary'
(359,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary'
(380,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary-700'
(389,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary'
(431,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary-700'
(438,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary'
(444,46): run-time error CSS1039: Token not allowed after unary operator: '-color-danger'
(446,24): run-time error CSS1039: Token not allowed after unary operator: '-color-danger'
(451,46): run-time error CSS1039: Token not allowed after unary operator: '-color-danger-700'
(451,71): run-time error CSS1039: Token not allowed after unary operator: '-color-danger'
(481,46): run-time error CSS1039: Token not allowed after unary operator: '-color-primary'
(495,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary-700'
(500,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text-soft'
(504,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text-soft'
(549,17): run-time error CSS1039: Token not allowed after unary operator: '-color-danger'
(564,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary-700'
(571,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text-soft'
(594,17): run-time error CSS1039: Token not allowed after unary operator: '-color-accent'
(624,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary-700'
(631,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary'
(636,22): run-time error CSS1039: Token not allowed after unary operator: '-color-danger'
(638,28): run-time error CSS1039: Token not allowed after unary operator: '-color-danger'
(643,22): run-time error CSS1039: Token not allowed after unary operator: '-color-danger-700'
(644,24): run-time error CSS1039: Token not allowed after unary operator: '-color-danger-700'
(668,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary-700'
(674,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text-soft'
(716,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary-700'
(836,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text-soft'
(853,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text'
(858,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary'
(880,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary'
(888,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary-700'
(894,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text-soft'
(912,28): run-time error CSS1039: Token not allowed after unary operator: '-color-border'
(914,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text'
(932,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary-700'
(936,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text-soft'
(967,46): run-time error CSS1039: Token not allowed after unary operator: '-color-primary'
(979,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary-700'
(984,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text-soft'
(1001,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text'
(1008,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary'
(1036,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text-soft'
(1042,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary'
(1059,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text-soft'
(1077,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text-soft'
(1085,28): run-time error CSS1039: Token not allowed after unary operator: '-color-border'
(1109,17): run-time error CSS1039: Token not allowed after unary operator: '-color-danger'
(1126,25): run-time error CSS1039: Token not allowed after unary operator: '-radius-pill'
(1128,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text'
(1130,22): run-time error CSS1039: Token not allowed after unary operator: '-shadow-sm'
(1136,22): run-time error CSS1039: Token not allowed after unary operator: '-shadow-md'
(1142,22): run-time error CSS1039: Token not allowed after unary operator: '-color-primary-900'
(1168,21): run-time error CSS1039: Token not allowed after unary operator: '-text-sm'
(1207,21): run-time error CSS1039: Token not allowed after unary operator: '-text-sm'
(1234,22): run-time error CSS1039: Token not allowed after unary operator: '-color-accent'
(1235,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary-900'
(1236,22): run-time error CSS1039: Token not allowed after unary operator: '-shadow-md'
(1404,17): run-time error CSS1039: Token not allowed after unary operator: '-color-text'
(1411,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary'
(1418,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary-700'
(1455,17): run-time error CSS1039: Token not allowed after unary operator: '-color-primary-700'
(1462,17): run-time error CSS1039: Token not allowed after unary operator: '-color-danger'
 */
:root {
    --color-primary: #003B8E;
    --color-primary-700: #002C6B;
    --color-primary-900: #001B42;
    --color-danger: #C62839;
    --color-danger-700: #A61F2D;
    --color-accent: #F2C94C;
    --color-accent-600: #D8AF35;
    --color-tropical: #16A6B6;
    --color-success: #16A34A;
    --color-warning: #F59E0B;
    --color-info: #0EA5E9;
    --color-bg: #F8F4EA;
    --color-surface: #FFFFFF;
    --color-surface-soft: #F8FAFC;
    --color-border: #E2E8F0;
    --color-text: #0F172A;
    --color-text-soft: #475569;
    --color-text-inverse: #FFFFFF;

    --shadow-sm: 0 8px 20px rgba(15, 23, 42, 0.06);
    --shadow-md: 0 16px 40px rgba(15, 23, 42, 0.10);
    --shadow-lg: 0 24px 60px rgba(15, 23, 42, 0.16);

    --radius-sm: 12px;
    --radius-md: 18px;
    --radius-lg: 28px;
    --radius-pill: 999px;

    --font-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

    --text-xs: clamp(.75rem, .72rem + .1vw, .82rem);
    --text-sm: clamp(.875rem, .84rem + .12vw, .95rem);
    --text-base: clamp(1rem, .96rem + .18vw, 1.08rem);
    --text-lg: clamp(1.125rem, 1.05rem + .28vw, 1.25rem);
    --text-xl: clamp(1.35rem, 1.2rem + .7vw, 1.8rem);
    --text-2xl: clamp(1.8rem, 1.4rem + 1.6vw, 2.8rem);
    --text-3xl: clamp(2.2rem, 1.8rem + 2.1vw, 3.5rem);
}

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

html {
    scroll-behavior: smooth;
}

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

    *,
    *::before,
    *::after {
        animation: none !important;
        transition: none !important;
    }
}

body {
    margin: 0;
    font-family: var(--font-sans);
    font-size: var(--text-base);
    line-height: 1.6;
    color: var(--color-text);
    background: linear-gradient(180deg, #fff 0%, var(--color-bg) 100%);
    text-rendering: optimizeLegibility;
}

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

a {
    color: inherit;
    text-decoration: none;
}

a:hover {
    text-decoration: none;
}

button,
input,
select,
textarea {
    font: inherit;
}

:focus-visible {
    outline: 3px solid rgba(22, 166, 182, .45);
    outline-offset: 3px;
}

.skip-link {
    position: absolute;
    left: 1rem;
    top: -100px;
    z-index: 9999;
    background: #fff;
    color: var(--color-text);
    padding: .75rem 1rem;
    border-radius: var(--radius-pill);
    box-shadow: var(--shadow-sm);
}

.skip-link:focus {
    top: 1rem;
}

/* =========================
   TOPBAR
========================= */
.site-topbar {
    background: var(--color-primary-900);
    color: rgba(255,255,255,.92);
    padding: .45rem 0;
    font-size: var(--text-sm);
}

.site-topbar__text {
    text-align: center;
    font-weight: 600;
}

.site-topbar__links a {
    color: rgba(255,255,255,.78);
    font-weight: 600;
    transition: color .2s ease;
}

.site-topbar__links a:hover {
    color: #fff;
}

/* =========================
   HEADER / NAVBAR
========================= */
.site-header {
    position: sticky;
    top: 0;
    z-index: 1040;
    transition: all .25s ease;
}

.site-header.is-scrolled .site-navbar {
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.10);
    border-bottom-color: rgba(226, 232, 240, .9);
}

.site-navbar {
    background: rgba(255,255,255,.92);
    backdrop-filter: saturate(1.3) blur(14px);
    border-bottom: 1px solid rgba(226, 232, 240, .75);
    min-height: 82px;
}

.site-brand {
    display: inline-flex;
    align-items: center;
    gap: .85rem;
}

.site-brand__logo {
    width: 54px;
    height: 54px;
    object-fit: contain;
}

.site-brand__text {
    display: flex;
    flex-direction: column;
    line-height: 1.08;
}

.site-brand__text strong {
    color: var(--color-primary-700);
    font-size: 1.05rem;
}

.site-brand__text small {
    color: var(--color-text-soft);
    font-size: .75rem;
}

.site-header__right {
    flex: 0 0 auto;
}

.site-menu-toggle {
    border: 1px solid rgba(148, 163, 184, .28);
    border-radius: 14px;
    padding: .55rem .75rem;
    box-shadow: 0 6px 18px rgba(15, 23, 42, 0.06);
}

.site-menu-toggle:focus {
    box-shadow: 0 0 0 .2rem rgba(0, 59, 142, .12);
}

.site-nav .nav-link {
    position: relative;
    color: var(--color-text);
    font-weight: 700;
    padding-inline: .9rem !important;
    padding-block: .8rem !important;
    transition: color .22s ease;
    white-space: nowrap;
}

.site-nav .nav-link:hover,
.site-nav .nav-link:focus {
    color: var(--color-primary);
}

.site-nav__item > .nav-link::before {
    content: "";
    position: absolute;
    left: .9rem;
    right: .9rem;
    bottom: .45rem;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--color-primary), var(--color-danger));
    transform: scaleX(0);
    transform-origin: left center;
    opacity: 0;
    transition: transform .22s ease, opacity .22s ease;
}

.site-nav__item > .nav-link:hover::before,
.site-nav__item > .nav-link:focus::before,
.site-nav__item > .nav-link.show::before {
    transform: scaleX(1);
    opacity: 1;
}

.site-nav .dropdown-toggle::after {
    margin-left: .45rem;
    vertical-align: .18em;
    transition: transform .22s ease;
}

.site-nav .dropdown-toggle.show::after {
    transform: rotate(180deg);
}

.btn-pill {
    border-radius: var(--radius-pill);
}

.btn-primary {
    --bs-btn-bg: var(--color-primary);
    --bs-btn-border-color: var(--color-primary);
    --bs-btn-hover-bg: var(--color-primary-700);
    --bs-btn-hover-border-color: var(--color-primary-700);
    --bs-btn-active-bg: var(--color-primary-700);
    --bs-btn-active-border-color: var(--color-primary-700);
}

.btn-danger {
    --bs-btn-bg: var(--color-danger);
    --bs-btn-border-color: var(--color-danger);
    --bs-btn-hover-bg: var(--color-danger-700);
    --bs-btn-hover-border-color: var(--color-danger-700);
}

.btn-outline-primary {
    --bs-btn-color: var(--color-primary);
    --bs-btn-border-color: var(--color-primary);
    --bs-btn-hover-bg: var(--color-primary);
    --bs-btn-hover-border-color: var(--color-primary);
}

.site-auth__logout-form {
    margin: 0;
}

.mobile-auth__logout-form {
    margin: 0;
}

.site-auth--user {
    display: flex;
    align-items: center;
    gap: 12px;
}

/* =========================
   DESKTOP LANGUAGE
========================= */
.site-lang-dropdown .dropdown-menu {
    min-width: 180px;
}

.site-lang-btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    border: 1px solid rgba(148, 163, 184, .28);
    background: rgba(255,255,255,.85);
    color: var(--color-text);
    border-radius: 999px;
    padding: .55rem .82rem;
    font-weight: 700;
    box-shadow: 0 6px 18px rgba(15, 23, 42, .05);
}

.site-lang-btn:hover {
    background: #fff;
    color: var(--color-primary);
    border-color: rgba(0, 59, 142, .18);
}

.site-lang-btn__flag {
    font-size: 1rem;
    line-height: 1;
}

.site-lang-btn__text {
    line-height: 1;
}

.site-lang-btn__text--short {
    font-size: .84rem;
    font-weight: 800;
    letter-spacing: .03em;
}

.site-lang-menu {
    border: 1px solid rgba(226, 232, 240, .95);
    border-radius: 16px;
    padding: .45rem;
    box-shadow: 0 18px 45px rgba(15, 23, 42, .12);
}

.site-lang-menu .dropdown-item {
    display: flex;
    align-items: center;
    gap: .65rem;
    border-radius: 10px;
    font-weight: 600;
    padding: .7rem .85rem;
}

.site-lang-option__flag {
    font-size: 1rem;
    line-height: 1;
}

.site-lang-menu .dropdown-item.active,
.site-lang-menu .dropdown-item:active {
    background: rgba(0, 59, 142, .08);
    color: var(--color-primary);
}

/* =========================
   AUTH ACTIONS / SEARCH
========================= */
.site-nav__actions {
    display: flex;
    align-items: center;
    gap: .7rem;
}

.site-search-trigger {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    min-height: 46px;
    padding: .7rem 1rem;
    border-radius: 999px;
    border: 1px solid rgba(148,163,184,.28);
    background: rgba(255,255,255,.9);
    color: var(--color-primary-700);
    font-weight: 700;
    box-shadow: 0 6px 18px rgba(15,23,42,.05);
    transition: all .2s ease;
}

.site-search-trigger:hover {
    background: #fff;
    border-color: rgba(0,59,142,.18);
    color: var(--color-primary);
    transform: translateY(-1px);
}

.site-search-trigger i {
    font-size: 1rem;
}

.site-search-trigger--icon {
    width: 46px;
    height: 46px;
    min-width: 46px;
    padding: 0;
    justify-content: center;
    gap: 0;
}

.site-search-trigger--icon span {
    display: none !important;
}

.site-auth {
    display: flex;
    align-items: center;
    gap: .7rem;
}

.site-auth-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .55rem;
    min-height: 46px;
    padding: .72rem 1.1rem;
    border-radius: 999px;
    font-weight: 700;
    border: 1px solid transparent;
    transition: all .2s ease;
}

.site-auth-btn--ghost {
    background: rgba(255,255,255,.88);
    color: var(--color-primary-700);
    border-color: rgba(148,163,184,.28);
    box-shadow: 0 6px 18px rgba(15,23,42,.05);
}

.site-auth-btn--ghost:hover {
    background: #fff;
    color: var(--color-primary);
    border-color: rgba(0,59,142,.18);
    transform: translateY(-1px);
}

.site-auth-btn--primary {
    background: linear-gradient(135deg, var(--color-danger), #df4155);
    color: #fff;
    border-color: var(--color-danger);
    box-shadow: 0 8px 20px rgba(198,40,57,.25);
}

.site-auth-btn--primary:hover {
    background: linear-gradient(135deg, var(--color-danger-700), var(--color-danger));
    color: #fff;
    transform: translateY(-1px);
}

.site-user-chip {
    display: inline-flex;
    align-items: center;
    gap: .75rem;
    min-height: 48px;
    padding: .55rem .8rem;
    border-radius: 999px;
    background: #fff;
    border: 1px solid rgba(148,163,184,.24);
    box-shadow: 0 8px 18px rgba(15,23,42,.06);
    transition: all .2s ease;
}

.site-user-chip:hover {
    transform: translateY(-1px);
    border-color: rgba(0,59,142,.18);
    box-shadow: 0 12px 24px rgba(15,23,42,.08);
}

.site-user-chip__avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, var(--color-primary), #2a66c7);
    color: #fff;
    font-size: .95rem;
    flex: 0 0 auto;
}

.site-user-chip__text {
    display: flex;
    flex-direction: column;
    line-height: 1.05;
}

.site-user-chip__text strong {
    font-size: .92rem;
    color: var(--color-primary-700);
}

.site-user-chip__text small {
    font-size: .72rem;
    color: var(--color-text-soft);
}

.site-user-chip__arrow {
    color: var(--color-text-soft);
    font-size: .9rem;
}

/* =========================
   MEGA MENU
========================= */
.site-nav__item--mega {
    position: static;
}

.site-mega-menu {
    width: min(1060px, calc(100vw - 2rem));
    left: 50% !important;
    border: 1px solid rgba(226, 232, 240, .95);
    border-radius: 22px;
    box-shadow: 0 22px 60px rgba(15, 23, 42, .14);
    overflow: hidden;
    background: #fff;
}

.site-mega-menu__inner {
    display: grid;
    grid-template-columns: 1.45fr .75fr;
    min-height: 100%;
}

.site-mega-menu__content {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.1rem;
    padding: 1.25rem;
}

.site-mega-menu__col {
    display: grid;
    gap: .65rem;
}

.site-mega-menu__eyebrow {
    display: inline-block;
    font-size: .78rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--color-danger);
    margin-bottom: .2rem;
}

.site-mega-link {
    display: block;
    padding: .85rem .9rem;
    border-radius: 16px;
    border: 1px solid transparent;
    background: linear-gradient(180deg, rgba(248,250,252,.88) 0%, #fff 100%);
    transition: background-color .2s ease, transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.site-mega-link strong {
    display: block;
    color: var(--color-primary-700);
    font-size: .96rem;
    margin-bottom: .18rem;
}

.site-mega-link small {
    display: block;
    color: var(--color-text-soft);
    font-size: .84rem;
    line-height: 1.35;
}

.site-mega-link:hover,
.site-mega-link:focus {
    transform: translateY(-2px);
    border-color: rgba(0, 59, 142, .12);
    box-shadow: 0 10px 24px rgba(15, 23, 42, .07);
    background: rgba(0, 59, 142, .03);
}

.site-mega-menu__feature {
    background: linear-gradient(135deg, rgba(0,59,142,.96), rgba(0,44,107,.96));
    color: #fff;
    padding: 1.35rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.site-mega-menu__feature .site-mega-menu__eyebrow {
    color: var(--color-accent);
    margin-bottom: .6rem;
}

.site-mega-menu__feature h3 {
    font-size: 1.28rem;
    line-height: 1.2;
    margin-bottom: .75rem;
}

.site-mega-menu__feature p {
    color: rgba(255,255,255,.86);
    font-size: .95rem;
    margin-bottom: 1rem;
}

.site-mega-menu__feature-actions {
    display: flex;
    flex-wrap: wrap;
    gap: .65rem;
}

.site-mega-btn {
    min-width: 110px;
    font-weight: 700;
    padding-inline: 1rem;
}

.site-mega-btn--light {
    background: #fff;
    color: var(--color-primary-700);
    border: 1px solid rgba(255,255,255,.35);
    box-shadow: 0 8px 18px rgba(0,0,0,.12);
}

.site-mega-btn--light:hover {
    background: #f8fbff;
    color: var(--color-primary);
    border-color: rgba(255,255,255,.55);
}

.site-mega-btn--danger {
    background: var(--color-danger);
    color: #fff;
    border: 1px solid var(--color-danger);
    box-shadow: 0 8px 18px rgba(0,0,0,.16);
}

.site-mega-btn--danger:hover {
    background: var(--color-danger-700);
    border-color: var(--color-danger-700);
    color: #fff;
}

.site-mega-menu--experiences {
    width: min(1220px, calc(100vw - 2rem));
}

.site-mega-menu__inner--experiences {
    grid-template-columns: 1.7fr .75fr;
}

.site-mega-menu__content--experiences {
    display: block;
    padding: 1.2rem;
}

.site-mega-menu__header {
    margin-bottom: 1rem;
}

.site-mega-menu__header h3 {
    margin: .2rem 0 .35rem;
    font-size: 1.2rem;
    color: var(--color-primary-700);
    font-weight: 800;
}

.site-mega-menu__header p {
    margin: 0;
    color: var(--color-text-soft);
    font-size: .92rem;
    max-width: 70ch;
}

.experience-province-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: .8rem;
    max-height: 520px;
    overflow: auto;
    padding-right: .25rem;
}

.experience-province-card {
    display: flex;
    flex-direction: column;
    gap: .55rem;
    padding: .55rem;
    border-radius: 16px;
    background: #fff;
    border: 1px solid rgba(226,232,240,.9);
    box-shadow: 0 8px 18px rgba(15,23,42,.05);
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.experience-province-card:hover {
    transform: translateY(-2px);
    border-color: rgba(0,59,142,.16);
    box-shadow: 0 14px 28px rgba(15,23,42,.08);
}

.experience-province-card img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    border-radius: 12px;
}

.experience-province-card span {
    font-size: .9rem;
    font-weight: 700;
    color: var(--color-primary-700);
    line-height: 1.2;
}

.site-mega-menu__feature--experiences {
    justify-content: center;
}

@media (min-width: 1200px) {
    .site-nav .dropdown-menu {
        display: block;
        opacity: 0;
        visibility: hidden;
        transition: opacity .22s ease, transform .22s ease, visibility .22s ease;
        pointer-events: none;
    }

    .site-nav .dropdown:not(.site-nav__item--mega) > .dropdown-menu {
        transform: translateY(10px);
    }

    .site-nav__item--mega > .dropdown-menu {
        transform: translateX(-50%) translateY(10px);
    }

    .site-nav .dropdown:hover > .dropdown-menu,
    .site-nav .dropdown .dropdown-menu.show {
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }

    .site-nav .dropdown:not(.site-nav__item--mega):hover > .dropdown-menu,
    .site-nav .dropdown:not(.site-nav__item--mega) .dropdown-menu.show {
        transform: translateY(0);
    }

    .site-nav__item--mega:hover > .dropdown-menu,
    .site-nav__item--mega .dropdown-menu.show {
        transform: translateX(-50%) translateY(0);
    }

    .site-navbar__container {
        max-width: 1860px;
        padding-inline: clamp(1rem, 2vw, 2.6rem);
        display: grid;
        grid-template-columns: auto minmax(0, 1fr);
        align-items: center;
        column-gap: 1.4rem;
    }

    .site-brand {
        min-width: 0;
        max-width: 195px;
    }

    .site-brand__text {
        min-width: 0;
    }

    .site-brand__text strong {
        display: block;
        white-space: nowrap;
    }

    .site-brand__text small {
        display: block;
        max-width: 140px;
        white-space: nowrap;
        padding-top: 1px;
    }

    .site-navbar .navbar-collapse {
        min-width: 0;
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: center;
        column-gap: .8rem;
    }

    .site-nav {
        min-width: 0;
        width: 100%;
        justify-content: center;
        flex-wrap: nowrap;
        gap: clamp(.02rem, .24vw, .28rem);
    }

    .site-nav .nav-link {
        padding-inline: clamp(.34rem, .42vw, .62rem) !important;
        font-size: .96rem;
    }

    .site-nav__actions {
        justify-self: end;
        margin-left: 0;
        gap: .45rem;
    }
}

@media (min-width: 1700px) {
    .site-navbar__container {
        max-width: 1940px;
    }
}

/* =========================
   MOBILE MENU
========================= */
.mobile-menu {
    max-width: 360px;
}

.mobile-menu .offcanvas-header {
    padding-top: 1rem;
    padding-bottom: 1rem;
}

.mobile-menu__subtitle {
    font-size: .88rem;
    color: var(--color-text-soft);
}

.mobile-menu__actions {
    margin-top: 1rem;
    margin-bottom: 1rem;
}

.mobile-menu__nav {
    display: grid;
    gap: .4rem;
}

.mobile-menu__nav > a {
    display: block;
    padding: .85rem .25rem;
    font-weight: 700;
    color: var(--color-text);
    border-bottom: 1px solid rgba(226, 232, 240, .65);
}

.mobile-menu__nav > a:hover {
    color: var(--color-primary);
}

.mobile-lang-card {
    display: grid;
    grid-template-columns: 46px 1fr;
    gap: .85rem;
    align-items: start;
    padding: 1rem;
    border-radius: 18px;
    background: linear-gradient(180deg, rgba(0,59,142,.04) 0%, rgba(0,59,142,.08) 100%);
    border: 1px solid rgba(0, 59, 142, .08);
    margin-bottom: .9rem;
}

.mobile-lang-card__icon {
    width: 46px;
    height: 46px;
    display: grid;
    place-items: center;
    border-radius: 14px;
    background: #fff;
    color: var(--color-primary);
    box-shadow: 0 8px 20px rgba(15, 23, 42, .06);
    font-size: 1.1rem;
}

.mobile-lang-card__content strong {
    display: block;
    font-size: .96rem;
    color: var(--color-primary-700);
    margin-bottom: .15rem;
}

.mobile-lang-card__content span {
    display: block;
    color: var(--color-text-soft);
    font-size: .88rem;
    line-height: 1.35;
}

.mobile-lang-switch {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .75rem;
    margin-bottom: 1rem;
}

.mobile-lang-switch__option {
    display: flex;
    flex-direction: column;
    gap: .2rem;
    padding: .85rem .9rem;
    border-radius: 16px;
    border: 1px solid var(--color-border);
    background: #fff;
    color: var(--color-text);
    box-shadow: 0 8px 18px rgba(15, 23, 42, .04);
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.mobile-lang-switch__option:hover {
    transform: translateY(-1px);
    border-color: rgba(0, 59, 142, .18);
    box-shadow: 0 12px 22px rgba(15, 23, 42, .08);
}

.mobile-lang-switch__option.is-active {
    border-color: rgba(0, 59, 142, .22);
    background: rgba(0, 59, 142, .05);
}

.mobile-lang-switch__label {
    font-weight: 800;
    color: var(--color-primary-700);
}

.mobile-lang-switch__option small {
    color: var(--color-text-soft);
    font-weight: 600;
}

.mobile-search-trigger {
    font-weight: 700;
}

.mobile-auth {
    display: grid;
    gap: .65rem;
}

.mobile-user-card {
    display: grid;
    grid-template-columns: 46px 1fr auto;
    gap: .85rem;
    align-items: center;
    padding: 1rem;
    border-radius: 18px;
    background: #fff;
    border: 1px solid rgba(148,163,184,.2);
    box-shadow: 0 10px 22px rgba(15,23,42,.06);
}

.mobile-user-card__avatar {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, var(--color-primary), #2a66c7);
    color: #fff;
    font-size: 1.05rem;
}

.mobile-user-card__content {
    display: flex;
    flex-direction: column;
    line-height: 1.1;
}

.mobile-user-card__content strong {
    color: var(--color-primary-700);
    font-size: .98rem;
}

.mobile-user-card__content small {
    color: var(--color-text-soft);
    font-size: .8rem;
}

.mobile-submenu {
    border-bottom: 1px solid rgba(226, 232, 240, .65);
}

.mobile-submenu-toggle {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    padding: .85rem .25rem;
    border: 0;
    background: transparent;
    color: var(--color-text);
    font-weight: 700;
    text-align: left;
}

.mobile-submenu-toggle i {
    transition: transform .22s ease;
    color: var(--color-primary);
}

.mobile-submenu-toggle.is-open i {
    transform: rotate(180deg);
}

.mobile-submenu-panel {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows .25s ease;
}

.mobile-submenu-panel.is-open {
    grid-template-rows: 1fr;
}

.mobile-submenu-panel__inner {
    overflow: hidden;
    display: grid;
    gap: .15rem;
    padding-left: .85rem;
    padding-bottom: .6rem;
}

.mobile-submenu-panel__inner a {
    display: block;
    padding: .7rem .25rem;
    color: var(--color-text-soft);
    font-weight: 600;
    border-bottom: 0;
}

.mobile-submenu-panel__inner a:hover {
    color: var(--color-primary);
}

/* SEARCH MODAL */
.portal-search-modal__content {
    border: 1px solid rgba(226,232,240,.95);
    border-radius: 24px;
    box-shadow: 0 24px 60px rgba(15,23,42,.16);
    overflow: hidden;
}

.portal-search-modal__header {
    border-bottom: 1px solid rgba(226,232,240,.8);
    padding: 1.15rem 1.25rem;
}

.portal-search-modal__subtitle {
    color: var(--color-text-soft);
    font-size: .92rem;
}

.portal-search-form {
    display: grid;
    gap: 1rem;
}

.portal-search-form__field {
    position: relative;
}

.portal-search-form__field i {
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-text-soft);
    font-size: 1rem;
}

.portal-search-form__field input {
    min-height: 58px;
    padding-left: 2.8rem;
    border-radius: 18px;
    border: 1px solid var(--color-border);
    box-shadow: none;
}

.portal-search-form__field input:focus {
    border-color: rgba(0,59,142,.22);
    box-shadow: 0 0 0 .2rem rgba(0,59,142,.08);
}

.portal-search-form__actions {
    display: flex;
    justify-content: flex-end;
}

.portal-search-quick {
    margin-top: 1.25rem;
}

.portal-search-quick__label {
    display: block;
    font-size: .82rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--color-danger);
    margin-bottom: .75rem;
}

.portal-search-quick__chips {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
}

.search-quick-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    min-height: 46px;
    padding: .75rem 1rem;
    border-radius: var(--radius-pill);
    background: rgba(0,59,142,.06);
    color: var(--color-text);
    font-weight: 700;
    box-shadow: var(--shadow-sm);
    transition: transform .2s ease, box-shadow .2s ease, background-color .2s ease;
}

.search-quick-chip:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
    background: rgba(0,59,142,.1);
}

/* FOOTER */
.site-footer {
    background: var(--color-primary-900);
    color: rgba(255,255,255,.9);
    padding: 3rem 0 1.5rem;
}

.footer-brand {
    display: flex;
    gap: .9rem;
    align-items: start;
}

.footer-brand img {
    width: 56px;
    height: 56px;
    object-fit: contain;
}

.footer-brand strong {
    display: block;
    color: #fff;
    margin-bottom: .3rem;
}

.footer-brand p {
    margin: 0;
    color: rgba(255,255,255,.72);
    font-size: var(--text-sm);
}

.footer-title {
    font-size: .92rem;
    font-weight: 800;
    color: #fff;
    margin-bottom: .8rem;
}

.footer-links {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: .45rem;
}

.footer-links a {
    color: rgba(255,255,255,.72);
}

.footer-link-disabled {
    color: rgba(255,255,255,.42);
    cursor: not-allowed;
}

.footer-links a:hover {
    color: #fff;
}

.site-footer__bottom {
    border-top: 1px solid rgba(255,255,255,.12);
    margin-top: 2rem;
    padding-top: 1rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: .75rem;
    font-size: var(--text-sm);
}

.site-footer__bottom p {
    margin: 0;
    color: rgba(255,255,255,.72);
}

.site-footer__legal {
    display: flex;
    gap: 1rem;
}

.site-footer__legal a {
    color: rgba(255,255,255,.72);
}

/* BACK TO TOP */
.back-to-top {
    position: fixed;
    right: 1rem;
    bottom: 1rem;
    z-index: 1030;
    width: 52px;
    height: 52px;
    border: 0;
    border-radius: 50%;
    background: var(--color-accent);
    color: var(--color-primary-900);
    box-shadow: var(--shadow-md);
    display: grid;
    place-items: center;
    font-size: 1.2rem;
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    transition: all .25s ease;
}

.back-to-top.is-visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* =========================
   RESPONSIVE - SHELL
========================= */
@media (max-width: 1599.98px) {
    .site-nav .nav-link {
        padding-inline: .54rem !important;
        font-size: .94rem;
    }

    .site-lang-btn__text {
        display: inline-flex;
    }
}

@media (max-width: 1439.98px) {
    .site-brand {
        max-width: 190px;
    }

    .site-brand__text small {
        padding-top: 1px;
    }

    .site-nav .nav-link {
        padding-inline: .46rem !important;
        font-size: .9rem;
    }

    .site-auth-btn--ghost span {
        display: none;
    }

    .site-auth-btn--ghost {
        min-width: 46px;
        padding-inline: .9rem;
    }

    .site-auth-btn--primary {
        padding-inline: 1rem;
    }

    .site-user-chip__text strong {
        max-width: 100px;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .site-user-chip__text small {
        display: none;
    }
}

@media (max-width: 1399.98px) {
    .site-mega-menu {
        width: min(980px, calc(100vw - 2rem));
    }

    .site-mega-menu--experiences {
        width: min(1120px, calc(100vw - 2rem));
    }

    .experience-province-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 1279.98px) {
    .site-nav .nav-link {
        padding-inline: .4rem !important;
        font-size: .88rem;
    }

    .site-auth-btn--primary span {
        display: none;
    }

    .site-auth-btn--primary {
        min-width: 46px;
        padding-inline: .9rem;
    }
}

@media (max-width: 1199.98px) {
    .site-navbar {
        min-height: 76px;
    }

    .site-mega-menu {
        display: none !important;
    }
}

@media (max-width: 767.98px) {
    .site-topbar__text {
        font-size: .82rem;
        line-height: 1.35;
    }

    .site-brand__logo {
        width: 46px;
        height: 46px;
    }

    .site-footer__bottom {
        flex-direction: column;
    }

    .portal-search-form__actions {
        justify-content: stretch;
    }

    .portal-search-form__actions .btn {
        width: 100%;
    }
}

/* =========================
   ACCOUNT DROPDOWN / COMMUNITY LINKS
========================= */
.site-account-dropdown {
    position: relative;
}

.site-account-dropdown .site-user-chip {
    appearance: none;
    border: 1px solid rgba(148, 163, 184, .24);
    cursor: pointer;
}

.site-account-dropdown .site-user-chip.dropdown-toggle::after {
    display: none;
}

.site-account-menu {
    min-width: 260px;
    padding: .55rem;
    border: 1px solid rgba(226, 232, 240, .95);
    border-radius: 18px;
    box-shadow: 0 22px 60px rgba(15, 23, 42, .14);
}

.site-account-menu__item {
    width: 100%;
    min-height: 46px;
    display: flex;
    align-items: center;
    gap: .72rem;
    padding: .75rem .85rem;
    border: 0;
    border-radius: 13px;
    background: transparent;
    color: var(--color-text);
    font-weight: 700;
    text-align: left;
    transition: background-color .2s ease, color .2s ease, transform .2s ease;
}

.site-account-menu__item i {
    color: var(--color-primary);
    font-size: 1rem;
}

.site-account-menu__item:hover,
.site-account-menu__item:focus {
    background: rgba(0, 59, 142, .06);
    color: var(--color-primary-700);
    transform: translateY(-1px);
}

.site-account-menu__button {
    cursor: pointer;
}

.site-account-menu__form {
    margin: 0;
}

.site-account-menu__divider {
    height: 1px;
    margin: .4rem .25rem;
    background: rgba(226, 232, 240, .95);
}

.mobile-user-host {
    position: relative;
}

.mobile-account-links {
    display: grid;
    gap: .55rem;
    margin-top: .8rem;
}

.mobile-account-link {
    min-height: 46px;
    display: flex;
    align-items: center;
    gap: .7rem;
    padding: .76rem .95rem;
    border-radius: 16px;
    background: #fff;
    border: 1px solid rgba(148, 163, 184, .2);
    color: var(--color-primary-700);
    font-weight: 800;
    box-shadow: 0 8px 18px rgba(15, 23, 42, .04);
    transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.mobile-account-link i {
    color: var(--color-danger);
}

.mobile-account-link:hover,
.mobile-account-link:focus {
    transform: translateY(-1px);
    border-color: rgba(0, 59, 142, .18);
    box-shadow: 0 12px 22px rgba(15, 23, 42, .08);
}

