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

.pc {
  display: none; }

.p-index_feature__bnr ul {
  width: 100%;
  overflow: hidden;
  padding: 20px 0 0 0; }
  .p-index_feature__bnr ul li {
    float: left;
    width: 48%; }
  .p-index_feature__bnr ul li:last-child {
    float: right; }

.jis {
  width: 90%;
  clear: both;
  overflow: hidden;
  margin: 0 auto 100px auto; }
  .jis dl {
    width: 40%;
    float: left;
    line-height: 1.5; }
    .jis dl dt {
      font-size: 3.4rem;
      color: #57a5d7;
      margin-bottom: 10px; }
      .jis dl dt span {
        font-size: 2.8rem;
        display: block; }
    .jis dl dd {
      line-height: 1.8;
      font-weight: normal; }
      .jis dl dd b {
        color: #f7931e;
        text-decoration: underline; }
  .jis .graf {
    width: 50%;
    float: right; }

.p-products .p-products_lineup__colors .swiper-pagination04 {
  margin-left: 0; }

.p-index_topics {
  padding: 120px 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 {
  display: flex;
  justify-content: space-between; }
  .p-index_topics__phtlist li {
    width: 30%;
    -webkit-transition: .7s ease;
    transition: .7s ease;
    opacity: 0;
    -webkit-transform: translateY(15px);
    transform: translateY(15px); }
    .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: 780px;
  margin: 0 auto;
  line-height: 1.5;
  margin-bottom: 120px; }
  .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; }
    .p-news dl dt {
      font-size: 2.1rem;
      margin-bottom: 10px; }
    .p-news dl dd {
      font-size: 3.6rem; }
  .p-news .pht {
    margin-bottom: 20px; }
  .p-news .pht2 {
    display: flex;
    justify-content: space-between;
    margin-bottom: 20px; }
    .p-news .pht2 img {
      width: 48%; }
  .p-news p {
    font-weight: normal;
    margin-bottom: 20px;
    line-height: 1.8; }
  .p-news .c-btn02 {
    width: 50%;
    margin: 0 auto; }

.topics__phtlist {
  width: 100%;
  overflow: hidden;
  margin-bottom: 40px; }
  .topics__phtlist li {
    width: 48%;
    float: left;
    margin-right: 4%;
    margin-bottom: 20px; }
    .topics__phtlist li img {
      margin-bottom: 5px; }
  .topics__phtlist li:nth-child(2n) {
    margin-right: 0; }
  .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: 500px;
  max-width: 100%;
  background-color: #fff;
  max-height: 600px;
  padding: 80px 60px 60px 60px;
  border-radius: 20px; }
  .js_modalContInner .img {
    margin-bottom: 15%; }
  .js_modalContInner p {
    text-align: center;
    margin-bottom: 10%;
    font-size: 18px; }
  .js_modalContInner ul {
    display: flex;
    justify-content: space-between;
    width: 30%;
    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 .bnr {
    position: absolute;
    right: 4%;
    bottom: 8%;
    width: 24%;
    z-index: 5;
    box-shadow: 3px 3px 15px -5px #555;
    border: 1px solid #fff; }
    .p-kv .bnr a {
      display: block;
      transition: .3s; }
    .p-kv .bnr a:hover {
      opacity: 0.7;
      transition: .3s; }

#concept {
  padding: 0% 0 8% 0; }
  #concept h2 {
    font-family: urw-din, sans-serif;
    font-weight: 400;
    font-size: 1.0vw;
    margin-bottom: 3%;
    margin-left: 5%;
    text-align: center;
    color: #79859b;
    letter-spacing: 3px;
    font-weight: 500; }
  #concept h3 {
    font-weight: 700;
    text-align: center;
    font-weight: 700;
    font-size: 2.4vw;
    letter-spacing: 4px; }

#prconsept {
  position: relative;
  overflow: hidden;
  padding-bottom: 5%;
  margin-bottom: 12%; }
  #prconsept h2 {
    font-size: 36px;
    line-height: 1.5;
    margin-bottom: 3%; }
  #prconsept p {
    font-size: 15px;
    text-align: justify; }
  #prconsept .txt {
    width: 52%;
    float: left; }
  #prconsept .pht1 {
    width: 43%;
    float: right; }
  #prconsept .pht2 {
    width: 25%;
    position: absolute;
    right: 30%;
    bottom: 0;
    z-index: 2; }

#fablic {
  position: relative;
  overflow: hidden;
  padding-bottom: 5%;
  margin-bottom: 0%; }
  #fablic p {
    font-size: 15px;
    text-align: justify; }
  #fablic b {
    font-size: 19px;
    color: #603813; }
  #fablic span {
    font-size: 13px;
    text-align: center; }
  #fablic .txt {
    width: 52%;
    float: right; }
    #fablic .txt .icn {
      width: 80%;
      margin: 0 auto 2% auto; }
  #fablic .read {
    font-size: 11px;
    line-height: 1.8;
    padding-top: 3%; }
  #fablic .pht {
    width: 43%;
    float: left; }

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

.lineup__head {
  margin: 0 0%; }
  .lineup__head .heading {
    font-size: 15px;
    margin-bottom: 20px; }
  .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: 2.7rem;
    margin-bottom: 10px; }
  .lineup__head .name .price {
    font-size: 2rem;
    margin-left: 20px; }
  .lineup__head .name .price small {
    font-size: 1.2rem; }

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

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

footer {
  position: relative;
  font-family: urw-din, sans-serif;
  padding: 2% 8% 2% 8%;
  background: #57A6D8;
  color: #fff;
  font-weight: normal; }
  footer a {
    color: #fff; }
  footer a:visited {
    color: #fff; }
  footer h2 {
    width: 12%;
    margin-bottom: 2%; }
  footer .copy {
    font-size: 0.8vw; }
  footer .wf {
    width: 10%;
    position: absolute;
    right: 8%;
    bottom: 17%; }
  footer nav {
    width: 25%;
    font-size: 0.8vw;
    letter-spacing: 1px;
    position: absolute;
    right: 8%;
    top: 25%; }
    footer nav ul {
      display: flex;
      justify-content: space-between; }
  footer .sns {
    width: 7%;
    margin-bottom: 2%; }
    footer .sns ul {
      display: flex;
      justify-content: space-between; }
    footer .sns li {
      width: 28%; }

.p-kv__logo {
  width: 35%; }

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

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

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

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

.blgbnr {
  position: absolute;
  width: 0%;
  left: -100%;
  bottom: 1%;
  z-index: -1; }

.loader {
  position: absolute;
  z-index: 0;
  font-size: 2vw;
  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; } }
.newsArea {
  background: #fff;
  box-shadow: 0px 10px 10px -6px rgba(0, 0, 0, 0.1);
  padding: 3% 0 1% 0;
  text-align: center;
  width: 80%;
  margin: 0 auto 8% auto;
  border-radius: 6px; }
  .newsArea .sp {
    display: none; }
  .newsArea h2 {
    font-size: 1.6vw;
    color: #6aa3d2;
    margin-bottom: 1%;
    letter-spacing: 1px; }
  .newsArea p {
    font-weight: 400;
    font-size: 1.1vw;
    line-height: 2; }
    .newsArea p a {
      color: #6aa3d2;
      text-decoration: underline; }
    .newsArea p a:hover {
      text-decoration: none; }

.comingsoon {
  display: flex;
  justify-content: space-between;
  width: 80%;
  margin: 0 auto; }
  .comingsoon .p-index_lineup__product {
    width: 70%; }
  .comingsoon .pht {
    width: 30%; }

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

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

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

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

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