/* ============================================================
   Annora Ceylon — template-header.css v4.1
   DARK THEME · Ceylon Midnight Obsidian + Antique Gold
   Prefix: tt-

   v4.1 — Full main.css token alignment:
   ✓ All z-index → var(--z-index-*)
   ✓ All shadows → var(--shadow-*) / var(--glow-*)
   ✓ All transitions → var(--transition-*)
   ✓ All border-radius → var(--radius-*)
   ✓ All container widths → var(--container-wide)
   ✓ All header heights → var(--header-height-nav / scrolled)
   ✓ All font-sizes → var(--text-*) scale
   ✓ All spacing → var(--spacing-*)
   ✓ Zero hardcoded hex, px sizes, or raw rgba() where a token exists
   ✓ Dropdown hover bug fix preserved
   ✓ Mobile drawer fully dark
   ============================================================ */

/* ── ANNOUNCEMENT BAR ──────────────────────────────────────── */
.tt-ann-bar {
    position: relative;
    background: var(--color-navy-abyss);
    overflow: hidden;
    height: 32px;
    display: flex;
    align-items: center;
    z-index: var(--z-index-fixed);
    border-bottom: none;
}
.tt-ann-bar.ann-hidden {
    height: 0;
    opacity: 0;
    pointer-events: none;
    overflow: hidden;
    transition: height var(--transition-slow), opacity var(--transition-slow);
}
.tt-ann-bar::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent 0%, var(--color-gold-bg) 50%, transparent 100%);
    pointer-events: none;
}

.tt-ann-track-wrap {
    flex: 1;
    overflow: hidden;
    height: 100%;
    display: flex;
    align-items: center;
    -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%);
    mask-image: linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%);
}
.tt-ann-track {
    display: flex;
    align-items: center;
    white-space: nowrap;
    animation: ttAnnScroll 120s linear infinite;
    will-change: transform;
}
.tt-ann-bar:hover .tt-ann-track { animation-play-state: paused; }
@keyframes ttAnnScroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
.tt-ann-item {
    font-family: var(--font-primary);
    font-size: var(--text-xs);
    font-weight: var(--fw-medium);
    letter-spacing: var(--ls-wide);
    color: var(--color-white-60);
    padding: 0 var(--spacing-5);
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-1-5);
}
.tt-ann-item i { color: var(--color-gold); font-size: 9px; }
.tt-ann-sep { color: var(--color-gold-glow); font-size: 5px; }
.tt-ann-close {
    flex-shrink: 0;
    background: none;
    border: none;
    color: var(--color-white-30);
    font-size: var(--text-xs);
    cursor: pointer;
    padding: 0 var(--spacing-3);
    height: 100%;
    transition: color var(--transition-fast);
}
.tt-ann-close:hover { color: var(--color-gold); }

/* ── TOP UTILITY BAR ────────────────────────────────────────── */
.tt-topbar {
    background: var(--color-navy-abyss);
    border-bottom: none;
    height: 40px;
    display: flex;
    align-items: center;
    position: sticky;
    top: 0;
    z-index: var(--z-index-max);
    transition: height var(--transition-base), opacity var(--transition-base);
}
.tt-topbar.topbar-hidden {
    height: 0;
    opacity: 0;
    overflow: hidden;
    pointer-events: none;
}
.tt-topbar-inner {
    width: 100%;
    max-width: var(--container-wide);
    margin: 0 auto;
    padding: 0 clamp(var(--spacing-4), 4vw, var(--spacing-14));
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--spacing-2-5);
}
.tt-topbar-left,
.tt-topbar-right { display: flex; align-items: center; gap: var(--spacing-1); }

.tt-topbar-link {
    display: flex;
    align-items: center;
    gap: var(--spacing-1-5);
    font-family: var(--font-primary);
    font-size: var(--text-xs);
    font-weight: var(--fw-regular);
    color: var(--color-white-60);
    text-decoration: none;
    padding: var(--spacing-0-5) var(--spacing-1-5);
    border-radius: var(--radius-sm);
    transition: color var(--transition-fast), background var(--transition-fast);
    white-space: nowrap;
}
.tt-topbar-link i { font-size: 10px; color: var(--color-gold); opacity: 0.8; }
.tt-topbar-link:hover {
    color: var(--color-gold-light);
    background: var(--color-gold-bg);
}

/* WhatsApp special link */
.tt-topbar-wa {
    padding: var(--spacing-0-5) var(--spacing-2-5);
    border-radius: var(--radius-full);
    border: 1px solid rgba(37, 211, 102, 0.22);
    transition: background var(--transition-fast), border-color var(--transition-fast);
}
.tt-topbar-wa i  { color: var(--wa-green) !important; font-size: 12px !important; opacity: 1 !important; }
.tt-topbar-wa span { color: var(--color-white-65); font-size: var(--text-xs); }
.tt-topbar-wa:hover { background: rgba(37, 211, 102, 0.10); border-color: rgba(37, 211, 102, 0.45); }
.tt-topbar-wa:hover,
.tt-topbar-wa:hover span { color: var(--wa-green); }

.tt-topbar-sep {
    width: 1px;
    height: 13px;
    background: var(--border-light);
    flex-shrink: 0;
    margin: 0 var(--spacing-0-5);
}
.tt-topbar-hours {
    display: flex;
    align-items: center;
    gap: var(--spacing-1-5);
    font-family: var(--font-primary);
    font-size: var(--text-xs);
    color: var(--color-white-40);
}
.tt-topbar-hours i { font-size: 9px; color: var(--color-gold); }

