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

=共通
=スマスロスーパーリオエース2 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: -1.2em;
}

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

#maker-copy {
  position: relative;
  padding-bottom: 2em;
  z-index: 1;
}
#maker-copy p {
  position: relative;
  background: #FFF;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-size: 0.875em;
  font-weight: 700;
  text-align: center;
}
#maker-copy p:before {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  -webkit-text-stroke: 0.3em #281847;
  z-index: -1;
}
#maker-copy p:after {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  text-shadow: 0em 0.2em 0.2em #422A7B;
  z-index: -2;
}

.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;
}

/* スマスロスーパーリオエース2 TOP
-------------------------------------------------------------*/
#top-page #wrap.bg1 {
  background: #FFF url("../img/top/tab1_bg.png") no-repeat top 88% center;
  background-size: 100% auto;
}
#top-page #wrap.bg2 {
  background: #FFF url("../img/top/tab2_bg.png") no-repeat top 86% center;
  background-size: 100% auto;
}
#top-page #wrap.bg3 {
  background: #FFF url("../img/top/tab3_bg.png") no-repeat top 89% center;
  background-size: 100% auto;
}

#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.4em 0 0.6em;
}
#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;
}
#member .name dl {
  left: 39%;
  bottom: 22%;
  line-height: 1.3;
  color: #3A3A3A;
}
#member .name dl dt {
  margin-bottom: 0;
  font-size: 1.725em;
  font-weight: bold;
}
#member .name dl dd {
  font-size: 1.14em;
  font-weight: 500;
  color: #FFF5CC;
}
#member .name .icon {
  top: 9%;
  left: 5.5%;
  width: 30%;
}
#member .name .title {
  top: 22%;
  left: 39%;
  width: 53%;
}

#login {
  padding: 0.6em 0.4em;
}
#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;
  margin: 0 0.4em;
}
#shop-search .inner {
  position: absolute;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 0 1.2em 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;
  color: inherit;
}
#shop-search .inner a {
  width: 9.1em;
  transform: translateY(-5%);
}
#shop-search .inner button {
  width: 9.1em;
  transform: translateY(-5%);
}
#shop-link {
  padding: 0 0 0.5em;
}

#played-history {
  margin: -0.5em 0 27em;
}

#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%;
}

/* プレイ履歴/プレイ結果/途中結果
-------------------------------------------------------------*/
#history-page #wrap.bg1 {
  background: #FFF url("../img/result/tab1_bg.png") no-repeat top 92.5% center;
  background-size: 100% auto;
}
#history-page #wrap.bg2 {
  background: #FFF url("../img/result/tab2_bg.png") no-repeat top 92% center;
  background-size: 100% auto;
}
#history-page #wrap.bg3 {
  background: #FFF url("../img/result/tab3_bg.png") no-repeat top 91% center;
  background-size: 100% auto;
}

#history-none-page #wrap.bg1 {
  height: 55em;
  background: #FFF url("../img/result/tab3_bg.png") no-repeat bottom 2em center;
  background-size: 100% auto;
}

#result-page #wrap.bg1 {
  background: #FFF url("../img/result/tab1_bg.png") no-repeat top 90% center;
  background-size: 100% auto;
}
#result-page #wrap.bg2 {
  background: #FFF url("../img/result/tab2_bg.png") no-repeat top 88.5% center;
  background-size: 100% auto;
}
#result-page #wrap.bg3 {
  background: #FFF url("../img/result/tab3_bg.png") no-repeat top 87% center;
  background-size: 100% auto;
}

#halfway-page #wrap.bg1 {
  background: #FFF url("../img/result/tab1_bg.png") no-repeat top 93.5% center;
  background-size: 100% auto;
}
#halfway-page #wrap.bg2 {
  background: #FFF url("../img/result/tab2_bg.png") no-repeat top 93% center;
  background-size: 100% auto;
}
#halfway-page #wrap.bg3 {
  background: #FFF url("../img/result/tab3_bg.png") no-repeat top 91.5% center;
  background-size: 100% auto;
}

.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 {
  position: relative;
  margin: 2em 0;
  text-align: center;
  font-size: 1.2em;
  font-weight: 700;
  color: #FFF;
  z-index: 1;
}
#result-none:before {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  -webkit-text-stroke: 0.3em #252525;
  z-index: -1;
}

