/* ══════════════════════════════════════════════════════
   UNION CHEZ GUEDES — Vert Vaudois × Bistrot
   Charte : crème / vert sapin / blanc / or laiton
   ══════════════════════════════════════════════════════ */

:root{
  --cream:#f5efe2;
  --cream-2:#ebe2d0;
  --paper:#fbf7ef;
  --green:#2d4a2b;          /* vert vaudois principal */
  --green-dark:#1f3520;     /* hover */
  --green-light:#4a6b48;    /* variations */
  --red-vd:#c0392b;          /* rouge vaudois — accent rare */
  --gold:#b8924e;            /* or laiton chaleureux */
  --wood:#a87b5b;
  --char:#1c2820;            /* texte sur fond clair */
  --text:#2c3a2a;
  --muted:#7a8275;
  --line:rgba(28,40,32,.12);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--paper);
  color:var(--text);
  font-family:'EB Garamond',Georgia,serif;
  font-size:17px;
  line-height:1.7;
  font-weight:400;
}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
::selection{background:var(--green);color:var(--cream);}

/* ── HEADER ── */
header{
  position:sticky;top:0;z-index:200;
  background:var(--paper);
  border-bottom:1px solid var(--line);
}
.header-top{
  background:var(--green);color:var(--cream);
  padding:.5rem 2.5rem;
  font-size:.78rem;letter-spacing:.05em;
  display:flex;justify-content:space-between;align-items:center;
  font-family:'Inter',sans-serif;
}
.header-top a:hover{color:white;text-decoration:underline;}
.header-main{
  padding:1.2rem 2.5rem;
  display:flex;align-items:center;justify-content:space-between;
}
.logo{
  font-family:'Playfair Display',Georgia,serif;
  font-size:1.5rem;font-weight:600;
  color:var(--char);letter-spacing:.01em;
  display:flex;flex-direction:column;line-height:1;
}
.logo-sub{
  font-family:'Inter',sans-serif;
  font-size:.62rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--green);margin-top:5px;
}
nav.main-nav{display:flex;gap:1.8rem;align-items:center;}
nav.main-nav a{
  font-family:'Inter',sans-serif;
  font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text);font-weight:500;
  padding:.5rem 0;border-bottom:2px solid transparent;
  transition:all .2s;
}
nav.main-nav a:hover,nav.main-nav a.active{
  color:var(--green);border-bottom-color:var(--green);
}
.btn-reserve{
  background:var(--green);color:var(--paper) !important;
  padding:.7rem 1.4rem !important;
  font-family:'Inter',sans-serif;font-size:.7rem !important;
  letter-spacing:.15em !important;text-transform:uppercase;font-weight:600;
  border:none !important;
  transition:background .2s !important;
}
.btn-reserve:hover{background:var(--green-dark) !important;color:var(--paper) !important;}

.menu-toggle{display:none;background:none;border:0;color:var(--char);font-size:1.6rem;cursor:pointer;}

/* ── PAGE HEADER ── */
.page-head{
  background:var(--cream);
  padding:5rem 2.5rem 4rem;
  text-align:center;
  border-bottom:1px solid var(--line);
}
.page-head .crumb{
  font-family:'Inter',sans-serif;
  font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--green);margin-bottom:1rem;
}
.page-head h1{
  font-family:'Playfair Display',Georgia,serif;
  font-size:clamp(2.5rem,5vw,4rem);
  font-weight:500;line-height:1.1;
  color:var(--char);
}
.page-head h1 em{font-style:italic;color:var(--green);}
.page-head .lead{
  margin-top:1.2rem;font-size:1.05rem;color:var(--muted);
  max-width:600px;margin-left:auto;margin-right:auto;
  font-style:italic;
}

