@charset "UTF-8";

html{
 scroll-padding-top: 80px;
}

body {
  font-family: 'Noto Sans JP', sans-serif;
  color: #333;
  margin: 0 auto;
  background-color: #002927;
  display: flex;
  flex-direction: column;
  align-items: center;
  scroll-padding-top: 80px;
}

a{
  color: #415A9E;
}

a:hover{
  text-decoration: none;
}

p,h2,h3,li,th,td{
  font-feature-settings: "palt";
}

p{
  font-size: 12px;
}

li{
  list-style: none;
  text-align: justify;
}

img{
  width: 100%;
}

.img_link{
  margin-bottom: 14px;
}

.img_link:hover{
  opacity: 0.8;
  transition-duration: 0.4s;
}

.pc{
  display: none !important;
}
.sp{
  display: block !important;
}

/****注意文言*****/

.attention{
  font-size: 11px;
  text-indent: -12px;
  margin-left: 12px;
  text-align: justify;
  margin-bottom: 4px;
}

/****fv*****/

.anker_group {
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  display: flex;
  justify-content: space-evenly;
  background: white;
  box-shadow: 0 2px 5px rgba(0,0,0,0.1);
  transition: opacity 0.3s ease, transform 0.3s ease;
  z-index: 9999;
}

.anker_1,.anker_2,.anker_3,.anker_4,.anker_5 {
  display: flex;
  flex-wrap: nowrap;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  flex: 1;
  padding: 8px;
  text-decoration: none;
}

