* {box-sizing: border-box; }
body {
  margin: 0;
  font-family: monospace;
  line-height: 1.6;
  color: #402924;
  background: #eef5ff;
}

.interior {text-align: center;}
img {max-width: 100%; height: auto; display: block; text-align:center;}
a {text-decoration: none; color: #402924; }
h1, h2, h3 { margin: 0.4em 0; }

.header {
  width: 100%;
  background: #eef5ff;
  border-bottom: 2px solid #7C9DD2;
  text-align: center;}

.header-image {align-items: center;
width: 100%;}

.tagline {margin-top: -4px; color: #402924; 
  text-align: center;}

.site-header{width: 100%;
  background: #eef5ff;
  border-bottom: 2px solid #7C9DD2;
  text-align: center;}


.main-nav {margin: 8px 0 12px; }
.main-nav a {
  display: inline-block; margin: 0 10px; padding: 6px 10px;
  border-radius: 999px; background: #fff; border: 1px solid #7C9DD2;
  text-align: center;}
.main-nav a:hover { background: #d1e4ff; }


#allcontent {
  font-family: 'Courier New', Courier, monospace;
  width:1200px;
  min-width: 700px;
  max-width: 1000px;
  margin:auto;
  background: #eef5ff;
  padding: 38px;
  border-radius: 16px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.08);
  margin-top: 40px;}

.vibe{border-color: white;
    border-radius: 5px;
    border-width: 1px;
    border-style: dashed;
    background-color: #ffeda8;
    padding: 25px;
    padding-left: 30px;
    margin: 10px;
    margin-right: 400px;
    background-repeat: no-repeat;
    background-position: top left;}


.float-right {float: right; margin: 0 0 16px 16px; }
.float-left  {float: left;  margin: 0 16px 16px 0; }
.clearfix::after {content: ""; display: block; clear: both; }


.intro-img {width: 350px; border-radius: 10px; }
.story-img {width: 290px; border-radius: 10px;}
.promo {
  width: 280px; background: #eef5ff; border: 1px solid #7C9DD2;
  padding-left: 30px;
  border-radius: 10px; padding: 16px;}
.price { font-weight: 700; font-size: 19px; }
.card {
  background: #e6efff; border: 1px solid #7C9DD2;
  border-radius: 10px; padding: 16px;}
.caption { font-size: 16px; color: #7a3e00; }

.menu-list { list-style: none; padding: 0; margin: 0 0 16px; }
.menu-list li {
  display: flex; justify-content: space-between; padding: 6px 0;
  border-bottom: 1px dashed #e6efff;}
.menu-list li span:last-child { font-weight: 600; }

.responsive {
  width: 35%;      
  height: auto;         
  margin: 0 20px 10px 0;  
  float: left;
  display: block; }

.menu-list li{
  display: block;
  overflow: hodden;
  padding: 10px 0 20px 0;
  border-bottom: 1px dashed #e6efff;}

.menu-list li span:first-of-type{
  display:block;}
.menu-list li span:last-child{
  font-weight: 600;
  float: right;
  margin-left: 10px;}

.menu-item img {
  transition: transform .3s ease, filter .3s ease;}

.menu-item:hover img {
  transform: scale(1.05);
  filter: brightness(1.1);}

.drink-alcohol-separator {
    display: block !important;
    text-align: center;
    font-weight: bold;
    color: #7C9DD2; 
    margin: 15px 0 5px 0;
    border-bottom: none !important; }

.grid-2 { display: grid; grid-template-columns: 1.2fr 1fr; gap: 16px; }

.map-placeholder {max-width:400px;}
.menu-item img {transition: transform .3s ease, filter .3s ease;}

.menu-item:hover img {
  transform: scale(1.05);
  filter: brightness(1.1);}

.reveal {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .6s ease, transform .6s ease;
  will-change: opacity, transform;}

.reveal.in-view {opacity: 1;
  transform: translateY(0);}
  body {background-color: #ffffff;}

.card {
  background-color: #c7d8f6;
  border: 1px solid #c7d8f6;
  box-shadow: 0 8px 20px rgba(0,0,0,0.05);}

  img:hover {
  filter: brightness(1.1) saturate(1.1);
  transition: filter .3s;}

  header {
  background: linear-gradient(90deg, #f8fbff, #e7efff);
  padding: 20px;}

  nav a {
  padding: 8px 18px;
  border-radius: 12px;
  transition: background 0.3s, color 0.3s;}

  nav a:hover {
  background: #7C9DD2;
  color: white;}

