@charset "UTF-8";
@keyframes fadeInPage {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes shine {
  100% {
    left: 125%;
  }
}
@keyframes scrollAnime {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}
@keyframes mediaImgCarousel {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-177.3333333333vw);
  }
}
/* 
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com 
Twitter: @rich_clark
*/
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  text-decoration: none;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

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

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

/***-----------------------------------
iOSでのデフォルトスタイルをリセット
-----------------------------------***/
input[type=submit], input[type=button] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  -moz-appearance: button;
       appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}

input[type=submit]::-webkit-search-decoration, input[type=button]::-webkit-search-decoration {
  display: none;
}

input[type=submit]::focus, input[type=button]::focus {
  outline-offset: -2px;
}

/***-----------------------------------
スタイル
-----------------------------------***/
body {
  background: rgb(255, 255, 255);
  /* font-family: 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif; */
  font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  font-weight: normal;
  color: rgb(50, 50, 50);
}

a {
  color: rgb(50, 50, 50);
}

a:hover {
  color: rgb(50, 50, 50);
}

a:active {
  color: rgb(50, 50, 50);
}

.center {
  text-align: center;
}

.left {
  text-align: left;
}

.right {
  text-align: right;
}

.clearfix {
  overflow: hidden;
}

.dot {
  -webkit-text-emphasis: filled dot rgb(255, 245, 30);
  text-emphasis: filled dot rgb(255, 245, 30);
}

.end {
  text-decoration: line-through;
}

.respon {
  width: 100%;
}

.respon-sp {
  max-width: 100%;
}

.str {
  font-weight: bold;
}

.ul {
  text-decoration: underline;
}

.ym {
  background: linear-gradient(transparent 60%, rgb(255, 250, 135) 60%);
  font-weight: bold;
}

.is-marker {
  font-weight: bold;
  background: linear-gradient(transparent 60%, #ffe958 60%, #ffe958 90%, transparent 90%);
}

.aqua {
  color: rgb(135, 195, 225);
}

.beige {
  color: rgb(255, 250, 165);
}

.black {
  color: rgb(0, 0, 0);
}

.blue {
  color: rgb(0, 105, 175);
}

.gray {
  color: rgb(210, 210, 210);
}

.green {
  color: rgb(55, 195, 155);
}

.navy {
  color: rgb(25, 40, 115);
}

.orange {
  color: rgb(255, 155, 0);
}

.pink {
  color: rgb(240, 130, 160);
}

.red {
  color: rgb(160, 0, 15);
}

.white {
  color: rgb(255, 255, 255);
}

.yellow {
  color: rgb(250, 240, 45);
}

/***-----------------------------------
pcとspでの表示非表示
-----------------------------------***/
.pc {
  display: none !important;
}

@media screen and (min-width: 640px) {
  .pc {
    display: block !important;
  }
}
.sp {
  display: block !important;
}

@media screen and (min-width: 640px) {
  .sp {
    display: none !important;
  }
}
/***-----------------------------------
font-size
-----------------------------------***/
.font120 {
  font-size: 120%;
}

.font150 {
  font-size: 150%;
}

.font180 {
  font-size: 180%;
}

.font210 {
  font-size: 210%;
}

.font240 {
  font-size: 240%;
}

@media screen and (min-width: 640px) {
  #access {
    /* margin-top: 40px; */
  }
}
@media (max-width: 640px) {
  #access h1 {
    font-size: 200%;
    padding-left: 5%;
    padding-right: 5%;
  }
}
.wrapper {
  background: url(../assets/img/bg.png) repeat;
}

.copyright {
  margin-top: 20px;
}

figcaption {
  line-height: 1.5;
}

.staticMain {
  margin-top: 100px;
}

@media screen and (min-width: 640px) {
  .staticMain {
    margin-top: 40px;
  }
}
/**
 * Swiper 9.2.4
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2023 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: April 21, 2023
 */
@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, swiper-container {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  z-index: 1;
  display: block;
}

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

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
  box-sizing: content-box;
}

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

.swiper-horizontal {
  touch-action: pan-y;
}

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

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

.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-backface-hidden .swiper-slide {
  transform: translateZ(0);
  backface-visibility: hidden;
}

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

.swiper-3d .swiper-wrapper {
  transform-style: preserve-3d;
}

.swiper-3d {
  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 {
  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-wrapper > .swiper-slide {
  scroll-snap-align: center center;
  scroll-snap-stop: always;
}

.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-lazy-preloader {
  width: 42px;
  height: 42px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -21px;
  margin-top: -21px;
  z-index: 10;
  transform-origin: 50%;
  box-sizing: border-box;
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-radius: 50%;
  border-top-color: transparent;
}

.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader, .swiper:not(.swiper-watch-progress) .swiper-lazy-preloader, swiper-container:not(.swiper-watch-progress) .swiper-lazy-preloader {
  animation: swiper-preloader-spin 1s infinite linear;
}

.swiper-lazy-preloader-white {
  --swiper-preloader-color:#fff;
}

.swiper-lazy-preloader-black {
  --swiper-preloader-color:#000;
}

@keyframes swiper-preloader-spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.swiper-virtual .swiper-slide {
  -webkit-backface-visibility: hidden;
  transform: translateZ(0);
}

.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: var(--swiper-navigation-top-offset, 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.swiper-button-hidden, .swiper-button-prev.swiper-button-hidden {
  opacity: 0;
  cursor: auto;
  pointer-events: none;
}

.swiper-navigation-disabled .swiper-button-next, .swiper-navigation-disabled .swiper-button-prev {
  display: none !important;
}

.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;
  font-variant: initial;
  line-height: 1;
}

.swiper-button-prev, .swiper-rtl .swiper-button-next {
  left: var(--swiper-navigation-sides-offset, 10px);
  right: auto;
}

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

.swiper-button-next, .swiper-rtl .swiper-button-prev {
  right: var(--swiper-navigation-sides-offset, 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-pagination-disabled > .swiper-pagination, .swiper-pagination.swiper-pagination-disabled {
  display: none !important;
}

.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
  bottom: var(--swiper-pagination-bottom, 8px);
  top: var(--swiper-pagination-top, auto);
  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: var(--swiper-pagination-bullet-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;
  -moz-appearance: none;
       appearance: none;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}

.swiper-pagination-bullet:only-child {
  display: none !important;
}

.swiper-pagination-bullet-active {
  opacity: 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: var(--swiper-pagination-right, 8px);
  left: var(--swiper-pagination-left, auto);
  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, :host(.swiper-horizontal.swiper-rtl) .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 0.2s transform, 0.2s right;
}

.swiper-pagination-fraction {
  color: var(--swiper-pagination-fraction-color, inherit);
}

.swiper-pagination-progressbar {
  background: var(--swiper-pagination-progressbar-bg-color, 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: var(--swiper-pagination-progressbar-size, 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: var(--swiper-pagination-progressbar-size, 4px);
  height: 100%;
  left: 0;
  top: 0;
}

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

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

.swiper-scrollbar-disabled > .swiper-scrollbar, .swiper-scrollbar.swiper-scrollbar-disabled {
  display: none !important;
}

.swiper-horizontal > .swiper-scrollbar, .swiper-scrollbar.swiper-scrollbar-horizontal {
  position: absolute;
  left: var(--swiper-scrollbar-sides-offset, 1%);
  bottom: var(--swiper-scrollbar-bottom, 4px);
  top: var(--swiper-scrollbar-top, auto);
  z-index: 50;
  height: var(--swiper-scrollbar-size, 4px);
  width: calc(100% - 2 * var(--swiper-scrollbar-sides-offset, 1%));
}

.swiper-scrollbar.swiper-scrollbar-vertical, .swiper-vertical > .swiper-scrollbar {
  position: absolute;
  left: var(--swiper-scrollbar-left, auto);
  right: var(--swiper-scrollbar-right, 4px);
  top: var(--swiper-scrollbar-sides-offset, 1%);
  z-index: 50;
  width: var(--swiper-scrollbar-size, 4px);
  height: calc(100% - 2 * var(--swiper-scrollbar-sides-offset, 1%));
}

.swiper-scrollbar-drag {
  height: 100%;
  width: 100%;
  position: relative;
  background: var(--swiper-scrollbar-drag-bg-color, rgba(0, 0, 0, 0.5));
  border-radius: var(--swiper-scrollbar-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%;
  -o-object-fit: contain;
     object-fit: contain;
}

.swiper-slide-zoomed {
  cursor: move;
  touch-action: none;
}

.swiper .swiper-notification, swiper-container .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;
  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;
  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;
  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;
  backface-visibility: hidden;
}

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

.swiper-cards {
  overflow: visible;
}

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

header.title {
  width: 90%;
  margin: 0 auto;
}

.pageTitle {
  font-size: 250%;
  font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
  letter-spacing: 4px;
  line-height: 1.2;
  text-align: center;
  color: #3c4169;
}

/***-----------------------------------
料金表
-----------------------------------***/
header.title {
  width: 90%;
  margin: 0 auto;
}

#cost .container {
  max-width: 700px;
}

#cost h2 {
  text-align: left;
  font-size: 150%;
  margin-bottom: 10px;
  color: #3c4169;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}

#cost .box {
  /* margin-bottom: 70px; */
}

#cost table {
  width: 100%;
  margin: 0 auto;
  background: #FFF;
  margin-bottom: 20px;
}

#cost thead {
  border-top: solid 1px #999;
  background: rgb(190, 190, 230);
}

#cost thead td {
  background: rgb(190, 190, 230) !important;
  letter-spacing: 3px !important;
}

#cost table td {
  line-height: 160%;
  letter-spacing: 1px;
  padding: 15px 20px;
  border-top: none;
  border-bottom: solid 1px #999;
  text-align: center;
  vertical-align: middle;
  border-collapse: collapse;
}

#cost table td:nth-child(1) {
  border-right: dotted 1px #999;
}

#cost table td:nth-child(2) {
  border-right: dotted 1px #999;
  background: rgb(240, 240, 255);
  text-shadow: 0.3px 0.3px 0, 0.3px -0.3px 0px, -0.3px 0.3px 0, -0.3px -0.3px 0px, 0.3px 0px 0px, 0px 0.3px 0px, -0.3px 0px 0px, 0px -0.3px 0px;
  letter-spacing: 1px;
}

#cost table td:last-child {
  border-right: none;
}

#cost table td.name {
  width: 25%;
}

#cost table td.price {
  font-size: 170%;
}

#cost .seki {
  font-size: 70%;
  line-height: 1;
}

#cost .day {
  font-size: 70%;
  line-height: 1;
}

#cost .en {
  font-size: 70%;
}

#cost .target {
  border-top: solid 1px #999;
  border-bottom: solid 1px #999;
  background: #FFF;
  padding: 20px 30px;
  line-height: 160%;
  font-size: 120%;
}

#cost .att {
  font-size: 90%;
  line-height: 150%;
}

#cost .contact {
  /* margin-top: -50px; */
  background: rgb(240, 240, 255);
}

#cost .contact h2 {
  font-size: 180%;
  text-align: center;
  margin-bottom: 30px;
  color: #333;
  font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
}

#cost .contact .btnTxt {
  text-align: center;
  color: rgb(60, 65, 105);
  font-size: 130%;
  line-height: 1.4;
  margin-bottom: 30px;
}

