/* ============================================
   CSS VARIABLES
============================================ */
:root {
    --color-charcoal: #1a1a1a;
    --color-charcoal-dark: #0d0d0d;
    --color-amber: #c9a962;
    --color-amber-light: #d4b97a;
    --color-amber-glow: rgba(201, 169, 98, 0.3);
    --color-burgundy: #722f37;
    --color-burgundy-glow: rgba(114, 47, 55, 0.4);
    --font-cinzel: 'Cinzel', serif;
    --font-cormorant: 'Cormorant Garamond', serif;
    --font-montserrat: 'Montserrat', sans-serif;
    --font-playfair: 'Playfair Display', serif;
    --font-poppins: 'Poppins', sans-serif;
}

/* ============================================
   RESET & BASE
============================================ */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: var(--font-montserrat);
    background-color: #000;
    color: #e5e5e5;
    overflow-x: hidden;
    line-height: 1.6;
}

::selection {
    background: var(--color-amber);
    color: #000;
}

/* Custom Scrollbar */
::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-track {
    background: var(--color-charcoal-dark);
}

::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, var(--color-amber), var(--color-burgundy));
    border-radius: 4px;
}

/* ============================================
   LOADING SCREEN
============================================ */
#loading-screen {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    transition: opacity 1s ease, visibility 1s ease;
}

#loading-screen.hidden {
    opacity: 0;
    visibility: hidden;
}

.loading-smoke {
    position: absolute;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.loading-smoke::before,
.loading-smoke::after {
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    animation: smokeFloat 8s ease-in-out infinite;
}

.loading-smoke::before {
    background: radial-gradient(ellipse at 30% 70%, rgba(255,255,255,0.03) 0%, transparent 50%);
    animation-delay: -2s;
}

.loading-smoke::after {
    background: radial-gradient(ellipse at 70% 50%, rgba(201,169,98,0.02) 0%, transparent 40%);
}

@keyframes smokeFloat {
    0%, 100% { transform: scale(1) translate(0, 0); opacity: 0.3; }
    50% { transform: scale(1.2) translate(30px, -20px); opacity: 0.6; }
}

.loading-content {
    position: relative;
    z-index: 1;
    text-align: center;
}

.loading-logo {
    height: 80px;
    margin-bottom: 30px;
    animation: fadeInScale 1.2s ease-out forwards;
}

@keyframes fadeInScale {
    from { opacity: 0; transform: scale(0.8); }
    to { opacity: 1; transform: scale(1); }
}

.loading-title {
    font-family: var(--font-cinzel);
    font-size: 2.5rem;
    background: linear-gradient(135deg, var(--color-amber) 0%, #fff 50%, var(--color-amber) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    margin-bottom: 10px;
    animation: fadeInUp 1s ease-out 0.3s forwards;
    opacity: 0;
}

.loading-subtitle {
    font-family: var(--font-playfair);
    font-size: 1.5rem;
    font-style: italic;
    color: rgba(255,255,255,0.6);
    margin-bottom: 40px;
    animation: fadeInUp 1s ease-out 0.5s forwards;
    opacity: 0;
}

.loading-bar {
    width: 150px;
    height: 2px;
    background: rgba(255,255,255,0.1);
    position: relative;
    overflow: hidden;
    margin: 0 auto;
}

.loading-bar::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 50%;
    height: 100%;
    background: linear-gradient(90deg, transparent, var(--color-amber), transparent);
    animation: loadingSlide 1.5s linear infinite;
}

@keyframes loadingSlide {
    from { transform: translateX(-100%); }
    to { transform: translateX(300%); }
}

.loading-text {
    margin-top: 24px;
    font-family: var(--font-cormorant);
    color: rgba(255,255,255,0.4);
    letter-spacing: 0.3em;
    font-size: 14px;
    animation: fadeInUp 1s ease-out 0.7s forwards;
    opacity: 0;
}

@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ============================================
   CURSOR EFFECTS
============================================ */
.cursor-glow {
    position: fixed;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(201,169,98,0.08) 0%, rgba(114,47,55,0.04) 30%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
    z-index: 1;
    transform: translate(-50%, -50%);
    filter: blur(40px);
    transition: opacity 0.3s ease;
}

.cursor-glow-inner {
    position: fixed;
    width: 150px;
    height: 150px;
    background: radial-gradient(circle, rgba(201,169,98,0.12) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
    z-index: 2;
    transform: translate(-50%, -50%);
    filter: blur(20px);
}

.smoke-particle {
    position: fixed;
    pointer-events: none;
    border-radius: 50%;
    z-index: 3;
    animation: smokeRise 4s ease-out forwards;
}

@keyframes smokeRise {
    0% {
        opacity: 0.6;
        transform: translate(-50%, -50%) scale(0.5);
    }
    50% { opacity: 0.3; }
    100% {
        opacity: 0;
        transform: translate(-50%, calc(-50% - 150px)) scale(3);
    }
}

/* ============================================
   FLOATING EMBERS
============================================ */
.embers-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 3;
    overflow: hidden;
}

.ember {
    position: absolute;
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255,160,80,0.9) 0%, rgba(255,100,40,0.6) 40%, transparent 70%);
    box-shadow: 0 0 8px rgba(255,140,50,0.8), 0 0 16px rgba(255,100,40,0.4);
    animation: emberFloat 10s linear infinite;
}

@keyframes emberFloat {
    0% { opacity: 0; transform: translateY(0) translateX(0); }
    10% { opacity: 1; }
    90% { opacity: 1; }
    100% { opacity: 0; transform: translateY(-100vh) translateX(30px); }
}

/* ============================================
   NAVIGATION
============================================ */
.nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    padding: 24px 0;
    transition: all 0.5s ease;
}

.nav.scrolled {
    padding: 12px 0;
    background: rgba(13, 13, 13, 0.8);
    backdrop-filter: blur(30px);
    -webkit-backdrop-filter: blur(30px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.nav.hidden {
    transform: translateY(-100%);
}

.nav-container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.nav-logo-link {
    display: block;
}

.nav-logo {
    height: 48px;
    transition: transform 0.3s ease;
}

.nav-logo-link:hover .nav-logo {
    transform: scale(1.02);
}

.nav-links {
    display: flex;
    align-items: center;
    gap: 32px;
}

.nav-link {
    color: #e5e5e5;
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.05em;
    position: relative;
    transition: color 0.3s ease;
}

.nav-link::after {
    content: '';
    position: absolute;
    bottom: -4px;
    left: 0;
    width: 0;
    height: 1px;
    background: var(--color-amber);
    transition: width 0.3s ease;
}

.nav-link:hover {
    color: var(--color-amber);
}

.nav-link:hover::after {
    width: 100%;
}

.btn-primary {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: linear-gradient(135deg, var(--color-amber) 0%, #a88942 100%);
    color: #000;
    font-family: var(--font-cinzel);
    font-weight: 600;
    padding: 12px 24px;
    border: none;
    cursor: pointer;
    transition: all 0.4s ease;
    letter-spacing: 2px;
    font-size: 14px;
    text-decoration: none;
    position: relative;
    overflow: hidden;
}

.btn-primary::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
    transition: left 0.6s ease;
}

.btn-primary:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 30px rgba(201, 169, 98, 0.3);
}

.btn-primary:hover::before {
    left: 100%;
}

.btn-secondary {
    display: inline-block;
    background: transparent;
    color: var(--color-amber);
    font-family: var(--font-cinzel);
    font-weight: 500;
    padding: 16px 32px;
    border: 1px solid var(--color-amber);
    cursor: pointer;
    transition: all 0.4s ease;
    letter-spacing: 2px;
    font-size: 14px;
    text-decoration: none;
    position: relative;
    overflow: hidden;
}

.btn-secondary::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--color-amber);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.4s ease;
    z-index: -1;
}

.btn-secondary:hover {
    color: #000;
}

.btn-secondary:hover::before {
    transform: scaleX(1);
}

.mobile-menu-btn {
    display: none;
    background: none;
    border: none;
    color: #fff;
    cursor: pointer;
    padding: 8px;
}

.menu-icon-close {
    display: none;
}

.mobile-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: rgba(13, 13, 13, 0.95);
    backdrop-filter: blur(30px);
    padding: 30px;
    text-align: center;
}

.mobile-menu.active {
    display: block;
}

.mobile-menu .nav-link {
    display: block;
    padding: 15px 0;
    font-size: 18px;
}

.mobile-reserve-btn {
    margin-top: 16px;
}

@media (max-width: 768px) {
    .nav-links {
        display: none;
    }
    .mobile-menu-btn {
        display: block;
    }
}

/* ============================================
   HERO SECTION
============================================ */
.hero {
    position: relative;
    height: 100vh;
    min-height: 600px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.hero-bg {
    position: absolute;
    inset: 0;
    background: url('https://heavenworld.in/demo/img/001.png') center/cover;
    filter: brightness(0.35) contrast(1.1);
    transform-origin: center;
}

.hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(0,0,0,0.6), transparent, rgba(0,0,0,0.6));
    z-index: 5;
}

.hero-overlay::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, rgba(0,0,0,0.5), transparent, rgba(0,0,0,0.5));
}

.hero-fog {
    position: absolute;
    inset: 0;
    z-index: 6;
    pointer-events: none;
}

.hero-fog::before,
.hero-fog::after {
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    animation: fogDrift 20s ease-in-out infinite;
}

.hero-fog::before {
    background: radial-gradient(ellipse at 20% 80%, rgba(255,255,255,0.04) 0%, transparent 60%);
}

.hero-fog::after {
    background: radial-gradient(ellipse at 80% 40%, rgba(201,169,98,0.03) 0%, transparent 50%);
    animation-delay: -10s;
}

@keyframes fogDrift {
    0%, 100% { transform: translateX(0); opacity: 0.3; }
    50% { transform: translateX(50px); opacity: 0.5; }
}

.hero-vignette {
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at center, transparent 0%, rgba(0,0,0,0.6) 100%);
    z-index: 7;
    pointer-events: none;
}

.hero-content {
    position: relative;
    z-index: 10;
    text-align: center;
    padding: 0 24px;
    max-width: 900px;
}

.hero-label {
    font-family: var(--font-cormorant);
    color: var(--color-amber);
    font-size: 18px;
    letter-spacing: 0.3em;
    margin-bottom: 24px;
    animation: heroFadeIn 1s ease-out 0.3s forwards;
    opacity: 0;
}

.hero-title {
    font-family: var(--font-cinzel);
    font-size: clamp(2.5rem, 8vw, 6rem);
    letter-spacing: 0.1em;
    margin-bottom: 8px;
    background: linear-gradient(135deg, var(--color-amber) 0%, #fff 50%, var(--color-amber) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    text-shadow: 0 0 60px rgba(201,169,98,0.3);
    animation: heroFadeIn 1s ease-out 0.5s forwards;
    opacity: 0;
}

.hero-subtitle {
    font-family: var(--font-playfair);
    font-size: clamp(1.5rem, 4vw, 2.5rem);
    font-style: italic;
    color: rgba(255,255,255,0.8);
    margin-bottom: 32px;
    animation: heroFadeIn 1s ease-out 0.9s forwards;
    opacity: 0;
}

.hero-divider {
    width: 80px;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--color-amber), transparent);
    margin: 0 auto 32px;
    animation: scaleXIn 1s ease-out 1.2s forwards;
    transform: scaleX(0);
}

@keyframes scaleXIn {
    from { transform: scaleX(0); }
    to { transform: scaleX(1); }
}

.hero-tagline {
    font-family: var(--font-cormorant);
    font-size: 20px;
    color: rgba(255,255,255,0.6);
    font-style: italic;
    margin-bottom: 48px;
    animation: heroFadeIn 1s ease-out 1.4s forwards;
    opacity: 0;
}

.hero-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    justify-content: center;
    animation: heroFadeIn 1s ease-out 1.6s forwards;
    opacity: 0;
}

@keyframes heroFadeIn {
    from { opacity: 0; transform: translateY(30px); }
    to { opacity: 1; transform: translateY(0); }
}

.scroll-indicator {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    text-align: center;
    animation: bounce 2.5s ease-in-out infinite;
}

.scroll-indicator span {
    display: block;
    font-family: var(--font-montserrat);
    font-size: 12px;
    letter-spacing: 0.2em;
    color: rgba(255,255,255,0.4);
    margin-bottom: 12px;
}

.scroll-indicator svg {
    width: 24px;
    height: 24px;
    color: var(--color-amber);
}

@keyframes bounce {
    0%, 100% { transform: translateX(-50%) translateY(0); }
    50% { transform: translateX(-50%) translateY(10px); }
}

/* ============================================
   SECTIONS - COMMON
============================================ */
.section {
    position: relative;
    padding: 50px 24px;
    overflow: hidden;
}

@media (min-width: 768px) {
    .section {
        padding: 80px 32px;
    }
}

.section-container {
    max-width: 1280px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.section-header {
    text-align: center;
    margin-bottom: 64px;
}

.section-label {
    font-family: var(--font-cormorant);
    color: var(--color-amber);
    font-size: 16px;
    letter-spacing: 0.25em;
    margin-bottom: 16px;
}

.section-title {
    font-family: var(--font-cinzel);
    font-size: clamp(2rem, 5vw, 3.5rem);
    margin-bottom: 24px;
    background: linear-gradient(135deg, var(--color-amber) 0%, #fff 50%, var(--color-amber) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    line-height: 1.1;
}

.section-divider {
    width: 80px;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--color-amber), transparent);
    margin-bottom: 32px;
}

.section-divider-center {
    margin-left: auto;
    margin-right: auto;
}

.section-subtitle {
    font-family: var(--font-cormorant);
    font-size: 20px;
    color: rgba(255,255,255,0.6);
    max-width: 600px;
    margin: 0 auto;
}

/* Ambient Glows */
.ambient-glow {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    filter: blur(60px);
    animation: ambientPulse 10s ease-in-out infinite;
}

.ambient-glow-1 {
    width: 600px;
    height: 600px;
    top: 10%;
    right: -10%;
    background: radial-gradient(circle, rgba(201,169,98,0.08), transparent 70%);
}

.ambient-glow-2 {
    width: 500px;
    height: 500px;
    bottom: 5%;
    left: -5%;
    background: radial-gradient(circle, rgba(114,47,55,0.06), transparent 70%);
    animation-delay: -5s;
}

.ambient-glow-center {
    width: 500px;
    height: 500px;
    top: 30%;
    left: 50%;
    transform: translateX(-50%);
    background: radial-gradient(circle, rgba(201,169,98,0.05), transparent 70%);
    filter: blur(80px);
}

.ambient-glow-large {
    width: 700px;
    height: 700px;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    background: radial-gradient(circle, rgba(201,169,98,0.1), transparent 60%);
    filter: blur(100px);
}

@keyframes ambientPulse {
    0%, 100% { opacity: 0.4; transform: scale(1); }
    50% { opacity: 0.7; transform: scale(1.1); }
}

/* Animation Classes */
.fade-in {
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.8s ease, transform 0.8s ease;
}

