@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Cormorant+Infant:wght@300;400;500;600;700&family=Shippori+Mincho:wght@400;500;600;700;800&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Cormorant+Infant:wght@300;400;500;600;700&family=Shippori+Mincho:wght@400;500;600;700;800&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Cormorant+Infant:wght@300;400;500;600;700&family=Shippori+Mincho:wght@400;500;600;700;800&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Cormorant+Infant:wght@300;400;500;600;700&family=Shippori+Mincho:wght@400;500;600;700;800&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Cormorant+Infant:wght@300;400;500;600;700&family=Shippori+Mincho:wght@400;500;600;700;800&display=swap");
audio:not([controls]) {
  display: none;
}

button {
  overflow: visible;
  -webkit-appearance: button;
}

a, button {
  outline: 0;
}

details {
  display: block;
}

html {
  -ms-overflow-style: -ms-autohiding-scrollbar;
  overflow-y: scroll;
  -webkit-text-size-adjust: 100%;
}

input {
  -webkit-border-radius: 0;
}
input[type=button], input[type=reset], input[type=submit] {
  -webkit-appearance: button;
}
input[type=number] {
  width: auto;
}
input[type=search] {
  -webkit-appearance: textfield;
}
input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

main {
  display: block;
}

pre {
  overflow: auto;
}

progress {
  display: inline-block;
}

small {
  font-size: 75%;
}

summary {
  display: block;
}

svg:not(:root) {
  overflow: hidden;
}

template {
  display: none;
}

textarea {
  overflow: auto;
}

[hidden] {
  display: none;
}

*,
::before,
::after {
  box-sizing: inherit;
}

* {
  font-size: inherit;
  line-height: inherit;
}
*:before, *:after {
  box-sizing: border-box;
}

::before,
::after {
  text-decoration: inherit;
  vertical-align: inherit;
}

*,
::before,
::after {
  border-style: solid;
  border-width: 0;
}

* {
  background-repeat: no-repeat;
  margin: 0;
  padding: 0;
}

:root {
  background-color: #FFFFFF;
  box-sizing: border-box;
  color: #000000;
  cursor: default;
  font: 100%/1.5 sans-serif;
  text-rendering: optimizeLegibility;
}

a {
  text-decoration: none;
}

audio,
canvas,
iframe,
img,
svg,
video {
  vertical-align: middle;
}

button,
input,
select,
textarea {
  background-color: transparent;
}

button,
input,
select,
textarea {
  color: inherit;
  font-family: inherit;
  font-style: inherit;
  font-weight: inherit;
}

button,
[type=button],
[type=date],
[type=datetime],
[type=datetime-local],
[type=email],
[type=month],
[type=number],
[type=password],
[type=reset],
[type=search],
[type=submit],
[type=tel],
[type=text],
[type=time],
[type=url],
[type=week],
select,
textarea {
  min-height: 1.5em;
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
}

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

select {
  -moz-appearance: none;
  -webkit-appearance: none;
}
select::-ms-expand {
  display: none;
}
select::-ms-value {
  color: currentColor;
}

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

textarea {
  resize: vertical;
}

[aria-busy=true] {
  cursor: progress;
}

[aria-controls] {
  cursor: pointer;
}

[aria-disabled] {
  cursor: default;
}

[hidden][aria-hidden=false] {
  clip: rect(0 0 0 0);
  display: inherit;
  position: absolute;
}
[hidden][aria-hidden=false]:focus {
  clip: auto;
}

body {
  -webkit-font-smoothing: antialiased;
}

ul li {
  list-style-type: none;
}

figure {
  -webkit-margin-before: 0;
  -webkit-margin-after: 0;
  -webkit-margin-start: 0;
  -webkit-margin-end: 0;
}

button {
  cursor: pointer;
}

.full-layer, #gnavi-mb .inner, #gnavi-mb, #site-header:before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
}

/**
 * ホバーエフェクトの mixin<br>
 * 効果：中央からラインが伸びる（下）<br>
 * 参考：http://www.nxworld.net/tips/15-text-link-hover-effect-and-design.html
 *
 * @param {String} color ラインのカラー　デフォルトは #888
 * @param {String} border_height ラインの高さ　デフォルトは 1px
 * @param {String} transition トランジション　デフォルトは 0.3s
 */
/**
 * ホバーエフェクトの mixin で「中央からラインが伸びる（下）」のホバーじと同じ効果を上書きする<br>
 * 効果：中央からラインが伸びる（下）：ホバー<br>
 */
/**
 * ボックス型のボタン
 * ボタンのテキストにはクラスを設定したタグに data-button-text プロパティを設定して before と after にボタン名として入れられる
 * テキストは before に設定される。
 * ホバー時にはテキストがせり上がるようにしながら after が表示される。
 */
/**
 * ボタンクラスの基本を作る mixin<br>
 *
 * @param {String} element ボタンにするエレメント　デフォルトは .btn
 * @param {Boolean} responsive レスポンシブにする場合に true　デフォルトは false
 */
/**
 * スライドスイッチのクラスを構築 mixin<br>
 * 参考：https://proto.io/freebies/onoff/
 *
 * @param {String} cl クラス名
 * @param {String} h 高さ
 * @param {String} w 幅
 * @param {String} b ボーダーの幅
 * @param {String} offBgClr OFF の時のボタン背景色
 * @param {String} onBgClr ON の時のボタン背景色
 * @param {String} offBdClr OFF の時のボーダー色
 * @param {String} onBdClr ON の時のボーダー色
 * @param {String} swClr スライドするボタンの色
*/
/**
 * スライドスイッチのクラスを構築 mixin<br>
 * 参考：https://proto.io/freebies/onoff/
 * こちらは ON, OFF のテキストがスイッチの右側に表示される
 *
 * @param {String} cl クラス名
 * @param {String} h 高さ
 * @param {String} w 幅
 * @param {String} b ボーダーの幅
 * @param {String} offBgClr OFF の時のボタン背景色
 * @param {String} onBgClr ON の時のボタン背景色
 * @param {String} offBdClr OFF の時のボーダー色
 * @param {String} onBdClr ON の時のボーダー色
 * @param {String} swClr スライドするボタンの色
*/
/**
 * 指定されたプロパティに決められた基準のスペースを入れる mixin。
 *
 * @param {String} property name
 * @param {Number} 係数
 */
/**
 * コンテンツのプロパティ設定用 mixin。
 *
 * @param {String} property margin か padding　デフォルトは padding
 * @param {String} 配列での設定か、Large の指定
 * @param {String} Midium の指定
 * @param {String} Small の指定
 * @param {String} Extra small の指定
*/
/**
 * コンテンツスペース設定用 mixin。contents-space-XX にしたがって指定する。各サイズ設定に notset を入れるとそのサイズは設定されない。
 *
 * @param {String} property margin か padding　デフォルトは padding
 * @param {String} position top, bottom などの場所の指定。空の場合は全体の指定　デフォルトは空。例外的に vertical か side で左右、horizonal で上下の指定ができる。
 * @param {String} Large の指定
 * @param {String} Midium の指定
 * @param {String} Small の指定
 * @param {String} Extra small の指定
*/
/**
 * wrapper 用のサイドスペース設定 mixin。contents-space-XX にしたがって指定する
 *
 * @param {String} property margin か padding　デフォルトは padding
 * @param {String} position top, bottom などの場所の指定。空の場合は全体の指定　デフォルトは空。例外的に vertical か side で左右、horizonal で上下の指定ができる。
 * @param {String} Large の指定
 * @param {String} Midium の指定
 * @param {String} Small の指定
 * @param {String} Extra small の指定
*/
/**
 * コンテンツの指定したプロパティを設定されている contents-space-XX にしたがって指定する
 *
 * @param {String} property margin か padding　デフォルトは padding
 * @param {Array} position top, bottom などの場所の指定。空の場合は全体の指定　デフォルトは空
*/
/**
 * コンテンツの指定したプロパティを設定されている contents-subspace-XX にしたがって指定する
 *
 * @param {String} property margin か padding　デフォルトは padding
 * @param {Array} position top, bottom などの場所の指定。空の場合は全体の指定　デフォルトは空
*/
html {
  -webkit-overflow-scrolling: touch;
}

body {
  font-family: YakuHanMP, "Shippori Mincho", sans-serif;
}
body a:focus, body button:focus {
  outline: none;
}

a:focus, button:focus {
  outline: none;
}

small {
  font-size: 1em;
}

span.ib-text span {
  display: inline-block;
}

img {
  max-width: 100%;
}

address {
  font-style: normal;
}

