@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 {
  padding: 5%;
}



.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 ----------------- */
.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(24px, -4px + 6.667vw, 60px);
  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, 46px);
  font-weight: bold;
  line-height: 1.25;
  text-align: center;
}

.mv__text .jump {
  font-size: clamp(48px, 3.692px + 12.308vw, 96px);
}

.mv__text .jump2 {
  display: block;
  font-size: clamp(61px, 3.692px + 12.308vw, 77px);
  color: #FF0000;
  font-weight: 900;
  letter-spacing: -4px;
  margin-top: 3%;
}

.mv__text02 {
  color: #FF0101;
  font-size: clamp(28px, 1.538px + 5.128vw, 54px);
  text-align: center;
  margin-inline: auto;
  max-width: min(100%, 600px);
  position: relative;
  letter-spacing: -4px;
}

.mv__text02::before,
.mv__text02::after {
  content: "";
  display: block;
  border-top: 9px solid #FF0101;
  margin: 0.3em 0; /* 線と文字の間隔 */
}

@media (max-width: 400px) {

  .mv__text02::before,
  .mv__text02::after {
    width: 80%;   /* ← 横幅を少し短くする */
    margin: 5px auto; /* 中央寄せ */
    border-top: 6px solid #FF0101;
  }

  .mv__text03 .jump3 {
    margin-top: 15px;
}
}

.mv__text03 {
  color: #FF0101;
  font-size: clamp(20px, -2.154px + 6.154vw, 44px);
  font-weight: bold;
  text-align: center;
}

.mv__text03 .jump {
  font-size: clamp(45px, 2.308px + 7.692vw, 95px);
  font-weight: 400;
}

.mv__text03 .jump3 {
    display: inline-block;
    transform: scaleX(3) scaleY(1.5);
    transform-origin: center;
    margin-top: 20px;
}

.ouen {
  padding: 4% 10px;
}

.title {
    background: #DE9B9B;
    color: #ffffff;
    font-size: clamp(30px, 1.538px + 7.128vw, 56px);
    font-weight: bold;
    padding: 18px;
    text-align: center;
}

.title p {
  border: solid 5px #000000;
  padding: 34px 19px;
}

@media (max-width: 400px) {
  .title {
  padding: 9px 9px;
  }

  .title p {
    border: solid 2px #000000;
    padding: 18px 10px;
  }
}


/* sec01 ----------------- */
.sec01-flex {
  align-items: center;
  background: #e5e2da;
  display: flex;
  gap: 4%;
}

.sec01-flex__item:first-child {
  flex-grow: 1;
}

.sec01-flex__text {
  font-size: clamp(15px, 1.154px + 3.846vw, 30px);
  font-weight: bold;
  margin-bottom: 2%;
  margin-left: 4%;
}

.sec01-flex.-reverse {
  background: #fff;
}

.sec01-flex.-reverse .sec01-flex__item:first-child {
  order: 2;
}

.sec01-flex.-reverse .sec01-flex__item:last-child {
  order: 1;
}

.sec01__txtarea {
  background-color: #fff;
  border-radius: 8px;
  margin-bottom: 50px;
  padding: 20px;
}

.sec01__txtarea h3 {
  color: #000;
  font-size: clamp(13px, 3.5vw, 27px);
  font-weight: 700;
  letter-spacing: .05em;
  line-height: 1.7;
  text-align: center;
}

.sec01__txtarea h3 span {
  background-color: #fff000;
}

.sec01__txtarea p {
  font-size: clamp(13px, 3.5vw, 26.5px);
  font-weight: bold;
  line-height: 1.833;
  margin-bottom: 10%;
  text-align: center;
}

.sec01__txtarea p .changecolor01 {
  color: #c80000;
}
.sec01__txtarea p .changecolor02 {
  color: #00a100;
}

.sec01__ttl {
  position: relative;
}

.sec01__ttl h2 {
  margin-bottom: 20px;
}

/* sec02 ----------------- */
.sec02 {
  background-image: url('../image/img06.png');
}

.insta-link {
	display: inline-block;
	background-color: #ffffff;
	color: #fff;
	cursor: pointer;
	transition: all 0.3s ease 0s;
}
.insta-link:hover {
	opacity: 0.8;
}

/* 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(20px, 1.846px + 6.154vw, 40px);
  font-weight: bold;
  line-height: 1.5;
}

.sec06__text2 {
  font-size: clamp(20px, 1.846px + 6.154vw, 47px);
  font-weight: bold;
  line-height: 1.5;
  color: #D72A36;
}

.sec06__text2 .jump {
  font-size: clamp(36px, 2.769px + 9.231vw, 80px);
  color: #D72A36;
}

.sec06__text2 .jump2 {
  font-size: clamp(24px, 2.769px + 9.231vw, 64px);
  color: #D72A36;
  letter-spacing: -3px;
}

.sec06__text03 {
  font-size: clamp(18px, 1.154px + 3.846vw, 30px);
  text-align: left;
  margin-left: 5%;
}

.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: 7%;
  display: block;
  left: 0;
  margin: auto;
  max-width: min(64%, 480px);
  position: absolute;
  right: 0;
}
.insta-btn {
  bottom: 10%;
  display: block;
  left: 12px;
  margin: auto;
  max-width: min(64%, 480px);
  position: absolute;
  right: 0;
}
.insta-btn:hover {
  opacity: .5;
}

.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%;
}

.lh2em {
  line-height: 2em;
}

.animate__delay-05s {
  /* アニメーションの再生を遅らせる */
  animation-delay: .5s;
}

.animate__delay-1s {
  /* アニメーションの再生を遅らせる */
  animation-delay: 1s;
}

.animate__delay-1-5s {
  /* アニメーションの再生を遅らせる */
  animation-delay: 1.5s;
}
