@charset "UTF-8";
/*----------------------------------------------------------
更新日：2026年3月1日

=共通
=スマスロヨルムンガンド TOP
=プレイ履歴/プレイ結果/途中結果
=ショップ
=使い方

-------------------------------------------------------------*/
/* 共通
-------------------------------------------------------------*/
@import url("https://fonts.googleapis.com/css2?family=Akshar:wght@300..700&family=Germania+One&family=Konkhmer+Sleokchher&family=M+PLUS+1p&family=M+PLUS+Rounded+1c:wght@400;700&family=Radio+Canada+Big:wght@700&family=Chango&display=swap");
.page-title + #no-save {
  margin-top: -0.8em;
}

.akshar {
  font-family: "Akshar", sans-serif;
}

.mplus-rounded-bold {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 700;
  font-style: normal;
}

.germania-one {
  font-family: "Germania One", system-ui;
  font-weight: 400;
  font-style: normal;
}

.konkhmer-sleokchher {
  font-family: "Konkhmer Sleokchher", system-ui;
  font-weight: 400;
  font-style: normal;
}

.radio-canada-big-bold {
  font-family: "Radio Canada Big", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}

.chango {
  font-family: "Chango", sans-serif;
  font-weight: 400;
  font-style: normal;
}

/* スマスロヨルムンガンド TOP
-------------------------------------------------------------*/
#keyv {
  overflow: hidden;
  box-shadow: 0 0.2em 0.1em 0 rgba(0, 0, 0, 0.2);
}
#keyv #keyv-slider {
  opacity: 0;
}
#keyv #keyv-slider.slick-initialized {
  opacity: 1;
}
#keyv #keyv-slider .slick-dots {
  display: flex;
  justify-content: center;
  position: absolute;
  bottom: 0.6em;
  width: 100%;
}
#keyv #keyv-slider .slick-dots li {
  margin: 0 0.5em;
}
#keyv #keyv-slider .slick-dots li button {
  display: block;
  width: 0.92em;
  height: 0.92em;
  padding: 0;
  background: #BABABA;
  border-radius: 100vw;
  box-shadow: 0 0.2em 0 0 rgba(0, 0, 0, 0.73);
  text-indent: -9999px;
}
#keyv #keyv-slider .slick-dots li.slick-active button {
  background: #F6DF0A;
}

#member {
  position: relative;
  padding: 0.5em 0;
}
#member .marker img {
  position: absolute;
  right: 1.6em;
  bottom: 1.9em;
  width: 3em;
  z-index: 1;
}
#member .name {
  display: block;
  position: relative;
}
#member .name dl, #member .name .icon, #member .name .title {
  position: absolute;
  z-index: 1;
}
#member .name dl {
  left: 39%;
  bottom: 20%;
  line-height: 1.3;
}
#member .name dl dt {
  position: relative;
  background: #FFF;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-size: 1.725em;
  font-weight: bold;
}
#member .name dl dt:before {
  content: attr(data-text);
  position: absolute;
  left: 0;
  top: 0;
  -webkit-text-stroke: 0.2em #000;
  color: #FFF;
  z-index: -1;
}
#member .name .icon {
  top: 7%;
  left: 5.5%;
  width: 30%;
}
#member .name .title {
  top: 20%;
  left: 37%;
  width: 57%;
}

#login {
  padding: 0.5em 0;
}
#login .inner {
  position: relative;
}
#login .inner .icon, #login .inner .title, #login .inner .btn {
  position: absolute;
}
#login .inner .icon {
  top: 10%;
  left: 6%;
  width: 29%;
}
#login .inner .title {
  top: 15%;
  left: 40.5%;
  line-height: 1.3;
  font-size: 1.25em;
  font-weight: 700;
}
#login .inner .btn {
  left: 39.5%;
  bottom: 16%;
  width: 10.8em;
  height: 2.2em;
  margin: 0;
  box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
  background: #00C878;
  font-weight: 700;
  color: #FFF;
}

#shop-search {
  position: relative;
}
#shop-search .inner {
  position: absolute;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 0 1.5em 0 1.6em;
}
#shop-search .inner .gps {
  position: relative;
  display: inline-flex;
  align-items: center;
  font-size: 1.3em;
  font-weight: bold;
  transform: translateY(-5%);
}
#shop-search .inner .gps img {
  position: absolute;
  width: 1.6em;
  pointer-events: none;
}
#shop-search .inner .gps select {
  padding: 0 2.2em;
  text-shadow: 0 0.15em 0 rgba(0, 0, 0, 0.69);
  color: #FFF;
}
#shop-search .inner .gps select option {
  color: #3A3A3A;
}
#shop-search .inner a {
  width: 9.1em;
  transform: translateY(-5%);
}
#shop-search .inner button {
  width: 9.1em;
  transform: translateY(-5%);
}
#shop-link {
  padding-top: 0.6em;
}
#shop-link ul {
  display: flex;
  justify-content: space-between;
  padding: 0.5em 0.89em 1.4em;
}
#shop-link ul li {
  width: 12.15em;
}

