@charset "UTF-8";
/* autoprefixer grid: autoplace */
/* ==========================================================================
 Foundation
 ========================================================================== */
/* GFO template */
html {
  overflow-x: hidden;
  font-size: 62.5%;
}

/* http://meyerweb.com/eric/tools/css/reset/
v2.0 | 20110126
License: none (public domain)
*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  /* font-size: 100%;
font: inherit; */
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  /* line-height: 1; */
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

.project {
  font-size: 2.666vw;
  line-height: 1.4;
  font-family: "Shippori Mincho B1","游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
  font-weight: 600;
  background-color: #FFFFFF;
  color: #2B2E34;
}

.project *, .project *:before, .project *:after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.project h1, .project h2, .project h3, .project h4 {
  font-size: 100%;
}

@media screen and (min-width: 769px) {
  .project {
    font-size: 0.925vw;
  }
}

@media screen and (min-width: 1081px) {
  .project {
    font-size: 10px;
  }
}

a {
  color: #2B2E34;
  text-decoration: none;
}

img {
  vertical-align: middle;
  height: auto;
  width: 100%;
  max-width: 100%;
}

svg {
  width: 100%;
  height: auto;
  vertical-align: middle;
}

figure {
  margin: 0;
}

@media screen and (min-width: 769px) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
    }
}

/* ==========================================================================
 Layout
 ========================================================================== */
/* .l-container {
  width: 100%;
  overflow: hidden;
}

.l-container--gradient-brown {
  background: -webkit-gradient(linear, left top, right top, from(rgba(255, 255, 255, 0.3)), color-stop(0%, #f7edd7), color-stop(70%, #b88b7f), to(#6b1514));
  background: -webkit-linear-gradient(left, rgba(255, 255, 255, 0.3) 0%, #f7edd7 0%, #b88b7f 70%, #6b1514 100%);
  background: linear-gradient(to right, rgba(255, 255, 255, 0.3) 0%, #f7edd7 0%, #b88b7f 70%, #6b1514 100%);
}

.l-container--gradient-khaki {
  background: linear-gradient(90deg, rgba(215,237,247,1) 0%, rgba(235,216,186,1) 100%);
}

.l-container--gradient-blue {
  background: linear-gradient(90deg, rgba(208,232,220,1) 0%, rgba(96,165,186,1) 100%);
}

.l-container--darkgreen {
  background: #002A0F;
}

.l-container--darkred {
  background: #602447;
}


.l-content {
  position: relative;
  max-width: 1080px;
  margin-right: auto;
  margin-left: auto;
  padding-right: 5.333vw;
  padding-left: 5.333vw;
}

@media screen and (min-width: 769px) {
  .l-content {
    padding-right: 3.703vw;
    padding-left: 3.703vw;
  }
  .l-content--logo {
    padding-left: 2.314vw;
  }
}

.l-content2 {
  position: relative;
  max-width: 1080px;
  margin-right: auto;
  margin-left: auto;
  padding-right:0;
  padding-left: 0;
}

@media screen and (min-width: 769px) {
  .l-content2 {
    padding-right: 3.703vw;
    padding-left: 3.703vw;
  }
}


@media screen and (min-width: 1081px) {
  .l-content {
    padding-right: 40px;
    padding-left: 40px;
  }
  .l-content--logo {
    padding-left: 25px;
  }
}

.l-content--full {
  padding-right: 0;
  padding-left: 0;
}

.l-content--footer {
  padding-bottom: 0px;
}

@media screen and (min-width: 769px) {
  .l-content--footer {
    padding-bottom: 50px;
  }
}

.l-logo {
  margin-bottom: 5.3vw;
}

@media screen and (min-width: 769px) {
  .l-logo {
    margin-bottom: 3.7vw;
  }
}

@media screen and (min-width: 1081px) {
  .l-logo {
    margin-bottom: 40px;
  }
}

.l-column-list {
  padding-top: 17.9%;
  padding-bottom: 11.9%;
}

@media screen and (min-width: 769px) {
  .l-column-list {
    padding-top: 5%;
    padding-bottom: 1%;
  }
}

.l-categories {
  padding-top: 29.8%;
}

@media screen and (min-width: 769px) {
  .l-categories {
    padding-top: 16%;
  }
}

/* ==========================================================================
 Component
 ========================================================================== */
/* c-nav-button
----------------------------------------------------------------- */
/* .c-nav-button {
  border-radius: 3.2vw;
  overflow: hidden;
}

.c-nav-button__link {
  display: block;
  padding-bottom: 70%;
  background-size: cover;
  background-repeat: no-repeat;
}

.c-nav-button__link--interior {
  background-image: url(../img/btn_interior_sp.png);
}

.c-nav-button__link--gift {
  background-image: url(../img/btn_gift_sp.png);
}

@media screen and (min-width: 769px) {
  .c-nav-button__link {
    padding-top: 3.9%;
    padding-bottom: 3.9%;
    padding-left: 5%;
    padding-right: 5%;
    background-image: none;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

@media screen and (min-width: 769px) {
  .c-nav-button {
    border-radius: 0.75em;
    border: solid 0.2em #333;
  }
}

.nav_bg--2023{
  background-color: #67B5B7;
  padding: 3rem 1rem 1rem;
}

.nav_bg_in--2023{
  padding: 3rem 1rem 1rem;
}



.nav_container--2023{
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  padding: 1.5rem 0;
  flex-direction:row;
}

.nav_item--2023{
  font-family: "Noto Serif JP", sans-serif;
  font-weight: 500;
  width: 100%;
  font-size: 2rem;
  color: #FFF;
  margin: 0.5rem 0;
}

.nav_item_in--2023{
  font-family: "Noto Serif JP", sans-serif;
  font-weight: 500;
  width: 100%;
  font-size: 2rem;
  color: #333333;
  margin: 0.5rem 0;
  
}

@media screen and (min-width: 769px) {

  .nav_container--2023{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    padding: 1.5rem 0;
    flex-direction:column;
    height: 110px;
  }


  .nav_item--2023{
    font-family: "Noto Serif JP", sans-serif;
    font-weight: 500;
    width: 30%;
    font-size: 1.9rem;
    color: #FFF;
    margin: 0.5rem 0;
  }

  .nav_item_in--2023{
    font-family: "Noto Serif JP", sans-serif;
    font-weight: 500;
    width: 30%;
    font-size: 1.9rem;
    color: #333333;
    margin: 0.5rem 0;
  }
}

.nav_item_in--2023 a {
  color: #333333;
}

.nav_item--2023 a {
  color: #FFF;
}

.nav_item--2023::before{
  content: url(../img/nav_arrow.png);
  vertical-align: middle;
  padding-right: 5px;
}

.nav_item_in--2023::before{
  content: url(../img/nav_arrow_bk.png);
  vertical-align: middle;
  padding-right: 5px;
}  */



/* interiorgift2024AW
----------------------------------------------------------------- */
#pageContents{
  color: rgb(var(--c-222222));
}

.main-contents a{
  transition: 0.3s;
}
.main-contents a:hover{
  opacity: 0.7;
}

.u-space_sp{
  display: none !important;
}
.u-space_pc{
  display : block !important;
}
@media screen and (max-width: 767px) {
  .u-space_sp{
    display : block !important;
  }
  .u-space_pc{
    display: none !important;
  }
}

.main-ttl{
  background-color: #E3E0D6;
}
.main-ttl h1{
  width: 587px;
  margin: 0 auto;
  padding: 40px 0;
}

#message_slider{
  width: 100%;
  overflow: hidden;
  margin: 0 auto;
  padding: 0;
  max-height: 44.27vw;
}

.slick-slide{
  outline: none;
}

.slider{
  opacity: 0;
  transition: opacity .3s linear;
}
.slider.slick-initialized{
  opacity: 1;
}
@media screen and (max-width: 767px) {
  #message_slider{
    max-height: 69.334vw;
  }
}


.top-contents{
  max-width: 1100px;
  margin: 72px auto 0;
  padding: 0 10px;
}
.top-contents .banner-gift{
  max-width: 920px;
  margin: 0 auto;
}
.top-interior-contents{
  margin: 120px auto 0;
}
.top-interior-ttl{
  text-align: center;
}
.top-interior-ttl h2{
  font-size: 36px;
  letter-spacing: 0.15em;
}
.top-interior-ttl p{
  padding-top: 24px;
  font-size: 18px;
  letter-spacing: 0.05em;
  line-height: 2;
}

.top-interior-nav{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 62px;
}
.top-interior-nav-link{
  max-width: 504px;
  width: 49%;
  margin-top: 56px;
}
.top-interior-nav-link-top,
.top-interior-nav-link-top-02{
  margin-top: 0;
}
.top-interior-nav-bottom{
  display: flex;
  justify-content: space-between;
  margin-top: 8px;
}
.top-interior-nav-txt{
  margin-top: 32px;
}
.top-interior-nav-detail{
  font-size: 20px;
  line-height: 1.6;
}
.top-interior-nav-more{
  margin-top: 6px;
  font-size: 16px;
  color: #7B7B7B;
  text-decoration: underline;
}
.top-interior-nav-logo{
  width: 120px;
}

.top-staff-contents{
  margin-top: 70px;
  padding-top: 50px;
}
.top-staff-ttl{
  text-align: center;
}
.top-staff-ttl h2{
  font-size: 36px;
  letter-spacing: 0.15em;
}
.top-staff-ttl p{
  padding-top: 24px;
  font-size: 18px;
  letter-spacing: 0.05em;
  line-height: 2;
}

.top-staff-nav{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 72px;
}
.top-staff-nav-link{
  max-width: 246px;
  width: 21.6%;
  margin-top: 52px;
}
.top-staff-nav-link:first-child,
.top-staff-nav-link:nth-child(2),
.top-staff-nav-link:nth-child(3),
.top-staff-nav-link:nth-child(4){
  margin-top: 0;
}
.top-staff-nav-txt{
  margin-top: 16px;
  font-size: 16px;
  line-height: 1.6;
}

.footer-interior{
  margin: 120px auto 0;
  padding-bottom: 96px;
  background-color: #E3E0D6;
}
.footer-interior-nav{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  max-width: 1080px;
  margin: 0 auto;
  padding-top: 96px;
}
.footer-interior-nav li {
  position: relative;
  padding-right: 16px;
}
.footer-interior-nav li::before{
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  content: "";
  background-image: url(../img/footer-interior-line02.png);
  width: 2px;
  height: 64px;
  background-size: cover;
}
.footer-interior-nav li:after{
  position: absolute;
  bottom: 0;
  left: 0;
  content: "";
  background-image: url(../img/footer-interior-line01.png);
  width: 342px;
  height: 2px;
  background-size: cover;
}
.footer-interior-nav li:nth-child(3n){
  padding-right: 0;
}
.footer-interior-nav li:nth-child(3n)::before{
  position: static;
  content: "";
  background-image: none;
}
.footer-interior-nav li a{
  display: inline-block;
  width: 340px;
  margin: 10px 0;
  padding: 24px 0;
  font-size: 14px;
  text-align: center;
}
.footer-interior-nav li span{
  position: absolute;
  top: 50%;
  right: 18px;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-top: 8px solid transparent;
  border-left: 10px solid black;
  border-bottom: 8px solid transparent;
}
.footer-interior-nav li:nth-child(3n) span{
  right: 2px;
}
.footer-interior-nav li .page-arrow{
  transform: translateY(-50%) rotate(-90deg);
}

.footer-interior .banner-gift{
  max-width: 920px;
  width: 85%;
  margin: 54px auto 0;
}
.contents-nav{
  margin-top: 0;
}
@media screen and (max-width: 1100px) {
  .footer-interior-nav{
    display: block;
    width: 85%;
    margin: 0 auto;
    padding-top: 96px;
  }
  .footer-interior-nav li {
    position: relative;
    padding-right: 0;
  }
  .footer-interior-nav li::before{
    position: sticky;
    top: 0;
    right: 0;
    transform: none;
    content: "";
    background-image: none;
  }
  .footer-interior-nav li:after{
    position: absolute;
    bottom: 0;
    left: 0;
    content: "";
    background-image: url(../img/footer-interior-line03.png);
    width: 100%;
    height: 3px;
    background-size: cover;
  }
  .footer-interior-nav li a {
    display: inline-block;
    width: 100%;
    margin: 4px 0;
    padding: 14px 0;
    font-size: 14px;
    text-align: left;
  }
  .footer-interior-nav li span {
    right: 10px;
  }
  .footer-interior-nav li:nth-child(3n) span {
    right: 10px;
  }
}
@media screen and (max-width: 767px) {
  .main-ttl h1{
    width: 58.667vw;
    margin: 0 auto;
    padding: 4.8vw 0;
  }  
  .top-contents{
    max-width: 89.334vw;
    margin: 7.46667vw auto 0;
    padding: 0;
  }
  .top-contents .banner-gift{
    max-width: 122.667vw;
    margin: 0 auto;
  }
  .top-interior-contents{
    margin: 12.8vw auto 0;
  }
  .top-interior-ttl h2{
    font-size: 5.333vw;
  }
  .top-interior-ttl p{
    padding-top: 4.267vw;
    font-size: 3.733vw;
    letter-spacing: 0.05em;
    line-height: 2;
  }
  
  .top-interior-nav{
    display: block;
    margin-top: 6.667vw;
  }
  .top-interior-nav-link{
    max-width: none;
    width: 100%;
    margin-top: 8.533vw;
  }
  .top-interior-nav-link-top{
    margin-top: 6.667vw;
  }
  .top-interior-nav-link-top-02{
    margin-top: 8.533vw;
  }
  .top-interior-nav-bottom{
    display: flex;
    justify-content: space-between;
    margin-top: 4.267vw;
  }
  .top-interior-nav-txt{
    margin-top: 0;
  }
  .top-interior-nav-detail{
    font-size: 3.733vw;
    line-height: 1.6;
  }
  .top-interior-nav-more{
    margin-top: 2.667vw;
    font-size: 3.2vw;
  }
  .top-interior-nav-logo{
    width: 20vw;
  }
  
  .top-staff-contents{
    margin-top: 9.334vw;
    padding-top: 6.6667vw;
  }
  .top-staff-ttl{
    text-align: center;
  }
  .top-staff-ttl h2{
    font-size: 5.333vw;
    letter-spacing: 0.15em;
  }
  .top-staff-ttl p{
    padding-top: 4.267vw;
    font-size: 3.733vw;
    letter-spacing: 0.05em;
    line-height: 2;
  }
  
  .top-staff-nav{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: 7.467vw;
  }
  .top-staff-nav-link,
  .top-staff-nav-link:nth-child(3),
  .top-staff-nav-link:nth-child(4){
    max-width: none;
    width: 47.612%;
    margin-top: 7.467vw;
  }
  .top-staff-nav-link:first-child,
  .top-staff-nav-link:nth-child(2){
    margin-top: 0;
  }
  .top-staff-nav-txt{
    margin-top: 2.133vw;
    font-size: 3.2vw;
    line-height: 1.6;
  }
  
  .footer-interior{
    margin: 16vw auto 0;
    padding-bottom: 12.8vw;
    background-color: #E3E0D6;
  }
  .footer-interior-nav{
    display: block;
    width: 89.334vw;
    margin: 0 auto;
    padding-top: 9.6vw;
  }
  .footer-interior-nav li {
    position: relative;
    padding-right: 0;
  }
  .footer-interior-nav li::before{
    position: sticky;
    top: 0;
    right: 0;
    transform: none;
    content: "";
    background-image: none;
  }
  .footer-interior-nav li:after{
    position: absolute;
    bottom: 0;
    left: 0;
    content: "";
    background-image: url(../img/footer-interior-line03.png);
    width: 100%;
    height: 2px;
    background-size: cover;
  }
  .footer-interior-nav li a {
    display: inline-block;
    width: 100%;
    margin: 0 0;
    padding: 4.26667vw 0 3.2vw;
    font-size: 3.067vw;
    text-align: left;
  }
  .footer-interior-nav li span {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-top: 1.3334vw solid transparent;
    border-left: 1.6vw solid black;
    border-bottom: 1.3334vw solid transparent;
  }
  .footer-interior-nav li:nth-child(3n) span {
    right: 0;
  }  
  .footer-interior .banner-gift{
    width: 89.334vw;
    margin: 9.6vw auto 0;
  }
  .contents-nav{
    margin-top: 0;
  }
}

