@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Marcellus&family=Zen+Kaku+Gothic+New&display=swap");
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
}
/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}
/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}
/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}
/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  -webkit-box-sizing: content-box;
          box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}
/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}
/* Text-level semantics
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
}
/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted; /* 2 */
}
/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}
/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}
/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}
/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}
/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none;
}
/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}
/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input { /* 1 */
  overflow: visible;
}
/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select { /* 1 */
  text-transform: none;
}
/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}
/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}
/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}
/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}
/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  -webkit-box-sizing: border-box;
          box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}
/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}
/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}
/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
  -webkit-box-sizing: border-box;
          box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}
/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}
/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}
/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}
/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}
/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}
/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}
/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}
/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none;
}
/**
 * Swiper 6.8.4
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2021 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: August 23, 2021
 */
@font-face{font-family:swiper-icons;src:url('data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA') format('woff');font-weight:400;font-style:normal}
:root{--swiper-theme-color:#007aff}
.swiper-container{margin-left:auto;margin-right:auto;position:relative;overflow:hidden;list-style:none;padding:0;z-index:1}
.swiper-container-vertical>.swiper-wrapper{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}
.swiper-wrapper{position:relative;width:100%;height:100%;z-index:1;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-transition-property:-webkit-transform;transition-property:-webkit-transform;transition-property:transform;transition-property:transform, -webkit-transform;-webkit-box-sizing:content-box;box-sizing:content-box}
.swiper-container-android .swiper-slide,.swiper-wrapper{-webkit-transform:translate3d(0px,0,0);transform:translate3d(0px,0,0)}
.swiper-container-multirow>.swiper-wrapper{-ms-flex-wrap:wrap;flex-wrap:wrap}
.swiper-container-multirow-column>.swiper-wrapper{-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}
.swiper-container-free-mode>.swiper-wrapper{-webkit-transition-timing-function:ease-out;transition-timing-function:ease-out;margin:0 auto}
.swiper-container-pointer-events{-ms-touch-action:pan-y;touch-action:pan-y}
.swiper-container-pointer-events.swiper-container-vertical{-ms-touch-action:pan-x;touch-action:pan-x}
.swiper-slide{-ms-flex-negative:0;flex-shrink:0;width:100%;height:100%;position:relative;-webkit-transition-property:-webkit-transform;transition-property:-webkit-transform;transition-property:transform;transition-property:transform, -webkit-transform}
.swiper-slide-invisible-blank{visibility:hidden}
.swiper-container-autoheight,.swiper-container-autoheight .swiper-slide{height:auto}
.swiper-container-autoheight .swiper-wrapper{-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;-webkit-transition-property:height,-webkit-transform;transition-property:height,-webkit-transform;transition-property:transform,height;transition-property:transform,height,-webkit-transform}
.swiper-container-3d{-webkit-perspective:1200px;perspective:1200px}
.swiper-container-3d .swiper-cube-shadow,.swiper-container-3d .swiper-slide,.swiper-container-3d .swiper-slide-shadow-bottom,.swiper-container-3d .swiper-slide-shadow-left,.swiper-container-3d .swiper-slide-shadow-right,.swiper-container-3d .swiper-slide-shadow-top,.swiper-container-3d .swiper-wrapper{-webkit-transform-style:preserve-3d;transform-style:preserve-3d}
.swiper-container-3d .swiper-slide-shadow-bottom,.swiper-container-3d .swiper-slide-shadow-left,.swiper-container-3d .swiper-slide-shadow-right,.swiper-container-3d .swiper-slide-shadow-top{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none;z-index:10}
.swiper-container-3d .swiper-slide-shadow-left{background-image:-webkit-gradient(linear,right top, left top,from(rgba(0,0,0,.5)),to(rgba(0,0,0,0)));background-image:linear-gradient(to left,rgba(0,0,0,.5),rgba(0,0,0,0))}
.swiper-container-3d .swiper-slide-shadow-right{background-image:-webkit-gradient(linear,left top, right top,from(rgba(0,0,0,.5)),to(rgba(0,0,0,0)));background-image:linear-gradient(to right,rgba(0,0,0,.5),rgba(0,0,0,0))}
.swiper-container-3d .swiper-slide-shadow-top{background-image:-webkit-gradient(linear,left bottom, left top,from(rgba(0,0,0,.5)),to(rgba(0,0,0,0)));background-image:linear-gradient(to top,rgba(0,0,0,.5),rgba(0,0,0,0))}
.swiper-container-3d .swiper-slide-shadow-bottom{background-image:-webkit-gradient(linear,left top, left bottom,from(rgba(0,0,0,.5)),to(rgba(0,0,0,0)));background-image:linear-gradient(to bottom,rgba(0,0,0,.5),rgba(0,0,0,0))}
.swiper-container-css-mode>.swiper-wrapper{overflow:auto;scrollbar-width:none;-ms-overflow-style:none}
.swiper-container-css-mode>.swiper-wrapper::-webkit-scrollbar{display:none}
.swiper-container-css-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:start start}
.swiper-container-horizontal.swiper-container-css-mode>.swiper-wrapper{scroll-snap-type:x mandatory}
.swiper-container-vertical.swiper-container-css-mode>.swiper-wrapper{scroll-snap-type:y mandatory}
:root{--swiper-navigation-size:44px}
.swiper-button-next,.swiper-button-prev{position:absolute;top:50%;width:calc(var(--swiper-navigation-size)/ 44 * 27);height:var(--swiper-navigation-size);margin-top:calc(0px - (var(--swiper-navigation-size)/ 2));z-index:10;cursor:pointer;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;color:var(--swiper-navigation-color,var(--swiper-theme-color))}
.swiper-button-next.swiper-button-disabled,.swiper-button-prev.swiper-button-disabled{opacity:.35;cursor:auto;pointer-events:none}
.swiper-button-next:after,.swiper-button-prev:after{font-family:swiper-icons;font-size:var(--swiper-navigation-size);letter-spacing:0;text-transform:none;font-variant:initial;line-height:1}
.swiper-button-prev,.swiper-container-rtl .swiper-button-next{left:10px;right:auto}
.swiper-button-prev:after,.swiper-container-rtl .swiper-button-next:after{content:'prev'}
.swiper-button-next,.swiper-container-rtl .swiper-button-prev{right:10px;left:auto}
.swiper-button-next:after,.swiper-container-rtl .swiper-button-prev:after{content:'next'}
.swiper-button-next.swiper-button-white,.swiper-button-prev.swiper-button-white{--swiper-navigation-color:#ffffff}
.swiper-button-next.swiper-button-black,.swiper-button-prev.swiper-button-black{--swiper-navigation-color:#000000}
.swiper-button-lock{display:none}
.swiper-pagination{position:absolute;text-align:center;-webkit-transition:.3s opacity;transition:.3s opacity;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0);z-index:10}
.swiper-pagination.swiper-pagination-hidden{opacity:0}
.swiper-container-horizontal>.swiper-pagination-bullets,.swiper-pagination-custom,.swiper-pagination-fraction{bottom:10px;left:0;width:100%}
.swiper-pagination-bullets-dynamic{overflow:hidden;font-size:0}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{-webkit-transform:scale(.33);transform:scale(.33);position:relative}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active{-webkit-transform:scale(1);transform:scale(1)}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main{-webkit-transform:scale(1);transform:scale(1)}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev{-webkit-transform:scale(.66);transform:scale(.66)}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev{-webkit-transform:scale(.33);transform:scale(.33)}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next{-webkit-transform:scale(.66);transform:scale(.66)}
.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next{-webkit-transform:scale(.33);transform:scale(.33)}
.swiper-pagination-bullet{width:8px;height:8px;display:inline-block;border-radius:50%;background:#000;opacity:.2}
button.swiper-pagination-bullet{border:none;margin:0;padding:0;-webkit-box-shadow:none;box-shadow:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}
.swiper-pagination-clickable .swiper-pagination-bullet{cursor:pointer}
.swiper-pagination-bullet:only-child{display:none!important}
.swiper-pagination-bullet-active{opacity:1;background:var(--swiper-pagination-color,var(--swiper-theme-color))}
.swiper-container-vertical>.swiper-pagination-bullets{right:10px;top:50%;-webkit-transform:translate3d(0px,-50%,0);transform:translate3d(0px,-50%,0)}
.swiper-container-vertical>.swiper-pagination-bullets .swiper-pagination-bullet{margin:6px 0;display:block}
.swiper-container-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic{top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%);width:8px}
.swiper-container-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{display:inline-block;-webkit-transition:.2s transform,.2s top;transition:.2s transform,.2s top}
.swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet{margin:0 4px}
.swiper-container-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic{left:50%;-webkit-transform:translateX(-50%);transform:translateX(-50%);white-space:nowrap}
.swiper-container-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{-webkit-transition:.2s transform,.2s left;transition:.2s transform,.2s left}
.swiper-container-horizontal.swiper-container-rtl>.swiper-pagination-bullets-dynamic .swiper-pagination-bullet{-webkit-transition:.2s transform,.2s right;transition:.2s transform,.2s right}
.swiper-pagination-progressbar{background:rgba(0,0,0,.25);position:absolute}
.swiper-pagination-progressbar .swiper-pagination-progressbar-fill{background:var(--swiper-pagination-color,var(--swiper-theme-color));position:absolute;left:0;top:0;width:100%;height:100%;-webkit-transform:scale(0);transform:scale(0);-webkit-transform-origin:left top;transform-origin:left top}
.swiper-container-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill{-webkit-transform-origin:right top;transform-origin:right top}
.swiper-container-horizontal>.swiper-pagination-progressbar,.swiper-container-vertical>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite{width:100%;height:4px;left:0;top:0}
.swiper-container-horizontal>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,.swiper-container-vertical>.swiper-pagination-progressbar{width:4px;height:100%;left:0;top:0}
.swiper-pagination-white{--swiper-pagination-color:#ffffff}
.swiper-pagination-black{--swiper-pagination-color:#000000}
.swiper-pagination-lock{display:none}
.swiper-scrollbar{border-radius:10px;position:relative;-ms-touch-action:none;background:rgba(0,0,0,.1)}
.swiper-container-horizontal>.swiper-scrollbar{position:absolute;left:1%;bottom:3px;z-index:50;height:5px;width:98%}
.swiper-container-vertical>.swiper-scrollbar{position:absolute;right:3px;top:1%;z-index:50;width:5px;height:98%}
.swiper-scrollbar-drag{height:100%;width:100%;position:relative;background:rgba(0,0,0,.5);border-radius:10px;left:0;top:0}
.swiper-scrollbar-cursor-drag{cursor:move}
.swiper-scrollbar-lock{display:none}
.swiper-zoom-container{width:100%;height:100%;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;text-align:center}
.swiper-zoom-container>canvas,.swiper-zoom-container>img,.swiper-zoom-container>svg{max-width:100%;max-height:100%;-o-object-fit:contain;object-fit:contain}
.swiper-slide-zoomed{cursor:move}
.swiper-lazy-preloader{width:42px;height:42px;position:absolute;left:50%;top:50%;margin-left:-21px;margin-top:-21px;z-index:10;-webkit-transform-origin:50%;transform-origin:50%;-webkit-animation:swiper-preloader-spin 1s infinite linear;animation:swiper-preloader-spin 1s infinite linear;-webkit-box-sizing:border-box;box-sizing:border-box;border:4px solid var(--swiper-preloader-color,var(--swiper-theme-color));border-radius:50%;border-top-color:transparent}
.swiper-lazy-preloader-white{--swiper-preloader-color:#fff}
.swiper-lazy-preloader-black{--swiper-preloader-color:#000}
@-webkit-keyframes swiper-preloader-spin{100%{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}
@keyframes swiper-preloader-spin{100%{-webkit-transform:rotate(360deg);transform:rotate(360deg)}}
.swiper-container .swiper-notification{position:absolute;left:0;top:0;pointer-events:none;opacity:0;z-index:-1000}
.swiper-container-fade.swiper-container-free-mode .swiper-slide{-webkit-transition-timing-function:ease-out;transition-timing-function:ease-out}
.swiper-container-fade .swiper-slide{pointer-events:none;-webkit-transition-property:opacity;transition-property:opacity}
.swiper-container-fade .swiper-slide .swiper-slide{pointer-events:none}
.swiper-container-fade .swiper-slide-active,.swiper-container-fade .swiper-slide-active .swiper-slide-active{pointer-events:auto}
.swiper-container-cube{overflow:visible}
.swiper-container-cube .swiper-slide{pointer-events:none;-webkit-backface-visibility:hidden;backface-visibility:hidden;z-index:1;visibility:hidden;-webkit-transform-origin:0 0;transform-origin:0 0;width:100%;height:100%}
.swiper-container-cube .swiper-slide .swiper-slide{pointer-events:none}
.swiper-container-cube.swiper-container-rtl .swiper-slide{-webkit-transform-origin:100% 0;transform-origin:100% 0}
.swiper-container-cube .swiper-slide-active,.swiper-container-cube .swiper-slide-active .swiper-slide-active{pointer-events:auto}
.swiper-container-cube .swiper-slide-active,.swiper-container-cube .swiper-slide-next,.swiper-container-cube .swiper-slide-next+.swiper-slide,.swiper-container-cube .swiper-slide-prev{pointer-events:auto;visibility:visible}
.swiper-container-cube .swiper-slide-shadow-bottom,.swiper-container-cube .swiper-slide-shadow-left,.swiper-container-cube .swiper-slide-shadow-right,.swiper-container-cube .swiper-slide-shadow-top{z-index:0;-webkit-backface-visibility:hidden;backface-visibility:hidden}
.swiper-container-cube .swiper-cube-shadow{position:absolute;left:0;bottom:0px;width:100%;height:100%;opacity:.6;z-index:0}
.swiper-container-cube .swiper-cube-shadow:before{content:'';background:#000;position:absolute;left:0;top:0;bottom:0;right:0;-webkit-filter:blur(50px);filter:blur(50px)}
.swiper-container-flip{overflow:visible}
.swiper-container-flip .swiper-slide{pointer-events:none;-webkit-backface-visibility:hidden;backface-visibility:hidden;z-index:1}
.swiper-container-flip .swiper-slide .swiper-slide{pointer-events:none}
.swiper-container-flip .swiper-slide-active,.swiper-container-flip .swiper-slide-active .swiper-slide-active{pointer-events:auto}
.swiper-container-flip .swiper-slide-shadow-bottom,.swiper-container-flip .swiper-slide-shadow-left,.swiper-container-flip .swiper-slide-shadow-right,.swiper-container-flip .swiper-slide-shadow-top{z-index:0;-webkit-backface-visibility:hidden;backface-visibility:hidden}
.js-inview[data-inview=fade] {
  opacity: 0;
  -webkit-transition: opacity 1s;
  transition: opacity 1s;
}
.js-inview[data-inview=fade].is-inview {
  opacity: 1;
}
.js-inview[data-inview=fade-top] {
  opacity: 0;
  -webkit-transition: opacity 1s, -webkit-transform 1s;
  transition: opacity 1s, -webkit-transform 1s;
  transition: opacity 1s, transform 1s;
  transition: opacity 1s, transform 1s, -webkit-transform 1s;
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
}
.js-inview[data-inview=fade-top].is-inview {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.js-inview[data-inview=fade-left] {
  opacity: 0;
  -webkit-transition: opacity 0.5s, -webkit-transform 0.5s;
  transition: opacity 0.5s, -webkit-transform 0.5s;
  transition: opacity 0.5s, transform 0.5s;
  transition: opacity 0.5s, transform 0.5s, -webkit-transform 0.5s;
  -webkit-transform: translateX(-30px);
          transform: translateX(-30px);
}
.js-inview[data-inview=fade-left].is-inview {
  opacity: 1;
  -webkit-transform: translateX(0);
          transform: translateX(0);
}
.js-inview[data-inview=fade-right] {
  opacity: 0;
  -webkit-transition: opacity 0.5s, -webkit-transform 0.5s;
  transition: opacity 0.5s, -webkit-transform 0.5s;
  transition: opacity 0.5s, transform 0.5s;
  transition: opacity 0.5s, transform 0.5s, -webkit-transform 0.5s;
  -webkit-transform: translateX(30px);
          transform: translateX(30px);
}
.js-inview[data-inview=fade-right].is-inview {
  opacity: 1;
  -webkit-transform: translateX(0);
          transform: translateX(0);
}
.js-inview[data-inview=fade-bottom] {
  opacity: 0;
  -webkit-transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, transform 0.8s;
  transition: opacity 0.8s, transform 0.8s, -webkit-transform 0.8s;
  -webkit-transform: translateY(-30px);
          transform: translateY(-30px);
}
.js-inview[data-inview=fade-bottom].is-inview {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.js-inview[data-inview=btn] a::before,
.js-inview[data-inview=btn] button::before {
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: left top;
          transform-origin: left top;
}
.js-inview[data-inview=btn] span {
  opacity: 0;
  -webkit-transition: opacity 0.5s 0.3s, -webkit-transform 0.5s 0.3s;
  transition: opacity 0.5s 0.3s, -webkit-transform 0.5s 0.3s;
  transition: opacity 0.5s 0.3s, transform 0.5s 0.3s;
  transition: opacity 0.5s 0.3s, transform 0.5s 0.3s, -webkit-transform 0.5s 0.3s;
  -webkit-transform: translateY(10px);
          transform: translateY(10px);
}
.js-inview[data-inview=btn] i {
  opacity: 0;
  -webkit-transition: opacity 0.5s 0.3s, -webkit-transform 0.5s 0.3s;
  transition: opacity 0.5s 0.3s, -webkit-transform 0.5s 0.3s;
  transition: opacity 0.5s 0.3s, transform 0.5s 0.3s;
  transition: opacity 0.5s 0.3s, transform 0.5s 0.3s, -webkit-transform 0.5s 0.3s;
  -webkit-transform: translateY(10px);
          transform: translateY(10px);
}
.js-inview[data-inview=btn].is-inview a::before,
.js-inview[data-inview=btn].is-inview button::before {
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
}
.js-inview[data-inview=btn].is-inview span {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.js-inview[data-inview=btn].is-inview i {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.js-inview[data-inview=btn-border] a::after,
.js-inview[data-inview=btn-border] button::after {
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: left top;
          transform-origin: left top;
}
.js-inview[data-inview=btn-border] span {
  opacity: 0;
  -webkit-transition: opacity 0.8s 0.3s, -webkit-transform 0.5s 0.3s;
  transition: opacity 0.8s 0.3s, -webkit-transform 0.5s 0.3s;
  transition: opacity 0.8s 0.3s, transform 0.5s 0.3s;
  transition: opacity 0.8s 0.3s, transform 0.5s 0.3s, -webkit-transform 0.5s 0.3s;
  -webkit-transform: translateY(10px);
          transform: translateY(10px);
}
.js-inview[data-inview=btn-border].is-inview a::after,
.js-inview[data-inview=btn-border].is-inview button::after {
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
}
.js-inview[data-inview=btn-border].is-inview span {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.js-inview[data-inview=bg]::after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
  -webkit-transform-origin: right top;
          transform-origin: right top;
}
.js-inview[data-inview=bg].is-inview::after {
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
}
.js-inview[data-inview=bg-white]::after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  background-color: #fff;
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
  -webkit-transform-origin: right top;
          transform-origin: right top;
}
.js-inview[data-inview=bg-white].is-inview::after {
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
}
.js-inview[data-inview=bg-scale]::before {
  -webkit-transition: -webkit-transform 0.8s;
  transition: -webkit-transform 0.8s;
  transition: transform 0.8s;
  transition: transform 0.8s, -webkit-transform 0.8s;
  -webkit-transform: translate(-50%, -50%) scale(0.5);
          transform: translate(-50%, -50%) scale(0.5);
  -webkit-transform-origin: center center;
          transform-origin: center center;
}
.js-inview[data-inview=bg-scale].is-inview::before {
  -webkit-transform: translate(-50%, -50%) scale(1);
          transform: translate(-50%, -50%) scale(1);
}
.js-inview-photo[data-inview=scale-small] {
  -webkit-transition: -webkit-transform 1s;
  transition: -webkit-transform 1s;
  transition: transform 1s;
  transition: transform 1s, -webkit-transform 1s;
  -webkit-transform: scale(1.5);
          transform: scale(1.5);
}
.is-inview .js-inview-photo[data-inview=scale-small] {
  -webkit-transform: scale(1);
          transform: scale(1);
}
.js-inview-photo-img[data-inview=scale-small] {
  -webkit-transition: -webkit-transform 1s;
  transition: -webkit-transform 1s;
  transition: transform 1s;
  transition: transform 1s, -webkit-transform 1s;
  -webkit-transform: translateX(-50%) scale(1.5);
          transform: translateX(-50%) scale(1.5);
}
.is-inview .js-inview-photo-img[data-inview=scale-small] {
  -webkit-transform: translateX(-50%) scale(1);
          transform: translateX(-50%) scale(1);
}
.js-inview-eachItem[data-inview=fade] {
  opacity: 0;
  -webkit-transition: opacity 0.8s;
  transition: opacity 0.8s;
}
.js-inview-eachItem[data-inview=fade].is-inview {
  opacity: 1;
}
.js-inview-eachItem[data-inview=fade-top] {
  opacity: 0;
  -webkit-transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, transform 0.8s;
  transition: opacity 0.8s, transform 0.8s, -webkit-transform 0.8s;
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
}
.js-inview-eachItem[data-inview=fade-top].is-inview {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.js-inview-eachItem[data-inview=fade-bottom] {
  opacity: 0;
  -webkit-transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, transform 0.8s;
  transition: opacity 0.8s, transform 0.8s, -webkit-transform 0.8s;
  -webkit-transform: translateY(-30px);
          transform: translateY(-30px);
}
.js-inview-eachItem[data-inview=fade-bottom].is-inview {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.js-inview-eachItem[data-inview=fade-right] {
  opacity: 0;
  -webkit-transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, transform 0.8s;
  transition: opacity 0.8s, transform 0.8s, -webkit-transform 0.8s;
  -webkit-transform: translateX(30px);
          transform: translateX(30px);
}
.js-inview-eachItem[data-inview=fade-right].is-inview {
  opacity: 1;
  -webkit-transform: translateX(0);
          transform: translateX(0);
}
.js-inview-eachItem[data-inview=btn] a::before,
.js-inview-eachItem[data-inview=btn] button::before {
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: left top;
          transform-origin: left top;
}
.js-inview-eachItem[data-inview=btn] span {
  opacity: 0;
  -webkit-transition: opacity 0.8s 0.3s, -webkit-transform 0.5s 0.3s;
  transition: opacity 0.8s 0.3s, -webkit-transform 0.5s 0.3s;
  transition: opacity 0.8s 0.3s, transform 0.5s 0.3s;
  transition: opacity 0.8s 0.3s, transform 0.5s 0.3s, -webkit-transform 0.5s 0.3s;
  -webkit-transform: translateY(10px);
          transform: translateY(10px);
}
.js-inview-eachItem[data-inview=btn].is-inview a::before,
.js-inview-eachItem[data-inview=btn].is-inview button::before {
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
}
.js-inview-eachItem[data-inview=btn].is-inview span {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.js-inview-eachItem[data-inview=btn-border] a::after,
.js-inview-eachItem[data-inview=btn-border] button::after {
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: left top;
          transform-origin: left top;
}
.js-inview-eachItem[data-inview=btn-border] span {
  opacity: 0;
  -webkit-transition: opacity 0.8s 0.3s, -webkit-transform 0.5s 0.3s;
  transition: opacity 0.8s 0.3s, -webkit-transform 0.5s 0.3s;
  transition: opacity 0.8s 0.3s, transform 0.5s 0.3s;
  transition: opacity 0.8s 0.3s, transform 0.5s 0.3s, -webkit-transform 0.5s 0.3s;
  -webkit-transform: translateY(10px);
          transform: translateY(10px);
}
.js-inview-eachItem[data-inview=btn-border].is-inview a::after,
.js-inview-eachItem[data-inview=btn-border].is-inview button::after {
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
}
.js-inview-eachItem[data-inview=btn-border].is-inview span {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.js-inview-eachItem[data-inview=list-border]::before {
  -webkit-transition: -webkit-transform 0.8s;
  transition: -webkit-transform 0.8s;
  transition: transform 0.8s;
  transition: transform 0.8s, -webkit-transform 0.8s;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: left top;
          transform-origin: left top;
}
.js-inview-eachItem[data-inview=list-border] span,
.js-inview-eachItem[data-inview=list-border] figure,
.js-inview-eachItem[data-inview=list-border] a {
  opacity: 0;
  -webkit-transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, transform 0.8s;
  transition: opacity 0.8s, transform 0.8s, -webkit-transform 0.8s;
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
}
.js-inview-eachItem[data-inview=list-border] i {
  opacity: 0;
  -webkit-transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, transform 0.8s;
  transition: opacity 0.8s, transform 0.8s, -webkit-transform 0.8s;
  -webkit-transform: translateX(-20px) rotate(45deg);
          transform: translateX(-20px) rotate(45deg);
}
.js-inview-eachItem[data-inview=list-border].is-inview::before {
  -webkit-transform: scale(1);
          transform: scale(1);
}
.js-inview-eachItem[data-inview=list-border].is-inview span,
.js-inview-eachItem[data-inview=list-border].is-inview figure,
.js-inview-eachItem[data-inview=list-border].is-inview a {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.js-inview-eachItem[data-inview=list-border].is-inview i {
  opacity: 1;
  -webkit-transform: translateX(-10px) rotate(45deg);
          transform: translateX(-10px) rotate(45deg);
}
.js-inview-eachItem-fast[data-inview=fade-top] {
  opacity: 0;
  -webkit-transition: opacity 0.5s, -webkit-transform 0.5s;
  transition: opacity 0.5s, -webkit-transform 0.5s;
  transition: opacity 0.5s, transform 0.5s;
  transition: opacity 0.5s, transform 0.5s, -webkit-transform 0.5s;
  -webkit-transform: translateY(10px);
          transform: translateY(10px);
}
.js-inview-eachItem-fast[data-inview=fade-top].is-inview {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.js-inview-eachItem-delay[data-inview=fade] {
  opacity: 0;
  -webkit-transition: -webkit-transform 0.8s;
  transition: -webkit-transform 0.8s;
  transition: transform 0.8s;
  transition: transform 0.8s, -webkit-transform 0.8s;
}
.js-inview-eachItem-delay[data-inview=fade].is-inview {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.js-inview-eachItem-delay[data-inview=fade-top] {
  opacity: 0;
  -webkit-transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, transform 0.8s;
  transition: opacity 0.8s, transform 0.8s, -webkit-transform 0.8s;
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
}
.js-inview-eachItem-delay[data-inview=fade-top].is-inview {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.js-inview-eachItem-delay[data-inview=fade-right] {
  opacity: 0;
  -webkit-transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, transform 0.8s;
  transition: opacity 0.8s, transform 0.8s, -webkit-transform 0.8s;
  -webkit-transform: translateX(30px);
          transform: translateX(30px);
}
.js-inview-eachItem-delay[data-inview=fade-right].is-inview {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.js-inview-eachItem-delay[data-inview=fade-bottom] {
  opacity: 0;
  -webkit-transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, -webkit-transform 0.8s;
  transition: opacity 0.8s, transform 0.8s;
  transition: opacity 0.8s, transform 0.8s, -webkit-transform 0.8s;
  -webkit-transform: translateY(-30px);
          transform: translateY(-30px);
}
.js-inview-eachItem-delay[data-inview=fade-bottom].is-inview {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.js-inview-all[data-inview=btn] a::before,
.js-inview-all[data-inview=btn] button::before {
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: left top;
          transform-origin: left top;
}
.js-inview-all[data-inview=btn] span {
  opacity: 0;
  -webkit-transition: opacity 0.8s 0.3s, -webkit-transform 0.5s 0.3s;
  transition: opacity 0.8s 0.3s, -webkit-transform 0.5s 0.3s;
  transition: opacity 0.8s 0.3s, transform 0.5s 0.3s;
  transition: opacity 0.8s 0.3s, transform 0.5s 0.3s, -webkit-transform 0.5s 0.3s;
  -webkit-transform: translateY(10px);
          transform: translateY(10px);
}
.js-inview-all[data-inview=btn].is-inview a::before,
.js-inview-all[data-inview=btn].is-inview button::before {
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
}
.js-inview-all[data-inview=btn].is-inview span {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.js-inview-all[data-inview=btn-border] a::after,
.js-inview-all[data-inview=btn-border] button::after {
  -webkit-transition: -webkit-transform 0.4s;
  transition: -webkit-transform 0.4s;
  transition: transform 0.4s;
  transition: transform 0.4s, -webkit-transform 0.4s;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: left top;
          transform-origin: left top;
}
.js-inview-all[data-inview=btn-border] span {
  opacity: 0;
  -webkit-transition: opacity 0.8s 0.3s, -webkit-transform 0.5s 0.3s;
  transition: opacity 0.8s 0.3s, -webkit-transform 0.5s 0.3s;
  transition: opacity 0.8s 0.3s, transform 0.5s 0.3s;
  transition: opacity 0.8s 0.3s, transform 0.5s 0.3s, -webkit-transform 0.5s 0.3s;
  -webkit-transform: translateY(10px);
          transform: translateY(10px);
}
.js-inview-all[data-inview=btn-border].is-inview a::after,
.js-inview-all[data-inview=btn-border].is-inview button::after {
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
}
.js-inview-all[data-inview=btn-border].is-inview span {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
_:-ms-lang(x)::-ms-backdrop,
.js-inview-photo[data-inview=scale-small] {
  transform: scale(1);
}
_:-ms-lang(x)::-ms-backdrop,
.js-inview-photo-img[data-inview=scale-small] {
  transform: translateX(-50%) scale(1);
}
/**
 * Custom media queries
 * @example
 * @media (--mobile) {
 *    styles for mobile viewport
 * }
 */
/**
 * for mobile viewoport
 */
/**
 * text ellipsis for block multiline
 */
/*
 unsupport IE, Edge, Fx

@mixin text-ellipsis-block($rows) {
  display: box;
  box-orient: vertical;
  line-clamp: $rows;
  overflow: hidden;
}
*/
/**
 * element size
 */
/**
 * position layout
 */
/**
 * images
 */
/* == @import "../node_modules/normalize.css/normalize.css"; */
html.is-hidden {
  position: fixed;
  right: 0;
  left: 0;
  overflow: hidden;
}
html::-webkit-scrollbar {
  display: none;
}
body {
  font-family: "hiragino-mincho-pron", sans-serif;
  font-size: 1.6rem;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0;
}
a {
  color: #000;
  text-decoration: none;
}
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
h1,
h2,
h3,
h4,
h5,
h6,
div,
dl,
dt,
dd,
p {
  padding: 0;
  margin: 0;
}
ul,
ol,
li {
  padding: 0;
  margin: 0;
}
li {
  list-style: none;
}
img {
  vertical-align: bottom;
}
figure {
  padding: 0;
  margin: 0;
}
input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button {
  -webkit-appearance: none;
          appearance: none;
  margin: 0;
}
input[type=number] {
  -webkit-appearance: textfield;
     -moz-appearance: textfield;
          appearance: textfield;
}
.l-main {
  line-height: 1.2;
}
svg,
img {
  max-width: 100%;
}
html {
  scroll-behavior: smooth;
  background-color: #E8EAEA;
}
html figure img {
  width: 100%;
  height: 100%;
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
}
html .n-text {
  font-size: 1.5rem;
  color: #fff;
  font-family: "hiragino-mincho-pron", sans-serif;
  font-weight: 400;
  line-height: 200%;
  letter-spacing: 0.05em;
}
body.is-fixed {
  overflow: hidden;
  -ms-touch-action: none;
      touch-action: none;
}
.swiper-wrapper {
  -webkit-transition-timing-function: linear;
          transition-timing-function: linear;
}
.grecaptcha-badge {
  z-index: 1;
}
*, ::before, ::after{
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}
::backdrop{
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}
/*! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com */
/*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/
*,
::before,
::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box; /* 1 */
  border-width: 0; /* 2 */
  border-style: solid; /* 2 */
  border-color: #e5e7eb; /* 2 */
}
::before,
::after {
  --tw-content: '';
}
/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
5. Use the user's configured `sans` font-feature-settings by default.
6. Use the user's configured `sans` font-variation-settings by default.
7. Disable tap highlights on iOS
*/
html,
:host {
  line-height: 1.5; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -moz-tab-size: 4; /* 3 */
  -o-tab-size: 4;
     tab-size: 4; /* 3 */
  font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; /* 4 */
  -webkit-font-feature-settings: normal;
          font-feature-settings: normal; /* 5 */
  font-variation-settings: normal; /* 6 */
  -webkit-tap-highlight-color: transparent; /* 7 */
}
/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/
body {
  margin: 0; /* 1 */
  line-height: inherit; /* 2 */
}
/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/
hr {
  height: 0; /* 1 */
  color: inherit; /* 2 */
  border-top-width: 1px; /* 3 */
}
/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/
abbr:where([title]) {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}
/*
Remove the default font size and weight for headings.
*/
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
}
/*
Reset links to optimize for opt-in styling instead of opt-out.
*/
a {
  color: inherit;
  text-decoration: inherit;
}
/*
Add the correct font weight in Edge and Safari.
*/
b,
strong {
  font-weight: bolder;
}
/*
1. Use the user's configured `mono` font-family by default.
2. Use the user's configured `mono` font-feature-settings by default.
3. Use the user's configured `mono` font-variation-settings by default.
4. Correct the odd `em` font sizing in all browsers.
*/
code,
kbd,
samp,
pre {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; /* 1 */
  -webkit-font-feature-settings: normal;
          font-feature-settings: normal; /* 2 */
  font-variation-settings: normal; /* 3 */
  font-size: 1em; /* 4 */
}
/*
Add the correct font size in all browsers.
*/
small {
  font-size: 80%;
}
/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}
/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/
table {
  text-indent: 0; /* 1 */
  border-color: inherit; /* 2 */
  border-collapse: collapse; /* 3 */
}
/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  -webkit-font-feature-settings: inherit;
          font-feature-settings: inherit; /* 1 */
  font-variation-settings: inherit; /* 1 */
  font-size: 100%; /* 1 */
  font-weight: inherit; /* 1 */
  line-height: inherit; /* 1 */
  letter-spacing: inherit; /* 1 */
  color: inherit; /* 1 */
  margin: 0; /* 2 */
  padding: 0; /* 3 */
}
/*
Remove the inheritance of text transform in Edge and Firefox.
*/
button,
select {
  text-transform: none;
}
/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/
button,
input:where([type='button']),
input:where([type='reset']),
input:where([type='submit']) {
  -webkit-appearance: button; /* 1 */
  background-color: transparent; /* 2 */
  background-image: none; /* 2 */
}
/*
Use the modern Firefox focus style for all focusable elements.
*/
:-moz-focusring {
  outline: auto;
}
/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/
:-moz-ui-invalid {
  box-shadow: none;
}
/*
Add the correct vertical alignment in Chrome and Firefox.
*/
progress {
  vertical-align: baseline;
}
/*
Correct the cursor style of increment and decrement buttons in Safari.
*/
::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}
/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/
[type='search'] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}
/*
Remove the inner padding in Chrome and Safari on macOS.
*/
::-webkit-search-decoration {
  -webkit-appearance: none;
}
/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}
/*
Add the correct display in Chrome and Safari.
*/
summary {
  display: list-item;
}
/*
Removes the default spacing and border for appropriate elements.
*/
blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}
fieldset {
  margin: 0;
  padding: 0;
}
legend {
  padding: 0;
}
ol,
ul,
menu {
  list-style: none;
  margin: 0;
  padding: 0;
}
/*
Reset default styling for dialogs.
*/
dialog {
  padding: 0;
}
/*
Prevent resizing textareas horizontally by default.
*/
textarea {
  resize: vertical;
}
/*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/
input::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}
input::-moz-placeholder, textarea::-moz-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}
input::-ms-input-placeholder, textarea::-ms-input-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}
input::placeholder,
textarea::placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}
/*
Set the default cursor for buttons.
*/
button,
[role="button"] {
  cursor: pointer;
}
/*
Make sure disabled buttons don't get the pointer cursor.
*/
:disabled {
  cursor: default;
}
/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
   This can trigger a poorly considered lint error in some tools but is included by design.
*/
img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
  display: block; /* 1 */
  vertical-align: middle; /* 2 */
}
/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/
img,
video {
  max-width: 100%;
  height: auto;
}
/* Make elements with the HTML hidden attribute stay hidden by default */
[hidden]:where(:not([hidden="until-found"])) {
  display: none;
}
.fixed{
  position: fixed;
}
.absolute{
  position: absolute;
}
.relative{
  position: relative;
}
.bottom-\[-6rem\]{
  bottom: -6rem;
}
.bottom-\[3\.4rem\]{
  bottom: 3.4rem;
}
.left-0{
  left: 0px;
}
.left-1\/2{
  left: 50%;
}
.left-\[1\.4rem\]{
  left: 1.4rem;
}
.left-\[19\.7rem\]{
  left: 19.7rem;
}
.left-\[31\.1rem\]{
  left: 31.1rem;
}
.left-\[34\.9rem\]{
  left: 34.9rem;
}
.left-\[43\.2rem\]{
  left: 43.2rem;
}
.left-\[50\%\]{
  left: 50%;
}
.left-\[56rem\]{
  left: 56rem;
}
.left-\[85\.5rem\]{
  left: 85.5rem;
}
.right-\[3rem\]{
  right: 3rem;
}
.top-0{
  top: 0px;
}
.top-1\/2{
  top: 50%;
}
.top-\[-12rem\]{
  top: -12rem;
}
.top-\[-14\.5rem\]{
  top: -14.5rem;
}
.top-\[-16rem\]{
  top: -16rem;
}
.top-\[-3rem\]{
  top: -3rem;
}
.top-\[110\.5rem\]{
  top: 110.5rem;
}
.top-\[164rem\]{
  top: 164rem;
}
.top-\[182rem\]{
  top: 182rem;
}
.top-\[18rem\]{
  top: 18rem;
}
.top-\[253rem\]{
  top: 253rem;
}
.top-\[30rem\]{
  top: 30rem;
}
.top-\[35\.9rem\]{
  top: 35.9rem;
}
.top-\[50\%\]{
  top: 50%;
}
.z-\[-1\]{
  z-index: -1;
}
.z-\[1\]{
  z-index: 1;
}
.z-\[2\]{
  z-index: 2;
}
.mx-auto{
  margin-left: auto;
  margin-right: auto;
}
.mt-\[-1px\]{
  margin-top: -1px;
}
.mt-\[-30\.5rem\]{
  margin-top: -30.5rem;
}
.mt-\[12rem\]{
  margin-top: 12rem;
}
.mt-\[25\.3rem\]{
  margin-top: 25.3rem;
}
.mt-\[4rem\]{
  margin-top: 4rem;
}
.mt-\[50rem\]{
  margin-top: 50rem;
}
.mt-\[57\.3rem\]{
  margin-top: 57.3rem;
}
.mt-\[5rem\]{
  margin-top: 5rem;
}
.mt-\[61\.7rem\]{
  margin-top: 61.7rem;
}
.block{
  display: block;
}
.flex{
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.grid{
  display: -ms-grid;
  display: grid;
}
.contents{
  display: contents;
}
.hidden{
  display: none;
}
.h-\[\.6rem\]{
  height: .6rem;
}
.h-\[\.8rem\]{
  height: .8rem;
}
.h-\[1\.2rem\]{
  height: 1.2rem;
}
.h-\[1\.3rem\]{
  height: 1.3rem;
}
.h-\[1\.8rem\]{
  height: 1.8rem;
}
.h-\[10\.2rem\]{
  height: 10.2rem;
}
.h-\[18\.8rem\]{
  height: 18.8rem;
}
.h-\[1rem\]{
  height: 1rem;
}
.h-\[2\.5rem\]{
  height: 2.5rem;
}
.h-\[25\.2rem\]{
  height: 25.2rem;
}
.h-\[2rem\]{
  height: 2rem;
}
.h-\[30\.7rem\]{
  height: 30.7rem;
}
.h-\[31\.3rem\]{
  height: 31.3rem;
}
.h-\[32\.2rem\]{
  height: 32.2rem;
}
.h-\[35\.2rem\]{
  height: 35.2rem;
}
.h-\[41\.8rem\]{
  height: 41.8rem;
}
.h-\[45\.6rem\]{
  height: 45.6rem;
}
.h-\[6\.6rem\]{
  height: 6.6rem;
}
.h-\[69\.1rem\]{
  height: 69.1rem;
}
.h-dvh{
  height: 100dvh;
}
.w-\[\.6rem\]{
  width: .6rem;
}
.w-\[\.8rem\]{
  width: .8rem;
}
.w-\[1\.2rem\]{
  width: 1.2rem;
}
.w-\[1\.3rem\]{
  width: 1.3rem;
}
.w-\[1\.7rem\]{
  width: 1.7rem;
}
.w-\[1\.8rem\]{
  width: 1.8rem;
}
.w-\[112rem\]{
  width: 112rem;
}
.w-\[114\.2rem\]{
  width: 114.2rem;
}
.w-\[13\.8rem\]{
  width: 13.8rem;
}
.w-\[17\.2rem\]{
  width: 17.2rem;
}
.w-\[2\.5rem\]{
  width: 2.5rem;
}
.w-\[21\.8rem\]{
  width: 21.8rem;
}
.w-\[24rem\]{
  width: 24rem;
}
.w-\[27\.8rem\]{
  width: 27.8rem;
}
.w-\[2rem\]{
  width: 2rem;
}
.w-\[33\.4rem\]{
  width: 33.4rem;
}
.w-\[46rem\]{
  width: 46rem;
}
.w-\[52\.7rem\]{
  width: 52.7rem;
}
.w-\[59\.4rem\]{
  width: 59.4rem;
}
.w-\[6\.6rem\]{
  width: 6.6rem;
}
.w-\[81rem\]{
  width: 81rem;
}
.w-\[90\.8rem\]{
  width: 90.8rem;
}
.w-\[90rem\]{
  width: 90rem;
}
.w-\[97\.1rem\]{
  width: 97.1rem;
}
.w-fit{
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.w-full{
  width: 100%;
}
.flex-shrink{
  -ms-flex-negative: 1;
      flex-shrink: 1;
}
.flex-shrink-0{
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.translate-x-\[-50\%\]{
  --tw-translate-x: -50%;
  -webkit-transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
          transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.translate-y-\[-50\%\]{
  --tw-translate-y: -50%;
  -webkit-transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
          transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.translate-y-\[100\%\]{
  --tw-translate-y: 100%;
  -webkit-transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
          transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.transform{
  -webkit-transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
          transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.flex-col{
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.items-start{
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.items-center{
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.justify-center{
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.gap-\[\.8rem\]{
  gap: .8rem;
}
.gap-\[16\.2rem\]{
  gap: 16.2rem;
}
.gap-\[2\.4rem\]{
  gap: 2.4rem;
}
.gap-\[3\.6rem\]{
  gap: 3.6rem;
}
.gap-\[4\.2rem\]{
  gap: 4.2rem;
}
.gap-\[4rem\]{
  gap: 4rem;
}
.gap-\[5\.2rem\]{
  gap: 5.2rem;
}
.overflow-hidden{
  overflow: hidden;
}
.whitespace-nowrap{
  white-space: nowrap;
}
.rounded-\[9999px\]{
  border-radius: 9999px;
}
.border{
  border-width: 1px;
}
.border-b-\[1px\]{
  border-bottom-width: 1px;
}
.border-\[\#fff\]{
  --tw-border-opacity: 1;
  border-color: rgb(255 255 255 / var(--tw-border-opacity, 1));
}
.bg-\[\#28526C\]{
  --tw-bg-opacity: 1;
  background-color: rgb(40 82 108 / var(--tw-bg-opacity, 1));
}
.bg-\[\#E8EAEA\]{
  --tw-bg-opacity: 1;
  background-color: rgb(232 234 234 / var(--tw-bg-opacity, 1));
}
.bg-\[\#ffff\]{
  background-color: #ffff;
}
.bg-\[rgba\(255\2c 255\2c 255\2c 0\.3\)\]{
  background-color: rgba(255,255,255,0.3);
}
.bg-white{
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}
.pb-\[1\.6rem\]{
  padding-bottom: 1.6rem;
}
.pb-\[14rem\]{
  padding-bottom: 14rem;
}
.pb-\[2px\]{
  padding-bottom: 2px;
}
.pb-\[35rem\]{
  padding-bottom: 35rem;
}
.pb-\[40\.8rem\]{
  padding-bottom: 40.8rem;
}
.pt-\[15rem\]{
  padding-top: 15rem;
}
.pt-\[20\.4rem\]{
  padding-top: 20.4rem;
}
.pt-\[20rem\]{
  padding-top: 20rem;
}
.pt-\[45rem\]{
  padding-top: 45rem;
}
.text-\[1\.2rem\]{
  font-size: 1.2rem;
}
.text-\[1\.5rem\]{
  font-size: 1.5rem;
}
.text-\[2rem\]{
  font-size: 2rem;
}
.text-\[4rem\]{
  font-size: 4rem;
}
.text-\[5\.8rem\]{
  font-size: 5.8rem;
}
.font-\[300\]{
  font-weight: 300;
}
.font-\[400\]{
  font-weight: 400;
}
.font-\[500\]{
  font-weight: 500;
}
.leading-\[100\%\]{
  line-height: 100%;
}
.leading-\[120\%\]{
  line-height: 120%;
}
.leading-\[170\%\]{
  line-height: 170%;
}
.leading-\[200\%\]{
  line-height: 200%;
}
.tracking-\[\.04em\]{
  letter-spacing: .04em;
}
.tracking-\[\.05em\]{
  letter-spacing: .05em;
}
.text-\[\#464141\]{
  --tw-text-opacity: 1;
  color: rgb(70 65 65 / var(--tw-text-opacity, 1));
}
.text-\[\#fff\]{
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}
.underline{
  -webkit-text-decoration-line: underline;
          text-decoration-line: underline;
}
.transition{
  -webkit-transition-property: color, background-color, border-color, fill, stroke, opacity, -webkit-text-decoration-color, -webkit-box-shadow, -webkit-transform, -webkit-filter, -webkit-backdrop-filter;
  transition-property: color, background-color, border-color, fill, stroke, opacity, -webkit-text-decoration-color, -webkit-box-shadow, -webkit-transform, -webkit-filter, -webkit-backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-text-decoration-color, -webkit-box-shadow, -webkit-transform, -webkit-filter, -webkit-backdrop-filter;
  -webkit-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
          transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  -webkit-transition-duration: 150ms;
          transition-duration: 150ms;
}
/* overflow-x-autoのスクロールバー消す */
.scrollbar-hide::-webkit-scrollbar {
    display: none;
  }
.scrollbar-hide {
    -ms-overflow-style: none; /* IEとEdge用 */
    scrollbar-width: none; /* Firefox用 */
  }
/* 三角形のクリップパス */
.clip-path {
    -webkit-clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
            clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
  }
/* テキスト行数制限 */
.txt-limit {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2; /* 任意の行数を指定 */
  }
/* 文字縦にする */
.vertical-text {
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    text-orientation: upright;
  }
/* ぼかしグラデーション */
.b-grad {
    background: -webkit-gradient(linear, left bottom, left top, color-stop(95%, rgb(0, 0, 0)), to(rgba(0, 0, 0, 0)));
    background: linear-gradient(to top, rgb(0, 0, 0) 95%, rgba(0, 0, 0, 0) 100%);
    -webkit-mask-composite: source-in, xor;
            mask-composite: intersect;
  }
/* ドットの下ボーダー */
.bg-two {
    background-image: linear-gradient(to right, #fff 5px, transparent 5px);
    background-size: 10px 1px;
    background-repeat: repeat-x;
    background-position: left bottom;
  }
.concept-bg {
    background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(40, 82, 108, 0)), color-stop(10%, rgba(40, 82, 108, 0.7)), color-stop(24%, rgba(40, 82, 108, 0.98)), color-stop(54%, rgb(40, 82, 108)), color-stop(85%, rgba(40, 82, 108, 0.85)), to(rgba(40, 82, 108, 0)));
    background-image: linear-gradient(to bottom, rgba(40, 82, 108, 0) 0%, rgba(40, 82, 108, 0.7) 10%, rgba(40, 82, 108, 0.98) 24%, rgb(40, 82, 108) 54%, rgba(40, 82, 108, 0.85) 85%, rgba(40, 82, 108, 0) 100%);
  }
.font-hi {
    font-family: "hiragino-mincho-pron", sans-serif;
  }
.font-zen {
    font-family: "zen-kaku-gothic-new", sans-serif;
  }
.font-mar {
    font-family: "Marcellus", serif;
  }
.l-footer {
  background-color: #fff;
  padding-top: 9.2rem;
  padding-bottom: 9.8rem;
}
.l-footer .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.l-footer .wrap > figure {
  width: 20.5rem;
  height: 9.6rem;
}
.l-footer .wrap > figure svg {
  width: 100%;
  height: 100%;
}
.l-footer .wrap .link-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 12rem;
  margin-top: 1.3rem;
}
.l-footer .wrap .link-list .t-box p {
  font-size: 1.5rem;
  font-family: "hiragino-mincho-pron", sans-serif;
  font-weight: 500;
  line-height: 170%;
  letter-spacing: 0.05em;
  color: #464141;
}
.l-footer .wrap .link-list .t-box > div {
  display: contents;
}
.l-footer .wrap .link-list .t-box > div a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.8rem;
  margin-top: 4.7rem;
}
.l-footer .wrap .link-list .t-box > div a:nth-of-type(n+2) {
  margin-top: 1.7rem;
}
.l-footer .wrap .link-list .t-box > div a figure svg {
  width: 100%;
  height: 100%;
}
.l-footer .wrap .link-list .t-box > div a figure svg * {
  fill: #464141;
}
.l-footer .wrap .link-list .t-box > div a p {
  font-size: 1.5rem;
  font-family: "Marcellus", serif;
  font-weight: 400;
  line-height: 100%;
  letter-spacing: 0.04em;
  color: #464141;
}
.l-footer .wrap .link-list ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 3rem;
}
.l-footer .wrap .link-list ul li {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.l-footer .wrap .link-list ul li a {
  font-size: 1.5rem;
  font-family: "Marcellus", serif;
  font-weight: 400;
  line-height: 100%;
  letter-spacing: 0.04em;
  color: #464141;
}
.l-header * {
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
.l-header .hn-bg {
  width: 100%;
  height: 100vh;
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 98;
  background-color: #959595;
  mix-blend-mode: multiply;
  pointer-events: none;
  opacity: 0;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
.l-header .wrap {
  position: fixed;
  top: 0;
  right: 0;
  width: 37rem;
  height: 100dvh;
  padding: 0 4rem;
  padding-top: 4rem;
  z-index: 99;
  pointer-events: none;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
  overflow-y: auto;
}
.l-header .wrap .fast-btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  gap: 3.8rem;
  pointer-events: auto;
}
.l-header .wrap .fast-btn * {
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
.l-header .wrap .fast-btn > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.7rem;
}
.l-header .wrap .fast-btn > a p {
  font-size: 1.6rem;
  font-family: "Marcellus", serif;
  font-weight: 400;
  line-height: 100%;
  letter-spacing: 0.04em;
  color: #fff;
}
.l-header .wrap .fast-btn > a.frame svg:not(.aro) * {
  fill: #fff;
}
.l-header .wrap .fast-btn .hn-btn {
  display: block;
  width: 3rem;
  height: 3rem;
  position: relative;
  cursor: pointer;
}
.l-header .wrap .fast-btn .hn-btn span {
  width: 2.8rem;
  height: 1px;
  background-color: #fff;
  position: absolute;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  left: 50%;
  pointer-events: none;
}
.l-header .wrap .fast-btn .hn-btn span:nth-child(1) {
  top: calc(50% + 0.4rem);
}
.l-header .wrap .fast-btn .hn-btn span:nth-child(2) {
  top: calc(50% - 0.4rem);
}
.l-header .wrap .m-memu {
  margin-top: 10rem;
  position: relative;
  opacity: 0;
  pointer-events: none;
}
.l-header .wrap .m-memu > p {
  width: 100%;
  font-size: 1.2rem;
  font-family: "zen-kaku-gothic-new", sans-serif;
  font-weight: 400;
  line-height: 100%;
  letter-spacing: 0.04em;
  color: #464141;
  text-align: center;
  position: absolute;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  top: -6.2rem;
  left: 50%;
}
.l-header .wrap .m-memu > ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2.1rem;
}
.l-header .wrap .m-memu > ul > li > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding-bottom: 2.1rem;
  border-bottom: 1px solid #464141;
}
.l-header .wrap .m-memu > ul > li > a * {
  color: #464141;
}
.l-header .wrap .m-memu > ul > li > a p {
  font-size: 1.5rem;
  font-family: "Marcellus", serif;
  font-weight: 400;
  line-height: 100%;
  letter-spacing: 0.04em;
}
.l-header .wrap .m-memu > ul > li > a span {
  font-size: 1.2rem;
  font-family: "zen-kaku-gothic-new", sans-serif;
  font-weight: 400;
  line-height: 100%;
  letter-spacing: 0.04em;
}
.l-header .wrap .m-memu .inst {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1em;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-right: auto;
  margin-top: 4rem;
}
.l-header .wrap .m-memu .inst p {
  font-size: 1.2rem;
  font-family: "Marcellus", serif;
  font-weight: 400;
  line-height: 100%;
  letter-spacing: 0.04em;
  color: #464141;
}
.l-header.is-scroll .fast-btn > a p {
  color: #464141;
}
.l-header.is-scroll .fast-btn > a.frame {
  background-color: rgba(70, 65, 65, 0.2) !important;
}
.l-header.is-scroll .fast-btn .hn-btn span {
  background-color: #464141;
}
.l-header.is-open .hn-bg {
  opacity: 1;
}
.l-header.is-open .wrap {
  background-color: #D9D9D9;
}
.l-header.is-open .wrap .fast-btn > a:not(.frame) figure svg.aro * {
  stroke: #464141;
}
.l-header.is-open .wrap .fast-btn > a.frame {
  background-color: rgba(70, 65, 65, 0.2);
}
.l-header.is-open .wrap .fast-btn p {
  color: #464141;
}
.l-header.is-open .wrap .hn-btn span {
  background-color: #464141;
}
.l-header.is-open .wrap .hn-btn span:nth-child(1) {
  top: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(35deg);
          transform: translate(-50%, -50%) rotate(35deg);
}
.l-header.is-open .wrap .hn-btn span:nth-child(2) {
  top: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(-35deg);
          transform: translate(-50%, -50%) rotate(-35deg);
}
.l-header.is-open .wrap .m-memu {
  opacity: 1;
  pointer-events: auto;
}
.l-header.is-404 .fast-btn > a:not(.frame) figure svg.aro * {
  stroke: #464141 !important;
}
.l-header.is-404 .fast-btn > a.frame {
  background-color: rgba(70, 65, 65, 0.2);
}
.l-header.is-404 .fast-btn p {
  color: #464141 !important;
}
.l-header.is-404 .hn-btn span {
  background-color: #464141 !important;
}
.l-header.is-none .frame {
  opacity: 0;
  pointer-events: none;
}
.p-404 {
  width: 100%;
  height: 70dvh;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.p-404 .text-box * {
  font-family: "zen-kaku-gothic-new", sans-serif;
}
.p-404 .text-box h4 {
  font-size: 3rem;
  font-weight: 700;
  text-align: center;
}
.p-404 .text-box > p {
  font-size: 2rem;
  font-weight: 500;
  text-align: center;
  margin-top: 3rem;
}
.p-404 .text-box a {
  display: block;
  margin-top: 4rem;
  -webkit-text-decoration-line: underline;
          text-decoration-line: underline;
  -webkit-text-decoration-color: #000;
          text-decoration-color: #000;
  text-decoration-thickness: 0.2rem;
  text-underline-offset: 0.9rem;
  -webkit-text-decoration-skip-ink: none;
          text-decoration-skip-ink: none;
}
.p-404 .text-box a p {
  font-size: 2rem;
  font-weight: 500;
  text-align: center;
}
.p-top {
  overflow: hidden;
}
.p-top section {
  position: relative;
}
.p-top .f-item {
  opacity: 0;
  -webkit-transition: 1.5s all;
  transition: 1.5s all;
}
.p-top .f-item.is-visible {
  opacity: 1;
}
.p-top .s-mv .scroll_down {
  position: absolute;
  z-index: 3;
  right: 5rem;
  bottom: 12rem;
}
.p-top .s-mv .scroll_down .scroll-line {
  width: 2px;
  height: 6rem;
  background: rgba(255, 255, 255, 0.5);
  position: relative;
}
.p-top .s-mv .scroll_down .scroll-line:before {
  content: "";
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  background: #fff;
  -webkit-animation: sdl01 3s cubic-bezier(0.76, 0, 0.3, 1) forwards infinite;
          animation: sdl01 3s cubic-bezier(0.76, 0, 0.3, 1) forwards infinite;
}
@-webkit-keyframes sdl01 {
  0% {
    -webkit-transform: scale(1, 0);
            transform: scale(1, 0);
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
  }
  50% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
  }
  50.1% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: 0 100%;
            transform-origin: 0 100%;
  }
  100% {
    -webkit-transform: scale(1, 0);
            transform: scale(1, 0);
    -webkit-transform-origin: 0 100%;
            transform-origin: 0 100%;
  }
}
@keyframes sdl01 {
  0% {
    -webkit-transform: scale(1, 0);
            transform: scale(1, 0);
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
  }
  50% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: 0 0;
            transform-origin: 0 0;
  }
  50.1% {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: 0 100%;
            transform-origin: 0 100%;
  }
  100% {
    -webkit-transform: scale(1, 0);
            transform: scale(1, 0);
    -webkit-transform-origin: 0 100%;
            transform-origin: 0 100%;
  }
}
.p-top .s-access .point-box .one, .p-top .s-access .point-box .two {
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
  -webkit-animation: an-one 5s cubic-bezier(0.76, 0, 0.3, 1) forwards infinite;
          animation: an-one 5s cubic-bezier(0.76, 0, 0.3, 1) forwards infinite;
}
@-webkit-keyframes an-one {
  0% {
    -webkit-transform: translate(-50%, -50%) scale(0, 0);
            transform: translate(-50%, -50%) scale(0, 0);
    -webkit-transform-origin: 50% 50%;
            transform-origin: 50% 50%;
    opacity: 1;
  }
  65% {
    -webkit-transform: translate(-50%, -50%) scale(1, 1);
            transform: translate(-50%, -50%) scale(1, 1);
    -webkit-transform-origin: 50% 50%;
            transform-origin: 50% 50%;
    opacity: 1;
  }
  100% {
    -webkit-transform: translate(-50%, -50%) scale(1, 1);
            transform: translate(-50%, -50%) scale(1, 1);
    -webkit-transform-origin: 50% 50%;
            transform-origin: 50% 50%;
    opacity: 0;
  }
}
@keyframes an-one {
  0% {
    -webkit-transform: translate(-50%, -50%) scale(0, 0);
            transform: translate(-50%, -50%) scale(0, 0);
    -webkit-transform-origin: 50% 50%;
            transform-origin: 50% 50%;
    opacity: 1;
  }
  65% {
    -webkit-transform: translate(-50%, -50%) scale(1, 1);
            transform: translate(-50%, -50%) scale(1, 1);
    -webkit-transform-origin: 50% 50%;
            transform-origin: 50% 50%;
    opacity: 1;
  }
  100% {
    -webkit-transform: translate(-50%, -50%) scale(1, 1);
            transform: translate(-50%, -50%) scale(1, 1);
    -webkit-transform-origin: 50% 50%;
            transform-origin: 50% 50%;
    opacity: 0;
  }
}
.p-top .s-gallery {
  padding-bottom: 57.7rem;
  position: relative;
}
.p-top .s-gallery .gswip-outer {
  padding-bottom: 5.4rem;
  position: absolute;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  left: 50%;
  bottom: 0;
  opacity: 0;
  pointer-events: none;
  -webkit-transition: 1s all;
  transition: 1s all;
}
.p-top .s-gallery .gswip-outer.is-active {
  opacity: 1;
  pointer-events: auto;
}
.p-top .s-gallery .gswip-outer .gallery-swiper {
  width: 112rem;
  margin: 0 auto;
  overflow: hidden;
}
.p-top .s-gallery .gswip-outer .gallery-swiper > ul > li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 6.3rem;
}
.p-top .s-gallery .gswip-outer .gallery-swiper > ul > li > figure {
  width: 78rem;
  height: 48.3rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.p-top .s-gallery .gswip-outer .gallery-swiper > ul > li > .t-box {
  margin-top: 1.3rem;
  -webkit-transition: 0.5s all;
  transition: 0.5s all;
}
.p-top .s-gallery .gswip-outer .gallery-swiper > ul > li > .t-box h4 {
  font-size: 2rem;
  font-family: "hiragino-mincho-pron", sans-serif;
  font-weight: 300;
  line-height: 120%;
  letter-spacing: 0.05em;
  color: #000;
}
.p-top .s-gallery .gswip-outer .gallery-swiper > ul > li > .t-box p {
  font-size: 1.5rem;
  font-family: "hiragino-mincho-pron", sans-serif;
  line-height: 170%;
  letter-spacing: 0.05em;
  color: #464141;
  margin-top: 2.4rem;
}
.p-top .s-gallery .gswip-outer .swiper-button {
  width: 1rem;
  height: 2rem;
  left: auto;
  right: auto;
  position: relative;
  margin-top: 0;
}
.p-top .s-gallery .gswip-outer .swiper-button svg {
  width: 100%;
  height: 100%;
}
.p-top .s-gallery .gswip-outer .swiper-button-box {
  position: absolute;
  bottom: -0.1rem;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  left: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 9.2rem;
}
.p-top .s-gallery .gswip-outer .swiper-button-prev::after {
  display: none;
}
.p-top .s-gallery .gswip-outer .swiper-button-prev svg {
  -webkit-transform: rotate(-180deg);
          transform: rotate(-180deg);
}
.p-top .s-gallery .gswip-outer .swiper-button-next::after {
  display: none;
}
.p-top .s-gallery .gswip-outer .swiper-button-disabled {
  opacity: 0.7;
  pointer-events: none;
}
.p-top .s-gallery .gswip-outer .swiper-scrollbar {
  position: absolute;
  display: block;
  background-color: #D9D9D9;
  width: 104rem;
  height: 2px;
  -webkit-transform: translateY(50%);
          transform: translateY(50%);
  bottom: 0;
  left: 0;
}
.p-top .s-gallery .gswip-outer .swiper-scrollbar span {
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
  display: block;
  height: 2px;
  background-color: #1F44A2;
  max-width: 100%;
}
.p-top .s-gallery .gswip-outer .swiper-pagination {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  position: absolute;
  bottom: 0rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.p-top .s-gallery .gswip-outer .swiper-pagination .custom-pagination {
  font-size: 1.4rem;
  font-family: "Marcellus", serif;
  font-weight: 400;
  color: #464141;
  line-height: normal;
  letter-spacing: 0em;
}
.p-top .s-news .news-list {
  width: 100%;
  padding-top: 3rem;
  border-top: 1px solid #464141;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 3rem;
}
.p-top .s-news .news-list > li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 4.5rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid #464141;
}
.p-top .s-news .news-list > li span {
  font-size: 1.5rem;
  font-family: "Marcellus", serif;
  font-weight: 400;
  line-height: 200%;
  letter-spacing: 0.05em;
  color: #464141;
}
.p-top .s-news .news-list > li p {
  width: 100%;
  font-size: 1.5rem;
  font-family: "hiragino-mincho-pron", sans-serif;
  font-weight: 500;
  line-height: 200%;
  letter-spacing: 0.05em;
  color: #464141;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}
.p-top .s-faq .faq-list {
  margin-top: 4rem;
  padding-top: 3rem;
  border-top: 1px solid #464141;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 3rem;
  padding-bottom: 7rem;
  position: relative;
}
.p-top .s-faq .faq-list::before {
  content: "";
  width: 100%;
  height: 9rem;
  display: block;
  background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(232, 234, 234, 0.5)), color-stop(50%, rgba(232, 234, 234, 0.7)), to(rgb(232, 234, 234)));
  background-image: linear-gradient(to bottom, rgba(232, 234, 234, 0.5) 0%, rgba(232, 234, 234, 0.7) 50%, rgb(232, 234, 234) 100%);
  position: absolute;
  bottom: 7rem;
  left: 0;
  z-index: 1;
  -webkit-transition: 0.5s all;
  transition: 0.5s all;
}
.p-top .s-faq .faq-list .btn {
  font-size: 1.5rem;
  font-family: "hiragino-mincho-pron", sans-serif;
  font-weight: 500;
  line-height: 200%;
  letter-spacing: 0.05em;
  color: #464141;
  position: absolute;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  bottom: -2rem;
  left: 50%;
  z-index: 2;
  cursor: pointer;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
.p-top .s-faq .faq-list .btn.close {
  opacity: 0 !important;
  pointer-events: none !important;
}
.p-top .s-faq .faq-list li {
  padding-bottom: 3rem;
  border-bottom: 1px solid #464141;
  position: relative;
  cursor: pointer;
}
.p-top .s-faq .faq-list li:nth-child(n+5) {
  display: none;
}
.p-top .s-faq .faq-list li .question h4 {
  font-size: 1.5rem;
  font-family: "hiragino-mincho-pron", sans-serif;
  font-weight: 500;
  line-height: 200%;
  letter-spacing: 0.05em;
  color: #464141;
  padding-left: 3.7rem;
  padding-right: 3.3rem;
  position: relative;
}
.p-top .s-faq .faq-list li .question h4::before {
  content: "Q";
  font-size: 2rem;
  font-family: "Marcellus", serif;
  font-weight: 400;
  line-height: 200%;
  letter-spacing: 0.05em;
  position: absolute;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  top: 50%;
  left: 0;
  color: #464141;
}
.p-top .s-faq .faq-list li .answer {
  margin-top: 3.5rem;
  display: none;
}
.p-top .s-faq .faq-list li .answer h4 {
  font-size: 1.5rem;
  font-family: "hiragino-mincho-pron", sans-serif;
  font-weight: 500;
  line-height: 200%;
  letter-spacing: 0.05em;
  color: #464141;
  padding-left: 3.4rem;
  position: relative;
}
.p-top .s-faq .faq-list li .answer h4::before {
  content: "A";
  font-size: 2rem;
  font-family: "Marcellus", serif;
  font-weight: 400;
  line-height: 200%;
  letter-spacing: 0.05em;
  color: #464141;
  position: absolute;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  top: 50%;
  left: 0;
}
.p-top .s-faq .faq-list li aside {
  position: absolute;
  top: 1.3rem;
  right: 0;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
.p-top .s-faq .faq-list li aside figure {
  width: 1.4rem;
  height: 0.9rem;
}
.p-top .s-faq .faq-list li aside figure svg {
  width: 100%;
  height: 100%;
}
.p-top .s-faq .faq-list li.is-active aside {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}
.p-top .s-faq .faq-list.is-open::before {
  opacity: 0;
  pointer-events: none;
}
.p-top .s-faq .faq-list.is-open .btn.open {
  opacity: 0 !important;
  pointer-events: none !important;
}
.p-top .s-faq .faq-list.is-open .btn.close {
  opacity: 1 !important;
  pointer-events: auto !important;
}
.p-top .s-faq .faq-list.is-none {
  padding-bottom: 0;
}
.p-top .s-faq .faq-list.is-none::before {
  opacity: 0;
  pointer-events: none;
}
.p-top .s-faq .faq-list.is-none .btn {
  opacity: 0 !important;
  pointer-events: none !important;
}
.p-top .s-contact .form-wrap {
  margin-top: 4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2rem;
}
.p-top .s-contact .form-wrap p {
  width: 100%;
}
.p-top .s-contact .form-wrap .item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 0.9rem;
}
.p-top .s-contact .form-wrap .item p {
  font-size: 1.5rem;
  font-family: "hiragino-mincho-pron", sans-serif;
  font-weight: 500;
  line-height: 200%;
  letter-spacing: 0.05em;
  color: #464141;
}
.p-top .s-contact .form-wrap .item p sup {
  font-size: 0.8rem;
  font-family: "hiragino-mincho-pron", sans-serif;
  font-weight: 700;
  line-height: 200%;
  letter-spacing: 0.05em;
  color: #464141;
}
.p-top .s-contact .form-wrap .item input {
  width: 100%;
  height: 3.2rem;
  padding: 0 1.5rem;
  border: 1px solid #464141;
  background-color: #E8EAEA;
}
.p-top .s-contact .form-wrap .item input::-webkit-input-placeholder {
  font-size: 1.5rem;
  font-family: "hiragino-mincho-pron", sans-serif;
  font-weight: 500;
  line-height: 200%;
  letter-spacing: 0.05em;
  color: rgba(70, 65, 65, 0.5);
  text-align: left;
}
.p-top .s-contact .form-wrap .item input::-moz-placeholder {
  font-size: 1.5rem;
  font-family: "hiragino-mincho-pron", sans-serif;
  font-weight: 500;
  line-height: 200%;
  letter-spacing: 0.05em;
  color: rgba(70, 65, 65, 0.5);
  text-align: left;
}
.p-top .s-contact .form-wrap .item input::-ms-input-placeholder {
  font-size: 1.5rem;
  font-family: "hiragino-mincho-pron", sans-serif;
  font-weight: 500;
  line-height: 200%;
  letter-spacing: 0.05em;
  color: rgba(70, 65, 65, 0.5);
  text-align: left;
}
.p-top .s-contact .form-wrap .item input::placeholder {
  font-size: 1.5rem;
  font-family: "hiragino-mincho-pron", sans-serif;
  font-weight: 500;
  line-height: 200%;
  letter-spacing: 0.05em;
  color: rgba(70, 65, 65, 0.5);
  text-align: left;
}
.p-top .s-contact .form-wrap .item.contact textarea {
  width: 100%;
  height: 24.6rem;
  padding: 1rem 2rem;
  border: 1px solid #464141;
  background-color: #E8EAEA;
}
.p-top .s-contact .form-wrap .item .purapori-eria {
  width: 100%;
  height: 24.6rem;
  border: 1px solid #464141;
  padding: 1rem 2rem;
  overflow-y: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2rem;
}
.p-top .s-contact .form-wrap .item .purapori-eria {
  /* スクロールバー全体 */
}
.p-top .s-contact .form-wrap .item .purapori-eria::-webkit-scrollbar {
  background-color: #E8EAEA;
  border-left: 1px solid #464141;
  width: 12px;
  height: 100%;
}
.p-top .s-contact .form-wrap .item .purapori-eria {
  /* スクロールバーのつまみ（スクロールする部分） */
}
.p-top .s-contact .form-wrap .item .purapori-eria::-webkit-scrollbar-thumb {
  height: 4.6rem;
  background-color: #A0A0A0;
  border: 3.5px solid transparent;
  background-clip: content-box;
}
.p-top .s-contact .form-wrap .item .purapori-eria br {
  display: none;
}
.p-top .s-contact .form-wrap .item .purapori-eria p {
  font-size: 1.5rem;
  font-family: "hiragino-mincho-pron", sans-serif;
  font-weight: 500;
  line-height: 200%;
  letter-spacing: 0.05em;
  color: rgba(70, 65, 65, 0.5);
}
.p-top .s-contact .form-wrap .item .purapori-eria .t-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.p-top .s-contact .form-wrap .item .purapori-eria .t-box h4 {
  font-size: 1.8rem;
  font-family: "hiragino-mincho-pron", sans-serif;
  font-weight: 500;
  line-height: 200%;
  letter-spacing: 0.05em;
  color: rgba(70, 65, 65, 0.5);
  padding-left: 2rem;
  position: relative;
  border-left: 2px solid rgba(70, 65, 65, 0.5);
  margin-bottom: 1rem;
}
.p-top .s-contact .form-wrap .consent {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
.p-top .s-contact .form-wrap .consent span {
  font-size: 1.4rem;
  font-family: "hiragino-mincho-pron", sans-serif;
  font-weight: 500;
  line-height: 200%;
  letter-spacing: 0.05em;
  color: #464141;
}
.p-top .s-contact .form-wrap .consent span sup {
  font-size: 0.8rem;
  font-weight: 700;
  line-height: 200%;
  letter-spacing: 0.05em;
  color: #464141;
}
.p-top .s-contact .form-wrap .submit {
  margin: 0 auto;
  margin-top: 2rem;
}
.p-top .s-contact .form-wrap .submit p {
  height: 4.1rem;
  line-height: 4.1rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  background-color: rgba(70, 65, 65, 0.2);
  border-radius: 9999px;
  font-size: 1.5rem;
  font-family: "hiragino-mincho-pron", sans-serif;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: #464141;
}
.p-top .s-contact .form-wrap .submit p input {
  padding: 0 9.6rem;
  cursor: pointer;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
.p-top .s-contact .form-wrap .submit p .wpcf7-spinner {
  position: absolute;
}
[id^=anchor] > * {
  pointer-events: auto;
}
.anchor-box {
  width: 10rem;
  height: 2rem;
  position: absolute;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  left: 50%;
  pointer-events: none;
  background-color: transparent;
}
.c-hover-op {
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
.\[\&_\*\]\:transition-all *{
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
          transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  -webkit-transition-duration: 150ms;
          transition-duration: 150ms;
}
.\[\&_\*\]\:duration-1000 *{
  -webkit-transition-duration: 1000ms;
          transition-duration: 1000ms;
}
.\[\&_\*\]\:duration-300 *{
  -webkit-transition-duration: 300ms;
          transition-duration: 300ms;
}
.\[\&_\.t-box\>h4\]\:mt-\[1rem\] .t-box>h4{
  margin-top: 1rem;
}
.\[\&_\.t-box\>h4\]\:pl-\[3\.6rem\] .t-box>h4{
  padding-left: 3.6rem;
}
.\[\&_\.t-box\>h4\]\:text-\[2rem\] .t-box>h4{
  font-size: 2rem;
}
.\[\&_\.t-box\>h4\]\:font-\[300\] .t-box>h4{
  font-weight: 300;
}
.\[\&_\.t-box\>h4\]\:leading-\[150\%\] .t-box>h4{
  line-height: 150%;
}
.\[\&_\.t-box\>h4\]\:tracking-\[\.05em\] .t-box>h4{
  letter-spacing: .05em;
}
.\[\&_\.t-box\>h4\]\:text-\[\#000\] .t-box>h4{
  --tw-text-opacity: 1;
  color: rgb(0 0 0 / var(--tw-text-opacity, 1));
}
.\[\&_\.t-box\>h4\]\:font-hi .t-box>h4 {
    font-family: "hiragino-mincho-pron", sans-serif;
  }
.\[\&_\.t-box\>p\]\:mt-\[3\.2rem\] .t-box>p{
  margin-top: 3.2rem;
}
.\[\&_\.t-box\>p\]\:pl-\[3\.6rem\] .t-box>p{
  padding-left: 3.6rem;
}
.\[\&_\.t-box\>p\]\:font-\[500\] .t-box>p{
  font-weight: 500;
}
.\[\&_\.t-box\>p\]\:leading-\[200\%\] .t-box>p{
  line-height: 200%;
}
.\[\&_\.t-box\>p\]\:tracking-\[\.05em\] .t-box>p{
  letter-spacing: .05em;
}
.\[\&_\.t-box\>p\]\:text-\[\#464141\] .t-box>p{
  --tw-text-opacity: 1;
  color: rgb(70 65 65 / var(--tw-text-opacity, 1));
}
.\[\&_\.t-box\>p\]\:font-hi .t-box>p {
    font-family: "hiragino-mincho-pron", sans-serif;
  }
.\[\&_\.t-box\>span\:before\]\:absolute .t-box>span:before{
  position: absolute;
}
.\[\&_\.t-box\>span\:before\]\:left-\[0\] .t-box>span:before{
  left: 0;
}
.\[\&_\.t-box\>span\:before\]\:top-\[50\%\] .t-box>span:before{
  top: 50%;
}
.\[\&_\.t-box\>span\:before\]\:h-\[1px\] .t-box>span:before{
  height: 1px;
}
.\[\&_\.t-box\>span\:before\]\:w-\[2\.7rem\] .t-box>span:before{
  width: 2.7rem;
}
.\[\&_\.t-box\>span\:before\]\:translate-y-\[-50\%\] .t-box>span:before{
  --tw-translate-y: -50%;
  -webkit-transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
          transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.\[\&_\.t-box\>span\:before\]\:bg-\[\#464141\] .t-box>span:before{
  --tw-bg-opacity: 1;
  background-color: rgb(70 65 65 / var(--tw-bg-opacity, 1));
}
.\[\&_\.t-box\>span\:before\]\:content-\[\'\'\] .t-box>span:before{
  --tw-content: '';
  content: var(--tw-content);
}
.\[\&_\.t-box\>span\]\:relative .t-box>span{
  position: relative;
}
.\[\&_\.t-box\>span\]\:pl-\[3\.7rem\] .t-box>span{
  padding-left: 3.7rem;
}
.\[\&_\.t-box\>span\]\:text-\[1\.4rem\] .t-box>span{
  font-size: 1.4rem;
}
.\[\&_\.t-box\>span\]\:font-\[400\] .t-box>span{
  font-weight: 400;
}
.\[\&_\.t-box\>span\]\:leading-\[100\%\] .t-box>span{
  line-height: 100%;
}
.\[\&_\.t-box\>span\]\:tracking-\[\.04em\] .t-box>span{
  letter-spacing: .04em;
}
.\[\&_\.t-box\>span\]\:text-\[\#464141\] .t-box>span{
  --tw-text-opacity: 1;
  color: rgb(70 65 65 / var(--tw-text-opacity, 1));
}
.\[\&_\.t-box\>span\]\:font-mar .t-box>span {
    font-family: "Marcellus", serif;
  }
.\[\&_\.t-box\]\:relative .t-box{
  position: relative;
}
.\[\&_\.t-box\]\:w-\[43rem\] .t-box{
  width: 43rem;
}
.\[\&_img\]\:scale-\[120\%\] img{
  --tw-scale-x: 120%;
  --tw-scale-y: 120%;
  -webkit-transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
          transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.\[\&_li\.is-active\]\:border-\[\#464141\] li.is-active{
  --tw-border-opacity: 1;
  border-color: rgb(70 65 65 / var(--tw-border-opacity, 1));
}
.\[\&_li\:hover\]\:cursor-pointer li:hover{
  cursor: pointer;
}
.\[\&_li\]\:border-b-\[1px\] li{
  border-bottom-width: 1px;
}
.\[\&_li\]\:pb-\[\.8rem\] li{
  padding-bottom: .8rem;
}
.\[\&_li\]\:text-center li{
  text-align: center;
}
.\[\&_li\]\:text-\[1\.5rem\] li{
  font-size: 1.5rem;
}
.\[\&_li\]\:font-\[500\] li{
  font-weight: 500;
}
.\[\&_li\]\:leading-\[170\%\] li{
  line-height: 170%;
}
.\[\&_li\]\:tracking-\[\.05em\] li{
  letter-spacing: .05em;
}
.\[\&_li\]\:text-\[\#464141\] li{
  --tw-text-opacity: 1;
  color: rgb(70 65 65 / var(--tw-text-opacity, 1));
}
.\[\&_li\]\:font-hi li {
    font-family: "hiragino-mincho-pron", sans-serif;
  }
.\[\&_svg\]\:h-full svg{
  height: 100%;
}
.\[\&_svg\]\:w-full svg{
  width: 100%;
}
@media screen and (min-width: 1600px) {
  html {
    font-size: calc(160px / 1400 * 100);
  }
}
@media screen and (min-width: 768px) and (max-width: 1599px) {
  html {
    font-size: calc(10vw / 1400 * 100);
  }
}
@media screen and (max-width: 767px) {
  html {
    font-size: calc(10vw / 400 * 100);
  }
  html,
  body {
    width: 100%;
    height: 100%;
  }
  h1,
  h2,
  h3,
  h4,
  h5,
  h6,
  div,
  dl,
  dt,
  dd,
  p {
    padding: 0;
    margin: 0;
  }
  img {
    width: auto;
    max-width: 100%;
    height: auto;
    max-height: 100%;
  }
  .pc {
    display: none !important;
  }
}
@media screen and (min-width: 768px) {
  [href*="tel:"] {
    pointer-events: none;
  }
  .sp {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  html .n-text {
    font-size: 1.4rem;
  }
    .concept-bg {
      background-image: -webkit-gradient(linear, left top, left bottom, from(rgba(40, 82, 108, 0)), color-stop(10%, rgba(40, 82, 108, 0.6)), color-stop(24%, rgba(40, 82, 108, 0.98)), color-stop(54%, rgb(40, 82, 108)), color-stop(85%, rgba(40, 82, 108, 0.85)), to(rgba(40, 82, 108, 0)));
      background-image: linear-gradient(to bottom, rgba(40, 82, 108, 0) 0%, rgba(40, 82, 108, 0.6) 10%, rgba(40, 82, 108, 0.98) 24%, rgb(40, 82, 108) 54%, rgba(40, 82, 108, 0.85) 85%, rgba(40, 82, 108, 0) 100%);
    }
  .l-footer {
    padding-top: 4.4rem;
    padding-bottom: 9.5rem;
  }
  .l-footer .wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .l-footer .wrap > figure {
    width: 14.5rem;
    height: 6.8rem;
  }
  .l-footer .wrap .link-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 4rem;
    margin-top: 0;
  }
  .l-footer .wrap .link-list .t-box {
    margin-top: 2rem;
  }
  .l-footer .wrap .link-list .t-box p {
    font-size: 1.3rem;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto;
  }
  .l-footer .wrap .link-list .t-box > div {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 3.6rem;
    margin-top: 4rem;
  }
  .l-footer .wrap .link-list .t-box > div a {
    margin-top: 0;
  }
  .l-footer .wrap .link-list .t-box > div a:nth-of-type(n+2) {
    margin-top: 0;
  }
  .l-footer .wrap .link-list ul {
    display: -ms-grid;
    display: grid;
    -ms-grid-rows: (auto)[3];
    grid-template-rows: repeat(3, auto);
    grid-auto-flow: column;
    grid-gap: 1.5rem;
    gap: 1.5rem;
    grid-column-gap: 1.8rem;
    -webkit-column-gap: 1.8rem;
       -moz-column-gap: 1.8rem;
            column-gap: 1.8rem;
  }
  .l-header .wrap {
    width: 100%;
  }
  .l-header .wrap .fast-btn > a {
    width: 100%;
    padding: 1.8rem;
    gap: 0.8rem;
    z-index: 10;
  }
  .l-header .wrap .fast-btn > a:not(.frame) {
    opacity: 0;
    pointer-events: none;
    background-color: #fff;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    position: fixed;
    left: 0;
    bottom: 5rem;
    bottom: 0;
  }
  .l-header .wrap .fast-btn > a.frame {
    background-color: #464141 !important;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    position: fixed;
    left: 0;
    bottom: 0;
  }
  .l-header .wrap .fast-btn > a.frame p {
    color: #fff !important;
  }
  .l-header .wrap .m-memu {
    padding: 0 1.5rem;
  }
  .l-header .wrap .m-memu .inst {
    margin: 0 auto;
    margin-top: 4rem;
  }
  .l-header.is-open .wrap {
    padding-bottom: 16rem;
  }
  .l-header.is-open .wrap .fast-btn > a:not(.frame) {
    opacity: 1;
    pointer-events: auto;
  }
  .l-header.is-open .wrap .fast-btn > a:not(.frame) figure svg:not(.aro) * {
    fill: #464141 !important;
  }
  .l-header.is-open .wrap .fast-btn > a.frame {
    background-color: #464141;
    opacity: 1;
    pointer-events: auto;
  }
  .l-header.is-404 .fast-btn > a:not(.frame) figure svg:not(.aro) * {
    fill: #464141 !important;
  }
  .l-header.is-404 .fast-btn > a.frame {
    background-color: #464141;
    opacity: 1;
    pointer-events: auto;
  }
  .p-404 {
    padding: 0 2rem;
  }
  .p-404 .text-box h4 {
    font-size: 2rem;
    text-align: left;
  }
  .p-404 .text-box > p {
    font-size: 1.6rem;
    text-align: left;
  }
  .p-404 .text-box a p {
    font-size: 1.6rem;
  }
  .p-top .s-mv .scroll_down {
    bottom: 14rem;
    right: 2.4rem;
  }
  .p-top .s-access .anchor-box {
    top: 3rem;
  }
  .p-top .s-gallery .anchor-box {
    top: 8rem;
  }
  .p-top .s-gallery .gswip-outer {
    width: 100%;
    padding: 0 0rem;
    padding-bottom: 6.1rem;
    bottom: auto;
    top: 26rem;
  }
  .p-top .s-gallery .gswip-outer .gallery-swiper {
    width: 100%;
  }
  .p-top .s-gallery .gswip-outer .gallery-swiper > ul > li {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 2.8rem;
  }
  .p-top .s-gallery .gswip-outer .gallery-swiper > ul > li > figure {
    width: 100%;
    height: auto;
    aspect-ratio: 320/198;
  }
  .p-top .s-gallery .gswip-outer .gallery-swiper > ul > li > .t-box {
    margin-top: 0;
    width: 100%;
    padding: 0 2rem;
  }
  .p-top .s-gallery .gswip-outer .gallery-swiper > ul > li > .t-box h4 {
    font-size: 1.8rem;
    width: 100%;
    text-align: left;
  }
  .p-top .s-gallery .gswip-outer .gallery-swiper > ul > li > .t-box p {
    font-size: 1.4rem;
    margin-top: 1.5rem;
    width: 100%;
    text-align: left;
  }
  .p-top .s-gallery .gswip-outer .swiper-scrollbar {
    width: 27.2rem;
  }
  .p-top .s-gallery .gswip-outer .swiper-pagination .custom-pagination {
    font-size: 1.5rem;
  }
  .p-top .s-news .news-list {
    padding-top: 1.5rem;
    gap: 1.5rem;
  }
  .p-top .s-news .news-list > li {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 2rem;
    padding-bottom: 1.5rem;
  }
  .p-top .s-news .news-list > li span {
    font-size: 1.3rem;
  }
  .p-top .s-news .news-list > li p {
    font-size: 1.4rem;
  }
  .p-top .s-faq .anchor-box {
    top: 3rem;
  }
  .p-top .s-faq .faq-list {
    gap: 1.5rem;
    padding-top: 1.5rem;
  }
  .p-top .s-faq .faq-list .btn {
    bottom: 0rem;
  }
  .p-top .s-faq .faq-list li {
    padding-bottom: 1.5rem;
  }
  .p-top .s-faq .faq-list li .question h4::before {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    top: -0.6rem;
  }
  .p-top .s-faq .faq-list li .answer {
    margin-top: 3rem;
  }
  .p-top .s-faq .faq-list li .answer h4::before {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    top: 0rem;
  }
  .p-top .s-contact .anchor-box {
    top: 8rem;
  }
  .p-top .s-contact .form-wrap {
    gap: 1.8rem;
  }
  .p-top .s-contact .form-wrap .item p {
    font-size: 1.4rem;
  }
  .p-top .s-contact .form-wrap .item input::-webkit-input-placeholder {
    font-size: 1.4rem;
  }
  .p-top .s-contact .form-wrap .item input::-moz-placeholder {
    font-size: 1.4rem;
  }
  .p-top .s-contact .form-wrap .item input::-ms-input-placeholder {
    font-size: 1.4rem;
  }
  .p-top .s-contact .form-wrap .item input::placeholder {
    font-size: 1.4rem;
  }
  .p-top .s-contact .form-wrap .item.contact textarea {
    height: 14.4rem;
  }
  .p-top .s-contact .form-wrap .item .purapori-eria {
    height: 19.4rem;
  }
  .p-top .s-contact .form-wrap .submit {
    margin-top: 3rem;
  }
  .p-top .s-contact .form-wrap .submit p {
    background-color: #464141;
    color: #fff;
  }
}
@media screen and (min-width: 768px) {
  .l-header .wrap .fast-btn > a.frame {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    padding: 0.5rem 1.2rem;
    border-radius: 9999px;
    background-color: rgba(255, 255, 255, 0.2);
  }
  .l-header.is-scroll .fast-btn > a figure svg:not(.aro) * {
    fill: #464141 !important;
  }
  .l-header.is-open .wrap .fast-btn > a:not(.frame) figure svg:not(.aro) * {
    fill: #464141 !important;
  }
  .l-header.is-open .wrap .fast-btn > a.frame svg:not(.aro) * {
    fill: #464141 !important;
  }
  .l-header.is-404 .fast-btn > a:not(.frame) figure svg:not(.aro) * {
    fill: #464141 !important;
  }
  .l-header.is-404 .fast-btn > a.frame svg:not(.aro) * {
    fill: #464141 !important;
  }
  .p-top .s-news .anchor-box {
    top: 5rem;
  }
  .p-top .s-faq .anchor-box {
    top: 17rem;
  }
  .p-top .s-faq .faq-list .btn:hover {
    opacity: 0.7;
  }
  .p-top .s-contact .anchor-box {
    top: 18rem;
  }
  .p-top .s-contact .form-wrap .submit p input:hover {
    opacity: 0.7;
  }
  .c-hover-op:hover {
    opacity: 0.7;
  }
}
@media (max-width: 767px){
  .sp\:bottom-\[-4\.5rem\]{
    bottom: -4.5rem;
  }
  .sp\:bottom-\[-5\.2re\]{
    bottom: -5.2re;
  }
  .sp\:left-\[2\.5rem\]{
    left: 2.5rem;
  }
  .sp\:left-\[20\.4rem\]{
    left: 20.4rem;
  }
  .sp\:left-\[24\.8rem\]{
    left: 24.8rem;
  }
  .sp\:left-\[27\.2rem\]{
    left: 27.2rem;
  }
  .sp\:left-\[2rem\]{
    left: 2rem;
  }
  .sp\:left-\[4rem\]{
    left: 4rem;
  }
  .sp\:left-\[50\%\]{
    left: 50%;
  }
  .sp\:right-\[4rem\]{
    right: 4rem;
  }
  .sp\:top-\[-6rem\]{
    top: -6rem;
  }
  .sp\:top-\[-7rem\]{
    top: -7rem;
  }
  .sp\:top-\[104rem\]{
    top: 104rem;
  }
  .sp\:top-\[11rem\]{
    top: 11rem;
  }
  .sp\:top-\[125\.5rem\]{
    top: 125.5rem;
  }
  .sp\:top-\[174rem\]{
    top: 174rem;
  }
  .sp\:top-\[216rem\]{
    top: 216rem;
  }
  .sp\:top-\[2rem\]{
    top: 2rem;
  }
  .sp\:top-\[32rem\]{
    top: 32rem;
  }
  .sp\:top-\[52rem\]{
    top: 52rem;
  }
  .sp\:top-\[6rem\]{
    top: 6rem;
  }
  .sp\:mr-\[-12rem\]{
    margin-right: -12rem;
  }
  .sp\:mt-\[-19\.2rem\]{
    margin-top: -19.2rem;
  }
  .sp\:mt-\[-2rem\]{
    margin-top: -2rem;
  }
  .sp\:mt-\[10\.8rem\]{
    margin-top: 10.8rem;
  }
  .sp\:mt-\[2\.8rem\]{
    margin-top: 2.8rem;
  }
  .sp\:mt-\[24\.8rem\]{
    margin-top: 24.8rem;
  }
  .sp\:mt-\[38\.6rem\]{
    margin-top: 38.6rem;
  }
  .sp\:mt-\[3rem\]{
    margin-top: 3rem;
  }
  .sp\:mt-\[47\.6rem\]{
    margin-top: 47.6rem;
  }
  .sp\:mt-\[4rem\]{
    margin-top: 4rem;
  }
  .sp\:mt-\[7rem\]{
    margin-top: 7rem;
  }
  .sp\:aspect-\[32\/18\]{
    aspect-ratio: 32/18;
  }
  .sp\:h-\[\.5rem\]{
    height: .5rem;
  }
  .sp\:h-\[1\.1rem\]{
    height: 1.1rem;
  }
  .sp\:h-\[12rem\]{
    height: 12rem;
  }
  .sp\:h-\[13\.8rem\]{
    height: 13.8rem;
  }
  .sp\:h-\[14\.4rem\]{
    height: 14.4rem;
  }
  .sp\:h-\[16\.4rem\]{
    height: 16.4rem;
  }
  .sp\:h-\[16\.6rem\]{
    height: 16.6rem;
  }
  .sp\:h-\[2\.2rem\]{
    height: 2.2rem;
  }
  .sp\:h-\[20rem\]{
    height: 20rem;
  }
  .sp\:h-\[29\.8rem\]{
    height: 29.8rem;
  }
  .sp\:h-\[33\.2rem\]{
    height: 33.2rem;
  }
  .sp\:h-\[5\.7rem\]{
    height: 5.7rem;
  }
  .sp\:h-auto{
    height: auto;
  }
  .sp\:w-\[\.5rem\]{
    width: .5rem;
  }
  .sp\:w-\[1\.5rem\]{
    width: 1.5rem;
  }
  .sp\:w-\[10rem\]{
    width: 10rem;
  }
  .sp\:w-\[12\.2rem\]{
    width: 12.2rem;
  }
  .sp\:w-\[16rem\]{
    width: 16rem;
  }
  .sp\:w-\[17\.7rem\]{
    width: 17.7rem;
  }
  .sp\:w-\[2\.2rem\]{
    width: 2.2rem;
  }
  .sp\:w-\[20\.7rem\]{
    width: 20.7rem;
  }
  .sp\:w-\[24\.9rem\]{
    width: 24.9rem;
  }
  .sp\:w-\[32\.8rem\]{
    width: 32.8rem;
  }
  .sp\:w-\[35\.4rem\]{
    width: 35.4rem;
  }
  .sp\:w-\[5\.7rem\]{
    width: 5.7rem;
  }
  .sp\:w-full{
    width: 100%;
  }
  .sp\:translate-x-\[-50\%\]{
    --tw-translate-x: -50%;
    -webkit-transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
            transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  }
  .sp\:flex-col{
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .sp\:flex-wrap{
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .sp\:items-center{
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .sp\:justify-center{
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .sp\:gap-\[0\]{
    gap: 0;
  }
  .sp\:gap-\[1\.5rem\]{
    gap: 1.5rem;
  }
  .sp\:gap-\[2rem\]{
    gap: 2rem;
  }
  .sp\:gap-\[4\.5rem\]{
    gap: 4.5rem;
  }
  .sp\:gap-\[4rem\]{
    gap: 4rem;
  }
  .sp\:px-\[4rem\]{
    padding-left: 4rem;
    padding-right: 4rem;
  }
  .sp\:pb-\[10rem\]{
    padding-bottom: 10rem;
  }
  .sp\:pb-\[1rem\]{
    padding-bottom: 1rem;
  }
  .sp\:pb-\[24\.8rem\]{
    padding-bottom: 24.8rem;
  }
  .sp\:pb-\[8\.1rem\]{
    padding-bottom: 8.1rem;
  }
  .sp\:pr-\[0\]{
    padding-right: 0;
  }
  .sp\:pt-\[13\.3rem\]{
    padding-top: 13.3rem;
  }
  .sp\:pt-\[29\.3rem\]{
    padding-top: 29.3rem;
  }
  .sp\:pt-\[6rem\]{
    padding-top: 6rem;
  }
  .sp\:pt-\[8rem\]{
    padding-top: 8rem;
  }
  .sp\:text-\[1\.4rem\]{
    font-size: 1.4rem;
  }
  .sp\:text-\[1\.8rem\]{
    font-size: 1.8rem;
  }
  .sp\:text-\[2\.1rem\]{
    font-size: 2.1rem;
  }
  .sp\:text-\[3\.8rem\]{
    font-size: 3.8rem;
  }
  .sp\:leading-\[200\%\]{
    line-height: 200%;
  }
  .sp\:\[\&\:before\]\:absolute:before{
    position: absolute;
  }
  .sp\:\[\&\:before\]\:left-0:before{
    left: 0px;
  }
  .sp\:\[\&\:before\]\:top-\[1px\]:before{
    top: 1px;
  }
  .sp\:\[\&\:before\]\:z-\[-1\]:before{
    z-index: -1;
  }
  .sp\:\[\&\:before\]\:h-\[55rem\]:before{
    height: 55rem;
  }
  .sp\:\[\&\:before\]\:w-full:before{
    width: 100%;
  }
  .sp\:\[\&\:before\]\:translate-y-\[-100\%\]:before{
    --tw-translate-y: -100%;
    -webkit-transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
            transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  }
  .sp\:\[\&\:before\]\:bg-\[\#E8EAEA\]:before{
    --tw-bg-opacity: 1;
    background-color: rgb(232 234 234 / var(--tw-bg-opacity, 1));
  }
  .sp\:\[\&\:before\]\:content-\[\'\'\]:before{
    --tw-content: '';
    content: var(--tw-content);
  }
  .sp\:\[\&_\*\]\:relative *{
    position: relative;
  }
  .sp\:\[\&_\*\]\:z-\[1\] *{
    z-index: 1;
  }
  .sp\:\[\&_\.t-box\>h4\]\:text-\[1\.8rem\] .t-box>h4{
    font-size: 1.8rem;
  }
  .sp\:\[\&_\.t-box\>span\]\:text-\[1\.3rem\] .t-box>span{
    font-size: 1.3rem;
  }
  .sp\:\[\&_\.t-box\]\:w-full .t-box{
    width: 100%;
  }
  .sp\:\[\&_li\:nth-child\(4\)\]\:mr-\[\.5rem\] li:nth-child(4){
    margin-right: .5rem;
  }
  .sp\:\[\&_li\:nth-child\(5\)\]\:ml-\[\.5rem\] li:nth-child(5){
    margin-left: .5rem;
  }
  .sp\:\[\&_li\]\:px-\[1rem\] li{
    padding-left: 1rem;
    padding-right: 1rem;
  }
}
@media (min-width: 768px){
  .pc\:mx-auto{
    margin-left: auto;
    margin-right: auto;
  }
  .pc\:ml-\[27\.2rem\]{
    margin-left: 27.2rem;
  }
  .pc\:ml-\[44\.5rem\]{
    margin-left: 44.5rem;
  }
  .pc\:ml-\[68\.4rem\]{
    margin-left: 68.4rem;
  }
  .pc\:ml-\[76rem\]{
    margin-left: 76rem;
  }
  .pc\:mr-auto{
    margin-right: auto;
  }
  .pc\:max-w-\[140rem\]{
    max-width: 140rem;
  }
  .pc\:translate-x-\[-50\%\]{
    --tw-translate-x: -50%;
    -webkit-transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
            transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  }
  .pc\:justify-center{
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .pc\:pl-\[5rem\]{
    padding-left: 5rem;
  }
  .pc\:\[\&_li\]\:max-w-\[17\.6rem\] li{
    max-width: 17.6rem;
  }
  .pc\:\[\&_li\]\:flex-1 li{
    -webkit-box-flex: 1;
        -ms-flex: 1 1 0%;
            flex: 1 1 0%;
  }
}
/*# sourceMappingURL=../../_cache/_maps/styles.css.map */