/***-----------------------------------
モバイル用スタイル
-----------------------------------***/
@media (max-width: 640px) {
  #cost h1 {
    font-size: 200%;
    padding-left: 5%;
    padding-right: 5%;
  }
  #cost h2 {
    font-size: 130%;
  }
  #cost table td {
    padding: 10px;
    border-top: none;
    letter-spacing: 2px;
  }
  #cost table td.name {
    letter-spacing: 0.5px !important;
    line-height: 120%;
  }
  #cost table td.price {
    padding: 10px 5px;
    font-size: 6vw;
    letter-spacing: 0.5px !important;
  }
  #cost table td:nth-child(2) {
    font-weight: bold;
    text-shadow: none;
  }
  #cost table .border {
    border-top: solid 1px #999;
    margin: 5px 0;
  }
  #cost .contact .btnTxt {
    text-align: left;
  }
}
/***-----------------------------------
ご葬儀の事前相談お問い合わせはこちら
-----------------------------------***/
#counsel .lead {
  text-align: center;
  margin-top: 40px;
}

#counsel .number {
  margin: 60px auto 20px;
}

#counsel .number .no {
  margin: 0 auto 10px;
  width: 100px;
  border-bottom: solid 2px rgb(60, 65, 105);
  text-align: center;
  color: #3c4169;
  font-size: 280%;
  font-weight: bold;
  line-height: 1.4;
  font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
}

#counsel .soudan {
  background: #fff;
  border: solid 1px #ccc;
  margin: 10px auto 20px;
  width: 1000px;
  overflow: hidden;
}

#counsel .soudan li {
  width: 248px;
  float: left;
  border-right: dotted 1px #ccc;
  padding: 20px 0;
  list-style: none;
  text-align: center;
  letter-spacing: 0;
  color: #3c4169;
}

#counsel .soudan li:last-child {
  border-right: none;
}

#counsel .soudan li p {
  text-align: center;
}

/* お客様に合わせてお選び */
#counsel .select {
  width: 780px;
  margin: 0 auto 80px;
  overflow: hidden;
  background: #fff;
  border-left: 1px dotted #cacaca;
}

#counsel .select li {
  width: 257px;
  float: left;
  text-align: center;
  padding: 0 1px;
  border-right: 1px dotted #cacaca;
  list-style: none;
}

#counsel .select li.last {
  border: none;
  width: 256px;
}

#counsel .select li .photo {
  margin-bottom: 15px;
}

#counsel .select li .txt {
  text-align: left;
  padding: 10px 20px;
}

#counsel .select li .link a {
  color: #222;
  height: 36px;
  margin: 5px 25px 20px 25px;
  display: block;
  text-align: center;
  line-height: 36px;
  text-decoration: none;
  border: 1px solid #497BAE;
}

#counsel .select li .link a:hover {
  color: #222;
  text-decoration: none;
  background: #C9EAF2;
}

#counsel .select li .link a i {
  padding-right: 5px;
  color: #497BAE;
}

#counsel .select li .link a:hover i {
  color: #fff;
}

#counsel .select li h4 {
  font-weight: normal;
  font-size: 110%;
  margin-bottom: 5px;
  color: rgb(60, 65, 105);
}

/* オンライン */
#counsel .online {
  background: rgb(240, 240, 255);
}

#counsel .online .inner {
  margin: 0 auto;
  width: 960px;
  padding: 50px 0;
}

#counsel .online .inner {
  margin: 0 auto;
  width: 960px;
  padding: 40px 0;
  color: rgb(60, 65, 105);
}

#counsel .online .txt01 {
  font-size: 150%;
  text-align: center;
  line-height: 1.4;
  margin: 40px 0 20px;
}

#counsel .online .txt02 {
  font-size: 200%;
  text-align: center;
  margin-bottom: 20px;
}

/* 対面相談 */
#counsel .faceTo {
  background: #fff;
  padding-top: 50px;
}

#counsel .step {
  width: 868px;
  overflow: hidden;
  padding: 30px;
  border: 1px solid #cacaca;
  margin: 0 auto -40px;
}

#counsel .step h3.boxTitle {
  font-size: 30px;
  font-weight: normal;
  text-align: center;
  padding: 0 0 20px;
}

#counsel .step ol {
  overflow: hidden;
  width: 868px;
  margin-bottom: 10px;
  list-style: none;
}

#counsel .step .box {
  float: left;
}

#counsel .step .wrap {
  padding: 10px;
}

#counsel .step .border {
  border-right: 1px dotted #cacaca;
  padding: 10px;
  height: 130px;
}

#counsel .step h3.flow {
  border-top: 1px solid #cacaca;
  border-bottom: 1px solid #cacaca;
  background: #f6f6f6;
  color: #333;
  font-size: 12px;
  font-weight: normal;
  padding: 5px 0 0 15px;
  line-height: 26px;
}

#counsel .step h3.flow span {
  font-size: 30px;
}

#counsel .step .step1 h3 {
  border-left: 1px solid #cacaca;
}

#counsel .step .step2 h3 {
  border-right: 1px solid #cacaca;
}

#counsel .step .step3 h3 {
  border-right: 1px solid #cacaca;
  background: #f0bd34;
  color: #fff;
}

#counsel .step h4 {
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝L", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-size: 30px;
  font-weight: 100;
  letter-spacing: -0.5px;
  margin: 10px 0;
}

#counsel .step .ph {
  text-align: center;
  margin: 10px 0 20px 10px;
  float: right;
}

#counsel .step p {
  font-size: 0.8em;
  line-height: 1.6;
  letter-spacing: 1px;
}

#counsel .step .step1,
#counsel .step .step2 {
  width: 30%;
}

#counsel .step .step3 {
  width: 40%;
}

#counsel .step .longArrow {
  position: relative;
}

#counsel .step .longArrow::before {
  content: "";
  display: block;
  position: absolute;
  top: 9px;
  left: 0px;
  width: 864px;
  height: 8px;
  background: linear-gradient(to right, #f4e4b8, #f0bd34);
}

#counsel .step .longArrow::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 838px;
  width: 14px;
  height: 14px;
  border: 6px solid;
  border-color: transparent transparent #f0bd34 #f0bd34;
  transform: rotate(-135deg);
}

#counsel .step .term {
  margin-top: 35px;
  text-align: center;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝L", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-size: 26px;
  font-weight: bold;
}

#counsel .faceTo .txt01 {
  font-size: 150%;
  text-align: center;
  line-height: 1.4;
  margin: 40px 0 20px;
  color: rgb(60, 65, 105);
}

#counsel .faceTo .txt02 {
  font-size: 200%;
  text-align: center;
  margin-bottom: 20px;
  color: rgb(60, 65, 105);
}

/* 電話相談 */
#counsel .telContact {
  background: rgb(240, 240, 255);
}

#counsel .telContact h3 {
  font-size: 250%;
  text-align: center;
}

#counsel .telContact .txt01 {
  font-size: 150%;
  text-align: center;
  line-height: 1.4;
  margin: 40px 0 20px;
  color: rgb(60, 65, 105);
}

#counsel .telContact .txt02 {
  font-size: 200%;
  text-align: center;
  margin-bottom: 20px;
  color: rgb(60, 65, 105);
}

#counsel .txtCenter {
  text-align: center;
}

#counsel .mb20 {
  margin-bottom: 20px;
}

#counsel .mb50 {
  margin-bottom: 50px;
}

/***-----------------------------------
telButton
-----------------------------------***/
.telButton {
  text-align: center;
}

.telButton a {
  width: 420px;
  padding: 15px 0 20px;
  display: inline-block;
  background: linear-gradient(#505082 0%, #323264 50%, #28285a 51%, #000032 100%);
  border: solid 1px #390000;
  color: rgb(255, 255, 255);
  font-size: 24px;
  border-radius: 6px;
}

.telButton a:hover {
  transition: 0.3s all;
  opacity: 0.6;
}

.telButton a p {
  font-size: 40px;
  color: rgb(255, 255, 255);
  line-height: 120%;
  font-weight: bold;
  text-align: center;
}

.telButton a p:nth-of-type(2) {
  color: rgb(255, 255, 255);
  font-size: 25px;
  line-height: 150%;
  font-weight: bold;
  text-align: center;
}

@media (max-width: 640px) {
  .telButton a {
    width: 96%;
    font-size: 100%;
  }
  .telButton a p {
    font-size: 200%;
  }
  .telButton a p:nth-of-type(2) {
    font-size: 120%;
  }
}
/***-----------------------------------
モバイル用スタイル
-----------------------------------***/
@media (max-width: 640px) {
  #counsel h1 {
    font-size: 200%;
    padding-left: 5%;
    padding-right: 5%;
  }
  #counsel .lead {
    width: 90%;
    margin: 40px auto 0;
    text-align: left;
  }
  #counsel .spTxt {
    width: 90%;
    margin: 0 auto 20px;
    text-align: left;
  }
  #counsel .number {
    margin: 40px auto 20px;
  }
  #counsel .select {
    border-left: none;
    width: 90%;
  }
  #counsel .select li {
    width: auto;
    float: none;
    border-right: none;
  }
  #counsel .select li h4 {
    font-size: 140%;
    font-weight: bold;
  }
  #counsel .online .inner {
    width: 90%;
  }
  #counsel .online img {
    width: 100%;
    height: auto;
  }
  #counsel .txt01 {
    text-align: left !important;
  }
  #counsel .txt02 {
    text-align: left !important;
    line-height: 1.4;
    font-weight: bold !important;
  }
  /* step */
  #counsel .step {
    width: 90%;
    background: url(../static/img/counsel/arrow_o_bg.gif) 100% center no-repeat;
    background-size: 26px;
    padding: 0;
    margin: 20px auto -40px;
    border: 1px solid #cacaca;
  }
  #counsel .step h3.boxTitle {
    font-size: 7vw;
    font-weight: normal;
    text-align: center;
    padding: 15px 0 0;
  }
  #counsel .step ol {
    overflow: hidden;
    width: 95%;
    margin: 0 0 0 10px;
  }
  #counsel .step .box {
    float: none;
  }
  #counsel .step .wrap {
    border-bottom: 1px dotted #cacaca;
  }
  #counsel .step .border {
    border-right: none;
    padding: 10px 0;
    overflow: hidden;
    height: auto;
  }
  #counsel .step .border p {
    margin: 0;
  }
  #counsel .step h3.flow {
    display: none;
  }
  #counsel .step h4 {
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝L", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-size: 6vw;
    font-weight: bold;
    padding-bottom: 10px;
    letter-spacing: -0.5px;
  }
  #counsel .step .ph {
    padding-left: 5px;
  }
  #counsel .step .ph img {
    width: auto;
    float: right;
    padding-left: 5px;
  }
  #counsel .step .step1,
  #counsel .step .step2,
  #counsel .step .step3 {
    width: 90%;
    overflow: hidden;
  }
  #counsel .step .step3 ul {
    margin-bottom: 20px;
  }
  #counsel .step .step3 li {
    list-style-type: disc;
    margin-left: 40px;
  }
  #counsel .step .longArrow {
    display: none;
  }
  #counsel .step .term {
    font-size: 80%;
    text-align: left;
    margin: 20px 10px;
  }
}
/***-----------------------------------
モバイル用スタイル（横置き）
-----------------------------------***/
@media (max-width: 896px) and (orientation: landscape) {
  #counsel .lead {
    width: 90%;
    margin: 40px auto 0;
    text-align: left;
  }
  #counsel .spTxt {
    width: 90%;
    margin: 0 auto 20px;
    text-align: left;
  }
  #counsel .number {
    margin: 40px auto 20px;
  }
  #counsel .soudan {
    width: 500px;
  }
  #counsel .soudan li:first-child {
    border-bottom: dotted 1px #ccc;
  }
  #counsel .soudan li:nth-child(2) {
    border-bottom: dotted 1px #ccc;
    border-right: none;
  }
  #counsel .select {
    border-left: none;
    width: 90%;
  }
  #counsel .select li {
    width: auto;
    float: none;
    border-right: none;
  }
  #counsel .select li h4 {
    font-size: 140%;
    font-weight: bold;
  }
  #counsel .online .inner {
    width: 90%;
  }
  #counsel .online img {
    width: 100%;
    height: auto;
  }
  #counsel .txt01 {
    text-align: left !important;
  }
  #counsel .txt02 {
    text-align: left !important;
    line-height: 1.4;
    font-weight: bold !important;
  }
  /* step */
  #counsel .step {
    width: 90%;
    background: url(../assets/img/counsel/arrow_o_bg.gif) 100% center no-repeat;
    background-size: 26px;
    padding: 0;
    margin: 20px auto -40px;
    border: 1px solid #cacaca;
  }
  #counsel .step h3.boxTitle {
    font-size: 7vw;
    font-weight: normal;
    text-align: center;
    padding: 15px 0 0;
  }
  #counsel .step ol {
    overflow: hidden;
    width: 95%;
    margin: 0 0 0 10px;
  }
  #counsel .step .box {
    float: none;
  }
  #counsel .step .wrap {
    border-bottom: 1px dotted #cacaca;
  }
  #counsel .step .border {
    border-right: none;
    padding: 10px 0;
    overflow: hidden;
    height: auto;
  }
  #counsel .step .border p {
    margin: 0;
  }
  #counsel .step h3.flow {
    display: none;
  }
  #counsel .step h4 {
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝L", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-size: 6vw;
    font-weight: bold;
    padding-bottom: 10px;
    letter-spacing: -0.5px;
  }
  #counsel .step .ph {
    padding-left: 5px;
  }
  #counsel .step .ph img {
    width: auto;
    float: right;
    padding-left: 5px;
  }
  #counsel .step .step1,
  #counsel .step .step2,
  #counsel .step .step3 {
    width: 90%;
    overflow: hidden;
  }
  #counsel .step .step3 ul {
    margin-bottom: 20px;
  }
  #counsel .step .step3 li {
    list-style-type: disc;
    margin-left: 40px;
  }
  #counsel .step .longArrow {
    display: none;
  }
  #counsel .step .term {
    font-size: 120%;
    text-align: left;
    margin: 20px 10px;
  }
}
/***-----------------------------------
お葬式の流れ
-----------------------------------***/
#flow .content {
  margin: -30px auto 0;
  width: 90%;
  max-width: 700px;
  padding-bottom: 40px;
}