.wrapper {
  margin-left: auto;
  margin-right: auto;
  max-width: 1366px;
  min-width: 320px;
  padding-left: 25px;
  padding-right: 25px;
  position: relative;
}
@media (min-width: 968px) and (max-width: 1023px) {
  .wrapper {
    padding-left: 25px;
    padding-right: 25px;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .wrapper {
    padding-left: 25px;
    padding-right: 25px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .wrapper {
    padding-left: 25px;
    padding-right: 25px;
  }
}
@media (max-width: 479px) {
  .wrapper {
    padding-left: 25px;
    padding-right: 25px;
  }
}

.img-circle {
  border-radius: 50%;
  overflow: hidden;
}

.img-cover, .img-contain {
  height: 100%;
  background-repeat: no-repeat;
  background-position: center center;
}
.img-cover.img-center-top, .img-contain.img-center-top {
  background-position: center top;
}
.img-cover.img-center-bottom, .img-contain.img-center-bottom {
  background-position: center bottom;
}

.img-cover {
  background-size: cover;
}

.img-contain {
  background-size: contain;
}

.txt {
  display: inline-block;
}
.txt span {
  display: inline-block;
}

.ib-text span {
  display: inline-block;
}

.hidden {
  display: none !important;
}

.eng {
  font-family: YakuHanMP, "Cormorant Infant", sans-serif;
}

a {
  color: rgb(35, 35, 35);
}
a:hover {
  color: rgb(11, 74, 107);
}
@media (min-width: 1024px) {
  a:hover, a:active, a:focus {
    text-decoration: none;
  }
}

.youtube, .googlemap, .if-resp {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 56.25%;
  overflow: hidden;
}
.youtube iframe, .googlemap iframe, .if-resp iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.ev-click-disabled {
  pointer-events: none;
}

.ev-click-enabled {
  pointer-events: auto;
}

.eng, .fm-eng {
  font-family: YakuHanMP, "Cormorant Infant", sans-serif;
}

.fm-head {
  font-family: YakuHanMP, "Shippori Mincho", sans-serif;
}

.flex {
  display: flex;
}

.flex-column, .flex-column-center {
  display: flex;
  flex-direction: column;
}
@media (min-width: 480px) and (max-width: 767px) {
  .flex-column, .flex-column-center {
    flex-wrap: wrap;
  }
}
@media (max-width: 479px) {
  .flex-column, .flex-column-center {
    display: block;
  }
}

.flex-column-center {
  justify-content: center;
  align-items: center;
}
@media (min-width: 480px) and (max-width: 767px) {
  .flex-column-center {
    flex-wrap: wrap;
  }
}
@media (max-width: 479px) {
  .flex-column-center {
    display: block;
  }
}

.swiper-button-next, .swiper-button-prev {
  color: rgb(11, 74, 107) !important;
}
@media (max-width: 479px) {
  .swiper-button-next, .swiper-button-prev {
    top: 20% !important;
    color: rgb(245, 245, 245) !important;
  }
}

/**
 * Swiper 7.4.1
 * 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: December 24, 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");
  font-weight: 400;
  font-style: normal;
}
:root {
  --swiper-theme-color:#007aff;
}

.swiper {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  z-index: 1;
}

.swiper-vertical > .swiper-wrapper {
  flex-direction: column;
}

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  box-sizing: content-box;
}

.swiper-android .swiper-slide, .swiper-wrapper {
  transform: translate3d(0px, 0, 0);
}

.swiper-pointer-events {
  touch-action: pan-y;
}

.swiper-pointer-events.swiper-vertical {
  touch-action: pan-x;
}

.swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
}

.swiper-slide-invisible-blank {
  visibility: hidden;
}

.swiper-autoheight, .swiper-autoheight .swiper-slide {
  height: auto;
}

.swiper-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height;
}

.swiper-3d, .swiper-3d.swiper-css-mode .swiper-wrapper {
  perspective: 1200px;
}

.swiper-3d .swiper-cube-shadow, .swiper-3d .swiper-slide, .swiper-3d .swiper-slide-shadow, .swiper-3d .swiper-slide-shadow-bottom, .swiper-3d .swiper-slide-shadow-left, .swiper-3d .swiper-slide-shadow-right, .swiper-3d .swiper-slide-shadow-top, .swiper-3d .swiper-wrapper {
  transform-style: preserve-3d;
}

.swiper-3d .swiper-slide-shadow, .swiper-3d .swiper-slide-shadow-bottom, .swiper-3d .swiper-slide-shadow-left, .swiper-3d .swiper-slide-shadow-right, .swiper-3d .swiper-slide-shadow-top {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10;
}

.swiper-3d .swiper-slide-shadow {
  background: rgba(0, 0, 0, 0.15);
}

.swiper-3d .swiper-slide-shadow-left {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-right {
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-top {
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-3d .swiper-slide-shadow-bottom {
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-css-mode > .swiper-wrapper {
  overflow: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none;
}

.swiper-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start;
}

.swiper-horizontal.swiper-css-mode > .swiper-wrapper {
  scroll-snap-type: x mandatory;
}

.swiper-vertical.swiper-css-mode > .swiper-wrapper {
  scroll-snap-type: y mandatory;
}

.swiper-centered > .swiper-wrapper::before {
  content: "";
  flex-shrink: 0;
  order: 9999;
}

.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
  margin-inline-start: var(--swiper-centered-offset-before);
}

.swiper-centered.swiper-horizontal > .swiper-wrapper::before {
  height: 100%;
  min-height: 1px;
  width: var(--swiper-centered-offset-after);
}

.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
  margin-block-start: var(--swiper-centered-offset-before);
}

.swiper-centered.swiper-vertical > .swiper-wrapper::before {
  width: 100%;
  min-width: 1px;
  height: var(--swiper-centered-offset-after);
}

.swiper-centered > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: center center;
}

.swiper-virtual.swiper-css-mode .swiper-wrapper::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
}

.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper::after {
  height: 1px;
  width: var(--swiper-virtual-size);
}

.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper::after {
  width: 1px;
  height: var(--swiper-virtual-size);
}

: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: flex;
  align-items: 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: 0.35;
  cursor: auto;
  pointer-events: none;
}

.swiper-button-next:after, .swiper-button-prev:after {
  font-family: swiper-icons;
  font-size: var(--swiper-navigation-size);
  text-transform: none !important;
  letter-spacing: 0;
  text-transform: none;
  font-variant: initial;
  line-height: 1;
}

.swiper-button-prev, .swiper-rtl .swiper-button-next {
  left: 10px;
  right: auto;
}

.swiper-button-prev:after, .swiper-rtl .swiper-button-next:after {
  content: "prev";
}

.swiper-button-next, .swiper-rtl .swiper-button-prev {
  right: 10px;
  left: auto;
}

.swiper-button-next:after, .swiper-rtl .swiper-button-prev:after {
  content: "next";
}

.swiper-button-lock {
  display: none;
}

.swiper-pagination {
  position: absolute;
  text-align: center;
  transition: 0.3s opacity;
  transform: translate3d(0, 0, 0);
  z-index: 10;
}

.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}

.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .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 {
  transform: scale(0.33);
  position: relative;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  transform: scale(0.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  transform: scale(0.33);
}

.swiper-pagination-bullet {
  width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
  height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
  display: inline-block;
  border-radius: 50%;
  background: var(--swiper-pagination-bullet-inactive-color, #000);
  opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2);
}

button.swiper-pagination-bullet {
  border: none;
  margin: 0;
  padding: 0;
  box-shadow: none;
  -webkit-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: var(--swiper-pagination-bullet-opacity, 1);
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
}

.swiper-pagination-vertical.swiper-pagination-bullets, .swiper-vertical > .swiper-pagination-bullets {
  right: 10px;
  top: 50%;
  transform: translate3d(0px, -50%, 0);
}

.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet, .swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
  display: block;
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic, .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  top: 50%;
  transform: translateY(-50%);
  width: 8px;
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet, .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  display: inline-block;
  transition: 0.2s transform, 0.2s top;
}

.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px);
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic, .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}

.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 0.2s transform, 0.2s left;
}

.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 0.2s transform, 0.2s right;
}

.swiper-pagination-progressbar {
  background: rgba(0, 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%;
  transform: scale(0);
  transform-origin: left top;
}

.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  transform-origin: right top;
}

.swiper-horizontal > .swiper-pagination-progressbar, .swiper-pagination-progressbar.swiper-pagination-horizontal, .swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite, .swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
  width: 100%;
  height: 4px;
  left: 0;
  top: 0;
}

.swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite, .swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite, .swiper-pagination-progressbar.swiper-pagination-vertical, .swiper-vertical > .swiper-pagination-progressbar {
  width: 4px;
  height: 100%;
  left: 0;
  top: 0;
}

.swiper-pagination-lock {
  display: none;
}

.swiper-scrollbar {
  border-radius: 10px;
  position: relative;
  -ms-touch-action: none;
  background: rgba(0, 0, 0, 0.1);
}

.swiper-horizontal > .swiper-scrollbar {
  position: absolute;
  left: 1%;
  bottom: 3px;
  z-index: 50;
  height: 5px;
  width: 98%;
}

.swiper-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, 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: flex;
  justify-content: 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%;
  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;
  transform-origin: 50%;
  animation: swiper-preloader-spin 1s infinite linear;
  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;
}

@keyframes swiper-preloader-spin {
  100% {
    transform: rotate(360deg);
  }
}
.swiper .swiper-notification {
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
  opacity: 0;
  z-index: -1000;
}

.swiper-free-mode > .swiper-wrapper {
  transition-timing-function: ease-out;
  margin: 0 auto;
}

.swiper-grid > .swiper-wrapper {
  flex-wrap: wrap;
}

.swiper-grid-column > .swiper-wrapper {
  flex-wrap: wrap;
  flex-direction: column;
}

.swiper-fade.swiper-free-mode .swiper-slide {
  transition-timing-function: ease-out;
}

.swiper-fade .swiper-slide {
  pointer-events: none;
  transition-property: opacity;
}

.swiper-fade .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-fade .swiper-slide-active, .swiper-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-cube {
  overflow: visible;
}

.swiper-cube .swiper-slide {
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  z-index: 1;
  visibility: hidden;
  transform-origin: 0 0;
  width: 100%;
  height: 100%;
}

.swiper-cube .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-cube.swiper-rtl .swiper-slide {
  transform-origin: 100% 0;
}

.swiper-cube .swiper-slide-active, .swiper-cube .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-cube .swiper-slide-active, .swiper-cube .swiper-slide-next, .swiper-cube .swiper-slide-next + .swiper-slide, .swiper-cube .swiper-slide-prev {
  pointer-events: auto;
  visibility: visible;
}

.swiper-cube .swiper-slide-shadow-bottom, .swiper-cube .swiper-slide-shadow-left, .swiper-cube .swiper-slide-shadow-right, .swiper-cube .swiper-slide-shadow-top {
  z-index: 0;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-cube .swiper-cube-shadow {
  position: absolute;
  left: 0;
  bottom: 0px;
  width: 100%;
  height: 100%;
  opacity: 0.6;
  z-index: 0;
}

.swiper-cube .swiper-cube-shadow:before {
  content: "";
  background: #000;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  filter: blur(50px);
}

.swiper-flip {
  overflow: visible;
}

.swiper-flip .swiper-slide {
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  z-index: 1;
}

.swiper-flip .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-flip .swiper-slide-active, .swiper-flip .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-flip .swiper-slide-shadow-bottom, .swiper-flip .swiper-slide-shadow-left, .swiper-flip .swiper-slide-shadow-right, .swiper-flip .swiper-slide-shadow-top {
  z-index: 0;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-creative .swiper-slide {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  overflow: hidden;
  transition-property: transform, opacity, height;
}

.swiper-cards {
  overflow: visible;
}

.swiper-cards .swiper-slide {
  transform-origin: center bottom;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  overflow: hidden;
}

@media (max-width: 479px) {
  .hidden-sp {
    display: none !important;
  }
}

@media (min-width: 480px) and (max-width: 767px) {
  .hidden-tb {
    display: none !important;
  }
}

@media (max-width: 1023px) {
  .hidden-mb {
    display: none !important;
  }
}

@media (min-width: 480px) {
  .hidden-no-sp {
    display: none !important;
  }
}

@media (min-width: 768px) and (max-width: 967px) {
  .hidden-spc {
    display: none !important;
  }
}

@media (min-width: 968px) and (max-width: 1023px) {
  .hidden-lpc {
    display: none !important;
  }
}

@media (min-width: 1024px) {
  .hidden-pc {
    display: none !important;
  }
}

:root {
  background: white;
}

h2 {
  font-size: clamp(19px, 2.789vw, 27px);
  font-weight: 500;
  letter-spacing: 0.05rem;
}
@media (min-width: 968px) and (max-width: 1023px) {
  h2 {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  h2 {
    font-size: clamp(20px, 3.125vw, 24px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  h2 {
    font-size: clamp(25px, 5vw, 24px);
  }
}
@media (max-width: 479px) {
  h2 {
    font-size: clamp(16px, 5vw, 24px);
  }
}

body {
  width: 100vw;
  overflow: hidden;
  font-family: YakuHanMP, "Shippori Mincho", sans-serif;
  font-weight: 400;
  font-style: normal;
  line-height: 2;
  letter-spacing: 0.05rem;
  font-size: clamp(11px, 1.653vw, 16px);
}
@media (min-width: 968px) and (max-width: 1023px) {
  body {
    font-size: clamp(11px, 1.653vw, 16px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  body {
    font-size: clamp(13px, 2.083vw, 16px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  body {
    font-size: clamp(17px, 3.333vw, 16px);
  }
}
@media (max-width: 479px) {
  body {
    font-size: clamp(11px, 3.333vw, 16px);
  }
}
@media (max-width: 479px) {
  body {
    line-height: 1.9;
  }
}

a {
  transition-duration: 0.5s;
}
a:hover {
  transition-duration: 0.5s;
}

#site-header {
  font-family: YakuHanMP, "Shippori Mincho", sans-serif;
  font-weight: 500;
  font-style: normal;
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 100;
}
#site-header:before {
  content: "";
  display: block;
}
#site-header .wrapper {
  position: relative;
  height: 100%;
}
@media (max-width: 479px) {
  #site-header .wrapper {
    padding-left: initial;
    padding-right: initial;
  }
}
#site-header .flex {
  height: 100%;
  align-items: center;
}
#site-header .flex-row {
  flex-direction: row !important;
}
#site-header .flex-column {
  flex-direction: column !important;
}
#site-header .logo {
  padding-top: 1.317715959vw;
  padding-bottom: 1.317715959vw;
  padding-left: 1.756954612vw;
  padding-right: 1.756954612vw;
  background: rgb(11, 74, 107);
  position: relative;
  z-index: 1000;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #site-header .logo {
    padding-top: 1.7595307918vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #site-header .logo {
    padding-top: 1.8614270941vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #site-header .logo {
    padding-top: 2.3468057366vw;
  }
}
@media (max-width: 479px) {
  #site-header .logo {
    padding-top: 3.75782881vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #site-header .logo {
    padding-bottom: 1.7595307918vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #site-header .logo {
    padding-bottom: 1.8614270941vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #site-header .logo {
    padding-bottom: 2.3468057366vw;
  }
}
@media (max-width: 479px) {
  #site-header .logo {
    padding-bottom: 3.75782881vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #site-header .logo {
    padding-left: 2.3460410557vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #site-header .logo {
    padding-left: 2.4819027921vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #site-header .logo {
    padding-left: 3.1290743155vw;
  }
}
@media (max-width: 479px) {
  #site-header .logo {
    padding-left: 5.0104384134vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #site-header .logo {
    padding-right: 2.3460410557vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #site-header .logo {
    padding-right: 2.4819027921vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #site-header .logo {
    padding-right: 3.1290743155vw;
  }
}
@media (max-width: 479px) {
  #site-header .logo {
    padding-right: 5.0104384134vw;
  }
}
#site-header .logo a {
  display: flex;
  align-items: center;
}
@media (max-width: 479px) {
  #site-header .logo a {
    align-items: flex-start;
  }
}
#site-header .logo a svg {
  width: auto;
  height: 3.074670571vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #site-header .logo a svg {
    height: 3.9100684262vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #site-header .logo a svg {
    height: 4.1365046536vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #site-header .logo a svg {
    height: 5.2151238592vw;
  }
}
@media (max-width: 479px) {
  #site-header .logo a svg {
    height: 8.3507306889vw;
  }
}
#site-header .logo a svg path {
  fill: rgb(245, 245, 245);
}
#site-header .header-nav {
  flex-grow: 1;
}
#site-header .header-nav .nav-menu {
  display: flex;
  justify-content: flex-end;
  width: 100%;
}
#site-header .header-nav .nav-menu .menu-item {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: clamp(10px, 1.446vw, 14px);
  margin-left: 12px;
  margin-right: 12px;
}
#site-header .header-nav .nav-menu .menu-item a {
  color: rgb(245, 245, 245);
}
@media (min-width: 768px) and (max-width: 967px) {
  #site-header .header-nav .nav-menu .menu-item {
    margin-left: 12px;
    margin-right: 12px;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #site-header .header-nav .nav-menu .menu-item {
    margin-left: 6px;
    margin-right: 6px;
    font-size: clamp(10px, 1.446vw, 14px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #site-header .header-nav .nav-menu .menu-item {
    margin-left: 4px;
    margin-right: 4px;
    font-size: clamp(12px, 1.823vw, 14px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #site-header .header-nav .nav-menu .menu-item {
    margin-left: 5px;
    margin-right: 5px;
    font-size: clamp(15px, 2.917vw, 14px);
  }
}
#site-header .header-nav .nav-menu .menu-item.inquiry {
  margin-right: 25px;
}
#site-header .header-nav .nav-menu .menu-item.inquiry a {
  color: rgb(245, 245, 245) !important;
  padding: 10px 30px;
  background: rgb(11, 74, 107);
  border: 1px solid rgb(11, 74, 107);
}
#site-header .header-nav .nav-menu .menu-item.inquiry a:hover {
  color: rgb(11, 74, 107) !important;
  background-color: rgb(245, 245, 245);
}
#site-header.overmv {
  background: white;
}
#site-header.overmv .logo {
  position: relative;
}
#site-header.overmv .logo:before {
  content: "";
  background: rgb(11, 74, 107);
  width: 50vw;
  position: absolute;
  left: -50vw;
  top: 0;
  height: 100%;
  z-index: -1;
}
#site-header.overmv .header-nav .nav-menu .menu-item a {
  color: rgb(35, 35, 35);
}
#site-header.overmv .header-nav .nav-menu .menu-item.inquiry a {
  color: rgb(245, 245, 245);
}
#site-header.overmv .header-nav .nav-menu .menu-item.inquiry a:hover {
  color: rgb(11, 74, 107);
}

@media (max-width: 967px) {
  .no-side {
    padding-left: initial;
    padding-right: initial;
  }
}

#mainvisual {
  position: relative;
  position: relative;
}
#mainvisual figure {
  position: relative;
  width: 100%;
}
#mainvisual figure:before {
  content: "";
  display: block;
  padding-top: 53.64%;
}
#mainvisual figure img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  border-radius: 0vw;
  object-fit: cover;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) {
  #mainvisual figure img {
    border-radius: 0vw;
  }
}
#mainvisual .inner {
  position: relative;
  margin-left: auto;
  margin-right: auto;
}
#mainvisual .catch {
  position: absolute;
  top: 16.6666666667vw;
  left: 9.4436310395vw;
}
@media (max-width: 479px) {
  #mainvisual .catch {
    top: 36%;
    left: 6%;
  }
}
#mainvisual .catch h1 {
  font-size: clamp(45px, 6.612vw, 64px);
  color: rgb(245, 245, 245);
  font-weight: 500;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #mainvisual .catch h1 {
    font-size: clamp(39px, 5.785vw, 56px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #mainvisual .catch h1 {
    font-size: clamp(47px, 7.292vw, 56px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #mainvisual .catch h1 {
    font-size: clamp(59px, 11.667vw, 56px);
  }
}
@media (max-width: 479px) {
  #mainvisual .catch h1 {
    font-size: clamp(24px, 7.5vw, 36px);
  }
}
#mainvisual .page {
  position: relative;
  padding-top: 2.196193265vw;
  padding-left: 4.39238653vw;
  height: 5.8565153734vw;
  margin-top: -5.8565153734vw;
  width: 50%;
  background-color: white;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #mainvisual .page {
    padding-top: 2.9325513196vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #mainvisual .page {
    padding-top: 3.1023784902vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #mainvisual .page {
    padding-top: 3.9113428944vw;
  }
}
@media (max-width: 479px) {
  #mainvisual .page {
    padding-top: 6.2630480167vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #mainvisual .page {
    padding-left: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #mainvisual .page {
    padding-left: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #mainvisual .page {
    padding-left: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #mainvisual .page {
    padding-left: 0vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #mainvisual .page {
    height: 7.8201368524vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #mainvisual .page {
    height: 8.2730093071vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #mainvisual .page {
    height: 10.4302477184vw;
  }
}
@media (max-width: 479px) {
  #mainvisual .page {
    height: 16.7014613779vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #mainvisual .page {
    margin-top: -7.8201368524vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #mainvisual .page {
    margin-top: -8.1695966908vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #mainvisual .page {
    margin-top: -10.2998696219vw;
  }
}
@media (max-width: 479px) {
  #mainvisual .page {
    margin-top: -16.7014613779vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #mainvisual .page {
    width: 70%;
  }
}
@media (max-width: 479px) {
  #mainvisual .page {
    width: 75%;
  }
}
#mainvisual .page:before {
  content: "";
  position: absolute;
  background-color: white;
  left: -99vw;
  width: 100vw;
  top: 0;
  bottom: 0;
}
#mainvisual .page .title {
  display: flex;
  justify-content: flex-start;
}
#mainvisual .page .title .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #mainvisual .page .title .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #mainvisual .page .title .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #mainvisual .page .title .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #mainvisual .page .title .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #mainvisual .page .title .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #mainvisual .page .title .sec-title {
    text-align: left;
  }
}
#mainvisual .page .title .sec-title:before, #mainvisual .page .title .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#mainvisual .page .title .sec-title:before {
  left: 0;
}
#mainvisual .page .title .sec-title:after {
  left: 60px;
  right: initial;
}
#mainvisual .page .title .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(0% + 8px);
  width: 52px;
  z-index: 1;
}
#mainvisual .page .title .sec-title {
  font-size: clamp(25px, 3.719vw, 36px);
  font-weight: 500;
  left: initial;
  transform: initial;
  line-height: 1.4;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #mainvisual .page .title .sec-title {
    font-size: clamp(25px, 3.719vw, 36px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #mainvisual .page .title .sec-title {
    font-size: clamp(30px, 4.688vw, 36px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #mainvisual .page .title .sec-title {
    font-size: clamp(39px, 7.5vw, 36px);
  }
}
@media (max-width: 479px) {
  #mainvisual .page .title .sec-title {
    font-size: clamp(14px, 4.375vw, 21px);
  }
}
#mainvisual .page .title .sec-title.pichup {
  font-size: clamp(15px, 2.169vw, 21px);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #mainvisual .page .title .sec-title.pichup {
    font-size: clamp(15px, 2.169vw, 21px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #mainvisual .page .title .sec-title.pichup {
    font-size: clamp(17px, 2.734vw, 21px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #mainvisual .page .title .sec-title.pichup {
    font-size: clamp(23px, 4.375vw, 21px);
  }
}
@media (max-width: 479px) {
  #mainvisual .page .title .sec-title.pichup {
    font-size: clamp(14px, 4.375vw, 21px);
  }
}
.home #mainvisual {
  position: relative;
}
.home #mainvisual figure {
  position: relative;
  width: 100%;
}
.home #mainvisual figure:before {
  content: "";
  display: block;
  padding-top: 53.64%;
}
.home #mainvisual figure img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  border-radius: 0vw;
  object-fit: cover;
}
@media (min-width: 968px) and (max-width: 1023px) {
  .home #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .home #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .home #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) {
  .home #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) {
  .home #mainvisual {
    position: relative;
  }
  .home #mainvisual figure {
    position: relative;
    width: 100%;
  }
  .home #mainvisual figure:before {
    content: "";
    display: block;
    padding-top: 150%;
  }
  .home #mainvisual figure img {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 100%;
    height: 100%;
    border-radius: 0vw;
    object-fit: cover;
  }
}
@media (max-width: 479px) and (min-width: 968px) and (max-width: 1023px) {
  .home #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) and (min-width: 768px) and (max-width: 967px) {
  .home #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  .home #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  .home #mainvisual figure img {
    border-radius: 0vw;
  }
}
.single-post #mainvisual {
  overflow: initial;
  position: relative;
}
.single-post #mainvisual figure {
  position: relative;
  width: 100%;
}
.single-post #mainvisual figure:before {
  content: "";
  display: block;
  padding-top: 30%;
}
.single-post #mainvisual figure img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  border-radius: 0vw;
  object-fit: cover;
}
@media (min-width: 968px) and (max-width: 1023px) {
  .single-post #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .single-post #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .single-post #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) {
  .single-post #mainvisual figure img {
    border-radius: 0vw;
  }
}
.single-post #mainvisual.casestudy {
  position: relative;
}
.single-post #mainvisual.casestudy figure {
  position: relative;
  width: 100%;
}
.single-post #mainvisual.casestudy figure:before {
  content: "";
  display: block;
  padding-top: 53.64%;
}
.single-post #mainvisual.casestudy figure img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  border-radius: 0vw;
  object-fit: cover;
}
@media (min-width: 968px) and (max-width: 1023px) {
  .single-post #mainvisual.casestudy figure img {
    border-radius: 0vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .single-post #mainvisual.casestudy figure img {
    border-radius: 0vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .single-post #mainvisual.casestudy figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) {
  .single-post #mainvisual.casestudy figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) {
  .single-post #mainvisual.casestudy {
    position: relative;
  }
  .single-post #mainvisual.casestudy figure {
    position: relative;
    width: 100%;
  }
  .single-post #mainvisual.casestudy figure:before {
    content: "";
    display: block;
    padding-top: 100%;
  }
  .single-post #mainvisual.casestudy figure img {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 100%;
    height: 100%;
    border-radius: 0vw;
    object-fit: cover;
  }
}
@media (max-width: 479px) and (min-width: 968px) and (max-width: 1023px) {
  .single-post #mainvisual.casestudy figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) and (min-width: 768px) and (max-width: 967px) {
  .single-post #mainvisual.casestudy figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  .single-post #mainvisual.casestudy figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  .single-post #mainvisual.casestudy figure img {
    border-radius: 0vw;
  }
}
.single-post #mainvisual.pickup {
  position: relative;
}
.single-post #mainvisual.pickup figure {
  position: relative;
  width: 100%;
}
.single-post #mainvisual.pickup figure:before {
  content: "";
  display: block;
  padding-top: 53.64%;
}
.single-post #mainvisual.pickup figure img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  border-radius: 0vw;
  object-fit: cover;
}
@media (min-width: 968px) and (max-width: 1023px) {
  .single-post #mainvisual.pickup figure img {
    border-radius: 0vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .single-post #mainvisual.pickup figure img {
    border-radius: 0vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .single-post #mainvisual.pickup figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) {
  .single-post #mainvisual.pickup figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) {
  .single-post #mainvisual.pickup {
    position: relative;
  }
  .single-post #mainvisual.pickup figure {
    position: relative;
    width: 100%;
  }
  .single-post #mainvisual.pickup figure:before {
    content: "";
    display: block;
    padding-top: 100%;
  }
  .single-post #mainvisual.pickup figure img {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 100%;
    height: 100%;
    border-radius: 0vw;
    object-fit: cover;
  }
}
@media (max-width: 479px) and (min-width: 968px) and (max-width: 1023px) {
  .single-post #mainvisual.pickup figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) and (min-width: 768px) and (max-width: 967px) {
  .single-post #mainvisual.pickup figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  .single-post #mainvisual.pickup figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  .single-post #mainvisual.pickup figure img {
    border-radius: 0vw;
  }
}
#gnavi-toggle {
  height: 100px;
  display: flex;
  justify-content: center;
  align-items: center;
  position: fixed;
  top: 0;
  right: 24px;
  z-index: 400;
}
@media (max-width: 1023px) {
  #gnavi-toggle {
    height: 90px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #gnavi-toggle {
    right: 20px;
  }
}
#gnavi-toggle .btn-gnavi {
  width: 35px;
  height: 17.5px;
  position: relative;
}
#gnavi-toggle .btn-gnavi:before, #gnavi-toggle .btn-gnavi:after {
  transition: all 0.25s ease;
  transition-property: transform, top, bottom, background-color;
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 2px;
  background: rgb(245, 245, 245);
}
#gnavi-toggle .btn-gnavi:before {
  transform: translateY(-17.5555555556px) rotate(0);
}
#gnavi-toggle .btn-gnavi .bar {
  transition: all 0.25s ease;
  transition-property: opacity, background-color;
  display: block;
  width: 100%;
  height: 2px;
  background: rgb(245, 245, 245);
}
body.gnavi-open #gnavi-toggle .btn-gnavi:before, body.gnavi-open #gnavi-toggle .btn-gnavi:after {
  top: 0;
  bottom: 10px;
}
body.gnavi-open #gnavi-toggle .btn-gnavi:before {
  transform: rotate(-205deg);
}
body.gnavi-open #gnavi-toggle .btn-gnavi:after {
  transform: rotate(205deg);
}
body.gnavi-open #gnavi-toggle .btn-gnavi .bar {
  opacity: 0;
}

body.gnavi-open #gnavi-toggle .btn-gnavi:before, body.gnavi-open #gnavi-toggle .btn-gnavi:after {
  background: rgb(35, 35, 35);
}
body.gnavi-open #gnavi-toggle .btn-gnavi .bar {
  background: rgb(35, 35, 35);
}

#gnavi-toggle .menusp {
  font-weight: 600;
  line-height: 1;
}
#gnavi-toggle.overnav .btn .btn-gnavi {
  width: 35px;
  height: 17.5px;
  position: relative;
}
#gnavi-toggle.overnav .btn .btn-gnavi:before, #gnavi-toggle.overnav .btn .btn-gnavi:after {
  transition: all 0.25s ease;
  transition-property: transform, top, bottom, background-color;
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 2px;
  background: rgb(11, 74, 107);
}
#gnavi-toggle.overnav .btn .btn-gnavi:before {
  transform: translateY(-17.5555555556px) rotate(0);
}
#gnavi-toggle.overnav .btn .btn-gnavi .bar {
  transition: all 0.25s ease;
  transition-property: opacity, background-color;
  display: block;
  width: 100%;
  height: 2px;
  background: rgb(11, 74, 107);
}
body.gnavi-open #gnavi-toggle.overnav .btn .btn-gnavi:before, body.gnavi-open #gnavi-toggle.overnav .btn .btn-gnavi:after {
  top: 0;
  bottom: 10px;
}
body.gnavi-open #gnavi-toggle.overnav .btn .btn-gnavi:before {
  transform: rotate(-205deg);
}
body.gnavi-open #gnavi-toggle.overnav .btn .btn-gnavi:after {
  transform: rotate(205deg);
}
body.gnavi-open #gnavi-toggle.overnav .btn .btn-gnavi .bar {
  opacity: 0;
}

.gnavi-close .menu-open {
  display: block;
}
.gnavi-close .menu-close {
  display: none !important;
}

.gnavi-open .menu-open {
  display: none;
}
.gnavi-open .menu-close {
  display: block !important;
}

#gnavi-mb {
  display: none;
  position: fixed;
  z-index: 20;
}
@media (min-width: 1024px) {
  #gnavi-mb {
    display: none !important;
  }
}
#gnavi-mb a {
  color: rgb(35, 35, 35);
  font-size: clamp(16px, 2.376vw, 23px);
  font-weight: 500;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #gnavi-mb a {
    font-size: clamp(16px, 2.376vw, 23px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #gnavi-mb a {
    font-size: clamp(19px, 2.995vw, 23px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #gnavi-mb a {
    font-size: clamp(25px, 4.792vw, 23px);
  }
}
@media (max-width: 479px) {
  #gnavi-mb a {
    font-size: clamp(15px, 4.792vw, 23px);
  }
}
#gnavi-mb a:hover {
  color: rgb(11, 74, 107);
}
#gnavi-mb .inner {
  padding-top: 100px;
}
@media (max-width: 1023px) {
  #gnavi-mb .inner {
    padding-top: 90px;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #gnavi-mb .inner {
    padding-top: 0;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #gnavi-mb .inner {
    padding-top: 0;
  }
}
@media (max-width: 479px) {
  #gnavi-mb .inner {
    padding-top: 0;
  }
}
#gnavi-mb .gnavi-menu, #gnavi-mb .gnavi-container, #gnavi-mb .nav-menu {
  height: 100%;
  background: rgba(255, 255, 255, 0.9);
}
#gnavi-mb .nav-menu {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding-bottom: 30px;
}
#gnavi-mb .nav-menu .menu-item {
  margin: 0.5em 0;
}
#gnavi-mb .current_page_item a, #gnavi-mb .current-category-ancestor a, #gnavi-mb .current-menu-item a {
  color: rgb(11, 74, 107);
}
#gnavi-mb.nav-open {
  display: block;
}
#gnavi-mb.nav-open.nav-trans-ready .inner {
  transition: 0.8s;
  transition-timing-function: ease-out;
  transform: translateY(-10vh);
  opacity: 0;
}
#gnavi-mb.nav-open.nav-trans-ready.nav-trans .inner {
  transform: translateY(0);
  opacity: 1;
}
#gnavi-mb.nav-close.nav-trans-ready {
  display: block;
}
#gnavi-mb.nav-close.nav-trans-ready .inner {
  transition: 0.5s;
  transition-timing-function: ease-out;
  transform: translateY(0);
  opacity: 1;
}
#gnavi-mb.nav-close.nav-trans-ready.nav-trans .inner {
  transform: translateY(-10vh);
  opacity: 0;
}

.container-wrap {
  position: relative;
}
.container-wrap .wrap-bg {
  position: absolute;
  right: -15vw;
  background-image: url(/wp-content/themes/fujiikogyo/img/common/bg-container.jpg);
  background-size: 100%;
  background-repeat: no-repeat;
  transform: rotate(-15deg);
  top: -15vh;
  width: 60%;
  height: 700px;
  z-index: -1;
}

#go2top {
  position: fixed;
  bottom: 100px;
  right: 30px;
  width: 48px;
  height: 48px;
  z-index: 19;
}
#go2top a svg .icon1 {
  fill: white;
}
#go2top a svg .icon2 {
  fill: rgb(11, 74, 107);
  stroke: rgb(11, 74, 107);
}
#go2top a:hover svg .icon1 {
  fill: rgb(11, 74, 107);
}
#go2top a:hover svg .icon2 {
  fill: white;
}

#site-footer {
  background-color: rgb(35, 35, 35);
  padding-top: 3.2942898975vw;
  padding-bottom: 3.2942898975vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #site-footer {
    padding-top: 4.3988269795vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #site-footer {
    padding-top: 4.6535677353vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #site-footer {
    padding-top: 5.8670143416vw;
  }
}
@media (max-width: 479px) {
  #site-footer {
    padding-top: 6.2630480167vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #site-footer {
    padding-bottom: 4.3988269795vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #site-footer {
    padding-bottom: 4.6535677353vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #site-footer {
    padding-bottom: 5.8670143416vw;
  }
}
@media (max-width: 479px) {
  #site-footer {
    padding-bottom: 6.2630480167vw;
  }
}
#site-footer .footer-main {
  display: grid;
  grid-template-columns: 1fr 270px;
  gap: 60px;
}
@media (max-width: 479px) {
  #site-footer .footer-main {
    display: grid;
    grid-template-columns: 1fr 60px;
    gap: 30px;
  }
}
#site-footer .footer-main .logo a {
  display: flex;
  align-items: center;
}
@media (max-width: 479px) {
  #site-footer .footer-main .logo a {
    align-items: flex-start;
  }
}
#site-footer .footer-main .logo a svg {
  width: auto;
  height: 3.074670571vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #site-footer .footer-main .logo a svg {
    height: 3.9100684262vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #site-footer .footer-main .logo a svg {
    height: 4.1365046536vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #site-footer .footer-main .logo a svg {
    height: 5.2151238592vw;
  }
}
@media (max-width: 479px) {
  #site-footer .footer-main .logo a svg {
    height: 8.3507306889vw;
  }
}
#site-footer .footer-main .logo a svg path {
  fill: rgb(245, 245, 245);
}
#site-footer .footer-main .footer-nav {
  margin-top: 2.196193265vw;
  color: rgb(245, 245, 245);
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #site-footer .footer-main .footer-nav {
    margin-top: 2.9325513196vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #site-footer .footer-main .footer-nav {
    margin-top: 3.1023784902vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #site-footer .footer-main .footer-nav {
    margin-top: 3.9113428944vw;
  }
}
@media (max-width: 479px) {
  #site-footer .footer-main .footer-nav {
    margin-top: 6.2630480167vw;
  }
}
#site-footer .footer-main .footer-nav > div {
  margin-right: 40px;
  flex-basis: 30%;
  margin-bottom: 5px;
}
@media (max-width: 479px) {
  #site-footer .footer-main .footer-nav > div {
    flex-basis: 100%;
  }
}
#site-footer .footer-main .footer-nav > div svg {
  margin-right: 8px;
}
#site-footer .footer-main .footer-nav > div svg path {
  fill: rgb(245, 245, 245);
}
#site-footer .footer-main .footer-blog {
  width: 100%;
  max-width: 270px;
  display: flex;
  justify-content: flex-end;
}
@media (max-width: 479px) {
  #site-footer .footer-main .footer-blog {
    max-width: initial;
    flex-direction: column;
  }
}
#site-footer .footer-main .footer-blog div {
  width: calc(33.3333% - 20px);
  margin-right: 10px;
}
@media (max-width: 479px) {
  #site-footer .footer-main .footer-blog div {
    width: 100%;
    margin-bottom: 20px;
  }
}
#site-footer .footer-main .footer-blog div a svg {
  margin-right: 8px;
}
#site-footer .footer-main .footer-blog div a svg path, #site-footer .footer-main .footer-blog div a svg rect {
  fill: rgb(245, 245, 245);
  transition-duration: 0.5s;
}
#site-footer .footer-main .footer-blog div a:hover svg {
  margin-right: 8px;
}
#site-footer .footer-main .footer-blog div a:hover svg path, #site-footer .footer-main .footer-blog div a:hover svg rect {
  fill: rgb(11, 74, 107);
  transition-duration: 0.5s;
}
#site-footer .copyright {
  margin-top: 3.6603221083vw;
  text-align: center;
  color: rgb(245, 245, 245);
  line-height: 1;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #site-footer .copyright {
    margin-top: 4.8875855327vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #site-footer .copyright {
    margin-top: 5.170630817vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #site-footer .copyright {
    margin-top: 6.518904824vw;
  }
}
@media (max-width: 479px) {
  #site-footer .copyright {
    margin-top: 10.4384133612vw;
  }
}
#site-footer .copyright small {
  font-size: 0.75rem;
}

.page-particular_about #site-header .header-nav .nav-menu .menu-item a, .category-pickup #site-header .header-nav .nav-menu .menu-item a, .category-casestudy #site-header .header-nav .nav-menu .menu-item a, .page-recruit #site-header .header-nav .nav-menu .menu-item a {
  color: rgb(35, 35, 35);
}

.loading #loader-bg {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0px;
  left: 0px;
  background: rgb(245, 245, 245);
  z-index: 999;
}
.loading #loader {
  position: fixed;
  top: 50%;
  left: 50%;
  width: 200px;
  height: 200px;
  margin-top: -100px;
  margin-left: -100px;
  text-align: center;
  color: #fff;
  z-index: 1000;
}

.loaded #loader-bg, .loaded #loader {
  display: none !important;
}

/*モーダルを開くボタン*/
.modal-open {
  cursor: pointer;
}

/*モーダル本体の指定 + モーダル外側の背景の指定*/
.modal-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  background: rgba(0, 0, 0, 0.7);
  padding: 40px 20px;
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  transition: 0.3s;
  box-sizing: border-box;
  z-index: 999;
  /*モーダル本体の擬似要素の指定*/
  /*モーダル本体に「active」クラス付与した時のスタイル*/
}
.modal-container:before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  height: 100%;
}
@media (max-width: 479px) {
  .modal-container:before {
    height: initial;
  }
}
.modal-container.active {
  opacity: 1;
  visibility: visible;
}

