/* =================================================================
   JIU XIANG JU — Global Stylesheet (Premium Edition)
   ================================================================= */

/* ===== CSS VARIABLES ===== */
:root {
  --c-primary: #B8283C;
  --c-primary-dark: #8C1F2E;
  --c-primary-deep: #6B1724;
  --c-primary-light: #D94058;
  --c-primary-glow: rgba(184,40,60,.15);
  --c-accent: #C9A84C;
  --c-accent-light: #E8D48B;
  --c-accent-glow: rgba(201,168,76,.15);
  --c-gold: linear-gradient(135deg, #C9A84C, #E8D48B, #C9A84C);
  --c-dark: #111111;
  --c-dark-soft: #1E1E1E;
  --c-dark-card: #1A1A1A;
  --c-text: #333333;
  --c-text-light: #5A5A5A;
  --c-text-muted: #8A8A8A;
  --c-bg: #FDFBF8;
  --c-bg-warm: #F8F3EC;
  --c-bg-cream: #FAF6F0;
  --c-bg-dark: #0F0F0F;
  --c-white: #FFFFFF;
  --c-border: #E6DDD3;
  --c-border-light: #F0EAE2;
  --font-heading: 'Playfair Display', 'Noto Serif SC', Georgia, serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-chinese: 'Noto Serif SC', serif;
  --shadow-xs: 0 1px 3px rgba(0,0,0,.04);
  --shadow-sm: 0 2px 8px rgba(0,0,0,.06);
  --shadow-md: 0 4px 24px rgba(0,0,0,.08);
  --shadow-lg: 0 8px 40px rgba(0,0,0,.1);
  --shadow-xl: 0 16px 60px rgba(0,0,0,.14);
  --shadow-glow: 0 0 40px rgba(184,40,60,.12);
  --shadow-gold: 0 0 30px rgba(201,168,76,.1);
  --radius-sm: 8px;
  --radius-md: 14px;
  --radius-lg: 22px;
  --radius-xl: 40px;
  --radius-full: 999px;
  --transition: .35s cubic-bezier(.4,0,.2,1);
  --transition-slow: .6s cubic-bezier(.4,0,.2,1);
}

/* ===== RESET ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:var(--font-body);color:var(--c-text);background:var(--c-bg);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,select,textarea{font-family:inherit;font-size:1rem}
::selection{background:var(--c-primary);color:var(--c-white)}

/* ===== UTILITIES ===== */
.container{max-width:1240px;margin:0 auto;padding:0 28px}
.section{padding:110px 0}
.section-sm{padding:80px 0}

.section-label{
  font-family:var(--font-body);font-size:.75rem;font-weight:700;
  text-transform:uppercase;letter-spacing:4px;color:var(--c-primary);
  margin-bottom:14px;display:inline-flex;align-items:center;gap:10px;
}
.section-label::before,.section-label::after{
  content:'';width:28px;height:1px;background:var(--c-primary);opacity:.4;
}
.section-title{
  font-family:var(--font-heading);font-size:clamp(2rem,4.5vw,3rem);
  font-weight:700;color:var(--c-dark);line-height:1.15;margin-bottom:18px;
}
.section-title em{font-style:italic;color:var(--c-primary)}
.section-desc{font-size:1.05rem;color:var(--c-text-light);max-width:620px;margin:0 auto 52px;line-height:1.8}
.section-header{text-align:center;margin-bottom:64px}

.divider{
  width:60px;height:3px;
  background:linear-gradient(90deg,var(--c-primary),var(--c-accent));
  border-radius:2px;margin:24px auto 0;
}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:15px 36px;border-radius:var(--radius-full);font-weight:600;
  font-size:.92rem;letter-spacing:.5px;transition:var(--transition);position:relative;overflow:hidden;
}
.btn-primary{
  background:var(--c-primary);color:var(--c-white);
  box-shadow:0 4px 20px rgba(184,40,60,.3);
}
.btn-primary::before{
  content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);
  transition:left .5s ease;
}
.btn-primary:hover::before{left:100%}
.btn-primary:hover{
  background:var(--c-primary-dark);transform:translateY(-2px);
  box-shadow:0 6px 28px rgba(184,40,60,.4);
}
.btn-outline{border:2px solid var(--c-white);color:var(--c-white);background:transparent}
.btn-outline:hover{background:var(--c-white);color:var(--c-primary);transform:translateY(-2px)}
.btn-white{
  background:var(--c-white);color:var(--c-primary);
  box-shadow:0 4px 16px rgba(0,0,0,.1);
}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(0,0,0,.15)}
.btn-outline-white{border:2px solid rgba(255,255,255,.5);color:var(--c-white);background:transparent}
.btn-outline-white:hover{background:var(--c-white);color:var(--c-primary)}
.btn-gold{
  background:linear-gradient(135deg,#C9A84C,#E8D48B);color:var(--c-dark);
  box-shadow:0 4px 20px rgba(201,168,76,.3);font-weight:700;
}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 6px 28px rgba(201,168,76,.4)}
.btn-full{width:100%}
.btn-sm{padding:10px 24px;font-size:.85rem}

