:root{--green:#2D7638;--ink:#1a1a1a;--soft:#f6f2ef;--sand:#d8c8bd;--gray:#e0e0e0;--dark:#20252c;--serif:'Crimson Text',serif;--en:'Arvo',serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;color:var(--ink);font-family:'Yu Gothic','YuGothic','Hiragino Kaku Gothic Pro','Meiryo',sans-serif;line-height:1.8;background:#fff}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}.wrap{max-width:1040px;margin:0 auto;padding:0 20px}.wide{max-width:1240px}.main-content{transition:.7s}.side-header{position:fixed;right:0;top:0;width:80px;height:100vh;background:#fff;z-index:20;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:16px 0}.menu-toggle{width:46px;height:46px;border:0;background:var(--green);display:grid;place-content:center;gap:6px;cursor:pointer}.menu-toggle span{display:block;width:28px;height:2px;background:#fff}.side-reserve{font-family:var(--en);writing-mode:vertical-rl}.side-copy{font-family:var(--en);font-size:12px;writing-mode:vertical-rl;white-space:nowrap}.drawer{position:fixed;right:80px;top:0;z-index:19;width:min(640px,calc(100vw - 80px));height:100vh;background:#fff;transform:translateX(120%);transition:.7s;overflow:auto}.menu-open .drawer{transform:none}.menu-open .main-content{transform:translateX(-50px);filter:blur(8px)}.drawer-inner{padding:54px 70px}.drawer-logo,.footer-logo{font:700 34px var(--en);letter-spacing:.1em;display:block;text-align:center;margin-bottom:40px}.drawer ul{display:grid;grid-template-columns:repeat(4,1fr);padding:0;margin:0 0 34px;list-style:none;border-left:1px dotted #ccc;border-top:1px dotted #ccc}.drawer li{border-right:1px dotted #ccc;border-bottom:1px dotted #ccc}.drawer a{display:block;text-align:center;padding:28px 8px}.drawer a:hover{background:var(--green);color:#fff}.drawer b{display:block;font-family:var(--en)}.drawer span{display:block;font-size:12px}.drawer-actions{display:flex;gap:12px;justify-content:center}.drawer-actions a{border:1px solid var(--green);padding:10px 24px}.mobile-reserve{display:none}.hero{height:100vh;min-height:640px;position:relative;overflow:hidden;display:grid;place-items:center;text-align:center;color:#fff}.hero-slider{position:absolute;inset:0}.hero-slider img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;animation:hero 18s infinite}.hero-slider img:nth-child(2){animation-delay:6s}.hero-slider img:nth-child(3){animation-delay:12s}.hero:after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.28)}.hero-curtain{position:absolute;inset:0;background:var(--green);z-index:2;animation:curtain 1.3s .3s forwards cubic-bezier(.7,0,.3,1)}.hero-content{position:relative;z-index:3;opacity:0;animation:fadeIn 1.2s 1.4s forwards}.hero-mark,.mini-logo{width:74px;height:74px;border:2px solid currentColor;border-bottom-color:var(--green);display:grid;place-content:center;border-radius:50%;font:700 38px var(--en);margin:0 auto 24px}.hero-copy{font:600 clamp(42px,8vw,92px)/.95 var(--serif);letter-spacing:.04em;margin:0 0 30px}.hero h1{font:700 28px/1.2 var(--en);letter-spacing:.18em}.hero h1 span{font-size:14px}.scroll-link{position:absolute;left:50%;bottom:-140px;transform:translateX(-50%);font-family:var(--en)}@keyframes hero{0%,100%{opacity:0;transform:scale(1)}6%,32%{opacity:1}38%{opacity:0;transform:scale(1.06)}}@keyframes curtain{to{transform:translateY(-100%)}}@keyframes fadeIn{to{opacity:1}}.section-title{text-align:center;font:400 42px var(--serif);letter-spacing:.1em;margin:0 0 46px}.section-title:after{content:"";display:block;width:20px;height:2px;background:var(--green);margin:12px auto 0}.section-title small{display:block;font:500 14px sans-serif;letter-spacing:.08em}.split{display:grid;grid-template-columns:1.25fr .9fr;align-items:center;gap:0}.greeting{padding:110px 0}.greeting figure{margin:0}.text-panel{background:#fff;margin-left:-80px;padding:44px 48px;position:relative}.lead{font-family:'Yu Mincho','Hiragino Mincho ProN',serif;font-weight:700;font-size:clamp(28px,4vw,38px);line-height:1.7;letter-spacing:.18em}.identity{position:relative;overflow:hidden;color:#fff;padding:120px 0}.identity-bg{position:absolute;inset:0}.identity-bg img{width:100%;height:100%;object-fit:cover;filter:blur(16px);transform:scale(1.06);transition:1.6s}.identity.is-visible .identity-bg img{filter:blur(0);transform:scale(1)}.identity:after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.55)}.identity-text{position:relative;z-index:1;max-width:760px;margin-left:calc((100% - 1040px)/2);padding-right:40px}.identity .section-title{text-align:left}.identity .section-title:after{margin-left:0}.brand-note{margin-top:-56px;position:relative;z-index:2}.note-box{background:#fff;display:grid;grid-template-columns:140px 1fr;gap:40px;align-items:center;padding:54px 76px;box-shadow:0 18px 45px rgba(0,0,0,.08)}.note-logo{font:700 76px var(--en);color:var(--green);text-align:center}.style,.instagram,.blog-preview{padding:86px 0}.style-grid,.gallery-grid,.instagram-grid{list-style:none;padding:0;margin:0;display:grid;gap:26px}.style-grid{grid-template-columns:repeat(4,1fr)}.style-grid li{position:relative;overflow:hidden;background:#eee}.style-grid span{position:absolute;left:0;right:0;bottom:0;background:rgba(0,0,0,.58);color:#fff;padding:8px 10px;text-align:center;font-size:13px}.line-button{display:inline-block;border:1px solid var(--ink);padding:10px 28px;font-family:var(--en);position:relative;transition:.25s}.line-button:hover{color:#fff;background:var(--green);border-color:var(--green)}.line-button.light{color:#fff;border-color:#fff}.center{text-align:center;margin-top:36px}.menu-section{padding:50px 0 150px;position:relative}.menu-layout{position:relative}.menu-layout figure{margin:0 0 0 110px}.menu-box{position:absolute;left:20px;top:34%;width:560px;background:#111;color:#fff;padding:48px 42px}.menu-box .section-title{color:#fff}.menu-list{display:grid;grid-template-columns:repeat(2,1fr);gap:6px 24px;padding:0;margin:24px 0 28px;list-style:none;font-family:var(--en)}.menu-list li:before{content:"";display:inline-block;width:14px;height:2px;background:var(--green);vertical-align:middle;margin-right:10px}.gallery{padding:80px 0}.gallery-grid{grid-template-columns:repeat(3,1fr)}.gallery button{border:0;padding:0;position:relative;width:100%;cursor:pointer;background:#000;overflow:hidden}.gallery img{filter:grayscale(1);transition:.35s}.gallery button:hover img{filter:grayscale(0);transform:scale(1.04)}.gallery span{position:absolute;inset:0;color:#fff;display:grid;place-content:center;font:20px var(--en);text-shadow:0 2px 12px #000}.instagram-grid{grid-template-columns:repeat(5,1fr)}.blog-grid,.blog-list{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.blog-card a{display:block;padding:15px;transition:.25s}.blog-card a:hover{background:#dedede}.blog-card time{font-weight:700;font-size:12px}.blog-card h3{font-size:16px;line-height:1.5;margin:.3em 0 .8em}.blog-card p{font-size:13px;border-top:1px solid currentColor;padding-top:12px}.blog-card span{font-family:var(--serif);display:block;text-align:right}.calendar{background:var(--gray);padding:80px 0}.calendar-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:34px}.month h3{text-align:center}.month table{width:100%;table-layout:fixed;border-collapse:collapse;font-family:var(--en);font-weight:700}.month th,.month td{text-align:center;padding:8px 0}.holiday span,.holiday-note dt{background:var(--green);color:#fff;border-radius:50%;width:30px;height:30px;display:inline-grid;place-content:center}.holiday-note{display:flex;align-items:center;gap:10px;font-weight:700}.notes{display:grid;grid-template-columns:repeat(2,1fr);gap:40px;border-top:1px dotted #999;margin-top:28px;padding-top:28px}.access{padding:80px 0}.access-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center}.map-card{height:360px;background:linear-gradient(135deg,#d8c8bd,#f6f2ef 45%,#2D7638);position:relative;overflow:hidden}.map-card:before{content:"";position:absolute;inset:45px;background:repeating-linear-gradient(45deg,transparent 0 38px,rgba(255,255,255,.6) 39px 43px),repeating-linear-gradient(-35deg,transparent 0 54px,rgba(0,0,0,.12) 55px 59px)}.map-card span{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:#fff;padding:18px 28px;font-family:var(--en)}.shop-name{font:700 22px var(--en);letter-spacing:.08em}.tel{font:700 28px var(--en);color:var(--green)}.reservation{padding:60px 0 90px}.reserve-box{text-align:center;background:var(--soft);padding:60px}.reserve-actions{display:flex;gap:18px;justify-content:center}.reserve-actions a,.recruit-form button{background:var(--green);color:#fff;padding:14px 34px;border:0}.footer{position:relative;overflow:hidden;color:#fff;text-align:center;padding:70px 20px}.footer-bg{position:absolute;inset:0;background:linear-gradient(rgba(0,0,0,.62),rgba(0,0,0,.62)),url('../img/photo-storefront.png') center/cover}.footer-inner{position:relative}.footer-logo{margin-bottom:12px}.footer-links{display:flex;gap:20px;justify-content:center;margin:24px 0}.reveal{opacity:0;transform:translateY(50px);transition:1s}.reveal.is-visible{opacity:1;transform:none}.lightbox[hidden]{display:none}.lightbox{position:fixed;inset:0;z-index:60;background:rgba(0,0,0,.88);display:grid;place-content:center;padding:30px}.lightbox img{max-height:86vh}.lightbox button{position:absolute;right:24px;top:18px;background:none;border:0;color:#fff;font-size:42px}.dark-page{background:var(--dark);color:#fff;min-height:100vh}.post-hero,.recruit-head{text-align:center;padding:90px 20px 55px}.post-layout{display:grid;grid-template-columns:1fr 250px;gap:56px;padding-bottom:80px}.blog-list{grid-template-columns:1fr;gap:28px}.blog-list .blog-card a{display:grid;grid-template-columns:230px 1fr;gap:22px;color:#fff}.blog-list .blog-card a:hover{background:rgba(255,255,255,.08)}.sidebar{border-top:1px solid #fff}.sidebar a{display:block;border-bottom:1px dotted rgba(255,255,255,.5);padding:12px 0}.pager a{display:inline-block;padding:8px 12px;margin-right:8px;background:#777}.pager .current{background:var(--green)}.article{max-width:800px;padding:80px 20px}.article h1{font-size:36px;line-height:1.35}.article-img{margin:30px 0}.wysiwyg h2{margin-top:2em}.post-links{display:flex;justify-content:space-between;border-top:1px solid #fff;margin-top:40px;padding-top:22px}.recruit-visual{width:100%;max-height:520px;object-fit:cover}.recruit-message{text-align:center;padding:80px 20px;font-weight:700;letter-spacing:.1em}.recruit-form{background:var(--gray);padding:70px 0}.recruit-form form{max-width:760px;margin:0 auto}.recruit-form label{display:block;margin-bottom:18px;font-weight:700}.recruit-form input,.recruit-form select,.recruit-form textarea{width:100%;border:1px solid #ccc;background:#fff;padding:14px;margin-top:6px}.privacy{background:#fff;height:180px;overflow:auto;padding:20px;margin:28px 0}.check{font-weight:400!important}.check input{width:auto}.complete-page{min-height:70vh;display:grid;place-content:center;text-align:center}.complete-box{background:var(--soft);padding:80px 40px}@media (max-width:900px){.side-header{display:flex;width:54px;height:54px;background:transparent;padding:4px;justify-content:flex-start}.side-header .side-reserve,.side-header .side-copy{display:none}.menu-toggle{width:46px;height:46px}.mobile-reserve{display:block;position:fixed;left:0;bottom:0;z-index:30;width:100%;background:var(--green);color:#fff;text-align:center;padding:12px;font:20px var(--en)}.drawer{right:0;width:290px}.drawer-inner{padding:50px 28px}.drawer ul{grid-template-columns:repeat(2,1fr)}.drawer span{display:none}.main-content{margin-right:0}.hero{height:140vw;min-height:560px}.split,.access-layout,.post-layout{grid-template-columns:1fr}.text-panel{margin:-45px 20px 0;padding:28px}.identity-text{margin:0 auto}.note-box{grid-template-columns:1fr;padding:36px 24px}.style-grid,.gallery-grid{grid-template-columns:repeat(2,1fr)}.instagram-grid{grid-template-columns:repeat(3,1fr)}.blog-grid{grid-template-columns:1fr}.menu-section{padding-bottom:40px}.menu-layout figure{margin:0 0 0 30px}.menu-box{position:relative;left:auto;top:auto;width:auto;margin:-45px 20px 0;padding:30px 24px}.calendar-grid,.notes{grid-template-columns:1fr}.blog-list .blog-card a{grid-template-columns:1fr}.section-title{font-size:36px}.reserve-box{padding:40px 20px}.reserve-actions{flex-direction:column}.footer{padding-bottom:90px}}
.style-grid img,
.gallery-grid img,
.instagram-grid img,
.blog-card img,
.recruit-visual {
  object-fit: cover;
}
.style-grid img,
.instagram-grid img {
  aspect-ratio: 1 / 1;
  width: 100%;
}
.gallery-grid img {
  aspect-ratio: 4 / 3;
  width: 100%;
}
.blog-card img {
  aspect-ratio: 5 / 3;
  width: 100%;
}
.hero-slider img {
  object-position: center;
}


/* LP layout */
.lp-page {
  background: #fff;
}
.lp-hero {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  display: flex;
  align-items: center;
  color: #fff;
  padding: 90px 120px 90px 80px;
}
.lp-hero-shade {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(0,0,0,.68), rgba(0,0,0,.28) 58%, rgba(0,0,0,.1));
  z-index: 1;
}
.lp-hero-content {
  position: relative;
  z-index: 2;
  max-width: 760px;
}
.lp-eyebrow,
.lp-kicker {
  font-family: var(--en);
  letter-spacing: .14em;
  color: var(--green);
  font-size: 13px;
  font-weight: 700;
}
.lp-hero .lp-eyebrow {
  color: #fff;
  opacity: .86;
}
.lp-hero h1 {
  font-family: 'Yu Mincho','Hiragino Mincho ProN',serif;
  font-size: clamp(42px, 6.5vw, 82px);
  line-height: 1.2;
  letter-spacing: .08em;
  margin: 18px 0 24px;
}
.lp-hero-lead {
  max-width: 620px;
  font-size: 17px;
}
.lp-actions {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 34px;
}
.lp-actions a {
  display: inline-flex;
  justify-content: center;
  min-width: 190px;
  border: 1px solid #fff;
  color: #fff;
  padding: 13px 28px;
  font-weight: 700;
  transition: .25s;
}
.lp-actions a:first-child,
.lp-actions.dark a:first-child {
  background: var(--green);
  border-color: var(--green);
}
.lp-actions a:hover {
  transform: translateY(-2px);
  opacity: .86;
}
.lp-section {
  padding: 92px 0;
}
.lp-section h2,
.lp-reservation h2 {
  font-family: 'Yu Mincho','Hiragino Mincho ProN',serif;
  font-size: clamp(30px, 4vw, 48px);
  line-height: 1.55;
  letter-spacing: .08em;
  margin: 8px 0 34px;
}
.problem-grid,
.benefit-grid,
.price-grid,
.voice-grid,
.lp-style-grid {
  display: grid;
  gap: 22px;
}
.problem-grid {
  grid-template-columns: repeat(4, 1fr);
  list-style: none;
  padding: 0;
  margin: 42px 0 0;
}
.problem-grid li {
  background: var(--soft);
  border-left: 4px solid var(--green);
  padding: 24px 22px;
  font-weight: 700;
}
.lp-concept {
  background: var(--soft);
}
.lp-split {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 60px;
  align-items: center;
}
.lp-split figure {
  margin: 0;
}
.lp-split img,
.lp-style-grid img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}
.check-list {
  padding: 0;
  margin: 28px 0 0;
  list-style: none;
}
.check-list li {
  border-top: 1px dotted #aaa;
  padding: 13px 0;
}
.check-list li:before {
  content: "";
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--green);
  margin-right: 10px;
}
.benefit-grid {
  grid-template-columns: repeat(3, 1fr);
}
.benefit-grid article,
.price-grid article,
.voice-grid blockquote {
  background: #fff;
  border: 1px solid #dedede;
  padding: 30px;
}
.benefit-grid span {
  font-family: var(--en);
  color: var(--green);
  font-size: 34px;
}
.benefit-grid h3,
.price-grid h3 {
  margin: 8px 0 12px;
}
.lp-style {
  background: #171b19;
  color: #fff;
}
.lp-style .lp-kicker {
  color: #98caa1;
}
.lp-style-grid {
  grid-template-columns: repeat(3, 1fr);
  padding: 0;
  margin: 0;
  list-style: none;
}
.lp-style-grid li {
  position: relative;
  overflow: hidden;
  background: #000;
}
.lp-style-grid span {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0,0,0,.58);
  padding: 14px;
  text-align: center;
  font-weight: 700;
}
.lp-menu {
  background: var(--soft);
}
.price-grid {
  grid-template-columns: repeat(4, 1fr);
}
.price-grid article {
  position: relative;
  min-height: 250px;
}
.price-grid .featured {
  border-color: var(--green);
  box-shadow: 0 18px 40px rgba(45,118,56,.14);
}
.badge {
  position: absolute;
  right: 18px;
  top: -16px;
  background: var(--green);
  color: #fff;
  padding: 4px 14px;
  font-weight: 700;
}
.price-grid strong {
  display: block;
  font-family: var(--en);
  color: var(--green);
  font-size: 28px;
  margin-top: 22px;
}
.flow-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.flow-list li {
  border-top: 2px solid var(--green);
  padding: 22px 12px 0;
}
.flow-list span {
  font: 700 38px var(--en);
  color: var(--green);
}
.lp-voice {
  background: var(--dark);
  color: #fff;
}
.lp-voice .lp-kicker {
  color: #98caa1;
}
.voice-grid {
  grid-template-columns: repeat(2, 1fr);
}
.voice-grid blockquote {
  margin: 0;
  color: var(--ink);
  font-weight: 700;
}
.voice-grid cite {
  display: block;
  margin-top: 16px;
  color: var(--green);
  font-style: normal;
}
.lp-faq details {
  border-top: 1px solid #ccc;
  padding: 18px 0;
}
.lp-faq details:last-child {
  border-bottom: 1px solid #ccc;
}
.lp-faq summary {
  cursor: pointer;
  font-weight: 700;
}
.lp-reservation {
  text-align: center;
  background: linear-gradient(rgba(0,0,0,.62),rgba(0,0,0,.62)), url('../img/photo-storefront.png') center / cover;
  color: #fff;
  padding: 110px 0;
}
.lp-reservation .lp-kicker {
  color: #fff;
}
.lp-actions.dark {
  justify-content: center;
}
.lp-actions.dark a {
  border-color: #fff;
}