.tt-topbar-socials { display: flex; align-items: center; gap: 1px; }
.tt-topbar-social {
    width: 22px; height: 22px;
    display: flex; align-items: center; justify-content: center;
    font-size: 10px;
    color: var(--color-white-35);
    text-decoration: none;
    border-radius: var(--radius-sm);
    transition: color var(--transition-fast), background var(--transition-fast);
}
.tt-topbar-social:hover { color: var(--color-gold); background: var(--color-gold-bg); }

.tt-topbar-badge {
    display: flex;
    align-items: center;
    gap: var(--spacing-1);
    font-family: var(--font-primary);
    font-size: var(--text-xs);
    font-weight: var(--fw-bold);
    color: var(--color-gold);
    letter-spacing: var(--ls-wider);
    text-transform: uppercase;
    padding: var(--spacing-0-5) var(--spacing-1-5);
    border-radius: var(--radius-sm);
    background: var(--color-gold-bg);
    border: 1px solid var(--border-gold);
    white-space: nowrap;
}
.tt-topbar-badge i { font-size: 8px; }

/* ── LANGUAGE SELECTOR ──────────────────────────────────────── */
.tt-lang-wrapper { position: relative; }
.tt-lang-trigger {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-1-5);
    background: var(--color-white-08);
    border: 1px solid var(--color-white-12);
    border-radius: var(--radius-full);
    padding: var(--spacing-0-5) var(--spacing-2-5);
    font-family: var(--font-primary);
    font-size: var(--text-xs);
    font-weight: var(--fw-medium);
    color: var(--color-white-60);
    cursor: pointer;
    transition: var(--transition-fast);
    white-space: nowrap;
    line-height: 1;
}
.tt-lang-trigger:hover,
.tt-lang-wrapper.lang-open .tt-lang-trigger {
    background: var(--color-gold);
    border-color: var(--color-gold);
    color: var(--color-navy-deep);
}
.tt-lang-trigger i:first-child { font-size: 9px; color: var(--color-gold); }
.tt-lang-trigger:hover i:first-child,
.tt-lang-wrapper.lang-open .tt-lang-trigger i:first-child { color: var(--color-navy-deep); }
.tt-lang-chevron { font-size: 7px !important; transition: transform var(--transition-fast); color: var(--color-white-30); }
.tt-lang-wrapper.lang-open .tt-lang-chevron { transform: rotate(180deg); }

.tt-lang-dropdown {
    position: absolute;
    top: calc(100% + var(--spacing-1-5));
    right: 0;
    width: 240px;
    background: var(--color-navy-abyss);
    border: 1px solid var(--border-gold);
    border-top: 2px solid var(--color-gold);
    border-radius: 0 0 var(--radius-lg) var(--radius-lg);
    box-shadow: var(--shadow-2xl);
    z-index: var(--z-index-max);
    opacity: 0;
    visibility: hidden;
    transform: translateY(calc(-1 * var(--spacing-1)));
    transition: var(--transition-base);
    overflow: hidden;
}
.tt-lang-dropdown.lang-open { opacity: 1; visibility: visible; transform: translateY(0); }
.tt-lang-dropdown-inner { padding: var(--spacing-2); }
.tt-lang-search-wrap {
    display: flex;
    align-items: center;
    gap: var(--spacing-1-5);
    background: var(--color-white-08);
    border: 1px solid var(--color-white-10);
    border-radius: var(--radius-md);
    padding: var(--spacing-1-5) var(--spacing-2);
    margin-bottom: var(--spacing-1);
}
.tt-lang-search-wrap i { font-size: 9px; color: var(--color-gold); flex-shrink: 0; }
.tt-lang-search {
    border: none;
    background: transparent;
    outline: none;
    font-family: var(--font-primary);
    font-size: var(--text-sm);
    color: var(--color-white-80);
    width: 100%;
}
.tt-lang-search::placeholder { color: var(--color-white-30); }
.tt-lang-list {
    max-height: 220px;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--color-white-18) transparent;
}
.tt-lang-list::-webkit-scrollbar { width: 3px; }
.tt-lang-list::-webkit-scrollbar-thumb { background: var(--color-white-18); border-radius: var(--radius-full); }
.tt-lang-option {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    padding: var(--spacing-1-5) var(--spacing-2);
    border-radius: var(--radius-md);
    font-family: var(--font-primary);
    font-size: var(--text-sm);
    color: var(--color-white-60);
    cursor: pointer;
    border-left: 2px solid transparent;
    transition: var(--transition-fast);
}
.tt-lang-option:hover {
    background: var(--color-white-08);
    color: var(--color-white);
    border-left-color: var(--color-gold);
    padding-left: var(--spacing-3);
}
.tt-lang-option.lang-active { color: var(--color-gold); font-weight: var(--fw-semibold); border-left-color: var(--color-gold); }
.tt-lang-option .tt-lang-flag { font-size: 0.95rem; line-height: 1; flex-shrink: 0; }
.tt-lang-option.lang-hidden { display: none; }