/* interior01 */

/* @media (min-width: 769px) {
  .main-contents a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
  }
  .main-contents a[href*="tel:"]:hover{
    opacity: 1;
  }
}

.interior-contents-wrapper{
  max-width: 920px;
  width: 90%;
  margin: 0 auto 0;
  padding-top: 46px;
}
.interior-contents{
  margin-top: 110px;
  padding-top: 50px;
}
.interior-contents-top{
  margin-top: 0;
  padding-top: 50px;
}
.interior-contents .interior-ttl{
  text-align: center;
}
.interior-contents .interior-ttl h2{
  font-size: 36px;
  letter-spacing: 0.15em;
}
.interior-contents .interior-ttl p{
  margin-top: 24px;
  font-size: 18px;
  letter-spacing: 0.05em;
  line-height: 1.6;
}
.interior-contents .interior-img{
  margin-top: 56px;
}
.interior-contents .interior-img-flex{
  display: flex;
  justify-content: space-between;
  margin-top: 16px;
}
.interior-contents .interior-img-flex p{
  max-width: 452px;
  width: 49.131%;
}
.interior-contents .interior-txt{
  margin-top: 40px;
  font-size: 16px;
  line-height: 1.6;
}
.interior-contents .interior-spec{
  margin-top: 14px;
  font-size: 14px;
  line-height: 1.8;
  color: #7B7B7B;
}
.interior-contents .interior-detail{
  display: flex;
  margin-top: 32px;
  padding-top: 32px;
  border-top: 1px solid #7B7B7B;
}
.interior-contents .interior-detail .interior-detail-txt{
  width: 385px;
  margin-right: 16px;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
}
.interior-contents .interior-detail .interior-brand{
  font-weight: 700;
}
.interior-contents .interior-detail .interior-place{
  padding-top: 6px;
}
.interior-contents .interior-detail .interior-tel{
  padding-top: 2px;
}
.interior-contents .interior-detail .interior-logo{
  width: 120px;
  margin-right: 48px;
}
.interior-contents .interior-detail .interior-shop{
  width: 320px;
  padding-top: 32px;
}
.interior-contents .interior-staff{
  max-width: 720px;
  margin: 72px auto 0;
}
.footer-interior01{
  margin-top: 160px;
}

@media screen and (max-width: 767px) {
  .interior-contents-wrapper{
    max-width: none;
    width: 89.334%;
    margin: 0 auto 0;
    padding-top: 6.13334vw;
  }
  .interior-contents{
    margin-top: 9.3334vw;
    padding-top: 6.6667vw;
  }
  .interior-contents-top{
    margin-top: 0;
    padding-top: 6.6667vw;
  }
  .interior-contents .interior-ttl{
    text-align: center;
  }
  .interior-contents .interior-ttl h2{
    font-size: 5.333vw;
  }
  .interior-contents .interior-ttl p{
    margin-top: 4.267vw;
    font-size: 3.733vw;
  }
  .interior-contents .interior-img{
    margin-top: 7.467vw;
  }
  .interior-contents .interior-img-flex{
    display: block;
    margin-top: 0;
  }
  .interior-contents .interior-img-flex p{
    max-width: none;
    width: 100%;
    margin-top: 2.133vw;
  }
  .interior-contents .interior-txt{
    margin-top: 6.933vw;
    font-size: 3.733vw;
    line-height: 1.6;
  }
  .interior-contents .interior-spec{
    margin-top: 4.267vw;
    font-size: 3.2vw;
    line-height: 1.6;
  }
  .interior-contents .interior-detail{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: 7.467vw;
    padding-top: 5.333vw;
    border-top: 1px solid #7B7B7B;
  }
  .interior-contents .interior-detail .interior-detail-txt{
    width: 65.067vw;
    margin-right: 2.133vw;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 3.2vw;
    font-weight: 400;
    line-height: 1.6;
  }
  .interior-contents .interior-detail .interior-brand{
    font-weight: 700;
  }
  .interior-contents .interior-detail .interior-place{
    padding-top: 0.8vw;
  }
  .interior-contents .interior-detail .interior-tel{
    padding-top: 0.267vw;
  }
  .interior-contents .interior-detail .interior-logo{
    width: 20vw;
    margin-right: 0;
  }
  .interior-contents .interior-detail .interior-shop{
    width: 53.333vw;
    margin: 0 auto;
    padding-top: 4.267vw;
  }
  .interior-contents .interior-staff{
    max-width: none;
    margin: 9.6vw auto 0;
  }
  .footer-interior01{
    margin-top: 21.333vw;
  }
} */

/* interior02 */

/* .interior-contents .interior-small-rooms{
  width: 280.5px;
  margin: 0 auto;
}
#interior02 .interior-contents .interior-ttl h2 {
  padding-top: 50px;
}
.footer-interior02{
  margin-top: 160px;
}
@media screen and (max-width: 767px) {
  .interior-contents .interior-small-rooms{
    width: 42.6667vw;
    margin: 0 auto;
  }
  #interior02 .interior-contents .interior-ttl h2 {
    padding-top: 4.267vw;
  }
  .footer-interior02{
    margin-top: 21.333vw;
  }
} */


/* goods */

/* .goods-contents-wrapper{
  max-width: 920px;
  width: 90%;
  margin: 96px auto 0;
}
.goods-page-ttl{
  text-align: center;
}
.goods-page-ttl h2{
  font-size: 36px;
  letter-spacing: 0.15em;
}
.goods-page-ttl p{
  margin-top: 24px;
  font-size: 18px;
  letter-spacing: 0.05em;
  line-height: 1.6;
}
.goods-contents{
  margin-top: 120px;
}
.goods-contents-top{
  margin-top: 96px;
}
.goods-contents .goods-logo{
  width: 120px;
  margin: 0 auto;
}
.goods-contents .goods-ttl{
  margin: 8px auto 0;
  font-size: 30px;
  text-align: center;
  letter-spacing: 0.075em;
}
.goods-contents .goods-img{
  margin: 40px auto 0;
  width: 100%;
}
.goods-contents .goods-txt{
  margin-top: 40px;
  font-size: 16px;
  line-height: 1.6;
}
.goods-contents .goods-spec{
  margin-top: 14px;
  font-size: 14px;
  line-height: 1.8;
  color: #7B7B7B;
}
.goods-contents .goods-detail{
  display: flex;
  justify-content: space-between;
  margin-top: 32px;
  padding-top: 32px;
  border-top: 1px solid #7B7B7B;
}
.goods-contents .goods-detail .goods-detail-txt{
  width: 538px;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
}
.goods-contents .goods-detail .goods-brand{
  font-weight: 700;
}
.goods-contents .goods-detail .goods-place{
  padding-top: 6px;
}
.goods-contents .goods-detail .goods-tel{
  padding-top: 2px;
}
.goods-contents .goods-detail .goods-shop{
  width: 320px;
  margin-right: 30px;
}
.footer-goods{
  margin-top: 160px;
}

@media screen and (max-width: 767px) {
  .goods-contents-wrapper {
    max-width: none;
    width: 89.334%;
    margin: 12.8vw auto 0;
  }
  .goods-page-ttl h2 {
    font-size: 5.333vw;
  }
  .goods-page-ttl p {
    margin-top: 4.267vw;
    font-size: 3.733vw;
  }
  .goods-contents {
    margin-top: 9.6vw;
  }
  .goods-contents-top {
    margin-top: 7.467vw;
  }
  .goods-contents .goods-logo {
    width: 26.667vw;
    margin: 0 auto;
  }
  .goods-contents .goods-ttl {
    margin: 1.06667vw auto 0;
    font-size: 4.267vw;
    text-align: center;
    letter-spacing: 0.05em;
  }
  .goods-contents .goods-img {
    margin: 7.4667vw auto 0;
    width: 100%;
  }
  .goods-contents .goods-txt {
    margin-top: 7.467vw;
    font-size: 3.733vw;
    line-height: 1.6;
  }
  .goods-contents .goods-spec {
    margin-top: 4.267vw;
    font-size: 3.2vw;
    line-height: 1.6;
    color: #7B7B7B;
  }
  .goods-contents .goods-detail {
    display: block;
    margin-top: 7.467vw;
    padding-top: 5.333vw;
    border-top: 1px solid #7B7B7B;
  }
  .goods-contents .goods-detail .goods-detail-txt {
    width: 100%;
    font-size: 3.2vw;
  }
  .goods-contents .goods-detail .goods-shop {
    width: 53.333vw;
    margin: 8vw auto 0;
  }
  .footer-goods{
    margin-top: 16vw;
  }
} */

/* column */

/* .column-contents-wrapper{
  max-width: 1080px;
  width: 90%;
  margin: 96px auto 0;
}
.column-staff-ttl{
  font-size: 36px;
  letter-spacing: 0.15em;
  text-align: center;
}
.column-main-img{
  margin-top: 60px;
}
.column-ttl-wrapper{
  margin-top: 56px;
  text-align: center;
  font-weight: 600;
  letter-spacing: 0.15em;
}
.column-ttl-wrapper .column-ttl{
  font-size: 36px;
}
.column-ttl-wrapper .column-person{
  margin-top: 16px;
  font-size: 20px;
}
.column-contents-inner{
  max-width: 800px;
  width: 90%;
  margin: 96px auto 0;
}
.column-contents-txt01{
  margin-top: 56px;
  font-size: 16px;
  line-height: 1.8;
}
.column-contents-txt01 p{
  margin-top: 40px;
  text-indent: 1em;
}
.column-contents-img02{
  margin-top: 96px;
}
.column-contents-txt02{
  margin-top: 56px;
  font-size: 16px;
  line-height: 1.8;
}
.column-contents-txt02 p{
  margin-top: 30px;
  text-indent: 1em;
}
.column-contents-txt02 p:first-child{
  font-size: 24px;
  text-indent: 0;
}
.column-detail{
  max-width: 1080px;
  margin: 120px auto 0;
  padding-top: 16px;
  border-top: 1px solid #707070;
}
.column-detail-inner{
  display: flex;
  justify-content: space-between;
  max-width: 920px;
  margin: 0 auto;
}
.column-detail-inner .column-icon{
  max-width: 160px;
}
.column-detail-inner .column-detail-txt{
  width: 384px;
  margin-left: 12px;
  padding-top: 32px;
  font-family: 'Noto Sans JP', sans-serif;
  line-height: 1.6;
}
.column-detail-inner .column-detail-txt p{
  padding-top: 4px;
  font-size: 16px;
  font-weight: 400;
}
.column-detail-inner .column-detail-txt p:first-child{
  padding-top: 0;
  font-size: 20px;
  font-weight: 700;
}
.column-detail-inner .column-detail-txt p:nth-child(2){
  padding-top: 6px;
}
.column-detail-inner .column-shopinfo{
  max-width: 320px;
  margin-top: 54px;
}
.column-detail-inner-attention{
  max-width: 940px;
}
.column-detail-inner .column-detail-txt-attention{
  width: 420px;
  margin-left: 6px;
}


@media screen and (max-width: 767px) {
  .column-contents-wrapper{
    max-width: none;
    width: 100%;
    margin: 0 auto 0;
  }
  .column-staff-ttl{
    font-size: 5.333vw;
    margin-top: 8vw;
  }
  .column-main-img{
    margin-top: 8vw;
  }
  .column-ttl-wrapper{
    width: 89.334%;
    margin: 7.4667vw auto 0;
  }
  .column-ttl-wrapper .column-ttl{
    font-size: 5.333vw;
  }
  .column-ttl-wrapper .column-person{
    margin-top: 2.133vw;
    font-size: 3.2vw;
  }
  .column-contents-inner{
    max-width: none;
    width: 89.334%;
    margin: 9.6vw auto 0;
  }
  .column-contents-txt01{
    margin-top: 7.467vw;
    font-size: 3.733vw;
    line-height: 1.8;
  }
  .column-contents-txt01 p{
    margin-top: 6.133vw;
    text-indent: 1em;
  }
  .column-contents-img02{
    margin-top: 15.2vw;
  }
  .column-contents-txt02{
    margin-top: 7.467vw;
    font-size: 3.733vw;
    line-height: 1.8;
  }
  .column-contents-txt02 p{
    margin-top: 5.333vw;
    text-indent: 1em;
  }
  .column-contents-txt02 p:first-child{
    font-size: 4.267vw;
    text-indent: 0;
  }
  .column-contents-txt02 p:nth-child(2){
    margin-top: 4.267vw;
  }
  .column-detail{
    max-width: none;
    width: 89.334%;
    margin: 12vw auto 0;
    padding-top: 5.333vw;
    border-top: 1px solid #707070;
  }
  .column-detail-inner{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    max-width: none;
    margin: 0 auto;
  }
  
  .column-detail-inner .column-icon{
    max-width: 20vw;
    order: 2;
  }
  .column-detail-inner .column-detail-txt{
    width: 65.067vw;
    margin-left: 0;
    padding-top: 0;
    font-family: 'Noto Sans JP', sans-serif;
    line-height: 1.6;
    order: 1;
  }
  .column-detail-inner .column-detail-txt p{
    padding-top: 0.533vw;
    font-size: 3.2vw;
    font-weight: 400;
  }
  .column-detail-inner .column-detail-txt p:first-child{
    padding-top: 0;
    font-size: 3.2vw;
    font-weight: 700;
  }
  .column-detail-inner .column-detail-txt p:nth-child(2){
    padding-top: 1.867vw;
  }
  .column-detail-inner .column-shopinfo{
    max-width: 53.333vw;
    margin: 4.2667vw auto 0;
    order: 3;
  }
  .column-detail-inner-attention{
    max-width: none;
  }
  .column-detail-inner .column-detail-txt-attention{
    width: 65.067vw;
    margin-left: 0;
  }
} */


