/* Royal Punjab - High-End Premium CSS v7
    Focus: High-Contrast, Typography Hierarchy & 3D Performance
*/

/* --- DESIGN SYSTEM --- */

/* --- CSS: assets/css/main.css --- */
:root {
    --bg-dark: #0a0a0a;
    --bg-light: #f9f7f2;
    --gold: #c9a96e;
    --spice: #b3391b;
    --text-light: #ffffff;
    --text-dark: #1a1a1a;
    --font-serif: 'Playfair Display', serif;
}

body { background: var(--bg-dark); color: var(--text-light); font-family: 'Inter', sans-serif; margin: 0; overflow-x: hidden; }

/* 1. HERO & BELT */
.hero-section { height: 100vh; position: relative; display: flex; align-items: center; justify-content: center; overflow: hidden; background: #000; }
.hero-plate-belt { position: absolute; bottom: 12%; width: 100%; overflow: hidden; opacity: 0.6; }
.belt-track { display: flex; width: max-content; }
.belt-track img { height: 260px; width: auto; margin: 0 50px; filter: drop-shadow(0 15px 30px rgba(0,0,0,0.8)); }

/* 2. NAVIGATION */
.main-header { position: fixed; top: 0; width: 100%; z-index: 1000; transition: 0.4s; padding: 25px 0; }
.header-scrolled { background: rgba(10, 10, 10, 0.95); backdrop-filter: blur(15px); padding: 15px 0; border-bottom: 1px solid rgba(201, 169, 110, 0.15); }
.nav-container { max-width: 1300px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; padding: 0 30px; }
.nav-logo { font-family: var(--font-serif); font-size: 1.8rem; color: #fff; text-decoration: none; font-weight: bold; }
.nav-links { list-style: none; display: flex; gap: 35px; }
.nav-links a { text-decoration: none; color: #fff; text-transform: uppercase; font-size: 0.8rem; letter-spacing: 2px; }
.nav-btn { background: var(--gold); color: #000 !important; padding: 10px 22px; border-radius: 4px; font-weight: 700; }

/* 3. 3D EXPERIENCE & MEGA SPACER */
.experience-trigger { height: 350vh; }
.immersive-sticky { position: sticky; top: 0; height: 100vh; width: 100%; overflow: hidden; background: #000; }
.immersive-wrapper { perspective: 1200px; transform-style: preserve-3d; width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; position: relative; }
.z-element { position: absolute; will-change: transform; filter: drop-shadow(0 30px 70px rgba(0,0,0,1)); pointer-events: none; }
.dish-1 { width: 420px; } .dish-2 { width: 380px; } .spice-a { width: 120px; } .spice-b { width: 90px; }

.mega-spacer { height: 80vh; } /* Der Leerraum für Premium-Feeling */
.naan-highlight { padding-bottom: 200px; text-align: center; }
.standalone-naan { width: 650px; max-width: 90vw; margin: 0 auto; filter: drop-shadow(0 40px 80px rgba(0,0,0,0.9)); }

/* 4. DISHES & MENU */
.container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.dish-row { display: flex; align-items: center; gap: 80px; margin-bottom: 140px; }
.dish-row.reverse { flex-direction: row-reverse; }
.dish-text { flex: 1; }
.category-title { font-family: var(--font-serif); font-size: 3rem; color: var(--gold); margin-bottom: 20px; }
.flying-plate { width: 100%; max-width: 550px; filter: drop-shadow(0 25px 50px rgba(0,0,0,0.8)); }

/* 5. GALLERY (PREMIUM) */
.gallery-card { background: #fff; border-radius: 20px; padding: 20px; box-shadow: 0 30px 60px rgba(0,0,0,0.06); transition: 0.5s; }
.gallery-card:hover { transform: translateY(-20px); }
.gallery-img-box { height: 450px; background: #eee; border-radius: 12px; display: flex; align-items: center; justify-content: center; }
.gallery-info { padding: 30px 10px; text-align: left; }
.gallery-info h4 { color: var(--text-dark); font-family: var(--font-serif); font-size: 1.8rem; }

/* 6. UTILITIES & DARK/LIGHT */
.light-bg { background: var(--bg-light); color: var(--text-dark); padding: 120px 0; }
.dark-bg { background: var(--bg-dark); padding: 120px 0; }
.center-content { text-align: center; display: flex; flex-direction: column; align-items: center; }
.section-title { font-family: var(--font-serif); font-size: clamp(2.8rem, 6vw, 4.8rem); margin-bottom: 30px; }
.gold-text { color: var(--gold); }
.decorative-line { width: 90px; height: 3px; background: var(--spice); margin-bottom: 35px; }
.btn-primary { background: var(--gold); color: #000; padding: 20px 50px; font-weight: bold; text-transform: uppercase; letter-spacing: 2px; text-decoration: none; border-radius: 4px; }
.usp-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; width: 100%; margin-top: 60px; }
.usp-icon { font-size: 3rem; margin-bottom: 15px; display: block; }

/* 7. REVIEWS & FAQ */
.review-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(350px, 1fr)); gap: 40px; }
.review-card { background: #161616; padding: 50px 40px; border-radius: 15px; border-top: 6px solid var(--gold); }
.stars { color: var(--gold); margin-bottom: 25px; font-size: 1.4rem; }
.faq-question { width: 100%; background: none; border: none; color: inherit; padding: 30px 0; border-bottom: 1px solid rgba(0,0,0,0.1); text-align: left; font-size: 1.6rem; cursor: pointer; display: flex; justify-content: space-between; font-family: var(--font-serif); }
.faq-answer { display: none; padding: 25px 0; opacity: 0.8; line-height: 1.8; }
.faq-item.active .faq-answer { display: block; }

/* 8. FOOTER */
.footer-pro { border-top: 1px solid rgba(255,255,255,0.05); padding: 100px 0 50px; }
.footer-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 60px; }