main {
  overflow: hidden;
}

.nav-fixed {
  opacity: 0;
  visibility: hidden;
}
.nav-fixed.fixed {
  opacity: 1;
  visibility: visible;
}
.nav-fixed.fixed + .group-btn-fixed {
  opacity: 1;
  visibility: visible;
}

.group-btn-fixed {
  opacity: 0;
  visibility: hidden;
}

@media screen and (min-width: 768px) {
  #footer .left {
    padding-top: 68px;
  }
  #footer .right {
    padding-top: 0;
  }
}

#header {
  background: url("../img/shared/bg2.jpg");
}
#header .logo {
  position: absolute;
  z-index: 3;
  top: 58px;
  left: 50%;
  transform: translateX(-50%);
  width: 44.5px;
}
@media screen and (min-width: 768px) {
  #header {
    position: relative;
    color: var(--color3);
  }
  #header h1 {
    height: 380px;
  }
  #header .group-nav {
    position: absolute;
    z-index: 3;
    left: 40px;
    top: 50px;
    display: flex;
    gap: 0 24px;
  }
  #header .group-nav .nav {
    display: flex;
    gap: 0 8px;
    height: 150px;
  }
  #header .group-nav .nav li a {
    display: block;
    text-decoration: none;
    position: relative;
    font-size: 17px;
    line-height: 2;
    width: 34px;
    letter-spacing: 0.1em;
    cursor: pointer;
  }
  #header .group-nav .nav li a::before {
    content: "";
    position: absolute;
    top: -20px;
    width: 3px;
    height: 14px;
    background: var(--color3);
    opacity: 0;
    visibility: hidden;
    left: 15px;
  }
  #header .group-nav .nav li a.active::before, #header .group-nav .nav li a:hover::before {
    opacity: 1;
    visibility: visible;
  }
  #header .group-nav .insta {
    line-height: 0;
  }
  #header .group-tel-btn {
    position: absolute;
    z-index: 3;
    right: 38px;
    top: 46px;
    text-align: right;
  }
  #header .group-tel-btn .tel .sub-tel {
    display: inline-block;
    vertical-align: super;
    margin: 0 3px 0 0;
    font-size: 13px;
  }
  #header .group-tel-btn .tel span {
    display: inline-flex;
    font-size: 25px;
  }
  #header .group-tel-btn .tel span::before {
    background-image: url("../img/shared/icon_tel.png");
    width: 17px;
    height: 18px;
  }
  #header .group-tel-btn .flex {
    margin: 12px 0 0;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 18px;
  }
  #header .group-tel-btn .flex .map {
    line-height: 1.5;
  }
  #header .group-tel-btn .flex .map a {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 15px;
    letter-spacing: 0.08em;
  }
  #header .group-tel-btn .flex .btn-web {
    width: 230px;
  }
  #header .group-tel-btn .flex .btn-web a {
    padding: 8px 0;
  }
  #header .logo {
    top: 115px;
    width: 70px;
  }
}

#key {
  padding: 292px var(--wrapPadding) 0;
  position: relative;
}
#key .bg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
}
@media screen and (min-width: 768px) {
  #key {
    padding: 324px 175px 0;
  }
  #key .bg {
    height: 665px;
  }
  #key h1 {
    top: 275px;
  }
  #key .key-slide .img {
    height: 730px;
  }
}