/* gift */
/* 
.gift-main-ttl h1 {
  width: 438px;
  margin: 0 auto;
  padding: 40px 0;
}
#gift .top-contents .banner-interior {
  max-width: 920px;
  margin: 0 auto;
}
#gift .top-gift-contents{
  margin-top: 120px;
}
#gift .top-gift-ttl{
  font-size: 36px;
  letter-spacing: 0.15em;
  text-align: center;
}
#gift .top-gift-nav{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 56px;
}
#gift .top-gift-nav-link{
  max-width: 246px;
  width: 21.6%;
  margin-top: 52px;
}
#gift .top-gift-nav-link:first-child,
#gift .top-gift-nav-link:nth-child(2),
#gift .top-gift-nav-link:nth-child(3),
#gift .top-gift-nav-link:nth-child(4){
  margin-top: 0;
}
#gift .top-gift-nav-txt{
  margin-top: 16px;
  font-size: 16px;
  line-height: 1.6;
  letter-spacing: 0.05em;
}
#gift .top-gift-nav-all{
  width: 416px;
  margin: 72px auto 0;
  text-align: center;
}
#gift .top-gift-nav-all a{
  display: block;
  position: relative;
  font-size: 18px;
  padding: 16px 0;
  background-color: #E3E0D6;
}
#gift .top-gift-nav-all a span {
  position: absolute;
  top: 50%;
  right: 16px;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-top: 8px solid transparent;
  border-left: 10px solid black;
  border-bottom: 8px solid transparent;
}

.footer-gift{
  margin: 160px auto 0;
  padding-bottom: 96px;
  background-color: #E3E0D6;
}
.footer-gift-nav{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  max-width: 1080px;
  margin: 0 auto;
  padding-top: 86px;
}
.footer-gift-nav li {
  position: relative;
  padding-right: 18px;
}
.footer-gift-nav li::before{
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  content: "";
  background-image: url(../img/gift/footer-gift-line02.png);
  width: 2px;
  height: 63px;
  background-size: cover;
}
.footer-gift-nav li:after{
  position: absolute;
  bottom: 0;
  left: 0;
  content: "";
  background-image: url(../img/gift/footer-gift-line01.png);
  width: 248px;
  height: 2px;
  background-size: cover;
}
.footer-gift-nav li:nth-child(4n){
  padding-right: 0;
}
.footer-gift-nav li:nth-child(4n)::before{
  position: static;
  content: "";
  background-image: none;
}
.footer-gift-nav li a{
  display: inline-block;
  width: 246px;
  margin: 6px 0;
  padding: 12px 0;
  font-size: 14px;
  text-align: center;
  line-height: 1.6;
  letter-spacing: 0.05em;
}
.footer-gift-nav li span{
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-top: 8px solid transparent;
  border-left: 10px solid black;
  border-bottom: 8px solid transparent;
}
.footer-gift-nav li:nth-child(4n) span{
  right: 4px;
}
.footer-gift-nav li .page-arrow{
  transform: translateY(-50%) rotate(-90deg);
}
.footer-gift .banner-interior{
  max-width: 920px;
  width: 85%;
  margin: 56px auto 0;
} */

/* .u-br_sp{
  display: none !important;
}
.u-br_pc{
  display : block !important;
}
@media screen and (max-width: 1100px) {
  .u-br_sp{
    display : block !important;
  }
  .u-br_pc{
    display: none !important;
  }

  .footer-gift-nav{
    display: block;
    width: 85%;
    margin: 0 auto;
    padding-top: 96px;
  }
  .footer-gift-nav li {
    position: relative;
    padding-right: 0;
  }
  .footer-gift-nav li::before{
    position: sticky;
    top: 0;
    right: 0;
    transform: none;
    content: "";
    background-image: none;
  }
  .footer-gift-nav li:after{
    position: absolute;
    bottom: 0;
    left: 0;
    content: "";
    background-image: url(../img/gift/footer-gift-line03.png);
    width: 100%;
    height: 3px;
    background-size: cover;
  }
  .footer-gift-nav li a {
    display: inline-block;
    width: 100%;
    margin: 4px 0;
    padding: 14px 0;
    font-size: 14px;
    text-align: left;
  }
  .footer-gift-nav li span {
    right: 10px;
  }
  .footer-gift-nav li:nth-child(4n) span {
    right: 10px;
  }
}

@media screen and (max-width: 767px) {
  .gift-main-ttl h1 {
    width: 43.867vw;
    margin: 0 auto;
    padding: 4.8vw 0;
  }  
  #gift .top-contents{
    max-width: 89.334vw;
    margin: 7.46667vw auto 0;
    padding: 0;
  }
  #gift .top-contents .banner-gift{
    max-width: 122.667vw;
    margin: 0 auto;
  }
  #gift .top-gift-contents{
    margin: 16vw auto 0;
  }
  #gift .top-gift-contents-top{
    margin: 12.8vw auto 0;
  }
  #gift .top-gift-ttl h2{
    font-size: 5.333vw;
  }
  #gift .top-gift-ttl p{
    padding-top: 4.267vw;
    font-size: 3.733vw;
    letter-spacing: 0.05em;
    line-height: 2;
  }
  
  #gift .top-gift-ttl{
    font-size: 5.3334vw;
    text-align: center;
  }
  #gift .top-gift-ttl h2{
    font-size: 5.333vw;
    letter-spacing: 0.15em;
  }
  #gift .top-gift-ttl p{
    padding-top: 4.267vw;
    font-size: 3.733vw;
    letter-spacing: 0.05em;
    line-height: 2;
  }
  
  #gift .top-gift-nav{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: 7.467vw;
  }
  #gift .top-gift-nav-link,
  #gift .top-gift-nav-link:nth-child(3),
  #gift .top-gift-nav-link:nth-child(4){
    max-width: none;
    width: 47.612%;
    margin-top: 7.467vw;
  }
  #gift .top-gift-nav-link:first-child,
  #gift .top-gift-nav-link:nth-child(2){
    margin-top: 0;
  }
  #gift .top-gift-nav-txt{
    margin-top: 2.133vw;
    font-size: 2.9334vw;
    line-height: 1.6;
  }
  #gift .top-gift-nav-all {
    width: 74.667vw;
    margin: 9.6vw auto 0;
    text-align: center;
  }
  #gift .top-gift-nav-all a {
    font-size: 3.2vw;
    padding: 4.2667vw 0;
  }
  #gift .top-gift-nav-all a span {
    right: 2.1334vw;
    border-top: 1.3334vw solid transparent;
    border-left: 1.6vw solid black;
    border-bottom: 1.3334vw solid transparent;
  }
  
  .footer-gift{
    margin: 16vw auto 0;
    padding-bottom: 12.8vw;
    background-color: #E3E0D6;
  }
  .footer-gift-nav{
    display: block;
    width: 89.334vw;
    margin: 0 auto;
    padding-top: 9.6vw;
  }
  .footer-gift-nav li {
    position: relative;
    padding-right: 0;
  }
  .footer-gift-nav li::before{
    position: sticky;
    top: 0;
    right: 0;
    transform: none;
    content: "";
    background-image: none;
  }
  .footer-gift-nav li:after{
    position: absolute;
    bottom: 0;
    left: 0;
    content: "";
    background-image: url(../img/gift/footer-gift-line03.png);
    width: 100%;
    height: 2px;
    background-size: cover;
  }
  .footer-gift-nav li a {
    display: inline-block;
    width: 100%;
    margin: 0 0;
    padding: 4.26667vw 0 3.2vw;
    font-size: 3.067vw;
    text-align: left;
  }
  .footer-gift-nav li span {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-top: 1.3334vw solid transparent;
    border-left: 1.6vw solid black;
    border-bottom: 1.3334vw solid transparent;
  }
  .footer-gift-nav li:nth-child(4n) span {
    right: 0;
  }  
  .footer-gift .banner-gift{
    width: 89.334vw;
    margin: 9.6vw auto 0;
  }

} */

/* gift01 */

/* .gift-contents-wrapper{
  max-width: 940px;
  margin: 0 auto;
  padding: 0 10px;
}
.gift-contents{
  margin-top: 64px;
  padding-top: 96px;
}
.gift-contents-top{
  margin-top: 0;
  padding-top: 96px;
}
.gift-contents-ttl{
  text-align: center;
}
.gift-contents-ttl h2{
  font-size: 36px;
}
.gift-contents-ttl p{
  margin-top: 24px;
  font-size: 18px;
  line-height: 1.8;
}

.gift-goods{
  margin-top: 70px;
  padding-top: 50px;
}
.gift-goods-top{
  margin-top: 46px;
  padding-top: 50px;
}
.gift-lead .gift-icon{
  width: 120px;
  margin: 0 auto;
}
.gift-lead .gift-ttl{
  margin-top: 8px;
  font-size: 30px;
  text-align: center;
  letter-spacing: 0.075em;
}
.gift-lead .gift-img{
  margin-top: 40px;
}
.gift-goods-introduce{
  display: flex;
  justify-content: space-between;
  margin-top: 40px;
}
.gift-goods-introduce .gift-goods-txt{
  width: 688px;
  line-height: 1.8;
}
.gift-goods-introduce .gift-goods-txt p{
  font-size: 16px;
}
.gift-goods-introduce .gift-goods-txt ul{
  margin-top: 12px;
  font-size: 14px;
  color: #7B7B7B;
}
.gift-goods-introduce .gift-goods-img{
  width: 200px;
}
.gift-detail{
  display: flex;
  justify-content: space-between;
  margin-top: 32px;
  padding-top: 32px;
  border-top: 1px solid #7B7B7B;
}
.gift-detail-txt{
  width: 538px;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 16px;
  line-height: 1.6;
  letter-spacing: 0.025em;
  font-weight: 400;
}
.gift-detail-txt .gift-brand{
  font-weight: 700;
}
.gift-detail-txt .gift-place{
  padding-top: 6px;
}
.gift-detail-txt .gift-tel{
  padding-top: 2px;
}
.gift-shop{
  max-width: 320px;
  margin-right: 30px;
}

@media screen and (max-width: 767px) {
  .gift-contents-wrapper{
    max-width: none;
    width: 89.334%;
    margin: 0 auto;
    padding: 0;
  }
  .gift-contents{
    margin-top: 3.2vw;
    padding-top: 12.8vw;
  }
  .gift-contents-top{
    margin-top: 0;
    padding-top: 12.8vw;
  }
  .gift-contents-ttl{
    text-align: center;
  }
  .gift-contents-ttl h2{
    font-size: 5.333vw;
  }
  .gift-contents-ttl p{
    margin-top: 4.267vw;
    font-size: 3.733vw;
    line-height: 1.8;
  }
  
  .gift-goods{
    margin-top: 2.9334vw;
    padding-top: 6.6667vw;
  }
  .gift-goods-top{
    margin-top: 0.8vw;
    padding-top: 6.6667vw;
  }
  .gift-lead .gift-icon{
    width: 26.667vw;
    margin: 0 auto;
  }
  .gift-lead .gift-ttl{
    margin-top: 1.067vw;
    font-size: 4.267vw;
    text-align: center;
    letter-spacing: 0.075em;
  }
  .gift-lead .gift-img{
    margin-top: 5.333vw;
  }
  .gift-goods-introduce{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-top: 5.333vw;
  }
  .gift-goods-introduce .gift-goods-txt{
    width: auto;
    line-height: 1.8;
  }
  .gift-goods-introduce .gift-goods-txt p{
    width: 100%;
    font-size: 3.733vw;
    line-height: 1.6;
  }
  .gift-goods-introduce .gift-goods-txt .gift-goods-txt-flex-sp{
    display: flex;
    justify-content: space-between;
    margin-top: 4.267vw;
  }
  .gift-goods-introduce .gift-goods-txt ul{
    width: 59.467vw;
    margin-top: 0;
    font-size: 3.2vw;
    color: #7B7B7B;
    line-height: 1.6;
  }
  .gift-goods-introduce .gift-goods-txt .gift-goods-img{
    width: 26.667vw;
  }
  .gift-detail{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-top: 7.467vw;
    padding-top: 5.333vw;
    border-top: 1px solid #7B7B7B;
  }
  .gift-detail-txt{
    width: 100%;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 3.2vw;
    line-height: 1.6;
    letter-spacing: 0.025em;
    font-weight: 400;
  }
  .gift-detail-txt .gift-brand{
    font-weight: 700;
  }
  .gift-detail-txt .gift-place{
    padding-top: 1.333vw;
  }
  .gift-detail-txt .gift-tel{
    padding-top: 0.267vw;
  }
  .gift-shop{
    max-width: 53.333vw;
    margin: 7.7334vw auto 0;
  }
} */

