@charset "UTF-8";
/*----------------------------------------------------------
更新日：2025年6月14日

=共通スタイル
=ヘッダーエリア(#header)
=フッターエリア(#footer)
=メインエリア(main)
=お知らせモーダル(#topics)
=フォーム関連(form)

-------------------------------------------------------------*/
/* =共通スタイル
------------------------------------------------------------*/
@import url("../css/reset.css");
@import url("https://fonts.googleapis.com/css2?family=M+PLUS+1p:wght@400;500;700;800;900&display=swap");
* {
  box-sizing: border-box;
}
*:before, *:after {
  box-sizing: border-box;
}

html {
  background: #FFF;
  touch-action: manipulation;
}

body {
  max-width: 750px;
  margin: 0 auto;
  background: #DFE3EB;
  line-height: 1.5;
  font-family: "M PLUS 1p", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 3.75dvw;
  color: #212121;
  word-wrap: break-word;
  word-break: break-all;
}
body.stop {
  overflow: hidden;
}

#wrap {
  display: flex;
  flex-direction: column;
  position: relative;
  width: 100%;
  max-width: 750px;
  min-height: 100dvh;
  margin: 0 auto;
  padding-top: 4.6em;
}

a {
  text-decoration: none;
}

img {
  max-width: 100%;
  vertical-align: bottom;
}

.pc {
  display: block;
}

.sp {
  display: none;
}

.baseWidth {
  position: relative;
  max-width: 750px;
  margin: 0 auto;
}

.flex {
  display: flex;
}