/*モーダル枠の指定*/
.modal-body {
  position: relative;
  display: inline-block;
  vertical-align: middle;
  max-width: 960px;
  width: 100%;
  padding: 50px 20px;
}
@media (max-width: 479px) {
  .modal-body {
    padding: 0;
  }
}
.modal-body header {
  margin-bottom: 60px;
}
.modal-body header p {
  line-height: 1.8;
  font-weight: 300;
}
@media (max-width: 479px) {
  .modal-body header p {
    text-align: left !important;
  }
}
.modal-body ul {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.modal-body ul li {
  width: 50%;
  padding-left: 10px;
  padding-right: 10px;
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  position: relative;
  margin-bottom: 60px;
}
@media (max-width: 479px) {
  .modal-body ul li {
    width: 100%;
  }
}
.modal-body ul li figure {
  margin-bottom: 30px;
  height: 100%;
}
.modal-body ul li a {
  display: flex;
  justify-content: center;
  text-align: center;
  width: 100%;
  max-width: 300px;
  margin-left: auto;
  margin-right: auto;
  background-color: rgb(11, 74, 107);
  padding: 15px 20px;
  color: rgb(245, 245, 245);
  font-weight: 700;
}
@media (max-width: 479px) {
  .modal-body ul li a {
    position: initial;
    padding: 10px;
    list-style: 1.7;
  }
}
.modal-body ul li a:hover {
  color: rgb(35, 35, 35);
  text-decoration: none;
}

/*モーダルを閉じるボタンの指定*/
.modal-close {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  top: 30px;
  right: 0px;
  width: 40px;
  height: 40px;
  font-size: 36px;
  color: rgb(245, 245, 245);
  background-color: rgb(11, 74, 107);
  border-radius: 50%;
  padding-bottom: 2px;
  cursor: pointer;
  z-index: 10;
}
@media (max-width: 479px) {
  .modal-close {
    top: 0px;
  }
}

/*モーダル内のコンテンツの指定*/
.modal-content {
  height: 75vh;
}
@media (max-width: 479px) {
  .modal-content {
    height: 60vh;
  }
}
@media (max-width: 479px) {
  .modal-content {
    padding: 20px;
  }
}
.modal-content .swiper-slide img {
  max-height: 75vh;
}
@media (max-width: 479px) {
  .modal-content .swiper-slide img {
    max-height: 60vh;
  }
}

.btn-area {
  margin-top: 5em;
}
@media (max-width: 1023px) {
  .btn-area {
    margin-top: 3em;
  }
}

.single-post .more {
  margin-top: 7.3206442167vw;
  margin-bottom: 14.6412884334vw;
  text-align: center;
}
@media (min-width: 968px) and (max-width: 1023px) {
  .single-post .more {
    margin-top: 9.7751710655vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .single-post .more {
    margin-top: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .single-post .more {
    margin-top: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  .single-post .more {
    margin-top: 15.6576200418vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  .single-post .more {
    margin-bottom: 19.550342131vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .single-post .more {
    margin-bottom: 20.6825232678vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .single-post .more {
    margin-bottom: 26.075619296vw;
  }
}
@media (max-width: 479px) {
  .single-post .more {
    margin-bottom: 19.624217119vw;
  }
}
.single-post .more .btn .btn_more {
  background: rgb(11, 74, 107);
  color: rgb(245, 245, 245);
  border: 1px solid rgb(11, 74, 107);
  margin-left: auto;
  margin-right: auto;
  width: 250px;
  height: 58px;
  text-align: center;
  display: block;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (min-width: 768px) and (max-width: 967px) {
  .single-post .more .btn .btn_more {
    width: 250px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .single-post .more .btn .btn_more {
    width: 250px;
  }
}
.single-post .more .btn .btn_more:hover {
  background: rgb(245, 245, 245);
  color: rgb(11, 74, 107);
}
.single-post .outline .size-auto, .post-single .single-wrapper .size-auto, #aboutus #about-welcome .welcome--content .text .text--position .size-auto,
.single-post .outline .size-full,
.post-single .single-wrapper .size-full,
#aboutus #about-welcome .welcome--content .text .text--position .size-full,
.single-post .outline .size-large,
.post-single .single-wrapper .size-large,
#aboutus #about-welcome .welcome--content .text .text--position .size-large,
.single-post .outline .size-medium,
.post-single .single-wrapper .size-medium,
#aboutus #about-welcome .welcome--content .text .text--position .size-medium,
.single-post .outline .size-thumbnail,
.post-single .single-wrapper .size-thumbnail,
#aboutus #about-welcome .welcome--content .text .text--position .size-thumbnail {
  max-width: 100%;
  height: auto;
}
.single-post .outline .alignleft, .post-single .single-wrapper .alignleft, #aboutus #about-welcome .welcome--content .text .text--position .alignleft {
  float: left;
  margin: 0 1.5em 0.8em 0;
}
.single-post .outline .alignright, .post-single .single-wrapper .alignright, #aboutus #about-welcome .welcome--content .text .text--position .alignright {
  float: right;
  margin: 0 0 0.8em 1.5em;
}
.single-post .outline .aligncenter, .post-single .single-wrapper .aligncenter, #aboutus #about-welcome .welcome--content .text .text--position .aligncenter {
  display: block;
  margin: 2em auto;
}
.single-post .outline .alignnone, .post-single .single-wrapper .alignnone, #aboutus #about-welcome .welcome--content .text .text--position .alignnone {
  max-width: 100%;
}
.single-post .outline .more-link, .post-single .single-wrapper .more-link, #aboutus #about-welcome .welcome--content .text .text--position .more-link {
  display: inline-block;
  margin-top: 0.8em;
}
.single-post .outline .clear-float, .post-single .single-wrapper .clear-float, #aboutus #about-welcome .welcome--content .text .text--position .clear-float {
  clear: both;
}
.single-post .outline .wp-caption, .post-single .single-wrapper .wp-caption, #aboutus #about-welcome .welcome--content .text .text--position .wp-caption {
  max-width: 100%;
}
.single-post .outline .wp-caption .wp-caption-text, .post-single .single-wrapper .wp-caption .wp-caption-text, #aboutus #about-welcome .welcome--content .text .text--position .wp-caption .wp-caption-text {
  max-width: 100%;
}
.single-post .outline p, .post-single .single-wrapper p, #aboutus #about-welcome .welcome--content .text .text--position p {
  margin-top: 1.65em;
}
.single-post .outline p:first-child, .post-single .single-wrapper p:first-child, #aboutus #about-welcome .welcome--content .text .text--position p:first-child {
  margin-top: 0;
}
.single-post .outline ul, .post-single .single-wrapper ul, #aboutus #about-welcome .welcome--content .text .text--position ul, .single-post .outline ol, .post-single .single-wrapper ol, #aboutus #about-welcome .welcome--content .text .text--position ol {
  margin: 1.8em 0;
  padding-left: 3em;
}
.single-post .outline ul ul, .post-single .single-wrapper ul ul, #aboutus #about-welcome .welcome--content .text .text--position ul ul, .single-post .outline ul ol, .post-single .single-wrapper ul ol, #aboutus #about-welcome .welcome--content .text .text--position ul ol, .single-post .outline ol ul, .post-single .single-wrapper ol ul, #aboutus #about-welcome .welcome--content .text .text--position ol ul, .single-post .outline ol ol, .post-single .single-wrapper ol ol, #aboutus #about-welcome .welcome--content .text .text--position ol ol {
  margin: 0.6em 0;
  padding-left: 2em;
}
.single-post .outline ul li, .post-single .single-wrapper ul li, #aboutus #about-welcome .welcome--content .text .text--position ul li {
  list-style-type: circle;
}
.single-post .outline table, .post-single .single-wrapper table, #aboutus #about-welcome .welcome--content .text .text--position table {
  width: 100%;
  margin: 3em 0;
  border-width: 1px 0 0 1px;
  border-style: solid;
  border-color: rgb(241, 241, 241);
}
.single-post .outline table tr th, .post-single .single-wrapper table tr th, #aboutus #about-welcome .welcome--content .text .text--position table tr th, .single-post .outline table tr td, .post-single .single-wrapper table tr td, #aboutus #about-welcome .welcome--content .text .text--position table tr td {
  padding: 0.5em 0.8em 0.45em;
  border-width: 0 1px 1px 0;
  border-style: solid;
  border-color: rgb(241, 241, 241);
  line-height: 1.4;
}
.single-post .outline table tr th, .post-single .single-wrapper table tr th, #aboutus #about-welcome .welcome--content .text .text--position table tr th {
  font-weight: bold;
}
.single-post .outline table tr td p, .post-single .single-wrapper table tr td p, #aboutus #about-welcome .welcome--content .text .text--position table tr td p {
  margin-top: 0.5em;
}

#concept .flex {
  height: 36.6032210835vw;
  justify-content: space-between;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #concept .flex {
    height: 48.8758553275vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #concept .flex {
    height: 51.7063081696vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #concept .flex {
    height: 65.1890482399vw;
  }
}
@media (max-width: 479px) {
  #concept .flex {
    height: 104.3841336117vw;
  }
}
@media (max-width: 479px) {
  #concept .flex {
    flex-direction: column;
    height: initial;
  }
}
#concept .vision {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: rgb(11, 74, 107);
  width: 50%;
  position: relative;
}
#concept .vision h2 {
  color: rgb(245, 245, 245);
  line-height: 2.7;
}
@media (max-width: 479px) {
  #concept .vision h2 {
    line-height: 1.6;
  }
}
#concept .vision:before {
  content: "";
  position: absolute;
  width: 100vw;
  height: 100%;
  background-color: rgb(11, 74, 107);
  left: -99vw;
}
@media (max-width: 479px) {
  #concept .vision {
    width: 100%;
    padding-top: 30px;
    padding-bottom: 30px;
  }
  #concept .vision:after {
    content: "";
    position: absolute;
    width: 100vw;
    height: 100%;
    background-color: rgb(11, 74, 107);
    right: -99vw;
  }
}
#concept .visiontext {
  width: 47%;
  max-width: 630px;
  display: flex;
  justify-content: center;
  align-items: center;
  line-height: 2.1;
  font-size: clamp(11px, 1.653vw, 16px);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #concept .visiontext {
    font-size: clamp(11px, 1.55vw, 15px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #concept .visiontext {
    font-size: clamp(13px, 1.953vw, 15px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #concept .visiontext {
    font-size: clamp(16px, 3.125vw, 15px);
  }
}
@media (max-width: 479px) {
  #concept .visiontext {
    font-size: clamp(10px, 3.125vw, 15px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #concept .visiontext {
    padding-top: 30px;
    padding-bottom: 30px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #concept .visiontext {
    padding-top: 30px;
    padding-bottom: 30px;
  }
}
@media (max-width: 479px) {
  #concept .visiontext {
    width: 100%;
    padding-top: 30px;
    padding-bottom: 30px;
  }
}

#home-casestudy .wrapper {
  padding-right: 0;
  overflow-x: visible;
}
@media (max-width: 479px) {
  #home-casestudy .wrapper {
    padding-right: 25px;
    margin-top: 60px;
  }
}
#home-casestudy .grid {
  display: grid;
  grid-template-columns: 439px 1fr;
  gap: 0;
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-casestudy .grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-casestudy .grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
  }
}
@media (max-width: 479px) {
  #home-casestudy .grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
  }
}
#home-casestudy .title {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  background-image: url(/wp-content/themes/fujiikogyo/img/common/bg-koshi.png);
  background-size: contain;
  background-repeat: repeat;
}
#home-casestudy .title:before {
  content: "";
  position: absolute;
  left: -100vw;
  top: 0;
  width: 100vw;
  z-index: -1;
  height: 100%;
  background-image: url(/wp-content/themes/fujiikogyo/img/common/bg-koshi.png);
  background-size: contain;
  background-repeat: repeat;
}
#home-casestudy .title .title-wrap {
  width: 80%;
  padding-bottom: 30px;
  position: relative;
}
#home-casestudy .title .title-wrap .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-casestudy .title .title-wrap .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-casestudy .title .title-wrap .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-casestudy .title .title-wrap .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #home-casestudy .title .title-wrap .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-casestudy .title .title-wrap .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #home-casestudy .title .title-wrap .sec-title {
    text-align: left;
  }
}
#home-casestudy .title .title-wrap .sec-title:before, #home-casestudy .title .title-wrap .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#home-casestudy .title .title-wrap .sec-title:before {
  left: 42%;
}
@media (max-width: 479px) {
  #home-casestudy .title .title-wrap .sec-title:before {
    left: 42%;
  }
}
#home-casestudy .title .title-wrap .sec-title:after {
  left: initial;
  right: 42%;
}
@media (max-width: 479px) {
  #home-casestudy .title .title-wrap .sec-title:after {
    left: initial;
    right: 42%;
  }
}
#home-casestudy .title .title-wrap .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(42% + 8px);
  right: calc(42% + 8px);
  width: initial;
  z-index: 1;
}
@media (max-width: 479px) {
  #home-casestudy .title .title-wrap .sec-title > span {
    left: calc(42% + 8px);
    right: calc(42% + 8px);
  }
}
@media (max-width: 479px) {
  #home-casestudy .title .title-wrap {
    width: 100%;
  }
}
#home-casestudy .title .title-wrap .btn {
  position: absolute;
  right: 0;
  bottom: 0;
  font-size: clamp(10px, 1.446vw, 14px);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-casestudy .title .title-wrap .btn {
    font-size: clamp(10px, 1.446vw, 14px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-casestudy .title .title-wrap .btn {
    font-size: clamp(12px, 1.823vw, 14px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-casestudy .title .title-wrap .btn {
    font-size: clamp(15px, 2.917vw, 14px);
  }
}
@media (max-width: 479px) {
  #home-casestudy .title .title-wrap .btn {
    font-size: clamp(9px, 2.917vw, 14px);
  }
}
#home-casestudy .title .title-wrap .btn a {
  position: relative;
  color: rgb(35, 35, 35);
}
#home-casestudy .title .title-wrap .btn a:before {
  content: "";
  position: absolute;
  width: 100%;
  height: 1px;
  background-color: rgb(35, 35, 35);
  left: 0;
  bottom: -3px;
}
#home-casestudy .title .title-wrap .btn a:after {
  content: "";
  position: absolute;
  right: -8px;
  bottom: -5.2px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 3px 0 4px 8px;
  border-color: transparent transparent transparent rgb(35, 35, 35);
  transform: rotate(26deg);
}
#home-casestudy .title .title-wrap .btn a:hover {
  color: rgb(11, 74, 107);
}
#home-casestudy .title .title-wrap .btn a:hover:before {
  background-color: rgb(11, 74, 107);
}
#home-casestudy .title .title-wrap .btn a:hover:after {
  border-color: transparent transparent transparent rgb(11, 74, 107);
}
#home-casestudy .study-item {
  overflow: hidden;
  width: 66vw;
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-casestudy .study-item {
    width: 50vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-casestudy .study-item {
    width: 100%;
    margin-top: 60px;
  }
}
@media (max-width: 479px) {
  #home-casestudy .study-item {
    width: 100%;
    margin-top: 60px;
  }
}
#home-casestudy .study-item .swiper {
  overflow: visible;
}
#home-casestudy .study-item .swiper .swiper-slide {
  width: 25.826446281vw;
}
@media (max-width: 479px) {
  #home-casestudy .study-item .swiper .swiper-slide {
    width: 52.1920668058vw;
  }
}
#home-casestudy .study-item .swiper .swiper-slide a {
  width: 100%;
  position: relative;
}
#home-casestudy .study-item .swiper .swiper-slide a .item-info {
  opacity: 0;
  position: absolute;
  margin: 2.0661157025vw;
  display: flex;
  justify-content: center;
  align-items: center;
  height: calc(100% - 4.132231405vw);
  width: calc(100% - 4.132231405vw);
  z-index: 2;
  background-color: rgba(0, 0, 0, 0.6);
  transition-duration: 0.5s;
}
@media (max-width: 479px) {
  #home-casestudy .study-item .swiper .swiper-slide a .item-info {
    margin: 4.1753653445vw;
    height: calc(100% - 8.3507306889vw);
    width: calc(100% - 8.3507306889vw);
  }
}
#home-casestudy .study-item .swiper .swiper-slide a .item-info .infobox {
  margin: 2.0661157025vw;
  color: white;
}
@media (max-width: 479px) {
  #home-casestudy .study-item .swiper .swiper-slide a .item-info .infobox {
    margin: 4.1753653445vw;
  }
}
#home-casestudy .study-item .swiper .swiper-slide a .item-info .infobox h3 {
  text-align: center;
  margin-bottom: 20px;
}
#home-casestudy .study-item .swiper .swiper-slide a .item-info .infobox .text .colabo {
  font-size: clamp(10px, 1.446vw, 14px);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-casestudy .study-item .swiper .swiper-slide a .item-info .infobox .text .colabo {
    font-size: clamp(10px, 1.446vw, 14px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-casestudy .study-item .swiper .swiper-slide a .item-info .infobox .text .colabo {
    font-size: clamp(12px, 1.823vw, 14px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-casestudy .study-item .swiper .swiper-slide a .item-info .infobox .text .colabo {
    font-size: clamp(15px, 2.917vw, 14px);
  }
}
@media (max-width: 479px) {
  #home-casestudy .study-item .swiper .swiper-slide a .item-info .infobox .text .colabo {
    font-size: clamp(9px, 2.917vw, 14px);
  }
}
#home-casestudy .study-item .swiper .swiper-slide a .item-info .infobox .text .feature {
  font-size: clamp(10px, 1.446vw, 14px);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-casestudy .study-item .swiper .swiper-slide a .item-info .infobox .text .feature {
    font-size: clamp(10px, 1.446vw, 14px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-casestudy .study-item .swiper .swiper-slide a .item-info .infobox .text .feature {
    font-size: clamp(12px, 1.823vw, 14px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-casestudy .study-item .swiper .swiper-slide a .item-info .infobox .text .feature {
    font-size: clamp(15px, 2.917vw, 14px);
  }
}
@media (max-width: 479px) {
  #home-casestudy .study-item .swiper .swiper-slide a .item-info .infobox .text .feature {
    font-size: clamp(9px, 2.917vw, 14px);
  }
}
#home-casestudy .study-item .swiper .swiper-slide a figure {
  position: relative;
  width: 100%;
  height: 30.9917355372vw;
  margin: 0 auto;
}
@media (max-width: 479px) {
  #home-casestudy .study-item .swiper .swiper-slide a figure {
    height: 52.1920668058vw;
  }
}
#home-casestudy .study-item .swiper .swiper-slide a figure img {
  object-fit: cover;
  position: absolute;
  width: 100%;
  height: 100%;
}
#home-casestudy .study-item .swiper .swiper-slide a:hover .item-info {
  opacity: 1;
  transition-duration: 0.5s;
}
#home-casestudy .study-item .swiper .swiper-slide a:hover figure img {
  transform: scale(1.05);
  transition-duration: 0.5s;
}
#home-casestudy .study-item .swiper-button-white {
  color: rgb(245, 245, 245);
  width: 30px;
  height: 30px;
  bottom: 10%;
  top: initial;
  right: initial;
}
@media (max-width: 479px) {
  #home-casestudy .study-item .swiper-button-white {
    width: 50px;
    height: 50px;
  }
}
#home-casestudy .study-item .swiper-button-white:after {
  font-size: clamp(14px, 2.066vw, 20px);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-casestudy .study-item .swiper-button-white:after {
    font-size: clamp(14px, 2.066vw, 20px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-casestudy .study-item .swiper-button-white:after {
    font-size: clamp(17px, 2.604vw, 20px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-casestudy .study-item .swiper-button-white:after {
    font-size: clamp(21px, 4.167vw, 20px);
  }
}
@media (max-width: 479px) {
  #home-casestudy .study-item .swiper-button-white:after {
    font-size: clamp(13px, 4.167vw, 20px);
  }
}
#home-casestudy .study-item .swiper-button-white.swiper-button-prev {
  left: 10px;
}
#home-casestudy .study-item .swiper-button-white.swiper-button-next {
  left: 40px;
}
@media (max-width: 479px) {
  #home-casestudy .study-item .swiper-button-white.swiper-button-next {
    left: 60px;
  }
}
#home-casestudy .study-item .swiper-scrollbar {
  bottom: 5%;
  background: rgba(255, 255, 255, 0.2);
  z-index: 99;
}
@media (max-width: 479px) {
  #home-casestudy .study-item .swiper-scrollbar {
    bottom: 10%;
  }
}
#home-casestudy .study-item .swiper-scrollbar .swiper-scrollbar-drag {
  height: 30px;
  width: 30px !important;
  position: relative;
  border: 5px solid white;
  opacity: 0.8;
  border-radius: 50%;
  left: 0;
  top: -12.5px;
  cursor: pointer;
  background: transparent;
}

