body {
  font-family: "Zen Kaku Gothic New",sans-serif; }

.sp {
  display: none; }

.p-index_feature__bnr ul {
  padding-top: 5%; }
  .p-index_feature__bnr ul li {
    margin-bottom: 5%; }

.jis {
  width: 100%;
  clear: both;
  overflow: hidden;
  margin: 0 auto 100px auto; }
  .jis dl {
    line-height: 1.5;
    margin-bottom: 5%; }
    .jis dl dt {
      font-size: 2.2rem;
      color: #57a5d7;
      margin-bottom: 10px;
      font-weight: 700; }
      .jis dl dt span {
        font-size: 1.9rem;
        display: block; }
    .jis dl dd {
      line-height: 1.8;
      font-weight: normal; }
      .jis dl dd b {
        color: #f7931e;
        text-decoration: underline; }

.p-index_topics {
  padding: 60px 0; }

.p-index_topics__ttl {
  font-size: 2.3rem;
  letter-spacing: 3px;
  font-family: urw-din, sans-serif;
  font-weight: 500;
  color: #57a5d7;
  margin-bottom: 30px;
  -webkit-transition: .7s ease;
  transition: .7s ease;
  opacity: 0;
  -webkit-transform: translateY(15px);
  transform: translateY(15px); }

.p-index_topics__phtlist li {
  -webkit-transition: .7s ease;
  transition: .7s ease;
  opacity: 0;
  -webkit-transform: translateY(15px);
  transform: translateY(15px);
  margin-bottom: 5%; }
  .p-index_topics__phtlist li img {
    margin-bottom: 5px; }
.p-index_topics__phtlist li.is-act, .p-index_topics__phtlist .p-index .p-index_topics__ttl.is-act {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0); }
.p-index_topics__phtlist li a {
  display: block;
  padding: 10px 0 12px;
  color: #414141;
  position: relative;
  -webkit-transition: 1s ease;
  transition: 1s ease;
  border-bottom: 1px solid #d7d4cf; }
.p-index_topics__phtlist li a .time {
  display: block;
  color: #b1d9ef;
  font-family: urw-din, sans-serif;
  font-size: 1.5rem;
  font-weight: 400; }
.p-index_topics__phtlist li a .ttl {
  font-size: 1.6rem;
  font-weight: 400;
  letter-spacing: .08em; }

.p-news {
  width: 86%;
  margin: 0 auto;
  margin-bottom: 120px;
  font-family: "Zen Kaku Gothic New",sans-serif; }
  .p-news h1 {
    font-size: 3.1rem;
    font-family: urw-din, sans-serif;
    letter-spacing: 2px;
    font-weight: 500;
    color: #57a5d7;
    text-align: center;
    padding: 60px 0; }
  .p-news .warp {
    margin-bottom: 60px; }
  .p-news dl {
    margin-bottom: 20px;
    line-height: 1.5; }
    .p-news dl dt {
      font-size: 1.4rem;
      margin-bottom: 10px; }
    .p-news dl dd {
      font-size: 2.2rem; }
  .p-news .pht {
    margin-bottom: 20px; }
  .p-news .pht2 img {
    margin-bottom: 20px; }
  .p-news p {
    font-weight: normal;
    margin-bottom: 20px;
    line-height: 1.8; }
  .p-news .c-btn02 {
    width: 70%;
    margin: 0 auto; }

.topics__phtlist li {
  margin-bottom: 5%; }
  .topics__phtlist li img {
    margin-bottom: 5px; }
.topics__phtlist li.is-act, .topics__phtlist .p-index .p-index_topics__ttl.is-act {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0); }
.topics__phtlist li a {
  display: block;
  padding: 10px 0 12px;
  color: #414141;
  position: relative;
  -webkit-transition: 1s ease;
  transition: 1s ease;
  border-bottom: 1px solid #d7d4cf; }
.topics__phtlist li a .time {
  display: block;
  color: #dfbc9c;
  font-family: urw-din, sans-serif;
  font-size: 1.5rem;
  font-weight: 400; }
.topics__phtlist li a .ttl {
  font-size: 1.6rem;
  font-weight: 400;
  letter-spacing: .08em; }

.js_modalBtnWrap {
  width: 300px;
  max-width: 100%;
  margin: 0 auto;
  text-align: center; }

.js_modalWrap {
  opacity: 0;
  z-index: -1;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%; }

.js_modalWrap.active {
  animation: modalOpen 0.3s ease forwards; }

.js_modalWrap.active2 {
  animation: modalClose 0.3s ease forwards; }

.js_modalBG {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7); }