/* Mobile language selector */
.tt-mob-lang-wrap { padding: 0 var(--spacing-4) var(--spacing-5); }
.tt-mob-lang-label {
    display: flex;
    align-items: center;
    gap: var(--spacing-1-5);
    font-family: var(--font-primary);
    font-size: var(--text-xs);
    font-weight: var(--fw-bold);
    color: var(--color-white-40);
    text-transform: uppercase;
    letter-spacing: var(--ls-wider);
    margin-bottom: var(--spacing-2);
}
.tt-mob-lang-label i { color: var(--color-gold); }
.tt-mob-lang-select {
    width: 100%;
    padding: var(--spacing-2) var(--spacing-3);
    border: 1px solid var(--border-gold);
    border-radius: var(--radius-md);
    font-family: var(--font-primary);
    font-size: var(--text-sm);
    color: var(--color-white-80);
    background: var(--color-navy-mid);
    cursor: pointer;
    outline: none;
    transition: border-color var(--transition-fast);
}
.tt-mob-lang-select:focus { border-color: var(--color-gold); }

.tt-header {
    position: sticky;
    top: 40px;
    z-index: var(--z-index-sticky);
    background: transparent;
}

.tt-navbar {
    background: var(--color-navy-abyss);
    border-bottom: 1px solid var(--border-gold);
    box-shadow: var(--shadow-md);
    transition: background var(--transition-slow), box-shadow var(--transition-slow);
    position: relative;
}
/* Thin gold separator between topbar and navbar */
.tt-navbar::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg,
        transparent 0%,
        rgba(var(--color-gold-rgb), 0.20) 30%,
        rgba(var(--color-gold-rgb), 0.35) 50%,
        rgba(var(--color-gold-rgb), 0.20) 70%,
        transparent 100%);
}
.tt-navbar.navbar-scrolled {
    background: var(--color-navy-deep);
    box-shadow: var(--shadow-xl);
    border-bottom-color: var(--border-gold);
}
/* Gold underline — appears on scroll */
.tt-navbar::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg,
        transparent 0%,
        var(--color-gold-glow) 30%,
        var(--color-gold) 50%,
        var(--color-gold-glow) 70%,
        transparent 100%);
    opacity: 0;
    transition: opacity var(--transition-slow);
}
.tt-navbar.navbar-scrolled::after { opacity: 1; }

.tt-navbar-inner {
    width: 100%;
    max-width: var(--container-wide);
    margin: 0 auto;
    padding: 0 clamp(var(--spacing-4), 4vw, var(--spacing-14));
    display: flex;
    align-items: center;
    gap: var(--spacing-4);
    height: var(--header-height-nav);
    transition: height var(--transition-base);
}
.tt-navbar.navbar-scrolled .tt-navbar-inner { height: var(--header-height-scrolled); }

/* ── BRAND ──────────────────────────────────────────────────── */
.tt-brand {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
    text-decoration: none;
    flex-shrink: 0;
    transition: opacity var(--transition-fast);
}
.tt-brand:hover { opacity: 0.90; }
.tt-brand-logo-wrap {
    width: 58px; height: 58px;
    border-radius: var(--radius-md);
    overflow: hidden;
    flex-shrink: 0;
}
.tt-brand-logo { width: 100%; height: 100%; object-fit: contain; display: block; }
.tt-brand-text { display: flex; flex-direction: column; line-height: var(--leading-tight); gap: 4px; }
.tt-brand-name {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: var(--fw-bold);
    color: var(--color-white-95);
    letter-spacing: var(--ls-tight);
    transition: color var(--transition-fast);
}
.tt-brand-tagline {
    font-family: var(--font-elegant);
    font-size: 11px;
    font-weight: var(--fw-medium);
    font-style: italic;
    color: var(--color-gold);
    letter-spacing: var(--ls-wide);
    opacity: 0.90;
}
.tt-brand:hover .tt-brand-name { color: var(--color-gold-light); }

/* ── NAV LIST ───────────────────────────────────────────────── */
.tt-nav-list {
    display: flex;
    align-items: center;
    list-style: none;
    margin: 0; padding: 0;
    flex: 1;
    justify-content: center;
}
.tt-nav-item { position: relative; }
.tt-nav-link {
    display: flex;
    align-items: center;
    gap: var(--spacing-1);
    padding: var(--spacing-2) var(--spacing-3);
    font-family: var(--font-primary);
    font-size: var(--text-sm);
    font-weight: var(--fw-medium);
    color: var(--color-white-75);
    text-decoration: none;
    border-radius: var(--radius-md);
    transition: color var(--transition-fast), background var(--transition-fast);
    white-space: nowrap;
    cursor: pointer;
    background: none;
    border: none;
    line-height: var(--leading-snug);
    letter-spacing: var(--ls-normal);
    position: relative;
}
.tt-nav-link::after {
    content: '';
    position: absolute;
    bottom: var(--spacing-0-5); left: var(--spacing-3); right: var(--spacing-3);
    height: 1.5px;
    background: var(--color-gold);
    transform: scaleX(0);
    transform-origin: center;
    transition: transform var(--transition-elegant);
    border-radius: var(--radius-xs);
}
.tt-nav-link:hover,
.tt-nav-link:focus {
    color: var(--color-white-95);
    background: var(--color-gold-bg-hover);
}
.tt-nav-link:hover::after { transform: scaleX(1); }
.tt-nav-link.active {
    color: var(--color-gold-light);
    font-weight: var(--fw-semibold);
    background: var(--color-gold-bg-hover);
}
.tt-nav-link.active::after,
.tt-nav-link[aria-current="page"]::after { transform: scaleX(1); }

.tt-nav-arrow {
    font-size: 8px;
    color: var(--color-white-30);
    transition: transform var(--transition-elegant), color var(--transition-fast);
    margin-top: 1px;
}
.tt-dropdown-parent.is-open .tt-nav-arrow,
.tt-mega-parent.is-open .tt-nav-arrow {
    transform: rotate(-180deg);
    color: var(--color-gold);
}

