/* ====================================
   Page Components — Part 2
   ==================================== */

/* Hero */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--navy-900) 0%,var(--navy-700) 50%,var(--blue-500) 100%);overflow:hidden}
.hero-bg-pattern{position:absolute;top:0;left:0;right:0;bottom:0;opacity:0.05;background-image:radial-gradient(circle at 20% 50%,var(--blue-300) 0%,transparent 50%),radial-gradient(circle at 80% 20%,var(--gold-500) 0%,transparent 50%),radial-gradient(circle at 50% 80%,var(--blue-500) 0%,transparent 50%)}
.hero-waves{position:absolute;bottom:0;left:0;right:0;height:120px;overflow:hidden}
.hero-waves svg{position:absolute;bottom:0;width:200%;height:100%}
.hero-wave-1{animation:wave 8s linear infinite;opacity:0.3}
.hero-wave-2{animation:wave 12s linear infinite reverse;opacity:0.2;bottom:-10px}
@keyframes wave{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.hero-content{position:relative;z-index:2;text-align:center;padding:var(--space-xl);max-width:800px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,0.1);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.15);padding:8px 20px;border-radius:var(--radius-xl);color:var(--gold-400);font-size:0.85rem;font-weight:500;margin-bottom:var(--space-xl);letter-spacing:1px;text-transform:uppercase}
.hero h1{color:var(--white);margin-bottom:var(--space-lg);font-weight:700;line-height:1.2}
.hero h1 span{color:var(--gold-400)}
.hero-subtitle{color:var(--sky-200);font-size:clamp(1rem,2vw,1.2rem);margin-bottom:var(--space-2xl);max-width:600px;margin-left:auto;margin-right:auto;font-weight:300;line-height:1.8}
.hero-buttons{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap}
.hero-stats{display:flex;gap:var(--space-3xl);justify-content:center;margin-top:var(--space-3xl);padding-top:var(--space-2xl);border-top:1px solid rgba(255,255,255,0.1)}
.hero-stat{text-align:center}
.hero-stat-number{font-family:var(--font-heading);font-size:2rem;font-weight:700;color:var(--gold-400);line-height:1.2}
.hero-stat-label{color:var(--sky-200);font-size:0.8rem;text-transform:uppercase;letter-spacing:1px;margin-top:4px}

/* Service Cards */
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-xl)}
.service-card{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-2xl) var(--space-xl);text-align:center;box-shadow:var(--shadow-sm);transition:all var(--transition-normal);border:1px solid transparent;position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--blue-500),var(--gold-500));transform:scaleX(0);transition:transform var(--transition-normal)}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--sky-100)}
.service-card:hover::before{transform:scaleX(1)}
.service-icon{width:70px;height:70px;background:linear-gradient(135deg,var(--sky-50),var(--sky-100));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.6rem;color:var(--blue-500);margin:0 auto var(--space-lg);transition:all var(--transition-normal)}
.service-card:hover .service-icon{background:linear-gradient(135deg,var(--blue-500),var(--blue-300));color:var(--white);transform:scale(1.05) rotate(5deg)}
.service-card h3{font-size:1.1rem;margin-bottom:var(--space-sm);font-family:var(--font-body);font-weight:600}
.service-card p{font-size:0.9rem;color:var(--gray-500);margin-bottom:0}

