/* ===== D' Coffee Bouteaque — bold & vibrant ===== */
:root{
  --espresso:#1d1410;
  --espresso-2:#2a1d16;
  --cream:#f7efe1;
  --cream-2:#efe2cd;
  --gold:#d8a64a;
  --gold-bright:#f0c25b;
  --rose:#c0476b;       /* scarlet rose pop */
  --rose-soft:#e07a98;
  --lavender:#7b6cc4;   /* lavender cold brew pop */
  --ink:#15100c;
  --muted:#8a7b69;
  --maxw:1200px;
  --ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Manrope',system-ui,sans-serif;
  background:var(--espresso);
  color:var(--cream);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
section{position:relative}

/* grain texture */
.grain{
  position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ===== buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-weight:700;font-size:.95rem;letter-spacing:.01em;
  padding:.95em 1.6em;border-radius:100px;cursor:pointer;border:1.5px solid transparent;
  transition:transform .3s var(--ease),background .3s,color .3s,box-shadow .3s;
}
.btn--solid{background:var(--gold);color:var(--ink);box-shadow:0 10px 30px -12px var(--gold)}
.btn--solid:hover{background:var(--gold-bright);transform:translateY(-3px);box-shadow:0 18px 40px -14px var(--gold-bright)}
.btn--ghost{border-color:rgba(247,239,225,.35);color:var(--cream)}
.btn--ghost:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-3px)}
.btn--pill{background:var(--cream);color:var(--ink);padding:.6em 1.2em;font-size:.85rem}
.btn--pill:hover{background:var(--gold-bright);transform:translateY(-2px)}

/* ===== nav ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:all .4s var(--ease)}
.nav__inner{
  max-width:var(--maxw);margin:0 auto;padding:1.4rem 2rem;
  display:flex;align-items:center;gap:2rem;
}
.nav.scrolled{background:rgba(20,16,12,.82);backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(216,166,74,.18)}
.nav.scrolled .nav__inner{padding:.85rem 2rem}
.nav__brand{display:flex;align-items:center;gap:.55rem;margin-right:auto}
.nav__brandmark{
  font-family:'Fraunces',serif;font-weight:900;font-size:1.7rem;color:var(--gold);
  line-height:1;
}
.nav__brandtext{font-family:'Cormorant Garamond',serif;font-size:1.15rem;letter-spacing:.06em;text-transform:uppercase;font-weight:600}
.nav__links{display:flex;gap:2rem}
.nav__links a{font-size:.92rem;font-weight:600;position:relative;opacity:.85;transition:opacity .25s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--gold);transition:width .3s var(--ease)}
.nav__links a:hover{opacity:1}
.nav__links a:hover::after{width:100%}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav__burger span{width:26px;height:2px;background:var(--cream);transition:.3s var(--ease)}

/* ===== hero ===== */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  padding:8rem 2rem 4rem;max-width:var(--maxw);margin:0 auto;}
.hero__media{position:absolute;inset:0;z-index:-1;overflow:hidden}
.hero__placeholder{
  position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 80% 10%, rgba(216,166,74,.22), transparent 55%),
    radial-gradient(90% 80% at 10% 90%, rgba(192,71,107,.20), transparent 55%),
    radial-gradient(70% 70% at 50% 50%, rgba(123,108,196,.12), transparent 60%),
    var(--espresso);
}
.hero__placeholder::after{
  content:"";position:absolute;inset:0;
  background:url("assets/photo-1.jpg") center/cover no-repeat;
  opacity:.22;mix-blend-mode:luminosity;filter:saturate(1.15);
}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,16,12,.4),rgba(20,16,12,.75) 70%,var(--espresso))}
.hero__content{max-width:760px}
.hero__eyebrow{font-weight:700;letter-spacing:.22em;text-transform:uppercase;font-size:.78rem;color:var(--gold);margin-bottom:1.4rem}
.hero__title{
  font-family:'Fraunces',serif;font-weight:900;line-height:.92;
  font-size:clamp(3.2rem,11vw,8.5rem);letter-spacing:-.02em;
}
.hero__title span{display:block}
.hero__title--accent{
  font-style:italic;font-weight:400;
  background:linear-gradient(100deg,var(--gold-bright),var(--rose-soft),var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero__sub{font-size:clamp(1.05rem,1.8vw,1.3rem);line-height:1.6;color:var(--cream-2);max-width:540px;margin:1.8rem 0 2.4rem}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap}
.hero__scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);
  display:flex;flex-direction:column;align-items:center;gap:.6rem}
