/*
Theme Name: GALA PhotoBooth
Theme URI: https://galaphotobooth.com
Author: GALA PhotoBooth
Author URI: https://galaphotobooth.com
Description: Custom WordPress theme for GALA PhotoBooth — Los Angeles' premier Mirror Booth rental. Elegant. Fun. Unforgettable.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
Text Domain: gala-photobooth
Tags: one-column, custom-menu, featured-images, theme-options, translation-ready
*/
        *, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
        html { scroll-behavior: smooth; }
        body {
            font-family: 'Inter', -apple-system, sans-serif;
            color: #2b2b2b;
            background: #fff;
            overflow-x: hidden;
            line-height: 1.7;
        }
        img { max-width: 100%; height: auto; display: block; }
        a { text-decoration: none; color: inherit; }
        ul { list-style: none; }

        :root {
            --gold: #c9a84c;
            --gold-light: #e2c97e;
            --gold-dark: #a3852e;
            --dark: #0a0a0a;
            --charcoal: #1a1a1a;
            --cream: #faf8f3;
            --white: #ffffff;
            --gray: #7a7a7a;
            --gray-light: #eaeaea;
            --shadow: 0 12px 48px rgba(0,0,0,0.08);
            --shadow-lg: 0 24px 64px rgba(0,0,0,0.12);
            --radius: 16px;
            --transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        }

        .container { max-width: 1240px; margin: 0 auto; padding: 0 28px; }
        .section { padding: 110px 0; }
        .section-label {
            font-size: 0.7rem; font-weight: 700; letter-spacing: 4px;
            text-transform: uppercase; color: var(--gold); margin-bottom: 16px; display: inline-block;
        }
        .section-title {
            font-family: 'Cormorant Garamond', serif;
            font-size: clamp(2.2rem, 4.5vw, 3.4rem);
            color: var(--dark); margin-bottom: 20px; line-height: 1.15; font-weight: 600;
        }
        .section-subtitle { font-size: 1.05rem; color: var(--gray); max-width: 580px; line-height: 1.8; }
        .text-center { text-align: center; }
        .mx-auto { margin-left: auto; margin-right: auto; }

        .btn {
            display: inline-flex; align-items: center; justify-content: center; gap: 8px;
            padding: 16px 40px; border-radius: 50px; font-weight: 600; font-size: 0.88rem;
            letter-spacing: 1px; text-transform: uppercase; transition: var(--transition);
            cursor: pointer; border: none; font-family: 'Inter', sans-serif;
        }
        .btn-gold {
            background: linear-gradient(135deg, var(--gold), var(--gold-light));
            color: var(--dark); box-shadow: 0 6px 24px rgba(201,168,76,0.35);
        }
        .btn-gold:hover { transform: translateY(-3px); box-shadow: 0 10px 36px rgba(201,168,76,0.5); }
        .btn-outline-light { background: transparent; color: #fff; border: 2px solid rgba(255,255,255,0.4); }
        .btn-outline-light:hover { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.8); }
        .btn-dark { background: var(--dark); color: #fff; }
        .btn-dark:hover { background: #222; transform: translateY(-2px); }
        .btn-sm { padding: 10px 24px; font-size: 0.75rem; }

        @keyframes fadeUp { from { opacity: 0; transform: translateY(40px); } to { opacity: 1; transform: translateY(0); } }
        @keyframes float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
        @keyframes glow { 0%, 100% { box-shadow: 0 0 20px rgba(201,168,76,0.2); } 50% { box-shadow: 0 0 50px rgba(201,168,76,0.4); } }

        /* ===== NAVBAR ===== */
        .navbar {
            position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
            padding: 24px 0; transition: var(--transition);
        }
        .navbar.scrolled {
            background: rgba(10,10,10,0.97); backdrop-filter: blur(20px);
            padding: 14px 0; box-shadow: 0 4px 30px rgba(0,0,0,0.3);
        }
        .navbar .container { display: flex; justify-content: space-between; align-items: center; }
        .logo {
            font-family: 'Cormorant Garamond', serif; font-size: 1.7rem; font-weight: 700;
            color: #fff; letter-spacing: 3px; text-transform: uppercase;
        }
        .logo span { color: var(--gold); }
        .nav-links { display: flex; gap: 32px; align-items: center; }
        .nav-links a {
            color: rgba(255,255,255,0.75); font-size: 0.82rem; font-weight: 500;
            letter-spacing: 1px; text-transform: uppercase; transition: var(--transition); position: relative;
        }
        .nav-links a:not(.nav-cta)::after {
            content: ''; position: absolute; bottom: -6px; left: 50%; width: 0; height: 1px;
            background: var(--gold); transition: var(--transition); transform: translateX(-50%);
        }
        .nav-links a:hover { color: #fff; }
        .nav-links a:hover::after { width: 100%; }
        .nav-cta {
            padding: 10px 28px !important;
            background: linear-gradient(135deg, var(--gold), var(--gold-light)) !important;
            color: var(--dark) !important; border-radius: 50px !important;
            font-weight: 700 !important; letter-spacing: 1px !important;
        }
        .nav-cta:hover { box-shadow: 0 4px 20px rgba(201,168,76,0.4); transform: translateY(-1px); }
        .hamburger { display: none; flex-direction: column; gap: 6px; cursor: pointer; z-index: 1001; }
        .hamburger span { width: 26px; height: 1.5px; background: #fff; transition: var(--transition); }

        /* ===== HERO ===== */
        .hero {
            position: relative; min-height: 100vh; display: flex; align-items: center;
            background: linear-gradient(160deg, rgba(10,10,10,0.88), rgba(10,10,10,0.7) 50%, rgba(10,10,10,0.85)),
                        url('images/hero.jpg') center/cover no-repeat; overflow: hidden;
        }
        .hero::before {
            content: ''; position: absolute; top: -200px; right: -100px;
            width: 700px; height: 700px;
            background: radial-gradient(circle, rgba(201,168,76,0.12), transparent 65%);
            animation: float 8s ease-in-out infinite; pointer-events: none;
        }
        .hero::after {
            content: ''; position: absolute; bottom: -150px; left: -80px;
            width: 500px; height: 500px;
            background: radial-gradient(circle, rgba(201,168,76,0.08), transparent 65%);
            animation: float 10s ease-in-out infinite reverse; pointer-events: none;
        }
        .hero-content { position: relative; z-index: 2; max-width: 720px; }
        .hero-tagline {
            display: inline-flex; align-items: center; gap: 10px;
            background: rgba(201,168,76,0.1); border: 1px solid rgba(201,168,76,0.25);
            padding: 10px 24px; border-radius: 50px; color: var(--gold-light);
            font-size: 0.78rem; font-weight: 600; letter-spacing: 3px;
            text-transform: uppercase; margin-bottom: 28px; backdrop-filter: blur(10px);
        }
        .hero h1 {
            font-family: 'Cormorant Garamond', serif;
            font-size: clamp(2.8rem, 6vw, 4.5rem); color: #fff;
            line-height: 1.1; margin-bottom: 28px; font-weight: 700;
        }
        .hero h1 .gold {
            background: linear-gradient(135deg, var(--gold-light), #f0dca0, var(--gold));
            -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
        }
        .hero-desc { font-size: 1.15rem; color: rgba(255,255,255,0.6); line-height: 1.9; margin-bottom: 44px; max-width: 540px; }
        .hero-buttons { display: flex; gap: 16px; flex-wrap: wrap; }
        .hero-stats {
            display: flex; gap: 56px; margin-top: 72px; padding-top: 40px;
            border-top: 1px solid rgba(255,255,255,0.08);
        }
        .hero-stat h3 { font-family: 'Cormorant Garamond', serif; font-size: 2.5rem; color: var(--gold); font-weight: 700; }
        .hero-stat p { font-size: 0.78rem; color: rgba(255,255,255,0.4); letter-spacing: 2px; text-transform: uppercase; margin-bottom: 0; }

        /* ===== BOOTH SHOWCASE ===== */
        .booth-showcase { background: var(--cream); }
        .booth-grid {
            display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: center;
        }
        .booth-image-wrap { position: relative; }
        .booth-image-wrap img {
            border-radius: var(--radius); box-shadow: var(--shadow-lg);
            width: 100%; height: 560px; object-fit: cover;
        }
        .booth-badge {
            position: absolute; bottom: -24px; right: -24px;
            background: var(--dark); color: var(--gold);
            padding: 28px 32px; border-radius: var(--radius); box-shadow: var(--shadow); text-align: center;
        }
        .booth-badge h4 { font-family: 'Cormorant Garamond', serif; font-size: 2rem; font-weight: 700; line-height: 1; }
        .booth-badge p { font-size: 0.7rem; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,0.5); margin-top: 4px; }
        .booth-specs { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 32px; }
        .booth-spec {
            display: flex; gap: 14px; align-items: flex-start;
            padding: 18px; background: #fff; border-radius: 12px; border: 1px solid var(--gray-light);
        }
        .booth-spec-icon {
            width: 44px; height: 44px; min-width: 44px; border-radius: 12px;
            background: linear-gradient(135deg, rgba(201,168,76,0.12), rgba(201,168,76,0.04));
            display: flex; align-items: center; justify-content: center; font-size: 1.1rem;
        }
        .booth-spec h5 { font-size: 0.85rem; font-weight: 600; margin-bottom: 2px; }
        .booth-spec p { font-size: 0.75rem; color: var(--gray); line-height: 1.5; }

        /* ===== EXPERIENCES ===== */
        .experiences { background: var(--dark); color: #fff; }
        .experiences .section-title { color: #fff; }
        .experiences .section-subtitle { color: rgba(255,255,255,0.5); }
        .exp-intro { text-align: center; margin-bottom: 48px; }
        .exp-grid {
            display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px;
        }
        .exp-card {
            padding: 28px 20px; border-radius: var(--radius);
            border: 1px solid rgba(255,255,255,0.06); background: rgba(255,255,255,0.03);
            transition: var(--transition); text-align: center;
        }
        .exp-card:hover {
            border-color: rgba(201,168,76,0.3); background: rgba(201,168,76,0.05); transform: translateY(-6px);
        }
        .exp-card .icon { font-size: 2rem; margin-bottom: 14px; display: block; }
        .exp-card h4 {
            font-family: 'Cormorant Garamond', serif; font-size: 1.1rem;
            font-weight: 600; margin-bottom: 6px; color: #fff;
        }
        .exp-card p { font-size: 0.78rem; color: rgba(255,255,255,0.4); line-height: 1.5; }
        .exp-essentials {
            margin-top: 48px; padding-top: 48px; border-top: 1px solid rgba(255,255,255,0.06);
        }
        .exp-essentials h3 {
            font-family: 'Cormorant Garamond', serif; font-size: 1.6rem;
            text-align: center; margin-bottom: 32px; color: var(--gold);
        }
        .essentials-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
        .essential-item {
            padding: 20px; border-radius: 12px;
            background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.04);
            text-align: center; transition: var(--transition);
        }
        .essential-item:hover { border-color: rgba(201,168,76,0.2); }
        .essential-item .icon { font-size: 1.5rem; margin-bottom: 8px; }
        .essential-item h5 { font-size: 0.85rem; font-weight: 600; color: #fff; }

        /* ===== EVENTS ===== */
        .events-grid {
            display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; margin-top: 56px;
        }
        .event-card {
            background: #fff; border-radius: var(--radius); overflow: hidden;
            box-shadow: 0 4px 24px rgba(0,0,0,0.05); transition: var(--transition);
        }
        .event-card:hover { transform: translateY(-10px); box-shadow: var(--shadow-lg); }
        .event-card-img { height: 280px; overflow: hidden; position: relative; }
        .event-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; }
        .event-card:hover .event-card-img img { transform: scale(1.08); }
        .event-card-img .overlay {
            position: absolute; inset: 0;
            background: linear-gradient(to top, rgba(10,10,10,0.6), transparent);
            opacity: 0; transition: var(--transition);
            display: flex; align-items: flex-end; padding: 24px;
        }
        .event-card:hover .event-card-img .overlay { opacity: 1; }
        .overlay .btn { padding: 10px 24px; font-size: 0.75rem; background: var(--gold); color: var(--dark); border-radius: 50px; }
        .event-card-body { padding: 28px; }
        .event-card-body h3 {
            font-family: 'Cormorant Garamond', serif; font-size: 1.5rem;
            margin-bottom: 10px; color: var(--dark); font-weight: 600;
        }
        .event-card-body p { font-size: 0.88rem; color: var(--gray); line-height: 1.7; }

        /* ===== HOW IT WORKS ===== */
        .steps-row {
            display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px;
            margin-top: 56px; position: relative;
        }
        .steps-row::before {
            content: ''; position: absolute; top: 44px; left: 12%; right: 12%;
            height: 1px; background: linear-gradient(to right, transparent, var(--gold), transparent);
        }
        .step { text-align: center; padding: 20px 16px; position: relative; }
        .step-num {
            width: 72px; height: 72px; border-radius: 50%;
            background: linear-gradient(135deg, var(--dark), #333);
            color: var(--gold); font-family: 'Cormorant Garamond', serif;
            font-size: 1.6rem; font-weight: 700;
            display: flex; align-items: center; justify-content: center;
            margin: 0 auto 24px; border: 2px solid var(--gold); position: relative; z-index: 2;
        }
        .step h4 { font-family: 'Cormorant Garamond', serif; font-size: 1.2rem; font-weight: 600; margin-bottom: 8px; }
        .step p { font-size: 0.82rem; color: var(--gray); line-height: 1.7; }

        /* ===== GALLERY ===== */
        .gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 56px; }
        .gal-item {
            border-radius: var(--radius); overflow: hidden; position: relative;
            cursor: pointer; aspect-ratio: 4/3;
        }
        .gal-item:first-child { grid-column: span 2; grid-row: span 2; aspect-ratio: auto; }
        .gal-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; }
        .gal-item:hover img { transform: scale(1.08); }
        .gal-item::after {
            content: ''; position: absolute; inset: 0;
            background: linear-gradient(to top, rgba(201,168,76,0.4), transparent 50%);
            opacity: 0; transition: var(--transition);
        }
        .gal-item:hover::after { opacity: 1; }

        /* ===== PRICING ===== */
        .pricing { background: var(--cream); }
        .pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; margin-top: 56px; align-items: start; }
        .price-card {
            background: #fff; border-radius: var(--radius); padding: 44px 36px;
            border: 2px solid var(--gray-light); transition: var(--transition); text-align: center; position: relative;
        }
        .price-card:hover { border-color: var(--gold-light); box-shadow: var(--shadow); }
        .price-card.popular { border-color: var(--gold); box-shadow: 0 20px 60px rgba(201,168,76,0.15); transform: scale(1.04); }
        .popular-badge {
            position: absolute; top: -16px; left: 50%; transform: translateX(-50%);
            background: linear-gradient(135deg, var(--gold-dark), var(--gold));
            color: #fff; padding: 8px 28px; border-radius: 50px;
            font-size: 0.68rem; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
        }
        .price-card h3 { font-family: 'Cormorant Garamond', serif; font-size: 1.6rem; font-weight: 600; }
        .price-card .price-sub { font-size: 0.82rem; color: var(--gray); margin-bottom: 4px; }
        .price-card .amount {
            font-family: 'Cormorant Garamond', serif; font-size: 3.5rem; font-weight: 700;
            color: var(--dark); margin: 16px 0 4px; line-height: 1;
        }
        .price-card .amount span { font-size: 1rem; font-weight: 400; color: var(--gray); font-family: 'Inter', sans-serif; }
        .price-card .dur { font-size: 0.78rem; color: var(--gray); margin-bottom: 28px; }
        .price-feats { text-align: left; margin-bottom: 32px; }
        .price-feats li {
            padding: 11px 0; font-size: 0.85rem; color: #555;
            display: flex; align-items: center; gap: 10px; border-bottom: 1px solid var(--gray-light);
        }
        .price-feats li:last-child { border-bottom: none; }
        .price-feats .ck { color: var(--gold); font-weight: 700; font-size: 0.9rem; }

        /* ===== AREAS ===== */
        .areas-content { display: grid; grid-template-columns: 1fr 1.2fr; gap: 56px; margin-top: 56px; align-items: start; }
        .areas-map-box {
            background: linear-gradient(135deg, var(--dark), #222); border-radius: var(--radius);
            padding: 56px; color: #fff; text-align: center; position: relative; overflow: hidden;
        }
        .areas-map-box::before {
            content: ''; position: absolute; inset: 0;
            background: radial-gradient(circle at 40% 50%, rgba(201,168,76,0.15), transparent 60%);
        }
        .areas-map-box .map-icon { font-size: 4rem; margin-bottom: 20px; position: relative; }
        .areas-map-box h3 { font-family: 'Cormorant Garamond', serif; font-size: 1.8rem; margin-bottom: 8px; position: relative; }
        .areas-map-box p { color: rgba(255,255,255,0.5); font-size: 0.88rem; position: relative; }
        .areas-list { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
        .area-item {
            display: flex; align-items: center; gap: 10px; padding: 14px 20px;
            background: var(--cream); border-radius: 12px; font-size: 0.88rem; font-weight: 500;
            transition: var(--transition);
        }
        .area-item:hover { background: rgba(201,168,76,0.08); transform: translateX(4px); }
        .area-item .pin { color: var(--gold); font-size: 0.9rem; }

        /* ===== TESTIMONIALS ===== */
        .testimonials { background: var(--cream); }
        .test-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; margin-top: 56px; }
        .test-card {
            background: #fff; border-radius: var(--radius); padding: 36px;
            box-shadow: 0 4px 20px rgba(0,0,0,0.04); transition: var(--transition);
        }
        .test-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
        .test-stars { color: var(--gold); font-size: 0.95rem; margin-bottom: 20px; letter-spacing: 3px; }
        .test-card blockquote { font-size: 0.92rem; line-height: 1.9; color: #555; margin-bottom: 24px; font-style: italic; }
        .test-author { display: flex; align-items: center; gap: 14px; }
        .test-avatar {
            width: 48px; height: 48px; border-radius: 50%;
            background: linear-gradient(135deg, var(--gold), var(--gold-light));
            display: flex; align-items: center; justify-content: center;
            color: var(--dark); font-weight: 700; font-size: 0.85rem;
        }
        .test-author-info h5 { font-size: 0.88rem; font-weight: 600; }
        .test-author-info p { font-size: 0.78rem; color: var(--gray); }

        /* ===== FAQ ===== */
        .faq-list { max-width: 760px; margin: 56px auto 0; }
        .faq-item {
            background: #fff; border-radius: var(--radius); margin-bottom: 12px;
            box-shadow: 0 2px 12px rgba(0,0,0,0.04); overflow: hidden;
        }
        .faq-q {
            padding: 22px 28px; display: flex; justify-content: space-between; align-items: center;
            cursor: pointer; font-weight: 600; font-size: 0.95rem; color: var(--dark); transition: var(--transition);
        }
        .faq-q:hover { color: var(--gold-dark); }
        .faq-toggle { font-size: 1.4rem; transition: transform 0.3s ease; color: var(--gold); line-height: 1; }
        .faq-item.open .faq-toggle { transform: rotate(45deg); }
        .faq-a { max-height: 0; overflow: hidden; transition: max-height 0.35s ease; }
        .faq-a-inner { padding: 0 28px 22px; font-size: 0.88rem; color: var(--gray); line-height: 1.9; }

        /* ===== CTA ===== */
        .cta-section {
            background: linear-gradient(160deg, var(--dark), #1f1f1f); position: relative; overflow: hidden;
        }
        .cta-section::before {
            content: ''; position: absolute; top: -40%; right: -10%;
            width: 600px; height: 600px;
            background: radial-gradient(circle, rgba(201,168,76,0.15), transparent 65%); pointer-events: none;
        }
        .cta-inner { position: relative; text-align: center; max-width: 640px; margin: 0 auto; }
        .cta-inner .section-title { color: #fff; }
        .cta-inner .section-subtitle { color: rgba(255,255,255,0.5); }
        .cta-btns { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; margin-top: 36px; }
        .cta-info { display: flex; justify-content: center; gap: 48px; margin-top: 44px; flex-wrap: wrap; }
        .cta-info-item { color: rgba(255,255,255,0.55); font-size: 0.88rem; display: flex; align-items: center; gap: 8px; }
        .cta-info-item span:first-child { color: var(--gold); }

        /* ===== CONTACT ===== */
        .contact-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 56px; margin-top: 56px; }
        .contact-form { background: #fff; padding: 44px; border-radius: var(--radius); box-shadow: var(--shadow); }
        .form-group { margin-bottom: 20px; }
        .form-group label { display: block; font-size: 0.82rem; font-weight: 600; color: var(--dark); margin-bottom: 6px; letter-spacing: 0.5px; }
        .form-group input, .form-group select, .form-group textarea {
            width: 100%; padding: 14px 18px; border: 2px solid var(--gray-light); border-radius: 12px;
            font-family: 'Inter', sans-serif; font-size: 0.88rem; transition: var(--transition); background: #fafafa;
        }
        .form-group input:focus, .form-group select:focus, .form-group textarea:focus {
            outline: none; border-color: var(--gold); background: #fff; box-shadow: 0 0 0 4px rgba(201,168,76,0.08);
        }
        .form-group textarea { resize: vertical; min-height: 120px; }
        .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
        .contact-cards { display: flex; flex-direction: column; gap: 16px; }
        .contact-card {
            padding: 24px; background: var(--cream); border-radius: var(--radius);
            display: flex; gap: 16px; align-items: flex-start;
        }
        .contact-card .cc-icon {
            width: 48px; height: 48px; min-width: 48px; border-radius: 14px;
            background: linear-gradient(135deg, var(--gold), var(--gold-light));
            display: flex; align-items: center; justify-content: center; font-size: 1.1rem;
        }
        .contact-card h5 { font-size: 0.92rem; font-weight: 600; margin-bottom: 4px; }
        .contact-card p { font-size: 0.82rem; color: var(--gray); line-height: 1.6; }

        /* ===== FOOTER ===== */
        .footer { background: var(--dark); color: rgba(255,255,255,0.6); padding: 72px 0 28px; }
        .footer-grid {
            display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px;
            padding-bottom: 48px; border-bottom: 1px solid rgba(255,255,255,0.06);
        }
        .footer-brand .logo { font-size: 1.5rem; margin-bottom: 16px; display: inline-block; }
        .footer-brand p { font-size: 0.85rem; line-height: 1.8; max-width: 300px; color: rgba(255,255,255,0.4); }
        .footer-social { display: flex; gap: 12px; margin-top: 24px; }
        .footer-social a {
            width: 42px; height: 42px; border-radius: 50%; background: rgba(255,255,255,0.06);
            display: flex; align-items: center; justify-content: center;
            transition: var(--transition); font-size: 0.85rem; color: rgba(255,255,255,0.5);
        }
        .footer-social a:hover { background: var(--gold); color: var(--dark); }
        .footer h5 { color: #fff; font-size: 0.9rem; font-weight: 600; margin-bottom: 20px; letter-spacing: 1px; }
        .footer-links li { margin-bottom: 10px; }
        .footer-links a { font-size: 0.82rem; color: rgba(255,255,255,0.4); transition: var(--transition); }
        .footer-links a:hover { color: var(--gold); }
        .footer-bottom {
            display: flex; justify-content: space-between; align-items: center;
            padding-top: 28px; font-size: 0.78rem; color: rgba(255,255,255,0.25);
        }

        /* ===== RESPONSIVE ===== */
        @media (max-width: 1024px) {
            .exp-grid, .essentials-grid { grid-template-columns: repeat(2, 1fr); }
            .pricing-grid, .events-grid, .test-grid { grid-template-columns: repeat(2, 1fr); }
            .steps-row { grid-template-columns: repeat(2, 1fr); }
            .steps-row::before { display: none; }
            .gallery-grid { grid-template-columns: repeat(2, 1fr); }
            .gal-item:first-child { grid-column: span 2; }
            .footer-grid { grid-template-columns: repeat(2, 1fr); }
            .booth-grid { grid-template-columns: 1fr; }
        }
        @media (max-width: 768px) {
            .section { padding: 80px 0; }
            .hamburger { display: flex; }
            .nav-links {
                display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0;
                background: var(--dark); flex-direction: column; justify-content: center;
                align-items: center; gap: 28px; z-index: 999;
            }
            .nav-links.active { display: flex; }
            .nav-links a { font-size: 1.1rem !important; color: rgba(255,255,255,0.8) !important; }
            .booth-grid, .areas-content, .contact-grid { grid-template-columns: 1fr; gap: 40px; }
            .exp-grid, .essentials-grid, .pricing-grid, .events-grid, .test-grid { grid-template-columns: 1fr; }
            .steps-row { grid-template-columns: 1fr; }
            .gallery-grid { grid-template-columns: 1fr; }
            .gal-item:first-child { grid-column: span 1; grid-row: span 1; }
            .areas-list { grid-template-columns: 1fr; }
            .hero-stats { flex-direction: column; gap: 20px; }
            .price-card.popular { transform: none; }
            .booth-specs { grid-template-columns: 1fr; }
            .footer-grid { grid-template-columns: 1fr; }
            .footer-bottom { flex-direction: column; gap: 8px; text-align: center; }
            .booth-badge { right: auto; left: 24px; bottom: -20px; }
        }

/* ===== FORM MESSAGES ===== */
.form-success-message,
.form-error-message {
    text-align: center;
    padding: 40px 28px;
    border-radius: 16px;
    margin-bottom: 32px;
    animation: fadeUp 0.6s ease;
}
.form-success-message {
    background: linear-gradient(135deg, rgba(16,185,129,0.08), rgba(16,185,129,0.04));
    border: 2px solid rgba(16,185,129,0.2);
}
.form-success-icon {
    width: 56px; height: 56px; border-radius: 50%;
    background: linear-gradient(135deg, #10b981, #34d399);
    color: #fff; font-size: 1.5rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 16px;
}
.form-success-message h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.5rem; color: #059669; margin-bottom: 8px;
}
.form-success-message p { font-size: 0.92rem; color: #555; }

.form-error-message {
    background: linear-gradient(135deg, rgba(239,68,68,0.08), rgba(239,68,68,0.04));
    border: 2px solid rgba(239,68,68,0.2);
}
.form-error-icon {
    width: 56px; height: 56px; border-radius: 50%;
    background: linear-gradient(135deg, #ef4444, #f87171);
    color: #fff; font-size: 1.5rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 16px;
}
.form-error-message h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.5rem; color: #dc2626; margin-bottom: 8px;
}
.form-error-message p { font-size: 0.92rem; color: #555; }
.form-error-message a { color: var(--gold-dark); font-weight: 600; }

/* ===== ALWAYS SOLID NAVBAR ===== */
.navbar {
    background: rgba(10,10,10,0.97);
    backdrop-filter: blur(20px);
    box-shadow: 0 2px 20px rgba(0,0,0,0.2);
}
.navbar.scrolled {
    box-shadow: 0 2px 30px rgba(0,0,0,0.3);
}

/* ===== HERO PADDING FOR NAVBAR ===== */
.hero { padding-top: 120px; }
.hero-content { padding-top: 24px; }