.anker_1{
  background: linear-gradient(#FFB159,#FF8800);
}

.anker_2{
  background: linear-gradient(#FFD063,#F4AB00);
}

.anker_3{
  background: linear-gradient(#FF81BA,#FF2989);
}

.anker_4{
  background: linear-gradient(#61C8FF,#00A6FF);
}

.anker_5{
  background: linear-gradient(#20D6E3,#00A1AD);
}

.anker_1 span,.anker_2 span,.anker_3 span,.anker_4 span,.anker_5 span {
  font-size: 10px;
  font-family: "Gamay-Editorial", sans-serif;
  font-weight: 500;
  color: #FFFF76;
  line-height: 12px;
  text-align: center;
  margin-bottom: 4px;
}

.anker_1 p,.anker_2 p,.anker_3 p,.anker_4 p,.anker_5 p {
  font-weight: 900;
  font-size: 12px;
  text-align: center;
  line-height: 16px;
  color: #fff;
}

.now_anker{
  display: flex;
  justify-content: center;
  width: 85%;
}

/****開催中・まもなくアイコン*****/

.kaisai_icon{
  position: relative
}

.now {
  position: absolute;
  top: -24px;
  width: 120px;
  transform: translateX(-155%) rotate(353deg);
}

.now_2 {
  position: absolute;
  top: -123px;
  width: 120px;
  transform: translateX(190%) rotate(-353deg);
}

.mamonaku {
  position: absolute;
  top: -38px;
  width: 116px;
  transform: translateX(56%) rotate(-353deg);
}


/****EVENT,CAMPAIGN*****/

#spesial_event, #campaign, #step3 {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

#spesial_event h2, .campaign_ttl {
  display: flex;
  align-items: center;
  margin-bottom: 20px;
  scroll-margin-top: 80px;
}

.campaign_ttl {
  position: relative;
  display: inline-block;
  padding-top: 40px;
}

.campaign_ttl::before {
  content: "";
  position: absolute;
  top: 5%;
  left: 36%;
  transform: translateX(-50%);
  width: 56px;
  height: 56px;
  background-image: url("../img/megaphone.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  z-index: 1;
  transform: rotate(20deg);
}

.ttl{
  font-family: 'Gamay-Editorial', sans-serif;
  font-weight: 700;
  font-style: italic;
  font-size: 36px;
  margin-bottom: 4px;
  background: linear-gradient(#FFFFFF,#FFFF00);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  display: inline-block;
  padding-right: 2px;
}

.anker_placeholder {
  height: 0;
  transition: height 0.3s ease;
}

.ttl_icon{
  width: 42px;
  transform: rotate(14deg);
}

.content_ttl_tradingcard{
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #F58200;
}

.ttl_label_nunber{
  font-family: "gamay-editorial", sans-serif;
  font-weight: bold;
  font-style: italic;
  font-size: 30px;
  margin-bottom: 4px;
  background: linear-gradient(#FFFFFF,#FFFF00);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  display: inline-block;
  transform: translateY(-3px);
  width: 21px;
}

.ttl_label{
  display: flex;
  align-items: center;
  margin-bottom: -8px;
  gap: 4px;

}

.ttl_label_event{
  font-weight: 900;
  font-size: 10px;
  color: #FFFF00;
  border-top: 1px solid #FFFF00;
  border-bottom: 1px solid #FFFF00;
  padding: 4px 2px;
  line-height: 1;
}

.ttl_label_sub{
  color: #FFFF00;
  font-size: 16px;
  font-weight: 700;
  transform: translateY(-1px);
}

.h3_date{
  font-weight: 900;
  font-size: 14px;
  color: #FFFFC1;
}

h3{
  font-family: "ruika","noto-sans-jp",sans-serif;
  font-weight: 100;
  color: #fff;
  font-size: 22px;
  text-align: center;
  line-height: 28px;
}

.curve{
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  margin-top: -0.5px;
  display: block;
  margin-bottom: 20px;
}

/****トレカ*****/

#content_tradingcard{
  background-color: #FFD599;
  width: 94%;
  margin-bottom: 40px;
}

.tradingcard_top{
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  padding:  0 12px 12px 12px;
}

.toreka_present{
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 2px;
  margin-bottom: 8px;
  position: relative;
  z-index: 2;
}

.icon_card_senchaku{
  width: 40px;
  position: absolute;
  top: -9px;
  left: 6px;
  z-index: 1;
  pointer-events: none; 
}

.icon_card_raijou{
  width: 60px;
  position: absolute;
  top: -28px;
  right: 10px;
  z-index: 1;
  pointer-events: none;
}

.gokurea_toreka{
  display: flex;
  width: 74%;
}

.text_present{
  font-size: 16px;
  font-weight: 500;
  margin-bottom: -2px;
}

.tradingcard_top_p_1{
  font-size: 16px;
  font-weight: 500;
}

.card_1{
  display: flex;
  transform: translateX(-5px);
}

.chusenkai_1{
  margin-bottom:20px;
}

.tradingcard_top_p_2{
  font-size: 18px;
  font-weight: 900;
  -webkit-text-stroke: 2px #E34500;
  paint-order: stroke;
  color: #fff;
}

.triangle-container {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin: 10px 0;
}

.triangle {
  width: 0;
  height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-top: 10px solid #FF743F;
}

.detail_anker_card{
  position: relative;
  text-decoration: none;
  margin-bottom: 10px;
  background: linear-gradient(#FF920C,#F55A00);
  padding: 14px 40px;
  padding-right: 50px;
  color: #fff;
  font-weight: 800;
  border-radius: 60px;
  font-size: 12px;
}

.detail_anker_card::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 17px;
  right: 38px;
  width: 6px;
  height: 6px;
  border-left: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
  transform: rotate(315deg);
}

/****ドリンク券****/

#content_drinkticket{
  background-color: #FFEBAB;
  width: 94%;
  margin-bottom: 40px;
  padding-bottom: 10px;
}

.content_ttl_drinkticket{
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #FFAA00;
}

.drinkticket_top{
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  padding: 0 12px 12px 12px;
}

.drinkticket_p_1{
  font-size: 15px;
  font-weight: 500;
}

.drinkticket_p_1 {
  position: relative;
  padding-left: 20px;
  margin-bottom: 8px;
}

.drinkticket_p_1::before {
  content: "";
  position: absolute;
  left: 0;
  top: 54%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: url("../img/icon_position.png") no-repeat center center;
  background-size: contain;
}

.p_booth{
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 12px;
}

.p_booth span{
  font-family: "ruika",serif;
  font-weight: 100;
  font-size: 22px;
  letter-spacing: 1px;
  -webkit-text-stroke: 2px #000;
  paint-order: stroke;
  color: #fff;
  background-color: #FFAA00;
  padding: 8px 8px;
  margin-right: 4px;
}

.drinkticket_p_2{
  font-weight: 700;
  font-size: 16px;
  text-align: center;
  color: #FF5E00;
  line-height: 20px;
  margin-top: 8px;
  margin-bottom: 10px;
}

/****写真撮影****/

#content_photo{
  background-color: #FFCAE5;
  width: 94%;
  margin-bottom: 40px;
}

.content_ttl_photo{
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #FF2989;
}

.photo_top{
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  padding: 0 12px 12px 12px;
}

.detail_anker_photo{
  position: relative;
  text-decoration: none;
  margin-bottom: 10px;
  background: linear-gradient(#ff78ae,#FF2989);
  padding: 14px 40px;
  padding-right: 50px;
  color: #fff;
  font-weight: 800;
  border-radius: 60px;
  font-size: 12px;
}

.detail_anker_photo::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 17px;
  right: 38px;
  width: 6px;
  height: 6px;
  border-left: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
  transform: rotate(315deg);
}

.campaign_date{
  margin-top: 10px;
  color: #fff;
  font-size: 14px;
  font-weight: 600;
}

.photo_ttl_sub{
  font-size: 17px;
  color: #FFFFC1;
  display: inline-block;
}

.photo_ttl_sub::before,.photo_ttl_sub::after {
  width: 2px;
  height: 18px;
  content: "";
  background-color: #FFFFC1;
  display: inline-block;
}

.photo_ttl_sub::before {
  margin-right: 0.5em;
  transform: rotate(-30deg) translateY(3px);
}

.photo_ttl_sub::after {
  margin-left: 0.5em;
  transform: rotate(30deg) translateY(3px);
}

.photo_left{
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  margin-bottom: 16px;
}

.photo_left_top{
  display: flex;
  flex-direction: row;
  gap: 4px;
}

.photo_chusen1kumi{
  width: 40%;
  margin-bottom: -4px;
}

.photo_left_top_inner_p1{
  font-size: 21px;
  line-height: 30px;
  font-family: "ruika","noto-sans-ckj-jp";
  font-weight: 100;
  -webkit-text-stroke: 2px #333;
  paint-order: stroke;
  color: #FFFF63;
}

.photo_left_top_inner_p2{
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 6px;
}

.photo_right{
  width: 54%;
  display: flex;
  transform: translateY(-5px);
}

.photo_content{
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
}

/****おサイフキャンペーン****/

#content_osaifucp{
  background-color: #C3EAFF;
  width: 94%;
  margin-bottom: 40px;
}

.content_ttl_osaifucp{
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #00A6FF;
}

.osaifucp_top{
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  padding: 0 12px 12px 12px;
}

.detail_anker_osaifucp{
  position: relative;
  text-decoration: none;
  margin-bottom: 10px;
  background: linear-gradient(#57C1FA,#0099FF);
  padding: 14px 40px;
  padding-right: 50px;
  color: #fff;
  font-weight: 800;
  border-radius: 60px;
  font-size: 12px;
}

.detail_anker_osaifucp::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 17px;
  right: 38px;
  width: 6px;
  height: 6px;
  border-left: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
  transform: rotate(315deg);
}

.osaifucp_top_ttl{
  font-family: "ruika","noto-sans-jp";
  font-weight: 100;
  font-size: 16px;
  color: #fff;
  display: inline-block;
  -webkit-text-stroke: 2px #0076B7;
  paint-order: stroke;
  margin-bottom: 10px;
}

.osaifucp_top_content{
  display: flex;
  flex-direction: column;
}

.osaifucp_prize{
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 8px;
}

.attached{
  position: absolute;
  width: 30%;
  top: 20px;
  right: 10px;
}

/****応援の声募集****/

.yell_ttl img{
  position: absolute;
  width: 54%;
  left: 60px;
  top: -52px;
}

.yell_ttl_sub{
  color: #FFFF00;
}

.yell_ttl{
  position: relative;
  background-color: #002927;
  color: #fff;
  text-align: center;
  font-family: "ruika","noto-sans-jp";
  font-weight: 100;
  font-size: 22px;
  padding-top: 20px;
  padding-bottom: 10px;
}

.yell_ttl::before {
  content: "";
  position: absolute;
  top: -58%;
  left: 11%;
  width: 180px;
  height: 180px;
  background-image: url("../img/flag.png");
  background-size: contain;
  background-repeat: no-repeat;
  clip-path: inset(0px 0px 80px 0px);
}

#content_yell{
  background-color: #E9F8F7;
  width: 94%;
  margin: 60px 0;
}

.content_ttl_yell{
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #00A1AD;
  padding-top: 12px;
}

.yell_top{
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  position: relative;
  padding: 0 12px 12px 12px;
  gap: 14px;
}

.yell_top_text{
  display: flex;
  flex-direction: column;
  font-size: 14px;
  text-align: center;
}

.yell_apply{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 20px;
  padding-top: 24px;
  margin: 20px;
  background-color: #fff;
  border: 1px solid #00A1AD;
  border-radius: 24px;
}

.yell_apply_ttl{
  font-size: 17px;
  font-weight: 900;
  color: #00A1AD;
}

.apply_line {
  width: 100%;
  height: 1px;
  background-color: #00A1AD;
  margin: 6px;
}

.yell_apply_step{
  display: flex;
  flex-direction: row;
  gap: 10px;
  margin-top: 10px;
}

.icon_yell_apply_step{
  font-family: "gamay",sans-serif;
  font-weight: 600;
  font-size: 12px;
  line-height: 16px;
}

.yell_apply_step_group{
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.icon_yell_apply_step span{
  font-size: 20px;
  margin-bottom: 3px;
}

.yell_apply_step_text{
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 14px;
}

.yell_apply_step_text span{
  font-weight: 900;
  color: #F58200;
}

.yell_apply_step_text p{
  font-weight: 600;
  font-size: 14px;
}

.icon_yell_apply_step{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #00A1AD;
  color: #fff;
  width: 50px;
  height: 50px;
  border-radius: 50px;
}

.btn_yell_apply{
  position: relative;
  text-decoration: none;
  background: linear-gradient(#666,#000);
  padding: 14px 30px;
  padding-right: 40px;
  color: #fff;
  font-weight: 800;
  border-radius: 60px;
  font-size: 12px;
  text-align: center;
  margin-bottom: 10px;
  width: 100px;
}

.btn_yell_apply::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 19px;
  right: 35px;
  width: 6px;
  height: 6px;
  border-left: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
  transform: rotate(225deg);
}

.btn_yell_apply img{
  width: 14px;
  margin-top: 2px;
  margin-right: 6px;
}

.yell_bottom{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 10px 30px 30px 30px;
  gap: 20px;
}

.yell_bottom p{
  text-align: center;
  font-size: 14px;
  font-weight: 600;
}

.btn_detail_apply{
  width: 80%;
  text-align: center;
  text-decoration: none;
  margin-bottom: 10px;
  background: linear-gradient(#20C1CD,#00A1AD);
  padding: 14px 40px;
  color: #fff;
  font-weight: 800;
  border-radius: 60px;
  font-size: 12px;
  cursor: pointer;
}

/****モーダル*****/

.modal {
  position: fixed;
  top: 0; left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(0, 0, 0, 0.6);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;;
  display: none;
}

.modal.is-active {
  display: flex;
}

.modal-container {
  position: relative;
  background: #fff;
  width: 90%;
  max-width: 800px;
  max-height: 90vh;
}

/* ← このボタンを右上に固定 */
.modal-close {
  position: absolute;
  top: 18px;
  right: 16px;
  z-index: 10;
  background: none;
  border: none;
  font-size: 14px;
  font-weight: 700;
  line-height: 14px;
  text-align: right;
  cursor: pointer;
  color: #ffffff;
  text-align: center;
}

/* 中身をスクロールできるようにする */
.yell_modal-content {
  overflow-y: auto;
  max-height: calc(90vh - 50px); /* 閉じるボタンのスペース確保 */
  padding: 16px;
  text-align: center;
  flex-grow: 1; /* スクロール部分を伸ばす */
}

.yell_modal-content p{
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 10px;
}


/* テーブルを画面いっぱいに広げる */
.yell_table {
  width: 100%;
  font-size: 12px;
  table-layout: fixed;
  border-collapse: collapse;
}

.yell_table th {
  padding: 8px;
  text-align: center;
  border: 1px solid #b0b0b0;
  background-color: #f5f5f5;
}

.yell_table td{
  padding: 8px;
  text-align: left;
  border: 1px solid #b0b0b0;
}

.yell_table th {
  width: 50px;
}

/****トレカ*****/

#content_tradingcard_2{
  background-color: #FFD599;
  width: 94%;
  margin-bottom: 40px;
}

.tradingcard_top_2{
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  padding:  0 12px;
}

.toreka_present_2{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  margin-bottom: 8px;
  position: relative;
  z-index: 2;
}

.icon_card_senchaku_2{
  width: 50px;
  position: absolute;
  top: -16px;
  left: 9px;
  z-index: 1;
  pointer-events: none; 
}

.icon_card_raijou_2{
  width: 60px;
  position: absolute;
  top: -30px;
  right: 10px;
  z-index: 1;
  pointer-events: none;
}

.gokurea_toreka_2{
  display: flex;
}

.text_present_2{
  font-size: 18px;
  font-weight: 500;
  margin-bottom: -2px;
}

.tradingcard_top_2_p_1{
  font-size: 17px;
  font-weight: 500;
}

.card_2{
  display: flex;
  transform: translateX(-5px);
}

.tradingcard_top_2_p_2{
  font-size: 18px;
  font-weight: 900;
  -webkit-text-stroke: 2px #E34500;
  paint-order: stroke;
  color: #fff;
}

.triangle-container_2 {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin: 14px 0 16px 0;
}

.tradingcard_bottom{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 20px;
  padding-top: 24px;
  margin: 0 20px 20px 20px;
  border-radius: 24px;
  background-color: #FFF9F1;
}

.tradingcard_bottom_line {
  width: 100%;
  height: 1px;
  background-color: #000;
  margin: 24px 0;
}

.chusenkai_ttl{
  width: 75%;
  padding-right: 14px;
}

.chusen_fukidashi{
  width: 90%;
  margin-bottom: 10px;
}

.tradingcard_bottom_p1 {
  font-size: 21px;
  line-height: 26px;
  font-family: "ruika", "noto-sans-ckj-jp";
  font-weight: 100;
  -webkit-text-stroke: 2px #333;
  paint-order: stroke;
  color: #FFFF00;
  text-align: center;
  margin-bottom: 2px;
}

.tradingcard_bottom_p2{
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 6px;
}

.tradingcard_bottom_p3{
  font-size: 14px;
  font-weight: 900;
  color: #E94709;
}

.tradingcard_bottom_p4{
  text-align: center;
  font-weight: 800;
  margin-top: 10px;
}

.baffaloes_tradingcard{
  display: flex;
  flex-direction: row;
  align-items: center;
  margin: 20px;
  gap: 10px;
}

.toreka_iphone{
  width: 100%;
  height: auto;
}

.baffaloes_tradingcard_right{
  display: flex;
  flex-direction: column;
  align-items: center;
}

.toreca_logo{
  width: 45%;
  height: auto; 
  margin-bottom: 6px;
}

.toreka_search{
  display: flex;
  flex-direction: row;
  align-items: center;
  margin-top: 10px;
}

.toreka_search_p_1{
  text-align: center;
  font-weight: 600;
  color: #1C276B;
  line-height: 16px;
}

.toreka_search_p{
  background-color: #fff;
  padding: 0 16px;
  height: 34px;
  line-height: 34px;
  font-size: 14px;
  font-weight: 900;
  color: #1C276B;
  border: 1px solid #1C276B;
  border-radius: 8px 0 0 8px;
}

.icon_search{
  width: 20px;
  background-color: #1C276B;
  padding: 7.9px 10px;
  border-radius: 0 8px 8px 0;
}

.btn_detail_toreka{
  position: relative;
  text-decoration: none;
  margin-top: 14px;
  background: linear-gradient(#FF920C,#F55A00);
  padding: 12px 40px;
  padding-right: 50px;
  color: #fff;
  font-weight: 800;
  border-radius: 60px;
  font-size: 12px;
}

.btn_detail_toreka::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 17px;
  right: 40px;
  width: 6px;
  height: 6px;
  border-left: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
  transform: rotate(225deg);
}

/****写真撮影****/

#content_photo_2{
  background-color: #FFCAE5;
  width: 94%;
  margin-bottom: 40px;
}

.photo_top_2{
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  padding: 0 12px 12px 12px;
}

.photo_left_2{
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  margin-bottom: 16px;
}

.photo_left_top_2{
  display: flex;
  flex-direction: row;
  gap: 4px;
}

.photo_left_top_inner_p1_2{
  font-size: 21px;
  line-height: 30px;
  font-family: "ruika","noto-sans-ckj-jp";
  font-weight: 100;
  -webkit-text-stroke: 2px #333;
  paint-order: stroke;
  color: #FFFF63;
}

.photo_left_top_inner_p2_2{
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 6px;
}

.photo_right_2{
  width: 54%;
  height: 54%;
  display: flex;
  transform: translateY(-13px);
}

.photo_content_2{
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
}

.campaign_detail_photo_box{
  display: flex;
  align-items: center;
  flex-direction: column;
  padding: 0 12px;
  margin-top: -14px;
  margin-bottom: 20px;
  gap: 4px;
}

.campaign_detail_photo_ttl{
  text-align: center;
  background-color: #FF64AA;
  width: 100%;
  padding: 8px 0;
}

.campaign_detail_photo_ttl p{
  font-weight: 800;
  color: #fff;
}

.campaign_detail_photo_row{
  display: flex;
  gap: 4px;
  width: 100%;
}

.campaign_detail_photo_label{
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #fff;
  color: #F4006E;
  font-weight: 800;
  text-align: center;
  padding: 8px;
  width: 80px;
}

.campaign_detail_photo_content{
  width: 100%;
  background-color: #fff;
  padding: 8px;
}

.campaign_detail_photo_content p{
  margin-bottom: 4px;
}

.campaign_detail_photo_content{
  text-align: justify;
}

.campaign_info{
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #FF2989;
  padding: 12px;
  margin: 12px;
}

.campaign_info_ttl{
  font-weight: 800;
  color: #FF2989;
  background-color: #fff;
  padding: 4px 12px 4px 14px;
  border-radius: 30px;
  margin-bottom: 8px;
}

.campaign_info_text{
  text-align: center;
  color: #fff;
  font-weight: 600;
}

.campaign_info_text span{
  color: #FFFF00;
}

.campaign_attention{
  font-size: 12px;
  text-indent: -1.3rem;
  margin-left: 1.3rem;
  margin-bottom: 4px;
}

.campaign_attention_number{
  font-size: 11px;
  text-indent: -20px;
  margin-left: 20px;
  margin-bottom: 4px;
}

.campaign_attention_box{
  padding: 0 12px;
}

.accordion_box {
  padding: 12px;
  margin-top: -20px;
}

.more {
  list-style-type: none;
  color: #415A9E;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;

  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  padding-right: 24px; 
  margin-bottom: 16px;
}

.more::-webkit-details-marker,
.more::marker {
  display: none;
}

.more::before,
.more::after {
  content: "";
  position: absolute;
  background-color: #415A9E;
}

.more::before {
  width: 12px;
  height: 2px;
  transform: translateX(407%);
}

.more::after {
  width: 2px;
  height: 12px;
  transform: translateX(2439%)
}

.accordion_box[open] .more::after {
  opacity: 0;
}

/****おサイフキャンペーン****/

#content_osaifucp_2{
  background-color: #C3EAFF;
  width: 94%;
  margin-bottom: 20px;
}

.content_ttl_osaifucp_2{
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #00A6FF;
}

.osaifucp_top_2{
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  padding: 0 12px 12px 12px;
}

.attached_2{
  position: absolute;
  width: 30%;
  transform: translateY(10%);
  right: 10px;
}

.osaifucp_top_content_2{
  display: flex;
  flex-direction: column;
  margin-bottom: 10px;
}

.campaign_detail_osaifu_box{
  display: flex;
  align-items: center;
  flex-direction: column;
  padding: 0 12px;
  margin-top: -14px;
  margin-bottom: 20px;
  gap: 4px;
}

.campaign_detail_osaifu_ttl{
  text-align: center;
  background-color: #51C2FF;
  width: 100%;
  padding: 8px 0;
}

.campaign_detail_osaifu_ttl p{
  font-weight: 800;
  color: #fff;
}

.campaign_detail_osaifu_row{
  display: flex;
  gap: 4px;
  width: 100%;
}

.campaign_detail_osaifu_label{
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #fff;
  color: #0395E3;
  font-weight: 800;
  text-align: center;
  padding: 8px;
  width: 80px;
}

.campaign_detail_osaifu_content{
  width: 100%;
  background-color: #fff;
  padding: 8px;
}

.campaign_detail_osaifu_content p{
  margin-bottom: 4px;
}

.campaign_detail_osaifu_content{
  text-align: justify;
}

/****ボタンなど*****/

.conversion{
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 12px;
}

.conversion_attention{
  background-color: #DF3C3C;
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  padding: 10px 20px;
  margin-bottom: 24px;
  text-align: center;
  position: relative;
}

.conversion_attention::after {
  content: "";
  position: absolute;
  bottom: -12px;
  left: 45%;
  background: #DF3C3C;
  height: calc(tan(30deg) * 50px / 2);
  width: 20px;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  transform: rotate(180deg);
}

.btn_download{
  position: relative;
  text-decoration: none;
  background: linear-gradient(#FF9558,#FF5E00);
  padding: 20px;
  width: 80%;
  text-align: center;
  border-radius: 100px;
  box-shadow: 3px 4px 0px rgba(0, 0, 0, 0.1);
}

.btn_download p{
  color: #fff;
  font-size: 16px;
  font-weight: 900;
  margin-right: 18px;
}

.btn_download p::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 28px;
  right: 90px;
  width: 8px;
  height: 8px;
  border-left: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(225deg);
}

.btn_entry{
  position: relative;
  text-decoration: none;
  background: linear-gradient(#fff,#F2F2F2);
  padding: 20px;
  width: 80%;
  text-align: center;
  border-radius: 100px;
  border: 1px solid #FF5E00;
}

.btn_entry p{
  color: #FF5E00;
  font-size: 16px;
  font-weight: 900;
  margin-right: 18px;
}

.btn_entry p::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 28px;
  right: 90px;
  width: 8px;
  height: 8px;
  border-left: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(225deg);
}

/****STEP1****/

#content_3step_step1{
  background-color: #DDFAFF;
  width: 94%;
  margin-bottom: 40px;
}