#rss {
  margin: 7vw var(--wrapPadding) 0;
  position: relative;
}
#rss h2 {
  font-size: 5.2vw;
  letter-spacing: 0.1em;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  #rss h2 {
    position: absolute;
    left: 0;
    top: -1vw;
    color: #282726;
  }
}
@media screen and (max-width: 767px) {
  #rss #feed dl {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
    align-items: flex-start;
  }
}
@media screen and (max-width: 767px) {
  #rss #feed dl dt {
    width: 140px;
  }
}
#rss #feed dl dt .date {
  display: block;
  line-height: 1;
  font-size: 12px;
  text-align: right;
  margin: 0 0 16px;
}
@media screen and (max-width: 767px) {
  #rss #feed dl dt .date {
    color: #282726;
  }
}
#rss #feed dl dt a {
  display: block;
}
#rss #feed dl dt a span {
  display: block;
  width: 100% !important;
  height: 106px !important;
  background: url("../img/index/rss_img.jpg") no-repeat center/cover;
}
#rss #feed dl dd {
  margin: 34px 0 0;
}
@media screen and (max-width: 767px) {
  #rss #feed dl dd {
    width: 150px;
  }
}
#rss #feed dl dd a {
  display: block;
  font-size: 13px;
  line-height: 18px;
  letter-spacing: 0;
  cursor: pointer;
  color: var(--color4);
}
#rss .btn-more {
  position: absolute;
  bottom: 5px;
  right: calc(50% + 10px);
}
#rss .btn-more a {
  display: flex;
  align-items: center;
  gap: 7px;
  justify-content: center;
  font-size: 13px;
  line-height: 1;
  color: var(--color4);
}
@media screen and (max-width: 767px) {
  #rss .btn-more a::after {
    content: "";
    background: url("../img/index/rss_arrow_sp.png") no-repeat bottom center/100% auto;
    width: 25px;
    height: 5.5px;
  }
}
#rss .btn-more a span {
  letter-spacing: 0.1em;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  #rss {
    position: absolute;
    right: 0;
    top: 496px;
    width: 130px;
    margin: 0;
  }
  #rss h2 {
    font-size: 18px;
    height: 90px;
    width: 27px;
    margin: 0 auto;
  }
  #rss #feed dl dt .date {
    font-size: 11px;
    text-align: center;
  }
  #rss #feed dl dt a span {
    height: 99px !important;
  }
  #rss #feed dl dt a:hover {
    opacity: 0.8;
  }
  #rss #feed dl dd {
    margin: 19px 0 0;
    height: 210px;
  }
  #rss #feed dl dd a {
    font-size: 14px;
    line-height: 22px;
    margin: 0 auto;
    letter-spacing: 0.06em;
  }
  #rss .btn-more {
    position: absolute;
    bottom: 0;
    left: 3px;
    right: auto;
  }
  #rss .btn-more a {
    font-size: 13px;
  }
  #rss .btn-more a::before {
    content: "";
    background: url("../img/index/rss_arrow.png") no-repeat bottom center/100% auto;
    width: 6px;
    height: 27px;
  }
}