#interview .interview-head {
  position: relative;
  padding-top: 10.541727672vw;
  padding-bottom: 10.541727672vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #interview .interview-head {
    padding-top: 14.0762463343vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .interview-head {
    padding-top: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .interview-head {
    padding-top: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  #interview .interview-head {
    padding-top: 18.7891440501vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #interview .interview-head {
    padding-bottom: 14.0762463343vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .interview-head {
    padding-bottom: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .interview-head {
    padding-bottom: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  #interview .interview-head {
    padding-bottom: 18.7891440501vw;
  }
}
#interview .interview-head:before {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  width: 50%;
  z-index: -1;
  height: 100%;
  background-image: url(/wp-content/themes/fujiikogyo/img/common/bg-koshi2.png);
  background-size: contain;
  background-repeat: repeat;
}
#interview .interview-head:after {
  content: "";
  position: absolute;
  right: -50%;
  top: 0;
  width: 50vw;
  z-index: -1;
  height: 100%;
  background-image: url(/wp-content/themes/fujiikogyo/img/common/bg-koshi2.png);
  background-size: contain;
  background-repeat: repeat;
}
#interview .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #interview .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #interview .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #interview .sec-title {
    text-align: left;
  }
}
#interview .sec-title:before, #interview .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#interview .sec-title:before {
  left: 30%;
}
@media (max-width: 479px) {
  #interview .sec-title:before {
    left: 30%;
  }
}
#interview .sec-title:after {
  left: initial;
  right: 30%;
}
@media (max-width: 479px) {
  #interview .sec-title:after {
    left: initial;
    right: 30%;
  }
}
#interview .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(30% + 8px);
  right: calc(30% + 8px);
  width: initial;
  z-index: 1;
}
@media (max-width: 479px) {
  #interview .sec-title > span {
    left: calc(30% + 8px);
    right: calc(30% + 8px);
  }
}
#interview h2 {
  text-align: center;
  margin-bottom: 6.588579795vw;
  display: inline-block;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #interview h2 {
    margin-bottom: 8.7976539589vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview h2 {
    margin-bottom: 9.3071354705vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview h2 {
    margin-bottom: 11.7340286832vw;
  }
}
@media (max-width: 479px) {
  #interview h2 {
    margin-bottom: 6.2630480167vw;
  }
}
#interview .text {
  padding-top: 7.5402635432vw;
  width: 68.3016105417vw;
  max-width: 933px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #interview .text {
    padding-top: 10.0684261975vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .text {
    padding-top: 10.6514994829vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .text {
    padding-top: 13.4289439374vw;
  }
}
@media (max-width: 479px) {
  #interview .text {
    padding-top: 6.2630480167vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #interview .text {
    width: 91.2023460411vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .text {
    width: 96.4839710445vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .text {
    width: 121.6427640156vw;
  }
}
@media (max-width: 479px) {
  #interview .text {
    width: 73.0688935282vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #interview .text {
    max-width: 933px;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .text {
    max-width: 933px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .text {
    max-width: 933px;
  }
}
@media (max-width: 479px) {
  #interview .text {
    max-width: 450px;
  }
}
@media (min-width: 480px) {
  #interview .text {
    text-align: center;
  }
}
#interview .interview--item {
  display: flex;
  justify-content: center;
  margin-bottom: 9.9560761347vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #interview .interview--item {
    margin-bottom: 13.2942326491vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .interview--item {
    margin-bottom: 14.0641158221vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .interview--item {
    margin-bottom: 17.7314211213vw;
  }
}
@media (max-width: 479px) {
  #interview .interview--item {
    margin-bottom: 12.5260960334vw;
  }
}
@media (max-width: 479px) {
  #interview .interview--item {
    flex-direction: column;
  }
}
#interview .interview--item figure {
  width: calc(50vw - 40px);
  margin-right: 40px;
  height: 36.6032210835vw;
  overflow: hidden;
  position: relative;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #interview .interview--item figure {
    height: 48.8758553275vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .interview--item figure {
    height: 51.7063081696vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .interview--item figure {
    height: 65.1890482399vw;
  }
}
@media (max-width: 479px) {
  #interview .interview--item figure {
    height: 62.630480167vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .interview--item figure {
    width: calc(50% - 10px);
    margin-right: 10px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .interview--item figure {
    width: 100%;
  }
}
@media (max-width: 479px) {
  #interview .interview--item figure {
    width: 100%;
  }
}
#interview .interview--item figure img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#interview .interview--info {
  width: calc(50% - 40px);
  margin-left: 40px;
  position: relative;
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .interview--info {
    width: calc(50% - 10px);
    margin-left: 10px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .interview--info {
    width: 100%;
    margin-left: initial;
  }
}
@media (max-width: 479px) {
  #interview .interview--info {
    width: 100%;
    margin-left: initial;
  }
}
#interview .interview--info:before {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  width: 50vw;
  z-index: -1;
  height: 100%;
  background-image: url(/wp-content/themes/fujiikogyo/img/common/bg-koshi2.png);
  background-size: contain;
  background-repeat: repeat;
}
#interview .interview--info:after {
  content: "";
  position: absolute;
  right: -50vw;
  top: 0;
  width: 50vw;
  z-index: -1;
  height: 100%;
  background-image: url(/wp-content/themes/fujiikogyo/img/common/bg-koshi2.png);
  background-size: contain;
  background-repeat: repeat;
}
#interview .interview--info .interview--company {
  background-color: rgb(35, 35, 35);
  color: white;
  height: 6.8814055637vw;
  padding-left: 64px;
  margin-bottom: 4.39238653vw;
  display: flex;
  align-items: center;
  position: relative;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #interview .interview--info .interview--company {
    height: 9.1886608016vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .interview--info .interview--company {
    height: 9.7207859359vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .interview--info .interview--company {
    height: 12.2555410691vw;
  }
}
@media (max-width: 479px) {
  #interview .interview--info .interview--company {
    height: 18.7891440501vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #interview .interview--info .interview--company {
    padding-left: 64px;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .interview--info .interview--company {
    padding-left: 10px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .interview--info .interview--company {
    padding-left: 10px;
  }
}
@media (max-width: 479px) {
  #interview .interview--info .interview--company {
    padding-left: 30px;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #interview .interview--info .interview--company {
    margin-bottom: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .interview--info .interview--company {
    margin-bottom: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .interview--info .interview--company {
    margin-bottom: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #interview .interview--info .interview--company {
    margin-bottom: 6.2630480167vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .interview--info .interview--company {
    padding-right: 10px;
  }
}
#interview .interview--info .interview--company:after {
  content: "";
  position: absolute;
  right: -50%;
  width: 50vw;
  height: 100%;
  z-index: -1;
  background-color: rgb(35, 35, 35);
}
#interview .interview--info .interview--company h3 {
  font-size: clamp(19px, 2.789vw, 27px);
  letter-spacing: 0.05rem;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #interview .interview--info .interview--company h3 {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .interview--info .interview--company h3 {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .interview--info .interview--company h3 {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #interview .interview--info .interview--company h3 {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
#interview .interview--info .interview--company h3 span {
  font-size: clamp(11px, 1.653vw, 16px);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #interview .interview--info .interview--company h3 span {
    font-size: clamp(11px, 1.653vw, 16px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .interview--info .interview--company h3 span {
    font-size: clamp(13px, 2.083vw, 16px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .interview--info .interview--company h3 span {
    font-size: clamp(17px, 3.333vw, 16px);
  }
}
@media (max-width: 479px) {
  #interview .interview--info .interview--company h3 span {
    font-size: clamp(11px, 3.333vw, 16px);
  }
}
#interview .interview--info .interview--text {
  max-width: 635px;
  padding-left: 25px;
  padding-right: 25px;
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .interview--info .interview--text {
    padding-left: 25px;
    padding-right: 25px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .interview--info .interview--text {
    padding-left: 25px;
    padding-right: 25px;
  }
}
@media (max-width: 479px) {
  #interview .interview--info .interview--text {
    padding-left: 25px;
    padding-right: 25px;
  }
}
#interview .interview--item:nth-child(2n) {
  flex-direction: row-reverse;
}
@media (max-width: 479px) {
  #interview .interview--item:nth-child(2n) {
    flex-direction: column;
  }
}
#interview .interview--item:nth-child(2n) figure {
  margin-right: initial;
  margin-left: 40px;
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .interview--item:nth-child(2n) figure {
    width: calc(50% - 10px);
    margin-left: 10px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .interview--item:nth-child(2n) figure {
    margin-left: initial;
  }
}
@media (max-width: 479px) {
  #interview .interview--item:nth-child(2n) figure {
    margin-left: initial;
  }
}
#interview .interview--item:nth-child(2n) .interview--info {
  margin-left: initial;
  margin-right: 40px;
}
#interview .interview--item:nth-child(2n) .interview--info:before {
  right: initial;
  left: 0;
}
#interview .interview--item:nth-child(2n) .interview--info:after {
  right: initial;
  left: -50vw;
}
@media (min-width: 768px) and (max-width: 967px) {
  #interview .interview--item:nth-child(2n) .interview--info {
    width: calc(50% - 10px);
    margin-right: 10px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #interview .interview--item:nth-child(2n) .interview--info {
    width: 100%;
    margin-right: initial;
  }
}
@media (max-width: 479px) {
  #interview .interview--item:nth-child(2n) .interview--info {
    width: 100%;
    margin-right: initial;
  }
}
#interview .interview--item:nth-child(2n) .interview--info .interview--company {
  overflow: hidden;
}
#interview .interview--item:nth-child(2n) .interview--info .interview--company h3 {
  width: 100%;
  max-width: 635px;
  margin-right: 0;
  margin-left: auto;
}
#interview .interview--item:nth-child(2n) .interview--info .interview--text {
  width: 100%;
  max-width: 635px;
  margin-right: 0;
  margin-left: auto;
}
@media (max-width: 479px) {
  #interview .interview--item:nth-child(2n) .interview--info .interview--text {
    padding-left: 25px;
    padding-right: 25px;
  }
}

#home-pickup {
  padding: 5.8565153734vw 0;
  background-color: rgb(11, 74, 107);
  position: relative;
}
#home-pickup:after {
  content: "";
  position: absolute;
  width: 100%;
  height: 65%;
  bottom: 0;
  background-image: url(/wp-content/themes/fujiikogyo/img/common/bg-koshi_white.png);
  background-size: 50%;
  background-repeat: repeat;
  z-index: 0;
  opacity: 0.3;
}
#home-pickup .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-pickup .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-pickup .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-pickup .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #home-pickup .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-pickup .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #home-pickup .sec-title {
    text-align: left;
  }
}
#home-pickup .sec-title:before, #home-pickup .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(245, 245, 245);
  z-index: 2;
}
#home-pickup .sec-title:before {
  left: 30%;
}
@media (max-width: 479px) {
  #home-pickup .sec-title:before {
    left: 30%;
  }
}
#home-pickup .sec-title:after {
  left: initial;
  right: 30%;
}
@media (max-width: 479px) {
  #home-pickup .sec-title:after {
    left: initial;
    right: 30%;
  }
}
#home-pickup .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(245, 245, 245);
  bottom: -8px;
  left: calc(30% + 8px);
  right: calc(30% + 8px);
  width: initial;
  z-index: 1;
}
@media (max-width: 479px) {
  #home-pickup .sec-title > span {
    left: calc(30% + 8px);
    right: calc(30% + 8px);
  }
}
#home-pickup h2 {
  color: white;
  text-align: center;
  display: inline-block;
}
#home-pickup h2.sec-title {
  font-size: clamp(39px, 5.785vw, 56px);
  line-height: 1.4;
  margin-bottom: 6.588579795vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-pickup h2.sec-title {
    font-size: clamp(39px, 5.785vw, 56px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-pickup h2.sec-title {
    font-size: clamp(47px, 7.292vw, 56px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-pickup h2.sec-title {
    font-size: clamp(59px, 11.667vw, 56px);
  }
}
@media (max-width: 479px) {
  #home-pickup h2.sec-title {
    font-size: clamp(28px, 8.75vw, 42px);
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-pickup h2.sec-title {
    margin-bottom: 8.7976539589vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-pickup h2.sec-title {
    margin-bottom: 9.3071354705vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-pickup h2.sec-title {
    margin-bottom: 11.7340286832vw;
  }
}
@media (max-width: 479px) {
  #home-pickup h2.sec-title {
    margin-bottom: 6.2630480167vw;
  }
}
#home-pickup .wrapper {
  position: relative;
}
@media (max-width: 479px) {
  #home-pickup .wrapper {
    padding-bottom: 80px;
  }
}
#home-pickup .btn {
  position: absolute;
  right: 4.39238653vw;
  top: 4.39238653vw;
  z-index: 1;
  font-size: clamp(10px, 1.446vw, 14px);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-pickup .btn {
    font-size: clamp(10px, 1.446vw, 14px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-pickup .btn {
    font-size: clamp(12px, 1.823vw, 14px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-pickup .btn {
    font-size: clamp(15px, 2.917vw, 14px);
  }
}
@media (max-width: 479px) {
  #home-pickup .btn {
    font-size: clamp(9px, 2.917vw, 14px);
  }
}
@media (max-width: 479px) {
  #home-pickup .btn {
    top: initial;
    left: 4.39238653vw;
    bottom: 4.39238653vw;
    text-align: center;
  }
}
#home-pickup .btn a {
  position: relative;
  color: rgb(245, 245, 245);
}
#home-pickup .btn a:before {
  content: "";
  position: absolute;
  width: 100%;
  height: 1px;
  background-color: rgb(245, 245, 245);
  left: 0;
  bottom: -3px;
}
#home-pickup .btn a:after {
  content: "";
  position: absolute;
  right: -8px;
  bottom: -5.2px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 3px 0 4px 8px;
  border-color: transparent transparent transparent rgb(245, 245, 245);
  transform: rotate(26deg);
}
#home-pickup .btn a:hover {
  color: rgb(245, 245, 245);
}
#home-pickup .btn a:hover:before {
  background-color: rgb(245, 245, 245);
}
#home-pickup .btn a:hover:after {
  border-color: transparent transparent transparent rgb(245, 245, 245);
}
#home-pickup .post-list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 60px;
  position: relative;
  z-index: 1;
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-pickup .post-list {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 30px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-pickup .post-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
  }
}
@media (max-width: 479px) {
  #home-pickup .post-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
  }
}
@media (max-width: 479px) {
  #home-pickup .post-list .list-item {
    margin-top: 30px;
  }
}
#home-pickup .post-list .list-item .post-item-inner .post-item .thum {
  aspect-ratio: 3/2;
}
#home-pickup .post-list .list-item .post-item-inner .post-item .thum img {
  height: 100%;
}
#home-pickup .post-list .list-item .post-item-inner .post-item .text-area {
  color: rgb(245, 245, 245);
  margin-top: 25px;
}
#home-pickup .post-list .list-item .post-item-inner .post-item .text-area.black {
  color: rgb(35, 35, 35);
}
#home-pickup .post-list .list-item .post-item-inner .post-item .text-area .cat {
  padding: 3px 8px;
  margin-right: 10px;
}
#home-pickup .post-list .list-item .post-item-inner .post-item .text-area .cat.deals {
  border: 1px solid rgb(245, 245, 245);
  background-color: rgb(11, 74, 107);
  color: rgb(245, 245, 245);
}
#home-pickup .post-list .list-item .post-item-inner .post-item .text-area .cat.info {
  border: 1px solid rgb(245, 245, 245);
  background-color: rgb(245, 245, 245);
  color: rgb(35, 35, 35);
}
#home-pickup .post-list .list-item .post-item-inner .post-item .text-area .cat.event {
  border: 1px solid rgb(35, 35, 35);
  background-color: rgb(35, 35, 35);
  color: rgb(245, 245, 245);
}
#home-pickup .post-list .list-item .post-item-inner .post-item .post-title {
  margin-top: 15px;
}