.js_modalContInner {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  width: 90%;
  max-width: 90%;
  background-color: #fff;
  max-height: 600px;
  padding: 15% 12% 12% 12%;
  border-radius: 20px; }
  .js_modalContInner .img {
    margin-bottom: 15%; }
  .js_modalContInner p {
    text-align: center;
    margin-bottom: 10%;
    font-size: 3vw;
    font-weight: 700; }
  .js_modalContInner ul {
    display: flex;
    justify-content: space-between;
    width: 45%;
    margin: 0 auto; }
    .js_modalContInner ul li {
      width: 40%; }

.js_modalCont {
  max-height: 520px; }

.js_modalCont > * + * {
  margin-top: 10px; }

.js_modalContInner > .js_modalClose + * {
  margin-top: 0; }

.js_modalClose {
  display: block;
  position: absolute;
  top: 20px;
  right: 20px;
  width: 20px;
  height: 20px;
  overflow: hidden;
  cursor: pointer;
  z-index: 1001; }

.js_modalClose::before,
.js_modalClose::after {
  content: "";
  background-color: #222;
  position: absolute;
  top: -5px;
  right: 10px;
  width: 1px;
  height: 30px; }

.js_modalClose::before {
  transform: rotate(45deg); }

.js_modalClose::after {
  transform: rotate(-45deg); }

@keyframes modalOpen {
  0% {
    opacity: 0; }
  100% {
    opacity: 1;
    z-index: 1000; } }
@keyframes modalClose {
  0% {
    opacity: 1;
    z-index: 1000; }
  100% {
    opacity: 0; } }
.p-kv {
  position: relative; }
  .p-kv .p-kv__logo {
    bottom: -5%;
    width: 80%;
    margin: 0 auto; }
  .p-kv .bnr {
    width: 60%;
    position: absolute;
    right: 5%;
    bottom: 3%;
    z-index: 5;
    box-shadow: 3px 3px 10px -5px #555;
    border: 1px solid #fff;
    font-weight: normal;
    display: none; }
    .p-kv .bnr a {
      display: block;
      transition: .3s; }
    .p-kv .bnr a:hover {
      opacity: 0.7;
      transition: .3s; }

#concept {
  overflow: hidden;
  font-family: "Zen Kaku Gothic New",sans-serif; }
  #concept h2 {
    font-family: urw-din, sans-serif;
    font-weight: 400;
    font-size: 3.0vw;
    margin-bottom: 4%;
    font-weight: 500;
    letter-spacing: 3px;
    color: #79859b;
    text-align: center; }
  #concept h3 {
    font-weight: 700;
    text-align: center;
    font-weight: 700;
    font-size: 5.7vw;
    letter-spacing: 0px;
    line-height: 1.5; }

.p-index .p-index_feature {
  padding: 15% 0 15% 0; }

.p-index_concept .container {
  padding: 0; }
.p-index_concept .p-index_concept__img.-n01 {
  margin: 0; }
.p-index_concept .p-index .p-index_products__img {
  margin: 0; }

.p-index .p-index-ttl01_ja {
  margin-bottom: 5%;
  font-size: 5.2vw; }

.p-index .p-index_topics {
  margin: 0 auto;
  width: 84%; }
  .p-index .p-index_topics .container {
    padding: 0; }

#prconsept {
  width: 100%;
  position: relative;
  overflow: hidden;
  padding-bottom: 5%;
  margin-bottom: 12%;
  font-family: "Zen Kaku Gothic New",sans-serif; }
  #prconsept p {
    text-align: justify; }
  #prconsept .txt {
    margin: 0 8%; }
  #prconsept .pht1 {
    width: 70%;
    margin-bottom: 10%; }
  #prconsept .pht2 {
    width: 40%;
    position: absolute;
    right: 0%;
    top: 25%;
    z-index: 2; }

#fablic {
  position: relative;
  overflow: hidden;
  padding-bottom: 5%;
  margin-bottom: 0%;
  font-family: "Zen Kaku Gothic New",sans-serif; }
  #fablic p {
    text-align: justify; }
  #fablic b {
    font-size: 4.4vw;
    color: #603813; }
  #fablic span {
    font-size: 2.8vw;
    text-align: center;
    letter-spacing: 0;
    line-height: 1.2; }
  #fablic .txt {
    margin: 0 8%; }
    #fablic .txt .icn {
      width: 100%;
      margin: 0 auto 2% auto; }
  #fablic .read {
    font-size: 2.6vw;
    line-height: 1.8;
    padding-top: 5%; }
  #fablic .pht {
    margin-bottom: 10%; }

.p-index .p-index_lineup__hero {
  background: url("../img/2025/top_lineup_img.webp") center/cover no-repeat; }

