@charset "UTF-8";
/********************************************************

setting

********************************************************/
:root {
  --margin-block: 200px; }

@media (min-width: 1101px) and (max-width: 1280px) {
  :root {
    --margin-block: 120px; } }
@media (min-width: 641px) and (max-width: 1100px) {
  :root {
    --margin-block: 90px; } }
@media (max-width: 640px) {
  :root {
    --margin-block: 70px; } }
/* -------------------------------------------------------

common

------------------------------------------------------- */
body {
  overflow-x: visible; }
  @media screen and (max-width: 1170px) {
    body {
      overflow: hidden; } }

.bg_townguide {
  background: #f4ece5; }

.page-townguide {
  font-weight: 400; }

/* -------------------------------------------------------

intro

------------------------------------------------------- */
.section_intro {
  width: 100%; }
  .section_intro ul {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    position: relative;
    gap: 0 50px; }
  .section_intro li {
    width: min(16.5%, 314px);
    z-index: 2; }
    @media screen and (max-width: 970px) {
      .section_intro li {
        width: 157px; } }

.section_intro .intro_head {
  margin: clamp(225px, 28.125vw, 450px) auto 0 auto;
  position: relative; }
  @media screen and (max-width: 600px) {
    .section_intro .intro_head {
      margin: clamp(125px, 15.625vw, 250px) auto 0 auto; } }
  @media screen and (max-width: 750px) {
    .section_intro .intro_head .js-intro-slider {
      display: block;
      opacity: 1;
      visibility: visible;
      z-index: 2; } }
  @media screen and (max-width: 750px) {
    .section_intro .intro_head .js-intro-slider .slick-slide {
      margin: 0 20px; } }
  @media screen and (max-width: 750px) {
    .section_intro .intro_head .js-intro-slider .slick-slide:nth-child(odd) {
      margin-top: -30px !important; } }
  @media screen and (max-width: 750px) {
    .section_intro .intro_head .js-intro-slider .slick-list {
      overflow: inherit; } }
  .section_intro .intro_head li {
    margin-bottom: -70px; }
    .section_intro .intro_head li:nth-child(2), .section_intro .intro_head li:nth-child(3) {
      margin-bottom: 50px; }
      @media screen and (max-width: 750px) {
        .section_intro .intro_head li:nth-child(2), .section_intro .intro_head li:nth-child(3) {
          margin-bottom: 0; } }

.intro-copy_title {
  margin: clamp(100px, 12.5vw, 200px) auto clamp(75px, 9.375vw, 150px) auto;
  text-align: center;
  z-index: 2;
  font-weight: 500; }
  .intro-copy_title .main {
    width: min(80%, 820px);
    margin: 0 auto clamp(20px, 2.5vw, 40px) auto; }
  .intro-copy_title .sub {
    font-size: 20px;
    background: linear-gradient(to right, #c9af8f, #66b2bd);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    width: 50%;
    margin: 0 auto;
    line-height: 1.6; }
    @media screen and (min-width: 750px) {
      .intro-copy_title .sub {
        font-size: calc(20px + 0.0068376068 * (100vw - 750px)); } }
    @media screen and (min-width: 1920px) {
      .intro-copy_title .sub {
        font-size: 28px; } }
    @media screen and (max-width: 1170px) {
      .intro-copy_title .sub {
        width: 90%; } }
  .intro-copy_title .text {
    font-size: 14px;
    line-height: 2.5;
    margin: clamp(35px, 4.375vw, 70px) auto 0 auto;
    width: 90%; }
    @media screen and (min-width: 750px) {
      .intro-copy_title .text {
        font-size: calc(14px + 0.0017094017 * (100vw - 750px)); } }
    @media screen and (min-width: 1920px) {
      .intro-copy_title .text {
        font-size: 16px; } }

.section_intro .intro_bottom {
  position: relative; }
  @media screen and (max-width: 750px) {
    .section_intro .intro_bottom {
      display: none; } }
  @media screen and (max-width: 1170px) {
    .section_intro .intro_bottom ul {
      gap: 0 10px; } }
  .section_intro .intro_bottom li {
    margin-bottom: 150px; }
    .section_intro .intro_bottom li:nth-child(1), .section_intro .intro_bottom li:nth-child(5) {
      margin-bottom: 300px; }
    .section_intro .intro_bottom li:nth-child(2), .section_intro .intro_bottom li:nth-child(4) {
      margin-bottom: 220px; }

.section_intro .bg {
  position: absolute;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  z-index: 1;
  pointer-events: none; }
  @media screen and (max-width: 750px) {
    .section_intro .bg {
      width: 200%; } }

.section_intro .intro_bottom .bg {
  bottom: 0; }
  @media screen and (max-width: 1170px) {
    .section_intro .intro_bottom .bg {
      bottom: 100px; } }
  @media screen and (max-width: 750px) {
    .section_intro .intro_bottom .bg {
      display: none; } }

/* -------------------------------------------------------

shop-guide

------------------------------------------------------- */
.section_shop-guide {
  padding: 0 0 clamp(150px, 18.75vw, 300px) 0; }
  @media screen and (max-width: 600px) {
    .section_shop-guide {
      padding: 0 0 clamp(75px, 9.375vw, 150px) 0; } }

.block_shop-guide {
  margin: clamp(150px, 18.75vw, 300px) auto 0 auto; }
  @media screen and (max-width: 1170px) {
    .block_shop-guide {
      margin: clamp(75px, 9.375vw, 150px) auto 0 auto; } }
  .block_shop-guide:first-child {
    margin: clamp(75px, 9.375vw, 150px) auto 0 auto; }

.shop-guide_wrap {
  width: min(96%, 1900px);
  margin: 0 auto;
  display: flex;
  align-items: flex-start;
  justify-content: space-between; }
  @media screen and (max-width: 1170px) {
    .shop-guide_wrap {
      display: block;
      width: 90%; } }

/*------- shop link -------*/
.shop-guide_container {
  width: min(89%, 1694px);
  margin: 0 auto clamp(60px, 7.5vw, 120px) auto; }
  @media screen and (max-width: 1170px) {
    .shop-guide_container {
      margin-bottom: 30px; } }

.shop-guide_header {
  display: none; }
  @media screen and (max-width: 1170px) {
    .shop-guide_header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 15px 20px;
      background-color: #b67b30;
      color: #fff;
      cursor: pointer;
      position: relative; }
      .shop-guide_header .en {
        font-family: "Montserrat", serif;
        font-size: 20px;
        margin: 0; }
      .shop-guide_header::after {
        content: "";
        position: absolute;
        right: 20px;
        top: 55%;
        width: 12px;
        height: 12px;
        border-top: 2px solid #fff;
        border-right: 2px solid #fff;
        transform: translateY(-75%) rotate(135deg);
        transition: transform 0.3s ease; }
      .shop-guide_header.is-open::after {
        transform: translateY(-25%) rotate(-45deg); } }

.shop-guide_link ul {
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: 0 20px; }
  @media screen and (max-width: 1170px) {
    .shop-guide_link ul {
      display: none; } }
  .shop-guide_link ul li {
    flex: 1;
    position: relative;
    border-top: 2px solid #ded6cd;
    border-bottom: 2px solid #ded6cd; }
    @media screen and (max-width: 1170px) {
      .shop-guide_link ul li {
        border-top: none;
        border-bottom: 2px solid #f4ece5; } }
    .shop-guide_link ul li a {
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      padding: 20px 10px;
      text-decoration: none;
      color: #705b46;
      transition: all 0.3s ease; }
      @media screen and (max-width: 1170px) {
        .shop-guide_link ul li a {
          background: #FFF;
          padding: 1rem 1.5rem;
          align-items: flex-start; } }
      .shop-guide_link ul li a .main {
        font-weight: 500;
        letter-spacing: 0.1em;
        margin-bottom: 5px;
        font-size: 14px; }
        @media screen and (min-width: 1280px) {
          .shop-guide_link ul li a .main {
            font-size: calc(14px + 0.015625 * (100vw - 1280px)); } }
        @media screen and (min-width: 1920px) {
          .shop-guide_link ul li a .main {
            font-size: 24px; } }
        @media screen and (max-width: 1170px) {
          .shop-guide_link ul li a .main {
            margin-bottom: 0.2rem;
            font-size: 16px; } }
        .shop-guide_link ul li a .main.en {
          font-family: "Montserrat", serif; }
      .shop-guide_link ul li a .sub {
        font-size: 12px; }
        @media screen and (min-width: 750px) {
          .shop-guide_link ul li a .sub {
            font-size: calc(12px + 0.0017094017 * (100vw - 750px)); } }
        @media screen and (min-width: 1920px) {
          .shop-guide_link ul li a .sub {
            font-size: 14px; } }
        @media screen and (max-width: 1170px) {
          .shop-guide_link ul li a .sub {
            font-size: 10px; } }
    .shop-guide_link ul li.active {
      border-top: 2px solid #b67b30;
      border-bottom: 2px solid #b67b30; }
      @media screen and (max-width: 1170px) {
        .shop-guide_link ul li.active {
          border-top: none;
          border-bottom: 4px solid #b67b30; } }
      .shop-guide_link ul li.active a {
        color: #b67b30; }
      .shop-guide_link ul li.active::before {
        content: "";
        position: absolute;
        bottom: -10px;
        left: 50%;
        transform: translateX(-50%);
        border-left: 8px solid transparent;
        border-right: 8px solid transparent;
        border-top: 10px solid #b67b30;
        z-index: 1; }
        @media screen and (max-width: 1170px) {
          .shop-guide_link ul li.active::before {
            display: none; } }

/*------- shop title -------*/
.shop-guide_title {
  width: min(89%, 1694px);
  margin: 0 auto;
  text-align: center; }
  .shop-guide_title .cate {
    display: inline-flex;
    align-items: center;
    border-radius: 40px;
    color: #FFF;
    padding: 0.7rem 1.5rem;
    font-size: 16px;
    margin: 0 0 clamp(10px, 1.25vw, 20px) 0; }
    @media screen and (min-width: 750px) {
      .shop-guide_title .cate {
        font-size: calc(16px + 0.0051282051 * (100vw - 750px)); } }
    @media screen and (min-width: 1920px) {
      .shop-guide_title .cate {
        font-size: 22px; } }
    .shop-guide_title .cate .icon {
      margin-right: 1rem; }
      @media screen and (max-width: 600px) {
        .shop-guide_title .cate .icon img {
          width: 20px; } }
    .shop-guide_title .cate_gourmet {
      background: #ff5252; }
    .shop-guide_title .cate_cafe {
      background: #0097a7; }
    .shop-guide_title .cate_gym {
      background: #e65100; }
    .shop-guide_title .cate_italian {
      background: #a52714; }
  .shop-guide_title .shop-name {
    font-size: 22px;
    line-height: 1.0;
    font-weight: 300;
    margin: 0 0 clamp(45px, 5.625vw, 90px) 0; }
    @media screen and (min-width: 750px) {
      .shop-guide_title .shop-name {
        font-size: calc(22px + 0.0239316239 * (100vw - 750px)); } }
    @media screen and (min-width: 1920px) {
      .shop-guide_title .shop-name {
        font-size: 50px; } }
    @media screen and (max-width: 600px) {
      .shop-guide_title .shop-name {
        margin-bottom: 30px; } }
    .shop-guide_title .shop-name .en {
      font-family: "Montserrat", serif; }
    .shop-guide_title .shop-name .sub {
      font-size: 13px;
      margin-top: 0.5rem; }
      @media screen and (min-width: 750px) {
        .shop-guide_title .shop-name .sub {
          font-size: calc(13px + 0.0094017094 * (100vw - 750px)); } }
      @media screen and (min-width: 1920px) {
        .shop-guide_title .shop-name .sub {
          font-size: 24px; } }

/*------- 左カラム：画像 -------*/
.shop-guide_main-img-wrap {
  flex: 0 0 49%;
  max-width: 49%;
  position: sticky;
  top: 100px; }
  @media screen and (max-width: 1170px) {
    .shop-guide_main-img-wrap {
      display: block;
      max-width: 100%;
      position: static;
      margin-bottom: 20px; } }

.shop-guide_main-img img {
  display: block;
  width: 100%;
  height: auto; }

/*------- 右カラム：詳細 -------*/
.shop-guide_contents {
  flex: 0 0 50%;
  max-width: 50%;
  display: flex;
  flex-direction: column;
  background: #FFF;
  border-radius: 10px;
  background-image: linear-gradient(to right, #e6cdaf, #8bc5cd);
  background-size: 100% 10px;
  background-repeat: no-repeat;
  background-position: top;
  overflow: hidden; }
  @media screen and (max-width: 1170px) {
    .shop-guide_contents {
      display: block;
      max-width: 100%; } }
  .shop-guide_contents .inner {
    width: min(80%, 605px);
    margin: 0 auto;
    padding: clamp(60px, 7.5vw, 120px) 0 clamp(60px, 7.5vw, 120px) 0; }
    @media screen and (max-width: 1170px) {
      .shop-guide_contents .inner {
        width: 80%;
        padding: clamp(37.5px, 4.6875vw, 75px) 0 clamp(45px, 5.625vw, 90px) 0; } }
  .shop-guide_contents__title {
    border-bottom: 2px solid #e9e9e9;
    color: #aa7b41;
    font-size: 18px;
    line-height: 1.4;
    position: relative;
    padding-bottom: 2.5rem;
    margin: 0 0 clamp(30px, 3.75vw, 60px) 0; }
    @media screen and (min-width: 750px) {
      .shop-guide_contents__title {
        font-size: calc(18px + 0.011965812 * (100vw - 750px)); } }
    @media screen and (min-width: 1920px) {
      .shop-guide_contents__title {
        font-size: 32px; } }
    .shop-guide_contents__title::after {
      content: "";
      position: absolute;
      bottom: -1px;
      left: 0;
      width: 80px;
      height: 2px;
      background-color: #aa7b41; }
  .shop-guide_contents__copy {
    font-size: 14px;
    line-height: 2.4;
    margin: clamp(30px, 3.75vw, 60px) 0 clamp(40px, 5vw, 80px) 0;
    flex-wrap: 500; }
    @media screen and (min-width: 750px) {
      .shop-guide_contents__copy {
        font-size: calc(14px + 0.0034188034 * (100vw - 750px)); } }
    @media screen and (min-width: 1920px) {
      .shop-guide_contents__copy {
        font-size: 18px; } }
    @media screen and (max-width: 1170px) {
      .shop-guide_contents__copy {
        line-height: 2.1; } }
    @media screen and (max-width: 600px) {
      .shop-guide_contents__copy {
        font-size: 12px; } }
    .shop-guide_contents__copy .marker {
      background: #f8f2ea;
      color: #aa7b41;
      font-weight: 600; }
  .shop-guide_contents__comment {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: clamp(50px, 6.25vw, 100px) 0 clamp(35px, 4.375vw, 70px) 0; }
    .shop-guide_contents__comment .fukidashi {
      background: #e9eef0;
      position: relative;
      display: inline-block;
      border: 1px solid #9baeb8;
      border-radius: 10px;
      width: min(66%, 400px);
      padding: clamp(20px, 2.5vw, 40px) clamp(20px, 2.5vw, 40px) clamp(20px, 2.5vw, 40px) clamp(20px, 2.5vw, 40px);
      color: #4e6c7e;
      font-size: 12px;
      line-height: 2.0;
      font-weight: 500; }
      @media screen and (min-width: 750px) {
        .shop-guide_contents__comment .fukidashi {
          font-size: calc(12px + 0.0017094017 * (100vw - 750px)); } }
      @media screen and (min-width: 1920px) {
        .shop-guide_contents__comment .fukidashi {
          font-size: 14px; } }
      @media screen and (max-width: 1170px) {
        .shop-guide_contents__comment .fukidashi {
          width: 66%; } }
      @media screen and (max-width: 600px) {
        .shop-guide_contents__comment .fukidashi {
          font-size: 10px; } }
      .shop-guide_contents__comment .fukidashi::before {
        content: "";
        position: absolute;
        top: 50%;
        right: -31px;
        margin-top: -15px;
        border: 15px solid transparent;
        border-left: 16px solid #9baeb8;
        z-index: 1; }
      .shop-guide_contents__comment .fukidashi::after {
        content: "";
        position: absolute;
        top: 50%;
        right: -29px;
        margin-top: -15px;
        border: 15px solid transparent;
        border-left: 16px solid #e9eef0;
        z-index: 2; }
      .shop-guide_contents__comment .fukidashi p {
        position: absolute;
        top: -20px;
        left: 10px; }
        @media screen and (max-width: 600px) {
          .shop-guide_contents__comment .fukidashi p {
            width: 75%; } }
    .shop-guide_contents__comment .img {
      width: min(28%, 170px); }
      .shop-guide_contents__comment .img img {
        border-radius: 10px; }
  .shop-guide_contents__date .date-title {
    border-bottom: 2px solid #e9e9e9;
    color: #aa7b41;
    font-size: 12px;
    line-height: 1.4;
    position: relative;
    padding-bottom: 1rem;
    font-family: "Montserrat", serif;
    margin: 0 0 clamp(25px, 3.125vw, 50px) 0;
    font-weight: 500; }
    @media screen and (min-width: 750px) {
      .shop-guide_contents__date .date-title {
        font-size: calc(12px + 0.0017094017 * (100vw - 750px)); } }
    @media screen and (min-width: 1920px) {
      .shop-guide_contents__date .date-title {
        font-size: 14px; } }
    .shop-guide_contents__date .date-title::after {
      content: "";
      position: absolute;
      bottom: -1px;
      left: 0;
      width: 80px;
      height: 2px;
      background-color: #aa7b41; }
  .shop-guide_contents__date .date_wrap {
    display: flex;
    justify-content: space-between; }
    .shop-guide_contents__date .date_wrap__info {
      width: 60%; }
      .shop-guide_contents__date .date_wrap__info .shop-name {
        font-size: 18px;
        margin: 0 0 clamp(15px, 1.875vw, 30px) 0; }
        @media screen and (min-width: 750px) {
          .shop-guide_contents__date .date_wrap__info .shop-name {
            font-size: calc(18px + 0.0051282051 * (100vw - 750px)); } }
        @media screen and (min-width: 1920px) {
          .shop-guide_contents__date .date_wrap__info .shop-name {
            font-size: 24px; } }
        @media screen and (max-width: 600px) {
          .shop-guide_contents__date .date_wrap__info .shop-name {
            font-size: 14px; } }
        .shop-guide_contents__date .date_wrap__info .shop-name .en {
          font-family: "Montserrat", serif; }
        .shop-guide_contents__date .date_wrap__info .shop-name span {
          font-size: 60%; }
      .shop-guide_contents__date .date_wrap__info dl {
        display: flex;
        flex-wrap: wrap;
        font-size: 10px;
        line-height: 1.4; }
        @media screen and (min-width: 750px) {
          .shop-guide_contents__date .date_wrap__info dl {
            font-size: calc(10px + 0.0034188034 * (100vw - 750px)); } }
        @media screen and (min-width: 1920px) {
          .shop-guide_contents__date .date_wrap__info dl {
            font-size: 14px; } }
        .shop-guide_contents__date .date_wrap__info dl dt,
        .shop-guide_contents__date .date_wrap__info dl dd {
          margin-bottom: 1rem; }
        .shop-guide_contents__date .date_wrap__info dl dt {
          margin-right: 1%;
          width: 20%; }
          @media screen and (max-width: 750px) {
            .shop-guide_contents__date .date_wrap__info dl dt {
              width: 100%;
              margin-right: 0;
              margin-bottom: 0.2rem;
              font-weight: 600; } }
        .shop-guide_contents__date .date_wrap__info dl dd {
          width: 79%; }
          @media screen and (max-width: 750px) {
            .shop-guide_contents__date .date_wrap__info dl dd {
              width: 100%;
              margin-bottom: 1.5rem; } }
    .shop-guide_contents__date .date_wrap__img {
      width: min(39%, 260px); }
      @media screen and (max-width: 750px) {
        .shop-guide_contents__date .date_wrap__img {
          width: 36%; } }
      .shop-guide_contents__date .date_wrap__img img {
        border-radius: 10px; }
  .shop-guide_contents__map {
    margin: clamp(25px, 3.125vw, 50px) 0 0 0; }
    .shop-guide_contents__map iframe {
      border-radius: 10px; }

@media screen and (max-width: 970px) {
  .shop-guide_main-img-wrap,
  .shop-guide_contents {
    max-width: 100%;
    flex: none; } }

.text_coming-soon {
  width: min(89%, 493px);
  margin: 0 auto;
  padding: 0 0 clamp(150px, 18.75vw, 300px) 0; }
  @media screen and (max-width: 970px) {
    .text_coming-soon {
      padding: 0 0 clamp(75px, 9.375vw, 150px) 0; } }
