:root{
  --text:#4b0f14;          
  --accent:#9c2a33;       
  --muted:#a97579;   
--muted2:#c8868b4c;     
  --border:rgba(0,0,0,.12);
  --bg:#ffffff;
  --soft:#faf7f6;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text)}
body{font-family:"EB Garamond",serif;font-size:18px;line-height:1.35}
img{display:block;max-width:100%;height:auto}

.container{width:min(1200px,75%);margin-inline:auto}

.site-header{position:sticky;top:0;z-index:10;background:#fff;border-bottom:1px solid var(--border)}
.navwrap{display:flex;align-items:center;justify-content:space-between;padding:10px 0}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);font-weight:600}
.brand img{width:34px;height:34px;object-fit:contain}
.brand span{font-size:26px;letter-spacing:.15px}
.navlinks{display:flex;gap:28px}
.navlinks a{color:var(--accent);text-decoration:none;font-weight:600;text-transform:uppercase;font-size:14px}
.navlinks a.active{border-bottom:2px solid var(--accent)}
.brand img{
  height: 52px;          width: auto;           object-fit: contain;
}

.navwrap{
  min-height: 80px;      padding: 8px 0;
}

@media (min-width: 1400px){
  .brand img{ height: 50px; }
}

@media (max-width: 640px){
  .brand img{ height: 48px; }
}

.duo-hero{display:grid;grid-template-columns:1fr 1fr}
.duo-hero { 
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;              margin: 0;           padding: 0;
}

.duo-hero .duo-img { 
  margin: 0;         }

.duo-hero .duo-img img{
  display: block;      width: 100%;
  height: 100%;
  object-fit: cover;
}

.duo-hero{
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw); }

.duo-img{aspect-ratio:4/3;overflow:hidden}
.duo-img img{width:100%;height:100%;object-fit:cover}

.about{padding:40px 0 10px;}
.eyebrow{font-size:14px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:4px 0 12px}
.about-copy{max-width:1200px;font-size:20px}


.location-grid{display:grid;grid-template-columns:minmax(260px,420px) 1fr;align-items:start;gap:44px}
.location-copy{font-style:normal;text-align:center;align-self:center;font-weight:700;color:var(--accent)}