/* ── HERO HOMEPAGE — avec vraie image ── */
.hero{
  position:relative;
  display:grid;grid-template-columns:1.1fr 1fr;
  gap:0;
  min-height:88vh;
  background:var(--cream);
  overflow:hidden;
}
.hero-content{
  padding:5rem 4rem;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;z-index:2;
  background:var(--cream);
}
.hero-tag{
  display:inline-block;
  font-family:'Inter',sans-serif;
  font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--green);
  border-top:1px solid var(--gold);border-bottom:1px solid var(--gold);
  padding:.5rem 1.4rem;margin-bottom:2rem;
  align-self:flex-start;
}
.hero h1{
  font-family:'Playfair Display',Georgia,serif;
  font-size:clamp(2.8rem,5vw,5rem);
  font-weight:500;line-height:1.05;
  margin-bottom:1.5rem;color:var(--char);
}
.hero h1 em{font-style:italic;color:var(--green);}
.hero-sub{
  font-size:1.1rem;max-width:520px;
  color:var(--text);margin-bottom:2.5rem;
  line-height:1.75;
}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;}
.btn-primary{
  display:inline-block;
  background:var(--green);color:var(--paper);
  padding:1rem 2.2rem;
  font-family:'Inter',sans-serif;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;
  transition:background .2s,transform .2s;
}
.btn-primary:hover{background:var(--green-dark);transform:translateY(-2px);}
.btn-outline{
  display:inline-block;
  border:1.5px solid var(--char);color:var(--char);
  padding:1rem 2.2rem;
  font-family:'Inter',sans-serif;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;
  transition:all .2s;
}
.btn-outline:hover{background:var(--char);color:var(--paper);}

.hero-visual{
  position:relative;
  background:url("data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 900" preserveAspectRatio="xMidYMid slice"><defs><linearGradient id="bg" x1="0" y1="0" x2="0" y2="1"><stop offset="0" stop-color="%23f5efe2"/><stop offset="0.4" stop-color="%23e8e0cd"/><stop offset="1" stop-color="%23ddd2b8"/></linearGradient><linearGradient id="hill" x1="0" y1="0" x2="0" y2="1"><stop offset="0" stop-color="%234a6b48"/><stop offset="1" stop-color="%232d4a2b"/></linearGradient></defs><rect width="1200" height="900" fill="url(%23bg)"/><circle cx="900" cy="200" r="80" fill="%23b8924e" opacity="0.35"/><path d="M0 500 Q 300 440 600 480 T 1200 460 L 1200 900 L 0 900 Z" fill="%234a6b48" opacity="0.5"/><path d="M0 600 Q 350 540 700 580 T 1200 560 L 1200 900 L 0 900 Z" fill="url(%23hill)"/><g><rect x="500" y="660" width="180" height="180" fill="%23f5efe2"/><polygon points="490,660 590,560 690,660" fill="%238b1e2e"/><rect x="540" y="730" width="30" height="50" fill="%231f3520"/><rect x="600" y="720" width="40" height="35" fill="%231f3520"/><rect x="510" y="700" width="20" height="20" fill="%23b8924e" opacity="0.6"/></g><g opacity="0.7"><circle cx="200" cy="780" r="20" fill="%234a6b48"/><circle cx="240" cy="770" r="15" fill="%234a6b48"/><circle cx="950" cy="760" r="25" fill="%234a6b48"/><circle cx="1000" cy="775" r="18" fill="%234a6b48"/></g><text x="600" y="850" font-family="Georgia, serif" font-size="22" fill="%23f5efe2" text-anchor="middle" opacity="0.65" font-style="italic">Une auberge familiale au cœur du Gros-de-Vaud</text></svg>") center/cover no-repeat;
}
.hero-visual::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to right,rgba(245,239,226,.4) 0%,transparent 30%);
}
.hero-badge{
  position:absolute;bottom:2rem;left:-3rem;
  background:var(--paper);padding:1.2rem 1.6rem;
  box-shadow:0 12px 35px rgba(28,40,32,.18);
  border-left:3px solid var(--green);
  z-index:3;
  display:flex;align-items:center;gap:1rem;
  max-width:280px;
}
.hero-badge-num{
  font-family:'Playfair Display',Georgia,serif;
  font-size:2.2rem;color:var(--green);font-weight:500;line-height:1;
}
.hero-badge-text{font-size:.8rem;color:var(--muted);line-height:1.4;}
.hero-badge-text strong{display:block;color:var(--char);font-family:'Playfair Display',serif;font-size:.95rem;font-weight:500;margin-bottom:2px;}