#flow .number {
  margin: 60px auto 20px;
}

#flow .number .no {
  margin: 0 auto 10px;
  width: 100px;
  border-bottom: solid 2px rgb(60, 65, 105);
  text-align: center;
  color: #3c4169;
  font-size: 280%;
  font-weight: bold;
  line-height: 1.4;
  font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
}

#flow .content h3 {
  color: #3c4169;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}

#flow .content ul {
  background: #fff;
  padding: 10px 30px 20px;
  border-radius: 10px;
  margin: 10px auto 20px;
}

#flow .content li {
  background: #fff;
  border-bottom: solid 1px #ccc;
  padding: 5px 0;
  list-style: inside;
}

#flow .contact {
  background: rgb(240, 240, 255);
}

#flow .contact h2 {
  font-size: 150%;
  text-align: center;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  letter-spacing: 1px;
  color: rgb(60, 65, 105);
}

#flow .contact .btnTxt {
  text-align: center;
  color: rgb(60, 65, 105);
  font-size: 180%;
  line-height: 1.4;
  margin: 30px 0;
}

#flow .att {
  font-size: 90%;
  color: #666;
}

#flow .mb20 {
  margin-bottom: 20px;
}

#flow .mb50 {
  margin-bottom: 50px;
}

/***-----------------------------------
telButton
-----------------------------------***/
.telButton {
  text-align: center;
}

.telButton a {
  width: 420px;
  padding: 15px 0 20px;
  display: inline-block;
  background: linear-gradient(#505082 0%, #323264 50%, #28285a 51%, #000032 100%);
  border: solid 1px #390000;
  color: rgb(255, 255, 255);
  font-size: 24px;
  border-radius: 6px;
}

.telButton a:hover {
  transition: 0.3s all;
  opacity: 0.6;
}

.telButton a p {
  font-size: 40px;
  color: rgb(255, 255, 255);
  line-height: 120%;
  font-weight: bold;
  text-align: center;
}

.telButton a p:nth-of-type(2) {
  color: rgb(255, 255, 255);
  font-size: 25px;
  line-height: 150%;
  font-weight: bold;
  text-align: center;
}

@media (max-width: 640px) {
  .telButton a {
    width: 96%;
    font-size: 100%;
  }
  .telButton a p {
    font-size: 200%;
  }
  .telButton a p:nth-of-type(2) {
    font-size: 120%;
  }
}
/***-----------------------------------
モバイル用スタイル
-----------------------------------***/
@media (max-width: 640px) {
  #flow h1 {
    font-size: 200%;
    padding-left: 5%;
    padding-right: 5%;
  }
}
/***-----------------------------------
hall
-----------------------------------***/
main#hall {
  margin: 0 auto;
  padding-bottom: 200px;
  width: 90%;
}

#hall h2 {
  padding-top: 200px;
  padding-bottom: 30px;
}

#hall p {
  text-align: center;
}

/***-----------------------------------
式場･火葬場のご予約はこちら
-----------------------------------***/
#hurry .reservation h2 {
  margin-bottom: 0;
}

#hurry .contact {
  background: rgb(240, 240, 255);
}

#hurry .contact h2 {
  font-size: 180%;
  text-align: center;
  margin-bottom: 20px;
}

#hurry .contact .btnTxt {
  text-align: center;
  color: rgb(60, 65, 105);
  font-size: 180%;
  line-height: 1.4;
  margin-bottom: 30px;
}

/***-----------------------------------
モバイル用スタイル
-----------------------------------***/
@media (max-width: 640px) {
  #hurry h1 {
    font-size: 200%;
    padding-left: 5%;
    padding-right: 5%;
  }
  #hurry .contact h2 {
    text-align: left;
  }
  #hurry .contact .btnTxt {
    text-align: left;
  }
}
#kyouka h2 {
  margin-bottom: 15px;
}
@media (max-width: 640px) {
  #kyouka h2 {
    margin-bottom: 2.6666666667vw;
  }
}
#kyouka .telContact .container .txt01 {
  text-align: center;
  margin-bottom: 20px;
}
@media (max-width: 640px) {
  #kyouka .telContact .container .txt01 {
    margin-bottom: 4vw;
  }
}
#kyouka .telContact .container .txt01 .is-marker {
  font-weight: bold;
  background: linear-gradient(transparent 60%, #ffe958 60%, #ffe958 90%, transparent 90%);
}
@media (max-width: 640px) {
  #kyouka .telContact .container .telButton {
    width: 345px;
  }
}
#kyouka .telContact .container .telButton a {
  width: auto;
  min-width: 420px;
  padding-left: 20px;
  padding-right: 20px;
}
@media (max-width: 640px) {
  #kyouka .telContact .container .telButton a {
    display: block;
    min-width: auto;
    padding-left: 2.6666666667vw;
    padding-right: 2.6666666667vw;
  }
}
#kyouka .telContact .container .telButton .is-text {
  font-size: 22px;
  margin-bottom: 8px;
}
@media (max-width: 640px) {
  #kyouka .telContact .container .telButton .is-text {
    font-size: 18px;
  }
}
#kyouka .telContact .container .telButton .is-number {
  font-size: 46px;
  letter-spacing: 3px;
  line-height: 1;
}
@media (max-width: 640px) {
  #kyouka .telContact .container .telButton .is-number {
    font-size: 11.2vw;
  }
}
#kyouka .contact {
  background: rgb(240, 240, 255);
}
#kyouka .contact .btnTxt {
  text-align: center;
  margin-bottom: 10px;
}
@media (max-width: 640px) {
  #kyouka .contact .btnTxt {
    margin-bottom: 1.3333333333vw;
  }
}

/***-----------------------------------
特定商取引法に関する表示
-----------------------------------***/
#law .width700 {
  max-width: 700px;
}

#law table {
  width: 90%;
  margin: 0 auto;
  border-collapse: collapse;
}

#law table th {
  width: 200px;
  line-height: 160%;
  letter-spacing: 1px;
  padding: 20px 15px;
  border-bottom: solid 1px #999;
  text-align: left;
}

#law table td {
  line-height: 160%;
  letter-spacing: 1px;
  padding: 20px 15px;
  border-bottom: dotted 1px #999;
  border-top: none;
}

/***-----------------------------------
モバイル用スタイル
-----------------------------------***/
@media (max-width: 640px) {
  #law h1 {
    font-size: 200%;
    padding-left: 5%;
    padding-right: 5%;
  }
  #law table {
    border-top: solid 1px #999;
  }
  #law table th {
    width: auto;
    display: block;
    color: #3c4169;
    border-bottom: dotted 1px #999;
  }
  #law table td {
    width: auto;
    display: block;
    border-bottom: solid 1px #999;
  }
}
/***-----------------------------------
感染防止を第一に考えたご葬儀について
-----------------------------------***/
#prevent .width700 {
  max-width: 700px;
}

#prevent h2 {
  font-size: 200%;
  font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
  letter-spacing: 4px;
  line-height: 1.2;
  text-align: center;
  margin-bottom: 40px;
}

#prevent .guidelines {
  background: rgb(240, 240, 255);
}

#prevent .guidelines ul {
  padding-left: 30px;
  margin-bottom: 20px;
}

#prevent .guidelines .txt {
  margin-bottom: 20px;
}

#prevent .guidelines .btnTxt {
  text-align: center;
  color: rgb(60, 65, 105);
  font-size: 150%;
  margin-bottom: 20px;
}

#prevent h3 {
  color: #3c4169;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  margin-bottom: 20px;
}

#prevent .mb50 {
  margin-bottom: 50px;
}

/***-----------------------------------
モバイル用スタイル
-----------------------------------***/
@media (max-width: 640px) {
  #prevent h1 {
    font-size: 200%;
    padding-left: 5%;
    padding-right: 5%;
  }
  #prevent .guidelines .btnTxt {
    line-height: 130%;
    font-weight: bold;
  }
}
/***-----------------------------------
プライバシーポリシー
-----------------------------------***/
#privacy .width700 {
  max-width: 700px;
}

#privacy h2 {
  font-size: 150%;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  letter-spacing: 4px;
  line-height: 150%;
  text-align: justify;
  margin-bottom: 20px;
  color: #3c4169;
}

#privacy ul.privacyUl {
  padding-left: 30px;
}

#privacy ol.privacyOl {
  padding-left: 40px;
}

#privacy .mb20 {
  margin-bottom: 20px;
}

#privacy .mb50 {
  margin-bottom: 50px;
}

