/* ═══════════════════════════════════════════════════════════════
   style.css — Ammachi Kadai | Luxury Maroon & Gold Theme v8.0
   Warm Maroon Heritage · Premium UI · Tamil Chettinad Aesthetic
   Production Ready · Mobile-First · Full Responsive
═══════════════════════════════════════════════════════════════ */
/* ── CSS Variables ──────────────────────────────────────────── */
:root { /* ── Core Palette — Warmer, richer maroon (less pure black) ── */
  --maroon-dark:      #110003; /* was #060000 — now has warmth */
  --maroon-base:      #1c0006; /* was #140000 */
  --maroon-mid:       #2d0009; /* was #250000 */
  --maroon-rich:      #480010; /* was #3d0000 — deeper crimson */
  --maroon-accent:    #6b1220; /* was #5e0e0e — richer */
  --maroon-surface:   #3a000e; /* new: card surfaces, lifted */
  --maroon-lift:      #220008; /* new: slightly above base */
  /* ── Gold Palette ── */
  --gold:             #c9922a; --gold-light:       #e2aa40; --gold-bright:      #f0c060; --gold-pale:        #faeabb; --gold-warm:        #d4a03a; /* new: warm mid-gold */
  --gold-muted:       rgba(201,146,42,0.13); --gold-glow:        rgba(201,146,42,0.24); --gold-glow-lg:     rgba(201,146,42,0.45); --gold-glow-xl:     rgba(201,146,42,0.65); /* ── Warmth Overlays — key to removing the "black void" feel ── */
  --warm-glow-1:      rgba(180, 60, 20, 0.06); /* subtle crimson warmth */
  --warm-glow-2:      rgba(201,146,42,0.04); /* gold warmth base */
  /* ── Text ── */
  --white:            #ffffff; --white-90:         rgba(255,255,255,0.92); --white-70:         rgba(255,255,255,0.72); --white-50:         rgba(255,255,255,0.52); --white-40:         rgba(255,255,255,0.40); --white-20:         rgba(255,255,255,0.14); --white-10:         rgba(255,255,255,0.08); --white-5:          rgba(255,255,255,0.04); /* ── Shadows ── */
  --shadow:           rgba(0,0,0,0.50); --shadow-lg:        rgba(0,0,0,0.78); --shadow-warm:      rgba(100,10,0,0.40); /* warm-tinted shadow */
  /* ── Typography ── */
  --font-display:     'Cormorant Garamond', Georgia, serif; --font-body:        'DM Sans', -apple-system, sans-serif; /* ── Layout ── */
  --section-pad:      100px; --section-pad-md:   72px; --section-pad-sm:   52px; --container-max:    1220px; --gap:              28px; --radius-sm:        8px; --radius:           13px; --radius-lg:        20px; --radius-xl:        30px; /* ── Motion ── */
  --ease:             cubic-bezier(0.4, 0, 0.2, 1); --spring:           cubic-bezier(0.34, 1.56, 0.64, 1); --dur:              0.36s; --dur-slow:         0.60s; /* ── Nav ── */
  --nav-h:            68px; --drawer-w:         300px; }
/* ── Reset ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; overflow-x: hidden; font-size: 16px; }
body { background-color: var(--maroon-dark); /* Subtle warm ambient gradient on the body itself */
  background-image:
    radial-gradient(ellipse 140% 60% at 50% 0%, rgba(100,10,20,0.35) 0%, transparent 60%),
    radial-gradient(ellipse 80% 40% at 10% 100%, rgba(100,10,0,0.18) 0%, transparent 50%); color: var(--white); font-family: var(--font-body); line-height: 1.75; overflow-x: hidden; }
img { max-width: 100%; display: block; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; }
button { cursor: pointer; font-family: var(--font-body); border: none; background: none; }
input, select, textarea { font-family: var(--font-body); }
::selection { background: var(--gold); color: var(--maroon-dark); }
/* ── Scrollbar ──────────────────────────────────────────────── */
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--maroon-base); }
::-webkit-scrollbar-thumb { background: linear-gradient(180deg, var(--gold-bright), var(--gold)); border-radius: 4px; }
/* ── Container ──────────────────────────────────────────────── */
.container { max-width: var(--container-max); margin: 0 auto; padding: 0 clamp(16px, 5vw, 44px); }
/* ══════════════════════════════════════════════════════════════
   PAGE LOADER
══════════════════════════════════════════════════════════════ */
.page-loader { position: fixed; inset: 0; background: var(--maroon-dark); background-image:
    radial-gradient(ellipse 100% 80% at 50% 0%, rgba(100,10,20,0.50) 0%, transparent 65%); z-index: 9999; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 24px; transition: opacity 0.55s var(--ease), visibility 0.55s; }
.page-loader.hidden { opacity: 0; visibility: hidden; pointer-events: none; }
.loader-brand { display: flex; align-items: center; justify-content: center; }
.loader-logo { height: 72px; width: auto; object-fit: contain; animation: loaderPulse 1.3s ease-in-out infinite; filter: drop-shadow(0 0 20px rgba(201,146,42,0.50)); }
.loader-logo-text { font-family: var(--font-display); font-size: 2.8rem; color: var(--gold); letter-spacing: 2px; animation: loaderPulse 1.3s ease-in-out infinite; }
.loader-bar { width: 120px; height: 2px; background: rgba(201,146,42,0.15); border-radius: 2px; overflow: hidden; }
.loader-bar::after { content: ''; display: block; height: 100%; background: linear-gradient(90deg, transparent, var(--gold-bright), transparent); animation: loaderSlide 1.3s ease-in-out infinite; }
@keyframes loaderPulse {
 0%, 100% { opacity: 0.35; transform: scale(0.97); }
50% { opacity: 1; transform: scale(1); }
 }
@keyframes loaderSlide {
 0% { transform: translateX(-100%); }
100% { transform: translateX(200%); }
 }