/* gift02 */

/* #gift02 .gift-goods-introduce {
  display: block;
  margin-top: 40px;
}
#gift02 .gift-goods-introduce .gift-goods-txt {
  width: 100%;
}
@media screen and (max-width: 767px) {
  #gift02 .gift-goods-introduce {
    display: block;
    margin-top: 5.333vw;
  }
  #gift02 .gift-goods-introduce .gift-goods-txt {
    width: 100%;
  }
  #gift02 .gift-goods-introduce .gift-goods-txt ul {
    margin-top: 3.4667vw;
  }
} */


/* js-lozad
----------------------------------------------------------------- */
.js-lozad {
  opacity: 0;
  -webkit-transform: translateY(20px);
      -ms-transform: translateY(20px);
          transform: translateY(20px);
  -webkit-transition: opacity 1s, -webkit-transform 1s;
  transition: opacity 1s, -webkit-transform 1s;
  transition: opacity 1s, transform 1s;
  transition: opacity 1s, transform 1s, -webkit-transform 1s;
}

.js-lozad--show {
  opacity: 1;
  -webkit-transform: translateY(0);
      -ms-transform: translateY(0);
          transform: translateY(0);
}

/* c-pagetop
----------------------------------------------------------------- */
.c-pagetop {
  display: none;
  width: 38px;
  height: 38px;
  display: block;
  position: fixed;
  z-index: 999;
  bottom: 5.333vw;
  right: 5.333vw;
}

@media screen and (min-width: 769px) {
  .c-pagetop {
    bottom: 3.703vw;
    right: 3.703vw;
  }
}

@media screen and (min-width: 1081px) {
  .c-pagetop {
    bottom: 40px;
    right: 40px;
  }
}




/* 20240123 interior2024SS */

:root {

  /* var color */
  --c-ffffff: 255, 255, 255;
  --c-000000: 0, 0, 0;
  --c-222222: 34, 34, 34;
  --c-333333: 51, 51, 51;
  --c-f5eee5: 245, 238, 229;
  --c-bac5bc: 186, 197, 188;
  --c-181000: 24, 16, 0;
  --c-707070: 112, 112, 112;
  --c-e5d8c8: 229, 216, 200;
  --c-f4f2d4: 244, 242, 212;
  --c-f2f0ed: 242, 240, 237;
  --c-535353: 83, 83, 83;
  --c-eae7e2: 234, 231, 226;
  --c-f6f4b0: 246, 244, 176;

  /* var font */
  --f-ntj: 'Noto Sans JP', sans-serif;
  --f-sg: 'Sawarabi Gothic', sans-serif;
  --f-sm: 'Shippori Mincho', serif;
  --f-smb: 'Shippori Mincho B1', serif;

}

/* fonts */
.f-ntj-r {
  font-family: var(--f-ntj);
  font-weight: 400;
}
.f-ntj-m {
  font-family: var(--f-ntj);
  font-weight: 500;
}
.f-ntj-b {
  font-family: var(--f-ntj);
  font-weight: 700;
}
.f-ntj-bl {
  font-family: var(--f-ntj);
  font-weight: 900;
}
.f-sg {
  font-family: var(--f-sg);
  font-weight: 400;
}
.f-sm-r {
  font-family: var(--f-sm);
  font-weight: 400;
}
.f-sm-m {
  font-family: var(--f-sm);
  font-weight: 500;
}
.f-sm-b {
  font-family: var(--f-sm);
  font-weight: 700;
}
.f-smb-r {
  font-family: var(--f-smb);
  font-weight: 400;
}
.f-smb-m {
  font-family: var(--f-smb);
  font-weight: 500;
}
.f-smb-b {
  font-family: var(--f-smb);
  font-weight: 700;
}

/* components */
.c-inner {
  margin-inline: auto;
  padding-inline: 50px;
  max-width: 1000px;
}
@media screen and (max-width: 750px) {
  .c-inner {
    margin-inline: auto;
    padding-inline: 0;
    max-width: none;
    width: 87.2%;
  }
}
.c-ls-zero {
  letter-spacing: 0;
}
.c-ls-minus {
  letter-spacing: -0.025em;
}
.mi-la {
  margin-inline: auto 0;
}
.mi-ra {
  margin-inline: 0 auto;
}


.contents-nav,
.breadcrumb,
.global-footer {
  position: relative;
  z-index: 1;
}
.global-footer {
  background: rgb(var(--c-ffffff));
}


.sp-video {
  width: 100%;
  display: block;
}
.pc-video {
  display: none;
}
@media screen and (min-width: 751px) {
  .sp-video {
    display: none;
  }
  .pc-video {
    width: 100%;
    display: block;
  }

}

.br-pc {
  display: block;
}
.br-sp {
  display: none;
}
@media screen and (max-width: 750px) {
  .br-pc {
    display: none;
  }
  .br-sp {
    display: block;
  }
}


.mv__video {
  width: 100%;
  height: 100%;
  vertical-align: bottom;
}
@media screen and (max-width: 750px) {

}

.lead {
  padding-block: 92px 100px;
  background: rgb(var(--c-f2f0ed));
  text-align: center;
  color: rgb(var(--c-222222));
}
.lead .lead__title {
  margin-inline: auto;
  width: fit-content;
  font-size: 36px;
  line-height: 1.944;
  letter-spacing: 0.4em;
}
.lead .lead__text {
  max-width: 700px;
  width: 70%;
  margin: 40px auto 0;
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.1em;
  text-align: left;
}
@media screen and (min-width: 1001px) and (max-width: 1280px) {

}
@media screen and (min-width: 751px) and (max-width: 1000px) {
  .lead {
    padding-block: 9.2vw 10vw;
  }
  .lead .lead__title {
    font-size: 3.6vw;
  }
  .lead .lead__text {
    font-size: 1.8vw;
  }
}
@media screen and (max-width: 750px) {
  .lead {
    padding-block: 13.33vw 13.33vw;
  }
  .lead .lead__title {
    font-size: 5.8667vw;
  }
  .lead .lead__text {
    width: 87.2%;
    margin-top: 1em;
    font-size: 4.267vw;
    line-height: 1.6;
    letter-spacing: 0.05em;;
  }
}


.anchor {
  padding-block: 54px 56px;
}
.anchor nav{
  max-width: 1000px;
  margin: auto;
}
.anchor .anchor__title {
  margin-inline: auto;
  max-width: 600px;
  width: 560%;
  height: auto;
}
.anchor .anchor__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 60px 50px;
  margin-top: 40px;
}
.anchor .anchor__list::after {
  content:"";
  display: block;
  width: 30%;
}
.anchor .anchor__list li {
  width: 30%;
}
.anchor .anchor__list li a {
  position: relative;
  display: flex;
  flex-direction: column;
  padding-bottom: 20px;
  border-bottom: 1px solid #A0A0A0;
  height: 100%;
  transition: all .3s;
}
.anchor .anchor__list li a:hover{
  opacity: 1;
}
.anchor .anchor__list li a .anchor__hover{
  display: none;
  position: absolute;
  top: 0;
  left: 0;
}
.anchor .anchor__list li a:hover .anchor__hover{
  display: block;
}
.anchor .anchor__list li a h3{
  margin-top: 20px;
}

.anchor .anchor__list li a .anchor__catch{
  font-size: 16px;
  letter-spacing: 0.1em;
}

.anchor .anchor__list li a .anchor__catch{  
  margin-top: 12px;
}

/* .anchor .anchor__list li a.anchor-bottom .anchor__catch{
  margin-top: auto;
} */

.anchor .anchor__list li a::after {
  content: '';
  position: absolute;
  right: 0;
  bottom: 9.5%;
  background: url(../img/anchor-arrow-next.svg) no-repeat;
  background-size: 100% auto;
  width: 20px;
  aspect-ratio: 20 / 12.5;
}
.anchor .anchor__list li a.anchor-bottom::after {
  content: '';
  position: absolute;
  right: 0;
  bottom: 7.5%;
  background: url(../img/anchor-arrow-under.svg) no-repeat;
  background-size: 100% auto;
  width: 12.5px;
  aspect-ratio: 12.5 / 20;
}


@media screen and (min-width: 1001px) and (max-width: 1280px) {
  .anchor nav{
    max-width: none;
    width: 90%;
    margin: auto;
  }
  .anchor .anchor__list{
    justify-content: flex-start;
  }

  .anchor .anchor__list li {
    width: calc(calc(100% - 100px) / 3);
  } 

}
@media screen and (min-width: 751px) and (max-width: 1000px) {
  .anchor {
    padding-block: 5.4vw 5.6vw;
  }
  .anchor nav{
    max-width: none;
    width: 90%;
    margin: auto;
  }
  .anchor .anchor__title {
    font-size: 1.6vw;
  }
  .anchor .anchor__list {
    gap: 40px 25px;
    margin-top: 4vw;
    justify-content: flex-start;
  }
  .anchor .anchor__list li {
    width: calc(calc(100% - 50px) / 3);
  }
  
  .anchor .anchor__list li a .anchor__catch{
    font-size: 1.8vw;
  }
  .anchor .anchor__list li a:hover .anchor__hover{
    display: none;
    opacity: 0;
  }
}
@media screen and (max-width: 750px) {
  .anchor {
    width: 87.2%;
    margin-inline: auto;
    padding-block: 16vw;
  }
  .anchor .anchor__title {
    width: 100%;
    font-size: 3.734vw;
  }
  .anchor .anchor__list {
    width: 80vw;
    margin-inline: auto;
    gap: 10.667vw 0;
    margin-top: 13.33vw;
  }
  .anchor .anchor__list::after {
    width: 46.032%;
  }
  .anchor .anchor__list li {
    width: 100%;
  }
  .anchor .anchor__list li a {
    padding-bottom: 5.333vw;
    width: 100%;
  }
  .anchor .anchor__list li a:hover .anchor__hover{
    display: none;
    opacity: 0;
  }
  .anchor .anchor__list li a figure{
    position: relative;
  }
  .anchor .anchor__list li a h3{
    margin-top: 5.333vw;
  }
  
  .anchor .anchor__list li a .anchor__catch{
    font-size: 4.2667vw;
  }
  
  .anchor .anchor__list li a:not(.anchor-bottom) .anchor__catch{  
    margin-top: 1em;
  }
  
  .anchor .anchor__list li a::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 7vw;
    background: url(../img/anchor-arrow-next.svg) no-repeat;
    background-size: 100% auto;
    width: 5.333vw;
    aspect-ratio: 20 / 12.5;
  }
  .anchor .anchor__list li a.anchor-bottom::after {
    content: '';
    position: absolute;
    right: 0;
    bottom: 7.5%;
    background: url(../img/anchor-arrow-under.svg) no-repeat;
    background-size: 100% auto;
    width: 12.5px;
    aspect-ratio: 12.5 / 20;
  }

  .anchor .anchor__list li a.anchor-bottom .anchor__catch{  
    margin-top: 8.8vw;
  }

  /* spのみ */

  .anchor .anchor__list li a figure::after{
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    aspect-ratio: 60 / 7;
  }

  .anchor .anchor__list li a.r0 figure::after{
    background: url('../img/anchor-sp-no00.png') no-repeat;
    background-size: cover;
  }

  .anchor .anchor__list li a.r1 figure::after{
    background: url('../img/anchor-sp-no01.png') no-repeat;
    background-size: cover;
  }

  .anchor .anchor__list li a.r2 figure::after{
    background: url('../img/anchor-sp-no02.png') no-repeat;
    background-size: cover;
  }

  .anchor .anchor__list li a.r3 figure::after{
    background: url('../img/anchor-sp-no03.png') no-repeat;
    background-size: cover;
  }

  .anchor .anchor__list li a.r4 figure::after{
    background: url('../img/anchor-sp-no04.png') no-repeat;
    background-size: cover;
  }

  .anchor .anchor__list li a.r5 figure::after{
    background: url('../img/anchor-sp-no05.png') no-repeat;
    background-size: cover;
  }

  .anchor .anchor__list li a.r6 figure::after{
    background: url('../img/anchor-sp-no06.png') no-repeat;
    background-size: cover;
  }

  .anchor .anchor__list li a.r7 figure::after{
    background: url('../img/anchor-sp-no07.png') no-repeat;
    background-size: cover;
  }

  .anchor .anchor__list li a.r8 figure::after{
    background: url('../img/anchor-sp-no08.png') no-repeat;
    background-size: cover;
  }

}


.rooms-bn-top{

}

.brand {

}
.brand .brand__item {
  padding: 100px 0 100px;
}
.brand .brand__item + .brand__item {
  border-top: 1px solid rgb(var(--c-000000));
}
.brand .brand__item .brand__top {
  display: flex;
  flex-direction: column;
  margin: auto;
  max-width: 1000px;
}
.brand .brand__item .brand__top .brand__head {
  max-width: 500px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 30px;
  margin: auto;
}
.brand .brand__item .brand__top .brand__head .name {
  display: flex;
  border-bottom: 1px solid rgb(var(--c-222222));
}
.brand .brand__item .brand__top .brand__head .name picture{
  width: 100%;
}
.brand .brand__item .brand__top .brand__head .mes {
  font-size: 27px;
  line-height: 1.55;
  letter-spacing: 0.15em;
  text-align: center;
}
.brand .brand__item .brand__top .brand__head .setting {
  padding: 10px 0;
  font-size: 14px;
  line-height: 1.55;
  letter-spacing: 0.05em;
  text-align: center;
  border-top: 1px solid rgb(var(--c-222222));
  border-bottom: 1px solid rgb(var(--c-222222));
}
.brand .brand__item .brand__top .text {
  margin-top: 30px;
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.05em;
  text-align: center;
}