/***-----------------------------------
モバイル用スタイル
-----------------------------------***/
@media (max-width: 640px) {
  #privacy h1 {
    font-size: 200%;
    padding-left: 5%;
    padding-right: 5%;
  }
  #privacy h2 {
    font-size: 150%;
  }
}
/***-----------------------------------
葬祭費補助金制度
-----------------------------------***/
#subsidy .container {
  max-width: 700px;
}

#subsidy h2 {
  font-size: 160%;
  font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
  letter-spacing: 4px;
  line-height: 1.2;
  text-align: left;
  margin-bottom: 20px;
}

#subsidy .att {
  font-size: 90%;
  color: #666;
}

#subsidy .list {
  padding-left: 30px;
}

#subsidy .list li {
  margin-bottom: 20px;
}

#subsidy .contact {
  background: rgb(240, 240, 255);
}

#subsidy .contact h2 {
  font-size: 180%;
  text-align: center;
  margin-bottom: 30px;
}

#subsidy .contact .btnTxt {
  text-align: center;
  color: rgb(60, 65, 105);
  font-size: 130%;
  line-height: 1.4;
  margin-bottom: 30px;
}

#subsidy .mb20 {
  margin-bottom: 20px;
}

#subsidy .mb50 {
  margin-bottom: 50px;
}

#subsidy table {
  width: 100%;
  margin: 0 auto;
  background: #FFF;
  margin-bottom: 20px;
}

#subsidy thead {
  border-top: solid 1px #999;
}

#subsidy thead td {
  background: rgb(190, 190, 230) !important;
  letter-spacing: 3px;
}

#subsidy table td {
  line-height: 110%;
  letter-spacing: 1px;
  padding: 15px 0;
  border-top: none;
  border-bottom: solid 1px #999;
  text-align: center;
  vertical-align: middle;
  border-collapse: collapse;
}

#subsidy table td:nth-child(1) {
  border-right: dotted 1px #999;
}

#subsidy table td:nth-child(2) {
  background: rgb(240, 240, 255);
}

#subsidy table td.name {
  width: 40%;
}

#subsidy table .price {
  font-size: 170%;
}

#subsidy table .small {
  font-size: 70%;
}

/***-----------------------------------
モバイル用スタイル
-----------------------------------***/
@media (max-width: 640px) {
  #subsidy h1 {
    font-size: 200%;
    padding-left: 5%;
    padding-right: 5%;
  }
  #subsidy .guidelines .btnTxt {
    line-height: 130%;
    font-weight: bold;
  }
  #subsidy .contact .btnTxt {
    text-align: left;
  }
}
.page-hall-list {
  width: 1000px;
  margin: 0 auto;
}
.page-hall-list__block {
  border-bottom: 1px solid #333;
  padding-bottom: 40px;
}
.page-hall-list__block:not(:last-child) {
  margin-bottom: 60px;
}

.page-hall-list-fee button {
  display: block;
}
.page-hall-list-fee textarea.price-html-copy {
  margin-bottom: 50px;
}
.page-hall-list-fee table {
  width: 100%;
  background-color: #fff;
  line-height: 1.7;
  table-layout: fixed;
  font-size: 16px;
  margin-top: 20px;
  margin-bottom: 20px;
}
.page-hall-list-fee table tr {
  border: 1px solid #D2D2D2;
}
.page-hall-list-fee table th,
.page-hall-list-fee table td {
  width: 30%;
  vertical-align: middle;
  text-align: center;
  border-right: 1px solid #D2D2D2;
  padding: 12px 10px;
}
.page-hall-list-fee table th {
  background-color: #EEF8F4;
}
.page-hall-list-fee table th .is-headline {
  display: block;
}
.page-hall-list-fee table th .is-small {
  font-weight: normal;
  font-size: 0.8em;
}
.page-hall-list-fee table tbody th {
  background-color: #FAFAFA;
}
.page-hall-list-fee table tbody td .table-box {
  line-height: 1;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  border-spacing: 3px 10px;
}
.page-hall-list-fee table tbody td .table-box .row {
  display: flex;
  align-items: center;
  gap: 10px;
}
.page-hall-list-fee table tbody td .table-box .row + .row {
  margin-top: 10px;
}
.page-hall-list-fee table tbody td .table-box .row .cell-headline {
  font-weight: bold;
  color: #57b597;
  border: 1px solid #57b597;
  border-radius: 30px;
  line-height: 1;
  vertical-align: middle;
  font-size: 14px;
  padding: 4px 8px;
}
.page-hall-list-fee table tbody td .table-box .row .cell-price {
  font-weight: bold;
  display: flex;
  align-items: baseline;
  justify-content: flex-end;
  letter-spacing: 0.8px;
  font-size: 23px;
  gap: 5px;
}
.page-hall-list-fee table tbody td .table-box .is-yen {
  font-weight: normal;
  font-size: 16px;
}
.page-hall-list-fee .adaptation-criteria {
  background-color: #fff;
  border-radius: 8px;
  border: 6px solid #F1F1F1;
  line-height: 1.5;
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 24px;
  font-size: 16px;
}
.page-hall-list-fee .adaptation-criteria__headline {
  color: #AD9A4A;
  font-weight: bold;
  width: 172px;
  padding-left: 28px;
}
.page-hall-list-fee .adaptation-criteria__text {
  width: 570px;
}

#petfuneral h2 {
  margin-bottom: 15px;
}
@media (max-width: 640px) {
  #petfuneral h2 {
    margin-bottom: 2.6666666667vw;
  }
}
@media (min-width: 640px) {
  #petfuneral .container {
    width: 710px;
  }
}
#petfuneral .container .txt01 {
  margin-bottom: 20px;
}
@media (max-width: 640px) {
  #petfuneral .container .txt01 {
    margin-bottom: 4vw;
  }
}
#petfuneral .container .txt01 .is-marker {
  font-weight: bold;
  background: linear-gradient(transparent 60%, #ffe958 60%, #ffe958 90%, transparent 90%);
}
@media (max-width: 640px) {
  #petfuneral .container .telButton {
    width: 345px;
  }
}
#petfuneral .container .telButton a {
  width: auto;
  min-width: 420px;
  padding-left: 20px;
  padding-right: 20px;
}
@media (max-width: 640px) {
  #petfuneral .container .telButton a {
    display: block;
    min-width: auto;
    padding-left: 2.6666666667vw;
    padding-right: 2.6666666667vw;
  }
}
#petfuneral .container .telButton .is-text {
  font-size: 22px;
  margin-bottom: 8px;
}
@media (max-width: 640px) {
  #petfuneral .container .telButton .is-text {
    font-size: 18px;
  }
}
#petfuneral .container .telButton .is-number {
  font-size: 46px;
  letter-spacing: 3px;
  line-height: 1;
}
@media (max-width: 640px) {
  #petfuneral .container .telButton .is-number {
    font-size: 11.2vw;
  }
}
#petfuneral .contact {
  background: rgb(240, 240, 255);
}
#petfuneral .contact .btnTxt {
  text-align: center;
  margin-bottom: 10px;
}
@media (max-width: 640px) {
  #petfuneral .contact .btnTxt {
    margin-bottom: 1.3333333333vw;
  }
}

/***-----------------------------------
スタイル
-----------------------------------***/
.wrapper {
  width: 100%;
  overflow: hidden;
  display: flex;
  flex-flow: column;
  min-height: 80vh;
}

.entry-content {
  flex: 1;
  width: 900px;
  margin: 0 auto;
}

.container {
  width: 800px;
  margin: 0 auto;
  padding: 60px 0;
  /*ここでコンテナの上下のスペースを調整する*/
  box-sizing: border-box;
}

.container.is-contact {
  padding-top: 0;
}

h1 {
  font-size: 36px;
  font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
  letter-spacing: 4px;
  line-height: 150%;
  text-align: center;
}

h2 {
  font-size: 36px;
  font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
  letter-spacing: 4px;
  line-height: 150%;
  text-align: center;
}

h3 {
  font-size: 24px;
  font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
  letter-spacing: 3px;
  line-height: 150%;
  text-align: justify;
}

p,
ul,
ol,
li,
th,
td,
dt,
dd {
  font-size: 18px;
  line-height: 180%;
  letter-spacing: 1px;
  text-align: justify;
}

.telLink {
  text-decoration: underline;
  color: rgb(60, 65, 105);
}

@media screen and (max-width: 823px) {
  .container {
    width: 750px;
  }
}
@media screen and (max-width: 768px) {
  .container {
    width: 650px;
  }
}
@media screen and (max-width: 667px) {
  .container {
    width: 550px;
  }
}
/***-----------------------------------
header1
-----------------------------------***/
.header {
  color: rgb(60, 65, 105);
}

.header__top {
  width: 1000px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 130px;
}

.header__top.is-contact {
  width: 800px;
}

.header__box {
  display: flex;
  align-items: center;
  gap: 20px;
  font-size: 24px;
  font-weight: bold;
}

.header__logo-title {
  font-size: 30px;
  color: #333;
  line-height: 1;
  font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
  letter-spacing: 4px;
  font-weight: bold;
}

.header__logo-title a {
  display: flex;
  align-items: center;
  gap: 10px;
}

.header__logo-title .is-common {
  width: 30px;
}

.header__musubysImg img {
  width: 70px;
}

.header__address {
  font-size: 16px;
  line-height: 1;
  margin-top: 10px;
}

.header__box.is-contact p {
  font-weight: bold;
  font-size: 24px;
}

.header__cta-tel {
  background: #7d0035;
  padding: 20px 10px;
  border-radius: 6px;
  box-shadow: 0px 5px #4c0020;
  transition: 0.2s all ease 0s;
  color: #fff;
  text-align: center;
  margin-bottom: 13px;
}

.header__cta-tel:hover {
  background-color: #9b2254;
  transition: 0.3s all;
  box-shadow: none;
  transform: translate3d(0, 3px, 0);
}

.header__cta-tel .telIcon {
  background: url(../assets/img/icon_tel.png) left 50% no-repeat;
  background-size: 20px auto;
  display: inline-block;
  padding-left: 24px;
  font-size: 20px;
  line-height: 1;
  font-weight: bold;
}

.header__cta-text {
  font-weight: bold;
  text-align: center;
  font-size: 16px;
  color: #004169;
  line-height: 1;
}

.header1 {
  background: url("../assets/img/bg.png") repeat;
  color: rgb(60, 65, 105);
}

.header1 .container {
  width: 1000px;
  padding: 20px 0;
}

.header1-inner .wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
}

.header1 .logo {
  width: auto;
}

.header1 .logo h1 {
  text-align: left;
  font-size: 30px;
  color: #333;
  margin-bottom: 5px;
  line-height: 1;
}

.header1 .logo h1 a {
  display: flex;
  align-items: center;
  gap: 10px;
}

@media screen and (max-width: 768px) {
  .header1 .logo h1.long-title {
    font-size: 20px !important;
    letter-spacing: 0;
  }
  .header1 .logo h1.hakuzen {
    font-size: 20px !important;
    letter-spacing: 0;
  }
}
.header1 .logo h1 img.is-common {
  width: 30px;
}

.header1 .logo h1 img.is-area {
  width: 70px;
}

.header1 .logo p.header__logo-title img {
  width: 30px;
  margin-bottom: -4px;
  margin-right: 5px;
}

.header1 .logo p {
  font-size: 16px;
}