#played-history {
  margin-top: -0.5em;
  padding: 0 0 1em;
}

#banner {
  padding-top: 0.25em;
}
#banner .line {
  padding: 0.8em 0 1.5em;
}

.modal #medal {
  background: none;
  border-radius: 0.6em;
}
.modal #medal .inner {
  position: relative;
}
.modal #medal .inner .btn-area {
  position: absolute;
  bottom: 0.5em;
  width: 100%;
  padding: 0;
  text-align: center;
}
.modal #medal .inner .btn-area img {
  width: 70%;
}

/* プレイ履歴/プレイ結果/途中結果
-------------------------------------------------------------*/
.play-detail {
  position: relative;
  display: flex;
  align-items: center;
}
.play-detail a {
  position: absolute;
  right: 1em;
  padding: 0.1em 0.25em;
  border: 0.1em solid #FFF;
  color: #FFF;
}

#result-none {
  padding: 2em 0;
  text-align: center;
  font-size: 1.2em;
  font-weight: 700;
  color: #FFF;
}

#date-search {
  position: relative;
  margin: -0.2em 0 0.5em;
  padding: 0.5em 0.7em;
}
#date-search ul {
  position: absolute;
  left: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 0em 2.5em 1em;
  font-size: 1.2em;
  font-weight: 700;
  z-index: 1;
}
#date-search ul div {
  display: inline-block;
  position: relative;
  background: #FFF;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
#date-search ul div:before {
  display: inline-block;
  content: attr(data-text);
  position: absolute;
  left: 0;
  top: 0;
  text-shadow: 0 0.15em 0 rgba(0, 0, 0, 0.69);
  color: #FFF;
  z-index: -1;
}
#date-search ul a {
  display: inline-block;
  position: relative;
  background: linear-gradient(180deg, #F4C43E 25.65%, #FFF475 36.48%, #B4741A 79.82%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
#date-search ul a:before {
  display: inline-block;
  content: attr(data-text);
  position: absolute;
  left: 0;
  top: 0;
  text-shadow: 0 0.15em 0 rgba(0, 0, 0, 0.69);
  color: #FFF;
  z-index: -1;
}
#date-search ul a.no-link {
  color: #A3A3A3;
}

#result-board {
  position: relative;
  padding: 0em 0 1em;
}
#result-board h2 {
  margin: 0 0 0.5em;
}
#result-board .tab {
  position: relative;
  padding: 0 0.89em;
}
#result-board .tab ul {
  position: absolute;
  bottom: 0;
  display: flex;
  justify-content: center;
  align-items: stretch;
  width: calc(100% - 1.78em);
  height: 100%;
}
#result-board .tab ul li {
  width: 33.3333%;
}
#result-board .tab ul li:has(.active) {
  width: 47%;
}
#result-board .tab ul li a {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
}
#result-board .tab ul li a.active + img {
  display: block;
}
#result-board .tab ul li img {
  display: none;
  position: absolute;
  top: 0;
  left: 0;
}
#result-board .tab .bg {
  opacity: 0;
}
#result-board .tab-contents {
  margin: 0 0.89em;
}
#result-board .tab-contents .box {
  display: none;
  position: relative;
}
#result-board .result-list {
  position: relative;
  margin-bottom: 1.5em;
  background: url("../img/result/list_bg.jpg") repeat-y 50% 0;
  background-size: 100% auto;
  box-shadow: 0.1em 0.15em 0 0 rgba(0, 0, 0, 0.8);
}
#result-board .result-list h3 {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#result-board .result-list .list-inner ul {
  position: relative;
  padding: 0.8em 0;
  z-index: 1;
}
#result-board .result-list .list-inner ul.txt li {
  overflow: hidden;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  padding: 0.1em 0.65em;
  white-space: nowrap;
  font-size: 1.15em;
  font-weight: 800;
}
#result-board .result-list .list-inner ul.txt li div span {
  position: relative;
}
#result-board .result-list .list-inner ul.txt li div span.fontS {
  font-size: 0.7em;
}
#result-board .result-list .list-inner ul.txt li div span:before {
  content: attr(data-text);
  position: absolute;
  left: 0;
  top: 0;
  -webkit-text-stroke: 0.2em  #000;
  z-index: -1;
}
#result-board .result-list .list-inner ul.txt li div span:after {
  content: attr(data-text);
  position: absolute;
  left: 0;
  top: 0;
  text-shadow: 0 0.2em 0 black;
  z-index: -2;
}
#result-board .result-list .list-inner ul.txt li div .kerning {
  letter-spacing: -0.12em;
}
#result-board .result-list .list-inner ul.txt li div:first-of-type.adjust {
  font-size: 0.87em;
}
#result-board .result-list .list-inner ul.txt li div:first-of-type.indent {
  padding-left: 1em;
  font-size: 0.87em;
}
#result-board .result-list .list-inner ul.txt li div:first-of-type.indent2 {
  padding-left: 2em;
  font-size: 0.87em;
}
#result-board .result-list .list-inner ul.txt li div:first-of-type.indent3 {
  padding-left: 3em;
  font-size: 0.87em;
}
#result-board .result-list .list-inner ul.txt li div:first-of-type span {
  background: #FFF;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
