@charset 'utf-8';

/* 共通
------------------------------- */
html {
  scroll-behavior: smooth;
}

body {
  font-family: 'Noto Sans JP', sans-serif;
}

img,
picture {
  height: auto;
  vertical-align: bottom;
  width: 100%;
}

.wrapper {
  margin: 0 auto;
  max-width: 750px;
  width: 100%;
}

.wrap {
  width: 100%;
}

.wrap02 {
  padding: 10px;
}

.wrap03 {
  padding-left: 15px;
  padding-right: 15px;
}

.wrap04 {
  padding-left: 30px;
  padding-right: 30px;
}

.wrap-shinsyun-ttl {
  padding: 15px 0;
}

.mT3p {
  margin-top: 3%;
}
.mT4p {
  margin-top: 4%;
}
.mT5p {
  margin-top: 5%;
}
.mT6p {
  margin-top: 6%;
}
.mT7p {
  margin-top: 7%;
}
.mT8p {
  margin-top: 8%;
}
.mT9p {
  margin-top: 9%;
}
.mT10p {
  margin-top: 10%;
}

.mB1p {
  margin-bottom: 1%;
}
.mB2p {
  margin-bottom: 2%;
}
.mB3p {
  margin-bottom: 3%;
}
.mB4p {
  margin-bottom: 4%;
}
.mB5p {
  margin-bottom: 5%;
}
.mB6p {
  margin-bottom: 6%;
}
.mB7p {
  margin-bottom: 7%;
}
.mB8p {
  margin-bottom: 8%;
}
.mB9p {
  margin-bottom: 9%;
}
.mB10p {
  margin-bottom: 10%;
}

.pT3p {
  padding-top: 3%;
}
.pT4p {
  padding-top: 4%;
}
.pT5p {
  padding-top: 5%;
}
.pT6p {
  padding-top: 6%;
}
.pT7p {
  padding-top: 7%;
}
.pT8p {
  padding-top: 8%;
}
.pT9p {
  padding-top: 9%;
}
.pT10p {
  padding-top: 10%;
}

.pB3p {
  padding-bottom: 3%;
}
.pB4p {
  padding-bottom: 4%;
}
.pB5p {
  padding-bottom: 5%;
}
.pB6p {
  padding-bottom: 6%;
}
.pB7p {
  padding-bottom: 7%;
}
.pB8p {
  padding-bottom: 8%;
}
.pB9p {
  padding-bottom: 9%;
}
.pB10p {
  padding-bottom: 10%;
}
.pB15p {
  padding-bottom: 15%;
}
.pB20p {
  padding-bottom: 20%;
}

.position-r {
  position: relative;
}

.center {
  text-align: center;
}

/* mv ----------------- */

body {
  color: #363131;
}

nav {
    color: #363131;
}

.mv {
  background-image: url('../image/img06.png');
}

.mv__ttl {
  align-items: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
  z-index: 1;
}

.mv__ttl {
  font-size: clamp(20px, -4px + 6.667vw, 46px);
  font-weight: bold;
  margin-bottom: 5%;
  margin-top: 2%;
}

.mv__logo {
  display: flex;
  justify-content: center;
}

.mv__logo h1 {
  height: auto;
  max-width: min(78%, 550px);
}

.mv__text {
  font-size: clamp(22px, -.154px + 6.154vw, 25px);
  line-height: 1.25;
  text-align: center;
}



.mv__text02 {
  background: #fff;
  border: 4px solid #c1272d;
  color: #c1272d;
  font-size: clamp(20px, 1.538px + 5.128vw, 40px);
  font-weight: bold;
  margin-inline: auto;
  max-width: min(100%, 480px);
  padding: 1% 2%;
  text-align: center;
}

.mv__text03 {
  color: #c1272d;
  font-size: clamp(20px, -2.154px + 6.154vw, 44px);
  font-weight: bold;
  text-align: center;
}


.ouen {
  padding: 4% 10px;
}

/* ナビゲーション */
.hero {
  position: relative;
  height: 800px; /* 高さは好みで */
  background: url("../image/image-01.jpg") no-repeat center center/cover;
  display: flex;
  justify-content: center;
  align-items: center;
  color: white; /* タイトルなどが見やすいように */
  text-align: center;
}

.nav {
  position: absolute;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
}

.nav__inner {
  background: #fff;
  border-radius: 50px; /* 丸いカプセル型 */
  box-shadow: 0 4px 10px rgba(0,0,0,0.15);
  padding: 16px 90px;
}