.page-title {
  position: relative;
  padding: 0.38em 1em;
  background: linear-gradient(to bottom, #000b51 0%, #0017a7 50%, #0066df 100%);
  text-align: center;
  text-shadow: 0 0.15em 0.3em #002FAA;
  font-size: 1.28em;
  color: #FFF;
}

.headline1 {
  margin-bottom: 1em;
  line-height: 1.2;
  text-align: center;
  font-size: 1.42em;
  font-weight: bold;
  color: #217BF5;
}
.headline1.orange {
  color: #FF6B00;
}

.radius-box {
  margin: 0.85em 1.14em 0;
  border-radius: 1.14em;
  box-shadow: 0 0.4em 1.1em 0 rgba(16, 42, 97, 0.2);
  background: #FFF;
}
.radius-box + .radius-box {
  margin-top: 0.43em;
}
.radius-box:last-child {
  margin-bottom: 1.14em;
}

.btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 13.15em;
  height: 2.41em;
  margin: 0 auto;
  border-radius: 100vw;
  box-shadow: 0 0.1em 0.1em 0 rgba(16, 42, 97, 0.25);
  letter-spacing: 0.05em;
  font-size: 1.3em;
  color: #FFF;
}
.btn + .btn {
  margin-top: 1.25em;
}
.btn.btn-red {
  background: #EC0000;
}
.btn.btn-blue {
  background: linear-gradient(360deg, #217BF5 20.51%, #3DB3FF 94.51%) !important;
}
.btn.btn-orange {
  background: linear-gradient(to bottom, #ffa140 5%, #ff7a00 47%) !important;
}
.btn.btn-pink {
  background: #EC007F !important;
}
.btn.btn-gray {
  background: #8A9AC3 !important;
}
.btn.btn-mini {
  width: 14.5em;
  background: #217BF5;
  letter-spacing: normal;
  color: #FFF;
}
.btn.btn-mini.arrow:after {
  content: "";
  display: inline-flex;
  width: 0.8em;
  height: 1em;
  margin-left: 1em;
  background: url("../img/common/arrow_w_r.svg") no-repeat;
  background-size: contain;
}

.btn-area {
  padding: 1em 0;
}

.txt-link {
  color: inherit;
}
.txt-link:not(:hover) {
  text-decoration: underline;
}

.no-link {
  pointer-events: none;
}

.kome {
  font-size: 0.875em;
}

.caution,
p.error {
  color: #E72530;
}

.youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.youtube iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.modal {
  display: none;
  z-index: 99999;
}
.modal .modal-main {
  overflow: auto;
  position: fixed;
  top: 2.15em;
  left: 50%;
  width: 24.88em;
  max-height: calc(100svh - 4.3em);
  padding-bottom: 0.5em;
  background: #FFF;
  border-radius: 1.14em;
  box-shadow: 0 0.4em 1.1em 0 rgba(16, 42, 97, 0.2);
  transform: translateX(-50%);
  z-index: 1;
}
.modal .overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
}

.red {
  color: #E72530 !important;
}

.left {
  text-align: left !important;
}

.right {
  text-align: right !important;
}

.center {
  text-align: center !important;
}

.mt0, .mv0, .ma0 {
  margin-top: 0 !important;
}

.mr0, .mh0, .ma0 {
  margin-right: 0 !important;
}

.mb0, .mv0, .ma0 {
  margin-bottom: 0 !important;
}

.ml0, .mh0, .ma0 {
  margin-left: 0 !important;
}

.pt0, .pv0, .pa0 {
  padding-top: 0 !important;
}

.pr0, .ph0, .pa0 {
  padding-right: 0 !important;
}

.pb0, .pv0, .pa0 {
  padding-bottom: 0 !important;
}

.pl0, .ph0, .pa0 {
  padding-left: 0 !important;
}

.mt05em, .mv05em, .ma05em {
  margin-top: 0.5em !important;
}

.mr05em, .mh05em, .ma05em {
  margin-right: 0.5em !important;
}

.mb05em, .mv05em, .ma05em {
  margin-bottom: 0.5em !important;
}

.ml05em, .mh05em, .ma05em {
  margin-left: 0.5em !important;
}

.mt1em, .mv1em, .ma1em {
  margin-top: 1em !important;
}

.mr1em, .mh1em, .ma1em {
  margin-right: 1em !important;
}

.mb1em, .mv1em, .ma1em {
  margin-bottom: 1em !important;
}

.ml1em, .mh1em, .ma1em {
  margin-left: 1em !important;
}

.pt1em, .pv1em, .pa1em {
  padding-top: 1em !important;
}

.pr1em, .ph1em, .pa1em {
  padding-right: 1em !important;
}

.pb1em, .pv1em, .pa1em {
  padding-bottom: 1em !important;
}

.pl1em, .ph1em, .pa1em {
  padding-left: 1em !important;
}

.mt2em, .mv2em, .ma2em {
  margin-top: 2em !important;
}

.mr2em, .mh2em, .ma2em {
  margin-right: 2em !important;
}

.mb2em, .mv2em, .ma2em {
  margin-bottom: 2em !important;
}

.ml2em, .mh2em, .ma2em {
  margin-left: 2em !important;
}

.pt2em, .pv2em, .pa2em {
  padding-top: 2em !important;
}

.pr2em, .ph2em, .pa2em {
  padding-right: 2em !important;
}

.pb2em, .pv2em, .pa2em {
  padding-bottom: 2em !important;
}

.pl2em, .ph2em, .pa2em {
  padding-left: 2em !important;
}

.mt3em, .mv3em, .ma3em {
  margin-top: 3em !important;
}

.mr3em, .mh3em, .ma3em {
  margin-right: 3em !important;
}

.mb3em, .mv3em, .ma3em {
  margin-bottom: 3em !important;
}

.ml3em, .mh3em, .ma3em {
  margin-left: 3em !important;
}

.pt3em, .pv3em, .pa3em {
  padding-top: 3em !important;
}

.pr3em, .ph3em, .pa3em {
  padding-right: 3em !important;
}

.pb3em, .pv3em, .pa3em {
  padding-bottom: 3em !important;
}

.pl3em, .ph3em, .pa3em {
  padding-left: 3em !important;
}

/* =ヘッダーエリア(#header)
------------------------------------------------------------*/
#header {
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0;
  width: 100%;
  max-width: 750px;
  z-index: 9999;
}
#header.active {
  height: 100dvh;
}
#header.active .inner .menu {
  display: none;
}
#header.active .inner .menu.close {
  display: block;
}
#header .inner {
  position: relative;
  z-index: 1;
}
#header .inner .logo img {
  position: absolute;
  top: 50%;
  left: 1em;
  height: 80%;
  z-index: 2;
  transform: translateY(-50%);
}
#header .inner .home, #header .inner .menu, #header .inner .close, #header .inner .reel {
  position: absolute;
  top: 50%;
  height: 84%;
  cursor: pointer;
  z-index: 2;
}
#header .inner .home {
  left: 50%;
  transform: translate(-50%, -55%);
}
#header .inner .reel {
  right: 14%;
  transform: translate(0, -50%);
}
#header .inner .menu {
  right: 0;
  transform: translate(0, -50%);
}
#header .inner .menu.close {
  display: none;
}
#header .inner .bg {
  width: 100%;
}
#header nav {
  overflow: auto;
  display: none;
  flex-grow: 1;
  background: rgba(0, 0, 0, 0.7);
}
#header nav ul {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  padding: 0.8em 0.36em;
  z-index: 1;
}
#header nav ul li {
  width: 33.3333%;
  padding: 0.42em 0.26em;
}
#header #reel .modal-detail {
  overflow: auto;
  position: fixed;
  top: 0;
  left: 50%;
  width: 100%;
  max-width: 750px;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  transform: translateX(-50%);
}
#header #reel .modal-detail .close-btn {
  position: absolute;
  top: 0;
  right: 0;
  width: 3em;
  z-index: 2;
}
#header #reel .modal-detail .inner {
  position: relative;
  max-width: 750px;
  height: 100dvh;
  margin: 0 auto;
  padding: 2em 0;
  background: url("../img/common/reel_bg.png") no-repeat top center;
  background-size: 100% auto;
  text-align: center;
}
#header #reel .modal-detail .inner img {
  max-height: 100%;
}