/* ── BOOK NOW BUTTON ────────────────────────────────────────── */
.tt-book-btn {
    display: flex;
    align-items: center;
    gap: var(--spacing-1-5);
    padding: var(--spacing-2-5) var(--spacing-5);
    background: var(--gradient-gold);
    color: var(--color-navy-deep);
    font-family: var(--font-primary);
    font-size: var(--text-sm);
    font-weight: var(--fw-bold);
    text-decoration: none;
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-gold);
    transition: var(--transition-elegant);
    flex-shrink: 0;
    white-space: nowrap;
    letter-spacing: var(--ls-normal);
}
.tt-book-icon { font-size: 12px; }
.tt-book-btn:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-gold-lg);
    filter: brightness(1.05);
    color: var(--color-navy-deep);
    text-decoration: none;
    background: var(--gradient-gold-hover);
}
.tt-book-btn:active { transform: translateY(0); }

/* ═══════════════════════════════════════════════════════════════
   DROPDOWNS — STICKY HOVER BUG FIX PRESERVED
   280ms close delay + bridge ::before on both dropdown and panel
   ═══════════════════════════════════════════════════════════════ */
.tt-dropdown {
    position: absolute;
    top: calc(100% + var(--spacing-2));
    left: 50%;
    transform: translateX(-50%) translateY(calc(-1 * var(--spacing-2)));
    min-width: 252px;
    background: var(--color-navy-abyss);
    border: 1px solid var(--border-gold);
    border-top: 2px solid var(--color-gold);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-premium);
    list-style: none;
    margin: 0; padding: var(--spacing-1);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
        opacity var(--transition-elegant),
        transform var(--transition-elegant),
        visibility var(--transition-elegant);
    z-index: var(--z-index-dropdown);
}
/* Bridge — lets mouse travel gap without triggering mouseleave */
.tt-dropdown::before {
    content: '';
    position: absolute;
    bottom: 100%;
    left: 0; right: 0;
    height: 16px;
    background: transparent;
}
/* Gold arrow pointer */
.tt-dropdown::after {
    content: '';
    position: absolute;
    top: -7px;
    left: 50%;
    transform: translateX(-50%);
    width: 11px; height: 6px;
    background: var(--color-gold);
    clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
}
.tt-dropdown-parent.is-open .tt-dropdown {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
}

.tt-dd-link {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    padding: var(--spacing-2) var(--spacing-3);
    font-family: var(--font-primary);
    font-size: var(--text-sm);
    font-weight: var(--fw-regular);
    color: var(--color-white-75);
    text-decoration: none;
    border-radius: var(--radius-md);
    transition: var(--transition-fast);
    letter-spacing: var(--ls-normal);
}
.tt-dd-link i {
    width: 16px;
    text-align: center;
    font-size: 11px;
    color: var(--color-gold);
    opacity: 0.60;
    transition: opacity var(--transition-fast), transform var(--transition-fast);
    flex-shrink: 0;
}
.tt-dd-link:hover {
    background: var(--color-gold-bg-hover);
    color: var(--color-gold-light);
    padding-left: var(--spacing-4);
}
.tt-dd-link:hover i { opacity: 1; transform: scale(1.1); }
.tt-dd-green i { color: var(--color-green-light) !important; opacity: 1 !important; }
.tt-dd-divider {
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--border-gold), transparent);
    margin: var(--spacing-1) var(--spacing-1-5);
}

/* ── MEGA MENU ──────────────────────────────────────────────── */
.tt-mega-menu {
    position: absolute;
    top: calc(100% + var(--spacing-2));
    left: 50%;
    transform: translateX(-50%) translateY(calc(-1 * var(--spacing-2)));
    width: min(94vw, 1080px);
    background: var(--color-navy-abyss);
    border: 1px solid var(--border-gold);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-2xl);
    visibility: hidden;
    pointer-events: none;
    transition:
        opacity var(--transition-premium),
        transform var(--transition-premium),
        visibility var(--transition-premium);
    z-index: var(--z-index-dropdown);
    overflow: hidden;
}
/* Gold top stripe */
.tt-mega-menu::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: var(--gradient-gold);
}
/* Bridge — same pattern as dropdown */
.tt-mega-menu::after {
    content: '';
    position: absolute;
    bottom: 100%;
    left: 0; right: 0;
    height: 16px;
    background: transparent;
}
.tt-mega-parent.is-open .tt-mega-menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
}

.tt-mega-inner { padding: var(--spacing-6) var(--spacing-6) var(--spacing-5); }

.tt-mega-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: var(--spacing-5);
    padding-bottom: var(--spacing-4);
    border-bottom: 1px solid var(--border-gold);
}
.tt-mega-eyebrow {
    display: block;
    font-family: var(--font-primary);
    font-size: var(--text-xs);
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-widest);
    text-transform: uppercase;
    color: var(--color-gold);
    margin-bottom: var(--spacing-1);
}
.tt-mega-title {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: var(--fw-bold);
    color: var(--color-white-95);
    margin: 0 0 var(--spacing-0-5);
    line-height: var(--leading-tight);
}
.tt-mega-sub {
    font-family: var(--font-primary);
    font-size: var(--text-sm);
    color: var(--color-white-50);
    margin: 0;
}
.tt-mega-view-all {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-1-5);
    padding: var(--spacing-2) var(--spacing-4);
    background: var(--gradient-gold);
    color: var(--color-navy-deep);
    font-family: var(--font-primary);
    font-size: var(--text-sm);
    font-weight: var(--fw-bold);
    text-decoration: none;
    border-radius: var(--radius-md);
    white-space: nowrap;
    transition: var(--transition-elegant);
    flex-shrink: 0;
    box-shadow: var(--shadow-gold);
    letter-spacing: var(--ls-normal);
}
.tt-mega-view-all:hover {
    transform: translateX(2px) translateY(-1px);
    box-shadow: var(--shadow-gold-lg);
    color: var(--color-navy-deep);
    background: var(--gradient-gold-hover);
}