.brand .brand__item .brand__bottom {
  display: flex;
  flex-direction: column;
  gap: 100px;
  margin-inline: auto;
  /* max-width: 1000px; */
  margin-top: 100px;
}
.brand .brand__item .brand__bottom .brand__thumb {
  max-width: 555px;
  width: 72.55%;
  margin-inline: auto;
}
.brand .brand__item .brand__bottom .brand__full {
  width: 750px;
  width: 98.04%;
  margin-inline: auto;
}

.brand .brand__item .brand__bottom .brand__slide {
  display: none;
}
.brand .brand__item .brand__bottom .brand__product {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 48px 0;
}

.brand .brand__item .brand__bottom .brand__product:not(.brand__ismyself) {
  max-width: 765px;
  margin-inline: auto;
}

.brand .brand__item .brand__bottom .brand__read {
  position: relative;
  max-width: 750px;
  width: 98%;
  margin-inline: auto;
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.05em;
}
.brand .brand__item .brand__bottom .brand__spec {
  position: relative;
  margin-top: 10px;
  padding: 40px 60px 25px 30px;
  box-sizing: border-box;
  font-size: 13px;
  line-height: 1.616;
  letter-spacing: 0.05em;
}
.brand .brand__item .brand__bottom .brand__spec::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  background: url('../img/bg_brand-spec_upper.svg') no-repeat;
  background-size: 100% auto;
  width: 70px;
  height: 70px;
}
.brand .brand__item .brand__bottom .brand__spec::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  background: url('../img/bg_brand-spec_lower.svg') no-repeat;
  background-size: 100% auto;
  width: 57px;
  height: 57px;
}
.brand .brand__item .brand__bottom .brand__desc .info {
  text-align: center;
}
.brand .brand__item .brand__bottom .brand__desc .info + p {
  margin-top: 80px;
  font-size: 13px;
}
.brand .brand__item .brand__bottom .brand__desc .info .shopname a {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 0 20px 0 0;
  border-bottom: 1px solid rgb(var(--c-222222));
  position: relative;
}

.brand .brand__item .brand__bottom .brand__desc .info .shopname a::after{
  content:'';
  position: absolute;
  background: url('../img/btn-link-brand.svg') no-repeat;
  background-size: contain;
  width: 10px;
  height: 7px;
  right: 0;

}
.brand .brand__item .brand__bottom .brand__desc .info .category{
  margin-top: 25px;
}
.brand .brand__item .brand__bottom .brand__desc .info .place{
  margin-top: 0.1em;
}
.brand .brand__item .brand__bottom .brand__desc .info .tel{
  margin-left: 1em;
}

/* top select_brands */
.brand.select_brands .brand__item{
  background: rgb(var(--c-f2f0ed));
  padding: 100px 0 120px;
}

/* ismyself */
.brand .brand__item .brand__ismyself{
  background: rgb(var(--c-f2f0ed));
  padding: 70px 0;
  display: flex;
  flex-direction: column;
  gap: 30px;
}

.brand .brand__item .brand__ismyself-title{
  display: flex;
  gap: 40px;
  width: 490px;
  margin: auto;
}

.brand .brand__item .brand__ismyself-title img{
  width: 100px;
  height: 100px;
}

.brand .brand__item .brand__ismyself-title h3{
  font-size: 27px;
  line-height: 1.77;
  letter-spacing: 0.15em;
}

.brand .brand__item .brand__ismyself .brand__full{
  width: 600px;
  margin-inline: auto;
}

.brand .brand__item .brand__ismyself .brand__ismyself-catch{
  font-size: 27px;
  text-align: center;
}

.brand .brand__item .brand__ismyself .brand__read{
  width: 750px;
  margin-inline: auto;
  margin-top: -30px;
}

/* brand__intro */
.brand .brand__item .brand__intro {
  --_border-radius: 10px;

  margin-inline: auto;
  padding-block: 60px;
  max-width: 768px;
  width: 100%;
  border-radius: var(--_border-radius);
  background-color: rgb(var(--c-eae7e2));
}
.brand .brand__item .brand__intro .intro__contents {
  display: flex;
  flex-direction: column;
  margin-inline: auto;
  width: 570px;
}
.brand .brand__item .brand__intro .intro__contents .intro__title {
  margin-top: -16px;
  font-size: 25px;
  line-height: 1.68;
  letter-spacing: 0.15em;
  color: rgb(var(--c-535353));
  text-align: center;
  order: 1;
}
.brand .brand__item .brand__intro .intro__contents .intro__sub {
  order: 0;
}
.brand .brand__item .brand__intro .intro__contents .intro__text {
  margin-top: 13px;
  font-size: 13px;
  line-height: 1.616;
  letter-spacing: 0.05em;
  text-align: center;
  order: 2;
}
.brand .brand__item .brand__intro .intro__contents .intro__thumb {
  position: relative;
  margin-top: 32px;
  order: 3;
}
.brand .brand__item .brand__intro .intro__contents .intro__thumb .intro__copy {
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  row-gap: 14px;
}
.brand .brand__item .brand__intro .intro__contents .intro__thumb .intro__copy.lt {
  top: 50px;
  left: -30px;
}
.brand .brand__item .brand__intro .intro__contents .intro__thumb .intro__copy.rb {
  bottom: 33px;
  left: calc(50% + 75px);
}
.brand .brand__item .brand__intro .intro__contents .intro__thumb .intro__copy span {
  display: inline-block;
  padding: 1px 20px;
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.05em;
  background-color: rgb(var(--c-f6f4b0));
  white-space: nowrap;
}
.brand .brand__item .brand__intro .intro__contents .intro__read {
  margin-top: 24px;
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.05em;
  order: 4;
}
.brand .brand__item .brand__intro .intro__contents .intro__spec {
  margin-top: 16px;
  font-size: 13px;
  line-height: 1.616;
  letter-spacing: 0.05em;
  order: 5;
}
.brand .brand__item .brand__intro .intro__contents .intro__note {
  margin-top: 8px;
  order: 6;
}
.brand .brand__item .brand__intro .intro__contents .intro__note li {
  font-size: 13px;
  line-height: 1.616;
  letter-spacing: 0.05em;
}

@media screen and (max-width: 750px) {
  .brand .brand__item {
    padding: 10.6667vw 0 18.667vw;
  }
  .brand .brand__item + .brand__item {
    border-top: 1px solid rgb(var(--c-000000));
  }
  .brand .brand__item .brand__top {
    display: flex;
    flex-direction: column;
    margin: auto;
    max-width: 1000px;
  }
  .brand .brand__item .brand__top .brand__head {
    max-width: none;
    width: 87.2%;
    display: flex;
    flex-direction: column;
    gap: 30px;
    margin: auto;
  }
  .brand .brand__item .brand__top .brand__head .name {
    display: flex;
    border-bottom: 1px solid rgb(var(--c-222222));
  }
  .brand .brand__item .brand__top .brand__head .name picture{
    width: 100%;
  }
  .brand .brand__item .brand__top .brand__head .mes {
    font-size: 5.86667vw;
    line-height: 1.727;
    letter-spacing: 0.015em;
    text-align: left;
  }
  .brand .brand__item .brand__top .brand__head .setting {
    padding: 2.13vw 0;
    font-size: 3.2vw;
    letter-spacing: 0.03em;
    text-align: left;
  }
  .brand .brand__item .brand__top .text {
    width: 87.2%;
    margin: 8vw auto 0;
    font-size: 4.26667vw;
    line-height: 1.6;
    letter-spacing: 0.05em;
    text-align: left;
  }
  
  .brand .brand__item .brand__bottom {
    display: flex;
    flex-direction: column;
    gap: 16.5vw;
    margin-inline: auto;
    max-width: 1000px;
    margin-top: 10.667vw;
    overflow: visible;
  }
  .brand .brand__item .brand__bottom .brand__thumb {
    width: 87.2%;
    margin-inline: auto;
  }
  .brand .brand__item .brand__bottom .brand__full {
    width: 87.2%;
    margin-inline: auto;
  }
  
  .brand .brand__item .brand__bottom .brand__slide {
    display: none;
  }
  .brand .brand__item .brand__bottom .brand__product {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 5.866vw 0;
    margin-inline: auto;
  }

  .brand .brand__item .brand__bottom .brand__read {
    width: 100%;
    font-size: 3.734vw;
    line-height: 1.6;
    letter-spacing: 0.03em;
  }
  .brand .brand__item .brand__bottom .brand__spec {
    position: relative;
    width: 100%;
    margin: 2.6667vw auto 0;
    padding: 5.6vw 4.2667vw 4.2667vw 4.2667vw;
    font-size: 3.2vw;
    line-height: 1.667;
    overflow: visible;
  }
  .brand .brand__item .brand__bottom .brand__spec::before {
    right: -8px;
    width: 40px;
    height: 40px;
  }
  .brand .brand__item .brand__bottom .brand__spec::after {
    width: 32px;
    height: 32px;
    background-position-y: -1px;
    overflow: visible;
  }
  .brand .brand__item .brand__bottom .brand__desc{
    width: 87.2%;
    margin: auto;
  }
  .brand .brand__item .brand__bottom .brand__desc .info {
    text-align: left;
  }
  .brand .brand__item .brand__bottom .brand__desc .info + p {
    margin-top: 80px;
    font-size: 3.46667vw;
  }
  .brand .brand__item .brand__bottom .brand__desc .info .shopname a {
    display: inline-flex;
    align-items: center;
    gap: 2.6667vw;
    padding: 0 4.8vw 1.333vw 0;
  }
  
  .brand .brand__item .brand__bottom .brand__desc .info .shopname a::after{
    content:'';
    position: absolute;
    background: url('../img/btn-link-brand.svg') no-repeat;
    background-size: contain;
    width: 2.667vw;
    height: 1.6667vw;
    aspect-ratio: 20 / 12.5;
  
  }
  .brand .brand__item .brand__bottom .brand__desc .info .category{
    margin-top: 4vw;
  }
  .brand .brand__item .brand__bottom .brand__desc .info .place{
    margin-top: 0.3em;
  }

    /* top select_brands */
  .brand.select_brands .brand__item{
    padding: 13.33vw 0 13.33vw;
  }

  /* ismyself */
  .brand .brand__item .brand__ismyself{
    padding: 8vw 0;
    gap: 5.333vw;
    width: 100%;
  }

  .brand .brand__item .brand__ismyself-title{
    display: flex;
    gap: 3.5vw;
    width: 87.2%;
    align-items: center;
  }

  .brand .brand__item .brand__ismyself-title img{
    width: 24vw;
    height: 24vw;
  }

  .brand .brand__item .brand__ismyself-title h3{
    font-size: 4.8vw;
    line-height: 1.77;
    letter-spacing: 0.1em;
  }

  .brand .brand__item .brand__ismyself .brand__full{
    width: 87.2%;
    margin-inline: auto;
  }

  .brand .brand__item .brand__ismyself .brand__ismyself-catch{
    font-size: 4.8vw;
    text-align: left;
    width: 87.2%;
    margin-inline: auto;
 
  }

  .brand .brand__item .brand__ismyself .brand__read{
    width: 100%;
    margin-top: -2vw;
  }


  /* brand__intro */
  .brand .brand__item .brand__intro {
    --_border-radius: unset;

    padding-block: 12.8vw;
    width: 100%;
  }
  .brand .brand__item .brand__intro .intro__contents {
    width: 87.2%;
  }
  .brand .brand__item .brand__intro .intro__contents .intro__title {
    margin-top: -1.6vw;
    font-size: 4.8vw;
    letter-spacing: 0.1em;
  }
  .brand .brand__item .brand__intro .intro__contents .intro__sub {
    order: 0;
  }
  .brand .brand__item .brand__intro .intro__contents .intro__text {
    margin-top: 3.2vw;
    font-size: 2.934vw;
  }
  .brand .brand__item .brand__intro .intro__contents .intro__thumb {
    margin-top: 8.534vw;
  }
  .brand .brand__item .brand__intro .intro__contents .intro__thumb .intro__copy {
    row-gap: 1.067vw;
  }
  .brand .brand__item .brand__intro .intro__contents .intro__thumb .intro__copy.lt {
    top: 5.334vw;
    left: -4.267vw;
  }
  .brand .brand__item .brand__intro .intro__contents .intro__thumb.r4 .intro__copy.lt {
    top: 2.934vw;
    left: -2.134vw;
  }
  .brand .brand__item .brand__intro .intro__contents .intro__thumb .intro__copy.rb {
    bottom: 2.134vw;
    left: calc(50% + 1.067vw);
  }
  .brand .brand__item .brand__intro .intro__contents .intro__thumb.r1 .intro__copy.rb {
    bottom: 2.134vw;
    left: calc(50% - 1.067vw);
  }
  .brand .brand__item .brand__intro .intro__contents .intro__thumb.r2 .intro__copy.rb {
    bottom: unset;
    top: 2.667vw;
    left: calc(50% - 1.334vw);
  }
  .brand .brand__item .brand__intro .intro__contents .intro__thumb.r3 .intro__copy.rb {
    bottom: 1.867vw;
    left: calc(50% + 1.067vw);
  }
  .brand .brand__item .brand__intro .intro__contents .intro__thumb.r5 .intro__copy.rb {
    bottom: unset;
    top: 2.667vw;
    left: calc(50% - 5.867vw);
  }
  .brand .brand__item .brand__intro .intro__contents .intro__thumb.r6 .intro__copy.rb {
    bottom: 2.134vw;
    left: calc(50% - 8vw);
  }
  .brand .brand__item .brand__intro .intro__contents .intro__thumb .intro__copy span {
    padding: 1px 2.667vw;
    font-size: 3.467vw;
  }
  .brand .brand__item .brand__intro .intro__contents .intro__read {
    margin-top: 5.334vw;
    font-size: 3.734vw;
    line-height: 1.6;
  }
  .brand .brand__item .brand__intro .intro__contents .intro__spec {
    margin-top: 3.2vw;
    font-size: 3.2vw;
    line-height: 1.667;
  }
  .brand .brand__item .brand__intro .intro__contents .intro__note {
    margin-top: 2.134;
  }
  .brand .brand__item .brand__intro .intro__contents .intro__note li {
    font-size: 3.2vw;
  }

}

