@charset "UTF-8";
* {
  margin: 0;
  padding: 0;
}
@font-face {
  font-family: 'Noto Serif JP', serif;
  font-weight: 600;
  src: url("../font/NotoSerifJP-SemiBold_subset.woff") format("woff"), url('../font/NotoSerifJP-SemiBold_subset.otf') format('opentype');
}
html {
  overflow-y: scroll;
}
img {
  border: none;
  vertical-align: top;
}
.clear {
  clear: both;
}
.campaignlp_page {
  overflow: hidden;
}
body.device_tablet {
  min-width: 1200px;
}
@media (max-width: 768px) {
  body, body.device_tablet {
    min-width: initial;
  }
}
body {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 16px;
  -webkit-text-size-adjust: 100%
}
header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 86px;
  background: #e70012;
  display: flex;
  align-items: center;
  z-index: 5000;
}
header .header_inner {
  width: 100%;
  box-sizing: border-box;
  padding: 0 40px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
header .header_inner img {
  width: 100%;
  height: auto;
}
header .header_logo {
  width: 75px;
}
header .header_sns {
  display: flex;
}
header .header_sns_line, header .header_sns_twitter {
  width: 39px;
}
header .header_sns_line {
  margin-right: 30px;
}
.hero_container {
  position: relative;
  overflow: hidden;
}
.hero_container #particles_upper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 800px;
  z-index: 0;
}
.hero_section {
  background: #d82425;
  background: url("../images/hero_bg_pc.png") repeat-x center bottom;
  background-size: auto 100%;
  position: relative;
  overflow: hidden;
  min-height: 700px;
  margin-top: 85px;
}
.hero_section .hero_inner {
  max-width: 960px;
  margin: 0 auto;
  position: relative;
  min-height: 700px;
}
.hero_section .hero_inner .hero_logo {
  width: 260px;
  position: absolute;
  left: 343px;
  top: 47px;
  z-index: 500;
}
.hero_section .hero_inner .hero_logo img {
  width: 100%;
  height: auto;
}
.hero_section .hero_inner .hero_catch1, .hero_section .hero_inner .hero_catch2 {
  position: absolute;
  z-index: 200;
}
.hero_section .hero_inner .hero_catch1 div, .hero_section .hero_inner .hero_catch2 div {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}
.hero_section .hero_inner .hero_catch1 img, .hero_section .hero_inner .hero_catch2 img {
  width: 100%;
  height: auto;
}
.hero_section .hero_inner .hero_catch1 {
  width: 180px;
  left: 822px;
  top: 34px;
}
.hero_section .hero_inner .hero_catch2 {
  width: 205px;
  left: -51px;
  top: 34px;
}
.hero_section .hero_inner .hero_chara {
  width: 858px;
  margin: 0 0 0 50px;
  z-index: 100;
  min-height: 700px;
  top: 19px;
}
.hero_section .hero_copyright {
  width: 100%;
  text-align: center;
  font-size: 11px;
  color: #fff;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  position: absolute;
  left: 0;
  bottom: 10px;
  display: flex;
  justify-content: center;
}
.hero_section .hero_copyright_caption {
  width: 200px;
}
.hero_section .hero_copyright_caption img {
  width: 100%;
  height: auto;
}
.hero_section .hero_inner .hero_cloud1, .hero_section .hero_inner .hero_cloud2, .hero_section .hero_inner .hero_cloud3, .hero_section .hero_inner .hero_cloud4 {
  position: absolute;
}
.hero_section .hero_inner .hero_cloud1 {
  top: 0;
  left: -208px;
  width: 577px;
}
.hero_section .hero_inner .hero_cloud2 {
  top: -36px;
  left: 549px;
  width: 968px;
}
.hero_section .hero_inner .hero_cloud3 {
  top: 494px;
  left: -349px;
  width: 707px;
}
.hero_section .hero_inner .hero_cloud4 {
  top: 529px;
  left: 601px;
  width: 787px;
}
.hero_section .hero_cloud1 div, .hero_section .hero_cloud2 div, .hero_section .hero_cloud3 div, .hero_section .hero_cloud4 div {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}
.hero_section .hero_cloud1 img, .hero_section .hero_cloud2 img, .hero_section .hero_cloud3 img, .hero_section .hero_cloud4 img {
  width: 100%;
  height: auto;
}
.hero_inner .hero_chara {
  position: relative;
}
.hero_inner .hero_chara .hero_center {
  width: 480px;
  position: relative;
  left: 0186px;
  top: 113px;
}
.hero_inner .hero_chara .hero_center div {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}
.hero_inner .hero_chara .hero_chara_upper, .hero_inner .hero_chara .hero_chara_lower {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}
.hero_inner .hero_chara .hero_chara_center {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}
.hero_inner .hero_chara .hero_chara_upper div, .hero_inner .hero_chara .hero_chara_lower div {
  position: absolute;
}
.hero_inner .hero_chara div img {
  width: 100%;
  height: auto;
}
.hero_date {
  height: 80px;
  background: #E40012;
  display: flex;
  justify-content: center;
  align-items: center;
}
.hero_date .hero_date_caption {
  width: 593px;
}
.hero_date .hero_date_caption img {
  width: 100%;
  height: auto;
  position: relative;
  z-index: 300;
}
.first_phase.loadingEnd {
  z-index: 4000;
}
.second_phase.loadingEnd::after {
  animation: coverStart 0.6s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}