/* ── SECTIONS ── */
section{padding:6rem 2.5rem;}
.container{max-width:1200px;margin:0 auto;}
.sec-head{text-align:center;margin-bottom:3.5rem;}
.sec-tag{
  font-family:'Inter',sans-serif;
  font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--green);margin-bottom:1rem;
}
.sec-title{
  font-family:'Playfair Display',Georgia,serif;
  font-size:clamp(2rem,4vw,3rem);font-weight:500;
  line-height:1.15;color:var(--char);
}
.sec-title em{font-style:italic;color:var(--green);}
.sec-line{
  width:50px;height:1px;background:var(--gold);
  margin:1.2rem auto 0;
}

/* ── INTRO ── */
.intro{background:var(--paper);}
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.intro-text p{margin-bottom:1.2rem;font-size:1.05rem;line-height:1.85;}
.intro-text p:last-child{margin-bottom:0;}
.intro-text strong{color:var(--green);}
.intro-img{
  aspect-ratio:4/5;
  background:url("data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 400 500" preserveAspectRatio="xMidYMid slice"><defs><linearGradient id="sky" x1="0" y1="0" x2="0" y2="1"><stop offset="0" stop-color="%23f5efe2"/><stop offset="0.6" stop-color="%23e8e0cd"/></linearGradient><linearGradient id="hill1" x1="0" y1="0" x2="0" y2="1"><stop offset="0" stop-color="%234a6b48"/><stop offset="1" stop-color="%232d4a2b"/></linearGradient><linearGradient id="hill2" x1="0" y1="0" x2="0" y2="1"><stop offset="0" stop-color="%232d4a2b"/><stop offset="1" stop-color="%231f3520"/></linearGradient></defs><rect width="400" height="500" fill="url(%23sky)"/><circle cx="320" cy="120" r="40" fill="%23b8924e" opacity="0.4"/><path d="M0 280 Q 100 240 200 280 T 400 270 L 400 500 L 0 500 Z" fill="url(%23hill1)" opacity="0.7"/><path d="M0 340 Q 120 300 240 350 T 400 330 L 400 500 L 0 500 Z" fill="url(%23hill2)"/><g opacity="0.85"><rect x="170" y="385" width="50" height="55" fill="%23f5efe2"/><polygon points="165,385 195,355 225,385" fill="%23a83a2c"/><rect x="180" y="405" width="10" height="15" fill="%231f3520"/><rect x="200" y="400" width="12" height="10" fill="%231f3520"/></g><g opacity="0.6"><circle cx="80" cy="430" r="8" fill="%234a6b48"/><circle cx="100" cy="425" r="6" fill="%234a6b48"/><circle cx="320" cy="420" r="10" fill="%234a6b48"/><circle cx="340" cy="425" r="7" fill="%234a6b48"/></g><text x="200" y="475" font-family="Georgia, serif" font-size="14" fill="%23f5efe2" text-anchor="middle" opacity="0.7" font-style="italic">Poliez-Pittet · Vaud</text></svg>") center/cover;
  border:8px solid var(--paper);
  box-shadow:0 15px 40px rgba(28,40,32,.18);
}

/* ── AMBIANCE GALLERY ── */
.ambiance{background:var(--cream);}
.amb-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  grid-auto-rows:200px;gap:1rem;margin-top:3rem;
  max-width:1200px;margin-left:auto;margin-right:auto;
}
.amb-item{
  position:relative;overflow:hidden;
  border:5px solid var(--paper);
  box-shadow:0 8px 25px rgba(28,40,32,.1);
}
.amb-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s;}
.amb-item:hover img{transform:scale(1.05);}
.amb-item.tall{grid-row:span 2;}
.amb-item.wide{grid-column:span 2;}

