/* Bếp 12 Mùa — main styles (extracted from bep12mua_v6_journal.html) */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:'Lora',Georgia,serif;color:#2C1810;background:#FAF6EF;overflow-x:hidden;line-height:1.7}

:root{
  --green:#1A4A2E;
  --green-dark:#0F2E1C;
  --green-mid:#2A6040;
  --amber:#C8721E;
  --amber-light:#E8943A;
  --cream:#FAF6EF;
  --cream-mid:#F0E8D8;
  --cream-dark:#DDD0BB;
  --text:#2C1810;
  --text-mid:#4A3828;
  --text-muted:#7A6050;
  --white:#FFFCF7;
  --font-display:'Playfair Display',Georgia,serif;
  --font-body:'Lora',Georgia,serif;
  --font-ui:'DM Mono',monospace;
  --ease:0.32s cubic-bezier(0.25,0.46,0.45,0.94);
}

h1,h2,h3,h4{font-family:var(--font-display);color:var(--text);line-height:1.2}
h1{font-size:clamp(2rem,5vw,3.8rem);font-weight:700}
h2{font-size:clamp(1.75rem,3.8vw,2.7rem);font-weight:600}
h3{font-size:clamp(1rem,2.2vw,1.3rem);font-weight:400}
p{font-size:1rem;line-height:1.85;color:var(--text-mid)}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}