@keyframes coverStart {
  0% {
    transform-origin: left;
    transform: scaleX(0);
  }
  55% {
    transform-origin: left;
    transform: scaleX(1);
  }
  55.001% {
    transform-origin: right;
  }
  100% {
    transform-origin: right;
    transform: scaleX(0);
  }
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.introduction_section {
  background-image: url("../images/bg_fubuki1_pc.png"), url("../images/introduction_bg_pc.jpg");
  background-repeat: no-repeat, repeat;
  background-size: 3000px, 550px;
  background-position: center 10px, center 0;
  padding: 55px 20px 350px;
}
.introduction_section .introduction_inner {
  max-width: 1010px;
  margin: 0 auto;
}
.introduction_section .introduction_flex {
  display: flex;
  justify-content: space-between;
  margin: 0 auto 40px;
}
.introduction_section .introduction_item {
  width: 250px;
}
.introduction_section .introduction_btn {
  width: 410px;
  margin: 0 auto 20px;
  position: relative;
  z-index: 1000;
}
.introduction_section .introduction_item img, .introduction_section .introduction_btn img {
  width: 100%;
  height: auto;
}
.introduction_section .introduction_btn img {
  box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.3);
  transition: transform 0.1s;
}
.introduction_section .introduction_btn_notes {
  text-align: center;
  font-size: 14px;
}
.matsuri_section {
  background: url("../images/menu_bg_pc.png") no-repeat center 0;
  position: relative;
  z-index: 1;
  top: -300px;
  margin-bottom: -300px;
  padding-bottom: 350px;
}
.matsuri_section img {
  width: 100%;
  height: auto;
}
.matsuri_section h2 {
  margin: 0;
  padding: 0;
}
.matsuri_section .matsuri_section_title {
  width: 720px;
  margin: 0 auto 35px;
  padding-top: 10px;
  position: relative;
  z-index: 100;
}
.matsuri_section .matsuri_section_title .menu_chara {
  width: 195px;
  position: absolute;
  top: 182px;
  right: -190px;
  z-index: 100;
  background: url("../images/menu_figure_pc.png") no-repeat 0 0;
  background-size: 100%;
}
.matsuri_section .menu_item_wrap {
  width: 943px;
  margin: 0 auto 30px;
}
.matsuri_section .menu_item_wrap .menu_item {
  position: relative;
  left: -30px;
}
.matsuri_section .menu_item_wrap .menu_item:nth-child(2) {
  left: inherit;
  right: -30px;
}
.matsuri_section .menu_cloud1_inner {
  position: relative;
  max-width: 960px;
  margin: 0 auto;
}
.matsuri_section .menu_cloud1_inner .menu_cloud1-1, .matsuri_section .menu_cloud1_inner .menu_cloud1-2, .matsuri_section .menu_cloud1_inner .menu_cloud1-3 {
  position: absolute;
}
.matsuri_section .menu_cloud1_inner .menu_cloud1-1 {
  width: 650px;
  right: -525px;
  top: -125px;
}
.matsuri_section .menu_cloud1_inner .menu_cloud1-1::after {
  content: '';
  display: block;
  width: 410px;
  height: 565px;
  position: absolute;
  top: 70px;
  left: -50px;
  background: url("../images/bg_fubuki2_pc.png");
  background-size: 410px;
}
.matsuri_section .menu_cloud1_inner .menu_cloud1-2 {
  width: 707px;
  top: 130px;
  left: -617px;
}
.matsuri_section .menu_cloud1_inner .menu_cloud1-2::after {
  content: '';
  display: block;
  width: 410px;
  height: 565px;
  position: absolute;
  top: 310px;
  left: 170px;
  background: url("../images/bg_fubuki2_pc.png");
  background-size: 410px;
}
.matsuri_section .menu_cloud1_inner .menu_cloud1-3 {
  width: 785px;
  right: -760px;
  top: 583px;
}
.matsuri_section .menu_cloud1_inner .menu_cloud1-3::after {
  content: '';
  display: block;
  width: 495px;
  height: 1300px;
  position: absolute;
  top: 50px;
  left: -20px;
  background: url("../images/bg_fubuki3_pc.png");
  background-size: 495px;
}
.matsuri_section .menu_cloud2_inner {
  position: relative;
  max-width: 1100px;
  z-index: 0;
  margin: 0 auto;
}
.matsuri_section .menu_cloud2_inner .menu_cloud2-1, .matsuri_section .menu_cloud2_inner .menu_cloud2-2, .matsuri_section .menu_cloud2_inner .menu_cloud2-3 {
  position: absolute;
}
.matsuri_section .menu_cloud2_inner .menu_cloud2-1 {
  width: 576px;
  left: -400px;
  top: 45px;
}
.matsuri_section .menu_cloud2_inner .menu_cloud2-1::after {
  content: '';
  display: block;
  width: 410px;
  height: 565px;
  position: absolute;
  top: -110px;
  left: 0;
  background: url("../images/bg_fubuki2_pc.png");
  background-size: 410px;
}
.matsuri_section .menu_cloud2_inner .menu_cloud2-2 {
  width: 650px;
  top: 675px;
  left: -670px;
}
.matsuri_section .genteicard_title {
  max-width: 964px;
  position: relative;
  z-index: 10;
  margin: 0 auto;
  display: flex;
  justify-content: flex-end;
}
.matsuri_section h2 {
  width: 763px;
}
.matsuri_section p {
  font-size: 13px;
  color: #fff;
  margin-left: 110px;
  transform: translateY(-10px);
}
.matsuri_section .genteicard_figure {
  width: 180px;
  position: absolute;
  left: 0;
  top: 20px;
  background: url("../images/genteicard_figure_pc.png") no-repeat 0 0;
  background-size: 100%;
}
.genteicard_section .genteicard_wrap {
  max-width: 1023px;
  margin: 0 auto 95px;
}
.genteicard_8 {
  max-width: 1010px;
  margin: 0 auto 20px;
  padding: 0 15px;
}
.genteicard_8_notes {
  color: #fff;
  text-align: center;
  font-size: 13px;
  margin: 0 !important;
}
/* ==== 銀だこ祭り 2 ==== */
.danran_section {
  background: url("../images/danran_bg_pc.png") repeat-x center 0;
  position: relative;
  z-index: 1;
  top: -600px;
  margin-bottom: -600px;
  padding: 0 20px 470px;
}
.danran_section img {
  width: 100%;
  height: auto;
}
.danran_section .danran_section_title {
  position: relative;
  width: 520px;
  margin: 0 auto 35px;
}
.danran_section .danran_section_title h2 {
  width: 100%;
  margin: 0;
  padding: 0;
}
.danran_section .danran_section_title .danran_chara {
  position: absolute;
  width: 217px;
  top: 150px;
  right: -243px;
  background: url("../images/danran_chara_pc.png") no-repeat 0 0;
  background-size: 100%;
}
.danran_section .danran_date {
  width: 545px;
  margin: 0 auto 25px;
}
.danran_section .danran_item {
  max-width: 1000px;
  margin: 0 auto 160px;
}
.clearfile_title_inner {
  position: relative;
  max-width: 960px;
  margin: 0 auto;
}
.clearfile_title_inner .clearfile_title_cloud {
  width: 580px;
  position: absolute;
  top: 0;
  left: -450px;
}
.clearfile_title_inner .clearfile_title_cloud::after {
  content: '';
  display: block;
  width: 410px;
  height: 565px;
  position: absolute;
  top: -200px;
  left: 0;
  background: url("../images/bg_fubuki2_pc.png");
  background-size: 410px;
}
.clearfile_title_inner .clearfile_title_cloud img {
  width: 100%;
  height: auto;
}
.clearfile_title {
  position: relative;
  max-width: 603px;
  margin: 0 auto 50px;
}
.clearfile_title .clearfile_chara {
  position: absolute;
  left: -208px;
  top: -112px;
  width: 202px;
  background: url("../images/clearfile_chara_pc.png") no-repeat 0 0;
  background-size: 100%;
}
.clearfile_item_flex {
  max-width: 990px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.clearfile_item {
  width: 480px;
  margin: 0 0 40px;
}
.danran_cloud1_inner {
  position: relative;
  max-width: 960px;
  margin: 0 auto;
}
.danran_cloud1_inner .danran_cloud1-1, .danran_cloud1_inner .danran_cloud1-2, .danran_cloud1_inner .danran_cloud1-3 {
  position: absolute;
}
.danran_cloud1_inner .danran_cloud1-1 {
  width: 647px;
  right: -625px;
  top: -140px;
}
.danran_cloud1_inner .danran_cloud1-1::after {
  content: '';
  display: block;
  width: 410px;
  height: 565px;
  position: absolute;
  top: -50px;
  left: 0;
  background: url("../images/bg_fubuki2_pc.png");
  background-size: 410px;
}
.danran_cloud1_inner .danran_cloud1-2 {
  width: 710px;
  top: 120px;
  left: -560px;
}
.danran_cloud1_inner .danran_cloud1-2::after {
  content: '';
  display: block;
  width: 410px;
  height: 565px;
  position: absolute;
  top: 190px;
  left: 110px;
  background: url("../images/bg_fubuki2_pc.png");
  background-size: 410px;
}
.danran_cloud1_inner .danran_cloud1-3 {
  width: 780px;
  right: -755px;
  top: 380px;
}
.danran_cloud1_inner .danran_cloud1-3::after {
  content: '';
  display: block;
  width: 355px;
  height: 355px;
  position: absolute;
  top: 40px;
  left: 120px;
  background: url("../images/bg_fubuki4_pc.png");
  background-size: 355px;
}
/* ==== 銀だこ祭り 3 ==== */
.goods_section {
  background-image: url("../images/goods_bg_pc.png"), url("../images/goods_bg3_pc.png");
  background-repeat: no-repeat, no-repeat;
  background-position: center 0, center bottom;
  position: relative;
  z-index: 1;
  top: -300px;
  margin-bottom: -300px;
  padding: 0 20px 400px;
  min-height: 2000px;
}
.goods_section img {
  width: 100%;
  height: auto;
}
.goods_section .goods_section_title_inner {
  position: relative;
  max-width: 960px;
  margin: 0 auto;
}
.goods_section .goods_section_title_inner .goods_cloud1 {
  position: absolute;
  width: 650px;
  top: -150px;
  right: -590px;
}
.goods_section .goods_section_title_inner .goods_cloud2 {
  position: absolute;
  width: 707px;
  top: 112px;
  left: -610px;
}
.goods_section .goods_section_title_inner .goods_cloud2::after {
  content: '';
  display: block;
  width: 410px;
  height: 565px;
  position: absolute;
  top: 190px;
  left: 30px;
  background: url("../images/bg_fubuki2_pc.png");
  background-size: 410px;
}
.goods_section .goods_section_title_inner .goods_cloud3 {
  position: absolute;
  width: 760px;
  top: 300px;
  right: -730px;
}
.goods_section .goods_section_title_inner .goods_cloud3::after {
  content: '';
  display: block;
  width: 410px;
  height: 565px;
  position: absolute;
  top: 50px;
  left: 110px;
  background: url("../images/bg_fubuki2_pc.png");
  background-size: 410px;
}
.goods_section .goods_section_title {
  position: relative;
  max-width: 1005px;
  margin: 0 auto 65px;
}
.goods_section .goods_section_title h2 {
  width: 100%;
  margin: 0;
  padding: 0;
}
.goods_section .goods_section_title .goods_chara {
  position: absolute;
  width: 200px;
  top: 210px;
  left: -35px;
  z-index: 10;
  background: url("../images/goods_chara_pc.png") no-repeat 0 0;
  background-size: 100%;
}
.goods_section .goods_item_inner {
  position: relative;
  max-width: 1062px;
  margin: 0 auto;
}
.goods_section .goods_item_inner .goods_cloud4 {
  position: absolute;
  width: 580px;
  top: 100px;
  left: -360px;
}
.goods_section .goods_item_inner .goods_cloud4::after {
  content: '';
  display: block;
  width: 355px;
  height: 355px;
  position: absolute;
  top: -220px;
  left: 20px;
  background: url("../images/bg_fubuki4_pc.png");
  background-size: 355px;
}
.goods_section .goods_item_inner .goods_cloud5 {
  position: absolute;
  width: 580px;
  top: 90px;
  right: -610px;
}
.goods_section .goods_item_inner .goods_cloud6 {
  position: absolute;
  width: 650px;
  top: -77px;
  left: -710px;
}
.goods_section .goods_item_inner .goods_cloud7 {
  position: absolute;
  width: 650px;
  top: 130px;
  right: -560px;
}
.goods_section .goods_item_inner .goods_cloud7::after {
  content: '';
  display: block;
  width: 355px;
  height: 355px;
  position: absolute;
  top: -220px;
  left: 100px;
  background: url("../images/bg_fubuki4_pc.png");
  background-size: 355px;
}
.goods_section .goods_item {
  max-width: 1022px;
  margin: 0 auto 15px;
  padding: 0 20px;
  position: relative;
  z-index: 10;
}
.goods_item .goods_btn_pos {
  position: absolute;
  left: 0;
  bottom: 35px;
  width: 100%;
  text-align: center;
}
.goods_btn_pos div {
  width: 395px;
  margin: 0 auto 5px;
}
.goods_btn_pos p {
  text-align: center;
  font-size: 13px;
  position: relative;
  z-index: 100;
}
.goods_section .goods_item img {
  width: 100%;
  height: auto;
}
@media(max-width: 960px) {
  .goods_item .goods_btn_pos {
    bottom: 8vw;
  }
  .goods_btn_pos div {
    width: 79vw;
    margin: 0 auto 5px;
  }
  .goods_btn_pos p {
    font-size: 10px;
  }
}
.spec_flex {
  display: flex;
  justify-content: center;
  margin-top: 60px;
  margin-bottom: 15px;
  position: relative;
}
.online_notes {
  max-width: 800px;
  margin: 0 auto 60px;
  padding: 0 20px;
  font-size: 13px;
  text-align: right;
}
@media (max-width: 960px) {
  .online_notes {
    font-size: 10px;
    text-align: center;
    margin: 0;
    padding-top: 15px;
  }
}
.spec_flex_inner {
  background: rgba(255, 255, 255, 0.7);
  padding: 15px 30px;
  position: relative;
}
.spec_flex_inner .notes {
  padding: 10px;
  border: 1px solid #000;
  background: #fff;
  margin-top: 10px;
}
.spec_flex_inner .notes p {
  text-align: center;
  font-weight: bold;
  margin: 0 0 15px;
  font-size: 15px;
}
.spec_flex_inner .notes ul {
  margin-left: 1em;
}
.spec_flex_inner .notes li {
  list-style: none;
  line-height: 1.5;
  margin-bottom: 3px;
  position: relative;
  font-size: 15px;
}
.spec_flex_inner .notes li::after {
  content: '・';
  display: block;
  position: absolute;
  top: 0;
  left: -1em;
}
.spec_flex_inner .chara_rengoku {
  width: 200px;
  position: absolute;
  top: 0;
  left: -204px;
  background: url("../images/chara_rengoku_pc.png") no-repeat 0 0;
  background-size: 100%;
}
.chara_rengoku.sp_obj {
  width: 36vw;
  margin: -70px auto 20px;
  background: url("../images/chara_rengoku_pc.png") no-repeat 0 0;
  background-size: 100%;
  position: relative;
}
.spec_flex_inner .chara_rengoku .chara_rengoku img {
  width: 100%;
  height: auto;
}
.goods_spec {
  margin: 0 20px;
  background: rgba(255, 255, 255, 0.75);
  padding: 15px 15px 100px;
}
.goods_spec .notes {
  background: #fff;
  margin-top: 15px;
  padding: 15px;
  border: 1px solid #000
}
.goods_spec .notes p {
  margin-bottom: 10px;
}
.goods_spec .notes ul {
  margin-left: 1em;
}
.goods_spec .notes ul li {
  font-size: 14px;
  line-height: 1.6;
  margin-bottom: 5px;
  position: relative;
  list-style: none;
}
.goods_spec .notes ul li::after {
  content: '・';
  display: block;
  position: absolute;
  top: 0;
  left: -1em;
}
.goods_spec .notes p {
  text-align: center;
  font-weight: bold;
  margin: 0 0 5px;
}
.spec_flex_inner dl {
  padding: 5px;
  display: flex;
}
.spec_flex_inner dt, .goods_spec dt {
  padding-right: 10px;
  font-weight: bold;
  line-height: 1.5;
}
.goods_spec dt {
  margin: 0 0 3px;
}
.spec_flex_inner dd, .goods_spec dd {
  line-height: 1.5;
  font-size: 14px;
  font-weight: bold;
}
.goods_spec dd {
  margin: 0 0 10px;
}
.goods_btn {
  max-width: 548px;
  margin: 0 auto 40px;
}
/* ==== 銀だこ祭り 4 ==== */
/* ==== フォロリツ ===== */
.follow_section {
  background-image: url("../images/follow_bg_pc.png");
  background-repeat: no-repeat;
  background-position: center 0;
  position: relative;
  z-index: 1;
  top: -300px;
  margin-bottom: -300px;
  padding: 0 20px 400px;
  min-height: 2000px;
}
.follow_section.long {
  background-image: url("../images/follow_bg_pc.png"), url("../images/goods_bg2_pc.png");
  background-repeat: no-repeat, no-repeat;
  background-position: center 0, center bottom;
}
.follow_section img {
  width: 100%;
  height: auto;
}
.follow_section_title_inner {
  position: relative;
  max-width: 1000px;
  margin: 0 auto;
}
.follow_section_title_inner .follow_cloud1 {
  position: absolute;
  width: 707px;
  top: 235px;
  left: -630px;
}
.follow_section_title_inner .follow_cloud1::after {
  content: '';
  display: block;
  width: 410px;
  height: 565px;
  position: absolute;
  top: 240px;
  left: 90px;
  background: url("../images/bg_fubuki2_pc.png");
  background-size: 410px;
}
.follow_section_title_inner .follow_cloud2 {
  position: absolute;
  width: 785px;
  top: 415px;
  right: -740px;
}
.follow_section_title_inner .follow_cloud2::after {
  content: '';
  display: block;
  width: 410px;
  height: 565px;
  position: absolute;
  top: 50px;
  left: 150px;
  background: url("../images/bg_fubuki2_pc.png");
  background-size: 410px;
}
.follow_section_title {
  position: relative;
  padding: 0 20px;
}
.follow_section_title img {
  width: 100%;
  height: auto;
}
.follow_section_title .follow_chara {
  position: absolute;
  width: 285px;
  top: 80px;
  right: -40px;
  background: url("../images/chara_zenitsu.png") no-repeat 0 0;
  background-size: 100%;
}
.follow_section_title h2 {
  max-width: 610px;
  margin: 0 auto 40px;
  padding: 0;
}
.follow_section_title .lead {
  max-width: 934px;
  margin: 0 auto 50px;
}
.follow_btn {
  max-width: 400px;
  margin: 0 auto 15px;
}
.follow_btn img {
  width: 100%;
  height: auto;
  box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.3);
  transition: transform 0.1s;
}
.follow_btn + p {
  color: #fff;
  text-align: center;
  font-size: 13px;
  margin-bottom: 60px;
}
.follow_date {
  max-width: 1000px;
  margin: 0 auto 25px;
}
.follow_date img {
  width: 100%;
  height: auto;
}
.follow_date + p {
  color: #fff;
  text-align: center;
  font-size: 13px;
  margin-bottom: 130px;
}
.follow_prise_inner {
  max-width: 1015px;
  margin: 0 auto;
  position: relative;
}
.follow_prise_inner img {
  width: 100%;
  height: auto;
}
.follow_prise_inner .follow_cloud3 {
  width: 580px;
  position: absolute;
  top: -133px;
  left: -447px;
}
.follow_prise_inner .follow_cloud3::after {
  content: '';
  display: block;
  width: 410px;
  height: 565px;
  position: absolute;
  top: -110px;
  left: 40px;
  background: url("../images/bg_fubuki2_pc.png");
  background-size: 410px;
}
.follow_prise_inner .follow_cloud4 {
  width: 650px;
  position: absolute;
  top: 0;
  right: -555px;
}
.follow_prise_inner .follow_cloud4::after {
  content: '';
  display: block;
  width: 355px;
  height: 355px;
  position: absolute;
  top: -150px;
  left: 150px;
  background: url("../images/bg_fubuki4_pc.png");
  background-size: 355px;
}
.follow_prise_inner .follow_cloud5 {
  width: 650px;
  position: absolute;
  top: 410px;
  left: -620px;
}
.follow_prise_inner .follow_cloud6 {
  width: 575px;
  position: absolute;
  top: 570px;
  right: -480px;
}
.follow_prise_wrap {
  max-width: 1015px;
  margin: 0 auto;
}
.follow_prise_wrap img {
  width: 100%;
  height: auto;
}
.follow_prise_wrap .follow_prise1 {
  max-width: 945px;
  margin-bottom: 35px;
}
.follow_prise_wrap .follow_prise2, .follow_prise_wrap .follow_prise3 {
  width: 100%;
}
.follow_prise_wrap .follow_prise2 {
  margin-bottom: 35px;
}
.follow_prise_wrap .follow_prise3 {
  margin-bottom: 195px;
}
.term_wrap {
  max-width: 1000px;
  margin: 0 auto;
}
.term_wrap img {
  width: 100%;
  height: auto;
}
.term_wrap h3 {
  margin-bottom: 10px;
}
.term_wrap h3 + p {
  text-align: center;
  color: #fff;
  margin-bottom: 25px;
}
.acc_title {
  background: #0E0E0E;
  height: 60px;
  position: relative;
  border-radius: 8px;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 0 8px;
}
.acc_title .acc_text {
  width: 88px;
  transform: translateY(1px);
}
.acc_title .acc_trigger {
  width: 20px;
  height: 20px;
  background: #FFF;
  border-radius: 10px;
  position: absolute;
  top: 20px;
  right: 20px;
}
.acc_trigger::before, .acc_trigger::after {
  content: '';
  display: block;
  width: 10px;
  height: 2px;
  background: #0E0E0E;
  transition: all 0.3s;
  position: absolute;
  top: 9px;
  left: 5px;
}
.acc_trigger::after {
  transform: rotate(90deg);
}
.open .acc_trigger:before {
  transform: rotate(180deg);
}
.open .acc_trigger:after {
  transform: rotate(270deg);
  opacity: 0;
}
.oubo_body {
  border-radius: 8px;
  background: url(../images/introduction_bg_pc.jpg);
  background-size: 550px;
  padding: 40px 30px;
  display: none;
  text-align: center;
  margin-bottom: 10px;
}
.oubo_body.open {
  display: block;
}
.oubo_box p {
  line-height: 1.8;
  margin: 0 0 20px;
}
.oubo_box p a {
  color: #E70012;
  text-decoration: underline;
}
.oubo_box p a:hover {
  color: #E70012;
  text-decoration: none;
}
.oubo_box p.oubo_notes {
  font-size: 12px;
}
.oubo_twitter_btn {
  width: 520px;
  margin: 0 auto 10px;
}
.oubo_twitter_btn img {
  box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.3);
  transition: transform 0.1s;
}
.oubo_figure {
  max-width: 938px;
  margin: 0 auto 15px;
}
.oubo_figure + p {
  font-size: 13px;
}
.oubo_step_sb {
  width: 147px;
  margin: 0 auto 10px;
}
.oubo_step_sb2 {
  width: 147px;
  margin: 20px auto 5px;
}
.oubo_step_sb3 {
  width: 90px;
  margin: 0 auto 10px;
}
.oubo_line {
  margin: 30px 0;
  height: 14px;
  position: relative;
}
.oubo_line::before, .oubo_line::after {
  content: '';
  display: block;
  height: 1px;
  background: #000;
  width: calc(50% - 45px);
  position: absolute;
  top: 50%;
}
.oubo_line::before {
  left: 0;
}
.oubo_line::after {
  right: 0;
}
.clearfile_marge {
  max-width: 990px;
  margin: 0 auto;
  position: relative;
}
.clearfile_marge .clearfile_notes {
  position: absolute;
  top: 115px;
  left: 10px;
}
.clearfile_marge .clearfile_notes ul {
  margin-left: 1em;
}
.clearfile_marge .clearfile_notes ul li {
  list-style: none;
  position: relative;
  margin: 0 0 3px;
  line-height: 1.5;
  font-size: 14px;
}
.clearfile_marge .clearfile_notes ul li span {
  position: absolute;
  top: 0;
  left: -1em;
}
.gentei_catch {
  display: flex;
  justify-content: center;
}
.gentei_catch_mark {
  width: 220px;
}
.gentei_catch_caption ul {
  margin-left: 1em;
}
.gentei_catch_caption li {
  font-size: 13px;
  line-height: 1.5;
  margin: 0 0 2px;
  color: #fff;
  list-style: none;
  position: relative;
}
.gentei_catch_caption li span {
  position: absolute;
  top: 0;
  left: -1em;
}
.term_body {
  border-radius: 8px;
  background: url(../images/introduction_bg_pc.jpg);
  background-size: 550px;
  padding: 40px 30px;
  display: none;
}
.terms_inner {
  word-break: break-all;
}
.terms_inner h5 {
  font-size: 16px;
  line-height: 1.5;
  margin: 40px 0 5px;
}
.terms_inner h6 {
  font-size: 16px;
  font-weight: normal;
  margin: 20px 0 0px;
}
.terms_inner h5:first-child {
  margin-top: 0;
}
.terms_inner p, .terms_inner li {
  font-size: 15px;
}
.terms_inner a {
  color: #E70012;
  text-decoration: underline;
}
.terms_inner .policyExtra {
  font-size: 13px;
}
.terms_inner p {
  line-height: 1.8;
  margin: 0 0 1.5em;
  word-break: break-all;
}
.terms_inner ul {
  margin: 0 0 0 1.5em;
}
.terms_inner ul.no_offset {
  margin: 10px 0 1em 2em;
}
.terms_inner ul.no_offset li {
  position: relative;
}
.terms_inner ul.no_offset span.offset {
  display: block;
  position: absolute;
  top: 0;
  left: -2.5em;
}
.terms_inner ul li {
  list-style: none;
  position: relative;
  margin: 0 0 5px;
}
.terms_inner ul.square {
  margin: 0 0 0 1.5em;
}
.terms_inner ul.attention {
  margin-left: 1em;
}
.terms_inner ul.dot {
  margin-left: 1em;
}
.terms_inner ul.dot li, .terms_inner ul.attention li {
  position: relative;
  line-height: 1.7;
}
.terms_inner ul.dot li::after {
  content: '・';
  display: block;
  position: absolute;
  top: 0;
  left: -1em;
}
.terms_inner ul.dot li.extra_none::after {
  content: '';
}
.terms_inner ul.dot li.extra_none {
  position: relative;
}
.terms_inner ul.dot li.extra_none span.mark {
  position: absolute;
  top: 0;
  left: -1em;
}
.terms_inner ul.square li::after {
  content: '';
  display: block;
  width: 1em;
  height: 1em;
  background: #333;
  position: absolute;
  left: -1.5em;
  top: 0.25em;
}
.terms_inner ul li span.mark {
  position: absolute;
  left: -1em;
  top: 0;
}
.terms_inner ol {
  padding-left: 25px;
}
.terms_inner ol li {
  margin: 0 0 7px;
  line-height: 1.7;
}
.shop_section {
  background: url("../images/shop_bg_pc.png") no-repeat center top;
  position: relative;
  top: -300px;
  margin-bottom: -500px;
  z-index: 100;
  padding-top: 270px;
  padding-bottom: 120px;
  min-height: 1000px;
}
.shop_section img {
  width: 100%;
  height: auto;
}
.shop_section .shop_inner {
  max-width: 900px;
  margin: 0 auto;
  position: relative;
}
.shop_section .shop_inner .shop_cloud {
  position: absolute;
  width: 710px;
  top: -290px;
  left: -685px;
}
.shop_section .shop_inner .shop_cloud::after {
  content: '';
  display: block;
  width: 410px;
  height: 565px;
  position: absolute;
  top: 120px;
  left: 140px;
  background: url("../images/bg_fubuki2_pc.png");
  background-size: 410px;
}
.shop_section h3 {
  width: 690px;
  margin: 0 auto 10px;
}
.shop_section h3 + p {
  color: #fff;
  text-align: center;
  font-size: 13px;
  margin-bottom: 35px;
}
.shop_section .shop_caption {
  max-width: 990px;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 30px;
  background: url("../images/shop_caption_bg.jpg") repeat-y 0 0;
}
.shop_section .shop_caption h4 {
  font-family: 'Noto Serif JP', serif;
  font-weight: 600;
  text-align: center;
  font-size: 22px;
  margin: 0 0 20px;
}
.shop_section .shop_caption ul {
  margin-left: 1em;
}
.shop_section .shop_caption ul li {
  list-style: none;
  line-height: 1.6;
  margin: 0 0 7px;
  font-size: 14px;
  position: relative;
}
.shop_section .shop_caption ul li span {
  position: absolute;
  top: 0;
  left: -1em;
}
.shop_section .shop_caption .shop_linkbtn {
  max-width: 410px;
  margin: 0 auto 20px;
}
.shop_section .shop_caption .shop_linkbtn img {
  box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.3);
  transition: transform 0.1s;
}
.aboutanime_section {
  background: url("../images/about_anime_bg_pc.png") no-repeat center top;
  position: relative;
  top: -300px;
  margin-bottom: -300px;
  z-index: 100;
  padding-bottom: 120px;
}
.aboutanime_section img {
  width: 100%;
  height: auto;
}
.aboutanime_section .aboutanime_inner {
  max-width: 780px;
  margin: 0 auto;
  text-align: center;
  padding: 270px 20px 0;
  color: #fff;
  position: relative;
}
.aboutanime_section .aboutanime_inner .anime_cloud1 {
  position: absolute;
  top: -140px;
  right: -806px;
  width: 785px;
}
.aboutanime_section .aboutanime_inner .anime_cloud1::after {
  content: '';
  display: block;
  width: 410px;
  height: 565px;
  position: absolute;
  top: 50px;
  left: 140px;
  background: url("../images/bg_fubuki2_pc.png");
  background-size: 410px;
}
.aboutanime_section .aboutanime_inner .anime_cloud2 {
  position: absolute;
  top: 5px;
  left: -517px;
  width: 650px;
}
.aboutanime_section .aboutanime_inner h3 {
  max-width: 690px;
  margin: 0 auto 45px;
  position: relative;
  z-index: 10;
}
.aboutanime_section .aboutanime_inner h3 + p {
  line-height: 2.0;
  font-size: 14px;
  margin-bottom: 50px;
  position: relative;
  z-index: 10;
  text-align: left;
}
.aboutanime_section .aboutanime_inner h3 + p a {
  color: #fff;
  text-decoration: underline;
}
.aboutanime_section .link_btn {
  max-width: 410px;
  margin: 0 auto 40px;
}
.aboutanime_section .link_btn img {
  transition: transform 0.1s;
}
.aboutanime_section .anime_bnr {
  max-width: 380px;
  margin: 0 auto;
}
footer {
  background: #E70012;
  padding: 50px 20px 20px;
  box-sizing: border-box;
  min-height: 340px;
}
footer p {
  line-height: 1.8;
}
.pagetop {
  position: fixed;
  bottom: 40px;
  right: 40px;
  width: 95px;
  z-index: 500;
  cursor: pointer;
  display: none;
  transition: bottom 0.3s;
}
.pagetop.footerFixed {
  bottom: 358px;
}
.pagetop img {
  width: 100%;
  height: auto;
  position: relative;
}
.pagetop img {
  width: 100%;
  height: auto;
}
.shop_section .shop_caption h4 {
  font-size: 18px;
}
.footer_contact_link {
  font-size: 14px;
  margin: 5px 0 20px;
  text-align: center;
}
.footer_contact_link a {
  color: #fff;
  text-decoration: underline;
}
.footer_contact_link a:hover {
  color: #fff;
  text-decoration: none;
}
.footer_inner img {
  width: 100%;
  height: auto;
  transition: transform 0.1s;
}
.footer_faq_btn {
  max-width: 400px;
  margin: 0 auto 40px;
}
.footer_faq_btn img {
  box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.3);
  transition: transform 0.1s;
}
.footer_contact {
  margin: 0 auto 20px;
  text-align: center;
  color: #fff;
}
.footer_contact h4 {
  font-size: 14px;
  font-weight: bold;
  color: #fff;
  line-height: 1;
  margin: 0 0 13px;
}
.footer_contact h5 {
  font-size: 14px;
  margin: 0 0 10px;
}
.footer_tel a {
  color: #fff;
  text-decoration: none;
}
.footer_contact_notes {
  font-size: 12px;
}
.oubo_box.step2 {
  position: relative;
}
.oubo_box.step2 .chara_uzui {
  width: 275px;
  height: 340px;
  position: absolute;
  top: -150px;
  right: -40px;
  background: url("../images/chara_uzui.png") no-repeat 0 0;
  background-size: 100%;
}
.oubo_box.step2 .chara_uzui img {
  width: 100%;
  height: auto;
}
@media (hover: hover) {
  .footer_faq_btn:hover img, .oubo_twitter_btn:hover img, .follow_btn:hover img {
    transform: translateX(1px) translateY(1px);
  }
}
@media (min-width: 768px) {
  br.spbr {
    display: none;
  }
}
@media (max-width: 767px) {
  br.pcbr {
    display: none;
  }
}
@media (min-width: 961px) {
  .sp_obj {
    display: none;
  }
}
@media (max-width: 960px) {
  .pc_obj {
    display: none;
  }
}
/* ==== 共通パーツ ===== */
.anchor {
  position: relative;
  padding-top: 300px;
  margin-top: -300px;
}
.anchor.matsuri2 {
  padding-top: 650px;
  margin-top: -650px;
}
.anchor.matsuri3 {
  padding-top: 300px;
  margin-top: -300px;
}
.anchor.matsuri4 {
  padding-top: 350px;
  margin-top: -350px;
}
@media(max-width: 768px) {
  .anchor.matsuri1 {
    padding-top: 250px;
    margin-top: -250px;
  }
  .anchor.matsuri2 {
    padding-top: 250px;
    margin-top: -250px;
  }
}
.gentei_catch_flex {
  display: flex;
  justify-content: center;
  margin: 0 0 50px;
}
.danran_section .gentei_catch_flex {
  margin-bottom: 20px;
}
.mgnb05 {
  margin-bottom: 5px !important;
}
.mgnb15 {
  margin-bottom: 15px !important;
}
.mgnt30 {
  margin-top: 30px !important
}
.offCover {
  position: relative;
}
.offCover::after {
  content: '';
  position: absolute;
  top: 0px;
  left: -50px;
  width: calc(100% + 100px);
  height: 100%;
  background: rgba(255, 255, 255, 0.8);
  border: 4px solid #eb0000;
  z-index: 100;
}
.offCover.cover2::after {
  left: 0px;
  width: 100%;
}
.offCover .offCatch {
  width: 100%;
  position: absolute;
  z-index: 200;
  top: calc(50% - 70px);
  left: 0;
}
.offCatch h3 {
  width: 750px;
  margin: 0 auto;
}
.offCatch img {
  width: 100%;
  height: auto;
}
.offWrap {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 20px;
}
@media(max-width: 768px) {
  .offCover::after {
    left: 0;
    width: 100%;
    border: 4px solid #eb0000;
    box-sizing: border-box;
  }
  .offCover.cover1::after, .offCover.cover2::after {
    left: 10px;
    width: calc(100% - 20px);
  }
  .offCover.cover3::after, .offCover.cover4::after {
    left: -10px;
    width: calc(100% + 20px);
  }
  .offCover .offCatch {
    top: 100px;
  }
  .offCatch h3 {
    width: 80%;
  }
}
.campaign_end {
  margin: 0 0 80px;
  border: 4px solid #eb0000;
}
@media(max-width: 767px) {
  .campaign_end {
    margin: 0 20px 40px;
  }
}
.campaign_end img {
  width: 100%;
  height: auto;
}