/* ── HIGHLIGHTS ── */
.highlights{background:var(--paper);}
.high-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:2rem;}
.high-card{
  text-align:center;padding:2.5rem 2rem;
  border:1px solid var(--line);background:var(--paper);
  transition:all .3s;
}
.high-card:hover{border-color:var(--green);transform:translateY(-4px);box-shadow:0 12px 30px rgba(28,40,32,.08);}
.high-icon{font-size:2.4rem;margin-bottom:1rem;}
.high-name{
  font-family:'Playfair Display',Georgia,serif;
  font-size:1.3rem;font-weight:500;color:var(--char);margin-bottom:.5rem;
}
.high-desc{font-size:.95rem;color:var(--muted);line-height:1.6;}
.high-link{
  display:inline-block;margin-top:1rem;
  font-family:'Inter',sans-serif;
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--green);font-weight:600;
  border-bottom:1px solid var(--green);padding-bottom:2px;
}

/* ── MENU CARDS HOMEPAGE ── */
.menus-list{background:var(--cream);}
.menus-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem;}
.menu-card{
  background:var(--paper);
  border:1px solid var(--line);
  padding:2rem;
  display:flex;flex-direction:column;
  transition:all .3s;
}
.menu-card:hover{border-color:var(--green);transform:translateY(-3px);box-shadow:0 12px 30px rgba(28,40,32,.08);}
.menu-card h3{
  font-family:'Playfair Display',Georgia,serif;
  font-size:1.4rem;font-weight:500;
  color:var(--char);margin-bottom:.5rem;
}
.menu-card h3 em{font-style:italic;color:var(--green);}
.menu-card p{font-size:.92rem;color:var(--muted);flex:1;margin-bottom:1.2rem;line-height:1.6;}
.menu-card .arrow{
  font-family:'Inter',sans-serif;
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--green);font-weight:600;
}

/* ── MENU LIST (sub-pages) ── */
.menu-section{background:var(--paper);}
.menu-loading{text-align:center;color:var(--muted);padding:4rem 0;font-style:italic;}
.menu-cat{margin-bottom:3.5rem;}
.menu-cat-title{
  font-family:'Playfair Display',Georgia,serif;
  font-size:1.7rem;font-weight:500;font-style:italic;
  color:var(--green);
  padding-bottom:.6rem;border-bottom:2px solid var(--green);
  margin-bottom:1rem;
}
.menu-cat-sub{
  font-family:'Inter',sans-serif;
  font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;
  color:var(--muted);margin-top:-.5rem;margin-bottom:1.5rem;font-style:italic;
}
.menu-items{max-width:780px;margin:0 auto;}
.menu-item{
  display:flex;align-items:flex-start;justify-content:space-between;
  padding:1rem 0;
  border-bottom:1px dotted rgba(28,40,32,.18);
  gap:1rem;
}
.menu-item:last-child{border-bottom:none;}
.menu-item-left{flex:1;}
.menu-item-name{
  font-family:'Playfair Display',Georgia,serif;
  font-size:1.1rem;font-weight:500;color:var(--char);
  margin-bottom:.2rem;line-height:1.3;
}
.menu-item-desc{font-size:.9rem;color:var(--muted);font-style:italic;line-height:1.5;}
.menu-item-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:.4rem;}
.menu-tag{
  font-family:'Inter',sans-serif;
  font-size:.55rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--green);border:1px solid var(--green);
  padding:2px 7px;
}
.menu-item-price{
  font-family:'Playfair Display',Georgia,serif;
  font-size:1.15rem;font-weight:500;
  color:var(--green);white-space:nowrap;
}
.menu-item-price small{font-size:.7rem;color:var(--muted);font-weight:400;}

.menu-note{
  text-align:center;margin-top:3rem;
  font-size:.85rem;color:var(--muted);font-style:italic;
}