/* About */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3xl);align-items:center}
.about-image{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3}
.about-image-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--navy-700),var(--blue-500));display:flex;flex-direction:column;align-items:center;justify-content:center;color:rgba(255,255,255,0.5);gap:var(--space-md)}
.about-image-placeholder i{font-size:3rem}
.about-image-placeholder span{font-size:0.9rem}
.about-badge{position:absolute;bottom:20px;right:20px;background:var(--gold-500);color:var(--navy-900);padding:16px 24px;border-radius:var(--radius-md);text-align:center;box-shadow:var(--shadow-lg)}
.about-badge-number{font-family:var(--font-heading);font-size:1.8rem;font-weight:700;line-height:1}
.about-badge-text{font-size:0.75rem;text-transform:uppercase;letter-spacing:1px;font-weight:600}
.about-content h2{margin-bottom:var(--space-lg)}
.about-content .subtitle{color:var(--blue-500);font-weight:600;font-size:0.9rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:var(--space-sm)}
.about-content p{color:var(--gray-500);font-size:0.95rem}
.about-features{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);margin-top:var(--space-xl)}
.about-feature{display:flex;align-items:center;gap:var(--space-sm);font-size:0.9rem;font-weight:500;color:var(--navy-800)}
.about-feature i{color:var(--gold-500);font-size:0.8rem}

/* Reviews */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-xl)}
.review-card{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-2xl);box-shadow:var(--shadow-sm);transition:all var(--transition-normal);border:1px solid var(--gray-100);position:relative}
.review-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.review-card::before{content:'"';position:absolute;top:16px;right:24px;font-size:4rem;line-height:1;color:var(--sky-100);font-family:var(--font-heading)}
.review-stars{display:flex;gap:2px;margin-bottom:var(--space-md)}
.review-stars i{color:var(--gold-500);font-size:0.85rem}
.review-text{font-size:0.9rem;color:var(--gray-500);margin-bottom:var(--space-lg);line-height:1.7;min-height:80px}
.review-author{display:flex;align-items:center;gap:var(--space-sm)}
.review-avatar{width:42px;height:42px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--blue-500),var(--blue-300));display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:700;font-size:1rem}
.review-author-name{font-weight:600;font-size:0.9rem;color:var(--navy-800)}
.review-author-date{font-size:0.75rem;color:var(--gray-500)}
.review-source{display:flex;align-items:center;gap:6px;margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--gray-100);font-size:0.75rem;color:var(--gray-500)}
.review-source i{color:#4285f4}

/* CTA Banner */
.cta-banner{position:relative;padding:var(--space-4xl) 0;background:linear-gradient(135deg,var(--navy-900),var(--navy-700));overflow:hidden}
.cta-banner::before{content:'';position:absolute;top:-50%;right:-30%;width:600px;height:600px;background:radial-gradient(circle,rgba(26,111,181,0.2) 0%,transparent 70%);border-radius:var(--radius-full)}
.cta-content{position:relative;z-index:2;text-align:center}
.cta-content h2{color:var(--white);margin-bottom:var(--space-md)}
.cta-content p{color:var(--sky-200);font-size:1.1rem;margin-bottom:var(--space-2xl);max-width:500px;margin-left:auto;margin-right:auto}
.cta-buttons{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap}

/* Gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md)}
.gallery-item{border-radius:var(--radius-md);overflow:hidden;aspect-ratio:1;background:linear-gradient(135deg,var(--navy-700),var(--blue-500));display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.3);font-size:2rem;position:relative;cursor:pointer;transition:all var(--transition-normal)}
.gallery-item:hover{transform:scale(1.03);box-shadow:var(--shadow-md)}
.gallery-item:first-child{grid-column:span 2;grid-row:span 2;font-size:3rem}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}
.gallery-item:hover img{transform:scale(1.1)}

/* Page Hero */
.page-hero{padding:calc(var(--header-height) + var(--space-3xl)) 0 var(--space-3xl);background:linear-gradient(135deg,var(--navy-900),var(--navy-700));text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 30% 40%,rgba(26,111,181,0.15) 0%,transparent 50%),radial-gradient(circle at 70% 60%,rgba(201,168,76,0.1) 0%,transparent 50%)}
.page-hero-content{position:relative;z-index:2}
.page-hero h1{color:var(--white);margin-bottom:var(--space-sm)}
.page-hero p{color:var(--sky-200);font-size:1.05rem;max-width:550px;margin:0 auto}
.page-hero .breadcrumb{display:flex;justify-content:center;gap:var(--space-sm);margin-top:var(--space-lg);font-size:0.85rem;color:var(--sky-200)}
.page-hero .breadcrumb a{color:var(--gold-400)}.breadcrumb-divider{color:rgba(255,255,255,0.3)}