#step3 h2{
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #fff;
  font-size: 16px;
  font-weight: 900;
}

.step3_ttl {
  position: relative;
  display: inline-block;
}

.content_ttl_step1{
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #00B2D1;
}

.step1_top{
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  padding: 0 12px 12px 12px;
}

.step1_container{
  display: flex;
  flex-direction: row;
  gap: 12px;
  margin-bottom: 12px;
}

.step_box{
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #FAFDFF;
  border: 1px solid #60ADBB;
  border-radius: 16px;
  padding: 10px 16px;
  width: 50%;
}

.step_box_number{
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "gamay",sans-serif;
  font-weight: 500;
  font-size: 14px;
  color: #fff;
  background-color: #2AB7D0;
  width: 26px;
  height: 24px;
  padding-bottom: 2px;
  border-radius: 30px;
  margin-bottom: 4px;
}

.step_box_ttl{
  font-size: 15px;
  font-weight: 700;
  color: #045D7D;
}

.step_box_text{
  text-align: center;
}

.step1_attention{
  color: #DF3C3C;
  font-weight: 600;
  text-align: center;
  margin-top: 10px;
  margin-bottom: 10px;
}

/****STEP2****/

#content_3step_step2{
  background-color: #DDFAFF;
  width: 94%;
  margin-bottom: 40px;
}