/* 4-column grid */
.tt-mega-grid { display: grid; grid-template-columns: 1.2fr 1fr 0.85fr 0.95fr; gap: 0; align-items: start; }
.tt-mega-col { padding: 0 var(--spacing-5); border-right: 1px solid var(--color-gold-glow-sm); }
.tt-mega-col:first-child { padding-left: 0; }
.tt-mega-col:last-child  { border-right: none; padding-right: 0; }

.tt-mega-col-label {
    display: flex;
    align-items: center;
    gap: var(--spacing-1-5);
    font-family: var(--font-primary);
    font-size: var(--text-xs);
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-wider);
    text-transform: uppercase;
    color: var(--color-gold);
    margin-bottom: var(--spacing-2-5);
    padding-bottom: var(--spacing-2);
    border-bottom: 1px solid var(--border-gold);
    flex-wrap: wrap;
}
.tt-mega-col-label-second {
    margin-top: var(--spacing-4);
    margin-bottom: var(--spacing-2);
}
.tt-mega-col-icon { font-size: 13px; }
.tt-mega-col-season {
    margin-left: auto;
    font-size: var(--text-xs);
    font-weight: var(--fw-medium);
    letter-spacing: var(--ls-normal);
    color: var(--color-white-40);
    background: var(--color-white-05);
    padding: 2px var(--spacing-1-5);
    border-radius: var(--radius-full);
    text-transform: none;
}

/* Package links */
.tt-mega-pkg-list { list-style: none; margin: 0; padding: 0; }
.tt-mega-pkg-link {
    display: flex;
    flex-direction: column;
    gap: 1px;
    padding: var(--spacing-1-5) var(--spacing-2);
    border-radius: var(--radius-md);
    text-decoration: none;
    border-left: 2px solid transparent;
    transition: background var(--transition-fast), border-color var(--transition-fast), padding-left var(--transition-fast);
    margin-bottom: 1px;
}
.tt-mega-pkg-link:hover {
    background: var(--color-gold-bg-hover);
    border-left-color: var(--color-gold);
    padding-left: var(--spacing-3);
}
.tt-pkg-code {
    font-family: var(--font-primary);
    font-size: var(--text-xs);
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-wider);
    color: var(--color-gold);
    opacity: 0.70;
    text-transform: uppercase;
}
.tt-mega-pkg-link:hover .tt-pkg-code { opacity: 1; }
.tt-pkg-title {
    font-family: var(--font-primary);
    font-size: var(--text-sm);
    font-weight: var(--fw-medium);
    color: var(--color-white-75);
    line-height: var(--leading-snug);
    transition: color var(--transition-fast);
}
.tt-mega-pkg-link:hover .tt-pkg-title { color: var(--color-gold-light); }
.tt-pkg-meta {
    font-family: var(--font-primary);
    font-size: var(--text-xs);
    color: var(--color-white-35);
    display: flex;
    align-items: center;
    gap: var(--spacing-1);
}
.tt-pkg-meta i { font-size: 9px; }

.tt-mega-col-more {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-1);
    margin-top: var(--spacing-2);
    font-family: var(--font-primary);
    font-size: var(--text-sm);
    font-weight: var(--fw-semibold);
    color: var(--color-gold);
    text-decoration: none;
    opacity: 0.72;
    transition: gap var(--transition-fast), opacity var(--transition-fast);
}
.tt-mega-col-more:hover { gap: var(--spacing-2); opacity: 1; color: var(--color-gold-light); }
.tt-mega-col-more i { font-size: 9px; }

/* Browse by type list */
.tt-mega-type-list { list-style: none; margin: 0; padding: 0; }
.tt-mega-type-link {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
    padding: var(--spacing-1-5) var(--spacing-2);
    border-radius: var(--radius-md);
    font-family: var(--font-primary);
    font-size: var(--text-sm);
    color: var(--color-white-65);
    text-decoration: none;
    border-left: 2px solid transparent;
    transition: var(--transition-fast);
    margin-bottom: 1px;
}
.tt-mega-type-link i { font-size: 11px; color: var(--color-gold); opacity: 0.55; width: 14px; text-align: center; transition: opacity var(--transition-fast); }
.tt-mega-type-link:hover {
    background: var(--color-gold-bg);
    color: var(--color-gold-light);
    border-left-color: var(--color-gold);
    padding-left: var(--spacing-3);
}
.tt-mega-type-link:hover i { opacity: 1; }