#home-contact {
  padding: 5.8565153734vw 0;
  position: relative;
  background-color: rgb(241, 241, 241);
}
#home-contact:after {
  content: "";
  position: absolute;
  width: 100%;
  height: 70%;
  bottom: 0;
  background-image: url(/wp-content/themes/fujiikogyo/img/common/bg-koshi60.png);
  background-size: 50%;
  background-repeat: repeat;
  z-index: 0;
  opacity: 0.3;
}
#home-contact .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-contact .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-contact .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-contact .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #home-contact .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-contact .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #home-contact .sec-title {
    text-align: left;
  }
}
#home-contact .sec-title:before, #home-contact .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#home-contact .sec-title:before {
  left: 30%;
}
@media (max-width: 479px) {
  #home-contact .sec-title:before {
    left: 30%;
  }
}
#home-contact .sec-title:after {
  left: initial;
  right: 30%;
}
@media (max-width: 479px) {
  #home-contact .sec-title:after {
    left: initial;
    right: 30%;
  }
}
#home-contact .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(30% + 8px);
  right: calc(30% + 8px);
  width: initial;
  z-index: 1;
}
@media (max-width: 479px) {
  #home-contact .sec-title > span {
    left: calc(30% + 8px);
    right: calc(30% + 8px);
  }
}
#home-contact h2 {
  text-align: center;
  display: inline-block;
}
#home-contact h2.sec-title {
  font-size: clamp(39px, 5.785vw, 56px);
  line-height: 1.4;
  margin-bottom: 6.588579795vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-contact h2.sec-title {
    font-size: clamp(39px, 5.785vw, 56px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-contact h2.sec-title {
    font-size: clamp(47px, 7.292vw, 56px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-contact h2.sec-title {
    font-size: clamp(59px, 11.667vw, 56px);
  }
}
@media (max-width: 479px) {
  #home-contact h2.sec-title {
    font-size: clamp(28px, 8.75vw, 42px);
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-contact h2.sec-title {
    margin-bottom: 8.7976539589vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-contact h2.sec-title {
    margin-bottom: 9.3071354705vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-contact h2.sec-title {
    margin-bottom: 11.7340286832vw;
  }
}
@media (max-width: 479px) {
  #home-contact h2.sec-title {
    margin-bottom: 6.2630480167vw;
  }
}
#home-contact .wrapper .visiontext {
  display: flex;
  justify-content: center;
}
@media (max-width: 479px) {
  #home-contact .wrapper .visiontext {
    margin-top: 30px;
  }
}
#home-contact .wrapper .links {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0px;
  margin-top: 3.2942898975vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-contact .wrapper .links {
    margin-top: 4.3988269795vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-contact .wrapper .links {
    margin-top: 4.6535677353vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-contact .wrapper .links {
    margin-top: 5.8670143416vw;
  }
}
@media (max-width: 479px) {
  #home-contact .wrapper .links {
    margin-top: 6.2630480167vw;
  }
}
@media (max-width: 479px) {
  #home-contact .wrapper .links {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0px;
  }
}
#home-contact .wrapper .links .item {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding-top: 3.2942898975vw;
  padding-bottom: 3.2942898975vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-contact .wrapper .links .item {
    padding-top: 4.3988269795vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-contact .wrapper .links .item {
    padding-top: 4.6535677353vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-contact .wrapper .links .item {
    padding-top: 5.8670143416vw;
  }
}
@media (max-width: 479px) {
  #home-contact .wrapper .links .item {
    padding-top: 6.2630480167vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-contact .wrapper .links .item {
    padding-bottom: 4.3988269795vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-contact .wrapper .links .item {
    padding-bottom: 4.6535677353vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-contact .wrapper .links .item {
    padding-bottom: 5.8670143416vw;
  }
}
@media (max-width: 479px) {
  #home-contact .wrapper .links .item {
    padding-bottom: 6.2630480167vw;
  }
}
#home-contact .wrapper .links .item:nth-child(1) {
  border-right: 1px solid rgb(151, 151, 151);
}
@media (max-width: 479px) {
  #home-contact .wrapper .links .item:nth-child(1) {
    border: none;
  }
}
#home-contact .wrapper .links .item h4 {
  font-size: clamp(15px, 2.169vw, 21px);
  font-weight: 400;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-contact .wrapper .links .item h4 {
    font-size: clamp(15px, 2.169vw, 21px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-contact .wrapper .links .item h4 {
    font-size: clamp(17px, 2.734vw, 21px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-contact .wrapper .links .item h4 {
    font-size: clamp(23px, 4.375vw, 21px);
  }
}
@media (max-width: 479px) {
  #home-contact .wrapper .links .item h4 {
    font-size: clamp(14px, 4.375vw, 21px);
  }
}
#home-contact .wrapper .links .item .btn .btn_more {
  background: rgb(11, 74, 107);
  color: rgb(245, 245, 245);
  border: 1px solid rgb(11, 74, 107);
  margin-left: auto;
  margin-right: auto;
  width: 250px;
  height: 58px;
  text-align: center;
  display: block;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-contact .wrapper .links .item .btn .btn_more {
    width: 250px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-contact .wrapper .links .item .btn .btn_more {
    width: 250px;
  }
}
#home-contact .wrapper .links .item .btn .btn_more:hover {
  background: rgb(245, 245, 245);
  color: rgb(11, 74, 107);
}
#home-contact .wrapper .links .item .btn {
  margin-top: 40px;
  position: relative;
  z-index: 10;
}
#home-contact .wrapper .links .item .telephone {
  margin-top: 30px;
  border-top: 1px solid rgb(35, 35, 35);
  border-bottom: 1px solid rgb(35, 35, 35);
  padding-top: 10px;
  padding-bottom: 10px;
}
#home-contact .wrapper .links .item .telephone .tel {
  font-size: clamp(29px, 4.339vw, 42px);
  letter-spacing: 0.1rem;
  line-height: 1;
  padding-left: 30px;
  padding-right: 30px;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-contact .wrapper .links .item .telephone .tel {
    font-size: clamp(29px, 4.339vw, 42px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-contact .wrapper .links .item .telephone .tel {
    font-size: clamp(35px, 5.469vw, 42px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-contact .wrapper .links .item .telephone .tel {
    font-size: clamp(45px, 8.75vw, 42px);
  }
}
@media (max-width: 479px) {
  #home-contact .wrapper .links .item .telephone .tel {
    font-size: clamp(28px, 8.75vw, 42px);
  }
}

#home-content {
  position: relative;
  padding: 5.8565153734vw 0;
}
#home-content:before {
  content: "";
  position: absolute;
  width: 50%;
  top: 0;
  bottom: 0;
  left: 0;
  background-color: rgb(11, 74, 107);
  z-index: -1;
}
@media (max-width: 479px) {
  #home-content:before {
    bottom: 50%;
    right: 0;
    width: 100%;
  }
}
#home-content:after {
  content: "";
  position: absolute;
  width: 50%;
  top: 0;
  bottom: 0;
  right: 0;
  background-color: rgb(35, 35, 35);
  z-index: -1;
}
@media (max-width: 479px) {
  #home-content:after {
    top: 50%;
    left: 0;
    width: 100%;
  }
}
#home-content .wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
@media (max-width: 479px) {
  #home-content .wrapper {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0px;
  }
}
#home-content .wrapper .commitment, #home-content .wrapper .flow {
  width: 70.7174231332%;
  margin-left: auto;
  margin-right: auto;
  color: rgb(245, 245, 245);
}
#home-content .wrapper .commitment .btn .btn_more, #home-content .wrapper .flow .btn .btn_more {
  background: rgb(11, 74, 107);
  color: rgb(245, 245, 245);
  border: 1px solid rgb(11, 74, 107);
  margin-left: auto;
  margin-right: auto;
  width: 250px;
  height: 58px;
  text-align: center;
  display: block;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-content .wrapper .commitment .btn .btn_more, #home-content .wrapper .flow .btn .btn_more {
    width: 250px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-content .wrapper .commitment .btn .btn_more, #home-content .wrapper .flow .btn .btn_more {
    width: 250px;
  }
}
#home-content .wrapper .commitment .btn .btn_more:hover, #home-content .wrapper .flow .btn .btn_more:hover {
  background: rgb(245, 245, 245);
  color: rgb(11, 74, 107);
}
#home-content .wrapper .commitment .sec-title, #home-content .wrapper .flow .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #home-content .wrapper .commitment .sec-title, #home-content .wrapper .flow .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-content .wrapper .commitment .sec-title, #home-content .wrapper .flow .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-content .wrapper .commitment .sec-title, #home-content .wrapper .flow .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #home-content .wrapper .commitment .sec-title, #home-content .wrapper .flow .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-content .wrapper .commitment .sec-title, #home-content .wrapper .flow .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #home-content .wrapper .commitment .sec-title, #home-content .wrapper .flow .sec-title {
    text-align: left;
  }
}
#home-content .wrapper .commitment .sec-title:before, #home-content .wrapper .commitment .sec-title:after, #home-content .wrapper .flow .sec-title:before, #home-content .wrapper .flow .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(245, 245, 245);
  z-index: 2;
}
#home-content .wrapper .commitment .sec-title:before, #home-content .wrapper .flow .sec-title:before {
  left: 43%;
}
@media (max-width: 479px) {
  #home-content .wrapper .commitment .sec-title:before, #home-content .wrapper .flow .sec-title:before {
    left: 43%;
  }
}
#home-content .wrapper .commitment .sec-title:after, #home-content .wrapper .flow .sec-title:after {
  left: initial;
  right: 43%;
}
@media (max-width: 479px) {
  #home-content .wrapper .commitment .sec-title:after, #home-content .wrapper .flow .sec-title:after {
    left: initial;
    right: 43%;
  }
}
#home-content .wrapper .commitment .sec-title > span, #home-content .wrapper .flow .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(245, 245, 245);
  bottom: -8px;
  left: calc(43% + 8px);
  right: calc(43% + 8px);
  width: initial;
  z-index: 1;
}
@media (max-width: 479px) {
  #home-content .wrapper .commitment .sec-title > span, #home-content .wrapper .flow .sec-title > span {
    left: calc(43% + 8px);
    right: calc(43% + 8px);
  }
}
@media (max-width: 479px) {
  #home-content .wrapper .commitment, #home-content .wrapper .flow {
    width: 100%;
    padding-bottom: 60px;
  }
  #home-content .wrapper .commitment .sec-title, #home-content .wrapper .flow .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (max-width: 479px) and (min-width: 968px) and (max-width: 1023px) {
  #home-content .wrapper .commitment .sec-title, #home-content .wrapper .flow .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 768px) and (max-width: 967px) {
  #home-content .wrapper .commitment .sec-title, #home-content .wrapper .flow .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #home-content .wrapper .commitment .sec-title, #home-content .wrapper .flow .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #home-content .wrapper .commitment .sec-title, #home-content .wrapper .flow .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #home-content .wrapper .commitment .sec-title, #home-content .wrapper .flow .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #home-content .wrapper .commitment .sec-title, #home-content .wrapper .flow .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #home-content .wrapper .commitment .sec-title:before, #home-content .wrapper .commitment .sec-title:after, #home-content .wrapper .flow .sec-title:before, #home-content .wrapper .flow .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(245, 245, 245);
    z-index: 2;
  }
}
@media (max-width: 479px) {
  #home-content .wrapper .commitment .sec-title:before, #home-content .wrapper .flow .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #home-content .wrapper .commitment .sec-title:before, #home-content .wrapper .flow .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) {
  #home-content .wrapper .commitment .sec-title:after, #home-content .wrapper .flow .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #home-content .wrapper .commitment .sec-title:after, #home-content .wrapper .flow .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) {
  #home-content .wrapper .commitment .sec-title > span, #home-content .wrapper .flow .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(245, 245, 245);
    bottom: -8px;
    left: calc(40% + 8px);
    right: calc(40% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #home-content .wrapper .commitment .sec-title > span, #home-content .wrapper .flow .sec-title > span {
    left: calc(40% + 8px);
    right: calc(40% + 8px);
  }
}
#home-content .wrapper .commitment .sec-title, #home-content .wrapper .flow .sec-title {
  margin-bottom: 60px;
}
@media (max-width: 479px) {
  #home-content .wrapper .commitment .sec-title, #home-content .wrapper .flow .sec-title {
    margin-top: 30px;
    margin-bottom: 30px;
    text-align: center;
  }
}
@media (min-width: 480px) {
  #home-content .wrapper .commitment .text, #home-content .wrapper .flow .text {
    text-align: center;
  }
}
#home-content .wrapper .commitment .btn, #home-content .wrapper .flow .btn {
  margin-top: 40px;
  position: relative;
  z-index: 10;
}
@media (max-width: 479px) {
  #home-content .wrapper .commitment .btn, #home-content .wrapper .flow .btn {
    margin-bottom: 30px;
  }
}
#home-content .wrapper .commitment .btn .btn_more {
  background: rgb(35, 35, 35);
  color: rgb(245, 245, 245);
  border: 1px solid rgb(35, 35, 35);
  margin-left: auto;
  margin-right: auto;
  width: 250px;
  height: 58px;
  text-align: center;
  display: block;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (min-width: 768px) and (max-width: 967px) {
  #home-content .wrapper .commitment .btn .btn_more {
    width: 250px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #home-content .wrapper .commitment .btn .btn_more {
    width: 250px;
  }
}
#home-content .wrapper .commitment .btn .btn_more:hover {
  background: rgb(245, 245, 245);
  color: rgb(35, 35, 35);
}
#map {
  filter: grayscale(100%);
}
#map iframe {
  width: 100vw;
}
#map iframe #mapDiv .gm-style div div div {
  display: none;
}

