@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@400;500;700;900&family=Zen+Maru+Gothic:wght@400;500;700;900&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}
.font-ttl {
  font-family: "Zen Maru Gothic", serif;
  font-weight: 700;
  color: #222; }
.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(20px);
          transform: translateY(20px); }
.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 1.2s, -webkit-transform 1.2s;
  transition: opacity 1.2s, -webkit-transform 1.2s;
  transition: opacity 1.2s, transform 1.2s;
  transition: opacity 1.2s, transform 1.2s, -webkit-transform 1.2s;
  -webkit-transform: translateY(15px);
          transform: translateY(15px); }
.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
 */
/**
* Variables
*/
/** extend */
/** http://bourbon.io/docs/#timing-functions */
/** example @include transition(all 5s $ease-in-circ);*/
/**
transition timing-function:
ease - cubic-bezier(0.25, 0.1, 0.25, 1.0) を指定したのと同じ（開始と完了を滑らかにする）（初期値）
linear - cubic-bezier(0.0, 0.0, 1.0, 1.0) を指定したのと同じ（一定）
ease-in - cubic-bezier(0.42, 0, 1.0, 1.0) を指定したのと同じ（ゆっくり始まる）
ease-out - cubic-bezier(0, 0, 0.58, 1.0) を指定したのと同じ（ゆっくり終わる）
ease-in-out - cubic-bezier(0.42, 0, 0.58, 1.0) を指定したのと同じ（ゆっくり始まってゆっくり終わる）
*/
/* == @import "../node_modules/normalize.css/normalize.css"; */
[v-cloak] {
  display: none; }
html {
  font-size: calc(10vw / 1400 * 100); }
body {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 1.6rem;
  color: #222;
  letter-spacing: 0; }
body.no-scroll {
    overflow: hidden; }
.l-main {
  background-color: #f2eee9; }
a {
  color: #000;
  text-decoration: none; }
a,
span {
  display: inline-block; }
*,
*::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; }
h2,
h3,
h4,
h5,
h6 {
  font-family: "Zen Maru Gothic", serif;
  font-weight: 700;
  color: #222; }
ul,
ol,
li {
  padding: 0;
  margin: 0; }
li {
  list-style: none; }
img {
  vertical-align: bottom; }
figure {
  padding: 0;
  margin: 0; }
picture {
  display: block;
  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%; }
/*! tailwindcss v3.3.6 | 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.
*/
html {
  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, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", 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 */
}
/*
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 */
  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,
[type='button'],
[type='reset'],
[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] {
  display: none;
}
*, ::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:  ;
}
::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:  ;
}
.l-footer {
  position: relative;
  background-color: #F2EEE9;
  padding: 3rem 0 5rem; }
.l-footer__inner {
    width: 110rem;
    margin-inline: auto; }
.l-footer__content {
    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;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column; }
.l-footer__content h2 {
      font-size: 1.8rem;
      font-weight: 700;
      letter-spacing: 0.05em;
      line-height: 1.8;
      color: #FF7F2F;
      text-align: center; }
.l-footer__content p {
      font-size: 1.5rem;
      font-weight: 500;
      letter-spacing: 0.05em;
      line-height: 1.8;
      color: #222222;
      text-align: center; }
.l-footer__content-link {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      gap: 0 1rem;
      margin-top: 1rem; }
.l-footer__content-link span {
        background-color: #fff;
        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;
        width: 2.5rem;
        height: 2.5rem;
        border-radius: 50%; }
.l-footer__content-link span svg {
          -webkit-transform: rotate(-135deg);
                  transform: rotate(-135deg); }
.l-footer__content-link .link01 {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-transition: .3s;
        transition: .3s; }
.l-footer__content-link .link01 span {
          position: relative;
          width: 3rem;
          height: 3rem;
          background-color: #fff;
          border-radius: 50%;
          margin-right: 0.5rem;
          -webkit-transition: .3s;
          transition: .3s; }
.l-footer__content-link .link01 span svg {
            position: absolute;
            top: 50%;
            left: 50%;
            -webkit-transform: translate(-50%, -50%) rotate(215deg);
                    transform: translate(-50%, -50%) rotate(215deg);
            width: 0.6rem; }
.l-footer__content-link .link01 p {
          font-size: 1.5rem;
          font-weight: 500;
          letter-spacing: 0.05em;
          line-height: 1.4;
          color: #222222;
          -webkit-transition: .3s;
          transition: .3s; }
.l-footer__content figure {
      width: 25rem;
      height: auto;
      margin-top: 2rem;
      margin-inline: auto; }
.l-footer__content figure img {
        width: 100%;
        height: 100%;
        -o-object-fit: contain;
           object-fit: contain; }
.l-footer__logo {
    margin-top: 4rem;
    margin-inline: auto; }
.l-footer__logo svg {
      margin-inline: auto; }
.l-footer__copy {
    margin-top: 3.5rem;
    text-align: center; }
.l-footer__copy small {
      font-size: 1.3rem;
      font-weight: 500;
      letter-spacing: 0.05em;
      line-height: 1.4;
      color: #222222; }
.l-footer__toTop {
    position: absolute;
    bottom: 10rem;
    right: 8.8rem; }
.l-footer__toTop a {
      width: 12.7rem;
      height: 20rem;
      -webkit-transition: .3s;
      transition: .3s; }
.l-footer__toTop a img {
        width: 100%;
        height: 100%;
        -o-object-fit: contain;
           object-fit: contain; }
.sp-entry {
  display: none;
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  -webkit-transition: .3s;
  transition: .3s;
  opacity: 0;
  pointer-events: none;
  z-index: -1; }
.sp-entry.is-active {
    opacity: 1;
    pointer-events: all;
    z-index: 100; }
.sp-entry button {
    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;
    background-color: #FF7F2F;
    width: 19.4rem;
    padding: 1.7rem 0;
    border-radius: 4rem; }
.sp-entry button span {
      width: 2.54rem;
      height: 2.1rem;
      margin-right: 0.8rem; }
.sp-entry button span svg {
        width: 100%;
        height: 100%; }
.sp-entry button p {
      color: #fff; }
.fixed-circle {
  position: fixed;
  right: 4rem;
  bottom: 4rem;
  width: 15rem;
  height: 15rem;
  z-index: 9;
  -webkit-transition: .3s;
  transition: .3s;
  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; }
.fixed-circle.is-none {
    opacity: 0 !important;
    pointer-events: none; }
.fixed-circle-txt {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    width: 10rem;
    height: 10rem;
    z-index: 1; }
.fixed-circle-txt.main {
      width: 10rem;
      height: auto; }
.fixed-circle-txt img {
      width: 100%;
      height: 100%;
      -o-object-fit: contain;
         object-fit: contain; }
.fixed-circle-bg {
    width: 15.3rem;
    height: 15.3rem;
    -webkit-animation: 20s linear infinite rotation1;
            animation: 20s linear infinite rotation1; }
.fixed-circle-bg img {
      width: 100%;
      height: 100%;
      -o-object-fit: contain;
         object-fit: contain; }
@-webkit-keyframes rotation1 {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0); }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg); } }
@keyframes rotation1 {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0); }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg); } }
.l-footer-ntxt {
  margin-top: 2rem; }
.l-footer-ntxt .l-footer__content-link {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center; }
.l-footer-ntxt .l-footer__content-link.mail span svg {
      -webkit-transform: rotate(0);
              transform: rotate(0); }
.l-footer-ntxt .mintxt {
    font-size: 1.2rem;
    margin-top: 1rem; }
.l-header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  height: 14rem;
  background-color: transparent;
  -webkit-transition: background-color 0.3s, height 0.3s;
  transition: background-color 0.3s, height 0.3s; }
.l-header.is-scroll {
    height: 8rem;
    background-color: white; }
.l-header.is-scroll .l-header__logo {
      margin-left: 0; }
.l-header__inner {
    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;
    width: 100%;
    height: 100%;
    padding: 0 4rem;
    -webkit-transition: padding 0.3s;
    transition: padding 0.3s; }
.l-header__logo {
    margin-left: 4rem;
    -webkit-transition: margin 0.3s;
    transition: margin 0.3s; }
.l-header__sp-toggle {
    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;
    width: 9rem;
    height: 4rem;
    font-family: "Zen Maru Gothic", serif;
    font-size: 1.4rem;
    font-weight: bold;
    color: white;
    letter-spacing: 0.1rem;
    background: #ff7f2f;
    border-radius: 2.9rem; }
.l-header__sp-menu {
    position: fixed;
    top: 0;
    left: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    display: none;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 100vw;
    height: 100vh;
    overflow-y: scroll;
    background-color: rgb(242 238 233 / 90%); }
.l-header__sp-menu-list {
      position: relative;
      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;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      width: 36rem;
      padding: 9.4rem 0;
      background-color: #ff7f2f;
      border-radius: 2.9rem; }
.l-header__sp-menu-item {
      width: 27rem;
      font-family: "Zen Maru Gothic", serif;
      font-size: 2.2rem;
      font-weight: bold;
      color: white;
      text-align: left;
      white-space: nowrap; }
.l-header__sp-menu-close {
      position: absolute;
      top: 2.5rem;
      right: 2.5rem;
      font-family: "Zen Maru Gothic", serif;
      font-size: 1.4rem;
      font-weight: bold;
      color: white;
      letter-spacing: 0.1rem; }
.l-header__menu {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center; }
.l-header__menu li:nth-of-type(n + 2) {
      margin-left: 3.2rem; }
.l-header__menu li a {
      font-size: 1.5rem;
      font-weight: 700;
      letter-spacing: 0.05em;
      line-height: 1.4;
      font-family: "Zen Maru Gothic", serif;
      color: #222;
      -webkit-transition: 0.3s;
      transition: 0.3s; }
.l-main--default-page {
  padding-top: 16rem;
  padding-bottom: 10rem; }
.c-btn01 {
  position: relative;
  z-index: 1;
  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;
  width: 28.8rem;
  height: 7rem;
  margin-inline: auto;
  overflow: hidden;
  background-color: #f2eee9;
  border-radius: 5rem;
  -webkit-transition: 0.3s;
  transition: 0.3s; }
.c-btn01::before {
    position: absolute;
    top: 0;
    right: 0;
    width: 50%;
    height: 100%;
    content: "";
    background-color: #ffca3b;
    border-top-right-radius: 5rem;
    border-bottom-right-radius: 5rem;
    -webkit-transition: 0.3s;
    transition: 0.3s; }
.c-btn01::after {
    position: absolute;
    top: 0;
    left: 0;
    width: 50%;
    height: 100%;
    content: "";
    background-color: #ff7f2f;
    border-top-left-radius: 5rem;
    border-bottom-left-radius: 5rem;
    -webkit-transition: 0.3s;
    transition: 0.3s; }
.c-btn01 span {
    position: relative;
    z-index: 2;
    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;
    width: calc(100% - 0.8rem);
    height: calc(100% - 0.8rem);
    padding-left: 2rem;
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 1.3;
    color: #222;
    letter-spacing: 0.05em;
    background-color: #fff;
    border-radius: 5rem;
    -webkit-transition: 0.3s;
    transition: 0.3s; }
.c-btn01 span::before {
      position: absolute;
      top: 50%;
      left: 3rem;
      width: 2.3rem;
      height: 2.3rem;
      content: "";
      border: solid 0.8rem #ffca3b;
      border-radius: 50%;
      -webkit-transition: 0.3s;
      transition: 0.3s;
      -webkit-transform: translateY(-50%);
              transform: translateY(-50%); }
.c-btn01-s {
    width: 30rem;
    height: 8.5rem; }
.c-btn01-s span {
      padding-left: 3rem;
      font-size: 2rem;
      letter-spacing: 0.02em; }
.c-btn01-s span::before {
        left: 1.8rem; }
.c-btn01-m {
    width: 35rem;
    height: 8rem; }
.c-btn01-m span {
      padding-left: 3rem;
      font-family: "Zen Maru Gothic", serif;
      font-size: 2.8rem;
      letter-spacing: 0.05em; }
.c-btn01-m span::before {
        left: 3rem; }
.c-btn01-c {
    width: 30rem;
    height: 8.5rem; }
.c-btn01-c span {
      padding-left: 0;
      font-size: 2rem;
      letter-spacing: 0.02em; }
.c-btn01-c span::before {
        left: 2.4rem; }
.c-btn02 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 40rem;
  padding: 1.5rem;
  margin-right: auto;
  background-color: #ff7f2f;
  border: 2px solid #ff7f2f;
  border-radius: 3rem;
  -webkit-transition: 0.3s;
  transition: 0.3s; }
.c-btn02 p {
    position: relative;
    font-family: "Zen Maru Gothic", serif;
    color: #fff !important;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    line-height: 1.4; }
.c-btn02 p::before {
      position: absolute;
      top: 50%;
      left: -2.5rem;
      width: 1.9rem;
      height: 1.9rem;
      content: "";
      background-color: #fff;
      border-radius: 50%;
      -webkit-transition: 0.3s;
      transition: 0.3s;
      -webkit-transform: translateY(-50%);
              transform: translateY(-50%); }
.c-btn02 p::after {
      position: absolute;
      top: 50%;
      left: -1.9rem;
      width: 0.7rem;
      height: 0.7rem;
      content: "";
      background-color: #ff7f2f;
      border-radius: 50%;
      -webkit-transition: 0.3s;
      transition: 0.3s;
      -webkit-transform: translateY(-50%);
              transform: translateY(-50%); }
.c-btn-camera {
  position: relative;
  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;
  width: 19.4rem;
  height: 6rem;
  padding-left: 4rem;
  margin-inline: auto;
  font-family: "Zen Maru Gothic", serif;
  font-size: 1.5rem;
  font-weight: bold;
  color: white;
  background-color: #ff7f2f;
  border-radius: 3.7rem;
  -webkit-box-shadow: 0 0.3rem 0.8rem rgb(160 129 71 / 16%);
          box-shadow: 0 0.3rem 0.8rem rgb(160 129 71 / 16%); }
.c-btn-camera::before {
    position: absolute;
    top: 50%;
    left: 2.7rem;
    display: block;
    width: 2.6rem;
    height: 2.1rem;
    content: "";
    background-color: white;
    -webkit-transform: translate(0, -50%);
            transform: translate(0, -50%);
    -webkit-mask-image: url(../svg/icon-camera.svg);
            mask-image: url(../svg/icon-camera.svg);
    -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
    -webkit-mask-position: center;
            mask-position: center;
    -webkit-mask-size: contain;
            mask-size: contain; }
.c-over-link {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 1; }
.c-modal {
  position: fixed;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 90%;
  height: 90%;
  border-radius: 3rem;
  background-color: #FFFFFF;
  z-index: 0;
  opacity: 0;
  pointer-events: none;
  padding: 5rem;
  -webkit-transition: .4s opacity;
  transition: .4s opacity; }
.c-modal.is-active {
    opacity: 1;
    pointer-events: all;
    z-index: 10000; }
.c-modal__video {
    display: none; }
.c-modal__video.is-active {
      display: block; }
.c-modal__video-wrap {
      width: 100%;
      height: 100%; }
.c-modal__video-wrap iframe {
        width: 100%;
        height: 100%; }
.c-modal__close {
    position: absolute;
    top: -2rem;
    right: -2rem;
    width: 5rem;
    height: 5rem;
    background-color: #FF7F2F;
    border-radius: 50%; }
.c-modal__close::before, .c-modal__close::after {
      position: absolute;
      content: "";
      top: 50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%) rotate(45deg);
              transform: translate(-50%, -50%) rotate(45deg);
      width: 2rem;
      height: 0.3rem;
      background-color: #F2EEE9; }
.c-modal__close:after {
      -webkit-transform: translate(-50%, -50%) rotate(-45deg);
              transform: translate(-50%, -50%) rotate(-45deg); }
.overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(242, 238, 233, 0.8);
  z-index: 0;
  pointer-events: none;
  opacity: 0;
  -webkit-transition: .4s opacity;
  transition: .4s opacity; }
.overlay.is-active {
    opacity: 1;
    pointer-events: all;
    z-index: 9999; }
.c-sns-list {
  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: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 8rem 0; }
.c-sns-list__ttl {
    font-size: 2.4rem;
    font-weight: bold;
    font-family: "Zen Maru Gothic", serif;
    letter-spacing: 0.1rem;
    margin-bottom: 2.5rem; }
.c-sns-list__list {
    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;
    gap: 2.4rem; }
.c-sns-list__item a {
    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;
    width: 10.5rem;
    height: 10.5rem;
    background-color: white;
    border-radius: 100%; }
.c-speech-balloon {
  position: relative;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  padding: 1.5rem 4rem;
  font-family: "Zen Maru Gothic", serif;
  font-size: 2rem;
  font-weight: bold;
  letter-spacing: 0.2rem;
  background-color: #ffca3b;
  border-radius: 3.7rem; }
.c-speech-balloon::before {
    position: absolute;
    top: 100%;
    left: 50%;
    display: block;
    width: 3.4rem;
    height: 1.6rem;
    content: "";
    background-color: #ffca3b;
    -webkit-transform: translate(-50%, 0) translateX(-2rem);
            transform: translate(-50%, 0) translateX(-2rem);
    -webkit-mask-image: url(../svg/ic-sb-before.svg);
            mask-image: url(../svg/ic-sb-before.svg);
    -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
    -webkit-mask-size: contain;
            mask-size: contain;
    -webkit-mask-position: center;
            mask-position: center; }
.c-text--beginner {
  color: #FF7F2F; }
.c-text--intermediate {
  color: #88B3AB; }
.c-text--advanced {
  color: #4B639A; }
.c-ttl01 p {
  position: relative;
  padding-left: 2.5rem;
  font-family: "Zen Maru Gothic", serif;
  color: #222;
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.4; }
.c-ttl01 p::before {
    position: absolute;
    top: 50%;
    left: 0;
    width: 2rem;
    height: 2rem;
    content: "";
    background-color: #ffca3b;
    border-radius: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%); }
.c-ttl01 p::after {
    position: absolute;
    top: 50%;
    left: 0.6rem;
    width: 0.8rem;
    height: 0.8rem;
    content: "";
    background-color: #fff;
    border-radius: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%); }
.c-ttl-simple-dot {
  position: relative;
  margin-bottom: 3.5rem;
  font-family: "Zen Maru Gothic", serif;
  font-size: 4.2rem;
  font-weight: bold;
  line-height: 1.3;
  letter-spacing: 0.05em; }
.c-ttl-simple-dot::before {
    position: absolute;
    top: 2rem;
    right: calc(100% + 0.5rem);
    width: 1.6rem;
    height: 1.6rem;
    content: "";
    background-color: #ffca3b;
    border-radius: 100%; }
.c-ttl-simple {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1rem;
  font-family: "Zen Maru Gothic", serif;
  font-weight: bold; }
.c-ttl-simple__main {
    font-size: 4.2rem;
    color: #ff7f2f; }
.c-ttl-simple__sub {
    font-size: 3.2rem; }
.c-ttl-bg-en {
  position: relative;
  text-align: center; }
.c-ttl-bg-en__en {
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    font-family: "Zen Maru Gothic", serif;
    font-size: 13rem;
    font-weight: bold;
    color: #fffbf7;
    -webkit-transform: translate(0, calc(-50% - 1rem));
            transform: translate(0, calc(-50% - 1rem)); }
.c-ttl-bg-en__main {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 1rem;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    font-family: "Zen Maru Gothic", serif;
    font-size: 3.2rem;
    font-weight: bold;
    letter-spacing: 0.2rem; }
.c-ttl-bg-en__main::before {
      display: block;
      width: 1.3rem;
      height: 1.3rem;
      content: "";
      background-color: #ffca3b;
      border-radius: 100%; }
.c-ttl-top-circle {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-family: "Zen Maru Gothic", serif;
  font-size: 3.2rem;
  font-weight: bold;
  text-align: center; }
.c-ttl-top-circle::before {
    display: block;
    width: 4.6rem;
    height: 4.6rem;
    content: "";
    border: solid 1.5rem #ffca3b;
    border-radius: 100%; }
.c-remark-list__dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  margin-bottom: 1.5rem;
  font-weight: 500; }
.c-remark-list__dl--full {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column; }
.c-remark-list__dl--full .c-remark-list__dt {
      width: 100%;
      border: none; }
.c-remark-list__dl--full .c-remark-list__dd {
      width: 100%;
      border: none;
      padding-inline: 0;
      font-size: 1.4rem;
      line-height: 2; }
.c-remark-list__dt {
  width: 7rem;
  border-bottom: solid 2px #222222;
  font-size: 1.8rem;
  font-weight: bold;
  font-family: "Zen Maru Gothic", serif;
  padding: 0.5rem 0; }
.c-remark-list__dd {
  width: calc(100% - 7rem);
  border-bottom: solid 2px #C3B4A8;
  font-size: 1.8rem;
  padding: 0.5rem 1.5rem; }
.c-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; }
.c-google-maps {
  position: relative;
  padding-bottom: 75%;
  height: 0;
  overflow: hidden; }
.c-google-maps iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important; }
.c-inner {
  width: 110rem;
  margin-inline: auto; }
.c-inner--home {
    width: 100rem; }
.c-l-inner {
  width: 120rem;
  margin: 0 auto; }
.modal {
  position: fixed;
  top: 3rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 110rem;
  z-index: -1;
  opacity: 0;
  pointer-events: none;
  -webkit-transition: .4s;
  transition: .4s; }
.modal.is-open {
    z-index: 9999;
    opacity: 1;
    pointer-events: all; }
.modal__ttl {
    position: relative;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    background: url(./../images/top/harf-circle.png) no-repeat center center/cover;
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    width: 40rem; }
.modal__ttl-wrap {
      margin-top: 4rem;
      margin-bottom: 1rem; }
.modal__ttl-wrap img {
        width: 3.8rem;
        height: 3.1rem;
        -o-object-fit: contain;
           object-fit: contain;
        margin-inline: auto; }
.modal__ttl-wrap h2 {
        font-size: 3rem;
        font-weight: 700;
        letter-spacing: 0.05em;
        line-height: 1.4; }
.modal__container {
    background-color: #fff;
    border-radius: 2rem;
    padding: 6rem 5.5rem 6rem 9rem; }
.modal__body {
    max-height: 45rem;
    overflow-y: scroll;
    padding-right: 3rem; }
.modal__body::-webkit-scrollbar {
      background: #F2EEE9;
      width: 0.5rem;
      border-radius: 1rem; }
.modal__body::-webkit-scrollbar-thumb {
      background-color: #FF7F2F;
      border-radius: 1rem; }
.modal__body p {
      position: relative;
      font-size: 1.5rem;
      font-weight: 500;
      letter-spacing: 0.05em;
      line-height: 1.4;
      color: #222222;
      padding-left: 1.6rem; }
.modal__body p:nth-of-type(n + 2) {
        margin-top: 1.2rem; }
.modal__body p::before {
        position: absolute;
        content: "";
        top: 0.6rem;
        left: 0;
        background: url(./../images/top/orange-circle.png) no-repeat center center/contain;
        width: 1rem;
        height: 1rem; }
.modal__body span {
      font-size: 1.5rem;
      font-weight: 500;
      letter-spacing: 0.05em;
      line-height: 1.4;
      color: #222222;
      padding-left: 1.6rem; }
.modal__btn {
    margin-top: 4rem; }
.modal__btn-link {
      margin-inline: auto; }
.modal__close {
  position: absolute;
  bottom: 2rem;
  right: 4rem;
  cursor: pointer;
  z-index: -1;
  -webkit-transition: .4s;
  transition: .4s;
  opacity: 0;
  pointer-events: none; }
.modal__close.is-open {
    z-index: 10000;
    opacity: 1;
    pointer-events: all; }
.modal__close p {
    display: block;
    width: 10rem;
    text-align: center;
    font-size: 1.6rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 1.4;
    color: #FF7F2F;
    background-color: #fff;
    padding: 1rem 0;
    border: 2px solid #FF7F2F;
    border-radius: 4rem;
    -webkit-transition: .4s;
    transition: .4s; }
.bg-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 110vw;
  height: 110vh;
  background-color: #F2EEE9;
  z-index: -1;
  opacity: 0;
  pointer-events: none;
  -webkit-transition: .4s;
  transition: .4s; }
.bg-overlay.is-open {
    z-index: 999;
    opacity: 1;
    pointer-events: all; }
/**
* wordpress
* WYSIWYG compatchble style
*/
.c-wp-post_article strong {
  font-weight: bold; }
.c-wp-post_article em {
  font-style: italic; }
.c-wp-post_article ul {
  margin-left: 1em;
  display: block;
  list-style-type: disc !important;
  margin-before: 1em;
  margin-after: 1em;
  margin-start: 0px;
  margin-end: 0px;
  padding-start: 40px; }
.c-wp-post_article ol {
  display: block;
  list-style-type: decimal !important;
  margin-before: 1em;
  margin-after: 1em;
  margin-start: 0px;
  margin-end: 0px;
  padding-start: 40px; }
.c-wp-post_article li {
  display: list-item;
  text-align: match-parent; }
.c-wp-post_article img {
  width: auto; }
.c-wp-post_article .alignleft {
  display: inline;
  float: left; }
.c-wp-post_article .alignright {
  display: inline;
  float: right; }
.c-wp-post_article .aligncenter {
  display: block;
  margin-right: auto;
  margin-left: auto; }
.c-wp-post_article blockquote.alignleft,
.c-wp-post_article .wp-caption.alignleft,
.c-wp-post_article img.alignleft {
  margin: 0.4em 1.6em 1.6em 0; }
.c-wp-post_article blockquote.alignright,
.c-wp-post_article .wp-caption.alignright,
.c-wp-post_article img.alignright {
  margin: 0.4em 0 1.6em 1.6em; }
.c-wp-post_article blockquote.aligncenter,
.c-wp-post_article .wp-caption.aligncenter,
.c-wp-post_article img.aligncenter {
  clear: both;
  margin-top: 0.4em;
  margin-bottom: 1.6em; }
.c-wp-post_article .wp-caption.alignleft,
.c-wp-post_article .wp-caption.alignright,
.c-wp-post_article .wp-caption.aligncenter {
  margin-bottom: 1.2em; }
/**
 * clearfix micro
 */
.clearfix:after {
  content: "";
  clear: both;
  display: block; }
/**
 * text ellipsis., text...
 */
.text-ellipsis {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap; }
.u-hide {
  display: none; }
.u-click {
  cursor: pointer; }
/* ==========================================================================
 font-size
========================================================================== */
/* font-size */
.u-fs-0 {
  font-size: 0rem !important; }
.u-fs-1 {
  font-size: 0.1rem !important; }
.u-fs-2 {
  font-size: 0.2rem !important; }
.u-fs-3 {
  font-size: 0.3rem !important; }
.u-fs-4 {
  font-size: 0.4rem !important; }
.u-fs-5 {
  font-size: 0.5rem !important; }
.u-fs-6 {
  font-size: 0.6rem !important; }
.u-fs-7 {
  font-size: 0.7rem !important; }
.u-fs-8 {
  font-size: 0.8rem !important; }
.u-fs-9 {
  font-size: 0.9rem !important; }
.u-fs-10 {
  font-size: 1rem !important; }