/* ── BANQUETS ── */
.banquet-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;
  max-width:1100px;margin:0 auto;
}
.banquet-card{
  background:var(--cream);
  border:1px solid var(--line);
  padding:2rem;text-align:center;
  position:relative;
  transition:all .3s;
}
.banquet-card:hover{border-color:var(--green);transform:translateY(-3px);}
.banquet-card .num{
  font-family:'Playfair Display',Georgia,serif;
  font-style:italic;font-size:.85rem;
  color:var(--green);margin-bottom:.6rem;letter-spacing:.05em;
}
.banquet-card .price{
  position:absolute;top:1rem;right:1rem;
  font-family:'Playfair Display',Georgia,serif;
  font-size:1.4rem;font-weight:600;color:var(--green);
}
.banquet-card .courses{
  font-size:.92rem;color:var(--text);line-height:1.7;
}
.banquet-card .courses .sep{
  display:block;color:var(--gold);margin:.6rem 0;letter-spacing:.5em;font-size:.7rem;
}

/* ── RESERVE BLOCK ── */
.reserve-block{
  background:linear-gradient(135deg,var(--green) 0%,var(--green-dark) 100%);
  color:var(--paper);text-align:center;padding:5rem 2.5rem;
  position:relative;overflow:hidden;
}
.reserve-block::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 40 40'%3E%3Cpath d='M0 20h40M20 0v40' stroke='%23f5efe2' stroke-opacity='.06' stroke-width='1'/%3E%3C/svg%3E");
}
.reserve-inner{position:relative;z-index:2;max-width:600px;margin:0 auto;}
.reserve-block h2{
  font-family:'Playfair Display',Georgia,serif;
  font-size:clamp(2rem,4vw,3rem);font-weight:500;
  margin-bottom:1rem;color:var(--paper);
}
.reserve-block h2 em{font-style:italic;color:var(--gold);}
.reserve-block p{
  font-size:1.05rem;color:rgba(245,239,226,.85);
  margin-bottom:2rem;line-height:1.8;
}
.btn-fork{
  display:inline-flex;align-items:center;gap:.8rem;
  background:var(--paper);color:var(--char);
  padding:1.1rem 2.4rem;
  font-family:'Inter',sans-serif;
  font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
  transition:all .2s;
}
.btn-fork:hover{background:var(--gold);color:var(--paper);transform:translateY(-2px);}
.btn-fork-icon{font-size:1.1rem;}
.fork-note{
  margin-top:1.5rem;font-size:.78rem;
  color:rgba(245,239,226,.6);font-style:italic;
}

/* ── HOTEL ── */
.hotel-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;}
.hotel-img{aspect-ratio:4/3;background-size:cover;background-position:center;border:6px solid var(--paper);box-shadow:0 12px 35px rgba(28,40,32,.12);}
.hotel-text h2{margin-bottom:1.2rem;}
.hotel-text p{margin-bottom:1.2rem;font-size:1rem;line-height:1.85;}
.hotel-features{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.5rem;}
.hotel-feat{padding:1rem;background:var(--cream);font-size:.85rem;}
.hotel-feat strong{display:block;color:var(--green);font-family:'Playfair Display',Georgia,serif;font-size:1.05rem;margin-bottom:.2rem;}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;}
.contact-block{
  background:var(--cream);padding:2.5rem;
  border:1px solid var(--line);
}
.contact-block h3{
  font-family:'Playfair Display',Georgia,serif;
  font-size:1.4rem;font-weight:500;
  color:var(--char);margin-bottom:1rem;
}
.contact-block h3 em{font-style:italic;color:var(--green);}
.contact-line{
  display:flex;gap:.8rem;align-items:flex-start;
  margin-bottom:1rem;font-size:.95rem;
}
.contact-line .ico{color:var(--green);font-size:1.1rem;flex-shrink:0;width:1.5rem;}
.contact-line a:hover{color:var(--green);}
.hours-list{margin-top:1rem;}
.hours-row{
  display:flex;justify-content:space-between;
  padding:.5rem 0;border-bottom:1px dotted var(--line);
  font-size:.92rem;
}
.hours-row:last-child{border-bottom:none;}
.hours-day{color:var(--muted);text-transform:capitalize;}
.hours-time{color:var(--text);}
.hours-closed{color:var(--red-vd);font-style:italic;}