/* ===== NAVBAR ===== */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:18px 0;transition:var(--transition);
}
.navbar.scrolled{
  background:rgba(255,255,255,.98);backdrop-filter:blur(16px);
  padding:10px 0;box-shadow:0 2px 20px rgba(0,0,0,.06);
}
.nav-container{display:flex;align-items:center;justify-content:space-between;max-width:1240px;margin:0 auto;padding:0 28px}

.nav-logo{display:flex;align-items:center;gap:12px}
.logo-img{height:72px;width:auto;border-radius:8px;transition:var(--transition)}
.navbar.scrolled .logo-img{height:58px}

.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{
  padding:9px 18px;border-radius:var(--radius-full);font-size:.88rem;
  font-weight:500;color:rgba(255,255,255,.85);transition:var(--transition);
  position:relative;
}
.nav-links a::after{
  content:'';position:absolute;bottom:4px;left:50%;transform:translateX(-50%);
  width:0;height:2px;background:var(--c-accent);border-radius:1px;transition:var(--transition);
}
.nav-links a:hover::after,.nav-links a.active::after{width:20px}
.nav-links a:hover{color:var(--c-white)}
.nav-cta{
  background:var(--c-primary)!important;color:var(--c-white)!important;
  box-shadow:0 2px 14px rgba(184,40,60,.3);margin-left:8px;
}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--c-primary-dark)!important}
.navbar.scrolled .nav-links a{color:var(--c-text)}
.navbar.scrolled .nav-links a:hover{color:var(--c-primary)}
.navbar.scrolled .nav-links a.active{color:var(--c-primary)}
.navbar.scrolled .nav-cta{color:var(--c-white)!important}

.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px;z-index:1001}
.nav-toggle span{width:24px;height:2px;background:var(--c-white);border-radius:2px;transition:var(--transition)}
.navbar.scrolled .nav-toggle span{background:var(--c-dark)}
.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-toggle.active span:nth-child(2){opacity:0}
.nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ===== HERO (Homepage) ===== */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  justify-content:center;overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;
  background-color:var(--c-dark);
  background-size:cover;background-position:center;background-repeat:no-repeat;
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(17,17,17,.9) 0%,rgba(140,31,46,.75) 50%,rgba(17,17,17,.88) 100%);
}
.hero-content{
  position:relative;z-index:2;text-align:center;padding:100px 28px 0;max-width:820px;
}
.hero-subtitle{
  font-size:1rem;font-weight:500;letter-spacing:4px;text-transform:uppercase;
  color:var(--c-accent);margin-bottom:14px;
}
.hero-title{
  font-family:var(--font-heading);font-size:clamp(3rem,8vw,5.5rem);
  font-weight:700;color:var(--c-white);line-height:1;margin-bottom:6px;
}
.hero-chinese{
  font-family:var(--font-chinese);font-size:clamp(1.2rem,3vw,1.8rem);
  color:var(--c-accent);letter-spacing:16px;margin-bottom:22px;
}
.hero-tagline{
  font-family:var(--font-heading);font-size:clamp(1.1rem,2.5vw,1.4rem);
  font-style:italic;color:rgba(255,255,255,.9);margin-bottom:18px;
}
.hero-desc{
  font-size:1.05rem;color:rgba(255,255,255,.75);max-width:580px;
  margin:0 auto 40px;line-height:1.8;
}
.hero-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero-scroll{
  position:absolute;bottom:40px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  color:rgba(255,255,255,.5);font-size:.75rem;letter-spacing:2px;
}
.scroll-line{
  width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,.5),transparent);
  animation:scrollPulse 2s infinite;
}
@keyframes scrollPulse{
  0%,100%{opacity:.3;transform:scaleY(.6)}
  50%{opacity:1;transform:scaleY(1)}
}