#read {
  background: url("../img/shared/bg2.jpg");
  position: relative;
  overflow: hidden;
  padding: 38vw 0 58.4vw;
}
#read .deco {
  position: absolute;
  width: 56.4vw;
  right: calc(50% - 9vw);
  bottom: 8.5vw;
}
#read .deco2 {
  position: absolute;
  width: 47.8vw;
  left: calc(50% - 1.3vw);
  top: 195vw;
}
#read .ttl1 {
  position: absolute;
  z-index: 3;
  color: var(--color4);
  top: 18.4vw;
  left: calc(50% + 20.8vw);
  font-size: 6.67vw;
  line-height: 1.2;
  letter-spacing: 0.1em;
}
#read .ttl1 .fs {
  font-size: 16.4vw;
  position: relative;
}
#read .ttl1 .fs:nth-of-type(1) {
  left: -1vw;
  letter-spacing: -0.06em;
}
#read .ttl1 .fs:nth-of-type(2) {
  left: 2.27vw;
  letter-spacing: -0.06em;
}
#read .ttl1 .fs:nth-of-type(3) {
  left: -1.3vw;
  letter-spacing: 0.02em;
}
#read .ttl1 .pt {
  display: inline-block;
  padding-top: 41.3vw;
}
#read .ttl2 {
  position: absolute;
  z-index: 3;
  top: 66.67vw;
  right: calc(50% + 26.67vw);
  color: var(--color4);
  font-size: 6.67vw;
  line-height: 1.1;
  letter-spacing: 0.12em;
}
#read .ttl2 .fs {
  font-size: 17.73vw;
  position: relative;
  letter-spacing: 0.02em;
}
#read .ttl2 .fs::before {
  content: "";
  position: absolute;
  border-radius: 50%;
  width: 1.87vw;
  height: 1.87vw;
  background: var(--color4);
  right: -6vw;
  top: 50%;
  transform: translateY(-50%);
}
#read .ttl2 .fs:nth-of-type(2) {
  left: -3vw;
  margin: 0 0 2vw;
}
#read .img {
  margin: 0 30.8vw 0 24vw;
}
#read .img2 {
  margin: 62.4vw 45.3vw 0 0;
  position: relative;
  z-index: 2;
}
#read .img3 {
  position: absolute;
  z-index: 2;
  width: 114vw;
  top: 93.2vw;
  left: calc(50% - 27.87vw);
}
#read .box-txt {
  margin: 9vw var(--wrapPadding) 0;
}
#read .box-txt .txt {
  color: var(--color2);
  letter-spacing: 0.12em;
}
#read .box-txt .btn-link {
  margin-top: 15vw;
}
@media screen and (min-width: 768px) {
  #read {
    padding: 184px 0 107px;
  }
  #read .deco {
    width: 427px;
    right: calc(50% + 299px);
    bottom: 126px;
  }
  #read .deco2 {
    width: 369px;
    left: calc(50% + 307px);
    bottom: 248px;
    top: auto;
  }
  #read .ttl1 {
    top: 307px;
    left: calc(50% + 294px);
    font-size: 50px;
  }
  #read .ttl1 .cl {
    color: #d9d3cc;
  }
  #read .ttl1 .fs {
    font-size: 123px;
  }
  #read .ttl1 .fs:nth-of-type(1) {
    left: -8px;
  }
  #read .ttl1 .fs:nth-of-type(2) {
    left: 17px;
  }
  #read .ttl1 .fs:nth-of-type(3) {
    left: -10px;
  }
  #read .ttl1 .pt {
    padding-top: 310px;
  }
  #read .ttl2 {
    top: 354px;
    right: calc(50% + 330px);
    font-size: 50px;
  }
  #read .ttl2 .fs {
    font-size: 133px;
  }
  #read .ttl2 .fs::before {
    width: 14px;
    height: 14px;
    right: -2px;
  }
  #read .ttl2 .fs:nth-of-type(2) {
    left: -20px;
    margin: 0 0 13px;
  }
  #read .ttl2 .fs:nth-of-type(2)::before {
    right: 7px;
  }
  #read .img {
    width: 490px;
    margin: 0 auto;
  }
  #read .img2 {
    width: 1468px;
    margin: 0 auto;
    max-width: calc(100% - 60px);
  }
  #read .img3 {
    width: 956px;
    top: 667px;
    left: calc(50% - 34px);
  }
  #read .box-txt {
    position: relative;
    z-index: 4;
    background: rgba(221, 216, 210, 0.9);
    padding: 65px 0 89px;
    width: 615px;
    margin: -221px 0 0 calc(50% - 461px);
  }
  #read .box-txt .txt {
    height: 450px;
    margin: 0 auto;
    width: 481px;
  }
  #read .box-txt .btn-link {
    margin-top: 9px;
  }
}