.fade-in.visible {
    opacity: 1;
    transform: translateY(0);
}

.fade-in-left {
    opacity: 0;
    transform: translateX(-60px);
    transition: opacity 1s ease, transform 1s ease;
}

.fade-in-left.visible {
    opacity: 1;
    transform: translateX(0);
}

.fade-in-right {
    opacity: 0;
    transform: translateX(60px);
    transition: opacity 1s ease, transform 1s ease;
}

.fade-in-right.visible {
    opacity: 1;
    transform: translateX(0);
}

/* ============================================
   ABOUT SECTION
============================================ */
.about-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 60px;
    align-items: center;
}

@media (min-width: 1024px) {
    .about-grid {
        grid-template-columns: 1fr 1fr;
        gap: 80px;
    }
}

.about-images {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.about-images-col {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.about-images-col-offset {
    padding-top: 64px;
}

.about-image-wrapper {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    transition: transform 0.4s ease;
}

.about-image-wrapper:hover {
    transform: scale(1.02);
}

.about-image-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.7s ease;
}

.about-image-wrapper:hover img {
    transform: scale(1.1);
}

.about-image-wrapper::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.6), transparent);
}

.about-image-1 { height: 256px; }
.about-image-2 { height: 192px; }
.about-image-3 { height: 192px; }
.about-image-4 { height: 256px; }

.about-text {
    font-family: var(--font-cormorant);
    font-size: 20px;
    color: rgba(255,255,255,0.7);
    line-height: 1.7;
    margin-bottom: 32px;
}

.about-text-small {
    font-family: var(--font-poppins);
    font-size: 15px;
    color: rgba(255,255,255,0.5);
    line-height: 1.7;
    margin-bottom: 40px;
}

/* Feature List */
.feature-list {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.feature-item {
    display: flex;
    gap: 16px;
    transition: transform 0.3s ease;
}

.feature-item:hover {
    transform: translateX(10px);
}

.feature-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(201,169,98,0.2), transparent);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: transform 0.3s ease;
}

.feature-item:hover .feature-icon {
    transform: scale(1.1);
}

.feature-icon svg {
    width: 20px;
    height: 20px;
    color: var(--color-amber);
}

.feature-content h4 {
    font-family: var(--font-montserrat);
    font-weight: 600;
    font-size: 16px;
    margin-bottom: 4px;
    color: #fff;
}

.feature-content p {
    font-family: var(--font-poppins);
    font-size: 14px;
    color: rgba(255,255,255,0.5);
}



/* ============================================
   MENU SECTION
============================================ */
.menu-tabs {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-bottom: 48px;
    flex-wrap: wrap;
}

@media (min-width: 768px) {
    .menu-tabs {
        gap: 32px;
    }
}

.menu-tab {
    padding: 12px 24px;
    font-family: var(--font-montserrat);
    font-size: 14px;
    letter-spacing: 0.05em;
    color: rgba(255,255,255,0.5);
    background: none;
    border: none;
    cursor: pointer;
    position: relative;
    transition: all 0.3s ease;
}

.menu-tab:hover {
    color: rgba(255,255,255,0.8);
}

.menu-tab.active {
    color: var(--color-amber);
}

.menu-tab.active::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--color-amber), transparent);
}

.menu-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
}

.menu-content {
    display: none;
}

.menu-content.active {
    display: grid;
}

@media (min-width: 768px) {
    .menu-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 24px;
    }
}

.menu-item {
    display: flex;
    background: rgba(26, 26, 26, 0.7);
    backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    overflow: hidden;
    transition: all 0.5s ease;
}

.menu-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 30px rgba(201, 169, 98, 0.1);
}

.menu-item-image {
    width: 96px;
    height: 96px;
    flex-shrink: 0;
    overflow: hidden;
}

@media (min-width: 768px) {
    .menu-item-image {
        width: 128px;
        height: 128px;
    }
}

.menu-item-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.6;
    transition: all 0.5s ease;
}

.menu-item:hover .menu-item-image img {
    opacity: 0.8;
    transform: scale(1.1);
}

.menu-item-content {
    padding: 16px 20px;
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

@media (min-width: 768px) {
    .menu-item-content {
        padding: 20px 24px;
    }
}

.menu-item-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 8px;
}

.menu-item-name {
    font-family: var(--font-cinzel);
    font-size: 18px;
    transition: color 0.3s ease;
}

.menu-item:hover .menu-item-name {
    color: var(--color-amber);
}

.menu-item-price {
    font-family: var(--font-montserrat);
    font-weight: 700;
    font-size: 18px;
    color: var(--color-amber);
    white-space: nowrap;
}

.menu-item-desc {
    font-family: var(--font-poppins);
    font-size: 14px;
    color: rgba(255,255,255,0.5);
}

/* ============================================
   GALLERY SECTION
============================================ */
.gallery-section {
    background: linear-gradient(to bottom, transparent, rgba(13,13,13,0.3), transparent);
}

.gallery-grid {
    column-count: 2;
    column-gap: 12px;
}

@media (min-width: 768px) {
    .gallery-grid {
        column-count: 3;
        column-gap: 16px;
    }
}

@media (min-width: 1024px) {
    .gallery-grid {
        column-count: 4;
    }
}

.gallery-item {
    break-inside: avoid;
    margin-bottom: 12px;
    border-radius: 8px;
    overflow: hidden;
    position: relative;
    cursor: pointer;
    transition: transform 0.4s ease;
}

@media (min-width: 768px) {
    .gallery-item {
        margin-bottom: 16px;
    }
}

.gallery-item:hover {
    transform: scale(1.02);
}

.gallery-item img {
    width: 100%;
    display: block;
    transition: transform 0.7s ease;
}

.gallery-item:hover img {
    transform: scale(1.1);
}

.gallery-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.8), transparent);
    opacity: 0;
    transition: opacity 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.gallery-item:hover .gallery-overlay {
    opacity: 1;
}

.gallery-overlay-icon {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: rgba(255,255,255,0.1);
    backdrop-filter: blur(10px);
    display: flex;
    align-items: center;
    justify-content: center;
}

.gallery-overlay-icon svg {
    width: 24px;
    height: 24px;
    color: #fff;
}

/* Lightbox */
.lightbox {
    position: fixed;
    inset: 0;
    z-index: 200;
    display: none;
    align-items: center;
    justify-content: center;
    background: rgba(0,0,0,0.95);
    backdrop-filter: blur(20px);
}

.lightbox.active {
    display: flex;
}

.lightbox-img {
    max-width: 90vw;
    max-height: 90vh;
    object-fit: contain;
    border-radius: 8px;
}

.lightbox-close {
    position: absolute;
    top: 32px;
    right: 32px;
    background: none;
    border: none;
    color: rgba(255,255,255,0.6);
    cursor: pointer;
    padding: 8px;
    transition: color 0.3s ease;
}

.lightbox-close:hover {
    color: #fff;
}

.lightbox-close svg {
    width: 32px;
    height: 32px;
}

/* ============================================
   EXPERIENCE SECTION
============================================ */
.experience-section {
    position: relative;
}

.experience-bg {
    position: absolute;
    inset: 0;
    background: url('https://heavenworld.in/demo/img/003.png') center/cover;
    filter: brightness(0.2) blur(40px);
}

.experience-bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to right, #000, rgba(0,0,0,0.8), #000);
}

.experience-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
}

@media (min-width: 640px) {
    .experience-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .experience-grid {
        grid-template-columns: repeat(4, 1fr);
        gap: 32px;
    }
}

.experience-card {
    text-align: center;
    padding: 32px 24px;
    background: rgba(26, 26, 26, 0.7);
    backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 16px;
    transition: all 0.5s ease;
    position: relative;
    overflow: hidden;
}

.experience-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle, rgba(201,169,98,0.1), transparent 70%);
    opacity: 0;
    transition: opacity 0.5s ease;
}

.experience-card:hover::before {
    opacity: 1;
}

.experience-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 20px 40px rgba(201, 169, 98, 0.1);
}

.experience-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto 24px;
    border-radius: 16px;
    background: linear-gradient(135deg, rgba(201,169,98,0.2), transparent);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.5s ease;
    position: relative;
    z-index: 1;
}

.experience-card:hover .experience-icon {
    transform: scale(1.1);
}

.experience-icon svg {
    width: 32px;
    height: 32px;
    color: var(--color-amber);
}

.experience-title {
    font-family: var(--font-cinzel);
    font-size: 18px;
    margin-bottom: 12px;
    transition: color 0.3s ease;
    position: relative;
    z-index: 1;
}

.experience-card:hover .experience-title {
    color: var(--color-amber);
}

.experience-desc {
    font-family: var(--font-poppins);
    font-size: 14px;
    color: rgba(255,255,255,0.5);
    position: relative;
    z-index: 1;
}

.experience-cta {
    text-align: center;
    margin-top: 64px;
}

/* ============================================
   TESTIMONIALS SECTION
============================================ */
.testimonials-section {
    background: linear-gradient(to bottom, transparent, rgba(13,13,13,0.3), transparent);
}

.testimonials-container {
    max-width: 900px;
    margin: 0 auto;
}

.testimonial-wrapper {
    position: relative;
    min-height: 320px;
}

@media (min-width: 768px) {
    .testimonial-wrapper {
        min-height: 280px;
    }
}

.testimonial {
    position: absolute;
    inset: 0;
    text-align: center;
    padding: 12px 12px;
    background: rgba(26, 26, 26, 0.7);
    backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 16px;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.5s ease, transform 0.5s ease;
    transform: translateY(20px);
}

.testimonial.active {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.testimonial-quote {
    font-family: var(--font-playfair);
    font-size: 72px;
    color: rgba(201,169,98,0.2);
    line-height: 0;
    position: absolute;
    top: 32px;
    left: 32px;
}

.testimonial-stars {
    display: flex;
    justify-content: center;
    gap: 4px;
    margin-bottom: 32px;
    margin-top: 32px;
}

.testimonial-stars svg {
    width: 20px;
    height: 20px;
}

.testimonial-stars .star-filled {
    color: var(--color-amber);
    fill: var(--color-amber);
}

.testimonial-stars .star-empty {
    color: rgba(255,255,255,0.2);
}

.testimonial-text {
    font-family: var(--font-cormorant);
    font-size: 20px;
    font-style: italic;
    color: rgba(255,255,255,0.8);
    line-height: 1.7;
    /*margin-bottom: 32px;*/
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
}

@media (min-width: 768px) {
    .testimonial-text {
        font-size: 24px;
    }
}

.testimonial-author {
    font-family: var(--font-montserrat);
    font-weight: 600;
    font-size: 18px;
    color: var(--color-amber);
    margin-bottom: 4px;
}

.testimonial-location {
    font-family: var(--font-poppins);
    font-size: 14px;
    color: rgba(255,255,255,0.4);
}

.testimonial-dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 32px;
}

.testimonial-dot {
    width: 8px;
    height: 8px;
    border-radius: 4px;
    background: rgba(255,255,255,0.2);
    cursor: pointer;
    transition: all 0.3s ease;
    border: none;
}

.testimonial-dot:hover {
    background: rgba(255,255,255,0.4);
}

.testimonial-dot.active {
    background: var(--color-amber);
    width: 32px;
}

/* ============================================
   RESERVATION SECTION
============================================ */
.reservation-section {
    position: relative;
}

.reservation-bg {
    position: absolute;
    inset: 0;
    background: url('https://heavenworld.in/demo/img/006.png') center/cover;
    filter: brightness(0.15) blur(2px);
}

.reservation-bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, #000, rgba(0,0,0,0.5), rgba(0,0,0,0.8));
}

.reservation-form {
    max-width: 800px;
    margin: 0 auto;
    padding: 48px 32px;
    background: rgba(13, 13, 13, 0.8);
    backdrop-filter: blur(30px);
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: 24px;
}

@media (min-width: 768px) {
    .reservation-form {
        padding: 60px 48px;
    }
}

.form-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
}

@media (min-width: 768px) {
    .form-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 24px;
    }
}

.form-group {
    position: relative;
}

.form-group-full {
    grid-column: 1 / -1;
}

.form-label {
    display: block;
    font-family: var(--font-montserrat);
    font-size: 14px;
    color: rgba(255,255,255,0.5);
    margin-bottom: 8px;
    letter-spacing: 0.05em;
}

.form-input,
.form-select {
    width: 100%;
    padding: 16px 20px;
    background: rgba(26, 26, 26, 0.6);
    border: 1px solid rgba(201, 169, 98, 0.2);
    border-radius: 12px;
    color: #e5e5e5;
    font-family: var(--font-poppins);
    font-size: 16px;
    transition: all 0.3s ease;
}

.form-input:focus,
.form-select:focus {
    outline: none;
    border-color: var(--color-amber);
    box-shadow: 0 0 20px rgba(201, 169, 98, 0.2);
}

.form-input::placeholder {
    color: rgba(255, 255, 255, 0.4);
}

.form-select {
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.4)' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 16px center;
    background-size: 16px;
}

.form-select option {
    background: #1a1a1a;
    color: #e5e5e5;
}

.btn-submit {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    background: linear-gradient(135deg, var(--color-amber) 0%, #a88942 100%);
    color: #000;
    font-family: var(--font-cinzel);
    font-weight: 600;
    padding: 16px 32px;
    border: none;
    border-radius: 0;
    cursor: pointer;
    font-size: 14px;
    letter-spacing: 2px;
    transition: all 0.4s ease;
}

.btn-submit:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 30px rgba(201, 169, 98, 0.3);
}

.btn-submit:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.btn-submit svg {
    width: 20px;
    height: 20px;
}