@media (max-width: 900px) {
  .lp-hero {
    min-height: 100svh;
    padding: 78px 22px 96px;
  }
  .lp-hero h1 {
    font-size: 38px;
  }
  .lp-section {
    padding: 62px 0;
  }
  .problem-grid,
  .benefit-grid,
  .price-grid,
  .flow-list,
  .voice-grid,
  .lp-style-grid,
  .lp-split {
    grid-template-columns: 1fr;
  }
  .problem-grid {
    gap: 12px;
  }
  .price-grid article {
    min-height: auto;
  }
  .sp-br {
    display: none;
  }
}


.floating-reserve {
  position: fixed;
  left: 50%;
  bottom: 22px;
  z-index: 80;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 280px;
  padding: 15px 42px;
  background: var(--green);
  color: #fff;
  border: 1px solid rgba(255,255,255,.7);
  box-shadow: 0 18px 38px rgba(0,0,0,.22);
  font-weight: 700;
  letter-spacing: .08em;
  transition: .25s;
}
.floating-reserve:after {
  content: "";
  width: 9px;
  height: 9px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
  margin-left: 16px;
}
.floating-reserve:hover {
  text-decoration: none;
  transform: translateX(-50%) translateY(-2px);
  box-shadow: 0 22px 42px rgba(0,0,0,.28);
}
body {
  padding-bottom: 76px;
}