#scene {
  padding: 23.2vw 0 0;
  position: relative;
}
#scene .ttl {
  position: absolute;
  width: 100vw;
  top: 0;
  right: 0;
}
#scene h3 {
  font-size: 6.67vw;
  line-height: 1.92;
  letter-spacing: 0.25em;
}
@media screen and (max-width: 767px) {
  #scene h3 {
    height: 66.8vw;
    width: 38.4192vw;
    margin: 0 0 0 34.67vw;
  }
}
#scene .txt {
  margin: 8vw 0 11vw;
  letter-spacing: 0.12em;
}
#scene .img {
  margin: 0 3.67vw;
}
@media screen and (min-width: 768px) {
  #scene {
    padding: 206px 0 0;
    min-height: 552px;
  }
  #scene .ttl {
    width: 306px;
    top: 112px;
    right: calc(50% + 413px);
  }
}
@media screen and (min-width: 768px) and (max-width: 1438px) {
  #scene .ttl {
    right: auto;
    left: 0;
  }
}
@media screen and (min-width: 768px) {
  #scene .wrap {
    width: 1300px;
  }
  #scene .group-content {
    margin: 0 auto;
    width: 1010px;
    max-width: 100%;
  }
  #scene h3 {
    font-size: 30px;
    line-height: 62px;
    padding: 19px 0 0;
  }
  #scene .txt {
    margin: 39px 0 54px 92px;
  }
  #scene .btn-link {
    margin: 0 0 0 195px;
  }
  #scene .img {
    position: absolute;
    margin: 0;
    top: 0;
    right: 0;
    width: calc(50% - 56px);
    height: 552px;
    max-width: calc(100% - 556px);
  }
}

#course {
  margin: 56vw 0 0;
  position: relative;
  padding: 0 0 41vw;
}
#course h2 {
  position: absolute;
  top: -3px;
  right: 0;
  font-size: 5.42vw;
  line-height: 2;
  display: flex;
  align-items: center;
}
#course h2 .ttl {
  display: block;
  width: 32vw;
  box-sizing: border-box;
  height: 27vw;
  letter-spacing: 0.12em;
  padding: 0 10.58vw;
  border-bottom: 1px solid;
  margin: 0 0 3vw;
  text-align: left;
}
#course h2 .tit {
  letter-spacing: 0.5em;
  width: 10.84vw;
  margin: 0 auto;
}
#course h3 {
  margin: 0 0 0 20vw;
  letter-spacing: 0.25em;
  font-size: 6.67vw;
  line-height: 1.92;
}
@media screen and (max-width: 767px) {
  #course h3 {
    height: 98vw;
  }
}
#course .txt {
  margin: 8vw var(--wrapPadding) 17vw;
  letter-spacing: 0.12em;
}
@media screen and (min-width: 768px) {
  #course {
    margin: 163px 0 0;
    padding: 0 0 217px;
    min-height: 566px;
  }
  #course h2 {
    font-size: 19px;
  }
  #course h2 .ttl {
    width: 114px;
    box-sizing: border-box;
    height: 94px;
    letter-spacing: 0.12em;
    padding: 0 38px;
    border-bottom: 1px solid;
    margin: 0 0 20px;
    text-align: left;
  }
  #course h2 .tit {
    width: 38px;
  }
  #course .img {
    position: absolute;
    top: 0;
    left: 0;
    width: calc(50% + 31px);
    height: 566px;
    max-width: calc(100% - 600px);
  }
  #course .group-content {
    width: 1000px;
    margin: 0 auto;
    max-width: 100%;
  }
  #course .group-content .inner {
    width: 407px;
    margin: 0 0 0 calc(50% + 93px);
  }
}
@media screen and (min-width: 768px) and (max-width: 1250px) {
  #course .group-content .inner {
    margin-left: calc(100% - 460px);
  }
}
@media screen and (min-width: 768px) and (max-width: 1100px) {
  #course .group-content .inner {
    margin-left: calc(100% - 530px);
  }
}
@media screen and (min-width: 768px) {
  #course h3 {
    margin: 0 -30px 0 0;
    padding: 30px 0 0;
    font-size: 30px;
    line-height: 62px;
  }
  #course .txt {
    margin: 30px 0 73px 6px;
  }
  #course .btn-link {
    margin: 0 0 0 auto;
  }
}