.header1 .logo p.header__logo-title {
  text-align: left;
  font-size: 30px;
  color: #333;
  margin-bottom: 5px;
  font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
  font-weight: bold;
  letter-spacing: 4px;
  line-height: 150%;
}

.header1 .btn {
  background: #7d0035;
  padding: 12px 10px;
  border-radius: 6px;
  box-shadow: 0px 5px #4c0020;
  transition: 0.2s all ease 0s;
  text-align: center;
}

.header1 .btn:hover {
  background: #9b2254;
  transition: 0.3s all;
  box-shadow: none;
  transform: translate3d(0, 3px, 0);
}

.header1 .btn p {
  color: rgb(255, 255, 255);
  font-size: 20px;
}

.header1 .btn .telIcon {
  background: url("../assets/img/icon_tel.png") left 50% no-repeat;
  background-size: 20px auto;
  display: inline-block;
  padding-left: 24px;
}

.header1 .btn .spBtn {
  line-height: 120%;
}

.header1 .btn p span {
  font-size: 14px;
}

.header1 .btn i {
  font-size: 16px;
  margin-right: 10px;
  position: relative;
  top: -2px;
}

.header1 .text {
  text-align: center;
  font-size: 16px;
  padding-top: 5px;
  margin-bottom: -6px;
  color: rgb(60, 65, 105);
}

.header1 .right {
  font-weight: bold;
  /* position: absolute;
  right: 0;
  bottom: 0; */
}

.header1 .musubys {
  position: absolute;
  right: 260px;
  bottom: 20px;
}

.header1 .musubys img {
  width: 95px;
  height: auto;
}

@media screen and (min-width: 1300px) {
  .header1 .container {
    width: 1200px;
  }
}
@media screen and (max-width: 1024px) {
  .header1 .container {
    width: 810px;
  }
}
@media screen and (max-width: 823px) {
  .header1 .container {
    width: 750px;
  }
}
@media screen and (max-width: 768px) {
  .header1 .container {
    width: 700px;
  }
}
@media screen and (max-width: 667px) {
  .header1 .container {
    width: 620px;
  }
  .header1 .btn {
    width: 220px;
  }
}
@media screen and (max-width: 640px) {
  .header1 .container {
    width: 550px;
  }
  .header1 .btn {
    width: 220px;
  }
  .header1 h1.long-title {
    font-size: 20px !important;
  }
}
/***-----------------------------------
gNavi
-----------------------------------***/
.gNaviPC {
  width: 100%;
  background-color: #004169;
}

.gNaviPC i {
  padding-right: 6px;
}

.gNaviPC ul {
  list-style-type: none;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 0;
  overflow: hidden;
}

.gNaviPC li {
  width: 20%;
  float: left;
  margin: 0;
  padding: 0;
  text-align: left;
}

.gNaviPC li a {
  display: block;
  margin: 0;
  padding: 8px 0 8px 15px;
  color: #fff;
  font-size: 14px;
  line-height: 1.3;
  text-decoration: none;
}

.gNaviPC li a:hover {
  background: rgb(80, 80, 130);
  color: #fff;
}

@media screen and (min-width: 1300px) {
  .gNaviPC ul {
    max-width: 1050px;
  }
}
@media screen and (max-width: 1024px) {
  .gNaviPC ul {
    max-width: 810px;
  }
}
@media screen and (max-width: 823px) {
  .gNaviPC ul {
    max-width: 750px;
  }
}
@media screen and (max-width: 768px) {
  .gNaviPC ul {
    max-width: 700px;
  }
}
@media screen and (max-width: 667px) {
  .gNaviPC ul {
    max-width: 620px;
  }
}
@media screen and (max-width: 640px) {
  .gNaviPC ul {
    max-width: 550px;
  }
}
@media only screen and (max-width: 768px) {
  .gNaviPC i {
    padding-right: 3px;
  }
  .gNaviPC li a {
    padding: 7px 5px 7px 0;
    font-size: 12px;
    line-height: 1.3;
  }
}
/***-----------------------------------
top-image1
-----------------------------------***/
.top-image1 .image {
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: cover;
  height: 500px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.top-image1 .image h2 {
  writing-mode: vertical-rl;
  text-align: center;
  margin: 0 auto;
  padding: 60px 0 0;
  font-size: 40px;
  height: 550px;
  position: absolute;
  top: 40%;
  left: 50%;
  transform: translate(-50%, -50%);
  letter-spacing: 5px !important;
  text-shadow: rgba(255, 255, 255, 0.4) 2px 0px 4px, rgba(255, 255, 255, 0.4) -2px 0px 4px, rgba(255, 255, 255, 0.4) 0px -2px 4px, rgba(255, 255, 255, 0.4) -2px 0px 4px, rgba(255, 255, 255, 0.4) 2px 2px 4px, rgba(255, 255, 255, 0.4) -2px 2px 4px, rgba(255, 255, 255, 0.4) 2px -2px 4px, rgba(255, 255, 255, 0.4) -2px -2px 4px, rgba(255, 255, 255, 0.4) 1px 2px 4px, rgba(255, 255, 255, 0.4) -1px 2px 4px, rgba(255, 255, 255, 0.4) 1px -2px 4px, rgba(255, 255, 255, 0.4) -1px -2px 4px, rgba(255, 255, 255, 0.4) 2px 1px 4px, rgba(255, 255, 255, 0.4) -2px 1px 4px, rgba(255, 255, 255, 0.4) 2px -1px 4px, rgba(255, 255, 255, 0.4) -2px -1px 4px, rgba(255, 255, 255, 0.4) 1px 1px 4px, rgba(255, 255, 255, 0.4) -1px 1px 4px, rgba(255, 255, 255, 0.4) 1px -1px 4px, rgba(255, 255, 255, 0.4) -1px -1px 4px;
}

.top-image1 .image h2.long-title {
  font-size: 32px;
}

.top-image1 .image h2 img {
  width: 40px;
  height: auto;
  margin-bottom: 8px;
}

/***-----------------------------------
emergency
-----------------------------------***/
.top-image1 .emergency {
  font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
  text-align: center;
}

.top-image1 .emergency h3 {
  font-size: 40px;
  font-weight: lighter;
  background: rgb(255, 255, 255);
  padding: 10px 20px;
  line-height: 1;
  letter-spacing: 5px;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 20px;
}

.top-image1 .emergency p {
  font-size: 24px;
  font-weight: lighter;
  letter-spacing: 2px;
  background: rgb(255, 255, 255);
  display: block;
  text-align: center;
  width: 380px;
  margin: 0 auto;
  text-wrap: nowrap;
  text-align: center;
  padding: 0 1.5%;
}

/***-----------------------------------
top-image-slide
-----------------------------------***/
.top-image-slide {
  position: relative;
}

.top-image-slide .emergency {
  font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
  text-align: center;
  z-index: 2;
  width: 60%;
  position: absolute;
  top: 180px;
  left: 0;
  right: 0;
  margin: auto;
}

.top-image-slide .emergency h3 {
  font-size: 40px;
  font-weight: lighter;
  background: rgb(255, 255, 255);
  padding: 10px 20px;
  line-height: 2;
  letter-spacing: 5px;
  display: inline;
}

.top-image-slide .emergency p {
  font-size: 24px;
  font-weight: lighter;
  letter-spacing: 2px;
  background: rgb(255, 255, 255);
  padding: 10px 20px;
  display: block;
  text-align: center;
  width: 380px;
  margin: 0 auto;
  text-wrap: nowrap;
  text-align: center;
  padding: 0 1.5%;
}

.top-caution {
  position: absolute;
  bottom: 30px;
  left: 0;
  right: 0;
  margin: 50px auto 0;
  width: 410px;
  z-index: 100;
  background-color: #BF1412;
  padding: 0 3px 3px;
  border-radius: 9px;
  font-family: "Noto Sans JP", sans-serif;
}

.top-caution__headline {
  color: #fff;
  font-weight: bold;
  font-size: 24px;
  padding-left: 50px;
  background-image: url("../assets/img/caution__headline_bg.svg");
  background-repeat: no-repeat;
  background-position: left 10px center;
}

.top-caution__text {
  font-weight: bold;
  background-color: #fff;
  padding: 13px 5px 13px 20px;
  border-radius: 0 0 8px 8px;
}

.top-caution__text p {
  font-size: 17px;
}

.top-caution__text p .is-fontsize {
  font-size: 22px;
  color: #BF1412;
  position: relative;
  padding-left: 17px;
  letter-spacing: 0;
}

.top-caution__text p .is-space {
  margin-left: 10px;
}

.top-caution__text p .is-fontsize:nth-child(1) {
  padding-right: 10px;
}

.top-caution__text p .is-fontsize::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  z-index: 2;
  width: 9px;
  height: 9px;
  background-color: #BF1412;
  border-radius: 50%;
}

.swiper {
  /*スライダーの幅と高さを調整*/
  width: 100%;
  height: 500px;
}

.swiper-slide {
  /*スライド要素の幅と高さを調整*/
  width: 100%;
  height: 100%;
  /*テキストの位置調整*/
  display: flex;
  justify-content: center;
  align-items: center;
  /*テキストの色と太さを指定*/
  color: #fff;
  font-weight: bold;
}

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

.swiper-button-next,
.swiper-button-prev {
  --swiper-navigation-color: #fff;
}

.swiper-button-prev {
  left: 12% !important;
}

.swiper-button-next {
  right: 12% !important;
}

.swiper-pagination-bullet-active {
  background-color: #fff !important;
}

/***-----------------------------------
warning
-----------------------------------***/
.warning {
  background: #FFF;
  width: 100%;
  padding: 30px 0;
}

.warning p {
  text-align: center;
}

/***-----------------------------------
support
-----------------------------------***/
.support {
  background: url("../assets/img/bg.png") repeat;
}

.support h2 {
  display: inline-block;
  font-size: 250%;
  letter-spacing: 3px;
  line-height: 150%;
  margin-bottom: 15px;
  color: #3c4169;
  background: url(../assets/img/icon_support.png);
  padding: 8px 0 8px 80px;
  background-size: 65px;
  background-repeat: no-repeat;
  background-position: center left;
}

.support-container {
  width: 100%;
  margin: 0 auto;
  padding: 60px 0;
  /*　ここでコンテナの上下のスペースを調整する　*/
  box-sizing: border-box;
  text-align: center;
}

.support p {
  text-align: center;
}

.support .blueBox {
  width: 550px;
  margin: 20px auto 0;
  padding: 20px 30px;
  box-sizing: border-box;
  background: #F0F0FF;
}

.support ul {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}

.support ul li {
  list-style: none;
  position: relative;
  font-weight: bold;
}

.support ul li.arrow {
  padding-top: 4px;
}

.support ul li.arrow img {
  width: 20px;
}

.support .whiteBox {
  padding: 15px;
  box-sizing: border-box;
  background: #FFF;
}

.support .whiteBox h3 {
  font-size: 150%;
  letter-spacing: 3px;
  line-height: 150%;
  text-align: center;
  margin-bottom: 10px;
}

.support .whiteBox p {
  font-size: 95%;
}

.attention {
  padding: 30px 0 20px;
}
.attention__text {
  width: 800px;
  margin: 0 auto;
  font-size: 18px;
}
.attention__text a {
  text-decoration: underline;
  color: #0000ff;
}

/***-----------------------------------
reservation
-----------------------------------***/
.reservation {
  background: url("../assets/img/bg.png") repeat;
}