.nav__list {
  display: flex;
  gap: 30px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.nav__item a {
  text-decoration: none;
  color: #363131;
  font-weight: bold;
}

.mv__title {
  font-size: clamp(32px, 2.462px + 8.205vw, 64px);
  color: #78C8C4;
  font-weight: bold;
  margin-bottom: 5%;
  justify-content: center;
  text-align: center;
  border-radius: 67px;
  font-family: serif;
}

.mv__inner {
  background-color: #fff;
  padding: 5%;
  border-radius: 65px;
}


.jump{
  font-size: clamp(18px, 2.308px + 7.692vw, 25px);
  font-weight: bold;
}

.jump2 {
  font-size: clamp(20px, 2.308px + 7.692vw, 32px);
  color: #ffffff;
  background-color: #78C8C4;
  margin: 10px;
}

.jump3 {
  font-size: clamp(25px, 2.308px + 7.692vw, 42px);
  font-weight: bold;
  color: #78C8C4;

}

/* sec01 ----------------- */
.sec01 {
  align-items: center;
  background: #78C8C4;
  display: flex;
  gap: 4%;
}

.sec01-flex__item:first-child {
  flex-grow: 1;
}


.maps {
    position: absolute;
    width: 30%;
    height: 40%;
    top: 876vw;
    bottom: 82%;
    right: 28vw;
    border: none;
    z-index: 999;
}

@media screen and (max-width: 1400px) {
  .maps {
    position: absolute;
    width: 30%;
    height: 40%;
    top: 873vw;
    bottom: 82%;
    right: 32vw;
    border: none;
    z-index: 999;
}
iframe {
     width: 352px;
    height: 251px;
}
}


@media screen and (max-width: 768px) {
  .maps {
    position: absolute;
    width: 10px;
    height: 40%;
    top: 885vw;
    bottom: 93%;
    right: 60vw;
    border: none;
    z-index: 999;
}
iframe {
    width: 100px;
    height: 76px;
}
}

/* sec02 ----------------- */
.sec02 .mv__grid {
    display: flex;
    gap: 20px;
    width: 100%;
}
.sec02 .mv__grid2 {
    display: flex;
    gap: 20px;
    width: 100%;
}

.sec02 .mv__grid2 {
  display: flex;
  gap: 20px;                /* アイテム間の余白 */
  justify-content: center;   /* 中央寄せ */
  width: 70%;               /* セクション幅いっぱい */
  max-width: 1200px;         /* .mv__grid と同じ幅に合わせる */
  margin: 0 auto;            /* 横中央に寄せる */
}

.sec02 .mv__grid2 > div {
  flex: 0 1 45%;             /* 2つ並べるための幅（調整可） */
  min-width: 0;              /* はみ出し防止 */
}

.mv__itemimg {
  max-width: 1600px;
}
/* sec03 ----------------- */
.sec03__text01,
.sec03__text02 {
  font-weight: bold;
  text-align: center;
}

.sec03__text01 {
  color: #c1272d;
  font-size: clamp(20px, 1.538px + 5.128vw, 40px);
}

.sec03__text02 {
  font-size: clamp(32px, 2.462px + 8.205vw, 64px);
}

/* sec05 ----------------- */
.sec05__btn {
  margin-inline: auto;
  max-width: min(78%, 550px);
}

.sec05__btn a:hover {
  opacity: .5;
}

/* sec06 ----------------- */
.sec06 {
  background-image: url('../image/img39.png');
}

.sec06__item01,
.sec06__item02,
.sec06__item03 {
  margin-inline: auto;
}

.sec06__item02 {
  height: min(61vw, 445px);
  position: relative;
}

.sec06__item02 picture {
  position: absolute;
  text-align: center;
}

.sec06__item02 picture img {
  max-width: min(51%, 360px);
}

.sec06__item03 {
  max-width: min(78%, 550px);
}

.sec06__text {
  font-size: clamp(24px, 1.846px + 6.154vw, 48px);
  font-weight: bold;
  line-height: 1.5;
}

.sec06__text .jump {
  font-size: clamp(36px, 2.769px + 9.231vw, 72px);
}

.sec06__text02 {
  font-size: clamp(15px, 1.154px + 3.846vw, 30px);
  text-align: center;
}

.sec-shopinfo__map iframe {
  height: 500px;
  width: 100%;
}

/* gotop ----------------- */
.gotop {
  background: #000;
}

.gotop__inner {
  margin-inline: auto;
  max-width: min(18%, 126px);
  padding: 2% 0;
}

/*
 * LINE友達募集ボタン
 * app追加ボタン
*/
.linecardbox,
.appcardbox {
  left: 0;
  position: relative;
  right: 0;
  width: 100%;
}

.linefriendbtn {
  bottom: 13%;
  display: block;
  left: 0;
  margin: auto;
  max-width: min(64%, 480px);
  position: absolute;
  right: 0;
}

.appfriendbtn {
  bottom: 6%;
  display: flex;
  gap: 4%;
  left: 0;
  margin-inline: auto;
  max-width: min(87%, 650px);
  position: absolute;
  right: 0;
}

.linefriendbtn:hover {
  opacity: .5;
}

.linefriendbtn2 {
  bottom: 20%;
  display: block;
  margin: auto;
  position: absolute;
  right: 5%;
  width: 44%;
}

.linefriendbtn2:hover {
  opacity: .5;
}

.cnt__ttl__wrap {
  margin-bottom: 3%;
}

.cnt__ttl {
  bottom: 110%;
  position: relative;
}

.cnt__ttl__content {
  margin-left: 25%;
  width: 75%;
}

.cnt__chara {
  bottom: -13%;
  left: -1%;
  position: absolute;
  z-index: 1;
}

.cnt__chara02 {
  bottom: -13%;
  position: absolute;
  right: -1%;
  z-index: 1;
}

.cnt__chara-width20 {
  width: 20%;
}

.cnt__chara-width25 {
  width: 25%;
}

.cnt__chara-width30 {
  width: 30%;
}

/* -------------------------------------- 調整用  */
.m0auto {
  margin: 0 auto;
}

.mb10ps {
  margin-bottom: 10%;
}

.pb10ps {
  padding-bottom: 10%;
}

@media screen and (max-width: 768px) {
  .hero {
  position: relative;
  height: 300px; /* 高さは好みで */
  background: url("../image/image-01-2.jpg") no-repeat center center/cover;
  display: flex;
  justify-content: center;
  align-items: center;
  color: white; /* タイトルなどが見やすいように */
  text-align: center;
}

/* モバイル用（600px以下） */
  .nav__inner {
display: none;
}
}