.submit-spinner {
    width: 24px;
    height: 24px;
    border: 2px solid #000;
    border-top-color: transparent;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* ============================================
   THE GRAND FINALE (LUXURY EDITORIAL FOOTER)
============================================ */
.luxury-grand-footer {
    background: #000000;
    position: relative;
    padding: 120px 0 0 0; /* Keeps spacing generous but snaps grounding bar to base */
    overflow: hidden;
    border-top: 1px solid rgba(201, 169, 98, 0.12);
}

.footer-ambient-glow {
    position: absolute;
    width: 700px;
    height: 500px;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    background: radial-gradient(circle, rgba(114, 47, 55, 0.08) 0%, transparent 70%);
    filter: blur(100px);
    pointer-events: none;
}

/* Upper Deck Sizing Rules */
.footer-upper-deck {
    max-width: 1320px;
    margin: 0 auto 90px;
    padding: 0 40px;
    display: grid;
    grid-template-columns: 1fr;
    gap: 60px;
    align-items: center;
}

@media (min-width: 1024px) {
    .footer-upper-deck {
        grid-template-columns: 6.5fr 5.5fr; /* Strategic layout balance */
        gap: 40px;
    }
}

/* Monolith Brand Typography Group */
.footer-brand-monolith {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.footer-monolith-logo {
    height: 54px;
    margin-bottom: 24px;
    filter: drop-shadow(0 4px 10px rgba(0,0,0,0.5));
}

.footer-poetic-manifesto {
    font-family: var(--font-cormorant);
    font-size: clamp(20px, 2.5vw, 24px);
    font-style: italic;
    color: var(--color-amber-light);
    margin-bottom: 8px;
    line-height: 1.4;
    letter-spacing: 0.02em;
}

.footer-monolith-title {
    font-family: var(--font-cinzel);
    font-size: clamp(1.8rem, 3.5vw, 2.8rem);
    letter-spacing: 0.12em;
    color: #ffffff;
    font-weight: 400;
    line-height: 1.1;
}

/* Out-Of-The-Box Glassmorphic Subscription Box */
.footer-subscribe-box {
    width: 100%;
}

.subscribe-label {
    font-family: var(--font-montserrat);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.3em;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 16px;
}

.footer-subscribe-form {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: 12px;
    background: rgba(13, 13, 13, 0.6);
    border: 1px solid rgba(255, 255, 255, 0.05);
    padding: 8px;
    border-radius: 4px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

@media (min-width: 550px) {
    .footer-subscribe-form {
        flex-direction: row;
        gap: 0;
    }
}

.subscribe-input-wrapper {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    flex-grow: 1;
}

.sub-mail-icon {
    width: 18px;
    height: 18px;
    color: rgba(201, 169, 98, 0.4);
}

.subscribe-field {
    width: 100%;
    background: transparent;
    border: none;
    outline: none;
    color: #ffffff;
    font-family: var(--font-poppins);
    font-size: 14px;
}

.subscribe-field::placeholder {
    color: rgba(255, 255, 255, 0.3);
}

.subscribe-action-btn {
    background: linear-gradient(135deg, var(--color-amber) 0%, #a88942 100__);
    border: none;
    outline: none;
    color: #000000;
    font-family: var(--font-cinzel);
    font-weight: 600;
    font-size: 12px;
    letter-spacing: 0.2em;
    padding: 16px 32px;
    cursor: pointer;
    border-radius: 2px;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.subscribe-action-btn:hover {
    box-shadow: 0 0 20px rgba(201, 169, 98, 0.3);
    transform: scale(1.01);
}

/* Middle Directory Deck Grid Layout */
.footer-directory-deck {
    max-width: 1320px;
    margin: 0 auto 80px;
    padding: 0 40px;
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 48px;
}

@media (min-width: 640px) {
    .footer-directory-deck {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .footer-directory-deck {
        grid-template-columns: 5.2fr 3.8fr 3fr; /* Asymmetric spacing focus */
        gap: 40px;
    }
}

.directory-node {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.directory-title {
    font-family: var(--font-cinzel);
    font-size: 13px;
    letter-spacing: 0.18em;
    color: rgba(255, 255, 255, 0.35);
    font-weight: 500;
    margin-bottom: 12px;
}

.directory-accent-line {
    width: 24px;
    height: 1px;
    background-color: rgba(201, 169, 98, 0.3);
    margin-bottom: 24px;
}

/* Master Hero Booking Targets */
.directory-hero-link {
    font-family: var(--font-cinzel);
    font-size: clamp(16px, 1.8vw, 22px);
    letter-spacing: 0.05em;
    color: #ffffff;
    text-decoration: none;
    line-height: 1.4;
    font-weight: 400;
    transition: color 0.3s ease;
}

.directory-hero-link .gold-num {
    display: block;
    font-family: var(--font-montserrat);
    font-weight: 600;
    color: var(--color-amber);
    margin-top: 4px;
    font-size: clamp(18px, 2vw, 24px);
    letter-spacing: 0px;
    transition: color 0.3s ease;
}

.directory-hero-link:hover { color: var(--color-amber-light); }
.directory-hero-link:hover .gold-num { color: #ffffff; }

.directory-sub-link {
    font-family: var(--font-poppins);
    font-size: 14px;
    color: rgba(255, 255, 255, 0.45);
    text-decoration: none;
    margin-top: 12px;
    transition: color 0.3s ease;
}
.directory-sub-link:hover { color: var(--color-amber); }

.directory-text-block {
    font-family: var(--font-poppins);
    font-size: 14px;
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.55);
    font-weight: 300;
    margin-bottom: 16px;
}

.directory-hours-block {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.directory-hours-block span {
    font-family: var(--font-montserrat);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.08em;
    color: rgba(255, 255, 255, 0.35);
}

/* Minimalist Link Matrices */
.directory-nav-links {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px 32px;
}

.directory-nav-links a {
    font-family: var(--font-montserrat);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.15em;
    color: rgba(255, 255, 255, 0.5);
    text-decoration: none;
    transition: all 0.3s ease;
}

.directory-nav-links a:hover {
    color: var(--color-amber);
    transform: translateX(4px);
}

/* Lower Grounding Deck Base Bar */
.footer-lower-grounding {
    border-top: 1px solid rgba(255, 255, 255, 0.04);
    padding: 32px 40px;
    position: relative;
    z-index: 2;
    background: #030303;
}

.grounding-container {
    max-width: 1320px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
}

@media (min-width: 768px) {
    .grounding-container {
        flex-direction: row;
        gap: 0;
    }
}

.copyright-text, .terms-anchor-link {
    font-family: var(--font-poppins);
    font-size: 12px;
    color: rgba(255, 255, 255, 0.3);
    letter-spacing: 0.02em;
}

.terms-anchor-link {
    text-decoration: none;
    font-family: var(--font-montserrat);
    font-weight: 500;
    letter-spacing: 0.1em;
    transition: color 0.3s ease;
}
.terms-anchor-link:hover { color: var(--color-amber); }

/* Compact Social Nodes */
.footer-social-ribbon {
    display: flex;
    gap: 16px;
}

.social-icon-circle {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.06);
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255, 255, 255, 0.4);
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    background: transparent;
}

.social-icon-circle svg {
    width: 16px;
    height: 16px;
}

.social-icon-circle:hover {
    border-color: var(--color-amber);
    color: #000000;
    background: var(--color-amber);
    transform: translateY(-3px);
    box-shadow: 0 10px 20px rgba(201, 169, 98, 0.15);
}

@media (max-width: 600px) {
    .footer-upper-deck, .footer-directory-deck, .footer-lower-grounding {
        padding-left: 24px;
        padding-right: 24px;
    }
    .footer-subscribe-form {
        padding: 4px;
    }
}



/* ============================================
   THE ROYAL ESTATE (HIGH READABILITY & EXPERIENCE)
============================================ */
.royal-estate-section {
    background: #000000;
    position: relative;
    padding: 120px 0;
    overflow: hidden;
    border-bottom: 1px solid rgba(201, 169, 98, 0.08);
}

.estate-container {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 40px;
}

/* Luxury Glow Accents */
.royal-glow-top {
    position: absolute;
    width: 600px;
    height: 500px;
    top: -10%;
    left: 20%;
    background: radial-gradient(circle, rgba(114, 47, 55, 0.12) 0%, transparent 70%);
    filter: blur(90px);
    pointer-events: none;
}
.royal-glow-bottom {
    position: absolute;
    width: 600px;
    height: 500px;
    bottom: -15%;
    right: 15%;
    background: radial-gradient(circle, rgba(201, 169, 98, 0.06) 0%, transparent 70%);
    filter: blur(100px);
    pointer-events: none;
}

/* Narrative Split Layout */
.estate-narrative-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
    margin-bottom: 70px;
    align-items: end;
}

@media (min-width: 1024px) {
    .estate-narrative-row {
        grid-template-columns: 4.5fr 7.5fr;
        gap: 64px;
    }
}

.estate-meta-label {
    font-family: var(--font-montserrat);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.35em;
    color: var(--color-amber);
    margin-bottom: 16px;
}

.estate-main-title {
    font-family: var(--font-cinzel);
    font-size: clamp(2.5rem, 4vw, 3.8rem);
    line-height: 1.1;
    letter-spacing: 0.05em;
    color: #ffffff;
    font-weight: 400;
    margin-bottom: 20px;
}

.gold-gradient-text {
    background: linear-gradient(135deg, #fff 0%, var(--color-amber) 50%, #a88942 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    font-weight: 700;
}

.estate-crest-line {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 24px;
}

.estate-crest-line .line-gold {
    width: 60px;
    height: 1px;
    background: linear-gradient(90deg, var(--color-amber), transparent);
}

.estate-crest-line .diamond-spark {
    color: var(--color-amber);
    font-size: 9px;
}

.estate-lead-quote {
    font-family: var(--font-cormorant);
    font-size: clamp(20px, 1.8vw, 24px);
    line-height: 1.5;
    color: rgba(255, 255, 255, 0.95);
    font-style: italic;
    margin-bottom: 20px;
    border-left: 2px solid var(--color-amber);
    padding-left: 20px;
}

.estate-paragraph {
    font-family: var(--font-poppins);
    font-size: 14px;
    line-height: 1.8;
    color: rgba(255, 255, 255, 0.55);
    font-weight: 300;
    letter-spacing: 0.01em;
}

.estate-signature-block {
    margin-top: 20px;
}

.sig-title {
    font-family: var(--font-montserrat);
    font-size: 9px;
    letter-spacing: 0.2em;
    color: rgba(255, 255, 255, 0.4);
    margin-bottom: 2px;
}

.sig-name {
    font-family: var(--font-playfair);
    font-size: 20px;
    font-style: italic;
    color: var(--color-amber-light);
}

/* Linear Images Grid */
.estate-visual-row {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 24px;
}

@media (min-width: 600px) {
    .estate-visual-row {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .estate-visual-row {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Experiential Linear Card */
.estate-linear-card {
    position: relative;
    height: 420px; /* Enhanced vertical posture for premium scanning */
    border-radius: 6px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.08);
    display: flex;
    align-items: flex-end;
    padding: 28px;
    cursor: pointer;
    transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.4s ease, box-shadow 0.4s ease;
}

.estate-card-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transform: scale(1.01);
    transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

/* High Contrast Normal State: 100% Readable Background */
.estate-card-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, 
        rgba(0, 0, 0, 0.95) 0%, 
        rgba(0, 0, 0, 0.75) 45%, 
        rgba(0, 0, 0, 0.3) 100%
    );
    transition: background 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Content Container Always Static & Sharp */
.estate-card-content {
    position: relative;
    z-index: 2;
    width: 100%;
    transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.card-number {
    font-family: var(--font-cinzel);
    font-size: 13px;
    color: var(--color-amber);
    display: block;
    margin-bottom: 6px;
    font-weight: 600;
}

.card-title {
    font-family: var(--font-cinzel);
    font-size: 18px;
    letter-spacing: 0.08em;
    color: #ffffff;
    margin-bottom: 8px;
    font-weight: 500;
    transition: color 0.3s ease;
}

/* Static, fully readable descriptions on default view */
.card-mini-desc {
    font-family: var(--font-poppins);
    font-size: 12.5px;
    color: rgba(255, 255, 255, 0.65);
    font-weight: 300;
    line-height: 1.5;
    margin-bottom: 16px;
    transition: color 0.3s ease;
}

.card-tag {
    display: inline-block;
    font-family: var(--font-montserrat);
    font-size: 8.5px;
    font-weight: 600;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--color-amber-light);
    background: rgba(201, 169, 98, 0.1);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
    padding: 6px 12px;
    border-radius: 3px;
    border: 1px solid rgba(201, 169, 98, 0.2);
    transition: all 0.3s ease;
}

/* Hover Engine: Smooth Experience Switch */
.estate-linear-card:hover {
    transform: translateY(-8px);
    border-color: var(--color-amber);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.6);
}

.estate-linear-card:hover .estate-card-bg {
    transform: scale(1.08); /* Sophisticated experiential zoom */
}

/* Changes background to dynamic warm burgundy night overlay */
.estate-linear-card:hover .estate-card-overlay {
    background: linear-gradient(to top, 
        rgba(114, 47, 55, 0.9) 0%, 
        rgba(26, 26, 26, 0.7) 50%, 
        rgba(0, 0, 0, 0.2) 100__
    );
}

.estate-linear-card:hover .card-title {
    color: #ffffff;
}

.estate-linear-card:hover .card-mini-desc {
    color: rgba(255, 255, 255, 0.85);
}

.estate-linear-card:hover .card-tag {
    color: #000000;
    background: var(--color-amber);
    border-color: var(--color-amber);
}

@media (max-width: 768px) {
    .estate-container {
        padding: 0 24px;
    }
    .estate-linear-card {
        height: 360px;
    }
}

/* ============================================
   THE HEAVENLY FEAST (GEOMETRIC LUXURY SYSTEM)
============================================ */
.culinary-feast-section {
    background: #000000;
    position: relative;
    padding: 120px 0;
    overflow: hidden;
}

.estate-container-fluid {
    width: 100%;
    padding: 0 0 0 40px;
}

.feast-glow-left {
    position: absolute;
    width: 500px;
    height: 500px;
    top: 20%;
    left: -10%;
    background: radial-gradient(circle, rgba(201, 169, 98, 0.04) 0%, transparent 70%);
    filter: blur(100px);
    pointer-events: none;
}

/* Header Matrix */
.feast-header-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 60px;
    padding-right: 40px;
}

.feast-meta-tag {
    font-family: var(--font-montserrat);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.3em;
    color: var(--color-amber);
    margin-bottom: 12px;
}

.feast-main-title {
    font-family: var(--font-cinzel);
    font-size: clamp(2rem, 3.5vw, 3.2rem);
    letter-spacing: 0.1em;
    color: #ffffff;
    font-weight: 400;
    line-height: 1.1;
    margin-bottom: 12px;
}

.feast-sub-bar {
    width: 40px;
    height: 1px;
    background: var(--color-amber);
}

/* Navigation Mechanics */
.feast-slider-controls {
    display: flex;
    gap: 12px;
}

.feast-nav-btn {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.1);
    background: transparent;
    color: #ffffff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.feast-nav-btn svg {
    width: 20px;
    height: 20px;
}

.feast-nav-btn:hover {
    border-color: var(--color-amber);
    color: var(--color-amber);
    background: rgba(201, 169, 98, 0.05);
}

/* Filmstrip Track Positioning */
.feast-carousel-viewport {
    overflow: hidden;
    padding: 20px 0;
}

.feast-carousel-track {
    display: flex;
    gap: 24px; /* Balanced structural spacing gap */
    transition: transform 0.7s cubic-bezier(0.16, 1, 0.3, 1);
    will-change: transform;
}

/* The Structural Geometric Parent Frame */
.feast-geo-item {
    flex: 0 0 290px;
    height: 460px;
    position: relative;
    perspective: 1000px;
}

/* Classic Luxury Linear Border Shell */
.geo-outline-card {
    position: absolute;
    inset: 0;
    border: 1px solid rgba(201, 169, 98, 0.2); /* Soft luxury border framing */
    padding: 10px; /* Internal spacing cushion to emphasize the geometric lines */
    overflow: hidden;
    background: transparent;
    /* Clean linear slant cut applied symmetrically to the layout */
    clip-path: polygon(0 0, 100% 4%, 100% 100%, 0 96%);
    transition: clip-path 0.5s cubic-bezier(0.16, 1, 0.3, 1), 
                border-color 0.5s ease, 
                transform 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.filmstrip-img-wrapper {
    position: absolute;
    inset: 10px; /* Anchored flawlessly right inside our custom border ring */
    background-size: cover;
    background-position: center;
    transform: scale(1.05);
    transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
    clip-path: polygon(0 0, 100% 4%, 100% 100%, 0 96%);
}

/* Ambient Visual Contrast Layers */
.filmstrip-overlay {
    position: absolute;
    inset: 10px;
    background: linear-gradient(to top, 
        rgba(0, 0, 0, 0.95) 0%, 
        rgba(0, 0, 0, 0.7) 45%, 
        rgba(0, 0, 0, 0.4) 100%
    );
    transition: background 0.5s cubic-bezier(0.16, 1, 0.3, 1);
    z-index: 1;
}

/* Inner Text Elements */
.filmstrip-content {
    position: absolute;
    bottom: 10px;
    left: 10px;
    width: calc(100% - 20px);
    padding: 32px 24px;
    z-index: 2;
}

.filmstrip-category {
    font-family: var(--font-cormorant);
    font-size: 13px;
    font-style: italic;
    color: var(--color-amber-light);
    display: block;
    margin-bottom: 4px;
    letter-spacing: 0.05em;
}

.filmstrip-title {
    font-family: var(--font-cinzel);
    font-size: 18px;
    letter-spacing: 0.08em;
    color: #ffffff;
    font-weight: 400;
    transition: color 0.3s ease;
}

/* Premium Geometric Interaction Effects */
.feast-geo-item:hover .geo-outline-card {
    border-color: var(--color-amber);
    /* Slant snaps into a perfectly straight, formal frame state on interaction */
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    transform: translateY(-8px);
}

.feast-geo-item:hover .filmstrip-img-wrapper {
    transform: scale(1.01); /* Resets back to clean frame alignment on zoom */
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}

.feast-geo-item:hover .filmstrip-overlay {
    background: linear-gradient(to top, 
        rgba(114, 47, 55, 0.85) 0%, /* Deep Night Burgundy Ambient transition */
        rgba(0, 0, 0, 0.5) 60%, 
        rgba(0, 0, 0, 0.1) 100%
    );
}

.feast-geo-item:hover .filmstrip-title {
    color: var(--color-amber);
}

@media (max-width: 768px) {
    .estate-container-fluid {
        padding-left: 24px;
    }
    .feast-header-row {
        padding-right: 24px;
    }
    .feast-geo-item {
        flex: 0 0 240px;
        height: 400px;
    }
}




/* ============================================
   THE LUXURY ARCHITECTURAL MENU DECK
============================================ */
.architectural-menu-section {
    background: #000000;
    position: relative;
    padding: 140px 0;
    overflow: hidden;
    border-bottom: 1px solid rgba(201, 169, 98, 0.08);
}

.arch-glow-top {
    position: absolute;
    width: 600px;
    height: 600px;
    top: -20%;
    left: -10%;
    background: radial-gradient(circle, rgba(201, 169, 98, 0.05) 0%, transparent 75%);
    filter: blur(100px);
    pointer-events: none;
}
.arch-glow-bottom {
    position: absolute;
    width: 500px;
    height: 500px;
    bottom: -10%;
    right: 20%;
    background: radial-gradient(circle, rgba(114, 47, 55, 0.08) 0%, transparent 70%);
    filter: blur(90px);
    pointer-events: none;
}

/* Master Asymmetric Layout Split */
.arch-menu-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: 64px;
    align-items: center;
}

@media (min-width: 1024px) {
    .arch-menu-layout {
        grid-template-columns: 3.5fr 8.5fr; /* Pure high-end lookbook layout split */
        gap: 60px;
    }
}

/* Left Panel Sticky Architecture */
@media (min-width: 1024px) {
    .arch-sticky-box {
        position: sticky;
        top: 140px;
    }
}

.arch-meta-label {
    font-family: var(--font-montserrat);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.3em;
    color: var(--color-amber);
    margin-bottom: 16px;
}

.arch-main-title {
    font-family: var(--font-cinzel);
    font-size: clamp(2.2rem, 3.8vw, 3.4rem);
    line-height: 1.1;
    letter-spacing: 0.06em;
    color: #ffffff;
    font-weight: 400;
    margin-bottom: 20px;
}

.arch-crest-divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 24px;
}

.arch-line-gold {
    width: 50px;
    height: 1px;
    background: linear-gradient(90deg, var(--color-amber), transparent);
}

.arch-diamond-spark {
    color: var(--color-amber);
    font-size: 8px;
}

.arch-manifesto-text {
    font-family: var(--font-poppins);
    font-size: 13.5px;
    line-height: 1.8;
    color: rgba(255, 255, 255, 0.45);
    font-weight: 300;
}

/* Right Panel Horizontal Deck Array */
.arch-deck-panel {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 32px;
}

@media (min-width: 600px) {
    .arch-deck-panel {
        grid-template-columns: repeat(3, 1fr); /* Forms beautiful, clean architectural columns */
        gap: 20px;
    }
}

/* The Minimalist Menu Card Item */
.arch-menu-card {
    background: transparent;
    position: relative;
    cursor: pointer;
}

.arch-card-geometry {
    border: 1px solid rgba(255, 255, 255, 0.05);
    background: #080808;
    padding: 16px 16px 24px 16px;
    border-radius: 4px;
    transition: all 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.arch-card-index {
    font-family: var(--font-montserrat);
    font-size: 9px;
    font-weight: 500;
    letter-spacing: 0.15em;
    color: rgba(255, 255, 255, 0.3);
    display: block;
    margin-bottom: 12px;
    transition: color 0.3s ease;
}

/* Image Vault: High-Legibility Window Frame */
.arch-image-vault {
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 1.45; /* Preserves vertical menu sheet dimensions cleanly */
    overflow: hidden;
    position: relative;
    border: 1px solid rgba(201, 169, 98, 0.1);
    background: #000;
}

.arch-menu-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
        object-position: left center;
    /* 100% Bright, vivid, clear and legible on baseline viewport load */
    filter: brightness(0.9) contrast(1.02);
    transform: scale(1.001);
    transition: transform 0.7s cubic-bezier(0.16, 1, 0.3, 1), filter 0.4s ease;
}

/* Footer Information Engine */
.arch-card-footer-UI {
    margin-top: 20px;
    position: relative;
    overflow: hidden;
    height: 44px; /* Locks baseline limits perfectly */
}

.arch-menu-label {
    font-family: var(--font-cinzel);
    font-size: 15px;
    letter-spacing: 0.08em;
    color: #ffffff;
    font-weight: 500;
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), color 0.3s ease;
    transform: translateY(10px);
}

/* Out-of-the-box Layered Shift Interaction Animation Capsules */
.arch-expand-capsule {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #080808;
    transform: translateY(100%);
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.arch-expand-capsule span {
    font-family: var(--font-montserrat);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.2em;
    color: var(--color-amber);
}

.arch-expand-capsule svg {
    width: 14px;
    height: 14px;
    color: var(--color-amber);
}

/* Modern Hover Interaction Switches */
.arch-menu-card:hover .arch-card-geometry {
    border-color: rgba(201, 169, 98, 0.3);
    box-shadow: 0 25px 50px rgba(0, 0, 0, 0.7);
    transform: translateY(-6px);
}

.arch-menu-card:hover .arch-card-index {
    color: var(--color-amber);
}

/* Image glides forward deep inside frame bounds on touch/hover */
.arch-menu-card:hover .arch-menu-img {
    transform: scale(1.05);
    filter: brightness(1.05) contrast(1.05);
}

/* Text rows translate upwards quietly to slide capsule forward */
.arch-menu-card:hover .arch-menu-label {
    transform: translateY(-100%);
}

.arch-menu-card:hover .arch-expand-capsule {
    transform: translateY(0);
}



/* ============================================
   THE CELEBRITY VIP DECK (HIGH USABILITY GRID)
============================================ */

.vip-deck-section {
    background: #000000;
    padding: 100px 0;
    overflow: hidden;
    border-bottom: 1px solid rgba(201, 169, 98, 0.08);
    position: relative !important;
}

.vip-deck-section .estate-container {
    width: 100% !important;
    max-width: 1320px !important; / साइज */
    margin-right: auto !important;
    margin-left: auto !important;
    padding-left: 15px !important;
    padding-right: 15px !important;
    box-sizing: border-box !important;
    position: relative !important;
}

.vip-deck-glow-left {
    position: absolute;
    width: 500px;
    height: 500px;
    top: 20%;
    left: -10%;
    background: radial-gradient(circle, rgba(114, 47, 55, 0.06) 0%, transparent 70%);
    filter: blur(100px);
    pointer-events: none;
}
.vip-deck-glow-right {
    position: absolute;
    width: 500px;
    height: 500px;
    bottom: 10%;
    right: -10%;
    background: radial-gradient(circle, rgba(201, 169, 98, 0.04) 0%, transparent 70%);
    filter: blur(100px);
    pointer-events: none;
}

/* Header UI Config */
.vip-deck-header-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 50px;
    width: 100%;
}

.vip-deck-meta-tag {
    font-family: var(--font-montserrat);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.3em;
    color: var(--color-amber);
    margin-bottom: 12px;
}

.vip-deck-main-title {
    font-family: var(--font-cinzel);
    font-size: clamp(2rem, 3.5vw, 3.2rem);
    letter-spacing: 0.1em;
    color: #ffffff;
    font-weight: 400;
    line-height: 1.1;
    margin-bottom: 12px;
}

.vip-deck-sub-bar {
    width: 40px;
    height: 1px;
    background: var(--color-amber);
}

/* Slider Main Container */
.vip-deck-slider-wrapper {
    position: relative !important;
    width: 100% !important;
}

/* Horizontal Track Layout */
.vip-deck-viewport {
    overflow-x: auto;
    scroll-behavior: smooth;
    padding: 10px 0;
    scrollbar-width: none;
    width: 100%;
}

.vip-deck-viewport::-webkit-scrollbar {
    display: none;
}

.vip-deck-track {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 24px;
    width: max-content;
}

/* The Magazine Style VIP Card Block */
.vip-deck-card {
    flex: 0 0 290px; 
    height: 440px;
    position: relative;
    cursor: pointer;
}

.vip-card-geometry {
    position: absolute;
    inset: 0;
    border-radius: 4px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.05);
    background: #080808;
    transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.4s ease;
}

.vip-card-img-wrapper {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    filter: brightness(0.85) contrast(1.02);
    transform: scale(1.01);
    transition: transform 0.7s cubic-bezier(0.16, 1, 0.3, 1), filter 0.4s ease;
}

/* Clean, sharp gold line wireframe accents */
.vip-card-frame-lines {
    position: absolute;
    inset: 16px;
    border: 1px solid rgba(201, 169, 98, 0.15);
    pointer-events: none;
    z-index: 3;
    transition: inset 0.5s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.4s ease;
}

/* High-Contrast Bottom Content Protection Overlay */
.vip-card-overlay-mask {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, 
        rgba(0, 0, 0, 0.95) 0%, 
        rgba(0, 0, 0, 0.4) 50%, 
        transparent 100%
    );
    z-index: 1;
    transition: background 0.4s ease;
}