#result-board .result-list .list-inner ul.txt li div:first-of-type span:before {
  color: #FFF;
}
#result-board .result-list .list-inner ul.txt li div:first-of-type span.effect_red {
  background: linear-gradient(180deg, #FFF2D0 40.38%, #E3662C 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
#result-board .result-list .list-inner ul.txt li div:last-of-type {
  flex-grow: 1;
  text-align: right;
}
#result-board .result-list .list-inner ul.txt li div:last-of-type.clear2000 span:first-of-type {
  display: none;
}
#result-board .result-list .list-inner ul.txt li div:last-of-type.clear2000 span.effect {
  background: linear-gradient(#FFF 18%, #28B6FD 89%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
#result-board .result-list .list-inner ul.txt li div:last-of-type.clear2000 span.effect:before {
  color: #FFF;
}
#result-board .result-list .list-inner ul.txt li div:last-of-type span {
  background: linear-gradient(180deg, #F4C43E 25.65%, #FFF475 36.48%, #B4741A 79.82%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
#result-board .result-list .list-inner ul.txt li div:last-of-type span:before {
  color: #FFF;
}
#result-board .result-list .list-inner ul.txt li div:last-of-type span.effect_pink {
  background: linear-gradient(#FFF 48%, #FF5C8A 50%, #FFB2CA 88%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
#result-board .result-list .list-inner ul.txt li div:last-of-type span.effect_blue {
  background: linear-gradient(#FFF 48%, #056FFF 50%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
#result-board .result-list .list-inner ul.txt li div:last-of-type span.effect_red {
  background: linear-gradient(#FFF 48%, #FF3C3C 50%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
#result-board .result-list .list-inner ul.txt li.flex-end {
  justify-content: flex-end;
}
#result-board .result-list .list-inner ul.card {
  display: flex;
  flex-wrap: wrap;
}
#result-board .result-list .list-inner ul.card#trophy {
  justify-content: center;
  padding: 2em 0;
}
#result-board .result-list .list-inner ul.card#trophy div {
  display: flex;
  justify-content: center;
  width: 100%;
}
#result-board .result-list .list-inner ul.card#trophy li {
  width: 27.5%;
  margin-bottom: 0;
  padding: 0;
}
#result-board .result-list .list-inner ul.card li {
  width: 50%;
  margin-bottom: 1.5em;
  padding: 0 0.836em;
  text-align: center;
}
#result-board .result-list .list-inner ul.card li.wide {
  width: 100%;
  padding: 0;
}
#result-board .result-list .list-inner ul.card li p {
  margin: 0 -0.836em;
  line-height: 1.2;
}
#result-board .result-list .list-inner ul.card li p span {
  display: block;
  color: #FFBD42;
}
#result-board .result-graph {
  position: relative;
  margin-bottom: 1em;
}