/* Reservation */
.reservation-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3xl)}
.reservation-card{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-2xl);box-shadow:var(--shadow-md);text-align:center;transition:all var(--transition-normal);border:1px solid var(--gray-100)}
.reservation-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.reservation-card-icon{width:80px;height:80px;background:linear-gradient(135deg,var(--sky-50),var(--sky-100));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--blue-500);margin:0 auto var(--space-lg)}
.reservation-card h3{margin-bottom:var(--space-sm);font-family:var(--font-body)}
.reservation-card p{color:var(--gray-500);font-size:0.9rem;margin-bottom:var(--space-lg)}
.reservation-info{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-2xl);box-shadow:var(--shadow-md);margin-top:var(--space-2xl)}
.reservation-info h3{margin-bottom:var(--space-lg)}
.reservation-features{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}
.reservation-feature{display:flex;align-items:start;gap:var(--space-md);padding:var(--space-lg);border-radius:var(--radius-md);background:var(--sky-50);transition:all var(--transition-fast)}
.reservation-feature:hover{background:var(--sky-100)}
.reservation-feature i{color:var(--blue-500);font-size:1.3rem;margin-top:4px}
.reservation-feature h4{font-size:0.95rem;margin-bottom:4px;font-family:var(--font-body)}
.reservation-feature p{font-size:0.82rem;color:var(--gray-500);margin-bottom:0}
.map-container{margin-top:var(--space-2xl);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);height:400px}
.map-container iframe{width:100%;height:100%;border:0}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3xl)}
.contact-form-card{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-2xl);box-shadow:var(--shadow-md)}
.form-group{margin-bottom:var(--space-lg)}
.form-group label{display:block;font-weight:500;font-size:0.9rem;margin-bottom:6px;color:var(--navy-800)}
.form-control{width:100%;padding:14px 18px;border:2px solid var(--gray-100);border-radius:var(--radius-md);font-family:var(--font-body);font-size:0.9rem;color:var(--gray-700);background:var(--off-white);transition:all var(--transition-fast)}
.form-control:focus{outline:none;border-color:var(--blue-400);background:var(--white);box-shadow:0 0 0 4px rgba(26,111,181,0.1)}
textarea.form-control{min-height:140px;resize:vertical}
.contact-info-cards{display:flex;flex-direction:column;gap:var(--space-lg)}
.contact-info-card{display:flex;align-items:center;gap:var(--space-lg);background:var(--white);padding:var(--space-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-normal);border:1px solid var(--gray-100)}
.contact-info-card:hover{transform:translateX(6px);box-shadow:var(--shadow-md);border-color:var(--sky-100)}
.contact-info-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--sky-50),var(--sky-100));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:var(--blue-500);flex-shrink:0}
.contact-info-card h4{font-size:0.9rem;margin-bottom:4px;font-family:var(--font-body)}
.contact-info-card p,.contact-info-card a{font-size:0.9rem;color:var(--gray-500);margin-bottom:0}
.contact-info-card a:hover{color:var(--blue-500)}

