/* ===== Reset & Base ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#1a0f0a;
  --char:#0d0805;
  --paper:#fdf6ed;
  --fire:#e63946;
  --ember:#ff6b35;
  --gold:#f4a261;
  --gold-deep:#c87f2c;
  --amber:#ffb627;
  --cream:#f5e6d3;
  --muted:#a08570;
  --line:rgba(244,162,97,.25);
  --shadow:0 20px 60px -20px rgba(0,0,0,.6);
  --serif:"Noto Serif SC",serif;
  --brush:"Ma Shan Zheng",cursive;
  --sans:"Noto Sans SC",sans-serif;
}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--sans);background:var(--char);color:var(--cream);line-height:1.7;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
em{font-style:normal;color:var(--ember);font-family:var(--brush);font-weight:400}

/* ===== Nav ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;backdrop-filter:blur(14px);background:rgba(13,8,5,.55);border-bottom:1px solid var(--line);transition:background .3s}
.nav.scrolled{background:rgba(13,8,5,.92);box-shadow:0 8px 30px -10px rgba(0,0,0,.7)}
.nav-inner{max-width:1240px;margin:0 auto;padding:14px 28px;display:flex;align-items:center;gap:24px}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-weight:900;font-size:22px}
.logo-mark{width:38px;height:38px;display:grid;place-items:center;background:linear-gradient(135deg,var(--fire),var(--ember));border-radius:10px;font-family:var(--brush);font-size:24px;color:#fff;box-shadow:0 4px 16px -4px var(--fire)}
.logo-text{letter-spacing:2px}
.nav-links{display:flex;gap:28px;margin-left:auto;font-size:15px;font-weight:500;color:var(--cream);opacity:.85}
.nav-links a{position:relative;padding:6px 0;transition:opacity .2s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--ember);transition:width .25s}
.nav-links a:hover{opacity:1}
.nav-links a:hover::after{width:100%}
.nav-cta{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:999px;background:linear-gradient(135deg,var(--fire),var(--ember));color:#fff;font-weight:700;font-size:14px;box-shadow:0 6px 20px -6px var(--fire);transition:transform .2s}
.nav-cta:hover{transform:translateY(-2px)}

/* ===== Hero ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;padding:120px 24px 80px}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.08);animation:heroZoom 18s ease-out forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(13,8,5,.35) 0%,rgba(13,8,5,.78) 60%,rgba(13,8,5,.95) 100%)}
.hero-glow{position:absolute;left:50%;top:38%;width:760px;height:760px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(255,107,53,.28) 0%,rgba(230,57,70,.12) 35%,transparent 70%);filter:blur(40px);pointer-events:none;animation:glowPulse 6s ease-in-out infinite}
@keyframes glowPulse{0%,100%{opacity:.6;transform:translate(-50%,-50%) scale(1)}50%{opacity:.9;transform:translate(-50%,-50%) scale(1.08)}}
.hero-content{position:relative;z-index:2;max-width:820px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;border:1px solid var(--gold);border-radius:999px;color:var(--gold);font-size:13px;font-weight:500;letter-spacing:2px;margin-bottom:32px;background:rgba(244,162,97,.08);animation:fadeUp .8s .1s both}
.hero-eyebrow i{color:var(--ember);font-size:16px}
.hero-title{font-family:var(--serif);font-weight:900;font-size:clamp(48px,9vw,108px);line-height:1.05;letter-spacing:2px;margin-bottom:28px}
.hero-line{display:block;animation:fadeUp .9s .25s both}
.hero-line--accent{color:transparent;background:linear-gradient(135deg,var(--amber),var(--ember),var(--fire));-webkit-background-clip:text;background-clip:text;animation:fadeUp .9s .4s both}
.hero-sub{font-size:clamp(16px,2vw,19px);color:rgba(245,230,211,.82);max-width:620px;margin:0 auto 36px;line-height:1.85;animation:fadeUp .9s .5s both}
.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:56px;animation:fadeUp .9s .6s both}
.btn{display:inline-flex;align-items:center;gap:8px;padding:15px 30px;border-radius:999px;font-weight:700;font-size:15px;letter-spacing:1px;transition:all .25s;cursor:pointer;border:none}
.btn-primary{background:linear-gradient(135deg,var(--fire),var(--ember));color:#fff;box-shadow:0 10px 30px -8px rgba(230,57,70,.6)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 40px -10px rgba(230,57,70,.75)}
.btn-ghost{background:rgba(245,230,211,.06);color:var(--cream);border:1px solid var(--line)}
.btn-ghost:hover{background:rgba(245,230,211,.12);border-color:var(--gold)}
.hero-meta{display:inline-flex;align-items:center;gap:24px;padding:18px 32px;background:rgba(13,8,5,.5);border:1px solid var(--line);border-radius:18px;backdrop-filter:blur(8px);animation:fadeUp .9s .75s both}
.meta-item{display:flex;align-items:center;gap:10px}
.meta-item i{font-size:22px;color:var(--gold)}
.meta-label{display:block;font-size:11px;color:var(--muted);letter-spacing:2px}
.meta-value{display:block;font-size:15px;font-weight:700;color:var(--cream)}
.meta-divider{width:1px;height:34px;background:var(--line)}
.hero-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--gold);font-size:12px;letter-spacing:3px;opacity:.7;animation:scrollBob 2.4s ease-in-out infinite}
@keyframes scrollBob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

/* ===== Sections ===== */
section{padding:110px 24px;position:relative}
.section-head{max-width:760px;margin:0 auto 60px;text-align:center}
.section-tag{display:inline-block;padding:6px 16px;border:1px solid var(--gold);border-radius:999px;color:var(--gold);font-size:12px;letter-spacing:3px;font-weight:500;margin-bottom:22px}
.section-title{font-family:var(--serif);font-weight:900;font-size:clamp(34px,6vw,60px);letter-spacing:2px;line-height:1.15}
.section-lead{margin-top:20px;color:rgba(245,230,211,.7);font-size:17px;line-height:1.85}