/* Text Element Layouts */
.vip-card-content {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 32px 24px;
    z-index: 2;
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.vip-card-title {
    font-family: var(--font-cinzel);
    font-size: 20px;
    letter-spacing: 0.05em;
    color: #ffffff;
    font-weight: 500;
    margin-bottom: 4px;
}

.vip-card-sub {
    font-family: var(--font-poppins);
    font-size: 12px;
    color: rgba(255, 255, 255, 0.45);
    font-weight: 300;
}

/* Interactive Hover States */
.vip-deck-card:hover .vip-card-geometry {
    border-color: rgba(201, 169, 98, 0.35);
    transform: translateY(-6px);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.6);
}

.vip-deck-card:hover .vip-card-img-wrapper {
    transform: scale(1.06);
    filter: brightness(1) contrast(1.05);
}

.vip-deck-card:hover .vip-card-frame-lines {
    inset: 12px;
    border-color: var(--color-amber);
}

.vip-deck-card:hover .vip-card-overlay-mask {
    background: linear-gradient(to top, 
        rgba(114, 47, 55, 0.85) 0%, 
        rgba(0, 0, 0, 0.3) 60%, 
        transparent 100%
    );
}

.vip-deck-card:hover .vip-card-content {
    transform: translateY(-2px);
}


/* ============================================
   VIP DECK MOBILE ARROWS FIXED LAYOUT
============================================ */
.vip-deck-section {
    position: relative !important;
}

/* Slider viewport box wrapper */
.vip-deck-container {
    position: relative !important;
    width: 86% !important; /* Forces side padding for breathing room */
    margin: 0 auto !important;
    overflow: hidden !important;
}

/* Absolute control positioning alignment override for mobile arrows */
.vip-deck-section .btn-prev, 
.vip-deck-section .btn-next {
    position: absolute !important;
    top: 50% !important; /* Perfectly centers vertically along the card height */
    transform: translateY(-50%) !important;
    width: 44px !important;
    height: 44px !important;
    border-radius: 50% !important;
    background: rgba(0, 0, 0, 0.75) !important;
    border: 1px solid #c9a962 !important;
    color: #c9a962 !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    z-index: 999 !important; /* Pushes button layers to the absolute top grid */
    cursor: pointer !important;
    pointer-events: auto !important;
}

/* Position mapping anchors */
.vip-deck-section .btn-prev {
    left: 10px !important;
}

.vip-deck-section .btn-next {
    right: 10px !important;
}

/* Hides any broken native formatting elements on screen viewports */
.vip-deck-section .btn-prev::after,
.vip-deck-section .btn-next::after {
    display: none !important;
}

@media (max-width: 600px) {
    .vip-deck-container {
        width: 82% !important;
    }
    .vip-deck-section .btn-prev { left: 5px !important; }
    .vip-deck-section .btn-next { right: 5px !important; }
}



