@charset "UTF-8";

/* # =================================================================
    # 共通要素
# ================================================================= */
html {
  font-size: 62.5%;
  font-family: "Zen Kaku Gothic New", sans-serif;
}
html.act {
  overflow: hidden;
}

body {
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
  color: #1C2936;
  font-weight: 400;
  letter-spacing: 0;
}

a, .link {
  color: #1C2936;
  text-decoration: none;
  transition: opacity 0.3s;
}
a.fig, .link.fig {
  display: inline-block;
  margin: 0;
  vertical-align: top;
}
a.fig picture, .link.fig picture {
  width: 100%;
  height: 100%;
  vertical-align: top;
}
a.fig img, .link.fig img {
  width: 100%;
  height: auto;
  vertical-align: top;
}

ul,
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  font-weight: inherit;
}

address {
  font-style: normal;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}
img.w100 {
  width: 100%;
}

/* *:focus {outline:none;} */
figure, .fig {
  margin: 0;
  vertical-align: top;
}
figure picture, .fig picture {
  width: 100%;
  height: 100%;
  vertical-align: top;
}
figure img, .fig img {
  width: 100%;
  height: auto;
  vertical-align: top;
}

@supports (-webkit-touch-callout: none) {
  body {
    /* The hack for Safari */
    height: -webkit-fill-available;
  }
}
.actinview .fadeIn00no {
  z-index: 1;
  opacity: 0;
  transition: opacity 1s;
}
.actinview .fadeIn00no.is-show {
  opacity: 1;
}
.actinview .fadeIn00kazari {
  z-index: 1;
  opacity: 0;
}
.actinview .fadeIn00kazari.is-show {
  animation: kazari 4s 0s ease-in-out;
}
@keyframes kazari {
  0% {
    opacity: 0;
  }
  30% {
    opacity: 1;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
.actinview .animadelay-1 {
  transition-delay: 0.1s !important;
}
.actinview .animadelay-2 {
  transition-delay: 0.2s !important;
}
.actinview .animadelay-3 {
  transition-delay: 0.3s !important;
}
.actinview .animadelay-4 {
  transition-delay: 0.4s !important;
}
.actinview .animadelay-5 {
  transition-delay: 0.5s !important;
}
.actinview .animadelay-6 {
  transition-delay: 0.6s !important;
}
.actinview .animadelay-7 {
  transition-delay: 0.7s !important;
}
.actinview .animadelay-8 {
  transition-delay: 0.8s !important;
}
.actinview .animadelay-9 {
  transition-delay: 0.9s !important;
}
.actinview .animadelay-10 {
  transition-delay: 1s !important;
}
.actinview .animadelay-11 {
  transition-delay: 1.1s !important;
}
.actinview .animadelay-12 {
  transition-delay: 1.2s !important;
}
.actinview .animadelay-13 {
  transition-delay: 1.3s !important;
}
.actinview .animadelay-14 {
  transition-delay: 1.4s !important;
}
.actinview .animadelay-15 {
  transition-delay: 1.5s !important;
}
.actinview .animadelay-16 {
  transition-delay: 1.6s !important;
}
.actinview .animadelay-17 {
  transition-delay: 1.7s !important;
}
.actinview .animadelay-18 {
  transition-delay: 1.8s !important;
}
.actinview .animadelay-19 {
  transition-delay: 1.9s !important;
}
.actinview .animadelay-20 {
  transition-delay: 2s !important;
}
.actinview .animadelay-21 {
  transition-delay: 2.1s !important;
}
.actinview .animadelay-22 {
  transition-delay: 2.2s !important;
}
.actinview .animadelay-23 {
  transition-delay: 2.3s !important;
}
.actinview .animadelay-24 {
  transition-delay: 2.4s !important;
}
.actinview .animadelay-25 {
  transition-delay: 2.5s !important;
}
.actinview .animadelay-26 {
  transition-delay: 2.6s !important;
}
.actinview .animadelay-27 {
  transition-delay: 2.7s !important;
}
.actinview .animadelay-28 {
  transition-delay: 2.8s !important;
}
.actinview .animadelay-29 {
  transition-delay: 2.9s !important;
}
.actinview .animadelay-30 {
  transition-delay: 3s !important;
}
.actinview .animadelay-31 {
  transition-delay: 3.1s !important;
}
.actinview .animadelay-32 {
  transition-delay: 3.2s !important;
}
.actinview .animadelay-33 {
  transition-delay: 3.3s !important;
}
.actinview .animadelay-34 {
  transition-delay: 3.4s !important;
}
.actinview .animadelay-35 {
  transition-delay: 3.5s !important;
}
.actinview .animadelay-36 {
  transition-delay: 3.6s !important;
}
.actinview .animadelay-37 {
  transition-delay: 3.7s !important;
}
.actinview .animadelay-38 {
  transition-delay: 3.8s !important;
}
.actinview .animadelay-39 {
  transition-delay: 3.9s !important;
}
.actinview .animadelay-40 {
  transition-delay: 4s !important;
}
.actinview .animadelay-41 {
  transition-delay: 4.1s !important;
}
.actinview .animadelay-42 {
  transition-delay: 4.2s !important;
}
.actinview .animadelay-43 {
  transition-delay: 4.3s !important;
}
.actinview .animadelay-44 {
  transition-delay: 4.4s !important;
}
.actinview .animadelay-45 {
  transition-delay: 4.5s !important;
}
.actinview .animadelay-46 {
  transition-delay: 4.6s !important;
}
.actinview .animadelay-47 {
  transition-delay: 4.7s !important;
}
.actinview .animadelay-48 {
  transition-delay: 4.8s !important;
}
.actinview .animadelay-49 {
  transition-delay: 4.9s !important;
}
.actinview .animadelay-50 {
  transition-delay: 5s !important;
}
.actinview .animadelay-51 {
  transition-delay: 5.1s !important;
}
.actinview .animadelay-52 {
  transition-delay: 5.2s !important;
}
.actinview .animadelay-53 {
  transition-delay: 5.3s !important;
}
.actinview .animadelay-54 {
  transition-delay: 5.4s !important;
}
.actinview .animadelay-55 {
  transition-delay: 5.5s !important;
}
.actinview .animadelay-56 {
  transition-delay: 5.6s !important;
}
.actinview .animadelay-57 {
  transition-delay: 5.7s !important;
}
.actinview .animadelay-58 {
  transition-delay: 5.8s !important;
}
.actinview .animadelay-59 {
  transition-delay: 5.9s !important;
}
.actinview .animadelay-60 {
  transition-delay: 6s !important;
}
.actinview .animadelay-61 {
  transition-delay: 6.1s !important;
}
.actinview .animadelay-62 {
  transition-delay: 6.2s !important;
}
.actinview .animadelay-63 {
  transition-delay: 6.3s !important;
}
.actinview .animadelay-64 {
  transition-delay: 6.4s !important;
}
.actinview .animadelay-65 {
  transition-delay: 6.5s !important;
}
.actinview .animadelay-66 {
  transition-delay: 6.6s !important;
}
.actinview .animadelay-67 {
  transition-delay: 6.7s !important;
}
.actinview .animadelay-68 {
  transition-delay: 6.8s !important;
}
.actinview .animadelay-69 {
  transition-delay: 6.9s !important;
}
.actinview .animadelay-70 {
  transition-delay: 7s !important;
}
.actinview .animadelay-71 {
  transition-delay: 7.1s !important;
}
.actinview .animadelay-72 {
  transition-delay: 7.2s !important;
}
.actinview .animadelay-73 {
  transition-delay: 7.3s !important;
}
.actinview .animadelay-74 {
  transition-delay: 7.4s !important;
}
.actinview .animadelay-75 {
  transition-delay: 7.5s !important;
}
.actinview .animadelay-76 {
  transition-delay: 7.6s !important;
}
.actinview .animadelay-77 {
  transition-delay: 7.7s !important;
}
.actinview .animadelay-78 {
  transition-delay: 7.8s !important;
}
.actinview .animadelay-79 {
  transition-delay: 7.9s !important;
}
.actinview .animadelay-80 {
  transition-delay: 8s !important;
}
.actinview .animadelay-81 {
  transition-delay: 8.1s !important;
}
.actinview .animadelay-82 {
  transition-delay: 8.2s !important;
}
.actinview .animadelay-83 {
  transition-delay: 8.3s !important;
}
.actinview .animadelay-84 {
  transition-delay: 8.4s !important;
}
.actinview .animadelay-85 {
  transition-delay: 8.5s !important;
}
.actinview .animadelay-86 {
  transition-delay: 8.6s !important;
}
.actinview .animadelay-87 {
  transition-delay: 8.7s !important;
}
.actinview .animadelay-88 {
  transition-delay: 8.8s !important;
}
.actinview .animadelay-89 {
  transition-delay: 8.9s !important;
}
.actinview .animadelay-90 {
  transition-delay: 9s !important;
}
.actinview .animadelay-91 {
  transition-delay: 9.1s !important;
}
.actinview .animadelay-92 {
  transition-delay: 9.2s !important;
}
.actinview .animadelay-93 {
  transition-delay: 9.3s !important;
}
.actinview .animadelay-94 {
  transition-delay: 9.4s !important;
}
.actinview .animadelay-95 {
  transition-delay: 9.5s !important;
}
.actinview .animadelay-96 {
  transition-delay: 9.6s !important;
}
.actinview .animadelay-97 {
  transition-delay: 9.7s !important;
}
.actinview .animadelay-98 {
  transition-delay: 9.8s !important;
}
.actinview .animadelay-99 {
  transition-delay: 9.9s !important;
}
.actinview .animadelay-100 {
  transition-delay: 10s !important;
}
.actinview .fadeIn00 {
  z-index: 1;
  transform: translate3d(0, 10%, 0);
  opacity: 0;
  transition: opacity 1s, transform 1s;
}
.actinview .fadeIn00.is-show {
  transform: translate3d(0, 0%, 0);
  opacity: 1;
}
#wrapper {
  position: relative;
  width: 100%;
  margin: 0 auto;
  padding: 0;
  overflow: hidden;
  overflow: clip;
}
#wrapper > *:not(.l-opening) {
  visibility: hidden;
  opacity: 0;
}

/* フォント */
.f_en {
  font-weight: 500;
  font-family: "Playfair Display", serif;
}

.f_jp {
  font-weight: 400;
  font-family: "Shippori Mincho", serif;
}

/* マージン */
.relative {
  z-index: 1;
  position: relative;
}

/* foundation */
html {
  /* All browsers without overlaying scrollbars */
  -webkit-text-size-adjust: 100%;
  box-sizing: border-box;
  overflow-y: scroll;
  /* iOS 8+ */
}

*,
::before,
::after {
  /* Set `background-repeat: no-repeat` to all elements and pseudo elements */
  box-sizing: inherit;
  background-repeat: no-repeat;
}

::before,
::after {
  text-decoration: inherit;
  /* Inherit text-decoration and vertical align to ::before and ::after pseudo elements */
  vertical-align: inherit;
}

* {
  /* Reset `padding` and `margin` of all elements */
  margin: 0;
  padding: 0;
}

/* # =================================================================
   # 一般的な要素
   # ================================================================= */
/* Add the correct display in iOS 4-7.*/
audio:not([controls]) {
  display: none;
  height: 0;
}

ol,
ul,
li {
  list-style: none;
}

hr {
  overflow: visible;
  /* Show the overflow in Edge and IE */
}

/*
* Correct `block` display not defined for any HTML5 element in IE 8/9
* Correct `block` display not defined for `details` or `summary` in IE 10/11
* and Firefox
* Correct `block` display not defined for `main` in IE 11
*/
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
  display: block;
}

summary {
  display: list-item;
  /* Add the correct display in all browsers */
}

small {
  font-size: 80%;
  /* Set font-size to 80% in `small` elements */
}

[hidden],
template {
  display: none;
  /* Add the correct display in IE */
}

abbr[title] {
  border-bottom: 1px dotted;
  /* Add a bordered underline effect in all browsers */
  text-decoration: none;
  /* Remove text decoration in Firefox 40+ */
}

a {
  /* Remove the gray background on active links in IE 10 */
  -webkit-text-decoration-skip: objects;
  background-color: transparent;
  /* Remove gaps in links underline in iOS 8+ and Safari 8+ */
}

a:active,
a:hover {
  outline-width: 0;
  /* Remove the outline when hovering in all browsers */
}

table {
  border-collapse: collapse;
  border-spacing: 0px;
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  /* Specify the font family of code elements */
}

b,
strong {
  font-weight: bolder;
  /* Correct style set to `bold` in Edge 12+, Safari 6.2+, and Chrome 18+ */
}

dfn {
  font-style: italic;
  /* Address styling not present in Safari and Chrome */
}

/* Address styling not present in IE 8/9 */
mark {
  background-color: #ff0;
  color: #000;
}