/* =フッターエリア(#footer)
------------------------------------------------------------*/
#footer {
  width: 100%;
}
#footer.fixed nav {
  display: block;
}
#footer nav {
  display: none;
  position: fixed;
  bottom: 0;
  max-width: 750px;
  transition: 0.1s;
  z-index: 2;
}
#footer nav ul {
  display: flex;
  position: absolute;
  top: 50%;
  width: 100%;
  transform: translateY(-50%);
  z-index: 1;
}
#footer nav ul li {
  position: relative;
  margin: -0.67em;
}
#footer nav ul li a img:last-of-type {
  display: none;
}
#footer nav ul li a .badge {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: -1em;
  left: 1em;
  width: 2.2em;
  height: 2.2em;
  border: 0.2em solid #FFF;
  border-radius: 100vw;
  box-shadow: 0 0.3em 0 0 rgba(0, 0, 0, 0.8);
  background: #F00;
  font-size: 1.2em;
  font-weight: bold;
  color: #FFF;
}
#footer nav ul li .bg {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
#footer nav > .bg {
  opacity: 0;
}
#footer .copy {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 2.85em;
  background: #00C2AF;
}
#footer .copy p {
  font-size: 1.15em;
  font-weight: bold;
  color: #FFF;
}
#footer .copy p span {
  color: #FFD600;
}
#footer.active-pachislot nav li:nth-of-type(2) img:first-of-type {
  display: none;
}
#footer.active-pachislot nav li:nth-of-type(2) img:last-of-type {
  display: block;
}
#footer.active-ranking nav li:nth-of-type(3) img:first-of-type {
  display: none;
}
#footer.active-ranking nav li:nth-of-type(3) img:last-of-type {
  display: block;
}
#footer.active-mypage nav li:last-of-type img:first-of-type, #footer.active-login nav li:last-of-type img:first-of-type {
  display: none;
}
#footer.active-mypage nav li:last-of-type img:last-of-type, #footer.active-login nav li:last-of-type img:last-of-type {
  display: block;
}