/* 追従ボタン */
.openbtn {
	position: fixed;
  bottom: 11%;
  right: 60px;
	/* display: flex; */
  display: none;
	align-items: center;
	justify-content: center;
	width: 100px;
  height: 128px;
	z-index: 500;
  cursor: pointer;
  pointer-events: all;
}

.hidden {
  animation: fade .2s ease-in-out forwards;
  pointer-events:none;
}

@keyframes fade {
  from {
      opacity: 1;
  }

  to {
      opacity: 0;
  }
}

.visible {
  animation: fadeOut .2s ease-in-out forwards;
  pointer-events:all;/* 重要 */
}

@keyframes fadeOut {
  from {
      opacity: 0;
  }

  to {
      opacity: 1;
  }
}


/* ナビゲーション */
.g-nav{
  position: fixed;
    z-index: 999;
    bottom: -120%;
    left:0;
    width: 100%;
    height: 278px;
    background: rgb(var(--c-f4f2d4));
    transition: all 0.6s;
}

.g-nav.panelactive{
  bottom: 0;
}

.g-nav-wrapper{
  width: 100%;
  height: 100%;
  position: relative;
}

.g-nav-wrapper .closebtn{
  position: absolute;
  right: 60px;
  top: 50%;
  transform: translateY(-50%);
  margin: auto 0;
  cursor: pointer;
  pointer-events: all;
}

.g-nav-inner{
  display: flex;
  flex-direction: column;
  gap: 30px;
  max-width: 760px;
  padding-block: 60px 60px;
  margin: auto;
}

.g-nav-inner .rooms-list{
  max-width: 200px;
  width: 26.3%;
  margin: auto;
}

.g-nav-inner ul{
  max-width: 760px;
  display: flex;
  flex-wrap: wrap;
  gap: 30px 20px;
  margin-inline: auto;
}

.g-nav-inner ul li{
    max-width: 240px;
    width: 31.58%;
}

/* page-link */

.page-link{
  background: rgb(var(--c-f4f2d4));
  padding-block: 80px;
}

.page-link ul{
  max-width: 1020px;
  display: flex;
  flex-wrap: wrap;
  gap: 30px 20px;
  margin-inline: auto;
}

.page-link ul li{
  max-width: 240px;
  width: 23.53%;
}

.page-link ul li a,
.g-nav-inner ul li a{
  display: flex;
  align-items: center;
  width: 100%;
  height: 40px;
  font-size: 13px;
  position: relative;
  border-left: 1px solid rgb(var(--c-222222));
  border-bottom: 1px solid rgb(var(--c-222222));
}

.page-link ul li a:not(.link-top),
.g-nav-inner ul li a{
  padding-left: 32px;
}

.page-link ul li a.link-top img{
  width: 41.667%;
  padding-left: 13px;
}

.page-link ul li a::after,
.g-nav-inner ul li a::after{
  content: '';
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  margin: auto 0;
  background: url(../img/anchor-arrow-next.svg) no-repeat;
  background-size: 100% auto;
  width: 15px;
  aspect-ratio: 30 / 18.7;
}

.page-link ul li a::before,
.g-nav-inner ul li a::before{
  content: '';
  position: absolute;
  width: 14px;
  height: 20px;
  top: 50%;
  transform: translateY(-50%);
  left: 13px;
  margin: auto 0;
}

.page-link ul li a.no-0::before,
.g-nav-inner ul li a.no-0::before{
  background: url('../img/btn-top-page.svg') no-repeat;
  background-size: 100% auto;
  width: 41.667%;
}

.page-link ul li a.no-r1::before,
.g-nav-inner ul li a.no-r1::before{
  background: url('../img/no-r1.svg') no-repeat;
  background-size: 100% auto;
}

.page-link ul li a.no-r2::before,
.g-nav-inner ul li a.no-r2::before{
  background: url('../img/no-r2.svg') no-repeat;
  background-size: 100% auto;
}

.page-link ul li a.no-r3::before,
.g-nav-inner ul li a.no-r3::before{
  background: url('../img/no-r3.svg') no-repeat;
  background-size: 100% auto;
}

.page-link ul li a.no-r4::before,
.g-nav-inner ul li a.no-r4::before{
  background: url('../img/no-r4.svg') no-repeat;
  background-size: 100% auto;
}

.page-link ul li a.no-r5::before,
.g-nav-inner ul li a.no-r5::before{
  background: url('../img/no-r5.svg') no-repeat;
  background-size: 100% auto;
}

.page-link ul li a.no-r6:before,
.g-nav-inner ul li a.no-r6::before{
  background: url('../img/no-r6.svg') no-repeat;
  background-size: 100% auto;
}

.page-link ul li a.no-r7:before,
.g-nav-inner ul li a.no-r7::before{
  background: url('../img/no-r7.svg') no-repeat;
  background-size: 100% auto;
}

@media screen and (min-width: 1100px) and (max-width: 1280px) {

  .g-nav-inner ul{
    width: 90%;
    gap: 30px 20px;
  }
  
  .g-nav-inner ul li{
    width: calc(calc(100% - 40px) / 3);
  }

  .page-link ul{
    width: 90%;
    gap: 30px 20px;
    margin-inline: auto;
  }

  .page-link ul li{
    width: calc(calc(100% - 60px) / 4);
  }
}
@media screen and (min-width: 1000px) and (max-width: 1099px) {
  .openbtn {
    right: 40px;
  }

  .g-nav-inner ul{
    width: 90%;
    gap: 30px 20px;
  }
  
  .g-nav-inner ul li{
    width: calc(calc(100% - 40px) / 3);
    font-size: 1.3vw;
  }

  .page-link ul{
    width: 90%;
    gap: 30px 20px;
    margin-inline: auto;
  }

  .page-link ul li{
    width: calc(calc(100% - 60px) / 4);
    font-size: 1.3vw;
  }

}

@media screen and (min-width: 751px) and (max-width: 1000px) {
  .openbtn {
    right: 40px;
  }
  .g-nav{
    position: fixed;
    z-index: 999;
    bottom: -120%;
    left:0;
    width: 100%;
    height: 360px;
    background: rgb(var(--c-f4f2d4));
    transition: all 0.6s;
  }
  
  .g-nav-wrapper .closebtn{
    right: 40px;
  }
  
  .g-nav-inner ul{
    max-width: none;
    width: calc(100% - 120px);
  }
  
  .g-nav-inner ul li{
    width: calc(calc(100% - 20px) / 2);
    font-size: 1.3vw;
  }
  
  /* page-link */ 
  .page-link ul{
    max-width: 500px;
    width: 90%;
    margin: auto;
  }
  
  .page-link ul li{
    max-width: none;
    width: calc(calc(100% - 20px) / 2);
    font-size: 1.3vw;
  }
  
  .page-link ul li a.link-top img{
    width: 35%;
  }

}

@media screen and (max-width: 750px) {
  /* 追従ボタン */
  .openbtn {
    position: fixed;
    bottom: 11%;
    right: 3.46667vw;
    width: 18.667vw;
    height: 24.08vw;
  }

  /* ナビゲーション */
  .g-nav{
    position: fixed;
      z-index: 999;
      bottom: -120%;
      left:0;
      width: 100%;
      height: 67.4667vw;
      background: rgb(var(--c-f4f2d4));
      transition: all 0.6s;
  }

  .g-nav.panelactive{
    bottom: 0;
  }

  .g-nav-wrapper{
    width: 100%;
    height: 100%;
    position: relative;
  }

  .g-nav-wrapper .closebtn{
    position: absolute;
    right: 6.4%;
    top: 8vw;
    transform: translateY(0);
    margin: auto 0;
    cursor: pointer;
    pointer-events: all;
  }

  .g-nav-inner{
    display: flex;
    flex-direction: column;
    gap: 5.333vw;
    padding-block: 8vw 8vw;
    margin: auto;
  }

  .g-nav-inner .rooms-list{
    max-width: none;
    width: 44vw;
  }

  .g-nav-inner ul{
    width: 87.2%;
    gap: 4.8vw 3.4667vw;
  }

  .g-nav-inner ul li{
      max-width: none;
      width: calc(calc(100% - 3.4667vw) / 2);
  }

  /* page-link */

  .page-link{
    padding-block: 8vw;
  }

  .page-link ul{
    width: 87.2%;
    gap: 5.333vw 3.4667vw;
  }

  .page-link ul li{
    max-width: none;
    width: calc(calc(100% - 3.4667vw) / 2);
  }

  .page-link ul li a,
  .g-nav-inner ul li a{
    display: flex;
    align-items: center;
    width: 100%;
    height: 10.6667vw;
    font-size: 2.9333vw;
    line-height: 1.5454;
  }

  .page-link ul li a:not(.link-top),
  .g-nav-inner ul li a{
    padding-left: 8.5333vw;
  }

  .page-link ul li a.link-top img{
    width: 53%;
    padding-left: 3vw;
  }

  .page-link ul li a::after,
  .g-nav-inner ul li a::after{
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 0;
    margin: auto 0;
    background: url(../img/anchor-arrow-next.svg) no-repeat;
    background-size: 100% auto;
    width: 10px;
    aspect-ratio: 981 / 613;
  }

  .page-link ul li a::before,
  .g-nav-inner ul li a::before{
    content: '';
    position: absolute;
    width: 2.6667vw;
    height: 3.8vw;
    top: 50%;
    transform: translateY(-50%);
    left: 3vw;
    margin: auto 0;
  }

  .page-link ul li a.no-0::before,
  .g-nav-inner ul li a.no-0::before{
    width: 53%;
  }

}

/* end */

.end {
  padding-block: 80px;
  background: rgb(var(--c-222222));
}
.end .end__list {
  display: flex;
  flex-direction: column;
}
.end .end__list li {
  color: rgb(var(--c-ffffff));
  font-size: 14px;
  line-height: 2.857;
  letter-spacing: 0.05em;
  white-space: nowrap;
}
@media screen and (min-width: 1001px) and (max-width: 1280px) {

}
@media screen and (min-width: 751px) and (max-width: 1000px) {
  .end .end__list li {
    font-size: 1.4vw;
    white-space: normal;
  } 
}
@media screen and (max-width: 750px) {
  .end {
    padding-block: 16vw;
  }
  .end .end__list li {
    font-size: 3.7333vw;
    line-height: 2;
    white-space: normal;
  }
}








/* gift2025aw */

:root {
  --color-base-white: 255 255 255;
  --color-base-black: 0 0 0;
  --color-base-text: 49 49 49;
  --color-base-link: 7 51 172;
  --color-base-tag: 234 234 234;
  --color-base-line: 227 227 227;
  --color-base-bg: 245 245 245;
  --color-base-box: 112 112 112;

  --color-slide-active: 49 49 49;
  --color-slide-inactive: 197 197 197;

  --border-radius-max: 100vmax;

  --font-mincho: "Hina Mincho", serif;
  --font-gothic: "Zen Kaku Gothic New", sans-serif;
  --font-serif: "Libre Baskerville", serif;

  --font-regular: 400;
  --font-medium: 500;
  --font-bold: 700;

  --z-index-default: 0;
  --z-index-cursor: 5;
  --z-index-main: 10;
}


.u-font-mincho {
  font-family: var(--font-mincho);
}
.u-font-gothic {
  font-family: var(--font-gothic);
}
.u-font-serif {
  font-family: var(--font-serif);
}
.u-space-init {
  letter-spacing: 0 !important;
}
.u-space-half {
  letter-spacing: -0.05em !important;
}
.u-space-ohf {
  letter-spacing: 0.125em !important;
}
.u-space-th {
  letter-spacing: 0.2em !important;
}

button {
  margin: unset;
  padding: unset;
  border: unset;
}

.c-btn__more {
  position: relative;
  display: grid;
  place-content: center;
  padding-inline: 17px;
  width: 42.1222%;
  aspect-ratio: 262/52;
  font-size: 17px;
  line-height: 1;
  letter-spacing: 0.1em;
  font-family: var(--font-serif);
  color: rgb(var(--color-base-white));
  background-color: rgba(var(--color-base-text) / .65);
  border-radius: var(--border-radius-max);
  cursor: pointer;
}
.c-btn__more::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 9.1604%;
  transform: translateY(-50%);
  width: 12px;
  aspect-ratio: 16/9;
  background-image: url(../img/btn_more.svg);
  background-repeat: no-repeat;
  background-size: contain;
  transition: transform 0.6s ease-in-out;
}
.c-btn__more[aria-expanded="true"]:after {
  transform: translateY(-50%) rotate(180deg);
}
@media screen and (max-width: 750px) {
  .c-btn__more {
    padding-inline: 3.2vw;
    font-size: 3.2vw;
  }
  .c-btn__more::after {
    width: 2.1334vw;
  }
}


.l-section {
  position: relative;
  z-index: var(--z-index-default);
}
#aw .l-section__header {
  position: fixed;
  inset: 0;
  background-color: rgb(var(--color-base-bg));
}
#kids .l-section__header {
  position: fixed;
  inset: 0;
  background-color: rgb(var(--color-base-bg));
}
.l-section__contents {
  position: relative;
  margin-inline: auto;
  width: 520px;
  color: rgb(var(--color-base-text));
  background-color: rgb(var(--color-base-white));
  /* filter: drop-shadow(0 0 35px rgba(var(--color-base-black) / .45)); */
  filter: drop-shadow(0 0 5px rgba(var(--color-base-black) / .45));
  z-index: var(--z-index-main);
}
#kids .l-section__contents {
  background-color: rgb(var(--color-base-bg));
}
@media screen and (max-width: 1024px) {
  .l-section__contents {
    margin-inline: auto 0;
  }
}
@media screen and (max-width: 750px) {
  .l-section__header {
    display: none;
  }
  .l-section__contents {
    margin-inline: auto;
    width: 100%;
  }
}