#particular {
  margin-bottom: 7.3206442167vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #particular {
    margin-bottom: 9.7751710655vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #particular {
    margin-bottom: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #particular {
    margin-bottom: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  #particular {
    margin-bottom: 12.5260960334vw;
  }
}
#particular .content-start {
  padding-top: 7.3206442167vw;
  padding-left: 4.39238653vw;
  padding-right: 4.39238653vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #particular .content-start {
    padding-top: 9.7751710655vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #particular .content-start {
    padding-top: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #particular .content-start {
    padding-top: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  #particular .content-start {
    padding-top: 12.5260960334vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #particular .content-start {
    padding-left: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #particular .content-start {
    padding-left: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #particular .content-start {
    padding-left: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #particular .content-start {
    padding-left: 0vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #particular .content-start {
    padding-right: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #particular .content-start {
    padding-right: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #particular .content-start {
    padding-right: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #particular .content-start {
    padding-right: 0vw;
  }
}
#particular .particular-item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
}
@media (max-width: 479px) {
  #particular .particular-item {
    display: grid;
    grid-template-columns: 1fr;
    gap: 60px;
  }
}
#particular .particular-item .info h2 {
  margin-bottom: 4.39238653vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #particular .particular-item .info h2 {
    margin-bottom: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #particular .particular-item .info h2 {
    margin-bottom: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #particular .particular-item .info h2 {
    margin-bottom: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #particular .particular-item .info h2 {
    margin-bottom: 8.3507306889vw;
  }
}
#particular .particular-item figure {
  display: flex;
  align-items: flex-end;
}
#flow {
  margin-bottom: 7.3206442167vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow {
    margin-bottom: 9.7751710655vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow {
    margin-bottom: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow {
    margin-bottom: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  #flow {
    margin-bottom: 12.5260960334vw;
  }
}
#flow .content-start {
  padding-top: 7.3206442167vw;
  padding-left: 4.39238653vw;
  padding-right: 4.39238653vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .content-start {
    padding-top: 9.7751710655vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .content-start {
    padding-top: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .content-start {
    padding-top: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  #flow .content-start {
    padding-top: 12.5260960334vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .content-start {
    padding-left: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .content-start {
    padding-left: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .content-start {
    padding-left: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #flow .content-start {
    padding-left: 0vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .content-start {
    padding-right: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .content-start {
    padding-right: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .content-start {
    padding-right: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #flow .content-start {
    padding-right: 0vw;
  }
}
#flow .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #flow .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #flow .sec-title {
    text-align: left;
  }
}
#flow .sec-title:before, #flow .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#flow .sec-title:before {
  left: 0;
}
#flow .sec-title:after {
  left: 60px;
  right: initial;
}
#flow .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(0% + 8px);
  width: 52px;
  z-index: 1;
}
#flow .period {
  margin-top: 8.0527086384vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .period {
    margin-top: 10.752688172vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .period {
    margin-top: 11.3753877973vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .period {
    margin-top: 14.3415906128vw;
  }
}
@media (max-width: 479px) {
  #flow .period {
    margin-top: 14.6137787056vw;
  }
}
#flow .period .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .period .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .period .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .period .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #flow .period .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .period .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #flow .period .sec-title {
    text-align: left;
  }
}
#flow .period .sec-title:before, #flow .period .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#flow .period .sec-title:before {
  left: 47%;
}
@media (max-width: 479px) {
  #flow .period .sec-title:before {
    left: 47%;
  }
}
#flow .period .sec-title:after {
  left: initial;
  right: 47%;
}
@media (max-width: 479px) {
  #flow .period .sec-title:after {
    left: initial;
    right: 47%;
  }
}
#flow .period .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(47% + 8px);
  right: calc(47% + 8px);
  width: initial;
  z-index: 1;
}
@media (max-width: 479px) {
  #flow .period .sec-title > span {
    left: calc(47% + 8px);
    right: calc(47% + 8px);
  }
}
@media (max-width: 479px) {
  #flow .period .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (max-width: 479px) and (min-width: 968px) and (max-width: 1023px) {
  #flow .period .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 768px) and (max-width: 967px) {
  #flow .period .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #flow .period .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #flow .period .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #flow .period .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #flow .period .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #flow .period .sec-title:before, #flow .period .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (max-width: 479px) {
  #flow .period .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #flow .period .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) {
  #flow .period .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #flow .period .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) {
  #flow .period .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(40% + 8px);
    right: calc(40% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #flow .period .sec-title > span {
    left: calc(40% + 8px);
    right: calc(40% + 8px);
  }
}
#flow .period .sec-title {
  margin-bottom: 6.588579795vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .period .sec-title {
    margin-bottom: 8.7976539589vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .period .sec-title {
    margin-bottom: 9.3071354705vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .period .sec-title {
    margin-bottom: 11.7340286832vw;
  }
}
@media (max-width: 479px) {
  #flow .period .sec-title {
    margin-bottom: 12.5260960334vw;
  }
}
#flow .period figure img {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
#flow .flow-items {
  margin-top: 11.7130307467vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items {
    margin-top: 15.6402737048vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items {
    margin-top: 16.5460186143vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items {
    margin-top: 20.8604954368vw;
  }
}
@media (max-width: 479px) {
  #flow .flow-items {
    margin-top: 18.7891440501vw;
  }
}
#flow .flow-items .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #flow .flow-items .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .sec-title {
    text-align: left;
  }
}
#flow .flow-items .sec-title:before, #flow .flow-items .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#flow .flow-items .sec-title:before {
  left: 47%;
}
@media (max-width: 479px) {
  #flow .flow-items .sec-title:before {
    left: 47%;
  }
}
#flow .flow-items .sec-title:after {
  left: initial;
  right: 47%;
}
@media (max-width: 479px) {
  #flow .flow-items .sec-title:after {
    left: initial;
    right: 47%;
  }
}
#flow .flow-items .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(47% + 8px);
  right: calc(47% + 8px);
  width: initial;
  z-index: 1;
}
@media (max-width: 479px) {
  #flow .flow-items .sec-title > span {
    left: calc(47% + 8px);
    right: calc(47% + 8px);
  }
}
@media (max-width: 479px) {
  #flow .flow-items .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (max-width: 479px) and (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #flow .flow-items .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #flow .flow-items .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .sec-title:before, #flow .flow-items .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #flow .flow-items .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #flow .flow-items .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(40% + 8px);
    right: calc(40% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #flow .flow-items .sec-title > span {
    left: calc(40% + 8px);
    right: calc(40% + 8px);
  }
}
#flow .flow-items .flow-items-content {
  margin-top: 5.1244509517vw;
  display: grid;
  grid-template-columns: 170px 1fr;
  gap: 90px;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .flow-items-content {
    margin-top: 6.8426197458vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content {
    margin-top: 7.2388831437vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content {
    margin-top: 9.1264667536vw;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content {
    margin-top: 14.6137787056vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content {
    display: grid;
    grid-template-columns: 170px 1fr;
    gap: 40px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .flow-nav ul {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 0px 10px;
  }
}
#flow .flow-items .flow-items-content .flow-nav ul li {
  margin-bottom: 1.4641288433vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .flow-items-content .flow-nav ul li {
    margin-bottom: 1.9550342131vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content .flow-nav ul li {
    margin-bottom: 2.0682523268vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content .flow-nav ul li {
    margin-bottom: 2.6075619296vw;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .flow-nav ul li {
    margin-bottom: 4.1753653445vw;
  }
}
#flow .flow-items .flow-items-content .flow-nav ul li a {
  width: calc(100% - 24px);
  padding: 6px 12px;
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  background-color: rgb(11, 74, 107);
  color: rgb(245, 245, 245);
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .flow-nav ul li a {
    width: 100%;
    font-size: clamp(16px, 2.376vw, 23px);
  }
}
@media (max-width: 479px) and (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .flow-items-content .flow-nav ul li a {
    font-size: clamp(16px, 2.376vw, 23px);
  }
}
@media (max-width: 479px) and (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content .flow-nav ul li a {
    font-size: clamp(19px, 2.995vw, 23px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content .flow-nav ul li a {
    font-size: clamp(25px, 4.792vw, 23px);
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #flow .flow-items .flow-items-content .flow-nav ul li a {
    font-size: clamp(9px, 2.917vw, 14px);
  }
}
#flow .flow-items .flow-items-content .flow-nav ul li a p {
  border-bottom: 1px solid rgb(245, 245, 245);
  width: 90%;
  text-align: center;
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .flow-nav ul li a p {
    width: 100%;
  }
}
#flow .flow-items .flow-items-content .flow-nav ul li a.show_btn {
  position: relative;
}
#flow .flow-items .flow-items-content .flow-nav ul li a.show_btn.show:before {
  content: "";
  position: absolute;
  top: 50%;
  right: -4.39238653vw;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 7.5px 0 7.5px 12px;
  border-color: transparent transparent transparent rgb(11, 74, 107);
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .flow-nav ul li a.show_btn.show:before {
    display: none;
  }
}
#flow .flow-items .flow-items-content .item .part-item {
  padding-top: 5.8565153734vw;
  padding-left: 10.2489019034vw;
  padding-right: 10.2489019034vw;
  padding-bottom: 11.7130307467vw;
  background-color: rgb(241, 241, 241);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .flow-items-content .item .part-item {
    padding-top: 7.8201368524vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content .item .part-item {
    padding-top: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content .item .part-item {
    padding-top: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .item .part-item {
    padding-top: 8.3507306889vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .flow-items-content .item .part-item {
    padding-left: 13.6852394917vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content .item .part-item {
    padding-left: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content .item .part-item {
    padding-left: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .item .part-item {
    padding-left: 4.1753653445vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .flow-items-content .item .part-item {
    padding-right: 13.6852394917vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content .item .part-item {
    padding-right: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content .item .part-item {
    padding-right: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .item .part-item {
    padding-right: 4.1753653445vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .flow-items-content .item .part-item {
    padding-bottom: 15.6402737048vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content .item .part-item {
    padding-bottom: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content .item .part-item {
    padding-bottom: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .item .part-item {
    padding-bottom: 8.3507306889vw;
  }
}
#flow .flow-items .flow-items-content .item .part-item h3 {
  font-size: clamp(15px, 2.169vw, 21px);
  font-weight: 500;
  margin-bottom: 2.9282576867vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .flow-items-content .item .part-item h3 {
    font-size: clamp(15px, 2.169vw, 21px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content .item .part-item h3 {
    font-size: clamp(17px, 2.734vw, 21px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content .item .part-item h3 {
    font-size: clamp(23px, 4.375vw, 21px);
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .item .part-item h3 {
    font-size: clamp(14px, 4.375vw, 21px);
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .flow-items-content .item .part-item h3 {
    margin-bottom: 3.9100684262vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content .item .part-item h3 {
    margin-bottom: 4.1365046536vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content .item .part-item h3 {
    margin-bottom: 5.2151238592vw;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .item .part-item h3 {
    margin-bottom: 6.2630480167vw;
  }
}
#flow .flow-items .flow-items-content .item .part-item .content {
  padding: 2.9282576867vw;
  display: grid;
  grid-template-columns: 0.7fr 1fr;
  gap: 30px;
  background-color: white;
  position: relative;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .flow-items-content .item .part-item .content {
    padding: 3.9100684262vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content .item .part-item .content {
    padding: 4.1365046536vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content .item .part-item .content {
    padding: 5.2151238592vw;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .item .part-item .content {
    padding: 4.1753653445vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content .item .part-item .content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 30px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content .item .part-item .content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 30px;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .item .part-item .content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 30px;
  }
}
#flow .flow-items .flow-items-content .item .part-item .content .construction {
  position: absolute;
  top: -3.6603221083vw;
  right: -3.6603221083vw;
  width: 7.3206442167vw;
  max-width: 100;
  height: 7.3206442167vw;
  max-height: 100;
  background-color: rgb(11, 74, 107);
  color: white;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  line-height: 1.4;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    top: -4.8875855327vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    top: -5.170630817vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    top: -6.518904824vw;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    top: -6.2630480167vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    right: -4.8875855327vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    right: -5.170630817vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    right: -6.518904824vw;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    right: -6.2630480167vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    width: 9.7751710655vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    width: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    width: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    width: 18.7891440501vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    max-width: 100;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    max-width: 100;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    max-width: 100;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    max-width: 90;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    height: 9.7751710655vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    height: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    height: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    height: 18.7891440501vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    max-height: 100;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    max-height: 100;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    max-height: 100;
  }
}
@media (max-width: 479px) {
  #flow .flow-items .flow-items-content .item .part-item .content .construction {
    max-height: 90;
  }
}

#recruit {
  margin-bottom: 7.3206442167vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #recruit {
    margin-bottom: 9.7751710655vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #recruit {
    margin-bottom: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit {
    margin-bottom: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  #recruit {
    margin-bottom: 12.5260960334vw;
  }
}
#recruit .content-start {
  padding-top: 7.3206442167vw;
  padding-left: 4.39238653vw;
  padding-right: 4.39238653vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #recruit .content-start {
    padding-top: 9.7751710655vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #recruit .content-start {
    padding-top: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit .content-start {
    padding-top: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  #recruit .content-start {
    padding-top: 12.5260960334vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #recruit .content-start {
    padding-left: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #recruit .content-start {
    padding-left: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit .content-start {
    padding-left: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #recruit .content-start {
    padding-left: 0vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #recruit .content-start {
    padding-right: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #recruit .content-start {
    padding-right: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit .content-start {
    padding-right: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #recruit .content-start {
    padding-right: 0vw;
  }
}
#recruit .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #recruit .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #recruit .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #recruit .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #recruit .sec-title {
    text-align: left;
  }
}
#recruit .sec-title:before, #recruit .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#recruit .sec-title:before {
  left: 0;
}
#recruit .sec-title:after {
  left: 60px;
  right: initial;
}
#recruit .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(0% + 8px);
  width: 52px;
  z-index: 1;
}
#recruit .period {
  margin-top: 8.0527086384vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #recruit .period {
    margin-top: 10.752688172vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #recruit .period {
    margin-top: 11.3753877973vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit .period {
    margin-top: 14.3415906128vw;
  }
}
@media (max-width: 479px) {
  #recruit .period {
    margin-top: 14.6137787056vw;
  }
}
#recruit .period .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #recruit .period .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #recruit .period .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit .period .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #recruit .period .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit .period .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #recruit .period .sec-title {
    text-align: left;
  }
}
#recruit .period .sec-title:before, #recruit .period .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#recruit .period .sec-title:before {
  left: 47%;
}
@media (max-width: 479px) {
  #recruit .period .sec-title:before {
    left: 47%;
  }
}
#recruit .period .sec-title:after {
  left: initial;
  right: 47%;
}
@media (max-width: 479px) {
  #recruit .period .sec-title:after {
    left: initial;
    right: 47%;
  }
}
#recruit .period .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(47% + 8px);
  right: calc(47% + 8px);
  width: initial;
  z-index: 1;
}
@media (max-width: 479px) {
  #recruit .period .sec-title > span {
    left: calc(47% + 8px);
    right: calc(47% + 8px);
  }
}
@media (max-width: 479px) {
  #recruit .period .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (max-width: 479px) and (min-width: 968px) and (max-width: 1023px) {
  #recruit .period .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 768px) and (max-width: 967px) {
  #recruit .period .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #recruit .period .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #recruit .period .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #recruit .period .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #recruit .period .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #recruit .period .sec-title:before, #recruit .period .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (max-width: 479px) {
  #recruit .period .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #recruit .period .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) {
  #recruit .period .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #recruit .period .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) {
  #recruit .period .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(40% + 8px);
    right: calc(40% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #recruit .period .sec-title > span {
    left: calc(40% + 8px);
    right: calc(40% + 8px);
  }
}
#recruit .period .sec-title {
  margin-bottom: 6.588579795vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #recruit .period .sec-title {
    margin-bottom: 8.7976539589vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #recruit .period .sec-title {
    margin-bottom: 9.3071354705vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit .period .sec-title {
    margin-bottom: 11.7340286832vw;
  }
}
@media (max-width: 479px) {
  #recruit .period .sec-title {
    margin-bottom: 12.5260960334vw;
  }
}
#recruit .period figure img {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
#recruit .recruit-items {
  margin-top: 11.7130307467vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #recruit .recruit-items {
    margin-top: 15.6402737048vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #recruit .recruit-items {
    margin-top: 16.5460186143vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit .recruit-items {
    margin-top: 20.8604954368vw;
  }
}
@media (max-width: 479px) {
  #recruit .recruit-items {
    margin-top: 18.7891440501vw;
  }
}
#recruit .recruit-items .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #recruit .recruit-items .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #recruit .recruit-items .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit .recruit-items .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #recruit .recruit-items .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit .recruit-items .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #recruit .recruit-items .sec-title {
    text-align: left;
  }
}
#recruit .recruit-items .sec-title:before, #recruit .recruit-items .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#recruit .recruit-items .sec-title:before {
  left: 47%;
}
@media (max-width: 479px) {
  #recruit .recruit-items .sec-title:before {
    left: 47%;
  }
}
#recruit .recruit-items .sec-title:after {
  left: initial;
  right: 47%;
}
@media (max-width: 479px) {
  #recruit .recruit-items .sec-title:after {
    left: initial;
    right: 47%;
  }
}
#recruit .recruit-items .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(47% + 8px);
  right: calc(47% + 8px);
  width: initial;
  z-index: 1;
}
@media (max-width: 479px) {
  #recruit .recruit-items .sec-title > span {
    left: calc(47% + 8px);
    right: calc(47% + 8px);
  }
}
@media (max-width: 479px) {
  #recruit .recruit-items .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (max-width: 479px) and (min-width: 968px) and (max-width: 1023px) {
  #recruit .recruit-items .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 768px) and (max-width: 967px) {
  #recruit .recruit-items .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #recruit .recruit-items .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #recruit .recruit-items .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #recruit .recruit-items .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #recruit .recruit-items .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #recruit .recruit-items .sec-title:before, #recruit .recruit-items .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (max-width: 479px) {
  #recruit .recruit-items .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #recruit .recruit-items .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) {
  #recruit .recruit-items .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #recruit .recruit-items .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) {
  #recruit .recruit-items .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(40% + 8px);
    right: calc(40% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #recruit .recruit-items .sec-title > span {
    left: calc(40% + 8px);
    right: calc(40% + 8px);
  }
}
#recruit .recruit-items .recruit-items-content {
  margin-top: 5.1244509517vw;
  width: 80vw;
  max-width: 947px;
  margin-left: auto;
  margin-right: auto;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #recruit .recruit-items .recruit-items-content {
    margin-top: 6.8426197458vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #recruit .recruit-items .recruit-items-content {
    margin-top: 7.2388831437vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit .recruit-items .recruit-items-content {
    margin-top: 9.1264667536vw;
  }
}
@media (max-width: 479px) {
  #recruit .recruit-items .recruit-items-content {
    margin-top: 14.6137787056vw;
  }
}
#recruit .recruit-items .recruit-items-content .recruit-item {
  margin-bottom: 9.5168374817vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #recruit .recruit-items .recruit-items-content .recruit-item {
    margin-bottom: 12.7077223851vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #recruit .recruit-items .recruit-items-content .recruit-item {
    margin-bottom: 13.4436401241vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit .recruit-items .recruit-items-content .recruit-item {
    margin-bottom: 16.9491525424vw;
  }
}
@media (max-width: 479px) {
  #recruit .recruit-items .recruit-items-content .recruit-item {
    margin-bottom: 27.139874739vw;
  }
}
#recruit .recruit-items .recruit-items-content .recruit-item h3 {
  margin-bottom: 1.0980966325vw;
  font-size: clamp(15px, 2.169vw, 21px);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #recruit .recruit-items .recruit-items-content .recruit-item h3 {
    margin-bottom: 1.4662756598vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #recruit .recruit-items .recruit-items-content .recruit-item h3 {
    margin-bottom: 1.5511892451vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit .recruit-items .recruit-items-content .recruit-item h3 {
    margin-bottom: 1.9556714472vw;
  }
}
@media (max-width: 479px) {
  #recruit .recruit-items .recruit-items-content .recruit-item h3 {
    margin-bottom: 3.1315240084vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #recruit .recruit-items .recruit-items-content .recruit-item h3 {
    font-size: clamp(15px, 2.169vw, 21px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #recruit .recruit-items .recruit-items-content .recruit-item h3 {
    font-size: clamp(17px, 2.734vw, 21px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit .recruit-items .recruit-items-content .recruit-item h3 {
    font-size: clamp(23px, 4.375vw, 21px);
  }
}
@media (max-width: 479px) {
  #recruit .recruit-items .recruit-items-content .recruit-item h3 {
    font-size: clamp(14px, 4.375vw, 21px);
  }
}
#recruit .recruit-items .recruit-items-content .content--item dl {
  display: flex;
  justify-content: space-between;
}
@media (max-width: 479px) {
  #recruit .recruit-items .recruit-items-content .content--item dl {
    flex-direction: column;
  }
}
#recruit .recruit-items .recruit-items-content .content--item dl dt, #recruit .recruit-items .recruit-items-content .content--item dl dd {
  padding: 0px 20px;
}
@media (max-width: 479px) {
  #recruit .recruit-items .recruit-items-content .content--item dl dt, #recruit .recruit-items .recruit-items-content .content--item dl dd {
    padding: 0px 15px;
  }
}
#recruit .recruit-items .recruit-items-content .content--item dl dt {
  width: 20%;
  background-color: rgb(11, 74, 107);
  color: rgb(245, 245, 245);
  line-height: 3;
}
@media (max-width: 479px) {
  #recruit .recruit-items .recruit-items-content .content--item dl dt {
    line-height: 2;
    width: 100%;
  }
}
#recruit .recruit-items .recruit-items-content .content--item dl dd {
  width: 80%;
  background-color: rgb(241, 241, 241);
  color: rgb(35, 35, 35);
  line-height: 3;
}
@media (max-width: 479px) {
  #recruit .recruit-items .recruit-items-content .content--item dl dd {
    line-height: 2;
    width: 100%;
  }
}
#recruit .recruit-items .recruit-items-content .content--item dl:nth-child(1) dt, #recruit .recruit-items .recruit-items-content .content--item dl:nth-child(1) dd {
  padding-top: 20px;
}
#recruit .recruit-items .recruit-items-content .content--item dl:nth-last-child(1) dt, #recruit .recruit-items .recruit-items-content .content--item dl:nth-last-child(1) dd {
  padding-bottom: 20px;
}
#recruit .recruit-items .recruit-items-content .content--item:nth-child(2) {
  grid-row: 1/2;
  grid-column: 2/3;
}
#recruit .recruit-items .recruit-items-content .content--item:nth-child(3) {
  grid-row: 2/3;
  grid-column: 2/3;
}
#recruit .recruit-items .btn .btn_more {
  background: rgb(11, 74, 107);
  color: rgb(245, 245, 245);
  border: 1px solid rgb(11, 74, 107);
  margin-left: auto;
  margin-right: auto;
  width: 250px;
  height: 58px;
  text-align: center;
  display: block;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (min-width: 768px) and (max-width: 967px) {
  #recruit .recruit-items .btn .btn_more {
    width: 250px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #recruit .recruit-items .btn .btn_more {
    width: 250px;
  }
}
#recruit .recruit-items .btn .btn_more:hover {
  background: rgb(245, 245, 245);
  color: rgb(11, 74, 107);
}
#contact {
  margin-bottom: 7.3206442167vw;
  margin-bottom: 14.6412884334vw;
  font-size: clamp(11px, 1.653vw, 16px);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #contact {
    margin-bottom: 9.7751710655vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #contact {
    margin-bottom: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #contact {
    margin-bottom: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  #contact {
    margin-bottom: 12.5260960334vw;
  }
}
#contact .content-start {
  padding-top: 7.3206442167vw;
  padding-left: 4.39238653vw;
  padding-right: 4.39238653vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #contact .content-start {
    padding-top: 9.7751710655vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #contact .content-start {
    padding-top: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #contact .content-start {
    padding-top: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  #contact .content-start {
    padding-top: 12.5260960334vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #contact .content-start {
    padding-left: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #contact .content-start {
    padding-left: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #contact .content-start {
    padding-left: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #contact .content-start {
    padding-left: 0vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #contact .content-start {
    padding-right: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #contact .content-start {
    padding-right: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #contact .content-start {
    padding-right: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #contact .content-start {
    padding-right: 0vw;
  }
}
#contact .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #contact .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #contact .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #contact .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #contact .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #contact .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #contact .sec-title {
    text-align: left;
  }
}
#contact .sec-title:before, #contact .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#contact .sec-title:before {
  left: 0;
}
#contact .sec-title:after {
  left: 60px;
  right: initial;
}
#contact .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(0% + 8px);
  width: 52px;
  z-index: 1;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #contact {
    margin-bottom: 19.550342131vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #contact {
    margin-bottom: 20.6825232678vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #contact {
    margin-bottom: 26.075619296vw;
  }
}
@media (max-width: 479px) {
  #contact {
    margin-bottom: 41.7536534447vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #contact {
    font-size: clamp(11px, 1.653vw, 16px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #contact {
    font-size: clamp(13px, 2.083vw, 16px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #contact {
    font-size: clamp(17px, 3.333vw, 16px);
  }
}
@media (max-width: 479px) {
  #contact {
    font-size: clamp(9px, 2.917vw, 14px);
  }
}
#contact .wrapper {
  max-width: 744px;
}
#contact .wrapper strong {
  color: rgb(11, 74, 107);
  font-weight: 400;
}
#contact .wrapper .wpcf7 {
  margin-top: 5.4904831625vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #contact .wrapper .wpcf7 {
    margin-top: 7.3313782991vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #contact .wrapper .wpcf7 {
    margin-top: 7.7559462254vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #contact .wrapper .wpcf7 {
    margin-top: 9.778357236vw;
  }
}
@media (max-width: 479px) {
  #contact .wrapper .wpcf7 {
    margin-top: 8.3507306889vw;
  }
}
#contact .wrapper .wpcf7 dl {
  margin-bottom: 2.9282576867vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #contact .wrapper .wpcf7 dl {
    margin-bottom: 3.9100684262vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #contact .wrapper .wpcf7 dl {
    margin-bottom: 4.1365046536vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #contact .wrapper .wpcf7 dl {
    margin-bottom: 5.2151238592vw;
  }
}
@media (max-width: 479px) {
  #contact .wrapper .wpcf7 dl {
    margin-bottom: 8.3507306889vw;
  }
}
#contact .wrapper .wpcf7 dl dt {
  font-size: clamp(10px, 1.446vw, 14px);
  margin-bottom: 6px;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #contact .wrapper .wpcf7 dl dt {
    font-size: clamp(10px, 1.446vw, 14px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #contact .wrapper .wpcf7 dl dt {
    font-size: clamp(12px, 1.823vw, 14px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #contact .wrapper .wpcf7 dl dt {
    font-size: clamp(15px, 2.917vw, 14px);
  }
}
@media (max-width: 479px) {
  #contact .wrapper .wpcf7 dl dt {
    font-size: clamp(9px, 2.917vw, 14px);
  }
}
#contact .wrapper .wpcf7 dl dt .required {
  display: inline-block;
  color: rgb(11, 74, 107);
  margin-left: 0.7320644217vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #contact .wrapper .wpcf7 dl dt .required {
    margin-left: 0.9775171065vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #contact .wrapper .wpcf7 dl dt .required {
    margin-left: 1.0341261634vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #contact .wrapper .wpcf7 dl dt .required {
    margin-left: 1.3037809648vw;
  }
}
@media (max-width: 479px) {
  #contact .wrapper .wpcf7 dl dt .required {
    margin-left: 2.0876826722vw;
  }
}
#contact .wrapper .wpcf7 dl .col2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
@media (max-width: 479px) {
  #contact .wrapper .wpcf7 dl .col2 {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
  }
}
#contact .wrapper .wpcf7 dl .address .col2 {
  margin-bottom: 2.9282576867vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #contact .wrapper .wpcf7 dl .address .col2 {
    margin-bottom: 3.9100684262vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #contact .wrapper .wpcf7 dl .address .col2 {
    margin-bottom: 4.1365046536vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #contact .wrapper .wpcf7 dl .address .col2 {
    margin-bottom: 5.2151238592vw;
  }
}
@media (max-width: 479px) {
  #contact .wrapper .wpcf7 dl .address .col2 {
    margin-bottom: 8.3507306889vw;
  }
}
#contact .wrapper .wpcf7 .consent {
  display: flex;
  justify-content: center;
}
#contact .wrapper .wpcf7 .btn {
  max-width: 160px;
  margin-left: auto;
  margin-right: auto;
}
#contact .wrapper .wpcf7 .btn span input {
  background: rgb(11, 74, 107);
  color: white;
}