.lineup__head {
  margin: 0 0%;
  font-family: "Zen Kaku Gothic New",sans-serif; }
  .lineup__head .heading {
    font-size: 3.2vw;
    font-weight: 600;
    margin-bottom: 3%; }
  .lineup__head .heading span {
    display: inline-block;
    line-height: 1;
    padding: 6px 12px 6px;
    border-radius: 5px;
    color: #57a5d7;
    border: 1px solid #57a5d7; }
  .lineup__head .name {
    font-size: 5.0vw;
    margin-bottom: 10px;
    font-weight: 600; }
  .lineup__head .name .price {
    font-size: 2rem;
    margin-left: 00px; }
  .lineup__head .name .price small {
    font-size: 1.2rem; }

.p-index_lineup__details {
  margin-bottom: 5%; }

.l-gnavi .sns {
  width: 50%;
  display: flex;
  justify-content: space-between; }
  .l-gnavi .sns a {
    display: block;
    width: 32%; }

footer {
  position: relative;
  padding: 8% 5%;
  background: #57A6D8;
  color: #fff;
  font-family: urw-din, sans-serif;
  padding-bottom: 30%; }
  footer a {
    color: #fff; }
  footer a:visited {
    color: #fff; }
  footer h2 {
    width: 40%;
    margin-bottom: 5%; }
  footer .copy {
    font-size: 2.6vw; }
  footer .wf {
    width: 35%;
    position: absolute;
    right: 5%;
    top: 9.5%; }
  footer nav {
    margin-bottom: 5%; }
    footer nav ul li {
      margin-bottom: 2%; }
  footer .sns {
    width: 30%;
    margin-bottom: 5%; }
    footer .sns ul {
      display: flex;
      justify-content: space-between; }
    footer .sns li {
      width: 28%; }

.p-index_concept {
  background: url("../img/2025/bg_sp.webp") no-repeat center top;
  background-size: 100%; }

.main-movie {
  width: 100%;
  background: #fff url("../img/2025/bg_active_sp.webp") no-repeat center top;
  background-size: cover; }

.main-movie .inner {
  aspect-ratio: 9/16;
  width: 100%;
  overflow: hidden; }
  .main-movie .inner .visible-xs {
    position: absolute;
    width: 100%;
    z-index: 2;
    aspect-ratio: 9/16; }

.main-movie iframe {
  aspect-ratio: 9/16;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: 0 0%;
  object-position: 0 0%;
  display: block; }

.blgbnr {
  position: fixed;
  width: 70%;
  left: 2%;
  bottom: 1%;
  z-index: 100; }

.loader {
  position: absolute;
  z-index: 0;
  font-size: 4vw;
  width: 1em;
  height: 1em;
  border-radius: 50%;
  left: 50%;
  top: 45%;
  text-indent: -9999em;
  -webkit-animation: load5 1.1s infinite ease;
  animation: load5 1.1s infinite ease;
  -webkit-transform: translateZ(0);
  -ms-transform: translateZ(0);
  transform: translateZ(0); }

@-webkit-keyframes load5 {
  0%,
  100% {
    box-shadow: 0em -2.6em 0em 0em #ffffff, 1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2), 2.5em 0em 0 0em rgba(255, 255, 255, 0.2), 1.75em 1.75em 0 0em rgba(255, 255, 255, 0.2), 0em 2.5em 0 0em rgba(255, 255, 255, 0.2), -1.8em 1.8em 0 0em rgba(255, 255, 255, 0.2), -2.6em 0em 0 0em rgba(255, 255, 255, 0.5), -1.8em -1.8em 0 0em rgba(255, 255, 255, 0.7); }
  12.5% {
    box-shadow: 0em -2.6em 0em 0em rgba(255, 255, 255, 0.7), 1.8em -1.8em 0 0em #ffffff, 2.5em 0em 0 0em rgba(255, 255, 255, 0.2), 1.75em 1.75em 0 0em rgba(255, 255, 255, 0.2), 0em 2.5em 0 0em rgba(255, 255, 255, 0.2), -1.8em 1.8em 0 0em rgba(255, 255, 255, 0.2), -2.6em 0em 0 0em rgba(255, 255, 255, 0.2), -1.8em -1.8em 0 0em rgba(255, 255, 255, 0.5); }
  25% {
    box-shadow: 0em -2.6em 0em 0em rgba(255, 255, 255, 0.5), 1.8em -1.8em 0 0em rgba(255, 255, 255, 0.7), 2.5em 0em 0 0em #ffffff, 1.75em 1.75em 0 0em rgba(255, 255, 255, 0.2), 0em 2.5em 0 0em rgba(255, 255, 255, 0.2), -1.8em 1.8em 0 0em rgba(255, 255, 255, 0.2), -2.6em 0em 0 0em rgba(255, 255, 255, 0.2), -1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2); }
  37.5% {
    box-shadow: 0em -2.6em 0em 0em rgba(255, 255, 255, 0.2), 1.8em -1.8em 0 0em rgba(255, 255, 255, 0.5), 2.5em 0em 0 0em rgba(255, 255, 255, 0.7), 1.75em 1.75em 0 0em #ffffff, 0em 2.5em 0 0em rgba(255, 255, 255, 0.2), -1.8em 1.8em 0 0em rgba(255, 255, 255, 0.2), -2.6em 0em 0 0em rgba(255, 255, 255, 0.2), -1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2); }
  50% {
    box-shadow: 0em -2.6em 0em 0em rgba(255, 255, 255, 0.2), 1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2), 2.5em 0em 0 0em rgba(255, 255, 255, 0.5), 1.75em 1.75em 0 0em rgba(255, 255, 255, 0.7), 0em 2.5em 0 0em #ffffff, -1.8em 1.8em 0 0em rgba(255, 255, 255, 0.2), -2.6em 0em 0 0em rgba(255, 255, 255, 0.2), -1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2); }
  62.5% {
    box-shadow: 0em -2.6em 0em 0em rgba(255, 255, 255, 0.2), 1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2), 2.5em 0em 0 0em rgba(255, 255, 255, 0.2), 1.75em 1.75em 0 0em rgba(255, 255, 255, 0.5), 0em 2.5em 0 0em rgba(255, 255, 255, 0.7), -1.8em 1.8em 0 0em #ffffff, -2.6em 0em 0 0em rgba(255, 255, 255, 0.2), -1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2); }
  75% {
    box-shadow: 0em -2.6em 0em 0em rgba(255, 255, 255, 0.2), 1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2), 2.5em 0em 0 0em rgba(255, 255, 255, 0.2), 1.75em 1.75em 0 0em rgba(255, 255, 255, 0.2), 0em 2.5em 0 0em rgba(255, 255, 255, 0.5), -1.8em 1.8em 0 0em rgba(255, 255, 255, 0.7), -2.6em 0em 0 0em #ffffff, -1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2); }
  87.5% {
    box-shadow: 0em -2.6em 0em 0em rgba(255, 255, 255, 0.2), 1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2), 2.5em 0em 0 0em rgba(255, 255, 255, 0.2), 1.75em 1.75em 0 0em rgba(255, 255, 255, 0.2), 0em 2.5em 0 0em rgba(255, 255, 255, 0.2), -1.8em 1.8em 0 0em rgba(255, 255, 255, 0.5), -2.6em 0em 0 0em rgba(255, 255, 255, 0.7), -1.8em -1.8em 0 0em #ffffff; } }
@keyframes load5 {
  0%,
  100% {
    box-shadow: 0em -2.6em 0em 0em #ffffff, 1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2), 2.5em 0em 0 0em rgba(255, 255, 255, 0.2), 1.75em 1.75em 0 0em rgba(255, 255, 255, 0.2), 0em 2.5em 0 0em rgba(255, 255, 255, 0.2), -1.8em 1.8em 0 0em rgba(255, 255, 255, 0.2), -2.6em 0em 0 0em rgba(255, 255, 255, 0.5), -1.8em -1.8em 0 0em rgba(255, 255, 255, 0.7); }
  12.5% {
    box-shadow: 0em -2.6em 0em 0em rgba(255, 255, 255, 0.7), 1.8em -1.8em 0 0em #ffffff, 2.5em 0em 0 0em rgba(255, 255, 255, 0.2), 1.75em 1.75em 0 0em rgba(255, 255, 255, 0.2), 0em 2.5em 0 0em rgba(255, 255, 255, 0.2), -1.8em 1.8em 0 0em rgba(255, 255, 255, 0.2), -2.6em 0em 0 0em rgba(255, 255, 255, 0.2), -1.8em -1.8em 0 0em rgba(255, 255, 255, 0.5); }
  25% {
    box-shadow: 0em -2.6em 0em 0em rgba(255, 255, 255, 0.5), 1.8em -1.8em 0 0em rgba(255, 255, 255, 0.7), 2.5em 0em 0 0em #ffffff, 1.75em 1.75em 0 0em rgba(255, 255, 255, 0.2), 0em 2.5em 0 0em rgba(255, 255, 255, 0.2), -1.8em 1.8em 0 0em rgba(255, 255, 255, 0.2), -2.6em 0em 0 0em rgba(255, 255, 255, 0.2), -1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2); }
  37.5% {
    box-shadow: 0em -2.6em 0em 0em rgba(255, 255, 255, 0.2), 1.8em -1.8em 0 0em rgba(255, 255, 255, 0.5), 2.5em 0em 0 0em rgba(255, 255, 255, 0.7), 1.75em 1.75em 0 0em #ffffff, 0em 2.5em 0 0em rgba(255, 255, 255, 0.2), -1.8em 1.8em 0 0em rgba(255, 255, 255, 0.2), -2.6em 0em 0 0em rgba(255, 255, 255, 0.2), -1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2); }
  50% {
    box-shadow: 0em -2.6em 0em 0em rgba(255, 255, 255, 0.2), 1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2), 2.5em 0em 0 0em rgba(255, 255, 255, 0.5), 1.75em 1.75em 0 0em rgba(255, 255, 255, 0.7), 0em 2.5em 0 0em #ffffff, -1.8em 1.8em 0 0em rgba(255, 255, 255, 0.2), -2.6em 0em 0 0em rgba(255, 255, 255, 0.2), -1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2); }
  62.5% {
    box-shadow: 0em -2.6em 0em 0em rgba(255, 255, 255, 0.2), 1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2), 2.5em 0em 0 0em rgba(255, 255, 255, 0.2), 1.75em 1.75em 0 0em rgba(255, 255, 255, 0.5), 0em 2.5em 0 0em rgba(255, 255, 255, 0.7), -1.8em 1.8em 0 0em #ffffff, -2.6em 0em 0 0em rgba(255, 255, 255, 0.2), -1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2); }
  75% {
    box-shadow: 0em -2.6em 0em 0em rgba(255, 255, 255, 0.2), 1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2), 2.5em 0em 0 0em rgba(255, 255, 255, 0.2), 1.75em 1.75em 0 0em rgba(255, 255, 255, 0.2), 0em 2.5em 0 0em rgba(255, 255, 255, 0.5), -1.8em 1.8em 0 0em rgba(255, 255, 255, 0.7), -2.6em 0em 0 0em #ffffff, -1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2); }
  87.5% {
    box-shadow: 0em -2.6em 0em 0em rgba(255, 255, 255, 0.2), 1.8em -1.8em 0 0em rgba(255, 255, 255, 0.2), 2.5em 0em 0 0em rgba(255, 255, 255, 0.2), 1.75em 1.75em 0 0em rgba(255, 255, 255, 0.2), 0em 2.5em 0 0em rgba(255, 255, 255, 0.2), -1.8em 1.8em 0 0em rgba(255, 255, 255, 0.5), -2.6em 0em 0 0em rgba(255, 255, 255, 0.7), -1.8em -1.8em 0 0em #ffffff; } }
.comingsoon {
  margin-bottom: 20%; }
  .comingsoon .p-index_lineup__product {
    margin-bottom: 3%;
    padding: 10% 0 0 0; }

.newsArea {
  background: #fff;
  box-shadow: 0px 10px 10px -6px rgba(0, 0, 0, 0.1);
  padding: 8% 0 3% 0;
  text-align: center;
  width: 90%;
  margin: 0 auto 12% auto;
  font-family: "Zen Kaku Gothic New",sans-serif;
  border-radius: 6px; }
  .newsArea .sp {
    display: block; }
  .newsArea h2 {
    font-size: 4.6vw;
    color: #6aa3d2;
    margin-bottom: 3%;
    letter-spacing: 0px;
    font-weight: 600; }
  .newsArea p {
    font-weight: 400;
    font-size: 3.2vw;
    line-height: 2; }
    .newsArea p a {
      color: #6aa3d2;
      text-decoration: underline; }
    .newsArea p a:hover {
      text-decoration: none; }

.sccolor {
  text-align: center;
  color: #6199ce;
  position: absolute;
  bottom: 70%;
  letter-spacing: 2px;
  font-weight: bold; }

.swiper-pagination01 span span {
  position: absolute;
  right: 3%;
  top: 44%;
  color: #6199ce;
  font-size: 16px;
  font-weight: bold; }

.swiper-pagination02 span span {
  position: absolute;
  right: 3%;
  top: 44%;
  color: #6199ce;
  font-size: 16px;
  font-weight: bold; }

.swiper-pagination03 span span {
  position: absolute;
  right: 3%;
  top: 44%;
  color: #6199ce;
  font-size: 16px;
  font-weight: bold; }

.swiper-pagination04 span span {
  position: absolute;
  right: 3%;
  top: 44%;
  color: #6199ce;
  font-size: 16px;
  font-weight: bold; }