.l-outline {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  /* gap: 100px; */
  gap: 16px;
  position: absolute;
  bottom: 8.075%;
  left: 4.5834%;
  /* width: calc(100% - 520px - 6.25% - (4.5834% * 2)); */
  width: calc(50% - 250px - (4.5834% * 2));
  overflow-y: auto;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
#aw .l-outline {
  top: calc(13.596% + 85px);
}
#kids .l-outline {
  top: calc(13.596% + 85px);
}
.l-outline::-webkit-scrollbar{
  display:none;
}
#aw .l-outline .p-outline__title {
  /* max-width: 550px; */
  /* max-width: 28.6459vw; */
  max-width: 18.2292vw;
  width: 100%;
}
#kids .l-outline .p-outline__title {
  /* max-width: 130px; */
  max-width: 18.2292vw;
  width: 100%;
}
.l-outline .p-outline__nav {
  /* max-width: 410px; */
  max-width: min(21.3542vw, 410px);
  width: 100%;
}
.l-outline .p-outline__nav .p-outline__list {
  display: grid;
  gap: 16px;
}
#aw .l-outline .p-outline__nav .p-outline__list li {
  --_border-size: 1px;
  border: var(--_border-size) solid rgb(var(--color-base-box));
}
@media screen and (max-width: 1280px) {
  #aw .l-outline {
    top: calc(13.596% + 65px);
  }
  #kids .l-outline {
    top: calc(13.596% + 65px);
  }
  .l-outline .p-outline__nav {
    /* width: 32.0312vw; */
  }
}
@media screen and (max-width: 1024px) {
  .l-outline {
    width: calc(100% - 520px - (4.5834% * 2));
  }
  #aw .l-outline .p-outline__title {
    /* max-width: 550px; */
    /* max-width: 28.6459vw; */
    max-width: unset;
  }
  #kids .l-outline .p-outline__title {
    /* max-width: 130px; */
    max-width: unset;
  }
  .l-outline .p-outline__nav {
    max-width: unset;
    width: 100%;
  }
}
@media screen and (max-width: 750px) {
  #aw .l-outline .p-outline__nav .p-outline__list li {
    --_border-size: 0.2vw;
  }
}


/*----------------------------------------------------
** index.html
----------------------------------------------------*/

#aw .l-hero {

}
#aw .l-hero .p-hero__heading {
  padding-block: 39px 65px;
}
#aw .l-hero .p-hero-lead {
  padding: 67px 43px 111px;
}
#aw .l-hero .p-hero-lead .p-hero-lead__title {
  font-size: 33px;
  line-height: 1.5834;
  letter-spacing: 0.1em;
  font-family: var(--font-mincho);
  font-weight: var(--font-regular);
}
#aw .l-hero .p-hero-lead .p-hero-lead__text {
  font-size: 18px;
  line-height: 2;
  letter-spacing: 0.025em;
  font-family: var(--font-mincho);
  font-weight: var(--font-regular);
}
#aw .l-hero .p-hero-lead .p-hero-lead__text:first-of-type {
  margin-top: 39px;
}
#aw .l-hero .p-hero-lead .p-hero-lead__text:not(:first-of-type) {
  margin-top: 1lh;
}
@media screen and (max-width: 750px) {
  #aw .l-hero .p-hero__heading {
    padding-block: 7.4667vw 12.5334vw;
  }
  #aw .l-hero .p-hero-lead {
    padding: 12.8vw 8.5334vw 21.3334vw;
  }
  #aw .l-hero .p-hero-lead .p-hero-lead__title {
    font-size: 6.4vw;
  }
  #aw .l-hero .p-hero-lead .p-hero-lead__text {
    font-size: 3.4667vw;
  }
  #aw .l-hero .p-hero-lead .p-hero-lead__text:first-of-type {
    margin-top: 7.4667vw;
  }
}


.l-feature {

}
.l-feature .p-feature__group {
  position: relative;
}
.l-feature .p-feature__heading {
  position: absolute;
}
.l-feature .p-feature__group:nth-child(1) .p-feature__heading {
  top: 71px;
  left: 6.4%;
}
.l-feature .p-feature__group:nth-child(2) .p-feature__heading {
  top: 39px;
  left: 6.4%;
}
.l-feature .p-feature__group:nth-child(3) .p-feature__heading {
  top: 448px;
  left: 6.4%;
}
.l-feature .p-feature__group:nth-child(4) .p-feature__heading {
  top: 459px;
  right: 5.3334%;
}
.l-feature .p-feature__title {
  display: grid;
  gap: 8px;
}
.l-feature .p-feature__title span {
  display: inline-block;
  padding: 6px 3px 6px 8px;
  width: fit-content;
  font-size: 18px;
  line-height: 1.1539;
  letter-spacing: 0.05em;
  font-family: var(--font-mincho);
  font-weight: var(--font-regular);
  color: rgb(var(--color-base-white));
  background-color: rgba(var(--color-base-black) / .35);
}
.l-feature .p-feature__head .p-feature__btn {
  margin: auto;
}
.l-feature .p-feature__content {
  position: relative;
  display: flex;
  flex-direction: column-reverse;
  padding: 55px 43px 111px;
}
.l-feature .p-feature__content .p-feature__head {
  position: relative;
  transform: translateY(-50%);
  z-index: 1;
  transition: transform 0.6s ease-in-out;
}
.l-feature .p-feature__content .p-feature__detail {
  position: relative;
  padding-bottom: 0;
  max-height: 125px;
  overflow: hidden;
  transition: max-height 0.6s ease-in-out, padding-bottom 0.6s ease-in-out;
}
.l-feature .p-feature__content .p-feature__detail::after {
  content: "";
  position: absolute;
  inset: 0;
  bottom: -1px;
  background: linear-gradient(180deg,rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.85) 65%, rgba(255, 255, 255, 1) 100%);
  opacity: 1;
  transition: opacity 0.6s ease-in-out;
  pointer-events: none;
}
.l-feature .p-feature__content .p-feature__head:has(.p-feature__btn[aria-expanded="true"]) {
  transform: translateY(0);
}
.l-feature .p-feature__content .p-feature__head:has(.p-feature__btn[aria-expanded="true"]) + .p-feature__detail {
  padding-bottom: 61px;
  max-height: 2000px;
}
.l-feature .p-feature__content .p-feature__head:has(.p-feature__btn[aria-expanded="true"]) + .p-feature__detail::after {
  opacity: 0;
}
.l-feature .p-feature__text {
  font-size: 18px;
  line-height: 1.8462;
  letter-spacing: 0.025em;
  font-family: var(--font-mincho);
}
.l-feature .p-feature-item .p-feature-item__visual {
  margin-top: 55px;
}
.l-feature .p-feature-item .p-feature-item__spec {
  margin-top: 28px;
  font-size: 17px;
  line-height: 1.75;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
}
.l-feature .p-feature-item .p-feature-item__note {
  font-size: 17px;
  line-height: 1.75;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
}
.l-feature .p-feature-item-service {
  display: grid;
  gap: 10px;
  margin-top: 24px;
}
.l-feature .p-feature-item-service .p-feature-item-service__title {
  font-size: 18px;
  line-height: 1.8462;
  letter-spacing: 0.025em;
  font-family: var(--font-serif);
  text-transform: uppercase;
}
.l-feature .p-feature-item-service .p-feature-item-service__tag {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.l-feature .p-feature-item-service .p-feature-item-service__tag li {
  padding: 3px 6px;
  font-size: 14px;
  line-height: 1;
  font-family: var(--font-gothic);
  background-color: rgb(var(--color-base-tag));
}
.l-feature .p-feature-item-info {
  display: grid;
  grid-template-columns: 1fr 24.1158%;
  gap: 22px;
  margin-top: 24px;
}
.l-feature .p-feature-item-info .p-feature-item-info__name a {
  font-size: 17px;
  line-height: 1.75;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
  font-weight: var(--font-medium);
  color: rgb(var(--color-base-link));
  text-decoration: underline;
  text-underline-offset: 4px;
}
.l-feature .p-feature-item-info .p-feature-item-info__place {
  margin-top: 17px;
  font-size: 17px;
  line-height: 1.5;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
}
.l-feature .p-feature-item-info .p-feature-item-info__tel a {
  font-size: 17px;
  line-height: 1.5;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
}
@media screen and (max-width: 750px) {
  .l-feature .p-feature__group:nth-child(1) .p-feature__heading {
    top: 13.6vw;
  }
  .l-feature .p-feature__group:nth-child(2) .p-feature__heading {
    top: 7.4667vw;
  }
  .l-feature .p-feature__group:nth-child(3) .p-feature__heading {
    top: 86.1334vw;
  }
  .l-feature .p-feature__group:nth-child(4) .p-feature__heading {
    top: 88.2667vw;
  }
  .l-feature .p-feature__title {
    gap: 1.6vw;
  }
  .l-feature .p-feature__title span {
    padding: 1.0667vw 0.5334vw 1.0667vw 1.6vw;
    font-size: 3.4667vw;
  }
  .l-feature .p-feature__content {
    padding: 10.6667vw 8.5334vw 21.3334vw;
  }
  .l-feature .p-feature__content .p-feature__detail {
    max-height: 24vw;
  }
  .l-feature .p-feature__content .p-feature__head:has(.p-feature__btn[aria-expanded="true"]) + .p-selection__detail {
    padding-bottom: 10.6667vw;
    max-height: 100vh;
  }
  .l-feature .p-feature__text {
    font-size: 3.4667vw;
  }
  .l-feature .p-feature-item .p-feature-item__visual {
    margin-top: 10.6667vw;
  }
  .l-feature .p-feature-item .p-feature-item__spec {
    margin-top: 5.3334vw;
    font-size: 3.2vw;
  }
  .l-feature .p-feature-item .p-feature-item__note {
    font-size: 3.2vw;
  }
  .l-feature .p-feature-item-service {
    gap: 2vw;
    margin-top: 4.6667vw;
  }
  .l-feature .p-feature-item-service .p-feature-item-service__title {
    font-size: 3.4667vw;
  }
  .l-feature .p-feature-item-service .p-feature-item-service__tag {
    gap: 1.0667vw;
  }
  .l-feature .p-feature-item-service .p-feature-item-service__tag li {
    padding: 0.5334vw 1.0667vw;
    font-size: 2.6667vw;
  }
  .l-feature .p-feature-item-info {
    gap: 4.2667vw;
    margin-top: 4.6667vw;
  }
  .l-feature .p-feature-item-info .p-feature-item-info__name a {
    font-size: 3.2vw;
  }
  .l-feature .p-feature-item-info .p-feature-item-info__place {
    margin-top: 3.2vw;
    font-size: 3.2vw;
  }
  .l-feature .p-feature-item-info .p-feature-item-info__tel a {
    font-size: 3.2vw;
  }
}


.l-selection {
  padding: 55px 43px 44px;
}
.l-selection__heading {

}
.l-selection .p-selection__thumb {
  margin-top: 22px;
}
.l-selection .p-selection__lead {
  margin-top: 22px;
  font-size: 18px;
  line-height: 2;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
  font-weight: var(--font-medium);
  text-align: center;
}
.l-selection .p-selection__list {
  margin-top: 83px;
}
.l-selection .p-selection__visual {
  margin-top: 28px;
}
.l-selection .p-selection__head .p-selection__btn {
  margin: auto;
}
.l-selection .p-selection__content {
  position: relative;
  display: flex;
  flex-direction: column-reverse;
  padding: 28px 0 67px;
}
.l-selection .p-selection__content .p-selection__head {
  position: relative;
  transform: translateY(-50%);
  z-index: 1;
  transition: transform 0.6s ease-in-out;
}
.l-selection .p-selection__content .p-selection__detail {
  position: relative;
  padding-bottom: 0;
  max-height: 125px;
  overflow: hidden;
  transition: max-height 0.6s ease-in-out, padding-bottom 0.6s ease-in-out;

}
.l-selection .p-selection__content .p-selection__detail::after {
  content: "";
  position: absolute;
  inset: 0;
  bottom: -1px;
  background: linear-gradient(180deg,rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.85) 65%, rgba(255, 255, 255, 1) 100%);
  opacity: 1;
  transition: opacity 0.6s ease-in-out;
  pointer-events: none;
}
.l-selection .p-selection__content .p-selection__head:has(.p-selection__btn[aria-expanded="true"]) {
  transform: translateY(0);
}
.l-selection .p-selection__content .p-selection__head:has(.p-selection__btn[aria-expanded="true"]) + .p-selection__detail {
  padding-bottom: 61px;
  max-height: 2000px;
}
.l-selection .p-selection__content .p-selection__head:has(.p-selection__btn[aria-expanded="true"]) + .p-selection__detail::after {
  opacity: 0;
}
.l-selection .p-selection__text {
  font-size: 18px;
  line-height: 1.8462;
  letter-spacing: 0.025em;
  font-family: var(--font-mincho);
}
.l-selection .p-selection-item .p-selection-item__spec {
  margin-top: 28px;
  font-size: 17px;
  line-height: 1.75;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
}
.l-selection .p-selection-item .p-selection-item__note {
  font-size: 17px;
  line-height: 1.75;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
}
.l-selection .p-selection-item-situation {
  display: grid;
  gap: 10px;
  margin-top: 24px;
}
.l-selection .p-selection-item-situation .p-selection-item-situation__title {
  font-size: 18px;
  line-height: 1.8462;
  letter-spacing: 0.025em;
  font-family: var(--font-serif);
  text-transform: uppercase;
}
.l-selection .p-selection-item-situation .p-selection-item-situation__tag {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.l-selection .p-selection-item-situation .p-selection-item-situation__tag li {
  padding: 3px 6px;
  font-size: 14px;
  line-height: 1;
  font-family: var(--font-gothic);
  background-color: rgb(var(--color-base-tag));
}
.l-selection .p-selection-item-service {
  display: grid;
  gap: 10px;
  margin-top: 13px;
}
.l-selection .p-selection-item-service .p-selection-item-service__title {
  font-size: 18px;
  line-height: 1.8462;
  letter-spacing: 0.025em;
  font-family: var(--font-serif);
  text-transform: uppercase;
}
.l-selection .p-selection-item-service .p-selection-item-service__tag {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.l-selection .p-selection-item-service .p-selection-item-service__tag li {
  padding: 3px 6px;
  font-size: 14px;
  line-height: 1;
  font-family: var(--font-gothic);
  background-color: rgb(var(--color-base-tag));
}
.l-selection .p-selection-item-info {
  display: grid;
  grid-template-columns: 1fr 24.1158%;
  gap: 22px;
  margin-top: 24px;
}
.l-selection .p-selection-item-info .p-selection-item-info__name a {
  font-size: 17px;
  line-height: 1.75;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
  font-weight: var(--font-medium);
  color: rgb(var(--color-base-link));
  text-decoration: underline;
  text-underline-offset: 4px;
}
.l-selection .p-selection-item-info .p-selection-item-info__place {
  margin-top: 17px;
  font-size: 17px;
  line-height: 1.5;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
}
.l-selection .p-selection-item-info .p-selection-item-info__tel a {
  font-size: 17px;
  line-height: 1.5;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
}
@media screen and (max-width: 750px) {
  .l-selection {
    padding: 10.6667vw 8.5334vw 8.5334vw;
  }
  .l-selection .p-selection__thumb {
    margin-top: 4.2667vw;
  }
  .l-selection .p-selection__lead {
    margin-top: 4.2667vw;
    font-size: 3.4667vw;
  }
  .l-selection .p-selection__list {
    margin-top: 16vw;
  }
  .l-selection .p-selection__visual {
    margin-top: 5.3334vw;
  }
  .l-selection .p-selection__content {
    padding: 5.3334vw 0 12.8vw;
  }
  .l-selection .p-selection__content .p-selection__detail {
    max-height: 24vw;
  }
  .l-selection .p-selection__content .p-selection__head:has(.p-selection__btn[aria-expanded="true"]) + .p-selection__detail {
    padding-bottom: 10.6667vw;
    max-height: 100vh;
  }
  .l-selection .p-selection__text {
    font-size: 3.4667vw;
  }
  .l-selection .p-selection-item .p-selection-item__spec {
    margin-top: 5.3334vw;
    font-size: 3.2vw;
  }
  .l-selection .p-selection-item .p-selection-item__note {
    font-size: 3.2vw;
  }
  .l-selection .p-selection-item-situation {
    gap: 2vw;
    margin-top: 4.6667vw;
  }
  .l-selection .p-selection-item-situation .p-selection-item-situation__title {
    font-size: 3.4667vw;
  }
  .l-selection .p-selection-item-situation .p-selection-item-situation__tag {
    gap: 1.0667vw;
  }
  .l-selection .p-selection-item-situation .p-selection-item-situation__tag li {
    padding: 0.5334vw 1.0667vw;
    font-size: 2.6667vw;
  }
  .l-selection .p-selection-item-service {
    gap: 2vw;
    margin-top: 2.5334vw;
  }
  .l-selection .p-selection-item-service .p-selection-item-service__title {
    font-size: 3.4667vw;
  }
  .l-selection .p-selection-item-service .p-selection-item-service__tag {
    gap: 1.0667vw;
  }
  .l-selection .p-selection-item-service .p-selection-item-service__tag li {
    padding: 0.5334vw 1.0667vw;
    font-size: 2.6667vw;
  }
  .l-selection .p-selection-item-info {
    gap: 4.2667vw;
    margin-top: 4.6667vw;
  }
  .l-selection .p-selection-item-info .p-selection-item-info__name a {
    font-size: 3.2vw;
  }
  .l-selection .p-selection-item-info .p-selection-item-info__place {
    margin-top: 3.2vw;
    font-size: 3.2vw;
  }
  .l-selection .p-selection-item-info .p-selection-item-info__tel a {
    font-size: 3.2vw;
  }  
}


.l-anchor {
  --_border-size: 1px;

  padding: 67px 43px;
  border-top: var(--_border-size) solid rgb(var(--color-base-line))
}
#kids .l-anchor {
  border-top: unset;
  background-color: rgb(var(--color-base-white));
}
.l-anchor .p-anchor__list {
  display: grid;
  gap: 17px;
}
@media screen and (max-width: 750px) {
  .l-anchor {
    --_border-size: 0.2667vw;
    padding: 12.8vw 8.5334vw;
  }
  .l-anchor .p-anchor__list {
    gap: 3.2vw;
  }
}


.l-announce {
  padding: 0 28px 67px;
  font-size: 17px;
  line-height: 1.6667;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
}
#kids .l-announce {
  background-color: rgb(var(--color-base-white));
}
@media screen and (max-width: 750px) {
  .l-announce {
    padding: 0 5.3334vw 12.8vw;
    font-size: 3.2vw;
  }
}