/* ===== PAGE HERO (Inner Pages) ===== */
.page-hero{
  position:relative;min-height:420px;display:flex;align-items:center;
  justify-content:center;overflow:hidden;text-align:center;
}
.page-hero-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
}
.page-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(17,17,17,.88),rgba(184,40,60,.7),rgba(17,17,17,.85));
}
.page-hero-content{position:relative;z-index:2;padding:120px 28px 60px}
.page-hero .section-label{color:var(--c-accent)}
.page-hero .section-label::before,.page-hero .section-label::after{background:var(--c-accent);opacity:.5}
.page-hero .section-title{color:var(--c-white);font-size:clamp(2.2rem,5vw,3.2rem)}
.page-hero .section-title em{color:var(--c-accent)}
.page-hero-desc{color:rgba(255,255,255,.7);font-size:1.05rem;max-width:550px;margin:12px auto 0}
.page-hero-breadcrumb{
  display:flex;align-items:center;gap:8px;justify-content:center;
  margin-top:24px;font-size:.85rem;color:rgba(255,255,255,.5);
}
.page-hero-breadcrumb a{color:rgba(255,255,255,.6);transition:var(--transition)}
.page-hero-breadcrumb a:hover{color:var(--c-accent)}
.page-hero-breadcrumb .sep{opacity:.4}

/* ===== HIGHLIGHTS ===== */
.highlights{
  background:var(--c-white);border-bottom:1px solid var(--c-border-light);padding:28px 0;
  position:relative;z-index:2;
}
.highlights .container{display:flex;justify-content:center;flex-wrap:wrap;gap:48px}
.highlight-item{display:flex;align-items:center;gap:16px}
.highlight-icon{font-size:2.2rem}
.highlight-item h4{font-size:.88rem;font-weight:600;color:var(--c-dark);margin-bottom:2px}
.highlight-item p{font-size:.76rem;color:var(--c-text-muted);letter-spacing:.3px}

/* ===== ABOUT (Homepage) ===== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.about-images{position:relative}
.about-img-main{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}
.about-img-main img{width:100%;height:460px;object-fit:cover;transition:transform .8s ease}
.about-img-main:hover img{transform:scale(1.04)}
.about-img-side{
  position:absolute;bottom:-30px;right:-30px;width:210px;
  border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-xl);border:5px solid var(--c-white);
}
.about-img-side img{width:100%;height:160px;object-fit:cover}
.about-badge{
  position:absolute;bottom:-24px;left:-24px;background:var(--c-primary);color:var(--c-white);
  padding:22px 28px;border-radius:var(--radius-md);text-align:center;box-shadow:var(--shadow-glow);
}
.badge-number{display:block;font-family:var(--font-heading);font-size:2.2rem;font-weight:700;line-height:1}
.badge-text{font-size:.72rem;opacity:.85;line-height:1.4;letter-spacing:.5px}

.about-text .section-title{margin-bottom:22px}
.about-text p{color:var(--c-text-light);margin-bottom:16px;font-size:.98rem;line-height:1.8}
.about-stats{display:flex;gap:44px;margin:36px 0}
.stat-num{display:block;font-family:var(--font-heading);font-size:2rem;font-weight:700;color:var(--c-primary)}
.stat-label{font-size:.76rem;color:var(--c-text-muted);text-transform:uppercase;letter-spacing:1.5px}

/* ===== FEATURED DISHES (Homepage) ===== */
.featured-dishes{background:var(--c-bg-cream)}
.dishes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.dish-card{
  background:var(--c-white);border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);transition:var(--transition);position:relative;
}
.dish-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.dish-card-img{position:relative;height:240px;overflow:hidden}
.dish-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.dish-card:hover .dish-card-img img{transform:scale(1.06)}
.dish-card-badge{
  position:absolute;top:16px;left:16px;
  background:var(--c-primary);color:var(--c-white);
  padding:5px 14px;border-radius:var(--radius-full);
  font-size:.72rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
}
.dish-card-body{padding:24px 26px}
.dish-card-body h3{
  font-family:var(--font-heading);font-size:1.2rem;font-weight:600;
  color:var(--c-dark);margin-bottom:8px;
}
.dish-card-body p{font-size:.88rem;color:var(--c-text-light);line-height:1.6;margin-bottom:16px}
.dish-card-footer{display:flex;justify-content:space-between;align-items:center}
.dish-price{
  font-family:var(--font-heading);font-size:1.2rem;font-weight:700;color:var(--c-primary);
}
.dish-link{
  font-size:.82rem;font-weight:600;color:var(--c-primary);
  display:flex;align-items:center;gap:4px;transition:var(--transition);
}
.dish-link:hover{gap:8px}