/* Mega menu CTA card */
.tt-mega-cta-card {
    position: relative;
    padding: var(--spacing-4);
    background: var(--gradient-card);
    border: 1px solid var(--border-gold);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-inner);
}
.tt-mega-cta-glow {
    position: absolute; top: -20px; right: -20px;
    width: 100px; height: 100px;
    background: radial-gradient(circle, var(--color-gold-glow) 0%, transparent 70%);
    pointer-events: none;
}
.tt-mega-cta-icon {
    width: 36px; height: 36px;
    display: flex; align-items: center; justify-content: center;
    background: var(--color-gold-bg-hover);
    border: 1px solid var(--border-gold);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-2-5);
    font-size: 15px;
    color: var(--color-gold-light);
}
.tt-mega-cta-eyebrow {
    display: block;
    font-family: var(--font-primary);
    font-size: var(--text-xs);
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-widest);
    text-transform: uppercase;
    color: var(--color-gold);
    margin-bottom: var(--spacing-0-5);
}
.tt-mega-cta-title {
    font-family: var(--font-display);
    font-size: var(--text-base);
    font-weight: var(--fw-bold);
    color: var(--color-white-95);
    margin: 0 0 var(--spacing-1-5);
}
.tt-mega-cta-desc {
    font-family: var(--font-primary);
    font-size: var(--text-xs);
    color: var(--color-white-55);
    margin: 0 0 var(--spacing-3);
    line-height: var(--leading-relaxed);
}
.tt-mega-cta-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-1);
    padding: var(--spacing-2) var(--spacing-3-5);
    background: var(--gradient-gold);
    color: var(--color-navy-deep);
    font-family: var(--font-primary);
    font-size: var(--text-sm);
    font-weight: var(--fw-bold);
    text-decoration: none;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-gold);
    transition: var(--transition-elegant);
    margin-bottom: var(--spacing-3);
    letter-spacing: var(--ls-normal);
}
.tt-mega-cta-btn:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-gold-lg);
    color: var(--color-navy-deep);
    background: var(--gradient-gold-hover);
}
.tt-mega-trust-row { display: flex; gap: var(--spacing-1); flex-wrap: wrap; }
.tt-mega-trust-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-1);
    padding: 2px var(--spacing-1-5);
    background: var(--color-white-05);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-full);
    font-family: var(--font-primary);
    font-size: var(--text-xs);
    font-weight: var(--fw-semibold);
    color: var(--color-white-60);
}
.tt-mega-trust-badge i { font-size: 8px; color: var(--color-gold); }

/* Best season guide card */
.tt-mega-season-guide {
    margin-top: var(--spacing-3-5);
    padding: var(--spacing-3) var(--spacing-3-5);
    background: var(--color-white-05);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-lg);
}
.tt-mega-season-title {
    font-family: var(--font-primary);
    font-size: var(--text-xs);
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-wider);
    text-transform: uppercase;
    color: var(--color-gold);
    margin-bottom: var(--spacing-2);
    display: flex;
    align-items: center;
    gap: var(--spacing-1);
}
.tt-mega-season-title i { font-size: 9px; }
.tt-mega-season-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-1-5);
    padding: var(--spacing-1) 0;
    border-bottom: 1px solid var(--border-light);
}
.tt-mega-season-item:last-child { border-bottom: none; padding-bottom: 0; }
.tt-season-flag { font-size: 13px; }
.tt-season-text { font-family: var(--font-primary); font-size: var(--text-xs); color: var(--color-white-55); }

/* ── HAMBURGER ──────────────────────────────────────────────── */
.tt-hamburger {
    display: none;
    flex-direction: column;
    justify-content: center;
    gap: var(--spacing-1);
    width: 40px; height: 40px;
    background: none;
    border: 1px solid var(--color-white-18);
    border-radius: var(--radius-md);
    cursor: pointer;
    padding: var(--spacing-2-5);
    transition: background var(--transition-fast), border-color var(--transition-fast);
    flex-shrink: 0;
}
.tt-hamburger:hover {
    background: var(--color-gold-bg);
    border-color: var(--border-gold);
}
.tt-ham-line {
    display: block;
    width: 100%; height: 1.5px;
    background: var(--color-white-75);
    border-radius: var(--radius-xs);
    transition: transform var(--transition-base), opacity var(--transition-base);
    transform-origin: center;
}
.tt-hamburger.is-open .tt-ham-1 { transform: translateY(6.5px) rotate(45deg); }
.tt-hamburger.is-open .tt-ham-2 { opacity: 0; transform: scaleX(0); }
.tt-hamburger.is-open .tt-ham-3 { transform: translateY(-6.5px) rotate(-45deg); }

/* ── MOBILE OVERLAY ─────────────────────────────────────────── */
.tt-mob-overlay {
    position: fixed; inset: 0;
    background: var(--color-dark-80);
    backdrop-filter: blur(5px);
    z-index: var(--z-index-overlay);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity var(--transition-slow), visibility var(--transition-slow);
}
.tt-mob-overlay.is-open { opacity: 1; visibility: visible; pointer-events: auto; }

/* ═══════════════════════════════════════════════════════════════
   MOBILE DRAWER — FULL DARK THEME
   ═══════════════════════════════════════════════════════════════ */
.tt-mob-drawer {
    position: fixed;
    top: 0; right: 0;
    width: min(88vw, 360px);
    height: 100dvh;
    background: var(--color-navy-abyss);
    z-index: var(--z-index-modal);
    transform: translateX(100%);
    transition: transform var(--transition-slow);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    box-shadow: var(--shadow-luxury);
    border-left: 1px solid var(--border-gold);
}
.tt-mob-drawer.is-open { transform: translateX(0); }

/* Gold left accent stripe */
.tt-mob-drawer::before {
    content: '';
    position: absolute;
    top: 0; bottom: 0; left: 0;
    width: 2px;
    background: var(--gradient-gold);
}