@media (max-width: 900px) {
  .mobile-reserve {
    display: none;
  }
  .floating-reserve {
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    min-width: 0;
    transform: none;
    padding: 14px 18px;
    border-left: 0;
    border-right: 0;
    border-bottom: 0;
    box-shadow: 0 -10px 30px rgba(0,0,0,.2);
    font-size: 16px;
  }
  .floating-reserve:hover {
    transform: none;
  }
}


/* Separate the footer from the reservation photo block */
.footer-bg {
  background:
    linear-gradient(rgba(0,0,0,.58), rgba(0,0,0,.58)),
    url('../img/photo-footer-person.png') center 38% / cover !important;
}


/* Calendar and access restored for LP */
.lp-calendar {
  background: var(--soft);
}
.lp-calendar-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
}
.lp-calendar-grid article {
  background: #fff;
  padding: 26px;
  border: 1px solid #ddd;
}
.lp-calendar-grid h3 {
  text-align: center;
  font-family: var(--en);
  margin: 0 0 18px;
}
.lp-calendar-grid table {
  width: 100%;
  table-layout: fixed;
  border-collapse: collapse;
  font-family: var(--en);
  font-weight: 700;
}
.lp-calendar-grid th,
.lp-calendar-grid td {
  text-align: center;
  padding: 8px 0;
}
.lp-calendar-grid .off {
  color: #fff;
  background: none;
}
.lp-calendar-grid .off:before {
  content: "";
  display: inline-block;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--green);
  vertical-align: middle;
  margin-right: -30px;
}
.calendar-note {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  margin-top: 22px;
}
.calendar-note span {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--green);
}
.lp-access-grid {
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 58px;
  align-items: center;
}
.lp-map {
  min-height: 380px;
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(216,200,189,.88), rgba(246,242,239,.82) 44%, rgba(45,118,56,.86)),
    url('../img/photo-styling-area.png') center / cover;
}
.lp-map:before {
  content: "";
  position: absolute;
  inset: 42px;
  background:
    repeating-linear-gradient(42deg, transparent 0 42px, rgba(255,255,255,.68) 43px 48px),
    repeating-linear-gradient(-36deg, transparent 0 56px, rgba(0,0,0,.14) 57px 62px);
}
.lp-map span {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background: #fff;
  color: var(--ink);
  padding: 18px 28px;
  text-align: center;
  font-family: var(--en);
  font-weight: 700;
  letter-spacing: .08em;
}
.access-name {
  font-family: var(--en);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: .08em;
}
.access-tel {
  font-family: var(--en);
  font-size: 28px;
  color: var(--green);
  font-weight: 700;
}
.access-actions a:last-child {
  color: var(--ink);
  border-color: var(--ink);
}