.hero__scrollline{width:1px;height:46px;background:linear-gradient(var(--gold),transparent);animation:scrolldrop 2s var(--ease) infinite}
@keyframes scrolldrop{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* hero logo crest */
.hero__crest{position:absolute;right:4%;top:50%;width:360px;height:360px;
  transform:translateY(-50%);z-index:0;perspective:1000px;
  animation:crestIn 1.3s var(--ease) both}
@media(max-width:1040px){.hero__crest{display:none}}

.crest__halo{position:absolute;inset:-10%;border-radius:50%;
  background:radial-gradient(circle, rgba(240,194,91,.32) 30%, rgba(240,194,91,.08) 52%, transparent 68%);
  filter:blur(10px);animation:haloPulse 5s ease-in-out infinite}

.crest__rays{position:absolute;inset:-6%;border-radius:50%;opacity:.55;
  background:repeating-conic-gradient(from 0deg,
    rgba(240,194,91,.0) 0deg 6deg, rgba(240,194,91,.55) 6deg 7deg, rgba(240,194,91,0) 7deg 13deg);
  -webkit-mask:radial-gradient(circle, transparent 52%, #000 54%, #000 70%, transparent 76%);
  mask:radial-gradient(circle, transparent 52%, #000 54%, #000 70%, transparent 76%);
  animation:raysSpin 26s linear infinite}

.crest__orbit{position:absolute;inset:0;animation:raysSpin 18s linear infinite reverse}
.crest__orbit i{position:absolute;top:50%;left:50%;width:9px;height:9px;margin:-4px;border-radius:50%;
  background:var(--gold-bright);box-shadow:0 0 12px var(--gold-bright)}
.crest__orbit i:nth-child(1){transform:rotate(0deg) translateX(186px)}
.crest__orbit i:nth-child(2){transform:rotate(120deg) translateX(186px);background:var(--rose-soft);box-shadow:0 0 12px var(--rose-soft)}
.crest__orbit i:nth-child(3){transform:rotate(240deg) translateX(186px);background:var(--lavender);box-shadow:0 0 12px var(--lavender)}

.crest__tilt{position:absolute;inset:8%;transform-style:preserve-3d;
  transition:transform .3s ease-out;will-change:transform}
.crest__ring{display:block;position:relative;width:100%;height:100%;border-radius:50%;overflow:hidden;
  animation:crestFloat 6s ease-in-out infinite;
  background:radial-gradient(circle at 50% 35%, #fff, #efe2cd 75%, #e2d2b4);
  border:3px solid var(--gold-bright);
  box-shadow:0 0 0 8px rgba(20,16,12,.55), 0 0 0 9px rgba(240,194,91,.5),
    0 26px 60px -18px rgba(0,0,0,.8), inset 0 0 40px rgba(120,90,30,.18)}
.crest__logo{position:absolute;inset:8%;width:84%;height:84%;object-fit:contain;
  filter:contrast(1.08) saturate(1.05) drop-shadow(0 2px 4px rgba(0,0,0,.15));
  transform-origin:50% 56%;animation:logoBreathe 6.5s ease-in-out infinite}
@keyframes logoBreathe{
  0%,100%{transform:scale(1) rotate(-1.2deg)}
  50%{transform:scale(1.05) rotate(1.2deg)}}
.crest__shine{position:absolute;top:-60%;left:-30%;width:55%;height:220%;pointer-events:none;
  background:linear-gradient(100deg, transparent, rgba(255,255,255,.55), transparent);
  transform:rotate(18deg) translateX(-60px);filter:blur(2px);
  animation:shineSweep 5.5s ease-in-out infinite}

.crest__sparkles i{position:absolute;width:14px;height:14px;opacity:0;
  background:radial-gradient(circle, #fff 0 18%, transparent 22%),
    conic-gradient(from 0deg, transparent, var(--gold-bright), transparent 25%, transparent 50%, var(--gold-bright), transparent 75%);
  -webkit-mask:radial-gradient(circle,#000,transparent 70%);
  animation:twinkle 3s ease-in-out infinite}
.crest__sparkles i:nth-child(1){top:6%;left:18%;animation-delay:.2s}
.crest__sparkles i:nth-child(2){top:14%;right:8%;width:20px;height:20px;animation-delay:1.1s}
.crest__sparkles i:nth-child(3){bottom:12%;left:6%;width:18px;height:18px;animation-delay:1.8s}
.crest__sparkles i:nth-child(4){bottom:6%;right:18%;animation-delay:2.4s}
.crest__sparkles i:nth-child(5){top:46%;right:-2%;width:11px;height:11px;animation-delay:.7s}

@keyframes crestIn{from{opacity:0;transform:translateY(-50%) scale(.6) rotate(-14deg)}
  to{opacity:1;transform:translateY(-50%) scale(1) rotate(0)}}
@keyframes crestFloat{0%,100%{transform:translateY(-8px) rotate(-1.5deg)}50%{transform:translateY(10px) rotate(1.5deg)}}
@keyframes raysSpin{to{transform:rotate(360deg)}}
@keyframes haloPulse{0%,100%{transform:scale(1);opacity:.55}50%{transform:scale(1.12);opacity:.9}}
@keyframes shineSweep{0%{transform:rotate(18deg) translateX(-120px)}55%,100%{transform:rotate(18deg) translateX(560px)}}
@keyframes twinkle{0%,100%{opacity:0;transform:scale(.5) rotate(0)}50%{opacity:1;transform:scale(1.15) rotate(45deg)}}

/* ===== marquee ===== */
.marquee{background:var(--gold);color:var(--ink);overflow:hidden;padding:.9rem 0;
  border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}
.marquee__track{display:flex;gap:2.4rem;white-space:nowrap;width:max-content;animation:marq 34s linear infinite;
  font-family:'Fraunces',serif;font-weight:600;font-size:1.15rem;align-items:center}
.marquee__track i{color:var(--rose);font-style:normal}
@keyframes marq{to{transform:translateX(-50%)}}

/* ===== shared section bits ===== */
.kicker{font-weight:700;letter-spacing:.22em;text-transform:uppercase;font-size:.78rem;color:var(--gold)}
.section-head{max-width:760px;margin:0 auto 3.5rem;text-align:center;padding:0 2rem}
.section-head h2{font-family:'Fraunces',serif;font-weight:900;font-size:clamp(2rem,5vw,3.4rem);line-height:1.04;margin:.8rem 0;letter-spacing:-.01em}
.section-head__sub{color:var(--muted);font-size:1.05rem;line-height:1.6}
h2{letter-spacing:-.01em}

/* ===== about ===== */
.about{padding:7rem 2rem;max-width:var(--maxw);margin:0 auto}
.about__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:4rem;align-items:center}
.about__media{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:4/5;box-shadow:0 40px 80px -30px rgba(0,0,0,.7)}
.about__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.about__media:hover img{transform:scale(1.06)}
.about__ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:2rem;text-align:center;
  background:
    radial-gradient(80% 60% at 30% 20%, rgba(216,166,74,.3), transparent 60%),
    radial-gradient(80% 60% at 80% 90%, rgba(192,71,107,.25), transparent 60%),
    var(--espresso-2)}
.about__ph::before{content:attr(data-label);font-family:'Cormorant Garamond',serif;font-size:1.25rem;letter-spacing:.05em;color:var(--cream-2);opacity:.7}
.about__badge{position:absolute;bottom:1.2rem;left:1.2rem;background:var(--gold);color:var(--ink);
  border-radius:14px;padding:.7rem 1.1rem;display:flex;flex-direction:column;line-height:1;font-family:'Fraunces',serif}
.about__badge span{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase}
.about__badge strong{font-size:1.7rem;font-weight:900}
.about__copy h2{font-family:'Fraunces',serif;font-weight:900;font-size:clamp(2rem,4.5vw,3.2rem);line-height:1.02;margin:.7rem 0 1.4rem}
.about__copy p{color:var(--cream-2);line-height:1.7;margin-bottom:1.1rem;max-width:48ch}
.about__stats{display:flex;gap:2.5rem;margin-top:2rem;flex-wrap:wrap}
.about__stats strong{display:block;font-family:'Fraunces',serif;font-size:1.9rem;color:var(--gold)}
.about__stats span{font-size:.85rem;color:var(--muted)}

/* ===== menu ===== */
.menu{padding:7rem 2rem;background:linear-gradient(180deg,var(--espresso),var(--espresso-2))}
.menu__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem}
.menu-card{
  background:rgba(247,239,225,.04);border:1px solid rgba(216,166,74,.2);border-radius:18px;padding:2rem;
  transition:transform .4s var(--ease),border-color .4s,background .4s;
}
.menu-card:hover{transform:translateY(-6px);border-color:var(--gold);background:rgba(247,239,225,.06)}
.menu-card__head{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;
  padding-bottom:1.1rem;margin-bottom:1.1rem;border-bottom:1px dashed rgba(216,166,74,.3)}
.menu-card__head h3{font-family:'Fraunces',serif;font-size:1.5rem;font-weight:900}
.menu-card__tag{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);text-align:right}
.menu-card ul{list-style:none;display:flex;flex-direction:column;gap:.85rem}
.menu-card li{display:flex;justify-content:space-between;align-items:baseline;gap:.8rem;font-size:1.02rem}
.menu-card li span{color:var(--cream)}
.menu-card li b{font-family:'Fraunces',serif;color:var(--gold);font-weight:700}
.menu-card li b.dot{color:rgba(216,166,74,.4)}
.menu-card li.signature span{color:var(--rose-soft)}
.menu-card li em{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--rose);
  border:1px solid rgba(192,71,107,.45);border-radius:100px;padding:.2em .7em;font-style:normal;white-space:nowrap}
.menu__note{text-align:center;color:var(--muted);font-size:.9rem;margin-top:2.5rem;max-width:var(--maxw);margin-left:auto;margin-right:auto}

/* ===== menu connectors (cards -> logo hub) ===== */
.menu__constellation{position:relative;max-width:var(--maxw);margin:0 auto}
.menu__constellation .menu__grid{max-width:none;margin:0}
.menu__links{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1;overflow:visible;display:none}
.menu__links path{fill:none;stroke:rgba(216,166,74,.4);stroke-width:1.5;stroke-linecap:round;
  stroke-dasharray:5 9;animation:menuFlow 1.4s linear infinite}
.menu__links .menu-link-dot{fill:var(--gold-bright);filter:drop-shadow(0 0 5px rgba(240,194,91,.95))}
@keyframes menuFlow{to{stroke-dashoffset:-14}}
.menu-card{position:relative;z-index:2}
.menu-hub{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:140px;height:140px;z-index:3;pointer-events:none;display:none}
.menu-hub__glow{position:absolute;inset:-42%;border-radius:50%;
  background:radial-gradient(circle,rgba(240,194,91,.3) 30%,rgba(240,194,91,.06) 54%,transparent 70%);
  animation:haloPulse 4.5s ease-in-out infinite}
.menu-hub__ring{position:absolute;inset:0;display:block;border-radius:50%;overflow:hidden;
  background:radial-gradient(circle at 50% 35%,#fff,#efe2cd 75%,#e2d2b4);
  border:3px solid var(--gold-bright);
  box-shadow:0 0 0 6px rgba(20,16,12,.55),0 0 0 7px rgba(240,194,91,.5),0 18px 40px -14px rgba(0,0,0,.7),inset 0 0 28px rgba(120,90,30,.18);
  animation:crestFloat 6s ease-in-out infinite}
.menu-hub__logo{position:absolute;inset:9%;width:82%;height:82%;object-fit:contain;filter:contrast(1.08) saturate(1.05);
  transform-origin:50% 56%;animation:logoBreathe 6.5s ease-in-out infinite}
@media(min-width:1041px){
  .menu__constellation .menu__grid{column-gap:11rem;row-gap:9rem}
  .menu__links,.menu-hub{display:block}
}

/* ===== gallery ===== */
.gallery{padding:7rem 2rem;max-width:var(--maxw);margin:0 auto}
.gallery__grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:1rem}
.gallery__item{position:relative;border-radius:16px;overflow:hidden;background:var(--espresso-2)}
.gallery__item--tall{grid-row:span 2}
.gallery__item--wide{grid-column:span 2}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.gallery__item:hover img{transform:scale(1.08)}
.gallery__item figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.4rem 1rem .9rem;
  font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--cream);
  background:linear-gradient(transparent,rgba(20,16,12,.8));
  opacity:0;transform:translateY(8px);transition:opacity .4s var(--ease),transform .4s var(--ease)}