/* ===== WHY CHOOSE US ===== */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.why-card{
  text-align:center;padding:40px 28px;border-radius:var(--radius-lg);
  background:var(--c-white);border:1px solid var(--c-border-light);
  transition:var(--transition);position:relative;overflow:hidden;
}
.why-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--c-primary),var(--c-accent));
  transform:scaleX(0);transition:var(--transition);
}
.why-card:hover::before{transform:scaleX(1)}
.why-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:transparent}
.why-icon{font-size:2.5rem;margin-bottom:20px}
.why-card h4{font-family:var(--font-heading);font-size:1.1rem;color:var(--c-dark);margin-bottom:10px}
.why-card p{font-size:.86rem;color:var(--c-text-light);line-height:1.6}

/* ===== TESTIMONIALS ===== */
.testimonials{background:var(--c-bg-cream)}
.testimonials-slider{overflow:hidden;position:relative;max-width:800px;margin:0 auto}
.testimonial-track{display:flex;transition:transform .6s cubic-bezier(.4,0,.2,1)}
.testimonial-card{flex:0 0 100%;padding:0 16px;text-align:center}
.testimonial-card .stars{color:var(--c-accent);font-size:1.2rem;margin-bottom:20px;letter-spacing:3px}
.testimonial-card > p{
  font-family:var(--font-heading);font-size:1.2rem;font-style:italic;
  color:var(--c-text);line-height:1.8;margin-bottom:28px;position:relative;padding:0 20px;
}
.testimonial-card > p::before{
  content:'"';font-family:var(--font-heading);font-size:4rem;color:var(--c-primary-glow);
  position:absolute;top:-20px;left:0;line-height:1;opacity:.15;
}
.testimonial-author{display:flex;align-items:center;gap:14px;justify-content:center}
.author-avatar{
  width:50px;height:50px;border-radius:50%;
  background:linear-gradient(135deg,var(--c-primary),var(--c-primary-light));
  color:var(--c-white);display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:1.1rem;box-shadow:0 4px 12px rgba(184,40,60,.2);
}
.testimonial-author strong{display:block;font-size:.92rem;color:var(--c-dark)}
.testimonial-author span{font-size:.78rem;color:var(--c-text-muted)}
.testimonial-dots{display:flex;justify-content:center;gap:10px;margin-top:36px}
.testimonial-dots .dot{
  width:10px;height:10px;border-radius:50%;background:var(--c-border);
  cursor:pointer;transition:var(--transition);
}
.testimonial-dots .dot.active{background:var(--c-primary);transform:scale(1.3)}