.reservation h2 {
  font-size: 35px;
  color: rgb(40, 40, 90);
  background: url(../assets/img/calendar-icon.png);
  margin: 0 auto 30px;
  padding: 8px 0 8px 80px;
  background-size: 65px;
  background-repeat: no-repeat;
  background-position: top left;
  display: inline-block;
}

/*細いマーカーライン*/
.marker_yellow_hoso {
  font-weight: bold;
  background: linear-gradient(transparent 70%, #fbed47 70%);
}

.reservation .txt {
  display: flex;
  justify-content: space-between;
  width: 690px;
  margin: 0 auto;
}

.reservation .wrap {
  padding: 10px 0;
}

.reservation .wrap h3 {
  letter-spacing: 1.5px;
  font-size: 130%;
  margin-bottom: 10px;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  font-weight: normal;
}

.reservation .sub {
  letter-spacing: 1.5px;
  font-size: 130%;
  margin-bottom: 30px;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  font-weight: normal;
}

.reservation .att p {
  font-size: 85%;
  line-height: 180%;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  font-weight: normal;
}

.reservation figure img {
  width: 120px;
}

.reservation figcaption {
  font-size: 85%;
  text-align: center;
  margin-top: 10px;
}

.reservation-container {
  margin: 0 auto;
  padding: 60px 0;
  /*　ここでコンテナの上下のスペースを調整する　*/
  box-sizing: border-box;
  text-align: center;
}

/***-----------------------------------
gaiyo
-----------------------------------***/
.gaiyo .fee tr {
  border: solid 1px rgb(50, 50, 50);
  border-left: none;
  border-right: none;
}

.gaiyo h2 {
  margin-bottom: 20px;
}

.gaiyo h2.mt50 {
  margin-top: 50px;
}

.hyou {
  margin: 0 auto 50px;
  border-collapse: collapse;
  width: 100%;
}

.hyou tr {
  border-top: solid 1px rgb(50, 50, 50);
  border-bottom: solid 1px rgb(50, 50, 50);
}

.hyou th,
.hyou td {
  padding: 10px;
}

.hyou th {
  border-right: solid 1px rgb(50, 50, 50);
  vertical-align: top;
  width: 100px;
}

.hyou .item {
  overflow: hidden;
}

.hyou .item dl {
  float: left;
  width: 160px;
  margin-right: 10px;
}

.hyou .item dt {
  float: left;
  height: 36px;
  line-height: 36px;
  padding: 0 8px;
  margin-right: 8px;
  background: rgb(190, 190, 230);
}

.hyou .item dd {
  height: 32px;
  line-height: 32px;
  margin-left: 30px;
  border: solid 2px rgb(190, 190, 230);
}

.hyou .wrap {
  display: flex;
  flex-wrap: wrap;
  width: 500px;
}

.hyou .wrap p {
  background: rgb(190, 190, 230);
  margin: 5px 10px;
  margin-left: 0px;
  padding: 0 5px;
}

.hyou .access {
  line-height: 150%;
}

.hyou .tel {
  display: none;
}

@media screen and (max-width: 768px) {
  .hyou th {
    width: 80px;
  }
  .hyou .wrap p {
    text-align: center;
    line-height: 150%;
  }
}
@media screen and (max-width: 640px) {
  .hyou .wrap p {
    margin-bottom: 5px;
  }
}
.att {
  line-height: 1.6;
  font-size: 12px;
  letter-spacing: 0;
  margin-top: 5px;
}

.gaiyo .fee {
  margin: 0 auto 10px;
  border-collapse: collapse;
  width: 100%;
}

.gaiyo .fee thead td {
  background: rgb(190, 190, 230) !important;
}

.gaiyo .fee td {
  text-align: center;
  vertical-align: middle;
  border-right: solid 1px rgb(50, 50, 50);
  line-height: 1.2;
  padding: 15px 0;
}

.gaiyo .fee td:last-child {
  border-right: none;
}

.gaiyo .fee td:nth-child(2) {
  background: rgb(240, 240, 255);
  font-weight: bold;
  font-size: 125%;
}

.gaiyo .fee .seki,
.gaiyo .fee .day {
  font-size: 70%;
}

.gaiyo .target {
  border-top: solid 1px #999;
  border-bottom: solid 1px #999;
  background: #FFF;
  padding: 20px 30px;
  line-height: 160%;
  font-size: 120%;
}

.gaiyo .photo {
  text-align: center;
}

.gaiyo .photo img {
  width: auto;
  height: auto;
}

/* 注釈 */
.gaiyo .notes {
  margin-top: 30px;
  font-size: 95%;
}

/* googleMap */
.gaiyo .map iframe {
  width: 100%;
  height: 450px;
  margin: 50px 0;
  border: 0;
}

/***-----------------------------------
button1
-----------------------------------***/
.button1 {
  background: rgb(240, 240, 255);
}

.button1 .container {
  overflow: hidden;
}

.button1 p {
  text-align: center;
  color: rgb(60, 65, 105);
  font-size: 24px;
}

.button1 .kokuho {
  clear: both;
  padding-top: 30px;
}

.button1 .kokuho p {
  border: 3px solid rgb(60, 65, 105);
  background-color: #fff;
  padding: 20px;
  font-size: 20px;
}

.button1 p:nth-of-type(2) {
  font-size: 30px;
  line-height: 150%;
  font-weight: bold;
}

.button1-inner {
  float: left;
  width: 48%;
}

.button1-inner.center {
  float: none;
  width: 48%;
  margin: 0 auto;
}

.button1-inner a {
  width: 100%;
  padding: 15px 0 20px;
  display: inline-block;
  background: linear-gradient(#ad1f5a 0%, #7d0035 50%, #560024 50%, #350016 100%);
  border: solid 1px #7d0035;
  box-sizing: border-box;
  color: rgb(255, 255, 255);
  font-size: 24px;
  border-radius: 6px;
}

.button1-inner a:hover {
  transition: 0.3s all;
  opacity: 0.6;
}

.button1-inner a p {
  font-size: 38px;
  color: rgb(255, 255, 255);
  line-height: 120%;
  font-weight: bold;
}

.button1-inner a p:nth-of-type(2) {
  color: rgb(255, 255, 255);
  font-size: 22px;
  line-height: 150%;
  font-weight: bold;
}

.button2-inner {
  float: right;
  width: 48%;
}

.button2-inner a {
  width: 100%;
  padding: 19px 0 24px;
  display: inline-block;
  background: linear-gradient(#fefefe 0%, #eee 50%, #ddd 51%, #aaa 100%);
  border: solid 1px #999;
  box-sizing: border-box;
  color: rgb(60, 65, 105);
  font-size: 24px;
  border-radius: 6px;
}

.button2-inner a:hover {
  transition: 0.3s all;
  opacity: 0.6;
}

.button2-inner a p {
  font-size: 34px;
  line-height: 120%;
  font-weight: bold;
}

.button2-inner a p:nth-of-type(2) {
  font-size: 20px;
  line-height: 150%;
  font-weight: bold;
}

@media screen and (max-width: 768px) {
  .button2-inner a {
    padding: 16px 0 22px;
  }
  .button1-inner a p {
    font-size: 30px;
  }
  .button2-inner a p {
    font-size: 28px;
  }
  .button1-inner a p:nth-of-type(2),
  .button2-inner a p:nth-of-type(2) {
    font-size: 18px;
  }
}
@media screen and (max-width: 667px) {
  .button2-inner a {
    padding: 16px 0 21px;
  }
  .button1-inner a p {
    font-size: 27px;
  }
  .button2-inner a p {
    font-size: 25px;
  }
  .button1-inner a p:nth-of-type(2),
  .button2-inner a p:nth-of-type(2) {
    font-size: 14px;
  }
}
.button3-inner {
  float: right;
  width: 48%;
}

.button3-inner a {
  width: 100%;
  padding: 12px 0 13px;
  display: inline-block;
  background: linear-gradient(#775643 0%, #4e2b14 100%);
  border: solid 1px #4e2b14;
  box-sizing: border-box;
  font-size: 24px;
  border-radius: 6px;
}

.button3-inner a:hover {
  transition: 0.3s all;
  opacity: 0.6;
}

.button3-inner a .sub1 {
  font-size: 16px;
  line-height: 1.1;
  width: 92px;
  float: left;
  font-weight: bold;
  padding: 3px 15px 0 35px;
  letter-spacing: 1.2px;
  color: rgb(255, 255, 255);
}

.button3-inner a .main {
  float: left;
  font-size: 38px;
  line-height: 120%;
  padding-bottom: 5px;
  padding-left: 0;
  font-weight: bold;
  font-family: "游ゴシック", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  color: rgb(255, 255, 255);
}

.button3-inner a .sub2 {
  font-size: 22px;
  line-height: 150%;
  font-weight: bold;
  border-top: solid 1px #fff;
  clear: both;
  text-align: center;
  width: 92%;
  margin: 0 auto;
  padding-top: 4px;
  color: rgb(255, 255, 255);
}

.button3-inner a .sub2 span {
  color: #FF0;
}

@media all and (-ms-high-contrast: none) {
  /* IEのみ */
  .button3-inner a .main {
    font-family: "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  }
}
@media screen and (max-width: 768px) {
  .button3-inner a {
    padding: 10px 0 8px;
  }
  .button3-inner a .sub1 {
    width: 88px;
    padding: 3px 10px 0 10px;
  }
  .button3-inner a .main {
    font-size: 36px;
    padding-bottom: 3px;
  }
  .button3-inner a .sub2 {
    padding-top: 2px;
  }
}
/***-----------------------------------
oshirase
-----------------------------------***/
.oshirase {
  background: url("../assets/img/bg.png") repeat;
}

.oshirase .item {
  width: 500px;
  margin: 20px auto;
}

.oshirase h2 {
  line-height: 120%;
}

.oshirase h2 span {
  font-size: 20px;
  letter-spacing: 0;
  margin-top: -5px;
}

.oshirase .item p:nth-of-type(1) {
  font-size: 16px;
  color: rgba(60, 65, 105, 0.9);
  border-bottom: solid 1px;
  margin-bottom: 7px;
}

.oshirase .item p:nth-of-type(2) {
  line-height: 150%;
}

.oshirase h2 img {
  width: 37px;
  margin-bottom: -6px;
  margin-right: 6px;
}

.oshirase a {
  color: rgba(60, 65, 105, 0.9);
  text-decoration: underline;
}

/* お知らせ一覧 */
.news-accordion {
  margin: 0 auto;
  list-style: none;
}

.news-accordion .newsPost {
  margin: 10px 0;
}

.news-accordion .newsPost section {
  border: 1px solid rgba(60, 65, 105, 0.9);
  background-color: #fff;
}

.news-accordion .newsPost .title {
  position: relative;
  cursor: pointer;
  padding: 2% 50px 2% 3%;
  font-size: 100%;
  transition: all 0.5s ease;
}

.news-accordion .newsPost .title .data {
  color: rgba(60, 65, 105, 0.9);
  font-weight: lighter;
}

.news-accordion .newsPost .box ul li {
  list-style-type: disc;
  margin-left: 30px;
}

.news-accordion .newsPost .box ol li {
  margin-left: 30px;
}

.news-accordion .newsPost table,
.news-accordion .newsPost td,
.news-accordion .newsPost th {
  border-collapse: collapse;
  border: 1px solid #333;
}

/*アイコンの＋と×*/
.news-accordion .newsPost .title::before,
.news-accordion .newsPost .title::after {
  position: absolute;
  content: "";
  width: 15px;
  height: 2px;
  background-color: rgba(60, 65, 105, 0.9);
}

.news-accordion .newsPost .title::before {
  top: 48%;
  right: 15px;
  transform: rotate(0deg);
}

.news-accordion .newsPost .title::after {
  top: 48%;
  right: 15px;
  transform: rotate(90deg);
}

/*　closeというクラスがついたら形状変化　*/
.news-accordion .newsPost .title.close::before {
  transform: rotate(45deg);
}

.news-accordion .newsPost .title.close::after {
  transform: rotate(-45deg);
}

/*アコーディオンで現れるエリア*/
.news-accordion .newsPost .box {
  display: none;
  /*はじめは非表示*/
  background: #f3f3f3;
  margin: 0 3% 3% 3%;
  padding: 2% 3%;
}

/***-----------------------------------
photo
-----------------------------------***/
.photo img {
  /* width: 100%; */
  /* height: auto; */
  width: 350px;
  height: 233px;
  margin-bottom: 10px;
}

.photo .item {
  margin: 0 auto;
  text-align: center;
  width: 700px;
  overflow: hidden;
}

.photo .item dl {
  width: 50%;
  float: left;
}

.photo .item dt {
  padding: 4px 20px;
  color: #fff;
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  background: rgb(60, 65, 105);
}

@media screen and (max-width: 823px) {
  .photo .item {
    width: auto;
  }
}
/***-----------------------------------
flow
-----------------------------------***/
.flow {
  background: url("../assets/img/bg.png") repeat;
}

.flow .container {
  width: 700px;
}

.flow .line-bottom {
  margin: 10px auto 20px;
  border-top: solid 2px rgb(60, 65, 105);
}

.flow h2:nth-of-type(1) {
  font-size: 25px;
  margin-bottom: 0px;
}

.flow .wrap {
  padding: 20px 0;
}

.flow .wrap h2 {
  line-height: 110%;
  color: rgb(60, 65, 105);
  margin-bottom: 10px;
}

.flow .wrap h2 span {
  font-size: 14px;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  letter-spacing: 1px;
  font-weight: 100;
  line-height: 100%;
}

.flow .number h2 {
  font-size: 45px;
}

.flow .kome2 {
  margin-top: 3px;
}

.flow .kome2 p1 {
  color: rgb(100, 100, 100);
  font-size: 13px;
  line-height: 120%;
}

@media screen and (max-width: 771px) {
  .flow .container {
    width: 650px;
  }
}
@media screen and (max-width: 667px) {
  .flow .container {
    width: 600px;
  }
}
@media screen and (max-width: 640px) {
  .flow .container {
    width: 550px;
  }
}
/***-----------------------------------
403ページ
-----------------------------------***/
.forbidden {
  padding: 180px 0 250px 0;
  background: url("../assets/img/bg.png") repeat;
}

.forbidden h1 {
  text-align: center;
  margin-bottom: 30px;
}

.forbidden p {
  text-align: center;
}

/***-----------------------------------
page-top
-----------------------------------***/
.page-top {
  position: fixed;
  bottom: 90px;
  right: 20px;
  z-index: 1;
}

.page-top a {
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(60, 130, 90, 0.9);
  width: 60px;
  height: 60px;
  border-radius: 40px;
  text-align: center;
}

.page-top i {
  font-size: 30px;
  color: rgba(255, 255, 255, 0.85);
}

.page-top a:hover {
  opacity: 0.85;
}

/***-----------------------------------
運営法人
-----------------------------------***/
.company {
  background: #8a8eb1;
  padding: 20px 0 40px;
}

.company table {
  margin: 0 auto;
  width: 520px;
  color: #fff;
}

.company table caption {
  padding: 20px 0;
  font-size: 18px;
}

.company table td {
  border-top: solid 1px #fff;
  border-bottom: solid 1px #fff;
}

.company table td a {
  color: #fff;
}

/***-----------------------------------
footer
-----------------------------------***/
.footer {
  background: rgb(60, 65, 105);
  color: rgb(255, 255, 255);
}

.footer .container {
  text-align: center;
  padding: 50px 0 100px;
}

.footer .container .pageBack a {
  color: #fff;
  border: solid 1px;
  border-radius: 5px;
  padding: 10px;
  margin-bottom: 20px;
  display: inline-block;
}

.footer .container ul {
  text-align: center;
}

.footer .container ul li {
  font-size: 12px;
  line-height: 1.1;
  display: inline-block;
  margin: 0 0 7px;
  border-left: 1px solid #fff;
}

.footer .container ul li:first-child {
  border-left: none;
}

.footer .container ul li a {
  padding: 0 15px;
  text-decoration: none;
  color: rgb(255, 255, 255);
}

.footer p {
  font-size: 12px;
  text-align: center;
}

#fixFooter,
#fixFooterKanagawa {
  display: none !important;
}

/***-----------------------------------
pcFixFooter
-----------------------------------***/
#pcFixFooter {
  background: rgb(60, 130, 90);
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 9999;
  width: 100%;
  padding: 6px 0 0;
}

#pcFixFooter ul {
  width: 1000px;
  margin: 0 auto;
}

#pcFixFooter ul.center {
  width: 680px;
  margin: 0 auto;
}

#pcFixFooter li {
  list-style-type: none;
  float: left;
}

