@charset "UTF-8";
/*
 * 参考
 * https: //github.com/Andy-set-studio/modern-css-reset/blob/master/src/reset.css
*/
/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
h5,
p,
figure,
blockquote,
dl,
dd {
  margin: 0;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul,
ol {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Set core root defaults */
html:focus-within {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  line-height: 1.5;
  min-height: 100vh;
  text-rendering: optimizeSpeed;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
}

/* Make images easier to work with */
img,
picture {
  display: block;
  max-width: 100%;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

li {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Remove all animations and transitions for people that prefer not to see them */
/*****************************************
 * 数値から単位を取り除く
 * 参考
 * https: //css-tricks.com/snippets/sass/
******************************************/
/*****************************************
 * px→remの計算
 * 参考
 * https: //webdou.net/sass-rem/
 * Sassではmath.div関数の使用が推奨のため、スラッシュ(/)演算子から変更
******************************************/
/*****************************************
 * vwの計算
 * 参考
 * https://webdou.net/sass-vw/
 * Sassではmath.div関数の使用が推奨のため、スラッシュ(/)演算子から変更
******************************************/
/*
font-size-rclamp
*/
/*
font一括入力
*/
html {
  font-size: 16px;
}

body {
  background-color: #0a1835;
  color: #fff;
  display: flex;
  flex-direction: column;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  line-break: strict;
  min-height: 100svh;
  overflow-wrap: anywhere;
  overflow-x: hidden;
  position: relative;
  text-rendering: optimizeSpeed;
  word-break: normal;
}

body.is-fixed {
  overflow: hidden;
}

a {
  color: inherit;
  display: inline-block;
  text-decoration: none;
  transition: opacity 0.3s;
}

main {
  flex-grow: 1;
}

img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

button {
  background: transparent;
  border: none;
  color: #000;
  padding: 0;
}

p {
  font-size: 0.90625rem;
  font-weight: 500;
  line-height: 2.4;
}

.l-header {
  background: transparent;
  height: auto;
  inset-block-start: 0;
  inset-inline-start: 0;
  position: fixed;
  width: 100%;
  z-index: 100;
}

.error404 .l-header {
  background: #0a1835;
}

.l-inner {
  margin-inline: auto;
  padding-inline: 1.25rem;
  width: 100%;
}

.l-pager {
  margin-top: 2rem;
}

.l-post-connect {
  margin-top: 1rem;
}

.l-site {
  background: #0a1835;
}

.c-breadcrumb {
  padding: 1rem 0;
}

.c-breadcrumb a {
  color: #0a1835;
}

.c-btn {
  background-color: transparent;
  border: 1px solid #fff;
  border-radius: 100vmax;
  color: #fff;
  display: inline-block;
  font-size: 0.875rem;
  font-weight: 400;
  min-width: 10.6875rem;
  padding: 0.9375rem 1.25rem;
  text-align: center;
  transition: 0.3s;
}

.c-fadeInTrigger {
  opacity: 0;
  transition: opacity 0.5s ease, translate 0.5s;
  translate: 0 0.625rem;
  visibility: hidden;
}
.c-fadeInTrigger.fadeIn {
  opacity: 1;
  translate: 0;
  visibility: visible;
}

.c-fadeUpTrigger > span {
  display: block;
  overflow: hidden;
}
.c-fadeUpTrigger > span > span {
  display: block;
  transform: translate3d(0, 100%, 0) skewY(12deg);
  transform-origin: left;
  transition: 1s ease-in-out transform;
}
.c-fadeUpTrigger.fadeUp::after {
  transform: scale(1, 1);
}
.c-fadeUpTrigger.fadeUp > span > span {
  transform: translate3d(0, 0, 0) skewY(0);
}

.c-heading-en {
  font-family: "Roboto", sans-serif;
  font-size: 3.625rem;
  font-weight: 700;
  line-height: 1.1724137931;
  position: relative;
  text-align: center;
}
.c-heading-en::after {
  aspect-ratio: 32.5/1.5;
  background: #fff;
  content: "";
  inset-block-end: -1.125rem;
  inset-inline-start: 50%;
  position: absolute;
  transform: scale(0, 1);
  transform-origin: left top;
  transition: transform 0.3s 1s ease;
  translate: -50%;
  width: 2.03125rem;
}

.c-heading-lv1 {
  font-family: "Roboto", sans-serif;
  font-size: 3.625rem;
  font-weight: 700;
  line-height: 0.8534482759;
  text-align: center;
}

.c-heading-lv2 {
  font-size: 1.65375rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.5;
  text-align: center;
}

.c-title {
  color: black;
  font-size: 1.5rem;
}

.p-404__title {
  font-size: 1.25rem;
  padding-block-start: 5rem;
  text-align: center;
}

.p-404__btn {
  margin-block-end: 3.75rem;
  margin-block-start: 2.5rem;
  text-align: center;
}

.p-accordion__wrap {
  padding-inline: 0.625rem;
}

.p-accordion:first-child {
  margin-block-start: 3.375rem;
}
.p-accordion:not(:first-child) {
  margin-block-start: 0.625rem;
}
.p-accordion__summary {
  align-items: center;
  background-color: color-mix(in sRGB, #fff, black var(--_darken, 0%));
  border-radius: 0.3125rem;
  color: #453c31;
  cursor: pointer;
  display: block grid;
  font-size: 0.9409375rem;
  font-weight: 600;
  gap: 0 0.5rem;
  grid-template-columns: auto 1fr auto;
  letter-spacing: 0.05em;
  line-height: 1.3616738625;
  padding: 0.9375rem 1rem 0.875rem;
  transition: background-color 0.3s, border-radius 0.3s;
}
.p-accordion__summary:focus-visible {
  --_darken: 20%;
}
.p-accordion__summary::after {
  border-block-end: 0;
  border-block-start: 0.5rem solid #453c31;
  border-inline-end: 0.25rem solid transparent;
  border-inline-start: 0.25rem solid transparent;
  border-style: solid;
  content: "";
  height: 0;
  margin-inline-end: 0.1875rem;
  transition: rotate 0.3s;
  width: 0;
}
.p-accordion__summary::-webkit-details-marker {
  display: none; /* Safari用 */
}
.p-accordion.open .p-accordion__summary::after {
  opacity: 0.7;
  rotate: 180deg;
}
.p-accordion.open .p-accordion__summary {
  border-radius: 0.3125rem 0.3125rem 0 0;
}
.p-accordion__title-q {
  align-self: start;
  color: #453c31;
  font-family: "Roboto", sans-serif;
  font-size: 1.5625rem;
  font-weight: 700;
  line-height: 1.074;
}
.p-accordion__title {
  padding-inline-end: 0.25rem;
}
.p-accordion__content {
  border-radius: 0 0 0.3125rem 0.3125rem;
  overflow: hidden;
}
.p-accordion__content-inner {
  --_background: #fff;
  background-color: var(--_background);
  color: #000;
  display: block grid;
  gap: 0 0.625rem;
  grid-template-columns: auto 1fr;
  padding: 0.625rem 1rem 0.875rem;
}
.p-accordion__content-a {
  color: #453c31;
  font-family: "Roboto", sans-serif;
  font-size: 1.5625rem;
  font-weight: 700;
  line-height: 1.074;
}
.p-accordion__content-text {
  color: #453c31;
  font-size: 0.875rem;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.6071428571;
}

.p-board-games-list {
  padding-block-end: 6.3125rem;
}

.p-board-games-list__heading {
  font-family: "Roboto", sans-serif;
  font-size: 2.125rem;
  font-weight: 700;
  line-height: 1.4558823529;
  margin-block-start: 2.125rem;
}
.p-board-games-list__heading span {
  margin-inline: 0.25rem;
}

.p-board-games-list__list-wrap {
  background: #d9d9d9;
  border-radius: 0.625rem;
  margin-block-start: 2.375rem;
  margin-inline: 0.375rem;
  overflow: hidden;
  padding: 0.9375rem 0rem 0.625rem;
  text-align: center;
}
.p-board-games-list__list-wrap.--mbs25 {
  margin-block-start: 1.5625rem;
}
.p-board-games-list__list-wrap iframe {
  background: #fff;
  padding: 0.3125rem;
  width: 93%;
}

.p-board-games-list .p-top-shop__store {
  margin-block-start: 2.1875rem;
}

.p-board-games-mv {
  aspect-ratio: 750/662;
  background: url(../images/p-board-games-mv_img_001.jpg) no-repeat center center/cover;
  display: grid;
  height: 100%;
  place-items: center;
  position: relative;
  width: 100%;
}

.p-board-games-mv__img {
  aspect-ratio: 136.39/163.81;
  inset-block-end: 0.9375rem;
  inset-inline-end: 0.8125rem;
  position: absolute;
  width: 4.2621875rem;
}

.p-contact {
  padding-block-end: 6.375rem;
}

.p-contact__inner {
  padding-inline: 1.40625rem;
}

::-moz-placeholder {
  color: #a2a2a2;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.4583333333;
}

::placeholder {
  color: #a2a2a2;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.4583333333;
}

.p-contact__contents {
  background: #fff;
  border-radius: 0.3125rem;
  margin-block-start: 2.8125rem;
  overflow: hidden;
  padding: 1rem 0.9375rem;
  padding-block-end: 1.4375rem;
}

.p-contact__content:not(:first-child) {
  margin-block-start: 1.4375rem;
}

.p-contact__head {
  color: #333;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.4583333333;
}

.p-contact__item {
  margin-top: 0.375rem;
}

.p-contact__item-example {
  color: gray;
  margin-top: 0.375rem;
}

.p-contact__required {
  color: #f71c1f;
  padding-left: 1em;
}

.p-contact__policy,
.p-contact__content,
.p-contact__btn {
  color: #333;
  font-size: 0.71875rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.4347826087;
}

.p-contact__policy {
  margin-block-start: 1rem;
  text-align: center;
}

.p-contact__policy-link {
  color: #f71c1f;
  transition: all 0.3s;
}

.p-contact__policy .wpcf7-list-item-label {
  margin-inline-end: 2.6875rem;
}

.p-contact__btn-wrap {
  display: flex;
  justify-content: center;
  margin-block-start: 0.875rem;
  margin-inline: auto;
  max-width: 18.75rem;
}

.p-contact__btn {
  background: #cf3e36;
  border-radius: 0.3125rem;
  display: inline-block;
  margin-inline: auto;
  min-width: 8.614375rem;
  overflow: hidden;
  padding: 0.09375rem;
  text-align: center;
}

.p-contact__btn .wpcf7-previous {
  background: #fff !important;
  color: #cf3e36 !important;
}

.p-contact__item-text,
.p-contact__item-tel,
.p-contact__item-email,
.p-contact__item-textarea,
.p-contact__item-select {
  background: none;
  background-color: transparent;
  border: 0.075rem solid rgba(44, 68, 116, 0.6);
  border-radius: 0.375rem;
  color: #333;
  font-family: inherit;
  font-size: 0.75rem;
  margin: 0;
  outline: none;
  padding: 0.75rem 0.9375rem;
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  max-height: 2.6625rem;
  width: 100%;
}

.p-contact__item-text:focus,
.p-contact__item-tel:focus,
.p-contact__item-email:focus,
.p-contact__item-textarea:focus,
.p-contact__item-select:focus {
  border: 1px solid rgba(0, 0, 0, 0.7);
  box-shadow: none;
  outline: none;
}

.p-contact__item-textarea {
  height: 9.45rem;
  max-height: unset;
  overflow: auto;
  resize: none;
}

.p-contact__item-message {
  white-space: pre-wrap;
}

.p-contact__item-select {
  background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAALJJREFUeNrslssNgCAQRCmB0ijBEuyEEijBEijBEizBEnAPy0UBWVj8JDvJJB5w3gsXVUoikXwsBrpAPdRCNcOmxi2P2yZ3cIKGU9dOCY0b590pdXhPHOyRyMEDsi4JhVIlSvBYTRGgSNTAQ+pFyyBRC7e5AdchUQt3d1fYIsEGb5Fgh1MktlFwisQwOIeE4/pGuDfhLRLscIrEMHiNxHB4SeIxeMyMPxkenyUSyT9zCDAAj5btZ4c3zaUAAAAASUVORK5CYII=");
  background-position: right 0.5em center;
  background-repeat: no-repeat;
  background-size: 1em;
  color: inherit;
  padding-right: 3em;
}

.p-contact__item-select:invalid {
  color: rgba(0, 0, 0, 0.32);
}

.p-contact__item-select select::-ms-expand {
  display: none;
}

.p-contact__item-radio input[type=radio],
.p-contact__item-checkbox input[type=checkbox] {
  opacity: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.p-contact__item-radio input[type=radio] + span,
.p-contact__item-checkbox input[type=checkbox] + span {
  color: #333;
  cursor: pointer;
  display: inline-block;
  font-size: 0.71875rem;
  padding: 0.5em 1em 0.5em 1.5em;
  position: relative;
}

.p-contact__item-radio input[type=radio]:focus + span,
.p-contact__item-checkbox input[type=checkbox]:focus + span {
  opacity: 0.7;
}

.p-contact__item-radio input[type=radio] + span::before,
.p-contact__item-checkbox input[type=checkbox] + span::before {
  background: white;
  border: 0.09rem solid rgba(44, 68, 116, 0.6);
  border-radius: 0.135rem;
  content: "";
  height: 1.125rem;
  inset-block-start: 50%;
  inset-inline-end: -1.25rem;
  position: absolute;
  transform: translateY(-50%);
  width: 1.125rem;
}

.p-contact__item-radio input[type=radio]:checked + span::before {
  background: white;
}

.p-contact__item-radio input[type=radio] + span::before {
  border-radius: 50%;
}

.p-contact__item-radio input[type=radio] + span::after {
  background: #333;
  border: 0.0625rem solid transparent;
  border-radius: 50%;
  content: "";
  height: 0.5em;
  inset-block-start: 50%;
  inset-inline-end: 0.25em;
  opacity: 0;
  padding: 0.125em;
  position: absolute;
  transform: translateY(-50%);
  transition: all 0.3s ease 0s;
  width: 0.5em;
}

.p-contact__item-checkbox input[type=checkbox] + span::after {
  border-bottom: 2px solid #333;
  border-left: 2px solid #333;
  content: "";
  display: block;
  height: 0.35em;
  inset-block-start: 50%;
  inset-inline-end: -1rem;
  margin-block-start: -0.0625rem;
  opacity: 0;
  position: absolute;
  transform: translateY(-50%) rotate(-45deg);
  transition: all 0.3s ease 0s;
  width: 0.8em;
}

.p-contact__item-checkbox input[type=checkbox]:checked + span::after,
.p-contact__item-radio input[type=radio]:checked + span::after {
  opacity: 1;
}

/* button */
.p-contact__btn input[type=submit],
.p-contact__btn input[type=button] {
  display: inline-block;
  margin: 0;
  padding: 0.5625rem;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  color: #fff;
  -moz-appearance: button;
       appearance: button;
  background: #cf3e36;
  border: 0.01875rem solid #fff;
  border-radius: 0.3125rem;
  box-sizing: border-box;
  cursor: pointer;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  line-height: 1.0269230769;
  transition: all 0.3s;
  width: 100%;
}

.p-contact__btn input[type=submit]:hover,
.p-contact__btn input[type=button]:hover,
.p-contact__btn input[type=submit]:focus,
.p-contact__btn input[type=button]:focus {
  opacity: 0.7;
  outline: none;
}

.p-contact__description {
  margin-block-start: 2.5rem;
}

.wpcf7-spinner {
  margin-inline-start: 0.5rem;
  position: absolute;
}

.p-cta {
  display: block;
  height: auto;
  inset-block-end: 0;
  inset-inline-start: 0;
  opacity: 0;
  position: fixed;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  visibility: hidden;
  width: 100%;
  z-index: 100;
}
.p-cta.is-show {
  opacity: 1;
  visibility: visible;
}

.p-cta .p-drawer__btn-area {
  position: static;
}

.p-drawer__icon {
  cursor: pointer;
  display: flex;
  flex-direction: column;
  height: 0.7875rem;
  inset-block-start: 1.40625rem;
  inset-inline-end: 1.4375rem;
  justify-content: space-between;
  position: fixed;
  scale: 1.2;
  transition: border 0.3s ease;
  width: 1.09375rem;
  z-index: 102;
}

.p-drawer__icon--bar {
  background: #fff;
  height: 0.125rem;
  width: 100%;
}

.p-drawer__icon.is-show {
  aspect-ratio: 1;
  border: 0.0625rem solid #fff;
  height: auto;
  inset-block-start: 1.0125rem;
  inset-inline-end: 1.2125rem;
  width: 1.6rem;
}
.p-drawer__icon.is-show .p-drawer__icon--bar:nth-of-type(1) {
  height: 0.078125rem;
  rotate: 45deg;
  translate: 0.375rem 0.7rem;
  width: 50%;
}
.p-drawer__icon.is-show .p-drawer__icon--bar:nth-of-type(2) {
  display: none;
}
.p-drawer__icon.is-show .p-drawer__icon--bar:nth-of-type(3) {
  height: 0.078125rem;
  rotate: -45deg;
  translate: 0.375rem -0.7rem;
  width: 50%;
}

.p-drawer {
  background: rgba(10, 24, 53, 0.8);
  height: 100vh;
  height: 100svh;
  inset-block-start: 0;
  inset-inline-end: 0;
  inset-inline-start: 0;
  overflow-y: scroll;
  position: fixed;
  width: 100%;
  z-index: 101;
}

.p-drawer__body {
  height: -moz-fit-content;
  height: fit-content;
  position: relative;
  width: 100%;
}
.p-drawer__body::after {
  aspect-ratio: 1;
  background: url(../images/p-drawer_img_001.png) no-repeat center center/cover;
  content: "";
  inset-block-start: 50%;
  inset-inline-start: 50%;
  position: absolute;
  translate: -50% -50%;
  width: 3.125rem;
}

.p-drawer__list {
  display: flex;
  flex-direction: column;
  padding-block-start: 4.84375rem;
  padding-inline-start: 5.21875rem;
}
.p-drawer__list li a {
  background-image: linear-gradient(90deg, #cf3e36, #cf3e36);
  background-position: left 80%;
  background-repeat: no-repeat;
  background-size: 0 0.0625rem;
  color: #fff;
  font-family: "Roboto", sans-serif;
  font-size: 1.5625rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 2.1;
  transition: color 0.3s ease, background-size 0.3s ease;
}

.p-drawer__btn-area {
  align-items: center;
  background: #414141;
  display: flex;
  gap: 0.375rem;
  inset-block-end: 0;
  inset-inline: 0;
  justify-content: center;
  padding-block: 0.5625rem;
  position: fixed;
}

.p-drawer__btn {
  background: #fff;
  border-radius: 100vmax;
  color: #414141;
  display: inline-block;
  font-size: 0.9625rem;
  font-weight: 700;
  line-height: 1.461038961;
  min-width: 10.6875rem;
  padding: 0.875rem 1rem;
}

.p-drawer__icon--bar {
  transition: all 0.5s ease;
}

.p-drawer {
  opacity: 0;
  transition: opacity 0.5s ease;
  visibility: hidden;
}
.p-drawer.is-show {
  opacity: 1;
  visibility: visible;
}

body:has(.p-drawer__icon.is-show) {
  overflow: hidden;
}

.p-footer {
  background: #000;
  display: grid;
  padding-block: 1.3125rem;
  place-items: center;
}

.p-footer__copyright small {
  color: #fff;
  font-size: 0.71875rem;
  font-weight: 400;
  line-height: 1.4347826087;
}

.p-header__inner {
  padding-block: 0.25rem;
  padding-inline: 0.8125rem;
}

.p-header__logo {
  aspect-ratio: 298/52.65;
  font-size: 2em;
  width: 9.3125rem;
}

.p-news-mv.p-board-games-mv {
  background: url(../images/p-news-mv_img_001.jpg) no-repeat center center/cover;
}

.p-pager-list {
  align-items: center;
  display: flex;
  justify-content: space-between;
  padding-block-end: 7.5rem;
}

.p-pager-list__btn a {
  display: inline-block;
  font-size: 1.875rem;
}

.p-pager-list__btn.--text-btn a {
  border: 0.075rem solid #fff;
  border-radius: 2rem;
  color: #fff;
  display: inline-block;
  font-size: 1.1571875rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1.4582770726;
  min-width: 13.1875rem;
  padding: 0.875rem;
  text-align: center;
  transition: all 0.3s ease, color 0.3s;
}

.p-pager .nav-links ul li span,
.p-pager .nav-links ul li a,
.p-pager .nav-links ul li span.current {
  color: #fff;
}

.p-pc-end {
  display: none;
}

.p-pc-end__body {
  height: -moz-fit-content;
  height: fit-content;
  width: 100%;
}

.p-pc-end__list {
  display: flex;
  flex-direction: column;
  padding-block-start: 8.9375rem;
  padding-inline-start: 3.625rem;
}
.p-pc-end__list li a {
  background-image: linear-gradient(90deg, #cf3e36, #cf3e36);
  background-position: left 80%;
  background-repeat: no-repeat;
  background-size: 0 0.0625rem;
  color: #fff;
  font-family: "Roboto", sans-serif;
  font-size: 1.6875rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 2.1;
  transition: color 0.3s ease, background-size 0.3s ease;
}

.p-pc-end__btn-area {
  display: grid;
  gap: 0.875rem;
  justify-content: center;
  margin-block-start: 4rem;
  padding-block: 0.5625rem;
}

.p-pc-end__btn-wrap {
  margin-inline-end: 1rem;
}

.p-pc-end__btn {
  background: transparent;
  border-radius: 100vmax;
  color: #fff;
  display: inline-block;
  font-size: 1.09125rem;
  font-weight: 700;
  line-height: 1.4318442153;
  min-width: 12.125rem;
  padding: 1rem 1rem;
}

.p-pc-end__icon--bar {
  transition: all 0.5s ease;
}

.p-pc-start {
  display: none;
}

.p-pc-start__link {
  aspect-ratio: 334.67/463.61;
  height: auto;
  margin-block-start: 8rem;
  width: 20.916875rem;
}

.p-post-article-mv {
  aspect-ratio: 750/400;
  background: url(../images/p-post-article-mv_img_001.jpg) no-repeat center center/cover;
  position: relative;
  width: 100%;
}
.p-post-article-mv::before {
  background: rgba(0, 0, 0, 0.25);
  content: "";
  inset: 0;
  position: absolute;
}

.p-post-article__inner.l-inner {
  margin-block-start: 2.75rem;
}

.p-post-article__title {
  color: #174a9e;
  font-size: 1.5625rem;
  font-weight: 600;
  line-height: 1.4;
  padding-block-end: 1.125rem;
  position: relative;
  text-align: center;
}
.p-post-article__title::after {
  background: #0a1835;
  content: "";
  height: 0.0625rem;
  inset-block-end: 0rem;
  inset-inline-start: 0;
  position: absolute;
  width: 100%;
}

.p-post-article__info {
  align-items: center;
  display: flex;
  gap: 0.625rem;
  justify-content: flex-start;
  margin-block-start: 0.5rem;
}

.p-post-article__category {
  align-items: center;
  display: flex;
  gap: 0.3125rem;
  justify-content: center;
}

.p-post-article__category li {
  border: 1px solid #0a1835;
  color: #0a1835;
  padding: 0.3125rem;
}

.p-post-article__box {
  margin: 6.4rem auto 0;
}

.p-post-article__content {
  background-color: #fff;
  border-radius: 0.3125rem;
  margin-block-end: 2.5rem;
  padding: 2.125rem 1rem 0;
  width: 100%;
}

.p-post-article__content-wrap {
  margin: auto;
  padding-bottom: 1.875rem;
  width: 100%;
}

.p-post-article__contents {
  margin-top: 1.875rem;
}

.p-post-article__main-img {
  aspect-ratio: 7/4;
}

.p-post-article__main-img img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-post-article__category {
  letter-spacing: 0;
}

.p-post-article__data {
  color: #000;
  font-size: 0.8125rem;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.5;
  padding-inline-start: 1.125rem;
  position: relative;
}
.p-post-article__data::before {
  aspect-ratio: 1;
  background: url(../images/p-post-article_icon_001.svg) no-repeat center center/cover;
  content: "";
  inset-block-start: 50%;
  inset-inline-start: 0;
  position: absolute;
  translate: 0 -50%;
  width: 0.8125rem;
}

.p-post-article__writer {
  color: #000;
  font-size: 0.8125rem;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.5;
  padding-inline-start: 1.125rem;
  position: relative;
}
.p-post-article__writer::before {
  aspect-ratio: 1;
  background: url(../images/p-post-article_icon_002.svg) no-repeat center center/cover;
  content: "";
  inset-block-start: 50%;
  inset-inline-start: 0;
  position: absolute;
  translate: 0 -50%;
  width: 0.8125rem;
}

.p-post-article__content h2 {
  background: rgba(23, 74, 158, 0.7);
  border-radius: 0.46875rem;
  color: #fff;
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.45;
  margin: 2.5rem 0 1.25rem;
  padding: 0.3125rem 0.625rem;
  padding: 0.5rem;
  text-align: center;
}

.p-post-article__contents h3 {
  border-left: 0.5em solid #0a1835;
  color: #000;
  font-size: 1.75rem;
  margin: 1.875rem 0 0.9375rem;
  padding-left: 0.625rem;
}

.p-post-article__contents h4 {
  font-size: 1rem;
  margin: 0.625rem 0;
}

.p-post-article__contents h5 {
  border-bottom: 2px solid #0a1835;
  border-top: 2px solid #0a1835;
  color: #000;
  display: inline-block;
  font-size: 1rem;
  margin: 0.625rem 0;
  padding: 0.125rem 0.78125rem;
}

.p-post-article__contents p {
  color: #000;
  font-size: 1.044375rem;
  font-weight: 400;
  line-height: 1.5559545183;
}

.p-post-article__contents a {
  color: #000;
  text-decoration: underline;
}

.p-post-article__contents img {
  margin: 2.1875rem 0;
}

.p-post-article__contents figure {
  margin: 0.625rem 0;
}

.p-post-article__contents figcaption {
  font-size: 0.75rem;
  margin: 0.625rem 0;
}

.p-post-card {
  background: #fff;
  border-radius: 0.3125rem;
  overflow: hidden;
}

.p-post-card__link {
  width: 100%;
}

.p-post-card__img {
  aspect-ratio: 611.96/336.27;
  margin-inline: auto;
  width: 19.12375rem;
}

.p-post-card__img img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-post-card__body {
  padding: 0.75rem 0.75rem 1.125rem;
  position: relative;
  text-align: center;
}

.p-post-card__title {
  color: #174a9e;
  font-size: 1.370625rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  line-height: 1.3816689466;
  margin-block-start: 0.9375rem;
}

.p-post-card__text {
  display: -webkit-box;
  margin-block-start: 0.3125rem;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.p-post-card__text p {
  color: #000;
  font-size: 1.044375rem;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.6247755835;
  text-align: start;
}

.p-post-card__text h2 {
  background: rgba(23, 74, 158, 0.7);
  border-radius: 0.46875rem;
  color: #fff;
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.45;
  margin: 0.625rem 0;
  padding: 0.3125rem 0.625rem;
  padding: 0.5rem;
  text-align: center;
}

.p-post-card__text h3 {
  border-left: 0.5em solid #0a1835;
  color: #000;
  font-size: 1.75rem;
  margin: 1.875rem 0 0.9375rem;
  padding-left: 0.625rem;
}

.p-post-card__text h4 {
  font-size: 1rem;
  margin: 0.625rem 0;
}

.p-post-card__text h5 {
  border-bottom: 2px solid #0a1835;
  border-top: 2px solid #0a1835;
  color: #000;
  display: inline-block;
  font-size: 1rem;
  margin: 0.625rem 0;
  padding: 0.125rem 0.78125rem;
}

.p-post-connect__title {
  color: #0a1835;
  font-size: 1.5rem;
}

.p-post-connect__items {
  display: grid;
  gap: 3.125rem;
  margin-top: 1rem;
}

.p-post-list {
  margin-inline: auto;
  max-width: 23.4375rem;
  padding-block-end: 6.3125rem;
  position: relative;
}

.p-post-list__wrap {
  margin: 2rem 0;
}

.p-post-list__title {
  color: #0a1835;
  font-size: 3rem;
}

.p-post-list__items {
  display: grid;
  gap: 1.75rem;
  grid-template-columns: repeat(1, 1fr);
  margin-block-start: 2.875rem;
}

.p-post-list__cards {
  margin-top: 3rem;
}

.p-post-list__btn {
  margin-top: 1.25rem;
  text-align: center;
}

.p-top-about {
  padding-block-start: 5.875rem;
}

.p-top-about__img01 {
  aspect-ratio: 630/385;
  margin-block-start: 3.5625rem;
  margin-inline: auto;
  width: 19.6875rem;
}

.p-top-about__title {
  font-size: 1.19625rem;
  font-weight: 600;
  line-height: 1.6;
  margin-block-start: 1.4375rem;
  text-align: center;
}

.p-top-about__text {
  font-size: 0.875rem;
  letter-spacing: 0.03em;
  line-height: 1.6;
  margin-block-start: 0.875rem;
  padding-inline: 0.6875rem;
}
.p-top-about__text.--02 {
  padding-inline-end: 0.5rem;
}

.p-top-about__img02 {
  aspect-ratio: 624/344;
  margin-block-start: 3.4375rem;
  margin-inline: auto;
  width: 19.5rem;
}

.p-top-board-games {
  padding-block-start: 6.25rem;
}

.p-top-board-games__heading {
  line-height: 0.8534482759;
}
.p-top-board-games__heading::after {
  inset-block-end: -1.6875rem;
}

.p-top-board-games__img {
  aspect-ratio: 482/362;
  margin-inline: auto;
  width: 15.0625rem;
}

.p-top-board-games__title {
  color: #310f2a;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.6;
  margin-block-start: 1.3125rem;
  text-align: center;
}

.p-top-board-games__list {
  margin-block-start: 0.625rem;
  padding-inline: 0.625rem;
}

.p-top-board-games__content {
  align-items: center;
  border-block-end: 0.0625rem solid #000;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  padding-block: 0.46875rem;
}
.p-top-board-games__content:first-child {
  border-block-start: 0.0625rem solid #000;
}

.p-top-board-games__term {
  color: #0a1835;
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.6;
  text-align: center;
}

.p-top-board-games__desc {
  color: #0a1835;
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.6;
  text-align: center;
}

.p-top-board-games__btn-wrap {
  margin-block-start: 2.4375rem;
  text-align: center;
}

.p-top-board-games__btn {
  font-family: "Roboto", sans-serif;
  font-size: 1.270625rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.3551401869;
  min-width: 9.375rem;
  padding-block: 0.6875rem;
}

.p-top-board-games .splide {
  margin-block-start: 4.125rem;
}

.p-top-board-games .splide__slide {
  background: #fff;
  border: 0.03125rem solid #000;
  border-radius: 0.625rem;
  padding: 1.9375rem 0.59375rem 1.625rem;
}

.p-top-drink-menu {
  padding-block-start: 5.4375rem;
}

.p-top-drink-menu__heading {
  line-height: 0.8534482759;
}
.p-top-drink-menu__heading::after {
  inset-block-end: -1.6875rem;
}

.p-top-drink-menu__sub-item {
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.5;
  position: relative;
}
.p-top-drink-menu__sub-item::before {
  aspect-ratio: 1;
  background: #fff;
  border-radius: 50%;
  content: "";
  inset-block-start: 58%;
  inset-inline-start: -0.8125rem;
  position: absolute;
  translate: 0 -50%;
  width: 0.25rem;
}

.p-top-drink-menu .p-top-plan__contents {
  margin-block-start: 4.125rem;
  padding-block-end: 1rem;
  padding-block-start: 2.125rem;
  padding-inline: 2.1875rem;
}

.p-top-drink-menu .p-top-plan__option-list {
  margin-block-start: 0.625rem;
}

.p-top-drink-menu .p-top-plan__option-term {
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 1.5;
}
.p-top-drink-menu .p-top-plan__option-term.--flex {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

.p-top-drink-menu .p-top-plan__content {
  padding: 0.375rem 1rem 0.3125rem 0.6875rem;
}

.p-top-drink-menu .p-top-plan__option-list > div:not(:first-child) {
  margin-block-start: 0.4375rem;
}

.p-top-drink-menu .p-top-plan__option-content {
  padding: 0.375rem 1rem 0.3125rem 0.6875rem;
}

.p-top-drink-menu__content {
  border-radius: 0.625rem;
  overflow: hidden;
}
.p-top-drink-menu__content .p-top-plan__option-term {
  background: #3580c4;
  padding: 0.4375rem 0.9375rem 0.3125rem;
}
.p-top-drink-menu__content .p-top-plan__option-desc {
  background: #015683;
  padding: 0.3125rem 2rem 0.625rem;
}

.p-top-drink-menu .--contents2 {
  height: 41.2675rem;
}
.p-top-drink-menu .--contents2 .p-top-plan__option-desc {
  padding: 1.1875rem 2rem 1.5625rem;
}

.p-top-drink-menu .splide {
  margin-inline: auto;
  max-width: 20.9375rem;
}

.p-top-drink-menu .splide__arrow {
  background: #3580c4;
  border: 0.1875rem solid #fff;
  box-shadow: 0rem 0.25rem 0.25rem rgba(0, 0, 0, 0.25);
  inset-block-start: 54.5%;
  opacity: 1;
  transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}

.p-top-drink-menu .splide__arrow:disabled {
  opacity: 0;
  visibility: hidden;
}

.p-top-drink-menu .splide__arrow--next {
  inset-inline-end: -0.4375rem;
}

.p-top-drink-menu .splide__arrow--prev {
  inset-inline-start: -0.4375rem;
}

.p-top-drink-menu .splide__arrow svg {
  fill: #fff;
}

.p-top-faq {
  padding-block-end: 9rem;
  padding-block-start: 5.5rem;
}

.p-top-gallery__inner {
  margin: 5% 5% 0 5%;
}

.p-top-gallery .splide__slide {
  aspect-ratio: 600/300;
  display: block;
  width: 100%;
}

.p-top-gallery .splide__slide picture {
  height: inherit;
  height: 100%;
}

.p-top-gallery .splide__slide img {
  display: block;
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-top-gallery .swiper-slide {
  aspect-ratio: 600/300;
  display: block;
  width: 100%;
}

.p-top-gallery .swiper-slide picture {
  height: inherit;
  height: 100%;
}

.p-top-gallery .swiper-slide img {
  display: block;
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-top-gallery .slick-track {
  display: block;
  width: 100%;
}

.p-top-gallery .slick-slide {
  aspect-ratio: 600/300;
  display: block;
  margin: 0 5px;
  width: 100%;
}

.p-top-gallery .slick-slide picture {
  height: inherit;
  height: 100%;
}

.p-top-gallery .slick-slide img {
  display: block;
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-top-intro {
  overflow-x: clip;
}

.p-top-intro__loop-text-wrap {
  margin-block-start: 1.8125rem;
  margin-inline: auto;
  overflow: hidden;
  position: relative;
  width: 212.5rem;
}
.p-top-intro__loop-text-wrap .loop {
  animation: loop 80s linear infinite;
  width: 100%;
}
.p-top-intro__loop-text-wrap .loop2 {
  animation: loop 80s -40s linear infinite;
  inset-block-start: 0;
  inset-inline-start: 0;
  position: absolute;
}
@keyframes loop {
  0% {
    transform: translateX(100%);
  }
  100% {
    transform: translateX(-100%);
  }
}

.p-top-intro__loop-text {
  font-size: 2.1875rem;
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 2.3428571429;
  text-wrap: nowrap;
}

.p-top-intro__heading {
  margin-block-start: 4.375rem;
}

.p-top-intro__text {
  margin-block-start: 1.9375rem;
  text-align: center;
}

.p-top-intro__img01 {
  aspect-ratio: 610/396;
  margin-block-start: 3.25rem;
  margin-inline: auto;
  width: 19.0625rem;
}

.p-top-mv-slick {
  background: black;
}

.p-top-mv-slick__inner {
  margin: 5% 5% 0 5%;
}

.p-top-mv-slick .slick-track {
  display: block;
  width: 100%;
}

.p-top-mv-slick .slick-slide {
  aspect-ratio: 600/300;
  display: block;
  margin: 0 5px;
  width: 100%;
}

.p-top-mv-slick .slick-slide picture {
  height: inherit;
  height: 100%;
}

.p-top-mv-slick .slick-slide img {
  display: block;
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-top-mv-splide {
  aspect-ratio: 750/1207;
  height: auto;
  width: 100%;
}

.p-top-mv-splide__inner {
  display: grid;
  height: 100%;
  place-items: center;
  position: relative;
}

.p-top-mv-splide__img {
  aspect-ratio: 491.34/590.15;
  margin-block-start: 0.5625rem;
  position: relative;
  width: 15.354375rem;
  z-index: 1;
}

.p-top-mv-splide .splide {
  inset: 0;
  position: absolute;
}

.p-top-mv-splide .splide__slide {
  display: block;
  width: 100%;
}

.p-top-mv-splide .splide__slide picture {
  height: inherit;
  height: 100%;
}

.p-top-mv-splide .splide__slide img {
  display: block;
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-top-mv-splide .splide__pagination {
  inset-block-end: 0.625rem;
}

.p-top-mv-splide .splide__pagination__page {
  aspect-ratio: 1;
  background: #fff;
  height: 100%;
  margin: 0.1875rem 0.34375rem;
  opacity: 1;
  width: 0.590625rem;
}
.p-top-mv-splide .splide__pagination__page.is-active {
  background: #310f2a;
  border: 0.0625rem solid #fff;
  transform: scale(1);
  width: 0.653125rem;
}

.p-top-mv-swiper__inner {
  margin: 5% 5% 0 5%;
}

.p-top-mv-swiper .swiper-slide {
  aspect-ratio: 600/300;
  display: block;
  width: 100%;
}

.p-top-mv-swiper .swiper-slide picture {
  height: inherit;
  height: 100%;
}

.p-top-mv-swiper .swiper-slide img {
  display: block;
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-top-mv-swiper .swiper-button-prev,
.p-top-mv-swiper .swiper-button-next {
  text-rendering: initial;
}

.p-top-plan {
  padding-block-start: 5.1875rem;
}

.p-top-plan__contents {
  background: #fff;
  border-radius: 0.7575rem;
  margin-block-start: 3.875rem;
  margin-inline: 0.4375rem;
  margin-inline: auto;
  max-width: 20.0625rem;
  padding: 1.875rem 1.625rem 2.75rem;
}

.p-top-plan__title {
  color: #310f2a;
  font-size: 1.71875rem;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
}
.p-top-plan__title.--mbs17 {
  margin-block-start: 1.0625rem;
}

.p-top-plan__list {
  margin-block-start: 0.8125rem;
}

.p-top-plan__content {
  border-radius: 0.625rem;
  overflow: hidden;
}
.p-top-plan__content:not(:first-child) {
  margin-block-start: 0.8125rem;
}

.p-top-plan__term {
  background: #3580c4;
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.5;
  padding: 0.5rem 0.625rem 0.5rem 1.25rem;
}
.p-top-plan__term span {
  display: inline-block;
  margin-inline-start: -0.375rem;
}

.p-top-plan__desc {
  background: #015683;
  font-size: 1.13625rem;
  font-weight: 500;
  line-height: 1.5;
  padding: 0.3125rem 1.25rem;
}

.p-top-plan__note {
  color: #000;
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 1.5;
  margin-block-start: 0.75rem;
  margin-inline-start: 0.25rem;
}

.p-top-plan__option-list {
  margin-block-start: 1.25rem;
}

.p-top-plan__option-content {
  align-items: center;
  background: #4cace2;
  border-radius: 0.625rem;
  display: flex;
  justify-content: space-between;
  overflow: hidden;
  padding: 0.375rem 1.25rem 0.3125rem;
}
.p-top-plan__option-content:not(:first-child) {
  margin-block-start: 0.9375rem;
}

.p-top-plan__option-term {
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 1.5;
}

.p-top-plan__option-desc {
  font-size: 1.13625rem;
  font-weight: 500;
  line-height: 1.5;
}

.p-top-post__inner {
  margin: 5% 5% 0 5%;
}

.p-top-post .splide__slide {
  display: block;
  width: 100%;
}

.p-top-post .splide__slide a {
  aspect-ratio: 600/400;
  display: block;
}

.p-top-post .splide__slide img {
  display: block;
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-top-post .splide__pagination {
  bottom: -2em;
}

.p-top-post .splide__pagination__page.is-active {
  background-color: blue;
}

.p-top-post .swiper {
  padding-bottom: 20px;
}

.p-top-post .swiper-slide {
  aspect-ratio: 600/300;
  display: block;
  width: 100%;
}

.p-top-post .swiper-slide img {
  display: block;
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-top-post .swiper-pagination {
  bottom: 0;
}

.p-top-post .swiper-button-prev,
.p-top-post .swiper-button-next {
  text-rendering: initial;
}

.p-top-post .slick-track {
  display: block;
  width: 100%;
}

.p-top-post .slick-slide {
  display: block;
  height: 100%;
  margin: 0 5px;
  width: 100%;
}

.p-top-post .slick-slide img {
  aspect-ratio: 600/300;
  display: block;
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-top-post .slick-next,
.p-top-post .slick-prev {
  background: gray;
}

.p-top-shop {
  margin-inline: auto;
  max-width: 23.4375rem;
  padding-block-start: 5.875rem;
}

.p-top-shop__store {
  border-block: 0.0625rem solid #fff;
  font-size: 1.3125rem;
  font-weight: 600;
  letter-spacing: 0.3em;
  line-height: 1.4;
  margin-block-start: 3.5625rem;
  margin-inline: 1.5625rem;
  padding: 0.4375rem 0rem 0.5625rem;
  text-align: center;
}

.p-top-shop__img {
  aspect-ratio: 630/335;
  margin-block-start: 1rem;
  margin-inline: auto;
  width: 19.6875rem;
}

.p-top-shop__text-lg {
  font-size: 1.19625rem;
  font-weight: 600;
  line-height: 1.55;
  margin-block-start: 1.1875rem;
  text-align: center;
}

.p-top-shop__text {
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.6;
  margin-block-start: 0.75rem;
  text-align: center;
}
.p-top-shop__text.--ls5 {
  letter-spacing: 0.05em;
}
.p-top-shop__text.--mbs-3 {
  margin-block-start: -0.1875rem;
}
.p-top-shop__text.--mbs8 {
  margin-block-start: 0.5rem;
}
.p-top-shop__text.--mbs10 {
  margin-block-start: 0.625rem;
}
.p-top-shop__text.--mbs18 {
  margin-block-start: 1.125rem;
}
.p-top-shop__text.--tas {
  text-align: start;
}
.p-top-shop__text.--mi10 {
  margin-inline: 0.625rem;
}

.p-top-shop__text-sm {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.6;
  translate: 0 -0.25rem;
}

.p-top-shop__term {
  border: 0.0625rem solid #fff;
  border-radius: 3.125rem;
  font-size: 0.875rem;
  font-weight: 400;
  letter-spacing: 0.1em;
  line-height: 1.4285714286;
  margin-block-start: 2.125rem;
  margin-inline: 0.625rem;
  padding: 0.25rem 0.75rem 0.1875rem;
  text-align: center;
}
.p-top-shop__term.--mbs27 {
  margin-block-start: 1.6875rem;
}

.p-top-shop__desc {
  text-align: center;
}

.p-top-shop__tel {
  font-size: 1.815625rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 0.6024096386;
  margin-block-start: 1.5rem;
}

.p-top-shop__note {
  font-size: 0.6125rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.6;
}

.p-top-shop__sub-list {
  margin-block-start: -0.25rem;
}

.p-top-shop__sub-content {
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.6;
}

.p-top-shop__sub-wrap {
  align-items: center;
  display: flex;
  justify-content: center;
}

.p-top-shop__sub-note {
  font-size: 0.75rem;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.6;
}

.p-top-shop__map {
  aspect-ratio: 630/374;
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.6;
  margin-block-start: 1.375rem;
  text-align: center;
  width: 19.6875rem;
}
.p-top-shop__map iframe {
  height: 100%;
  width: 100%;
}

.p-top-works {
  padding-bottom: 3.125rem;
}

.p-top-works__inner {
  margin: 5% 5% 0 5%;
}

.p-top-works .splide__slide {
  display: block;
  width: 100%;
}

.p-top-works .splide__slide a {
  aspect-ratio: 600/400;
  display: block;
}

.p-top-works .splide__slide img {
  display: block;
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-top-works .splide__pagination {
  bottom: -2em;
}

.p-top-works .splide__pagination__page.is-active {
  background-color: blue;
}

.p-top-works .swiper {
  padding-bottom: 20px;
}

.p-top-works .swiper-slide {
  aspect-ratio: 600/300;
  display: block;
  width: 100%;
}

.p-top-works .swiper-slide img {
  display: block;
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-top-works .swiper-pagination {
  bottom: 0;
}

.p-top-works .swiper-button-prev,
.p-top-works .swiper-button-next {
  text-rendering: initial;
}

.p-top-works .slick-track {
  display: block;
  width: 100%;
}

.p-top-works .slick-slide {
  display: block;
  height: 100%;
  margin: 0 5px;
  width: 100%;
}

.p-top-works .slick-slide img {
  aspect-ratio: 600/300;
  display: block;
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-top-works .slick-next,
.p-top-works .slick-prev {
  background: gray;
}

.pagination {
  width: 100%;
}
.nav-links ul {
  display: flex;
  justify-content: center;
}

.nav-links ul li a,
.nav-links ul li span {
  align-items: center;
  color: #0a1835;
  display: flex;
  flex-wrap: wrap;
  font-size: 1rem;
}

.nav-links ul li span.current {
  color: #000;
}

.nav-links ul li {
  margin: 0 0.3125rem;
  position: relative;
}

.nav-links ul li a,
.nav-links ul li span {
  display: block;
  padding: 0.3125rem;
  width: 100%;
}

.nav-links ul li .nav-links ul .dots {
  padding-left: 0;
  padding-right: 0;
}

@media (prefers-reduced-motion: reduce){
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
  }
}

@media (max-width: 375px){
  html {
    font-size: 4.2666666667vw;
  }
}

@media screen and (min-width: 768px){
  html {
    font-size: 1.1111111111vw;
  }
  .l-404 {
    min-height: 37.5rem;
  }
  .l-footer {
    margin-inline-start: 50%;
    position: relative;
    width: 27.291%;
    z-index: 1;
  }
  .l-inner {
    padding-inline: 1.5625rem;
  }
  .l-main {
    position: relative;
    z-index: 1;
  }
  .l-site {
    position: relative;
  }
  .l-site::before {
    background: url(../images/p-main_bg_001.jpg) no-repeat center center/cover;
    content: "";
    display: block;
    inset: 0;
    position: fixed;
  }
  .l-site::after {
    background: rgba(10, 24, 53, 0.9);
    content: "";
    inset: 0;
    position: fixed;
  }
  .c-title {
    color: red;
  }
  .p-cta {
    inset-inline-start: 50%;
    width: 27.291%;
  }
  .p-drawer__icon {
    inset-inline-end: 21.983125rem;
  }
  .p-drawer__icon.is-show {
    inset-inline-end: 21.983125rem;
  }
  .p-drawer__body {
    margin-inline: auto;
    max-width: 23.4375rem;
  }
  .p-header {
    margin-inline-start: 50%;
    width: 27.291%;
  }
  .p-header__logo {
    width: 9.75rem;
  }
  .p-pc-center {
    background: #0a1835;
    margin-inline-start: 50%;
    position: relative;
    width: 27.291%;
  }
  .p-pc-end {
    display: block;
    inset-block-start: 0;
    inset-inline-end: 0;
    position: fixed;
    width: 22.709%;
  }
  .p-pc-start {
    display: grid;
    inset-block-start: 0;
    inset-inline-start: 0;
    place-items: center;
    position: fixed;
    width: 50%;
  }
  .p-post-connect__items {
    row-gap: 2.5rem;
    -moz-column-gap: 1.25rem;
         column-gap: 1.25rem;
    grid-template-columns: repeat(4, 1fr);
  }
  .p-post-list {
    max-width: 24.56125rem;
  }
  .p-post-list__cards {
    margin-top: 6.25rem;
  }
  .p-post-list__btn {
    margin: 1.75rem auto 0;
    max-width: 64.375rem;
    padding: 0 0.625rem;
    width: 100%;
  }
  .p-top-mv-splide__img {
    width: 16.1875rem;
  }
  .p-top-mv {
    min-height: 100vh;
  }
  .nav-links ul li a,
  .nav-links ul li span {
    font-size: 1.5rem;
  }
  .nav-links ul li {
    margin: 0 0.625rem;
  }
  .nav-links ul li a,
  .nav-links ul li span {
    padding: 0.625rem;
  }
}

@media (any-hover: hover){
  a:hover {
    opacity: 0.7;
  }
  .c-btn:hover {
    background-color: #fff;
    color: #0a1835;
    cursor: pointer;
    opacity: 1;
    text-decoration: none;
  }
  .p-accordion__summary:hover {
    --_darken: 20%;
  }
  .p-drawer__list li a:hover {
    background-size: 100% 0.0625rem;
    color: #cf3e36;
    opacity: 1;
  }
  .p-drawer__btn:hover {
    background: #414141;
    color: #fff;
  }
  .p-pager-list__btn.--text-btn a:hover {
    background: #fff;
    color: #0a1835;
    opacity: 1;
  }
  .p-pc-end__list li a:hover {
    background-size: 100% 0.0625rem;
    color: #cf3e36;
    opacity: 1;
  }
  .p-pc-end__btn:hover {
    background: #fff;
    color: #0a1835;
  }
}

@media screen and (min-width: 992px){
  .c-title {
    color: blue;
  }
}

@media screen and (min-width: 1200px){
  .c-title {
    color: green;
  }
}

@media screen and (max-width: 767px){
  .p-contact__item-text:focus,
  .p-contact__item-tel:focus,
  .p-contact__item-email:focus,
  .p-contact__item-textarea:focus {
    font-size: 1rem;
  }
}
/*# sourceMappingURL=style.css.map */
