@charset "UTF-8";
html {
    scroll-behavior: smooth;
}

body {
    font-family:  "Noto Serif JP", serif;
}

img {
    width: 100%;
    height: auto;
}

h1 {
    overflow: hidden;
}

.btn {
    width: 88.21%;
    margin: 0 auto;
}

.map-btn {
    width: 67.84%;
    margin: 0 auto;
}

@media screen and (min-width: 769px) {
.btn {
    width: 25.67%;
}
}

/* main__title */
@media screen and (min-width: 769px) {
.main__title {
    margin-bottom: 62px;
}
}

/* main-chat */
@media screen and (min-width: 769px) {
.main-chat {
    padding-top: 100px;
}
}
/* offer */
.offer {
    position: relative;
    z-index: 0;
}

.offer .btn {
    position: absolute;
    bottom: 3%;
    left: 50%;
    transform: translateX(-50%);
    z-index: 100;
}

@media screen and (min-width: 769px) {
.offer .h2 {
    width: 52.04%;
    margin: 0 auto;
    padding: 60px 0;
}

.offer .btn {
    width: 44.03%;
    position: absolute;
    bottom: 8%;
}
}

/* store */
.store {
    position: relative;
    z-index: 0;
}

.store .map-btn {
    position: absolute;
    bottom: 5%;
    left: 50%;
    transform: translateX(-50%);
}

@media screen and (min-width: 769px) {
.store .map-btn {
    width: 20.2%;
    bottom: 20%;
    left: 20%;
    transform: translateX(0);
}
}

/* trouble */
.trouble {
    margin-top: -3%;
    position: sticky;
}

/* cat */
.cat .btn {
    margin: 24px auto;
}

@media screen and (min-width: 769px) {
.cat__inner{
    position: relative;
}    
.cat .btn {
    width: 25.67%;
    max-width: 493px ;
    position: absolute;
    bottom: 13%;
    right: 28%;
}
}

/* change */
.change {
    padding-bottom: 72px;
}

/* flow */
.flow {
    position: relative;
    z-index: 0;
}

.flow .btn {
    position: absolute;
    top: 21%;
    left: 50%;
    transform: translateX(-50%);
}

.odd_number {
    margin-top: -32%;
}

@media screen and (min-width: 769px) {
.flow .btn {
    width: 16.51%;
    top: 47%;
    left: 18.5%;
    transform: translateX(0);
}

.odd_number {
    margin-top: -25%;
}
}

/* FAQ */
.faq {
    background: url(../img/faq-bg.webp) no-repeat center;
    background-size: cover;
    padding: 4.15% 0;
}

.faq .h2 {
    width: 33.12%;
    margin: 0 auto 4.15% auto;
}

.faq__list {
    padding: 0 4.16%;
}

.faq__item {
    margin-bottom: 4.15%;
}
@media screen and (min-width: 769px) {
.faq {
    margin-top: -290px;
    position: sticky;
    z-index: 100;
}

.faq .h2 {
    width: 11.56%;
}

.faq__list {
    width: 48.95%;
    margin: 0 auto;
}
}

/* 店舗情報 */

iframe {
    display: block;
    width: 100%;
    padding: 0 4.16%;
}

#store .h2 {
    margin-bottom: 24px;
}

.access__list {
    padding: 4.16%;
}

.access__item {
    font-size: 0.87rem;
    display: flex;
    align-items: center;
    margin-bottom: 8px;
}

.access__title {
    white-space: nowrap;
    padding: 4px;
    margin-right: 3.8%;
    background: linear-gradient(45deg, #addbe3 60%, #ffffff 100% ) ;
}

.access__text {
    white-space: nowrap;
}

.sns {
    width: 12.1%;
    margin: 0 auto 24px auto;
}

@media screen and (min-width: 769px) {
#store .h2 {
    margin-bottom: 66px;
}

.iframe {
    width: 27.6%;
}

.store__inner {
display: flex;
justify-content: center;
align-items: center;
margin-bottom: 107px;
}

.access__list {
    padding: 0;
}

.access__item {
    font-size: 1.62rem;
    margin-bottom: 24px;

}

.sns {
    width: 4.47%;
    margin: 0 auto 49px auto;
}
}



/* フッター */
footer {
    background-color: #78bbe5;
    text-align: center;
}
small {
    font-size: 0.8rem;
    line-height: 2.571;
    display: block;
}
@media screen and (min-width: 769px) {
small {
    font-size: 1.25rem;
}

}



/* 既存の.btnスタイルはそのまま活かす */

/* アニメーションを上乗せする */
.btn img {
  display: block;
  width: 100%;
  height: auto;
  animation: bounce_img 1s infinite;
}

/* 画像を軽く上下に動かすアニメーション */
@keyframes bounce_img {
  0%   { transform: translateY(0px); }
  10%  { transform: translateY(3px); }
  20%  { transform: translateY(0px); }
  30%  { transform: translateY(3px); }
  40%  { transform: translateY(0px); }
  100% { transform: translateY(0px); }
}