.content_ttl_step2{
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #15A1CB;
}

.step2_top{
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  padding: 0 12px 12px 12px;
}

.btn_osaifu{
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  border: 1px solid #007295;
  text-decoration: none;
  padding: 10px 20px;
  border-radius: 50px;
  margin-top: 10px;
  gap: 6px;
  cursor: pointer;
  width: 50%;
  box-shadow: 2px 3px 0px #b8e3ea;
}

.btn_osaifu p{
  color: #007295;
  font-weight: 600;
}

.step2_tabs {
  display: flex;
  flex-wrap: wrap;
  padding: 12px;
  padding-bottom: 30px;
}

.step2_tabs label + label {
  margin-left: 8px;
}

.step2_tabs input[type="radio"] {
  position: absolute;
  opacity: 0;
}

.step2_tabs label {
  cursor: pointer;
  flex: 1;
  padding: 10px 0;
  text-align: center;
  font-size: 13px;
  font-weight: 600;
  border-bottom: 2px solid transparent;
  user-select: none;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 20px 20px 0 0;
}

.label1 {
  background-color: #f7ebf0;
  color: #c2185b;
  border: 1px solid #c2185b;
}

.label2 {
  background-color: #e0f7f6;
  color: #00796b;
  border: 1px solid #00796b;
}