/* ===== CTA BANNER ===== */
.cta-banner{
  position:relative;padding:100px 0;text-align:center;overflow:hidden;
}
.cta-banner-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
}
.cta-banner-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(17,17,17,.92),rgba(184,40,60,.8),rgba(17,17,17,.9));
}
.cta-content{position:relative;z-index:2}
.cta-content h2{
  font-family:var(--font-heading);font-size:clamp(1.9rem,4vw,2.8rem);
  color:var(--c-white);margin-bottom:14px;
}
.cta-content h2 em{font-style:italic;color:var(--c-accent)}
.cta-content p{color:rgba(255,255,255,.75);font-size:1.08rem;margin-bottom:32px}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* ===== FOOTER ===== */
.footer{background:var(--c-dark);color:rgba(255,255,255,.65);padding:72px 0 0}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:48px;margin-bottom:56px}
.footer-logo{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.footer-logo-img{height:100px;width:auto;border-radius:10px}
.footer-brand p{font-size:.88rem;line-height:1.7;margin-bottom:24px}

.social-links{display:flex;gap:10px}
.social-link{
  width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;font-weight:600;
  font-size:.82rem;color:rgba(255,255,255,.6);transition:var(--transition);
}
.social-link:hover{background:var(--c-primary);color:var(--c-white);transform:translateY(-2px)}

.footer-col h4{color:var(--c-white);font-size:.85rem;font-weight:600;margin-bottom:18px;text-transform:uppercase;letter-spacing:1.5px}
.footer-col ul li{margin-bottom:10px}
.footer-col ul a{font-size:.86rem;transition:var(--transition)}
.footer-col ul a:hover{color:var(--c-accent);padding-left:4px}
.contact-list li{font-size:.86rem;line-height:1.6;margin-bottom:14px}
.footer-hours{margin-top:20px}
.footer-hours strong{color:var(--c-white);font-size:.86rem}
.footer-hours p{font-size:.82rem}

.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);padding:28px 0;text-align:center;
}
.footer-bottom p{font-size:.8rem;color:rgba(255,255,255,.35)}

/* ===== CONTACT FORM ===== */
.contact-wrapper{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:start}
.contact-info .section-title{margin-bottom:22px}
.contact-info > p{color:var(--c-text-light);margin-bottom:36px;line-height:1.8}
.contact-details{display:flex;flex-direction:column;gap:28px}
.contact-detail{display:flex;align-items:flex-start;gap:18px}
.detail-icon{
  font-size:1.5rem;flex-shrink:0;width:50px;height:50px;
  border-radius:var(--radius-md);background:var(--c-primary-glow);
  display:flex;align-items:center;justify-content:center;
}
.contact-detail strong{display:block;font-size:.9rem;color:var(--c-dark);margin-bottom:3px}
.contact-detail p{font-size:.88rem;color:var(--c-text-light);line-height:1.5}

.contact-form-wrap{
  background:var(--c-white);border-radius:var(--radius-lg);
  padding:44px;box-shadow:var(--shadow-md);border:1px solid var(--c-border-light);
}
.contact-form h3{font-family:var(--font-heading);font-size:1.4rem;margin-bottom:28px;color:var(--c-dark)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-group{margin-bottom:20px}
.form-group label{
  display:block;font-size:.78rem;font-weight:600;color:var(--c-text);
  margin-bottom:7px;text-transform:uppercase;letter-spacing:.8px;
}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:13px 18px;border:1.5px solid var(--c-border);
  border-radius:var(--radius-sm);font-size:.92rem;color:var(--c-text);
  background:var(--c-bg);transition:var(--transition);outline:none;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  border-color:var(--c-primary);box-shadow:0 0 0 4px rgba(184,40,60,.08);
}
.form-group textarea{resize:vertical;min-height:90px}

/* ===== MENU PAGE ===== */
.menu-tabs{
  display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:52px;
}
.menu-tab{
  padding:11px 24px;border-radius:var(--radius-full);font-size:.84rem;
  font-weight:500;color:var(--c-text-light);background:var(--c-white);
  border:1.5px solid var(--c-border);transition:var(--transition);
}
.menu-tab:hover{border-color:var(--c-primary);color:var(--c-primary)}
.menu-tab.active{
  background:var(--c-primary);color:var(--c-white);border-color:var(--c-primary);
  box-shadow:0 3px 16px rgba(184,40,60,.25);
}
.menu-panel{display:none}
.menu-panel.active{display:block;animation:fadeInUp .5s ease}
@keyframes fadeInUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