#date-search {
  position: relative;
  margin: -1.2em 0 0.5em;
  padding: 0 0.7em;
}
#date-search ul {
  position: absolute;
  left: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 0.6em 2.5em 0;
  font-size: 1.2em;
  font-weight: 700;
  z-index: 1;
  transform: translateY(-5%);
}
#date-search ul div, #date-search ul a {
  display: inline-block;
  position: relative;
  background: linear-gradient(180deg, #FFFFFF 40%, #FFF100 59%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
#date-search ul div:before, #date-search ul a:before {
  display: inline-block;
  content: attr(data-text);
  position: absolute;
  left: 0;
  top: 0;
  text-shadow: 0 0.15em 0.1em #BF00B2;
  color: #FFF;
  z-index: -1;
}
#date-search ul div.no-link, #date-search ul a.no-link {
  background: linear-gradient(180deg, #CACACA 0%, #DADADA 44.23%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
#date-search ul div {
  position: relative;
  top: 5%;
}

#result-board {
  position: relative;
  margin-bottom: 26em;
  padding: 0em 0 1em;
}
#result-board h2 {
  margin: 0 0 0.5em;
}
#result-board .tab {
  position: relative;
}
#result-board .tab ul {
  position: absolute;
  bottom: 0;
  display: flex;
  justify-content: center;
  align-items: stretch;
  width: 100%;
  height: 100%;
}
#result-board .tab ul li {
  width: 33.3333%;
}
#result-board .tab ul li a {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
}
#result-board .tab ul li a.active {
  pointer-events: none;
}
#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 .box {
  display: none;
  position: relative;
}
#result-board .result-list {
  position: relative;
  margin-bottom: 0.5em;
}
#result-board .result-list h3 {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#result-board .result-list .list-inner {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  margin-top: 3.2em;
}
#result-board .result-list .list-inner.adjust {
  margin-top: 0;
}
#result-board .result-list .list-inner ul {
  position: relative;
  padding: 1em 1em 0;
  z-index: 1;
}
#result-board .result-list .list-inner ul.txt.gradation {
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1;
}
#result-board .result-list .list-inner ul.txt.gradation li {
  justify-content: flex-end;
  color: #A79550;
}
#result-board .result-list .list-inner ul.txt.gradation div {
  background: linear-gradient(180deg, #9954F6 0%, #F266F2 85.58%);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}
#result-board .result-list .list-inner ul.txt li {
  overflow: hidden;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: baseline;
  padding: 0.1em 0.5em;
  white-space: nowrap;
  letter-spacing: -4%;
  font-size: 1.275em;
  font-weight: 800;
}
#result-board .result-list .list-inner ul.txt li:empty:before {
  content: "　";
}
#result-board .result-list .list-inner ul.txt li .fontS {
  margin-left: 0.25em;
  font-size: 0.7em;
}
#result-board .result-list .list-inner ul.txt li .indent {
  padding-left: 1em;
}
#result-board .result-list .list-inner ul.txt li .indent2 {
  padding-left: 2em;
}
#result-board .result-list .list-inner ul.txt li .indent3 {
  padding-left: 3em;
}
#result-board .result-list .list-inner ul.txt li .effect {
  position: relative;
  background: linear-gradient(180deg, #FFF 40%, #FFCCFE 40%, #FFF 80%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
#result-board .result-list .list-inner ul.txt li .effect:before {
  content: attr(data-text);
  position: absolute;
  left: 0;
  top: 0;
  -webkit-text-stroke: 0.2em #B222AF;
  z-index: -1;
}
#result-board .result-list .list-inner ul.txt li .effect:after {
  content: attr(data-text);
  position: absolute;
  left: 0;
  top: 0;
  text-shadow: 0.18em 0.15em 0.05em #00A0E9;
  z-index: -2;
}
#result-board .result-list .list-inner ul.txt li .kome {
  font-size: 0.875em;
  color: #3D9DF2;
}
#result-board .result-list .list-inner ul.txt li.kerning {
  letter-spacing: -0.12em;
}
#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-page #wrap.icon {
  background: #FFF url("../img/shop/icon_bg.png") no-repeat top 100% center;
  background-size: 100% auto;
}
#shop-page #wrap.title {
  background: #FFF url("../img/shop/title_bg.png") no-repeat top 100% center;
  background-size: 100% auto;
}
#shop-page #wrap .page-title {
  margin-bottom: 0;
}