/* =メインエリア(main)
------------------------------------------------------------*/
main {
  flex-grow: 1;
}

/* お知らせモーダル
-------------------------------------------------------------*/
#topics .modal-main {
  display: flex;
  flex-direction: column;
  border: 0.285em solid #FFF;
}
#topics .modal-main .inner {
  overflow: auto;
  margin: 0.928em 0.642em 0;
  border: 0.23em solid #217BF5;
  border-radius: 0.571em;
}
#topics .modal-main .inner dl dt {
  padding: 0.6em 0.5em 0.6em 0.7em;
  background: #217BF5;
  font-weight: bold;
  color: #FFF;
}
#topics .modal-main .inner dl dt .date {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#topics .modal-main .inner dl dt .date div .tag {
  margin-left: 0.25em;
  padding: 0 1em;
  border-radius: 0.284em;
  font-weight: 800;
  color: #FFF !important;
}
#topics .modal-main .inner dl dt .date div .tag.orange {
  background: #FDA700;
}
#topics .modal-main .inner dl dt .date div .tag.red {
  background: #E72530;
}
#topics .modal-main .inner dl dt .title {
  font-size: 1.1em;
}
#topics .modal-main .inner dl dd {
  padding: 0.6em 0.7em 1em;
  font-size: 0.92em;
  font-weight: bold;
}
#topics .modal-main .inner dl dd img {
  display: block;
  margin: 0 auto;
}
#topics .modal-main .inner dl dd .flex {
  align-items: center;
}
#topics .modal-main .inner dl dd .flex img {
  flex-shrink: 0;
  width: 4.18em;
  margin-right: 0.5em;
}
#topics .modal-main .inner dl dd > * + * {
  margin-top: 1em;
}
#topics .modal-main .inner dl dd .caution {
  font-size: 0.76em;
}
#topics .modal-main .inner dl dd a {
  color: #007AFF;
}
#topics .modal-main .inner dl dd a:not(:hover) {
  text-decoration: underline;
}
#topics .modal-main .btn-area {
  flex-shrink: 0;
}

/* =フォーム関連(form)
-------------------------------------------------------------*/
input, button, select, textarea {
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}

button, input[type=button], input[type=reset], input[type=submit], select {
  cursor: pointer;
}

button {
  padding: 0;
}

select {
  -webkit-appearance: none;
  appearance: none;
}

form ::placeholder {
  color: #8A9AC3;
}
form :placeholder-shown {
  background: #D2DAEE;
}

.text-radio, .text-checkbox {
  display: flex;
  align-items: center;
  cursor: pointer;
}

.text-radio .input-radio, .text-radio .input-checkbox {
  display: none;
}
.text-radio .input-radio:checked + span, .text-radio .input-checkbox:checked + span {
  background-size: contain;
}
.text-radio .input-radio:checked + span img, .text-radio .input-checkbox:checked + span img {
  opacity: 0;
}
.text-radio span {
  display: block;
  width: 1.2em;
  height: 1.2em;
  margin-right: 0.25em;
  vertical-align: baseline;
  background: url("../img/counter/radio_on.svg") no-repeat;
  background-size: 0%;
}
.text-radio span img {
  vertical-align: baseline;
}