/* ============================================
   PERFECT ABSOLUTE LEFT & RIGHT LOCK ARROWS
============================================ */
.vip-deck-nav-btn {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 50px !important;
    height: 50px !important;
    border-radius: 50% !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    background: rgba(10, 10, 10, 0.85) !important;
    color: #ffffff !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    z-index: 100 !important;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

/* लेफ्ट एरो हमेशा इमेज बॉक्स के बाएं कोने के ऊपर लॉक रहेगा */
.vip-deck-nav-btn.btn-prev {
    left: -20px !important;
    right: auto !important;
}

/* राइट एरो हमेशा इमेज बॉक्स के दाएं कोने के ऊपर लॉक रहेगा */
.vip-deck-nav-btn.btn-next {
    right: -20px !important;
    left: auto !important;
}

.vip-deck-nav-btn svg {
    width: 20px !important;
    height: 20px !important;
}

.vip-deck-nav-btn:hover {
    border-color: var(--color-amber) !important;
    color: var(--color-amber) !important;
    background: rgba(201, 169, 98, 0.05) !important;
    box-shadow: 0 0 15px rgba(201, 169, 98, 0.4) !important;
}

@media (max-width: 992px) {
    .vip-deck-nav-btn.btn-prev { left: 5px !important; }
    .vip-deck-nav-btn.btn-next { right: 5px !important; }
}

@media (max-width: 768px) {
    .vip-deck-card {
        flex: 0 0 240px;
        height: 380px;
    }
}






/* ============================================
   UI/UX ENGINEERED CELEBRATIONS SECTION
============================================ */
.hx-banquet-section {
    position: relative !important;
    background-color: #050505 !important;
    padding: 120px 0 !important;
    overflow: hidden !important;
    border-bottom: 1px solid rgba(201, 169, 98, 0.08) !important;
    width: 100% !important;
    display: block !important;
}

/* आइसोलेटेड मास्टर कंटेनर - जो बाकी ग्रिड से डिस्टर्ब नहीं होगा */
.hx-banquet-master-container {
    width: 100% !important;
    max-width: 1320px !important;
    margin-right: auto !important;
    margin-left: auto !important;
    padding-left: 24px !important;
    padding-right: 24px !important;
    box-sizing: border-box !important;
    position: relative !important;
    z-index: 5 !important;
}

/* Ambient Luxury Lighting Backgrounds */
.hx-banquet-glow-1, .hx-banquet-glow-2 {
    position: absolute !important;
    width: 500px !important;
    height: 500px !important;
    pointer-events: none !important;
    filter: blur(130px) !important;
    z-index: 1 !important;
}
.hx-banquet-glow-1 { top: -5% !important; right: -5% !important; background: radial-gradient(circle, rgba(201, 169, 98, 0.05) 0%, transparent 70%) !important; }
.hx-banquet-glow-2 { bottom: -5% !important; left: -5% !important; background: radial-gradient(circle, rgba(114, 47, 55, 0.04) 0%, transparent 70%) !important; }

/* Centered Header Component */
.hx-banquet-header-node {
    text-align: center !important;
    max-width: 800px !important;
    margin: 0 auto 60px auto !important;
    display: block !important;
}

.hx-banquet-meta-label {
    font-family: var(--font-montserrat), 'Montserrat', sans-serif !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 0.35em !important;
    color: #c9a962 !important;
    margin-bottom: 14px !important;
    text-transform: uppercase !important;
}

.hx-banquet-display-title {
    font-family: var(--font-cinzel), 'Cinzel', serif !important;
    font-size: clamp(2.2rem, 3.8vw, 3.2rem) !important;
    letter-spacing: 0.06em !important;
    color: #ffffff !important;
    font-weight: 400 !important;
    line-height: 1.2 !important;
    margin: 0 0 18px 0 !important;
}

/* Luxury Divider Element */
.hx-banquet-luxury-divider {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 12px !important;
    margin-bottom: 24px !important;
}

.hx-wire-line {
    width: 50px !important;
    height: 1px !important;
    background: linear-gradient(90deg, transparent, #c9a962) !important;
}
.hx-banquet-luxury-divider .hx-wire-line:last-child {
    background: linear-gradient(90deg, #c9a962, transparent) !important;
}

.hx-spark-diamond {
    color: #c9a962 !important;
    font-size: 8px !important;
}

.hx-banquet-lead-text {
    font-family: var(--font-montserrat), 'Montserrat', sans-serif !important;
    font-size: 14px !important;
    color: rgba(255, 255, 255, 0.5) !important;
    line-height: 1.6 !important;
    font-weight: 300 !important;
    margin: 0 !important;
}

/* Forces 3-Column Layout Overriding any system crashes */
.hx-banquet-cards-wrapper {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 30px !important;
    width: 100% !important;
    justify-content: space-between !important;
}

/* Individual Card Structural Architecture */
.hx-event-premium-card {
    position: relative !important;
    height: 480px !important;
    flex: 1 !important; /* तीनों कार्ड्स को बराबर विड्थ में बाँधने के लिए */
    min-width: 0 !important;
}

.hx-event-card-surface {
    position: absolute !important;
    inset: 0 !important;
    background: #0d0d0d !important;
    border-radius: 6px !important;
    overflow: hidden !important;
    border: 1px solid rgba(255, 255, 255, 0.04) !important;
    transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.4s ease !important;
}

.hx-event-img-canvas {
    position: absolute !important;
    inset: 0 !important;
    background-size: cover !important;
    background-position: center !important;
    transform: scale(1) !important;
    transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.hx-event-shadow-overlay {
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(to top, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0.2) 60%, transparent 100%) !important;
    z-index: 2 !important;
}

/* Floating Numeric Badge */
.hx-event-index-tag {
    position: absolute !important;
    top: 24px !important;
    left: 24px !important;
    font-family: var(--font-montserrat), 'Montserrat', sans-serif !important;
    font-size: 10px !important;
    color: #ffffff !important;
    background: rgba(0, 0, 0, 0.7) !important;
    padding: 6px 14px !important;
    border-radius: 20px !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    letter-spacing: 0.12em !important;
    z-index: 3 !important;
}

/* Frosted Glass Content Panel - Fixed Text Visibility */
.hx-event-glass-capsule {
    position: absolute !important;
    bottom: 24px !important;
    left: 20px !important;
    right: 20px !important;
    background: rgba(12, 12, 12, 0.8) !important;
    backdrop-filter: blur(15px) !important;
    -webkit-backdrop-filter: blur(15px) !important;
    padding: 24px !important;
    border-radius: 4px !important;
    border: 1px solid rgba(255, 255, 255, 0.06) !important;
    z-index: 4 !important;
    transition: border-color 0.4s ease, background 0.4s ease !important;
}

.hx-event-main-title {
    font-family: var(--font-cinzel), 'Cinzel', serif !important;
    font-size: 18px !important;
    color: #ffffff !important;
    font-weight: 500 !important;
    margin: 0 0 6px 0 !important;
    letter-spacing: 0.04em !important;
}

.hx-event-sub-description {
    font-family: var(--font-montserrat), 'Montserrat', sans-serif !important;
    font-size: 12px !important;
    color: rgba(255, 255, 255, 0.45) !important;
    line-height: 1.5 !important;
    margin: 0 !important;
    font-weight: 300 !important;
}

/* Micro-Interactions on Hover */
.hx-event-premium-card:hover .hx-event-card-surface {
    transform: translateY(-8px) !important;
    border-color: rgba(201, 169, 98, 0.3) !important;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.8) !important;
}

.hx-event-premium-card:hover .hx-event-img-canvas {
    transform: scale(1.05) !important;
}

.hx-event-premium-card:hover .hx-event-glass-capsule {
    border-color: #c9a962 !important;
    background: rgba(18, 18, 18, 0.9) !important;
}

/* High-End Responsive Breakpoints */
@media (max-width: 992px) {
    .hx-banquet-cards-wrapper {
        flex-wrap: wrap !important;
    }
    .hx-event-premium-card {
        flex: 0 0 calc(50% - 15px) !important; 
    }
}

@media (max-width: 768px) {
    .hx-banquet-header-node { margin-bottom: 40px !important; }
    .hx-event-premium-card {
        flex: 0 0 100% !important; 
        height: 420px !important;
    }
}







/* ============================================
   THE LUXURY LOOKBOOK CLEAN GRID OVERHAUL
============================================ */
.luxury-mosaic-section {
    background: #000000;
    position: relative;
    padding: 120px 0;
    overflow: hidden;
    border-bottom: 1px solid rgba(201, 169, 98, 0.08);
}

.mosaic-glow-top {
    position: absolute;
    width: 600px;
    height: 600px;
    top: -10%;
    right: -10%;
    background: radial-gradient(circle, rgba(201, 169, 98, 0.03) 0%, transparent 70%);
    filter: blur(120px);
    pointer-events: none;
}
.mosaic-glow-bottom {
    position: absolute;
    width: 600px;
    height: 600px;
    bottom: -10%;
    left: -10%;
    background: radial-gradient(circle, rgba(114, 47, 55, 0.05) 0%, transparent 70%);
    filter: blur(120px);
    pointer-events: none;
}

.mosaic-header-block {
    text-align: center;
    margin-bottom: 50px;
}

.mosaic-meta-tag {
    font-family: var(--font-montserrat);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.35em;
    color: var(--color-amber);
    margin-bottom: 12px;
}

.mosaic-main-title {
    font-family: var(--font-cinzel);
    font-size: clamp(2.2rem, 3.8vw, 3.4rem);
    letter-spacing: 0.08em;
    color: #ffffff;
    font-weight: 400;
}

.mosaic-sub-bar {
    width: 50px;
    height: 1px;
    background: var(--color-amber);
    margin: 16px auto 0;
}

.mosaic-filter-ribbon {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 16px;
    margin-bottom: 50px;
    flex-wrap: wrap;
    background: rgba(10, 10, 10, 0.4);
    border: 1px solid rgba(255, 255, 255, 0.03);
    padding: 16px 32px;
    border-radius: 4px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    max-width: fit-content;
    margin-left: auto;
    margin-right: auto;
}

.mosaic-filter-btn {
    background: transparent;
    border: none;
    font-family: var(--font-montserrat);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.18em;
    color: rgba(255, 255, 255, 0.4);
    cursor: pointer;
    padding: 6px 4px;
    position: relative;
    transition: color 0.4s ease;
}

.mosaic-separator {
    color: rgba(201, 169, 98, 0.2);
    font-size: 8px;
    pointer-events: none;
}

.mosaic-filter-btn:hover { color: #ffffff; }
.mosaic-filter-btn.active { color: var(--color-amber); font-weight: 600; }

.mosaic-filter-btn.active::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 4px;
    right: 4px;
    height: 1px;
    background: var(--color-amber);
    box-shadow: 0 1px 6px var(--color-amber);
}

/* Symmetrical Grid Matrix Block */
.mosaic-aligned-matrix-grid {
display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)) !important;
    gap: 20px !important;
    width: 100% !important;
}

.hx-gallery-card {
    cursor: pointer !important;
    overflow: hidden !important;
    border-radius: 4px !important;
    position: relative !important;
}

.mosaic-actual-img {
    width: 100% !important;
    height: 300px !important;
    object-fit: cover !important;
    display: block !important;
    transition: transform 0.5s ease !important;
}

.hx-gallery-card:hover .mosaic-actual-img {
    transform: scale(1.05) !important;
}



@media (min-width: 768px) {
    .mosaic-aligned-matrix-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 20px;
    }
}

@media (min-width: 1024px) {
    .mosaic-aligned-matrix-grid {
        grid-template-columns: repeat(4, 1fr);
        gap: 24px;
    }
}

.mosaic-clean-panel {
    position: relative;
    width: 100%;
    aspect-ratio: 1 / 1;
    border-radius: 4px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.06);
    cursor: pointer;
    background: #050505;
    transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.4s ease, box-shadow 0.4s ease;
}

.mosaic-clean-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    filter: brightness(0.9) contrast(1.01);
    transform: scale(1.001);
    transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1), filter 0.5s ease;
}

.mosaic-clean-frame-lines {
    position: absolute;
    inset: 0px;
    border: 1px solid var(--color-amber);
    pointer-events: none;
    z-index: 3;
    opacity: 0;
    transition: inset 0.5s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.4s ease;
}

.mosaic-clean-shade {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.05);
    z-index: 1;
    transition: background 0.4s ease;
}

.mosaic-clean-panel:hover {
    border-color: rgba(201, 169, 98, 0.4);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.8);
}

.mosaic-clean-panel:hover .mosaic-clean-img {
    transform: scale(1.06);
    filter: brightness(1.02) contrast(1.04);
}

.mosaic-clean-panel:hover .mosaic-clean-frame-lines {
    opacity: 0.75;
    inset: 16px;
}

.mosaic-clean-panel:hover .mosaic-clean-shade {
    background: rgba(114, 47, 55, 0.12);
}

/* ============================================
   LIGHTBOX NAV & SLIDER SYSTEM STYLING
============================================ */
.lightbox {
    position: fixed;
    inset: 0;
    z-index: 2000;
    display: none;
    align-items: center;
    justify-content: space-between;
    background: rgba(0, 0, 0, 0.98);
    backdrop-filter: blur(25px);
    -webkit-backdrop-filter: blur(25px);
    padding: 0 40px;
}

.lightbox.active {
    display: flex;
}

.lightbox-content-wrapper {
    max-width: 75vw;
    max-height: 85vh;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    user-select: none;
}

.lightbox-img {
    max-width: 100%;
    max-height: 85vh;
    object-fit: contain;
    border-radius: 4px;
    box-shadow: 0 30px 60px rgba(0, 0, 0, 0.8);
    transition: opacity 0.3s cubic-bezier(0.16, 1, 0.3, 1), transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Luxury Slider Buttons */
.lightbox-nav-btn {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(15, 15, 15, 0.6);
    color: #ffffff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2010;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.lightbox-nav-btn svg {
    width: 24px;
    height: 24px;
    transition: transform 0.3s ease;
}

.lightbox-nav-btn:hover {
    border-color: var(--color-amber);
    color: var(--color-amber);
    background: rgba(201, 169, 98, 0.05);
}

.btn-lightbox-prev:hover svg { transform: translateX(-3px); }
.btn-lightbox-next:hover svg { transform: translateX(3px); }

.lightbox-close {
    position: absolute;
    top: 40px;
    right: 40px;
    background: none;
    border: none;
    color: rgba(255, 255, 255, 0.5);
    cursor: pointer;
    padding: 8px;
    z-index: 2020;
    transition: color 0.3s ease, transform 0.3s ease;
}

.lightbox-close:hover {
    color: var(--color-amber);
    transform: rotate(90deg);
}

.lightbox-close svg {
    width: 32px;
    height: 32px;
}

/* Mobile Adjustments for Slider Visibility */
@media (max-width: 768px) {
    .mosaic-aligned-matrix-grid {
        padding: 0 20px;
        gap: 12px;
    }
    .lightbox {
        padding: 0 16px;
    }
    .lightbox-content-wrapper {
        max-width: 100vw;
        max-height: 80vh;
    }
    /* Hide native arrow buttons on phone touch views to let swiping guide focus */
    .lightbox-nav-btn {
        display: none !important;
    }
}

/* ============================================
   THE ARCHITECTURE OF WONDER REGAL STYLING
============================================ */
.architecture-wonder-section {
    background: #000000;
    position: relative;
    padding: 120px 0;
    overflow: hidden;
    border-bottom: 1px solid rgba(201, 169, 98, 0.08);
}

.arch-wonder-glow-1 {
    position: absolute;
    width: 600px;
    height: 600px;
    top: -10%;
    left: -15%;
    background: radial-gradient(circle, rgba(114, 47, 55, 0.08) 0%, transparent 70%);
    filter: blur(120px);
    pointer-events: none;
}
.arch-wonder-glow-2 {
    position: absolute;
    width: 600px;
    height: 600px;
    bottom: -15%;
    right: -10%;
    background: radial-gradient(circle, rgba(201, 169, 98, 0.04) 0%, transparent 70%);
    filter: blur(120px);
    pointer-events: none;
}

.arch-wonder-header {
    text-align: center;
    margin-bottom: 72px;
}

.arch-wonder-meta {
    font-family: var(--font-montserrat);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.35em;
    color: var(--color-amber);
    margin-bottom: 14px;
}

.arch-wonder-title {
    font-family: var(--font-cinzel);
    font-size: clamp(2.2rem, 4.2vw, 3.4rem);
    letter-spacing: 0.06em;
    color: #ffffff;
    font-weight: 400;
    line-height: 1.15;
}

.arch-wonder-crest {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin-top: 20px;
}

.arch-wonder-crest .crest-wire {
    width: 60px;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--color-amber), transparent);
}