.tt-mob-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-4) var(--spacing-4);
    border-bottom: 1px solid var(--border-gold);
    background: var(--color-navy-deep);
    flex-shrink: 0;
}
.tt-mob-brand {
    display: flex;
    align-items: center;
    gap: var(--spacing-2-5);
    text-decoration: none;
}
.tt-mob-logo {
    width: 44px; height: 44px;
    border-radius: var(--radius-md);
    object-fit: contain;
}
.tt-mob-brand-text { display: flex; flex-direction: column; }
.tt-mob-brand-name {
    font-family: var(--font-display);
    font-size: var(--text-lg);
    font-weight: var(--fw-bold);
    color: var(--color-white-95);
    line-height: var(--leading-tight);
}
.tt-mob-brand-tagline {
    font-family: var(--font-elegant);
    font-size: var(--text-xs);
    font-style: italic;
    color: var(--color-gold);
    letter-spacing: var(--ls-wide);
}
.tt-mob-close {
    width: 32px; height: 32px;
    display: flex; align-items: center; justify-content: center;
    background: var(--color-white-05);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-md);
    color: var(--color-white-60);
    font-size: 12px;
    cursor: pointer;
    transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}
.tt-mob-close:hover {
    background: var(--color-gold-bg-hover);
    color: var(--color-gold-light);
    border-color: var(--border-gold);
}

.tt-mob-body {
    flex: 1;
    overflow-y: auto;
    padding: var(--spacing-2) 0 var(--spacing-6);
    scrollbar-width: thin;
    scrollbar-color: var(--border-gold) transparent;
}
.tt-mob-body::-webkit-scrollbar { width: 3px; }
.tt-mob-body::-webkit-scrollbar-thumb { background: var(--border-gold); border-radius: var(--radius-full); }

.tt-mob-nav { list-style: none; margin: 0; padding: 0 var(--spacing-2-5); }
.tt-mob-item { border-bottom: 1px solid var(--border-light); }
.tt-mob-item:last-child { border-bottom: none; }
.tt-mob-link {
    display: flex;
    align-items: center;
    gap: var(--spacing-2-5);
    padding: var(--spacing-3) var(--spacing-2-5);
    font-family: var(--font-primary);
    font-size: var(--text-base);
    font-weight: var(--fw-medium);
    color: var(--color-white-75);
    text-decoration: none;
    background: none;
    border: none;
    width: 100%;
    cursor: pointer;
    transition: color var(--transition-fast), background var(--transition-fast);
    border-radius: var(--radius-md);
}
.tt-mob-link i { font-size: 13px; width: 17px; text-align: center; color: var(--color-gold); opacity: 0.70; }
.tt-mob-link:hover { color: var(--color-gold-light); background: var(--color-gold-bg); }

.tt-mob-acc-trigger { display: flex; align-items: center; justify-content: space-between; }
.tt-mob-acc-trigger > span { display: flex; align-items: center; gap: var(--spacing-2-5); }
.tt-mob-arrow { font-size: 9px; color: var(--color-white-30); transition: transform var(--transition-elegant); flex-shrink: 0; }
.tt-mob-acc.is-open .tt-mob-arrow { transform: rotate(-180deg); color: var(--color-gold); }
.tt-mob-acc.is-open .tt-mob-link { color: var(--color-gold-light); }
.tt-mob-acc-body { max-height: 0; overflow: hidden; transition: max-height var(--transition-slow); }
.tt-mob-acc.is-open .tt-mob-acc-body { max-height: 1500px; }

.tt-mob-sub-link,
.tt-mob-pkg-link {
    display: block;
    padding: var(--spacing-2) var(--spacing-3-5) var(--spacing-2) var(--spacing-9);
    font-family: var(--font-primary);
    font-size: var(--text-sm);
    color: var(--color-white-55);
    text-decoration: none;
    transition: color var(--transition-fast), padding-left var(--transition-fast), background var(--transition-fast);
    border-radius: var(--radius-md);
    margin: 1px 0;
}
.tt-mob-sub-link:hover {
    color: var(--color-gold-light);
    padding-left: calc(var(--spacing-9) + var(--spacing-1));
    background: var(--color-gold-bg);
}
.tt-mob-pkg-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.tt-mob-pkg-link:hover { color: var(--color-gold-light); background: var(--color-gold-bg); }
.tt-mob-pkg-link em {
    font-style: normal;
    font-size: var(--text-xs);
    color: var(--color-gold);
    background: var(--color-gold-bg);
    border: 1px solid var(--border-gold);
    padding: 2px var(--spacing-1-5);
    border-radius: var(--radius-full);
}
.tt-mob-pkg-featured { color: var(--color-gold) !important; font-weight: var(--fw-semibold); }

.tt-mob-pkg-group { padding: var(--spacing-1) 0 var(--spacing-1-5); }
.tt-mob-pkg-label {
    padding: var(--spacing-2) var(--spacing-3-5) var(--spacing-1) var(--spacing-3-5);
    font-family: var(--font-primary);
    font-size: var(--text-xs);
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-wider);
    text-transform: uppercase;
    color: var(--color-gold);
    opacity: 0.85;
    border-top: 1px solid var(--color-gold-glow-sm);
    margin-top: var(--spacing-1);
}
.tt-mob-pkg-group:first-child .tt-mob-pkg-label { border-top: none; margin-top: 0; }