/* ══════════════════════════════════════════════════════════════
   NAVBAR
══════════════════════════════════════════════════════════════ */
.navbar { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; height: var(--nav-h); display: flex; align-items: center; justify-content: space-between; padding: 0 clamp(16px, 5vw, 56px); gap: 16px; background: rgba(18,0,5,0.90); backdrop-filter: blur(28px) saturate(1.8); -webkit-backdrop-filter: blur(28px) saturate(1.8); border-bottom: 1px solid rgba(201,146,42,0.18); transition: background var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.navbar.scrolled { background: rgba(18,0,5,0.97); box-shadow: 0 4px 40px rgba(100,10,0,0.45), 0 1px 0 rgba(201,146,42,0.22); border-color: rgba(201,146,42,0.30); }
/* ── Brand Logo ── */
.nav-brand { display: flex; align-items: center; flex-shrink: 0; position: relative; z-index: 1010; text-decoration: none; }
.nav-logo-img { height: 48px; width: auto; object-fit: contain; display: block; filter: drop-shadow(0 2px 10px rgba(201,146,42,0.28)); transition: filter var(--dur) var(--ease), transform var(--dur) var(--spring); }
.nav-brand:hover .nav-logo-img { filter: drop-shadow(0 4px 18px rgba(201,146,42,0.55)); transform: scale(1.03); }
.nav-logo-fallback { font-family: var(--font-display); font-size: clamp(1.2rem,3vw,1.75rem); font-weight: 700; color: var(--gold); letter-spacing: 0.4px; white-space: nowrap; line-height: 1; }
/* ── Desktop Nav Links ── */
.nav-links { display: flex; align-items: center; gap: clamp(4px,1.5vw,28px); list-style: none; margin: 0; padding: 0; flex: 1; justify-content: flex-end; }
.nav-link { color: var(--white-70); font-size: 0.875rem; font-weight: 500; letter-spacing: 0.2px; white-space: nowrap; position: relative; padding-bottom: 3px; transition: color var(--dur) var(--ease); display: inline-block; }
.nav-link::after { content: ''; position: absolute; bottom: -2px; left: 0; width: 0; height: 1px; background: var(--gold); transition: width var(--dur) var(--ease); }
.nav-link:hover { color: var(--gold-light); }
.nav-link:hover::after { width: 100%; }
/* ── CTA Pill ── */
.nav-cta { display: inline-flex !important; align-items: center; gap: 7px; background: linear-gradient(135deg, var(--gold), var(--gold-light)) !important; color: var(--maroon-dark) !important; padding: 9px 20px !important; border-radius: 50px !important; font-weight: 700 !important; font-size: 0.84rem !important; box-shadow: 0 4px 20px var(--gold-glow); transition: transform var(--dur) var(--spring), box-shadow var(--dur) var(--ease) !important; white-space: nowrap; }
.nav-cta::after { display: none !important; }
.nav-cta:hover { color: var(--maroon-dark) !important; transform: translateY(-2px) !important; box-shadow: 0 8px 32px var(--gold-glow-lg) !important; }
/* ── User Meta ── */
.nav-user-item { list-style: none; }
.nav-user-wrap { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.nav-avatar { width: 32px; height: 32px; background: rgba(201,146,42,0.15); border: 1.5px solid var(--gold); border-radius: 50%; display: grid; place-items: center; font-size: 0.8rem; color: var(--gold); font-weight: 700; flex-shrink: 0; }
.nav-username { font-size: 0.84rem; color: var(--white-70); max-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.nav-logout { font-size: 0.8rem !important; color: var(--white-40) !important; padding: 6px 14px !important; border: 1px solid var(--white-10) !important; border-radius: 50px !important; transition: all var(--dur) var(--ease) !important; white-space: nowrap; }
.nav-logout:hover { border-color: rgba(201,146,42,0.38) !important; color: var(--gold-light) !important; background: var(--gold-muted) !important; }
/* ══════════════════════════════════════════════════════════════
   HAMBURGER BUTTON
══════════════════════════════════════════════════════════════ */
.nav-toggle { display: none; position: relative; z-index: 1010; width: 44px; height: 44px; background: rgba(201,146,42,0.10); border: 1px solid rgba(201,146,42,0.32); border-radius: 10px; flex-direction: column; align-items: center; justify-content: center; gap: 5px; flex-shrink: 0; cursor: pointer; transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.nav-toggle:hover { background: var(--gold-muted); border-color: rgba(201,146,42,0.55); }
.nav-toggle.is-open { background: var(--gold-muted); border-color: rgba(201,146,42,0.55); }
.hamburger-line { display: block; width: 20px; height: 2px; background: var(--gold); border-radius: 2px; transform-origin: center; transition: transform 0.35s var(--ease), opacity 0.35s var(--ease), width 0.35s var(--ease); }
.hamburger-line:nth-child(2) { width: 14px; align-self: flex-start; margin-left: 12px; }
.nav-toggle.is-open .hamburger-line:nth-child(1) { transform: translateY(7px) rotate(45deg); width: 20px; }
.nav-toggle.is-open .hamburger-line:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-toggle.is-open .hamburger-line:nth-child(3) { transform: translateY(-7px) rotate(-45deg); width: 20px; }
/* ══════════════════════════════════════════════════════════════
   MOBILE MENU DRAWER
══════════════════════════════════════════════════════════════ */
.nav-backdrop { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.65); z-index: 1020; backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); transition: opacity 0.35s var(--ease); opacity: 0; }
.nav-backdrop.show { display: block; opacity: 1; }
.mobile-menu { position: fixed; top: 0; right: 0; width: min(var(--drawer-w), 85vw); height: 100dvh; height: 100vh; z-index: 1030; background:
    radial-gradient(ellipse at top right, rgba(201,146,42,0.09) 0%, transparent 50%),
    radial-gradient(ellipse at bottom left, rgba(120,10,20,0.18) 0%, transparent 55%),
    linear-gradient(180deg, var(--maroon-base) 0%, #150004 100%); border-left: 1px solid rgba(201,146,42,0.20); box-shadow: -8px 0 60px rgba(0,0,0,0.70), -2px 0 20px rgba(100,10,20,0.30); display: flex; flex-direction: column; transform: translateX(100%); transition: transform 0.40s cubic-bezier(0.4,0,0.2,1); overflow-y: auto; overflow-x: hidden; overscroll-behavior: contain; }
.mobile-menu.open { transform: translateX(0); }
.mobile-menu-header { display: flex; align-items: center; justify-content: space-between; padding: 18px 20px 16px; border-bottom: 1px solid rgba(201,146,42,0.14); background: rgba(18,0,5,0.50); flex-shrink: 0; }
.mobile-brand { display: flex; align-items: center; text-decoration: none; }
.mobile-logo-img { height: 40px; width: auto; object-fit: contain; filter: drop-shadow(0 2px 8px rgba(201,146,42,0.30)); }
.mobile-logo-fallback { font-family: var(--font-display); font-size: 1.4rem; font-weight: 700; color: var(--gold); letter-spacing: 0.4px; }
.mobile-close-btn { width: 38px; height: 38px; background: rgba(201,146,42,0.10); border: 1px solid rgba(201,146,42,0.30); border-radius: 9px; display: grid; place-items: center; color: var(--gold-light); font-size: 1rem; cursor: pointer; transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease),
              transform var(--dur) var(--spring), color var(--dur) var(--ease); flex-shrink: 0; }
.mobile-close-btn:hover { background: rgba(201,146,42,0.20); border-color: rgba(201,146,42,0.55); color: var(--gold-bright); transform: rotate(90deg); }
.mobile-menu-divider { height: 1px; background: linear-gradient(90deg, transparent, rgba(201,146,42,0.28), transparent); flex-shrink: 0; }
.mobile-nav-links { list-style: none; margin: 0; padding: 12px 12px 0; display: flex; flex-direction: column; gap: 3px; flex: 1; }
.mobile-menu.open .mobile-nav-links li { animation: drawerItemIn 0.40s var(--ease) both; }
.mobile-menu.open .mobile-nav-links li:nth-child(1) { animation-delay: 0.06s; }
.mobile-menu.open .mobile-nav-links li:nth-child(2) { animation-delay: 0.10s; }
.mobile-menu.open .mobile-nav-links li:nth-child(3) { animation-delay: 0.14s; }
.mobile-menu.open .mobile-nav-links li:nth-child(4) { animation-delay: 0.18s; }
.mobile-menu.open .mobile-nav-links li:nth-child(5) { animation-delay: 0.22s; }
.mobile-menu.open .mobile-nav-links li:nth-child(6) { animation-delay: 0.26s; }
@keyframes drawerItemIn {
 from { opacity: 0; transform: translateX(20px); }
to { opacity: 1; transform: translateX(0); }
 }
.mobile-nav-link { display: flex; align-items: center; gap: 14px; padding: 14px 16px; border-radius: var(--radius); border: 1px solid transparent; color: var(--white-70); font-size: 0.95rem; font-weight: 500; text-decoration: none; transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease),
              color var(--dur) var(--ease), transform var(--dur) var(--spring); position: relative; }
.mobile-nav-link:hover,
.mobile-nav-link:focus { background: rgba(201,146,42,0.10); border-color: rgba(201,146,42,0.24); color: var(--gold-light); transform: translateX(3px); }
.mnl-icon { width: 36px; height: 36px; background: rgba(201,146,42,0.10); border: 1px solid rgba(201,146,42,0.18); border-radius: 9px; display: grid; place-items: center; font-size: 0.85rem; color: var(--gold); flex-shrink: 0; transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.mobile-nav-link:hover .mnl-icon { background: rgba(201,146,42,0.18); border-color: rgba(201,146,42,0.42); }
.mnl-arrow { margin-left: auto; font-size: 0.68rem; color: var(--white-40); flex-shrink: 0; transition: transform var(--dur) var(--ease), color var(--dur) var(--ease); }
.mobile-nav-link:hover .mnl-arrow { transform: translateX(3px); color: var(--gold); }
.mobile-nav-cta { background: rgba(201,146,42,0.12); border-color: rgba(201,146,42,0.32) !important; color: var(--gold-light) !important; font-weight: 600; margin-top: 6px; }
.mobile-nav-cta .mnl-icon { background: rgba(201,146,42,0.20); border-color: rgba(201,146,42,0.40); color: var(--gold-bright); }
.mobile-nav-cta:hover { background: rgba(201,146,42,0.20) !important; border-color: rgba(201,146,42,0.50) !important; color: var(--gold-bright) !important; }
.mobile-user-block { margin-top: 12px; }
.mobile-user-inner { display: flex; align-items: center; gap: 12px; padding: 14px 16px; background: rgba(201,146,42,0.07); border: 1px solid rgba(201,146,42,0.20); border-radius: var(--radius); }
.mobile-avatar { width: 40px; height: 40px; background: rgba(201,146,42,0.15); border: 1.5px solid var(--gold); border-radius: 50%; display: grid; place-items: center; font-size: 1rem; color: var(--gold); font-weight: 700; flex-shrink: 0; }
.mobile-user-info { flex: 1; min-width: 0; }
.mobile-user-name { display: block; font-size: 0.9rem; font-weight: 600; color: var(--white-90); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mobile-user-role { display: block; font-size: 0.72rem; color: var(--gold); margin-top: 2px; text-transform: uppercase; letter-spacing: 1px; }
.mobile-logout-btn { width: 36px; height: 36px; background: rgba(231,76,60,0.10); border: 1px solid rgba(231,76,60,0.25); border-radius: 9px; display: grid; place-items: center; color: rgba(231,76,60,0.7); font-size: 0.88rem; text-decoration: none; flex-shrink: 0; transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease), color var(--dur) var(--ease); }
.mobile-logout-btn:hover { background: rgba(231,76,60,0.20); border-color: rgba(231,76,60,0.52); color: #ff7c6e; }
.mobile-menu-footer { padding: 16px 20px 24px; border-top: 1px solid rgba(201,146,42,0.12); display: flex; flex-direction: column; gap: 14px; flex-shrink: 0; background: rgba(18,0,5,0.35); margin-top: auto; }
.mobile-contact { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; font-size: 0.78rem; color: var(--white-40); }
.mobile-contact-link { display: flex; align-items: center; gap: 5px; color: var(--white-40); text-decoration: none; transition: color var(--dur) var(--ease); }
.mobile-contact-link:hover { color: var(--gold); }
.mobile-contact-link i { color: var(--gold); font-size: 0.72rem; }
.mobile-timing { display: flex; align-items: center; gap: 5px; }
.mobile-timing i { color: var(--gold); font-size: 0.72rem; }
.mobile-contact-sep { color: var(--white-10); }
.mobile-social { display: flex; gap: 8px; flex-wrap: wrap; }
.mobile-social a { width: 34px; height: 34px; background: var(--white-5); border: 1px solid var(--white-10); border-radius: 8px; display: grid; place-items: center; color: var(--white-40); font-size: 0.85rem; text-decoration: none; transition: all var(--dur) var(--ease); }
.mobile-social a:hover { background: var(--gold-muted); border-color: rgba(201,146,42,0.40); color: var(--gold); transform: translateY(-2px); }
/* ── Breakpoints ── */
@media (min-width: 821px) {
 .nav-toggle { display: none !important; }
.nav-links { display: flex !important; }
.mobile-menu { display: none !important; }
.nav-backdrop { display: none !important; }
 }
@media (max-width: 820px) {
 .nav-toggle { display: flex; }
.nav-links { display: none; }
.mobile-menu { display: flex; }
 }
@media (max-width: 380px) {
 .navbar { padding: 0 12px; }
.nav-logo-img { height: 38px; }
.nav-toggle { width: 40px; height: 40px; }
:root { --drawer-w: 280px; }
 }
/* ══════════════════════════════════════════════════════════════
   HERO SECTION
══════════════════════════════════════════════════════════════ */
.hero { min-height: 100svh; display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; /* Warm maroon background — no longer pure black */
  background:
    radial-gradient(ellipse 120% 70% at 50% -10%, rgba(140,30,30,0.55) 0%, transparent 55%),
    radial-gradient(ellipse 60% 50% at 80% 80%, rgba(100,10,0,0.30) 0%, transparent 55%),
    radial-gradient(ellipse 50% 40% at 10% 90%, rgba(120,15,5,0.22) 0%, transparent 55%),
    var(--maroon-dark); padding: clamp(96px, 15vw, 130px) clamp(16px, 5vw, 40px) clamp(60px, 8vw, 80px); }
.hero-pattern { position: absolute; inset: 0; background-image: radial-gradient(circle, rgba(201,146,42,0.18) 1px, transparent 1px); background-size: 42px 42px; opacity: 0.40; pointer-events: none; }
.hero-line-l, .hero-line-r { position: absolute; top: 50%; width: 1px; height: 220px; transform: translateY(-50%); background: linear-gradient(180deg, transparent 0%, var(--gold) 50%, transparent 100%); opacity: 0.35; }
.hero-line-l { left: clamp(20px, 6vw, 90px); }
.hero-line-r { right: clamp(20px, 6vw, 90px); }
.hero-content { position: relative; z-index: 2; text-align: center; max-width: 880px; width: 100%; }
.hero-eyebrow { display: inline-flex; align-items: center; gap: 10px; background: rgba(201,146,42,0.14); border: 1px solid rgba(201,146,42,0.32); border-radius: 50px; padding: 7px 20px; font-size: 0.76rem; font-weight: 600; color: var(--gold-bright); letter-spacing: 2.5px; text-transform: uppercase; margin-bottom: 28px; animation: fadeUp 0.9s 0.1s var(--ease) both; backdrop-filter: blur(8px); }
.hero-eyebrow::before { content: '✦'; font-size: 0.65rem; color: var(--gold); }
.hero-title { font-family: var(--font-display); font-size: clamp(3.2rem, 10vw, 8rem); font-weight: 700; color: var(--gold); line-height: 0.95; letter-spacing: 1px; margin-bottom: 16px; animation: fadeUp 0.9s 0.2s var(--ease) both; text-shadow: 0 4px 40px rgba(201,146,42,0.25), 0 2px 80px rgba(180,30,20,0.30); }
.hero-title em { font-style: italic; color: var(--gold-bright); font-weight: 400; }
.hero-tagline { font-size: clamp(0.8rem, 2vw, 1rem); color: var(--gold-light); font-weight: 400; letter-spacing: 4px; text-transform: uppercase; margin-bottom: 24px; animation: fadeUp 0.9s 0.3s var(--ease) both; }
.hero-divider { display: flex; align-items: center; justify-content: center; gap: 18px; margin: 0 auto 26px; animation: fadeUp 0.9s 0.35s var(--ease) both; }
.hero-divider span { display: block; height: 1px; width: 70px; background: linear-gradient(90deg, transparent, var(--gold)); }
.hero-divider span:last-child { background: linear-gradient(270deg, transparent, var(--gold)); }
.hero-divider .diamond { color: var(--gold); font-size: 0.65rem; opacity: 0.85; }
.hero-desc { font-size: clamp(0.9rem, 1.8vw, 1.06rem); color: var(--white-70); max-width: 560px; margin: 0 auto 44px; line-height: 1.90; animation: fadeUp 0.9s 0.4s var(--ease) both; }
.hero-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; animation: fadeUp 0.9s 0.5s var(--ease) both; }
.scroll-cue { position: absolute; bottom: 28px; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; gap: 7px; color: var(--white-40); font-size: 0.68rem; letter-spacing: 2.5px; text-transform: uppercase; animation: scrollPulse 2.8s ease-in-out infinite; white-space: nowrap; }
.scroll-cue::after { content: ''; display: block; width: 1px; height: 36px; background: linear-gradient(180deg, var(--gold-light), transparent); animation: scrollLine 2.8s ease-in-out infinite; }
@keyframes scrollPulse {
 0%, 100% { opacity: 0.35; transform: translateX(-50%) translateY(0); }
50% { opacity: 0.80; transform: translateX(-50%) translateY(7px); }
 }
@keyframes scrollLine {
 0% { opacity: 0; transform: scaleY(0); transform-origin: top; }
50% { opacity: 1; transform: scaleY(1); }
100% { opacity: 0; transform: scaleY(0); transform-origin: bottom; }
 }
@keyframes fadeUp {
 from { opacity: 0; transform: translateY(36px); }
to { opacity: 1; transform: translateY(0); }
 }
/* ══════════════════════════════════════════════════════════════
   SHARED SECTION UTILITIES
══════════════════════════════════════════════════════════════ */
section { padding: var(--section-pad) 0; }
.section-eyebrow { display: block; text-align: center; font-size: 0.74rem; font-weight: 600; letter-spacing: 3.5px; text-transform: uppercase; color: var(--gold); margin-bottom: 14px; }
.section-title { font-family: var(--font-display); font-size: clamp(2rem, 5vw, 3.8rem); font-weight: 700; color: var(--gold); text-align: center; line-height: 1.12; margin-bottom: 14px; text-shadow: 0 2px 30px rgba(201,146,42,0.20); }
.section-sub { text-align: center; color: var(--white-70); font-size: clamp(0.9rem, 1.8vw, 1.02rem); max-width: 560px; margin: 0 auto 56px; line-height: 1.85; }
.ornament { display: flex; align-items: center; justify-content: center; gap: 14px; margin: 0 auto 18px; width: fit-content; }
.ornament::before, .ornament::after { content: ''; display: block; height: 1px; width: 46px; background: var(--gold); opacity: 0.48; }
.ornament .diamond-icon { color: var(--gold); font-size: 0.75rem; }
/* ══════════════════════════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════════════════════════ */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 13px 32px; border-radius: 50px; font-weight: 600; font-size: 0.9rem; letter-spacing: 0.25px; border: 2px solid transparent; transition: transform var(--dur) var(--spring), box-shadow var(--dur) var(--ease),
              background var(--dur) var(--ease), color var(--dur) var(--ease),
              border-color var(--dur) var(--ease); cursor: pointer; white-space: nowrap; text-decoration: none; line-height: 1; }
.btn:active { transform: scale(0.96) !important; }
.btn-gold { background: linear-gradient(135deg, var(--gold), var(--gold-light)); color: var(--maroon-dark); box-shadow: 0 6px 24px var(--gold-glow), 0 2px 8px rgba(100,10,0,0.30); }
.btn-gold:hover { transform: translateY(-3px); box-shadow: 0 14px 40px var(--gold-glow-lg); }
.btn-outline { background: transparent; color: var(--gold); border-color: var(--gold); backdrop-filter: blur(4px); }
.btn-outline:hover { background: var(--gold); color: var(--maroon-dark); transform: translateY(-3px); }
.btn-lg { padding: 16px 42px; font-size: 1rem; }
.btn-full { width: 100%; }
/* ══════════════════════════════════════════════════════════════
   MENU SECTION — v5.0 Warm Premium
══════════════════════════════════════════════════════════════ */
.menu { background:
    radial-gradient(ellipse 100% 60% at 50% 0%, rgba(80,10,10,0.30) 0%, transparent 55%),
    var(--maroon-dark); }
/* ── Tab Navigation ── */
.menu-tabs { display: flex; justify-content: center; gap: 10px; margin-bottom: 48px; flex-wrap: wrap; }
.menu-tab { display: inline-flex; align-items: center; gap: 8px; padding: 12px 26px; border-radius: 50px; border: 1px solid rgba(201,146,42,0.28); background: rgba(201,146,42,0.04); color: var(--white-70); font-size: 0.88rem; font-weight: 600; font-family: var(--font-body); cursor: pointer; transition: all var(--dur) var(--ease); white-space: nowrap; letter-spacing: 0.2px; }
.menu-tab:hover { border-color: var(--gold); color: var(--gold-light); background: rgba(201,146,42,0.10); transform: translateY(-2px); }
.menu-tab.active { background: linear-gradient(135deg, var(--gold), var(--gold-light)); border-color: transparent; color: var(--maroon-dark); box-shadow: 0 6px 24px var(--gold-glow-lg); transform: translateY(-2px); }
.tab-icon { line-height: 1; display: flex; align-items: center; }
.tab-icon i { font-size: 1.05rem; }
.tab-label { font-size: 0.88rem; }
.tab-count { background: rgba(0,0,0,0.18); font-size: 0.72rem; font-weight: 700; padding: 2px 8px; border-radius: 50px; min-width: 22px; text-align: center; line-height: 1.6; opacity: 0.85; }
.menu-tab:not(.active) .tab-count { background: rgba(201,146,42,0.14); color: var(--gold); }
/* ── Tab Panels ── */
.menu-tab-panel { display: none; animation: tabFadeIn 0.38s var(--ease) both; }
.menu-tab-panel.active { display: block; }
@keyframes tabFadeIn {
 from { opacity: 0; transform: translateY(14px); }
to { opacity: 1; transform: translateY(0); }
 }
/* ── Panel Header ── */
.menu-panel-header { display: flex; align-items: center; justify-content: space-between; gap: 20px; margin-bottom: 36px; padding: 20px 26px; background:
    linear-gradient(135deg, rgba(201,146,42,0.09) 0%, rgba(100,10,10,0.25) 100%); border: 1px solid rgba(201,146,42,0.20); border-radius: var(--radius-lg); flex-wrap: wrap; box-shadow: inset 0 1px 0 rgba(201,146,42,0.10); }
.mph-left { display: flex; align-items: center; gap: 16px; }
.mph-icon { display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.mph-icon i { font-size: 2rem; color: var(--gold); line-height: 1; }
.mph-title { font-family: var(--font-display); font-size: clamp(1rem, 2.2vw, 1.35rem); color: var(--gold-light); font-weight: 600; margin-bottom: 3px; line-height: 1.2; }
.mph-sub { font-size: 0.82rem; color: var(--white-40); line-height: 1.5; }
.mph-note { display: inline-flex; align-items: center; gap: 7px; background: rgba(201,146,42,0.10); border: 1px solid rgba(201,146,42,0.24); color: var(--gold-light); padding: 7px 16px; border-radius: 50px; font-size: 0.77rem; font-weight: 600; white-space: nowrap; flex-shrink: 0; }
.mph-note i { color: var(--gold); font-size: 0.9rem; }
@media (max-width: 600px) {
 .menu-panel-header { padding: 16px; }
.mph-note { width: 100%; justify-content: center; }
 }
/* ── Sub-heading ── */
.menu-sub-heading { display: flex; align-items: center; gap: 10px; margin-bottom: 24px; padding: 13px 20px; background: linear-gradient(90deg, rgba(201,146,42,0.08) 0%, rgba(100,10,10,0.15) 100%); border: 1px solid rgba(201,146,42,0.18); border-radius: var(--radius); }
.menu-sub-heading i { font-size: 1.05rem; color: var(--gold); flex-shrink: 0; }
.menu-sub-heading span:last-child { font-size: 0.87rem; font-weight: 600; color: var(--white-70); letter-spacing: 0.3px; }
.msh-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.msh-dot.veg { background: #27ae60; }
.msh-dot.non { background: #e74c3c; }
/* ══════════════════════════════════════════════════════════════
   COMBO CARDS (Breakfast / Dinner)
══════════════════════════════════════════════════════════════ */
.menu-combo-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(min(100%, 270px), 1fr)); gap: 20px; }
.combo-card { background:
    linear-gradient(155deg, rgba(201,146,42,0.06) 0%, rgba(80,5,10,0.50) 100%),
    var(--maroon-surface); border: 1px solid rgba(201,146,42,0.17); border-radius: var(--radius-lg); overflow: hidden; position: relative; display: flex; flex-direction: column; transition: transform var(--dur) var(--spring), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.combo-card:hover { transform: translateY(-7px); box-shadow: 0 24px 56px var(--shadow-warm), 0 0 0 1px rgba(201,146,42,0.25); border-color: rgba(201,146,42,0.42); }
/* Number Badge */
.combo-number { position: absolute; top: 14px; left: 14px; z-index: 10; width: 34px; height: 34px; background: linear-gradient(135deg, var(--gold), var(--gold-light)); color: var(--maroon-dark); font-size: 0.76rem; font-weight: 800; border-radius: 9px; display: grid; place-items: center; font-family: var(--font-display); box-shadow: 0 3px 12px var(--gold-glow); letter-spacing: 0.3px; }
/* Card Header */
.combo-header { padding: 16px 16px 14px 58px; min-height: 62px; display: flex; align-items: center; gap: 10px; background: linear-gradient(135deg, rgba(201,146,42,0.10) 0%, transparent 100%); border-bottom: 1px solid rgba(201,146,42,0.14); position: relative; }
.combo-header::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, var(--gold), var(--gold-light), transparent); opacity: 0.50; }
.combo-header-icon { display: flex; align-items: center; justify-content: center; width: 28px; height: 28px; flex-shrink: 0; color: var(--gold); opacity: 0.65; }
.combo-header-icon i { font-size: 1.1rem; line-height: 1; }
.combo-name { font-family: var(--font-display); font-size: 1.05rem; font-weight: 700; color: var(--gold-light); line-height: 1.25; }
/* Items List */
.combo-items { padding: 18px 18px 14px; display: flex; flex-direction: column; gap: 9px; flex: 1; }
.combo-item { display: flex; align-items: center; gap: 11px; font-size: 0.84rem; color: var(--white-70); line-height: 1.45; padding: 7px 12px; border-radius: 8px; border: 1px solid transparent; transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease), color var(--dur) var(--ease); }
.combo-item:hover { background: rgba(201,146,42,0.07); border-color: rgba(201,146,42,0.16); color: var(--white-90); }
.ci-icon { display: flex; align-items: center; justify-content: center; flex-shrink: 0; width: 22px; height: 22px; background: rgba(201,146,42,0.12); border: 1px solid rgba(201,146,42,0.22); border-radius: 6px; }
.ci-icon i { font-size: 0.80rem; color: var(--gold); line-height: 1; }
/* Footer */
.combo-footer { display: flex; align-items: center; justify-content: space-between; padding: 11px 16px 14px; border-top: 1px solid rgba(201,146,42,0.10); margin-top: auto; background: rgba(18,0,5,0.25); }
.combo-veg-tag { display: inline-flex; align-items: center; gap: 6px; background: rgba(39,174,96,0.10); border: 1px solid rgba(39,174,96,0.28); color: #5dd88a; font-size: 0.72rem; font-weight: 600; padding: 4px 12px; border-radius: 50px; letter-spacing: 0.2px; }
.veg-dot-sm { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.veg-dot-sm.veg { background: #27ae60; }
.veg-dot-sm.non { background: #e74c3c; }
.combo-count-badge { display: inline-flex; align-items: center; gap: 5px; font-size: 0.72rem; color: var(--white-40); font-weight: 600; }
.combo-count-badge i { font-size: 0.82rem; color: var(--gold); opacity: 0.75; }
@media (max-width: 640px) {
 .menu-combo-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
.combo-header { padding: 13px 10px 12px 48px; min-height: 56px; }
.combo-name { font-size: 0.90rem; }
.combo-number { width: 30px; height: 30px; font-size: 0.68rem; border-radius: 8px; }
.combo-items { padding: 14px 14px 10px; gap: 7px; }
.combo-item { font-size: 0.77rem; padding: 6px 10px; gap: 9px; }
.ci-icon { width: 20px; height: 20px; border-radius: 5px; }
.ci-icon i { font-size: 0.72rem; }
.combo-footer { padding: 9px 12px 12px; }
 }
@media (max-width: 380px) {
 .menu-combo-grid { grid-template-columns: 1fr; }
.combo-item { font-size: 0.82rem; }
 }
/* ══════════════════════════════════════════════════════════════
   LUNCH — Day-wise Cards
══════════════════════════════════════════════════════════════ */
.lunch-day-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(min(100%, 260px), 1fr)); gap: 18px; }
.lunch-day-card { background:
    linear-gradient(155deg, rgba(201,146,42,0.06) 0%, rgba(80,5,10,0.45) 100%),
    var(--maroon-surface); border: 1px solid rgba(201,146,42,0.15); border-radius: var(--radius-lg); overflow: hidden; display: flex; flex-direction: column; transition: transform var(--dur) var(--spring), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.lunch-day-card:hover { transform: translateY(-6px); box-shadow: 0 20px 50px var(--shadow-warm), 0 0 0 1px rgba(201,146,42,0.25); border-color: rgba(201,146,42,0.40); }
.ldc-header { padding: 15px 16px 13px; background: linear-gradient(135deg, rgba(201,146,42,0.10) 0%, transparent 100%); border-bottom: 1px solid rgba(201,146,42,0.12); }
.ldc-day-badge { display: inline-flex; align-items: center; gap: 6px; background: linear-gradient(135deg, var(--gold), var(--gold-light)); color: var(--maroon-dark); font-size: 0.70rem; font-weight: 800; padding: 3px 11px; border-radius: 50px; letter-spacing: 0.5px; text-transform: uppercase; margin-bottom: 9px; }
.ldc-day-badge i { font-size: 0.78rem; }
.ldc-main-dish { font-family: var(--font-display); font-size: 1.05rem; font-weight: 700; color: var(--gold-light); line-height: 1.25; }
.ldc-items { padding: 14px 16px 10px; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.ldc-item { display: flex; align-items: center; gap: 9px; font-size: 0.81rem; color: var(--white-70); line-height: 1.4; }
.ldc-item i { font-size: 0.90rem; color: var(--gold); flex-shrink: 0; opacity: 0.80; width: 14px; text-align: center; }
.ldc-item--staple { color: var(--white-40); }
.ldc-item--staple i { opacity: 0.45; }
.ldc-footer { padding: 10px 16px 13px; border-top: 1px solid rgba(201,146,42,0.10); margin-top: auto; }
@media (max-width: 768px) {
 .lunch-day-grid { grid-template-columns: repeat(auto-fill, minmax(min(100%, 220px), 1fr)); gap: 13px; }
.ldc-main-dish { font-size: 0.95rem; }
.ldc-items { padding: 12px 14px 8px; gap: 5px; }
.ldc-item { font-size: 0.76rem; }
 }
@media (max-width: 480px) {
 .lunch-day-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
.ldc-header { padding: 11px 12px 10px; }
.ldc-main-dish { font-size: 0.88rem; }
.ldc-day-badge { font-size: 0.64rem; padding: 2px 9px; }
.ldc-items { padding: 10px 12px 8px; gap: 4px; }
.ldc-item { font-size: 0.72rem; gap: 7px; }
.ldc-footer { padding: 7px 12px 10px; }
.menu-sub-heading { padding: 11px 14px; }
.menu-sub-heading span:last-child { font-size: 0.80rem; }
 }
@media (max-width: 360px) {
 .lunch-day-grid { grid-template-columns: 1fr; }
 }
/* ══════════════════════════════════════════════════════════════
   FOOD CARDS (Snacks / Non-Veg Lunch)
══════════════════════════════════════════════════════════════ */
.menu-regular-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(min(100%, 290px), 1fr)); gap: 22px; }
.food-card { background:
    linear-gradient(155deg, rgba(201,146,42,0.06) 0%, rgba(80,5,10,0.50) 100%),
    var(--maroon-surface); border: 1px solid rgba(201,146,42,0.17); border-radius: var(--radius-lg); overflow: hidden; display: flex; flex-direction: column; transition: transform var(--dur) var(--spring), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease); }
.food-card:hover { transform: translateY(-7px); box-shadow: 0 22px 56px var(--shadow-warm), 0 0 0 1px rgba(201,146,42,0.24); border-color: rgba(201,146,42,0.40); }
.food-card-header { display: flex; align-items: center; gap: 10px; padding: 16px 18px 14px; background: linear-gradient(135deg, rgba(201,146,42,0.08) 0%, transparent 100%); border-bottom: 1px solid rgba(201,146,42,0.12); flex-wrap: wrap; }
.food-veg-indicator { width: 20px; height: 20px; border-radius: 4px; border: 1.5px solid; display: grid; place-items: center; flex-shrink: 0; background: rgba(18,0,5,0.60); }
.food-veg-indicator.veg { border-color: #27ae60; }
.food-veg-indicator.veg span { width: 8px; height: 8px; border-radius: 50%; background: #27ae60; display: block; }
.food-veg-indicator.non { border-color: #e74c3c; }
.food-veg-indicator.non span { width: 8px; height: 8px; border-radius: 50%; background: #e74c3c; display: block; }
.food-card-name { font-family: var(--font-display); font-size: 1.12rem; font-weight: 700; color: var(--gold-light); line-height: 1.2; flex: 1; }
.food-cat-badge { background: rgba(18,0,5,0.65); border: 1px solid rgba(201,146,42,0.32); color: var(--gold-light); font-size: 0.68rem; font-weight: 600; padding: 3px 10px; border-radius: 50px; letter-spacing: 0.3px; white-space: nowrap; flex-shrink: 0; }
.food-card-img-wrap { position: relative; width: 100%; height: 210px; overflow: hidden; background: var(--maroon-rich); flex-shrink: 0; }
.food-card-img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.52s var(--ease); }
.food-card:hover .food-card-img { transform: scale(1.06); }
.food-card-img-placeholder { display: none; position: absolute; inset: 0; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--maroon-mid), var(--maroon-rich)); }
.food-card-img-placeholder i { font-size: 3rem; color: var(--gold); opacity: 0.28; }
.food-card-img-wrap.img-error .food-card-img { display: none; }
.food-card-img-wrap.img-error .food-card-img-placeholder { display: flex; }
.food-card-body { padding: 16px 18px 20px; display: flex; flex-direction: column; gap: 7px; flex: 1; }
.food-item-row { display: flex; align-items: baseline; gap: 9px; font-size: 0.83rem; color: var(--white-70); line-height: 1.45; }
.fi-bullet { color: var(--gold); font-size: 0.46rem; flex-shrink: 0; opacity: 0.75; position: relative; top: -1px; }
.food-desc { font-size: 0.85rem; color: var(--white-70); line-height: 1.7; }
@media (max-width: 600px) {
 .menu-regular-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
.food-card-img-wrap { height: 155px; }
.food-card-name { font-size: 0.92rem; }
.food-cat-badge { display: none; }
.food-card-body { padding: 12px 14px 16px; gap: 5px; }
.food-item-row, .food-desc { font-size: 0.76rem; }
.food-card-header { padding: 13px 14px 11px; gap: 8px; }
 }
@media (max-width: 380px) {
 .menu-regular-grid { grid-template-columns: 1fr; }
.food-card-img-wrap { height: 200px; }
.food-card-name { font-size: 1rem; }
.food-cat-badge { display: inline-block; }
 }
/* ── Coming Soon ── */
.menu-coming-soon { text-align: center; padding: 80px 20px; background: rgba(50,5,10,0.60); border: 1px dashed rgba(201,146,42,0.24); border-radius: var(--radius-xl); }
.mcs-icon { margin-bottom: 16px; }
.mcs-icon i { font-size: 3rem; color: var(--gold); opacity: 0.55; }
.menu-coming-soon h4 { font-family: var(--font-display); font-size: 1.5rem; color: var(--gold-light); margin-bottom: 8px; }
.menu-coming-soon p { color: var(--white-40); font-size: 0.9rem; }
.menu-filters { display: none !important; }
/* ══════════════════════════════════════════════════════════════
   BOOKING SECTION
══════════════════════════════════════════════════════════════ */
.booking { background:
    radial-gradient(ellipse 80% 60% at 80% 50%, rgba(130,20,10,0.30) 0%, transparent 55%),
    radial-gradient(ellipse 60% 50% at 10% 30%, rgba(100,5,5,0.22) 0%, transparent 55%),
    linear-gradient(160deg, var(--maroon-base) 0%, var(--maroon-dark) 100%); position: relative; overflow: hidden; }
.booking::before { content: ''; position: absolute; bottom: -30%; right: -10%; width: 700px; height: 700px; background: radial-gradient(circle, rgba(201,146,42,0.08) 0%, transparent 65%); pointer-events: none; }
.booking-strip { background:
    linear-gradient(135deg, rgba(201,146,42,0.07) 0%, rgba(80,5,10,0.60) 100%),
    var(--maroon-mid); border: 1px solid rgba(201,146,42,0.30); border-radius: var(--radius-xl); padding: clamp(24px, 5vw, 52px); box-shadow: 0 0 90px rgba(201,146,42,0.15), 0 0 40px rgba(100,5,5,0.30),
              inset 0 1px 0 rgba(201,146,42,0.12); display: flex; align-items: center; gap: 40px; flex-wrap: wrap; justify-content: space-between; }
.booking-perks { display: flex; gap: 10px; flex-wrap: wrap; flex: 1; min-width: 220px; }
.booking-perk { display: flex; align-items: center; gap: 8px; background: rgba(201,146,42,0.06); border: 1px solid rgba(201,146,42,0.16); border-radius: 50px; padding: 9px 16px; font-size: 0.86rem; color: var(--white-70); white-space: nowrap; transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease), color var(--dur) var(--ease); }
.booking-perk:hover { border-color: rgba(201,146,42,0.35); background: var(--gold-muted); color: var(--gold-light); }
.perk-icon { font-size: 1rem; }
.booking-cta-block { display: flex; flex-direction: column; align-items: center; gap: 12px; min-width: 260px; flex-shrink: 0; }
.booking-main-btn { padding: 18px 44px !important; font-size: 1.08rem !important; font-weight: 700 !important; letter-spacing: 0.3px; border-radius: 50px !important; box-shadow: 0 8px 32px var(--gold-glow-lg) !important; }
.booking-main-btn:hover { transform: translateY(-3px) !important; }
.booking-note { font-size: 0.8rem; color: var(--white-40); text-align: center; line-height: 1.65; }
.booking-note strong { color: var(--gold-light); }
.slot-confirmed { background: rgba(39,174,96,0.09); border: 1px solid rgba(39,174,96,0.32); border-radius: var(--radius-lg); padding: 24px 28px; text-align: center; }
.slot-tick { font-size: 2rem; display: block; margin-bottom: 8px; }
.slot-confirmed strong { display: block; color: #5dd88a; font-family: var(--font-display); font-size: 1.25rem; margin-bottom: 6px; }
.slot-confirmed p { font-size: 0.82rem; color: var(--white-40); line-height: 1.65; }
.slot-email { color: var(--gold-light); }
@media (max-width: 768px) {
 .booking-strip { flex-direction: column; align-items: stretch; gap: 24px; padding: 24px 18px; border-radius: var(--radius-lg); }
.booking-perks { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; min-width: unset; width: 100%; }
.booking-perk { justify-content: center; text-align: center; padding: 11px 10px; font-size: 0.82rem; border-radius: 14px; gap: 6px; white-space: normal; flex-direction: column; line-height: 1.3; }
.perk-icon { font-size: 1.4rem; }
.booking-cta-block { width: 100%; min-width: unset; gap: 10px; }
.booking-main-btn { width: 100% !important; padding: 16px 24px !important; font-size: 1rem !important; border-radius: 50px !important; text-align: center; display: flex !important; align-items: center; justify-content: center; gap: 10px; }
.booking-note { font-size: 0.78rem; line-height: 1.7; }
.slot-confirmed { padding: 20px 16px; border-radius: var(--radius-lg); width: 100%; }
.slot-confirmed strong { font-size: 1.1rem; }
.slot-confirmed p { font-size: 0.8rem; }
 }
@media (max-width: 400px) {
 .booking-strip { padding: 20px 14px; gap: 20px; }
.booking-perks { gap: 8px; }
.booking-perk { padding: 10px 8px; font-size: 0.78rem; }
.perk-icon { font-size: 1.25rem; }
.booking-main-btn { font-size: 0.95rem !important; padding: 15px 20px !important; }
.booking-note { font-size: 0.74rem; }
 }
/* ══════════════════════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════════════════════ */
.footer { background:
    radial-gradient(ellipse 100% 60% at 50% 100%, rgba(80,5,10,0.35) 0%, transparent 55%),
    var(--maroon-dark); border-top: 1px solid rgba(201,146,42,0.18); padding: 72px 0 0; }
.footer-grid { display: grid; grid-template-columns: 2.2fr 1fr 1fr 1.3fr; gap: clamp(22px, 4vw, 52px); padding-bottom: 52px; border-bottom: 1px solid rgba(201,146,42,0.12); }
.footer-logo-wrap { margin-bottom: 14px; }
.footer-logo-img { height: 56px; width: auto; object-fit: contain; filter: drop-shadow(0 2px 10px rgba(201,146,42,0.25)); transition: filter var(--dur) var(--ease); }
.footer-logo-img:hover { filter: drop-shadow(0 4px 20px rgba(201,146,42,0.50)); }
.footer-logo-fallback { font-family: var(--font-display); font-size: 1.85rem; color: var(--gold); margin-bottom: 0; line-height: 1; }
.footer-brand p { font-size: 0.88rem; color: var(--white-40); line-height: 1.78; margin-bottom: 26px; max-width: 260px; }
.social-links { display: flex; gap: 9px; flex-wrap: wrap; }
.social-btn { width: 38px; height: 38px; background: rgba(201,146,42,0.06); border: 1px solid rgba(201,146,42,0.15); border-radius: 10px; display: grid; place-items: center; color: var(--white-40); font-size: 0.9rem; transition: all var(--dur) var(--ease); text-decoration: none; }
.social-btn:hover { background: var(--gold-muted); border-color: rgba(201,146,42,0.42); color: var(--gold); transform: translateY(-2px); }
.footer-col h4 { font-family: var(--font-display); font-size: 1.1rem; color: var(--gold-light); margin-bottom: 18px; font-weight: 600; }
.footer-links { display: flex; flex-direction: column; gap: 10px; }
.footer-links a { color: var(--white-40); font-size: 0.86rem; transition: color var(--dur) var(--ease), transform var(--dur) var(--ease); display: inline-block; }
.footer-links a:hover { color: var(--gold); transform: translateX(4px); }
.contact-item { display: flex; align-items: flex-start; gap: 10px; margin-bottom: 13px; }
.contact-item .ci-icon { color: var(--gold); font-size: 0.88rem; margin-top: 3px; flex-shrink: 0; width: 16px; text-align: center; }
.contact-item p { color: var(--white-40); font-size: 0.85rem; line-height: 1.6; word-break: break-word; }
.footer-bottom { padding: 20px 0; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px; }
.footer-bottom p { color: var(--white-40); font-size: 0.8rem; }
@media (max-width: 960px) {
 .footer-grid { grid-template-columns: 1fr 1fr; }
.footer-brand { grid-column: 1 / -1; }
.footer-brand p { max-width: 100%; }
 }
@media (max-width: 560px) {
 .footer-grid { grid-template-columns: 1fr; }
.footer-bottom { justify-content: center; text-align: center; }
 }
/* ══════════════════════════════════════════════════════════════
   AUTH PAGES
══════════════════════════════════════════════════════════════ */
.auth-page { min-height: 100svh; background: var(--maroon-dark); display: grid; grid-template-columns: 1fr 1fr; }
.auth-visual { background: linear-gradient(155deg, var(--maroon-base) 0%, var(--maroon-rich) 100%); display: flex; flex-direction: column; justify-content: center; padding: clamp(30px, 7vw, 80px); position: relative; overflow: hidden; }
.auth-visual::before { content: ''; position: absolute; top: -30%; right: -25%; width: 580px; height: 580px; background: radial-gradient(circle, rgba(201,146,42,0.10) 0%, transparent 65%); }
.auth-visual::after { content: ''; position: absolute; bottom: -20%; left: -15%; width: 380px; height: 380px; background: radial-gradient(circle, rgba(100,10,10,0.15) 0%, transparent 65%); }
.auth-visual-pattern { position: absolute; inset: 0; background-image: radial-gradient(circle, rgba(201,146,42,0.13) 1px, transparent 1px); background-size: 36px 36px; opacity: 0.42; }
.auth-visual-content { position: relative; z-index: 1; }
.auth-brand { font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3.6rem); font-weight: 700; color: var(--gold); margin-bottom: 8px; line-height: 1; }
.auth-brand-tag { font-size: clamp(0.7rem, 1.2vw, 0.82rem); color: var(--gold-light); letter-spacing: 3px; text-transform: uppercase; margin-bottom: 24px; display: block; }
.auth-visual-desc { color: var(--white-70); font-size: clamp(0.9rem, 1.5vw, 1.05rem); line-height: 1.85; max-width: 380px; margin-bottom: 44px; }
.auth-perks { display: flex; flex-direction: column; gap: 14px; }
.auth-perk { display: flex; align-items: center; gap: 14px; color: var(--white-70); font-size: 0.9rem; }
.auth-perk-icon { width: 38px; height: 38px; background: var(--gold-muted); border: 1px solid rgba(201,146,42,0.25); border-radius: 10px; display: grid; place-items: center; color: var(--gold); font-size: 1rem; flex-shrink: 0; }
.auth-form-side { display: flex; align-items: center; justify-content: center; padding: clamp(24px, 5vw, 64px); overflow-y: auto; background: var(--maroon-dark); }
.auth-card { width: 100%; max-width: 450px; background:
    linear-gradient(155deg, rgba(201,146,42,0.06) 0%, rgba(70,5,10,0.60) 100%),
    var(--maroon-mid); border: 1px solid rgba(201,146,42,0.24); border-radius: var(--radius-xl); padding: clamp(28px, 5vw, 52px); box-shadow: 0 0 90px rgba(201,146,42,0.12), 0 0 40px rgba(100,5,5,0.25); }
.auth-card-header { margin-bottom: 28px; }
.auth-back-link { display: inline-flex; align-items: center; gap: 6px; color: var(--white-40); font-size: 0.82rem; margin-bottom: 22px; transition: color var(--dur) var(--ease); text-decoration: none; }
.auth-back-link:hover { color: var(--gold-light); }
.auth-card-header h2 { font-family: var(--font-display); font-size: clamp(1.8rem, 3vw, 2.4rem); color: var(--gold); margin-bottom: 6px; }
.auth-card-header p { color: var(--white-40); font-size: 0.88rem; }
.auth-tabs { display: flex; background: rgba(18,0,5,0.60); border: 1px solid var(--white-10); border-radius: 50px; padding: 4px; gap: 3px; margin-bottom: 28px; }
.auth-tab { flex: 1; padding: 9px 12px; border-radius: 50px; border: none; background: transparent; color: var(--white-40); font-size: 0.86rem; font-weight: 600; transition: all var(--dur) var(--ease); cursor: pointer; }
.auth-tab.active { background: linear-gradient(135deg, var(--gold), var(--gold-light)); color: var(--maroon-dark); box-shadow: 0 3px 12px var(--gold-glow); }
.auth-tab:not(.active):hover { color: var(--white-70); background: var(--white-5); }
.form-section { display: none; }
.form-section.active { display: block; }
.form-row { margin-bottom: 16px; }
.form-row label { display: block; font-size: 0.8rem; font-weight: 600; color: var(--gold-light); margin-bottom: 7px; letter-spacing: 0.25px; }
.form-row input { width: 100%; padding: 12px 17px; background: rgba(18,0,5,0.80); border: 1px solid var(--white-10); border-radius: var(--radius); color: var(--white-90); font-size: 0.92rem; outline: none; transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease), background var(--dur) var(--ease); }
.form-row input:focus { border-color: var(--gold); box-shadow: 0 0 0 3px var(--gold-glow); background: var(--maroon-base); }
.form-row input::placeholder { color: var(--white-40); font-size: 0.86rem; }
.input-group { position: relative; }
.input-group input { padding-right: 48px; }
.input-eye { position: absolute; right: 14px; top: 50%; transform: translateY(-50%); background: none; border: none; color: var(--white-40); cursor: pointer; font-size: 0.92rem; padding: 4px; transition: color var(--dur) var(--ease); line-height: 1; }
.input-eye:hover { color: var(--gold); }
.form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.alert { display: flex; align-items: flex-start; gap: 10px; padding: 12px 15px; border-radius: var(--radius); font-size: 0.86rem; margin-bottom: 20px; border-left: 3px solid; line-height: 1.55; }
.alert-error { background: rgba(231,76,60,0.09); border-color: #e74c3c; color: #ff7c6e; }
.alert-success { background: rgba(39,174,96,0.09); border-color: #27ae60; color: #5dd88a; }
.alert-icon { flex-shrink: 0; margin-top: 1px; }
.form-footer { text-align: center; margin-top: 20px; font-size: 0.82rem; color: var(--white-40); }
.form-footer a { color: var(--gold); font-weight: 600; transition: color var(--dur) var(--ease); }
.form-footer a:hover { color: var(--gold-bright); }
@media (max-width: 780px) {
 .auth-page { grid-template-columns: 1fr; }
.auth-visual { display: none; }
.auth-form-side { padding: 28px 16px; min-height: 100svh; align-items: flex-start; padding-top: 50px; }
.form-grid-2 { grid-template-columns: 1fr; }
.auth-card { border-radius: var(--radius-lg); }
 }
/* ══════════════════════════════════════════════════════════════
   ADMIN DASHBOARD
══════════════════════════════════════════════════════════════ */
.admin-page { background: var(--maroon-dark); min-height: 100svh; padding-top: 66px; }
.admin-topbar { position: fixed; top: 0; left: 0; right: 0; height: 66px; background: rgba(18,0,5,0.96); backdrop-filter: blur(20px); border-bottom: 1px solid rgba(201,146,42,0.16); display: flex; align-items: center; justify-content: space-between; padding: 0 clamp(16px, 4vw, 44px); z-index: 100; gap: 16px; }
.admin-topbar-brand { display: flex; align-items: center; gap: 10px; }
.admin-topbar-brand h1 { font-family: var(--font-display); color: var(--gold); font-size: clamp(1.2rem, 2.5vw, 1.55rem); font-weight: 700; white-space: nowrap; }
.admin-badge { background: var(--gold-muted); border: 1px solid rgba(201,146,42,0.3); color: var(--gold-light); font-size: 0.72rem; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; padding: 3px 10px; border-radius: 50px; }
.admin-topbar-actions { display: flex; gap: 10px; align-items: center; flex-shrink: 0; }
.admin-body { padding: clamp(24px, 4vw, 44px) clamp(16px, 5vw, 44px); }
.admin-stat-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 200px), 1fr)); gap: 18px; margin-bottom: 32px; }
.admin-stat { background: linear-gradient(155deg, rgba(201,146,42,0.06) 0%, rgba(70,5,10,0.55) 100%), var(--maroon-surface); border: 1px solid rgba(201,146,42,0.16); border-radius: var(--radius-lg); padding: 24px 22px; display: flex; align-items: center; gap: 16px; transition: border-color var(--dur) var(--ease), transform var(--dur) var(--spring), box-shadow var(--dur) var(--ease); }
.admin-stat:hover { border-color: rgba(201,146,42,0.32); transform: translateY(-2px); box-shadow: 0 10px 30px var(--shadow-warm); }
.admin-stat-icon { width: 50px; height: 50px; background: var(--gold-muted); border: 1px solid rgba(201,146,42,0.22); border-radius: 13px; display: grid; place-items: center; font-size: 1.35rem; color: var(--gold); flex-shrink: 0; }
.admin-stat-num { font-family: var(--font-display); font-size: 2rem; color: var(--gold); font-weight: 700; line-height: 1; display: block; }
.admin-stat-label { font-size: 0.76rem; color: var(--white-40); margin-top: 4px; text-transform: uppercase; letter-spacing: 1px; display: block; }
.table-card { background: linear-gradient(155deg, rgba(201,146,42,0.04) 0%, rgba(60,5,8,0.70) 100%), var(--maroon-surface); border: 1px solid rgba(201,146,42,0.15); border-radius: var(--radius-lg); overflow: hidden; }
.table-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 24px; border-bottom: 1px solid rgba(201,146,42,0.12); flex-wrap: wrap; gap: 12px; }
.table-head h3 { font-family: var(--font-display); font-size: 1.3rem; color: var(--gold-light); }
.table-search-wrap { position: relative; }
.table-search-wrap input { padding: 9px 16px 9px 36px; background: rgba(18,0,5,0.80); border: 1px solid var(--white-10); border-radius: 50px; color: var(--white-90); font-size: 0.84rem; font-family: var(--font-body); width: 220px; outline: none; transition: border-color var(--dur) var(--ease); }
.table-search-wrap input:focus { border-color: rgba(201,146,42,0.5); }
.table-search-wrap::before { content: '🔍'; position: absolute; left: 12px; top: 50%; transform: translateY(-50%); font-size: 0.75rem; pointer-events: none; }
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.admin-table { width: 100%; border-collapse: collapse; min-width: 720px; }
.admin-table th { padding: 12px 18px; text-align: left; font-size: 0.72rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gold); background: rgba(201,146,42,0.06); border-bottom: 1px solid rgba(201,146,42,0.12); white-space: nowrap; }
.admin-table td { padding: 14px 18px; font-size: 0.87rem; color: var(--white-70); border-bottom: 1px solid var(--white-5); white-space: nowrap; transition: background var(--dur) var(--ease); }
.admin-table tr:last-child td { border-bottom: none; }
.admin-table tr:hover td { background: rgba(201,146,42,0.04); }
.admin-table code { background: rgba(18,0,5,0.80); border: 1px solid var(--white-10); border-radius: 5px; padding: 3px 8px; font-size: 0.76rem; color: var(--gold-light); font-family: 'Courier New', monospace; }
.badge-done { background: rgba(39,174,96,0.12); border: 1px solid rgba(39,174,96,0.38); color: #5dd88a; padding: 4px 12px; border-radius: 50px; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; display: inline-block; }
.table-empty { text-align: center; padding: 60px 20px; color: var(--white-40); }
.table-empty span { font-size: 2.5rem; display: block; margin-bottom: 12px; opacity: 0.5; }
@media (max-width: 540px) {
 .admin-stat-cards { grid-template-columns: 1fr 1fr; }
.table-search-wrap input { width: 180px; }
.admin-topbar-brand h1 { font-size: 1.1rem; }
 }
/* ══════════════════════════════════════════════════════════════
   BACK TO TOP
══════════════════════════════════════════════════════════════ */
.back-top { position: fixed; bottom: 26px; right: 26px; width: 46px; height: 46px; background: linear-gradient(135deg, var(--gold), var(--gold-light)); color: var(--maroon-dark); border-radius: 12px; display: grid; place-items: center; font-size: 1.1rem; box-shadow: 0 8px 24px var(--gold-glow-lg); cursor: pointer; border: none; opacity: 0; transform: translateY(12px); transition: opacity var(--dur) var(--ease), transform var(--dur) var(--spring); z-index: 500; }
.back-top.visible { opacity: 1; transform: translateY(0); }
.back-top:hover { transform: translateY(-3px); box-shadow: 0 12px 32px var(--gold-glow-xl); }
/* ══════════════════════════════════════════════════════════════
   SCROLL REVEAL
══════════════════════════════════════════════════════════════ */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity 0.62s var(--ease), transform 0.62s var(--ease); }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: 0.08s; }
.reveal-delay-2 { transition-delay: 0.16s; }
.reveal-delay-3 { transition-delay: 0.24s; }
.reveal-delay-4 { transition-delay: 0.32s; }
.reveal-delay-5 { transition-delay: 0.40s; }
/* ══════════════════════════════════════════════════════════════
   RESPONSIVE OVERRIDES
══════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
 :root { --section-pad: var(--section-pad-md); }
.hero-line-l, .hero-line-r { display: none; }
 }
@media (max-width: 480px) {
 :root { --section-pad: var(--section-pad-sm); }
.menu-filters { gap: 6px; }
.filter-btn { padding: 8px 14px; font-size: 0.80rem; }
 }
/* ── Utilities ── */
.text-gold { color: var(--gold); }
.text-muted { color: var(--white-40); }
.text-center { text-align: center; }
.d-none { display: none; }
.fw-700 { font-weight: 700; }