#drink {
  background: url("../img/shared/bg2.jpg");
  color: var(--color2);
  overflow: hidden;
}
#drink .right {
  position: relative;
}
#drink .right .deco {
  width: 16.8vw;
  position: absolute;
  top: 3.2vw;
  right: -2vw;
  z-index: 1;
}
#drink .right h2 {
  position: absolute;
  z-index: 2;
  width: -moz-max-content;
  width: max-content;
  text-align: right;
  font-size: 7.74vw;
  letter-spacing: 0.02em;
  line-height: 1.18;
  left: 50%;
  transform: translateX(-50%);
  top: 12vw;
  color: var(--color4);
}
#drink .right h2 .fs {
  font-size: 17vw;
  position: relative;
}
#drink .right h2 .fs:nth-of-type(1) {
  letter-spacing: -0.1em;
  top: -1.8vw;
}
#drink .right h2 .fs:nth-of-type(2) {
  top: 1.8vw;
  letter-spacing: -0.1em;
}
#drink .right h2 .fs2 {
  font-size: 9.552vw;
  letter-spacing: 0.02em;
}
#drink .right h2 .fs3 {
  font-size: 16.768vw;
  letter-spacing: -0.04em;
}
#drink .left {
  padding: 10vw 0 32.5vw;
}
#drink .left .txt {
  color: inherit;
}
#drink .left .txt1 {
  letter-spacing: 0.12em;
  margin: 0 var(--wrapPadding) 12vw;
}
#drink .left .btn-link {
  margin: 20vw auto 0;
}
#drink .left .flex {
  display: flex;
  align-items: flex-start;
  gap: 6vw;
}
@media screen and (max-width: 767px) {
  #drink .left .flex .img {
    width: 45.3vw;
  }
  #drink .left .flex .txt2 {
    width: 41vw;
  }
}
#drink .left .flex .txt2 {
  letter-spacing: 0.12em;
}
#drink .left .flex .txt2 .txt-latin {
  letter-spacing: 0.12em;
}
@media screen and (min-width: 768px) {
  #drink {
    display: flex;
    flex-direction: row-reverse;
  }
  #drink .right {
    width: 50%;
  }
  #drink .right .deco {
    width: 126px;
    top: 24px;
    right: -12px;
  }
  #drink .right h2 {
    font-size: 44px;
    top: 77px;
  }
  #drink .right h2 .fs {
    font-size: 97px;
  }
  #drink .right h2 .fs:nth-of-type(1) {
    top: -10.55px;
  }
  #drink .right h2 .fs:nth-of-type(2) {
    top: 10.55px;
  }
  #drink .right h2 .fs2 {
    font-size: 55px;
  }
  #drink .right h2 .fs3 {
    font-size: 96px;
  }
  #drink .right .img {
    height: 100%;
  }
  #drink .right .img img {
    -o-object-position: center 70%;
       object-position: center 70%;
  }
  #drink .left {
    width: 50%;
    padding: 109px 0 80px;
  }
  #drink .left .inner {
    width: 509px;
    margin: 0 auto;
    max-width: 90%;
    display: flex;
    flex-direction: column;
  }
  #drink .left .txt1 {
    height: 330px;
    order: 1;
    margin: 0;
  }
  #drink .left .btn-link {
    order: 2;
    margin: 5px 0 73px 164px;
  }
  #drink .left .flex {
    order: 3;
    justify-content: flex-end;
    gap: 26px;
  }
  #drink .left .flex .txt2 {
    height: 389px;
  }
  #drink .left .flex .txt2 .txt-latin {
    margin-top: 6px;
  }
}