/*
.input-checkbox {
	width: 2em;
	height: 2em;
	margin-right: 0.5em;
	background: #D2DAEE !important;
	border:0.15em solid #8A9AC3;
	border-radius: 0.25em;
}
.text-radio, .text-checkbox{
	position: relative;
	display: flex;
	align-items: center;
	cursor: pointer;
	&:before {
		content: '';
		display: block;
		border-radius: 50%;
		background: #D2DAEE;
		width: 2em;
		height: 2em;
		margin-right: 0.5em;
		border:0.15em solid #8A9AC3;
	}
}
.text-checkbox:before{
	border-radius: 0.25em;
}
.input-radio:checked { 
	+ .text-radio:after { 
		content: '';
		position: absolute;
		left: 4px;
		display: block;
		border-radius: 50%;
		width: 12px;
		height: 12px;
		background-color: #292A30;
	}
}
.input-checkbox:checked {
	+ .text-checkbox:before{
		background-color:#FFF;
	}
	+ .text-checkbox:after { 
		content: '';
		position: absolute;
		top: 50%;
		display: block;
		border:0.2em solid;
		border-top: 0; 
		border-left:0; 
		width: 0.7em;
		height: 1em;
		transform: rotate(45deg) translate(-10%,-90%);
	}
}
*/
.input-text,
.input-num,
.input-textarea,
.input-select,
.input-confirm {
  display: inline-block;
  width: 100%;
  padding: 0 0.5em;
  border: 0.15em solid #D2DAEE;
  background: none;
  border-radius: 0.4em;
  font-weight: bold;
}
.input-text:focus,
.input-num:focus,
.input-textarea:focus,
.input-select:focus,
.input-confirm:focus {
  outline: 0;
}
.input-text.error,
.input-num.error,
.input-textarea.error,
.input-select.error,
.input-confirm.error {
  border-color: #E72530;
}

.input-num {
  padding-right: 0;
}

.input-textarea {
  resize: vertical;
  width: 100%;
  min-width: 0;
  min-height: 6em;
  padding: 1em 1.25em;
  line-height: inherit;
}

.input-select-arrow {
  position: relative;
  border-radius: 0.571em;
  background: #D2DAEE;
}
.input-select-arrow .input-select {
  padding: 0 1em;
  color: #232323;
}
.input-select-arrow .input-select option:disabled {
  display: none;
  color: #8A9AC3;
}
.input-select-arrow .input-select:has(option:checked[value=""]) {
  color: #8A9AC3;
}
.input-select-arrow:after {
  border-left: 0.4em solid transparent;
  border-right: 0.4em solid transparent;
  border-top: 0.8em solid;
  content: "";
  position: absolute;
  right: 1em;
  top: 50%;
  pointer-events: none;
  transform: translateY(-50%);
}

.input-confirm:empty {
  min-height: 2.4em;
}

.switch input[type=checkbox] {
  width: 0;
  height: 0;
  visibility: hidden;
  margin: 0;
  padding: 0;
}
.switch label {
  cursor: pointer;
  width: 2.2em;
  height: 1.1em;
  background: #BABABA;
  display: block;
  border-radius: 100vw;
  position: relative;
}
.switch label:after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 1.1em;
  height: 1.1em;
  background: #fff;
  border-radius: 100vw;
  box-shadow: 0 0.1em 0 0 rgba(0, 0, 0, 0.2);
  transition: 0.3s;
}
.switch input:checked + label {
  background: #32D74B;
}
.switch input:checked + label:after {
  left: calc(100%);
  transform: translateX(-100%);
}

.required,
.any {
  padding: 0 1em;
  border-radius: 0.25em;
  text-align: center;
  font-size: 0.875em;
  font-weight: bold;
  color: #FFF;
}
.required.green,
.any.green {
  background: #09BE72 !important;
}
.required.orange,
.any.orange {
  background: #FF6B00 !important;
}
.required.gray,
.any.gray {
  background: #8A9AC3 !important;
}

.required {
  background: #E72530;
}

.any {
  background: #217BF5;
}

/* ------------------------------------------------------------------
	PC,タブレット (750px以上)
-------------------------------------------------------------------*/
@media screen and (min-width: 750px) {
  /* =PC共通スタイル
  -------------------------------------------------------------*/
  .pc {
    display: block !important;
  }

  .sp {
    display: none !important;
  }

  body {
    font-size: 28px;
  }
}
/* ------------------------------------------------------------------
	ここまで
-------------------------------------------------------------------*/