/* https://gist.github.com/unruthless/413930 */
sub,
sup {
  position: relative;
  font-size: 75%;
  line-height: 0;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* # =================================================================
   # フォーム要素
   # ================================================================= */
input {
  border-radius: 0;
}

/* Apply cursor pointer to button elements */
button,
[type=button],
[type=reset],
[type=submit],
[role=button] {
  cursor: pointer;
}

/* Replace pointer cursor in disabled elements */
[disabled] {
  cursor: default;
}

[type=number] {
  width: auto;
  /* Firefox 36+ */
}

[type=search] {
  -webkit-appearance: textfield;
  /* Safari 8+ */
}

[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
  /* Safari 8 */
}

textarea {
  overflow: auto;
  /* Internet Explorer 11+ */
  resize: vertical;
  /* Specify textarea resizability */
}

button,
input,
optgroup,
select,
textarea {
  font: inherit;
  /* Specify font inheritance of form elements */
}

optgroup {
  font-weight: bold;
  /* Restore the font weight unset by the previous rule. */
}

button {
  overflow: visible;
  /* Address `overflow` set to `hidden` in IE 8/9/10/11 */
}

/* Remove inner padding and border in Firefox 4+ */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  padding: 0;
  border-style: none;
}

/* Replace focus style removed in the border reset above */
button:-moz-focusring,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  outline: 1px dotted ButtonText;
}

button,
html [type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
  /* Correct the inability to style clickable types in iOS */
}

button,
select {
  text-transform: none;
  /* Firefox 40+, Internet Explorer 11- */
}

/* Remove the default button styling in all browsers */
button,
input,
select,
textarea {
  border-style: none;
  background-color: transparent;
  color: inherit;
}

/* Style select like a standard input */
select {
  -moz-appearance: none;
  /* Firefox 36+ */
  -webkit-appearance: none;
  /* Chrome 41+ */
}

select::-ms-expand {
  display: none;
  /* Internet Explorer 11+ */
}

select::-ms-value {
  color: currentColor;
  /* Internet Explorer 11+ */
}

legend {
  /* Correct the color inheritance from `fieldset` elements in IE */
  display: table;
  /* Correct the text wrapping in Edge and IE */
  max-width: 100%;
  border: 0;
  /* Correct `color` not being inherited in IE 8/9/10/11 */
  color: inherit;
  /* Correct the text wrapping in Edge and IE */
  white-space: normal;
  /* Correct the text wrapping in Edge and IE */
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* Correct the inability to style clickable types in iOS and Safari */
  font: inherit;
  /* Change font properties to `inherit` in Chrome and Safari */
}

[type=search] {
  -webkit-appearance: textfield;
  /* Correct the odd appearance in Chrome and Safari */
  outline-offset: -2px;
  /* Correct the outline style in Safari */
}

/* # =================================================================
   # メディア要素
   # ================================================================= */
img {
  border-style: none;
  /* Remove border when inside `a` element in IE 8/9/10 */
}

/* Add the correct vertical alignment in Chrome, Firefox, and Opera */
progress {
  vertical-align: baseline;
}

svg:not(:root) {
  overflow: hidden;
  /* Internet Explorer 11- */
}

audio,
canvas,
progress,
video {
  display: inline-block;
  /* Internet Explorer 11+, Windows Phone 8.1+ */
}

/* # =================================================================
   # アクセシビリティ
   # ================================================================= */
/* Hide content from screens but not screenreaders */
/* Specify the progress cursor of updating elements */
[aria-busy=true] {
  cursor: progress;
}

/* Specify the pointer cursor of trigger elements */
[aria-controls] {
  cursor: pointer;
}

/* Specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
[aria-disabled] {
  cursor: default;
}

/* # =================================================================
   # セレクション
   # ================================================================= */
/* Specify text selection background color and omit drop shadow */
::-moz-selection {
  background-color: #b3d4fc;
  /* Required when declaring ::selection */
  color: #000;
  text-shadow: none;
}

::selection {
  background-color: #b3d4fc;
  /* Required when declaring ::selection */
  color: #000;
  text-shadow: none;
}

/* layout */
.l-header__logo {
  z-index: 100;
  position: fixed;
  top: clamp(0px, 1.17vw, 18px) !important;
  left: clamp(0px, 2.99vw, 46px) !important;
  width: clamp(0px, 7.81vw, 120px);
}
.l-header__logo img, .l-header__logo svg {
  filter: invert(94%) sepia(23%) saturate(403%) hue-rotate(170deg) brightness(90%) contrast(99%);
}
.l-header__logo svg {
  fill: #D9E3E9;
  width: 100%;
}
.l-header__logo.act {
  position: fixed;
}
.l-header__logo.act img, .l-header__logo.act svg {
  filter: invert(29%) sepia(14%) saturate(1221%) hue-rotate(168deg) brightness(93%) contrast(94%);
}
.l-header__hedMenu {
  z-index: 2;
  position: absolute;
  top: clamp(0px, 1.3vw, 20px);
  right: clamp(0px, 6.51vw, 100px);
}
.l-header__hedMenu-list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 0 clamp(0px, 1.63vw, 25px);
}
.l-header__hedMenu-link {
  color: #D9E3E9;
  font-weight: 500;
  font-size: 14px;
  font-family: "Playfair Display", serif;
  text-transform: uppercase;
  transition: opacity 0.3s ease-in-out;
}
.l-header__hedMenu-link:hover {
  opacity: 0.5;
}
.l-header__glNavBtnWp {
  z-index: 200;
  position: fixed;
  top: clamp(0px, 1.3vw, 20px) !important;
  right: clamp(0px, 1.56vw, 24px) !important;
  left: auto !important;
  width: 6em;
  height: 2.5em !important;
  margin: auto;
  transition: opacity 0.3s ease-in-out;
}
.l-header__glNavBtnWp:hover {
  opacity: 0.5;
}
.l-header__glNavBtnWp.act {
  width: clamp(0px, 1.5vw, 23px);
}
.l-header__glNavBtnWp .glNavBtn--pc {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 0 clamp(0px, 0.39vw, 6px);
}
.l-header__glNavBtnWp .glNavBtn--pc i {
  width: clamp(0px, 0.26vw, 4px);
  height: clamp(0px, 0.26vw, 4px);
  border-radius: 100%;
  background-color: #D9E3E9;
}
.l-header__glNavBtnWp .glNavBtn--pc span {
  color: #D9E3E9;
  font-weight: 500;
  font-size: 14px;
  font-family: "Playfair Display", serif;
  text-transform: uppercase;
}
.l-header__glNavBtnWp .glNavBtn--pc.act {
  display: none;
}
.l-header__glNavBtnWp .glNavBtn--sp {
  display: none;
}
.l-header__glNavBtnWp .glNavBtnClose {
  display: none;
  position: relative;
  width: clamp(0px, 1.5vw, 23px);
  height: clamp(0px, 1.5vw, 23px);
  overflow: hidden;
}
.l-header__glNavBtnWp .glNavBtnClose::before, .l-header__glNavBtnWp .glNavBtnClose::after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  margin: auto;
  transform: rotate(45deg);
  background-color: #D9E3E9;
  content: "";
}
.l-header__glNavBtnWp .glNavBtnClose::after {
  transform: rotate(-45deg);
}
.l-header__glNavBtnWp .glNavBtnClose.act {
  display: block;
}
.l-header__glNavMenu {
  display: flex;
  z-index: -1;
  position: fixed !important;
  top: 0%;
  left: 0%;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: space-between;
  width: 0;
  height: 0;
  overflow-y: scroll;
  opacity: 0;
  transition: opacity 0.8s ease-in-out 0.5s;
}
.l-header__glNavMenu.act {
  z-index: 100;
  position: relative;
  width: 100vw;
  height: 100dvh !important;
  padding: 0 clamp(0px, 6.51vw, 100px);
  overflow: hidden;
  background-image: url("../img/common/megaMenuBg.png");
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  opacity: 1;
  transition: opacity 0.8s ease-in-out 0.5s;
}
.l-header__glNavMenu.act::before {
  z-index: -1;
  position: absolute;
  top: 0;
  top: clamp(0px, 6.51vw, 100px);
  right: 0;
  bottom: 0;
  bottom: auto;
  left: 0;
  width: clamp(0px, 58.59vw, 900px);
  height: clamp(0px, 81.38vw, 1250px);
  margin: auto;
  background-image: url("../img/common/megaMenuBgimg.png");
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  content: "";
  mix-blend-mode: overlay;
}
.l-header__pcMenu01 {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: space-between;
  width: 50%;
  height: auto;
  padding: clamp(0px, 8.46vw, 130px) 0 clamp(0px, 3.26vw, 50px);
}
.l-header__pcMenu01-logo {
  width: clamp(0px, 18.62vw, 286px);
}
.l-header__pcMenu01-snslist {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  margin-bottom: clamp(0px, 1.24vw, 19px);
  gap: 0 clamp(0px, 2.15vw, 33px);
}
.l-header__pcMenu01-snslist-item {
  width: clamp(0px, 1.95vw, 30px);
}
.l-header__pcMenu01-snslist-item a {
  transition: opacity 0.3s ease-in-out;
}
.l-header__pcMenu01-snslist-item a:hover {
  opacity: 0.8;
}
.l-header__pcMenu01-corpsite {
  font-weight: 400;
  font-size: 16px;
  font-family: "Shippori Mincho", serif;
}
.l-header__pcMenu01-corpsite a {
  color: #D9E3E9;
  transition: color 0.3s ease-in-out;
}
.l-header__pcMenu01-corpsite a:hover {
  color: rgba(217, 227, 233, 0.8);
}
.l-header__pcMenu02 {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  width: 50%;
  height: auto;
}
.l-header__pcMenu02-menubox {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 clamp(0px, 10.74vw, 165px);
}
.l-header__pcMenu02-menulist {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: flex-start;
  gap: clamp(0px, 2.99vw, 46px) 0;
}
.l-header__pcMenu02-menulist-item {
  font-weight: 500;
  font-weight: 500;
  font-size: 20px;
  font-family: "Playfair Display", serif;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.l-header__pcMenu02-menulist-item a {
  color: #fff;
  transition: color 0.3s ease-in-out;
}
.l-header__pcMenu02-menulist-item a:hover {
  color: rgba(255, 255, 255, 0.8);
}

.bgwhite .glNavBtn span {
  color: #364E65;
}
.bgwhite .glNavBtn i {
  background-color: #364E65;
}
.bgwhite img {
  filter: invert(29%) sepia(14%) saturate(1221%) hue-rotate(168deg) brightness(93%) contrast(94%);
}
.bgwhite svg {
  fill: #364E65;
}

.l-footer {
  z-index: 1;
  position: relative;
  width: 100%;
  padding: clamp(0px, 13.67vw, 210px) clamp(0px, 7.81vw, 120px) clamp(0px, 3.91vw, 60px);
  background: linear-gradient(180deg, #5c819d 0%, #1c2936 100%);
  color: #D9E3E9;
  animation: footerGradietionAnimation 3s ease infinite;
}
@keyframes footerGradietionAnimation {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}
.l-footer__cont01 {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: clamp(0px, 10.74vw, 165px);
}
.l-footer__logo {
  width: clamp(0px, 18.62vw, 286px);
}
.l-footer__menubox {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0 clamp(0px, 5.73vw, 88px);
}
.l-footer__menulist {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: flex-start;
  gap: clamp(0px, 1.95vw, 30px) 0;
}
.l-footer__menulist-item {
  font-weight: 500;
  font-weight: 500;
  font-size: 18px;
  font-family: "Playfair Display", serif;
  text-transform: uppercase;
}
.l-footer__menulist-item a {
  color: #D9E3E9;
  transition: color 0.3s ease-in-out;
}
.l-footer__menulist-item a:hover {
  color: rgba(217, 227, 233, 0.8);
}
.l-footer__cont02 {
  width: -moz-fit-content;
  width: fit-content;
  margin: auto;
}
.l-footer__snslist {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  margin-bottom: clamp(0px, 1.24vw, 19px);
  gap: 0 clamp(0px, 2.15vw, 33px);
}
.l-footer__snslist-item {
  width: clamp(0px, 1.95vw, 30px);
}
.l-footer__snslist-item a {
  transition: opacity 0.3s ease-in-out;
}
.l-footer__snslist-item a:hover {
  opacity: 0.8;
}
.l-footer__corpsite {
  font-weight: 400;
  font-size: 16px;
  font-family: "Shippori Mincho", serif;
  text-align: center;
}
.l-footer__corpsite a {
  color: #D9E3E9;
  transition: color 0.3s ease-in-out;
}
.l-footer__corpsite a:hover {
  color: rgba(217, 227, 233, 0.8);
}
.l-footer__cont03 {
  width: -moz-fit-content;
  width: fit-content;
  margin-top: -14em;
  margin-left: auto;
}
.l-footer__pagetop {
  width: clamp(0px, 5.21vw, 80px);
  margin-bottom: clamp(0px, 3.06vw, 47px);
  margin-left: auto;
  text-align: center;
}
.l-footer__pagetop a {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  height: 100%;
  gap: clamp(0px, 0.33vw, 5px) 0;
  transition: opacity 0.3s ease-in-out;
}
.l-footer__pagetop a:hover {
  opacity: 0.8;
}
.l-footer__pagetop a img {
  width: clamp(0px, 3.65vw, 56px);
  height: clamp(0px, 3.65vw, 56px);
}
.l-footer__pagetop a span {
  color: #D9E3E9;
  font-weight: 500;
  font-size: 12px;
}
.l-footer__copy {
  font-size: 12px;
  text-align: right;
}

/*component*/
.c-inner01 {
  width: 90%;
  max-width: 1060px;
  margin: 0 auto;
}

.c-btn01 {
  width: -moz-fit-content;
  width: fit-content;
  margin: auto;
}
.c-btn01--left {
  margin-left: 0;
}
.c-btn01--right {
  margin-right: 0;
}
.c-btn01__link {
  display: flex;
  position: relative;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  padding: clamp(0px, 0.65vw, 10px) clamp(0px, 2.6vw, 40px);
  gap: 0 clamp(0px, 0.65vw, 10px);
  border-radius: clamp(0px, 0.2vw, 3px);
  font-size: 14px;
  transition: filter 0.3s ease-in-out;
}
.c-btn01__link--white {
  color: #fff;
}
.c-btn01__link--bright {
  border: 1px solid #D9E3E9;
  color: #D9E3E9;
}
.c-btn01__link--blue {
  border: 1px solid #1C2936;
  color: #1C2936;
}
.c-btn01__link--lineupcontact {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  padding: clamp(0px, 1.43vw, 22px) clamp(0px, 0.65vw, 10px);
  gap: clamp(0px, 0.72vw, 11px) 0;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 0.1em;
}
.c-btn01__link--lineupcontact .c-btn01__txt {
  position: relative;
  font-size: 18px;
  letter-spacing: 0;
}
.c-btn01__link--lineupcontact .c-arwicon {
  position: absolute;
  top: 0;
  right: -2.5em;
  bottom: 0;
  margin: auto;
}
.c-btn01__link:hover {
  filter: brightness(1.2);
}

.cmnTtl02 {
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  font-weight: 500;
  font-size: 48px;
  text-align: center;
}
.cmnTtl02--white {
  color: #fff;
}
.cmnTtl02--bright {
  color: #D9E3E9;
}
.cmnTtl02--black {
  color: #1C2936;
}
.cmnTtl02--navy {
  color: #364E65;
}
.cmnTtl02 span {
  display: block;
}
.cmnTtl02 .f_en {
  font-weight: 500;
  font-size: 36px;
  line-height: 1;
  letter-spacing: 0.03em;
}
.cmnTtl02 .f_en em {
  font-style: normal;
  font-weight: 400;
  font-size: 34px;
  font-family: "Noto Serif JP", serif;
}
.cmnTtl02 .f_en--fs50 {
  font-size: 50px;
  letter-spacing: 0.02em;
}
.cmnTtl02 .f_jp {
  margin-top: clamp(0px, 0.46vw, 7px);
  font-size: 16px;
  line-height: 1.88;
}

.c-arwicon::before {
  -webkit-mask-image: url(../img/common/icoArw04.png);
  -webkit-mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  background-color: #1C2936;
  mask-image: url(../img/common/icoArw04.png);
  mask-position: center;
  mask-repeat: no-repeat;
  mask-size: contain;
}

.c-arwicon {
  display: block;
  position: relative;
  width: clamp(0px, 0.98vw, 15px);
  height: clamp(0px, 0.98vw, 15px);
}
.c-arwicon::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: clamp(0px, 0.78vw, 12px);
  height: clamp(0px, 0.72vw, 11px);
  margin: auto;
  transform: translate3d(0, 0, 0);
  background-color: #fff;
  content: "";
  transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;
}
.c-arwicon--bright::before {
  background-color: #D9E3E9;
}
.c-arwicon--blue::before {
  background-color: #1C2936;
}

.c-hvr:hover .c-arwicon::before {
  transform: translate3d(0.5em, 0, 0);
}

.l-opening {
  display: block;
  z-index: 201;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  height: 100dvh;
  background-image: url("../img/top/opBg.png");
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  background-color: #fff;
}
.l-opening::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
  content: "";
  animation: openingBgFadeIn 1.5s ease forwards;
}
@keyframes openingBgFadeIn {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
.l-opening__skip {
  z-index: 202;
  position: absolute;
  right: clamp(0px, 6.51vw, 100px);
  bottom: clamp(0px, 6.51vw, 100px);
  width: clamp(0px, 8.27vw, 127px);
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.3s;
}
.l-opening__skip:hover {
  opacity: 0.9;
}
.l-opening__img {
  display: none;
  position: absolute;
  top: 0;
  top: 30em;
  right: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
  transform: scale(1.8);
}
.l-opening__img img {
  -o-object-fit: cover;
  width: 100%;
  max-width: none;
  height: 100dvh;
  object-fit: cover;
}

/*project*/
/*utility*/
.sp {
  display: none !important;
}

.pc {
  display: block !important;
}
/*page*/
.p-index-fvwp {
  background-image: url("../img/top/fvwp_bg.png");
  background-position: center center;
  background-position: center top;
  background-size: cover;
  background-repeat: no-repeat;
}

.p-index-fv {
  position: absolute;
  position: relative;
  top: 0;
  width: 100%;
  height: 100dvh;
}
.p-index-fv__imgbox {
  z-index: 1;
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  width: auto;
  height: auto;
  margin: auto;
}
.p-index-fv__imgbox figure img {
  -o-object-fit: cover;
  width: 100%;
  max-width: none;
  height: 100dvh;
  object-fit: cover;
}
.p-index-fv__catch {
  z-index: 2;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: -moz-fit-content;
  width: fit-content;
  height: -moz-fit-content;
  height: fit-content;
  margin: auto;
  transform: translateX(clamp(0px, 19.53vw, 300px)) translateY(-140%);
  color: #D9E3E9;
  font-size: 30px;
  line-height: 1.67;
  opacity: 1;
}
.p-index-fv__ttlname {
  z-index: 2;
  position: absolute;
  right: 0;
  bottom: clamp(0px, 3.26vw, 50px);
  left: 0;
  width: clamp(0px, 30.34vw, 466px);
  margin: auto;
  opacity: 1;
}

.p-index-concept {
  z-index: 1;
  position: relative;
  padding: clamp(0px, 19.53vw, 300px) 0 clamp(0px, 39.06vw, 600px);
  color: #D9E3E9;
}
.p-index-concept__txtbox {
  width: 50%;
  margin-left: auto;
  padding-left: clamp(0px, 6.51vw, 100px);
}
.p-index-concept__ttl {
  margin-bottom: clamp(0px, 1.76vw, 27px);
}
.p-index-concept__ttl .f_en {
  display: block;
  margin-bottom: clamp(0px, 0.91vw, 14px);
  font-size: 16px;
  letter-spacing: 0.03em;
}
.p-index-concept__ttl .f_jp {
  display: block;
  font-size: 60px;
}
.p-index-concept__desc {
  margin-bottom: clamp(0px, 3.06vw, 47px);
  font-size: 26px;
  line-height: 1.77;
}

.index #contents {
  z-index: 1;
  position: relative;
  background-color: #fff;
}