/* ショップ
-------------------------------------------------------------*/
#shop {
  padding-top: 0.2em;
}
#shop .nav {
  position: relative;
}
#shop .nav ul {
  position: absolute;
  bottom: 0;
  display: flex;
  justify-content: center;
  align-items: stretch;
  width: 100%;
  height: 100%;
  padding: 0 3.8em;
}
#shop .nav ul li {
  flex-grow: 1;
}
#shop .nav ul li.active {
  width: 3em;
}
#shop .nav ul li a {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
}
#shop .icon-list,
#shop .title-list {
  display: flex;
  flex-wrap: wrap;
  margin: 0 0.895em 1em;
  background: url("../img/shop/list_bg.jpg") repeat-y 50% 0;
  background-size: 100% auto;
  box-shadow: 0.1em 0.15em 0 0 rgba(0, 0, 0, 0.8);
}
#shop .icon-list li.under img,
#shop .title-list li.under img {
  filter: brightness(0.5);
}
#shop .icon-list {
  padding: 1.5em 0.4em;
}
#shop .icon-list li {
  width: 33.3333%;
  margin-bottom: 1em;
  padding: 0 0.385em;
}
#shop .title-list {
  padding: 1.5em 3.2em 0.5em;
}
#shop .title-list li {
  margin-bottom: 1em;
}

.modal .shop-detail {
  overflow: auto;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
}
.modal .shop-detail .close-btn {
  position: absolute;
  top: 1.5em;
  right: 0;
  width: 3.8em;
  z-index: 2;
}
.modal .shop-detail .inner {
  position: relative;
  top: 2.5em;
  width: 93.3%;
  max-width: 750px;
  margin: 0 auto;
  padding: 0 0 1em;
  z-index: 1;
}
.modal .shop-detail .inner > *:not(img) {
  position: absolute;
}
.modal .shop-detail .inner .pic {
  left: 50%;
  transform: translateX(-50%);
}
.modal .shop-detail .inner .pic.icon {
  top: 8.2em;
  width: 29.72%;
}
.modal .shop-detail .inner .pic.title {
  top: 10em;
  width: 74%;
}
.modal .shop-detail .inner .pic.under img {
  filter: brightness(0.5);
}
.modal .shop-detail .inner .level {
  top: 19em;
  left: 50%;
  width: 58.3%;
  transform: translateX(-50%);
}
.modal .shop-detail .inner .condition {
  top: 24.5em;
  left: 50%;
  width: 92%;
  transform: translateX(-50%);
}
.modal .shop-detail .inner .condition dt span, .modal .shop-detail .inner .condition dd span {
  position: relative;
}
.modal .shop-detail .inner .condition dt span:before, .modal .shop-detail .inner .condition dd span:before {
  content: attr(data-text);
  position: absolute;
  left: 0;
  top: 0;
  -webkit-text-stroke: 0.2em  #000;
  z-index: -1;
}
.modal .shop-detail .inner .condition dt span:after, .modal .shop-detail .inner .condition dd span:after {
  content: attr(data-text);
  position: absolute;
  left: 0;
  top: 0;
  text-shadow: 0 0.2em 0 black;
  z-index: -2;
}
.modal .shop-detail .inner .condition dt {
  margin-bottom: 0.5em;
  padding-left: 2.5%;
  font-size: 1.425em;
  font-weight: 800;
}
.modal .shop-detail .inner .condition dt span {
  background: linear-gradient(180deg, #FFF2D0 40.38%, #E3662C 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.modal .shop-detail .inner .condition dt span:before {
  color: #FFF;
}
.modal .shop-detail .inner .condition dd {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.8em;
  padding: 0px 2.5% 0 6%;
  line-height: 1.2;
  font-size: 1.28em;
  font-weight: 800;
}
.modal .shop-detail .inner .condition dd span:first-of-type {
  background: #FFF;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.modal .shop-detail .inner .condition dd span:first-of-type:before {
  color: #FFF;
}
.modal .shop-detail .inner .condition dd span:last-of-type {
  background: linear-gradient(180deg, #F4C43E 25.65%, #FFF475 36.48%, #B4741A 79.82%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.modal .shop-detail .inner .condition dd span:last-of-type:before {
  color: #FFF;
}
.modal .shop-detail .inner .condition dd span.under {
  background: linear-gradient(180deg, #E2E2E2 25.65%, #B4B4B4 36.48%, #787878 79.82%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.modal .shop-detail .inner .shop-btn {
  position: absolute;
  top: 36.2em;
  left: 50%;
  width: 22em;
  transform: translateX(-50%);
}
.modal .shop-detail .inner .bg {
  width: 100%;
}
.modal .shop-detail .overlay {
  opacity: 0;
}

/* 使い方
-------------------------------------------------------------*/
#howto {
  margin-bottom: 2em;
}
#howto div {
  position: relative;
}
#howto div a {
  position: absolute;
  top: 57.7em;
  left: 50%;
  display: block;
  width: 13em;
  height: 4.6em;
  transform: translateX(-50%);
  z-index: 1;
}