#pcFixFooter .balloon {
  position: relative;
  background: #fff;
  padding: 8px 10px;
  margin-top: 8px;
  text-align: left;
  color: #333;
  font-size: 18px;
  font-weight: bold;
  line-height: 25px;
  border-radius: 10px;
  -webkit-border-radius: 10px;
  -moz-border-radius: 10px;
}

#pcFixFooter .balloon:after {
  border: solid transparent;
  content: "";
  height: 0;
  width: 0;
  pointer-events: none;
  position: absolute;
  border-color: rgba(255, 15, 0, 0);
  border-top-width: 5px;
  border-bottom-width: 5px;
  border-left-width: 10px;
  border-right-width: 10px;
  margin-top: -5px;
  border-left-color: #fff;
  left: 100%;
  top: 50%;
}

#pcFixFooter .balloon .icon {
  width: 25px;
  height: 25px;
  float: left;
  margin-right: 8px;
}

#pcFixFooter .telBtn {
  color: #fff;
  margin-left: 20px;
}

#pcFixFooter .telBtn a {
  color: #fff;
}

#pcFixFooter .telBtn .h24 {
  font-size: 16px;
  line-height: 1.4;
  letter-spacing: 3px;
  text-align: left;
}

#pcFixFooter .telBtn .h24 span {
  padding: 0 5px;
  border-radius: 4px;
  color: #fbed47;
  font-size: 12px;
  border: solid 1px #fbed47;
}

#pcFixFooter .telBtn .num {
  font-size: 36px;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 3px;
  text-shadow: #32754e 2px 0px 0px, #32754e -2px 0px 0px, #32754e 0px -2px 0px, #32754e 0px 2px 0px, #32754e 2px 2px 0px, #32754e -2px 2px 0px, #32754e 2px -2px 0px, #32754e -2px -2px 0px, #32754e 1px 2px 0px, #32754e -1px 2px 0px, #32754e 1px -2px 0px, #32754e -1px -2px 0px, #32754e 2px 1px 0px, #32754e -2px 1px 0px, #32754e 2px -1px 0px, #32754e -2px -1px 0px, #32754e 1px 1px 0px, #32754e -1px 1px 0px, #32754e 1px -1px 0px, #32754e -1px -1px 0px;
}

#pcFixFooter .mailBtn {
  float: right;
}

#pcFixFooter .mailBtn a {
  padding: 0px 36px 0px 2px;
  display: inline-block;
  background: linear-gradient(#3c825a, #154a2c);
  border: solid 1px #fff;
  box-sizing: border-box;
  color: rgb(255, 255, 255);
  border-radius: 6px;
}

#pcFixFooter .mailBtn a:hover,
#pcFixFooter .mailBtn a:hover img {
  transition: 0.3s all;
  opacity: 0.6;
}

#pcFixFooter .mailBtn a img {
  display: block;
  position: absolute;
  bottom: 5px;
}

#pcFixFooter .mailBtn a p {
  padding: 0 0 6px 0;
  font-size: 24.5px;
  font-weight: bold;
  line-height: 0.8;
  padding-left: 64px;
  margin: 0 auto;
  text-shadow: 3px 0 3px #0e4023, 0 3px 3px #0e4023, -3px 0 3px #0e4023, 0 -3px 3px #0e4023;
  position: relative;
}

#pcFixFooter .mailBtn a p:after {
  position: absolute;
  top: 48%;
  right: 13px;
  content: "";
  width: 8px;
  height: 8px;
  border-right: 3px solid rgb(255, 255, 255);
  border-top: 3px solid rgb(255, 255, 255);
  transform: translate(32px, -5px) rotate(45deg);
}

#pcFixFooter .mailBtn a .sub {
  font-size: 14px;
}

#pcFixFooter .mailBtn a .sub_yellow {
  color: #fbed47;
  padding-left: 30px;
  line-height: 1.7;
}

#pcFixFooter .mailBtn a .sub_b {
  font-size: 16px;
}

@media screen and (max-width: 1024px) {
  #pcFixFooter {
    padding: 6px 0 4px;
  }
  #pcFixFooter ul {
    width: 810px;
  }
  #pcFixFooter .balloon {
    width: 195px;
    line-height: 1.2;
    margin-top: 0;
  }
  #pcFixFooter .balloon .icon {
    width: 40px;
    height: 40px;
  }
  #pcFixFooter .telBtn .h24 {
    font-size: 14px;
    letter-spacing: 2px;
  }
  #pcFixFooter .telBtn .num {
    font-size: 33px;
    letter-spacing: 2px;
    padding-top: 4px;
  }
  #pcFixFooter .mailBtn a img {
    display: block;
    position: absolute;
    bottom: 1.2vw;
  }
  #pcFixFooter .mailBtn a p {
    letter-spacing: 0;
    font-size: 20px;
    padding-bottom: 10px;
  }
  #pcFixFooter .mailBtn a p:after {
    position: absolute;
    right: 10px;
  }
}
@media screen and (max-width: 823px) {
  #pcFixFooter ul {
    width: 766px;
  }
  #pcFixFooter .telBtn .h24 {
    letter-spacing: 1px;
  }
  #pcFixFooter .telBtn .num {
    letter-spacing: 1px;
  }
  #pcFixFooter .mailBtn a {
    padding: 1px 20px 10px 5px;
  }
  #pcFixFooter .mailBtn a p {
    letter-spacing: 0;
    font-size: 18px;
    padding-bottom: 4px;
  }
  #pcFixFooter .mailBtn a p:after {
    position: absolute;
    top: 58%;
    right: 20px;
    width: 6px;
    height: 6px;
  }
}
/***-----------------------------------
fixSideBanner
-----------------------------------***/
@media screen and (min-width: 900px) {
  .fixSideBanner {
    position: fixed;
    top: 10%;
    right: -121px;
    z-index: 9999;
    transform: translateX(0);
    opacity: 1;
    transition: opacity 1s, transform 0.5s;
  }
  .fadein {
    opacity: 1;
    transform: translateX(-121px);
  }
}
@media screen and (max-width: 900px) {
  .fixSideBanner {
    display: none;
  }
}
/*Landscape（画面横）*/
@media (max-device-width: 1024px) and (orientation: landscape) {
  .fixSideBanner {
    display: none;
  }
}
/*Portrait（画面縦）*/
@media (max-device-width: 768px) and (orientation: portrait) {
  .fixSideBanner {
    display: none;
  }
}
/*iPad第4世代*/
@media screen and (device-width: 768px) and (device-height: 1024px) and (-webkit-device-pixel-ratio: 2) {
  .fixSideBanner {
    display: none;
  }
}
/*iPadMini*/
@media screen and (device-width: 768px) and (device-height: 1024px) and (-webkit-device-pixel-ratio: 1) {
  .fixSideBanner {
    display: none;
  }
}
/***-----------------------------------
setting
-----------------------------------***/
.line-top {
  width: 75px;
  height: 3px;
  margin: 0 auto 25px;
  background: linear-gradient(90deg, rgb(60, 65, 105) 0%, rgb(60, 65, 105) 70%, rgb(35, 25, 20) 70%, rgb(35, 25, 20) 100%);
}

