
    :root {
      --red:#C8102E; --red-dark:#8B0A1E; --red-soft:#E8374F;
      --gold:#D4A017; --gold-lt:#F0C040;
      --ink:#0D0A08; --paper:#F7F0E6; --text-lt:rgba(247,240,230,.72);
    }
    *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
    html{scroll-behavior:smooth}
    body{font-family:'Inter',sans-serif;background:var(--ink);color:var(--paper);overflow-x:hidden}

    /* NAV */
    nav{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;justify-content:space-between;align-items:center;padding:1.6rem 3.5rem;transition:background .45s,padding .4s,border-color .4s;border-bottom:1px solid transparent}
    nav.scrolled{background:rgba(13,10,8,.9);backdrop-filter:blur(16px);padding:1rem 3.5rem;border-color:rgba(212,160,23,.18)}
    .nav-logo{display:flex;flex-direction:column;align-items:flex-start;text-decoration:none;line-height:1}
    .logo-cn{font-family:'Noto Serif SC',serif;font-size:1.5rem;color:var(--gold);letter-spacing:.12em}
    .logo-fr{font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(247,240,230,.45);margin-top:.15rem}
    .nav-links{display:flex;gap:2.4rem;list-style:none}
    .nav-links a{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--paper);opacity:.6;text-decoration:none;transition:opacity .25s,color .25s;position:relative}
    .nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transition:transform .3s}
    .nav-links a:hover{opacity:1;color:var(--gold-lt)}
    .nav-links a:hover::after{transform:scaleX(1)}

    .hamburger {
      display: none;
      flex-direction: column;
      background: none;
      border: none;
      cursor: pointer;
      padding: 10px;
    }
    .hamburger span {
      width: 25px;
      height: 3px;
      background: var(--paper);
      margin: 3px 0;
      transition: 0.3s;
    }
    .nav-links.active {
      display: flex !important;
    }

    /* HERO */
    #hero{position:relative;height:100vh;overflow:hidden;display:flex;align-items:center;justify-content:center}
    .hero-bg{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(13,10,8,.45) 0%,rgba(13,10,8,.2) 40%,rgba(13,10,8,.85) 100%),url('https://images.unsplash.com/photo-1526318896980-cf78c088247c?w=1600&q=80') center/cover no-repeat;transform:scale(1.07);transition:transform 9s ease-out}
    .hero-bg.loaded{transform:scale(1)}
    .hero-stripe{position:absolute;top:0;width:1px;height:100%;background:linear-gradient(to bottom,transparent,rgba(200,16,46,.4),transparent)}

    /* Lanterns */
    .lantern{position:absolute;top:-20px;display:flex;flex-direction:column;align-items:center;animation:sway 4s ease-in-out infinite;transform-origin:top center}
    .lantern:nth-child(odd){animation-direction:alternate-reverse;animation-duration:5s}
    .lantern-body{width:28px;height:44px;background:radial-gradient(ellipse at 40% 40%,#ff6b35,var(--red),var(--red-dark));border-radius:50%;box-shadow:0 0 20px rgba(200,16,46,.8),0 0 40px rgba(200,16,46,.3)}
    .lantern-top,.lantern-bot{width:18px;height:5px;background:var(--gold);border-radius:2px}
    .lantern-fringe{display:flex;gap:2px;margin-top:1px}
    .lantern-fringe span{width:1px;height:14px;background:linear-gradient(to bottom,var(--gold),transparent)}
    .lantern-string{width:1px;height:80px;background:linear-gradient(to bottom,rgba(212,160,23,.6),transparent);margin-top:-5px}
    @keyframes sway{0%,100%{transform:rotate(-4deg)}50%{transform:rotate(4deg)}}

    .hero-content{position:relative;z-index:2;text-align:center;display:flex;flex-direction:column;align-items:center}
    .hero-cn-big{font-family:'Noto Serif SC',serif;font-size:clamp(3rem,8vw,6.5rem);font-weight:300;color:var(--gold);letter-spacing:.2em;line-height:1;opacity:0;animation:fadeUp .9s .3s forwards;text-shadow:0 0 60px rgba(212,160,23,.4)}
    .hero-title{font-family:'Lora',serif;font-size:clamp(2rem,5vw,3.8rem);font-weight:400;line-height:1.2;margin-top:.5rem;opacity:0;animation:fadeUp .9s .55s forwards}
    .hero-title em{font-style:italic;color:var(--gold-lt)}
    .hero-line{width:80px;height:1px;background:var(--gold);margin:1.4rem auto;opacity:0;animation:fadeUp .6s .75s forwards}
    .hero-sub{font-size:.95rem;font-weight:300;color:var(--text-lt);max-width:480px;opacity:0;animation:fadeUp .8s .9s forwards}
    .hero-cta{margin-top:2.5rem;display:flex;gap:1.1rem;opacity:0;animation:fadeUp .8s 1.1s forwards}
    .btn{padding:.85rem 2.2rem;border:none;cursor:pointer;font-family:'Inter',sans-serif;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;text-decoration:none;transition:all .3s}
    .btn-primary{background:var(--red);color:var(--paper)}
    .btn-primary:hover{background:var(--red-soft);transform:translateY(-2px);box-shadow:0 8px 28px rgba(200,16,46,.45)}
    .btn-outline{background:transparent;color:var(--paper);border:1px solid rgba(247,240,230,.35)}
    .btn-outline:hover{border-color:var(--gold);color:var(--gold-lt);transform:translateY(-2px)}
    .scroll-hint{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.4rem;opacity:0;animation:fadeIn .8s 1.8s forwards}
    .scroll-hint span{font-family:'Noto Serif SC',serif;font-size:.75rem;letter-spacing:.2em;opacity:.4;color:var(--gold)}
    .scroll-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);opacity:.5;animation:bounce 1.6s ease-in-out infinite}
    @keyframes bounce{0%,100%{transform:translateY(0);opacity:.5}50%{transform:translateY(8px);opacity:.15}}

    /* HELPERS */
    .section-label{font-size:.68rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:.9rem}
    .section-title{font-family:'Lora',serif;font-size:clamp(2rem,4vw,3rem);font-weight:400;line-height:1.25}
    .section-title em{font-style:italic;color:var(--gold-lt)}
    .gold-rule{width:50px;height:2px;background:linear-gradient(to right,var(--gold),transparent);margin:1.4rem 0}

    /* STORY */
    #story{padding:8rem 4rem;display:grid;grid-template-columns:1fr 1fr;gap:6rem;max-width:1200px;margin:0 auto;align-items:center}
    .story-visual{position:relative}
    .story-img-main{width:100%;aspect-ratio:3/4;object-fit:cover;filter:sepia(.12) contrast(1.05);transition:filter .5s;position:relative;z-index:1}
    .story-img-main:hover{filter:sepia(0) contrast(1.1)}
    .story-img-accent{position:absolute;width:55%;aspect-ratio:1;object-fit:cover;bottom:-30px;right:-30px;z-index:2;border:4px solid var(--ink);filter:sepia(.1)}
    .story-cn-char{position:absolute;top:-30px;left:-20px;font-family:'Noto Serif SC',serif;font-size:8rem;font-weight:600;color:rgba(200,16,46,.08);line-height:1;z-index:0;pointer-events:none;user-select:none}
    .story-body{color:var(--text-lt);line-height:1.9;font-weight:300;font-size:.95rem}
    .story-body p+p{margin-top:1.2rem}
    .story-stats{display:flex;gap:2.5rem;margin-top:2.8rem;padding-top:2rem;border-top:1px solid rgba(247,240,230,.1)}
    .stat-num{font-family:'Lora',serif;font-size:2.4rem;color:var(--gold);line-height:1}
    .stat-label{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;opacity:.45;margin-top:.3rem}

    /* SPÉCIALITÉS */
    #specialites{padding:7rem 4rem;background:radial-gradient(ellipse at 20% 50%,rgba(200,16,46,.06),transparent 60%),radial-gradient(ellipse at 80% 30%,rgba(212,160,23,.04),transparent 60%)}
    .spec-header{text-align:center;margin-bottom:4rem}
    .spec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;max-width:1200px;margin:0 auto;background:rgba(247,240,230,.07)}
    .spec-card{background:var(--ink);padding:2.8rem 2.4rem;position:relative;overflow:hidden;transition:background .35s}
    .spec-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:0;background:linear-gradient(to bottom,var(--gold),var(--red));transition:height .4s ease}
    .spec-card:hover{background:rgba(247,240,230,.04)}
    .spec-card:hover::before{height:100%}
    .spec-num{font-family:'Noto Serif SC',serif;font-size:3rem;color:rgba(212,160,23,.15);line-height:1;margin-bottom:1.2rem}
    .spec-name{font-family:'Lora',serif;font-size:1.3rem;margin-bottom:.5rem}
    .spec-cn{font-family:'Noto Serif SC',serif;font-size:.85rem;color:var(--gold);opacity:.7;letter-spacing:.15em;margin-bottom:1rem}
    .spec-desc{font-size:.85rem;color:var(--text-lt);line-height:1.75;font-weight:300}
    .spec-tag{display:inline-block;margin-top:1.2rem;font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;padding:.25rem .7rem;background:rgba(200,16,46,.15);color:var(--red-soft);border:1px solid rgba(200,16,46,.25)}

    /* MENU */
    #menu{padding:7rem 4rem}
    .menu-header{text-align:center;margin-bottom:4rem}
    .menu-tabs{display:flex;justify-content:center;max-width:700px;margin:0 auto 3.5rem;border:1px solid rgba(247,240,230,.1)}
    .tab-btn{flex:1;background:none;border:none;cursor:pointer;padding:.9rem 1.2rem;font-family:'Inter',sans-serif;font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(247,240,230,.4);transition:background .3s,color .3s;border-right:1px solid rgba(247,240,230,.08)}
    .tab-btn:last-child{border-right:none}
    .tab-btn.active{background:rgba(200,16,46,.15);color:var(--gold-lt)}
    .tab-btn:hover:not(.active){background:rgba(255,255,255,.04);color:var(--paper)}
    .menu-panel{display:none;max-width:1100px;margin:0 auto}
    .menu-panel.active{display:block}
    .menu-list{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid rgba(247,240,230,.07)}
    .menu-item{padding:1.6rem 2rem;border-bottom:1px solid rgba(247,240,230,.07);border-right:1px solid rgba(247,240,230,.07);display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;transition:background .3s}
    .menu-item:nth-child(even){border-right:none}
    .menu-item:hover{background:rgba(200,16,46,.05)}
    .menu-item-info{flex:1}
    .menu-item-name{font-family:'Lora',serif;font-size:1.05rem;margin-bottom:.2rem}
    .menu-item-cn{font-family:'Noto Serif SC',serif;font-size:.72rem;color:var(--gold);opacity:.6;letter-spacing:.1em;margin-bottom:.5rem}
    .menu-item-desc{font-size:.82rem;color:var(--text-lt);line-height:1.65;font-weight:300}
    .menu-item-price{font-size:1rem;color:var(--gold);white-space:nowrap;padding-top:.1rem}

    /* GALLERY */
    #ambiance{padding:7rem 4rem}
    .ambiance-header{text-align:center;margin-bottom:3.5rem}
    .ambiance-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:260px 180px;gap:8px;max-width:1200px;margin:0 auto}
    .amb-item{overflow:hidden;position:relative;cursor:pointer}
    .amb-item:nth-child(1){grid-column:1/3;grid-row:1/3}
    .amb-item:nth-child(4){grid-column:3/5}
    .amb-item img{width:100%;height:100%;object-fit:cover;filter:brightness(.8) saturate(1.1);transition:transform .55s ease,filter .45s}
    .amb-item:hover img{transform:scale(1.08);filter:brightness(.95) saturate(1.2)}
    .amb-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(13,10,8,.6) 0%,transparent 60%);opacity:0;transition:opacity .35s;display:flex;align-items:flex-end;padding:1rem 1.2rem}
    .amb-item:hover .amb-overlay{opacity:1}
    .amb-overlay span{font-family:'Lora',serif;font-style:italic;font-size:.95rem;color:var(--paper);transform:translateY(6px);transition:transform .3s .05s}
    .amb-item:hover .amb-overlay span{transform:translateY(0)}

    /* AVIS */
    #avis{padding:7rem 4rem;background:rgba(200,16,46,.03);position:relative;overflow:hidden}
    #avis::before{content:'龍';position:absolute;font-family:'Noto Serif SC',serif;font-size:28rem;color:rgba(200,16,46,.03);right:-4rem;top:-4rem;line-height:1;pointer-events:none;user-select:none}
    .avis-header{text-align:center;margin-bottom:3.5rem}
    .avis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1100px;margin:0 auto;position:relative;z-index:1}
    .avis-card{padding:2.2rem;border:1px solid rgba(247,240,230,.07);background:rgba(255,255,255,.02);position:relative;transition:border-color .3s,transform .3s}
    .avis-card::before{content:'"';position:absolute;top:1rem;right:1.5rem;font-family:'Lora',serif;font-size:5rem;line-height:1;color:var(--red);opacity:.12}
    .avis-card:hover{border-color:rgba(200,16,46,.3);transform:translateY(-3px)}
    .stars{color:var(--gold);font-size:.9rem;letter-spacing:.08em;margin-bottom:1rem}
    .avis-text{font-family:'Lora',serif;font-style:italic;font-size:1rem;line-height:1.8;color:var(--text-lt)}
    .avis-author{margin-top:1.2rem;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);opacity:.65}

    /* RESERVATION */
    #reservation{padding:7rem 4rem;position:relative;overflow:hidden}
    #reservation::after{content:'福';position:absolute;bottom:-2rem;left:-2rem;font-family:'Noto Serif SC',serif;font-size:22rem;color:rgba(200,16,46,.04);pointer-events:none;user-select:none}
    .resa-inner{max-width:700px;margin:0 auto;text-align:center;position:relative;z-index:1}
    .resa-body{color:var(--text-lt);line-height:1.8;margin:1.5rem 0 2.5rem;font-weight:300}
    .resa-form{display:grid;grid-template-columns:1fr 1fr;gap:1rem;text-align:left}
    .form-field{display:flex;flex-direction:column;gap:.4rem}
    .form-field.full{grid-column:1/-1}
    .form-field label{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;opacity:.5}
    .form-field input,.form-field select{background:rgba(255,255,255,.04);border:1px solid rgba(247,240,230,.1);padding:.85rem 1rem;color:var(--paper);font-family:'Inter',sans-serif;font-size:.88rem;outline:none;transition:border-color .3s;appearance:none}
    .form-field input:focus,.form-field select:focus{border-color:var(--red)}
    .form-field select option{background:#1a0a0a}
    .resa-submit{grid-column:1/-1;margin-top:.4rem}
    .btn-block{width:100%;padding:1rem;font-size:.82rem}

    /* FOOTER */
    footer{border-top:1px solid rgba(247,240,230,.08)}
    .footer-main{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding:4rem 4rem 3rem;max-width:1300px;margin:0 auto}
    .footer-brand p{font-size:.82rem;opacity:.4;line-height:1.8;max-width:220px;margin-top:1rem}
    .footer-col h4{font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem}
    .footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
    .footer-col li{font-size:.83rem;opacity:.45}
    .footer-col a{color:inherit;text-decoration:none;transition:opacity .2s,color .2s}
    .footer-col a:hover{opacity:1;color:var(--gold-lt)}
    .footer-bottom{text-align:center;padding:1.4rem 4rem;border-top:1px solid rgba(247,240,230,.05);font-size:.72rem;opacity:.28}

    /* ANIMATIONS */
    @keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
    @keyframes fadeIn{from{opacity:0}to{opacity:1}}
    .reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
    .reveal.visible{opacity:1;transform:translateY(0)}

    /* RESPONSIVE */
    @media(max-width:960px){
      #story{grid-template-columns:1fr;gap:3rem;padding:5rem 2rem}
      .spec-grid{grid-template-columns:1fr 1fr}
      .ambiance-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
      .amb-item:nth-child(1),.amb-item:nth-child(4){grid-column:auto;grid-row:auto}
      .amb-item{height:200px}
      .avis-grid{grid-template-columns:1fr}
      .footer-main{grid-template-columns:1fr 1fr}
      nav{padding:1rem 2rem}
      nav.scrolled{padding:.8rem 2rem}
      #menu,#specialites,#ambiance,#avis,#reservation{padding:5rem 2rem}
      .menu-list{grid-template-columns:1fr}
      .menu-item{border-right:none}
    }
    @media(max-width:600px){
      .hamburger { display: flex; }
      .nav-links {
        position: absolute;
        top: 100%;
        left: 0;
        width: 100%;
        background: var(--ink);
        flex-direction: column;
        padding: 20px;
        display: none;
        gap: 20px;
      }
      .spec-grid{grid-template-columns:1fr}
      .resa-form{grid-template-columns:1fr}
      .form-field.full{grid-column:1}
      .footer-main{grid-template-columns:1fr;gap:2rem;padding:3rem 2rem}
      .footer-bottom{padding:1.2rem 2rem}
    }