#tab1:checked + .label1 {
  font-weight: 900;
  background: linear-gradient(#FF72B1, #FF2688);
  color: #fff;
  border: none;
  margin-right: 10px;
}

#tab2:checked + .label2 {
  font-weight: 900;
  background: linear-gradient(#58D5D1, #1CA9A3);
  color: #fff;
  border: none;
  margin-left: 10px;
}

#tab1:checked ~ #content1 {
  display: block;
  background-color: #F9EBF1;
  border: 1px solid #FF2688;
  border-radius: 0 0 20px 20px;
  width: 100%;
}

#tab2:checked ~ #content2 {
  display: block;
  background-color: #D5F2F1;
  border: 1px solid #319098;
  border-radius: 0 0 30px 30px;
  width: 100%;
}

.step2_tab-content {
  display: none;
  padding: 20px;
}

.content_megami{
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #fff;
  padding: 12px;
  border-radius: 16px;
  margin-bottom: 16px;
}

.content_megami img{
  width: 70%;
  margin: 12px;
}

.content_megami_step{
  font-family: "gamay",sans-serif;
  font-weight: 700;
  font-size: 13px;
  color: #FF64AA;
}

.content_megami_step span{
  font-size: 20px;
}

.content_megami_text{
  color: #782349;
  font-weight: 600;
  font-size: 13px;
  text-align: center;
}