/* QR Menu */
.qr-menu-section{padding:var(--space-3xl) 0 var(--space-4xl)}
.menu-accordion{max-width:var(--container-narrow);margin:0 auto}
.menu-category{margin-bottom:var(--space-md);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--gray-100);transition:all var(--transition-fast)}
.menu-category:hover{box-shadow:var(--shadow-md)}
.menu-category-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl);background:var(--white);cursor:pointer;user-select:none;transition:all var(--transition-fast);border:none;width:100%;text-align:left;font-family:var(--font-body)}
.menu-category-header:hover{background:var(--sky-50)}
.menu-category-header h3{font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--navy-800);display:flex;align-items:center;gap:var(--space-sm)}
.menu-category-header .cat-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--blue-500),var(--blue-300));border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--white);font-size:0.9rem}
.menu-category-header .toggle-icon{transition:transform var(--transition-fast);color:var(--gray-500);font-size:0.85rem}
.menu-category.active .toggle-icon{transform:rotate(180deg)}
.menu-category.active .menu-category-header{background:linear-gradient(135deg,var(--navy-800),var(--navy-700))}
.menu-category.active .menu-category-header h3{color:var(--white)}
.menu-category.active .menu-category-header .cat-icon{background:rgba(255,255,255,0.15)}
.menu-category.active .toggle-icon{color:var(--gold-400)}
.menu-items-list{max-height:0;overflow:hidden;transition:max-height 0.5s var(--ease-out);background:var(--white)}
.menu-category.active .menu-items-list{max-height:3000px}
.menu-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-xl);border-bottom:1px solid var(--gray-100);transition:background var(--transition-fast)}
.menu-item:last-child{border-bottom:none}
.menu-item:hover{background:var(--sky-50)}
.menu-item-info{flex:1}
.menu-item-name{font-weight:500;font-size:0.9rem;color:var(--navy-800)}
.menu-item-desc{font-size:0.78rem;color:var(--gray-500);margin-top:2px}
.menu-item-price{font-weight:600;font-size:0.95rem;color:var(--blue-500);white-space:nowrap;margin-left:var(--space-lg)}
.menu-tabs{display:flex;gap:var(--space-sm);justify-content:center;margin-bottom:var(--space-2xl);flex-wrap:wrap}
.menu-tab{padding:10px 24px;border:2px solid var(--gray-300);border-radius:var(--radius-xl);font-family:var(--font-body);font-weight:500;font-size:0.9rem;color:var(--gray-500);background:var(--white);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}
.menu-tab:hover,.menu-tab.active{border-color:var(--blue-500);color:var(--blue-500);background:var(--sky-50)}
.menu-tab.active{background:var(--blue-500);color:var(--white)}

/* About Page */
.about-page-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3xl);align-items:start}
.about-text p{color:var(--gray-500);font-size:0.95rem;line-height:1.8}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);margin-top:var(--space-2xl)}
.feature-card{text-align:center;padding:var(--space-xl);border-radius:var(--radius-md);background:var(--white);box-shadow:var(--shadow-sm);transition:all var(--transition-normal);border:1px solid var(--gray-100)}
.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.feature-card i{font-size:1.6rem;color:var(--blue-500);margin-bottom:var(--space-sm);display:block}
.feature-card h4{font-size:0.85rem;font-family:var(--font-body)}

/* 404 */
.error-page{min-height:80vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:var(--space-4xl);flex-direction:column}
.error-code{font-family:var(--font-heading);font-size:8rem;font-weight:700;color:var(--sky-100);line-height:1}
.error-page h2{margin:var(--space-md) 0}.error-page p{color:var(--gray-500);margin-bottom:var(--space-xl)}

/* Alerts */
.alert{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);margin-bottom:var(--space-lg);font-size:0.9rem;font-weight:500}
.alert-success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}
.alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}

/* Animations */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity 0.6s var(--ease-out),transform 0.6s var(--ease-out)}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-left{opacity:0;transform:translateX(-30px);transition:opacity 0.6s var(--ease-out),transform 0.6s var(--ease-out)}
.fade-left.visible{opacity:1;transform:translateX(0)}
.fade-right{opacity:0;transform:translateX(30px);transition:opacity 0.6s var(--ease-out),transform 0.6s var(--ease-out)}
.fade-right.visible{opacity:1;transform:translateX(0)}