.u-fs-11 {
  font-size: 1.1rem !important; }
.u-fs-12 {
  font-size: 1.2rem !important; }
.u-fs-13 {
  font-size: 1.3rem !important; }
.u-fs-14 {
  font-size: 1.4rem !important; }
.u-fs-15 {
  font-size: 1.5rem !important; }
.u-fs-16 {
  font-size: 1.6rem !important; }
.u-fs-17 {
  font-size: 1.7rem !important; }
.u-fs-18 {
  font-size: 1.8rem !important; }
.u-fs-19 {
  font-size: 1.9rem !important; }
.u-fs-20 {
  font-size: 2rem !important; }
.u-fs-21 {
  font-size: 2.1rem !important; }
.u-fs-22 {
  font-size: 2.2rem !important; }
.u-fs-23 {
  font-size: 2.3rem !important; }
.u-fs-24 {
  font-size: 2.4rem !important; }
.u-fs-25 {
  font-size: 2.5rem !important; }
.u-fs-26 {
  font-size: 2.6rem !important; }
.u-fs-27 {
  font-size: 2.7rem !important; }
.u-fs-28 {
  font-size: 2.8rem !important; }
.u-fs-29 {
  font-size: 2.9rem !important; }
.u-fs-30 {
  font-size: 3rem !important; }
.u-fs-31 {
  font-size: 3.1rem !important; }
.u-fs-32 {
  font-size: 3.2rem !important; }
.u-fs-33 {
  font-size: 3.3rem !important; }
.u-fs-34 {
  font-size: 3.4rem !important; }
.u-fs-35 {
  font-size: 3.5rem !important; }
.u-fs-36 {
  font-size: 3.6rem !important; }
.u-fs-37 {
  font-size: 3.7rem !important; }
.u-fs-38 {
  font-size: 3.8rem !important; }
.u-fs-39 {
  font-size: 3.9rem !important; }
.u-fs-40 {
  font-size: 4rem !important; }
.u-fs-41 {
  font-size: 4.1rem !important; }
.u-fs-42 {
  font-size: 4.2rem !important; }
.u-fs-43 {
  font-size: 4.3rem !important; }
.u-fs-44 {
  font-size: 4.4rem !important; }
.u-fs-45 {
  font-size: 4.5rem !important; }
.u-fs-46 {
  font-size: 4.6rem !important; }
.u-fs-47 {
  font-size: 4.7rem !important; }
.u-fs-48 {
  font-size: 4.8rem !important; }
.u-fs-49 {
  font-size: 4.9rem !important; }
/* ==========================================================================
 font-weigth
========================================================================== */
/* font-weigth */
.u-fw-l {
  font-weight: lighter !important; }
.u-fw-n {
  font-weight: normal !important; }
.u-fw-b {
  font-weight: bold !important; }
/**
 * clearfix micro
 */
.clearfix:after {
  content: "";
  clear: both;
  display: block; }
/**
 * text ellipsis., text...
 */
.text-ellipsis {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap; }
.u-hide {
  display: none; }
.u-click {
  cursor: pointer; }
/* ==========================================================================
 line-height
========================================================================== */
/* line-height */
.u-lh-0 {
  line-height: 0 !important; }
.u-lh-1 {
  line-height: 0.1 !important; }
.u-lh-2 {
  line-height: 0.2 !important; }
.u-lh-3 {
  line-height: 0.3 !important; }
.u-lh-4 {
  line-height: 0.4 !important; }
.u-lh-5 {
  line-height: 0.5 !important; }
.u-lh-6 {
  line-height: 0.6 !important; }
.u-lh-7 {
  line-height: 0.7 !important; }
.u-lh-8 {
  line-height: 0.8 !important; }
.u-lh-9 {
  line-height: 0.9 !important; }
.u-lh-10 {
  line-height: 1 !important; }
.u-lh-11 {
  line-height: 1.1 !important; }
.u-lh-12 {
  line-height: 1.2 !important; }
.u-lh-13 {
  line-height: 1.3 !important; }
.u-lh-14 {
  line-height: 1.4 !important; }
.u-lh-15 {
  line-height: 1.5 !important; }
.u-lh-16 {
  line-height: 1.6 !important; }
.u-lh-17 {
  line-height: 1.7 !important; }
.u-lh-18 {
  line-height: 1.8 !important; }
.u-lh-19 {
  line-height: 1.9 !important; }
.u-lh-20 {
  line-height: 2 !important; }
.u-lh-21 {
  line-height: 2.1 !important; }
.u-lh-22 {
  line-height: 2.2 !important; }
.u-lh-23 {
  line-height: 2.3 !important; }
.u-lh-24 {
  line-height: 2.4 !important; }
.u-lh-25 {
  line-height: 2.5 !important; }
.u-lh-26 {
  line-height: 2.6 !important; }
.u-lh-27 {
  line-height: 2.7 !important; }
.u-lh-28 {
  line-height: 2.8 !important; }
.u-lh-29 {
  line-height: 2.9 !important; }
.u-lh-30 {
  line-height: 3 !important; }
.u-lh-31 {
  line-height: 3.1 !important; }
.u-lh-32 {
  line-height: 3.2 !important; }
.u-lh-33 {
  line-height: 3.3 !important; }
.u-lh-34 {
  line-height: 3.4 !important; }
.u-lh-35 {
  line-height: 3.5 !important; }
.u-lh-36 {
  line-height: 3.6 !important; }
.u-lh-37 {
  line-height: 3.7 !important; }
.u-lh-38 {
  line-height: 3.8 !important; }
.u-lh-39 {
  line-height: 3.9 !important; }
.u-lh-40 {
  line-height: 4 !important; }
.u-lh-41 {
  line-height: 4.1 !important; }
.u-lh-42 {
  line-height: 4.2 !important; }
.u-lh-43 {
  line-height: 4.3 !important; }
.u-lh-44 {
  line-height: 4.4 !important; }
.u-lh-45 {
  line-height: 4.5 !important; }
.u-lh-46 {
  line-height: 4.6 !important; }
.u-lh-47 {
  line-height: 4.7 !important; }
.u-lh-48 {
  line-height: 4.8 !important; }
.u-lh-49 {
  line-height: 4.9 !important; }
/* ==========================================================================
 margin
========================================================================== */
.u-m-c {
  margin-right: auto !important;
  margin-left: auto !important; }
.u-m-r {
  margin-right: auto !important;
  margin-left: 0 !important; }
/* Top margin */
.u-mt-0 {
  margin-top: 0rem !important; }
.u-mt-1 {
  margin-top: 1rem !important; }
.u-mt-2 {
  margin-top: 2rem !important; }
.u-mt-3 {
  margin-top: 3rem !important; }
.u-mt-4 {
  margin-top: 4rem !important; }
.u-mt-5 {
  margin-top: 5rem !important; }
.u-mt-6 {
  margin-top: 6rem !important; }
.u-mt-7 {
  margin-top: 7rem !important; }
.u-mt-8 {
  margin-top: 8rem !important; }
.u-mt-9 {
  margin-top: 9rem !important; }
.u-mt-10 {
  margin-top: 10rem !important; }
.u-mt-11 {
  margin-top: 11rem !important; }
.u-mt-12 {
  margin-top: 12rem !important; }
.u-mt-13 {
  margin-top: 13rem !important; }
.u-mt-14 {
  margin-top: 14rem !important; }
.u-mt-15 {
  margin-top: 15rem !important; }
.u-mt-16 {
  margin-top: 16rem !important; }
.u-mt-17 {
  margin-top: 17rem !important; }
.u-mt-18 {
  margin-top: 18rem !important; }
.u-mt-19 {
  margin-top: 19rem !important; }
.u-mt-20 {
  margin-top: 20rem !important; }
.u-mt-21 {
  margin-top: 21rem !important; }
.u-mt-22 {
  margin-top: 22rem !important; }
.u-mt-23 {
  margin-top: 23rem !important; }
.u-mt-24 {
  margin-top: 24rem !important; }
.u-mt-25 {
  margin-top: 25rem !important; }
/* Right margin */
.u-mr-0 {
  margin-right: 0rem !important; }
.u-mr-1 {
  margin-right: 1rem !important; }
.u-mr-2 {
  margin-right: 2rem !important; }
.u-mr-3 {
  margin-right: 3rem !important; }
.u-mr-4 {
  margin-right: 4rem !important; }
.u-mr-5 {
  margin-right: 5rem !important; }
.u-mr-6 {
  margin-right: 6rem !important; }
.u-mr-7 {
  margin-right: 7rem !important; }
.u-mr-8 {
  margin-right: 8rem !important; }
.u-mr-9 {
  margin-right: 9rem !important; }
.u-mr-10 {
  margin-right: 10rem !important; }
.u-mr-11 {
  margin-right: 11rem !important; }
.u-mr-12 {
  margin-right: 12rem !important; }
.u-mr-13 {
  margin-right: 13rem !important; }
.u-mr-14 {
  margin-right: 14rem !important; }
.u-mr-15 {
  margin-right: 15rem !important; }
.u-mr-16 {
  margin-right: 16rem !important; }
.u-mr-17 {
  margin-right: 17rem !important; }
.u-mr-18 {
  margin-right: 18rem !important; }
.u-mr-19 {
  margin-right: 19rem !important; }
.u-mr-20 {
  margin-right: 20rem !important; }
.u-mr-21 {
  margin-right: 21rem !important; }
.u-mr-22 {
  margin-right: 22rem !important; }
.u-mr-23 {
  margin-right: 23rem !important; }
.u-mr-24 {
  margin-right: 24rem !important; }
.u-mr-25 {
  margin-right: 25rem !important; }
/* Bottom margin */
.u-mb-0 {
  margin-bottom: 0rem !important; }
.u-mb-1 {
  margin-bottom: 1rem !important; }
.u-mb-2 {
  margin-bottom: 2rem !important; }
.u-mb-3 {
  margin-bottom: 3rem !important; }
.u-mb-4 {
  margin-bottom: 4rem !important; }
.u-mb-5 {
  margin-bottom: 5rem !important; }
.u-mb-6 {
  margin-bottom: 6rem !important; }
.u-mb-7 {
  margin-bottom: 7rem !important; }
.u-mb-8 {
  margin-bottom: 8rem !important; }
.u-mb-9 {
  margin-bottom: 9rem !important; }
.u-mb-10 {
  margin-bottom: 10rem !important; }
.u-mb-11 {
  margin-bottom: 11rem !important; }
.u-mb-12 {
  margin-bottom: 12rem !important; }
.u-mb-13 {
  margin-bottom: 13rem !important; }
.u-mb-14 {
  margin-bottom: 14rem !important; }
.u-mb-15 {
  margin-bottom: 15rem !important; }
.u-mb-16 {
  margin-bottom: 16rem !important; }
.u-mb-17 {
  margin-bottom: 17rem !important; }
.u-mb-18 {
  margin-bottom: 18rem !important; }
.u-mb-19 {
  margin-bottom: 19rem !important; }
.u-mb-20 {
  margin-bottom: 20rem !important; }
.u-mb-21 {
  margin-bottom: 21rem !important; }
.u-mb-22 {
  margin-bottom: 22rem !important; }
.u-mb-23 {
  margin-bottom: 23rem !important; }
.u-mb-24 {
  margin-bottom: 24rem !important; }
.u-mb-25 {
  margin-bottom: 25rem !important; }
/* Left margin */
.u-ml-0 {
  margin-left: 0rem !important; }
.u-ml-1 {
  margin-left: 1rem !important; }
.u-ml-2 {
  margin-left: 2rem !important; }
.u-ml-3 {
  margin-left: 3rem !important; }
.u-ml-4 {
  margin-left: 4rem !important; }
.u-ml-5 {
  margin-left: 5rem !important; }
.u-ml-6 {
  margin-left: 6rem !important; }
.u-ml-7 {
  margin-left: 7rem !important; }
.u-ml-8 {
  margin-left: 8rem !important; }
.u-ml-9 {
  margin-left: 9rem !important; }
.u-ml-10 {
  margin-left: 10rem !important; }
.u-ml-11 {
  margin-left: 11rem !important; }
.u-ml-12 {
  margin-left: 12rem !important; }
.u-ml-13 {
  margin-left: 13rem !important; }
.u-ml-14 {
  margin-left: 14rem !important; }
.u-ml-15 {
  margin-left: 15rem !important; }
.u-ml-16 {
  margin-left: 16rem !important; }
.u-ml-17 {
  margin-left: 17rem !important; }
.u-ml-18 {
  margin-left: 18rem !important; }
.u-ml-19 {
  margin-left: 19rem !important; }
.u-ml-20 {
  margin-left: 20rem !important; }
.u-ml-21 {
  margin-left: 21rem !important; }
.u-ml-22 {
  margin-left: 22rem !important; }
.u-ml-23 {
  margin-left: 23rem !important; }
.u-ml-24 {
  margin-left: 24rem !important; }
.u-ml-25 {
  margin-left: 25rem !important; }
.u-objectFit {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center; }
.u-objectIn {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center center;
     object-position: center center; }
/* ==========================================================================
 padding
========================================================================== */
/* Top padding */
.u-pt-0 {
  padding-top: 0rem !important; }
.u-pt-1 {
  padding-top: 1rem !important; }
.u-pt-2 {
  padding-top: 2rem !important; }
.u-pt-3 {
  padding-top: 3rem !important; }
.u-pt-4 {
  padding-top: 4rem !important; }
.u-pt-5 {
  padding-top: 5rem !important; }
.u-pt-6 {
  padding-top: 6rem !important; }
.u-pt-7 {
  padding-top: 7rem !important; }
.u-pt-8 {
  padding-top: 8rem !important; }
.u-pt-9 {
  padding-top: 9rem !important; }
.u-pt-10 {
  padding-top: 10rem !important; }
.u-pt-11 {
  padding-top: 11rem !important; }
.u-pt-12 {
  padding-top: 12rem !important; }
.u-pt-13 {
  padding-top: 13rem !important; }
.u-pt-14 {
  padding-top: 14rem !important; }
.u-pt-15 {
  padding-top: 15rem !important; }
.u-pt-16 {
  padding-top: 16rem !important; }
.u-pt-17 {
  padding-top: 17rem !important; }
.u-pt-18 {
  padding-top: 18rem !important; }
.u-pt-19 {
  padding-top: 19rem !important; }
.u-pt-20 {
  padding-top: 20rem !important; }
.u-pt-21 {
  padding-top: 21rem !important; }
.u-pt-22 {
  padding-top: 22rem !important; }
.u-pt-23 {
  padding-top: 23rem !important; }
.u-pt-24 {
  padding-top: 24rem !important; }
.u-pt-25 {
  padding-top: 25rem !important; }
/* Right padding */
.u-pr-0 {
  padding-right: 0rem !important; }
.u-pr-1 {
  padding-right: 1rem !important; }
.u-pr-2 {
  padding-right: 2rem !important; }
.u-pr-3 {
  padding-right: 3rem !important; }
.u-pr-4 {
  padding-right: 4rem !important; }
.u-pr-5 {
  padding-right: 5rem !important; }
.u-pr-6 {
  padding-right: 6rem !important; }
.u-pr-7 {
  padding-right: 7rem !important; }
.u-pr-8 {
  padding-right: 8rem !important; }
.u-pr-9 {
  padding-right: 9rem !important; }
.u-pr-10 {
  padding-right: 10rem !important; }
.u-pr-11 {
  padding-right: 11rem !important; }
.u-pr-12 {
  padding-right: 12rem !important; }
.u-pr-13 {
  padding-right: 13rem !important; }
.u-pr-14 {
  padding-right: 14rem !important; }
.u-pr-15 {
  padding-right: 15rem !important; }
.u-pr-16 {
  padding-right: 16rem !important; }
.u-pr-17 {
  padding-right: 17rem !important; }
.u-pr-18 {
  padding-right: 18rem !important; }
.u-pr-19 {
  padding-right: 19rem !important; }
.u-pr-20 {
  padding-right: 20rem !important; }
.u-pr-21 {
  padding-right: 21rem !important; }
.u-pr-22 {
  padding-right: 22rem !important; }
.u-pr-23 {
  padding-right: 23rem !important; }
.u-pr-24 {
  padding-right: 24rem !important; }
.u-pr-25 {
  padding-right: 25rem !important; }
/* Bottom padding */
.u-pb-0 {
  padding-bottom: 0rem !important; }
.u-pb-1 {
  padding-bottom: 1rem !important; }
.u-pb-2 {
  padding-bottom: 2rem !important; }
.u-pb-3 {
  padding-bottom: 3rem !important; }
.u-pb-4 {
  padding-bottom: 4rem !important; }
.u-pb-5 {
  padding-bottom: 5rem !important; }
.u-pb-6 {
  padding-bottom: 6rem !important; }
.u-pb-7 {
  padding-bottom: 7rem !important; }
.u-pb-8 {
  padding-bottom: 8rem !important; }
.u-pb-9 {
  padding-bottom: 9rem !important; }
.u-pb-10 {
  padding-bottom: 10rem !important; }
.u-pb-11 {
  padding-bottom: 11rem !important; }
.u-pb-12 {
  padding-bottom: 12rem !important; }
.u-pb-13 {
  padding-bottom: 13rem !important; }
.u-pb-14 {
  padding-bottom: 14rem !important; }
.u-pb-15 {
  padding-bottom: 15rem !important; }
.u-pb-16 {
  padding-bottom: 16rem !important; }
.u-pb-17 {
  padding-bottom: 17rem !important; }
.u-pb-18 {
  padding-bottom: 18rem !important; }
.u-pb-19 {
  padding-bottom: 19rem !important; }
.u-pb-20 {
  padding-bottom: 20rem !important; }
.u-pb-21 {
  padding-bottom: 21rem !important; }
.u-pb-22 {
  padding-bottom: 22rem !important; }
.u-pb-23 {
  padding-bottom: 23rem !important; }
.u-pb-24 {
  padding-bottom: 24rem !important; }
.u-pb-25 {
  padding-bottom: 25rem !important; }
/* Left padding */
.u-pl-0 {
  padding-left: 0rem !important; }
.u-pl-1 {
  padding-left: 1rem !important; }
.u-pl-2 {
  padding-left: 2rem !important; }
.u-pl-3 {
  padding-left: 3rem !important; }
.u-pl-4 {
  padding-left: 4rem !important; }
.u-pl-5 {
  padding-left: 5rem !important; }
.u-pl-6 {
  padding-left: 6rem !important; }
.u-pl-7 {
  padding-left: 7rem !important; }
.u-pl-8 {
  padding-left: 8rem !important; }
.u-pl-9 {
  padding-left: 9rem !important; }
.u-pl-10 {
  padding-left: 10rem !important; }
.u-pl-11 {
  padding-left: 11rem !important; }
.u-pl-12 {
  padding-left: 12rem !important; }
.u-pl-13 {
  padding-left: 13rem !important; }
.u-pl-14 {
  padding-left: 14rem !important; }
.u-pl-15 {
  padding-left: 15rem !important; }
.u-pl-16 {
  padding-left: 16rem !important; }
.u-pl-17 {
  padding-left: 17rem !important; }
.u-pl-18 {
  padding-left: 18rem !important; }
.u-pl-19 {
  padding-left: 19rem !important; }
.u-pl-20 {
  padding-left: 20rem !important; }
.u-pl-21 {
  padding-left: 21rem !important; }
.u-pl-22 {
  padding-left: 22rem !important; }
.u-pl-23 {
  padding-left: 23rem !important; }
.u-pl-24 {
  padding-left: 24rem !important; }
.u-pl-25 {
  padding-left: 25rem !important; }
.js-parallax {
  overflow: hidden; }
.js-parallax img {
    -webkit-transform: scale(1.1) translateY(20px);
            transform: scale(1.1) translateY(20px); }
.js-parallax--reverse img {
    -webkit-transform: scale(1.1) translateY(-20px);
            transform: scale(1.1) translateY(-20px); }
/* ==========================================================================
 text-align
========================================================================== */
.u-ta-l {
  text-align: left !important; }
.u-ta-c {
  text-align: center !important; }
.u-ta-r {
  text-align: right !important; }
.u-1col {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap; }
.u-2col {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2; }
/**
 * BrowserSync
 */
#__bs_notify__ {
  display: none !important;
  font-size: 8px !important;
  opacity: .25;
  max-height: 50px; }
.__debug_mihon__ {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  margin: 0 auto 0 auto;
  z-index: 100000;
  pointer-events: none;
  cursor: none;
  width: 100%;
  overflow: hidden;
  text-align: center;
  -webkit-animation: __debug_mihon__ 1s infinite;
          animation: __debug_mihon__ 1s infinite;
  padding-top: 0px;
  margin-top: 0px; }
@-webkit-keyframes __debug_mihon__ {
  0% {
    opacity: 0; }
  60% {
    opacity: .5; }
  100% {
    opacity: .5; } }
/*
@example
 <div class="mihon">
  <img src="./images/sample1.png" alt="" class="type_pc">
  <img src="./images/sample2.png" alt="" class="type_sp">
</div>
*/
.p-contest {
  overflow: hidden; }
.p-contest .s-mv {
    position: relative;
    width: 100%;
    height: 100vh; }
.p-contest .s-mv__img {
      width: 90%;
      height: auto;
      margin-inline: auto; }
.p-contest .s-mv__img img {
        width: 100%;
        height: 100%;
        -o-object-fit: contain;
           object-fit: contain; }
.p-contest .s-mv__logo {
      position: absolute;
      top: 50%;
      left: 50%;
      z-index: 1;
      width: calc(28.28%);
      -webkit-transform: translate(-50%, -50%) translateY(6rem);
              transform: translate(-50%, -50%) translateY(6rem); }
.p-contest .s-mv__content {
      margin-top: 3rem; }
.p-contest .s-mv__content p {
        display: block;
        width: -webkit-fit-content;
        width: -moz-fit-content;
        width: fit-content;
        padding: 0.3rem 2rem;
        margin-inline: auto;
        color: #222;
        background-color: #ffca3b;
        border-radius: 2rem;
        font-size: 2rem;
        font-weight: 700;
        letter-spacing: 0.2em;
        line-height: 1.4; }
.p-contest .s-mv__content time {
        display: block;
        width: 31rem;
        margin-inline: auto;
        margin-top: 1rem; }
.p-contest .s-mv__content time img {
          width: 100%;
          height: 100%;
          -o-object-fit: contain;
             object-fit: contain; }
.p-contest .s-mv__end-text {
      margin-top: 1rem;
      font-family: "Zen Maru Gothic", serif;
      font-size: 2.6rem;
      font-weight: bold;
      color: #ff7f2f;
      text-align: center; }
.p-contest .s-mv__vote {
      width: calc(100% + 2rem);
      margin-top: 1rem;
      margin-bottom: 2rem;
      margin-left: -1rem;
      font-family: "Zen Maru Gothic", serif;
      font-size: 2.4rem;
      font-weight: bold;
      text-align: center; }
.p-contest .s-mv__btn {
      margin-top: 4rem; }
.p-contest .s-mv .mv-img {
      position: absolute;
      height: auto; }
.p-contest .s-mv .mv-img.mv-img01 {
        top: 0;
        left: -0.7rem;
        width: calc(14.64%); }
.p-contest .s-mv .mv-img.mv-img02 {
        top: 7rem;
        left: 16.5rem;
        width: calc(27.5%); }
.p-contest .s-mv .mv-img.mv-img03 {
        bottom: 4rem;
        left: 11.5rem;
        width: calc(19.71%); }
.p-contest .s-mv .mv-img.mv-img04 {
        bottom: -8rem;
        left: 50%;
        width: calc(18.78%);
        -webkit-transform: translateX(-50%) translateX(-30rem);
                transform: translateX(-50%) translateX(-30rem); }
.p-contest .s-mv .mv-img.mv-img05 {
        top: -12rem;
        left: 50%;
        width: calc(12.28%);
        -webkit-transform: translateX(-50%) translateX(9rem);
                transform: translateX(-50%) translateX(9rem); }
.p-contest .s-mv .mv-img.mv-img06 {
        bottom: -10rem;
        left: 50%;
        width: calc(18.28%);
        -webkit-transform: translateX(-50%) translateX(5rem);
                transform: translateX(-50%) translateX(5rem); }
.p-contest .s-mv .mv-img.mv-img07 {
        top: 50%;
        right: 8.5rem;
        width: calc(25.5%);
        -webkit-transform: translateY(-50%) translateY(-12rem);
                transform: translateY(-50%) translateY(-12rem); }
.p-contest .s-mv .mv-img.mv-img08 {
        right: 14.4rem;
        bottom: -13rem;
        width: calc(26.5%); }
.p-contest .s-mv .mv-img.mv-img09 {
        top: 50%;
        left: 3rem;
        width: 8rem;
        -webkit-transform: translateY(-50%) translateY(-8rem);
                transform: translateY(-50%) translateY(-8rem); }
.p-contest .s-mv .mv-img.mv-img10 {
        right: 0.9rem;
        bottom: 13rem;
        width: 6.1rem; }
.p-contest .s-mv .mv-img.mv-img11 {
        top: 50%;
        right: -3rem;
        width: 15.2rem;
        -webkit-transform: translateY(-50%) translateY(6rem);
                transform: translateY(-50%) translateY(6rem); }
.p-contest .s-mv .mv-img.mv-img12 {
        top: 50%;
        left: 1rem;
        width: 10rem;
        -webkit-transform: translateY(-50%) translateY(4rem);
                transform: translateY(-50%) translateY(4rem); }
.p-contest .s-mv .mv-img.corner-img01, .p-contest .s-mv .mv-img.corner-img02, .p-contest .s-mv .mv-img.corner-img03, .p-contest .s-mv .mv-img.corner-img04 {
        z-index: 1;
        width: 5.7rem; }
.p-contest .s-mv .mv-img.corner-img01 {
        top: 3rem;
        left: 3rem; }
.p-contest .s-mv .mv-img.corner-img02 {
        top: 3rem;
        right: 3rem;
        -webkit-transform: rotate(90deg);
                transform: rotate(90deg); }
.p-contest .s-mv .mv-img.corner-img03 {
        right: 3rem;
        bottom: 3rem;
        -webkit-transform: rotate(180deg);
                transform: rotate(180deg); }
.p-contest .s-mv .mv-img.corner-img04 {
        bottom: 3rem;
        left: 3rem;
        -webkit-transform: rotate(-90deg);
                transform: rotate(-90deg); }
.p-contest .s-mv .mv-img.side-img01 {
        top: 50%;
        left: 3rem;
        width: 3.2rem;
        -webkit-transform: translateY(-50%);
                transform: translateY(-50%); }
.p-contest .s-mv .mv-img.side-img02 {
        top: 50%;
        right: 3rem;
        width: 3.2rem;
        -webkit-transform: translateY(-50%) rotate(180deg);
                transform: translateY(-50%) rotate(180deg); }
.p-contest .s-desc-inner {
    width: 100%;
    height: 100%;
    padding: 4rem 19rem;
    margin-top: 3rem;
    background: #fff;
    border-radius: 2rem; }
.p-contest .s-desc-inner p {
      font-size: 1.5rem;
      font-weight: 500;
      line-height: 1.7;
      text-align: center;
      letter-spacing: 0.05em; }