.content_hataraku{
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #fff;
  padding: 12px;
  border-radius: 16px;
  margin-bottom: 16px;
}

.content_hataraku img{
  width: 70%;
  margin: 12px;
}

.content_hataraku_step{
  font-family: "gamay",sans-serif;
  font-weight: 700;
  font-size: 13px;
  color: #00A5BB;
}

.content_hataraku_step span{
  font-size: 20px;
}

.content_hataraku_text{
  color: #1C6C80;
  font-weight: 600;
  font-size: 13px;
  text-align: center;
}


.osaifu_modal-content {
  overflow-y: auto;
  max-height: calc(90vh - 50px); /* 閉じるボタンのスペース確保 */
  padding: 16px;
  text-align: center;
  flex-grow: 1; /* スクロール部分を伸ばす */
  background-color: #D2EFFF;
}

.osaifu_modal-content_top_ttl{
  font-family: "ruika","noto-sans-jp";
  font-size: 18px;
  margin-bottom: 6px;
  font-weight: 100;
  -webkit-text-stroke: 2px #002C8A;
  paint-order: stroke;
  color: #fff;
}

.osaifu_modal-content_top_text{
  margin-bottom: 16px;
}

.osaifu_modal-type{
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  border-radius: 20px;
  padding: 14px;
  gap: 20px;
  margin-bottom: 20px;
}