.arch-wonder-crest .crest-dot {
    color: var(--color-amber);
    font-size: 9px;
}

.arch-wonder-triptych-grid {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 32px;
    max-width: 1320px;
    margin: 0 auto;
    padding: 0 40px;
}

@media (min-width: 768px) {
    .arch-wonder-triptych-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 24px;
    }
}

@media (min-width: 1024px) {
    .arch-wonder-triptych-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 28px;
    }
}

/* Luxury Interactive Card Framework */
.wonder-pavilion-card {
    background: #080808;
    border: 1px solid rgba(255, 255, 255, 0.05);
    border-radius: 4px;
    position: relative;
    overflow: hidden;
    cursor: pointer;
    transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.4s ease, box-shadow 0.4s ease;
}

.pavilion-inner-geometry {
    padding: 44px 32px;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: relative;
    z-index: 5;
}

/* Interactive Top Indicator Bar */
.pavilion-progress-bar {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 3px;
    background: rgba(255, 255, 255, 0.02);
    z-index: 10;
}

.progress-fill {
    width: 0;
    height: 100%;
    background: var(--color-amber);
    transition: width 0.6s cubic-bezier(0.16, 1, 0.3, 1);
    box-shadow: 0 0 10px var(--color-amber);
}

/* Background Image Frame Window Layer */
.pavilion-bg-window {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    opacity: 0.15; /* Balanced ambient background value */
    transform: scale(1.01);
    transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.5s ease;
    z-index: 1;
}

.pavilion-matte-shade {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, 
        rgba(0, 0, 0, 0.95) 0%, 
        rgba(0, 0, 0, 0.7) 60%, 
        rgba(0, 0, 0, 0.85) 100%
    );
    z-index: 2;
    transition: background 0.4s ease;
}

/* Dynamic Outline Accents */
.pavilion-frame-lines {
    position: absolute;
    inset: 20px;
    border: 1px solid rgba(201, 169, 98, 0.1);
    pointer-events: none;
    z-index: 4;
    transition: inset 0.5s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.4s ease;
}

.pavilion-header-group {
    margin-bottom: 24px;
}

.pavilion-index {
    font-family: var(--font-montserrat);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.15em;
    color: rgba(255, 255, 255, 0.3);
    display: block;
    margin-bottom: 6px;
    transition: color 0.3s ease;
}

.pavilion-main-name {
    font-family: var(--font-cinzel);
    font-size: 19px;
    letter-spacing: 0.05em;
    color: #ffffff;
    font-weight: 500;
    transition: color 0.3s ease;
}

.pavilion-narrative {
    font-family: var(--font-poppins);
    font-size: 13.5px;
    line-height: 1.75;
    color: rgba(255, 255, 255, 0.5);
    font-weight: 300;
    margin-bottom: 32px;
    transition: color 0.3s ease;
}

/* Minimalist Action Capsule Trigger */
.pavilion-action-trigger {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 28px;
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 0.4s cubic-bezier(0.16, 1, 0.3, 1), transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.pavilion-action-trigger span {
    font-family: var(--font-montserrat);
    font-size: 9px;
    font-weight: 600;
    letter-spacing: 0.2em;
    color: var(--color-amber-light);
}

.pavilion-action-trigger svg {
    width: 14px;
    height: 14px;
    color: var(--color-amber-light);
    transition: transform 0.3s ease;
}

.pavilion-footer-metadata {
    width: 100%;
}

.metadata-line {
    width: 100%;
    height: 1px;
    background: rgba(255, 255, 255, 0.05);
    margin-bottom: 16px;
}

.metadata-tags {
    font-family: var(--font-montserrat);
    font-size: 9.5px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.35);
    line-height: 1.5;
    transition: color 0.3s ease;
}

/* Featured Visual Presets */
.wonder-pavilion-card.featured-card {
    border-color: rgba(201, 169, 98, 0.2);
}
.wonder-pavilion-card.featured-card .metadata-tags {
    color: var(--color-amber);
}

/* ============================================
   MASTER INTERACTION SWITCH TRIGGERS
============================================ */
.wonder-pavilion-card:hover {
    transform: translateY(-6px);
    border-color: rgba(201, 169, 98, 0.35);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.6);
}

/* Progress dash fills up entirely on active element focus */
.wonder-pavilion-card:hover .progress-fill {
    width: 100%;
}

/* Background image increases exposure illumination and executes zoom tracking */
.wonder-pavilion-card:hover .pavilion-bg-window {
    opacity: 0.35;
    transform: scale(1.06);
}

.wonder-pavilion-card:hover .pavilion-matte-shade {
    background: linear-gradient(to top, 
        rgba(0, 0, 0, 0.9) 0%, 
        rgba(114, 47, 55, 0.2) 50%, /* Elegant soft twilight accent wrap */
        rgba(0, 0, 0, 0.75) 100%
    );
}

/* Framelines expand outwards cleanly */
.wonder-pavilion-card:hover .pavilion-frame-lines {
    inset: 12px;
    border-color: var(--color-amber);
}

.wonder-pavilion-card:hover .pavilion-index { color: var(--color-amber); }
.wonder-pavilion-card:hover .pavilion-main-name { color: var(--color-amber-light); }
.wonder-pavilion-card:hover .pavilion-narrative { color: rgba(255, 255, 255, 0.75); }
.wonder-pavilion-card:hover .metadata-tags { color: #ffffff; }

/* Micro Button slides upwards into view smoothly */
.wonder-pavilion-card:hover .pavilion-action-trigger {
    opacity: 1;
    transform: translateY(0);
}

.wonder-pavilion-card:hover .pavilion-action-trigger:hover svg {
    transform: translateX(4px);
}

/* Isometric Isolation: Dims the rest of the deck when one card gets centered focus */
.arch-wonder-triptych-grid:has(.wonder-pavilion-card:hover) .wonder-pavilion-card:not(:hover) {
    opacity: 0.35;
    transform: scale(0.98);
}

@media (max-width: 768px) {
    .arch-wonder-triptych-grid {
        padding: 0 20px;
    }
    .wonder-pavilion-card {
        height: auto;
    }
    .pavilion-inner-geometry {
        padding: 36px 24px;
    }
    /* Lock interaction nodes to open default state layout arrays on small viewports */
    .pavilion-action-trigger {
        opacity: 1;
        transform: translateY(0);
    }
}




/* ============================================
   STICKY MOBILE BOTTOM ACTION BAR
============================================ */
.hx-mobile-sticky-bar {
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 60px !important;
    display: none !important; /* डिफ़ॉल्ट रूप से डेस्कटॉप पर छुपा रहेगा */
    grid-template-columns: 1fr 1fr !important; /* स्क्रीन को 50-50 के दो हिस्सों में बांटेगा */
    z-index: 999999 !important; /* सबसे ऊपर रखने के लिए हाई इंडेक्स */
    box-shadow: 0 -4px 15px rgba(0, 0, 0, 0.4) !important;
}

/* दोनों बटन्स के लिए कॉमन बेस स्टाइल */
.hx-sticky-btn {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    text-decoration: none !important;
    font-family: var(--font-montserrat), 'Montserrat', sans-serif !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    letter-spacing: 0.05em !important;
    height: 100% !important;
    transition: background 0.3s ease !important;
}

/* आइकॉन्स का साइज */
.hx-sticky-icon {
    width: 18px !important;
    height: 18px !important;
}

/* लेफ्ट साइड: कॉल बटन (लग्जरी थीम डार्क/गोल्ड) */
.hx-call-btn {
    background-color: #121212 !important;
    color: #ffffff !important;
    border-top: 1px solid rgba(201, 169, 98, 0.2) !important;
}
.hx-call-btn:active {
    background-color: #1a1a1a !important;
}

/* राइट साइड: व्हाट्सएप बटन (सॉलिड ब्रांड ग्रीन) */
.hx-wa-btn {
    background-color: #25D366 !important;
    color: #000000 !important;
}
.hx-wa-btn:active {
    background-color: #20ba59 !important;
}

/* ============================================
   RESPONSIVE SHOW/HIDE MEDIA QUERY
============================================ */
@media (max-width: 768px) {
    /* सिर्फ मोबाइल और टैबलेट स्क्रीन पर बार दिखाई देगी */
    .hx-mobile-sticky-bar {
        display: grid !important;
    }
    
    /* मोबाइल पर फ़ुटर का आखिरी कंटेंट बार के पीछे न छुपे, इसलिए बॉडी में बॉटम पैडिंग ऐड की */
    body {
        padding-bottom: 60px !important;
    }
}




/* ============================================
   RESERVATION WHATSAPP BUTTON UI FIXED
============================================ */
.hx-wa-submit-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 12px !important;
    background-color: #25D366 !important; /* व्हाट्सएप का ऑफिशियल सिग्नेचर ग्रीन */
    color: #000000 !important; /* डार्क बोल्ड टेक्स्ट */
    border: 1px solid #25D366 !important;
    font-weight: 600 !important;
    transition: all 0.4s ease !important;
    cursor: pointer !important;
    width: 100% !important;
}

/* व्हाट्सएप आइकॉन साइज कॉन्फ़िगरेशन */
.hx-wa-btn-icon {
    width: 18px !important;
    height: 18px !important;
}

/* होवर करने पर और आकर्षक ग्लो इफ़ेक्ट */
.hx-wa-submit-btn:hover {
    background-color: #20ba59 !important;
    border-color: #20ba59 !important;
    color: #000000 !important;
    box-shadow: 0 5px 20px rgba(37, 211, 102, 0.4) !important;
    transform: translateY(-2px) !important;
}

.hx-wa-submit-btn:active {
    transform: translateY(1px) !important;
}






/* ============================================
   FORCED STRUCTURAL ENGINE: BANQUET CARDS FIX
============================================ */
.hx-fixed-banquet-section {
    background-color: #000000 !important;
    padding: 60px 0 !important;
    width: 100% !important;
    position: relative !important;
    display: block !important;
    box-sizing: border-box !important;
}

.hx-banquet-grid-matrix-wrapper {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important; /* Forces perfect 3 columns layout */
    gap: 30px !important;
    width: 100% !important;
    max-width: 1200px !important;
    margin: 0 auto !important;
    box-sizing: border-box !important;
}

.hx-banquet-premium-card-node {
    width: 100% !important;
    min-height: 400px !important; /* फोर्स्ड मिनिमम हाइट ताकि पट्टियां न बनें */
    position: relative !important;
    box-sizing: border-box !important;
    display: block !important;
}

.hx-banquet-card-surface-box {
    width: 100% !important;
    height: 400px !important; /* फिक्स हाइट लॉक */
    position: relative !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    border: 1px solid rgba(255, 255, 255, 0.05) !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-end !important; /* कन्टेंट को नीचे रखने के लिए */
    box-sizing: border-box !important;
}

.hx-banquet-img-canvas-plane {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background-size: cover !important;
    background-position: center !important;
    transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1) !important;
    z-index: 1 !important;
}

.hx-banquet-premium-card-node:hover .hx-banquet-img-canvas-plane {
    transform: scale(1.08) !important; /* प्रीमियम ज़ूम इफेक्ट */
}

.hx-banquet-shadow-overlay-plane {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: linear-gradient(to top, rgba(0,0,0,0.95) 0%, rgba(0,0,0,0.4) 50%, transparent 100%) !important;
    z-index: 2 !important;
}

/* Glass Content Box Component Restored */
.hx-banquet-glass-capsule-core {
    position: relative !important;
    z-index: 3 !important;
    padding: 30px 25px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    text-align: left !important;
}

.hx-banquet-card-main-title {
    font-family: 'Cinzel', serif !important;
    font-size: 22px !important;
    color: #ffffff !important;
    margin: 0 0 10px 0 !important;
    font-weight: 400 !important;
    letter-spacing: 0.05em !important;
    display: block !important;
}

.hx-banquet-sub-description-text {
    font-family: 'Montserrat', sans-serif !important;
    font-size: 13px !important;
    color: rgba(255, 255, 255, 0.6) !important;
    line-height: 1.5 !important;
    margin: 0 !important;
    font-weight: 300 !important;
    display: block !important;
}

/* ============================================
   RESPONSIVE CORE BREAKPOINTS
============================================ */
@media (max-width: 992px) {
    .hx-banquet-grid-matrix-wrapper {
        grid-template-columns: repeat(2, 1fr) !important; /* टैबलेट पर 2 कॉलम */
    }
}

@media (max-width: 768px) {
    .hx-banquet-grid-matrix-wrapper {
        grid-template-columns: 1fr !important; /* मोबाइल पर सिंगल कॉलम फुल स्क्रीन वाइब */
    }
    .hx-banquet-card-surface-box, .hx-banquet-premium-card-node {
        height: 350px !important;
    }
}









/* ============================================
   UI/UX ARCHITECTURAL FIXES (NO OVERLAP)
============================================ */
.hx-wrapper-box {
    background-color: #000000 !important;
    padding: 60px 0 !important;
    font-family: 'Montserrat', 'Poppins', sans-serif !important;
    width: 100% !important;
    display: block !important;
    position: relative !important;
    box-sizing: border-box !important;
    color: #ffffff !important;
    margin-top: 90px !important;
}

.hx-pkg-master-container {
    width: 100% !important;
    max-width: 1200px !important;
    margin-right: auto !important;
    margin-left: auto !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
    box-sizing: border-box !important;
}

/* Header Text Align Block */
.hx-pkg-header-node {
    text-align: center !important;
    max-width: 800px !important;
    margin: 0 auto 50px auto !important;
    display: block !important;
}

.hx-pkg-meta-label {
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 0.35em !important;
    color: #d4a437 !important;
    margin-bottom: 12px !important;
    text-transform: uppercase !important;
}

.hx-pkg-display-title {
    font-family: 'Cinzel', serif !important;
    font-size: 38px !important;
    letter-spacing: 0.06em !important;
    color: #ffffff !important;
    font-weight: 400 !important;
    line-height: 1.3 !important;
    margin: 0 0 18px 0 !important;
}

.hx-pkg-luxury-divider {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 15px !important;
    margin-bottom: 24px !important;
}