#shop {
  padding-top: 0.2em;
}
#shop .nav {
  position: relative;
}
#shop .nav ul {
  position: absolute;
  bottom: 0;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  width: 100%;
  height: 100%;
  padding: 0 0.8em;
}
#shop .nav ul li {
  width: 50%;
}
#shop .nav ul li a {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
}
#shop .list-area {
  position: relative;
  margin-bottom: 26em;
}
#shop .list-area .icon-list,
#shop .list-area .title-list {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  z-index: 1;
}
#shop .list-area .icon-list li.under a,
#shop .list-area .title-list li.under a {
  display: block;
  position: relative;
}
#shop .list-area .icon-list li.under a img.filter,
#shop .list-area .title-list li.under a img.filter {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  filter: brightness(0) saturate(100%) invert(58%) sepia(78%) saturate(1707%) hue-rotate(160deg) brightness(94%) contrast(86%);
  opacity: 0.7;
}
#shop .list-area .icon-list {
  padding: 2em 1.2em 0;
}
#shop .list-area .icon-list li {
  width: 33.3333%;
  margin-bottom: 0.9em;
  padding: 0 0.42em;
}
#shop .list-area .title-list {
  padding: 2em 2.67em 0;
}
#shop .list-area .title-list li {
  margin-bottom: 1.15em;
}

.modal .shop-detail {
  overflow: auto;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 195, 249, 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: 0.5em;
  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 img {
  filter: drop-shadow(0 0.2em 0.2em rgba(0, 0, 0, 0.8));
}
.modal .shop-detail .inner .pic.icon {
  top: 8.5em;
  width: 7.25em;
}
.modal .shop-detail .inner .pic.title {
  top: 10em;
  width: 74%;
}
.modal .shop-detail .inner .pic.under img {
  filter: brightness(0.5) drop-shadow(0 0.2em 0.2em rgba(0, 0, 0, 0.8));
}
.modal .shop-detail .inner .level {
  top: 15.8em;
  left: 50%;
  width: 12.55em;
  transform: translateX(-50%);
}
.modal .shop-detail .inner .condition {
  top: 23.5em;
  left: 50%;
  width: 100%;
  transform: translateX(-50%);
}
.modal .shop-detail .inner .condition dd {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 2.5em 0 2.8em;
  line-height: 1.2;
  font-size: 1.28em;
  font-weight: 600;
}
.modal .shop-detail .inner .condition dd.under span {
  background: #FFF;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.modal .shop-detail .inner .condition dd.under span:last-of-type {
  background: linear-gradient(180deg, #FFFFFF 40.38%, #DADADA 45.67%, #A3A3A3 45.68%, #DADADA 72.6%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.modal .shop-detail .inner .condition dd.under span:last-of-type span {
  background: #FFF;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.modal .shop-detail .inner .condition dd span {
  position: relative;
  background: linear-gradient(180deg, #FFFFFF 40%, #FFF100 59%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.modal .shop-detail .inner .condition dd span:after {
  content: attr(data-text);
  position: absolute;
  left: 0;
  top: 0;
  text-shadow: 0 0.2em 0.2em rgba(34, 14, 124, 0.7);
  z-index: -2;
}
.modal .shop-detail .inner .condition dd span span {
  margin-left: 0.5em;
  font-size: 0.7em;
}
.modal .shop-detail .inner .condition dd .fontS {
  font-size: 0.9em;
}
.modal .shop-detail .inner .condition .line {
  display: block;
  margin: 0.8em 0 3.7em;
}
.modal .shop-detail .inner .shop-btn {
  position: absolute;
  top: 32.5em;
  left: 50%;
  width: 15.6em;
  transform: translateX(-50%);
}
.modal .shop-detail .inner .bg {
  width: 100%;
}
.modal .shop-detail .overlay {
  opacity: 0;
}

/* 使い方
-------------------------------------------------------------*/
#howto {
  margin-bottom: 2em;
  background: #FFF;
}
#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;
}