.osaifu_modal-type_group{
  display: flex;
  gap: 10px;
  align-items: center;
}

.osaifu_modal-type_left{
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  width: 60%;
  gap: 4px;
}

.alphabet_hataraku{
  font-family: "gamay",sans-serif;
  font-weight: 800;
  font-size: 18px;
  color: #62C3C9;
}

.osaifu_modal-type_left_sub_hataraku{
  font-weight: 700;
  color: #00A1AD;
}

.osaifu_modal-type_right_coupon_hataraku{
  font-weight: 800;
  color: #00A1AD;
}


.osaifu_modal-type_right{
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 50%;
}

.osaifu_modal-type_right_content{
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
}

.osaifu_modal-type_right_content_ttl_hataraku{
  line-height: 16px;
  background-color: #00A1AD;
  color: #fff;
  padding: 4px 10px;
  font-weight: 600;
  width: 35%;
}

.osaifu_modal-type_right_content_text_hataraku{
  font-size: 15px;
  font-weight: 900;
  color: #006E7B;
}

.osaifu_modal_btn_hataraku{
  background: linear-gradient(#3AA6B2,#006E7B);
  padding: 14px 0;
  width: 70%;
  color: #fff;
  font-weight: 700;
  border-radius: 40px;
  font-size: 11px;
  text-decoration: none;
}

.color_hataraku{
  background-color: #F5FEFF;
  border: 1px solid #00A1AD;
}

.color_mamori{
  background-color: #FFFCF7;
  border: 1px solid #F58200;
}

.color_megami{
  background-color: #FFFDFF;
  border: 1px solid #EC599B;
}


.osaifu_modal-type_left_sub_mamori{
  font-weight: 700;
  color: #FF9F00;
}

.alphabet_mamori{
  font-family: "gamay",sans-serif;
  font-weight: 800;
  font-size: 18px;
  color: #F8B569;
}

.osaifu_modal-type_right_content_ttl_mamori{
  line-height: 16px;
  background-color: #F5B140;
  color: #fff;
  padding: 4px 10px;
  font-weight: 600;
  width: 35%;
}

.osaifu_modal-type_right_content_text_mamori{
  font-size: 15px;
  font-weight: 900;
  color: #E76400;
}

.osaifu_modal-type_right_coupon_mamori{
  font-weight: 800;
  color: #F5B140;
}

.osaifu_modal_btn_mamori{
  background: linear-gradient(#FF9A4D,#E76400);
  padding: 14px 0;
  width: 70%;
  color: #fff;
  font-weight: 700;
  border-radius: 40px;
  font-size: 11px;
  text-decoration: none;
}


.osaifu_modal-type_left_sub_megami{
  font-weight: 700;
  color: #FF7AB6;
}

.alphabet_megami{
  font-family: "gamay",sans-serif;
  font-weight: 800;
  font-size: 18px;
  color: #FFADD2;
}

.osaifu_modal-type_right_coupon_megami{
  font-weight: 800;
  color: #FF7AB6;
}

.osaifu_modal-type_right_content_ttl_megami{
  line-height: 16px;
  background-color: #FF7AB6;
  color: #fff;
  padding: 4px 10px;
  font-weight: 600;
}

.osaifu_modal-type_right_content_text_megami{
  font-size: 15px;
  font-weight: 900;
  color: #C50059;
}

.osaifu_modal-type_right_content_text_megami_group{
  display: flex;
  flex-direction: row;
  gap: 10px;
}

.osaifu_modal-type_right_content_megami{
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
}

.osaifu_modal-type_right_content_text_megami_sub{
  font-weight: 500;
  font-size: 9px;
  line-height: 12px;
  color: #C50059;
}

.osaifu_modal_btn_megami{
  background: linear-gradient(#E15C98,#C50059);
  padding: 14px 0;
  width: 70%;
  color: #fff;
  font-weight: 700;
  border-radius: 40px;
  font-size: 11px;
  text-decoration: none;
}


.ui_reason{
  display: flex;
  flex-direction: column;
  margin-top: 40px;
}

.ui_reason_ttl{
  font-family: "ruika", "noto-sans-jp";
  font-size: 18px;
  margin-bottom: 6px;
  font-weight: 100;
  color: #002C8A;
}

.ui_reason_content_box{
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-bottom: 20px;
}

.ui_reason_content{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 35%;
  background-color: #fff;
  padding: 20px;
  border-radius: 14px;
  gap: 10px;
}

.ui_reason_content p{
  color: #002C8A;
  font-weight: 800;
  font-size: 14px;
  line-height: 18px;
}

.ui_reason_content span{
  font-weight: 500;
  font-size: 10px;
}

.ui_reason_content_illust{
  display: flex;
}

/****STEP3****/

.step_anker_group{
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  align-items: stretch;
  padding: 12px;
  gap: 12px;
  margin-bottom: 30px;
}

.step_anker{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-around;
  background-color: #DDFAFF;
  padding: 12px;
  padding-bottom: 30px;
  border-radius: 14px;
  width: 100%;
  text-decoration: none;
  position: relative;
}

.step_anker p::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 89%;
  right: 45%;
  width: 8px;
  height: 8px;
  border-left: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(315deg);
}

.step_anker_label{
  font-family: "gamay",sans-serif;
  font-weight: 600;
  font-size: 13px;
  padding: 0 12px 4px 12px;
  color: #fff;
  background-color: #00BEE0;
  border-radius: 30px;
  margin-bottom: 6px;
}

.step_anker_label span{
  font-size: 18px;
}

.step_anker_text{
  text-align: center;
  margin-bottom: 6px;
  font-weight: 700;
  font-size: 14px;
  line-height: 18px;
  color: #045D7D;
}

.step_anker_image_wrapper{
  text-align: center;
}

.step_anker img{
  display: block;
  width: 100%;
  text-align: center;
  margin-left: 8%;
}

.step_attention {
  font-size: 11px;
  text-indent: -12px;
  margin-left: 12px;
  text-align: justify;
  margin-bottom: 30px;
  color: #fff;
  padding: 12px;
  margin-top: -40px;
}

#content_3step_step3{
  background-color: #DDFAFF;
  width: 94%;
  margin-bottom: 40px;
}

.content_ttl_step3{
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #078CB9;
}

.step3_top{
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  padding: 0 12px 12px 12px;
  margin-bottom: 20px;
}

.step3_top_text{
  text-align: center;
  margin-bottom: 12px;
}

/****footer*****/

footer ul li{
  color: #6F6F6F;
  padding-bottom: 3px;
  text-indent: -1.3rem;
  margin-left: 1.3rem;
  }
  
  
  a img.btn:hover{
  opacity: 0.7;
  transition-duration: 0.4s;
  }
  
  .contents{
  margin: 60px auto;
  }
  
  
  footer{
  background-color: #F1F1F1;
  width: 100%;
  }
  
  footer .inner{
    padding: 30px 0;
    margin: 0 auto 10px;
    width: 90%;
    max-width: 1000px;
    color: #808080;
    font-size: 12px;
  }
  
  footer .inner ul li{
   color: #808080;
   font-weight: 400;
  }
  
  footer h4{
  border-bottom: 1px solid #808080;
  display: block;
  margin-bottom: 10px;
  font-size: 14px;
  padding-bottom: 5px;
  font-weight: 500;
  }
  
  footer p span{
  font-weight: 600;
  color: #141E50;
  }


@media screen and (min-width:451px) {
  html{
    background-image: url(../img/bg_img.jpg);
    background-size: cover;         /* 画面いっぱいに表示（必要に応じて） */
  background-repeat: no-repeat;   /* 繰り返さない */
  background-position: center;    /* 中央に表示 */
  background-attachment: fixed;
  }

  body{
    max-width:450px;
    margin: 0 auto;
    box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, .1);
  }

  h1{
    margin-bottom: -80px;
  }

  .sp{
    display: none !important;
  }
  .pc{
    display: block !important;
  }

  .fv_img{
    margin-bottom: 80px;
  }

  .anker_group {
    width: 450px;
    margin: 0 auto;
    transition: background 0.3s ease, box-shadow 0.3s ease;
  }
  
.now_anker{
    width: 70%;
}

  .photo_left_top_inner_p1 {
    font-size: 24px;
}

.photo_hero {
  width: 80%;
  display: flex;
  transform: translateY(-9px);
}

.osaifucp_top_ttl {
  font-size: 18px;
}

.modal-container{
  width: 500px;
}

.modal-close{
  display: none;
}


footer{
    background-color: #f1f1f1;
    padding-bottom: 80px;
    width: 100%;
}

}