@media (max-width: 900px) {
  .lp-calendar-grid,
  .lp-access-grid {
    grid-template-columns: 1fr;
  }
  .lp-calendar-grid article {
    padding: 18px 14px;
  }
  .lp-map {
    min-height: 300px;
  }
}


/* Store photo gallery */
.lp-store-gallery {
  background: #fff;
}
.store-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  padding: 0;
  margin: 0;
  list-style: none;
}
.store-gallery-grid li {
  position: relative;
  overflow: hidden;
  background: #000;
}
.store-gallery-grid img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  filter: grayscale(.25);
  transition: .35s;
}
.store-gallery-grid li:hover img {
  filter: grayscale(0);
  transform: scale(1.04);
}
.store-gallery-grid span {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 15px 16px;
  background: linear-gradient(transparent, rgba(0,0,0,.72));
  color: #fff;
  font-family: var(--en);
  text-align: center;
}

@media (max-width: 900px) {
  .store-gallery-grid {
    grid-template-columns: 1fr;
  }
}


/* Keep the hero catch copy to two intentional lines on desktop */
.lp-hero-content {
  max-width: 980px;
}
.lp-hero h1 {
  font-size: clamp(42px, 5.2vw, 68px);
}
.lp-hero h1 .nowrap {
  white-space: nowrap;
}