#aboutus {
  margin-bottom: 7.3206442167vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus {
    margin-bottom: 9.7751710655vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus {
    margin-bottom: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus {
    margin-bottom: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  #aboutus {
    margin-bottom: 12.5260960334vw;
  }
}
#aboutus .content-start {
  padding-top: 7.3206442167vw;
  padding-left: 4.39238653vw;
  padding-right: 4.39238653vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus .content-start {
    padding-top: 9.7751710655vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus .content-start {
    padding-top: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus .content-start {
    padding-top: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  #aboutus .content-start {
    padding-top: 12.5260960334vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus .content-start {
    padding-left: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus .content-start {
    padding-left: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus .content-start {
    padding-left: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #aboutus .content-start {
    padding-left: 0vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus .content-start {
    padding-right: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus .content-start {
    padding-right: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus .content-start {
    padding-right: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #aboutus .content-start {
    padding-right: 0vw;
  }
}
#aboutus .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #aboutus .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #aboutus .sec-title {
    text-align: left;
  }
}
#aboutus .sec-title:before, #aboutus .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#aboutus .sec-title:before {
  left: 0;
}
#aboutus .sec-title:after {
  left: 60px;
  right: initial;
}
#aboutus .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(0% + 8px);
  width: 52px;
  z-index: 1;
}
#aboutus #about-welcome {
  margin-top: 8.0527086384vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-welcome {
    margin-top: 10.752688172vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-welcome {
    margin-top: 11.3753877973vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome {
    margin-top: 14.3415906128vw;
  }
}
@media (max-width: 479px) {
  #aboutus #about-welcome {
    margin-top: 14.6137787056vw;
  }
}
#aboutus #about-welcome .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #aboutus #about-welcome .sec-title {
    text-align: left;
  }
}
#aboutus #about-welcome .sec-title:before, #aboutus #about-welcome .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#aboutus #about-welcome .sec-title:before {
  left: 48%;
}
@media (max-width: 479px) {
  #aboutus #about-welcome .sec-title:before {
    left: 48%;
  }
}
#aboutus #about-welcome .sec-title:after {
  left: initial;
  right: 48%;
}
@media (max-width: 479px) {
  #aboutus #about-welcome .sec-title:after {
    left: initial;
    right: 48%;
  }
}
#aboutus #about-welcome .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(48% + 8px);
  right: calc(48% + 8px);
  width: initial;
  z-index: 1;
}
@media (max-width: 479px) {
  #aboutus #about-welcome .sec-title > span {
    left: calc(48% + 8px);
    right: calc(48% + 8px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome .sec-title {
    text-align: left;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-welcome .sec-title {
    text-align: left;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-welcome .sec-title:before, #aboutus #about-welcome .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-welcome .sec-title:before {
    left: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-welcome .sec-title:before {
    left: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-welcome .sec-title:after {
    left: initial;
    right: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-welcome .sec-title:after {
    left: initial;
    right: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-welcome .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(45% + 8px);
    right: calc(45% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-welcome .sec-title > span {
    left: calc(45% + 8px);
    right: calc(45% + 8px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome .sec-title {
    text-align: left;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-welcome .sec-title {
    text-align: left;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome .sec-title:before, #aboutus #about-welcome .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome .sec-title:before {
    left: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-welcome .sec-title:before {
    left: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-welcome .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(40% + 8px);
    right: calc(40% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-welcome .sec-title > span {
    left: calc(40% + 8px);
    right: calc(40% + 8px);
  }
}
@media (max-width: 479px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (max-width: 479px) and (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-welcome .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-welcome .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #aboutus #about-welcome .sec-title:before, #aboutus #about-welcome .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (max-width: 479px) {
  #aboutus #about-welcome .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-welcome .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) {
  #aboutus #about-welcome .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-welcome .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) {
  #aboutus #about-welcome .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(40% + 8px);
    right: calc(40% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-welcome .sec-title > span {
    left: calc(40% + 8px);
    right: calc(40% + 8px);
  }
}
#aboutus #about-welcome .sec-title {
  margin-bottom: 6.588579795vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-welcome .sec-title {
    margin-bottom: 8.7976539589vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-welcome .sec-title {
    margin-bottom: 9.3071354705vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome .sec-title {
    margin-bottom: 11.7340286832vw;
  }
}
@media (max-width: 479px) {
  #aboutus #about-welcome .sec-title {
    margin-bottom: 12.5260960334vw;
  }
}
#aboutus #about-welcome .welcome--content {
  padding-left: 4.39238653vw;
  padding-right: 4.39238653vw;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 70px;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-welcome .welcome--content {
    padding-left: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-welcome .welcome--content {
    padding-left: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome .welcome--content {
    padding-left: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #aboutus #about-welcome .welcome--content {
    padding-left: 0vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-welcome .welcome--content {
    padding-right: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-welcome .welcome--content {
    padding-right: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome .welcome--content {
    padding-right: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #aboutus #about-welcome .welcome--content {
    padding-right: 0vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-welcome .welcome--content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-welcome .welcome--content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 30px;
  }
}
@media (max-width: 479px) {
  #aboutus #about-welcome .welcome--content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 30px;
  }
}
#aboutus #about-welcome .welcome--content .text {
  position: relative;
}
#aboutus #about-welcome .welcome--content .text .text--content {
  line-height: 2;
}
#aboutus #about-welcome .welcome--content .text .text--position {
  position: absolute;
  bottom: 0;
  right: 0;
}
@media (max-width: 479px) {
  #aboutus #about-welcome .welcome--content .text .text--position {
    position: initial;
    margin-top: 6.2630480167vw;
    text-align: right;
  }
}
#aboutus #about-company {
  margin-top: 8.0527086384vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-company {
    margin-top: 10.752688172vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-company {
    margin-top: 11.3753877973vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-company {
    margin-top: 14.3415906128vw;
  }
}
@media (max-width: 479px) {
  #aboutus #about-company {
    margin-top: 14.6137787056vw;
  }
}
#aboutus #about-company .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-company .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #aboutus #about-company .sec-title {
    text-align: left;
  }
}
#aboutus #about-company .sec-title:before, #aboutus #about-company .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#aboutus #about-company .sec-title:before {
  left: 48%;
}
@media (max-width: 479px) {
  #aboutus #about-company .sec-title:before {
    left: 48%;
  }
}
#aboutus #about-company .sec-title:after {
  left: initial;
  right: 48%;
}
@media (max-width: 479px) {
  #aboutus #about-company .sec-title:after {
    left: initial;
    right: 48%;
  }
}
#aboutus #about-company .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(48% + 8px);
  right: calc(48% + 8px);
  width: initial;
  z-index: 1;
}
@media (max-width: 479px) {
  #aboutus #about-company .sec-title > span {
    left: calc(48% + 8px);
    right: calc(48% + 8px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-company .sec-title {
    text-align: left;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-company .sec-title {
    text-align: left;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-company .sec-title:before, #aboutus #about-company .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-company .sec-title:before {
    left: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-company .sec-title:before {
    left: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-company .sec-title:after {
    left: initial;
    right: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-company .sec-title:after {
    left: initial;
    right: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-company .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(45% + 8px);
    right: calc(45% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-company .sec-title > span {
    left: calc(45% + 8px);
    right: calc(45% + 8px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-company .sec-title {
    text-align: left;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-company .sec-title {
    text-align: left;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-company .sec-title:before, #aboutus #about-company .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-company .sec-title:before {
    left: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-company .sec-title:before {
    left: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-company .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-company .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-company .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(40% + 8px);
    right: calc(40% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-company .sec-title > span {
    left: calc(40% + 8px);
    right: calc(40% + 8px);
  }
}
@media (max-width: 479px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (max-width: 479px) and (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-company .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-company .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-company .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #aboutus #about-company .sec-title:before, #aboutus #about-company .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (max-width: 479px) {
  #aboutus #about-company .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-company .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) {
  #aboutus #about-company .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-company .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) {
  #aboutus #about-company .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(40% + 8px);
    right: calc(40% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-company .sec-title > span {
    left: calc(40% + 8px);
    right: calc(40% + 8px);
  }
}
#aboutus #about-company .sec-title {
  margin-bottom: 6.588579795vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-company .sec-title {
    margin-bottom: 8.7976539589vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-company .sec-title {
    margin-bottom: 9.3071354705vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-company .sec-title {
    margin-bottom: 11.7340286832vw;
  }
}
@media (max-width: 479px) {
  #aboutus #about-company .sec-title {
    margin-bottom: 12.5260960334vw;
  }
}
#aboutus #about-company .company--content {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 30px;
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-company .company--content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-company .company--content {
    display: block;
  }
}
@media (max-width: 479px) {
  #aboutus #about-company .company--content {
    display: block;
  }
}
#aboutus #about-company .company--content .content--item dl {
  display: flex;
  justify-content: space-between;
}
#aboutus #about-company .company--content .content--item dl dt, #aboutus #about-company .company--content .content--item dl dd {
  padding: 0px 20px;
}
@media (max-width: 479px) {
  #aboutus #about-company .company--content .content--item dl dt, #aboutus #about-company .company--content .content--item dl dd {
    padding: 0px 15px;
  }
}
#aboutus #about-company .company--content .content--item dl dt {
  width: 30%;
  background-color: rgb(11, 74, 107);
  color: rgb(245, 245, 245);
  line-height: 3;
}
@media (max-width: 479px) {
  #aboutus #about-company .company--content .content--item dl dt {
    width: 35%;
  }
}
#aboutus #about-company .company--content .content--item dl dd {
  width: 70%;
  background-color: rgb(241, 241, 241);
  color: rgb(35, 35, 35);
  line-height: 3;
}
@media (max-width: 479px) {
  #aboutus #about-company .company--content .content--item dl dd {
    width: 65%;
  }
}
#aboutus #about-company .company--content .content--item dl:nth-child(1) dt, #aboutus #about-company .company--content .content--item dl:nth-child(1) dd {
  padding-top: 20px;
}
#aboutus #about-company .company--content .content--item dl:nth-last-child(1) dt, #aboutus #about-company .company--content .content--item dl:nth-last-child(1) dd {
  padding-bottom: 20px;
}
#aboutus #about-history {
  margin-top: 8.0527086384vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-history {
    margin-top: 10.752688172vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-history {
    margin-top: 11.3753877973vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history {
    margin-top: 14.3415906128vw;
  }
}
@media (max-width: 479px) {
  #aboutus #about-history {
    margin-top: 14.6137787056vw;
  }
}
#aboutus #about-history .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #aboutus #about-history .sec-title {
    text-align: left;
  }
}
#aboutus #about-history .sec-title:before, #aboutus #about-history .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#aboutus #about-history .sec-title:before {
  left: 48%;
}
@media (max-width: 479px) {
  #aboutus #about-history .sec-title:before {
    left: 48%;
  }
}
#aboutus #about-history .sec-title:after {
  left: initial;
  right: 48%;
}
@media (max-width: 479px) {
  #aboutus #about-history .sec-title:after {
    left: initial;
    right: 48%;
  }
}
#aboutus #about-history .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(48% + 8px);
  right: calc(48% + 8px);
  width: initial;
  z-index: 1;
}
@media (max-width: 479px) {
  #aboutus #about-history .sec-title > span {
    left: calc(48% + 8px);
    right: calc(48% + 8px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .sec-title {
    text-align: left;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-history .sec-title {
    text-align: left;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-history .sec-title:before, #aboutus #about-history .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-history .sec-title:before {
    left: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-history .sec-title:before {
    left: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-history .sec-title:after {
    left: initial;
    right: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-history .sec-title:after {
    left: initial;
    right: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-history .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(45% + 8px);
    right: calc(45% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-history .sec-title > span {
    left: calc(45% + 8px);
    right: calc(45% + 8px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .sec-title {
    text-align: left;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-history .sec-title {
    text-align: left;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .sec-title:before, #aboutus #about-history .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .sec-title:before {
    left: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-history .sec-title:before {
    left: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-history .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(40% + 8px);
    right: calc(40% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-history .sec-title > span {
    left: calc(40% + 8px);
    right: calc(40% + 8px);
  }
}
@media (max-width: 479px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (max-width: 479px) and (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-history .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-history .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #aboutus #about-history .sec-title:before, #aboutus #about-history .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (max-width: 479px) {
  #aboutus #about-history .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-history .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) {
  #aboutus #about-history .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-history .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) {
  #aboutus #about-history .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(40% + 8px);
    right: calc(40% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-history .sec-title > span {
    left: calc(40% + 8px);
    right: calc(40% + 8px);
  }
}
#aboutus #about-history .sec-title {
  margin-bottom: 6.588579795vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-history .sec-title {
    margin-bottom: 8.7976539589vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-history .sec-title {
    margin-bottom: 9.3071354705vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .sec-title {
    margin-bottom: 11.7340286832vw;
  }
}
@media (max-width: 479px) {
  #aboutus #about-history .sec-title {
    margin-bottom: 12.5260960334vw;
  }
}
#aboutus #about-history .history--content {
  display: grid;
  grid-template-columns: 0.35fr 0.65fr;
  gap: 40px;
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-history .history--content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .history--content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
  }
}
@media (max-width: 479px) {
  #aboutus #about-history .history--content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
  }
}
#aboutus #about-history .history--content .content--item dl {
  display: flex;
  justify-content: space-between;
}
@media (max-width: 479px) {
  #aboutus #about-history .history--content .content--item dl {
    flex-direction: column;
  }
}
#aboutus #about-history .history--content .content--item dl dt, #aboutus #about-history .history--content .content--item dl dd {
  padding: 0px 30px;
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-history .history--content .content--item dl dt, #aboutus #about-history .history--content .content--item dl dd {
    padding: 10px 20px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .history--content .content--item dl dt, #aboutus #about-history .history--content .content--item dl dd {
    padding: 10px 20px;
  }
}
@media (max-width: 479px) {
  #aboutus #about-history .history--content .content--item dl dt, #aboutus #about-history .history--content .content--item dl dd {
    padding: 10px 20px;
  }
}
#aboutus #about-history .history--content .content--item dl dt {
  width: 32%;
  background-color: rgb(11, 74, 107);
  color: rgb(245, 245, 245);
  line-height: 2.8;
}
@media (max-width: 479px) {
  #aboutus #about-history .history--content .content--item dl dt {
    width: 100%;
  }
}
#aboutus #about-history .history--content .content--item dl dd {
  width: 68%;
  background-color: rgb(241, 241, 241);
  color: rgb(35, 35, 35);
  line-height: 2.8;
}
@media (max-width: 479px) {
  #aboutus #about-history .history--content .content--item dl dd {
    width: 100%;
    line-height: 2.1;
  }
}
#aboutus #about-history .history--content .content--item dl:nth-child(1) dt, #aboutus #about-history .history--content .content--item dl:nth-child(1) dd {
  padding-top: 20px;
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-history .history--content .content--item dl:nth-child(1) dt, #aboutus #about-history .history--content .content--item dl:nth-child(1) dd {
    padding: 10px 20px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .history--content .content--item dl:nth-child(1) dt, #aboutus #about-history .history--content .content--item dl:nth-child(1) dd {
    padding: 10px 20px;
  }
}
@media (max-width: 479px) {
  #aboutus #about-history .history--content .content--item dl:nth-child(1) dt, #aboutus #about-history .history--content .content--item dl:nth-child(1) dd {
    padding: 10px 20px;
  }
}
#aboutus #about-history .history--content .content--item dl:nth-last-child(1) dt, #aboutus #about-history .history--content .content--item dl:nth-last-child(1) dd {
  padding-bottom: 20px;
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-history .history--content .content--item dl:nth-last-child(1) dt, #aboutus #about-history .history--content .content--item dl:nth-last-child(1) dd {
    padding: 10px 20px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-history .history--content .content--item dl:nth-last-child(1) dt, #aboutus #about-history .history--content .content--item dl:nth-last-child(1) dd {
    padding: 10px 20px;
  }
}
@media (max-width: 479px) {
  #aboutus #about-history .history--content .content--item dl:nth-last-child(1) dt, #aboutus #about-history .history--content .content--item dl:nth-last-child(1) dd {
    padding: 10px 20px;
  }
}
#aboutus #about-commendation {
  margin-top: 8.0527086384vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-commendation {
    margin-top: 10.752688172vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-commendation {
    margin-top: 11.3753877973vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-commendation {
    margin-top: 14.3415906128vw;
  }
}
@media (max-width: 479px) {
  #aboutus #about-commendation {
    margin-top: 14.6137787056vw;
  }
}
#aboutus #about-commendation .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-commendation .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #aboutus #about-commendation .sec-title {
    text-align: left;
  }
}
#aboutus #about-commendation .sec-title:before, #aboutus #about-commendation .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#aboutus #about-commendation .sec-title:before {
  left: 48%;
}
@media (max-width: 479px) {
  #aboutus #about-commendation .sec-title:before {
    left: 48%;
  }
}
#aboutus #about-commendation .sec-title:after {
  left: initial;
  right: 48%;
}
@media (max-width: 479px) {
  #aboutus #about-commendation .sec-title:after {
    left: initial;
    right: 48%;
  }
}
#aboutus #about-commendation .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(48% + 8px);
  right: calc(48% + 8px);
  width: initial;
  z-index: 1;
}
@media (max-width: 479px) {
  #aboutus #about-commendation .sec-title > span {
    left: calc(48% + 8px);
    right: calc(48% + 8px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-commendation .sec-title {
    text-align: left;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-commendation .sec-title {
    text-align: left;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-commendation .sec-title:before, #aboutus #about-commendation .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-commendation .sec-title:before {
    left: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-commendation .sec-title:before {
    left: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-commendation .sec-title:after {
    left: initial;
    right: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-commendation .sec-title:after {
    left: initial;
    right: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-commendation .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(45% + 8px);
    right: calc(45% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-commendation .sec-title > span {
    left: calc(45% + 8px);
    right: calc(45% + 8px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-commendation .sec-title {
    text-align: left;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-commendation .sec-title {
    text-align: left;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-commendation .sec-title:before, #aboutus #about-commendation .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-commendation .sec-title:before {
    left: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-commendation .sec-title:before {
    left: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-commendation .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-commendation .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-commendation .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(40% + 8px);
    right: calc(40% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-commendation .sec-title > span {
    left: calc(40% + 8px);
    right: calc(40% + 8px);
  }
}
@media (max-width: 479px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (max-width: 479px) and (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-commendation .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-commendation .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-commendation .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #aboutus #about-commendation .sec-title:before, #aboutus #about-commendation .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (max-width: 479px) {
  #aboutus #about-commendation .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-commendation .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) {
  #aboutus #about-commendation .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-commendation .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) {
  #aboutus #about-commendation .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(40% + 8px);
    right: calc(40% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-commendation .sec-title > span {
    left: calc(40% + 8px);
    right: calc(40% + 8px);
  }
}
#aboutus #about-commendation .sec-title {
  margin-bottom: 6.588579795vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-commendation .sec-title {
    margin-bottom: 8.7976539589vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-commendation .sec-title {
    margin-bottom: 9.3071354705vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-commendation .sec-title {
    margin-bottom: 11.7340286832vw;
  }
}
@media (max-width: 479px) {
  #aboutus #about-commendation .sec-title {
    margin-bottom: 12.5260960334vw;
  }
}
#aboutus #about-commendation .commendation--content {
  display: grid;
  grid-template-columns: 0.65fr 0.35fr;
  gap: 40px;
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-commendation .commendation--content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-commendation .commendation--content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
  }
}
@media (max-width: 479px) {
  #aboutus #about-commendation .commendation--content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
  }
}
#aboutus #about-commendation .commendation--content .content--item dl {
  display: flex;
  justify-content: space-between;
}
@media (max-width: 479px) {
  #aboutus #about-commendation .commendation--content .content--item dl {
    flex-direction: column;
  }
}
#aboutus #about-commendation .commendation--content .content--item dl dt, #aboutus #about-commendation .commendation--content .content--item dl dd {
  padding: 0px 30px;
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-commendation .commendation--content .content--item dl dt, #aboutus #about-commendation .commendation--content .content--item dl dd {
    padding: 10px 20px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-commendation .commendation--content .content--item dl dt, #aboutus #about-commendation .commendation--content .content--item dl dd {
    padding: 10px 20px;
  }
}
@media (max-width: 479px) {
  #aboutus #about-commendation .commendation--content .content--item dl dt, #aboutus #about-commendation .commendation--content .content--item dl dd {
    padding: 10px 20px;
  }
}
#aboutus #about-commendation .commendation--content .content--item dl dt {
  width: 17%;
  background-color: rgb(11, 74, 107);
  color: rgb(245, 245, 245);
  line-height: 2.8;
}
@media (max-width: 479px) {
  #aboutus #about-commendation .commendation--content .content--item dl dt {
    width: 100%;
  }
}
#aboutus #about-commendation .commendation--content .content--item dl dd {
  width: 83%;
  background-color: rgb(241, 241, 241);
  color: rgb(35, 35, 35);
  line-height: 2.8;
}
@media (max-width: 479px) {
  #aboutus #about-commendation .commendation--content .content--item dl dd {
    width: 100%;
    line-height: 2.1;
  }
}
#aboutus #about-commendation .commendation--content .content--item dl:nth-child(1) dt, #aboutus #about-commendation .commendation--content .content--item dl:nth-child(1) dd {
  padding-top: 20px;
}
@media (max-width: 479px) {
  #aboutus #about-commendation .commendation--content .content--item dl:nth-child(1) dt, #aboutus #about-commendation .commendation--content .content--item dl:nth-child(1) dd {
    padding: 10px 20px;
  }
}
#aboutus #about-commendation .commendation--content .content--item dl:nth-last-child(1) dt, #aboutus #about-commendation .commendation--content .content--item dl:nth-last-child(1) dd {
  padding-bottom: 20px;
}
@media (max-width: 479px) {
  #aboutus #about-commendation .commendation--content .content--item dl:nth-last-child(1) dt, #aboutus #about-commendation .commendation--content .content--item dl:nth-last-child(1) dd {
    padding: 10px 20px;
  }
}
#aboutus #about-access {
  margin-top: 8.0527086384vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-access {
    margin-top: 10.752688172vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-access {
    margin-top: 11.3753877973vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access {
    margin-top: 14.3415906128vw;
  }
}
@media (max-width: 479px) {
  #aboutus #about-access {
    margin-top: 14.6137787056vw;
  }
}
#aboutus #about-access .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #aboutus #about-access .sec-title {
    text-align: left;
  }
}
#aboutus #about-access .sec-title:before, #aboutus #about-access .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#aboutus #about-access .sec-title:before {
  left: 48%;
}
@media (max-width: 479px) {
  #aboutus #about-access .sec-title:before {
    left: 48%;
  }
}
#aboutus #about-access .sec-title:after {
  left: initial;
  right: 48%;
}
@media (max-width: 479px) {
  #aboutus #about-access .sec-title:after {
    left: initial;
    right: 48%;
  }
}
#aboutus #about-access .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(48% + 8px);
  right: calc(48% + 8px);
  width: initial;
  z-index: 1;
}
@media (max-width: 479px) {
  #aboutus #about-access .sec-title > span {
    left: calc(48% + 8px);
    right: calc(48% + 8px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .sec-title {
    text-align: left;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-access .sec-title {
    text-align: left;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-access .sec-title:before, #aboutus #about-access .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-access .sec-title:before {
    left: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-access .sec-title:before {
    left: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-access .sec-title:after {
    left: initial;
    right: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-access .sec-title:after {
    left: initial;
    right: 45%;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-access .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(45% + 8px);
    right: calc(45% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (min-width: 768px) and (max-width: 967px) and (max-width: 479px) {
  #aboutus #about-access .sec-title > span {
    left: calc(45% + 8px);
    right: calc(45% + 8px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .sec-title {
    text-align: left;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-access .sec-title {
    text-align: left;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .sec-title:before, #aboutus #about-access .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .sec-title:before {
    left: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-access .sec-title:before {
    left: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-access .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(40% + 8px);
    right: calc(40% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (min-width: 480px) and (max-width: 767px) and (max-width: 479px) {
  #aboutus #about-access .sec-title > span {
    left: calc(40% + 8px);
    right: calc(40% + 8px);
  }
}
@media (max-width: 479px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
    margin-bottom: 40px;
    text-align: center;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media (max-width: 479px) and (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-access .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-access .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #aboutus #about-access .sec-title:before, #aboutus #about-access .sec-title:after {
    content: "";
    position: absolute;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    bottom: -12px;
    border: 1px solid rgb(35, 35, 35);
    z-index: 2;
  }
}
@media (max-width: 479px) {
  #aboutus #about-access .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-access .sec-title:before {
    left: 40%;
  }
}
@media (max-width: 479px) {
  #aboutus #about-access .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-access .sec-title:after {
    left: initial;
    right: 40%;
  }
}
@media (max-width: 479px) {
  #aboutus #about-access .sec-title > span {
    position: absolute;
    height: 1px;
    background-color: rgb(35, 35, 35);
    bottom: -8px;
    left: calc(40% + 8px);
    right: calc(40% + 8px);
    width: initial;
    z-index: 1;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #aboutus #about-access .sec-title > span {
    left: calc(40% + 8px);
    right: calc(40% + 8px);
  }
}
#aboutus #about-access .sec-title {
  margin-bottom: 6.588579795vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #aboutus #about-access .sec-title {
    margin-bottom: 8.7976539589vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-access .sec-title {
    margin-bottom: 9.3071354705vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .sec-title {
    margin-bottom: 11.7340286832vw;
  }
}
@media (max-width: 479px) {
  #aboutus #about-access .sec-title {
    margin-bottom: 12.5260960334vw;
  }
}
#aboutus #about-access .access--content {
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-access .access--content {
    flex-direction: column;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .access--content {
    flex-direction: column;
  }
}
@media (max-width: 479px) {
  #aboutus #about-access .access--content {
    flex-direction: column;
  }
}
#aboutus #about-access .access--content .access--map {
  filter: grayscale(100%);
  position: relative;
  margin-left: -25vw;
  width: 100vw;
  height: 0;
  padding-bottom: 56.25%;
  overflow: hidden;
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-access .access--content .access--map {
    margin-left: 0;
    padding-bottom: 100%;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .access--content .access--map {
    margin-left: 0;
    padding-bottom: 100%;
  }
}
@media (max-width: 479px) {
  #aboutus #about-access .access--content .access--map {
    margin-left: 0;
    padding-bottom: 100%;
  }
}
#aboutus #about-access .access--content .access--map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
#aboutus #about-access .access--content .access--info {
  width: 25vw;
  margin-left: -60px;
  position: relative;
  z-index: 3;
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-access .access--content .access--info {
    margin-left: initial;
    width: 100%;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .access--content .access--info {
    margin-left: initial;
    width: 100%;
  }
}
@media (max-width: 479px) {
  #aboutus #about-access .access--content .access--info {
    margin-left: initial;
    width: 100%;
  }
}
#aboutus #about-access .access--content .access--info .info-container {
  width: 100%;
  padding: 50px;
  background-color: rgb(241, 241, 241);
}
@media (min-width: 768px) and (max-width: 967px) {
  #aboutus #about-access .access--content .access--info .info-container {
    padding: 30px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #aboutus #about-access .access--content .access--info .info-container {
    padding: 30px;
  }
}
@media (max-width: 479px) {
  #aboutus #about-access .access--content .access--info .info-container {
    padding: 30px;
  }
}
#aboutus #about-access .access--content .access--info .info-container .item {
  margin-bottom: 10px;
}
#aboutus #about-access .access--content .access--info .info-container .logomark {
  height: 40px;
  margin-bottom: 30px;
}
#aboutus #about-access .access--content .access--info .info-container .logomark svg {
  width: auto;
  height: 40px;
}
#aboutus #about-access .access--content .access--info .info-container .logomark svg path {
  fill: rgb(35, 35, 35);
}
#aboutus #about-access .access--content .access--info .info-container .icon span {
  min-width: 40px;
  display: inline-block;
}

#mainvisual {
  position: relative;
}
#mainvisual figure {
  position: relative;
  width: 100%;
}
#mainvisual figure:before {
  content: "";
  display: block;
  padding-top: 30%;
}
#mainvisual figure img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  border-radius: 0vw;
  object-fit: cover;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) {
  #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) {
  #mainvisual {
    position: relative;
  }
  #mainvisual figure {
    position: relative;
    width: 100%;
  }
  #mainvisual figure:before {
    content: "";
    display: block;
    padding-top: 100%;
  }
  #mainvisual figure img {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 100%;
    height: 100%;
    border-radius: 0vw;
    object-fit: cover;
  }
}
@media (max-width: 479px) and (min-width: 968px) and (max-width: 1023px) {
  #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) and (min-width: 768px) and (max-width: 967px) {
  #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) and (min-width: 480px) and (max-width: 767px) {
  #mainvisual figure img {
    border-radius: 0vw;
  }
}
@media (max-width: 479px) and (max-width: 479px) {
  #mainvisual figure img {
    border-radius: 0vw;
  }
}
#mainvisual .page .title .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  #mainvisual .page .title .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #mainvisual .page .title .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #mainvisual .page .title .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  #mainvisual .page .title .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #mainvisual .page .title .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  #mainvisual .page .title .sec-title {
    text-align: left;
  }
}
#mainvisual .page .title .sec-title:before, #mainvisual .page .title .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
#mainvisual .page .title .sec-title:before {
  left: 0;
}
#mainvisual .page .title .sec-title:after {
  left: 60px;
  right: initial;
}
#mainvisual .page .title .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(0% + 8px);
  width: 52px;
  z-index: 1;
}
#mainvisual .page .title .sec-title {
  left: initial;
  transform: initial;
}