.p-contest .s-desc-inner dl {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
      row-gap: 3rem; }
.p-contest .s-desc-inner dl div dt,
      .p-contest .s-desc-inner dl div dd {
        font-size: 1.5rem;
        font-weight: 500;
        line-height: 1.7;
        letter-spacing: 0.05em; }
.p-contest .s-desc-inner dl div dd {
        padding-left: 1.5rem; }
.p-contest .s-desc:first-of-type {
    margin-top: 17rem; }
.p-contest .s-desc:last-of-type {
    margin-top: 12rem; }
.p-contest .s-list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
    grid-column-gap: 2.3rem;
    -webkit-column-gap: 2.3rem;
       -moz-column-gap: 2.3rem;
            column-gap: 2.3rem;
    padding-bottom: 15rem;
    margin-top: 9.5rem; }
.p-contest .s-list > div {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
      padding: 3.5rem 4rem 5rem;
      background: #fff;
      border-radius: 2rem; }
.p-contest .s-list > div figure {
        width: 20rem;
        margin: 0 auto; }
.p-contest .s-list-ttl {
      margin-top: 3rem;
      font-family: "Zen Maru Gothic", serif;
      font-size: 3.2rem;
      font-weight: bold;
      color: #ff7f2f;
      text-align: center;
      letter-spacing: 0.05em; }
.p-contest .s-list-text {
      margin-top: 2rem;
      font-size: 1.6rem;
      font-weight: 500;
      line-height: 1.7; }
.p-contest .s-list-btn {
      margin-top: auto; }
.p-overview {
  margin-top: -7rem;
  overflow: hidden; }
.p-overview .s-mv {
    position: relative;
    width: 100%;
    height: 90rem; }
.p-overview .s-mv__img {
      width: 90%;
      height: auto;
      margin-inline: auto; }
.p-overview .s-mv__img img {
        width: 100%;
        height: 100%;
        -o-object-fit: contain;
           object-fit: contain; }
.p-overview .s-mv__logo {
      position: absolute;
      top: 50%;
      left: 50%;
      width: calc(28.28%);
      -webkit-transform: translate(-50%, -50%) translateY(6rem);
              transform: translate(-50%, -50%) translateY(6rem); }
.p-overview .s-mv__content {
      margin-top: 3rem; }
.p-overview .s-mv__content p {
        display: block;
        width: -webkit-fit-content;
        width: -moz-fit-content;
        width: fit-content;
        padding: 0.3rem 2rem;
        margin-inline: auto;
        color: #222;
        background-color: #ffca3b;
        border-radius: 2rem;
        font-size: 2rem;
        font-weight: 700;
        letter-spacing: 0.2em;
        line-height: 1.4; }
.p-overview .s-mv__content time {
        display: block;
        margin-top: 1rem; }
.p-overview .s-mv__content time img {
          width: 100%;
          height: 100%;
          -o-object-fit: contain;
             object-fit: contain; }
.p-overview .s-mv__btn {
      margin-top: 4rem; }
.p-overview .s-mv .mv-img {
      position: absolute;
      height: auto; }
.p-overview .s-mv .mv-img.mv-img01 {
        top: 0;
        left: -0.7rem;
        width: calc(14.64%); }
.p-overview .s-mv .mv-img.mv-img02 {
        top: 7rem;
        left: 16.5rem;
        width: calc(27.5%); }
.p-overview .s-mv .mv-img.mv-img03 {
        bottom: 4rem;
        left: 11.5rem;
        width: calc(19.71%); }
.p-overview .s-mv .mv-img.mv-img04 {
        bottom: -8rem;
        left: 50%;
        width: calc(18.78%);
        -webkit-transform: translateX(-50%) translateX(-40rem);
                transform: translateX(-50%) translateX(-40rem); }
.p-overview .s-mv .mv-img.mv-img05 {
        top: -12rem;
        left: 50%;
        width: calc(12.28%);
        -webkit-transform: translateX(-50%) translateX(9rem);
                transform: translateX(-50%) translateX(9rem); }
.p-overview .s-mv .mv-img.mv-img06 {
        bottom: -20rem;
        left: 50%;
        width: calc(18.28%);
        -webkit-transform: translateX(-50%) translateX(5rem);
                transform: translateX(-50%) translateX(5rem); }
.p-overview .s-mv .mv-img.mv-img07 {
        top: 50%;
        right: 8.5rem;
        width: calc(25.5%);
        -webkit-transform: translateY(-50%) translateY(-12rem);
                transform: translateY(-50%) translateY(-12rem); }
.p-overview .s-mv .mv-img.mv-img08 {
        right: 14.4rem;
        bottom: -13rem;
        width: calc(26.5%); }
.p-overview .s-mv .mv-img.mv-img09 {
        top: 50%;
        left: 3rem;
        width: 8rem;
        -webkit-transform: translateY(-50%) translateY(-8rem);
                transform: translateY(-50%) translateY(-8rem); }
.p-overview .s-mv .mv-img.mv-img10 {
        right: 0.9rem;
        bottom: 13rem;
        width: 6.1rem; }
.p-overview .s-mv .mv-img.mv-img11 {
        top: 50%;
        right: -3rem;
        width: 15.2rem;
        -webkit-transform: translateY(-50%) translateY(6rem);
                transform: translateY(-50%) translateY(6rem); }
.p-overview .s-mv .mv-img.mv-img12 {
        top: 50%;
        left: 1rem;
        width: 10rem;
        -webkit-transform: translateY(-50%) translateY(4rem);
                transform: translateY(-50%) translateY(4rem); }
.p-overview .s-mv .mv-img.corner-img01, .p-overview .s-mv .mv-img.corner-img02, .p-overview .s-mv .mv-img.corner-img03, .p-overview .s-mv .mv-img.corner-img04 {
        z-index: 1;
        width: 5.7rem; }
.p-overview .s-mv .mv-img.corner-img01 {
        top: 3rem;
        left: 3rem; }
.p-overview .s-mv .mv-img.corner-img02 {
        top: 3rem;
        right: 3rem;
        -webkit-transform: rotate(90deg);
                transform: rotate(90deg); }
.p-overview .s-mv .mv-img.corner-img03 {
        right: 3rem;
        bottom: 3rem;
        -webkit-transform: rotate(180deg);
                transform: rotate(180deg); }
.p-overview .s-mv .mv-img.corner-img04 {
        bottom: 3rem;
        left: 3rem;
        -webkit-transform: rotate(-90deg);
                transform: rotate(-90deg); }
.p-overview .s-mv .mv-img.side-img01 {
        top: 50%;
        left: 3rem;
        width: 3.2rem;
        -webkit-transform: translateY(-50%);
                transform: translateY(-50%); }
.p-overview .s-mv .mv-img.side-img02 {
        top: 50%;
        right: 3rem;
        width: 3.2rem;
        -webkit-transform: translateY(-50%) rotate(180deg);
                transform: translateY(-50%) rotate(180deg); }
.p-overview .s-theme {
    padding-bottom: 10rem;
    margin-top: 24rem; }
.p-overview .s-theme__inner {
      width: 120rem;
      margin-inline: auto; }
.p-overview .s-theme__ttl {
      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: center;
          -ms-flex-align: center;
              align-items: center; }
.p-overview .s-theme__ttl span {
        position: relative;
        width: 4.6rem;
        height: 4.6rem;
        background-color: #ffca3b;
        border-radius: 50%; }
.p-overview .s-theme__ttl span::before {
          position: absolute;
          top: 50%;
          left: 50%;
          width: 1.5rem;
          height: 1.5rem;
          content: "";
          background-color: #fff;
          border-radius: 50%;
          -webkit-transform: translate(-50%, -50%);
                  transform: translate(-50%, -50%); }
.p-overview .s-theme__ttl h2 {
        font-size: 3.2rem;
        font-weight: 700;
        letter-spacing: 0.05em;
        line-height: 1.6; }
.p-overview .s-theme__list {
      display: -ms-grid;
      display: grid;
      -ms-grid-columns: (1fr)[3];
      grid-template-columns: repeat(3, 1fr);
      grid-gap: 0 3rem;
      gap: 0 3rem;
      margin-top: 3.5rem; }
.p-overview .s-theme__item {
      position: relative;
      width: 100%;
      padding: 9rem 3.75rem 3.75rem;
      background-color: #fff;
      border-radius: 2rem; }
.p-overview .s-theme__item::before {
        position: absolute;
        top: 0;
        left: 4rem;
        width: 3rem;
        height: 0.8rem;
        content: "";
        border-radius: 0.6rem; }