.menu-category-header{
  display:flex;align-items:center;gap:16px;margin-bottom:32px;
}
.menu-category-header h3{
  font-family:var(--font-heading);font-size:1.5rem;color:var(--c-dark);white-space:nowrap;
}
.menu-category-header .line{flex:1;height:1px;background:var(--c-border)}

.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:20px}
.menu-item{
  background:var(--c-white);padding:26px;border-radius:var(--radius-md);
  border:1px solid var(--c-border-light);transition:var(--transition);position:relative;
}
.menu-item:hover{
  border-color:var(--c-primary);box-shadow:var(--shadow-md);transform:translateY(-3px);
}
.menu-item.featured{border:2px solid var(--c-primary);background:linear-gradient(135deg,var(--c-white),var(--c-primary-glow))}
.menu-badge{
  position:absolute;top:-11px;right:20px;
  background:var(--c-primary);color:var(--c-white);
  padding:5px 16px;border-radius:var(--radius-full);
  font-size:.7rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;
}
.menu-item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:10px}
.menu-item-header h4{font-family:var(--font-heading);font-size:1.05rem;font-weight:600;color:var(--c-dark);line-height:1.35}
.menu-item-header h4 .zh{font-family:var(--font-chinese);font-weight:600;color:var(--c-text);display:inline}
.menu-item-header h4 .en{font-family:var(--font-heading);font-weight:400;color:var(--c-text-light);font-size:.9rem;display:inline}
.menu-item-header h4 .slash{color:var(--c-text-muted);margin:0 4px;font-weight:300;font-size:.85rem}
.menu-item p .zh-desc{font-family:var(--font-chinese);color:var(--c-text-muted);font-size:.82rem;display:block;margin-top:2px}
.menu-price{
  font-family:var(--font-heading);font-size:1.1rem;font-weight:700;
  color:var(--c-primary);white-space:nowrap;
}
.menu-item p{font-size:.86rem;color:var(--c-text-light);line-height:1.55}
.menu-note{
  text-align:center;margin-top:44px;padding:24px;background:var(--c-white);
  border-radius:var(--radius-md);border:1px solid var(--c-border-light);
  color:var(--c-text-light);font-size:.9rem;
}

/* ===== GALLERY PAGE ===== */
.gallery-filters{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:48px}
.gallery-filter{
  padding:10px 22px;border-radius:var(--radius-full);font-size:.84rem;
  font-weight:500;color:var(--c-text-light);background:var(--c-white);
  border:1.5px solid var(--c-border);transition:var(--transition);
}
.gallery-filter:hover{border-color:var(--c-primary);color:var(--c-primary)}
.gallery-filter.active{background:var(--c-primary);color:var(--c-white);border-color:var(--c-primary)}

.gallery-masonry{columns:3;column-gap:20px}
.gallery-masonry .gallery-item{
  break-inside:avoid;margin-bottom:20px;border-radius:var(--radius-md);
  overflow:hidden;position:relative;cursor:pointer;
}
.gallery-masonry .gallery-item img{width:100%;display:block;transition:transform .7s ease}
.gallery-masonry .gallery-item:hover img{transform:scale(1.06)}
.gallery-masonry .gallery-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(17,17,17,.8) 0%,transparent 50%);
  display:flex;align-items:flex-end;padding:24px;opacity:0;transition:var(--transition);
}
.gallery-masonry .gallery-item:hover .gallery-overlay{opacity:1}
.gallery-masonry .gallery-overlay span{color:var(--c-white);font-weight:600;font-size:.95rem;letter-spacing:.5px}

/* Gallery Preview on Homepage */
.gallery-preview-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:240px;gap:16px}
.gallery-preview-item{position:relative;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;box-shadow:var(--shadow-sm);transition:var(--transition)}
.gallery-preview-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.gallery-preview-item:hover img{transform:scale(1.06)}
.gallery-preview-item:hover{box-shadow:var(--shadow-md)}
.gallery-preview-item.tall{grid-row:span 2}
.gallery-preview-item.wide{grid-column:span 2}
.gallery-preview-overlay{position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.65) 0%,transparent 60%);opacity:0;transition:var(--transition);display:flex;align-items:flex-end;padding:20px}
.gallery-preview-item:hover .gallery-preview-overlay{opacity:1}
.gallery-preview-overlay span{color:var(--c-white);font-weight:600;font-size:.95rem;letter-spacing:.5px}
.text-center{text-align:center}