.gallery__item:hover figcaption{opacity:1;transform:none}
.gallery__ph{position:absolute;inset:0;display:flex;align-items:flex-end;padding:1rem;
  background:radial-gradient(120% 120% at 30% 20%,rgba(216,166,74,.25),transparent 60%),var(--espresso-2)}
.gallery__ph--2{background:radial-gradient(120% 120% at 70% 30%,rgba(123,108,196,.3),transparent 60%),var(--espresso-2)}
.gallery__ph--3{background:radial-gradient(120% 120% at 50% 30%,rgba(192,71,107,.3),transparent 60%),var(--espresso-2)}
.gallery__ph--4{background:radial-gradient(100% 80% at 40% 20%,rgba(216,166,74,.32),transparent 60%),radial-gradient(80% 60% at 70% 100%,rgba(123,108,196,.25),transparent 60%),var(--espresso-2)}
.gallery__ph::before{content:attr(data-label);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--cream-2);opacity:.7}
.gallery__note{text-align:center;color:var(--muted);margin-top:2rem;font-size:.95rem}
.gallery__note a{color:var(--gold);font-weight:700}

/* ===== visit ===== */
.visit{padding:7rem 2rem;background:linear-gradient(180deg,var(--espresso-2),var(--espresso))}
.visit__grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;gap:3.5rem;align-items:stretch}
.visit__info h2{font-family:'Fraunces',serif;font-weight:900;font-size:clamp(2rem,4.5vw,3.2rem);margin:.6rem 0 2rem}
.visit__block{margin-bottom:1.8rem}
.visit__block h4{font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem}
.visit__block p{line-height:1.7;color:var(--cream-2)}
.link-arrow{color:var(--cream);font-weight:600;border-bottom:1px solid rgba(216,166,74,.4);transition:.25s}
.link-arrow:hover{color:var(--gold);border-color:var(--gold)}
.hours{list-style:none;display:flex;flex-direction:column;gap:.5rem;max-width:320px}
.hours li{display:flex;justify-content:space-between;padding-bottom:.5rem;border-bottom:1px dashed rgba(216,166,74,.18)}
.hours b{font-family:'Fraunces',serif;color:var(--gold)}
.visit__confirm{display:block;margin-top:.7rem;color:var(--muted);font-size:.8rem;font-style:italic}
.visit__map{border-radius:18px;overflow:hidden;min-height:420px;border:1px solid rgba(216,166,74,.25)}
.visit__map iframe{width:100%;height:100%;min-height:420px;border:0;filter:grayscale(.3) contrast(1.05)}