.p-overview .s-theme__item:nth-of-type(1)::before {
        background-color: #ff7f2f; }
.p-overview .s-theme__item:nth-of-type(1) h3 span {
        color: #ff7f2f; }
.p-overview .s-theme__item:nth-of-type(2)::before {
        background-color: #88b3ab; }
.p-overview .s-theme__item:nth-of-type(2) h3 span {
        color: #88b3ab; }
.p-overview .s-theme__item:nth-of-type(3)::before {
        background-color: #4a6089; }
.p-overview .s-theme__item:nth-of-type(3) h3 span {
        color: #4a6089; }
.p-overview .s-theme__item-wrap {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: end;
            -ms-flex-align: end;
                align-items: end; }
.p-overview .s-theme__item-subttl {
        font-size: 2rem;
        font-weight: 700;
        letter-spacing: 0.02em;
        line-height: 1.4;
        color: #222; }
.p-overview .s-theme__item figure {
        position: absolute;
        top: 3rem;
        right: 3rem;
        width: 5.3rem;
        height: 5.3rem; }
.p-overview .s-theme__item figure img {
          width: 100%;
          height: 100%;
          -o-object-fit: contain;
             object-fit: contain; }
.p-overview .s-theme__item h3 {
        font-size: 2.8rem;
        font-weight: 700;
        letter-spacing: 0.05em;
        line-height: 1.4; }
.p-overview .s-theme__item small {
        font-size: 2rem;
        font-weight: 700;
        letter-spacing: 0.02em;
        line-height: 1.4;
        margin-bottom: 0.2rem; }
.p-overview .s-theme__item p {
        font-size: 1.5rem;
        font-weight: 700;
        letter-spacing: 0.05em;
        line-height: 1.8;
        margin-top: 1.5rem;
        color: #222; }
.p-overview .s-overview {
    position: relative;
    padding-top: 10rem;
    padding-bottom: 9rem;
    background: url(./../images/top/overview-bg.webp) no-repeat center center/cover;
    opacity: 0; }
.p-overview .s-overview.is-block {
      opacity: 1;
      -webkit-transition-delay: 0.3s;
              transition-delay: 0.3s; }
.p-overview .s-overview__inner {
      position: relative; }
.p-overview .s-overview__img {
      position: relative;
      z-index: 2; }
.p-overview .s-overview__img img {
        position: absolute;
        height: auto; }
.p-overview .s-overview__img img:nth-of-type(1) {
          top: -8rem;
          left: -10rem;
          width: 19.5rem;
          -o-object-fit: contain;
             object-fit: contain; }
.p-overview .s-overview__img img:nth-of-type(2) {
          top: -5rem;
          right: -13rem;
          width: 22rem;
          -o-object-fit: contain;
             object-fit: contain; }
.p-overview .s-overview__ttl {
      position: relative;
      left: 50%;
      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: center;
          -ms-flex-align: center;
              align-items: center;
      width: 40rem;
      text-align: center;
      background: url(./../images/top/harf-circle.png) no-repeat center center/cover;
      -webkit-transform: translateX(-50%) translateY(-6rem);
              transform: translateX(-50%) translateY(-6rem); }
.p-overview .s-overview__ttl-wrap {
        margin-top: 4rem;
        margin-bottom: 1rem; }
.p-overview .s-overview__ttl-wrap img {
          width: 3.8rem;
          height: 3.1rem;
          -o-object-fit: contain;
             object-fit: contain;
          margin-inline: auto; }
.p-overview .s-overview__ttl-wrap h2 {
          font-size: 3rem;
          font-weight: 700;
          letter-spacing: 0.05em;
          line-height: 1.4; }
.p-overview .s-overview__containerTop {
      position: relative;
      z-index: 1;
      width: 100%;
      padding: 0 9rem;
      padding-bottom: 5rem;
      margin-top: -6.6rem;
      background-color: #fff;
      border-radius: 2rem; }
.p-overview .s-overview__containerTop-flex {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: start;
            -ms-flex-align: start;
                align-items: start;
        padding-top: 8rem; }
.p-overview .s-overview__containerTop .s-overview__right {
        width: 63.4rem;
        margin-left: 5.4rem; }
.p-overview .s-overview__containerTop .s-overview__right-item {
          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; }
.p-overview .s-overview__containerTop .s-overview__right-item:nth-of-type(n + 2) {
            margin-top: 2rem; }
.p-overview .s-overview__containerTop .s-overview__right-item-wrap {
            display: -webkit-box;
            display: -ms-flexbox;
            display: flex;
            -webkit-box-align: center;
                -ms-flex-align: center;
                    align-items: center; }
.p-overview .s-overview__containerTop .s-overview__right-item-wrap.wrap-left {
              position: relative; }
.p-overview .s-overview__containerTop .s-overview__right-item-wrap.wrap-left::before {
                position: absolute;
                top: 50%;
                width: 100%;
                content: "";
                border-top: dotted 3px #d9d2bf;
                -webkit-transform: translateY(-50%) translateY(0.3rem);
                        transform: translateY(-50%) translateY(0.3rem); }
.p-overview .s-overview__containerTop .s-overview__right-item-wrap.wrap-left img {
                width: 2.66rem;
                height: 3.45rem;
                -o-object-fit: contain;
                   object-fit: contain; }
.p-overview .s-overview__containerTop .s-overview__right-item-wrap.wrap-left p {
                font-size: 2.8rem;
                font-weight: 700;
                letter-spacing: 0.05em;
                line-height: 1.4;
                margin-left: 1rem;
                color: #222; }
.p-overview .s-overview__containerTop .s-overview__right-item-wrap.wrap-left p span {
                  font-size: 1.6rem;
                  font-weight: 700;
                  letter-spacing: 0.05em;
                  line-height: 1.4; }
.p-overview .s-overview__containerTop .s-overview__right-item-wrap.wrap-right span {
              font-size: 1.3rem;
              font-weight: 500;
              letter-spacing: 0.05em;
              line-height: 1.4;
              padding: 0.5rem 1.5rem;
              color: #222;
              white-space: nowrap;
              background-color: #ede7d5;
              border-radius: 1.5rem; }
.p-overview .s-overview__containerTop .s-overview__right-item-wrap.wrap-right p {
              font-size: 1.5rem;
              font-weight: 500;
              letter-spacing: 0.05em;
              line-height: 1.4;
              margin-left: 0.5rem;
              color: #222; }
.p-overview .s-overview__containerTop .s-overview__right-item .adjust-01::before {
            right: -15.8rem;
            width: 14.5rem; }
.p-overview .s-overview__containerTop .s-overview__right-item .adjust-02::before {
            right: -12.7rem;
            width: 11.7rem; }
.p-overview .s-overview__containerTop .s-overview__right-item .adjust-03::before {
            right: -15.6rem;
            width: 14.5rem; }
.p-overview .s-overview__containerTop .s-overview__right-item .adjust-04::before {
            right: -6.8rem;
            width: 6rem; }
.p-overview .s-overview__containerTop .s-overview__right-item .adjust-05::before {
            right: -6.9rem;
            width: 6rem; }
.p-overview .s-overview__containerTop .s-overview__right-item .adjust-06 {
            margin-left: 3rem; }
.p-overview .s-overview__containerTop .s-overview__right-item .adjust-06 p {
              margin-left: 0;
              font-size: 1.8rem; }
.p-overview .s-overview__containerTop .s-overview__right-item .adjust-06::before {
              right: -20.3rem;
              width: 19rem; }
.p-overview .s-overview__containerTop .s-overview__right-item .adjust-07 {
            margin-left: 3rem; }
.p-overview .s-overview__containerTop .s-overview__right-item .adjust-07 p {
              margin-left: 0;
              font-size: 1.8rem; }
.p-overview .s-overview__containerTop .s-overview__right-item .adjust-07::before {
              display: none; }
.p-overview .s-overview__containerTop .s-overview__right-item .before-none::before {
            display: none; }
.p-overview .s-overview__containerBottom {
      position: relative;
      z-index: 1;
      width: 100%;
      padding: 0 3rem 6rem 9rem;
      padding-bottom: 6rem;
      margin-top: 3rem;
      background-color: #fff;
      border-radius: 2rem; }
.p-overview .s-overview__containerBottom-flex {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: start;
            -ms-flex-align: start;
                align-items: start;
        padding-top: 8rem; }
.p-overview .s-overview__containerBottom-flex:nth-of-type(n + 2) {
          padding-top: 4rem; }
.p-overview .s-overview__containerBottom .s-overview__right {
        width: 75rem;
        margin-left: 5.4rem; }
.p-overview .s-overview__containerBottom .s-overview__right-item {
          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; }
.p-overview .s-overview__containerBottom .s-overview__right-item:nth-of-type(n + 2) {
            margin-top: 0.8rem; }
.p-overview .s-overview__containerBottom .s-overview__right-item-wrap {
            display: -webkit-box;
            display: -ms-flexbox;
            display: flex;
            -webkit-box-align: start;
                -ms-flex-align: start;
                    align-items: start; }
.p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left {
              position: relative; }
.p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left.column02 {
                -webkit-box-orient: vertical;
                -webkit-box-direction: normal;
                    -ms-flex-direction: column;
                        flex-direction: column; }
.p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left.column02 small {
                  margin-top: 0.5rem;
                  margin-bottom: 1rem;
                  font-size: 1.5rem;
                  font-weight: 500;
                  letter-spacing: 0.05em;
                  line-height: 1.6; }
.p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left img {
                width: 1.4rem;
                height: auto;
                -o-object-fit: contain;
                   object-fit: contain; }
.p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left p {
                font-size: 1.7rem;
                font-weight: 500;
                letter-spacing: 0.05em;
                line-height: 1.4;
                margin-left: 1rem;
                color: #222; }
.p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left p span {
                  font-size: 1.5rem;
                  font-weight: 500;
                  letter-spacing: 0.05em;
                  line-height: 1.4;
                  padding: 0;
                  background-color: initial !important; }
.p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left span {
                font-size: 1.4rem;
                font-weight: 500;
                letter-spacing: 0.05em;
                line-height: 1.4;
                padding: 0.3rem 2rem;
                color: #222;
                background-color: #ede7d5;
                border-radius: 2rem; }
.p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left span.w-83 {
                  width: 8.3rem;
                  text-align: center;
                  white-space: nowrap; }
.p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left small {
                font-size: 1.5rem;
                font-weight: 500;
                letter-spacing: 0.05em;
                line-height: 1.4;
                margin-left: 1.2rem;
                color: #222; }
.p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left small span {
                  padding: initial;
                  font-size: 1.7rem;
                  background-color: initial; }
.p-overview .s-method {
    position: relative;
    padding-top: 8rem; }
.p-overview .s-method__img01 {
      position: absolute;
      top: 3rem;
      left: 1rem;
      z-index: 1;
      width: 14rem;
      height: auto;
      -o-object-fit: contain;
         object-fit: contain; }
.p-overview .s-method__img02 {
      position: absolute;
      top: 2rem;
      right: 3rem;
      z-index: 1;
      width: 8.5rem;
      height: auto;
      -o-object-fit: contain;
         object-fit: contain; }
.p-overview .s-method__ttl {
      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: center;
          -ms-flex-align: center;
              align-items: center; }
.p-overview .s-method__ttl span {
        position: relative;
        width: 4.6rem;
        height: 4.6rem;
        border-radius: 50%; }
.p-overview .s-method__ttl span img {
          width: 100%;
          height: 100%;
          -o-object-fit: contain;
             object-fit: contain; }
.p-overview .s-method__ttl h2 {
        font-size: 3.2rem;
        font-weight: 700;
        letter-spacing: 0.05em;
        line-height: 1.6; }
.p-overview .s-method__container {
      padding: 8rem;
      margin-top: 3rem;
      background-color: #fff;
      border-radius: 2rem; }
.p-overview .s-method__list {
      position: relative;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-align: start;
          -ms-flex-align: start;
              align-items: start;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      width: 93.6rem; }
.p-overview .s-method__list::before {
        position: absolute;
        top: 50%;
        left: 50%;
        z-index: 1;
        width: 59rem;
        content: "";
        border-top: dotted 3px #d9d2bf;
        -webkit-transform: translate(-50%, -50%) translateY(-2.2rem);
                transform: translate(-50%, -50%) translateY(-2.2rem); }
.p-overview .s-method__item {
      width: 29rem; }
.p-overview .s-method__item-top p {
        font-size: 1.8rem;
        font-weight: 700;
        letter-spacing: 0.05em;
        line-height: 1.4;
        text-align: center; }
.p-overview .s-method__item-top p span {
          font-size: 1.4rem; }
.p-overview .s-method__item-dot {
        position: relative;
        z-index: 2;
        width: 2.6rem;
        height: 2.6rem;
        margin-inline: auto;
        margin-top: 2.4rem;
        border-radius: 50%; }
.p-overview .s-method__item-dot.color01 {
          background-color: #ff7f2f; }
.p-overview .s-method__item-dot.color02 {
          background-color: #88b3ab; }
.p-overview .s-method__item-dot.color03 {
          background-color: #4a6089; }
.p-overview .s-method__item-ttl {
        margin-top: 3.2rem; }
.p-overview .s-method__item-ttl h3 {
          font-size: 2.4rem;
          font-weight: 700;
          letter-spacing: 0.05em;
          line-height: 1.4;
          color: #222;
          text-align: center; }
.p-overview .s-method__item-txt {
        margin-top: 1.35rem; }
.p-overview .s-method__item-txt p {
          font-size: 1.5rem;
          font-weight: 500;
          letter-spacing: 0.05em;
          line-height: 1.4;
          color: #222;
          text-align: center; }
.p-overview .s-news {
    position: relative;
    margin-top: 10rem; }
.p-overview .s-news__ttl {
      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: center;
          -ms-flex-align: center;
              align-items: center; }
.p-overview .s-news__ttl span {
        position: relative;
        width: 4.6rem;
        height: 4.6rem;
        border-radius: 50%; }
.p-overview .s-news__ttl span img {
          width: 100%;
          height: 100%;
          -o-object-fit: contain;
             object-fit: contain; }
.p-overview .s-news__ttl h2 {
        font-size: 3.2rem;
        font-weight: 700;
        letter-spacing: 0.05em;
        line-height: 1.6; }
.p-overview .s-news__container {
      padding: 4rem 8rem;
      margin-top: 3rem;
      background-color: #fff;
      border-radius: 2rem; }
.p-overview .s-news__item {
      position: relative;
      width: 100%; }
.p-overview .s-news__item-subTitle {
        text-align: center; }
.p-overview .s-news__item-subTitle span {
          font-size: 1.7rem;
          font-weight: 500;
          letter-spacing: 0.05em;
          line-height: 1.4;
          color: #222; }
.p-overview .s-news__item-mainTitle {
        margin-top: 1rem;
        text-align: center; }
.p-overview .s-news__item-mainTitle h3 {
          font-size: 2.4rem;
          font-weight: 700;
          letter-spacing: 0.05em;
          line-height: 1.4;
          color: #222; }
.p-overview .s-news__item-text {
        margin-top: 1rem;
        text-align: center; }
.p-overview .s-news__item-text p {
          font-size: 1.7rem;
          font-weight: 500;
          letter-spacing: 0.05em;
          line-height: 1.4;
          color: #222; }
.p-overview .s-news__item-detail {
        width: 45rem;
        margin-inline: auto;
        margin-top: 1rem; }
.p-overview .s-news__item-detail p {
          position: relative;
          padding-left: 2rem;
          color: #222;
          font-size: 1.5rem;
          font-weight: 500;
          letter-spacing: 0.05em;
          line-height: 1.4; }
.p-overview .s-news__item-detail p::before {
            position: absolute;
            top: 0.6rem;
            left: 0;
            width: 1rem;
            height: 1rem;
            content: "";
            background-color: #ff7f2f;
            -webkit-transform: rotate(45deg);
                    transform: rotate(45deg); }
.p-overview .s-news__item-detail p a {
            color: #ff7f2f;
            border-bottom: 1px solid #ff7f2f;
            -webkit-transition: 0.3s;
            transition: 0.3s; }
.p-overview .s-news__item-detail p span {
            display: block;
            margin-top: 0.5rem; }
.p-overview .s-news__item-detail p span a {
              color: #ff7f2f;
              border: initial !important;
              -webkit-transition: 0.3s;
              transition: 0.3s; }
.p-overview .s-news__item-qr {
        position: absolute;
        right: 18rem;
        bottom: 0;
        width: 8rem;
        height: 8rem; }
.p-overview .s-news__item-qr img {
          width: 100%;
          height: 100%;
          -o-object-fit: contain;
             object-fit: contain; }
.p-overview .s-picture {
    margin-top: 6rem; }
.p-overview .s-picture__wrap {
      position: relative;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center; }
.p-overview .s-picture__list {
      display: -ms-grid;
      display: grid;
      -ms-grid-columns: (1fr)[3];
      grid-template-columns: repeat(3, 1fr);
      grid-column-gap: 3rem;
      -webkit-column-gap: 3rem;
         -moz-column-gap: 3rem;
              column-gap: 3rem; }
.p-overview .s-picture__list img {
        width: 33.4rem;
        height: auto;
        -o-object-fit: contain;
           object-fit: contain; }
.p-overview .s-picture__list img:nth-of-type(n + 2) {
          margin-left: 1.6rem; }
.p-award {
  padding-bottom: 3rem; }
.p-award-top2 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 6rem;
    padding: 0 10rem;
    margin-top: 6rem; }
.p-award-top2-item {
      padding: 4rem 5rem;
      background-color: white;
      border-radius: 3.4rem; }
.p-award-top2-item:nth-of-type(2) .p-award-top2-item__ttl::before {
        display: block;
        width: 3.9rem;
        height: 5.1rem;
        content: "";
        background: url(./../images/common/medal-silver.webp) no-repeat center center/contain !important; }
.p-award-top2-item__ttl {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        gap: 1.8rem;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        margin-bottom: 3rem;
        font-family: "Zen Maru Gothic", serif;
        font-size: 3rem;
        font-weight: bold; }
.p-award-top2-item__ttl::before {
          display: block;
          width: 3.9rem;
          height: 5.1rem;
          content: "";
          background: url(./../images/common/medal-gold.webp) no-repeat center center/contain !important; }
.p-award-top2-item__inner {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        gap: 4rem;
        -webkit-box-align: start;
            -ms-flex-align: start;
                align-items: flex-start;
        margin-bottom: 3rem; }
.p-award-top2-item__figure {
        width: 50rem;
        height: 33.4rem;
        overflow: hidden; }
.p-award-top2-item__desc-wrap {
        width: 43.2rem; }
.p-award-top2-item__cat {
        display: inline-block;
        width: auto;
        padding: 1.2rem 2.3rem;
        margin-bottom: 2rem;
        font-family: "Zen Maru Gothic", serif;
        font-size: 1.4rem;
        font-weight: bold;
        color: white;
        letter-spacing: 0.3rem;
        border-radius: 2rem 0 2rem 0 / 2rem 0 2rem 0; }
.p-award-top2-item__cat--beginner {
          background-color: #ff7f2f; }
.p-award-top2-item__cat--intermediate {
          background-color: #88b3ab; }
.p-award-top2-item__cat--advanced {
          background-color: #4b639a; }
.p-award-top2-item__overall-wrap {
        padding: 3.5rem 3rem;
        border: solid 3px #f2eee9;
        border-radius: 2rem; }
.p-award-top2-item__overall-ttl {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        gap: 0.5rem;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        padding-bottom: 1.2rem;
        margin-bottom: 2rem;
        font-family: "Zen Maru Gothic", serif;
        font-size: 2rem;
        font-weight: bold;
        border-bottom: solid 3px #f2eee9; }
.p-award-top2-item__overall-ttl::before {
          display: block;
          width: 1.8rem;
          height: 1.8rem;
          content: "";
          border: solid 6px #ffca3b;
          border-radius: 100%; }
.p-award-top2-item__overall-text {
        font-size: 1.4rem;
        font-weight: 500;
        line-height: 2; }
.p-award-top3t5 {
    gap: 3rem;
    margin-top: 6rem;
    margin-right: 10rem;
    margin-left: 10rem;
    background-color: #fff;
    border-radius: 3rem; }
.p-award-top3t5-ttl {
      padding-top: 5rem; }
.p-award-top3t5-ttl h3 {
        position: relative;
        font-family: "Zen Maru Gothic", serif;
        font-size: 2.8rem;
        font-weight: 700;
        line-height: 1.4;
        color: #222;
        text-align: center;
        letter-spacing: 0.05em; }
.p-award-top3t5-ttl h3::before {
          position: absolute;
          top: 50%;
          left: 2.2rem;
          width: 39%;
          height: 2px;
          content: "";
          background-color: #c3b4a8;
          -webkit-transform: translateY(-50%);
                  transform: translateY(-50%); }
.p-award-top3t5-ttl h3::after {
          position: absolute;
          top: 50%;
          right: 2.2rem;
          width: 39%;
          height: 2px;
          content: "";
          background-color: #c3b4a8;
          -webkit-transform: translateY(-50%);
                  transform: translateY(-50%); }
.p-award-top3t5-list {
      display: -ms-grid;
      display: grid;
      -ms-grid-columns: (1fr)[3];
      grid-template-columns: repeat(3, 1fr);
      padding-bottom: 3rem;
      margin-top: 4rem; }
.p-award-top3t5-item {
      padding: 0 2rem;
      background-color: white; }
.p-award-top3t5-item:first-of-type {
        border-right: 5px dotted #d1d1d1; }
.p-award-top3t5-item:last-of-type {
        border-left: 5px dotted #d1d1d1; }
.p-award-top3t5-item__ttl {
        position: relative;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        gap: 1rem;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        width: -webkit-fit-content;
        width: -moz-fit-content;
        width: fit-content;
        margin-inline: auto;
        margin-bottom: 2rem;
        font-family: "Zen Maru Gothic", serif;
        font-size: 2.2rem;
        font-weight: bold; }
.p-award-top3t5-item__ttl.ttl-bronze::before {
          position: absolute;
          top: 50%;
          left: -4rem;
          width: 3rem !important;
          height: 3.8rem !important;
          content: "";
          background: url(./../images/common/medal-bronze.webp) no-repeat center center/contain !important;
          -webkit-transform: translateY(-50%);
                  transform: translateY(-50%); }
.p-award-top3t5-item__figure-wrap {
        position: relative;
        width: 100%;
        height: 22.6rem;
        margin-bottom: 1.5rem;
        overflow: hidden;
        border-radius: 2rem; }
.p-award-top3t5-item__figure {
        width: 100%;
        height: 100%; }
.p-award-top3t5-item__cat {
        position: absolute;
        top: 0;
        left: 0;
        display: inline-block;
        width: auto;
        padding: 1.2rem 2.3rem;
        margin-bottom: 2rem;
        font-family: "Zen Maru Gothic", serif;
        font-size: 1.4rem;
        font-weight: bold;
        color: white;
        letter-spacing: 0.3rem;
        border-radius: 2rem 0 2rem 0 / 2rem 0 2rem 0; }
.p-award-top3t5-item__cat--beginner {
          background-color: #ff7f2f; }
.p-award-top3t5-item__cat--intermediate {
          background-color: #88b3ab; }
.p-award-top3t5-item__cat--advanced {
          background-color: #4b639a; }
.p-award-top3t5-item .c-remark-list__dl {
        margin-bottom: 0.5rem; }
.p-award-top3t5-item__overall-wrap {
        padding: 2rem 2.5rem;
        margin-top: 2rem;
        border: solid 3px #f2eee9;
        border-radius: 2rem; }
.p-award-top3t5-item__overall-ttl {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        gap: 0.5rem;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        padding-bottom: 0.5rem;
        margin-bottom: 1rem;
        font-family: "Zen Maru Gothic", serif;
        font-size: 1.8rem;
        font-weight: bold;
        border-bottom: solid 3px #f2eee9; }
.p-award-top3t5-item__overall-ttl::before {
          display: block;
          width: 1.8rem;
          height: 1.8rem;
          content: "";
          border: solid 0.6rem #ffca3b;
          border-radius: 100%; }
.p-award-top3t5-item__overall-text {
        font-size: 1.4rem;
        line-height: 2; }
.p-award-top3t5-item .c-btn-camera {
        margin-top: 2rem;
        background-color: #ff7f2f; }
.p-award-top6t9 {
    width: calc(100% - 20rem);
    padding: 5rem 4rem;
    margin: 6rem auto 2rem;
    background-color: white;
    border-radius: 2rem; }
.p-award-top6t9__ttl {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      gap: 3rem;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      margin-bottom: 3rem;
      font-family: "Zen Maru Gothic", serif;
      font-size: 2.8rem;
      font-weight: bold; }
.p-award-top6t9__ttl::before, .p-award-top6t9__ttl::after {
        display: block;
        -webkit-box-flex: 1;
            -ms-flex-positive: 1;
                flex-grow: 1;
        width: auto;
        height: 2px;
        content: "";
        background: #c3b4a8; }
.p-award-top6t9__list {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap; }
.p-award-top6t9-item {
      position: relative;
      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;
      width: 50%;
      padding-bottom: 3.8rem; }
.p-award-top6t9-item:nth-of-type(2n - 1) {
        padding-right: 3rem; }
.p-award-top6t9-item:nth-of-type(2n - 1)::after {
          position: absolute;
          top: 0;
          right: 0;
          display: block;
          width: 4px;
          height: 100%;
          content: "";
          background-image: url(../images/common/border-dots.webp);
          background-repeat: repeat-y;
          background-size: contain; }
.p-award-top6t9-item:nth-of-type(2n) {
        padding-left: 3rem; }
.p-award-top6t9-item:nth-of-type(n + 3) {
        padding-top: 3.5rem; }
.p-award-top6t9-item:nth-of-type(n + 3)::before {
          position: absolute;
          top: 0;
          left: 0;
          display: block;
          width: 100%;
          height: 4px;
          content: "";
          background-image: url(../images/common/border-dots-width.webp);
          background-repeat: repeat-x;
          background-size: contain; }
.p-award-top6t9-item:first-of-type::after {
        background-position: bottom center; }
.p-award-top6t9-item:nth-of-type(2)::after {
        background-position: top center; }
.p-award-top6t9-item:nth-last-of-type(2)::before {
        width: calc(100% - 0.5rem);
        background-position: center right; }
.p-award-top6t9-item:last-of-type::before {
        left: 0.5rem;
        width: calc(100% - 0.5rem);
        background-position: center left; }
.p-award-top6t9-item__left {
        width: 24.5rem; }
.p-award-top6t9-item__right {
        width: 26rem; }
.p-award-top6t9-item__figure-wrap {
        position: relative;
        width: 100%;
        height: 16.3rem;
        margin-bottom: 1.5rem;
        overflow: hidden;
        border-radius: 2rem; }
.p-award-top6t9-item__figure {
        width: 100%;
        height: 100%; }
.p-award-top6t9-item__cat {
        position: absolute;
        top: 0;
        left: 0;
        display: inline-block;
        width: auto;
        padding: 1.2rem 2.3rem;
        margin-bottom: 2rem;
        font-family: "Zen Maru Gothic", serif;
        font-size: 1.4rem;
        font-weight: bold;
        color: white;
        letter-spacing: 0.3rem;
        border-radius: 2rem 0 2rem 0 / 2rem 0 2rem 0; }
.p-award-top6t9-item__cat--beginner {
          background-color: #ff7f2f; }
.p-award-top6t9-item__cat--intermediate {
          background-color: #88b3ab; }
.p-award-top6t9-item__cat--advanced {
          background-color: #4b639a; }
.p-award-top6t9-item .c-remark-list__dl {
        margin-bottom: 0.5rem; }
.p-award-top6t9-item .c-remark-list__dt {
        font-size: 1.6rem; }
.p-award-top6t9-item .c-remark-list__dd {
        font-size: 1.6rem; }
.p-award-top6t9-item__overall-wrap {
        padding: 1.5rem 2rem;
        border: solid 3px #f2eee9;
        border-radius: 2rem; }
.p-award-top6t9-item__overall-ttl {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        gap: 0.5rem;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        padding-bottom: 0.5rem;
        margin-bottom: 1rem;
        font-family: "Zen Maru Gothic", serif;
        font-size: 1.6rem;
        font-weight: bold;
        border-bottom: solid 3px #f2eee9; }
.p-award-top6t9-item__overall-ttl::before {
          display: block;
          width: 1.4rem;
          height: 1.4rem;
          content: "";
          border: solid 0.5rem #ffca3b;
          border-radius: 100%; }
.p-award-top6t9-item__overall-text {
        font-size: 1.4rem;
        line-height: 2; }
.p-award-top6t9-item .c-btn-camera {
        margin-top: 1.4rem;
        background-color: #ff7f2f; }
.p-award-top10t12 {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[3];
    grid-template-columns: repeat(3, 1fr);
    grid-gap: 3rem;
    gap: 3rem;
    padding: 0 10rem;
    margin-top: 6rem; }
.p-award-top10t12-item {
      width: calc(calc(100 / 3) - 2rem);
      padding: 3rem 2rem;
      background-color: white;
      border-radius: 2rem; }
.p-award-top10t12-item__ttl {
        position: relative;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        gap: 1rem;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        width: -webkit-fit-content;
        width: -moz-fit-content;
        width: fit-content;
        margin-inline: auto;
        margin-top: 3.5rem;
        margin-bottom: 2rem;
        font-family: "Zen Maru Gothic", serif;
        font-size: 2.2rem;
        font-weight: bold; }
.p-award-top10t12-item__ttl.ttl-bronze::before {
          position: absolute;
          top: 50%;
          left: -3.6rem;
          width: 3rem !important;
          height: 3.8rem !important;
          content: "";
          background: url(./../images/common/medal-bronze.webp) no-repeat center center/contain !important;
          -webkit-transform: translateY(-50%);
                  transform: translateY(-50%); }
.p-award-top10t12-item__figure-wrap {
        position: relative;
        width: 100%;
        height: 22.6rem;
        margin-bottom: 1.5rem;
        overflow: hidden;
        border-radius: 2rem; }
.p-award-top10t12-item__figure {
        width: 100%;
        height: 100%; }
.p-award-top10t12-item__cat {
        position: absolute;
        top: 0;
        left: 0;
        display: inline-block;
        width: auto;
        padding: 1.2rem 2.3rem;
        margin-bottom: 2rem;
        font-family: "Zen Maru Gothic", serif;
        font-size: 1.4rem;
        font-weight: bold;
        color: white;
        letter-spacing: 0.3rem;
        border-radius: 2rem 0 2rem 0 / 2rem 0 2rem 0; }
.p-award-top10t12-item__cat--beginner {
          background-color: #ff7f2f; }
.p-award-top10t12-item__cat--intermediate {
          background-color: #88b3ab; }
.p-award-top10t12-item__cat--advanced {
          background-color: #4b639a; }
.p-award-top10t12-item .c-remark-list__dl {
        margin-bottom: 0.5rem; }
.p-award-top10t12-item__overall-wrap {
        padding: 2rem 2.5rem;
        margin-top: 2rem;
        border: solid 3px #f2eee9;
        border-radius: 2rem; }
.p-award-top10t12-item__overall-ttl {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        gap: 0.5rem;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        padding-bottom: 0.5rem;
        margin-bottom: 1rem;
        font-family: "Zen Maru Gothic", serif;
        font-size: 1.8rem;
        font-weight: bold;
        border-bottom: solid 3px #f2eee9; }
.p-award-top10t12-item__overall-ttl::before {
          display: block;
          width: 1.8rem;
          height: 1.8rem;
          content: "";
          border: solid 0.6rem #ffca3b;
          border-radius: 100%; }
.p-award-top10t12-item__overall-text {
        font-size: 1.4rem;
        line-height: 2; }
.p-award-top10t12-item .c-btn-camera {
        margin-top: 2rem;
        background-color: #ff7f2f; }
.p-award-btn {
    margin-top: 5rem; }
.p-company .s-intro {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -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;
  width: 100%;
  margin-top: 9rem; }
.p-company .s-intro span {
    display: block;
    margin-top: 4rem;
    font-size: 2rem;
    font-weight: bold;
    line-height: 1;
    color: #ff7f2f;
    text-align: center; }
.p-company .s-intro p {
    width: 104rem;
    margin: 0 auto;
    margin-top: 2rem;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1.7;
    text-align: center; }
.p-company .s-intro p a {
      display: inline;
      color: #ff7f2f;
      text-decoration: underline; }
.p-company .s-list {
  margin-top: 8rem; }
.p-company .s-list ul {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[3];
    grid-template-columns: repeat(3, 1fr);
    grid-row-gap: 6rem;
    row-gap: 6rem;
    grid-column-gap: 3rem;
    -webkit-column-gap: 3rem;
       -moz-column-gap: 3rem;
            column-gap: 3rem; }
.p-company .s-list ul li {
      width: 100%;
      height: 100%;
      padding: 2rem;
      background: #fff;
      border-radius: 2rem; }
.p-company .s-list ul li figure img {
        border-radius: 2rem; }
.p-company .s-list ul li dl {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        row-gap: 1rem;
        margin-top: 1.6rem; }
.p-company .s-list ul li dl div {
          display: -ms-grid;
          display: grid;
          -ms-grid-columns: 9rem 1fr;
          grid-template-columns: 9rem 1fr; }
.p-company .s-list ul li dl div dt {
            padding-bottom: 0.5rem;
            font-family: "Zen Maru Gothic", serif;
            font-size: 1.8rem;
            font-weight: bold;
            border-bottom: 2px solid #222; }
.p-company .s-list ul li dl div dd {
            padding-bottom: 0.5rem;
            padding-left: 1rem;
            font-size: 1.8rem;
            font-weight: 500;
            border-bottom: 2px solid #c3b4a8; }
.p-company .s-list-content {
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    padding: 2rem;
    margin-top: 2rem;
    border: 3px solid #f2eee9;
    border-radius: 2rem; }
.p-company .s-list-content p {
      padding-top: 1rem;
      margin-top: 0.8rem;
      font-size: 1.4rem;
      font-weight: 500;
      line-height: 2;
      border-top: 3px solid #f2eee9; }
.p-company .s-list-subttl {
    position: relative;
    padding-left: 2.3rem;
    font-family: "Zen Maru Gothic", serif;
    font-size: 1.8rem;
    font-weight: bold;
    letter-spacing: 0.05em; }
.p-company .s-list-subttl::before {
      position: absolute;
      top: 0.3rem;
      left: 0;
      -webkit-box-sizing: border-box;
              box-sizing: border-box;
      width: 1.8rem;
      height: 1.8rem;
      content: "";
      border: 6px solid #ffca3b;
      border-radius: 50%; }
.p-guide-list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: (1fr)[3];
  grid-template-columns: repeat(3, 1fr);
  grid-column-gap: 3rem;
  -webkit-column-gap: 3rem;
     -moz-column-gap: 3rem;
          column-gap: 3rem;
  margin-top: 6rem; }
.p-guide-list > li {
    position: relative;
    width: 100%;
    height: 100%;
    padding: 5rem 3.5rem;
    background: #fff;
    border-radius: 2rem; }
.p-guide-list > li > a {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      text-indent: -9999px; }
.p-guide-list__ttl {
    font-family: "Zen Maru Gothic", serif;
    font-size: 2.8rem;
    font-weight: bold;
    text-align: center;
    letter-spacing: 0.05em;
    -webkit-transition: 0.3s all;
    transition: 0.3s all; }
.p-guide-list__icon {
    margin: 0 auto;
    margin-top: 3.5rem; }
.p-guide-list__icon figure {
      width: 21rem;
      margin: 0 auto; }
.p-guide-list__text {
    margin-top: 3rem;
    font-family: "Zen Maru Gothic", serif;
    font-size: 1.5rem;
    font-weight: bold;
    line-height: 1.7;
    letter-spacing: 0.05em;
    -webkit-transition: 0.3s all;
    transition: 0.3s all; }
.p-guide-list__btn {
    margin-top: 3rem; }
.p-guide-list__btn div {
      position: relative;
      z-index: 2;
      cursor: pointer; }
.p-guide .s-check-list {
  margin-top: 6rem; }
.p-guide .s-check-list__ttl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 1rem;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin: 3.5rem 0;
    font-family: "Zen Maru Gothic", serif;
    font-size: 3.2rem;
    font-weight: bold;
    letter-spacing: 0.2rem; }
.p-guide .s-check-list__text {
    width: 88rem;
    margin-inline: auto;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.7; }
.p-guide .s-check-list__link-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 2.8rem;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 2rem; }
.p-guide .s-check-list__link-text {
    font-family: "Zen Maru Gothic", serif;
    font-size: 1.6rem;
    font-weight: bold; }
.p-guide .s-check-list__link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 0.5rem;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 12.5rem;
    height: 5.1rem;
    font-family: "Zen Maru Gothic", serif;
    font-size: 1.8rem;
    font-weight: bold;
    color: #333;
    background-color: white;
    border: solid 2px #ff7f2f;
    border-radius: 2.6rem;
    -webkit-transition: background-color 0.3s, color 0.3s;
    transition: background-color 0.3s, color 0.3s; }
.p-guide .s-check-list__link path {
      -webkit-transition: fill 0.3s;
      transition: fill 0.3s; }
.p-guide-under .s-intro {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 66rem 1fr;
  grid-template-columns: 66rem 1fr;
  grid-column-gap: 8rem;
  -webkit-column-gap: 8rem;
     -moz-column-gap: 8rem;
          column-gap: 8rem;
  margin-top: 8rem; }
.p-guide-under .s-intro-left {
    padding-top: 2rem; }
.p-guide-under .s-intro-left p {
      margin-top: 3rem;
      font-family: "Zen Maru Gothic", serif;
      font-size: 1.6rem;
      font-weight: bold;
      line-height: 1.7; }
.p-guide-under .s-intro-left p span {
        font-size: 2rem;
        color: #ff7f2f; }
.p-guide-under .s-intro-right {
    margin-right: -2rem; }
.p-guide-under .s-intro.cleaning {
    -webkit-column-gap: 13rem;
       -moz-column-gap: 13rem;
            column-gap: 13rem; }
.p-guide-under .s-desc {
  position: relative;
  margin-top: -2rem;
  background: #fff;
  border-radius: 2rem; }
.p-guide-under .s-desc-inner {
    padding: 6rem; }
.p-guide-under .s-desc-ttl {
    font-family: "Zen Maru Gothic", serif;
    font-size: 3.2rem;
    font-weight: bold;
    color: #ff7f2f;
    text-align: center;
    letter-spacing: 0.05em; }
.p-guide-under .s-desc-copy {
    margin-top: 3rem;
    font-family: "Zen Maru Gothic", serif;
    font-size: 2.4rem;
    font-weight: bold;
    text-align: center;
    letter-spacing: 0.05em; }
.p-guide-under .s-desc-text {
    padding: 0 6rem;
    margin-top: 3rem;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.7;
    letter-spacing: 0; }
.p-guide-under .s-desc-flow {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 6rem 1fr;
    grid-template-columns: 6rem 1fr;
    grid-column-gap: 1rem;
    -webkit-column-gap: 1rem;
       -moz-column-gap: 1rem;
            column-gap: 1rem;
    margin-top: 5rem; }
.p-guide-under .s-desc-flow__ttl {
      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;
      width: 100%;
      height: 20rem;
      font-family: "Zen Maru Gothic", serif;
      font-size: 2.4rem;
      font-weight: bold;
      color: #fff;
      letter-spacing: 0.2em;
      background: #ff7f2f;
      -webkit-writing-mode: vertical-rl;
          -ms-writing-mode: tb-rl;
              writing-mode: vertical-rl; }
.p-guide-under .s-desc-flow ul {
      display: -ms-grid;
      display: grid;
      -ms-grid-columns: (1fr)[4];
      grid-template-columns: repeat(4, 1fr);
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      background: #ede7d5; }
.p-guide-under .s-desc-flow ul > li {
        position: relative;
        display: -webkit-inline-box;
        display: -ms-inline-flexbox;
        display: inline-flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        height: 100%; }
.p-guide-under .s-desc-flow ul > li div {
          width: -webkit-fit-content;
          width: -moz-fit-content;
          width: fit-content;
          margin: 0 auto; }
.p-guide-under .s-desc-flow ul > li div span {
            font-family: "Zen Maru Gothic", serif;
            font-size: 2rem;
            font-weight: bold;
            letter-spacing: 0.05em; }
.p-guide-under .s-desc-flow ul > li div p {
            margin-top: 1rem;
            font-size: 1.6rem;
            font-weight: 500;
            line-height: 1.7; }
.p-guide-under .s-desc-list {
    position: relative;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    padding: 6rem 0 5rem;
    margin-top: 8rem;
    border: 5px solid #ffca3b; }
.p-guide-under .s-desc-list > span {
      position: absolute;
      top: -3rem;
      left: 50%;
      padding: 1.5rem 4rem;
      font-family: "Zen Maru Gothic", serif;
      font-size: 2rem;
      font-weight: bold;
      letter-spacing: 0.05em;
      background: #ffca3b;
      border-radius: 3.7rem;
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%); }
.p-guide-under .s-desc-list ul {
      display: -ms-grid;
      display: grid;
      -ms-grid-columns: (-webkit-max-content)[2];
      -ms-grid-columns: (max-content)[2];
      grid-template-columns: repeat(2, -webkit-max-content);
      grid-template-columns: repeat(2, max-content);
      grid-row-gap: 2rem;
      row-gap: 2rem;
      grid-column-gap: 5rem;
      -webkit-column-gap: 5rem;
         -moz-column-gap: 5rem;
              column-gap: 5rem;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center; }
.p-guide-under .s-desc-list ul li {
        position: relative;
        padding-left: 2.5rem;
        font-family: "Zen Maru Gothic", serif;
        font-size: 2.8rem;
        font-weight: bold;
        letter-spacing: 0.05em; }
.p-guide-under .s-desc-list ul li::before {
          position: absolute;
          top: 50%;
          left: 0;
          width: 1.6rem;
          height: 1.6rem;
          content: "";
          background: #ffca3b;
          border-radius: 50%;
          -webkit-transform: translateY(-50%);
                  transform: translateY(-50%); }
.p-guide-under .s-desc-list dl {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
      row-gap: 3rem;
      padding: 0 8rem; }
.p-guide-under .s-desc-list dl > div {
        display: -ms-grid;
        display: grid;
        -ms-grid-columns: 1fr 50rem;
        grid-template-columns: 1fr 50rem;
        grid-column-gap: 3rem;
        -webkit-column-gap: 3rem;
           -moz-column-gap: 3rem;
                column-gap: 3rem;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center; }
.p-guide-under .s-desc-list dl > div dt {
          position: relative;
          padding-left: 2.5rem;
          font-family: "Zen Maru Gothic", serif;
          font-size: 2.4rem;
          font-weight: bold;
          line-height: 1.5;
          letter-spacing: 0.05em; }
.p-guide-under .s-desc-list dl > div dt::before {
            position: absolute;
            top: 50%;
            left: 0;
            -webkit-box-sizing: border-box;
                    box-sizing: border-box;
            width: 2rem;
            height: 2rem;
            content: "";
            border: 7px solid #ffca3b;
            border-radius: 50%;
            -webkit-transform: translateY(-50%);
                    transform: translateY(-50%); }
.p-guide-under .s-desc-list dl > div dt > div {
            display: -ms-grid;
            display: grid;
            -ms-grid-columns: 8rem 1fr;
            grid-template-columns: 8rem 1fr;
            -webkit-box-align: center;
                -ms-flex-align: center;
                    align-items: center; }
.p-guide-under .s-desc-list dl > div dd {
          font-size: 1.6rem;
          font-weight: 500;
          line-height: 1.7; }
.p-guide-under .s-desc-content {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (auto)[2];
    grid-template-columns: repeat(2, auto);
    grid-column-gap: 10rem;
    -webkit-column-gap: 10rem;
       -moz-column-gap: 10rem;
            column-gap: 10rem;
    margin-top: 5rem; }
.p-guide-under .s-desc-content span {
      margin-top: 2rem;
      font-family: "Zen Maru Gothic", serif;
      font-size: 1.8rem;
      font-weight: bold;
      line-height: 1.4;
      letter-spacing: 0.05em; }
.p-guide-under .s-desc-content > div:first-of-type {
      position: relative; }
.p-guide-under .s-desc-content > div:first-of-type::after {
        position: absolute;
        top: 50%;
        right: -7rem;
        width: 4rem;
        height: 4rem;
        content: "";
        background: url(../images/guide/cooking/ic-arrow.svg);
        background-repeat: no-repeat;
        background-size: cover;
        -webkit-transform: translateY(-50%) translateY(-4rem);
                transform: translateY(-50%) translateY(-4rem); }
.p-guide-under .s-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 6rem;
  margin-top: 6rem; }
.p-guide-under .s-list > li {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 44rem;
    grid-template-columns: 1fr 44rem;
    grid-column-gap: 5rem;
    -webkit-column-gap: 5rem;
       -moz-column-gap: 5rem;
            column-gap: 5rem;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    padding: 6rem;
    background: #fff;
    border-radius: 2rem; }
.p-guide-under .s-list-ttl {
    font-family: "Zen Maru Gothic", serif;
    font-size: 3.2rem;
    font-weight: bold;
    line-height: 1.4;
    color: #ff7f2f;
    letter-spacing: 0.05em; }
.p-guide-under .s-list-copy {
    margin-top: 2rem;
    font-family: "Zen Maru Gothic", serif;
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.4;
    letter-spacing: 0.05em; }
.p-guide-under .s-list-text {
    margin-top: 2rem;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.7; }
.p-guide-under .s-type {
  padding: 6rem;
  margin-top: 6rem;
  background: #fff;
  border-radius: 2rem; }
.p-guide-under .s-type-ttl {
    font-family: "Zen Maru Gothic", serif;
    font-size: 3.2rem;
    font-weight: bold;
    line-height: 1.4;
    color: #ff7f2f;
    letter-spacing: 0.05em; }
.p-guide-under .s-type-subttl {
    position: relative;
    padding-left: 2.5rem;
    font-family: "Zen Maru Gothic", serif;
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.5;
    letter-spacing: 0.05em; }
.p-guide-under .s-type-subttl::before {
      position: absolute;
      top: 0.8rem;
      left: 0;
      -webkit-box-sizing: border-box;
              box-sizing: border-box;
      width: 2rem;
      height: 2rem;
      content: "";
      border: 7px solid #ffca3b;
      border-radius: 50%; }
.p-guide-under .s-type dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    row-gap: 3rem;
    margin-top: 5rem; }
.p-guide-under .s-type dl div {
      display: -ms-grid;
      display: grid;
      -ms-grid-columns: 1fr 30rem;
      grid-template-columns: 1fr 30rem;
      grid-column-gap: 7.5rem;
      -webkit-column-gap: 7.5rem;
         -moz-column-gap: 7.5rem;
              column-gap: 7.5rem; }
.p-guide-under .s-type dl div dt p {
        margin-top: 1.4rem;
        font-size: 1.6rem;
        font-weight: 500;
        line-height: 1.7; }
.p-guide-under .s-plus {
  padding: 6rem;
  margin-top: 6rem;
  background: #fff;
  border-radius: 2rem; }
.p-guide-under .s-plus-ttl {
    font-family: "Zen Maru Gothic", serif;
    font-size: 3.2rem;
    font-weight: bold;
    line-height: 1.4;
    color: #ff7f2f;
    text-align: center;
    letter-spacing: 0.05em; }
.p-guide-under .s-plus-wrap {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
    grid-column-gap: 6rem;
    -webkit-column-gap: 6rem;
       -moz-column-gap: 6rem;
            column-gap: 6rem;
    margin-top: 5rem; }
.p-guide-under .s-plus-wrap > div span {
      margin-top: 3rem;
      font-family: "Zen Maru Gothic", serif;
      font-size: 1.8rem;
      font-weight: bold;
      letter-spacing: 0.05em; }
.p-guide-under .s-plus-wrap > div p {
      margin-top: 2rem;
      font-size: 1.6rem;
      font-weight: 500;
      line-height: 1.7; }
.p-guide-under .s-other {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 5rem;
     -moz-column-gap: 5rem;
          column-gap: 5rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 8rem; }
.p-guide-under .s-other > figure {
    width: 16rem; }
.p-guide-under .s-other > ul {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (35rem)[2];
    grid-template-columns: repeat(2, 35rem);
    grid-column-gap: 3rem;
    -webkit-column-gap: 3rem;
       -moz-column-gap: 3rem;
            column-gap: 3rem; }
.p-guide-under .s-other > ul li p {
      padding: 0 1.5rem;
      margin-top: 1.4rem;
      font-size: 1.5rem;
      font-weight: bold;
      line-height: 1.7;
      letter-spacing: 0.05em; }
.p-movie .s-movie {
  margin-top: 15rem; }
.p-movie .s-movie__inner {
    width: 128rem;
    padding: 6rem;
    margin-inline: auto;
    margin-top: 8rem;
    background-color: #fffbf7;
    border-radius: 2rem; }
.p-movie .s-movie__list {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[3];
    grid-template-columns: repeat(3, 1fr);
    grid-gap: 6rem 4rem;
    gap: 6rem 4rem; }
.p-movie .s-movie__ready {
    margin-top: 1rem;
    font-family: "Zen Maru Gothic", serif;
    font-size: 3.4rem;
    font-weight: bold;
    color: #ff7f2f;
    text-align: center; }
.p-movie .s-movie__item {
    position: relative;
    border-radius: 1rem; }
.p-movie .s-movie__item-picture {
      position: relative;
      z-index: 2;
      width: 100%;
      height: auto;
      height: 24rem;
      overflow: hidden;
      cursor: pointer;
      border-radius: 1rem; }
.p-movie .s-movie__item-picture.is-active {
        z-index: -1; }
.p-movie .s-movie__item-picture figure {
        height: 100%; }
.p-movie .s-movie__item-picture figure img {
          width: 100%;
          height: 100%;
          -o-object-fit: cover;
             object-fit: cover; }
.p-movie .s-movie__item-movie {
      position: absolute;
      top: 0;
      left: 0;
      z-index: -1;
      width: 100%;
      height: 24rem; }
.p-movie .s-movie__item-movie.is-active {
        z-index: 1; }
.p-movie .s-movie__item-movie iframe {
        width: 100%;
        height: 100%;
        border-radius: 1rem; }
.p-movie .s-movie__item-play-icon {
      position: absolute;
      top: 50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
              transform: translate(-50%, -50%); }
.p-movie .s-movie__item-play-icon.is-active {
        display: none; }
.p-movie .s-movie__item-play-icon::before {
        position: absolute;
        top: 0;
        left: 0;
        z-index: 1;
        width: 100%;
        height: 100%;
        pointer-events: all;
        content: ""; }
.p-movie .s-movie__item-ttl {
      margin-top: 0.5rem; }
.p-movie .s-movie__item-ttl h3 {
        margin-bottom: 0.5rem;
        font-family: "Zen Maru Gothic", serif;
        font-size: 1.5rem;
        font-weight: bold;
        text-align: center;
        letter-spacing: 0.2rem; }
.p-movie .s-movie__item-desc {
      margin: 0;
      font-size: 1.5rem;
      font-weight: bold;
      text-align: center;
      letter-spacing: 0.2rem; }
.p-tomojika .s-profile {
  position: relative;
  margin-top: 12rem;
  background: #fff;
  border-radius: 2rem; }
.p-tomojika .s-profile-ttl {
    position: absolute;
    top: -3.5rem;
    left: -3rem; }
.p-tomojika .s-profile-wrap {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 24rem 1fr;
    grid-template-columns: 24rem 1fr;
    grid-column-gap: 5.5rem;
    -webkit-column-gap: 5.5rem;
       -moz-column-gap: 5.5rem;
            column-gap: 5.5rem;
    padding: 6rem 6rem 6rem 7.5rem; }
.p-tomojika .s-profile-wrap dl {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
      row-gap: 1rem; }
.p-tomojika .s-profile-wrap dl div {
        display: -ms-grid;
        display: grid;
        -ms-grid-columns: 10rem 1fr;
        grid-template-columns: 10rem 1fr;
        grid-column-gap: 1rem;
        -webkit-column-gap: 1rem;
           -moz-column-gap: 1rem;
                column-gap: 1rem; }
.p-tomojika .s-profile-wrap dl div dt {
          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;
          width: 100%;
          height: 2.8rem;
          font-size: 1.4rem;
          font-weight: 500;
          letter-spacing: 0.05em;
          background: #ede7d5;
          border-radius: 1.5rem; }
.p-tomojika .s-profile-wrap dl div dd {
          font-size: 1.5rem;
          font-weight: 500;
          line-height: 1.4;
          letter-spacing: 0.05em; }
.p-tomojika .s-about {
  margin-top: 12rem; }
.p-tomojika .s-about-wrap {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: 1fr 35.5rem;
    grid-template-columns: 1fr 35.5rem;
    grid-column-gap: 7rem;
    -webkit-column-gap: 7rem;
       -moz-column-gap: 7rem;
            column-gap: 7rem;
    padding: 6rem 7rem 6rem 6rem;
    margin-top: 3.5rem;
    background: #fff;
    border-radius: 2rem; }
.p-tomojika .s-about-wrap p {
      margin-top: 3rem;
      font-size: 1.6rem;
      font-weight: 500;
      line-height: 1.7; }
.p-tomojika .s-about-wrap p span {
        color: #ff7f2f; }
.p-tomojika .s-about-wrap > div > span {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      margin-top: 2rem;
      font-family: "Zen Maru Gothic", serif;
      font-size: 1.8rem;
      font-weight: bold;
      letter-spacing: 0.05em; }
.p-tomojika .s-about-ttl {
    font-family: "Zen Maru Gothic", serif;
    font-size: 3.2rem;
    font-weight: bold;
    color: #ff7f2f;
    letter-spacing: 0.05em; }
.p-tomojika .s-logo {
  padding: 6rem 9rem;
  margin-top: 6rem;
  background: #fff;
  border-radius: 2rem; }
.p-tomojika .s-logo-ttl {
    font-family: "Zen Maru Gothic", serif;
    font-size: 3.2rem;
    font-weight: bold;
    color: #ff7f2f;
    text-align: center;
    letter-spacing: 0.05em; }
.p-tomojika .s-logo-subttl {
    position: relative;
    padding-left: 2.5rem;
    font-family: "Zen Maru Gothic", serif;
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.5;
    letter-spacing: 0.05em; }
.p-tomojika .s-logo-subttl::before {
      position: absolute;
      top: 0.8rem;
      left: 0;
      -webkit-box-sizing: border-box;
              box-sizing: border-box;
      width: 2rem;
      height: 2rem;
      content: "";
      border: 7px solid #ffca3b;
      border-radius: 50%; }
.p-tomojika .s-logo-subttl span {
      display: block;
      margin-top: 1rem;
      font-size: 2rem;
      font-weight: bold;
      line-height: 1; }
.p-tomojika .s-logo-wrap p {
    padding: 0 3rem;
    margin-top: 3rem;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.7; }
.p-tomojika .s-logo-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    row-gap: 3rem;
    width: 80rem;
    margin-top: 5rem; }
.p-tomojika .s-logo-list > li {
      display: -ms-grid;
      display: grid;
      -ms-grid-columns: 16rem 1fr;
      grid-template-columns: 16rem 1fr;
      grid-column-gap: 4rem;
      -webkit-column-gap: 4rem;
         -moz-column-gap: 4rem;
              column-gap: 4rem; }
.p-tomojika .s-logo-list > li > ul {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        row-gap: 0.5rem; }
.p-tomojika .s-logo-list > li > ul li {
          font-size: 1.5rem;
          font-weight: 500;
          line-height: 1.7;
          letter-spacing: 0.05em; }
.p-tomojika .s-logo-list > li > ul li a {
            -webkit-transition: 0.3s all;
            transition: 0.3s all;
            text-decoration: underline; }
.p-tomojika .s-logo-list > li > ul li a:hover {
              color: #ff7f2f; }
.p-tomojika .s-logo-list > li dl {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        row-gap: 1rem; }
.p-tomojika .s-logo-list > li dl div {
          display: -ms-grid;
          display: grid;
          -ms-grid-columns: 10rem 1fr;
          grid-template-columns: 10rem 1fr;
          grid-column-gap: 1rem;
          -webkit-column-gap: 1rem;
             -moz-column-gap: 1rem;
                  column-gap: 1rem; }
.p-tomojika .s-logo-list > li dl div dt {
            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;
            width: 100%;
            height: 2.8rem;
            font-size: 1.4rem;
            font-weight: 500;
            letter-spacing: 0.05em;
            background: #ede7d5;
            border-radius: 1.5rem; }
.p-tomojika .s-logo-list > li dl div dd {
            font-size: 1.5rem;
            font-weight: 500;
            line-height: 1.4;
            letter-spacing: 0.05em; }
.p-tomojika .s-logo-content {
    margin-top: 3rem; }
.p-tomojika .s-logo-content .tomojika {
      display: -ms-grid;
      display: grid;
      -ms-grid-columns: (1fr)[3];
      grid-template-columns: repeat(3, 1fr);
      grid-gap: 2rem;
      gap: 2rem;
      margin-top: 3rem; }
.p-tomojika .s-logo-content .tomojika li {
        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;
        width: 100%;
        height: 100%;
        padding: 1rem 0;
        border: 1px solid #ffca3b; }
.p-tomojika .s-logo-content .tomojika li figure {
          width: 22rem;
          height: 22rem; }
.p-tomojika .s-logo-content .logomark {
      display: -ms-grid;
      display: grid;
      -ms-grid-columns: 34rem 22rem 31.8rem;
      grid-template-columns: 34rem 22rem 31.8rem;
      grid-column-gap: 2rem;
      -webkit-column-gap: 2rem;
         -moz-column-gap: 2rem;
              column-gap: 2rem;
      margin-top: 2rem; }
.p-tomojika .s-gallery {
  padding: 6rem 9rem 6rem 6rem;
  margin-top: 6rem;
  background: #fff;
  border-radius: 2rem; }
.p-tomojika .s-gallery-ttl {
    font-family: "Zen Maru Gothic", serif;
    font-size: 3.2rem;
    font-weight: bold;
    color: #ff7f2f;
    text-align: center;
    letter-spacing: 0.05em; }
.p-tomojika .s-gallery-inner {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
    grid-row-gap: 6rem;
    row-gap: 6rem;
    grid-column-gap: 9rem;
    -webkit-column-gap: 9rem;
       -moz-column-gap: 9rem;
            column-gap: 9rem;
    margin-top: 4rem; }
.p-tomojika .s-gallery-inner > div {
      display: -webkit-inline-box;
      display: -ms-inline-flexbox;
      display: inline-flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
      row-gap: 4rem;
      -webkit-box-align: start;
          -ms-flex-align: start;
              align-items: flex-start; }
.p-tomojika .s-gallery-inner > div:nth-of-type(2) {
        position: relative; }
.p-tomojika .s-gallery-inner > div:nth-of-type(2)::before {
          position: absolute;
          left: -4rem;
          width: 4px;
          height: 100%;
          content: "";
          background-image: radial-gradient(circle, #d1d1d1 2px, transparent 2px);
          background-size: 4px 14px; }
.p-tomojika .s-gallery-inner > div:nth-of-type(3) ul {
        display: -ms-grid;
        display: grid;
        -ms-grid-columns: (1fr)[3];
        grid-template-columns: repeat(3, 1fr);
        grid-row-gap: 3rem;
        row-gap: 3rem;
        grid-column-gap: 3.5rem;
        -webkit-column-gap: 3.5rem;
           -moz-column-gap: 3.5rem;
                column-gap: 3.5rem; }
.p-tomojika .s-gallery-inner > div:nth-of-type(3) ul li span {
          margin-top: 1.5rem;
          font-family: "Zen Maru Gothic", serif;
          font-size: 2rem;
          font-weight: bold;
          letter-spacing: 0.05em; }
.p-tomojika .s-gallery-inner > div:last-of-type figure {
        width: 29.3rem; }
.p-tomojika .s-gallery-expression ul {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 2rem;
    gap: 2rem; }
.p-tomojika .s-gallery-expression ul li {
      position: relative;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
      width: 100%;
      height: 100%;
      overflow: hidden;
      border: 1px solid #ffca3b;
      border-radius: 2rem; }
.p-tomojika .s-gallery-expression ul li span {
        position: absolute;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        height: 4rem;
        padding: 0 2.5rem;
        font-family: "Zen Maru Gothic", serif;
        font-size: 1.8rem;
        font-weight: bold;
        color: #fff;
        letter-spacing: 0.2em;
        background: #ff7f2f;
        border-bottom-right-radius: 2rem; }
.p-tomojika .s-gallery-expression ul li figure {
        width: 20.8rem;
        padding-top: 3.5rem;
        margin: auto auto 0; }
.s-entry {
  margin-top: 16rem; }
.s-entry__banner {
    margin-bottom: 3.8rem;
    -webkit-transition: opacity .3s;
    transition: opacity .3s; }
.s-entry__text {
    width: 88rem;
    font-size: 1.6rem;
    line-height: 1.7;
    margin-inline: auto;
    margin-bottom: 3rem; }
.s-entry__date {
    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;
    font-size: 2.4rem;
    font-weight: bold;
    font-family: "Zen Maru Gothic", serif;
    gap: 1.5rem;
    letter-spacing: 0.2rem; }
.s-entry__date-ttl {
      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;
      width: 13.4rem;
      height: 2.9rem;
      font-size: 2rem;
      letter-spacing: 0.5rem;
      background-color: #FFCA3B;
      border-radius: 1.5rem;
      color: #333333; }
.s-entry__bottom-wrap {
    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;
    gap: 2.5rem;
    margin-top: 2rem; }
.s-entry__bottom-wrap figure {
      width: 16rem; }
.s-entry__link {
    display: block;
    margin: 2.5rem auto 0;
    width: 16.5rem;
    text-align: center;
    padding-bottom: 0.5rem;
    font-size: 1.6rem;
    font-weight: bold;
    font-family: "Zen Maru Gothic", serif;
    position: relative;
    overflow-x: hidden; }
.s-entry__link::before, .s-entry__link::after {
      content: '';
      display: block;
      width: 100%;
      height: 2px;
      background-color: #222222;
      position: absolute;
      bottom: 0;
      left: 0;
      -webkit-transition: left 0.5s;
      transition: left 0.5s; }
.s-entry__link::after {
      left: calc(-100% - 5rem); }
.finish-text {
  font-size: 2.6rem;
  line-height: 1.7;
  font-family: "Zen Maru Gothic", serif;
  font-weight: 700;
  color: #FF7F2F; }
.p-top {
  overflow: hidden; }
.p-top p {
    margin-bottom: 3.5rem;
    font-family: "Zen Maru Gothic", serif;
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.7; }
.p-top p:last-of-type {
      margin-bottom: 0; }
.p-top .s-mv {
    position: relative;
    height: 80rem; }
.p-top .s-mv__swiper {
      position: absolute;
      left: 0;
      width: 100%; }
.p-top .s-mv__swiper .swiper-wrapper {
        -webkit-transition-timing-function: linear;
                transition-timing-function: linear; }
.p-top .s-mv__swiper .swiper-slide {
        -ms-flex-negative: 1;
            flex-shrink: 1;
        font-family: "Zen Maru Gothic", serif;
        font-size: 18rem;
        font-weight: bold;
        line-height: 1;
        color: #ede7d5; }
.p-top .s-mv__swiper--top {
        top: -8rem; }
.p-top .s-mv__swiper--bottom {
        bottom: -8rem; }
.p-top .s-mv__main-catch {
      position: absolute;
      top: calc(50% + 40px);
      right: 14rem;
      z-index: 1;
      font-family: "Zen Maru Gothic", serif;
      font-size: 5.1rem;
      font-weight: bold;
      line-height: 1.5;
      color: #222;
      letter-spacing: 2rem;
      opacity: 0;
      -webkit-writing-mode: vertical-rl;
          -ms-writing-mode: tb-rl;
              writing-mode: vertical-rl;
      -webkit-transform: translate(0, -50%);
              transform: translate(0, -50%); }
.p-top .s-mv__sub-catch {
      position: absolute;
      top: calc(50% + 40px);
      left: 14rem;
      z-index: 1;
      font-family: "Zen Maru Gothic", serif;
      font-size: 2.8rem;
      font-weight: bold;
      line-height: 2;
      letter-spacing: 1.5rem;
      white-space: nowrap;
      opacity: 0;
      -webkit-writing-mode: vertical-rl;
          -ms-writing-mode: tb-rl;
              writing-mode: vertical-rl;
      -webkit-transform: translate(0, -50%);
              transform: translate(0, -50%); }
.p-top .s-mv__inner {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%; }
.p-top .s-mv__mv-image {
      position: absolute;
      top: 21.3rem;
      left: calc(50vw - 33.5rem);
      z-index: 1;
      width: 67rem;
      opacity: 0;
      -webkit-transform: scale(1.2) rotate(-30deg);
              transform: scale(1.2) rotate(-30deg); }
.p-top .s-mv__mv-bg {
      position: absolute;
      top: 0;
      left: calc(50vw - 45.25rem);
      width: 90.5rem;
      opacity: 0;
      -webkit-transform: scale(1.2);
              transform: scale(1.2); }
.p-top .s-mv__mv-bottom {
      position: absolute;
      top: 51.5rem;
      left: calc(50vw - 45.25rem);
      width: 90.5rem;
      opacity: 0;
      -webkit-transform: scale(1.2);
              transform: scale(1.2); }
.p-top .s-about {
    position: relative;
    z-index: 1;
    padding-inline: 2.6rem;
    margin-top: 17rem; }
.p-top .s-about__illust {
      position: absolute;
      top: -16rem;
      right: -4rem;
      width: 23.6rem; }
.p-top .s-about > p {
      width: 73rem; }
.p-top .s-about__inner {
      margin-top: 6.7rem; }
.p-top .s-about__content {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-align: end;
          -ms-flex-align: end;
              align-items: flex-end;
      -webkit-box-pack: end;
          -ms-flex-pack: end;
              justify-content: flex-end; }
.p-top .s-about__content-left {
        width: 70rem; }
.p-top .s-about__content-left img {
          width: 100%;
          height: 100%;
          -o-object-fit: contain;
             object-fit: contain; }
.p-top .s-about__content-right {
        margin-bottom: -5rem;
        margin-left: -8rem; }
.p-top .s-about__content-right-wrap {
          position: relative;
          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: start;
          width: 20.8rem;
          padding: 2rem 2.5rem;
          background-color: #fff;
          border-radius: 17rem; }
.p-top .s-about__content-right-wrap::before {
            position: absolute;
            top: calc(100% - 0.5rem);
            left: 50%;
            width: 3.3rem;
            height: 1.7rem;
            content: "";
            background: url(./../images/top/hukidashi.webp) no-repeat center center/contain;
            -webkit-transform: translateX(-50%);
                    transform: translateX(-50%); }
.p-top .s-about__content-right-wrap h3 {
            font-size: 1.8rem;
            font-weight: 700;
            letter-spacing: 0.05em;
            line-height: 1.4;
            color: #ff7f2f; }
.p-top .s-about__content-right-wrap p {
            font-size: 1.4rem;
            font-weight: 500;
            letter-spacing: 0.05em;
            line-height: 1.8;
            color: #222; }
.p-top .s-about__content-right-wrap p span {
              color: #ff7f2f; }
.p-top .s-about__content-right img {
          position: relative;
          z-index: 2;
          width: 24.3rem;
          height: auto;
          margin-top: -2rem;
          margin-right: -6.7rem;
          margin-left: auto;
          -o-object-fit: contain;
             object-fit: contain; }
.p-top .s-article-list {
    margin-top: 13.5rem; }
.p-top .s-article-list__ttl {
      margin-bottom: 5rem; }
.p-top .s-article-list__slider {
      padding-left: 20rem;
      overflow-x: scroll; }
.p-top .s-article-list__slider::-webkit-scrollbar {
        display: none; }
.p-top .s-article-list__inner-wrap {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      gap: 18rem; }
.p-top .s-article-list__item {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      gap: 6rem;
      -webkit-box-align: end;
          -ms-flex-align: end;
              align-items: flex-end; }
.p-top .s-article-list__item:last-of-type {
        padding-right: 30rem; }
.p-top .s-article-list__img-wrap {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      gap: 1.5rem;
      -webkit-box-align: start;
          -ms-flex-align: start;
              align-items: flex-start; }
.p-top .s-article-list__en {
      font-size: 1.2rem;
      font-weight: bold;
      letter-spacing: 0.1rem;
      -webkit-writing-mode: vertical-rl;
          -ms-writing-mode: tb-rl;
              writing-mode: vertical-rl; }
.p-top .s-article-list__img {
      width: 36rem;
      height: 46rem;
      overflow: hidden;
      border-radius: 1rem; }
.p-top .s-article-list__desc-wrap {
      position: relative;
      width: 46rem;
      padding-bottom: 5.4rem; }
.p-top .s-article-list__item-ttl {
      margin-bottom: 1rem;
      font-family: "Zen Kaku Gothic New", sans-serif;
      font-size: 3.2rem;
      line-height: 1.7; }
.p-top .s-article-list__item-ttl::before {
        top: 2.4rem;
        right: calc(100% + 1rem);
        width: 1.2rem;
        height: 1.2rem; }
.p-top .s-article-list__text {
      font-family: "Zen Kaku Gothic New", sans-serif;
      font-size: 1.6rem;
      line-height: 1.7; }
.p-top .s-know {
    margin-top: 15rem; }
.p-top .s-know__ttl {
      margin-bottom: 7rem; }
.p-top .s-know__list {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
      -webkit-box-pack: justify;
          -ms-flex-pack: justify;
              justify-content: space-between;
      padding: 0 18.5rem;
      margin-top: 5.5rem; }
.p-top .s-know__item {
      position: relative;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
      width: 50%;
      text-align: center; }
.p-top .s-know__item-ttl {
        margin-top: 2rem;
        margin-bottom: 0;
        font-family: "Zen Maru Gothic", serif;
        font-size: 2.4rem;
        font-weight: bold; }
.p-top .s-know__item-desc {
        margin-bottom: 0;
        font-family: "Zen Maru Gothic", serif;
        font-size: 1.8rem;
        font-weight: bold; }
.p-top .s-know__item-quote {
        font-size: 1.6rem; }
.p-top .s-know__item:first-of-type {
        padding-right: 4rem; }
.p-top .s-know__item:first-of-type figure {
          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-pack: end;
              -ms-flex-pack: end;
                  justify-content: flex-end;
          height: 35rem; }
.p-top .s-know__item:first-of-type::after {
          position: absolute;
          top: 0;
          right: 0;
          width: 0.4rem;
          height: 100%;
          content: "";
          background-image: url(../images/common/border-dots.webp);
          background-repeat: repeat-y;
          background-size: contain; }
.p-top .s-know__item:nth-of-type(2) {
        padding-left: 4rem; }
.p-top .s-know__item:nth-of-type(2) figure {
          height: 35rem; }
.p-top .s-know__item:last-of-type {
        width: 100%;
        padding-top: 6rem;
        margin-top: 4rem; }
.p-top .s-know__item:last-of-type::before {
          position: absolute;
          top: 0;
          left: 0;
          width: 100%;
          height: 0.4rem;
          content: "";
          background-image: url(../images/common/border-dots-width.webp);
          background-repeat: repeat-x;
          background-size: contain; }
.p-top .s-check-list {
    margin-top: 6rem; }
.p-top .s-check-list__ttl {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      gap: 1rem;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      margin: 3.5rem 0;
      font-family: "Zen Maru Gothic", serif;
      font-size: 3.2rem;
      font-weight: bold;
      letter-spacing: 0.2rem; }
.p-top .s-check-list__text {
      width: 88rem;
      margin-inline: auto;
      font-size: 1.6rem;
      line-height: 1.7; }
.p-top .s-check-list__link-wrap {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      gap: 2.8rem;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      margin-top: 2rem; }
.p-top .s-check-list__link-text {
      font-family: "Zen Maru Gothic", serif;
      font-size: 1.6rem;
      font-weight: bold; }
.p-top .s-check-list__link {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      gap: 0.5rem;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      width: 12.5rem;
      height: 5.1rem;
      font-family: "Zen Maru Gothic", serif;
      font-size: 1.8rem;
      font-weight: bold;
      color: #333;
      background-color: white;
      border: solid 2px #ff7f2f;
      border-radius: 2.6rem;
      -webkit-transition: background-color 0.3s, color 0.3s;
      transition: background-color 0.3s, color 0.3s; }
.p-top .s-check-list__link path {
        -webkit-transition: fill 0.3s;
        transition: fill 0.3s; }
.p-top-img-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    padding-inline: 16rem;
    margin-top: 13rem;
    margin-bottom: 5rem; }
.p-top-img-list__item {
      width: 33.4rem;
      height: 22.7rem;
      border: solid 0.8rem white; }
.p-top-img-list__item figure {
        width: 100%;
        height: 100%;
        overflow: hidden; }
.p-top .bg-overlay {
    position: fixed;
    top: 0;
    left: 0;
    z-index: -1;
    width: 110vw;
    height: 110vh;
    pointer-events: none;
    background-color: #f2eee9;
    opacity: 0;
    -webkit-transition: 0.4s;
    transition: 0.4s; }
.p-top .bg-overlay.is-open {
      z-index: 999;
      pointer-events: all;
      opacity: 1; }
.p-voting-modal-list {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: #F2EEE9;
  z-index: 10000;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-top: 10rem;
  display: none; }
.p-voting-modal-list__close {
    position: absolute;
    top: 6rem;
    right: 5rem;
    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;
    gap: 1rem;
    font-size: 1.8rem;
    font-weight: bold;
    font-family: "Zen Maru Gothic", serif; }
.p-voting-modal-list__close svg {
      margin-top: 0.3rem; }
.p-voting-modal-list .swiper-container {
    height: 50rem; }
.p-voting-modal-list .swiper-arrow {
    position: relative;
    color: #333333;
    position: absolute;
    bottom: 2rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 1rem;
    font-weight: medium;
    font-family: "Zen Maru Gothic", serif;
    cursor: pointer;
    z-index: 10;
    font-weight: 500; }
.p-voting-modal-list .swiper-next {
    right: 21rem; }
.p-voting-modal-list .swiper-next::after {
      content: '';
      display: block;
      width: 1.1rem;
      height: 1.2rem;
      background: #FF7F2F;
      -webkit-mask-image: url(../svg/ic-swiper-arrow.svg);
              mask-image: url(../svg/ic-swiper-arrow.svg);
      -webkit-mask-repeat: no-repeat;
              mask-repeat: no-repeat;
      -webkit-mask-size: contain;
              mask-size: contain;
      -webkit-mask-position: center;
              mask-position: center;
      -webkit-transform: rotate(180deg);
              transform: rotate(180deg); }
.p-voting-modal-list .swiper-prev {
    right: 29rem; }
.p-voting-modal-list .swiper-prev::before {
      content: '';
      display: block;
      width: 1.1rem;
      height: 1.2rem;
      background: #FF7F2F;
      -webkit-mask-image: url(../svg/ic-swiper-arrow.svg);
              mask-image: url(../svg/ic-swiper-arrow.svg);
      -webkit-mask-repeat: no-repeat;
              mask-repeat: no-repeat;
      -webkit-mask-size: contain;
              mask-size: contain;
      -webkit-mask-position: center;
              mask-position: center; }
.p-voting-modal-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  position: relative;
  padding: 0 20rem 0 15rem; }
.p-voting-modal-item__figure {
    overflow: hidden;
    width: 60.9rem;
    height: 40.7rem;
    position: relative; }
.p-voting-modal-item__figure--youtube {
      cursor: pointer; }
.p-voting-modal-item__figure--youtube iframe {
        width: 100%;
        height: 35rem; }
.p-voting-modal-item__figure--youtube img {
        -webkit-transition: opacity .3s;
        transition: opacity .3s; }
.p-voting-modal-item__figure--youtube svg {
        position: absolute;
        top: 50%;
        left: 50%;
        -webkit-transform: translate(-50%, -50%);
                transform: translate(-50%, -50%); }
.p-voting-modal-item__desc-wrap {
    width: 39.1rem; }
.p-voting-modal-item__scroll-wrap {
    height: 40.7rem;
    overflow-y: scroll; }
.p-voting-modal-item__cat {
    font-size: 1.4rem;
    font-weight: bold;
    color: white;
    font-family: "Zen Maru Gothic", serif;
    letter-spacing: 0.3rem;
    padding: 1.2rem 2.3rem;
    border-radius: 2rem 0 2rem 0 / 2rem 0 2rem 0;
    display: inline-block;
    width: auto;
    margin-bottom: 2rem; }
.p-voting-modal-item__cat--beginner {
      background-color: #FF7F2F; }
.p-voting-modal-item__cat--intermediate {
      background-color: #88B3AB; }
.p-voting-modal-item__cat--advanced {
      background-color: #4B639A; }
.p-voting-modal-item .c-btn-camera {
    margin-top: 3rem;
    margin-left: 0;
    margin-right: auto; }
.p-works__page-desc {
  margin-top: 4.5rem;
  margin-bottom: 3.5rem;
  font-size: 1.6rem;
  line-height: 1.7;
  width: 84.3rem;
  text-align: center;
  margin-inline: auto; }
.p-works-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 5.5rem 3.6rem;
  width: 110rem;
  margin: 8.8rem auto 0;
  padding-bottom: 3rem; }
.p-works-item {
  width: calc(calc(100% / 3) - 2.4rem);
  position: relative; }
.p-works-item__figure-wrap {
    width: 100%;
    height: 22.7rem;
    border-radius: 2rem;
    overflow: hidden;
    position: relative; }
.p-works-item__figure {
    width: 100%;
    height: 100%; }
.p-works-item__figure img {
      -webkit-transition: -webkit-transform .3s;
      transition: -webkit-transform .3s;
      transition: transform .3s;
      transition: transform .3s, -webkit-transform .3s; }
.p-works-item__figure iframe {
      width: 100%;
      height: 100%; }
.p-works-item__cat {
    position: absolute;
    padding: 1.5rem 2rem;
    color: white;
    border-radius: 0 0 2rem 0 / 0 0 2rem 0;
    top: 0;
    left: 0;
    font-size: 1.4rem;
    font-weight: bold;
    letter-spacing: 0.4rem;
    font-size: "Zen Maru Gothic", serif; }
.p-works-item__cat--beginner {
      background-color: #FF7F2F; }
.p-works-item__cat--intermediate {
      background-color: #88B3AB; }
.p-works-item__cat--advanced {
      background-color: #4B639A; }
.p-works-item__ttl {
    font-size: 1.6rem;
    font-weight: bold;
    font-family: "Zen Maru Gothic", serif;
    margin-top: 1rem; }
.p-works-btn {
  margin-top: 5rem; }
@media screen and (min-width: 768px) {
  .ex-link {
    opacity: 1;
    -webkit-transition: opacity 0.2s linear;
    transition: opacity 0.2s linear; }
    .ex-link:hover {
      opacity: .5; }
  [href*="tel:"] {
    pointer-events: none; }
  .sp {
    display: none !important; }
          .l-footer__content-link .link01:hover span {
            background-color: #FF7F2F; }
            .l-footer__content-link .link01:hover span svg path {
              fill: #fff; }
          .l-footer__content-link .link01:hover p {
            color: #FF7F2F; }
        .l-footer__toTop a:hover {
          -webkit-transform: translateY(-0.8rem) scale(1.05);
                  transform: translateY(-0.8rem) scale(1.05); }
    .c-btn01:hover::after {
      width: 100%; }
    .c-btn01:hover p {
      color: #ff7f2f; }
      .c-btn01:hover p::before {
        background-color: #ff7f2f; }
    .c-btn02:hover {
      background-color: #fff; }
      .c-btn02:hover p {
        color: #ff7f2f !important; }
        .c-btn02:hover p::before {
          background-color: #ff7f2f; }
        .c-btn02:hover p::after {
          background-color: #fff; }
  .c-hov01:hover {
    color: #ff7f2f;
    text-shadow: 0 0 20px rgb(255 127 47 / 50%); }
  .c-hov02:hover {
    background-color: #fff !important; }
    .c-hov02:hover span svg path {
      fill: #ff7f2f; }
    .c-hov02:hover p {
      color: #ff7f2f !important; }
    .modal__close:hover p {
      background-color: #FF7F2F;
      color: #fff; }
  .for-mobile {
    display: none; }
  .for-mobile {
    display: none; }
  .u-1col-pc {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap; }
  .u-2col-pc {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2; }
        .p-contest .s-list-text {
          min-height: 14rem; }
              .p-overview .s-news__item-detail p a:hover {
                opacity: 0.6; }
                .p-overview .s-news__item-detail p span a:hover {
                  opacity: 0.6; }
        .p-company .s-list ul li {
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
              -ms-flex-direction: column;
                  flex-direction: column; }
      .p-company .s-list-content {
        height: 100%; }
        .p-guide-list > li > a:hover ~ .c-hover-text {
          color: #ff7f2f; }
          .p-guide-under .s-desc-flow ul > li:not(:last-child)::before, .p-guide-under .s-desc-flow ul > li:not(:last-child)::after {
            position: absolute;
            right: 1rem;
            width: 0.5rem;
            content: "";
            background-color: #fff; }
          .p-guide-under .s-desc-flow ul > li:not(:last-child)::before {
            top: -0.75rem;
            height: calc(50% + 1rem);
            -webkit-transform: rotate(-15deg);
                    transform: rotate(-15deg); }
          .p-guide-under .s-desc-flow ul > li:not(:last-child)::after {
            bottom: -0.75rem;
            height: calc(50% + 1rem);
            -webkit-transform: rotate(15deg);
                    transform: rotate(15deg); }
      .p-guide-under .s-list > li:nth-child(2) {
        grid-auto-flow: row;
        direction: rtl; }
        .p-guide-under .s-list > li:nth-child(2) .s-list-text {
          direction: ltr; }
        .p-tomojika .s-gallery-inner > div:nth-of-type(3) {
          -ms-grid-column-span: 2;
          grid-column: span 2; } }
@media screen and (max-width: 767px) {
    html {
      font-size: calc(10vw / 414 * 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; }
    .l-footer {
      padding: 4rem 0 6rem; }
      .l-footer__inner {
        width: 100%;
        padding: 0 4rem; }
      .l-footer__content {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column; }
        .l-footer__content p {
          margin-top: 1rem;
          line-height: 1.8; }
        .l-footer__content p span {
          font-size: 1.3rem; }
            .l-footer__content-link .link01 p {
              margin-top: 0; }
      .l-footer__logo {
        margin-top: 4rem; }
        .l-footer__logo svg {
          width: 13rem; }
      .l-footer__copy {
        margin-top: 2.5rem; }
      .l-footer__toTop {
        bottom: 2rem;
        right: 1.8rem; }
        .l-footer__toTop a {
          width: 9.2rem;
          height: 14.8rem; }
    .sp-entry {
      display: block; }
    .fixed-circle {
      right: 1rem;
      width: 12rem;
      height: 12rem;
      opacity: 1 !important; }
      .fixed-circle-txt {
        width: 8rem;
        height: 8rem; }
        .fixed-circle-txt.main {
          width: 8rem; }
      .fixed-circle-bg {
        width: 12rem;
        height: 12rem; }
    .l-header {
      height: 10rem; }
      .l-header.is-scroll {
        height: 6rem; }
      .l-header.is-scroll .l-header__inner {
        padding: 0 1rem; }
      .l-header__logo {
        margin: 0; }
        .l-header__logo svg {
          width: 11.5rem;
          height: auto; }
    .l-main--default-page {
      padding-top: 12rem;
      padding-bottom: 5rem; }
    .c-btn01 {
      width: 24.2rem;
      height: 6rem; }
        .c-btn01 span::before {
          left: 2.5rem; }
      .c-btn01-s {
        width: 100%;
        height: 7rem; }
      .c-btn01-m {
        width: 100%;
        height: 7rem; }
      .c-btn01-c {
        width: 100%;
        height: 7rem; }
    .c-btn02 {
      width: 24rem;
      padding: 1.5rem 1.5rem 1.5rem 3.5rem;
      margin-inline: auto;
      margin-top: 0.5rem; }
    .c-modal {
      padding: 1.5rem;
      height: 50%; }
        .c-modal__video-wrap {
          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-pack: center;
              -ms-flex-pack: center;
                  justify-content: center; }
          .c-modal__video-wrap iframe {
            height: auto; }
      .c-modal__close {
        width: 4rem;
        height: 4rem;
        top: -1rem;
        right: -1rem; }
    .c-sns-list {
      margin: 2rem 0 2.5rem; }
      .c-sns-list__list {
        gap: 1.7rem; }
      .c-sns-list__item a {
        width: 7.7rem;
        height: 7.7rem; }
    .c-sns-list__item--insta svg {
      width: 2.4rem; }
    .c-sns-list__item--x svg {
      width: 2.2rem; }
    .c-sns-list__item--youtube svg {
      width: 3.3rem; }
    .c-speech-balloon {
      white-space: nowrap; }
    .c-ttl01 p {
      font-size: 2rem; }
    .c-ttl-simple-dot {
      margin-bottom: 3rem;
      font-size: 2.4rem;
      line-height: 1.45; }
      .c-ttl-simple-dot::before {
        top: 1.3rem;
        width: 1.3rem;
        height: 1.3rem; }
      .c-ttl-simple__main {
        font-size: 2.5rem; }
      .c-ttl-simple__sub {
        font-size: 1.9rem; }
      .c-ttl-bg-en__en {
        font-size: 10rem; }
      .c-ttl-top-circle::before {
        width: 3rem;
        height: 3rem;
        border-width: 1rem; }
    .c-remark-list__dt {
      font-size: 1.6rem; }
    .c-remark-list__dd {
      font-size: 1.6rem; }
    .c-inner {
      width: 100%;
      padding: 0 2rem; }
    .c-l-inner {
      width: 100%;
      padding: 0 2rem; }
    .modal {
      top: 3rem;
      width: 90%; }
      .modal__ttl {
        background: url(./../images/top/harf-circle-sp.png) no-repeat center center/contain;
        width: 31rem;
        z-index: 2; }
        .modal__ttl-wrap {
          margin-top: 3rem; }
      .modal__container {
        padding: 3rem 2.5rem 6rem 3rem;
        -webkit-transform: translateY(-0.5rem);
                transform: translateY(-0.5rem); }
      .modal__body {
        max-height: 37rem; }
      .modal__btn {
        margin-top: 2rem; }
    .modal__close {
      bottom: 1rem;
      right: 1rem; }
      .modal__close p {
        padding: 0.7rem 0; }
  .for-large {
    display: none; }
  /* font-size */
  .u-fs-sp-0 {
    font-size: 0rem !important; }
  .u-fs-sp-1 {
    font-size: 0.1rem !important; }
  .u-fs-sp-2 {
    font-size: 0.2rem !important; }
  .u-fs-sp-3 {
    font-size: 0.3rem !important; }
  .u-fs-sp-4 {
    font-size: 0.4rem !important; }
  .u-fs-sp-5 {
    font-size: 0.5rem !important; }
  .u-fs-sp-6 {
    font-size: 0.6rem !important; }
  .u-fs-sp-7 {
    font-size: 0.7rem !important; }
  .u-fs-sp-8 {
    font-size: 0.8rem !important; }
  .u-fs-sp-9 {
    font-size: 0.9rem !important; }
  .u-fs-sp-10 {
    font-size: 1rem !important; }
  .u-fs-sp-11 {
    font-size: 1.1rem !important; }
  .u-fs-sp-12 {
    font-size: 1.2rem !important; }
  .u-fs-sp-13 {
    font-size: 1.3rem !important; }
  .u-fs-sp-14 {
    font-size: 1.4rem !important; }
  .u-fs-sp-15 {
    font-size: 1.5rem !important; }
  .u-fs-sp-16 {
    font-size: 1.6rem !important; }
  .u-fs-sp-17 {
    font-size: 1.7rem !important; }
  .u-fs-sp-18 {
    font-size: 1.8rem !important; }
  .u-fs-sp-19 {
    font-size: 1.9rem !important; }
  .u-fs-sp-20 {
    font-size: 2rem !important; }
  .u-fs-sp-21 {
    font-size: 2.1rem !important; }
  .u-fs-sp-22 {
    font-size: 2.2rem !important; }
  .u-fs-sp-23 {
    font-size: 2.3rem !important; }
  .u-fs-sp-24 {
    font-size: 2.4rem !important; }
  .u-fs-sp-25 {
    font-size: 2.5rem !important; }
  .u-fs-sp-26 {
    font-size: 2.6rem !important; }
  .u-fs-sp-27 {
    font-size: 2.7rem !important; }
  .u-fs-sp-28 {
    font-size: 2.8rem !important; }
  .u-fs-sp-29 {
    font-size: 2.9rem !important; }
  .u-fs-sp-30 {
    font-size: 3rem !important; }
  .u-fs-sp-31 {
    font-size: 3.1rem !important; }
  .u-fs-sp-32 {
    font-size: 3.2rem !important; }
  .u-fs-sp-33 {
    font-size: 3.3rem !important; }
  .u-fs-sp-34 {
    font-size: 3.4rem !important; }
  .u-fs-sp-35 {
    font-size: 3.5rem !important; }
  .u-fs-sp-36 {
    font-size: 3.6rem !important; }
  .u-fs-sp-37 {
    font-size: 3.7rem !important; }
  .u-fs-sp-38 {
    font-size: 3.8rem !important; }
  .u-fs-sp-39 {
    font-size: 3.9rem !important; }
  .u-fs-sp-40 {
    font-size: 4rem !important; }
  .u-fs-sp-41 {
    font-size: 4.1rem !important; }
  .u-fs-sp-42 {
    font-size: 4.2rem !important; }
  .u-fs-sp-43 {
    font-size: 4.3rem !important; }
  .u-fs-sp-44 {
    font-size: 4.4rem !important; }
  .u-fs-sp-45 {
    font-size: 4.5rem !important; }
  .u-fs-sp-46 {
    font-size: 4.6rem !important; }
  .u-fs-sp-47 {
    font-size: 4.7rem !important; }
  .u-fs-sp-48 {
    font-size: 4.8rem !important; }
  .u-fs-sp-49 {
    font-size: 4.9rem !important; }
  /* font-weigth */
  .u-fw-sp-l {
    font-weight: lighter !important; }
  .u-fw-sp-n {
    font-weight: normal !important; }
  .u-fw-sp-b {
    font-weight: bold !important; }
  .for-large {
    display: none; }
  /* line-height */
  .u-lh-sp-0 {
    line-height: 0 !important; }
  .u-lh-sp-1 {
    line-height: 0.1 !important; }
  .u-lh-sp-2 {
    line-height: 0.2 !important; }
  .u-lh-sp-3 {
    line-height: 0.3 !important; }
  .u-lh-sp-4 {
    line-height: 0.4 !important; }
  .u-lh-sp-5 {
    line-height: 0.5 !important; }
  .u-lh-sp-6 {
    line-height: 0.6 !important; }
  .u-lh-sp-7 {
    line-height: 0.7 !important; }
  .u-lh-sp-8 {
    line-height: 0.8 !important; }
  .u-lh-sp-9 {
    line-height: 0.9 !important; }
  .u-lh-sp-10 {
    line-height: 1 !important; }
  .u-lh-sp-11 {
    line-height: 1.1 !important; }
  .u-lh-sp-12 {
    line-height: 1.2 !important; }
  .u-lh-sp-13 {
    line-height: 1.3 !important; }
  .u-lh-sp-14 {
    line-height: 1.4 !important; }
  .u-lh-sp-15 {
    line-height: 1.5 !important; }
  .u-lh-sp-16 {
    line-height: 1.6 !important; }
  .u-lh-sp-17 {
    line-height: 1.7 !important; }
  .u-lh-sp-18 {
    line-height: 1.8 !important; }
  .u-lh-sp-19 {
    line-height: 1.9 !important; }
  .u-lh-sp-20 {
    line-height: 2 !important; }
  .u-lh-sp-21 {
    line-height: 2.1 !important; }
  .u-lh-sp-22 {
    line-height: 2.2 !important; }
  .u-lh-sp-23 {
    line-height: 2.3 !important; }
  .u-lh-sp-24 {
    line-height: 2.4 !important; }
  .u-lh-sp-25 {
    line-height: 2.5 !important; }
  .u-lh-sp-26 {
    line-height: 2.6 !important; }
  .u-lh-sp-27 {
    line-height: 2.7 !important; }
  .u-lh-sp-28 {
    line-height: 2.8 !important; }
  .u-lh-sp-29 {
    line-height: 2.9 !important; }
  .u-lh-sp-30 {
    line-height: 3 !important; }
  .u-lh-sp-31 {
    line-height: 3.1 !important; }
  .u-lh-sp-32 {
    line-height: 3.2 !important; }
  .u-lh-sp-33 {
    line-height: 3.3 !important; }
  .u-lh-sp-34 {
    line-height: 3.4 !important; }
  .u-lh-sp-35 {
    line-height: 3.5 !important; }
  .u-lh-sp-36 {
    line-height: 3.6 !important; }
  .u-lh-sp-37 {
    line-height: 3.7 !important; }
  .u-lh-sp-38 {
    line-height: 3.8 !important; }
  .u-lh-sp-39 {
    line-height: 3.9 !important; }
  .u-lh-sp-40 {
    line-height: 4 !important; }
  .u-lh-sp-41 {
    line-height: 4.1 !important; }
  .u-lh-sp-42 {
    line-height: 4.2 !important; }
  .u-lh-sp-43 {
    line-height: 4.3 !important; }
  .u-lh-sp-44 {
    line-height: 4.4 !important; }
  .u-lh-sp-45 {
    line-height: 4.5 !important; }
  .u-lh-sp-46 {
    line-height: 4.6 !important; }
  .u-lh-sp-47 {
    line-height: 4.7 !important; }
  .u-lh-sp-48 {
    line-height: 4.8 !important; }
  .u-lh-sp-49 {
    line-height: 4.9 !important; }
  .u-m-sp-c {
    margin-right: auto !important;
    margin-left: auto !important; }
  .u-m-sp-r {
    margin-right: auto !important;
    margin-left: 0 !important; }
  /* Top margin */
  .u-mt-sp-0 {
    margin-top: 0rem !important; }
  .u-mt-sp-1 {
    margin-top: 1rem !important; }
  .u-mt-sp-2 {
    margin-top: 2rem !important; }
  .u-mt-sp-3 {
    margin-top: 3rem !important; }
  .u-mt-sp-4 {
    margin-top: 4rem !important; }
  .u-mt-sp-5 {
    margin-top: 5rem !important; }
  .u-mt-sp-6 {
    margin-top: 6rem !important; }
  .u-mt-sp-7 {
    margin-top: 7rem !important; }
  .u-mt-sp-8 {
    margin-top: 8rem !important; }
  .u-mt-sp-9 {
    margin-top: 9rem !important; }
  .u-mt-sp-10 {
    margin-top: 10rem !important; }
  .u-mt-sp-11 {
    margin-top: 11rem !important; }
  .u-mt-sp-12 {
    margin-top: 12rem !important; }
  .u-mt-sp-13 {
    margin-top: 13rem !important; }
  .u-mt-sp-14 {
    margin-top: 14rem !important; }
  .u-mt-sp-15 {
    margin-top: 15rem !important; }
  .u-mt-sp-16 {
    margin-top: 16rem !important; }
  .u-mt-sp-17 {
    margin-top: 17rem !important; }
  .u-mt-sp-18 {
    margin-top: 18rem !important; }
  .u-mt-sp-19 {
    margin-top: 19rem !important; }
  .u-mt-sp-20 {
    margin-top: 20rem !important; }
  .u-mt-sp-21 {
    margin-top: 21rem !important; }
  .u-mt-sp-22 {
    margin-top: 22rem !important; }
  .u-mt-sp-23 {
    margin-top: 23rem !important; }
  .u-mt-sp-24 {
    margin-top: 24rem !important; }
  .u-mt-sp-25 {
    margin-top: 25rem !important; }
  /* Right margin */
  .u-mr-sp-0 {
    margin-right: 0rem !important; }
  .u-mr-sp-1 {
    margin-right: 1rem !important; }
  .u-mr-sp-2 {
    margin-right: 2rem !important; }
  .u-mr-sp-3 {
    margin-right: 3rem !important; }
  .u-mr-sp-4 {
    margin-right: 4rem !important; }
  .u-mr-sp-5 {
    margin-right: 5rem !important; }
  .u-mr-sp-6 {
    margin-right: 6rem !important; }
  .u-mr-sp-7 {
    margin-right: 7rem !important; }
  .u-mr-sp-8 {
    margin-right: 8rem !important; }
  .u-mr-sp-9 {
    margin-right: 9rem !important; }
  .u-mr-sp-10 {
    margin-right: 10rem !important; }
  .u-mr-sp-11 {
    margin-right: 11rem !important; }
  .u-mr-sp-12 {
    margin-right: 12rem !important; }
  .u-mr-sp-13 {
    margin-right: 13rem !important; }
  .u-mr-sp-14 {
    margin-right: 14rem !important; }
  .u-mr-sp-15 {
    margin-right: 15rem !important; }
  .u-mr-sp-16 {
    margin-right: 16rem !important; }
  .u-mr-sp-17 {
    margin-right: 17rem !important; }
  .u-mr-sp-18 {
    margin-right: 18rem !important; }
  .u-mr-sp-19 {
    margin-right: 19rem !important; }
  .u-mr-sp-20 {
    margin-right: 20rem !important; }
  .u-mr-sp-21 {
    margin-right: 21rem !important; }
  .u-mr-sp-22 {
    margin-right: 22rem !important; }
  .u-mr-sp-23 {
    margin-right: 23rem !important; }
  .u-mr-sp-24 {
    margin-right: 24rem !important; }
  .u-mr-sp-25 {
    margin-right: 25rem !important; }
  /* Bottom margin */
  .u-mb-sp-0 {
    margin-bottom: 0rem !important; }
  .u-mb-sp-1 {
    margin-bottom: 1rem !important; }
  .u-mb-sp-2 {
    margin-bottom: 2rem !important; }
  .u-mb-sp-3 {
    margin-bottom: 3rem !important; }
  .u-mb-sp-4 {
    margin-bottom: 4rem !important; }
  .u-mb-sp-5 {
    margin-bottom: 5rem !important; }
  .u-mb-sp-6 {
    margin-bottom: 6rem !important; }
  .u-mb-sp-7 {
    margin-bottom: 7rem !important; }
  .u-mb-sp-8 {
    margin-bottom: 8rem !important; }
  .u-mb-sp-9 {
    margin-bottom: 9rem !important; }
  .u-mb-sp-10 {
    margin-bottom: 10rem !important; }
  .u-mb-sp-11 {
    margin-bottom: 11rem !important; }
  .u-mb-sp-12 {
    margin-bottom: 12rem !important; }
  .u-mb-sp-13 {
    margin-bottom: 13rem !important; }
  .u-mb-sp-14 {
    margin-bottom: 14rem !important; }
  .u-mb-sp-15 {
    margin-bottom: 15rem !important; }
  .u-mb-sp-16 {
    margin-bottom: 16rem !important; }
  .u-mb-sp-17 {
    margin-bottom: 17rem !important; }
  .u-mb-sp-18 {
    margin-bottom: 18rem !important; }
  .u-mb-sp-19 {
    margin-bottom: 19rem !important; }
  .u-mb-sp-20 {
    margin-bottom: 20rem !important; }
  .u-mb-sp-21 {
    margin-bottom: 21rem !important; }
  .u-mb-sp-22 {
    margin-bottom: 22rem !important; }
  .u-mb-sp-23 {
    margin-bottom: 23rem !important; }
  .u-mb-sp-24 {
    margin-bottom: 24rem !important; }
  .u-mb-sp-25 {
    margin-bottom: 25rem !important; }
  /* Left margin */
  .u-ml-sp-0 {
    margin-left: 0rem !important; }
  .u-ml-sp-1 {
    margin-left: 1rem !important; }
  .u-ml-sp-2 {
    margin-left: 2rem !important; }
  .u-ml-sp-3 {
    margin-left: 3rem !important; }
  .u-ml-sp-4 {
    margin-left: 4rem !important; }
  .u-ml-sp-5 {
    margin-left: 5rem !important; }
  .u-ml-sp-6 {
    margin-left: 6rem !important; }
  .u-ml-sp-7 {
    margin-left: 7rem !important; }
  .u-ml-sp-8 {
    margin-left: 8rem !important; }
  .u-ml-sp-9 {
    margin-left: 9rem !important; }
  .u-ml-sp-10 {
    margin-left: 10rem !important; }
  .u-ml-sp-11 {
    margin-left: 11rem !important; }
  .u-ml-sp-12 {
    margin-left: 12rem !important; }
  .u-ml-sp-13 {
    margin-left: 13rem !important; }
  .u-ml-sp-14 {
    margin-left: 14rem !important; }
  .u-ml-sp-15 {
    margin-left: 15rem !important; }
  .u-ml-sp-16 {
    margin-left: 16rem !important; }
  .u-ml-sp-17 {
    margin-left: 17rem !important; }
  .u-ml-sp-18 {
    margin-left: 18rem !important; }
  .u-ml-sp-19 {
    margin-left: 19rem !important; }
  .u-ml-sp-20 {
    margin-left: 20rem !important; }
  .u-ml-sp-21 {
    margin-left: 21rem !important; }
  .u-ml-sp-22 {
    margin-left: 22rem !important; }
  .u-ml-sp-23 {
    margin-left: 23rem !important; }
  .u-ml-sp-24 {
    margin-left: 24rem !important; }
  .u-ml-sp-25 {
    margin-left: 25rem !important; }
  /* Top padding */
  .u-pt-sp-0 {
    padding-top: 0rem !important; }
  .u-pt-sp-1 {
    padding-top: 1rem !important; }
  .u-pt-sp-2 {
    padding-top: 2rem !important; }
  .u-pt-sp-3 {
    padding-top: 3rem !important; }
  .u-pt-sp-4 {
    padding-top: 4rem !important; }
  .u-pt-sp-5 {
    padding-top: 5rem !important; }
  .u-pt-sp-6 {
    padding-top: 6rem !important; }
  .u-pt-sp-7 {
    padding-top: 7rem !important; }
  .u-pt-sp-8 {
    padding-top: 8rem !important; }
  .u-pt-sp-9 {
    padding-top: 9rem !important; }
  .u-pt-sp-10 {
    padding-top: 10rem !important; }
  .u-pt-sp-11 {
    padding-top: 11rem !important; }
  .u-pt-sp-12 {
    padding-top: 12rem !important; }
  .u-pt-sp-13 {
    padding-top: 13rem !important; }
  .u-pt-sp-14 {
    padding-top: 14rem !important; }
  .u-pt-sp-15 {
    padding-top: 15rem !important; }
  .u-pt-sp-16 {
    padding-top: 16rem !important; }
  .u-pt-sp-17 {
    padding-top: 17rem !important; }
  .u-pt-sp-18 {
    padding-top: 18rem !important; }
  .u-pt-sp-19 {
    padding-top: 19rem !important; }
  .u-pt-sp-20 {
    padding-top: 20rem !important; }
  .u-pt-sp-21 {
    padding-top: 21rem !important; }
  .u-pt-sp-22 {
    padding-top: 22rem !important; }
  .u-pt-sp-23 {
    padding-top: 23rem !important; }
  .u-pt-sp-24 {
    padding-top: 24rem !important; }
  .u-pt-sp-25 {
    padding-top: 25rem !important; }
  /* Right padding */
  .u-pr-sp-0 {
    padding-right: 0rem !important; }
  .u-pr-sp-1 {
    padding-right: 1rem !important; }
  .u-pr-sp-2 {
    padding-right: 2rem !important; }
  .u-pr-sp-3 {
    padding-right: 3rem !important; }
  .u-pr-sp-4 {
    padding-right: 4rem !important; }
  .u-pr-sp-5 {
    padding-right: 5rem !important; }
  .u-pr-sp-6 {
    padding-right: 6rem !important; }
  .u-pr-sp-7 {
    padding-right: 7rem !important; }
  .u-pr-sp-8 {
    padding-right: 8rem !important; }
  .u-pr-sp-9 {
    padding-right: 9rem !important; }
  .u-pr-sp-10 {
    padding-right: 10rem !important; }
  .u-pr-sp-11 {
    padding-right: 11rem !important; }
  .u-pr-sp-12 {
    padding-right: 12rem !important; }
  .u-pr-sp-13 {
    padding-right: 13rem !important; }
  .u-pr-sp-14 {
    padding-right: 14rem !important; }
  .u-pr-sp-15 {
    padding-right: 15rem !important; }
  .u-pr-sp-16 {
    padding-right: 16rem !important; }
  .u-pr-sp-17 {
    padding-right: 17rem !important; }
  .u-pr-sp-18 {
    padding-right: 18rem !important; }
  .u-pr-sp-19 {
    padding-right: 19rem !important; }
  .u-pr-sp-20 {
    padding-right: 20rem !important; }
  .u-pr-sp-21 {
    padding-right: 21rem !important; }
  .u-pr-sp-22 {
    padding-right: 22rem !important; }
  .u-pr-sp-23 {
    padding-right: 23rem !important; }
  .u-pr-sp-24 {
    padding-right: 24rem !important; }
  .u-pr-sp-25 {
    padding-right: 25rem !important; }
  /* Bottom padding */
  .u-pb-sp-0 {
    padding-bottom: 0rem !important; }
  .u-pb-sp-1 {
    padding-bottom: 1rem !important; }
  .u-pb-sp-2 {
    padding-bottom: 2rem !important; }
  .u-pb-sp-3 {
    padding-bottom: 3rem !important; }
  .u-pb-sp-4 {
    padding-bottom: 4rem !important; }
  .u-pb-sp-5 {
    padding-bottom: 5rem !important; }
  .u-pb-sp-6 {
    padding-bottom: 6rem !important; }
  .u-pb-sp-7 {
    padding-bottom: 7rem !important; }
  .u-pb-sp-8 {
    padding-bottom: 8rem !important; }
  .u-pb-sp-9 {
    padding-bottom: 9rem !important; }
  .u-pb-sp-10 {
    padding-bottom: 10rem !important; }
  .u-pb-sp-11 {
    padding-bottom: 11rem !important; }
  .u-pb-sp-12 {
    padding-bottom: 12rem !important; }
  .u-pb-sp-13 {
    padding-bottom: 13rem !important; }
  .u-pb-sp-14 {
    padding-bottom: 14rem !important; }
  .u-pb-sp-15 {
    padding-bottom: 15rem !important; }
  .u-pb-sp-16 {
    padding-bottom: 16rem !important; }
  .u-pb-sp-17 {
    padding-bottom: 17rem !important; }
  .u-pb-sp-18 {
    padding-bottom: 18rem !important; }
  .u-pb-sp-19 {
    padding-bottom: 19rem !important; }
  .u-pb-sp-20 {
    padding-bottom: 20rem !important; }
  .u-pb-sp-21 {
    padding-bottom: 21rem !important; }
  .u-pb-sp-22 {
    padding-bottom: 22rem !important; }
  .u-pb-sp-23 {
    padding-bottom: 23rem !important; }
  .u-pb-sp-24 {
    padding-bottom: 24rem !important; }
  .u-pb-sp-25 {
    padding-bottom: 25rem !important; }
  /* Left padding */
  .u-pl-sp-0 {
    padding-left: 0rem !important; }
  .u-pl-sp-1 {
    padding-left: 1rem !important; }
  .u-pl-sp-2 {
    padding-left: 2rem !important; }
  .u-pl-sp-3 {
    padding-left: 3rem !important; }
  .u-pl-sp-4 {
    padding-left: 4rem !important; }
  .u-pl-sp-5 {
    padding-left: 5rem !important; }
  .u-pl-sp-6 {
    padding-left: 6rem !important; }
  .u-pl-sp-7 {
    padding-left: 7rem !important; }
  .u-pl-sp-8 {
    padding-left: 8rem !important; }
  .u-pl-sp-9 {
    padding-left: 9rem !important; }
  .u-pl-sp-10 {
    padding-left: 10rem !important; }
  .u-pl-sp-11 {
    padding-left: 11rem !important; }
  .u-pl-sp-12 {
    padding-left: 12rem !important; }
  .u-pl-sp-13 {
    padding-left: 13rem !important; }
  .u-pl-sp-14 {
    padding-left: 14rem !important; }
  .u-pl-sp-15 {
    padding-left: 15rem !important; }
  .u-pl-sp-16 {
    padding-left: 16rem !important; }
  .u-pl-sp-17 {
    padding-left: 17rem !important; }
  .u-pl-sp-18 {
    padding-left: 18rem !important; }
  .u-pl-sp-19 {
    padding-left: 19rem !important; }
  .u-pl-sp-20 {
    padding-left: 20rem !important; }
  .u-pl-sp-21 {
    padding-left: 21rem !important; }
  .u-pl-sp-22 {
    padding-left: 22rem !important; }
  .u-pl-sp-23 {
    padding-left: 23rem !important; }
  .u-pl-sp-24 {
    padding-left: 24rem !important; }
  .u-pl-sp-25 {
    padding-left: 25rem !important; }
  .u-ta-l-sp {
    text-align: left !important; }
  .u-ta-c-sp {
    text-align: center !important; }
  .u-ta-r-sp {
    text-align: right !important; }
  .u-1col-sp {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap; }
  .u-2col-sp {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2; }
    .p-contest {
      margin-top: 0; }
      .p-contest .s-mv {
        height: 78rem; }
        .p-contest .s-mv__logo {
          top: auto;
          bottom: 6rem;
          z-index: 5;
          width: 29.5rem;
          -webkit-transform: translate(-50%, 0);
                  transform: translate(-50%, 0); }
        .p-contest .s-mv__content {
          margin-top: 1rem; }
        .p-contest .s-mv__end-text {
          margin-bottom: 2rem;
          font-size: 2.4rem; }
        .p-contest .s-mv__vote {
          width: 100%;
          margin-bottom: 1rem;
          margin-left: 0;
          line-height: 1.5; }
          .p-contest .s-mv .mv-img.mv-img01 {
            top: 0;
            left: 0.3rem;
            width: 17rem; }
          .p-contest .s-mv .mv-img.mv-img02 {
            top: 5.1rem;
            left: 50%;
            width: 20rem;
            -webkit-transform: translateX(-50%);
                    transform: translateX(-50%); }
          .p-contest .s-mv .mv-img.mv-img03 {
            top: 18rem;
            bottom: initial;
            left: 50%;
            width: 15rem;
            -webkit-transform: translateX(-50%) rotate(15deg) translateX(-2rem);
                    transform: translateX(-50%) rotate(15deg) translateX(-2rem); }
          .p-contest .s-mv .mv-img.mv-img04 {
            bottom: 9rem;
            left: -3rem;
            width: 14.2rem;
            -webkit-transform: rotate(36deg);
                    transform: rotate(36deg); }
          .p-contest .s-mv .mv-img.mv-img05 {
            top: -10rem;
            right: -1rem;
            left: initial;
            width: 17.8rem;
            -webkit-transform: initial;
                    transform: initial; }
          .p-contest .s-mv .mv-img.mv-img08 {
            top: 50%;
            right: -4rem;
            bottom: initial;
            width: 17.5rem;
            -webkit-transform: translateY(-50%) translateY(-3rem) translateX(-2rem) rotate(-10deg);
                    transform: translateY(-50%) translateY(-3rem) translateX(-2rem) rotate(-10deg); }
          .p-contest .s-mv .mv-img.corner-img01, .p-contest .s-mv .mv-img.corner-img02, .p-contest .s-mv .mv-img.corner-img03, .p-contest .s-mv .mv-img.corner-img04 {
            width: 2rem; }
          .p-contest .s-mv .mv-img.corner-img01 {
            top: 2rem;
            left: 2rem; }
          .p-contest .s-mv .mv-img.corner-img02 {
            top: 2rem;
            right: 2rem; }
          .p-contest .s-mv .mv-img.corner-img03 {
            right: 2rem;
            bottom: 2rem; }
          .p-contest .s-mv .mv-img.corner-img04 {
            bottom: 2rem;
            left: 2rem; }
          .p-contest .s-mv .mv-img.side-img01 {
            left: 2rem;
            width: 2rem; }
          .p-contest .s-mv .mv-img.side-img02 {
            right: 2rem;
            width: 2rem; }
      .p-contest .s-desc-inner {
        padding: 3rem;
        margin-top: 2rem; }
        .p-contest .s-desc-inner p {
          text-align: left; }
        .p-contest .s-desc-inner dl {
          row-gap: 2rem; }
      .p-contest .s-desc:first-of-type {
        margin-top: 5rem; }
      .p-contest .s-desc:last-of-type {
        margin-top: 5rem; }
      .p-contest .s-list {
        -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
        row-gap: 5rem;
        padding-bottom: 9rem;
        margin-top: 5rem; }
        .p-contest .s-list > div {
          padding: 3rem; }
        .p-contest .s-list-ttl {
          margin-top: 2rem;
          font-size: 2.6rem; }
        .p-contest .s-list-btn {
          margin-top: 2rem; }
    .p-overview {
      margin-top: 0; }
      .p-overview .s-mv {
        height: 65rem; }
        .p-overview .s-mv__logo {
          z-index: 5;
          width: 29.5rem;
          -webkit-transform: translate(-50%, -50%) translateY(20rem);
                  transform: translate(-50%, -50%) translateY(20rem); }
        .p-overview .s-mv__content {
          margin-top: 1rem; }
          .p-overview .s-mv .mv-img.mv-img01 {
            top: 0;
            left: 0.3rem;
            width: 17rem; }
          .p-overview .s-mv .mv-img.mv-img02 {
            top: 5.1rem;
            left: 50%;
            width: 20rem;
            -webkit-transform: translateX(-50%);
                    transform: translateX(-50%); }
          .p-overview .s-mv .mv-img.mv-img03 {
            top: 18rem;
            bottom: initial;
            left: 50%;
            width: 15rem;
            -webkit-transform: translateX(-50%) rotate(15deg) translateX(-2rem);
                    transform: translateX(-50%) rotate(15deg) translateX(-2rem); }
          .p-overview .s-mv .mv-img.mv-img04 {
            bottom: 9rem;
            left: -3rem;
            width: 14.2rem;
            -webkit-transform: rotate(36deg);
                    transform: rotate(36deg); }
          .p-overview .s-mv .mv-img.mv-img05 {
            top: -10rem;
            right: -1rem;
            left: initial;
            width: 17.8rem;
            -webkit-transform: initial;
                    transform: initial; }
          .p-overview .s-mv .mv-img.mv-img08 {
            top: 50%;
            right: -4rem;
            bottom: initial;
            width: 17.5rem;
            -webkit-transform: translateY(-50%) translateY(-3rem) translateX(-2rem) rotate(-10deg);
                    transform: translateY(-50%) translateY(-3rem) translateX(-2rem) rotate(-10deg); }
          .p-overview .s-mv .mv-img.corner-img01, .p-overview .s-mv .mv-img.corner-img02, .p-overview .s-mv .mv-img.corner-img03, .p-overview .s-mv .mv-img.corner-img04 {
            width: 2rem; }
          .p-overview .s-mv .mv-img.corner-img01 {
            top: 2rem;
            left: 2rem; }
          .p-overview .s-mv .mv-img.corner-img02 {
            top: 2rem;
            right: 2rem; }
          .p-overview .s-mv .mv-img.corner-img03 {
            right: 2rem;
            bottom: 2rem; }
          .p-overview .s-mv .mv-img.corner-img04 {
            bottom: 2rem;
            left: 2rem; }
          .p-overview .s-mv .mv-img.side-img01 {
            left: 2rem;
            width: 2rem; }
          .p-overview .s-mv .mv-img.side-img02 {
            right: 2rem;
            width: 2rem; }
      .p-overview .s-theme {
        padding-bottom: 4rem;
        margin-top: 10rem; }
        .p-overview .s-theme__inner {
          width: 100%;
          padding: 0 2rem; }
          .p-overview .s-theme__ttl span {
            width: 3rem;
            height: 3rem; }
            .p-overview .s-theme__ttl span::before {
              width: 1rem;
              height: 1rem; }
        .p-overview .s-theme__list {
          -ms-grid-columns: (1fr)[1];
          grid-template-columns: repeat(1, 1fr);
          gap: 2rem 0;
          margin-top: 3rem; }
        .p-overview .s-theme__item {
          padding: 3.5rem 3rem 3rem; }
      .p-overview .s-overview {
        padding-top: 15rem;
        padding-bottom: 3rem; }
        .p-overview .s-overview__img {
          position: absolute;
          top: -8rem;
          left: -10rem;
          z-index: 1;
          width: 19.6rem;
          height: 22rem; }
            .p-overview .s-overview__img img:nth-of-type(1) {
              top: -6rem;
              left: 11rem;
              width: 19.6rem;
              height: 22rem;
              -webkit-transform: rotate(-10deg);
                      transform: rotate(-10deg); }
            .p-overview .s-overview__img img:nth-of-type(2) {
              display: none; }
        .p-overview .s-overview__ttl {
          z-index: 2;
          width: 31rem;
          background: url(./../images/top/harf-circle-sp.png) no-repeat center center/contain; }
          .p-overview .s-overview__ttl-wrap {
            margin-top: 3rem; }
        .p-overview .s-overview__containerTop {
          padding: 0 1rem 4rem 3rem; }
          .p-overview .s-overview__containerTop-flex {
            -webkit-box-orient: vertical;
            -webkit-box-direction: normal;
                -ms-flex-direction: column;
                    flex-direction: column;
            padding-top: 3rem; }
          .p-overview .s-overview__containerTop .s-overview__right {
            width: 100%;
            margin-top: 1.8rem;
            margin-left: 0; }
            .p-overview .s-overview__containerTop .s-overview__right-item {
              -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: start; }
                  .p-overview .s-overview__containerTop .s-overview__right-item-wrap.wrap-left::before {
                    display: none; }
                  .p-overview .s-overview__containerTop .s-overview__right-item-wrap.wrap-left p {
                    font-size: 2.6rem; }
                    .p-overview .s-overview__containerTop .s-overview__right-item-wrap.wrap-left p.sp-font {
                      font-size: 2rem; }
                    .p-overview .s-overview__containerTop .s-overview__right-item-wrap.wrap-left p span {
                      font-size: 1.4rem; }
              .p-overview .s-overview__containerTop .s-overview__right-item-wrap.wrap-right {
                margin-top: 0.3rem;
                margin-left: 3.5rem; }
                .p-overview .s-overview__containerTop .s-overview__right-item-wrap.wrap-right span {
                  padding: 0.2rem 1rem; }
        .p-overview .s-overview__containerBottom {
          padding: 3rem; }
          .p-overview .s-overview__containerBottom-flex {
            -webkit-box-orient: vertical;
            -webkit-box-direction: normal;
                -ms-flex-direction: column;
                    flex-direction: column;
            padding-top: 0; }
            .p-overview .s-overview__containerBottom-flex:nth-of-type(n + 2) {
              padding-top: 2rem; }
          .p-overview .s-overview__containerBottom .s-overview__right {
            width: 100%;
            margin-top: 1.3rem;
            margin-left: 0; }
            .p-overview .s-overview__containerBottom .s-overview__right-item {
              -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: start; }
              .p-overview .s-overview__containerBottom .s-overview__right-item-wrap {
                -webkit-box-align: start;
                    -ms-flex-align: start;
                        align-items: start; }
                .p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left.column01 {
                  -webkit-box-orient: vertical;
                  -webkit-box-direction: normal;
                      -ms-flex-direction: column;
                          flex-direction: column; }
                  .p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left.column01 small {
                    margin-top: 0.5rem;
                    margin-bottom: 1rem;
                    font-size: 1.5rem;
                    font-weight: 500;
                    letter-spacing: 0.05em;
                    line-height: 1.6; }
                    .p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left.column02 small {
                      margin-left: 0; }
                  .p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left img {
                    margin-top: 0.5rem !important; }
                  .p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left p {
                    margin-left: 0.5rem;
                    font-size: 1.5rem; }
                  .p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left small {
                    font-size: 1.3rem !important; }
                    .p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left small span {
                      font-size: 1.5rem; }
      .p-overview .s-method {
        padding-top: 3rem; }
          .p-overview .s-method__ttl span {
            width: 3rem;
            height: 3rem; }
        .p-overview .s-method__container {
          position: relative;
          z-index: 2;
          padding: 3rem;
          margin-top: 3rem; }
        .p-overview .s-method__list {
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
              -ms-flex-direction: column;
                  flex-direction: column;
          width: 100%; }
          .p-overview .s-method__list::before {
            top: 25rem;
            left: -16.2rem;
            width: 35rem;
            -webkit-transform: rotate(90deg);
                    transform: rotate(90deg); }
        .p-overview .s-method__item {
          width: 100%; }
        .p-overview .s-method__item:nth-of-type(n + 2) {
          margin-top: 2.4rem; }
          .p-overview .s-method__item-top p {
            margin-left: 3.4rem;
            text-align: left; }
        .p-overview .s-method__item-wrap {
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-align: center;
              -ms-flex-align: center;
                  align-items: center;
          margin-top: 0.5rem; }
          .p-overview .s-method__item-dot {
            margin: 0; }
          .p-overview .s-method__item-ttl {
            margin-top: 0;
            margin-left: 1.4rem; }
          .p-overview .s-method__item-txt {
            margin-left: 3.4rem; }
            .p-overview .s-method__item-txt p {
              line-height: 1.6;
              text-align: left; }
      .p-overview .s-news {
        margin-top: 6rem; }
        .p-overview .s-news__ttl {
          text-align: center; }
          .p-overview .s-news__ttl span {
            width: 3rem;
            height: 3rem; }
        .p-overview .s-news__container {
          position: relative;
          z-index: 2;
          padding: 3rem 2rem 3rem 3rem;
          margin-top: 3rem; }
        .p-overview .s-news__item {
          width: 100%; }
            .p-overview .s-news__item-subTitle span {
              font-size: 1.5rem; }
            .p-overview .s-news__item-mainTitle h3 {
              font-size: 2.2rem; }
            .p-overview .s-news__item-text p {
              font-size: 1.5rem; }
          .p-overview .s-news__item-detail {
            width: 100%; }
              .p-overview .s-news__item-detail p span {
                margin-top: 1rem;
                font-size: 1.3rem;
                white-space: nowrap; }
          .p-overview .s-news__item-qr {
            position: static;
            margin-top: 2rem;
            margin-left: 2rem; }
      .p-overview .s-picture {
        margin-top: 4rem; }
        .p-overview .s-picture__wrap {
          height: 17rem; }
          .p-overview .s-picture__list img {
            width: 22.6rem;
            height: 15.4rem; }
        .p-overview .s-picture__list.infinity-scroll {
          position: absolute;
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-column-gap: 0;
             -moz-column-gap: 0;
                  column-gap: 0;
          -webkit-box-align: center;
              -ms-flex-align: center;
                  align-items: center;
          -webkit-animation-duration: 15s;
                  animation-duration: 15s;
          -webkit-animation-timing-function: linear;
                  animation-timing-function: linear;
          -webkit-animation-iteration-count: infinite;
                  animation-iteration-count: infinite; }
          .p-overview .s-picture__list.infinity-scroll:nth-of-type(1) {
            -webkit-animation-name: top-scroll;
                    animation-name: top-scroll; }
          .p-overview .s-picture__list.infinity-scroll:nth-of-type(2) {
            -webkit-animation-name: bottom-scroll;
                    animation-name: bottom-scroll; }
        @-webkit-keyframes top-scroll {
          from {
            -webkit-transform: translateX(0);
                    transform: translateX(0); }
          to {
            -webkit-transform: translateX(-130%);
                    transform: translateX(-130%); } }
        @keyframes top-scroll {
          from {
            -webkit-transform: translateX(0);
                    transform: translateX(0); }
          to {
            -webkit-transform: translateX(-130%);
                    transform: translateX(-130%); } }
        @-webkit-keyframes bottom-scroll {
          from {
            -webkit-transform: translateX(130%);
                    transform: translateX(130%); }
          to {
            -webkit-transform: translateX(0);
                    transform: translateX(0); } }
        @keyframes bottom-scroll {
          from {
            -webkit-transform: translateX(130%);
                    transform: translateX(130%); }
          to {
            -webkit-transform: translateX(0);
                    transform: translateX(0); } }
      .p-award-top2 {
        gap: 5rem;
        padding: 0 2rem;
        margin-top: 4rem; }
        .p-award-top2-item {
          position: relative;
          padding: 2.5rem 2rem; }
          .p-award-top2-item:nth-of-type(2) .p-award-top2-item__ttl::before {
            width: 3rem;
            height: 3.9rem; }
          .p-award-top2-item__ttl {
            -webkit-box-pack: center;
                -ms-flex-pack: center;
                    justify-content: center;
            margin-bottom: 2rem;
            font-size: 2.6rem; }
            .p-award-top2-item__ttl::before {
              width: 3rem;
              height: 3.9rem; }
          .p-award-top2-item__inner {
            -webkit-box-orient: vertical;
            -webkit-box-direction: normal;
                -ms-flex-direction: column;
                    flex-direction: column;
            gap: 2rem;
            margin-bottom: 1rem; }
          .p-award-top2-item__figure {
            width: 100%;
            height: 21.3rem;
            border-radius: 2rem; }
          .p-award-top2-item__desc-wrap {
            position: relative;
            z-index: 1;
            width: 100%; }
          .p-award-top2-item__cat {
            position: absolute;
            top: -23.3rem;
            left: 0; }
        .p-award-top2-item .c-remark-list__dl {
          margin-bottom: 1rem; }
          .p-award-top2-item__overall-wrap {
            padding: 2.5rem;
            padding-bottom: 2rem; }
          .p-award-top2-item__overall-ttl {
            margin-bottom: 1.5rem;
            font-size: 1.8rem; }
      .p-award-top3t5 {
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
        padding: 0 2rem;
        margin-top: 5rem;
        margin-right: 2rem;
        margin-left: 2rem; }
            .p-award-top3t5-ttl h3::before {
              width: 17%; }
            .p-award-top3t5-ttl h3::after {
              width: 17%; }
        .p-award-top3t5-list {
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
              -ms-flex-direction: column;
                  flex-direction: column;
          -ms-grid-columns: (1fr)[1];
          grid-template-columns: repeat(1, 1fr);
          margin-top: 2rem; }
        .p-award-top3t5-item {
          width: 100%;
          padding: 2.3rem 0 3rem; }
          .p-award-top3t5-item:first-of-type {
            border-right: initial;
            border-bottom: 4px dotted #d1d1d1; }
          .p-award-top3t5-item:last-of-type {
            border-top: 4px dotted #d1d1d1;
            border-left: initial; }
          .p-award-top3t5-item__figure-wrap {
            height: 21.3rem; }
          .p-award-top3t5-item__overall-wrap {
            padding-top: 2.5rem; }
      .p-award-top6t9 {
        width: 100%;
        padding: 0 2rem;
        margin: 6rem auto 0;
        background-color: transparent; }
        .p-award-top6t9__list {
          gap: 5rem; }
        .p-award-top6t9-item {
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
              -ms-flex-direction: column;
                  flex-direction: column;
          width: 100%;
          padding: 3rem 2rem;
          background-color: white;
          border-radius: 2rem; }
            .p-award-top6t9-item:nth-of-type(2n - 1)::after {
              top: auto;
              bottom: -2.5rem;
              width: 100%;
              height: 4px;
              background-image: url(../images/common/border-dots-width.webp);
              background-repeat: repeat-x; }
          .p-award-top6t9-item:nth-of-type(2n)::after {
            position: absolute;
            bottom: -2.5rem;
            left: 0;
            display: block;
            width: 100%;
            height: 4px;
            content: "";
            background-image: url(../images/common/border-dots-width.webp);
            background-repeat: repeat-x;
            background-size: contain; }
            .p-award-top6t9-item:nth-of-type(n + 3)::before {
              display: none; }
          .p-award-top6t9-item:last-of-type::before {
            display: none; }
        .p-award-top6t9-item:last-of-type::after {
          display: none; }
        .p-award-top6t9-item__inner {
          width: 100%; }
          .p-award-top6t9-item__left {
            width: 100%; }
          .p-award-top6t9-item__right {
            width: 100%; }
          .p-award-top6t9-item__figure-wrap {
            height: 21.3rem; }
          .p-award-top6t9-item__overall-wrap {
            padding: 2.5rem;
            padding-bottom: 2rem;
            margin-top: 2rem; }
          .p-award-top6t9-item__overall-ttl {
            margin-bottom: 1.5rem;
            font-size: 1.8rem; }
      .p-award-top10t12 {
        -ms-grid-columns: (1fr)[1];
        grid-template-columns: repeat(1, 1fr);
        gap: 3rem 0;
        padding: 0 2rem;
        margin-top: 5rem; }
        .p-award-top10t12-item {
          width: 100%; }
          .p-award-top10t12-item__figure-wrap {
            height: 21.3rem; }
          .p-award-top10t12-item__overall-wrap {
            padding-top: 2.5rem; }
      .p-award-btn {
        width: 100%;
        padding: 0 5rem; }
    .p-company .s-intro {
      margin-top: 5rem; }
      .p-company .s-intro .c-speech-balloon {
        text-align: center; }
      .p-company .s-intro p {
        width: 100%;
        margin-top: 2rem;
        text-align: left; }
    .p-company .s-list {
      margin-top: 3rem; }
      .p-company .s-list ul {
        -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
        row-gap: 5rem; }
              .p-company .s-list ul li dl div dt {
                font-size: 1.6rem; }
              .p-company .s-list ul li dl div dd {
                font-size: 1.6rem; }
      .p-company .s-list-content {
        padding: 2.5rem; }
    .p-guide-list {
      -ms-grid-columns: 1fr;
      grid-template-columns: 1fr;
      row-gap: 3rem;
      margin-top: 3rem; }
      .p-guide-list > li {
        padding: 3rem; }
      .p-guide-list__text {
        font-size: 1.6rem; }
      .p-guide .s-check-list__ttl {
        margin-bottom: 2rem;
        font-size: 2.6rem;
        letter-spacing: 0; }
        .p-guide .s-check-list__ttl svg {
          width: 2.6rem; }
      .p-guide .s-check-list__text {
        width: 100%;
        font-size: 1.5rem; }
      .p-guide .s-check-list__link-wrap {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        gap: 1rem; }
  .p-guide-under .c-ttl-top-circle {
    line-height: 1.5; }
    .p-guide-under .s-intro {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: reverse;
          -ms-flex-direction: column-reverse;
              flex-direction: column-reverse;
      margin-top: 3rem; }
      .p-guide-under .s-intro-left {
        padding-top: 0;
        margin-top: 5rem;
        text-align: center; }
        .p-guide-under .s-intro-left .c-speech-balloon {
          text-align: center; }
        .p-guide-under .s-intro-left p {
          padding: 0 1.5rem;
          font-size: 1.5rem;
          font-weight: 500;
          text-align: left; }
          .p-guide-under .s-intro-left p span {
            font-size: 1.8rem; }
      .p-guide-under .s-intro-right {
        padding: 0 3rem;
        margin-right: 0; }
    .p-guide-under .s-desc {
      margin-top: 5rem; }
      .p-guide-under .s-desc-inner {
        padding: 3rem; }
      .p-guide-under .s-desc-ttl {
        width: -webkit-fit-content;
        width: -moz-fit-content;
        width: fit-content;
        margin: 0 auto;
        font-size: 2.6rem;
        line-height: 1.4;
        text-align: left; }
      .p-guide-under .s-desc-copy {
        margin-top: 2rem;
        font-size: 2rem;
        line-height: 1.5; }
      .p-guide-under .s-desc-text {
        padding: 0;
        margin-top: 2rem; }
      .p-guide-under .s-desc-flow {
        -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
        row-gap: 1rem;
        margin-top: 3rem; }
        .p-guide-under .s-desc-flow__ttl {
          height: 6rem;
          -webkit-writing-mode: horizontal-tb;
              -ms-writing-mode: lr-tb;
                  writing-mode: horizontal-tb; }
        .p-guide-under .s-desc-flow ul {
          -ms-grid-rows: (1fr)[4];
          grid-template-rows: repeat(4, 1fr);
          -ms-grid-columns: none;
          grid-template-columns: none;
          height: 67.5rem; }
            .p-guide-under .s-desc-flow ul > li div {
              text-align: center; }
              .p-guide-under .s-desc-flow ul > li div p {
                margin-top: 2rem; }
          .p-guide-under .s-desc-flow ul > li:not(:last-child)::before, .p-guide-under .s-desc-flow ul > li:not(:last-child)::after {
            position: absolute;
            bottom: 1rem;
            height: 0.5rem;
            content: "";
            background-color: #fff; }
          .p-guide-under .s-desc-flow ul > li:not(:last-child)::before {
            left: -0.75rem;
            width: calc(50% + 1rem);
            -webkit-transform: rotate(15deg);
                    transform: rotate(15deg); }
          .p-guide-under .s-desc-flow ul > li:not(:last-child)::after {
            right: -0.75rem;
            width: calc(50% + 1rem);
            -webkit-transform: rotate(-15deg);
                    transform: rotate(-15deg); }
      .p-guide-under .s-desc-list {
        padding: 4rem 2rem 3rem;
        margin: 0 auto;
        margin-top: 6rem; }
        .p-guide-under .s-desc-list > span {
          width: calc(100% + 3rem);
          padding: 1.5rem;
          font-size: 1.9rem;
          text-align: center;
          white-space: nowrap; }
        .p-guide-under .s-desc-list ul {
          -ms-grid-columns: 1fr;
          grid-template-columns: 1fr;
          -webkit-box-pack: start;
              -ms-flex-pack: start;
                  justify-content: flex-start; }
          .p-guide-under .s-desc-list ul li {
            font-size: 2rem;
            white-space: nowrap; }
            .p-guide-under .s-desc-list ul li::before {
              width: 1.5rem;
              height: 1.5rem; }
        .p-guide-under .s-desc-list dl {
          padding: 0; }
          .p-guide-under .s-desc-list dl > div {
            -ms-grid-columns: 1fr;
            grid-template-columns: 1fr; }
            .p-guide-under .s-desc-list dl > div dt {
              font-size: 1.8rem; }
              .p-guide-under .s-desc-list dl > div dt > div {
                -ms-grid-columns: 6rem 1fr;
                grid-template-columns: 6rem 1fr;
                -webkit-column-gap: 0.5rem;
                   -moz-column-gap: 0.5rem;
                        column-gap: 0.5rem; }
            .p-guide-under .s-desc-list dl > div dd {
              margin-top: 1rem; }
      .p-guide-under .s-desc-content {
        -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
        row-gap: 10rem;
        margin-top: 3rem; }
          .p-guide-under .s-desc-content > div:first-of-type::after {
            top: inherit;
            right: inherit;
            bottom: -7rem;
            left: 50%;
            -webkit-transform: translateX(-50%) rotate(90deg);
                    transform: translateX(-50%) rotate(90deg); }
    .p-guide-under .s-list {
      row-gap: 5rem;
      margin-top: 5rem; }
      .p-guide-under .s-list > li {
        -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
        row-gap: 3rem;
        padding: 3rem; }
      .p-guide-under .s-list-ttl {
        font-size: 2.6rem;
        text-align: center; }
      .p-guide-under .s-list-copy {
        font-size: 2rem;
        text-align: center; }
    .p-guide-under .s-type {
      padding: 3rem;
      margin-top: 5rem; }
      .p-guide-under .s-type-ttl {
        font-size: 2.6rem;
        text-align: center; }
      .p-guide-under .s-type-subttl {
        font-size: 2rem; }
        .p-guide-under .s-type-subttl::before {
          top: 0.6rem; }
      .p-guide-under .s-type dl {
        row-gap: 4rem;
        margin-top: 2rem; }
        .p-guide-under .s-type dl div {
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-orient: vertical;
          -webkit-box-direction: reverse;
              -ms-flex-direction: column-reverse;
                  flex-direction: column-reverse; }
        .p-guide-under .s-type dl div dt {
          margin-top: 1.5rem; }
          .p-guide-under .s-type dl div dt p {
            margin-top: 1rem; }
    .p-guide-under .s-plus {
      padding: 3rem;
      margin-top: 5rem; }
      .p-guide-under .s-plus-ttl {
        font-size: 2.6rem;
        text-align: center; }
      .p-guide-under .s-plus-wrap {
        -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
        row-gap: 3rem;
        margin-top: 2rem; }
        .p-guide-under .s-plus-wrap > div span {
          margin-top: 1.5rem; }
        .p-guide-under .s-plus-wrap > div p {
          margin-top: 1.5rem; }
    .p-guide-under .s-other {
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
      row-gap: 3rem;
      margin-top: 5rem; }
      .p-guide-under .s-other > figure {
        width: 15rem; }
      .p-guide-under .s-other > ul {
        -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
        row-gap: 3rem;
        padding: 0 3rem; }
    .p-movie .s-movie {
      padding: 0 2rem;
      margin-top: 5.5rem; }
      .p-movie .s-movie__inner {
        width: 100%;
        padding: 1.5rem;
        margin-top: 5rem; }
      .p-movie .s-movie__list {
        -ms-grid-columns: (1fr)[1];
        grid-template-columns: repeat(1, 1fr);
        gap: 3rem 0; }
      .p-movie .s-movie__ready {
        font-size: 2.6rem; }
      .p-movie .s-movie__item {
        width: 100%; }
        .p-movie .s-movie__item-picture {
          height: 19.5rem; }
        .p-movie .s-movie__item-movie {
          height: 19.5rem; }
          .p-movie .s-movie__item-movie iframe {
            height: 24rem; }
        .p-movie .s-movie__item-ttl {
          margin-top: 1.3rem; }
          .p-movie .s-movie__item-ttl h3 {
            font-size: 1.5rem; }
        .p-movie .s-movie__item-desc {
          font-size: 1.4rem; }
    .p-tomojika .s-profile {
      margin-top: 6rem; }
      .p-tomojika .s-profile-ttl {
        left: 50%;
        -webkit-transform: translateX(-50%);
                transform: translateX(-50%); }
      .p-tomojika .s-profile-wrap {
        -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
        padding: 2rem 3rem 3rem; }
        .p-tomojika .s-profile-wrap dl {
          row-gap: 2rem; }
          .p-tomojika .s-profile-wrap dl div {
            -ms-grid-columns: 1fr;
            grid-template-columns: 1fr; }
            .p-tomojika .s-profile-wrap dl div dd {
              margin-top: 1rem;
              line-height: 1.7; }
    .p-tomojika .s-about {
      margin-top: 5rem; }
      .p-tomojika .s-about-wrap {
        -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
        row-gap: 3rem;
        padding: 3rem; }
          .p-tomojika .s-about-wrap p span {
            display: inline; }
        .p-tomojika .s-about-wrap p {
          margin-top: 2rem; }
      .p-tomojika .s-about-ttl {
        font-size: 2.6rem;
        line-height: 1.4;
        text-align: center; }
    .p-tomojika .s-logo {
      padding: 3rem;
      margin-top: 5rem; }
      .p-tomojika .s-logo-ttl {
        font-size: 2.6rem;
        line-height: 1.4;
        text-align: center; }
      .p-tomojika .s-logo-subttl {
        font-size: 2rem; }
        .p-tomojika .s-logo-subttl::before {
          top: 0.6rem; }
        .p-tomojika .s-logo-subttl span {
          margin-top: 2rem;
          margin-left: -2.5rem;
          font-size: 1.8rem; }
      .p-tomojika .s-logo-wrap p {
        padding: 0;
        margin-top: 2rem; }
      .p-tomojika .s-logo-list {
        width: 100%;
        margin-top: 3rem; }
        .p-tomojika .s-logo-list > li {
          -ms-grid-columns: 1fr;
          grid-template-columns: 1fr;
          row-gap: 1rem; }
            .p-tomojika .s-logo-list > li > ul li {
              position: relative;
              padding-left: 1.4rem; }
              .p-tomojika .s-logo-list > li > ul li::before {
                position: absolute;
                top: 0.8rem;
                left: 0;
                width: 1rem;
                height: 1rem;
                content: "";
                background: #ffca3b;
                border-radius: 50%; }
          .p-tomojika .s-logo-list > li dl {
            row-gap: 1.5rem; }
            .p-tomojika .s-logo-list > li dl div {
              display: -webkit-inline-box;
              display: -ms-inline-flexbox;
              display: inline-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; }
              .p-tomojika .s-logo-list > li dl div dt {
                width: 10rem; }
              .p-tomojika .s-logo-list > li dl div dd {
                margin-top: 0.8rem; }
      .p-tomojika .s-logo-content {
        margin-top: 5rem; }
        .p-tomojika .s-logo-content .tomojika {
          -ms-grid-columns: (1fr)[2];
          grid-template-columns: repeat(2, 1fr);
          margin-top: 2rem; }
            .p-tomojika .s-logo-content .tomojika li figure {
              width: 14rem;
              height: 14rem; }
        .p-tomojika .s-logo-content .logomark {
          -ms-grid-columns: 1fr;
          grid-template-columns: 1fr;
          row-gap: 1rem; }
          .p-tomojika .s-logo-content .logomark li:first-child {
            width: 30rem; }
          .p-tomojika .s-logo-content .logomark li:nth-child(2) {
            width: 18.8rem; }
          .p-tomojika .s-logo-content .logomark li:last-child {
            width: 27rem; }
    .p-tomojika .s-gallery {
      padding: 3rem 1.5rem;
      margin-top: 5rem; }
      .p-tomojika .s-gallery-ttl {
        font-size: 2.6rem;
        line-height: 1.4;
        text-align: center; }
      .p-tomojika .s-gallery-inner {
        -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
        row-gap: 5rem;
        margin-top: 3rem; }
        .p-tomojika .s-gallery-inner .c-speech-balloon {
          width: -webkit-fit-content;
          width: -moz-fit-content;
          width: fit-content;
          margin: 0 auto; }
        .p-tomojika .s-gallery-inner > div {
          -webkit-box-align: center;
              -ms-flex-align: center;
                  align-items: center; }
          .p-tomojika .s-gallery-inner > div:nth-of-type(2) picture {
            padding: 0 1.5rem; }
          .p-tomojika .s-gallery-inner > div:nth-of-type(3) ul {
            -ms-grid-columns: 1fr;
            grid-template-columns: 1fr;
            row-gap: 3rem;
            padding: 0 1.5rem; }
          .p-tomojika .s-gallery-inner > div:last-of-type figure {
            width: 100%;
            padding: 0 1.5rem; }
      .p-tomojika .s-gallery-expression ul {
        padding: 0 1.5rem; }
          .p-tomojika .s-gallery-expression ul li span {
            height: 3rem;
            padding: 0 1.7rem; }
          .p-tomojika .s-gallery-expression ul li figure {
            width: 13.8rem; }
    .s-entry {
      margin-top: 4rem; }
      .s-entry__banner {
        margin-bottom: 3rem; }
      .s-entry__text {
        width: 100%;
        padding-left: 3rem;
        padding-right: 1rem;
        font-size: 1.5rem;
        line-height: 1.8;
        margin-bottom: 2rem; }
      .s-entry__date {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        gap: 1rem;
        text-align: center;
        line-height: 1.5; }
        .s-entry__date-ttl {
          width: 18.6rem;
          height: 3rem;
          color: #222222; }
      .s-entry__bottom-wrap {
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
            -ms-flex-direction: column-reverse;
                flex-direction: column-reverse; }
        .s-entry__bottom-wrap figure {
          width: 8.5rem;
          margin-right: 26rem;
          margin-top: -7rem; }
    .s-entry .c-btn01 {
      width: 26.5rem;
      height: 7.9rem; }
      .s-entry .c-btn01 span {
        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;
        padding: 0;
        gap: 1rem; }
        .s-entry .c-btn01 span::before {
          position: relative;
          left: auto;
          top: auto;
          -webkit-transform: translate(0, 0.1rem);
                  transform: translate(0, 0.1rem); }
    .p-top {
      margin-top: 0; }
      .p-top p {
        margin-bottom: 3rem; }
      .p-top .s-mv {
        height: 61rem; }
          .p-top .s-mv__swiper .swiper-slide {
            font-size: 8rem; }
          .p-top .s-mv__swiper--top {
            top: -3rem; }
          .p-top .s-mv__swiper--bottom {
            bottom: -2rem; }
        .p-top .s-mv__main-catch {
          position: relative;
          top: auto;
          right: auto;
          z-index: 1;
          padding-top: 14rem;
          margin-bottom: 1rem;
          font-size: 3.6rem;
          line-height: 1.3;
          text-align: center;
          letter-spacing: 0.4rem;
          -webkit-writing-mode: horizontal-tb;
              -ms-writing-mode: lr-tb;
                  writing-mode: horizontal-tb;
          -webkit-transform: none;
                  transform: none; }
        .p-top .s-mv__sub-catch {
          position: relative;
          top: auto;
          left: auto;
          font-size: 1.8rem;
          text-align: center;
          letter-spacing: 0.1rem;
          -webkit-writing-mode: horizontal-tb;
              -ms-writing-mode: lr-tb;
                  writing-mode: horizontal-tb;
          -webkit-transform: none;
                  transform: none; }
        .p-top .s-mv__inner {
          overflow: hidden; }
        .p-top .s-mv__mv-image {
          top: 27.3rem;
          left: calc(50vw - 18rem);
          width: 36rem; }
        .p-top .s-mv__mv-bg {
          left: calc(50vw - 24rem);
          width: 48rem; }
        .p-top .s-mv__mv-bottom {
          top: 43rem;
          left: calc(50vw - 24rem);
          width: 48rem; }
      .p-top .s-about {
        padding: 0 2.5rem 0 4.5rem;
        margin-top: 8rem; }
        .p-top .s-about__illust {
          top: -8.5rem;
          right: 0;
          width: 12.5rem; }
        .p-top .s-about > p {
          width: 100%;
          padding-right: 1rem;
          font-size: 1.7rem;
          line-height: 1.7; }
        .p-top .s-about__inner {
          width: 100vw;
          margin-top: 3rem;
          margin-left: -4.5rem; }
        .p-top .s-about__content {
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
              -ms-flex-direction: column;
                  flex-direction: column; }
          .p-top .s-about__content-left {
            width: 100%;
            -webkit-transform: translateX(3rem);
                    transform: translateX(3rem); }
            .p-top .s-about__content-left img {
              -webkit-transform: translate(2rem, 0);
                      transform: translate(2rem, 0); }
          .p-top .s-about__content-right {
            width: 100%; }
            .p-top .s-about__content-right-wrap {
              width: 33rem;
              height: 8.5rem;
              padding-left: 4.5rem;
              margin-left: -2rem; }
              .p-top .s-about__content-right-wrap::before {
                -webkit-transform: translateX(-50%) translateX(-2rem);
                        transform: translateX(-50%) translateX(-2rem); }
              .p-top .s-about__content-right-wrap p {
                font-size: 1.3rem; }
            .p-top .s-about__content-right img {
              margin-right: 5rem; }
        .p-top .s-article-list__slider {
          padding: 0 3rem; }
        .p-top .s-article-list__inner-wrap {
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
              -ms-flex-direction: column;
                  flex-direction: column;
          gap: 4.4rem; }
        .p-top .s-article-list__item {
          -webkit-box-sizing: border-box;
                  box-sizing: border-box;
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
              -ms-flex-direction: column;
                  flex-direction: column;
          gap: 2rem;
          height: auto; }
          .p-top .s-article-list__item:last-of-type {
            padding-right: 0; }
        .p-top .s-article-list__img-wrap {
          width: 100%;
          padding-left: 1.5rem; }
        .p-top .s-article-list__img {
          width: 26.7rem;
          height: 34.1rem; }
        .p-top .s-article-list__desc-wrap {
          width: 100%;
          padding-bottom: 1rem;
          padding-left: 2rem; }
        .p-top .s-article-list__item-ttl {
          font-size: 2rem; }
          .p-top .s-article-list__item-ttl::before {
            top: 1.3rem;
            width: 1rem;
            height: 1rem; }
        .p-top .s-article-list__text {
          font-size: 1.5rem; }
      .p-top .s-know {
        margin-top: 10rem; }
        .p-top .s-know__ttl {
          margin-bottom: 5rem; }
        .p-top .s-know__list {
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
              -ms-flex-direction: column;
                  flex-direction: column;
          padding: 0 3.5rem;
          margin-top: 2rem; }
        .p-top .s-know__item {
          width: 100%;
          padding: 3rem 0;
          font-size: 2rem; }
          .p-top .s-know__item-ttl {
            font-size: 2rem; }
          .p-top .s-know__item-desc {
            font-size: 1.5rem; }
          .p-top .s-know__item-quote {
            font-size: 1.4rem; }
          .p-top .s-know__item:first-of-type {
            padding-right: 0; }
            .p-top .s-know__item:first-of-type figure {
              display: inline-block;
              height: auto; }
            .p-top .s-know__item:first-of-type::after {
              top: auto;
              bottom: 0;
              width: 100%;
              height: 0.4rem;
              background-image: url(../images/common/border-dots-width.webp);
              background-repeat: repeat-x; }
          .p-top .s-know__item:nth-of-type(2) {
            padding-left: 0; }
            .p-top .s-know__item:nth-of-type(2) figure {
              height: auto; }
          .p-top .s-know__item:last-of-type {
            padding-top: 3rem;
            margin-top: 0; }
      .p-top .s-check-list {
        padding: 0 4rem; }
        .p-top .s-check-list__ttl {
          margin-bottom: 2rem;
          font-size: 2.6rem;
          letter-spacing: 0; }
          .p-top .s-check-list__ttl svg {
            width: 2.6rem; }
        .p-top .s-check-list__text {
          width: 100%;
          font-size: 1.5rem; }
        .p-top .s-check-list__link-wrap {
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
              -ms-flex-direction: column;
                  flex-direction: column;
          gap: 1rem; }
      .p-top-img-list {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        gap: 2rem;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        padding: 0 2rem;
        margin-top: 5rem;
        margin-bottom: 0; }
      .p-top-img-list__wrap {
        width: 100vw;
        margin-top: 5.6rem;
        overflow: hidden; }
    .p-voting-modal-list {
      -webkit-box-align: start;
          -ms-flex-align: start;
              align-items: flex-start;
      padding-top: 0;
      height: 100vh; }
      .p-voting-modal-list__close {
        top: 3rem;
        right: 2rem;
        z-index: 10; }
      .p-voting-modal-list .swiper-container {
        height: 100vh;
        padding-bottom: 5rem; }
      .p-voting-modal-list .swiper-arrow {
        bottom: 4.5rem; }
      .p-voting-modal-list .swiper-next {
        right: 10rem; }
        .p-voting-modal-list .swiper-next::before {
          position: absolute;
          content: "";
          top: 50%;
          left: 50%;
          -webkit-transform: translate(-50%, -50%);
                  transform: translate(-50%, -50%);
          width: 9rem;
          height: 4.5rem;
          pointer-events: all; }
      .p-voting-modal-list .swiper-prev {
        right: auto;
        left: 10rem; }
        .p-voting-modal-list .swiper-prev::after {
          position: absolute;
          content: "";
          top: 50%;
          left: 50%;
          -webkit-transform: translate(-50%, -50%);
                  transform: translate(-50%, -50%);
          width: 9rem;
          height: 4.5rem;
          pointer-events: all; }
    .p-voting-modal-item {
      padding: 8rem 2rem 2rem;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      gap: 2.5rem;
      overflow-y: scroll;
      max-height: 100vh; }
      .p-voting-modal-item__figure {
        width: 100%;
        min-height: 24rem;
        max-height: 24rem; }
          .p-voting-modal-item__figure--youtube iframe {
            height: 100%; }
      .p-voting-modal-item__desc-wrap {
        width: 100%;
        height: auto; }
      .p-voting-modal-item__scroll-wrap {
        overflow: visible;
        height: auto; }
      .p-voting-modal-item .c-btn-camera {
        margin: 3rem auto; }
    .p-works__page-desc {
      width: 100%;
      padding: 0 2rem;
      text-align: left; }
    .p-works-list {
      width: 100%;
      padding: 0 2rem;
      gap: 3.5rem; }
    .p-works-item {
      width: 100%; }
      .p-works-item__ttl {
        font-size: 1.5rem; }
    .p-works-btn {
      width: 100%;
      padding: 0 5rem; } }
@media screen and (max-width: 767px) and (max-width: 767px) {
      .p-overview .s-overview__containerBottom .s-overview__right-item-wrap.wrap-left.column01 small {
        margin-left: 0; } }
@media (hover: hover) {
      .p-guide .s-check-list__link:hover {
        color: white;
        background-color: #ff7f2f; }
        .p-guide .s-check-list__link:hover path {
          fill: white; }
      .s-entry__banner:hover {
        opacity: 0.7; }
      .s-entry__link:hover::before {
        left: calc(100% + 5rem); }
      .s-entry__link:hover::after {
        left: 0; }
        .p-top .s-check-list__link:hover {
          color: white;
          background-color: #ff7f2f; }
          .p-top .s-check-list__link:hover path {
            fill: white; }
        .p-voting-modal-item__figure--youtube:hover img {
          opacity: 0.7; }
    .p-works-item:hover .p-works-item__figure img {
      -webkit-transform: scale(1.1);
              transform: scale(1.1); } }
/*# sourceMappingURL=../../_cache/_maps/styles.css.map */