.map-wrap{margin-top:3rem;}
.map-frame{
  height:380px;border:6px solid var(--paper);
  box-shadow:0 12px 35px rgba(28,40,32,.12);overflow:hidden;
}
.map-frame iframe{width:100%;height:100%;border:0;display:block;}

/* ── FOOTER ── */
footer{
  background:var(--char);color:var(--cream);
  padding:4rem 2.5rem 1.5rem;
}
.foot-grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;
  margin-bottom:3rem;
}
.foot-col h4{
  font-family:'Inter',sans-serif;
  font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--gold);margin-bottom:1rem;font-weight:600;
}
.foot-col ul{list-style:none;}
.foot-col li{margin-bottom:.5rem;font-size:.9rem;}
.foot-col a{color:rgba(245,239,226,.7);transition:color .2s;}
.foot-col a:hover{color:var(--gold);}
.foot-brand{
  font-family:'Playfair Display',Georgia,serif;
  font-size:1.6rem;color:var(--cream);
}
.foot-brand-sub{
  font-family:'Inter',sans-serif;
  font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--gold);margin-top:.4rem;
}
.foot-desc{font-size:.88rem;color:rgba(245,239,226,.6);margin-top:1rem;line-height:1.7;}
.foot-bot{
  max-width:1200px;margin:0 auto;
  padding-top:1.5rem;border-top:1px solid rgba(245,239,226,.1);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;
  font-size:.75rem;color:rgba(245,239,226,.45);
}

/* ── REVEAL ── */
.r{opacity:0;transform:translateY(24px);transition:opacity .8s,transform .8s;}
.r.v{opacity:1;transform:none;}
.r1{transition-delay:.1s;}
.r2{transition-delay:.2s;}
.r3{transition-delay:.3s;}

/* ── MOBILE ── */
@media(max-width:900px){
  .header-top{padding:.5rem 1rem;font-size:.7rem;}
  .header-top .ht-r{display:none;}
  .header-main{padding:1rem 1rem;}
  nav.main-nav{
    display:none;position:absolute;top:100%;left:0;right:0;
    background:var(--paper);flex-direction:column;gap:0;
    border-bottom:1px solid var(--line);padding:1rem 0;
  }
  nav.main-nav.open{display:flex;}
  nav.main-nav a{padding:.8rem 1.5rem;width:100%;border-bottom:none;}
  .menu-toggle{display:block;}
  .hero{grid-template-columns:1fr;}
  .hero-content{padding:5rem 1.5rem 3rem;}
  .hero-visual{height:50vh;order:-1;}
  .hero-badge{display:none;}
  section{padding:3.5rem 1.2rem;}
  .page-head{padding:3.5rem 1.2rem 2.5rem;}
  .intro-grid,.hotel-grid,.contact-grid{grid-template-columns:1fr;gap:2.5rem;}
  .high-grid,.menus-grid{grid-template-columns:1fr;}
  .banquet-grid{grid-template-columns:1fr;}
  .amb-grid{grid-template-columns:1fr 1fr;grid-auto-rows:160px;}
  .amb-item.wide{grid-column:span 2;}
  .foot-grid{grid-template-columns:1fr 1fr;gap:2rem;}
  .foot-col:first-child{grid-column:span 2;}
  footer{padding:3rem 1.2rem 1rem;}
  .reserve-block{padding:3.5rem 1.2rem;}
}
@media(max-width:500px){
  .menu-item{flex-direction:column;align-items:flex-start;}
  .menu-item-price{align-self:flex-end;}
  .foot-grid{grid-template-columns:1fr;}
  .foot-col:first-child{grid-column:auto;}
  .hotel-features{grid-template-columns:1fr;}
  .amb-grid{grid-template-columns:1fr;grid-auto-rows:180px;}
  .amb-item.wide,.amb-item.tall{grid-column:auto;grid-row:auto;}
}