/* Lightbox */
.lightbox{
  position:fixed;inset:0;z-index:3000;background:rgba(0,0,0,.92);
  display:none;align-items:center;justify-content:center;padding:40px;
  backdrop-filter:blur(8px);
}
.lightbox.active{display:flex}
.lightbox img{max-width:90%;max-height:85vh;border-radius:var(--radius-md);box-shadow:var(--shadow-xl)}
.lightbox-close{
  position:absolute;top:24px;right:32px;font-size:2rem;color:rgba(255,255,255,.7);
  cursor:pointer;transition:var(--transition);z-index:3001;
}
.lightbox-close:hover{color:var(--c-white);transform:rotate(90deg)}
.lightbox-caption{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  color:rgba(255,255,255,.8);font-size:1rem;font-weight:500;
}

/* ===== ABOUT PAGE ===== */
.timeline{position:relative;max-width:800px;margin:0 auto;padding:20px 0}
.timeline::before{
  content:'';position:absolute;left:50%;top:0;bottom:0;width:2px;
  background:linear-gradient(to bottom,var(--c-primary),var(--c-accent));
  transform:translateX(-50%);
}
.timeline-item{
  position:relative;padding:0 0 48px;display:grid;grid-template-columns:1fr 1fr;gap:60px;
}
.timeline-item:nth-child(even) .timeline-content{grid-column:2;text-align:left}
.timeline-item:nth-child(even) .timeline-date{grid-column:1;text-align:right;grid-row:1}
.timeline-item:nth-child(odd) .timeline-content{grid-column:1;text-align:right;grid-row:1}
.timeline-item:nth-child(odd) .timeline-date{grid-column:2;text-align:left}
.timeline-dot{
  position:absolute;left:50%;top:4px;width:16px;height:16px;
  background:var(--c-primary);border-radius:50%;border:3px solid var(--c-white);
  transform:translateX(-50%);box-shadow:var(--shadow-glow);z-index:1;
}
.timeline-date{
  font-family:var(--font-heading);font-size:1.3rem;font-weight:700;color:var(--c-primary);
  padding-top:0;
}
.timeline-content h4{font-family:var(--font-heading);font-size:1.1rem;color:var(--c-dark);margin-bottom:6px}
.timeline-content p{font-size:.88rem;color:var(--c-text-light);line-height:1.6}

.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.value-card{
  text-align:center;padding:40px 30px;border-radius:var(--radius-lg);
  background:var(--c-white);border:1px solid var(--c-border-light);
  transition:var(--transition);
}
.value-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.value-icon{font-size:2.8rem;margin-bottom:18px}
.value-card h4{font-family:var(--font-heading);font-size:1.1rem;color:var(--c-dark);margin-bottom:10px}
.value-card p{font-size:.86rem;color:var(--c-text-light);line-height:1.6}

/* ===== FAQ ===== */
.faq-list{max-width:780px;margin:0 auto}
.faq-item{
  border:1px solid var(--c-border-light);border-radius:var(--radius-md);
  margin-bottom:14px;overflow:hidden;background:var(--c-white);transition:var(--transition);
}
.faq-item:hover{border-color:var(--c-border)}
.faq-question{
  padding:22px 28px;font-weight:600;font-size:.98rem;color:var(--c-dark);
  display:flex;justify-content:space-between;align-items:center;cursor:pointer;
  transition:var(--transition);
}
.faq-question:hover{color:var(--c-primary)}
.faq-question .faq-icon{
  font-size:1.4rem;color:var(--c-primary);transition:var(--transition);
  flex-shrink:0;margin-left:12px;
}
.faq-item.open .faq-question{color:var(--c-primary)}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-answer{
  max-height:0;overflow:hidden;transition:max-height .4s ease;
}
.faq-answer-inner{
  padding:0 28px 22px;font-size:.9rem;color:var(--c-text-light);line-height:1.7;
}
.faq-item.open .faq-answer{max-height:300px}