@media (max-width: 900px) {
  .lp-hero h1 .nowrap {
    white-space: normal;
  }
}


/* Reservation page */
.reservation-page {
  background: var(--soft);
}
.reservation-hero {
  color: #fff;
  text-align: center;
  padding: 95px 20px 70px;
  background:
    linear-gradient(rgba(0,0,0,.58), rgba(0,0,0,.58)),
    url('../img/photo-storefront.png') center / cover;
}
.reservation-hero h1 {
  font-family: var(--serif);
  font-size: clamp(44px, 6vw, 72px);
  letter-spacing: .12em;
  margin: 10px 0 12px;
}
.reservation-form-section {
  padding: 70px 0 95px;
}
.reservation-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 44px;
  align-items: start;
}
.reservation-form,
.reservation-card {
  background: #fff;
  border: 1px solid #ddd;
  padding: 34px;
}
.reservation-form h2,
.reservation-card h2 {
  margin: 0 0 24px;
  font-family: 'Yu Mincho','Hiragino Mincho ProN',serif;
  letter-spacing: .08em;
}
.reservation-form label {
  display: block;
  margin-bottom: 18px;
  font-weight: 700;
}
.reservation-form input,
.reservation-form select,
.reservation-form textarea {
  display: block;
  width: 100%;
  margin-top: 7px;
  padding: 14px 12px;
  border: 1px solid #cfcfcf;
  background: #fff;
  font: inherit;
}
.reservation-form textarea {
  resize: vertical;
}
.reservation-form .form-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0 18px;
}
.reservation-form .check {
  font-weight: 500;
}
.reservation-form .check input {
  display: inline-block;
  width: auto;
  margin: 0 8px 0 0;
}
.reservation-form button {
  width: 100%;
  border: 0;
  background: var(--green);
  color: #fff;
  padding: 16px;
  font-weight: 700;
  letter-spacing: .08em;
  cursor: pointer;
}
.reservation-side {
  position: sticky;
  top: 24px;
}
.reservation-side img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}
.reservation-card {
  border-top: 0;
}
.reservation-card dl {
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: 8px 14px;
  border-top: 1px dotted #aaa;
  padding-top: 18px;
}
.reservation-card dt {
  font-weight: 700;
}

@media (max-width: 900px) {
  .reservation-layout,
  .reservation-form .form-grid {
    grid-template-columns: 1fr;
  }
  .reservation-form,
  .reservation-card {
    padding: 24px 20px;
  }
  .reservation-side {
    position: static;
  }
}


/* Return home button for sub pages */
.home-return-button {
  position: fixed;
  left: 22px;
  bottom: 22px;
  z-index: 90;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 22px;
  background: #fff;
  color: var(--ink);
  border: 1px solid var(--green);
  box-shadow: 0 14px 32px rgba(0,0,0,.16);
  font-weight: 700;
  letter-spacing: .06em;
}
.home-return-button:before {
  content: "";
  width: 9px;
  height: 9px;
  border-left: 2px solid var(--green);
  border-bottom: 2px solid var(--green);
  transform: rotate(45deg);
  margin-right: 10px;
}
.home-return-button:hover {
  background: var(--green);
  color: #fff;
  text-decoration: none;
}
.home-return-button:hover:before {
  border-color: #fff;
}

@media (max-width: 900px) {
  .home-return-button {
    left: 12px;
    bottom: 66px;
    padding: 10px 14px;
    font-size: 13px;
  }
}