.site-footer{border-top:1px solid var(--border);padding:22px 0;color:#7b5b5e}


.menu-row{
  display:grid;
  grid-template-columns: minmax(640px, 1fr) 270px 270px 270px;   align-items:start;
  gap:48px;
  padding:60px 4%;
}

.menu-row.photo-xl{
  grid-template-columns: minmax(840px, 1fr) 270px 270px 270px;
}

.menu-row.has-right-figure{
  grid-template-columns: minmax(640px, 1fr) 270px 270px 270px 300px; }

.menu-photo{overflow:hidden}
.menu-photo img{width:100%; height:auto; display:block}

.right-figure{grid-column: 5}

.menu-columns{display:contents}
.col{display:flex;flex-direction:column;gap:10px}
.col-title{margin:0 0 0px;font-size:20px;font-weight:700;text-transform:lowercase}
.col-title .sub{font-weight:600;color:#a97579}
.col-title.invisible{visibility:hidden;height:0;margin:0}
.menu-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:18px}
.menu-list li{font-size:14px;line-height:1;color:#6b2c33}
.menu-list .num{color:#9c2a33;font-weight:700;margin-right:6px}
.menu-list li{
  display: flex;                align-items: baseline;
  gap: 12px;                    white-space: nowrap;        }

.menu-list li br{
  display: none;
}

@media (max-width: 1200px){
  .menu-row{grid-template-columns:minmax(560px,1fr) 250px 250px 250px}
  .menu-row.photo-xl{grid-template-columns:minmax(720px,1fr) 250px 250px 250px}
  .menu-row.has-right-figure{grid-template-columns:minmax(560px,1fr) 250px 250px 250px 260px}
}
@media (max-width: 960px){
  .menu-row,
  .menu-row.photo-xl,
  .menu-row.has-right-figure{
    grid-template-columns:1fr; gap:24px;
  }
  .col-title.invisible{display:none}
  .right-figure{grid-column:auto}
}
.menu-row.photo-xl{
    padding: 60px 4% 60px 0;     }

.menu-row.photo-xl .menu-photo{
  border-radius: 0;            }


@media (max-width: 960px){
  .menu-row.photo-xl{
    padding: 40px 4%;            }
  .menu-row.photo-xl .menu-photo{
    border-radius: 6px;
  }
}
.menu-row > .menu-photo { margin: 0; }              .menu-row.photo-xl > .menu-photo { margin-left: 0; } 
.menu-row.photo-xl { padding-left: 0; }

html, body { overflow-x: hidden; }

.menu-row.photo-narrow{
    grid-template-columns: minmax(640px, 1fr) 370px 270px 270px;
}

.menu-row.photo-narrow .menu-photo{
  width: 460px;             justify-self: start;    }

.menu-row.photo-narrow .menu-photo{
  width: 230px;            justify-self: start;   }
@media (min-width: 1400px){
  .menu-row.photo-narrow .menu-photo{ width: 250px; } }
@media (max-width: 960px){
  .menu-row.photo-narrow .menu-photo{ width: 100%; }  }
.menu-row.photo-narrow .menu-photo{
  width: 230px;            justify-self: start;     margin-left: 280px;     }

@media (max-width: 960px){
  .menu-row.photo-narrow .menu-photo{
    width: 100%;
    margin-left: 0;        }
}

.menu-row.has-right-figure{
    grid-template-columns: minmax(540px, 1fr) 270px 270px minmax(420px, 1fr);
  gap: 64px;                   padding: 60px 4%;
}

.menu-row.has-right-figure .right-figure{ grid-column: 4; }

.menu-row.has-right-figure > .menu-photo:first-of-type{
  width: 560px;                justify-self: start;
}
.menu-row.has-right-figure .right-figure{
  width: 420px;                justify-self: end;
}

.duo-img img {
  opacity: 0;
  transition: opacity 1.6s ease;
}

.duo-img img.loaded {
  opacity: 1;
}


@media (max-width: 1100px){
  .menu-row{grid-template-columns:minmax(360px,1fr) 240px 240px 240px;gap:28px}
}
@media (max-width: 920px){
  .menu-row{grid-template-columns:minmax(320px,1fr) 220px 220px 220px}
}
@media (max-width: 860px){
  .duo-hero{grid-template-columns:1fr}
  .location-grid{grid-template-columns:1fr}
  .menu-row{grid-template-columns:1fr;gap:20px}
  .menu-photo.hero img{width:115%;transform:translateX(-4%)}   .menu-photo.wide.hero img{width:125%;transform:translateX(-5%)}
  .col-title.invisible{display:none}
  .reserv-form{grid-template-columns:1fr}
}

@media (max-width: 1024px){
  .brand img{ height: 48px; }
  .navlinks{ gap: 20px; }
  .navlinks a{ font-size: 13px; }
}

@media (max-width: 768px){
  .navwrap{
    flex-wrap: wrap;               row-gap: 8px;
    padding: 8px 0;
  }

    .brand{
    flex: 1 0 100%;
    justify-content: center;     }

    .navlinks{
    flex: 1 0 100%;
    justify-content: center;       gap: 16px;
    margin-top: 4px;
  }
}

@media (max-width: 420px){
  .brand img{ height: 42px; }           .navlinks{
    gap: 14px;
    overflow-x: auto;                     white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 6px;                }
  .navlinks a{ font-size: 12px; }
}
@media (max-width: 960px){
  .menu-row.photo-narrow{
    grid-template-columns: 1fr;
  }
}

.reserv { padding: 56px 0 88px; background: var(--bg); }

.reserv-card{

  border-radius: 12px;
  background:#fff;
  padding: 28px min(6vw,48px) 40px;
  max-width: 860px;
  margin: 0 auto;
}

.reserv-title{
  margin: 0 0 22px;
  font-size: 36px;
  font-weight: 700;
  color: var(--accent);
  line-height: 1.1;
}

.reserv-form{
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
}

.reserv-form label{
  display: grid;
  gap: 10px;
  font-size: 14px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #a6a6a6;
}

.reserv-form input,
.reserv-form select,
.reserv-form textarea{
  appearance: none;
  border: none;
  border-bottom: 4px solid #2f2f2f;
  padding: 14px 8px 14px 0;
  background: transparent;
  color: var(--text);
  font-family: "EB Garamond", serif;
  font-size: 22px;
  line-height: 1.1;
}

.reserv-form input::placeholder{ color:#8a8a8a; }

.reserv-form input:focus{
  outline: none;
  border-bottom-color: var(--accent);
}
.reserv-form label:focus-within{ color: var(--text); }

.reserv-form input[type="date"]::-webkit-calendar-picker-indicator,
.reserv-form input[type="time"]::-webkit-calendar-picker-indicator{
  filter: grayscale(1) opacity(.75);
}

.reserv-form input[type="number"]::-webkit-outer-spin-button,
.reserv-form input[type="number"]::-webkit-inner-spin-button{ -webkit-appearance: none; margin:0; }


.btn-outline{
  justify-self: stretch;
  padding: 16px 20px;
  border: 3px solid #2f2f2f;
  border-radius: 6px;
  background: transparent;
  color: var(--muted2);
  font-weight: 700;
  font-size: 20px;
  text-transform: lowercase;
  cursor: pointer;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
}



@media (max-width: 640px){
  .reserv-card{ padding: 22px 16px 28px; border-radius: 10px; }
  .reserv-title{ font-size: 28px; margin-bottom: 14px; }
  .reserv-form{ gap: 22px; }
  .reserv-form input{ font-size: 20px; border-bottom-width: 3px; }
  .btn-outline{ font-size: 18px; padding: 14px 16px; border-width: 3px; }
}
@media (min-width: 641px){
  .reserv-card{
    max-width: 550px;              padding: 22px 28px 30px;       border-width: 2px;             border-radius: 10px;
  }

  .reserv-title{
    font-size: 28px;               margin-bottom: 14px;
  }

  .reserv-form{ gap: 18px; }

  .reserv-form label{
    font-size: 12px;               letter-spacing: .12em;
    gap: 8px;
  }

  .reserv-form input,
  .reserv-form select,
  .reserv-form textarea{
    font-size: 18px;               padding: 10px 6px 10px 0;
    border-bottom-width: 3px;    }

  .btn-outline{
    font-size: 18px;               padding: 12px 16px;
    border-width: 2px;
  }
}
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

.btn-outline{

  border-radius:10px;
  background-color:#fff;              cursor:pointer;
}

.btn-wordmark{
    width: clamp(220px, 40vw, 420px);
  height: 64px;                      
    background-image: url("./img/res.png");   background-repeat: no-repeat;
  background-position: center;
  background-size: 70% auto;         
    color: transparent;
}



.reserv-form .btn-wordmark{
  justify-self: center;       width: clamp(160px, 30vw, 220px);
  height: 64px;
  background-image: url("./img/res.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 70% auto;
  color: transparent;       }

@media (max-width: 640px){
  .reserv-form .btn-wordmark{
    width: min(300px, 60%);
    height: 56px;
    background-size: 80% auto;
  }
}
.reserv-form .btn-wordmark{
  border: none;            box-shadow: none;      }
.reserv-form .btn-wordmark{
  transition: transform 160ms ease;     transform-origin: center;
}

.reserv-form .btn-wordmark:hover,
.reserv-form .btn-wordmark:focus-visible{
  transform: scale(1.04);             }

.reserv-form .btn-wordmark:active{
  transform: scale(0.98);              }

@media (prefers-reduced-motion: reduce){
  .reserv-form .btn-wordmark{ transition: none; }
}
.reserv-msg{
  margin-top: 16px;
  padding: 14px 16px;
  border: 2px solid var(--accent);
  border-radius: 8px;
  background: #fff;
  color: var(--text);
  font-weight: 600;
  display: none;
}
.reserv-msg.show{ display: block; animation: fadeIn 180ms ease-out; }
.reserv-msg .tick{
  display:inline-block; margin-right:10px; font-weight:700; color: var(--accent);
}

@keyframes fadeIn{ from{opacity:0; transform: translateY(4px);} to{opacity:1; transform:none;} }
.reserv-msg{
  margin-top:16px; padding:14px 16px; border:2px solid var(--accent);
  border-radius:8px; background:#fff; color:var(--text); font-weight:600;
  display:none;
}
.reserv-msg.show{ display:block; animation: fadeIn .18s ease-out; }
.reserv-msg .icon{ font-weight:800; margin-right:10px; }
.reserv-msg .icon.ok{ color:var(--accent); }

.reserv-msg.error{ border-color:#c0392b; background:#fff6f5; color:#7a1b1b; }
.reserv-msg.error .icon{ color:#c0392b; }

.input-error{ border-bottom-color:#c0392b !important; }

@keyframes fadeIn{ from{opacity:0; transform:translateY(4px)} to{opacity:1; transform:none} }
.location-card{
  align-self: center;          justify-self: center;        max-width: 520px;            width: 100%;
}
.location-card img{
  width: 70%;
  height: auto;
  display: block;
  border-radius: 6px;          object-fit: contain;
  margin-left: 15%;
}

@media (min-width: 1100px){
  .location-photo img{ max-height: 520px; object-fit: cover; }
}

.location-grid > figure,
.location-photo,
.location-card {
  margin: 0;
}

.location { padding-bottom: 0; }

.location-card img { display: block; }
.menu-list.oysters li{
  display: grid;                              grid-template-columns: auto 1fr auto;       gap: 12px;
  align-items: baseline;
  white-space: normal;                      }

.menu-list.oysters .price{
  justify-self: end;
}

.menu-list.oysters li.sizes{
  font-weight: 700;
}

.menu-list.oysters li br{ display:none; }
.site-header.is-scrolled{
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(4px);
}

:root{
  --ease-soft: cubic-bezier(.22, .61, .36, 1);   --dur-soft:  520ms;
}

.site-header{
  transition:
    background-color .32s var(--ease-soft),
    box-shadow       .32s var(--ease-soft),
    backdrop-filter  .32s var(--ease-soft);
  will-change: background-color, box-shadow, backdrop-filter;
}

.site-header.is-scrolled{
  background-color: rgba(255,255,255,.88);
  backdrop-filter: blur(8px) saturate(125%);
  box-shadow:
    0 6px 28px rgba(0,0,0,.05),
    0 1px 0   rgba(0,0,0,.06);
}

.reveal{
  opacity: 0;
  transform: translateY(6px);             will-change: opacity, transform;
}
.reveal.in{
  opacity: 1;
  transform: none;
  transition:
    opacity   var(--dur-soft) var(--ease-soft),
    transform var(--dur-soft) var(--ease-soft);
  transition-delay: var(--reveal-delay, 0ms); }


html{ scroll-behavior: smooth; }

:target{ scroll-margin-top: calc(80px + 12px); }

@media (prefers-reduced-motion: reduce){
  .site-header{ transition: none; }
  .reveal, .reveal.in{
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

:root{
  --reveal-ease: cubic-bezier(.16,1,.3,1);     --reveal-duration: 520ms;                    --reveal-distance: 10px;                     --reveal-blur: 6px;                        }

.reveal{
  opacity: 0;
  transform: translateY(var(--reveal-distance)) scale(.995);
  filter: blur(var(--reveal-blur));
  transition:
    opacity var(--reveal-duration) var(--reveal-ease) var(--reveal-delay,0ms),
    transform var(--reveal-duration) var(--reveal-ease) var(--reveal-delay,0ms),
    filter calc(var(--reveal-duration) * .8) var(--reveal-ease) var(--reveal-delay,0ms);
  will-change: opacity, transform, filter;
}

.reveal.in{
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
}


.menu-row .menu-photo img.reveal{
  opacity: 0;
  transform: translateY(8px) scale(1.02);
}
.menu-row .menu-photo img.reveal.in{
  opacity: 1;
  transform: none;
  transition:
    opacity   var(--dur-soft) var(--ease-soft),
    transform var(--dur-soft) var(--ease-soft);
  transition-delay: var(--reveal-delay, 0ms);
}

.menu-list li.reveal{ transform: translateY(4px); }
.menu-list li.reveal.in{ transform: none; }

.menu-list li:hover .item{ text-decoration: underline; text-underline-offset: 2px; }

@media (prefers-reduced-motion: reduce){
  .reveal,.reveal.in,
  .menu-row .menu-photo img.reveal,
  .menu-row .menu-photo img.reveal.in{
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}
:root{
  --ease-soft: cubic-bezier(.22,.61,.36,1);
  --dur-soft: 520ms;
}

.site-header{
  transition:
    background var(--dur-soft) var(--ease-soft),
    box-shadow var(--dur-soft) var(--ease-soft),
    backdrop-filter var(--dur-soft) var(--ease-soft);
}
.site-header.is-scrolled{
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(4px);
}

.reveal{
  opacity: 0;
  transform: translateY(8px);
  will-change: opacity, transform;
}
.reveal.in{
  opacity: 1;
  transform: none;
  transition:
    opacity   var(--dur-soft) var(--ease-soft),
    transform var(--dur-soft) var(--ease-soft);
  transition-delay: var(--reveal-delay, 0ms);
}

.reserv .reserv-card.reveal{ transform: translateY(10px) scale(.995); }
.reserv .reserv-card.reveal.in{ transform: none; }
.reserv .reserv-form label.reveal,
.reserv .reserv-form input.reveal,
.reserv .reserv-form button.reveal{
  transform: translateY(6px);
}
.reserv .reserv-form label.reveal.in,
.reserv .reserv-form input.reveal.in,
.reserv .reserv-form button.reveal.in{
  transform: none;
}

:target{ scroll-margin-top: 90px; }

@media (prefers-reduced-motion: reduce){
  .reveal,
  .reveal.in{
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

.shop-grid{
  list-style: none;
  margin: 0 0 18px;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px 36px;
  align-items: start;
}

.product-card{
  text-align: center;
}

.product-media{
  aspect-ratio: 5/7;
  display: grid;
  place-items: center;
  background: #fff;
  overflow: hidden;
  transition: transform 360ms cubic-bezier(.22,.61,.36,1),
              box-shadow 360ms cubic-bezier(.22,.61,.36,1);
}
.product-media img{
  width: 96%;
  height: 96%;
  object-fit: contain;
}

.product-card:hover .product-media{
  transform: translateY(-4px);
  box-shadow: 0 10px 28px rgba(0,0,0,.10);
}

.product-name{
  margin: 12px 0 6px;
  font-weight: 700;
  font-size: 18px;
  color: var(--text);
}
.product-desc{
  margin: 0 0 6px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.25;
}
.product-price{
  font-weight: 800;
  color: var(--accent);
  font-size: 18px;
}
.product-price span{ font-weight: 700; }

.reveal{ opacity:0; transform: translateY(8px); }
.reveal.in{
  opacity:1; transform:none;
  transition: opacity 520ms cubic-bezier(.22,.61,.36,1),
              transform 520ms cubic-bezier(.22,.61,.36,1);
  transition-delay: var(--reveal-delay, 0ms);
}

.site-header{
  transition: background 520ms cubic-bezier(.22,.61,.36,1),
              box-shadow 520ms cubic-bezier(.22,.61,.36,1),
              backdrop-filter 520ms cubic-bezier(.22,.61,.36,1);
}
.site-header.is-scrolled{
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(4px);
}

@media (max-width: 1100px){
  .shop-grid{ grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 860px){
  .shop-grid{ grid-template-columns: repeat(2, 1fr); gap: 22px; }
}
@media (max-width: 540px){
  .shop-grid{ grid-template-columns: 1fr; }
  .product-media img{ width: 78%; height: 78%; }
}
.meddon-regular {
  font-family: "Meddon", cursive;
  font-weight: 400;
  font-style: normal;
}
.closing-image{ padding: 40px 0 80px; }
.closing-image .container{
  display: flex;
  justify-content: center;
}
.closing-media{ margin: 0; }                 .closing-media img{
  display: block;
  width: min(350px, 92vw);                     height: auto;
  border-radius: 6px;                        }

.menu-row.reveal{        --reveal-duration: 900ms;  --reveal-distance: 14px; }
.menu-photo img.reveal{  --reveal-duration: 1000ms; --reveal-distance: 16px; }
.menu-list li.reveal{    --reveal-duration: 650ms;  --reveal-distance: 8px; }

@media (prefers-reduced-motion: reduce){
  .reveal{ transition: none; opacity: 1; transform: none; }
}
:root{ --reveal-ease: cubic-bezier(.16,1,.3,1); }

.reveal{
  opacity: 0;
  transform: translateY(var(--reveal-distance, 10px));
  transition:
    opacity   var(--reveal-duration, 800ms) var(--reveal-ease) var(--reveal-delay, 0ms),
    transform var(--reveal-duration, 800ms) var(--reveal-ease) var(--reveal-delay, 0ms);
}

.reveal.in{ opacity: 1; transform: none; }


/* ===== Mobile menu variables (tweak to match your maroon) ===== */


/* ===== Responsive switches ===== */
@media (max-width: 900px){
  .navlinks{ display:none; }   /* hide desktop nav on mobile */
  .burger{ display:block; }
}
/* FORCE logo + burger on the same line (mobile) */
.site-header .navwrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:nowrap;          /* important: prevents wrapping */
}

/* Make brand not steal the whole row */
.site-header .brand{
  display:flex;
  align-items:center;
  flex: 0 1 auto;
  min-width: 0;
}

/* Control logo size so it fits with burger */
.site-header .brand img{
  height: 54px;              /* adjust if needed */
  width: auto;
  display:block;
}


@media (max-width: 900px){
  .navlinks{ display:none; }
  .burger{ display:block; }
}
@media (max-width: 900px){
  .site-header .navwrap{ flex-direction: row !important; }
}

/* ===== FINAL MOBILE MENU (one button morphs into X, no clipping) ===== */
:root{
  --header-h: 82px;
  --pad-x: 22px;
  --logo-h: 48px;
  --burger-ink: #b35c5c;
  --menu-bg: #6b2b25;
  --menu-ink: #ffffff;
}

.site-header .navwrap{
  min-height: var(--header-h);
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:nowrap;
  padding: 0 var(--pad-x);
}

.site-header .brand img{
  height: var(--logo-h);
  width:auto;
  display:block;
}

/* One button (burger -> X) */
.menu-btn{
  display:none;
  width:44px;
  height:44px;
  border:0;
  padding:10px;
  background:transparent;
  cursor:pointer;
  position:relative;
  overflow: visible; /* prevents “cut” */
}

.menu-btn .bar{
  display:block;
  width:100%;
  height:2px;
  background: var(--burger-ink);
  border-radius:2px;
  transition: transform .22s ease, opacity .18s ease;
}

.menu-btn .b1{ transform: translateY(-8px); }
.menu-btn .b2{ transform: translateY(0); }
.menu-btn .b3{ transform: translateY(8px); }

/* X state */
body.menu-open .menu-btn .b1{ transform: translateY(0) rotate(45deg); }
body.menu-open .menu-btn .b2{ opacity:0; }
body.menu-open .menu-btn .b3{ transform: translateY(0) rotate(-45deg); }

/* Menu overlay UNDER header (logo stays fixed) */
.mobile-menu{
  position:fixed;
  left:0; right:0;
  top: var(--header-h);
  bottom:0;
  background: var(--menu-bg);
  z-index: 9990;

  opacity:0;
  pointer-events:none;
  transform: translateY(-8px);
  transition: opacity .2s ease, transform .2s ease;
}

body.menu-open .mobile-menu{
  opacity:1;
  pointer-events:auto;
  transform: translateY(0);
}

.mobile-links{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  gap:22px;
  padding-top: 140px;
  padding-inline: 24px;
  text-align:center;
}

.mobile-links a{
  color: var(--menu-ink);
  text-decoration:none;
  font-family: "EB Garamond", serif;
  letter-spacing: 1px;
  font-size: 22px;
  line-height: 1.05;
}

body.menu-open{ overflow:hidden; }

@media (max-width: 900px){
  .navlinks{ display:none; }
  .menu-btn{ display:block; }
  .container{ width: 80%; } /* optional */
}
/* Lock scroll when menu is open */
body.menu-open{
  overflow:hidden;
}
/* give space on the right so the rotated X never hits the edge */
.site-header .navwrap{
  padding-right: calc(var(--pad-x) + 10px) !important;
}

/* keep button inside */
.menu-btn{
  margin-right: max(10px, env(safe-area-inset-right));
  padding: 0;                 /* important */
}

/* center + shorten bars so rotation stays inside */
.menu-btn .bar{
  width: 26px;                /* was 100% */
  margin: 0 auto;             /* center horizontally */
}

/* keep vertical offsets but smaller so it doesn't hit edges */
.menu-btn .b1{ transform: translateY(-7px); }
.menu-btn .b3{ transform: translateY(7px); }
.menu-btn{ position: relative; padding:0; }
.menu-btn .bar{
  position:absolute;
  left:50%;
  top:50%;
  width:28px;
  height:2px;
  transform-origin:center;
  margin:0;
}
.menu-btn .b1{ transform: translate(-50%,-50%) translateY(-7px); }
.menu-btn .b2{ transform: translate(-50%,-50%); }
.menu-btn .b3{ transform: translate(-50%,-50%) translateY(7px); }

body.menu-open .menu-btn .b1{ transform: translate(-50%,-50%) rotate(45deg); }
body.menu-open .menu-btn .b2{ opacity:0; }
body.menu-open .menu-btn .b3{ transform: translate(-50%,-50%) rotate(-45deg); }
/* ===== One background block behind ALL mobile links ===== */
/* FULL-WIDTH background under ALL menu links */
body.menu-open .mobile-links{
  position: relative;

  width: 100%;
  max-width: none;
  margin: 0;
  padding: 36px 24px 42px;

  /* background color */
  background: rgb(107, 43, 37); /* maroon */
  border-radius: 0;                   /* full-width = no rounding */

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 22px;
  text-align: center;
}


/* Links should NOT have their own background now */
body.menu-open .mobile-links a{
  background: none;
  border: none;
  padding: 10px 0;
  display: block;
}

/* Optional hover */
body.menu-open .mobile-links a:hover,
body.menu-open .mobile-links a:focus-visible{
  opacity: .9;
  transform: translateY(-1px);
}

/* FULL SCREEN overlay (covers everything, even header) */
.mobile-menu{
  position: fixed;
  inset: 0;                 /* top/right/bottom/left = 0 */
  z-index: 9990;
  background: rgba(107, 43, 37, 0.75);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  opacity: 0;
  pointer-events: none;
  transform: translateY(-8px);
  transition: opacity .2s ease, transform .2s ease;
    top: var(--header-h);                      /* start under header */
  height: calc(100dvh - var(--header-h));    
}

body.menu-open .mobile-menu{
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

/* Make the links block fill the whole overlay */
body.menu-open .mobile-links{
  height: 107dvh;            /* mobile-safe full height */
  width: 100%;
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 22px;
  text-align: center;
}

/* Links: no individual backgrounds */
body.menu-open .mobile-links a{
  background: none;
  border: none;
  padding: 10px 0;
  display: block;
}
:root{
  --text:#4b0f14;          
  --accent:#9c2a33;       
  --muted:#a97579;   
--muted2:#c8868b4c;     
  --border:rgba(0,0,0,.12);
  --bg:#ffffff;
  --soft:#faf7f6;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text)}
body{font-family:"EB Garamond",serif;font-size:18px;line-height:1.35}
img{display:block;max-width:100%;height:auto}

.container{width:min(1200px,75%);margin-inline:auto}

.site-header{position:sticky;top:0;z-index:10;background:#fff;border-bottom:1px solid var(--border)}
.navwrap{display:flex;align-items:center;justify-content:space-between;padding:10px 0}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);font-weight:600}
.brand img{width:34px;height:34px;object-fit:contain}
.brand span{font-size:26px;letter-spacing:.15px}
.navlinks{display:flex;gap:28px}
.navlinks a{color:var(--accent);text-decoration:none;font-weight:600;text-transform:uppercase;font-size:14px}
.navlinks a.active{border-bottom:2px solid var(--accent)}
.brand img{
  height: 52px;          width: auto;           object-fit: contain;
}

.navwrap{
  min-height: 80px;      padding: 8px 0;
}

@media (min-width: 1400px){
  .brand img{ height: 50px; }
}

@media (max-width: 640px){
  .brand img{ height: 48px; }
}

.duo-hero{display:grid;grid-template-columns:1fr 1fr}
.duo-hero { 
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;              margin: 0;           padding: 0;
}

.duo-hero .duo-img { 
  margin: 0;         }

.duo-hero .duo-img img{
  display: block;      width: 100%;
  height: 100%;
  object-fit: cover;
}

.duo-hero{
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw); }

.duo-img{aspect-ratio:4/3;overflow:hidden}
.duo-img img{width:100%;height:100%;object-fit:cover}

.about{padding:40px 0 10px;}
.eyebrow{font-size:14px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:4px 0 12px}
.about-copy{max-width:1200px;font-size:20px}


.location-grid{display:grid;grid-template-columns:minmax(260px,420px) 1fr;align-items:start;gap:44px}
.location-copy{font-style:normal;text-align:center;align-self:center;font-weight:700;color:var(--accent)}

.site-footer{border-top:1px solid var(--border);padding:22px 0;color:#7b5b5e}


.menu-row{
  display:grid;
  grid-template-columns: minmax(640px, 1fr) 270px 270px 270px;   align-items:start;
  gap:48px;
  padding:60px 4%;
}

.menu-row.photo-xl{
  grid-template-columns: minmax(840px, 1fr) 270px 270px 270px;
}

.menu-row.has-right-figure{
  grid-template-columns: minmax(640px, 1fr) 270px 270px 270px 300px; }

.menu-photo{overflow:hidden; }
.menu-photo img{width:100%; height:auto; display:block}

.right-figure{grid-column: 5}

.menu-columns{display:contents}
.col{display:flex;flex-direction:column;gap:10px}
.col-title{margin:0 0 0px;font-size:20px;font-weight:700;text-transform:lowercase}
.col-title .sub{font-weight:600;color:#a97579}
.col-title.invisible{visibility:hidden;height:0;margin:0}
.menu-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:18px}
.menu-list li{font-size:14px;line-height:1;color:#6b2c33}
.menu-list .num{color:#9c2a33;font-weight:700;margin-right:6px}
.menu-list li{
  display: flex;                align-items: baseline;
  gap: 12px;                    white-space: nowrap;        }

.menu-list li br{
  display: none;
}

@media (max-width: 1200px){
  .menu-row{grid-template-columns:minmax(560px,1fr) 250px 250px 250px}
  .menu-row.photo-xl{grid-template-columns:minmax(720px,1fr) 250px 250px 250px}
  .menu-row.has-right-figure{grid-template-columns:minmax(560px,1fr) 250px 250px 250px 260px}
}
@media (max-width: 960px){
  .menu-row,
  .menu-row.photo-xl,
  .menu-row.has-right-figure{
    grid-template-columns:1fr; gap:24px;
  }
  .col-title.invisible{display:none}
  .right-figure{grid-column:auto}
}
.menu-row.photo-xl{
    padding: 60px 4% 60px 0;     }

.menu-row.photo-xl .menu-photo{
  border-radius: 0;            }


@media (max-width: 960px){
  .menu-row.photo-xl{
    padding: 40px 4%;            }

}
.menu-row > .menu-photo { margin: 0; }              .menu-row.photo-xl > .menu-photo { margin-left: 0; } 
.menu-row.photo-xl { padding-left: 0; }

html, body { overflow-x: hidden; }

.menu-row.photo-narrow{
    grid-template-columns: minmax(640px, 1fr) 370px 270px 270px;
}

.menu-row.photo-narrow .menu-photo{
  width: 460px;             justify-self: start;    }

.menu-row.photo-narrow .menu-photo{
  width: 230px;            justify-self: start;   }
@media (min-width: 1400px){
  .menu-row.photo-narrow .menu-photo{ width: 250px; } }
@media (max-width: 960px){
  .menu-row.photo-narrow .menu-photo{ width: 100%; }  }
.menu-row.photo-narrow .menu-photo{
  width: 230px;            justify-self: start;     margin-left: 280px;     }

@media (max-width: 960px){
  .menu-row.photo-narrow .menu-photo{
    width: 100%;
    margin-left: 0;        }
}

.menu-row.has-right-figure{
    grid-template-columns: minmax(540px, 1fr) 270px 270px minmax(420px, 1fr);
  gap: 64px;                   padding: 60px 4%;
}

.menu-row.has-right-figure .right-figure{ grid-column: 4; }

.menu-row.has-right-figure > .menu-photo:first-of-type{
  width: 560px;                justify-self: start;
}
.menu-row.has-right-figure .right-figure{
  width: 420px;                justify-self: end;
}

.duo-img img {
  opacity: 0;
  transition: opacity 1.6s ease;
}

.duo-img img.loaded {
  opacity: 1;
}


@media (max-width: 1100px){
  .menu-row{grid-template-columns:minmax(360px,1fr) 240px 240px 240px;gap:28px}
}
@media (max-width: 920px){
  .menu-row{grid-template-columns:minmax(320px,1fr) 220px 220px 220px}
}
@media (max-width: 860px){
  .duo-hero{grid-template-columns:1fr}
  .location-grid{grid-template-columns:1fr}
  .menu-row{grid-template-columns:1fr;gap:20px}
  .menu-photo.hero img{width:115%;transform:translateX(-4%)}   .menu-photo.wide.hero img{width:125%;transform:translateX(-5%)}
  .col-title.invisible{display:none}
  .reserv-form{grid-template-columns:1fr}
}

@media (max-width: 1024px){
  .brand img{ height: 48px; }
  .navlinks{ gap: 20px; }
  .navlinks a{ font-size: 13px; }
}

@media (max-width: 768px){
  .navwrap{
    flex-wrap: wrap;               row-gap: 8px;
    padding: 8px 0;
  }

    .brand{
    flex: 1 0 100%;
    justify-content: center;     }

    .navlinks{
    flex: 1 0 100%;
    justify-content: center;       gap: 16px;
    margin-top: 4px;
  }
}

@media (max-width: 420px){
  .brand img{ height: 42px; }           .navlinks{
    gap: 14px;
    overflow-x: auto;                     white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 6px;                }
  .navlinks a{ font-size: 12px; }
}
@media (max-width: 960px){
  .menu-row.photo-narrow{
    grid-template-columns: 1fr;
  }
}

.reserv { padding: 56px 0 88px; background: var(--bg); }

.reserv-card{

  border-radius: 12px;
  background:#fff;
  padding: 28px min(6vw,48px) 40px;
  max-width: 860px;
  margin: 0 auto;
}

.reserv-title{
  margin: 0 0 22px;
  font-size: 36px;
  font-weight: 700;
  color: var(--accent);
  line-height: 1.1;
}

.reserv-form{
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
}

.reserv-form label{
  display: grid;
  gap: 10px;
  font-size: 14px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #a6a6a6;
}

.reserv-form input,
.reserv-form select,
.reserv-form textarea{
  appearance: none;
  border: none;
  border-bottom: 4px solid #2f2f2f;
  padding: 14px 8px 14px 0;
  background: transparent;
  color: var(--text);
  font-family: "EB Garamond", serif;
  font-size: 22px;
  line-height: 1.1;
}

.reserv-form input::placeholder{ color:#8a8a8a; }

.reserv-form input:focus{
  outline: none;
  border-bottom-color: var(--accent);
}
.reserv-form label:focus-within{ color: var(--text); }

.reserv-form input[type="date"]::-webkit-calendar-picker-indicator,
.reserv-form input[type="time"]::-webkit-calendar-picker-indicator{
  filter: grayscale(1) opacity(.75);
}

.reserv-form input[type="number"]::-webkit-outer-spin-button,
.reserv-form input[type="number"]::-webkit-inner-spin-button{ -webkit-appearance: none; margin:0; }


.btn-outline{
  justify-self: stretch;
  padding: 16px 20px;
  border: 3px solid #2f2f2f;
  border-radius: 6px;
  background: transparent;
  color: var(--muted2);
  font-weight: 700;
  font-size: 20px;
  text-transform: lowercase;
  cursor: pointer;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
}



@media (max-width: 640px){
  .reserv-card{ padding: 22px 16px 28px; border-radius: 10px; }
  .reserv-title{ font-size: 28px; margin-bottom: 14px; }
  .reserv-form{ gap: 22px; }
  .reserv-form input{ font-size: 20px; border-bottom-width: 3px; }
  .btn-outline{ font-size: 18px; padding: 14px 16px; border-width: 3px; }
}
@media (min-width: 641px){
  .reserv-card{
    max-width: 550px;              padding: 22px 28px 30px;       border-width: 2px;             border-radius: 10px;
  }

  .reserv-title{
    font-size: 28px;               margin-bottom: 14px;
  }

  .reserv-form{ gap: 18px; }

  .reserv-form label{
    font-size: 12px;               letter-spacing: .12em;
    gap: 8px;
  }

  .reserv-form input,
  .reserv-form select,
  .reserv-form textarea{
    font-size: 18px;               padding: 10px 6px 10px 0;
    border-bottom-width: 3px;    }

  .btn-outline{
    font-size: 18px;               padding: 12px 16px;
    border-width: 2px;
  }
}
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

.btn-outline{

  border-radius:10px;
  background-color:#fff;              cursor:pointer;
}

.btn-wordmark{
    width: clamp(220px, 40vw, 420px);
  height: 64px;                      
    background-image: url("./img/res.png");   background-repeat: no-repeat;
  background-position: center;
  background-size: 70% auto;         
    color: transparent;
}



.reserv-form .btn-wordmark{
  justify-self: center;       width: clamp(160px, 30vw, 220px);
  height: 64px;
  background-image: url("./img/res.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 70% auto;
  color: transparent;       }

@media (max-width: 640px){
  .reserv-form .btn-wordmark{
    width: min(300px, 60%);
    height: 56px;
    background-size: 80% auto;
  }
}
.reserv-form .btn-wordmark{
  border: none;            box-shadow: none;      }
.reserv-form .btn-wordmark{
  transition: transform 160ms ease;     transform-origin: center;
}

.reserv-form .btn-wordmark:hover,
.reserv-form .btn-wordmark:focus-visible{
  transform: scale(1.04);             }

.reserv-form .btn-wordmark:active{
  transform: scale(0.98);              }

@media (prefers-reduced-motion: reduce){
  .reserv-form .btn-wordmark{ transition: none; }
}
.reserv-msg{
  margin-top: 16px;
  padding: 14px 16px;
  border: 2px solid var(--accent);
  border-radius: 8px;
  background: #fff;
  color: var(--text);
  font-weight: 600;
  display: none;
}
.reserv-msg.show{ display: block; animation: fadeIn 180ms ease-out; }
.reserv-msg .tick{
  display:inline-block; margin-right:10px; font-weight:700; color: var(--accent);
}

@keyframes fadeIn{ from{opacity:0; transform: translateY(4px);} to{opacity:1; transform:none;} }
.reserv-msg{
  margin-top:16px; padding:14px 16px; border:2px solid var(--accent);
  border-radius:8px; background:#fff; color:var(--text); font-weight:600;
  display:none;
}
.reserv-msg.show{ display:block; animation: fadeIn .18s ease-out; }
.reserv-msg .icon{ font-weight:800; margin-right:10px; }
.reserv-msg .icon.ok{ color:var(--accent); }

.reserv-msg.error{ border-color:#c0392b; background:#fff6f5; color:#7a1b1b; }
.reserv-msg.error .icon{ color:#c0392b; }

.input-error{ border-bottom-color:#c0392b !important; }

@keyframes fadeIn{ from{opacity:0; transform:translateY(4px)} to{opacity:1; transform:none} }
.location-card{
  align-self: center;          justify-self: center;        max-width: 520px;            width: 100%;
}
.location-card img{
  width: 70%;
  height: auto;
  display: block;
  margin-left: 15%;
}

@media (min-width: 1100px){
  .location-photo img{ max-height: 520px; object-fit: cover; }
}

.location-grid > figure,
.location-photo,
.location-card {
  margin: 0;
}

.location { padding-bottom: 0; }

.location-card img { display: block; }
.menu-list.oysters li{
  display: grid;                              grid-template-columns: auto 1fr auto;       gap: 12px;
  align-items: baseline;
  white-space: normal;                      }

.menu-list.oysters .price{
  justify-self: end;
}

.menu-list.oysters li.sizes{
  font-weight: 700;
}

.menu-list.oysters li br{ display:none; }
.site-header.is-scrolled{
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(4px);
}

:root{
  --ease-soft: cubic-bezier(.22, .61, .36, 1);   --dur-soft:  520ms;
}

.site-header{
  transition:
    background-color .32s var(--ease-soft),
    box-shadow       .32s var(--ease-soft),
    backdrop-filter  .32s var(--ease-soft);
  will-change: background-color, box-shadow, backdrop-filter;
}

.site-header.is-scrolled{
  background-color: rgba(255,255,255,.88);
  backdrop-filter: blur(8px) saturate(125%);
  box-shadow:
    0 6px 28px rgba(0,0,0,.05),
    0 1px 0   rgba(0,0,0,.06);
}

.reveal{
  opacity: 0;
  transform: translateY(6px);             will-change: opacity, transform;
}
.reveal.in{
  opacity: 1;
  transform: none;
  transition:
    opacity   var(--dur-soft) var(--ease-soft),
    transform var(--dur-soft) var(--ease-soft);
  transition-delay: var(--reveal-delay, 0ms); }


html{ scroll-behavior: smooth; }

:target{ scroll-margin-top: calc(80px + 12px); }

@media (prefers-reduced-motion: reduce){
  .site-header{ transition: none; }
  .reveal, .reveal.in{
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

:root{
  --reveal-ease: cubic-bezier(.16,1,.3,1);     --reveal-duration: 520ms;                    --reveal-distance: 10px;                     --reveal-blur: 6px;                        }

.reveal{
  opacity: 0;
  transform: translateY(var(--reveal-distance)) scale(.995);
  filter: blur(var(--reveal-blur));
  transition:
    opacity var(--reveal-duration) var(--reveal-ease) var(--reveal-delay,0ms),
    transform var(--reveal-duration) var(--reveal-ease) var(--reveal-delay,0ms),
    filter calc(var(--reveal-duration) * .8) var(--reveal-ease) var(--reveal-delay,0ms);
  will-change: opacity, transform, filter;
}

.reveal.in{
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
}


.menu-row .menu-photo img.reveal{
  opacity: 0;
  transform: translateY(8px) scale(1.02);
}
.menu-row .menu-photo img.reveal.in{
  opacity: 1;
  transform: none;
  transition:
    opacity   var(--dur-soft) var(--ease-soft),
    transform var(--dur-soft) var(--ease-soft);
  transition-delay: var(--reveal-delay, 0ms);
}

.menu-list li.reveal{ transform: translateY(4px); }
.menu-list li.reveal.in{ transform: none; }

.menu-list li:hover .item{ text-decoration: underline; text-underline-offset: 2px; }

@media (prefers-reduced-motion: reduce){
  .reveal,.reveal.in,
  .menu-row .menu-photo img.reveal,
  .menu-row .menu-photo img.reveal.in{
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}
:root{
  --ease-soft: cubic-bezier(.22,.61,.36,1);
  --dur-soft: 520ms;
}

.site-header{
  transition:
    background var(--dur-soft) var(--ease-soft),
    box-shadow var(--dur-soft) var(--ease-soft),
    backdrop-filter var(--dur-soft) var(--ease-soft);
}
.site-header.is-scrolled{
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(4px);
}

.reveal{
  opacity: 0;
  transform: translateY(8px);
  will-change: opacity, transform;
}
.reveal.in{
  opacity: 1;
  transform: none;
  transition:
    opacity   var(--dur-soft) var(--ease-soft),
    transform var(--dur-soft) var(--ease-soft);
  transition-delay: var(--reveal-delay, 0ms);
}

.reserv .reserv-card.reveal{ transform: translateY(10px) scale(.995); }
.reserv .reserv-card.reveal.in{ transform: none; }
.reserv .reserv-form label.reveal,
.reserv .reserv-form input.reveal,
.reserv .reserv-form button.reveal{
  transform: translateY(6px);
}
.reserv .reserv-form label.reveal.in,
.reserv .reserv-form input.reveal.in,
.reserv .reserv-form button.reveal.in{
  transform: none;
}

:target{ scroll-margin-top: 90px; }

@media (prefers-reduced-motion: reduce){
  .reveal,
  .reveal.in{
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

.shop-grid{
  list-style: none;
  margin: 0 0 18px;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px 36px;
  align-items: start;
}

.product-card{
  text-align: center;
}

.product-media{
  aspect-ratio: 5/7;
  display: grid;
  place-items: center;
  background: #fff;
  overflow: hidden;
  transition: transform 360ms cubic-bezier(.22,.61,.36,1),
              box-shadow 360ms cubic-bezier(.22,.61,.36,1);
}
.product-media img{
  width: 96%;
  height: 96%;
  object-fit: contain;
}

.product-card:hover .product-media{
  transform: translateY(-4px);
  box-shadow: 0 10px 28px rgba(0,0,0,.10);
}

.product-name{
  margin: 12px 0 6px;
  font-weight: 700;
  font-size: 18px;
  color: var(--text);
}
.product-desc{
  margin: 0 0 6px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.25;
}
.product-price{
  font-weight: 800;
  color: var(--accent);
  font-size: 18px;
}
.product-price span{ font-weight: 700; }

.reveal{ opacity:0; transform: translateY(8px); }
.reveal.in{
  opacity:1; transform:none;
  transition: opacity 520ms cubic-bezier(.22,.61,.36,1),
              transform 520ms cubic-bezier(.22,.61,.36,1);
  transition-delay: var(--reveal-delay, 0ms);
}

.site-header{
  transition: background 520ms cubic-bezier(.22,.61,.36,1),
              box-shadow 520ms cubic-bezier(.22,.61,.36,1),
              backdrop-filter 520ms cubic-bezier(.22,.61,.36,1);
}
.site-header.is-scrolled{
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(4px);
}

@media (max-width: 1100px){
  .shop-grid{ grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 860px){
  .shop-grid{ grid-template-columns: repeat(2, 1fr); gap: 22px; }
}
@media (max-width: 540px){
  .shop-grid{ grid-template-columns: 1fr; }
  .product-media img{ width: 78%; height: 78%; }
}
.meddon-regular {
  font-family: "Meddon", cursive;
  font-weight: 400;
  font-style: normal;
}
.closing-image{ padding: 40px 0 80px; }
.closing-image .container{
  display: flex;
  justify-content: center;
}
.closing-media{ margin: 0; }                 .closing-media img{
  display: block;
  width: min(350px, 92vw);                     height: auto;
                     }

.menu-row.reveal{        --reveal-duration: 900ms;  --reveal-distance: 14px; }
.menu-photo img.reveal{  --reveal-duration: 1000ms; --reveal-distance: 16px; }
.menu-list li.reveal{    --reveal-duration: 650ms;  --reveal-distance: 8px; }

@media (prefers-reduced-motion: reduce){
  .reveal{ transition: none; opacity: 1; transform: none; }
}
:root{ --reveal-ease: cubic-bezier(.16,1,.3,1); }

.reveal{
  opacity: 0;
  transform: translateY(var(--reveal-distance, 10px));
  transition:
    opacity   var(--reveal-duration, 800ms) var(--reveal-ease) var(--reveal-delay, 0ms),
    transform var(--reveal-duration, 800ms) var(--reveal-ease) var(--reveal-delay, 0ms);
}

.reveal.in{ opacity: 1; transform: none; }

@media (max-width: 900px){
  .navlinks{ display:none; }   
  .burger{ display:block; }
}

.site-header .navwrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:nowrap;        
}

.site-header .brand{
  display:flex;
  align-items:center;
  flex: 0 1 auto;
  min-width: 0;
}

.site-header .brand img{
  height: 54px;           
  width: auto;
  display:block;
}

@media (max-width: 900px){
  .navlinks{ display:none; }
  .burger{ display:block; }
}
@media (max-width: 900px){
  .site-header .navwrap{ flex-direction: row !important; }
}

:root{
  --header-h: 82px;
  --pad-x: 22px;
  --logo-h: 48px;
  --burger-ink: #b35c5c;
  --menu-bg: #6b2b25;
  --menu-ink: #ffffff;
}

.site-header .navwrap{
  min-height: var(--header-h);
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:nowrap;
  padding: 0 var(--pad-x);
}

.site-header .brand img{
  height: var(--logo-h);
  width:auto;
  display:block;
}

.menu-btn{
  display:none;
  width:44px;
  height:44px;
  border:0;
  padding:10px;
  background:transparent;
  cursor:pointer;
  position:relative;
  overflow: visible; 
}

.menu-btn .bar{
  display:block;
  width:100%;
  height:2px;
  background: var(--burger-ink);
  border-radius:2px;
  transition: transform .22s ease, opacity .18s ease;
}

.menu-btn .b1{ transform: translateY(-8px); }
.menu-btn .b2{ transform: translateY(0); }
.menu-btn .b3{ transform: translateY(8px); }

body.menu-open .menu-btn .b1{ transform: translateY(0) rotate(45deg); }
body.menu-open .menu-btn .b2{ opacity:0; }
body.menu-open .menu-btn .b3{ transform: translateY(0) rotate(-45deg); }

.mobile-menu{
  position:fixed;
  left:0; right:0;
  top: var(--header-h);
  bottom:0;
  background: var(--menu-bg);
  z-index: 9990;

  opacity:0;
  pointer-events:none;
  transform: translateY(-8px);
  transition: opacity .2s ease, transform .2s ease;
}

body.menu-open .mobile-menu{
  opacity:1;
  pointer-events:auto;
  transform: translateY(0);
}

.mobile-links{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  gap:22px;
  padding-top: 140px;
  padding-inline: 24px;
  text-align:center;
}

.mobile-links a{
  color: var(--menu-ink);
  text-decoration:none;
  font-family: "EB Garamond", serif;
  letter-spacing: 1px;
  font-size: 22px;
  line-height: 1.05;
}

body.menu-open{ overflow:hidden; }

@media (max-width: 900px){
  .navlinks{ display:none; }
  .menu-btn{ display:block; }
  .container{ width: 80%; } 
}

body.menu-open{
  overflow:hidden;
}

.site-header .navwrap{
  padding-right: calc(var(--pad-x) + 10px) !important;
}

.menu-btn{
  margin-right: max(10px, env(safe-area-inset-right));
  padding: 0;                
}

.menu-btn .bar{
  width: 26px;                
  margin: 0 auto;            
}

.menu-btn .b1{ transform: translateY(-7px); }
.menu-btn .b3{ transform: translateY(7px); }
.menu-btn{ position: relative; padding:0; }
.menu-btn .bar{
  position:absolute;
  left:50%;
  top:50%;
  width:28px;
  height:2px;
  transform-origin:center;
  margin:0;
}
.menu-btn .b1{ transform: translate(-50%,-50%) translateY(-7px); }
.menu-btn .b2{ transform: translate(-50%,-50%); }
.menu-btn .b3{ transform: translate(-50%,-50%) translateY(7px); }

body.menu-open .menu-btn .b1{ transform: translate(-50%,-50%) rotate(45deg); }
body.menu-open .menu-btn .b2{ opacity:0; }
body.menu-open .menu-btn .b3{ transform: translate(-50%,-50%) rotate(-45deg); }

body.menu-open .mobile-links{
  position: relative;

  width: 100%;
  max-width: none;
  margin: 0;
  padding: 36px 24px 42px;

  background: rgb(107, 43, 37); 
  border-radius: 0;                  

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 22px;
  text-align: center;
}

body.menu-open .mobile-links a{
  background: none;
  border: none;
  padding: 10px 0;
  display: block;
}

body.menu-open .mobile-links a:hover,
body.menu-open .mobile-links a:focus-visible{
  opacity: .9;
  transform: translateY(-1px);
}

.mobile-menu{
  position: fixed;
  inset: 0;               
  z-index: 9990;
  background: rgba(107, 43, 37, 0.75);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);

  opacity: 0;
  pointer-events: none;
  transform: translateY(-8px);
  transition: opacity .2s ease, transform .2s ease;
    top: var(--header-h);                      
  height: calc(100dvh - var(--header-h));    
}

body.menu-open .mobile-menu{
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

body.menu-open .mobile-links{
  height: 107dvh;         
  width: 100%;
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 22px;
  text-align: center;
}

body.menu-open .mobile-links a{
  background: none;
  border: none;
  padding: 10px 0;
  display: block;
}

:root{
  --soft-ease: cubic-bezier(.22,.61,.36,1);
  --soft-dur: 100ms;
}

body{
  opacity: 0;
  transform: translateY(6px);
  transition: opacity var(--soft-dur) var(--soft-ease),
              transform var(--soft-dur) var(--soft-ease);
}

body.is-ready{
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: reduce){
  body{ opacity: 1; transform: none; transition: none; }
}

.reveal{
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 1.2s ease, transform 1.2s ease; /* slower */
}

.reveal.in{
  opacity: 1;
  transform: translateY(0);
}
