
:root{
    --bg:#041915;
    --bg-deep:#02100d;
    --panel:#07231f;
    --panel-2:#0c2e28;
    --cream:#ece8df;
    --cream-2:#f5efe5;
    --gold:#d6b168;
    --gold-soft:#b79147;
    --text:#fbf9f2;
    --muted:#cdbf9e;
    --line:rgba(214,177,104,.28);
    --shadow:0 12px 36px rgba(0,0,0,.28);
    --radius:20px;
    --radius-sm:14px;
    --container:1280px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    font-family:'Be Vietnam Pro',sans-serif;
    background:linear-gradient(180deg,var(--bg-deep),var(--bg));
    color:var(--text);
}
a{text-decoration:none;color:inherit}
button,input,textarea{font:inherit}
button{cursor:pointer}
img{max-width:100%;display:block}
.container{width:min(var(--container),calc(100% - 48px));margin:0 auto}
.page-shell{overflow:hidden}

/* Header */
.site-header{
    position:sticky;top:0;z-index:1000;
    backdrop-filter:blur(18px);
    background:linear-gradient(180deg,rgba(1,16,13,.96),rgba(2,19,16,.88));
    border-bottom:1px solid rgba(214,177,104,.14);
}
.nav-wrap{
    min-height:92px;
    display:grid;
    grid-template-columns:auto 1fr auto auto;
    gap:22px;
    align-items:center;
}
.brand{display:flex;align-items:center;gap:14px}
.brand-icon{
    width:44px;height:44px;border:1px solid var(--line);border-radius:50%;
    display:grid;place-items:center;color:var(--gold);font-size:18px;
    background:radial-gradient(circle at 30% 30%,rgba(214,177,104,.18),rgba(214,177,104,.04));
}
.brand-copy{display:flex;flex-direction:column;line-height:1}
.brand-title{
    font-family:'Playfair Display',serif;
    font-size:42px;font-weight:700;letter-spacing:.6px;color:#f0d28a;
}
.brand-subtitle{
    font-size:11px;letter-spacing:2.5px;color:var(--muted);margin-top:7px
}
.main-nav{
    display:flex;align-items:center;justify-content:center;gap:28px;flex-wrap:wrap
}
.main-nav a{
    font-size:14px;font-weight:500;text-transform:uppercase;color:#f3eee4;
    opacity:.88;position:relative
}
.main-nav a::after{
    content:"";position:absolute;left:0;bottom:-11px;width:100%;height:2px;border-radius:2px;
    background:linear-gradient(90deg,transparent,var(--gold),transparent);
    transform:scaleX(0);transition:.35s ease;
}
.main-nav a:hover,.main-nav a.active{color:#fff;opacity:1}
.main-nav a:hover::after,.main-nav a.active::after{transform:scaleX(1)}
.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:10px;
    min-height:54px;padding:0 28px;border-radius:14px;font-weight:600;border:1px solid transparent;
    transition:.28s ease;white-space:nowrap
}
.btn-gold{
    background:linear-gradient(180deg,#edca80,#c49a4a);
    color:#12211b;box-shadow:0 12px 25px rgba(196,154,74,.18)
}
.btn-gold:hover{transform:translateY(-2px);filter:brightness(1.04)}
.btn-outline{
    border-color:rgba(214,177,104,.55);color:#f5ecd7;
    background:rgba(4,30,25,.38)
}
.btn-outline:hover{background:rgba(214,177,104,.08)}
.btn-light{
    background:rgba(255,255,255,.04);border-color:rgba(12,46,40,.18);color:#173029;
    background:linear-gradient(180deg,#fbf7ef,#e8e1d7)
}
.btn-book-header{padding:0 22px;min-height:50px}
.mobile-toggle,.mobile-menu{display:none}

/* Hero */
.hero-section{
    position:relative;
    padding:38px 0 0;
    background:
        radial-gradient(circle at 10% 10%,rgba(26,123,103,.18),transparent 26%),
        radial-gradient(circle at 84% 18%,rgba(214,177,104,.12),transparent 20%),
        linear-gradient(120deg,#031814 0%,#03211c 40%,#0a1514 100%);
}
.hero-section::before{
    content:"";position:absolute;inset:0;
    background:
      radial-gradient(circle at 15% 20%,rgba(255,255,255,.06),transparent 24%),
      radial-gradient(circle at 20% 32%,rgba(26,123,103,.11),transparent 10%);
    pointer-events:none
}
.hero-grid{
    min-height:680px;
    display:grid;
    grid-template-columns:1.02fr .98fr;
    align-items:center;
}
.hero-content{position:relative;padding:70px 0 98px}
.hero-dots{
    position:absolute;left:-4px;top:178px;display:flex;flex-direction:column;gap:12px
}
.hero-dots span{
    width:8px;height:8px;border-radius:50%;background:rgba(214,177,104,.45);display:block
}
.hero-dots span:first-child{height:36px;width:8px;border-radius:999px;background:var(--gold)}
.eyebrow{font-size:13px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin:0 0 18px}
.hero-content h1{
    margin:0;font-family:'Playfair Display',serif;font-size:72px;line-height:1.04;max-width:720px;
    font-weight:600;letter-spacing:-1px
}
.hero-content h1 span{display:block;color:#e4be74}
.hero-desc{font-size:22px;max-width:620px;color:#efe4cf;margin:22px 0 38px}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap}
.hero-visual{
    position:relative;height:680px;display:grid;place-items:center
}
.hero-plate{
    width:540px;height:360px;border-radius:32px;position:absolute;right:18px;top:98px;
    background:
       radial-gradient(circle at 60% 40%,rgba(255,202,122,.12),transparent 30%),
       linear-gradient(135deg,#39230f,#8b6230 42%,#34210e 100%);
    transform:rotate(-1deg);
    box-shadow:0 30px 60px rgba(0,0,0,.45);
}
.hero-plate::before{
    content:"";position:absolute;inset:18px;border-radius:26px;
    border:1px solid rgba(255,221,166,.18)
}
.plate-center{
    position:absolute;inset:50px 64px;border-radius:50% / 46%;
    background:
      radial-gradient(circle at 50% 45%,rgba(147,89,37,.25),transparent 44%),
      linear-gradient(180deg,#846233,#3e2410 60%,#644321);
    box-shadow:inset 0 0 0 4px rgba(219,178,102,.12), inset 0 16px 28px rgba(255,215,160,.08);
}
.food{
    position:absolute;border-radius:24px;background:linear-gradient(180deg,#b57e49,#78451d);
    box-shadow:0 12px 22px rgba(0,0,0,.26)
}
.food-a{width:138px;height:44px;left:86px;top:132px;transform:rotate(8deg)}
.food-b{width:128px;height:38px;left:132px;top:98px;transform:rotate(2deg)}
.food-c{width:126px;height:36px;left:156px;top:152px;transform:rotate(-7deg)}
.leaf{
    position:absolute;background:linear-gradient(180deg,#7ab167,#2b6c39);border-radius:60% 40% 55% 45%;
    transform-origin:center;opacity:.96
}
.leaf-a{width:84px;height:30px;left:250px;top:86px;transform:rotate(28deg)}
.leaf-b{width:70px;height:24px;left:276px;top:112px;transform:rotate(6deg)}
.leaf-c{width:52px;height:20px;left:286px;top:82px;transform:rotate(-18deg)}
.lotus-petal{
    position:absolute;width:74px;height:110px;
    background:linear-gradient(180deg,#f7b2cb,#df6b96);
    border-radius:55% 55% 8% 8% / 72% 72% 14% 14%;
    right:-28px;bottom:50px;transform-origin:bottom center;
    box-shadow:0 12px 18px rgba(0,0,0,.24)
}
.p1{transform:rotate(-32deg)}
.p2{transform:rotate(0deg);right:18px;bottom:24px;height:122px}
.p3{transform:rotate(32deg);right:68px}
.lotus-core{
    position:absolute;width:60px;height:60px;border-radius:50%;right:38px;bottom:52px;
    background:radial-gradient(circle at 40% 40%,#f8d46a,#f3a824 65%,#c97714);
    box-shadow:0 0 0 10px rgba(255,234,175,.08)
}
.side-bowl{
    position:absolute;border-radius:50%;
    background:radial-gradient(circle at 40% 35%,#6a4422,#24150b);
    box-shadow:0 18px 40px rgba(0,0,0,.32)
}
.bowl-1{width:104px;height:104px;right:24px;top:38px}
.bowl-2{width:82px;height:82px;right:150px;top:54px}
.bowl-3{width:92px;height:92px;right:66px;bottom:138px}

/* Sections shared */
.section-heading h2,.sub-heading h3,.about-copy h2,.reservation-panel h3,.event-copy h3,.contact-box h3,.social-box h3{
    font-family:'Playfair Display',serif
}
.section-heading.center{text-align:center}
.section-heading h2{
    font-size:42px;color:#d7b56f;margin:0 0 22px;text-transform:uppercase;letter-spacing:1px
}
.section-label{
    margin:0 0 12px;color:#b89356;text-transform:uppercase;letter-spacing:2px;font-size:13px;font-weight:600
}
.sub-heading{
    display:flex;align-items:center;justify-content:space-between;gap:20px;
    margin-bottom:16px
}
.sub-heading h3{font-size:42px;margin:0;color:#193229;text-transform:uppercase}
.sub-heading a{font-size:13px;text-transform:uppercase;letter-spacing:1px;color:#92703b}

/* About */
.about-strip{
    background:linear-gradient(180deg,var(--cream-2),var(--cream));
    color:#1c2f28;padding:38px 0 42px;border-top:1px solid rgba(255,255,255,.08)
}
.about-grid{
    display:grid;grid-template-columns:1.08fr 1.52fr;gap:28px;align-items:start
}
.about-copy{padding:12px 0}
.about-copy h2{
    font-size:50px;line-height:1.08;margin:0 0 18px;color:#23362d
}
.about-copy p{font-size:18px;line-height:1.8;color:#47574f;margin:0 0 28px;max-width:560px}
.value-list{
    display:grid;grid-template-columns:repeat(4,1fr);border-left:1px solid rgba(28,47,40,.08)
}
.value-item{
    padding:22px 24px;min-height:260px;border-right:1px solid rgba(28,47,40,.08);
    display:flex;flex-direction:column;align-items:center;text-align:center;justify-content:center
}
.value-icon{
    width:74px;height:74px;border-radius:50%;display:grid;place-items:center;font-size:32px;
    color:#b88f4e;background:radial-gradient(circle at 30% 30%,rgba(214,177,104,.14),rgba(214,177,104,.02))
}
.value-item h3{
    font-size:22px;line-height:1.35;color:#24362f;margin:20px 0 10px;text-transform:uppercase
}
.value-item p{margin:0;color:#53645c;line-height:1.65}

/* Menu */
.menu-section{
    background:linear-gradient(180deg,#031713,#04221d 16%,#041a17 100%);
    padding:32px 0 44px
}
.tab-pills{
    display:flex;flex-wrap:wrap;justify-content:center;gap:0;border:1px solid var(--line);
    border-radius:999px;overflow:hidden;background:rgba(6,34,30,.55);max-width:1120px;margin:0 auto 26px
}
.tab-pill{
    background:none;border:0;color:#efead8;padding:18px 26px;font-size:16px;font-weight:500;
    border-right:1px solid rgba(214,177,104,.18);min-width:120px
}
.tab-pill:last-child{border-right:0}
.tab-pill.active{background:linear-gradient(180deg,#e9c77d,#c59d4f);color:#10211c}
.menu-card-row{
    position:relative;display:grid;grid-template-columns:repeat(5,1fr) 56px;gap:18px;align-items:stretch
}
.menu-card{
    background:linear-gradient(180deg,#062924,#051e1b);border:1px solid var(--line);border-radius:18px;
    overflow:hidden;box-shadow:var(--shadow)
}
.menu-thumb,.featured-thumb,.event-image,.gallery-item{
    background-size:cover;background-position:center
}
.menu-thumb{
    height:180px;position:relative;
    background:
      radial-gradient(circle at 30% 28%,rgba(255,244,224,.15),transparent 20%),
      linear-gradient(135deg,#553216,#9e6a2f 40%,#264433 100%);
}
.menu-thumb::after,.featured-thumb::after{
    content:"";position:absolute;inset:0;
    background:
      radial-gradient(circle at 30% 30%,rgba(255,255,255,.16),transparent 28%),
      radial-gradient(circle at 66% 60%,rgba(255,212,145,.18),transparent 24%);
    mix-blend-mode:screen
}
.thumb-badge{
    position:absolute;left:14px;top:14px;padding:8px 12px;border-radius:999px;
    background:rgba(4,23,19,.72);border:1px solid rgba(255,255,255,.08);font-size:12px;color:#f0dcab
}
.menu-card-body{padding:18px 18px 20px}
.menu-card h3{margin:0 0 14px;font-size:24px;font-family:'Playfair Display',serif;color:#fff}
.price-row{display:flex;align-items:center;justify-content:space-between;gap:16px}
.price{font-weight:700;color:#dfb86b}
.ghost-link{
    border:1px solid rgba(214,177,104,.4);padding:10px 14px;border-radius:12px;font-size:12px;
    text-transform:uppercase;color:#f5ead0
}
.carousel-arrow{
    width:56px;height:56px;border-radius:50%;border:1px solid var(--line);background:rgba(6,34,30,.9);
    color:#f0d08c;align-self:center;justify-self:center
}
.carousel-arrow.small{width:44px;height:44px}
.feature-reservation-grid{
    margin-top:26px;display:grid;grid-template-columns:1.18fr .82fr;gap:28px
}
.featured-panel{color:#21362e;background:var(--cream-2);padding:22px;border-radius:20px}
.featured-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.featured-card{
    background:linear-gradient(180deg,#083029,#061b18);border-radius:16px;overflow:hidden;color:#fff;
    box-shadow:0 12px 26px rgba(0,0,0,.22)
}
.featured-thumb{height:164px}
.featured-body{padding:14px 14px 16px}
.featured-body h4{
    margin:0 0 10px;font-size:24px;line-height:1.18;font-family:'Playfair Display',serif
}
.stars{display:flex;gap:4px;color:#f0c96e;margin-top:8px}
.reservation-panel{
    position:relative;background:linear-gradient(180deg,#03221d,#031915);border:1px solid var(--line);
    border-radius:22px;padding:26px 24px 24px;box-shadow:var(--shadow)
}
.reservation-panel h3{
    font-size:42px;margin:0 0 20px;text-transform:uppercase;color:#d8b66e
}
.floral-line{
    position:absolute;right:18px;top:30px;width:170px;height:240px;opacity:.2;pointer-events:none
}
.floral-line::before,.floral-line::after{
    content:"";position:absolute;border:1px solid rgba(214,177,104,.75);border-radius:50%
}
.floral-line::before{width:112px;height:112px;right:0;bottom:0}
.floral-line::after{width:56px;height:56px;right:60px;bottom:60px}
.booking-form{position:relative;z-index:1}
.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:14px}
.booking-form input,.booking-form textarea{
    width:100%;border-radius:12px;border:1px solid rgba(214,177,104,.28);
    background:rgba(255,255,255,.03);color:#fdf5e5;padding:16px 16px;outline:none
}
.booking-form input:focus,.booking-form textarea:focus{border-color:#d5b06b}
.btn-submit{width:100%;margin-top:14px}
.form-status,.newsletter-status{min-height:20px;margin:14px 0 0;color:#e8d2a0;font-size:14px}

/* Events */
.events-section{
    background:linear-gradient(180deg,#f1eadf,#efe7db);
    color:#1f312a;padding:0 0 28px
}
.event-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:0}
.event-card{
    display:grid;grid-template-columns:1.05fr .95fr;
    min-height:280px;background:#f0e8dc;overflow:hidden
}
.event-card.private-dining{
    background:linear-gradient(180deg,#07231f,#031814);grid-template-columns:.9fr 1.1fr;color:#fff
}
.event-copy{padding:34px 34px 30px}
.event-copy.light h3,.event-copy.light ul{color:#25362f}
.event-copy h3{margin:0 0 16px;font-size:40px;line-height:1.14}
.event-copy ul{margin:0 0 22px;padding-left:20px;color:#536359;line-height:1.8}
.room-image{
    background:
      radial-gradient(circle at 35% 28%,rgba(255,236,178,.28),transparent 18%),
      linear-gradient(135deg,#4b2b17,#8d6139 52%,#1c1714 100%)
}
.private-image{
    background:
      radial-gradient(circle at 68% 36%,rgba(255,240,195,.24),transparent 18%),
      linear-gradient(135deg,#593518,#9f6b2a 50%,#253126 100%)
}

/* Reviews */
.review-section{
    background:linear-gradient(180deg,#04211d,#031511);
    padding:32px 0 40px
}
.review-row{display:grid;grid-template-columns:44px repeat(4,1fr) 44px;gap:18px;align-items:center}
.review-card{
    border:1px solid var(--line);border-radius:18px;padding:22px;background:rgba(6,37,32,.72);
    min-height:216px;box-shadow:var(--shadow)
}
.review-card p{line-height:1.75;color:#eee3cd;margin:14px 0 20px}
.review-author{display:flex;align-items:center;gap:12px}
.avatar{
    width:44px;height:44px;border-radius:50%;
    display:grid;place-items:center;background:linear-gradient(180deg,#efcd85,#bc9144);color:#10211c;font-weight:700
}
.review-author strong{display:block}
.review-author span:last-child{display:block;color:#c8b894;font-size:14px}

/* Gallery */
.gallery-section{
    background:linear-gradient(180deg,#04211d,#03211c);
    padding:8px 0 28px
}
.gallery-section .sub-heading h3{color:#d7b56f}
.gallery-section .sub-heading a{color:#e0c27f}
.gallery-row{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.gallery-item{height:142px;border-radius:16px;border:1px solid var(--line)}

/* Contact */
.contact-section{
    background:linear-gradient(180deg,#f0e8dc,#efe7db);
    color:#20322b;padding:18px 0 0
}
.contact-grid{display:grid;grid-template-columns:.84fr 1.18fr .78fr;gap:22px;align-items:stretch}
.contact-box,.map-box,.social-box{
    background:#f8f4ec;border:1px solid rgba(31,49,42,.08);border-radius:18px;padding:24px;position:relative
}
.contact-box h3,.social-box h3{font-size:34px;margin:0 0 18px}
.contact-list{list-style:none;padding:0;margin:0;display:grid;gap:16px;line-height:1.6;color:#526159}
.contact-list i{margin-right:10px;color:#b9914f}
.map-box{min-height:230px;overflow:hidden}
.map-grid{
    position:absolute;inset:0;
    background:
      linear-gradient(90deg,rgba(155,155,155,.12) 1px, transparent 1px) 0 0/38px 38px,
      linear-gradient(rgba(155,155,155,.12) 1px, transparent 1px) 0 0/38px 38px,
      linear-gradient(135deg,#ddd6ca,#f7f2e9);
}
.map-grid::before{
    content:"";position:absolute;left:22%;top:0;bottom:0;width:120px;background:rgba(177,198,212,.16);
    filter:blur(1px);transform:rotate(10deg)
}
.map-pin{
    position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
    display:flex;gap:12px;align-items:flex-start;padding:18px 18px;background:#fff;border-radius:16px;
    box-shadow:0 14px 30px rgba(0,0,0,.12)
}
.map-pin i{font-size:28px;color:#d14d43}
.map-pin strong{display:block;margin-bottom:6px}
.map-pin span{font-size:14px;color:#596960}
.social-row{display:flex;gap:12px;flex-wrap:wrap}
.social-row a{
    width:50px;height:50px;border-radius:50%;display:grid;place-items:center;border:1px solid rgba(31,49,42,.12);
    color:#20322b;background:#fff
}
.social-row a:last-child{width:auto;padding:0 16px;border-radius:999px;font-weight:600}
.lotus-art{
    position:absolute;right:-24px;bottom:-32px;width:180px;height:180px;opacity:.18
}
.lotus-art::before,.lotus-art::after{
    content:"";position:absolute;border:2px solid #bd9555;border-radius:50%
}
.lotus-art::before{inset:18px;border-radius:60% 60% 10% 10% / 75% 75% 12% 12%}
.lotus-art::after{inset:0;border-radius:60% 60% 10% 10% / 75% 75% 12% 12%;transform:rotate(35deg)}

/* Footer */
.site-footer{
    background:linear-gradient(180deg,#05211d,#031511);
    padding-top:28px
}
.footer-grid{
    display:grid;grid-template-columns:1.05fr 1.1fr .85fr .8fr;gap:28px;align-items:start
}
.footer-brand-line .brand-title{font-size:40px}
.footer-brand p,.newsletter p{color:#cfbf9b;line-height:1.8}
.newsletter h4,.footer-links h4{
    margin:0 0 16px;color:#dfbc76;font-size:24px;font-family:'Playfair Display',serif;text-transform:uppercase
}
.newsletter-form{
    display:grid;grid-template-columns:1fr 58px;gap:10px;margin-top:14px
}
.newsletter-form input{
    border-radius:14px;border:1px solid rgba(214,177,104,.24);
    background:rgba(255,255,255,.03);color:#fff;padding:16px
}
.newsletter-form button{
    border:0;border-radius:14px;background:linear-gradient(180deg,#ebc77d,#c39a4c);color:#10211c
}
.footer-links .link-columns{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.footer-links .link-columns.single{grid-template-columns:1fr}
.footer-links a{display:block;color:#e9ddc3;margin:10px 0}
.copyright{
    margin-top:24px;border-top:1px solid rgba(214,177,104,.12);padding:18px 24px;text-align:center;color:#d5c39f
}

/* Visual card backgrounds */
.dish-1{background:
 radial-gradient(circle at 35% 30%,rgba(255,249,231,.18),transparent 24%),
 linear-gradient(135deg,#6d3b20,#c88745 52%,#36513c)}
.dish-2{background:
 radial-gradient(circle at 50% 44%,rgba(255,238,204,.18),transparent 22%),
 linear-gradient(135deg,#5f3919,#b97d34 56%,#3d5b48)}
.dish-3{background:
 radial-gradient(circle at 68% 38%,rgba(255,236,194,.18),transparent 22%),
 linear-gradient(135deg,#4a2b14,#9f6f32 52%,#2f5647)}
.dish-4{background:
 radial-gradient(circle at 58% 26%,rgba(255,228,177,.18),transparent 22%),
 linear-gradient(135deg,#4d2a16,#c08a43 56%,#284d45)}
.dish-5{background:
 radial-gradient(circle at 42% 32%,rgba(255,235,195,.2),transparent 26%),
 linear-gradient(135deg,#553114,#ab7840 52%,#305643)}

.feature-1{background:
 radial-gradient(circle at 28% 34%,rgba(255,246,223,.16),transparent 22%),
 linear-gradient(135deg,#52311b,#9b6935 56%,#21312c)}
.feature-2{background:
 radial-gradient(circle at 62% 30%,rgba(255,241,214,.16),transparent 24%),
 linear-gradient(135deg,#482716,#9f6d39 55%,#294435)}
.feature-3{background:
 radial-gradient(circle at 65% 34%,rgba(255,236,207,.16),transparent 24%),
 linear-gradient(135deg,#4b2914,#8f6332 55%,#2c4738)}
.feature-4{background:
 radial-gradient(circle at 50% 26%,rgba(255,246,221,.16),transparent 24%),
 linear-gradient(135deg,#3f2918,#9b6b34 50%,#5b7c5c)}

.gallery-1,.gallery-2,.gallery-3,.gallery-4,.gallery-5,.gallery-6{
 background:
   radial-gradient(circle at 58% 30%,rgba(255,243,214,.18),transparent 22%),
   linear-gradient(135deg,#4c2d18,#9a6d38 48%,#1f201e)
}
.gallery-2{background:
   radial-gradient(circle at 44% 30%,rgba(255,243,214,.18),transparent 22%),
   linear-gradient(135deg,#55331e,#b37a3a 48%,#24392d)}
.gallery-3{background:
   radial-gradient(circle at 48% 30%,rgba(255,243,214,.16),transparent 22%),
   linear-gradient(135deg,#352113,#7a532e 48%,#1e2e28)}
.gallery-4{background:
   radial-gradient(circle at 60% 30%,rgba(255,243,214,.16),transparent 22%),
   linear-gradient(135deg,#4f301f,#8e673f 48%,#222822)}
.gallery-5{background:
   radial-gradient(circle at 50% 30%,rgba(255,243,214,.16),transparent 22%),
   linear-gradient(135deg,#52331a,#8d6534 48%,#1f2620)}
.gallery-6{background:
   radial-gradient(circle at 50% 30%,rgba(255,243,214,.16),transparent 22%),
   linear-gradient(135deg,#56321a,#9f7440 48%,#23362d)}

/* Responsive */
@media (max-width: 1220px){
    .main-nav{display:none}
    .mobile-toggle{display:grid;place-items:center;width:48px;height:48px;background:none;border:1px solid var(--line);color:#f3e2bd;border-radius:12px}
    .mobile-menu{
        display:none;padding:0 24px 24px;flex-direction:column;gap:14px
    }
    .mobile-menu.open{display:flex}
    .hero-grid,.about-grid,.feature-reservation-grid,.event-grid,.contact-grid,.footer-grid{grid-template-columns:1fr}
    .hero-visual{height:520px}
    .menu-card-row{grid-template-columns:repeat(2,1fr)}
    .featured-grid{grid-template-columns:repeat(2,1fr)}
    .review-row{grid-template-columns:repeat(2,1fr)}
    .review-row .carousel-arrow.small{display:none}
    .gallery-row{grid-template-columns:repeat(3,1fr)}
    .value-list{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 820px){
    .container{width:min(var(--container),calc(100% - 28px))}
    .brand-title{font-size:34px}
    .hero-content h1{font-size:50px}
    .hero-desc{font-size:18px}
    .hero-visual{height:420px}
    .hero-plate{width:100%;max-width:500px;height:310px;right:0}
    .value-list,.featured-grid,.menu-card-row,.gallery-row,.review-row{grid-template-columns:1fr}
    .contact-grid{gap:16px}
    .form-row{grid-template-columns:1fr}
    .btn-book-header{display:none}
    .site-header .container.nav-wrap{grid-template-columns:auto 1fr auto}
    .event-card,.event-card.private-dining{grid-template-columns:1fr}
    .sub-heading h3,.about-copy h2,.reservation-panel h3,.section-heading h2,.contact-box h3,.social-box h3{font-size:30px}
    .hero-actions{flex-direction:column;align-items:flex-start}
}