.hx-wire-line {
    width: 60px !important;
    height: 1px !important;
    background: linear-gradient(90deg, transparent, #d4a437) !important;
}
.hx-pkg-luxury-divider .hx-wire-line:last-child {
    background: linear-gradient(90deg, #d4a437, transparent) !important;
}

.hx-spark-diamond {
    color: #d4a437 !important;
    font-size: 8px !important;
}

/* 2-Column Grid Core with Stack Flow */
.hx-banquet-cards-wrapper {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 40px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    margin-bottom: 60px !important;
}

.hx-event-premium-card {
    background: #050505 !important;
    border: 1px solid rgba(255, 255, 255, 0.04) !important;
    padding: 35px 25px !important;
    border-radius: 4px !important;
    box-sizing: border-box !important;
    display: flex !important;
    flex-direction: column !important;
    position: relative !important;
    height: 100% !important; /* सभी बॉक्स की ऊँचाई समान करने के लिए */
}

.hx-event-index-tag {
    font-size: 10px !important;
    color: #d4a437 !important;
    letter-spacing: 0.15em !important;
    font-weight: 600 !important;
    margin-bottom: 15px !important;
    display: block !important;
    text-align: left !important;
}

.hx-event-main-title {
    font-family: 'Cinzel', serif !important;
    font-size: 24px !important;
    color: #ffffff !important;
    font-weight: 400 !important;
    letter-spacing: 0.05em !important;
    margin: 15px 0 5px 0 !important;
    text-align: left !important;
}

.hx-event-sub-label {
    font-family: 'Cinzel', serif !important;
    font-size: 15px !important;
    color: #ffffff !important;
    font-weight: 300 !important;
    margin: 0 0 15px 0 !important;
    text-align: left !important;
}

/* Pricing Display */
.hx-pkg-price {
    font-family: 'Cinzel', serif !important;
    font-size: 24px !important;
    color: #d4a437 !important;
    font-weight: 500 !important;
    margin-bottom: 20px !important;
    text-align: left !important;
}

.hx-pkg-starting {
    font-size: 12px !important;
    color: rgba(255, 255, 255, 0.4) !important;
    font-family: 'Montserrat', sans-serif !important;
}

/* Info Description Frames */
.hx-pkg-specs {
    background: rgba(255, 255, 255, 0.02) !important;
    border-left: 2px solid #d4a437 !important;
    padding: 12px 18px !important;
    margin-bottom: 20px !important;
    font-size: 13px !important;
    color: rgba(255, 255, 255, 0.8) !important;
    line-height: 1.6 !important;
    text-align: left !important;
}
.hx-pkg-specs div { margin-bottom: 5px !important; }

/* Capacity Grid list */
.hx-caps-list-block ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 8px 0 0 0 !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 6px !important;
}
.hx-caps-list-block li { font-size: 12px !important; color: rgba(255,255,255,0.6) !important; }

/* Horizontal Guard for Scrollable Tables on Mobile Screen */
.hx-table-scroll-guard {
    width: 100% !important;
    overflow-x: auto !important;
    margin-bottom: 25px !important;
}

.hx-premium-table {
    width: 100% !important;
    border-collapse: collapse !important;
    min-width: 480px !important;
}

.hx-premium-table th {
    background: rgba(212, 164, 55, 0.08) !important;
    color: #d4a437 !important;
    font-family: 'Cinzel', serif !important;
    font-weight: 500;
    font-size: 11px !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    padding: 10px !important;
    text-align: left !important;
}

.hx-premium-table td {
    border: 1px solid rgba(255, 255, 255, 0.04) !important;
    padding: 10px !important;
    font-size: 12px !important;
    color: rgba(255, 255, 255, 0.55) !important;
    line-height: 1.4 !important;
    text-align: left !important;
}

/* Bottom Absolute-Safe CTA Buttons */
.hx-pkg-action-btn {
    width: 100% !important;
    padding: 15px 0 !important;
    background-color: transparent !important;
    color: #ffffff !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0.15em !important;
    cursor: pointer !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    border-radius: 4px !important;
    transition: all 0.4s ease !important;
    box-sizing: border-box !important;
    margin-top: auto !important; /* बटन को हमेशा बॉक्स के एंड में लॉक रखेगा बिना ओवरलैप के */
}

.hx-pkg-wa-icon {
    width: 16px !important;
    height: 16px !important;
    max-width: 16px !important;
    max-height: 16px !important;
}

.hx-pkg-action-btn:hover {
    background-color: #25D366 !important;
    border-color: #25D366 !important;
    color: #000000 !important;
    box-shadow: 0 5px 20px rgba(37, 211, 102, 0.3) !important;
}

.hx-pkg-featured-node {
    border-color: rgba(212, 164, 55, 0.25) !important;
    background: linear-gradient(145deg, #090909 0%, #020202 100%) !important;
}

/* Terms Component Block Styling */
.hx-pkg-terms-node {
    margin-top: 60px !important;
    border-top: 1px solid rgba(255, 255, 255, 0.05) !important;
    padding-top: 60px !important;
    text-align: left !important;
}

.hx-pkg-terms-title {
    font-family: 'Cinzel', serif !important;
    font-size: 32px !important;
    color: #ffffff !important;
    margin: 0 0 15px 0 !important;
    text-transform: uppercase !important;
}

.hx-pkg-terms-line {
    width: 60px !important;
    height: 2px !important;
    background: #d4a437 !important;
    margin-bottom: 40px !important;
}

.hx-pkg-terms-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 15px !important;
}

.hx-term-item {
    display: flex !important;
    align-items: flex-start !important;
    gap: 20px !important;
    background: rgba(255,255,255,0.01) !important;
    padding: 15px 20px !important;
    border-radius: 4px !important;
    border: 1px solid rgba(255,255,255,0.02) !important;
}

.hx-term-item span {
    font-family: 'Cinzel', serif !important;
    color: #d4a437 !important;
    font-size: 14px !important;
    font-weight: 600 !important;
}

.hx-term-item p {
    font-size: 13px !important;
    color: rgba(255, 255, 255, 0.5) !important;
    line-height: 1.6 !important;
    margin: 0 !important;
    text-align: left !important;
}

.hx-pkg-brand-box {
    margin: 60px auto 0 auto !important;
    text-align: center !important;
    padding: 45px 35px !important;
    border: 1px solid rgba(212, 164, 55, 0.2) !important;
    background: #080806 !important;
}

.hx-pkg-brand-box h3 {
    font-size: 26px !important;
    margin: 0 0 15px 0 !important;
    color: #d4a437 !important;
    font-family: 'Cinzel', serif !important;
}

.hx-pkg-brand-box p {
    font-size: 14px !important;
    line-height: 1.7 !important;
    color: rgba(255, 255, 255, 0.45) !important;
    margin: 0 !important;
}

/* ============================================
   ORIGINAL IMAGE SLIDER ENGINE FIXED
============================================ */
.package-image-slider {
    width: 100% !important;
    margin-bottom: 15px !important;
    display: block !important;
}

.slider-container {
    width: 100% !important;
    overflow: hidden !important;
    position: relative !important;
    border-radius: 12px !important;
}

.slides {
    display: flex !important;
    width: 5000% !important; /* रेडियो सिलेक्शन विड्थ फिक्स */
    transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.slide {
    width: 2% !important;
    flex-shrink: 0 !important;
}

.slide img {
    width: 100% !important;
    height: 320px !important;
    object-fit: cover !important;
    display: block !important;
    border-radius: 12px !important;
}

.package-image-slider input {
    display: none !important;
}

/* Radio Control Slider Triggers */
#p1-slide1:checked ~ .slides { transform: translateX(0%); }
#p1-slide2:checked ~ .slides { transform: translateX(-2%); }
#p1-slide3:checked ~ .slides { transform: translateX(-4%); }
#p1-slide4:checked ~ .slides { transform: translateX(-6%); }
#p1-slide5:checked ~ .slides { transform: translateX(-8%); }

#p2-slide1:checked ~ .slides { transform: translateX(0%); }
#p2-slide2:checked ~ .slides { transform: translateX(-2%); }
#p2-slide3:checked ~ .slides { transform: translateX(-4%); }
#p2-slide4:checked ~ .slides { transform: translateX(-6%); }
#p2-slide5:checked ~ .slides { transform: translateX(-8%); }
#p2-slide6:checked ~ .slides { transform: translateX(-10%); }

#p3-slide1:checked ~ .slides { transform: translateX(0%); }
#p3-slide2:checked ~ .slides { transform: translateX(-2%); }
#p3-slide3:checked ~ .slides { transform: translateX(-4%); }
#p3-slide4:checked ~ .slides { transform: translateX(-6%); }
#p3-slide5:checked ~ .slides { transform: translateX(-8%); }

#p4-slide1:checked ~ .slides { transform: translateX(0%); }
#p4-slide2:checked ~ .slides { transform: translateX(-2%); }
#p4-slide3:checked ~ .slides { transform: translateX(-4%); }
#p4-slide4:checked ~ .slides { transform: translateX(-6%); }
#p4-slide5:checked ~ .slides { transform: translateX(-8%); }

.navigation {
    position: absolute !important;
    bottom: 15px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    display: flex !important;
    gap: 10px !important;
    z-index: 10 !important;
}

.navigation label {
    width: 10px !important;
    height: 10px !important;
    border-radius: 50% !important;
    background: #ffffff !important;
    cursor: pointer !important;
    border: 1px solid #000000 !important;
    display: inline-block !important;
    transition: background 0.3s ease !important;
}

.navigation label:hover {
    background: #d4a437 !important;
}

/* Tablet & Mobile Breakpoints */
@media (max-width: 992px) {
    .hx-banquet-cards-wrapper {
        grid-template-columns: 1fr !important;
    }
    .hx-caps-list-block ul {
        grid-template-columns: 1fr !important;
    }
}







/* ============================================
   SPECIAL OCCASION CTA LUXURY STYLES
============================================ */
.hx-cta-luxury-node {
    margin-top: 80px !important;
    border-top: 1px solid rgba(255, 255, 255, 0.05) !important;
    padding: 80px 40px !important;
    text-align: center !important;
    background: linear-gradient(to bottom, rgba(212, 164, 55, 0.02) 0%, transparent 100%) !important;
    border-radius: 4px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    display: block !important;
}

.hx-cta-meta-label {
    font-family: 'Montserrat', sans-serif !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 0.35em !important;
    color: #d4a437 !important;
    margin-bottom: 16px !important;
    text-transform: uppercase !important;
}

.hx-cta-display-title {
    font-family: 'Cinzel', serif !important;
    font-size: clamp(1.8rem, 3.5vw, 2.8rem) !important;
    letter-spacing: 0.05em !important;
    color: #ffffff !important;
    font-weight: 400 !important;
    line-height: 1.4 !important;
    margin: 0 0 24px 0 !important;
}

.gold-gradient-text {
    background: linear-gradient(90deg, #d4a437 0%, #ffffff 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
}

/* Button Layout Wrapper */
.hx-cta-buttons-wrapper {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 20px !important;
    margin-top: 40px !important;
    flex-wrap: wrap !important;
}

/* Button Base Styles */
.hx-cta-btn {
    padding: 16px 35px !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0.15em !important;
    text-decoration: none !important;
    border-radius: 4px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    transition: all 0.4s ease !important;
    box-sizing: border-box !important;
    min-width: 220px !important;
}

/* 1. सॉलिड गोल्ड थीम बटन */
.hx-btn-gold {
    background-color: #d4a437 !important;
    color: #000000 !important;
    border: 1px solid #d4a437 !important;
}
.hx-btn-gold:hover {
    background-color: transparent !important;
    color: #ffffff !important;
    box-shadow: 0 5px 20px rgba(212, 164, 55, 0.2) !important;
}

/* 2. लग्जरी डार्क बॉर्डर बटन */
.hx-btn-dark {
    background-color: transparent !important;
    color: #ffffff !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
}
.hx-btn-dark:hover {
    border-color: #d4a437 !important;
    color: #d4a437 !important;
}

/* 3. व्हाट्सएप ब्रांड ग्रीन बटन */
.hx-btn-wa {
    background-color: transparent !important;
    color: #ffffff !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
}
.hx-btn-wa:hover {
    background-color: #25D366 !important;
    border-color: #25D366 !important;
    color: #000000 !important;
    box-shadow: 0 5px 20px rgba(37, 211, 102, 0.3) !important;
}

/* Responsive Tweak */
@media (max-width: 768px) {
    .hx-cta-luxury-node { padding: 50px 20px !important; }
    .hx-cta-buttons-wrapper { flex-direction: column !important; width: 100% !important; }
    .hx-cta-btn { width: 100% !important; }
}





/* ============================================
   GRAND FOOTER CORE ENGINE STYLE PARAMS
============================================ */
.luxury-grand-footer {
    background-color: #000000 !important;
    position: relative !important;
    padding: 80px 0 0 0 !important; /* बॉटम पैडिंग जीरो ताकि पट्टी छोटी लगे */
    width: 100% !important;
    display: block !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
    border-top: 1px solid rgba(255, 255, 255, 0.03) !important;
}

.footer-ambient-glow {
    position: absolute !important;
    bottom: 0 !important;
    right: -10% !important;
    width: 500px !important;
    height: 500px !important;
    background: radial-gradient(circle, rgba(201, 169, 98, 0.03) 0%, transparent 70%) !important;
    filter: blur(100px) !important;
    pointer-events: none !important;
    z-index: 1 !important;
}

/* 3-Column Header Deck */
.footer-directory-deck.hx-minimized-deck {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 0 20px 40px 20px !important;
    display: grid !important;
    grid-template-columns: 0.9fr 1.1fr 1.1fr !important;
    gap: 50px !important;
    align-items: start !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04) !important;
    box-sizing: border-box !important;
}

.footer-brand-monolith {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    text-align: left !important;
}

.footer-monolith-logo {
    max-width: 80px !important;
    height: auto !important;
    margin-bottom: 15px !important;
}

.footer-poetic-manifesto {
    font-size: 14px !important;
    font-style: italic !important;
    color: rgba(255, 255, 255, 0.4) !important;
    margin: 0 0 5px 0 !important;
}

.footer-monolith-title {
    font-family: 'Cinzel', serif !important;
    font-size: 24px !important;
    letter-spacing: 0.1em !important;
    color: #ffffff !important;
    margin: 0 !important;
}

.directory-node {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    text-align: left !important;
}

.directory-title {
    font-family: 'Cinzel', serif !important;
    font-size: 14px !important;
    color: #ffffff !important;
    letter-spacing: 0.1em !important;
    margin: 0 0 12px 0 !important;
}

.directory-accent-line {
    width: 35px !important;
    height: 1px !important;
    background: #d4a437 !important;
    margin-bottom: 20px !important;
}

.directory-hero-link {
    font-family: 'Cinzel', serif !important;
    font-size: 18px !important;
    color: #ffffff !important;
    text-decoration: none !important;
    line-height: 1.4 !important;
    margin-bottom: 10px !important;
    transition: color 0.3s ease !important;
}
.directory-hero-link:hover { color: #d4a437 !important; }

.gold-num {
    color: #d4a437 !important;
    display: block !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 16px !important;
    margin-top: 4px !important;
}

.directory-sub-link {
    font-size: 13px !important;
    color: rgba(255, 255, 255, 0.4) !important;
    text-decoration: none !important;
    transition: color 0.3s ease !important;
}
.directory-sub-link:hover { color: #ffffff !important; }

.directory-text-block {
    font-size: 13px !important;
    color: rgba(255, 255, 255, 0.5) !important;
    line-height: 1.6 !important;
    margin: 0 0 15px 0 !important;
}

.directory-hours-block {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
    font-size: 11px !important;
    letter-spacing: 0.05em !important;
    color: rgba(255, 255, 255, 0.35) !important;
}

/* Middle Bridge Grid Flex System */
.footer-vibe-bridge {
    max-width: 1200px !important;
    margin: 0 auto !important;
    padding: 40px 20px !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: flex-start !important;
    gap: 60px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04) !important;
    box-sizing: border-box !important;
}

.hx-footer-insta-box {
    flex: 1 !important;
    max-width: 600px !important;
    text-align: left !important;
}

/* Inline Header alignment for Instagram and Social Rings */
.hx-insta-header-inline {
    display: flex !important;
    justify-content: space-between !important;
    align-items: flex-end !important;
    width: 100% !important;
    margin-bottom: 12px !important;
}

.hx-insta-label, .hx-order-label {
    font-size: 10px !important;
    font-weight: 600 !important;
    letter-spacing: 0.3em !important;
    color: #d4a437 !important;
    margin-bottom: 6px !important;
    text-transform: uppercase !important;
}

.hx-insta-headline {
    font-family: 'Cinzel', serif !important;
    font-size: 26px !important;
    color: #ffffff !important;
    margin: 0 !important;
    letter-spacing: 0.05em !important;
}

.hx-insta-paragraph {
    font-size: 13px !important;
    color: rgba(255, 255, 255, 0.45) !important;
    line-height: 1.6 !important;
    margin: 0 !important;
    font-weight: 300 !important;
}

/* New Social Ribbon Placement rules */
.footer-social-ribbon-inline {
    display: flex !important;
    gap: 12px !important;
}

.social-icon-circle {
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    background: rgba(255, 255, 255, 0.02) !important;
    border: 1px solid rgba(255, 255, 255, 0.07) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: rgba(255, 255, 255, 0.4) !important;
    transition: all 0.3s ease !important;
}

.social-icon-circle svg {
    width: 15px !important;
    height: 15px !important;
}

.social-icon-circle:hover {
    color: #d4a437 !important;
    border-color: #d4a437 !important;
    background: rgba(212, 164, 55, 0.05) !important;
    transform: translateY(-2px) !important;
}

/* ============================================
   ORDER PLATFORMS - TEXT ONLY WITH BRAND HOVERS
============================================ */
.hx-footer-order-box {
    flex: 0 0 auto !important;
    text-align: left !important;
    min-width: 340px !important;
}

.hx-order-platforms {
    display: flex !important;
    gap: 12px !important;
    margin-top: 15px !important;
}

/* Base Button Style - Ultra Clean & Minimal */
.hx-aggregator-btn {
    flex: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 14px 20px !important;
    border-radius: 4px !important;
    background: rgba(255, 255, 255, 0.01) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    text-decoration: none !important;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1) !important;
    box-sizing: border-box !important;
}

/* Button Typography */
.hx-btn-label-text {
    font-family: 'Montserrat', sans-serif !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0.15em !important;
    color: rgba(255, 255, 255, 0.6) !important;
    transition: color 0.3s ease !important;
}

/* ZOMATO HOVER STATE - Brand Red Text & Glow */
.hx-aggregator-btn.hx-zomato-text-gate:hover {
    border-color: #E23744 !important;
    background: rgba(226, 55, 68, 0.03) !important;
    box-shadow: 0 4px 20px rgba(226, 55, 68, 0.15) !important;
}

.hx-zomato-text-gate:hover .hx-btn-label-text {
    color: #E23744 !important; /* Zomato Red Color On Hover */
}

/* SWIGGY HOVER STATE - Brand Orange Text & Glow */
.hx-aggregator-btn.hx-swiggy-text-gate:hover {
    border-color: #FC8019 !important;
    background: rgba(252, 128, 25, 0.03) !important;
    box-shadow: 0 4px 20px rgba(252, 128, 25, 0.15) !important;
}

.hx-swiggy-text-gate:hover .hx-btn-label-text {
    color: #FC8019 !important; /* Swiggy Orange Color On Hover */
}

/* Responsive adjustment for small mobiles */
@media (max-width: 480px) {
    .hx-footer-order-box {
        min-width: 100% !important;
    }
    .hx-order-platforms {
        flex-direction: column !important;
        gap: 10px !important;
    }
}

/* ============================================
   SLICK COPPYRIGHT PATTI AT ABSOLUTE CENTER
============================================ */
.footer-lower-grounding-min {
    width: 100% !important;
    background-color: #020202 !important; /* थोड़ी और डार्क और थिन पट्टी */
    padding: 18px 20px !important; /* पैडिंग कम करके पट्टी पतली की गई */
    box-sizing: border-box !important;
    text-align: center !important;
    display: block !important;
}

.copyright-text-center {
    font-size: 11px !important;
    color: rgba(255, 255, 255, 0.25) !important;
    margin: 0 !important;
    display: block !important;
    text-align: center !important;
    letter-spacing: 0.05em !important;
}

/* Responsive Structural Breakdown */
@media (max-width: 992px) {
    .footer-directory-deck.hx-minimized-deck {
        grid-template-columns: 1fr !important;
        gap: 35px !important;
    }
    .footer-vibe-bridge {
        flex-direction: column !important;
        gap: 35px !important;
    }
    .hx-insta-header-inline {
        flex-direction: row !important;
        align-items: center !important;
    }
    .hx-footer-insta-box, .hx-footer-order-box {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
    }
}

@media (max-width: 480px) {
    .hx-order-platforms {
        flex-direction: column !important;
    }
    .hx-insta-header-inline {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 15px !important;
    }
}







/* ============================================
   NEW CLEAN RESPONSIVE GRID HARDWARE
============================================ */
.luxury-mosaic-section {
    padding: 60px 0;
    background: #000;
    width: 100%;
    overflow: hidden;
}

.section-container {
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
}

/* Scroll-stopping horizontal ribbon for mobile chips */
.mosaic-filter-ribbon {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 15px;
    margin-bottom: 40px;
    flex-wrap: wrap;
}

/* User-friendly Mobile Grid Matrix Layout */
.mosaic-aligned-matrix-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important; /* Desktop Default */
    gap: 20px !important;
    width: 100% !important;
}

.mosaic-clean-panel {
    position: relative !important;
    width: 100% !important;
    height: 320px !important; /* Perfect balance square height */
    border-radius: 8px !important;
    overflow: hidden !important;
    cursor: pointer;
    border: 1px solid rgba(201, 169, 98, 0.2);
    transition: transform 0.3s ease, border-color 0.3s ease;
}

.mosaic-clean-panel:hover {
    transform: translateY(-5px);
    border-color: rgba(201, 169, 98, 0.8);
}

.mosaic-clean-img {
    width: 100% !important;
    height: 100% !important;
    background-size: cover !important;
    background-position: center !important;
    transition: transform 0.5s ease;
}

.mosaic-clean-panel:hover .mosaic-clean-img {
    transform: scale(1.05);
}

.mosaic-clean-shade {
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    background: linear-gradient(to bottom, transparent 60%, rgba(0,0,0,0.8));
}

/* ============================================
   RESPONSIVE MEDIA QUERIES (MOBILE FIX ENGINE)
============================================ */
@media (max-width: 992px) {
    .mosaic-aligned-matrix-grid {
        grid-template-columns: repeat(2, 1fr) !important; /* Tablets */
        gap: 15px !important;
    }
    .mosaic-clean-panel {
        height: 280px !important;
    }
}

@media (max-width: 600px) {
    /* Fluid Chip horizontal swipe rules for mobile viewports */
    .mosaic-filter-ribbon {
        justify-content: flex-start !important;
        flex-wrap: nowrap !important;
        overflow-x: auto !important;
        padding-bottom: 10px;
        -webkit-overflow-scrolling: touch;
        gap: 10px !important;
        width: 100%;
    }

    .mosaic-filter-btn {
        flex: 0 0 auto !important;
        padding: 8px 16px !important;
        font-size: 12px !important;
        background: rgba(201, 169, 98, 0.05);
        border: 1px solid rgba(201, 169, 98, 0.3);
        border-radius: 20px;
        color: #fff;
    }

    .mosaic-filter-btn.active {
        background: #c9a962 !important;
        color: #000 !important;
    }

    .mosaic-separator {
        display: none !important; /* Hide diamonds on mobile for clean look */
    }

    .mosaic-aligned-matrix-grid {
        grid-template-columns: repeat(2, 1fr) !important; /* User friendly 2-Column on Mobile Phones */
        gap: 10px !important;
    }

    .mosaic-clean-panel {
        height: 180px !important; /* Perfect mobile item asset aspect ratio box */
    }
}

/* ============================================
   LIGHTBOX USER EXPERIENCE MOBILE OPTIMIZATION
============================================ */
.lightbox {
    position: fixed;
    top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(0, 0, 0, 0.95);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 999999;
    opacity: 0; pointer-events: none;
    transition: opacity 0.3s ease;
}

.lightbox.active {
    opacity: 1; pointer-events: auto;
}

.lightbox-content-wrapper {
    max-width: 85%;
    max-height: 80%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.lightbox-img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    border-radius: 4px;
    border: 1px solid rgba(201, 169, 98, 0.3);
}

/* Big fat finger-friendly mobile action layout buttons */
.lightbox-nav-btn {
    position: absolute;
    background: rgba(0, 0, 0, 0.5);
    border: 1px solid rgba(201, 169, 98, 0.3);
    color: #c9a962;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    z-index: 10;
}

#lightbox-prev { left: 20px; }
#lightbox-next { right: 20px; }

.lightbox-close {
    position: absolute;
    top: 20px;
    right: 20px;
    background: none;
    border: none;
    color: #fff;
    width: 40px;
    height: 40px;
    cursor: pointer;
}

.lightbox-nav-btn svg, .lightbox-close svg {
    width: 24px;
    height: 24px;
}

@media (max-width: 768px) {
    /* Hide navigation arrows on tiny screens and lean on native touch fluid swipe gestures */
    .lightbox-nav-btn {
        display: none !important;
    }
    .lightbox-content-wrapper {
        max-width: 95%;
    }
}


/* Smooth Hover Animations */
.vip-insta-direct-link:hover .play-btn-circle {
    background: #c9a962 !important;
    transform: scale(1.1);
    box-shadow: 0 0 25px rgba(201,169,98,0.8) !important;
}
.vip-insta-direct-link:hover .play-btn-circle svg {
    fill: #000 !important;
}
.vip-insta-direct-link:hover .vip-card-img-wrapper {
    transform: scale(1.05) !important;
    transition: transform 0.4s ease !important;
}





/* ============================================
   CINEMATIC VIDEO HERO SECTION - FINE TUNING
============================================ */
#home {
    position: relative !important;
    height: 100vh !important;
    min-height: 500px !important;
    overflow: hidden !important;
    background: #000000 !important; /* Pure luxury background fallback */
}