/*----------------------------------------------------
** kids.html
----------------------------------------------------*/

#kids .l-hero {
  display: flex;
  flex-direction: column;
  padding-block: 43px 53px;
}
#kids .l-hero .p-hero__visual {
  order: 0;
}
#kids .l-hero .p-hero__heading {
  margin-top: 22px;
  order: 1;
}
#kids .l-hero .p-hero__text {
  order: 2;
  font-size: 18px;
  line-height: 2;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
  font-weight: var(--font-medium);
  text-align: center;
}
#kids .l-hero .p-hero__text:first-of-type {
  margin-top: 43px;
}
#kids .l-hero .p-hero__text:not(:first-of-type) {
  margin-top: 0.5lh;
}
@media screen and (max-width: 750px) {
  #kids .l-hero {
    padding-block: 8.2667vw 10.1334vw;
  }
  #kids .l-hero .p-hero__heading {
    margin-top: 4.2667vw;
  }
  #kids .l-hero .p-hero__text {
    font-size: 3.4667vw;
  }
  #kids .l-hero .p-hero__text:first-of-type {
    margin-top: 8.2667vw;
  }
}


.l-reference {
  margin: 0 43px;
  padding-block: 38px 35px;
  background-image: url(../img/kids/reference_line.svg), url(../img/kids/reference_line.svg);
  background-repeat: no-repeat, no-repeat;
  background-position: 0 0, 100% 100%;
  background-size: 100%, 100%;
}
.l-reference .p-reference__lead {
  font-size: 18px;
  line-height: 2;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
  font-weight: var(--font-medium);
  text-align: center;
}
.l-reference .p-reference__list {
  display: grid;
  grid-template-columns: repeat(3, minmax(32.4591%, 1fr));
  column-gap: 6px;
  margin: 22px auto 0;
  width: 98.0708%;
}
.l-reference .p-reference__list .p-reference__icon {
  margin: 0 auto;
  width: 50.5051%;
}
.l-reference .p-reference__list .p-reference__text {
  margin-top: 11px;
  font-size: 17px;
  line-height: 1.5;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
  font-weight: var(--font-medium);
  text-align: center;
}
@media screen and (max-width: 750px) {
  .l-reference {
    margin: 0 8.5334vw;
    padding-block: 7.3334vw 6.6667vw;
  }
  .l-reference .p-reference__lead {
    font-size: 3.4667vw;
  }
  .l-reference .p-reference__list {
    column-gap: 1.0667vw;
    margin: 4.2667vw auto 0;
  }
  .l-reference .p-reference__list .p-reference__text {
    margin-top: 2.1334vw;
    font-size: 3.2vw;
  }
}


.l-shop {
  margin-top: 65px;
}
.l-shop .p-shop__group {
  position: relative;
}
.l-shop .p-shop__visual {
  --_border-size: 2px;
  margin: 0 43px;
  border: var(--_border-size) solid rgb(var(--color-base-box));
}
.l-shop .p-shop__head .p-shop__btn {
  margin: auto;
}
.l-shop .p-shop__content {
  position: relative;
  display: flex;
  flex-direction: column-reverse;
  padding: 55px 43px 67px;
}
.l-shop .p-shop__content .p-shop__head {
  position: relative;
  transform: translateY(-50%);
  z-index: 1;
  transition: transform 0.6s ease-in-out;
}
.l-shop .p-shop__content .p-shop__detail {
  position: relative;
  padding-bottom: 0;
  max-height: 222px;
  overflow: hidden;
  transition: max-height 0.6s ease-in-out, padding-bottom 0.6s ease-in-out;
}
.l-shop .p-shop__content .p-shop__detail::after {
  content: "";
  position: absolute;
  inset: 0;
  bottom: -1px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(245, 245, 245, 1) 80%, rgba(245, 245, 245, 1) 100%);
  opacity: 1;
  transition: opacity 0.6s ease-in-out;
  pointer-events: none;
}
.l-shop .p-shop__content .p-shop__head:has(.p-shop__btn[aria-expanded="true"]) {
  transform: translateY(0);
}
.l-shop .p-shop__content .p-shop__head:has(.p-shop__btn[aria-expanded="true"]) + .p-shop__detail {
  padding-bottom: 61px;
  max-height: 2000px;
}
.l-shop .p-shop__content .p-shop__head:has(.p-shop__btn[aria-expanded="true"]) + .p-shop__detail::after {
  opacity: 0;
}
.l-shop .p-shop-item .p-shop-item__title {
  font-size: 21px;
  line-height: 1.8667;
  letter-spacing: 0.25em;
  font-family: var(--font-gothic);
  font-weight: var(--font-medium);
}
.l-shop .p-shop-item .p-shop-item__text {
  margin-top: 28px;
  font-size: 18px;
  line-height: 1.8462;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
  font-weight: var(--font-medium);
}

.l-shop .p-shop-item .p-shop-item__spec {
  margin-top: 28px;
  font-size: 17px;
  line-height: 1.75;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
}
.l-shop .p-shop-item .p-shop-item__note {
  font-size: 17px;
  line-height: 1.75;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
}
.l-shop .p-shop-item-service {
  display: grid;
  gap: 10px;
  margin-top: 24px;
}
.l-shop .p-shop-item-service .p-shop-item-service__title {
  font-size: 18px;
  line-height: 1.8462;
  letter-spacing: 0.025em;
  font-family: var(--font-serif);
  text-transform: uppercase;
}
.l-shop .p-shop-item-service .p-shop-item-service__tag {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.l-shop .p-shop-item-service .p-shop-item-service__tag li {
  padding: 3px 6px;
  font-size: 14px;
  line-height: 1;
  font-family: var(--font-gothic);
  background-color: rgb(var(--color-base-tag));
}
.l-shop .p-shop-item-info {
  display: grid;
  grid-template-columns: 1fr 24.1158%;
  gap: 22px;
  margin-top: 24px;
}
.l-shop .p-shop-item-info .p-shop-item-info__name a {
  font-size: 17px;
  line-height: 1.75;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
  font-weight: var(--font-medium);
  color: rgb(var(--color-base-link));
  text-decoration: underline;
  text-underline-offset: 4px;
}
.l-shop .p-shop-item-info .p-shop-item-info__place {
  margin-top: 17px;
  font-size: 17px;
  line-height: 1.5;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
}
.l-shop .p-shop-item-info .p-shop-item-info__tel a {
  font-size: 17px;
  line-height: 1.5;
  letter-spacing: 0.025em;
  font-family: var(--font-gothic);
}
@media screen and (max-width: 750px) {
  .l-shop {
    margin-top: 12.5334vw;
  }
  .l-shop .p-shop__visual {
    --_border-size: 0.4vw;
    margin: 0 8.5334vw;
  }
  .l-shop .p-shop__content {
    padding: 10.6667vw 8.5334vw 8.1334vw;
  }
  .l-shop .p-shop__content .p-shop__detail {
    max-height: 42.6667vw;
  }
  .l-shop .p-shop__content .p-shop__head:has(.p-shop__btn[aria-expanded="true"]) + .p-shop__detail {
    padding-bottom: 11.7334vw;
    max-height: 100vh;
  }
  .l-shop .p-shop-item .p-shop-item__title {
    font-size: 4vw;
  }
  .l-shop .p-shop-item .p-shop-item__text {
    margin-top: 5.3334vw;
    font-size: 3.4667vw;
  }
  .l-shop .p-shop-item .p-shop-item__spec {
    margin-top: 5.3334vw;
    font-size: 3.2vw;
  }
  .l-shop .p-shop-item .p-shop-item__note {
    font-size: 3.2vw;
  }
  .l-shop .p-shop-item-service {
    gap: 2vw;
    margin-top: 4.6667vw;
  }
  .l-shop .p-shop-item-service .p-shop-item-service__title {
    font-size: 3.4667vw;
  }
  .l-shop .p-shop-item-service .p-shop-item-service__tag {
    gap: 1.0667vw;
  }
  .l-shop .p-shop-item-service .p-shop-item-service__tag li {
    padding: 0.5334vw 1.0667vw;
    font-size: 2.6667vw;
  }
  .l-shop .p-shop-item-info {
    gap: 4.2667vw;
    margin-top: 4.6667vw;
  }
  .l-shop .p-shop-item-info .p-shop-item-info__name a {
    font-size: 3.2vw;
  }
  .l-shop .p-shop-item-info .p-shop-item-info__place {
    margin-top: 3.2vw;
    font-size: 3.2vw;
  }
  .l-shop .p-shop-item-info .p-shop-item-info__tel a {
    font-size: 3.2vw;
  }
}


/* slick custom */
.slick-dotted.slick-slider {
  margin-bottom: unset;
}
.slick-dots {
  bottom: -8%;
  z-index: var(--z-index-cursor);
}
.slick-dots li {
  width: 8px;
  height: 8px;
  margin: 0 6px;
}
.slick-dots li button {
  width: 8px;
  height: 8px;
  padding: unset;
}
.slick-dots li button:before {
  font-size: 8px;
  line-height: 1;
  width: 100%;
  height: 100%;
  color: rgb(var(--color-slide-inactive));
}
.slick-dots li.slick-active button:before {
  color: rgb(var(--color-slide-active));
}
@media screen and (max-width: 750px) {
  .slick-dots li {
    width: 1.6vw;
    height: 1.6vw;
    margin: 0 1.0667vw;
  }
  .slick-dots li button {
    width: 1.6vw;
    height: 1.6vw;
  }
  .slick-dots li button:before {
    font-size: 1.6vw;
  }
}