/* Footer */
.main-footer{position:relative;background:var(--navy-900);color:var(--sky-200)}
.footer-wave{color:var(--navy-900);line-height:0;margin-top:-1px}
.footer-wave svg{width:100%;height:60px}
.footer-content{padding:var(--space-3xl) 0}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:var(--space-2xl)}
.footer-logo .logo-name{font-size:1.1rem}.footer-logo .logo-sub{color:var(--gray-500)}
.footer-desc{font-size:0.85rem;color:var(--gray-500);margin:var(--space-lg) 0;line-height:1.7}
.footer-social{display:flex;gap:var(--space-sm)}
.footer-social a{width:40px;height:40px;border-radius:var(--radius-md);background:rgba(255,255,255,0.06);display:flex;align-items:center;justify-content:center;color:var(--sky-200);font-size:0.9rem;transition:all var(--transition-fast)}
.footer-social a:hover{background:var(--blue-500);color:var(--white);transform:translateY(-3px)}
.footer-title{font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--white);margin-bottom:var(--space-lg)}
.footer-links li{margin-bottom:var(--space-sm)}
.footer-links a{font-size:0.85rem;color:var(--gray-500);transition:all var(--transition-fast);display:flex;align-items:center;gap:6px}
.footer-links a::before{content:'›';color:var(--blue-500);font-weight:700}
.footer-links a:hover{color:var(--white);transform:translateX(4px)}
.footer-contact li{display:flex;align-items:start;gap:var(--space-sm);margin-bottom:var(--space-md);font-size:0.85rem}
.footer-contact i{color:var(--blue-400);margin-top:4px;width:16px;text-align:center}
.footer-contact a:hover{color:var(--white)}
.footer-hours li{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,0.06);font-size:0.85rem}
.footer-hours li span:last-child{color:var(--gold-400);font-weight:500}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.06);padding:var(--space-lg) 0;text-align:center;font-size:0.8rem;color:var(--gray-500)}

/* Responsive */
@media(max-width:1024px){
.services-grid{grid-template-columns:repeat(2,1fr)}.reviews-grid{grid-template-columns:repeat(2,1fr)}
.gallery-grid{grid-template-columns:repeat(3,1fr)}.gallery-item:first-child{grid-column:span 1;grid-row:span 1}
.footer-grid{grid-template-columns:1fr 1fr}.reservation-features{grid-template-columns:repeat(2,1fr)}
.features-grid{grid-template-columns:repeat(2,1fr)}}

@media(max-width:768px){
:root{--header-height:70px}
.main-header{background:rgba(10,22,40,0.95);backdrop-filter:blur(20px)}
.main-nav{position:fixed;top:0;right:-300px;width:280px;height:100vh;background:var(--navy-900);padding:calc(var(--header-height) + var(--space-xl)) var(--space-xl) var(--space-xl);transition:right var(--transition-normal);z-index:998;box-shadow:-4px 0 30px rgba(0,0,0,0.3)}
.main-nav.active{right:0}.nav-list{flex-direction:column;gap:0}
.nav-link{display:block;padding:14px 16px;font-size:1rem;border-radius:var(--radius-md)}
.hamburger{display:flex}.header-phone span{display:none}.header-phone{border:none;padding:8px}
.hero-stats{gap:var(--space-xl)}.hero-stat-number{font-size:1.5rem}
.about-grid,.about-page-grid,.contact-grid,.reservation-grid{grid-template-columns:1fr}
.services-grid{grid-template-columns:1fr 1fr}.reviews-grid{grid-template-columns:1fr}
.gallery-grid{grid-template-columns:repeat(2,1fr)}.footer-grid{grid-template-columns:1fr}
.reservation-features{grid-template-columns:1fr}.features-grid{grid-template-columns:repeat(2,1fr)}
.section{padding:var(--space-3xl) 0}.container{padding:0 var(--space-lg)}}

@media(max-width:480px){
.services-grid{grid-template-columns:1fr}.hero-stats{flex-direction:column;gap:var(--space-md)}
.hero-buttons{flex-direction:column;align-items:center}
.features-grid,.about-features{grid-template-columns:1fr}
.gallery-grid{grid-template-columns:1fr 1fr}}