.tt-mob-view-all {
    display: flex;
    align-items: center;
    gap: var(--spacing-1-5);
    padding: var(--spacing-2-5) var(--spacing-3-5);
    font-family: var(--font-primary);
    font-size: var(--text-sm);
    font-weight: var(--fw-semibold);
    color: var(--color-gold-light);
    text-decoration: none;
    background: var(--color-gold-bg);
    border: 1px solid var(--border-gold);
    border-radius: var(--radius-md);
    margin: var(--spacing-2) var(--spacing-2-5);
    transition: background var(--transition-fast);
}
.tt-mob-view-all i { font-size: 11px; color: var(--color-gold); }
.tt-mob-view-all:hover { background: var(--color-gold-bg-hover); }

/* Mobile CTA buttons */
.tt-mob-cta-wrap { display: flex; flex-direction: column; gap: var(--spacing-2); padding: var(--spacing-3-5) var(--spacing-3-5) 0; }
.tt-mob-book-btn {
    display: flex; align-items: center; justify-content: center;
    gap: var(--spacing-1-5); padding: var(--spacing-3) var(--spacing-4);
    background: var(--gradient-gold);
    color: var(--color-navy-deep);
    font-family: var(--font-primary); font-size: var(--text-base); font-weight: var(--fw-bold);
    text-decoration: none; border-radius: var(--radius-lg);
    box-shadow: var(--shadow-gold);
    transition: var(--transition-elegant);
}
.tt-mob-book-btn:hover {
    transform: translateY(-1px);
    box-shadow: var(--shadow-gold-lg);
    color: var(--color-navy-deep);
    background: var(--gradient-gold-hover);
}
.tt-mob-wa-btn {
    display: flex; align-items: center; justify-content: center;
    gap: var(--spacing-1-5); padding: var(--spacing-2-5) var(--spacing-4);
    background: var(--gradient-green);
    color: var(--color-white);
    font-family: var(--font-primary); font-size: var(--text-sm); font-weight: var(--fw-semibold);
    text-decoration: none; border-radius: var(--radius-lg);
    transition: opacity var(--transition-fast), transform var(--transition-fast);
}
.tt-mob-wa-btn:hover { opacity: 0.90; transform: translateY(-1px); color: var(--color-white); }

/* Contact chips */
.tt-mob-contact-row { display: flex; gap: var(--spacing-2); padding: var(--spacing-3) var(--spacing-3-5) 0; }
.tt-mob-contact-chip {
    flex: 1;
    display: flex; align-items: center; justify-content: center;
    gap: var(--spacing-1-5); padding: var(--spacing-2) var(--spacing-2);
    background: var(--color-white-05);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-lg);
    font-family: var(--font-primary); font-size: var(--text-sm); font-weight: var(--fw-medium);
    color: var(--color-white-60); text-decoration: none;
    transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}
.tt-mob-contact-chip i { font-size: 12px; color: var(--color-gold); }
.tt-mob-contact-chip:hover {
    background: var(--color-gold-bg);
    color: var(--color-gold-light);
    border-color: var(--border-gold);
}

/* Trust badges row */
.tt-mob-trust-row { display: flex; flex-wrap: wrap; gap: var(--spacing-1-5); padding: var(--spacing-3) var(--spacing-3-5) 0; }
.tt-mob-trust-badge {
    display: flex; align-items: center;
    gap: var(--spacing-1); padding: var(--spacing-1) var(--spacing-2);
    background: var(--color-white-05);
    border: 1px solid var(--border-light);
    border-radius: var(--radius-full);
    font-family: var(--font-primary); font-size: var(--text-xs); font-weight: var(--fw-semibold);
    color: var(--color-white-55);
}
.tt-mob-trust-badge i { font-size: 9px; color: var(--color-gold); }

/* ── ACTIVE PAGE STATE ──────────────────────────────────────── */
.tt-nav-link.active,
.tt-nav-link[aria-current="page"] {
    color: var(--color-gold-light);
    font-weight: var(--fw-semibold);
    background: var(--color-gold-bg-hover);
}

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media (max-width: 1280px) {
    .tt-mega-menu { width: min(96vw, 920px); }
    .tt-mega-grid { grid-template-columns: 1.1fr 1fr 0.9fr 0.85fr; }
    .tt-nav-link { padding: var(--spacing-2) var(--spacing-2-5); font-size: var(--text-sm); }
}
@media (max-width: 1100px) {
    .tt-mega-grid { grid-template-columns: repeat(2, 1fr); }
    .tt-mega-col { border-right: none; padding: var(--spacing-2-5) 0; border-bottom: 1px solid var(--color-gold-glow-sm); }
    .tt-mega-col:last-child { border-bottom: none; }
    .tt-mega-col:nth-child(odd)  { padding-right: var(--spacing-4); border-right: 1px solid var(--color-gold-glow-sm); }
    .tt-mega-col:nth-child(even) { padding-left: var(--spacing-4); }
}
@media (max-width: 1024px) {
    .tt-nav-list, .tt-book-btn { display: none; }
    .tt-hamburger { display: flex; }
    .tt-topbar-hours, .tt-topbar-badge { display: none; }
    .tt-navbar-inner { height: var(--header-height-scrolled); }
}
@media (max-width: 640px) {
    .tt-topbar { display: none; }
    .tt-brand-name { font-size: var(--text-lg); }
    .tt-brand-tagline { display: none; }
    .tt-brand-logo-wrap { width: 40px; height: 40px; }
    .tt-ann-bar { height: 28px; }
}
@media (prefers-reduced-motion: reduce) {
    .tt-ann-track { animation: none; }
    .tt-dropdown,
    .tt-mega-menu,
    .tt-mob-drawer,
    .tt-mob-overlay { transition: none; }
    .tt-nav-link::after { transition: none; }
}