#floor {
  position: relative;
  color: var(--color3);
  padding: 0 0 32vw;
}
#floor .group-title {
  position: absolute;
  z-index: 2;
  top: 83.2vw;
  left: -1vw;
  width: 30vw;
}
#floor .group-title h3 {
  position: absolute;
  z-index: 2;
  top: 9vw;
  line-height: 1;
  right: 3vw;
  font-size: 8.13vw;
  letter-spacing: 0;
}
#floor .group-title h3 .fs {
  position: relative;
  font-size: 12.8vw;
}
#floor .group-title h3 .fs:nth-of-type(2) {
  left: 2.13vw;
}
#floor .group-title h3 .pt {
  display: inline-block;
  padding-top: 24.4vw;
}
#floor .wrap {
  padding: 0;
}
#floor h4 {
  text-align: center;
  letter-spacing: 0.25em;
  line-height: 1.5;
  font-size: 5.6vw;
}
@media screen and (max-width: 767px) {
  #floor h4 {
    height: 138.4vw;
    margin: 0 0 0 9vw;
    width: 8.4vw;
  }
}
#floor .img2 {
  margin: 21vw 0 0 42.67vw;
}
#floor .map {
  position: absolute;
  top: 142vw;
  right: 10vw;
  width: 60.267vw;
}
#floor .txt {
  margin: 0 var(--wrapPadding);
}
@media screen and (min-width: 768px) {
  #floor {
    padding: 160px 0 150px;
  }
  #floor .deco {
    position: absolute;
    width: 424px;
    left: calc(50% + 400px);
    bottom: -38px;
  }
  #floor .group-title {
    position: absolute;
    z-index: 2;
    top: 0;
    left: -5px;
    width: auto;
  }
  #floor .group-title h3 {
    top: 74px;
    right: 29px;
    font-size: 61px;
  }
  #floor .group-title h3 .fs {
    font-size: 96px;
  }
  #floor .group-title h3 .fs:nth-of-type(2) {
    left: 16px;
  }
  #floor .group-title h3 .pt {
    padding-top: 183px;
  }
  #floor .wrap {
    width: 1476px;
    display: flex;
    flex-direction: column;
  }
  #floor h4 {
    text-align: center;
    order: 1;
    font-size: 33px;
    margin: 0 0 48px;
  }
  #floor .img {
    order: 2;
    margin: 0 0 0 auto;
    width: 803px;
    height: 597px;
    max-width: calc(100% - 550px);
  }
  #floor .img2 {
    position: absolute;
    top: 696px;
    right: calc(50% + 66px);
    margin: 0;
  }
  #floor .map {
    position: absolute;
    top: 145px;
    right: calc(50% + 154px);
    width: auto;
  }
}
@media screen and (min-width: 768px) and (max-width: 1300px) {
  #floor .map {
    right: calc(100% - 500px);
  }
}
@media screen and (min-width: 768px) {
  #floor .txt {
    order: 2;
    margin: 72px 0 0 calc(50% + 6px);
    height: 350px;
    letter-spacing: 0.12em;
    width: 444px;
  }
}