#casestudy, #archive-post-list {
  margin-bottom: 7.3206442167vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #casestudy, #archive-post-list {
    margin-bottom: 9.7751710655vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #casestudy, #archive-post-list {
    margin-bottom: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #casestudy, #archive-post-list {
    margin-bottom: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  #casestudy, #archive-post-list {
    margin-bottom: 12.5260960334vw;
  }
}
#casestudy .content-start, #archive-post-list .content-start {
  padding-top: 7.3206442167vw;
  padding-left: 4.39238653vw;
  padding-right: 4.39238653vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #casestudy .content-start, #archive-post-list .content-start {
    padding-top: 9.7751710655vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #casestudy .content-start, #archive-post-list .content-start {
    padding-top: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #casestudy .content-start, #archive-post-list .content-start {
    padding-top: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  #casestudy .content-start, #archive-post-list .content-start {
    padding-top: 12.5260960334vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #casestudy .content-start, #archive-post-list .content-start {
    padding-left: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #casestudy .content-start, #archive-post-list .content-start {
    padding-left: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #casestudy .content-start, #archive-post-list .content-start {
    padding-left: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #casestudy .content-start, #archive-post-list .content-start {
    padding-left: 0vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  #casestudy .content-start, #archive-post-list .content-start {
    padding-right: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #casestudy .content-start, #archive-post-list .content-start {
    padding-right: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #casestudy .content-start, #archive-post-list .content-start {
    padding-right: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  #casestudy .content-start, #archive-post-list .content-start {
    padding-right: 0vw;
  }
}
#casestudy .casestudy--item, #casestudy .casestudy--item1, #archive-post-list .casestudy--item, #archive-post-list .casestudy--item1 {
  margin-top: 9.5168374817vw;
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #casestudy .casestudy--item, #casestudy .casestudy--item1, #archive-post-list .casestudy--item, #archive-post-list .casestudy--item1 {
    margin-top: 12.7077223851vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #casestudy .casestudy--item, #casestudy .casestudy--item1, #archive-post-list .casestudy--item, #archive-post-list .casestudy--item1 {
    margin-top: 13.4436401241vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #casestudy .casestudy--item, #casestudy .casestudy--item1, #archive-post-list .casestudy--item, #archive-post-list .casestudy--item1 {
    margin-top: 16.9491525424vw;
  }
}
@media (max-width: 479px) {
  #casestudy .casestudy--item, #casestudy .casestudy--item1, #archive-post-list .casestudy--item, #archive-post-list .casestudy--item1 {
    margin-top: 12.5260960334vw;
  }
}
#casestudy .casestudy--item .list-item.item3, #casestudy .casestudy--item1 .list-item.item3, #archive-post-list .casestudy--item .list-item.item3, #archive-post-list .casestudy--item1 .list-item.item3 {
  width: 33.333%;
}
@media (max-width: 479px) {
  #casestudy .casestudy--item .list-item.item3, #casestudy .casestudy--item1 .list-item.item3, #archive-post-list .casestudy--item .list-item.item3, #archive-post-list .casestudy--item1 .list-item.item3 {
    width: 50%;
  }
}
#casestudy .casestudy--item .list-item.item4, #casestudy .casestudy--item1 .list-item.item4, #archive-post-list .casestudy--item .list-item.item4, #archive-post-list .casestudy--item1 .list-item.item4 {
  width: 25%;
}
@media (max-width: 479px) {
  #casestudy .casestudy--item .list-item.item4, #casestudy .casestudy--item1 .list-item.item4, #archive-post-list .casestudy--item .list-item.item4, #archive-post-list .casestudy--item1 .list-item.item4 {
    width: 50%;
  }
}
#casestudy .casestudy--item .list-item a, #casestudy .casestudy--item1 .list-item a, #archive-post-list .casestudy--item .list-item a, #archive-post-list .casestudy--item1 .list-item a {
  position: relative;
  display: block;
}
#casestudy .casestudy--item .list-item a figure, #casestudy .casestudy--item1 .list-item a figure, #archive-post-list .casestudy--item .list-item a figure, #archive-post-list .casestudy--item1 .list-item a figure {
  position: relative;
  aspect-ratio: 3/2;
  overflow: hidden;
}
#casestudy .casestudy--item .list-item a figure img, #casestudy .casestudy--item1 .list-item a figure img, #archive-post-list .casestudy--item .list-item a figure img, #archive-post-list .casestudy--item1 .list-item a figure img {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}
#casestudy .casestudy--item .list-item a .item-title, #casestudy .casestudy--item1 .list-item a .item-title, #archive-post-list .casestudy--item .list-item a .item-title, #archive-post-list .casestudy--item1 .list-item a .item-title {
  position: absolute;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: rgba(0, 0, 0, 0.4);
  opacity: 0;
  transition-duration: 0.5s;
  top: 0;
  left: 0;
}
#casestudy .casestudy--item .list-item a .item-title span, #casestudy .casestudy--item1 .list-item a .item-title span, #archive-post-list .casestudy--item .list-item a .item-title span, #archive-post-list .casestudy--item1 .list-item a .item-title span {
  border-top: 1px solid rgb(245, 245, 245);
  border-bottom: 1px solid rgb(245, 245, 245);
  color: rgb(245, 245, 245);
  width: 20%;
  text-align: center;
  padding-top: 6px;
  padding-bottom: 6px;
  transition-duration: 0.5s;
}
#casestudy .casestudy--item .list-item a:hover .item-title, #casestudy .casestudy--item1 .list-item a:hover .item-title, #archive-post-list .casestudy--item .list-item a:hover .item-title, #archive-post-list .casestudy--item1 .list-item a:hover .item-title {
  opacity: 1;
  transition-duration: 0.5s;
}
#casestudy .casestudy--item .list-item a:hover .item-title span, #casestudy .casestudy--item1 .list-item a:hover .item-title span, #archive-post-list .casestudy--item .list-item a:hover .item-title span, #archive-post-list .casestudy--item1 .list-item a:hover .item-title span {
  width: 80%;
  transition-duration: 0.5s;
}
#casestudy .more, #archive-post-list .more {
  margin-top: 6.588579795vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #casestudy .more, #archive-post-list .more {
    margin-top: 8.7976539589vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #casestudy .more, #archive-post-list .more {
    margin-top: 9.3071354705vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #casestudy .more, #archive-post-list .more {
    margin-top: 11.7340286832vw;
  }
}
@media (max-width: 479px) {
  #casestudy .more, #archive-post-list .more {
    margin-top: 18.7891440501vw;
  }
}
#casestudy .more .btn .btn_more, #archive-post-list .more .btn .btn_more {
  background: rgb(11, 74, 107);
  color: rgb(245, 245, 245);
  border: 1px solid rgb(11, 74, 107);
  margin-left: auto;
  margin-right: auto;
  width: 250px;
  height: 58px;
  text-align: center;
  display: block;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (min-width: 768px) and (max-width: 967px) {
  #casestudy .more .btn .btn_more, #archive-post-list .more .btn .btn_more {
    width: 250px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #casestudy .more .btn .btn_more, #archive-post-list .more .btn .btn_more {
    width: 250px;
  }
}
#casestudy .more .btn .btn_more:hover, #archive-post-list .more .btn .btn_more:hover {
  background: rgb(245, 245, 245);
  color: rgb(11, 74, 107);
}
#casestudy .more .page-load-status, #archive-post-list .more .page-load-status {
  text-align: center;
}

#archive-post-list .post-list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 60px;
  position: relative;
  z-index: 1;
}
@media (min-width: 768px) and (max-width: 967px) {
  #archive-post-list .post-list {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 30px;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #archive-post-list .post-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
  }
}
@media (max-width: 479px) {
  #archive-post-list .post-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
  }
}
@media (max-width: 479px) {
  #archive-post-list .post-list .list-item {
    margin-top: 30px;
  }
}
#archive-post-list .post-list .list-item .post-item-inner .post-item .thum {
  aspect-ratio: 3/2;
}
#archive-post-list .post-list .list-item .post-item-inner .post-item .thum img {
  height: 100%;
}
#archive-post-list .post-list .list-item .post-item-inner .post-item .text-area {
  color: rgb(245, 245, 245);
  margin-top: 25px;
}
#archive-post-list .post-list .list-item .post-item-inner .post-item .text-area.black {
  color: rgb(35, 35, 35);
}
#archive-post-list .post-list .list-item .post-item-inner .post-item .text-area .cat {
  padding: 3px 8px;
  margin-right: 10px;
}
#archive-post-list .post-list .list-item .post-item-inner .post-item .text-area .cat.deals {
  border: 1px solid rgb(245, 245, 245);
  background-color: rgb(11, 74, 107);
  color: rgb(245, 245, 245);
}
#archive-post-list .post-list .list-item .post-item-inner .post-item .text-area .cat.info {
  border: 1px solid rgb(245, 245, 245);
  background-color: rgb(245, 245, 245);
  color: rgb(35, 35, 35);
}
#archive-post-list .post-list .list-item .post-item-inner .post-item .text-area .cat.event {
  border: 1px solid rgb(35, 35, 35);
  background-color: rgb(35, 35, 35);
  color: rgb(245, 245, 245);
}
#archive-post-list .post-list .list-item .post-item-inner .post-item .post-title {
  margin-top: 15px;
}
#archive-post-list .post-list {
  margin-top: 9.5168374817vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  #archive-post-list .post-list {
    margin-top: 12.7077223851vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  #archive-post-list .post-list {
    margin-top: 13.4436401241vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  #archive-post-list .post-list {
    margin-top: 16.9491525424vw;
  }
}
@media (max-width: 479px) {
  #archive-post-list .post-list {
    margin-top: 12.5260960334vw;
  }
}

.post-single {
  margin-bottom: 7.3206442167vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  .post-single {
    margin-bottom: 9.7751710655vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .post-single {
    margin-bottom: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .post-single {
    margin-bottom: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  .post-single {
    margin-bottom: 12.5260960334vw;
  }
}
.post-single .content-start {
  padding-top: 7.3206442167vw;
  padding-left: 4.39238653vw;
  padding-right: 4.39238653vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  .post-single .content-start {
    padding-top: 9.7751710655vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .post-single .content-start {
    padding-top: 10.3412616339vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .post-single .content-start {
    padding-top: 13.037809648vw;
  }
}
@media (max-width: 479px) {
  .post-single .content-start {
    padding-top: 12.5260960334vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  .post-single .content-start {
    padding-left: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .post-single .content-start {
    padding-left: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .post-single .content-start {
    padding-left: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  .post-single .content-start {
    padding-left: 0vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  .post-single .content-start {
    padding-right: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .post-single .content-start {
    padding-right: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .post-single .content-start {
    padding-right: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  .post-single .content-start {
    padding-right: 0vw;
  }
}
.post-single .sec-title {
  font-size: clamp(19px, 2.789vw, 27px);
  margin-bottom: 40px;
  text-align: center;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 968px) and (max-width: 1023px) {
  .post-single .sec-title {
    font-size: clamp(19px, 2.789vw, 27px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .post-single .sec-title {
    font-size: clamp(23px, 3.516vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .post-single .sec-title {
    font-size: clamp(29px, 5.625vw, 27px);
  }
}
@media (max-width: 479px) {
  .post-single .sec-title {
    font-size: clamp(18px, 5.625vw, 27px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .post-single .sec-title {
    text-align: left;
  }
}
@media (max-width: 479px) {
  .post-single .sec-title {
    text-align: left;
  }
}
.post-single .sec-title:before, .post-single .sec-title:after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  bottom: -12px;
  border: 1px solid rgb(35, 35, 35);
  z-index: 2;
}
.post-single .sec-title:before {
  left: 0;
}
.post-single .sec-title:after {
  left: 60px;
  right: initial;
}
.post-single .sec-title > span {
  position: absolute;
  height: 1px;
  background-color: rgb(35, 35, 35);
  bottom: -8px;
  left: calc(0% + 8px);
  width: 52px;
  z-index: 1;
}
.post-single .post-item-inner {
  margin-top: 8.0527086384vw;
  padding-left: 4.39238653vw;
  padding-right: 4.39238653vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  .post-single .post-item-inner {
    margin-top: 10.752688172vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .post-single .post-item-inner {
    margin-top: 11.3753877973vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .post-single .post-item-inner {
    margin-top: 14.3415906128vw;
  }
}
@media (max-width: 479px) {
  .post-single .post-item-inner {
    margin-top: 14.6137787056vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  .post-single .post-item-inner {
    padding-left: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .post-single .post-item-inner {
    padding-left: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .post-single .post-item-inner {
    padding-left: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  .post-single .post-item-inner {
    padding-left: 0vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  .post-single .post-item-inner {
    padding-right: 5.8651026393vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .post-single .post-item-inner {
    padding-right: 6.2047569804vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .post-single .post-item-inner {
    padding-right: 7.8226857888vw;
  }
}
@media (max-width: 479px) {
  .post-single .post-item-inner {
    padding-right: 0vw;
  }
}
.post-single .post-item-inner .post-item-outline {
  display: grid;
  grid-template-columns: 0.8fr 1fr;
  gap: 0 60px;
}
@media (max-width: 479px) {
  .post-single .post-item-inner .post-item-outline {
    display: grid;
    grid-template-columns: 1fr;
    gap: 25px;
  }
}
.post-single .post-item-inner .post-item-outline .content--item dl {
  display: flex;
  justify-content: space-between;
}
.post-single .post-item-inner .post-item-outline .content--item dl dt, .post-single .post-item-inner .post-item-outline .content--item dl dd {
  padding: 0px 30px;
}
.post-single .post-item-inner .post-item-outline .content--item dl dt {
  width: 32%;
  background-color: rgb(11, 74, 107);
  color: rgb(245, 245, 245);
  line-height: 2.8;
}
.post-single .post-item-inner .post-item-outline .content--item dl dd {
  width: 68%;
  background-color: rgb(241, 241, 241);
  color: rgb(35, 35, 35);
  line-height: 1.7;
}
.post-single .post-item-inner .post-item-outline .content--item dl:nth-child(1) dt, .post-single .post-item-inner .post-item-outline .content--item dl:nth-child(1) dd {
  padding-top: 20px;
}
.post-single .post-item-inner .post-item-outline .content--item dl:nth-last-child(1) dt, .post-single .post-item-inner .post-item-outline .content--item dl:nth-last-child(1) dd {
  padding-bottom: 20px;
}
.post-single .gallery {
  margin-top: 8.0527086384vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  .post-single .gallery {
    margin-top: 10.752688172vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .post-single .gallery {
    margin-top: 11.3753877973vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .post-single .gallery {
    margin-top: 14.3415906128vw;
  }
}
@media (max-width: 479px) {
  .post-single .gallery {
    margin-top: 14.6137787056vw;
  }
}
.post-single .gallery #thumbs .swiper-wrapper {
  margin-left: -0.5490483163vw;
  margin-right: -0.5490483163vw;
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  flex-basis: 11.2737920937vw;
}
@media (min-width: 968px) and (max-width: 1023px) {
  .post-single .gallery #thumbs .swiper-wrapper {
    margin-left: -0.7331378299vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .post-single .gallery #thumbs .swiper-wrapper {
    margin-left: -0.7755946225vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .post-single .gallery #thumbs .swiper-wrapper {
    margin-left: -0.9778357236vw;
  }
}
@media (max-width: 479px) {
  .post-single .gallery #thumbs .swiper-wrapper {
    margin-left: -1.5657620042vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  .post-single .gallery #thumbs .swiper-wrapper {
    margin-right: -0.7331378299vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .post-single .gallery #thumbs .swiper-wrapper {
    margin-right: -0.7755946225vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .post-single .gallery #thumbs .swiper-wrapper {
    margin-right: -0.9778357236vw;
  }
}
@media (max-width: 479px) {
  .post-single .gallery #thumbs .swiper-wrapper {
    margin-right: -1.5657620042vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  .post-single .gallery #thumbs .swiper-wrapper {
    flex-basis: 15.0537634409vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .post-single .gallery #thumbs .swiper-wrapper {
    flex-basis: 15.9255429162vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .post-single .gallery #thumbs .swiper-wrapper {
    flex-basis: 20.0782268579vw;
  }
}
@media (max-width: 479px) {
  .post-single .gallery #thumbs .swiper-wrapper {
    flex-basis: 14.6137787056vw;
  }
}
.post-single .gallery #thumbs .swiper-wrapper .swiper-item {
  margin-left: 0.5490483163vw;
  margin-right: 0.5490483163vw;
  margin-bottom: 1.0980966325vw;
  max-width: 20%;
  height: 220px;
}
@media (min-width: 968px) and (max-width: 1023px) {
  .post-single .gallery #thumbs .swiper-wrapper .swiper-item {
    margin-left: 0.7331378299vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .post-single .gallery #thumbs .swiper-wrapper .swiper-item {
    margin-left: 0.7755946225vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .post-single .gallery #thumbs .swiper-wrapper .swiper-item {
    margin-left: 0.9778357236vw;
  }
}
@media (max-width: 479px) {
  .post-single .gallery #thumbs .swiper-wrapper .swiper-item {
    margin-left: 1.5657620042vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  .post-single .gallery #thumbs .swiper-wrapper .swiper-item {
    margin-right: 0.7331378299vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .post-single .gallery #thumbs .swiper-wrapper .swiper-item {
    margin-right: 0.7755946225vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .post-single .gallery #thumbs .swiper-wrapper .swiper-item {
    margin-right: 0.9778357236vw;
  }
}
@media (max-width: 479px) {
  .post-single .gallery #thumbs .swiper-wrapper .swiper-item {
    margin-right: 1.5657620042vw;
  }
}
@media (min-width: 968px) and (max-width: 1023px) {
  .post-single .gallery #thumbs .swiper-wrapper .swiper-item {
    margin-bottom: 1.4662756598vw;
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .post-single .gallery #thumbs .swiper-wrapper .swiper-item {
    margin-bottom: 1.5511892451vw;
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .post-single .gallery #thumbs .swiper-wrapper .swiper-item {
    margin-bottom: 1.9556714472vw;
  }
}
@media (max-width: 479px) {
  .post-single .gallery #thumbs .swiper-wrapper .swiper-item {
    margin-bottom: 3.1315240084vw;
  }
}
@media (max-width: 479px) {
  .post-single .gallery #thumbs .swiper-wrapper .swiper-item {
    max-width: 46%;
    height: 160px;
  }
}
.post-single .gallery #thumbs .swiper-wrapper .swiper-item img {
  object-fit: cover;
  height: 220px;
}
@media (max-width: 479px) {
  .post-single .gallery #thumbs .swiper-wrapper .swiper-item img {
    height: 160px;
  }
}
.single-post .outline div, .single-post .outline p {
  line-height: 2;
}
.single-post .outline b, .single-post .outline strong {
  font-weight: 600;
  position: relative;
  text-decoration: none;
  z-index: 1;
  display: inline;
  padding: 0 2px 4px;
}
.single-post .outline u {
  position: relative;
  text-decoration: none;
  background: linear-gradient(transparent 80%, rgba(11, 74, 107, 0.3) 0%);
  display: inline;
  padding: 0 2px 4px;
}
.single-post .outline ul, .single-post .outline ol {
  margin-top: 2.196193265vw;
  margin-bottom: 2.196193265vw;
}
.single-post .outline ul li, .single-post .outline ol li {
  position: relative;
  padding-left: 20px;
  display: flex;
  justify-content: flex-start;
  margin-bottom: 1.4641288433vw;
  line-height: 1.65;
}
.single-post .outline ul li:before, .single-post .outline ol li:before {
  content: "・";
  font-weight: 600;
  position: absolute;
  width: 20px;
  left: 0;
  top: 0px;
  color: rgb(11, 74, 107);
}
.single-post .outline ol {
  counter-reset: num;
  list-style-type: none !important;
}
.single-post .outline ol li {
  padding-left: 28px;
}
.single-post .outline ol li:before {
  content: "";
  counter-increment: num;
  content: counter(num) ".";
  font-weight: 400;
  position: absolute;
  width: 20px;
  left: 0;
  top: 0px;
}
.single-post .outline h3 {
  color: rgb(11, 74, 107);
  font-size: clamp(15px, 2.169vw, 21px);
  font-weight: 500;
}
@media (min-width: 968px) and (max-width: 1023px) {
  .single-post .outline h3 {
    font-size: clamp(15px, 2.169vw, 21px);
  }
}
@media (min-width: 768px) and (max-width: 967px) {
  .single-post .outline h3 {
    font-size: clamp(17px, 2.734vw, 21px);
  }
}
@media (min-width: 480px) and (max-width: 767px) {
  .single-post .outline h3 {
    font-size: clamp(23px, 4.375vw, 21px);
  }
}
@media (max-width: 479px) {
  .single-post .outline h3 {
    font-size: clamp(14px, 4.375vw, 21px);
  }
}
.single-post .outline blockquote {
  background-color: rgb(241, 241, 241);
  padding: 2.196193265vw 2.196193265vw;
  margin-top: 2.196193265vw;
  margin-bottom: 2.196193265vw;
  position: relative;
  line-height: 2;
}
.single-post .outline a {
  text-decoration: none;
  position: relative;
  color: rgb(35, 35, 35);
  font-weight: 400;
  word-break: break-all;
  z-index: 1;
  background: linear-gradient(transparent 80%, rgba(11, 74, 107, 0.3) 0%);
  display: inline;
  padding: 0 2px 4px;
}
.single-post .outline a:hover {
  background: linear-gradient(transparent 80%, rgba(11, 74, 107, 0.7) 0%);
}
.single-post .outline p > iframe {
  width: 100%;
  height: 100%;
  margin-bottom: 3.6603221083vw;
}
.single-post .outline p > iframe {
  width: 100%;
  aspect-ratio: 16/9;
}

input, textarea, select {
  background: rgb(241, 241, 241);
  border: 1px solid rgb(241, 241, 241);
  padding: 8px 16px;
  width: 100%;
}

div.wpcf7-validation-errors, div.wpcf7-acceptance-missing, .wpcf7-response-output {
  border: 1px solid rgb(11, 74, 107) !important;
}

.wpcf7-not-valid-tip {
  font-size: clamp(11px, 1.693vw, 13px) !important;
  color: rgb(11, 74, 107) !important;
  margin-left: 0.7320644217vw;
  display: inline-block !important;
}

.wpcf7-list-item label {
  display: grid;
  grid-template-columns: 20px 1fr;
  gap: 8px;
  align-items: center;
}
.wpcf7-list-item label input[type=checkbox] {
  padding: 2px 2px;
  width: 20px;
  height: 20px;
}

@media (max-width: 479px) {
  #contact #title .sec-title h2 {
    font-size: clamp(21px, 6.563vw, 21px);
  }
}
#contact .inner .form_area {
  margin-top: 7.3206442167vw;
  max-width: 768px;
  margin-left: auto;
  margin-right: auto;
}
#contact .inner .form_area label {
  font-size: clamp(13px, 1.953vw, 15px);
  font-weight: 500;
}
#contact .inner .form_area label em {
  font-size: clamp(11px, 1.693vw, 13px);
  font-style: normal;
}
#contact .inner .form_area .wpcf7-radio {
  margin-bottom: 1.4641288433vw;
}
#contact .inner .form_area .sub {
  font-size: clamp(11px, 1.693vw, 13px);
  font-style: normal;
}
#contact .inner .form_area .small {
  max-width: 100px;
}
#contact .inner .form_area .wpcf7-submit {
  width: initial;
  margin-left: auto;
  margin-right: auto;
  display: block;
}