.line-top-white {
  width: 75px;
  height: 3px;
  margin: 0 auto 25px;
  background: rgb(255, 255, 255);
}

.line-bottom {
  width: 100px;
  margin: 25px auto 45px;
  border-top: solid 3px rgb(60, 65, 105);
}

.line-bottom-white {
  width: 45px;
  margin: 20px auto 60px;
  border-top: solid 3px rgb(255, 255, 255);
}

.line-subtitle {
  width: 60px;
  height: 2px;
  margin: 0 auto 25px 0;
  background: linear-gradient(90deg, rgb(60, 65, 105) 0%, rgb(60, 65, 105) 70%, rgb(35, 25, 20) 70%, rgb(35, 25, 20) 100%);
}

.line-subtitle-white {
  width: 60px;
  height: 2px;
  margin: 0 auto 25px 0;
  background: rgb(255, 255, 255);
}

/***-----------------------------------
サブページ CvButton
-----------------------------------***/
.staticCV {
  width: 100%;
  max-width: 700px;
  overflow: hidden;
  margin: 0 auto;
}

.staticCV .tel {
  float: left;
  width: 48%;
}
.staticCV .tel.is-pet {
  float: none;
  width: 500px;
  margin: 0 auto;
}

.staticCV .tel a {
  width: 100%;
  padding: 20px 0;
  display: inline-block;
  background: linear-gradient(#ad1f5a 0%, #7d0035 50%, #560024 50%, #350016 100%);
  border: solid 1px #7d0035;
  box-sizing: border-box;
  color: rgb(255, 255, 255);
  border-radius: 6px;
}

.staticCV .tel a:hover {
  transition: 0.3s all;
  opacity: 0.6;
}

.staticCV .tel a p {
  font-size: 36px;
  color: rgb(255, 255, 255);
  /* line-height: 120%; */
  line-height: 1;
  font-weight: bold;
  text-align: center;
  margin-bottom: 8px;
}

.staticCV .tel a p:nth-of-type(2) {
  color: rgb(255, 255, 255);
  font-size: 18px;
  /* line-height: 150%; */
  line-height: 1;
  font-weight: bold;
  text-align: center;
}

.staticCV .tel a p:nth-of-type(2) > span {
  color: #FF0;
}

.staticCV .tel a .is-color {
  color: #FF0;
}

.staticCV .mail {
  float: right;
  width: 48%;
}

.staticCV .mail a {
  width: 100%;
  padding: 20px 0 22px;
  display: inline-block;
  background: linear-gradient(#fefefe 0%, #eee 50%, #ddd 51%, #aaa 100%);
  border: solid 1px #999;
  box-sizing: border-box;
  color: rgb(60, 65, 105);
  border-radius: 6px;
}

.staticCV .mail a:hover {
  transition: 0.3s all;
  opacity: 0.6;
}

.staticCV .mail a p {
  font-size: 30px;
  line-height: 120%;
  font-weight: bold;
  text-align: center;
}

.staticCV .mail a p:nth-of-type(2) {
  font-size: 18px;
  line-height: 150%;
  font-weight: bold;
}

.staticCV .download {
  float: right;
  width: 48%;
}

.staticCV .download a {
  width: 100%;
  padding: 17.5px 0;
  display: inline-block;
  background: linear-gradient(#775643 0%, #4e2b14 100%);
  border: solid 1px #4e2b14;
  box-sizing: border-box;
  color: rgb(255, 255, 255);
  border-radius: 6px;
}

.staticCV .download a:hover {
  transition: 0.3s all;
  opacity: 0.6;
}

.staticCV .download a .sub1 {
  font-size: 16px;
  line-height: 1.1;
  width: 92px;
  float: left;
  font-weight: bold;
  padding: 3px 10px 0 20px;
  letter-spacing: 1.2px;
}

.staticCV .download a .main {
  font-size: 28px;
  line-height: 120%;
  padding-bottom: 5px;
  font-weight: bold;
  text-align: center;
  font-family: "游ゴシック", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
}

.staticCV .download a .sub2 {
  font-size: 21px;
  line-height: 150%;
  font-weight: bold;
  border-top: solid 1px #fff;
  clear: both;
  text-align: center;
  width: 92%;
  margin: 0 auto;
  padding-top: 4px;
}

.staticCV .download a .sub2 span {
  color: #FF0;
}

@media screen and (max-width: 768px) {
  .staticCV .tel a p {
    font-size: 30px;
  }
  .staticCV .mail a p {
    font-size: 28px;
  }
  .staticCV .tel a p:nth-of-type(2),
  .staticCV .mail a p:nth-of-type(2) {
    font-size: 18px;
  }
  .staticCV .download a .sub1 {
    padding: 0 10px 0 15px;
  }
}
@media screen and (max-width: 667px) {
  .staticCV .tel a p {
    font-size: 27px;
  }
  .staticCV .mail a p {
    font-size: 25px;
  }
  .staticCV .tel a p:nth-of-type(2),
  .staticCV .mail a p:nth-of-type(2) {
    font-size: 14px;
  }
  .staticCV .download a .sub1 {
    padding: 0;
  }
}
.breadcrumb {
  background: rgb(240, 240, 255);
}

.breadcrumb > nav {
  width: 700px;
  margin: 0 auto;
}

.breadcrumb > nav > ol {
  display: flex;
  align-items: center;
  gap: 30px;
  height: 50px;
}

.breadcrumb > nav > ol > li {
  list-style: none;
  font-size: 12px;
  line-height: 1;
  position: relative;
}

.breadcrumb > nav > ol > li > a {
  color: #62a5fe;
  text-decoration: underline;
}

.breadcrumb > nav > ol > li:not(:last-child)::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  right: -18px;
  width: 6px;
  height: 6px;
  border-top: 2px solid #777;
  border-right: 2px solid #777;
  transform: rotate(45deg);
  margin: auto;
}

/* 年末対応の文言 */
.top-image1 .emergency span {
  font-size: 24px;
  letter-spacing: 2px;
  line-height: 3;
  color: #fff;
  background-color: rgb(60, 65, 105);
  padding: 12px;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  font-weight: bold;
  display: block;
  text-align: center;
  width: 380px;
  margin: 0 auto;
  text-wrap: nowrap;
  text-align: center;
  padding: 0 1.5%;
}

.top-image-slide .emergency span {
  font-size: 24px;
  letter-spacing: 2px;
  line-height: 3;
  color: #fff;
  background-color: rgb(60, 65, 105);
  padding: 12px;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  font-weight: bold;
  display: block;
  text-align: center;
  width: 380px;
  margin: 0 auto;
  text-wrap: nowrap;
  text-align: center;
  padding: 0 1.5%;
}

.nenmatu {
  color: #C40024;
  line-height: 170%;
  display: block;
  width: 100%;
  text-align: center;
  padding: 10px 0;
  font-size: 1.6vw;
}

/* 資料請求・お見積り */
.page-contact__img {
  margin-bottom: 40px;
}

.contact-form {
  border-collapse: collapse;
  border-top: 1px solid #b4b4b4;
}

.contact-form tbody tr th {
  width: 280px;
  background: #F0F0FF;
  border-right: 1px dotted #b4b4b4;
  padding: 25px 6px 25px 15px;
  vertical-align: middle;
  font-size: 18px;
  font-weight: bold;
  position: relative;
}

.contact-form tbody tr th p {
  /* text-align: center; */
  line-height: 1.4;
  font-size: 17.6px;
  letter-spacing: 0;
}

.contact-form tbody tr th .is-required {
  background: #CC3D3E;
  color: #fff;
  border-radius: 3px;
  padding: 2px 4px;
  font-size: 12px;
  /* margin-right: 5px; */
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 34px;
  height: 18px;
  line-height: 18px;
  text-align: center;
  right: 10px;
}

.contact-form tbody tr td {
  padding: 25px 10px 25px 30px;
  background: #fff;
  width: 510px;
}

.contact-form tbody tr td .check {
  padding: 10px;
  border: solid 1px #ccc;
  background: #EEE;
  border-radius: 3px;
  line-height: 1;
}

.contact-form tbody tr td .check .last {
  margin: 0;
}

.contact-form tbody tr td .yellow {
  background: #FFEEEE;
}

.contact-form tbody tr td input[type=text],
.contact-form tbody tr td input[type=email] {
  font-size: 18px;
  width: 90%;
  padding: 10px;
  border: 0;
  border: solid 1px #ccc;
}

.contact-form tbody tr td textarea {
  font-size: 18px;
  width: 90%;
  padding: 10px;
  border: 0;
  border: solid 1px #ccc;
}

input.wpcf7-form-control.wpcf7-submit.has-spinner.submit_btn {
  padding: 40px 100px;
  background: linear-gradient(#505082 0%, #323264 50%, #28285a 51%, #000032 100%);
  border: solid 1px #390000;
  border-radius: 10px;
  border: none;
  font-size: 24px;
  color: #fff;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, sans-serif;
  font-weight: bold;
  margin: 50px auto 0;
  text-align: center;
  display: block;
}

.sms {
  font-size: 14px;
  text-align: center;
}

.privacyBox {
  border: 1px solid #ccc;
  border-radius: 4px;
  width: 80%;
  height: 120px;
  margin: 50px auto 10px;
  overflow-x: hidden;
  overflow-y: scroll;
  padding: 20px;
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, sans-serif;
  line-height: 2;
  background: #fff;
}

.privacyBox h3 {
  display: block;
  font-size: 17px;
  font-weight: bold;
  padding: 5px 0;
  text-align: center;
}

.privacyBox ol li {
  list-style: outside none decimal;
  margin: 0 0 10px 1.5em;
  padding-left: 0.5em;
  font-size: 13px;
}

.privacyBox p {
  padding: 10px 0 0 25px;
}

.complete {
  max-width: 800px;
  line-height: 150%;
  margin: 0 auto;
  border: solid 1px #ccc;
  background: #fff;
  padding: 35px 50px;
  clear: both;
}

.complete:not(:last-child) {
  margin-bottom: 30px;
}

.completeRelated {
  padding: 15px 20px;
  border: solid 1px #ccc;
  background: #EEE;
  border-radius: 10px;
  margin-top: 40px;
}
/*# sourceMappingURL=laptop.css.map */