/* ===== footer ===== */
.footer{background:var(--ink);padding:3.5rem 2rem}
.footer__inner{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.footer__brand{display:flex;align-items:center;gap:.9rem}
.footer__mark{font-family:'Fraunces',serif;font-weight:900;font-size:2.2rem;color:var(--gold)}
.footer__brand strong{font-family:'Cormorant Garamond',serif;font-size:1.3rem;letter-spacing:.08em;text-transform:uppercase;display:block}
.footer__brand em{color:var(--muted);font-size:.82rem}
.footer__links{display:flex;gap:1.6rem}
.footer__links a{font-size:.9rem;color:var(--cream-2);transition:color .25s}
.footer__links a:hover{color:var(--gold)}
.footer__copy{color:var(--muted);font-size:.82rem;width:100%;text-align:center;padding-top:2rem;margin-top:1rem;border-top:1px solid rgba(247,239,225,.08)}

/* ===== reveal animation ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease);transition-delay:var(--d,0s)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none}
  .marquee__track,.hero__scrollline,.crest__rays,.crest__orbit,.crest__halo,.crest__shine,.crest__sparkles i,.crest__ring,.crest__logo,.menu__links path,.menu-hub__glow,.menu-hub__ring,.menu-hub__logo{animation:none}
  .menu__links .menu-link-dot{display:none}
}

/* ===== responsive ===== */
@media(max-width:900px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
  .nav__menu-open .nav__links{display:flex;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;background:rgba(20,16,12,.97);backdrop-filter:blur(14px);padding:1.5rem 2rem;gap:1.4rem}
  .about__grid,.visit__grid{grid-template-columns:1fr;gap:2.5rem}
  .menu__grid{grid-template-columns:1fr}
  .gallery__grid{grid-template-columns:repeat(2,1fr)}
  .gallery__item--wide{grid-column:span 2}
}
@media(max-width:560px){
  .nav__inner{padding:1rem 1.2rem}
  .hero{padding:7rem 1.4rem 4rem}
  .about,.menu,.gallery,.visit{padding:4.5rem 1.4rem}
  .about__stats{gap:1.5rem}
  .gallery__grid{grid-template-columns:1fr;grid-auto-rows:180px}
  .gallery__item--wide,.gallery__item--tall{grid-column:auto;grid-row:auto}
  .footer__inner{flex-direction:column;text-align:center}
}