#shopinfo {
  position: relative;
}
#shopinfo .inner {
  position: relative;
  background: #000;
  color: var(--color);
  padding: 33.2vw 0 29vw;
}
#shopinfo .bg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
}
#shopinfo .bg-active {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  opacity: 0;
  visibility: hidden;
  transition: all 0.5s;
}
#shopinfo[style*="visibility: visible"] .bg-active {
  opacity: 1;
  visibility: visible;
  transition-delay: 1s;
}
@media screen and (max-width: 767px) {
  #shopinfo .logo {
    width: 28px;
    margin: 0 auto;
  }
}
#shopinfo .name {
  text-align: center;
  margin: 4vw 0 8vw;
  letter-spacing: 0.12em;
  color: var(--color3);
}
#shopinfo .flex {
  margin: 0 0 20vw;
}
#shopinfo .flex .group-tel-btn {
  color: var(--color3);
}
#shopinfo .flex .group-tel-btn .btn-web {
  margin: 0 auto;
}
#shopinfo .flex .note-tel {
  margin: 1px -20px 14px;
  color: var(--color3);
}
#shopinfo .flex .box-info {
  padding: 5vw 0 0;
  text-align: center;
}
#shopinfo .flex .box-info .tit {
  font-size: 16.5px;
  line-height: 1.5;
  margin: 0 0 10px;
  letter-spacing: 0.12em;
}
#shopinfo .flex .box-info .txt {
  font-size: 14px;
  line-height: 27.5px;
  letter-spacing: 0.12em;
  margin-left: -10px;
  margin-right: -10px;
}
#shopinfo .info .col + .col {
  margin-top: 20px;
}
#shopinfo .info .col dl {
  display: flex;
  line-height: 1.75;
  align-items: flex-start;
}
#shopinfo .info .col dl + dl {
  margin-top: 20px;
}
#shopinfo .info .col dl dt {
  width: 90px;
  letter-spacing: 0;
}
#shopinfo .info .col dl dd {
  width: calc(100% - 90px);
  letter-spacing: 0.12em;
}
#shopinfo .info .col dl dd .link-map {
  display: inline-flex;
  vertical-align: baseline;
  align-items: center;
  letter-spacing: 0.08em;
  margin-left: 20px;
  font-size: 15px;
  gap: 0 4px;
  color: var(--color3);
}
#shopinfo .info .col dl dd .link-map::before {
  content: "";
  background: url("../img/shared/icon_map_sp.png") no-repeat center/100% auto;
  width: 10.5px;
  height: 13.5px;
}
@media screen and (min-width: 768px) {
  #shopinfo .inner {
    width: 1400px;
    max-width: calc(100% - 100px);
    margin: 0 auto;
    padding: 220px 0 194px;
  }
  #shopinfo .bg, #shopinfo .bg-active {
    height: 998px;
  }
  #shopinfo .logo {
    text-align: center;
  }
  #shopinfo .name {
    margin: 33px 0 92px;
    line-height: 1.75;
  }
  #shopinfo .flex {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: 750px;
    margin: 0 auto 121px;
  }
  #shopinfo .flex .note-tel {
    margin: 1px -20px 14px;
  }
  #shopinfo .flex .box-info {
    width: 401px;
    text-align: left;
    box-sizing: border-box;
    border-left: 1px solid rgba(255, 255, 255, 0.36);
    padding: 0 0 0 40px;
  }
  #shopinfo .flex .box-info .tit {
    font-size: 18px;
    margin: 3px 0 11px;
  }
  #shopinfo .flex .box-info .txt {
    font-size: 16px;
    line-height: 1.75;
    margin-right: -30px;
    margin-left: 0;
  }
  #shopinfo .info {
    display: flex;
    justify-content: space-between;
  }
  #shopinfo .info .col {
    width: 50%;
  }
  #shopinfo .info .col + .col {
    margin-top: 0;
  }
  #shopinfo .info .col dl + dl {
    margin-top: 28px;
  }
  #shopinfo .info .col dl dt {
    width: 110px;
  }
  #shopinfo .info .col dl dd {
    width: calc(100% - 110px);
  }
  #shopinfo .info .col dl dd .link-map::before {
    background: url("../img/shared/icon_map.png") no-repeat center/100% auto;
    width: 15px;
    height: 20px;
  }
}

#ggmap .ggmap {
  height: 300px;
}
#ggmap .ggmap iframe {
  width: 100%;
  height: 100%;
}
@media screen and (min-width: 768px) {
  #ggmap {
    padding: 62px 0 0;
  }
  #ggmap .group-btn {
    display: flex;
    align-items: center;
    margin: 0 50px 21px;
    justify-content: flex-end;
    gap: 21px;
  }
  #ggmap .group-btn .btn2 {
    font-size: 13px;
    line-height: 1.5;
  }
  #ggmap .group-btn .btn-link2 {
    width: 180px;
  }
  #ggmap .group-btn .btn-link2 a {
    display: block;
    text-align: center;
    text-decoration: none;
    font-size: 17px;
    border: 1px solid rgba(231, 228, 225, 0.45);
    line-height: 2;
    padding: 7px 0;
  }
  #ggmap .group-btn .btn-link2 a:hover {
    opacity: 0.8;
  }
  #ggmap .ggmap {
    height: 600px;
  }
}

@media screen and (max-width: 767px) {
  #footer .left {
    padding: 8vw 0;
  }
}

#footer .right {
  padding-top: 0;
}