/* Forces the embedded YouTube container to stretch perfectly without clipping gaps */
#hero-ambient-yt-player {
    width: 100vw !important;
    height: 56.25vw !important; /* Balanced 16:9 cinematic aspect ratio mapping */
    min-height: 100vh !important;
    min-width: 177.77vh !important;
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    z-index: 1 !important;
    pointer-events: none !important;
    opacity: 0.8 !important; /* Boosts visibility to show your elite footage clearly */
}

/* Compact Text and Tight Formatting Spacing Control */
.hero-content {
    position: relative !important;
    z-index: 5 !important;
    max-width: 850px !important;
    margin: 0 auto !important;
    padding: 0 20px !important;
    text-align: center !important;
}

.hero-label {
    font-size: 13px !important;
    letter-spacing: 5px !important;
    margin-bottom: 8px !important; /* Reduced layout space gap */
    opacity: 0.9;
}

.hero-title {
    font-size: clamp(42px, 6vw, 75px) !important; /* Dynamically resizes scale across devices */
    letter-spacing: 8px !important;
    line-height: 1.1 !important;
    margin: 0 0 12px 0 !important; /* Fixed tight bottom line height gap */
    font-weight: 700 !important;
    text-shadow: 0 4px 24px rgba(0, 0, 0, 0.75) !important;
}

.hero-subtitle {
    font-size: clamp(16px, 2vw, 22px) !important;
    font-style: italic !important;
    font-family: 'Playfair Display', serif !important;
    color: #e5e5e5 !important;
    margin-bottom: 24px !important; /* Compressed text block separation */
    letter-spacing: 1px !important;
}

.hero-divider {
    width: 60px !important;
    height: 1px !important;
    background: #c9a962 !important;
    margin: 0 auto 30px auto !important; /* Tighter margins for layout coherence */
    box-shadow: 0 0 8px #c9a962;
}

/* Buttons Spacing Tweaks */
.hero-buttons {
    display: flex !important;
    gap: 15px !important;
    justify-content: center !important;
    flex-wrap: wrap !important;
    margin-top: 10px !important;
}

.hero-buttons .btn-primary,
.hero-buttons .btn-secondary {
    padding: 14px 32px !important;
    font-size: 12px !important;
    letter-spacing: 2px !important;
    border-radius: 4px !important;
    transition: all 0.3s cubic-bezier(0.25, 1, 0.5, 1) !important;
}

/* Clean Overlays handling so they dont wash out video colors */
.hero-overlay {
    position: absolute !important;
    top: 0; left: 0; width: 100%; height: 100%;
    background: radial-gradient(circle, transparent 30%, rgba(0,0,0,0.65) 100%) !important;
    z-index: 2 !important;
    pointer-events: none !important;
}

/* Mobile Devices Optimization Layer Override */
@media (max-width: 600px) {
    #hero-ambient-yt-player {
        opacity: 0.85 !important; /* Clear view on low-brightness phone displays */
    }
    .hero-content {
        padding-top: 25vh !important; /* Centers block cleanly on mobile viewports */
    }
    .hero-title {
        letter-spacing: 4px !important;
    }
    .hero-buttons {
        flex-direction: column !important;
        width: 100% !important;
        max-width: 280px !important;
        margin: 0 auto !important;
        gap: 12px !important;
    }
}



@media (max-width: 768px) {
    .hero-content {
        padding-top: 15vh !important;
    }
    .hero-buttons {
        flex-direction: column !important;
        align-items: center !important;
    }
    .hero-buttons a {
        width: 100% !important;
        max-width: 280px !important;
        text-align: center;
    }
}