/* ===== Menu ===== */
.menu{background:linear-gradient(180deg,var(--char) 0%,#160d08 100%)}
.menu-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.dish{background:linear-gradient(165deg,#1f140d,#160c07);border:1px solid var(--line);border-radius:24px;overflow:hidden;transition:transform .35s,box-shadow .35s,border-color .35s}
.dish:hover{transform:translateY(-6px);box-shadow:0 30px 60px -25px rgba(230,57,70,.4);border-color:rgba(244,162,97,.5)}
.dish--feature{grid-column:1/-1;display:grid;grid-template-columns:1.1fr 1fr;align-items:stretch}
.dish-img{height:240px;background-size:cover;background-position:center;position:relative}
.dish-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(13,8,5,.5))}
.dish--feature .dish-img{height:auto;min-height:380px}
.dish-body{padding:30px 30px 34px}
.dish-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.dish-name{font-family:var(--serif);font-weight:900;font-size:26px;letter-spacing:1px;color:var(--cream)}
.dish--feature .dish-name{font-size:34px}
.dish-price{font-family:var(--serif);font-weight:700;font-size:18px;color:var(--amber);white-space:nowrap}
.dish-desc{color:rgba(245,230,211,.72);font-size:15.5px;line-height:1.85;margin-bottom:20px}
.dish-tags{display:flex;gap:8px;flex-wrap:wrap}
.tag{padding:5px 14px;border-radius:999px;font-size:12px;font-weight:600;letter-spacing:1px;background:rgba(244,162,97,.12);color:var(--gold);border:1px solid rgba(244,162,97,.25)}

/* ===== Story ===== */
.story{position:relative;overflow:hidden}
.story-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:grayscale(.2) brightness(.55)}
.story-overlay{position:absolute;inset:0;background:linear-gradient(115deg,rgba(13,8,5,.96) 0%,rgba(13,8,5,.78) 50%,rgba(26,15,10,.6) 100%)}
.story-inner{position:relative;z-index:2;max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr;gap:60px;align-items:center}
.section-tag--light{border-color:var(--gold);color:var(--gold)}
.section-title--light{color:#fff}
.story-lead{font-size:20px;font-weight:500;color:#fff;margin-bottom:18px;font-family:var(--serif)}
.story-text p{color:rgba(245,230,211,.78);font-size:16px;line-height:1.95;margin-bottom:16px}
.story-quote{margin-top:30px;padding:26px 28px;border-left:3px solid var(--ember);background:rgba(255,107,53,.06);border-radius:0 14px 14px 0;position:relative}
.story-quote i{position:absolute;top:18px;right:22px;font-size:42px;color:rgba(255,107,53,.3)}
.story-quote p{font-family:var(--brush);font-size:24px;color:var(--amber);line-height:1.6;margin:0}
.story-quote cite{display:block;margin-top:14px;font-style:normal;font-size:14px;color:var(--gold);letter-spacing:2px}
.story-stats{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.stat{padding:32px 24px;background:rgba(245,230,211,.05);border:1px solid var(--line);border-radius:18px;text-align:center;backdrop-filter:blur(6px);transition:transform .3s,border-color .3s}
.stat:hover{transform:translateY(-4px);border-color:var(--gold)}
.stat-num{display:block;font-family:var(--serif);font-weight:900;font-size:48px;color:transparent;background:linear-gradient(135deg,var(--amber),var(--ember));-webkit-background-clip:text;background-clip:text;line-height:1}
.stat-label{display:block;margin-top:8px;font-size:13px;letter-spacing:3px;color:var(--muted)}

/* ===== Location ===== */
.location{background:linear-gradient(180deg,#160d08 0%,var(--char) 100%)}
.location-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1fr 1.1fr;gap:40px;align-items:stretch}
.location-info{display:flex;flex-direction:column;gap:18px}
.info-card{display:flex;gap:18px;padding:26px 28px;background:linear-gradient(165deg,#1f140d,#160c07);border:1px solid var(--line);border-radius:18px;transition:transform .3s,border-color .3s}
.info-card:hover{transform:translateX(6px);border-color:rgba(244,162,97,.45)}
.info-icon{flex:0 0 52px;height:52px;display:grid;place-items:center;background:linear-gradient(135deg,var(--fire),var(--ember));border-radius:14px;font-size:24px;color:#fff;box-shadow:0 8px 22px -8px var(--fire)}
.info-title{font-family:var(--serif);font-weight:700;font-size:18px;color:var(--cream);margin-bottom:6px;letter-spacing:1px}
.info-text{color:rgba(245,230,211,.7);font-size:14.5px;line-height:1.7}

.location-map{position:relative;border-radius:22px;overflow:hidden;border:1px solid var(--line);background:#0a0604;min-height:440px}
.map-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(244,162,97,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(244,162,97,.08) 1px,transparent 1px);background-size:44px 44px}
.map-street{position:absolute;background:rgba(244,162,97,.1)}
.map-street--1{left:0;right:0;top:50%;height:14px;transform:translateY(-50%)}
.map-street--2{left:30%;top:0;bottom:0;width:12px}
.map-street--3{right:18%;top:50%;width:60%;height:8px;background:rgba(230,57,70,.15)}
.map-gate{position:absolute;top:18px;left:50%;transform:translateX(-50%);padding:6px 16px;background:rgba(244,162,97,.15);border:1px solid var(--gold);border-radius:999px;font-size:12px;color:var(--gold);letter-spacing:2px}
.map-pin-anim{position:absolute;left:50%;top:55%;transform:translate(-50%,-50%);width:54px;height:54px;display:grid;place-items:center}
.map-pin-anim i{font-size:40px;color:var(--fire);filter:drop-shadow(0 6px 14px rgba(230,57,70,.7));position:relative;z-index:2;animation:pinBob 2.2s ease-in-out infinite}
@keyframes pinBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.map-pulse{position:absolute;inset:0;border-radius:50%;background:var(--fire);opacity:.3;animation:pulse 2s ease-out infinite}
@keyframes pulse{0%{transform:scale(.6);opacity:.5}100%{transform:scale(2.4);opacity:0}}
.map-label{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);padding:14px 22px;background:rgba(13,8,5,.85);border:1px solid var(--gold);border-radius:14px;text-align:center;backdrop-filter:blur(8px)}
.map-label strong{display:block;font-family:var(--serif);font-size:16px;color:var(--amber);letter-spacing:1px}
.map-label span{display:block;font-size:12px;color:var(--muted);margin-top:2px}

/* ===== Voices ===== */
.voices{background:linear-gradient(180deg,var(--char) 0%,#160d08 100%)}
.voices-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.voice{padding:32px 30px;background:linear-gradient(165deg,#1f140d,#150b06);border:1px solid var(--line);border-radius:20px;transition:transform .3s,border-color .3s,box-shadow .3s}
.voice:hover{transform:translateY(-5px);border-color:rgba(244,162,97,.45);box-shadow:0 24px 50px -25px rgba(230,57,70,.35)}
.voice-stars{display:flex;gap:3px;margin-bottom:18px}
.voice-stars i{color:var(--amber);font-size:18px}
.voice blockquote{font-size:16px;line-height:1.85;color:rgba(245,230,211,.85);margin-bottom:22px;position:relative;padding-left:18px;border-left:2px solid var(--ember)}
.voice-name{display:block;font-family:var(--serif);font-weight:700;font-size:16px;color:var(--cream)}
.voice-role{display:block;font-size:12.5px;color:var(--gold);letter-spacing:1px;margin-top:3px}

/* ===== Footer ===== */
.footer{padding:50px 24px 40px;background:#080503;border-top:1px solid var(--line)}
.footer-inner{max-width:1180px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}
.footer-brand{display:flex;align-items:center;gap:14px}
.footer-brand strong{display:block;font-family:var(--serif);font-size:18px;color:var(--cream);letter-spacing:1px}
.footer-brand span{display:block;font-size:13px;color:var(--muted);margin-top:2px}
.footer-note{text-align:right}
.footer-note p{color:var(--gold);font-size:14px;letter-spacing:1px}
.footer-copy{color:var(--muted)!important;font-size:12px!important;margin-top:6px!important}

/* ===== Reveal on scroll ===== */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ===== Responsive ===== */
@media(max-width:900px){
  .nav-links{display:none}
  .nav-inner{padding:12px 18px}
  .hero-meta{flex-wrap:wrap;gap:14px;padding:14px 20px}
  .meta-divider{display:none}
  .menu-grid{grid-template-columns:1fr}
  .dish--feature{grid-template-columns:1fr}
  .dish--feature .dish-img{min-height:240px}
  .story-inner{grid-template-columns:1fr;gap:40px}
  .location-grid{grid-template-columns:1fr}
  .voices-grid{grid-template-columns:1fr}
  .footer-inner{flex-direction:column;text-align:center}
  .footer-note{text-align:center}
  section{padding:80px 20px}
}