.p-index-navygradarea {
  position: relative;
  background-color: #364E65;
  color: #D9E3E9;
}
.p-index-navygradarea__bg {
  z-index: 0;
  position: sticky;
  top: 0;
  width: 100%;
  height: 100vh;
  mix-blend-mode: overlay;
  pointer-events: none;
}
.p-index-navygradarea__bg img {
  -o-object-fit: cover;
  -o-object-position: center;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.p-index-navygradarea__cont {
  position: absolute;
  top: 0;
  width: 100%;
}
.p-index-navygradarea__kirakira {
  position: absolute;
  width: 48em;
  mix-blend-mode: color-dodge;
}
.p-index-navygradarea__kirakira.img01 {
  top: 200em;
  right: -5em;
}
.p-index-navygradarea__kirakira.img02 {
  top: 282em;
  left: -5em;
}
.p-index-navygradarea__kirakira.img03 {
  top: 314em;
  right: -5em;
}
.p-index-navygradarea__kirakira.img04 {
  top: 430em;
  left: -5em;
}
.p-index-navygradarea__kirakira.img05 {
  top: 544em;
  right: -5em;
}

.p-index-concept02 {
  z-index: 1;
  top: 0;
  width: 100%;
  padding: clamp(0px, 13.02vw, 200px) 0 clamp(0px, 13.02vw, 200px);
  background-image: url("../img/top/concept02_bg.png");
  background-position: center center;
  background-position: center bottom;
  background-size: cover;
  background-repeat: no-repeat;
  color: #D9E3E9;
}
.p-index-concept02__txtbox {
  width: 43.0188679245%;
}
.p-index-concept02__ttl {
  margin-bottom: clamp(0px, 2.6vw, 40px);
  font-size: 40px;
  line-height: 1.63;
  letter-spacing: 0.1em;
}
.p-index-concept02__desc {
  font-size: 16px;
  line-height: 2.25;
  letter-spacing: 0.1em;
}
.p-index-concept02__note {
  margin-top: clamp(0px, 0.85vw, 13px);
  font-size: 13px;
  letter-spacing: 0.1em;
}

.p-index-feature {
  position: relative;
  padding: clamp(0px, 13.02vw, 200px) 0 clamp(0px, 13.67vw, 210px);
  border-bottom: 1px solid #D9E3E9;
}
.p-index-feature__ttl {
  margin-bottom: clamp(0px, 3.91vw, 60px);
}
.p-index-feature__catch {
  margin-bottom: clamp(0px, 6.51vw, 100px);
  font-weight: 500;
  text-align: center;
}
.p-index-feature__catch-txt01 {
  margin-bottom: clamp(0px, 1.5vw, 23px);
  font-size: 32px;
}
.p-index-feature__catch-txt02 {
  font-size: 20px;
}
.p-index-feature .ft_contwp {
  position: relative;
}
.p-index-feature .ft_contwp--03 {
  margin-bottom: clamp(0px, 11.07vw, 170px);
}
.p-index-feature .ft_cont {
  position: relative;
  margin-bottom: clamp(0px, 13.02vw, 200px);
}
.p-index-feature .ft_cont--flex {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  flex-wrap: nowrap;
  align-items: flex-start;
  justify-content: center;
  margin-right: calc((100vw - 100%) / 2 * -1);
}
.p-index-feature .ft_cont--flex.nomargin {
  margin: 0;
}
.p-index-feature .ft_cont--flexrev {
  display: flex;
  flex-direction: row-reverse;
  flex-wrap: wrap;
  flex-wrap: nowrap;
  align-items: flex-start;
  justify-content: center;
  margin-left: calc((100vw - 100%) / 2 * -1);
}
.p-index-feature .ft_cont--01 {
  padding: 0 4.7169811321%;
}
.p-index-feature .ft_cont--02 {
  margin-bottom: clamp(0px, 26.04vw, 400px);
}
.p-index-feature .ft_cont--03a {
  margin-bottom: clamp(0px, 3.26vw, 50px);
}
.p-index-feature .ft_cont--03b {
  align-items: center;
  margin: 0;
}
.p-index-feature .ft_cont--04 {
  margin-bottom: 0;
}
.p-index-feature .ft_cont__txtbox {
  width: clamp(0px, 32.55vw, 500px);
}
.p-index-feature .ft_cont__txtbox--03a {
  width: clamp(0px, 35.81vw, 550px);
}
.p-index-feature .ft_cont__ttl {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: flex-start;
  margin-bottom: clamp(0px, 2.54vw, 39px);
  gap: 0 clamp(0px, 1.95vw, 30px);
}
.p-index-feature .ft_cont__ttl-num {
  margin-bottom: clamp(0px, 0.65vw, 10px);
}
.p-index-feature .ft_cont__ttl-num--01 {
  width: clamp(0px, 9.24vw, 142px);
}
.p-index-feature .ft_cont__ttl-num--02 {
  width: clamp(0px, 10.61vw, 163px);
}
.p-index-feature .ft_cont__ttl-num--03 {
  width: clamp(0px, 11.26vw, 173px);
  margin-bottom: clamp(0px, 1.82vw, 28px);
}
.p-index-feature .ft_cont__ttl-num--04 {
  width: clamp(0px, 11.26vw, 173px);
  margin-bottom: clamp(0px, 1.95vw, 30px);
}
.p-index-feature .ft_cont__ttl-txt {
  font-weight: 400;
  font-size: 30px;
  line-height: 1.53;
  font-family: "Shippori Mincho", serif;
  letter-spacing: 0.02em;
}
.p-index-feature .ft_cont__desc {
  font-size: 15px;
  line-height: 2.4;
  letter-spacing: 0.1em;
}
.p-index-feature .ft_cont__desc--02sub {
  margin-top: clamp(0px, 1.95vw, 30px);
  font-size: 13px;
  line-height: 1.54;
}
.p-index-feature .ft_cont__desc--03sub {
  margin-top: clamp(0px, 2.8vw, 43px);
  font-size: 14px;
  line-height: 1.57;
  letter-spacing: 0.05em;
}
.p-index-feature .ft_cont__f01list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-start;
  margin-top: clamp(0px, 4.56vw, 70px);
  gap: 0 clamp(0px, 0.91vw, 14px);
}
.p-index-feature .ft_cont__f01list-item {
  width: calc(33% - clamp(0px, 0.91vw, 14px) / 2);
}
.p-index-feature .ft_cont__f01list figcaption {
  padding: clamp(0px, 0.65vw, 10px) 0;
  background-color: #D9E3E9;
  color: #52738D;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0.03em;
  text-align: center;
}
.p-index-feature .ft_cont__02expimg {
  width: clamp(0px, 21.22vw, 326px);
  margin-top: clamp(0px, 3.91vw, 60px);
}
.p-index-feature .ft_cont__imgbox--02 {
  position: relative;
  width: 61.320754717%;
  margin-right: clamp(0px, 6.05vw, 93px);
}
.p-index-feature .ft_cont__imgbox--03a {
  width: 64.9056603774%;
  margin-left: clamp(0px, 9.77vw, 150px);
}
.p-index-feature .ft_cont__imgbox--03b {
  width: 47.1698113208%;
  margin-right: clamp(0px, 5.86vw, 90px);
}
.p-index-feature .ft_cont__imgbox--04 {
  width: 64.9056603774%;
  margin-right: clamp(0px, 5.86vw, 90px);
}
.p-index-feature .ft_cont__02img01 {
  width: 93.0769230769%;
}
.p-index-feature .ft_cont__02img02 {
  position: absolute;
  right: 0;
  bottom: -25em;
  width: 46.1538461538%;
}
.p-index-feature .ft_cont__03img01 {
  width: 100%;
}
.p-index-feature .ft_cont__03img02 {
  width: clamp(0px, 22.79vw, 350px);
  margin-left: auto;
}
.p-index-feature .ft_cont__04img01 {
  width: 100%;
}
.p-index-feature .ft_cont__bgimg {
  z-index: -1 !important;
  position: absolute;
  aspect-ratio: 902/602;
  width: clamp(0px, 58.59vw, 900px);
  height: auto;
  animation: fadeIn00kazari 0.5s 1s ease-in-out forwards;
  mix-blend-mode: color-dodge;
  filter: blur(10px);
}
@keyframes fadeIn00kazari {
  0% {
    filter: blur(10px);
  }
  100% {
    filter: blur(0);
  }
}
.p-index-feature .ft_cont__bgimg img {
  -o-object-fit: cover;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.p-index-feature .ft_cont__bgimg.img01 {
  right: -40em;
  bottom: -12em;
}
.p-index-feature .ft_cont__bgimg.img02 {
  bottom: -27em;
  left: -15em;
}
.p-index-feature .ft_cont__bgimg.img03 {
  right: 5em;
  bottom: -13em;
}
.p-index-feature .ft_cont__bgimg.img04 {
  top: -39em;
  left: -52em;
}
.p-index-feature .ft_cont__bgimg.img05 {
  right: 11em;
  bottom: -5em;
}
.p-index-feature .ft_light {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: center;
  margin-top: clamp(0px, 7.16vw, 110px);
  gap: 0 clamp(0px, 5.86vw, 90px);
}
.p-index-feature .ft_light__box {
  width: clamp(0px, 20.83vw, 320px);
  padding: clamp(0px, 1.3vw, 20px);
  overflow: hidden;
  border-radius: clamp(0px, 0.91vw, 14px);
  background-color: #D9E3E9;
}
.p-index-feature .ft_light__box dt {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  margin-bottom: clamp(0px, 0.85vw, 13px);
  gap: 0 0.25em;
  color: #52738D;
  font-weight: 700;
  font-size: 20px;
  letter-spacing: 0.05em;
  text-align: center;
}
.p-index-feature .ft_light__box dt .txt_arw {
  width: 1em;
}
.p-index-feature .ft_light__box dt .txt_arw img {
  width: 100%;
}
.p-index-feature .ft_light__box dd {
  width: clamp(0px, 18.23vw, 280px);
}

.p-index-option {
  padding: clamp(0px, 13.02vw, 200px) 0 clamp(0px, 13.67vw, 210px);
}
.p-index-option__ttl {
  margin-bottom: clamp(0px, 1.17vw, 18px);
}
.p-index-option__catch {
  margin-bottom: clamp(0px, 2.6vw, 40px);
  font-size: 20px;
  text-align: center;
}
.p-index-option__catch-txt02 {
  margin-top: clamp(0px, 2.15vw, 33px);
}
.p-index-option__list {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
}
.p-index-option__list-item {
  width: 48.3962264151%;
}
.p-index-option__list-wp {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: flex-start;
}
.p-index-option__list-txtbox {
  width: 57.1150097466%;
  padding: clamp(0px, 1.04vw, 16px) 0 clamp(0px, 1.5vw, 23px) clamp(0px, 1.63vw, 25px);
  background-color: #D9E3E9;
  color: #364E65;
}
.p-index-option__list-imgbox {
  width: 42.8849902534%;
}
.p-index-option__list-ttl {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: flex-start;
  margin-bottom: clamp(0px, 0.65vw, 10px);
  padding-bottom: clamp(0px, 0.65vw, 10px);
  gap: 0 clamp(0px, 0.65vw, 10px);
  border-bottom: 1px solid #364E65;
}
.p-index-option__list-ttl span {
  display: block;
}
.p-index-option__list-ttl .img {
  width: clamp(0px, 4.62vw, 71px);
  margin-bottom: clamp(0px, 0.2vw, 3px);
}
.p-index-option__list-ttl .num {
  font-weight: 500;
  font-size: 24px;
  line-height: 1;
  letter-spacing: 0.1em;
}
.p-index-option__list-txtcont {
  padding-right: clamp(0px, 1.3vw, 20px);
}
.p-index-option__list-catch {
  margin-bottom: clamp(0px, 0.91vw, 14px);
  font-weight: 500;
  font-size: 18px;
  line-height: 1.56;
  letter-spacing: 0.02em;
}
.p-index-option__list-desc {
  font-size: 15px;
  line-height: 1.6;
}
.p-index-option__lasttxt {
  margin-top: clamp(0px, 0.26vw, 4px);
  font-size: 13px;
  text-align: right;
}

.p-index-bp {
  padding: clamp(0px, 13.02vw, 200px) 0 clamp(0px, 13.67vw, 210px);
  background-color: #EBEDED;
}
.p-index-bp__ttl {
  margin-bottom: clamp(0px, 4.82vw, 74px);
}
.p-index-bp .bpcont:not(:last-child) {
  margin-bottom: clamp(0px, 15.63vw, 240px);
}
.p-index-bp .bpcont__ttl {
  position: relative;
  margin-bottom: clamp(0px, 6.51vw, 100px);
  padding-left: clamp(0px, 7.81vw, 120px);
  font-size: 36px;
  line-height: 1.56;
}
.p-index-bp .bpcont__ttl::before {
  position: absolute;
  top: 0;
  right: 0;
  right: auto;
  bottom: 0;
  left: 0;
  width: clamp(0px, 6.38vw, 98px);
  height: clamp(0px, 6.38vw, 98px);
  margin: auto;
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  content: "";
}
.p-index-bp .bpcont__ttl--01::before {
  background-image: url("../img/top/bp_num01.png");
}
.p-index-bp .bpcont__ttl--02::before {
  background-image: url("../img/top/bp_num02.png");
}
.p-index-bp .bpcont__ttl--03::before {
  background-image: url("../img/top/bp_num03.png");
}
.p-index-bp .bpcont__ttl--04::before {
  background-image: url("../img/top/bp_num04.png");
}
.p-index-bp .bpcont__list {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: flex-start;
}
.p-index-bp .bpcont__list-item {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  padding: clamp(0px, 2.6vw, 40px) 0;
  border-bottom: 1px solid #364E65;
}
.p-index-bp .bpcont__list-item--rev {
  flex-direction: row-reverse;
}
.p-index-bp .bpcont__list-item:first-child {
  padding-top: 0;
}
.p-index-bp .bpcont__list-item:last-child {
  padding-bottom: 0;
  border-bottom: none;
}
.p-index-bp .bpcont__list-txtbox {
  width: 60.0943396226%;
}
.p-index-bp .bpcont__list-txtbox--02 {
  width: 61.320754717%;
  padding-left: clamp(0px, 3.26vw, 50px);
}
.p-index-bp .bpcont__list-imgbox--01 {
  width: 29.7169811321%;
}
.p-index-bp .bpcont__list-imgbox--02 {
  width: 36.9811320755%;
}
.p-index-bp .bpcont__list-imgbox--03 {
  width: 16.4150943396%;
  margin: auto;
}
.p-index-bp .bpcont__list-ttl {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  margin-bottom: clamp(0px, 2.8vw, 43px);
  gap: 0 clamp(0px, 0.33vw, 5px);
}
.p-index-bp .bpcont__list-ttl-numwp {
  position: relative;
  aspect-ratio: 1;
  width: clamp(0px, 3.26vw, 50px);
}
.p-index-bp .bpcont__list-ttl-numwp::before {
  position: absolute;
  top: 0;
  right: 0;
  right: auto;
  bottom: 0;
  left: 0;
  left: clamp(0px, 0.33vw, 5px);
  width: 100%;
  height: 1px;
  margin: auto;
  transform: rotate(-55deg);
  background-color: #1C2936;
  content: "";
}
.p-index-bp .bpcont__list-ttl-num {
  position: absolute;
  top: clamp(0px, 0.2vw, 3px);
  left: 0;
  font-style: normal;
  font-weight: 500;
  font-size: 22px;
  line-height: 1;
  letter-spacing: 0.1em;
}
.p-index-bp .bpcont__list-ttl-txt {
  position: relative;
  font-weight: 500;
  font-size: 20px;
  line-height: 1.5;
}
.p-index-bp .bpcont__list-desc {
  font-size: 15px;
  line-height: 2;
  letter-spacing: 0.1em;
}
.p-index-bp .bpcont__cont {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
}
.p-index-bp .bpcont__cont-desc {
  width: 47.1698113208%;
  font-size: 15px;
  line-height: 2.13;
  letter-spacing: 0.1em;
}
.p-index-bp .bpcont__cont-imgbox {
  width: 45.1886792453%;
}
.p-index-bp .bpcont__pointlist {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-start;
  gap: clamp(0px, 3.91vw, 60px) clamp(0px, 3.19vw, 49px);
}
.p-index-bp .bpcont__pointlist-item {
  position: relative;
  width: 30.1886792453%;
}
.p-index-bp .bpcont__pointlist-numbox {
  position: absolute;
  top: 0;
  left: 0;
}
.p-index-bp .bpcont__pointlist-imgbox {
  height: clamp(0px, 8.59vw, 132px);
  margin: auto;
}
.p-index-bp .bpcont__pointlist-imgbox img {
  animation: ico_scale 3s ease-in-out infinite;
}
@keyframes ico_scale {
  0% {
    transform: scale(0.9);
  }
  50% {
    transform: scale(1);
  }
  100% {
    transform: scale(0.9);
  }
}
.p-index-bp .bpcont__pointlist-imgbox.img01 {
  width: clamp(0px, 3.91vw, 60px);
}
.p-index-bp .bpcont__pointlist-imgbox.img02 {
  width: clamp(0px, 7.94vw, 122px);
}
.p-index-bp .bpcont__pointlist-imgbox.img03 {
  width: clamp(0px, 5.73vw, 88px);
}
.p-index-bp .bpcont__pointlist-imgbox.img04 {
  width: clamp(0px, 6.64vw, 102px);
}
.p-index-bp .bpcont__pointlist-imgbox.img05 {
  width: clamp(0px, 4.62vw, 71px);
}
.p-index-bp .bpcont__pointlist-imgbox.img06 {
  width: clamp(0px, 5.27vw, 81px);
}
.p-index-bp .bpcont__pointlist-imgbox.img07 {
  width: clamp(0px, 3.26vw, 50px);
}
.p-index-bp .bpcont__pointlist-imgbox.img08 {
  width: clamp(0px, 5.08vw, 78px);
}
.p-index-bp .bpcont__pointlist-imgbox.img09 {
  width: clamp(0px, 6.05vw, 93px);
}
.p-index-bp .bpcont__pointlist-ttl {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: center;
  height: 4em;
  margin-bottom: clamp(0px, 1.17vw, 18px);
  padding-bottom: clamp(0px, 0.98vw, 15px);
  border-bottom: 1px solid #364E65;
  font-weight: 500;
  font-size: 20px;
  line-height: 1.6;
  text-align: center;
}
.p-index-bp .bpcont__pointlist-desc {
  height: 6em;
  font-size: 15px;
  line-height: 1.87;
  letter-spacing: 0.05em;
  text-align: center;
}
.p-index-bp .bpcont__pointlist-desc .small {
  margin-top: clamp(0px, 0.59vw, 9px);
  font-size: 12px;
}
.p-index-bp .bpcont__pointlist-subimgbox {
  width: 100%;
  margin-top: clamp(0px, 0.98vw, 15px);
}
.p-index-bp .bpcont__movie {
  margin-top: clamp(0px, 11.07vw, 170px);
}
.p-index-bp .bpcont__movie-ttl {
  margin-bottom: clamp(0px, 2.15vw, 33px);
  font-size: 26px;
  line-height: 1.08;
  letter-spacing: 0.1em;
  text-align: center;
}
.p-index-bp .bpcont__movie-iframe {
  aspect-ratio: 16/9;
  width: clamp(0px, 51.43vw, 790px);
  margin: auto;
}
.p-index-bp .bpcont__movie-iframe iframe {
  -o-object-fit: cover;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.p-index-support {
  padding: clamp(0px, 13.02vw, 200px) 0 clamp(0px, 13.67vw, 210px);
  background-image: url("../img/top/bg_support.jpg");
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  color: #fff;
}
.p-index-support__ttl {
  margin-bottom: clamp(0px, 3.13vw, 48px);
}
.p-index-support__ico {
  width: clamp(0px, 4.49vw, 69px);
  margin: auto;
  margin-bottom: clamp(0px, 0.59vw, 9px);
}
.p-index-support__catch {
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto clamp(0px, 1.56vw, 24px);
  font-weight: 500;
  font-size: 24px;
  letter-spacing: 0.05em;
}
.p-index-support__catch::before {
  position: absolute;
  top: 0;
  top: auto;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  margin: auto;
  background-color: #fff;
  content: "";
}
.p-index-support__desc {
  margin-bottom: clamp(0px, 3.45vw, 53px);
  font-size: 15px;
  line-height: 2.13;
  letter-spacing: 0.1em;
  text-align: center;
}
.p-index-support__txtbox {
  padding: clamp(0px, 1.43vw, 22px) clamp(0px, 0.65vw, 10px) clamp(0px, 1.63vw, 25px);
  background-color: rgba(255, 255, 255, 0.3);
}
.p-index-support__txtbox-ttl {
  margin-bottom: clamp(0px, 0.78vw, 12px);
  font-weight: 400;
  font-size: 16px;
  font-family: "Shippori Mincho", serif;
  text-align: center;
}
.p-index-support__txtbox-desc {
  font-size: 14px;
  line-height: 2.29;
  letter-spacing: 0.1em;
  text-align: center;
}

.p-index-lineup {
  padding: clamp(0px, 13.02vw, 200px) 0 clamp(0px, 13.67vw, 210px);
  background: linear-gradient(180deg, #1c2936 0%, #364e65 100%);
  color: #D9E3E9;
}
.p-index-lineup__ttl {
  margin-bottom: -5em;
}
.p-index-lineup__conpact {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  margin-top: clamp(0px, 15.63vw, 240px);
  padding: clamp(0px, 4.56vw, 70px) clamp(0px, 11.07vw, 170px);
  border-radius: clamp(0px, 0.65vw, 10px);
  background-color: rgba(255, 255, 255, 0.35);
  color: #fff;
}
.p-index-lineup__conpact-txtbox {
  width: 71.6666666667%;
}
.p-index-lineup__conpact-txtbox .s-lineup__ttl-maru {
  left: clamp(0px, 13.02vw, 200px);
}
.p-index-lineup__conpact-imgbox {
  width: 27.7777777778%;
}
.p-index-lineup__conpact-imgbox .img {
  width: clamp(0px, 9.7vw, 149px);
  margin: auto;
  margin-bottom: clamp(0px, 2.93vw, 45px);
}
.p-index-lineup__contact {
  width: clamp(0px, 29.49vw, 453px);
  margin: auto;
  margin-top: clamp(0px, 4.1vw, 63px);
}
.p-index-lineup__tel {
  margin-top: clamp(0px, 1.69vw, 26px);
  font-weight: 500;
  font-size: 16px;
  text-align: center;
}

.s-lineup__ttl {
  position: relative;
  margin-bottom: clamp(0px, 0.98vw, 15px);
  padding-bottom: clamp(0px, 0.65vw, 10px);
  border-bottom: 1px solid #fff;
}
.s-lineup__ttl-exp {
  margin-bottom: clamp(0px, 2.47vw, 38px);
  font-size: 18px;
  line-height: 1.44;
}
.s-lineup__ttl-main {
  font-weight: 300;
  font-size: 40px;
  font-family: "Oswald", sans-serif;
}
.s-lineup__ttl-sub {
  font-weight: 500;
  font-size: 16px;
  line-height: 2;
}
.s-lineup__ttl-maru {
  display: flex;
  position: absolute;
  right: 0;
  bottom: clamp(0px, 0.98vw, 15px);
  flex-direction: column;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  width: clamp(0px, 7.81vw, 120px);
  height: clamp(0px, 7.81vw, 120px);
  margin: auto;
  border-radius: 100%;
  background-color: #D9E3E9;
  color: #364E65;
  font-weight: 500;
  text-align: center;
}
.s-lineup__ttl-maru .txt01 {
  font-size: 16px;
  line-height: 1.2;
}
.s-lineup__ttl-maru .txt02 {
  margin-top: clamp(0px, 0.33vw, 5px);
  font-size: 15px;
  line-height: 1;
}
.s-lineup__ttl-maru .txt02 span {
  font-weight: 300;
  font-weight: 400;
  font-size: 37px;
  font-family: "Oswald", sans-serif;
}
.s-lineup__list {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-start;
  margin-bottom: clamp(0px, 0.65vw, 10px);
  gap: clamp(0px, 0.65vw, 10px);
}
.s-lineup__list-item {
  padding: clamp(0px, 0.33vw, 5px) clamp(0px, 0.65vw, 10px);
  border-radius: clamp(0px, 0.2vw, 3px);
  background-color: #fff;
  color: #364E65;
  font-weight: 500;
  font-size: 14px;
}
.s-lineup__table {
  width: 100%;
  margin-bottom: clamp(0px, 1.95vw, 30px);
}
.s-lineup__table th, .s-lineup__table td {
  padding: 0.1em 0;
  font-size: 13px;
  vertical-align: top;
}
.s-lineup__table th {
  width: 35%;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-align: left;
}
.s-lineup__table td {
  width: 65%;
  font-weight: 400;
  letter-spacing: 0.1em;
}
.s-lineup__cau {
  margin-top: -1em;
  color: #fff;
  font-size: 13px;
  letter-spacing: 0.05em;
}
.s-lineup__cau a {
  color: #fff;
  text-decoration: underline;
}
.s-lineup__cau a:hover {
  text-decoration: none;
}

.p-index-brand {
  padding: clamp(0px, 13.02vw, 200px) 0 clamp(0px, 13.67vw, 210px);
  background-image: url("../img/top/bg_brand.jpg");
  background-position: center center;
  background-position: center bottom;
  background-size: cover;
  background-repeat: no-repeat;
  color: #D9E3E9;
}
.p-index-brand__seller {
  display: contents;
}
.p-index-brand__ttl {
  width: clamp(0px, 17.84vw, 274px);
  margin: auto;
  margin-bottom: clamp(0px, 1.3vw, 20px);
}
.p-index-brand__catch {
  width: clamp(0px, 42.71vw, 656px);
  margin: auto;
  margin-bottom: clamp(0px, 3.13vw, 48px);
}
.p-index-brand__desc {
  margin-bottom: clamp(0px, 3.91vw, 60px);
  font-weight: 500;
  font-size: 16px;
  line-height: 2.13;
  letter-spacing: 0.1em;
  text-align: center;
  text-shadow: 3px 3px 6px #1C2936;
}

.p-index-bg02 {
  background-color: #E7EAEB;
  color: #364E65;
}

.p-index-shop {
  padding: clamp(0px, 13.02vw, 200px) 0 clamp(0px, 6.51vw, 100px);
}
.p-index-shop__ttl {
  margin-bottom: clamp(0px, 6.25vw, 96px);
}
.p-index-shop__bnlist {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: center;
}
.p-index-shop__bnlist-item {
  aspect-ratio: 612/248;
  width: 39.84375%;
  overflow: hidden;
}
.p-index-shop__bnlist-link {
  display: block;
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  color: #fff;
}
.p-index-shop__bnlist-link::before {
  z-index: 1;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
  background-color: rgba(0, 0, 0, 0.3);
  content: "";
  mix-blend-mode: multiply;
  opacity: 1;
  transition: opacity 0.3s ease-in-out;
}
.p-index-shop__bnlist-link .img {
  z-index: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.p-index-shop__bnlist-link .img img {
  -o-object-fit: cover;
  object-fit: cover;
  transition: transform 0.3s ease-in-out;
}
.p-index-shop__bnlist-link .txtbox {
  z-index: 2;
  position: absolute;
  bottom: clamp(0px, 1.69vw, 26px);
  left: clamp(0px, 2.21vw, 34px);
}
.p-index-shop__bnlist-link .txtbox .f_en {
  display: block;
  font-weight: 500;
  font-size: 30px;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}
.p-index-shop__bnlist-link .txtbox .txt_jp {
  display: block;
  font-weight: 500;
  font-size: 14px;
}
.p-index-shop__bnlist-link:hover::before {
  opacity: 0;
}

.p-index-scene {
  padding: clamp(0px, 13.02vw, 200px) 0 clamp(0px, 13.67vw, 210px);
}
.p-index-scene__ttl {
  margin-bottom: clamp(0px, 2.6vw, 40px);
}

.introStore-slider {
  position: relative;
  width: clamp(0px, 84.64vw, 1300px);
  height: clamp(0px, 34.51vw, 530px);
  margin: 0 auto;
}
.introStore-slider__images {
  position: relative;
  overflow: visible;
}
.introStore-slider__images .swiper-slide {
  box-sizing: border-box;
  aspect-ratio: 286/405;
  width: 20%;
  width: clamp(0px, 18.62vw, 286px);
  margin: 0 clamp(0px, 0.46vw, 7px);
  transition: width 1s ease 1.8s, margin 1s ease 1.8s;
  will-change: width, margin;
}
.introStore-slider__images .swiper-slide .nolink {
  pointer-events: none;
}
.introStore-slider__images .swiper-slide-active {
  width: 29%;
}
.introStore-slider__images .swiper-slide:not(.introStore-slider__images .swiper-slide-active) {
  width: clamp(0px, 18.62vw, 286px);
}
.introStore-slider__images .swiper-slide:hover .introStore-card img {
  transform: scale(1.1);
}
.introStore-slider__images .introStore-card {
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.introStore-slider__images .introStore-card img {
  -o-object-fit: cover;
  object-fit: cover;
  transition: transform 0.3s ease-in-out;
}
.introStore-slider__nav {
  display: flex;
  z-index: 10;
  position: absolute;
  top: 35%;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  aspect-ratio: 2/3;
  width: clamp(0px, 2.6vw, 40px);
  transform: translateY(-35%);
  cursor: pointer;
  transition: color 0.3s ease-in-out;
}
.introStore-slider__nav::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: clamp(0px, 1.3vw, 20px);
  height: clamp(0px, 1.95vw, 30px);
  margin: auto;
  background-image: url("../img/common/icoArw02.png");
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  content: "";
}
.introStore-slider__nav--prev {
  left: clamp(0px, 1.3vw, 20px);
}
.introStore-slider__nav--prev::before {
  transform: rotate(180deg);
}
.introStore-slider__nav--next {
  right: clamp(0px, 1.3vw, 20px);
}
.introStore-slider__nav:hover {
  color: #364E65;
}
.introStore-slider__viewmore {
  z-index: 10;
  position: absolute;
  right: clamp(0px, 19.53vw, 300px);
  right: clamp(0px, 0vw, 0px);
  bottom: 0;
}
.introStore-slider__texts-box {
  position: absolute;
  bottom: -2em;
  left: clamp(0px, 26.04vw, 400px);
  left: clamp(0px, 55.99vw, 860px);
  max-width: 400px;
  max-width: 240px;
}
.introStore-slider__texts {
  padding-left: clamp(0px, 3.26vw, 50px);
  overflow: hidden;
  color: #364E65;
  font-weight: 500;
}
.introStore-slider__texts::before {
  position: absolute;
  top: 0;
  right: 0;
  right: auto;
  bottom: 0;
  bottom: auto;
  left: 0;
  width: clamp(0px, 2.21vw, 34px);
  height: clamp(0px, 2.21vw, 34px);
  margin: auto;
  margin: 0;
  background-image: url("../img/top/introStorelink.png");
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  content: "";
}
.introStore-slider__texts .introStore-text__place {
  font-size: 18px;
  text-indent: -0.5em;
  opacity: 0;
  transition: opacity 0.4s ease-in-out 1.8s;
}
.introStore-slider__texts .introStore-text__name {
  font-size: 16px;
  opacity: 0;
  transition: opacity 0.4s ease-in-out 1.8s;
}
.introStore-slider__texts .swiper-slide-active .introStore-text__place {
  opacity: 1;
}
.introStore-slider__texts .swiper-slide-active .introStore-text__name {
  opacity: 1;
}

.c-circleCarousel {
  position: relative;
  aspect-ratio: 1;
  width: 100%;
  height: auto;
  margin: 0 auto;
  perspective: 3000px;
}
.c-circleCarousel::before {
  z-index: -1;
  position: absolute;
  top: 0;
  top: clamp(0px, 7.16vw, 110px);
  right: 0;
  bottom: 0;
  bottom: auto;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
  transform: scaleY(0.25) scaleX(0.8);
  transform-origin: center center;
  border: 2px solid #D9E3E9;
  border-radius: 100%;
  content: "";
}

.c-circleCarousel__inner {
  position: absolute;
  inset: 0;
  transform: rotateX(80deg);
  transform-style: preserve-3d;
}

.c-circleCarousel__item {
  z-index: 2;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  width: clamp(0px, 24.02vw, 369px);
  height: clamp(0px, 39.39vw, 605px);
  margin: auto;
  transform-style: preserve-3d;
  transition: transform 0.4s ease;
}

.c-circleCarousel__itemInner {
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.4s ease;
  will-change: transform;
}

.c-circleCarousel__item.is-active .c-circleCarousel__itemInner {
  transform: scale(1);
}

.c-circleCarousel__item:not(.is-active) .c-circleCarousel__itemInner {
  transform: scale(0.5);
  box-shadow: none;
}

/* ▼ 説明ブロック（右下） */
.c-circleCarousel__descs {
  z-index: 3;
  position: absolute;
  right: -3em; /* 必要に応じて微調整 */
  bottom: clamp(0px, 16.93vw, 260px); /* ボタンとかぶらない位置に */
  width: clamp(0px, 26.04vw, 400px); /* お好みで */
}

.c-circleCarousel__desc {
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
}

.c-circleCarousel__desc.is-active {
  opacity: 1;
  pointer-events: auto;
}

.c-circleCarousel__btn {
  z-index: 100;
  position: absolute;
  top: 0;
  bottom: 0;
  width: clamp(0px, 1.3vw, 20px);
  height: clamp(0px, 1.95vw, 30px);
  margin: auto;
  cursor: pointer;
}
.c-circleCarousel__btn::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
  background-image: url("../img/common/icoArw02.png");
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  content: "";
}
.c-circleCarousel__btn--prev {
  left: -1em;
}
.c-circleCarousel__btn--prev::before {
  transform: rotate(180deg);
}
.c-circleCarousel__btn--next {
  right: -1em;
}
@media screen and (max-width: 1536px) {
  body {
    margin: 0;
  }
  .l-header__hedMenu-link {
    font-size: 1.4rem;
  }
  .l-header__glNavBtnWp .glNavBtn--pc span {
    font-size: 1.4rem;
  }
  .l-header__pcMenu01-corpsite {
    font-size: 1.6rem;
  }
  .l-header__pcMenu02-menulist-item {
    font-size: 2rem;
  }
  .l-footer__menulist-item {
    font-size: 1.8rem;
  }
  .l-footer__corpsite {
    font-size: 1.6rem;
  }
  .l-footer__pagetop a span {
    font-size: 1.2rem;
  }
  .l-footer__copy {
    font-size: 1.2rem;
  }
  .c-btn01__link {
    font-size: 1.4rem;
  }
  .c-btn01__link--lineupcontact {
    font-size: 1.6rem;
  }
  .c-btn01__link--lineupcontact .c-btn01__txt {
    font-size: 1.8rem;
  }
  .cmnTtl02 {
    font-size: 4.8rem;
  }
  .cmnTtl02 .f_en {
    font-size: 3.6rem;
  }
  .cmnTtl02 .f_en em {
    font-size: 3.4rem;
  }
  .cmnTtl02 .f_en--fs50 {
    font-size: 5rem;
  }
  .cmnTtl02 .f_jp {
    font-size: 1.6rem;
  }
  .p-index-fv__catch {
    font-size: 3rem;
  }
  .p-index-concept__ttl .f_en {
    font-size: 1.6rem;
  }
  .p-index-concept__ttl .f_jp {
    font-size: 6rem;
  }
  .p-index-concept__desc {
    font-size: 2.6rem;
  }
  .p-index-concept02__ttl {
    font-size: 4rem;
  }
  .p-index-concept02__desc {
    font-size: 1.6rem;
  }
  .p-index-concept02__note {
    font-size: 1.3rem;
  }
  .p-index-feature__catch-txt01 {
    font-size: 3.2rem;
  }
  .p-index-feature__catch-txt02 {
    font-size: 2rem;
  }
  .p-index-feature .ft_cont__ttl-txt {
    font-size: 3rem;
  }
  .p-index-feature .ft_cont__desc {
    font-size: 1.5rem;
  }
  .p-index-feature .ft_cont__desc--02sub {
    font-size: 1.3rem;
  }
  .p-index-feature .ft_cont__desc--03sub {
    font-size: 1.4rem;
  }
  .p-index-feature .ft_cont__f01list figcaption {
    font-size: 1.8rem;
  }
  .p-index-feature .ft_light__box dt {
    font-size: 2rem;
  }
  .p-index-option__catch {
    font-size: 2rem;
  }
  .p-index-option__list-ttl .num {
    font-size: 2.4rem;
  }
  .p-index-option__list-catch {
    font-size: 1.8rem;
  }
  .p-index-option__list-desc {
    font-size: 1.5rem;
  }
  .p-index-option__lasttxt {
    font-size: 1.3rem;
  }
  .p-index-bp .bpcont__ttl {
    font-size: 3.6rem;
  }
  .p-index-bp .bpcont__list-ttl-num {
    font-size: 2.2rem;
  }
  .p-index-bp .bpcont__list-ttl-txt {
    font-size: 2rem;
  }
  .p-index-bp .bpcont__list-desc {
    font-size: 1.5rem;
  }
  .p-index-bp .bpcont__cont-desc {
    font-size: 1.5rem;
  }
  .p-index-bp .bpcont__pointlist-ttl {
    font-size: 2rem;
  }
  .p-index-bp .bpcont__pointlist-desc {
    font-size: 1.5rem;
  }
  .p-index-bp .bpcont__pointlist-desc .small {
    font-size: 1.2rem;
  }
  .p-index-bp .bpcont__movie-ttl {
    font-size: 2.6rem;
  }
  .p-index-support__catch {
    font-size: 2.4rem;
  }
  .p-index-support__desc {
    font-size: 1.5rem;
  }
  .p-index-support__txtbox-ttl {
    font-size: 1.6rem;
  }
  .p-index-support__txtbox-desc {
    font-size: 1.4rem;
  }
  .p-index-lineup__tel {
    font-size: 1.6rem;
  }
  .s-lineup__ttl-exp {
    font-size: 1.8rem;
  }
  .s-lineup__ttl-main {
    font-size: 4rem;
  }
  .s-lineup__ttl-sub {
    font-size: 1.6rem;
  }
  .s-lineup__ttl-maru .txt01 {
    font-size: 1.6rem;
  }
  .s-lineup__ttl-maru .txt02 {
    font-size: 1.5rem;
  }
  .s-lineup__ttl-maru .txt02 span {
    font-size: 3.7rem;
  }
  .s-lineup__list-item {
    font-size: 1.4rem;
  }
  .s-lineup__table th, .s-lineup__table td {
    font-size: 1.3rem;
  }
  .s-lineup__cau {
    font-size: 1.3rem;
  }
  .p-index-brand__desc {
    font-size: 1.6rem;
  }
  .p-index-shop__bnlist-link .txtbox .f_en {
    font-size: 3rem;
  }
  .p-index-shop__bnlist-link .txtbox .txt_jp {
    font-size: 1.4rem;
  }
  .introStore-slider__texts .introStore-text__place {
    font-size: 1.8rem;
  }
  .introStore-slider__texts .introStore-text__name {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 1500px) {
  body {
    margin: 0;
  }
  html {
    font-size: 0.625vw;
  }
}
@media screen and (max-width: 1289px) {
  body {
    margin: 0;
  }
  html {
    font-size: 0.6666666667vw;
  }
  .c-inner01 {
    width: 90%;
  }
  .p-index-fv__catch {
    left: 53%;
  }
}
@media screen and (max-width: 1024px) {
  body {
    margin: 0;
  }
  .p-index-fv__catch {
    left: 56%;
  }
}
@media screen and (max-width: 896px) {
  body {
    margin: 0;
  }
  html {
    font-size: 2.6666666667vw;
  }
  .actinview .fadeIn00no .fadeIn00 {
    transition: opacity 1s;
  }
  .l-header {
    z-index: 101;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 13.33vw;
    background-color: transparent;
    transition: background-color 0.8s ease-in-out;
  }
  .l-header.scrolled {
    background-color: #364E65;
  }
  .l-header__logo {
    top: 3.2vw !important;
    left: 5.33vw !important;
    width: 28.53vw;
  }
  .l-header__hedMenu {
    display: none;
  }
  .l-header__glNavBtnWp {
    top: 3.47vw !important;
    right: 6.13vw !important;
    width: 8vw;
    height: 2.67vw;
  }
  .l-header__glNavBtnWp.act {
    width: 6.13vw;
  }
  .l-header__glNavBtnWp .glNavBtn--pc {
    display: none;
  }
  .l-header__glNavBtnWp .glNavBtn--pc i {
    width: 1.07vw;
    height: 1.07vw;
  }
  .l-header__glNavBtnWp .glNavBtn--pc span {
    font-size: 12px;
  }
  .l-header__glNavBtnWp .glNavBtn--sp {
    display: flex;
    visibility: visible;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: flex-start;
    gap: 2.13vw 0;
    opacity: 1;
    transition: opacity 0.8s ease-in-out 0.5s;
  }
  .l-header__glNavBtnWp .glNavBtn--sp span {
    width: 100%;
    height: 1px;
    border-radius: 100px;
    background-color: #CFDDE4;
  }
  .l-header__glNavBtnWp .glNavBtn--sp.act {
    visibility: hidden;
    height: 0;
    opacity: 0;
  }
  .l-header__glNavBtnWp .glNavBtnClose {
    width: 6.13vw;
    height: 6.13vw;
    opacity: 0;
    transition: opacity 0.8s ease-in-out 0.5s;
  }
  .l-header__glNavBtnWp .glNavBtnClose.act {
    opacity: 1;
  }
  .l-header__glNavMenu {
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-start;
  }
  .l-header__glNavMenu.act {
    padding: 21.33vw 5.87vw 5.33vw;
    overflow-y: scroll;
    background-image: url("../img/common/megaMenuBgsp.png");
  }
  .l-header__glNavMenu.act::before {
    top: 18.67vw;
    width: 95.2vw;
    height: 132.53vw;
    opacity: 0.7;
  }
  .l-header__pcMenu01 {
    display: contents;
  }
  .l-header__pcMenu01-logo {
    order: 1;
    width: 45.07vw;
    margin: 0 auto 13.33vw;
    padding: 0;
  }
  .l-header__pcMenu01-cont02 {
    order: 3;
  }
  .l-header__pcMenu01-snslist {
    margin-bottom: 3.2vw;
    gap: 0 8.8vw;
  }
  .l-header__pcMenu01-snslist-item {
    width: 8vw;
  }
  .l-header__pcMenu01-corpsite {
    font-size: 14px;
  }
  .l-header__pcMenu02 {
    order: 2;
    width: 100%;
    margin-bottom: 24vw;
  }
  .l-header__pcMenu02-menubox {
    justify-content: center;
    gap: 0 13.33vw;
  }
  .l-header__pcMenu02-menulist {
    gap: 13.33vw 0;
  }
  .l-header__pcMenu02-menulist-item {
    font-size: 14px;
  }
  .l-header__copy {
    margin-top: 10.67vw;
    color: #fff;
    font-size: 12px;
    text-align: center;
  }
  .l-footer {
    padding: 24vw 6.13vw 5.33vw;
  }
  .l-footer__cont01 {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: flex-start;
    margin-bottom: 28.27vw;
  }
  .l-footer__logo {
    width: 45.07vw;
    margin: auto;
    margin-bottom: 13.33vw;
  }
  .l-footer__menubox {
    justify-content: center;
    gap: 0 17.6vw;
  }
  .l-footer__menulist {
    gap: 9.33vw 0;
  }
  .l-footer__menulist-item {
    font-size: 14px;
  }
  .l-footer__cont02 {
    margin: 0;
    margin-bottom: 10.67vw;
  }
  .l-footer__snslist {
    justify-content: flex-start;
    margin-bottom: 3.2vw;
    gap: 0 8.8vw;
  }
  .l-footer__snslist-item {
    width: 8vw;
  }
  .l-footer__corpsite {
    font-size: 14px;
    text-align: left;
  }
  .l-footer__cont03 {
    margin-top: 0;
    margin-right: auto;
  }
  .l-footer__pagetop {
    position: absolute;
    right: 5.87vw;
    bottom: 20.27vw;
    width: 21.33vw;
    margin-bottom: 0;
  }
  .l-footer__pagetop a {
    gap: 1.33vw 0;
  }
  .l-footer__pagetop a img {
    width: 14.93vw;
    height: 14.93vw;
  }
  .l-footer__copy {
    text-align: center;
  }
  .c-inner01 {
    width: 92.5%;
  }
  .c-btn01--spcenter {
    margin-right: auto;
    margin-left: auto;
  }
  .c-btn01__link {
    padding: 3.2vw 15.2vw;
    gap: 0 3.47vw;
    border-radius: 0.8vw;
    font-weight: 500;
    font-size: 13px;
    letter-spacing: 0.1em;
  }
  .c-btn01__link--lineupcontact {
    padding: 4.53vw 2.67vw 5.07vw;
    gap: 1.6vw 0;
    font-size: 14px;
  }
  .c-btn01__link--lineupcontact .c-arwicon {
    right: -1.5em;
  }
  .cmnTtl02 .f_en--fs50 {
    font-size: 36px;
    line-height: 1.22;
  }
  .cmnTtl02 .f_jp {
    margin-top: 1.87vw;
  }
  .c-arwicon {
    width: 4vw;
    height: 4vw;
  }
  .c-arwicon::before {
    width: 3.47vw;
    height: 3.2vw;
  }
  .l-opening {
    background-image: url("../img/top/opBgsp.png");
  }
  .l-opening__skip {
    right: 6.67vw;
    bottom: 18.67vw;
    width: 33.87vw;
  }
  .l-opening__img {
    top: 10em;
    transform: scale(1.2);
  }
  .sp {
    display: block !important;
  }
  .pc {
    display: none !important;
  }
  .p-index-fvwp {
    background-image: url("../img/top/fvwp_bgsp.png");
  }
  .p-index-fv__imgbox {
    right: auto;
    left: -50%;
    width: 200%;
    height: 100lvh;
  }
  .p-index-fv__imgbox figure {
    width: 100%;
    height: 100%;
  }
  .p-index-fv__imgbox figure img {
    -o-object-position: top;
    height: 90lvh;
    object-position: top;
  }
  .p-index-fv__catch {
    top: auto;
    right: 0;
    bottom: 48vw;
    left: 0;
    margin: auto;
    transform: none;
    font-size: 20px;
    line-height: 1.6;
  }
  .p-index-fv__ttlname {
    bottom: 13.33vw;
    width: 63.47vw;
  }
  .p-index-concept {
    padding: 53.33vw 0 13.33vw;
    background: linear-gradient(180deg, transparent, #1c2936 52%, #1c2936);
  }
  .p-index-concept__txtbox {
    width: 100%;
    padding-left: 0;
  }
  .p-index-concept__ttl {
    margin-bottom: 2.13vw;
  }
  .p-index-concept__ttl .f_en {
    margin-bottom: 3.73vw;
  }
  .p-index-concept__ttl .f_jp {
    font-size: 42px;
  }
  .p-index-concept__desc {
    margin-bottom: 9.07vw;
    font-size: 22px;
    line-height: 1.82;
  }
  .p-index-navygradarea {
    background: linear-gradient(25deg, #1C2936 0%, #48657C 31.34%, #1C2936 100%);
  }
  .p-index-navygradarea__bg {
    display: none;
    height: 100dvh;
  }
  .p-index-navygradarea__kirakira {
    width: 28em;
  }
  .p-index-navygradarea__kirakira.img01 {
    top: 148em;
  }
  .p-index-navygradarea__kirakira.img02 {
    top: 277em;
    right: -5em;
    left: auto;
  }
  .p-index-navygradarea__kirakira.img03 {
    top: 404em;
  }
  .p-index-navygradarea__kirakira.img04 {
    top: 544em;
    right: -5em;
    left: auto;
  }
  .p-index-navygradarea__kirakira.img05 {
    display: none;
  }
  .p-index-concept02 {
    padding: 30.67vw 0 141.33vw;
    background-image: url("../img/top/concept02_bgsp.png");
    background-size: 100%;
  }
  .p-index-concept02__txtbox {
    width: 100%;
  }
  .p-index-concept02__ttl {
    margin-bottom: 8vw;
    font-size: 28px;
    line-height: 1.64;
  }
  .p-index-concept02__desc {
    font-size: 14px;
    line-height: 2;
  }
  .p-index-concept02__note {
    margin-top: 2.13vw;
    font-size: 12px;
  }
  .p-index-feature {
    padding: 26.67vw 0 29.33vw;
  }
  .p-index-feature__ttl {
    margin-bottom: 8vw;
  }
  .p-index-feature__catch {
    margin-bottom: 17.87vw;
  }
  .p-index-feature__catch-txt01 {
    margin-bottom: 2.13vw;
    font-size: 22px;
  }
  .p-index-feature__catch-txt02 {
    font-size: 16px;
  }
  .p-index-feature .ft_contwp--03 {
    margin-bottom: 0;
  }
  .p-index-feature .ft_cont {
    margin-bottom: 26.67vw;
  }
  .p-index-feature .ft_cont--flex {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: flex-start;
    margin-right: 0;
    gap: 9.6vw 0;
  }
  .p-index-feature .ft_cont--flexrev {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: center;
    margin-left: 0;
    gap: 9.6vw 0;
  }
  .p-index-feature .ft_cont--01 {
    padding: 0;
  }
  .p-index-feature .ft_cont--02 {
    margin-bottom: 26.67vw;
  }
  .p-index-feature .ft_cont--03a {
    margin-bottom: 20.27vw;
  }
  .p-index-feature .ft_cont--04 {
    margin-bottom: 0;
  }
  .p-index-feature .ft_cont__txtbox {
    width: 100%;
  }
  .p-index-feature .ft_cont__ttl {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: flex-start;
    margin-bottom: 8vw;
  }
  .p-index-feature .ft_cont__ttl-num {
    margin-bottom: 8vw;
  }
  .p-index-feature .ft_cont__ttl-num--01 {
    width: 30.93vw;
  }
  .p-index-feature .ft_cont__ttl-num--02 {
    width: 35.2vw;
  }
  .p-index-feature .ft_cont__ttl-num--03 {
    width: 35.2vw;
    margin-bottom: 5.33vw;
  }
  .p-index-feature .ft_cont__ttl-num--04 {
    width: 33.33vw;
    margin-bottom: 5.33vw;
  }
  .p-index-feature .ft_cont__ttl-txt {
    font-size: 24px;
    line-height: 1.67;
    letter-spacing: 0;
  }
  .p-index-feature .ft_cont__desc {
    font-size: 14px;
    line-height: 2;
  }
  .p-index-feature .ft_cont__desc--02sub {
    margin-top: 5.33vw;
  }
  .p-index-feature .ft_cont__desc--03sub {
    margin-top: 3.2vw;
  }
  .p-index-feature .ft_cont__f01list {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: flex-start;
    margin-top: 8vw;
    gap: 6.67vw 0;
  }
  .p-index-feature .ft_cont__f01list-item {
    width: 100%;
  }
  .p-index-feature .ft_cont__f01list figcaption {
    padding: 2.67vw 0;
    font-size: 16px;
  }
  .p-index-feature .ft_cont__02expimg {
    width: 100%;
    margin-top: 7.2vw;
  }
  .p-index-feature .ft_cont__imgbox--02 {
    width: 100%;
    margin-right: 0;
  }
  .p-index-feature .ft_cont__imgbox--03a {
    width: 100%;
    margin-left: 0;
  }
  .p-index-feature .ft_cont__imgbox--03b {
    width: 100%;
    margin-right: 0;
  }
  .p-index-feature .ft_cont__imgbox--04 {
    width: 100%;
    margin-right: 0;
  }
  .p-index-feature .ft_cont__02img01 {
    width: 100%;
  }
  .p-index-feature .ft_cont__02img02 {
    position: static;
    width: 100%;
  }
  .p-index-feature .ft_cont__03img02 {
    width: 62.93vw;
    margin-right: auto;
    margin-left: 0;
  }
  .p-index-feature .ft_cont__bgimg {
    aspect-ratio: 902/602;
    width: 133.33vw;
    height: auto;
  }
  .p-index-feature .ft_cont__bgimg.img01 {
    right: -20em;
    bottom: -16em;
  }
  .p-index-feature .ft_cont__bgimg.img02 {
    bottom: -16em;
    left: -10em;
  }
  .p-index-feature .ft_cont__bgimg.img03 {
    right: -13em;
    bottom: -8em;
  }
  .p-index-feature .ft_cont__bgimg.img04 {
    top: -31em;
    left: -13em;
  }
  .p-index-feature .ft_cont__bgimg.img05 {
    right: -11em;
    bottom: -5em;
  }
  .p-index-feature .ft_light {
    align-items: stretch;
    justify-content: space-between;
    margin-top: 10.67vw;
    gap: 0;
  }
  .p-index-feature .ft_light__box {
    width: 41.87vw;
    padding: 3.73vw;
    border-radius: 1.6vw;
  }
  .p-index-feature .ft_light__box dt {
    margin-bottom: 2.93vw;
    font-size: 16px;
  }
  .p-index-feature .ft_light__box dd {
    width: 100%;
  }
  .p-index-option {
    padding: 26.67vw 0 29.33vw;
  }
  .p-index-option__ttl {
    margin-bottom: 7.47vw;
  }
  .p-index-option__catch {
    margin-bottom: 10.67vw;
    line-height: 1.6;
  }
  .p-index-option__catch-txt02 {
    margin-top: 8vw;
  }
  .p-index-option__list {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: flex-start;
    gap: 10.67vw 0;
  }
  .p-index-option__list-item {
    width: 100%;
  }
  .p-index-option__list-wp {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: flex-start;
  }
  .p-index-option__list-txtbox {
    width: 100%;
    padding: 6.13vw 6.67vw;
  }
  .p-index-option__list-imgbox {
    width: 100%;
    padding: 0 6.13vw 6.13vw;
    background-color: #D9E3E9;
  }
  .p-index-option__list-ttl {
    margin-bottom: 2.67vw;
    padding-bottom: 2.67vw;
    gap: 0 2.67vw;
  }
  .p-index-option__list-ttl .img {
    width: 19.47vw;
    margin-bottom: 0.8vw;
  }
  .p-index-option__list-txtcont {
    padding: 0;
  }
  .p-index-option__list-catch {
    margin-bottom: 3.73vw;
  }
  .p-index-option__lasttxt {
    margin-top: 1.07vw;
    text-align: left;
  }
  .p-index-bp {
    padding: 26.67vw 0 29.33vw;
  }
  .p-index-bp__ttl {
    margin-bottom: 20vw;
  }
  .p-index-bp .bpcont:not(:last-child) {
    margin-bottom: 32vw;
  }
  .p-index-bp .bpcont__ttl {
    margin-bottom: 13.33vw;
    padding: 33.33vw 0 0;
    font-size: 20px;
    line-height: 1.5;
    text-align: center;
  }
  .p-index-bp .bpcont__ttl::before {
    right: 0;
    bottom: auto;
    width: 26.13vw;
    height: 26.13vw;
  }
  .p-index-bp .bpcont__list-item {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: flex-start;
    padding: 20vw 0;
    gap: 7.2vw 0;
  }
  .p-index-bp .bpcont__list-item--rev {
    flex-direction: column;
  }
  .p-index-bp .bpcont__list-txtbox {
    width: 100%;
  }
  .p-index-bp .bpcont__list-txtbox--02 {
    width: 100%;
    padding-left: 0;
  }
  .p-index-bp .bpcont__list-imgbox {
    width: 95%;
    margin: auto;
  }
  .p-index-bp .bpcont__list-imgbox--03 {
    width: 46.4vw;
  }
  .p-index-bp .bpcont__list-ttl {
    margin-bottom: 8.53vw;
    gap: 0 4vw;
  }
  .p-index-bp .bpcont__list-ttl-numwp {
    width: 12vw;
  }
  .p-index-bp .bpcont__list-ttl-numwp::before {
    left: 2.67vw;
  }
  .p-index-bp .bpcont__list-ttl-num {
    top: 0.8vw;
  }
  .p-index-bp .bpcont__list-desc {
    font-size: 14px;
    line-height: 1.86;
  }
  .p-index-bp .bpcont__cont {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: flex-start;
    gap: 8.53vw 0;
  }
  .p-index-bp .bpcont__cont-desc {
    width: 100%;
    font-size: 14px;
    line-height: 1.86;
  }
  .p-index-bp .bpcont__cont-imgbox {
    width: 100%;
  }
  .p-index-bp .bpcont__pointlist {
    align-items: stretch;
    justify-content: space-between;
    gap: 24.53vw 0;
  }
  .p-index-bp .bpcont__pointlist-item {
    width: 41.07vw;
  }
  .p-index-bp .bpcont__pointlist-numbox {
    top: -6.67vw;
  }
  .p-index-bp .bpcont__pointlist-numbox .bpcont__list-ttl-num {
    font-size: 20px;
  }
  .p-index-bp .bpcont__pointlist-numbox .bpcont__list-ttl-numwp::before {
    left: 1.33vw;
    transform: rotate(-65deg);
  }
  .p-index-bp .bpcont__pointlist-imgbox {
    height: 26.67vw;
  }
  .p-index-bp .bpcont__pointlist-imgbox.img01 {
    width: 12vw;
  }
  .p-index-bp .bpcont__pointlist-imgbox.img02 {
    width: 24.53vw;
  }
  .p-index-bp .bpcont__pointlist-imgbox.img03 {
    width: 17.6vw;
  }
  .p-index-bp .bpcont__pointlist-imgbox.img04 {
    width: 20.53vw;
  }
  .p-index-bp .bpcont__pointlist-imgbox.img05 {
    width: 14.13vw;
  }
  .p-index-bp .bpcont__pointlist-imgbox.img06 {
    width: 16.27vw;
  }
  .p-index-bp .bpcont__pointlist-imgbox.img07 {
    width: 10.13vw;
  }
  .p-index-bp .bpcont__pointlist-imgbox.img08 {
    width: 15.73vw;
  }
  .p-index-bp .bpcont__pointlist-imgbox.img09 {
    width: 18.67vw;
  }
  .p-index-bp .bpcont__pointlist-ttl {
    margin-bottom: 4.8vw;
    padding-bottom: 4.8vw;
    font-size: 14px;
    line-height: 1.71;
    letter-spacing: 0;
  }
  .p-index-bp .bpcont__pointlist-desc {
    height: auto;
    font-size: 14px;
    line-height: 1.71;
    text-align: left;
  }
  .p-index-bp .bpcont__pointlist-desc .small {
    margin-top: 1.33vw;
  }
  .p-index-bp .bpcont__pointlist-subimgbox {
    margin-top: 4.8vw;
  }
  .p-index-bp .bpcont__movie {
    margin-top: 24.53vw;
  }
  .p-index-bp .bpcont__movie-ttl {
    margin-bottom: 3.47vw;
    font-size: 16px;
    line-height: 1.75;
  }
  .p-index-bp .bpcont__movie-iframe {
    width: 100%;
  }
  .p-index-support {
    padding: 26.67vw 0 29.33vw;
    background-image: url("../img/top/bg_supportsp.jpg");
  }
  .p-index-support__ttl {
    margin-bottom: 16.53vw;
  }
  .p-index-support__ico {
    width: 18.4vw;
    margin-bottom: 4.27vw;
  }
  .p-index-support__catch {
    margin: 0 auto 6.4vw;
    font-size: 18px;
    line-height: 1.78;
    text-align: center;
    text-decoration: underline;
  }
  .p-index-support__catch::before {
    display: none;
  }
  .p-index-support__desc {
    margin-bottom: 9.6vw;
    font-size: 14px;
    line-height: 1.86;
    text-align: left;
  }
  .p-index-support__txtbox {
    padding: 5.87vw 6.4vw 6.67vw;
  }
  .p-index-support__txtbox-ttl {
    margin-bottom: 2.67vw;
  }
  .p-index-support__txtbox-desc {
    font-weight: 500;
    line-height: 1.57;
  }
  .p-index-support__txtbox-desc .kome {
    display: block;
    margin-top: 5.33vw;
    font-weight: 400;
    text-align: left;
  }
  .p-index-lineup {
    padding: 26.67vw 0 29.33vw;
  }
  .p-index-lineup__ttl {
    margin-bottom: -2em;
  }
  .p-index-lineup__conpact {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: flex-start;
    margin-top: 22.93vw;
    padding: 9.33vw 5.33vw;
    gap: 10.13vw 0;
    border-radius: 2.67vw;
  }
  .p-index-lineup__conpact-txtbox {
    width: 100%;
  }
  .p-index-lineup__conpact-txtbox .s-lineup__ttl-maru {
    right: 0;
    left: auto;
  }
  .p-index-lineup__conpact-imgbox {
    width: 100%;
  }
  .p-index-lineup__conpact-imgbox .img {
    width: 50.67vw;
  }
  .p-index-lineup__contact {
    width: 100%;
    margin-top: 18.67vw;
  }
  .p-index-lineup__tel {
    margin-top: 2.67vw;
    font-size: 14px;
    line-height: 1.71;
  }
  .s-lineup__ttl {
    margin-bottom: 4vw;
    padding-bottom: 2.67vw;
  }
  .s-lineup__ttl-exp {
    margin-bottom: 5.33vw;
    font-size: 17px;
    line-height: 1.41;
  }
  .s-lineup__ttl-main {
    font-size: 32px;
  }
  .s-lineup__ttl-sub {
    font-size: 14px;
    line-height: 1.57;
  }
  .s-lineup__ttl-maru {
    right: -4vw;
    bottom: 5.33vw;
    width: 32vw;
    height: 32vw;
  }
  .s-lineup__ttl-maru .txt02 {
    margin-top: 1.33vw;
  }
  .s-lineup__ttl-maru--br22 {
    z-index: 0;
    top: 0;
    right: -1em !important;
    bottom: auto;
  }
  .s-lineup__ttl .sponlyimg {
    z-index: 1;
    position: relative;
    width: 40vw;
    margin: 5.33vw auto 2.67vw;
  }
  .s-lineup__list {
    margin-bottom: 2.67vw;
    gap: 2.4vw;
  }
  .s-lineup__list-item {
    padding: 1.07vw 2.13vw;
    border-radius: 0.8vw;
  }
  .s-lineup__table {
    margin-bottom: 5.33vw;
  }
  .s-lineup__cau {
    margin-top: 2.67vw;
    margin-left: 1em;
    font-size: 10px;
    line-height: 1.4;
    text-indent: -1em;
  }
  .s-lineup__btn {
    margin: 9.6vw auto 0;
  }
  .s-lineup__btn--conpact {
    margin-top: 0;
  }
  .p-index-brand {
    padding: 0;
    background: none;
  }
  .p-index-brand__seller {
    display: block;
    padding: 34.67vw 0 112vw;
    background-image: url("../img/top/bg_brandsp.jpg");
    background-position: center center;
    background-position: center bottom;
    background-size: cover;
    background-repeat: no-repeat;
  }
  .p-index-brand__ttl {
    width: 49.87vw;
    margin-bottom: 9.87vw;
  }
  .p-index-brand__catch {
    width: 88.27vw;
    margin-bottom: 12.8vw;
  }
  .p-index-brand__desc {
    margin-bottom: 0;
    font-size: 14px;
    line-height: 1.71;
    letter-spacing: 0;
    text-align: left;
    text-shadow: none;
  }
  .p-index-brand__btn {
    width: 100%;
  }
  .p-index-brand__btn .c-btn01__link {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    padding-right: 0;
    padding-left: 0;
    text-align: center;
  }
  .p-index-brand__spserver {
    position: relative;
    padding: 0 0 160vw;
    background-image: url("../img/top/bg_brand_serversp.jpg");
    background-position: center center;
    background-position: center bottom;
    background-size: cover;
    background-repeat: no-repeat;
  }
  .p-index-brand__spserver .p-index-brand__btn {
    position: absolute;
    right: 0;
    bottom: 14.67vw;
    left: 0;
    width: 88%;
    margin: auto;
  }
  .p-index-shop {
    padding: 26.67vw 6.13vw 13.33vw;
  }
  .p-index-shop__ttl {
    margin-bottom: 6.4vw;
  }
  .p-index-shop__bnlist {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 4.27vw 0;
  }
  .p-index-shop__bnlist-item {
    aspect-ratio: 330/160;
    width: 100%;
  }
  .p-index-shop__bnlist-link .txtbox {
    bottom: 3.2vw;
    left: 4.8vw;
  }
  .p-index-shop__bnlist-link .txtbox .f_en {
    font-size: 20px;
  }
  .p-index-scene {
    padding: 13.33vw 0 32vw;
  }
  .p-index-scene__ttl {
    margin-bottom: 19.47vw;
  }
  .introStore-slider {
    width: 100%;
    height: 114.67vw;
  }
  .introStore-slider__images .swiper-slide {
    aspect-ratio: 157/223;
    width: 40%;
    height: auto !important;
    margin: 0 1.33vw;
    transition: width 0.8s ease 0.8s, margin 0.8s ease 0.8s;
  }
  .introStore-slider__images .swiper-slide-active {
    width: 55%;
  }
  .introStore-slider__images .swiper-slide:not(.introStore-slider__images .swiper-slide-active) {
    width: 41.87vw;
  }
  .introStore-slider__nav {
    top: 28%;
    width: 8.53vw;
    transform: translateY(-28%);
  }
  .introStore-slider__nav::before {
    width: 4.27vw;
    height: 7.2vw;
  }
  .introStore-slider__nav--prev {
    left: 5.33vw;
  }
  .introStore-slider__nav--next {
    right: 5.33vw;
  }
  .introStore-slider__viewmore {
    right: 0;
    left: 0;
    margin: auto;
  }
  .introStore-slider__texts-box {
    right: auto;
    bottom: 13.33vw;
    left: 18.67vw;
    max-width: 81.33vw;
    margin: auto;
  }
  .introStore-slider__texts {
    padding-left: 10.67vw;
  }
  .introStore-slider__texts::before {
    width: 9.07vw;
    height: 9.07vw;
    transform: rotate(90deg);
  }
  .introStore-slider__texts .introStore-text__place {
    font-size: 16px;
    transition: opacity 0.4s ease 0.8s;
  }
  .introStore-slider__texts .introStore-text__name {
    font-size: 15px;
    line-height: 1.3;
    transition: opacity 0.4s ease 0.8s;
  }
  .c-circleCarousel {
    width: 100vw;
    margin: 0 calc(50% - 50vw) 192vw;
  }
  .c-circleCarousel::before {
    top: 21.33vw;
    transform: scaleY(0.3) scaleX(0.85);
  }
  .c-circleCarousel__inner {
    transform: rotateX(50deg);
  }
  .c-circleCarousel__item {
    aspect-ratio: 369/605;
    width: 100%;
    height: auto !important;
    margin: 0 auto;
  }
  .c-circleCarousel__item.is-active .c-circleCarousel__itemInner {
    transform: scale(0.65);
  }
  .c-circleCarousel__item:not(.is-active) .c-circleCarousel__itemInner {
    transform: scale(0.2);
  }
  .c-circleCarousel__descs {
    right: 0;
    bottom: -66.67vw;
    left: 0;
    width: 85%;
    margin: auto;
  }
  .c-circleCarousel__btn {
    top: auto;
    bottom: -26.67vw;
    width: 5.33vw;
    height: 8vw;
  }
  .c-circleCarousel__btn--prev {
    left: 6%;
  }
  .c-circleCarousel__btn--next {
    right: 6%;
  }
}
@media screen and (max-width: 599px) {
  body {
    margin: 0;
  }
  .c-inner01 {
    width: 88%;
  }
}
@media screen and (max-width: 374px) {
  body {
    margin: 0;
  }
}
@media screen and (max-width: 320px) {
  body {
    margin: 0;
  }
  .l-opening__skip {
    bottom: 8vw;
  }
  .p-index-fv__imgbox {
    left: -40%;
    width: 180%;
  }
  .p-index-fv__catch {
    bottom: 32vw;
    font-size: 15px;
  }
  .p-index-fv__ttlname {
    bottom: 8vw;
    width: 48vw;
  }
}
@media screen and (min-width: 1921px) {
  html {
    font-size: 0.5208333333vw;
  }
  img {
    width: 100%;
  }
  .c-inner01 {
    width: clamp(0px, 69.01vw, 1060px) !important;
    max-width: none;
  }
}
@media screen and (min-width: 1025px) {
  .tel {
    cursor: default;
    pointer-events: none;
  }
}
@media screen {
  [hidden~=screen] {
    display: inherit;
  }
  [hidden~=screen]:not(:active):not(:focus):not(:target) {
    clip: rect(0 0 0 0) !important;
    position: absolute !important;
  }
}
@media screen and (max-width: 896px) and (max-width: 1536px) {
  .l-header__glNavBtnWp .glNavBtn--pc span {
    font-size: 1.2rem;
  }
  .l-header__pcMenu01-corpsite {
    font-size: 1.4rem;
  }
  .l-header__pcMenu02-menulist-item {
    font-size: 1.4rem;
  }
  .l-header__copy {
    font-size: 1.2rem;
  }
  .l-footer__menulist-item {
    font-size: 1.4rem;
  }
  .l-footer__corpsite {
    font-size: 1.4rem;
  }
  .c-btn01__link {
    font-size: 1.3rem;
  }
  .c-btn01__link--lineupcontact {
    font-size: 1.4rem;
  }
  .cmnTtl02 .f_en--fs50 {
    font-size: 3.6rem;
  }
  .p-index-fv__catch {
    font-size: 2rem;
  }
  .p-index-concept__ttl .f_jp {
    font-size: 4.2rem;
  }
  .p-index-concept__desc {
    font-size: 2.2rem;
  }
  .p-index-concept02__ttl {
    font-size: 2.8rem;
  }
  .p-index-concept02__desc {
    font-size: 1.4rem;
  }
  .p-index-concept02__note {
    font-size: 1.2rem;
  }
  .p-index-feature__catch-txt01 {
    font-size: 2.2rem;
  }
  .p-index-feature__catch-txt02 {
    font-size: 1.6rem;
  }
  .p-index-feature .ft_cont__ttl-txt {
    font-size: 2.4rem;
  }
  .p-index-feature .ft_cont__desc {
    font-size: 1.4rem;
  }
  .p-index-feature .ft_cont__f01list figcaption {
    font-size: 1.6rem;
  }
  .p-index-feature .ft_light__box dt {
    font-size: 1.6rem;
  }
  .p-index-bp .bpcont__ttl {
    font-size: 2rem;
  }
  .p-index-bp .bpcont__list-desc {
    font-size: 1.4rem;
  }
  .p-index-bp .bpcont__cont-desc {
    font-size: 1.4rem;
  }
  .p-index-bp .bpcont__pointlist-numbox .bpcont__list-ttl-num {
    font-size: 2rem;
  }
  .p-index-bp .bpcont__pointlist-ttl {
    font-size: 1.4rem;
  }
  .p-index-bp .bpcont__pointlist-desc {
    font-size: 1.4rem;
  }
  .p-index-bp .bpcont__movie-ttl {
    font-size: 1.6rem;
  }
  .p-index-support__catch {
    font-size: 1.8rem;
  }
  .p-index-support__desc {
    font-size: 1.4rem;
  }
  .p-index-lineup__tel {
    font-size: 1.4rem;
  }
  .s-lineup__ttl-exp {
    font-size: 1.7rem;
  }
  .s-lineup__ttl-main {
    font-size: 3.2rem;
  }
  .s-lineup__ttl-sub {
    font-size: 1.4rem;
  }
  .s-lineup__cau {
    font-size: 1rem;
  }
  .p-index-brand__desc {
    font-size: 1.4rem;
  }
  .p-index-shop__bnlist-link .txtbox .f_en {
    font-size: 2rem;
  }
  .introStore-slider__texts .introStore-text__place {
    font-size: 1.6rem;
  }
  .introStore-slider__texts .introStore-text__name {
    font-size: 1.5rem;
  }
}
@media screen and (min-width: 1501px) {
  .c-inner01 {
    width: 1060px;
  }
}
@media screen and (max-width: 320px) and (max-width: 1536px) {
  .p-index-fv__catch {
    font-size: 1.5rem;
  }
}