/* ===== MODAL ===== */
.modal{
  position:fixed;inset:0;z-index:2000;display:none;align-items:center;
  justify-content:center;padding:28px;
}
.modal.active{display:flex}
.modal-content{
  background:var(--c-white);padding:52px;border-radius:var(--radius-lg);
  text-align:center;max-width:460px;width:100%;box-shadow:var(--shadow-xl);
  animation:modalIn .4s ease;
}
@keyframes modalIn{from{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-icon{
  width:68px;height:68px;border-radius:50%;
  background:linear-gradient(135deg,var(--c-primary),var(--c-primary-light));
  color:var(--c-white);font-size:1.8rem;display:flex;align-items:center;
  justify-content:center;margin:0 auto 22px;box-shadow:var(--shadow-glow);
}
.modal-content h3{font-family:var(--font-heading);font-size:1.5rem;color:var(--c-dark);margin-bottom:12px}
.modal-content p{color:var(--c-text-light);margin-bottom:28px;line-height:1.6}
.modal-backdrop{position:fixed;inset:0;z-index:1999;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);display:none}
.modal-backdrop.active{display:block}

/* ===== SCROLL REVEAL ===== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}
.reveal-delay-4{transition-delay:.4s}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .about-grid{grid-template-columns:1fr;gap:52px}
  .about-images{max-width:520px;margin:0 auto}
  .contact-wrapper{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .dishes-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-masonry{columns:2}
  .timeline::before{left:24px}
  .timeline-item{grid-template-columns:1fr;gap:0;padding-left:56px}
  .timeline-item:nth-child(even) .timeline-content,
  .timeline-item:nth-child(odd) .timeline-content,
  .timeline-item:nth-child(even) .timeline-date,
  .timeline-item:nth-child(odd) .timeline-date{grid-column:1;text-align:left;grid-row:auto}
  .timeline-dot{left:24px}
}
@media(max-width:768px){
  .section{padding:80px 0}
  .nav-toggle{display:flex}
  .nav-links{
    position:fixed;top:0;right:-100%;width:300px;height:100vh;
    background:var(--c-white);flex-direction:column;padding:90px 32px 32px;
    gap:6px;transition:var(--transition);box-shadow:var(--shadow-xl);z-index:999;
  }
  .nav-links.open{right:0}
  .nav-links a{color:var(--c-text)!important;padding:14px 22px;width:100%;border-radius:var(--radius-sm);font-size:.95rem}
  .nav-links a::after{display:none}
  .nav-links a:hover{background:var(--c-bg-warm)}
  .nav-cta{margin-top:12px}

  .highlights .container{gap:20px}
  .highlight-item{flex:1 1 45%;justify-content:center}
  .logo-img{height:48px}
  .navbar.scrolled .logo-img{height:42px}

  .menu-grid{grid-template-columns:1fr}
  .dishes-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr}
  .gallery-masonry{columns:1}
  .gallery-preview-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .gallery-preview-item.tall{grid-row:span 1}
  .gallery-preview-item.wide{grid-column:span 2}

  .about-stats{gap:24px;flex-wrap:wrap}
  .about-img-side{right:-10px;bottom:-20px;width:160px}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .page-hero{min-height:340px}
  .page-hero .section-title{font-size:clamp(1.8rem,5vw,2.4rem)}
  .hero-content{padding-top:80px}
}
@media(max-width:480px){
  .hero-btns,.cta-btns{flex-direction:column;width:100%;max-width:320px;margin:0 auto}
  .btn{width:100%}
  .menu-tabs{gap:6px}
  .menu-tab{padding:9px 16px;font-size:.78rem}
  .contact-form-wrap{padding:28px}
  .gallery-filters{gap:6px}
  .gallery-filter{padding:8px 16px;font-size:.78rem}
  .gallery-preview-grid{grid-template-columns:1fr;grid-auto-rows:200px}
  .gallery-preview-item.wide{grid-column:span 1}
}