.lbl{font-family:var(--font-ui);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--amber)}
.wrap{max-width:1240px;margin:0 auto;padding:0 2rem}
@media(max-width:640px){.wrap{padding:0 1.1rem}}
section{padding:5rem 0}
@media(max-width:768px){section{padding:3.5rem 0}}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:50px;padding:0 1.75rem;font-family:var(--font-ui);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:var(--ease);border:1.5px solid transparent;border-radius:2px;white-space:nowrap;text-decoration:none;-webkit-tap-highlight-color:transparent}
.btn-green{background:var(--green);color:var(--amber-light);border-color:var(--green)}
.btn-green:hover{background:var(--green-dark);border-color:var(--green-dark);transform:translateY(-2px)}
.btn-amber{background:var(--amber);color:#fff;border-color:var(--amber)}
.btn-amber:hover{background:#A85C14;border-color:#A85C14;transform:translateY(-2px)}
.btn-outline-amber{background:transparent;color:var(--amber);border-color:var(--amber)}
.btn-outline-amber:hover{background:var(--amber);color:#fff}
.btn-ghost-cream{background:transparent;color:var(--cream);border-color:rgba(250,246,239,.45)}
.btn-ghost-cream:hover{background:rgba(250,246,239,.12)}
.btn-w{width:100%}

/* REVEAL */
.rv{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.rv.in{opacity:1;transform:translateY(0)}
.rv1{transition-delay:.1s}.rv2{transition-delay:.18s}.rv3{transition-delay:.26s}
@media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}}

/* ======= SKIP ======= */
.skip{position:absolute;top:-100px;left:1rem;background:var(--amber);color:#fff;padding:.65rem 1.25rem;border-radius:2px;z-index:9999;transition:top .2s;font-family:var(--font-ui);font-size:.75rem;letter-spacing:.08em}
.skip:focus{top:1rem}

/* ======= LANG SWITCHER ======= */
#lang-bar{position:fixed;top:0;left:0;right:0;z-index:1000;height:36px;background:var(--green-dark);display:flex;align-items:center;justify-content:flex-end;padding:0 2rem;gap:0;transition:opacity .3s}
.lang-btn{font-family:var(--font-ui);font-size:.6rem;letter-spacing:.12em;color:rgba(250,246,239,.5);background:none;border:none;cursor:pointer;padding:.4rem .55rem;transition:color .2s;text-transform:uppercase}
.lang-btn:hover,.lang-btn.active{color:var(--amber-light)}
.lang-sep{color:rgba(250,246,239,.2);font-size:.6rem;padding:0 .1rem}
@media(max-width:480px){#lang-bar{padding:0 1rem}}

/* ======= NAV ======= */
#nav{position:fixed;top:36px;left:0;right:0;z-index:999;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;transition:background .4s,box-shadow .4s,padding .3s}
#nav.solid{background:var(--cream);box-shadow:0 1px 0 var(--cream-dark)}
.nav-logo img{height:62px;width:auto;transition:opacity .3s}
.nav-logo .logo-white{display:block}
.nav-logo .logo-color{display:none}
#nav.solid .nav-logo .logo-white{display:none}
#nav.solid .nav-logo .logo-color{display:block}
.nav-links{display:none;gap:2.2rem;align-items:center}
.nav-links a{font-family:var(--font-ui);font-size:.68rem;letter-spacing:.13em;color:rgba(255,255,255,.82);transition:color .25s;text-transform:uppercase}
#nav.solid .nav-links a{color:var(--text-muted)}
.nav-links a:hover{color:var(--amber-light) !important}
.nav-book{min-height:38px;padding:0 1.1rem;font-size:.68rem}
@media(min-width:768px){.nav-links{display:flex}}

.burger{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;z-index:1001}
.burger span{display:block;width:24px;height:1.5px;background:#fff;transition:var(--ease)}
#nav.solid .burger span{background:var(--green)}
.burger.open span:nth-child(1){transform:rotate(45deg) translate(4.5px,4.5px)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:rotate(-45deg) translate(4.5px,-4.5px)}
@media(min-width:768px){.burger{display:none}}

/* MOBILE MENU */
#mob{position:fixed;inset:0;background:var(--green-dark);z-index:998;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.75rem;opacity:0;pointer-events:none;transition:opacity .3s}
#mob.open{opacity:1;pointer-events:all}
#mob a.mob-link{font-family:var(--font-display);font-size:1.9rem;color:var(--cream);font-style:italic;transition:color .2s}
#mob a.mob-link:hover{color:var(--amber-light)}
#mob .mob-cta{display:flex;flex-direction:column;gap:.65rem;width:220px;margin-top:.5rem}
#mob .mob-langs{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;margin-top:.5rem}
#mob .mob-langs button{font-family:var(--font-ui);font-size:.65rem;color:rgba(250,246,239,.4);background:none;border:none;cursor:pointer;letter-spacing:.12em;text-transform:uppercase}
#mob .mob-langs button.active{color:var(--amber-light)}

/* ======= HERO ======= */
#hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;padding-top:72px}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.hero-ov{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(15,46,28,.93) 0%,rgba(15,46,28,.6) 38%,rgba(15,46,28,.2) 65%,transparent 100%)}
.hero-content{position:relative;z-index:2;width:100%;padding:0 0 4.5rem}
.hero-content .wrap{display:flex;flex-direction:column;gap:1.4rem;align-items:flex-start}
.hero-brand{display:flex;align-items:center;gap:1.25rem;opacity:0;animation:fUp .85s ease .15s forwards}
.hero-logo{width:88px;height:88px;object-fit:contain;filter:drop-shadow(0 2px 12px rgba(0,0,0,.35))}
@media(min-width:768px){.hero-logo{width:110px;height:110px}}
.hero-brand-text{display:flex;flex-direction:column;gap:3px}
.hero-brand-name{font-family:var(--font-display);font-size:clamp(1.6rem,3.5vw,2.2rem);color:#fff;font-weight:700;line-height:1;letter-spacing:.01em}
.hero-brand-type{font-family:var(--font-ui);font-size:.7rem;letter-spacing:.22em;color:var(--amber-light);text-transform:uppercase}
.hero-pill{display:inline-flex;align-items:center;gap:.5rem;background:rgba(200,114,30,.18);border:1px solid rgba(200,114,30,.4);border-radius:50px;padding:.35rem .9rem}
.hero-pill .lbl{font-size:.6rem;letter-spacing:.2em;color:var(--amber-light)}
.hero-content h1{color:#fff;max-width:680px;opacity:0;animation:fUp .85s ease .35s forwards}
.hero-sub{font-family:var(--font-display);font-style:italic;font-size:clamp(1rem,2.5vw,1.45rem);color:rgba(250,246,239,.78);max-width:520px;opacity:0;animation:fUp .85s ease .5s forwards;line-height:1.55}
.hero-btns{display:flex;flex-wrap:wrap;gap:.85rem;opacity:0;animation:fUp .85s ease .65s forwards}
.hero-meta{display:flex;gap:2.5rem;opacity:0;animation:fUp .85s ease .8s forwards;flex-wrap:wrap;margin-top:.5rem}
.hmeta{display:flex;flex-direction:column;gap:2px}
.hmeta .ml{font-family:var(--font-ui);font-size:.58rem;letter-spacing:.18em;color:rgba(250,246,239,.38)}
.hmeta .mv{font-family:var(--font-ui);font-size:.72rem;color:rgba(250,246,239,.78)}
.hero-pill{opacity:0;animation:fUp .85s ease .2s forwards}
.hero-scroll{position:absolute;bottom:2rem;right:2rem;z-index:2;display:flex;flex-direction:column;align-items:center;gap:6px;opacity:0;animation:fUp 1s ease 1s forwards}
.hero-scroll span{font-family:var(--font-ui);font-size:.55rem;letter-spacing:.22em;color:rgba(250,246,239,.35);writing-mode:vertical-rl}
.s-line{width:1px;height:44px;background:linear-gradient(to bottom,rgba(250,246,239,.4),transparent);animation:sAnim 2s ease infinite}
@keyframes fUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes sAnim{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
@media(max-width:640px){.hero-btns{flex-direction:column}.hero-btns .btn{width:100%}.hero-scroll{display:none}}

/* ======= SEAFOOD BADGE ======= */
.seafood-strip{background:var(--green);padding:1.1rem 0;text-align:center}
.seafood-strip-inner{display:flex;align-items:center;justify-content:center;gap:2rem;flex-wrap:wrap}
.ss-item{display:flex;align-items:center;gap:.6rem;font-family:var(--font-ui);font-size:.65rem;letter-spacing:.14em;color:rgba(250,246,239,.7);text-transform:uppercase}
.ss-dot{width:4px;height:4px;border-radius:50%;background:var(--amber);flex-shrink:0}
.ss-item.highlight{color:var(--amber-light);font-weight:500}

/* ======= STORY ======= */
#story{background:var(--white)}
.story-grid{display:grid;gap:4rem;align-items:start}
@media(min-width:900px){.story-grid{grid-template-columns:1fr 1fr;gap:5rem}}
.story-text .lbl{display:block;margin-bottom:1.25rem}
.story-text h2{margin-bottom:1.5rem}
.story-text p{margin-bottom:1.1rem}
.vals{display:flex;flex-direction:column;gap:.8rem;margin-top:2rem}
.vc{display:flex;gap:.9rem;align-items:flex-start;padding:1rem 1.15rem;border-left:2px solid var(--amber);background:var(--cream);transition:var(--ease)}
.vc:hover{background:var(--cream-mid);transform:translateX(4px)}
.vi{width:34px;height:34px;flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:1px}
.vi svg{width:20px;height:20px}
.vc h3{font-family:var(--font-ui);font-size:.66rem;letter-spacing:.14em;color:var(--amber);margin-bottom:.25rem;text-transform:uppercase}
.vc p{font-size:.87rem;margin:0;line-height:1.6}
.story-aside{display:flex;flex-direction:column;gap:1.5rem}
.sp{position:relative;border-radius:8px;overflow:hidden;aspect-ratio:16/11}
.sp img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.sp:hover img{transform:scale(1.04)}
.sp-cap{position:absolute;bottom:0;left:0;right:0;padding:.65rem .9rem;background:linear-gradient(transparent,rgba(15,46,28,.85));font-family:var(--font-ui);font-size:.58rem;letter-spacing:.14em;color:rgba(250,246,239,.65)}
.pq{background:var(--green);color:var(--cream);padding:1.75rem 2rem;border-radius:8px}
.pq blockquote{font-family:var(--font-display);font-style:italic;font-size:1.1rem;line-height:1.65;margin-bottom:.9rem;color:rgba(250,246,239,.9)}
.pq cite{font-family:var(--font-ui);font-size:.6rem;letter-spacing:.14em;color:var(--amber-light);font-style:normal}

/* ======= SIGNATURE ======= */
#signature{background:var(--cream)}
.sig-grid{display:grid;gap:3.5rem;align-items:center}
@media(min-width:900px){.sig-grid{grid-template-columns:1fr 1fr;gap:5rem}}
.sig-photos{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.sig-main{grid-column:1/-1;border-radius:8px;overflow:hidden;aspect-ratio:16/10}
.sig-main img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.sig-main:hover img{transform:scale(1.03)}
.sig-sm{border-radius:6px;overflow:hidden;aspect-ratio:4/3}
.sig-sm img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.sig-sm:hover img{transform:scale(1.05)}
.sig-text .lbl{display:block;margin-bottom:1.25rem}
.sig-text h2{margin-bottom:1.5rem}
.sig-text p{margin-bottom:1.1rem}
.sig-quote{font-family:var(--font-display);font-style:italic;font-size:1.15rem;color:var(--green);border-left:3px solid var(--amber);padding:1rem 1.4rem;margin:1.5rem 0;line-height:1.55}
.sig-btns{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:1.75rem}
@media(max-width:640px){.sig-btns .btn{flex:1;min-width:130px}}

/* ======= SPACE ======= */
#space{background:var(--green-dark);padding:5rem 0}
#space h2{color:var(--cream)}
.sh{margin-bottom:3rem}
.sh p{color:rgba(250,246,239,.6);max-width:500px;margin-top:.75rem}
.gallery{columns:2;gap:.65rem}
@media(min-width:768px){.gallery{columns:3}}
@media(min-width:1100px){.gallery{columns:4}}
.gi{break-inside:avoid;margin-bottom:.65rem;position:relative;overflow:hidden;border-radius:5px;cursor:pointer}
.gi img{width:100%;display:block;transition:transform .5s}
.gi:hover img{transform:scale(1.06)}
.gi-ov{position:absolute;inset:0;background:rgba(15,46,28,0);transition:.3s;display:flex;align-items:flex-end;padding:.6rem}
.gi:hover .gi-ov{background:rgba(15,46,28,.38)}
.gi-tag{font-family:var(--font-ui);font-size:.56rem;letter-spacing:.14em;color:rgba(250,246,239,0);transition:.3s;text-transform:uppercase}
.gi:hover .gi-tag{color:rgba(250,246,239,.8)}

/* ======= MANIFESTO ======= */
#manifesto{background:var(--green);padding:6rem 0;text-align:center}
.mani-inner{max-width:800px;margin:0 auto}
.mani-mark{font-family:var(--font-ui);font-size:.62rem;letter-spacing:.28em;color:rgba(250,246,239,.38);margin-bottom:1.5rem}
.mani-div{width:44px;height:1px;background:var(--amber);margin:0 auto 1.5rem}
.mani-inner h2{font-family:var(--font-display);font-style:italic;font-size:clamp(1.45rem,3.2vw,2.3rem);color:var(--cream);line-height:1.48;font-weight:400;margin-bottom:1.25rem}
.mani-credit{font-family:var(--font-ui);font-size:.62rem;letter-spacing:.2em;color:rgba(250,246,239,.35);margin-bottom:2.5rem}

/* ======= REVIEWS ======= */
#reviews{background:var(--white)}
.rev-hd{margin-bottom:3rem}
.rev-grid{display:grid;gap:1.25rem}
@media(min-width:600px){.rev-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.rev-grid{grid-template-columns:repeat(3,1fr)}}
.rc{padding:1.6rem;border:1px solid var(--cream-dark);border-radius:8px;background:var(--cream);display:flex;flex-direction:column;gap:.85rem}
.rc-stars{color:var(--amber);font-size:.85rem;letter-spacing:3px}
.rc-text{font-style:italic;font-size:.93rem;line-height:1.75;color:var(--text-mid);flex:1}
.rc-author{display:flex;align-items:center;gap:.55rem}
.rc-flag{font-size:1rem}
.rc-name{font-family:var(--font-ui);font-size:.62rem;letter-spacing:.1em;color:var(--text-muted)}
.rev-links{display:flex;gap:1.5rem;margin-top:2rem;flex-wrap:wrap}
.rev-links a{font-family:var(--font-ui);font-size:.67rem;letter-spacing:.1em;color:var(--green);border-bottom:1px solid var(--amber);padding-bottom:2px;transition:color .2s}
.rev-links a:hover{color:var(--amber)}

/* ======= BOOKING ======= */
#booking{background:var(--cream)}
.bk-grid{display:grid;gap:3.5rem}
@media(min-width:900px){.bk-grid{grid-template-columns:1fr 1.15fr;gap:5rem;align-items:start}}
.ic .lbl{display:block;margin-bottom:1.1rem}
.ic h2{margin-bottom:2rem}
.ir{display:flex;gap:.9rem;align-items:flex-start;margin-bottom:1.35rem}
.ii{width:36px;height:36px;flex-shrink:0;background:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px rgba(26,74,46,.1)}
.ii svg{width:17px;height:17px}
.il{font-family:var(--font-ui);font-size:.6rem;letter-spacing:.14em;color:var(--green);margin-bottom:.18rem;text-transform:uppercase}
.iv{font-size:.9rem;color:var(--text);margin:0;line-height:1.55}
.iv a{color:var(--green);border-bottom:1px solid var(--cream-dark)}
.iv a:hover{border-color:var(--amber);color:var(--amber)}
.soc-lbl{font-family:var(--font-ui);font-size:.6rem;letter-spacing:.18em;color:var(--text-muted);margin:1.75rem 0 .85rem;text-transform:uppercase}
.socs{display:grid;grid-template-columns:1fr 1fr;gap:.55rem}
.sb{display:flex;align-items:center;gap:.6rem;padding:.75rem .9rem;border-radius:5px;border:1px solid var(--cream-dark);font-family:var(--font-ui);font-size:.65rem;letter-spacing:.07em;color:var(--text);transition:var(--ease);min-height:48px;background:var(--white)}
.sb svg{width:17px;height:17px;flex-shrink:0}
.sb:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(26,74,46,.1)}
.sb.fb:hover{border-color:#1877F2;color:#1877F2}
.sb.ig:hover{border-color:#E1306C;color:#E1306C}
.sb.wa:hover{border-color:#25D366;color:#25D366}
.sb.zl:hover{border-color:#0068FF;color:#0068FF}
.soc-note{font-size:.8rem;font-style:italic;color:var(--text-muted);margin-top:.7rem}

/* FORM */
.fc{background:var(--white);padding:2rem 2.25rem;border-radius:10px;box-shadow:0 2px 24px rgba(26,74,46,.07)}
.fc h3{font-family:var(--font-display);font-size:1.3rem;color:var(--green);margin-bottom:.35rem}
.fc .fsub{font-size:.82rem;color:var(--text-muted);margin-bottom:1.5rem}
.fr{display:grid;gap:.85rem;margin-bottom:.85rem}
@media(min-width:480px){.fr.two{grid-template-columns:1fr 1fr}}
.fg{display:flex;flex-direction:column;gap:.32rem}
.fg label{font-family:var(--font-ui);font-size:.59rem;letter-spacing:.14em;color:var(--green);text-transform:uppercase}
.fg input,.fg select,.fg textarea{width:100%;min-height:50px;padding:0 .875rem;border:1px solid var(--cream-dark);border-radius:5px;font-family:var(--font-body);font-size:1rem;color:var(--text);background:var(--cream);transition:border-color .2s;appearance:none;-webkit-appearance:none}
.fg select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%231A4A2E'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .875rem center;padding-right:2rem}
.fg textarea{min-height:78px;padding:.7rem .875rem;resize:vertical;line-height:1.6}
.fg input:focus,.fg select:focus,.fg textarea:focus{outline:none;border-color:var(--green)}
.fg input::placeholder,.fg textarea::placeholder{color:#C4B09A}
.pos-note{font-family:var(--font-ui);font-size:.6rem;letter-spacing:.08em;color:var(--text-muted);margin-bottom:1.1rem;padding:.65rem .9rem;background:rgba(26,74,46,.06);border-radius:4px;border-left:2px solid var(--green)}
.sub-btn{width:100%;min-height:54px;font-size:.82rem;letter-spacing:.14em;margin-top:.35rem}
.fok{display:none;background:#f0fdf4;border:1px solid #86efac;border-radius:5px;padding:1rem 1.15rem;margin-top:.85rem;font-size:.9rem;color:#166534;line-height:1.6}
.fok.show{display:block}

/* FLOATING CHAT */
#cfab{position:fixed;bottom:20px;right:16px;z-index:700;background:var(--green);color:var(--amber-light);border:none;border-radius:50px;padding:.72rem 1.1rem;display:flex;align-items:center;gap:.45rem;font-family:var(--font-ui);font-size:.68rem;letter-spacing:.08em;cursor:pointer;box-shadow:0 4px 18px rgba(15,46,28,.4);transition:var(--ease)}
#cfab:hover{background:var(--green-dark);transform:translateY(-2px)}
#cfab svg{width:17px;height:17px}
@media(min-width:768px){#cfab{bottom:28px;right:28px}}
#cpop{position:fixed;bottom:76px;right:16px;z-index:701;width:min(296px,calc(100vw - 32px));background:var(--white);border-radius:10px;box-shadow:0 8px 36px rgba(15,46,28,.18);opacity:0;pointer-events:none;transform:translateY(10px);transition:opacity .3s,transform .3s}
#cpop.open{opacity:1;pointer-events:all;transform:translateY(0)}
@media(min-width:768px){#cpop{right:28px;bottom:88px}}
.ph{background:var(--green-dark);color:var(--cream);padding:.85rem 1.1rem;border-radius:10px 10px 0 0;display:flex;justify-content:space-between;align-items:flex-start}
.ph h4{font-family:var(--font-display);font-size:.92rem;margin-bottom:.08rem}
.ph p{font-family:var(--font-ui);font-size:.58rem;letter-spacing:.07em;color:rgba(250,246,239,.5);margin:0}
.pcl{background:none;border:none;color:var(--cream);cursor:pointer;opacity:.6;font-size:.95rem;padding:2px}
.pcl:hover{opacity:1}
.pch-list{padding:.85rem}
.pch{display:flex;align-items:center;gap:.75rem;padding:.75rem .9rem;border-radius:5px;border:1px solid var(--cream-dark);margin-bottom:.5rem;color:var(--text);font-size:.87rem;transition:var(--ease);min-height:52px}
.pch svg{width:21px;height:21px;flex-shrink:0}
.pch span{flex:1}
.pch small{font-family:var(--font-ui);font-size:.57rem;color:var(--text-muted);display:block}
.pch:hover{transform:translateX(3px)}
.pch.zl:hover{border-color:#0068FF;background:#f0f5ff}
.pch.wa:hover{border-color:#25D366;background:#f0fff5}
.pch.fb:hover{border-color:#1877F2;background:#f0f4ff}
.pp-phone{text-align:center;padding:0 .85rem .85rem;font-size:.78rem;color:var(--text-muted);font-style:italic}
.pp-phone a{color:var(--green)}

/* FOOTER */
footer{background:#0A1E0F;color:var(--cream);padding:4rem 0 2rem}
.ft{display:grid;gap:3rem;margin-bottom:3rem}
@media(min-width:640px){.ft{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.ft{grid-template-columns:2fr 1fr 1.1fr}}
.fb-brand .flogo{height:56px;width:auto;margin-bottom:1rem}
.fb-brand .ftag{font-family:var(--font-ui);font-size:.6rem;letter-spacing:.2em;color:var(--amber);margin-bottom:.85rem;text-transform:uppercase}
.fb-brand p{font-size:.84rem;color:rgba(250,246,239,.45);line-height:1.7;margin:0}
.fn h4,.fsc h4{font-family:var(--font-ui);font-size:.6rem;letter-spacing:.2em;color:var(--amber);margin-bottom:1rem;text-transform:uppercase}
.fn ul{list-style:none}
.fn li{margin-bottom:.45rem}
.fn a{font-size:.86rem;color:rgba(250,246,239,.55);transition:color .2s}
.fn a:hover{color:var(--cream)}
.fsl{display:flex;flex-direction:column;gap:.45rem}
.fsl a{display:flex;align-items:center;gap:.6rem;color:rgba(250,246,239,.55);font-size:.84rem;transition:color .2s;min-height:30px}
.fsl a svg{width:15px;height:15px;flex-shrink:0}
.fsl a:hover{color:var(--cream)}
.foot-bottom{border-top:1px solid rgba(250,246,239,.08);padding-top:1.25rem;display:flex;flex-direction:column;gap:.3rem}
@media(min-width:600px){.foot-bottom{flex-direction:row;justify-content:space-between;align-items:center}}
.fcopy{font-family:var(--font-ui);font-size:.62rem;letter-spacing:.05em;color:rgba(250,246,239,.28)}
.fseo{font-family:var(--font-ui);font-size:.58rem;color:rgba(250,246,239,.18)}

/* ======= SEASONAL JOURNAL ======= */
#journal{background:var(--cream)}
.jnl-header{display:flex;align-items:flex-end;justify-content:space-between;gap:1.5rem;margin-bottom:2.5rem;flex-wrap:wrap}
.jnl-header-left .lbl{display:block;margin-bottom:.75rem}
.jnl-header-left h2{margin-bottom:.6rem}
.jnl-header-left p{font-size:.92rem;color:var(--text-muted);max-width:480px;margin:0}
.btn-outline-green{background:transparent;color:var(--green);border-color:var(--green);white-space:nowrap;align-self:flex-end}
.btn-outline-green:hover{background:var(--green);color:var(--cream)}
@media(max-width:600px){.jnl-header{flex-direction:column;align-items:flex-start}.btn-outline-green{width:100%}}

.jnl-grid{display:grid;gap:1.5rem}
@media(min-width:640px){.jnl-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:960px){.jnl-grid{grid-template-columns:repeat(3,1fr)}}

.jnl-card{background:var(--white);border-radius:10px;overflow:hidden;border:1px solid var(--cream-dark);transition:var(--ease);display:flex;flex-direction:column}
.jnl-card:hover{transform:translateY(-5px);box-shadow:0 12px 32px rgba(26,74,46,.1)}

.jnl-img{position:relative;aspect-ratio:16/10;overflow:hidden;flex-shrink:0}
.jnl-img-inner{width:100%;height:100%;transition:transform .6s ease}
.jnl-card:hover .jnl-img-inner{transform:scale(1.05)}

/* Journal card image backgrounds using real restaurant photos via CSS */
.jnl-img-1{background:linear-gradient(135deg,rgba(26,74,46,.3),rgba(15,46,28,.5)),center/cover no-repeat;background-color:#2A5A3A}
.jnl-img-2{background:linear-gradient(135deg,rgba(92,51,24,.3),rgba(44,24,16,.5)),center/cover no-repeat;background-color:#5C3318}
.jnl-img-3{background:linear-gradient(135deg,rgba(200,114,30,.25),rgba(92,51,24,.45)),center/cover no-repeat;background-color:#8B5E3C}

/* We'll inject real images via JS after load */
.jnl-img-inner{position:relative;display:flex;align-items:center;justify-content:center}
.jnl-img-inner::after{content:'';position:absolute;inset:0;background:inherit}

.jnl-month{position:absolute;top:.75rem;left:.75rem;font-family:var(--font-ui);font-size:.6rem;letter-spacing:.18em;color:#fff;background:rgba(26,74,46,.75);padding:.3rem .7rem;border-radius:50px;text-transform:uppercase;backdrop-filter:blur(4px)}

.jnl-body{padding:1.25rem 1.4rem 1.5rem;display:flex;flex-direction:column;gap:.65rem;flex:1}
.jnl-tag{font-family:var(--font-ui);font-size:.6rem;letter-spacing:.15em;color:var(--amber);text-transform:uppercase}
.jnl-title{font-family:var(--font-display);font-size:1.05rem;line-height:1.35;color:var(--text);font-weight:600;transition:color .2s}
.jnl-card:hover .jnl-title{color:var(--green)}
.jnl-excerpt{font-size:.88rem;line-height:1.72;color:var(--text-muted);flex:1}
.jnl-read{font-family:var(--font-ui);font-size:.68rem;letter-spacing:.1em;color:var(--green);border-bottom:1px solid var(--amber);padding-bottom:2px;display:inline-block;transition:color .2s;margin-top:auto}
.jnl-read:hover{color:var(--amber)}

@media(max-width:640px){
  .jnl-card{flex-direction:row;max-height:140px}
  .jnl-img{width:120px;flex-shrink:0;aspect-ratio:unset}
  .jnl-body{padding:1rem}
  .jnl-excerpt{display:none}
}
@media(max-width:400px){
  .jnl-card{flex-direction:column;max-height:none}
  .jnl-img{width:100%;aspect-ratio:16/10}
  .jnl-excerpt{display:block}
}


/* ===== MOBILE CRITICAL FIXES ===== */
/* Ensure no horizontal overflow anywhere */
html,body{max-width:100%;overflow-x:hidden}
img{max-width:100%;height:auto}

/* Nav: account for lang-bar height on mobile */
@media(max-width:767px){
  #hero{padding-top:calc(36px + 56px)}
  #nav{padding:.75rem 1rem}
  .nav-logo img{height:48px}
}

/* Touch targets — all interactive min 48x48 */
@media(max-width:768px){
  .btn{min-height:52px;padding:0 1.25rem}
  .soc-btn,.sb{min-height:52px}
  .lang-btn{min-height:36px;padding:.4rem .6rem;font-size:.65rem}
  .jnl-read{min-height:32px;display:inline-flex;align-items:center}
}

/* Hero mobile: stack cleanly */
@media(max-width:480px){
  .hero-brand{gap:.9rem}
  .hero-logo{width:72px;height:72px}
  .hero-brand-name{font-size:1.35rem}
  .hero-brand-type{font-size:.62rem}
  .hero-meta{gap:1.25rem}
  .hmeta .mv{font-size:.68rem}
}

/* Story grid: single col on small screens */
@media(max-width:640px){
  .story-grid,.sig-grid,.bk-grid{grid-template-columns:1fr;gap:2.5rem}
}

/* Gallery: 2 cols minimum on mobile */
@media(max-width:400px){
  .gallery{columns:1}
}

/* Form: full width inputs, bigger touch targets */
@media(max-width:640px){
  .fr.two{grid-template-columns:1fr}
  .fg input,.fg select,.fg textarea{min-height:52px;font-size:16px}
  .fc{padding:1.5rem 1.25rem}
}

/* Social channels: maintain 2-col grid */
@media(max-width:360px){
  .socs{grid-template-columns:1fr}
}

/* Booking section: info before form */
@media(max-width:900px){
  .bk-grid{display:flex;flex-direction:column}
  .ic{order:1}.fc{order:2}
}

/* Reviews: single col on very small */
@media(max-width:480px){
  .rev-grid{grid-template-columns:1fr}
}

/* Journal: card layout improvements mobile */
@media(max-width:640px){
  .jnl-header{margin-bottom:1.75rem}
  .jnl-grid{gap:1rem}
}

/* Footer: clean stack */
@media(max-width:480px){
  .ft{grid-template-columns:1fr;gap:2rem}
  .foot-bottom{flex-direction:column;gap:.35rem}
}

/* Floating chat: avoid content overlap */
@media(max-width:767px){
  #cfab{bottom:16px;right:12px;padding:.65rem .95rem;font-size:.65rem}
  #cpop{right:12px;bottom:68px;width:calc(100vw - 24px)}
}

/* Manifesto: better mobile padding */
@media(max-width:640px){
  #manifesto{padding:3.5rem 0}
  .mani-inner h2{font-size:1.35rem}
}

/* Seafood strip: wrap gracefully */
@media(max-width:600px){
  .seafood-strip-inner{gap:1rem .75rem;padding:0 1rem}
  .ss-item{font-size:.6rem}
  .ss-dot{display:none}
}

/* Lang bar: fit all 5 languages */
@media(max-width:380px){
  #lang-bar{gap:0;padding:0 .5rem}
  .lang-btn{padding:.35rem .4rem;font-size:.55rem}
  .lang-sep{padding:0}
}

