@charset "UTF-8";
/* -------------------
  VARIABLES
--------------------*/
.font-a {
  font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif; }

.font-b {
  font-family: "Noto Serif JP", serif; }

.font-c {
  font-family: "Noto Serif JP", serif; }

.noto-serif jp-black {
  font-family: "Noto Serif JP", serif;
  font-weight: 900;
  font-style: normal; }

.noto-serif jp-bold {
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  font-style: normal; }

.noto-serif jp-semibold {
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-style: normal; }

.noto-serif jp-medium {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-style: normal; }

.noto-serif jp-regular {
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
  font-style: normal; }

.noto-serif jp-light {
  font-family: "Noto Serif JP", serif;
  font-weight: 300;
  font-style: normal; }

.noto-serif jp-extralight {
  font-family: "Noto Serif JP", serif;
  font-weight: 200;
  font-style: normal; }

.noto-sans jp-100-900 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal; }

.spring-lp {
  font-family: spring-lp, sans-serif;
  font-style: normal; }

/* -------------------
  MIXIN
--------------------*/
/* 
.example {
  font-size: vw(12);
}
*/
/* 
.example {
  font-size: fs(12); <- 12px quite
}
*/
/* 
.example {
  @include mq() {
    width: 100%;
  }
}
*/
/* -------------------
  COMMON
--------------------*/
body {
  font-family: "Noto Sans JP", sans-serif;
  color: #000;
  font-size: 16px;
  line-height: 1.73;
  font-weight: 500;
  position: relative;
  text-size-adjust: 100%;
  font-feature-settings: "palt";
  letter-spacing: 0.05em; }

section,
article,
header,
footer,
time {
  display: block; }

p,
ul,
table {
  margin-bottom: 1.6em; }

h2,
h3,
h4,
h5,
h6 {
  line-height: 1.6;
  margin-bottom: 1em;
  font-weight: bold; }

a {
  transition: all 0.3s ease 0s;
  cursor: pointer; }
  a[href^="tel:"] {
    pointer-events: none; }
    @media screen and (max-width: 767px) {
      a[href^="tel:"] {
        pointer-events: auto; } }
  a:hover {
    opacity: 0.7; }

img {
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
  pointer-events: none; }
  img.w100 {
    width: 100%; }
  img.pc-only {
    display: inline; }
    @media screen and (max-width: 767px) {
      img.pc-only {
        display: none; } }
  img.sp-only {
    display: none; }
    @media screen and (max-width: 767px) {
      img.sp-only {
        display: inline; } }

.pc-only {
  display: block; }
  @media screen and (max-width: 767px) {
    .pc-only {
      display: none; } }

.sp-only {
  display: none; }
  @media screen and (max-width: 767px) {
    .sp-only {
      display: block; } }

.pc-only2 {
  display: inline; }
  @media screen and (max-width: 767px) {
    .pc-only2 {
      display: none; } }

.sp-only2 {
  display: none; }
  @media screen and (max-width: 767px) {
    .sp-only2 {
      display: inline; } }

.c-width {
  max-width: 1200px;
  margin: 0 auto; }

.c-width-980 {
  max-width: 980px;
  margin: 0 auto; }

/* Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
  margin-bottom: 0 !important; }

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0; }
  .slick-list:focus {
    outline: none; }
  .slick-list.dragging {
    cursor: pointer;
    cursor: hand; }

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0); }

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto; }
  .slick-track:before, .slick-track:after {
    content: "";
    display: table; }
  .slick-track:after {
    clear: both; }
  .slick-loading .slick-track {
    visibility: hidden; }

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none; }
  [dir="rtl"] .slick-slide {
    float: right; }
  .slick-slide img {
    display: block; }
  .slick-slide.slick-loading img {
    display: none; }
  .slick-slide.dragging img {
    pointer-events: none; }
  .slick-initialized .slick-slide {
    display: block; }
  .slick-loading .slick-slide {
    visibility: hidden; }
  .slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent; }

.slick-arrow.slick-hidden {
  display: none; }

.slick-dots {
  display: flex;
  justify-content: center;
  bottom: 35px; }
  .slick-dots li {
    opacity: 0.5; }
    .slick-dots li:last-child {
      margin-right: 0; }
    .slick-dots li button {
      position: relative;
      display: inline-block;
      width: 10px;
      height: 10px;
      font-size: 0;
      background-color: #fff;
      border-radius: 50%; }
      .slick-dots li button:before {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        -webkit-transform: translate(-50%, -50%);
        display: inline-block;
        width: 10px;
        height: 10px;
        background-color: #EEEEEE;
        border-radius: 50%;
        content: ""; }
    .slick-dots li.slick-active {
      opacity: 1; }
      .slick-dots li.slick-active button {
        border: none; }
        .slick-dots li.slick-active button:before {
          background-color: #ffcc00; }

.slick-prev,
.slick-next {
  position: absolute;
  top: calc(50% - 20px);
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: #6B9FE8;
  z-index: 1;
  transition: all .3s; }
  .slick-prev:hover, .slick-prev:focus,
  .slick-next:hover,
  .slick-next:focus {
    outline: 0; }
  .slick-prev:hover,
  .slick-next:hover {
    background-color: #2f5baf; }
  .slick-prev span,
  .slick-next span {
    display: block;
    position: relative;
    width: 100%;
    height: 100%; }
    .slick-prev span:before,
    .slick-next span:before {
      position: absolute;
      top: 15px;
      border: solid #fff;
      border-width: 0 2px 2px 0;
      display: inline-block;
      padding: 4px;
      content: ""; }

.slick-prev {
  left: 0; }
  @media screen and (max-width: 1050px) {
    .slick-prev {
      left: 10px; } }
  .slick-prev span:before {
    left: 17px;
    transform: rotate(135deg);
    -webkit-transform: rotate(135deg); }

.slick-next {
  right: 0; }
  @media screen and (max-width: 1050px) {
    .slick-next {
      right: 10px; } }
  .slick-next span:before {
    left: 20px;
    transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg) translate(-50%, -50%); }
  @media all and (-ms-high-contrast: none) {
    .slick-next {
      /* IE10 */
      /* IE11 */ }
      .slick-next span:before {
        left: 15px; }
      .slick-next *::-ms-backdrop:before,
      .slick-next span:before {
        left: 15px; } }

.ui-datepicker {
  background-color: #fff;
  padding: .8em .5em .3em; }

.ui-datepicker .ui-datepicker-title {
  font-size: 0.875rem;
  text-align: center; }

.ui-widget.ui-widget-content {
  border-radius: 5px; }

.ui-widget-header {
  border: none;
  background: inherit;
  color: #474F5F;
  font-weight: bold; }

.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default, .ui-button, html .ui-button.ui-state-disabled:hover, html .ui-button.ui-state-disabled:active {
  border: none;
  background: #ECF0F4;
  font-weight: bold;
  color: #3B93D2;
  text-align: center;
  padding: 7px 9px;
  font-size: 0.6875rem; }

.ui-datepicker th {
  padding: .7em .3em;
  text-align: center;
  font-weight: bold;
  border: 0;
  color: #AFB4BC;
  font-size: 0.6875rem; }

.ui-datepicker .ui-datepicker-prev,
.ui-datepicker .ui-datepicker-next {
  position: absolute;
  left: 10px;
  cursor: pointer;
  font-size: 0.75rem; }
  .ui-datepicker .ui-datepicker-prev:hover,
  .ui-datepicker .ui-datepicker-next:hover {
    border: none;
    background-color: #fff; }

.ui-datepicker .ui-datepicker-next {
  right: 10px;
  left: auto; }

.ui-datepicker .ui-datepicker-prev span,
.ui-datepicker .ui-datepicker-next span {
  margin-top: -6px; }

.ui-icon {
  width: 10px;
  height: 10px; }

.ui-widget-content .ui-state-default:hover {
  border: 0px;
  text-align: center;
  background: #000;
  color: #fff; }

.ui-widget-content .ui-state-active {
  border: 0px;
  background: #000;
  color: #fff; }

.ui-datepicker td {
  padding: 1px; }

a.ui-state-default {
  width: 100%;
  display: block; }

/* Fade up */
.fadeup {
  opacity: 0;
  transform: translate(0, 35%);
  transition: opacity 2s cubic-bezier(0.165, 0.84, 0.44, 1) 0s, transform 2s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
  .fadeup.in {
    opacity: 1;
    transform: translate(0, 0); }

.fadeup2 {
  transform: translate(0, 80px);
  transition: transform 1s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
  .fadeup2.in {
    transform: translate(0, 0); }

/* Fade in */
.fadein {
  opacity: 0;
  transition: opacity 2.5s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
  .fadein.in {
    opacity: 1; }

/* Fade up */
.fadeleft {
  opacity: 0;
  transform: translate(-80px, 0);
  transition: opacity 1s cubic-bezier(0.165, 0.84, 0.44, 1) 0s, transform 1s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
  .fadeleft.in {
    opacity: 1;
    transform: translate(0, 0); }

.fadeleft2 {
  transform: translate(-80px, 0);
  transition: transform 1s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
  .fadeleft2.in {
    transform: translate(0, 0); }

/* Fade up */
.faderight {
  opacity: 0;
  transform: translate(80px, 0);
  transition: opacity 1s cubic-bezier(0.165, 0.84, 0.44, 1) 0s, transform 1s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
  .faderight.in {
    opacity: 1;
    transform: translate(0, 0); }

.faderight2 {
  transform: translate(80px, 0);
  transition: transform 1s cubic-bezier(0.165, 0.84, 0.44, 1) 0s; }
  .faderight2.in {
    transform: translate(0, 0); }

.fuwafuwa {
  animation: fuwafuwa 1.5s infinite; }

.fuwafuwa-t {
  animation: fuwafuwa-t 3.5s infinite; }

@keyframes fuwafuwa {
  0% {
    transform: translateY(0px); }
  50% {
    transform: translateY(-20px); }
  100% {
    transform: translateY(0px); } }

@keyframes fuwafuwa-t {
  0% {
    transform: translateY(0px); }
  40% {
    opacity: 1; }
  100% {
    transform: translateY(-180%);
    opacity: 0; } }

/* Nina */
.button--ninaWrap {
  display: inline-block;
  text-align: center;
  min-width: 154px;
  max-width: 100%;
  background: #fff;
  border-radius: 72px;
  overflow: hidden; }
  @media screen and (max-width: 767px) {
    .button--ninaWrap {
      width: 100%; } }

.button--nina {
  position: relative;
  display: inline-block;
  height: 55px;
  line-height: 56px;
  color: #474F5F;
  -webkit-transition: background-color 0.3s;
  transition: background-color 0.3s;
  vertical-align: middle;
  font-size: 0.75rem;
  font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
  font-weight: 500;
  z-index: 1;
  -webkit-backface-visibility: hidden;
  -moz-osx-font-smoothing: grayscale;
  text-align: center; }
  .button--nina span {
    vertical-align: middle; }

.button--nina > span {
  display: inline-block;
  opacity: 0;
  color: #fff;
  -webkit-transform: translate3d(0, -10px, 0);
  transform: translate3d(0, -10px, 0);
  -webkit-transition: -webkit-transform 0.3s, opacity 0.3s;
  transition: transform 0.3s, opacity 0.3s;
  -webkit-transition-timing-function: cubic-bezier(0.75, 0, 0.125, 1);
  transition-timing-function: cubic-bezier(0.75, 0, 0.125, 1); }

.button--nina::before {
  content: attr(data-text);
  position: absolute;
  top: -12px;
  left: 0;
  width: 100%;
  height: 100%;
  padding: 1em 0;
  -webkit-transition: -webkit-transform 0.3s, opacity 0.3s;
  transition: transform 0.3s, opacity 0.3s;
  -webkit-transition-timing-function: cubic-bezier(0.75, 0, 0.125, 1);
  transition-timing-function: cubic-bezier(0.75, 0, 0.125, 1); }

.button--ninaWrap:hover {
  background-color: #474F5F;
  letter-spacing: -1.5px; }

.button--ninaWrap:hover .button--nina {
  letter-spacing: -1.5px; }

.button--ninaWrap:hover .button--nina::before {
  opacity: 0;
  -webkit-transform: translate3d(0, 100%, 0);
  transform: translate3d(0, 100%, 0); }

.button--ninaWrap:hover .button--nina > span {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0); }

.button--ninaWrap:hover .button--nina > span:nth-child(1) {
  -webkit-transition-delay: 0.045s;
  transition-delay: 0.045s; }

.button--ninaWrap:hover .button--nina > span:nth-child(2) {
  -webkit-transition-delay: 0.09s;
  transition-delay: 0.09s; }

.button--ninaWrap:hover .button--nina > span:nth-child(3) {
  -webkit-transition-delay: 0.135s;
  transition-delay: 0.135s; }

.button--ninaWrap:hover .button--nina > span:nth-child(4) {
  -webkit-transition-delay: 0.18s;
  transition-delay: 0.18s; }

.button--ninaWrap:hover .button--nina > span:nth-child(5) {
  -webkit-transition-delay: 0.225s;
  transition-delay: 0.225s; }

.button--ninaWrap:hover .button--nina > span:nth-child(6) {
  -webkit-transition-delay: 0.27s;
  transition-delay: 0.27s; }

.button--ninaWrap:hover .button--nina > span:nth-child(7) {
  -webkit-transition-delay: 0.315s;
  transition-delay: 0.315s; }

.button--ninaWrap:hover .button--nina > span:nth-child(8) {
  -webkit-transition-delay: 0.36s;
  transition-delay: 0.36s; }

.button--ninaWrap:hover .button--nina > span:nth-child(9) {
  -webkit-transition-delay: 0.405s;
  transition-delay: 0.405s; }

.button--ninaWrap:hover .button--nina > span:nth-child(10) {
  -webkit-transition-delay: 0.45s;
  transition-delay: 0.45s; }

.button--nina:after {
  position: absolute;
  right: -2px;
  top: calc(50% - 4px);
  display: inline-block;
  width: 5px;
  height: 9px;
  background: url(../images/common/icon-arrow-right.svg) no-repeat;
  transition: all .3s;
  content: "";
  z-index: 1; }

.button--ninaWrap:hover .button--nina:after {
  top: calc(50% - 3px);
  display: inline-block;
  transform: translateX(18px);
  background-image: url(../images/common/icon-arrow-right-white.svg); }

.button--ninaWrap--blue {
  background: #4AABB8; }
  .button--ninaWrap--blue .button--nina {
    color: #fff; }
    .button--ninaWrap--blue .button--nina span {
      color: #4AABB8; }
    .button--ninaWrap--blue .button--nina::after {
      background: url(../images/common/icon-arrow-right-white.svg) no-repeat; }
  .button--ninaWrap--blue:hover {
    background-color: #fff;
    letter-spacing: -1.5px; }
    .button--ninaWrap--blue:hover .button--nina {
      color: #4AABB8; }
      .button--ninaWrap--blue:hover .button--nina::after {
        background: url(../images/common/icon-arrow-right-blue.svg) no-repeat; }

.delay-1 {
  transition-delay: .1s; }

.delay-2 {
  transition-delay: .2s; }

.delay-3 {
  transition-delay: .3s; }

.delay-4 {
  transition-delay: .4s; }

.delay-5 {
  transition-delay: .5s; }

.delay-6 {
  transition-delay: .6s; }

.delay-7 {
  transition-delay: .7s; }

.delay-8 {
  transition-delay: .8s; }

.delay-9 {
  transition-delay: .9s; }

.delay-10 {
  transition-delay: 1s; }

.delay-11 {
  transition-delay: 1.1s; }

.delay-12 {
  transition-delay: 1.2s; }

.delay-13 {
  transition-delay: 1.3s; }

.delay-14 {
  transition-delay: 1.4s; }

.delay-15 {
  transition-delay: 1.5s; }

.delay-16 {
  transition-delay: 1.6s; }

.delay-17 {
  transition-delay: 1.7s; }

.delay-18 {
  transition-delay: 1.8s; }

.delay-19 {
  transition-delay: 1.9s; }

.delay-20 {
  transition-delay: 2.0s; }

.delay-21 {
  transition-delay: 2.1s; }

.delay-22 {
  transition-delay: 2.2s; }

.delay-23 {
  transition-delay: 2.3s; }

.delay-24 {
  transition-delay: 2.4s; }

.ani-delay-1 {
  animation-delay: .1s; }

.ani-delay-2 {
  animation-delay: .2s; }

.ani-delay-3 {
  animation-delay: .3s; }

.ani-delay-4 {
  animation-delay: .4s; }

.ani-delay-5 {
  animation-delay: .5s; }

.ani-delay-6 {
  animation-delay: .6s; }

.ani-delay-7 {
  animation-delay: .7s; }

.ani-delay-8 {
  animation-delay: .8s; }

.ani-delay-9 {
  animation-delay: .9s; }

.ani-delay-10 {
  animation-delay: 1s; }

.ani-delay-11 {
  animation-delay: 1.1s; }

.ani-delay-12 {
  animation-delay: 1.2s; }

.ani-delay-13 {
  animation-delay: 1.3s; }

.ani-delay-14 {
  animation-delay: 1.4s; }

.ani-delay-15 {
  animation-delay: 1.5s; }

.ani-delay-16 {
  animation-delay: 1.6s; }

.ani-delay-17 {
  animation-delay: 1.7s; }

.ani-delay-18 {
  animation-delay: 1.8s; }

.ani-delay-19 {
  animation-delay: 1.9s; }

.ani-delay-20 {
  animation-delay: 2.0s; }

.ani-delay-21 {
  animation-delay: 2.1s; }

.ani-delay-22 {
  animation-delay: 2.2s; }

.ani-delay-23 {
  animation-delay: 2.3s; }

.ani-delay-24 {
  animation-delay: 2.4s; }

/* -------------------
  PARTS
--------------------*/
.mgt-0 {
  margin-top: 0; }

.mgt-5 {
  margin-top: 5px; }

.mgt-10 {
  margin-top: 10px; }

.mgt-15 {
  margin-top: 15px; }

.mgt-20 {
  margin-top: 20px; }

.mgt-25 {
  margin-top: 25px; }

.mgt-30 {
  margin-top: 30px; }

.mgt-35 {
  margin-top: 35px; }

.mgt-40 {
  margin-top: 40px; }

.mgt-45 {
  margin-top: 45px; }

.mgt-50 {
  margin-top: 50px; }

.mgt-55 {
  margin-top: 55px; }

.mgt-60 {
  margin-top: 60px; }

.mgt-65 {
  margin-top: 65px; }

.mgt-70 {
  margin-top: 70px; }

.mgt-75 {
  margin-top: 75px; }

.mgt-80 {
  margin-top: 80px; }

.mgt-85 {
  margin-top: 85px; }

.mgt-90 {
  margin-top: 90px; }

.mgt-95 {
  margin-top: 95px; }

.mgt-100 {
  margin-top: 100px; }

.mgb-0 {
  margin-bottom: 0 !important; }

.mgb-5 {
  margin-bottom: 5px; }

.mgb-10 {
  margin-bottom: 10px; }

.mgb-15 {
  margin-bottom: 15px; }

.mgb-20 {
  margin-bottom: 20px; }

.mgb-25 {
  margin-bottom: 25px; }

.mgb-30 {
  margin-bottom: 30px; }

.mgb-35 {
  margin-bottom: 35px; }

.mgb-40 {
  margin-bottom: 40px; }

.mgb-45 {
  margin-bottom: 45px; }

.mgb-50 {
  margin-bottom: 50px; }

.mgb-55 {
  margin-bottom: 55px; }

.mgb-60 {
  margin-bottom: 60px; }

.mgb-65 {
  margin-bottom: 65px; }

.mgb-70 {
  margin-bottom: 70px; }

.mgb-75 {
  margin-bottom: 75px; }

.mgb-80 {
  margin-bottom: 80px; }

.mgb-85 {
  margin-bottom: 85px; }

.mgb-90 {
  margin-bottom: 90px; }

.mgb-95 {
  margin-bottom: 95px; }

.mgb-100 {
  margin-bottom: 100px; }

.mgl-0 {
  margin-left: 0; }

.mgl-1 {
  margin-left: 1px; }

.mgl-2 {
  margin-left: 2px; }

.mgl-3 {
  margin-left: 3px; }

.mgl-4 {
  margin-left: 4px; }

.mgl-5 {
  margin-left: 5px; }

.mgl-6 {
  margin-left: 6px; }

.mgl-7 {
  margin-left: 7px; }

.mgl-8 {
  margin-left: 8px; }

.mgl-9 {
  margin-left: 9px; }

.mgl-10 {
  margin-left: 10px; }

.mgr-0 {
  margin-right: 0; }

.mgr-1 {
  margin-right: 1px; }

.mgr-2 {
  margin-right: 2px; }

.mgr-3 {
  margin-right: 3px; }

.mgr-4 {
  margin-right: 4px; }

.mgr-5 {
  margin-right: 5px; }

.mgr-6 {
  margin-right: 6px; }

.mgr-7 {
  margin-right: 7px; }

.mgr-8 {
  margin-right: 8px; }

.mgr-9 {
  margin-right: 9px; }

.mgr-10 {
  margin-right: 10px; }

.mgr-20 {
  margin-right: 20px; }
  @media screen and (max-width: 767px) {
    .mgr-20 {
      margin-right: 10px; } }

.pdt-10 {
  padding-top: 10px !important; }

.pdt-20 {
  padding-top: 20px !important; }

.pdt-30 {
  padding-top: 30px !important; }

.pdt-40 {
  padding-top: 40px !important; }

.pdt-50 {
  padding-top: 50px !important; }

.mx-0 {
  margin-left: 0 !important;
  margin-right: 0 !important; }

.my-0 {
  margin-top: 0 !important;
  margin-bottom: 0 !important; }

.px-0 {
  padding-left: 0 !important;
  padding-right: 0 !important; }

.py-0 {
  padding-top: 0 !important;
  padding-bottom: 0 !important; }

.m-center {
  margin: 0 auto; }

.mb-10 {
  margin-bottom: 10px !important; }

.mt-10 {
  margin-top: 10px !important; }

.mr-10 {
  margin-right: 10px !important; }

.ml-10 {
  margin-left: 10px !important; }

.pb-10 {
  padding-bottom: 10px !important; }

.pt-10 {
  padding-top: 10px !important; }

.pr-10 {
  padding-right: 10px !important; }

.pl-10 {
  padding-left: 10px !important; }

.mb-15 {
  margin-bottom: 15px !important; }

.mt-15 {
  margin-top: 15px !important; }

.mr-15 {
  margin-right: 15px !important; }

.ml-15 {
  margin-left: 15px !important; }

.pb-15 {
  padding-bottom: 15px !important; }

.pt-15 {
  padding-top: 15px !important; }

.pr-15 {
  padding-right: 15px !important; }

.pl-15 {
  padding-left: 15px !important; }

.mb-20 {
  margin-bottom: 20px !important; }

.mt-20 {
  margin-top: 20px !important; }

.mr-20 {
  margin-right: 20px !important; }

.ml-20 {
  margin-left: 20px !important; }

.pb-20 {
  padding-bottom: 20px !important; }

.pt-20 {
  padding-top: 20px !important; }

.pr-20 {
  padding-right: 20px !important; }

.pl-20 {
  padding-left: 20px !important; }

.mb-25 {
  margin-bottom: 25px !important; }

.mt-25 {
  margin-top: 25px !important; }

.mr-25 {
  margin-right: 25px !important; }

.ml-25 {
  margin-left: 25px !important; }

.pb-25 {
  padding-bottom: 25px !important; }

.pt-25 {
  padding-top: 25px !important; }

.pr-25 {
  padding-right: 25px !important; }

.pl-25 {
  padding-left: 25px !important; }

.mb-30 {
  margin-bottom: 30px !important; }

.mt-30 {
  margin-top: 30px !important; }

.mr-30 {
  margin-right: 30px !important; }

.ml-30 {
  margin-left: 30px !important; }

.pb-30 {
  padding-bottom: 30px !important; }

.pt-30 {
  padding-top: 30px !important; }

.pr-30 {
  padding-right: 30px !important; }

.pl-30 {
  padding-left: 30px !important; }

.mb-35 {
  margin-bottom: 35px !important; }

.mt-35 {
  margin-top: 35px !important; }

.mr-35 {
  margin-right: 35px !important; }

.ml-35 {
  margin-left: 35px !important; }

.pb-35 {
  padding-bottom: 35px !important; }

.pt-35 {
  padding-top: 35px !important; }

.pr-35 {
  padding-right: 35px !important; }

.pl-35 {
  padding-left: 35px !important; }

.mb-40 {
  margin-bottom: 40px !important; }

.mt-40 {
  margin-top: 40px !important; }

.mr-40 {
  margin-right: 40px !important; }

.ml-40 {
  margin-left: 40px !important; }

.pb-40 {
  padding-bottom: 40px !important; }

.pt-40 {
  padding-top: 40px !important; }

.pr-40 {
  padding-right: 40px !important; }

.pl-40 {
  padding-left: 40px !important; }

.mb-45 {
  margin-bottom: 45px !important; }

.mt-45 {
  margin-top: 45px !important; }

.mr-45 {
  margin-right: 45px !important; }

.ml-45 {
  margin-left: 45px !important; }

.pb-45 {
  padding-bottom: 45px !important; }

.pt-45 {
  padding-top: 45px !important; }

.pr-45 {
  padding-right: 45px !important; }

.pl-45 {
  padding-left: 45px !important; }

.mb-50 {
  margin-bottom: 50px !important; }

.mt-50 {
  margin-top: 50px !important; }

.mr-50 {
  margin-right: 50px !important; }

.ml-50 {
  margin-left: 50px !important; }

.pb-50 {
  padding-bottom: 50px !important; }

.pt-50 {
  padding-top: 50px !important; }

.pr-50 {
  padding-right: 50px !important; }

.pl-50 {
  padding-left: 50px !important; }

.mb-55 {
  margin-bottom: 55px !important; }

.mt-55 {
  margin-top: 55px !important; }

.mr-55 {
  margin-right: 55px !important; }

.ml-55 {
  margin-left: 55px !important; }

.pb-55 {
  padding-bottom: 55px !important; }

.pt-55 {
  padding-top: 55px !important; }

.pr-55 {
  padding-right: 55px !important; }

.pl-55 {
  padding-left: 55px !important; }

.mb-60 {
  margin-bottom: 60px !important; }

.mt-60 {
  margin-top: 60px !important; }

.mr-60 {
  margin-right: 60px !important; }

.ml-60 {
  margin-left: 60px !important; }

.pb-60 {
  padding-bottom: 60px !important; }

.pt-60 {
  padding-top: 60px !important; }

.pr-60 {
  padding-right: 60px !important; }

.pl-60 {
  padding-left: 60px !important; }

.mb-65 {
  margin-bottom: 65px !important; }

.mt-65 {
  margin-top: 65px !important; }

.mr-65 {
  margin-right: 65px !important; }

.ml-65 {
  margin-left: 65px !important; }

.pb-65 {
  padding-bottom: 65px !important; }

.pt-65 {
  padding-top: 65px !important; }

.pr-65 {
  padding-right: 65px !important; }

.pl-65 {
  padding-left: 65px !important; }

.mb-70 {
  margin-bottom: 70px !important; }

.mt-70 {
  margin-top: 70px !important; }

.mr-70 {
  margin-right: 70px !important; }

.ml-70 {
  margin-left: 70px !important; }

.pb-70 {
  padding-bottom: 70px !important; }

.pt-70 {
  padding-top: 70px !important; }

.pr-70 {
  padding-right: 70px !important; }

.pl-70 {
  padding-left: 70px !important; }

.mb-75 {
  margin-bottom: 75px !important; }

.mt-75 {
  margin-top: 75px !important; }

.mr-75 {
  margin-right: 75px !important; }

.ml-75 {
  margin-left: 75px !important; }

.pb-75 {
  padding-bottom: 75px !important; }

.pt-75 {
  padding-top: 75px !important; }

.pr-75 {
  padding-right: 75px !important; }

.pl-75 {
  padding-left: 75px !important; }

.mb-80 {
  margin-bottom: 80px !important; }

.mt-80 {
  margin-top: 80px !important; }

.mr-80 {
  margin-right: 80px !important; }

.ml-80 {
  margin-left: 80px !important; }

.pb-80 {
  padding-bottom: 80px !important; }

.pt-80 {
  padding-top: 80px !important; }

.pr-80 {
  padding-right: 80px !important; }

.pl-80 {
  padding-left: 80px !important; }

.mb-85 {
  margin-bottom: 85px !important; }

.mt-85 {
  margin-top: 85px !important; }

.mr-85 {
  margin-right: 85px !important; }

.ml-85 {
  margin-left: 85px !important; }

.pb-85 {
  padding-bottom: 85px !important; }

.pt-85 {
  padding-top: 85px !important; }

.pr-85 {
  padding-right: 85px !important; }

.pl-85 {
  padding-left: 85px !important; }

.mb-90 {
  margin-bottom: 90px !important; }

.mt-90 {
  margin-top: 90px !important; }

.mr-90 {
  margin-right: 90px !important; }

.ml-90 {
  margin-left: 90px !important; }

.pb-90 {
  padding-bottom: 90px !important; }

.pt-90 {
  padding-top: 90px !important; }

.pr-90 {
  padding-right: 90px !important; }

.pl-90 {
  padding-left: 90px !important; }

.mb-95 {
  margin-bottom: 95px !important; }

.mt-95 {
  margin-top: 95px !important; }

.mr-95 {
  margin-right: 95px !important; }

.ml-95 {
  margin-left: 95px !important; }

.pb-95 {
  padding-bottom: 95px !important; }

.pt-95 {
  padding-top: 95px !important; }

.pr-95 {
  padding-right: 95px !important; }

.pl-95 {
  padding-left: 95px !important; }

.mb-100 {
  margin-bottom: 100px !important; }

.mt-100 {
  margin-top: 100px !important; }

.mr-100 {
  margin-right: 100px !important; }

.ml-100 {
  margin-left: 100px !important; }

.pb-100 {
  padding-bottom: 100px !important; }

.pt-100 {
  padding-top: 100px !important; }

.pr-100 {
  padding-right: 100px !important; }

.pl-100 {
  padding-left: 100px !important; }

.mb-105 {
  margin-bottom: 105px !important; }

.mt-105 {
  margin-top: 105px !important; }

.mr-105 {
  margin-right: 105px !important; }

.ml-105 {
  margin-left: 105px !important; }

.pb-105 {
  padding-bottom: 105px !important; }

.pt-105 {
  padding-top: 105px !important; }

.pr-105 {
  padding-right: 105px !important; }

.pl-105 {
  padding-left: 105px !important; }

.mb-110 {
  margin-bottom: 110px !important; }

.mt-110 {
  margin-top: 110px !important; }

.mr-110 {
  margin-right: 110px !important; }

.ml-110 {
  margin-left: 110px !important; }

.pb-110 {
  padding-bottom: 110px !important; }

.pt-110 {
  padding-top: 110px !important; }

.pr-110 {
  padding-right: 110px !important; }

.pl-110 {
  padding-left: 110px !important; }

.mb-115 {
  margin-bottom: 115px !important; }

.mt-115 {
  margin-top: 115px !important; }

.mr-115 {
  margin-right: 115px !important; }

.ml-115 {
  margin-left: 115px !important; }

.pb-115 {
  padding-bottom: 115px !important; }

.pt-115 {
  padding-top: 115px !important; }

.pr-115 {
  padding-right: 115px !important; }

.pl-115 {
  padding-left: 115px !important; }

.mb-120 {
  margin-bottom: 120px !important; }

.mt-120 {
  margin-top: 120px !important; }

.mr-120 {
  margin-right: 120px !important; }

.ml-120 {
  margin-left: 120px !important; }

.pb-120 {
  padding-bottom: 120px !important; }

.pt-120 {
  padding-top: 120px !important; }

.pr-120 {
  padding-right: 120px !important; }

.pl-120 {
  padding-left: 120px !important; }

.mb-125 {
  margin-bottom: 125px !important; }

.mt-125 {
  margin-top: 125px !important; }

.mr-125 {
  margin-right: 125px !important; }

.ml-125 {
  margin-left: 125px !important; }

.pb-125 {
  padding-bottom: 125px !important; }

.pt-125 {
  padding-top: 125px !important; }

.pr-125 {
  padding-right: 125px !important; }

.pl-125 {
  padding-left: 125px !important; }

.mb-130 {
  margin-bottom: 130px !important; }

.mt-130 {
  margin-top: 130px !important; }

.mr-130 {
  margin-right: 130px !important; }

.ml-130 {
  margin-left: 130px !important; }

.pb-130 {
  padding-bottom: 130px !important; }

.pt-130 {
  padding-top: 130px !important; }

.pr-130 {
  padding-right: 130px !important; }

.pl-130 {
  padding-left: 130px !important; }

.mb-135 {
  margin-bottom: 135px !important; }

.mt-135 {
  margin-top: 135px !important; }

.mr-135 {
  margin-right: 135px !important; }

.ml-135 {
  margin-left: 135px !important; }

.pb-135 {
  padding-bottom: 135px !important; }

.pt-135 {
  padding-top: 135px !important; }

.pr-135 {
  padding-right: 135px !important; }

.pl-135 {
  padding-left: 135px !important; }

.mb-140 {
  margin-bottom: 140px !important; }

.mt-140 {
  margin-top: 140px !important; }

.mr-140 {
  margin-right: 140px !important; }

.ml-140 {
  margin-left: 140px !important; }

.pb-140 {
  padding-bottom: 140px !important; }

.pt-140 {
  padding-top: 140px !important; }

.pr-140 {
  padding-right: 140px !important; }

.pl-140 {
  padding-left: 140px !important; }

.mb-145 {
  margin-bottom: 145px !important; }

.mt-145 {
  margin-top: 145px !important; }

.mr-145 {
  margin-right: 145px !important; }

.ml-145 {
  margin-left: 145px !important; }

.pb-145 {
  padding-bottom: 145px !important; }

.pt-145 {
  padding-top: 145px !important; }

.pr-145 {
  padding-right: 145px !important; }

.pl-145 {
  padding-left: 145px !important; }

.mb-150 {
  margin-bottom: 150px !important; }

.mt-150 {
  margin-top: 150px !important; }

.mr-150 {
  margin-right: 150px !important; }

.ml-150 {
  margin-left: 150px !important; }

.pb-150 {
  padding-bottom: 150px !important; }

.pt-150 {
  padding-top: 150px !important; }

.pr-150 {
  padding-right: 150px !important; }

.pl-150 {
  padding-left: 150px !important; }

.mb-155 {
  margin-bottom: 155px !important; }

.mt-155 {
  margin-top: 155px !important; }

.mr-155 {
  margin-right: 155px !important; }

.ml-155 {
  margin-left: 155px !important; }

.pb-155 {
  padding-bottom: 155px !important; }

.pt-155 {
  padding-top: 155px !important; }

.pr-155 {
  padding-right: 155px !important; }

.pl-155 {
  padding-left: 155px !important; }

.mb-160 {
  margin-bottom: 160px !important; }

.mt-160 {
  margin-top: 160px !important; }

.mr-160 {
  margin-right: 160px !important; }

.ml-160 {
  margin-left: 160px !important; }

.pb-160 {
  padding-bottom: 160px !important; }

.pt-160 {
  padding-top: 160px !important; }

.pr-160 {
  padding-right: 160px !important; }

.pl-160 {
  padding-left: 160px !important; }

.mb-165 {
  margin-bottom: 165px !important; }

.mt-165 {
  margin-top: 165px !important; }

.mr-165 {
  margin-right: 165px !important; }

.ml-165 {
  margin-left: 165px !important; }

.pb-165 {
  padding-bottom: 165px !important; }

.pt-165 {
  padding-top: 165px !important; }

.pr-165 {
  padding-right: 165px !important; }

.pl-165 {
  padding-left: 165px !important; }

.mb-170 {
  margin-bottom: 170px !important; }

.mt-170 {
  margin-top: 170px !important; }

.mr-170 {
  margin-right: 170px !important; }

.ml-170 {
  margin-left: 170px !important; }

.pb-170 {
  padding-bottom: 170px !important; }

.pt-170 {
  padding-top: 170px !important; }

.pr-170 {
  padding-right: 170px !important; }

.pl-170 {
  padding-left: 170px !important; }

.mb-175 {
  margin-bottom: 175px !important; }

.mt-175 {
  margin-top: 175px !important; }

.mr-175 {
  margin-right: 175px !important; }

.ml-175 {
  margin-left: 175px !important; }

.pb-175 {
  padding-bottom: 175px !important; }

.pt-175 {
  padding-top: 175px !important; }

.pr-175 {
  padding-right: 175px !important; }

.pl-175 {
  padding-left: 175px !important; }

.mb-180 {
  margin-bottom: 180px !important; }

.mt-180 {
  margin-top: 180px !important; }

.mr-180 {
  margin-right: 180px !important; }

.ml-180 {
  margin-left: 180px !important; }

.pb-180 {
  padding-bottom: 180px !important; }

.pt-180 {
  padding-top: 180px !important; }

.pr-180 {
  padding-right: 180px !important; }

.pl-180 {
  padding-left: 180px !important; }

.mb-185 {
  margin-bottom: 185px !important; }

.mt-185 {
  margin-top: 185px !important; }

.mr-185 {
  margin-right: 185px !important; }

.ml-185 {
  margin-left: 185px !important; }

.pb-185 {
  padding-bottom: 185px !important; }

.pt-185 {
  padding-top: 185px !important; }

.pr-185 {
  padding-right: 185px !important; }

.pl-185 {
  padding-left: 185px !important; }

.mb-190 {
  margin-bottom: 190px !important; }

.mt-190 {
  margin-top: 190px !important; }

.mr-190 {
  margin-right: 190px !important; }

.ml-190 {
  margin-left: 190px !important; }

.pb-190 {
  padding-bottom: 190px !important; }

.pt-190 {
  padding-top: 190px !important; }

.pr-190 {
  padding-right: 190px !important; }

.pl-190 {
  padding-left: 190px !important; }

.mb-195 {
  margin-bottom: 195px !important; }

.mt-195 {
  margin-top: 195px !important; }

.mr-195 {
  margin-right: 195px !important; }

.ml-195 {
  margin-left: 195px !important; }

.pb-195 {
  padding-bottom: 195px !important; }

.pt-195 {
  padding-top: 195px !important; }

.pr-195 {
  padding-right: 195px !important; }

.pl-195 {
  padding-left: 195px !important; }

.mb-200 {
  margin-bottom: 200px !important; }

.mt-200 {
  margin-top: 200px !important; }

.mr-200 {
  margin-right: 200px !important; }

.ml-200 {
  margin-left: 200px !important; }

.pb-200 {
  padding-bottom: 200px !important; }

.pt-200 {
  padding-top: 200px !important; }

.pr-200 {
  padding-right: 200px !important; }

.pl-200 {
  padding-left: 200px !important; }

.mb-205 {
  margin-bottom: 205px !important; }

.mt-205 {
  margin-top: 205px !important; }

.mr-205 {
  margin-right: 205px !important; }

.ml-205 {
  margin-left: 205px !important; }

.pb-205 {
  padding-bottom: 205px !important; }

.pt-205 {
  padding-top: 205px !important; }

.pr-205 {
  padding-right: 205px !important; }

.pl-205 {
  padding-left: 205px !important; }

.mb-210 {
  margin-bottom: 210px !important; }

.mt-210 {
  margin-top: 210px !important; }

.mr-210 {
  margin-right: 210px !important; }

.ml-210 {
  margin-left: 210px !important; }

.pb-210 {
  padding-bottom: 210px !important; }

.pt-210 {
  padding-top: 210px !important; }

.pr-210 {
  padding-right: 210px !important; }

.pl-210 {
  padding-left: 210px !important; }

.mb-215 {
  margin-bottom: 215px !important; }

.mt-215 {
  margin-top: 215px !important; }

.mr-215 {
  margin-right: 215px !important; }

.ml-215 {
  margin-left: 215px !important; }

.pb-215 {
  padding-bottom: 215px !important; }

.pt-215 {
  padding-top: 215px !important; }

.pr-215 {
  padding-right: 215px !important; }

.pl-215 {
  padding-left: 215px !important; }

.mb-220 {
  margin-bottom: 220px !important; }

.mt-220 {
  margin-top: 220px !important; }

.mr-220 {
  margin-right: 220px !important; }

.ml-220 {
  margin-left: 220px !important; }

.pb-220 {
  padding-bottom: 220px !important; }

.pt-220 {
  padding-top: 220px !important; }

.pr-220 {
  padding-right: 220px !important; }

.pl-220 {
  padding-left: 220px !important; }

.mb-225 {
  margin-bottom: 225px !important; }

.mt-225 {
  margin-top: 225px !important; }

.mr-225 {
  margin-right: 225px !important; }

.ml-225 {
  margin-left: 225px !important; }

.pb-225 {
  padding-bottom: 225px !important; }

.pt-225 {
  padding-top: 225px !important; }

.pr-225 {
  padding-right: 225px !important; }

.pl-225 {
  padding-left: 225px !important; }

.mb-230 {
  margin-bottom: 230px !important; }

.mt-230 {
  margin-top: 230px !important; }

.mr-230 {
  margin-right: 230px !important; }

.ml-230 {
  margin-left: 230px !important; }

.pb-230 {
  padding-bottom: 230px !important; }

.pt-230 {
  padding-top: 230px !important; }

.pr-230 {
  padding-right: 230px !important; }

.pl-230 {
  padding-left: 230px !important; }

.mb-235 {
  margin-bottom: 235px !important; }

.mt-235 {
  margin-top: 235px !important; }

.mr-235 {
  margin-right: 235px !important; }

.ml-235 {
  margin-left: 235px !important; }

.pb-235 {
  padding-bottom: 235px !important; }

.pt-235 {
  padding-top: 235px !important; }

.pr-235 {
  padding-right: 235px !important; }

.pl-235 {
  padding-left: 235px !important; }

.mb-240 {
  margin-bottom: 240px !important; }

.mt-240 {
  margin-top: 240px !important; }

.mr-240 {
  margin-right: 240px !important; }

.ml-240 {
  margin-left: 240px !important; }

.pb-240 {
  padding-bottom: 240px !important; }

.pt-240 {
  padding-top: 240px !important; }

.pr-240 {
  padding-right: 240px !important; }

.pl-240 {
  padding-left: 240px !important; }

.mb-245 {
  margin-bottom: 245px !important; }

.mt-245 {
  margin-top: 245px !important; }

.mr-245 {
  margin-right: 245px !important; }

.ml-245 {
  margin-left: 245px !important; }

.pb-245 {
  padding-bottom: 245px !important; }

.pt-245 {
  padding-top: 245px !important; }

.pr-245 {
  padding-right: 245px !important; }

.pl-245 {
  padding-left: 245px !important; }

.mb-250 {
  margin-bottom: 250px !important; }

.mt-250 {
  margin-top: 250px !important; }

.mr-250 {
  margin-right: 250px !important; }

.ml-250 {
  margin-left: 250px !important; }

.pb-250 {
  padding-bottom: 250px !important; }

.pt-250 {
  padding-top: 250px !important; }

.pr-250 {
  padding-right: 250px !important; }

.pl-250 {
  padding-left: 250px !important; }

.mb-255 {
  margin-bottom: 255px !important; }

.mt-255 {
  margin-top: 255px !important; }

.mr-255 {
  margin-right: 255px !important; }

.ml-255 {
  margin-left: 255px !important; }

.pb-255 {
  padding-bottom: 255px !important; }

.pt-255 {
  padding-top: 255px !important; }

.pr-255 {
  padding-right: 255px !important; }

.pl-255 {
  padding-left: 255px !important; }

.mb-260 {
  margin-bottom: 260px !important; }

.mt-260 {
  margin-top: 260px !important; }

.mr-260 {
  margin-right: 260px !important; }

.ml-260 {
  margin-left: 260px !important; }

.pb-260 {
  padding-bottom: 260px !important; }

.pt-260 {
  padding-top: 260px !important; }

.pr-260 {
  padding-right: 260px !important; }

.pl-260 {
  padding-left: 260px !important; }

.mb-265 {
  margin-bottom: 265px !important; }

.mt-265 {
  margin-top: 265px !important; }

.mr-265 {
  margin-right: 265px !important; }

.ml-265 {
  margin-left: 265px !important; }

.pb-265 {
  padding-bottom: 265px !important; }

.pt-265 {
  padding-top: 265px !important; }

.pr-265 {
  padding-right: 265px !important; }

.pl-265 {
  padding-left: 265px !important; }

.mb-270 {
  margin-bottom: 270px !important; }

.mt-270 {
  margin-top: 270px !important; }

.mr-270 {
  margin-right: 270px !important; }

.ml-270 {
  margin-left: 270px !important; }

.pb-270 {
  padding-bottom: 270px !important; }

.pt-270 {
  padding-top: 270px !important; }

.pr-270 {
  padding-right: 270px !important; }

.pl-270 {
  padding-left: 270px !important; }

.mb-275 {
  margin-bottom: 275px !important; }

.mt-275 {
  margin-top: 275px !important; }

.mr-275 {
  margin-right: 275px !important; }

.ml-275 {
  margin-left: 275px !important; }

.pb-275 {
  padding-bottom: 275px !important; }

.pt-275 {
  padding-top: 275px !important; }

.pr-275 {
  padding-right: 275px !important; }

.pl-275 {
  padding-left: 275px !important; }

.mb-280 {
  margin-bottom: 280px !important; }

.mt-280 {
  margin-top: 280px !important; }

.mr-280 {
  margin-right: 280px !important; }

.ml-280 {
  margin-left: 280px !important; }

.pb-280 {
  padding-bottom: 280px !important; }

.pt-280 {
  padding-top: 280px !important; }

.pr-280 {
  padding-right: 280px !important; }

.pl-280 {
  padding-left: 280px !important; }

.mb-285 {
  margin-bottom: 285px !important; }

.mt-285 {
  margin-top: 285px !important; }

.mr-285 {
  margin-right: 285px !important; }

.ml-285 {
  margin-left: 285px !important; }

.pb-285 {
  padding-bottom: 285px !important; }

.pt-285 {
  padding-top: 285px !important; }

.pr-285 {
  padding-right: 285px !important; }

.pl-285 {
  padding-left: 285px !important; }

.mb-290 {
  margin-bottom: 290px !important; }

.mt-290 {
  margin-top: 290px !important; }

.mr-290 {
  margin-right: 290px !important; }

.ml-290 {
  margin-left: 290px !important; }

.pb-290 {
  padding-bottom: 290px !important; }

.pt-290 {
  padding-top: 290px !important; }

.pr-290 {
  padding-right: 290px !important; }

.pl-290 {
  padding-left: 290px !important; }

.mb-295 {
  margin-bottom: 295px !important; }

.mt-295 {
  margin-top: 295px !important; }

.mr-295 {
  margin-right: 295px !important; }

.ml-295 {
  margin-left: 295px !important; }

.pb-295 {
  padding-bottom: 295px !important; }

.pt-295 {
  padding-top: 295px !important; }

.pr-295 {
  padding-right: 295px !important; }

.pl-295 {
  padding-left: 295px !important; }

/* -------------------
  Date, time, phone
--------------------*/
@media screen and (max-width: 767px) {
  .table2 {
    overflow-x: auto; } }

.table2 table {
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%; }

.table2 th {
  background-color: #F2F5F7;
  border: 1px solid #E6EEF2;
  box-sizing: border-box;
  font-weight: 700;
  padding: 20px 15px;
  width: 185px; }

.table2 td {
  border: 1px solid #E6EEF2;
  box-sizing: border-box;
  padding: 20px 15px; }

@media screen and (max-width: 767px) {
  .table2.type2 table {
    width: 220vw; } }

.table {
  font-size: 0.75rem;
  color: #474F5F; }
  .tableWrap2 {
    max-height: 400px;
    overflow-y: auto; }
    @media screen and (max-width: 767px) {
      .tableWrap2 {
        max-height: 200px; } }
  @media screen and (max-width: 767px) {
    .tableWrap {
      width: 220vw;
      overflow: auto; } }
  .table thead {
    background-color: #F4F4F4;
    font-weight: bold; }
    .table thead th {
      text-align: center; }
  .table tbody tr {
    border-bottom: solid 1px #EBEBEB; }
  .table th.t_date {
    width: 130px; }
    @media screen and (max-width: 767px) {
      .table th.t_date {
        width: 155px; } }
  @media screen and (max-width: 767px) {
    .table th.t_name {
      width: 130px; } }
  .table th.t_review {
    width: 95px; }
    @media screen and (max-width: 767px) {
      .table th.t_review {
        width: 100px; } }
  .table th.t_points {
    width: 80px; }
  .table th.t_detail {
    width: 60px; }
  .table th.t_cbox {
    width: 45px;
    padding-right: 0; }
    @media screen and (max-width: 767px) {
      .table th.t_cbox {
        width: 35px; } }
  .table th.t_think {
    width: 180px;
    padding-right: 0; }
    @media screen and (max-width: 767px) {
      .table th.t_think {
        width: auto; } }
  .table td {
    vertical-align: middle; }
    .table td.t_cbox {
      padding-right: 0; }

.table > :not(caption) > * > * {
  padding: 10px 15px; }
  @media screen and (max-width: 767px) {
    .table > :not(caption) > * > * {
      padding: 10px; } }

.align-center {
  text-align: center; }

.align-left {
  text-align: left !important; }

.align-right {
  text-align: right; }

.align-top {
  align-items: flex-start !important; }

.cc {
  display: flex;
  justify-content: center;
  align-items: center; }

.d_flex {
  display: flex; }
  .d_flex.between {
    justify-content: space-between; }
  .d_flex.center {
    justify-content: center; }
  @media screen and (max-width: 767px) {
    .d_flex {
      display: block; } }

.d_flex2 {
  display: flex;
  align-items: center; }

.d_flex3 {
  display: flex;
  justify-content: center; }

.col2-75 {
  display: flex;
  justify-content: space-between; }
  @media screen and (max-width: 767px) {
    .col2-75 {
      display: block; } }
  @media screen and (max-width: 767px) {
    .col2-75--left {
      width: 100%;
      margin-bottom: 20px; } }
  .col2-75--right {
    width: 25%;
    margin-left: 20px;
    flex-shrink: 0; }
    @media screen and (max-width: 767px) {
      .col2-75--right {
        width: 100%;
        margin-left: 0; } }

.col2-25 {
  display: flex;
  justify-content: space-between; }
  @media screen and (max-width: 767px) {
    .col2-25 {
      display: block; } }
  .col2-25--left {
    width: 25%;
    margin-right: 20px;
    flex-shrink: 0; }
    @media screen and (max-width: 767px) {
      .col2-25--left {
        width: 100%;
        margin-right: 0;
        margin-bottom: 20px; } }
  @media screen and (max-width: 767px) {
    .col2-25--right {
      width: 100%;
      margin-bottom: 20px; } }

.col2 {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -10px; }
  @media screen and (max-width: 767px) {
    .col2 {
      display: block;
      margin: 0; } }
  .col2-item {
    width: 50%;
    padding: 0 10px;
    margin-bottom: 20px; }
    @media screen and (max-width: 767px) {
      .col2-item {
        width: 100%;
        padding: 0; } }
    .col2-item--inner {
      display: block; }

.col3 {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -10px; }
  @media screen and (max-width: 767px) {
    .col3 {
      display: block;
      margin: 0; } }
  .col3-item {
    width: 33.33%;
    padding: 0 10px;
    margin-bottom: 20px; }
    @media screen and (max-width: 767px) {
      .col3-item {
        width: 100%;
        padding: 0; } }
    .col3-item--inner {
      display: block; }

.col4 {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -10px; }
  @media screen and (max-width: 767px) {
    .col4 {
      display: block;
      margin: 0; } }
  .col4-item {
    width: 25%;
    padding: 0 10px;
    margin-bottom: 20px; }
    @media screen and (max-width: 767px) {
      .col4-item {
        width: 100%;
        padding: 0; } }
    .col4-item--inner {
      display: block; }

.col5 {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -10px; }
  @media screen and (max-width: 767px) {
    .col5 {
      display: block;
      margin: 0; } }
  .col5-item {
    width: 20%;
    padding: 0 10px;
    margin-bottom: 20px; }
    @media screen and (max-width: 767px) {
      .col5-item {
        width: 100%;
        padding: 0; } }
    .col5-item--inner {
      display: block; }

.pagination {
  line-height: 1;
  margin: 50px 0 90px; }
  @media screen and (max-width: 767px) {
    .pagination {
      margin: 40px 0 70px; } }
  .pagination-inner {
    display: flex;
    justify-content: center;
    align-items: center; }
  .pagination .prev-area,
  .pagination .number-area,
  .pagination .next-area {
    display: flex;
    align-items: center; }
  .pagination .prev-area,
  .pagination .next-area {
    letter-spacing: -0.2em; }
    .pagination .prev-area li a span,
    .pagination .next-area li a span {
      transform: scale(0.6, 1); }
  .pagination li {
    margin: 0 5px;
    list-style: none; }
    .pagination li a {
      display: block;
      background: #0071bc;
      color: #fff;
      width: 50px;
      height: 50px;
      display: flex;
      justify-content: center;
      align-items: center;
      border-radius: 10px;
      border: 1px solid #0071bc; }
      .pagination li a:hover {
        color: #0071bc;
        background: #fff; }
  .pagination .number-area li.current {
    color: #0071bc;
    background: #fff;
    width: 50px;
    height: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 10px;
    border: 1px solid #0071bc; }

/* -------------------
	BREADCRUMB
--------------------*/
.breadcrumb {
  margin-top: 22px;
  padding: 0 30px; }
  @media screen and (max-width: 1050px) {
    .breadcrumb {
      white-space: nowrap;
      overflow-x: auto;
      margin-top: 5px;
      margin-bottom: 12px; } }
  @media screen and (max-width: 1050px) {
    .breadcrumb {
      padding: 0 8px; } }
  .breadcrumb-wrapper {
    padding-top: 15px; }
    @media screen and (max-width: 1050px) {
      .breadcrumb-wrapper {
        padding: 0 0 5px 0; } }
  .breadcrumb ul li {
    display: inline-block;
    font-size: 0.75rem;
    position: relative;
    padding-right: 20px;
    color: #000; }
    .breadcrumb ul li a {
      display: inline-block;
      color: #68A0FA;
      transition: all .3s; }
      .breadcrumb ul li a:hover {
        opacity: .8; }
    .breadcrumb ul li:last-child {
      padding-right: 0; }
      .breadcrumb ul li:last-child:before {
        display: none; }
    .breadcrumb ul li:before {
      display: inline-block;
      position: absolute;
      top: 7px;
      right: 4px;
      width: 4px;
      height: 5px;
      background: url(../images/common/icon-breadcrumb.svg) center center/100% 100% no-repeat;
      content: ""; }
    @media screen and (max-width: 1050px) {
      .breadcrumb ul li {
        margin-bottom: 8px; } }
    .breadcrumb ul li a {
      transition: all .3s; }
      .breadcrumb ul li a:hover {
        opacity: .7; }

/* -------------------
  THUMBNAIL, IMAGE
--------------------*/
.thumb-ttl {
  margin-top: 10px; }

/* -------------------
  PAGE TOP
--------------------*/
.page-top {
  position: fixed;
  bottom: 0;
  right: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 80px;
  height: 80px;
  cursor: pointer;
  opacity: 0;
  background-color: #7b7b6c;
  transition: all 0.3s;
  z-index: -1; }
  .page-top.active {
    opacity: 1;
    z-index: 8999; }
    .page-top.active:hover {
      opacity: .6; }
  .page-top span {
    display: block;
    height: 6px;
    width: 12px;
    background: url(../images/common/pageTop.png) no-repeat;
    background-size: 100%;
    text-indent: 180%;
    white-space: nowrap;
    overflow: hidden; }

/* -------------------
  ACCORDION
--------------------*/
.accordion-label {
  background: #F2F5F7;
  border-bottom: 1px solid #fff;
  box-sizing: border-box;
  cursor: pointer;
  display: flex;
  font-weight: 700;
  height: 65px;
  align-items: center;
  padding: 25px 70px 25px 20px;
  position: relative;
  transition: all 0.6s; }
  .accordion-label:after {
    position: absolute;
    right: 20px;
    top: 50%;
    display: inline-block;
    border: solid #939393;
    border-width: 0 0 2px 2px;
    display: inline-block;
    padding: 2px;
    transform: translateY(-50%) rotate(-45deg);
    -webkit-transform: translateY(-50%) rotate(-45deg);
    transition: all .25s;
    content: ""; }
  .accordion-label.active:after {
    transform: translateY(-50%) rotate(135deg);
    -webkit-transform: translateY(-50%) rotate(135deg); }

.accordion-cnt {
  display: none;
  padding: 25px 70px 25px 20px; }

/* -------------------
  TABS
--------------------*/
@media screen and (max-width: 1050px) {
  .tabs-navWrapper {
    white-space: nowrap;
    overflow-x: auto; } }

.tabs-nav {
  display: flex;
  width: 100%; }

.tabs-item {
  width: 220px;
  max-width: 100%;
  font-size: 1.125rem;
  color: #818181;
  background-color: #EBEBEB;
  margin-right: 8px;
  padding: 17px 15px;
  cursor: pointer;
  text-align: center;
  transition: all .3s; }
  @media screen and (max-width: 767px) {
    .tabs-item {
      display: flex;
      align-items: center;
      justify-content: center;
      width: 33.33%;
      margin-right: 0;
      font-size: 0.875rem; } }
  .tabs-item:last-child {
    margin-right: 0; }
  .tabs-item.active, .tabs-item:hover {
    color: #5DC1CF;
    background-color: #fff; }
  @media screen and (max-width: 767px) {
    .tabs-item.type2 {
      width: 50%; } }
  .tabs-item.type3 {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 126px;
    max-width: 20%;
    font-size: 0.875rem;
    font-weight: bold;
    padding: 17px 3px;
    margin-right: 0; }
    @media screen and (max-width: 767px) {
      .tabs-item.type3 {
        max-width: 100%;
        width: 100%;
        font-size: 0.75rem; } }

.tabs-cnt {
  background-color: #fff;
  padding: 30px 20px 0; }
  .tabs-cnt.type2 {
    padding-bottom: 40px; }
  .tabs-cnt.type3 {
    padding-left: 0;
    padding-right: 0; }
  @media screen and (max-width: 767px) {
    .tabs-cnt.type4 {
      padding-left: 0;
      padding-right: 0; } }

@media screen and (max-width: 1050px) {
  .tabs2-navWrapper {
    white-space: nowrap;
    overflow-x: auto; } }

.tabs2-nav {
  margin: 0 auto;
  padding: 0 2vw; }

.tabs2-item {
  padding: 20px 15px;
  color: #474F5F;
  font-size: 1.5rem;
  font-weight: bold;
  background: none;
  cursor: pointer;
  text-align: center;
  transition: all .3s; }
  @media screen and (max-width: 1050px) {
    .tabs2-item {
      font-size: 1.25rem; } }
  .tabs2-item span {
    padding-top: 42px;
    background: url(../images/common/icon-fac-black.svg) top center no-repeat; }
  @media screen and (min-width: 1051px) {
    .tabs2-item {
      cursor: auto; } }

.tabs2-title {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 170px;
  background: url(../images/top/bg-tabItem-blue.svg) no-repeat;
  background-size: 100% 100%;
  margin: 0 0 7px; }
  .tabs2-title-type2 {
    background-image: url(../images/top/bg-tabItem-pink.svg); }
    .tabs2-title-type2 span {
      background: url(../images/common/icon-doc-black.svg) top center no-repeat; }
  @media screen and (max-width: 1050px) {
    .tabs2-title {
      height: 39vw; } }

.tabs2-cnt {
  display: flex;
  background-color: #fff;
  margin: 7px 0 0; }

.tabs2-panel {
  width: 50%;
  padding: 0 15px; }

.tabs2-menu .thumb {
  position: relative;
  background: url(../images/top/bg-card-blue.png);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  background-position: center center;
  height: 139px;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 0 20px; }
  @media screen and (max-width: 767px) {
    .tabs2-menu .thumb {
      height: 29vw; } }
  .tabs2-menu .thumb figcaption {
    font-size: 0.9375rem;
    font-weight: 700;
    position: absolute;
    bottom: 15px;
    display: block;
    text-align: center;
    width: 100%; }
    @media screen and (max-width: 1050px) {
      .tabs2-menu .thumb figcaption {
        font-size: 0.8125rem;
        bottom: 12px; } }
  @media screen and (max-width: 1050px) {
    .tabs2-menu .thumb img {
      max-width: 65%;
      max-height: 65%; } }

.tabs2-menu-type2 .thumb {
  background-image: url(../images/top/bg-card-green.png); }

@media screen and (max-width: 1050px) {
  .tabs2-menu {
    display: flex;
    flex-flow: row wrap; } }

.tabs2-menu li {
  width: 32%;
  margin: 0 calc(4% / 2) 10px 0; }
  .tabs2-menu li:nth-of-type(3n) {
    margin: 0 0 10px 0; }

.modal-complete {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  width: 180px;
  height: 180px;
  padding: 0;
  margin: 0;
  color: #FFFFFF;
  background: #191B1D;
  opacity: .8;
  border-radius: 3px;
  z-index: 8000; }
  .modal-complete--cnt {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    height: 100%; }
    .modal-complete--cnt-icon {
      text-align: center; }
      .modal-complete--cnt-icon img {
        width: 46px; }
    .modal-complete--cnt-msg {
      margin-top: 20px;
      font-size: 0.875rem;
      line-height: 1.25rem;
      text-align: center; }

.btn-close {
  background: #818181 url(../images/common/icon-x.svg) center center no-repeat;
  opacity: 1;
  border-radius: 50%; }

.modal-dialog.type2 {
  max-width: 600px; }

.modal-confirm {
  width: 335px;
  max-width: 100%;
  padding: 5px 20px 25px;
  margin: 0 auto;
  text-align: center; }
  @media screen and (max-width: 767px) {
    .modal-confirm {
      padding-bottom: 35px; } }
  .modal-confirm .modal-header {
    margin-bottom: 30px;
    border-bottom: none;
    padding-right: 0; }
  .modal-confirm .btn-white {
    margin-bottom: 10px; }
    @media screen and (max-width: 767px) {
      .modal-confirm .btn-white {
        margin-bottom: 20px; } }
  .modal-confirm .btn-blue {
    margin-bottom: 15px; }
    @media screen and (max-width: 767px) {
      .modal-confirm .btn-blue {
        margin-bottom: 25px; } }
  .modal-confirm .btn-white,
  .modal-confirm .btn-blue {
    display: block;
    width: 100%;
    height: 52px;
    line-height: 52px;
    padding: 0; }
  .modal-confirm--ttl {
    color: #474F5F;
    font-weight: bold;
    margin-bottom: 15px; }
  .modal-confirm--msg {
    margin-bottom: 30px;
    font-size: 0.875rem; }
  .modal-confirm--close {
    color: #68A0FA;
    font-size: 0.75rem;
    cursor: pointer; }

.modal-backdrop.show {
  opacity: .8; }

.modal-colection {
  width: 600px;
  max-width: 95%;
  margin: 0 auto;
  text-align: center; }
  @media screen and (max-width: 767px) {
    .modal-colection {
      padding-bottom: 35px; } }
  .modal-colection .btn-close {
    margin-right: 0;
    padding: 0;
    background: url(../images/common/icon-x.svg) center center no-repeat; }
  .modal-colection .modal-header {
    padding: 15px 20px;
    margin-bottom: 30px;
    border-bottom: none;
    background-color: #5DC1CF; }
    .modal-colection .modal-header--ttl {
      font-size: 1rem;
      line-height: 1;
      font-weight: bold;
      color: #fff; }
  .modal-colection--close {
    color: #68A0FA;
    font-size: 0.75rem;
    cursor: pointer; }
  .modal-colection--list {
    padding: 10px 30px 20px; }
    .modal-colection--list-row {
      display: flex;
      flex-wrap: wrap;
      margin: 0 -10px; }
      .modal-colection--list-row-item {
        width: 33.33%;
        padding: 10px; }
        @media screen and (max-width: 767px) {
          .modal-colection--list-row-item {
            width: 100%; } }
        .modal-colection--list-row-item a {
          position: relative;
          display: flex;
          justify-content: center;
          align-items: center;
          width: 100%;
          height: 60px;
          padding-bottom: 20px;
          font-size: 1rem;
          font-family: spring-lp, sans-serif;
          color: #474F5F;
          border: solid 1px #5DC1CF;
          background-color: #F4F4F4;
          border-radius: 2px;
          transition: all .25s; }
          @media screen and (max-width: 767px) {
            .modal-colection--list-row-item a {
              padding: 0 15px 0 45px; } }
          .modal-colection--list-row-item a:hover {
            opacity: .7; }
          .modal-colection--list-row-item a:after {
            position: absolute;
            bottom: 10px;
            left: 50%;
            transform: translateX(-50%);
            display: block;
            width: 14px;
            height: 14px;
            border-radius: 50%;
            border: solid 1px #5DC1CF;
            content: ""; }
            @media screen and (max-width: 767px) {
              .modal-colection--list-row-item a:after {
                left: 25px;
                top: 50%;
                transform: translate(0, -50%); } }
        .modal-colection--list-row-item.disable a {
          color: #C7C7C7;
          border-color: #EBEBEB;
          background-color: #EBEBEB; }
          .modal-colection--list-row-item.disable a:after {
            width: 6px;
            height: 2px;
            bottom: 16px;
            background-color: #C7C7C7;
            border: none; }
        .modal-colection--list-row-item.cancel a {
          color: #C7C7C7;
          border-color: #EBEBEB;
          background-color: #F4F4F4; }
          .modal-colection--list-row-item.cancel a:after {
            width: auto;
            height: auto;
            bottom: 5px;
            font-size: 1.25rem;
            background: none;
            border: none;
            color: #5DC1CF;
            font-weight: normal;
            content: "×"; }

.modal-find {
  max-width: 1000px; }
  .modal-find .modal-header {
    border-bottom: none; }
  .modal-find .checkboxWrap label {
    width: 100%;
    padding-left: 28px;
    color: #818181;
    font-size: 0.875rem; }
  .modal-find .checkboxWrap-outer {
    position: relative;
    display: block;
    text-align: left;
    padding-right: 28px;
    padding: 15px 28px 15px 15px;
    margin-right: 0;
    width: 100%;
    background-color: #fff; }
    .modal-find .checkboxWrap-outer:hover {
      background-color: #EFFDF9; }
      .modal-find .checkboxWrap-outer:hover .checkboxWrap label {
        color: #5DC1CF; }
    .modal-find .checkboxWrap-outer:after {
      position: absolute;
      top: 50%;
      right: 22px;
      transform: translateY(-50%);
      display: block;
      width: 5px;
      height: 10px;
      background: url(../images/common/icon-arrow-right-blue.svg) no-repeat;
      background-size: contain;
      content: ""; }
  .modal-find .tabs {
    display: flex;
    padding: 0 40px 40px; }
    .modal-find .tabs-navWrapper {
      display: flex;
      flex-wrap: wrap;
      width: 30%;
      min-width: 200px;
      flex-shrink: 0;
      border-right: solid 1px #EBEBEB; }
    .modal-find .tabs-nav {
      display: flex;
      flex-wrap: wrap;
      flex-flow: column; }
    .modal-find .tabs-cnt {
      padding: 0;
      width: 100%; }
      .modal-find .tabs-cnt--list {
        display: flex;
        flex-wrap: wrap;
        height: 550px;
        overflow-y: auto; }
      .modal-find .tabs-cnt--item {
        width: 50%;
        background-color: #FAFAFA; }
        .modal-find .tabs-cnt--item:nth-child(2n + 1) {
          border-right: solid 1px #EBEBEB; }
  .modal-find--foot {
    text-align: center;
    padding-bottom: 30px; }
    .modal-find--foot-direct {
      margin-bottom: 10px; }

@media screen and (max-width: 767px) {
  .modal-form .container6 {
    padding: 0 20px; } }

.modal-form .form-search {
  margin-bottom: 10px; }
  .modal-form .form-search .input.hasBtn {
    font-size: 0.875rem; }

.modal-form .form-search02--inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 20px 0 30px; }
  @media screen and (max-width: 767px) {
    .modal-form .form-search02--inner {
      display: block; } }

@media screen and (max-width: 767px) {
  .modal-form .form-search02--label {
    text-align: left;
    margin-bottom: 8px; } }

.modal-form .form-search02--cnt .form-input {
  display: flex;
  align-items: center; }
  .modal-form .form-search02--cnt .form-input .input._date {
    width: 170px;
    margin-left: 30px; }

/* -------------------
  SLICK SLIDER
--------------------*/
body .slick-prev,
body .slick-next {
  width: 20px;
  height: 35px;
  top: auto;
  bottom: -26px; }
  @media screen and (max-width: 767px) {
    body .slick-prev,
    body .slick-next {
      width: 33px;
      height: 33px; } }

body .slick-prev {
  left: calc(50% - 130px); }
  @media screen and (max-width: 767px) {
    body .slick-prev {
      left: 7px; } }
  body .slick-prev:before {
    content: "";
    display: block;
    opacity: 1;
    width: 100%;
    height: 100%;
    background: url(../images/slick/arrow-left.svg) no-repeat center center;
    background-size: cover; }

body .slick-next {
  right: calc(50% - 130px); }
  @media screen and (max-width: 767px) {
    body .slick-next {
      right: 7px; } }
  body .slick-next:before {
    content: "";
    display: block;
    opacity: 1;
    width: 100%;
    height: 100%;
    background: url(../images/slick/arrow-right.svg) no-repeat center center;
    background-size: cover; }

body .slick-dots {
  bottom: 0px;
  left: 50%;
  transform: translate(-50%, 0); }
  @media screen and (max-width: 767px) {
    body .slick-dots {
      bottom: 20px; } }
  body .slick-dots li {
    bottom: 0 !important;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    margin: 0 5px;
    padding: 0;
    opacity: 1;
    cursor: pointer; }
    body .slick-dots li button {
      font-size: 0;
      line-height: 0;
      display: block;
      width: 10px;
      height: 10px;
      border-radius: 50%;
      padding: 0;
      cursor: pointer;
      color: transparent;
      border: 0;
      outline: none;
      background: transparent; }
      body .slick-dots li button:before {
        line-height: 20px;
        position: absolute;
        top: 0;
        left: 0;
        transform: translate(0, 0);
        width: 10px;
        height: 10px;
        border-radius: 50%;
        content: "" !important;
        display: block;
        background-color: #cccccc;
        text-align: center;
        opacity: 1;
        color: black;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale; }
    body .slick-dots li.slick-active button:before {
      background-color: #a01e28;
      width: 10px;
      height: 10px; }

.l-header {
  width: 100%;
  position: sticky;
  top: 0;
  background-color: #fff;
  z-index: 100;
  height: 63px; }
  @media screen and (max-width: 767px) {
    .l-header {
      height: 60px; } }
  .l-header-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 97%;
    margin: 0 auto;
    padding: 14px 0; }
    @media screen and (max-width: 767px) {
      .l-header-inner {
        padding: 0;
        width: 100%; } }
  .l-header__logo {
    max-width: 450px;
    width: 35%; }
    @media screen and (max-width: 767px) {
      .l-header__logo {
        width: auto;
        padding-left: 10px; }
        .l-header__logo img {
          width: 76.25vw; } }

.gnav {
  font-size: 14px;
  font-weight: bold;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 30px; }
  @media screen and (max-width: 767px) {
    .gnav {
      flex-direction: column; } }
  .gnav__list {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 0;
    gap: 25px; }
    @media screen and (max-width: 767px) {
      .gnav__list {
        flex-direction: column; } }
  .gnav__item > a:hover {
    color: #a01e28;
    opacity: 1; }
  .gnav__btn a {
    display: inline-block;
    width: 160px;
    background-color: #a01e28;
    color: #fff;
    border-radius: 21px;
    padding: 5px 0;
    letter-spacing: 0.3em; }

.header-badge {
  position: fixed;
  left: 40px;
  top: 56px;
  width: 218px;
  z-index: 3; }
  @media screen and (max-width: 767px) {
    .header-badge {
      width: 110px;
      left: 10px;
      top: 56px; } }
  .header-badge a {
    display: block; }

@media screen and (max-width: 767px) {
  #hamburger {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 60px;
    height: 60px;
    background: #a01e28;
    cursor: pointer;
    transition: 1s; }
    #hamburger .inner {
      position: relative;
      width: 20px;
      height: 18px; }
      #hamburger .inner .inner_line {
        display: block;
        position: absolute;
        left: 0;
        width: 100%;
        height: 1px;
        transition: 0.4s;
        background: #fff; }
        #hamburger .inner .inner_line#line1 {
          top: 0; }
          #hamburger .inner .inner_line#line1.active {
            transform: translateY(8px) rotate(-45deg); }
        #hamburger .inner .inner_line#line2 {
          top: 50%;
          transform: translate(0, -50%); }
          #hamburger .inner .inner_line#line2.active {
            background: none; }
        #hamburger .inner .inner_line#line3 {
          bottom: 0; }
          #hamburger .inner .inner_line#line3.active {
            transform: translateY(-9px) rotate(45deg); }
    #hamburger .label {
      font-size: 10px;
      text-align: center; }
  #hamburger-menu {
    position: fixed;
    background-size: cover;
    width: 100%;
    height: calc(100vh - 60px);
    top: 60px;
    left: 0;
    background-size: cover;
    transition: 0.7s;
    z-index: 4;
    background: #f1f1f1;
    opacity: 0;
    display: none; }
    #hamburger-menu.active {
      display: block;
      opacity: 1;
      animation: fadeIn 0.3s ease-in 0s forwards; }
    #hamburger-menu .hamburger-menu-inner {
      overflow: auto;
      height: 100vh;
      display: block;
      padding: 80px 30px 40px; } }
    @media screen and (max-width: 767px) and (max-width: 767px) {
      #hamburger-menu .hamburger-menu-inner {
        padding: 60px 30px 80px; } }

@keyframes fadeIn {
  0% {
    display: none;
    opacity: 0; }
  1% {
    display: block;
    opacity: 0; }
  100% {
    display: block;
    opacity: 1; } }

.foot-contact {
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  padding: 40px 40px 80px; }
  @media screen and (max-width: 767px) {
    .foot-contact {
      font-size: 14px;
      padding: 20px; } }

.l-footer {
  font-size: 14px; }
  @media screen and (max-width: 767px) {
    .l-footer {
      margin-bottom: 56px; } }
  .l-footer-inner {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    padding: 20px 0; }
    @media screen and (max-width: 767px) {
      .l-footer-inner {
        flex-direction: column;
        text-align: center;
        align-items: center; } }
  .l-footer__logo {
    margin-bottom: 10px; }
    .l-footer__logo img {
      width: 150px; }
  @media screen and (max-width: 767px) {
    .l-footer .footernav {
      padding-top: 20px; } }
  .l-footer .footernav__list {
    display: flex;
    margin: 0;
    gap: 20px; }
  .l-footer .footernav__item a:hover {
    color: #a01e28; }
  .l-footer .copyright {
    text-align: center;
    background: #a01e28;
    color: #fff;
    padding: 12px; }
    @media screen and (max-width: 767px) {
      .l-footer .copyright {
        padding: 12px 0; } }
    .l-footer .copyright small {
      font-size: 12px; }
      @media screen and (max-width: 767px) {
        .l-footer .copyright small {
          font-size: 11px; } }

@media screen and (max-width: 767px) {
  .footfix-btn {
    position: fixed;
    left: 0;
    bottom: 0;
    width: 100%; }
    .footfix-btn__list {
      display: flex;
      margin: 0;
      gap: 1px;
      background: #fff;
      border-top: 1px solid #fff; }
      .footfix-btn__list > li {
        width: calc((100% - 2px) / 3); }
        .footfix-btn__list > li a {
          display: flex;
          justify-content: center;
          align-items: center;
          text-align: center;
          color: #fff;
          font-size: 3.5vw;
          font-weight: bold;
          height: 56px;
          background: #a01e28;
          line-height: 1.22;
          letter-spacing: 0; } }

.sidebar-search {
  padding: 20px 0 40px;
  background-color: #fff; }
  .sidebar-search--head {
    padding: 0 10px 20px; }
  .sidebar-search--img {
    margin-bottom: 18px;
    text-align: center; }
  .sidebar-search--ttl {
    margin-bottom: 10px; }
  .sidebar-search--ratingWrap {
    display: flex;
    align-items: center;
    margin-bottom: 10px; }
  .sidebar-search--rating {
    display: flex;
    align-items: center; }
    .sidebar-search--rating-stars {
      display: flex;
      align-items: center; }
      .sidebar-search--rating-stars img {
        display: inline-block;
        margin-right: 3px; }
    .sidebar-search--rating-number {
      line-height: 1; }
    .sidebar-search--rating-cmt {
      position: relative;
      display: block;
      padding-left: 22px; }
      .sidebar-search--rating-cmt:before {
        position: absolute;
        top: 5px;
        left: 0;
        width: 17px;
        height: 15px;
        display: block;
        background: url(../images/search/icon-msg.svg) no-repeat;
        background-size: 100% 100%;
        content: ""; }
  .sidebar-search .form {
    border-top: solid 1px #EBEBEB; }
    .sidebar-search .form-row {
      display: flex;
      padding: 12px 15px;
      border-bottom: solid 1px #EBEBEB; }
      .sidebar-search .form-row:last-child {
        border-bottom: none; }
      .sidebar-search .form-row--cnt {
        width: 100%; }
        @media screen and (max-width: 767px) {
          .sidebar-search .form-row--cnt .label-box {
            flex-wrap: wrap;
            flex-flow: column; }
            .sidebar-search .form-row--cnt .label-box .link-blue {
              display: block; } }
    .sidebar-search .form-label {
      width: 72px;
      margin-right: 12px;
      flex-shrink: 0;
      margin-bottom: 0; }
      @media screen and (max-width: 767px) {
        .sidebar-search .form-label {
          margin-right: 20px; } }
  .sidebar-search--map {
    margin: 30px 0 35px; }

.kv {
  background: url(../images/kv-slide-1.jpg) no-repeat center/cover;
  position: relative;
  opacity: 0;
  transition: opacity 0.3s linear;
  aspect-ratio: 3584 / 2048; }
  @media screen and (max-width: 767px) {
    .kv {
      background: url(../images/sp/kv-slide-1.jpg) no-repeat center/cover;
      aspect-ratio: 400 / 498; } }
  .kv.in {
    opacity: 1; }
  @media screen and (max-width: 767px) {
    .kv:before {
      content: "";
      display: block;
      width: 100%;
      height: 50%;
      position: absolute;
      left: 0;
      bottom: 0;
      background: black;
      background: linear-gradient(0deg, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0) 100%);
      z-index: 1; } }
  .kv img {
    width: 100%; }
  .kv__catch {
    position: absolute;
    right: 4vw;
    top: 4.66667vw;
    z-index: 5; }
    @media screen and (max-width: 767px) {
      .kv__catch {
        width: 100%;
        right: auto;
        top: auto;
        left: 50%;
        bottom: 20px;
        transform: translate(-50%, 0);
        text-align: center; } }
    .kv__catch img {
      width: 16.66667vw; }
      @media screen and (max-width: 767px) {
        .kv__catch img {
          width: 62.5vw; } }
  @media screen and (max-width: 767px) {
    .kv__list-sp .slick-slide {
      aspect-ratio: 400 / 498; }
      .kv__list-sp .slick-slide img {
        object-fit: cover;
        width: 100%;
        height: 100%; } }

.kv-catch {
  text-align: center;
  padding: 50px; }
  @media screen and (max-width: 767px) {
    .kv-catch {
      padding: 20px; } }
  .kv-catch img {
    width: 924px; }
    @media screen and (max-width: 767px) {
      .kv-catch img {
        width: 100%; } }

.welcome-sect {
  background: url(../images/welcome-bg.jpg) no-repeat center/cover;
  text-align: center;
  padding: 70px 0; }
  @media screen and (max-width: 767px) {
    .welcome-sect {
      padding: 50px 0; } }
  .welcome-sect-inner {
    max-width: 1370px;
    margin: 0 auto;
    position: relative; }
    .welcome-sect-inner:before, .welcome-sect-inner:after {
      content: "";
      display: block;
      width: 138px;
      height: 138px;
      position: absolute;
      top: -20px; }
      @media screen and (max-width: 767px) {
        .welcome-sect-inner:before, .welcome-sect-inner:after {
          width: 87px;
          height: 87px;
          top: -30px; } }
    .welcome-sect-inner:before {
      background: url(../images/welcome-orn-left-top.svg) no-repeat center/contain;
      left: 0; }
      @media screen and (max-width: 767px) {
        .welcome-sect-inner:before {
          left: 15px; } }
    .welcome-sect-inner:after {
      background: url(../images/welcome-orn-right-top.svg) no-repeat center/contain;
      right: 0; }
      @media screen and (max-width: 767px) {
        .welcome-sect-inner:after {
          right: 15px; } }
  .welcome-sect__ttl {
    font-family: spring-lp, sans-serif;
    font-weight: 700;
    font-size: 64px;
    color: #a01e28; }
    @media screen and (max-width: 767px) {
      .welcome-sect__ttl {
        font-size: 40px; } }
  .welcome-sect__lead {
    font-size: 53px;
    color: #a01e28;
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
    font-weight: bold;
    margin-bottom: 40px; }
    @media screen and (max-width: 767px) {
      .welcome-sect__lead {
        font-size: 6.25vw;
        margin-bottom: 15px; } }
  .welcome-sect__body {
    font-family: "Noto Serif JP", serif;
    font-size: 23px;
    line-height: 2.47; }
    @media screen and (max-width: 767px) {
      .welcome-sect__body {
        font-size: 3.5vw; } }
    .welcome-sect__body .from {
      color: #a01e28;
      font-size: 28px;
      font-weight: bold; }
      @media screen and (max-width: 767px) {
        .welcome-sect__body .from {
          font-size: 5vw; } }
  .welcome-sect__orn {
    padding: 0 0 70px; }
    @media screen and (max-width: 767px) {
      .welcome-sect__orn {
        padding: 0 0 40px; } }
    .welcome-sect__orn img {
      width: 233px; }
      @media screen and (max-width: 767px) {
        .welcome-sect__orn img {
          width: 148px; } }
  .welcome-sect__countdown {
    color: #a01e28;
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif; }
    .welcome-sect__countdown .ttl {
      line-height: 1.3;
      font-weight: 700;
      margin-bottom: 30px;
      letter-spacing: 0.2em; }
      .welcome-sect__countdown .ttl .line-1 {
        font-size: 28px; }
        @media screen and (max-width: 767px) {
          .welcome-sect__countdown .ttl .line-1 {
            font-size: 18px; } }
      .welcome-sect__countdown .ttl .line-2 {
        font-size: 58px; }
        @media screen and (max-width: 767px) {
          .welcome-sect__countdown .ttl .line-2 {
            font-size: 37px; } }
    .welcome-sect__countdown .cnt {
      display: flex;
      justify-content: center;
      gap: 70px; }
      @media screen and (max-width: 767px) {
        .welcome-sect__countdown .cnt {
          gap: 40px; } }
      .welcome-sect__countdown .cnt .unit {
        line-height: 1.06;
        font-family: "Noto Serif JP", serif; }
        .welcome-sect__countdown .cnt .unit:not(:last-child) {
          position: relative; }
          .welcome-sect__countdown .cnt .unit:not(:last-child):after {
            content: "";
            display: block;
            width: 1px;
            height: 100%;
            background: #a01e28;
            position: absolute;
            right: -30px;
            top: 50%;
            transform: translate(0, -50%); }
            @media screen and (max-width: 767px) {
              .welcome-sect__countdown .cnt .unit:not(:last-child):after {
                right: -20px; } }
        .welcome-sect__countdown .cnt .unit .line-1 {
          font-size: 25px;
          font-weight: 500;
          text-align: left; }
          @media screen and (max-width: 767px) {
            .welcome-sect__countdown .cnt .unit .line-1 {
              font-size: 16px; } }
        .welcome-sect__countdown .cnt .unit .line-2 {
          font-size: 126px; }
          @media screen and (max-width: 767px) {
            .welcome-sect__countdown .cnt .unit .line-2 {
              font-size: 17.5vw;
              line-height: 1; } }
          .welcome-sect__countdown .cnt .unit .line-2 .day {
            font-size: 67px; }
            @media screen and (max-width: 767px) {
              .welcome-sect__countdown .cnt .unit .line-2 .day {
                font-size: 8.75vw; } }

.oc-schedule {
  text-align: center;
  background: #a01e28;
  color: #fff;
  padding: 100px 0 0; }
  @media screen and (max-width: 767px) {
    .oc-schedule {
      padding: 50px 0 0; } }
  .oc-schedule__ttl {
    font-size: 50px;
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
    margin-bottom: 30px; }
    @media screen and (max-width: 767px) {
      .oc-schedule__ttl {
        font-size: 32px; } }
  .oc-schedule__lead {
    font-size: 20px;
    font-family: "Noto Serif JP", serif;
    margin-bottom: 60px; }
    @media screen and (max-width: 767px) {
      .oc-schedule__lead {
        font-size: 15px;
        line-height: 2.13;
        margin-bottom: 40px; } }
  .oc-schedule__line {
    margin-bottom: 130px; }
    @media screen and (max-width: 767px) {
      .oc-schedule__line {
        margin-bottom: 60px; } }
    .oc-schedule__line a {
      display: block; }
    .oc-schedule__line img {
      width: 360px; }
      @media screen and (max-width: 767px) {
        .oc-schedule__line img {
          width: 270px; } }
  .oc-schedule__bnr {
    text-align: center;
    margin-bottom: 90px; }
    @media screen and (max-width: 767px) {
      .oc-schedule__bnr {
        margin-bottom: 40px;
        padding: 0 3px 0 10px; } }
    .oc-schedule__bnr a {
      display: block; }
      .oc-schedule__bnr a img {
        width: 802px; }
  .oc-schedule__schedule {
    max-width: 980px;
    margin: 0 auto; }

.ad-rsv {
  background: #f0f0f0;
  padding: 90px 0; }
  @media screen and (max-width: 767px) {
    .ad-rsv {
      padding: 40px 20px; } }
  .ad-rsv__ttl {
    text-align: center; }
    .ad-rsv__ttl .icon img {
      width: 80px; }
      @media screen and (max-width: 767px) {
        .ad-rsv__ttl .icon img {
          width: 57px; } }
    .ad-rsv__ttl .txt {
      color: #a01e28;
      font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 40px;
      margin-bottom: 30px;
      font-size: 43px; }
      @media screen and (max-width: 767px) {
        .ad-rsv__ttl .txt {
          flex-direction: column;
          gap: 0;
          margin-bottom: 20px;
          font-size: 27px; } }
  .ad-rsv-flex {
    display: flex;
    gap: 20px; }
    @media screen and (max-width: 767px) {
      .ad-rsv-flex {
        flex-direction: column; } }
  .ad-rsv-unit {
    width: calc((100% - 20px) / 2);
    background: #fff;
    text-align: center; }
    @media screen and (max-width: 767px) {
      .ad-rsv-unit {
        width: 100%; } }
    .ad-rsv-unit .header {
      background: #9e1e28;
      color: #fff;
      font-size: 24px;
      padding: 10px; }
      @media screen and (max-width: 767px) {
        .ad-rsv-unit .header {
          font-size: 22px;
          line-height: 1.36; } }
    .ad-rsv-unit .cnt {
      padding: 26px 36px;
      min-height: 130px;
      text-align: left; }
      @media screen and (max-width: 767px) {
        .ad-rsv-unit .cnt {
          font-size: 16px;
          padding: 23px 20px;
          letter-spacing: 0; } }
      .ad-rsv-unit .cnt .lead {
        color: #a01e28;
        font-weight: bold;
        font-size: 20px;
        line-height: 1.55;
        margin-bottom: 15px; }
        @media screen and (max-width: 767px) {
          .ad-rsv-unit .cnt .lead {
            font-size: 5vw; } }
      @media screen and (max-width: 767px) {
        .ad-rsv-unit .cnt .body {
          font-size: 4vw; } }
      .ad-rsv-unit .cnt .body ul li {
        position: relative;
        padding-left: 20px; }
        .ad-rsv-unit .cnt .body ul li .num {
          position: absolute;
          left: 0; }
  .ad-rsv-set {
    margin-bottom: 80px; }
    @media screen and (max-width: 767px) {
      .ad-rsv-set {
        margin-bottom: 64px; } }
  .ad-rsv-white {
    background: #fff;
    display: flex;
    padding: 60px 80px; }
    @media screen and (max-width: 767px) {
      .ad-rsv-white {
        flex-direction: column;
        padding: 30px 20px;
        gap: 20px; } }
    .ad-rsv-white .left {
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 20px 0;
      width: 50%;
      gap: 20px;
      border-top: 1px solid #000000;
      border-bottom: 1px solid #000000; }
      @media screen and (max-width: 767px) {
        .ad-rsv-white .left {
          width: 100%; } }
      .ad-rsv-white .left .icon img {
        width: 113px; }
        @media screen and (max-width: 767px) {
          .ad-rsv-white .left .icon img {
            width: 65px; } }
      .ad-rsv-white .left .txt {
        display: flex;
        flex-direction: column;
        line-height: 1.5; }
        .ad-rsv-white .left .txt .line-1 {
          font-size: 30px;
          font-weight: bold; }
          @media screen and (max-width: 767px) {
            .ad-rsv-white .left .txt .line-1 {
              font-size: 17px; } }
        .ad-rsv-white .left .txt .line-2 {
          font-size: 36px;
          font-weight: bold; }
          @media screen and (max-width: 767px) {
            .ad-rsv-white .left .txt .line-2 {
              font-size: 20px; } }
    .ad-rsv-white .right {
      width: 50%;
      padding-left: 60px;
      display: flex;
      flex-direction: column;
      justify-content: space-between; }
      @media screen and (max-width: 767px) {
        .ad-rsv-white .right {
          width: 100%;
          padding: 0;
          gap: 20px;
          font-size: 4vw; } }
      .ad-rsv-white .right .btn a {
        display: inline-block; }
        .ad-rsv-white .right .btn a img {
          width: 400px; }
  .ad-rsv-red {
    background: #9e1e28;
    padding: 60px 80px; }
    @media screen and (max-width: 767px) {
      .ad-rsv-red {
        padding: 30px 20px; } }
    .ad-rsv-red .flow-list-wrap {
      display: flex;
      gap: 30px; }
      @media screen and (max-width: 767px) {
        .ad-rsv-red .flow-list-wrap {
          display: block; } }
    .ad-rsv-red .flow-list {
      width: calc((100% - 30px) / 2);
      margin: 0;
      display: flex;
      flex-direction: column;
      justify-content: space-between; }
      @media screen and (max-width: 767px) {
        .ad-rsv-red .flow-list {
          width: 100%;
          display: block; } }
    .ad-rsv-red .flow-item {
      display: flex;
      margin-bottom: 10px;
      letter-spacing: 0; }
      .ad-rsv-red .flow-item .number {
        background: #f5911e;
        color: #fff;
        display: flex;
        justify-content: center;
        align-items: center;
        text-align: center;
        font-size: 21px;
        width: 52px; }
        @media screen and (max-width: 767px) {
          .ad-rsv-red .flow-item .number {
            width: 43px; } }
      .ad-rsv-red .flow-item .cnt {
        width: calc(100% - 52px);
        background: #fff;
        padding: 15px;
        font-size: 17px;
        line-height: 1.58; }
        @media screen and (max-width: 767px) {
          .ad-rsv-red .flow-item .cnt {
            width: calc(100% - 43px);
            line-height: 1.35;
            font-size: 4vw; } }
        .ad-rsv-red .flow-item .cnt p {
          margin: 0; }
        .ad-rsv-red .flow-item .cnt .note {
          font-size: 12px;
          padding: 5px 0 0; }
        .ad-rsv-red .flow-item .cnt .red {
          color: #ff0000; }
      .ad-rsv-red .flow-item.item-5 .cnt, .ad-rsv-red .flow-item.item-6 .cnt {
        min-height: 116px;
        display: flex;
        align-items: center; }
        @media screen and (max-width: 767px) {
          .ad-rsv-red .flow-item.item-5 .cnt, .ad-rsv-red .flow-item.item-6 .cnt {
            min-height: auto;
            display: block; } }
      .ad-rsv-red .flow-item.last .cnt {
        width: 100%;
        display: flex;
        padding-bottom: 0; }
        @media screen and (max-width: 767px) {
          .ad-rsv-red .flow-item.last .cnt {
            padding-bottom: 15px; } }
        .ad-rsv-red .flow-item.last .cnt .icon img {
          width: 60px; }
        .ad-rsv-red .flow-item.last .cnt .txt {
          width: calc(100% - 60px);
          padding-left: 20px;
          padding-top: 8px; }
          @media screen and (max-width: 767px) {
            .ad-rsv-red .flow-item.last .cnt .txt {
              padding-top: 0; } }

.kokogasugoi-oc {
  text-align: center;
  padding: 90px; }
  @media screen and (max-width: 767px) {
    .kokogasugoi-oc {
      padding: 30px 0px; } }
  .kokogasugoi-oc__ttl {
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
    font-weight: 100;
    margin-bottom: 50px;
    line-height: 1.2;
    background: #a01e28;
    color: #fff;
    position: relative; }
    @media screen and (max-width: 767px) {
      .kokogasugoi-oc__ttl {
        margin: 0 20px 30px; } }
    .kokogasugoi-oc__ttl:before, .kokogasugoi-oc__ttl:after {
      content: "";
      display: block;
      background: #fff;
      width: 40px;
      height: 40px;
      border-radius: 50%;
      position: absolute;
      left: -20px;
      top: -20px; }
      @media screen and (max-width: 767px) {
        .kokogasugoi-oc__ttl:before, .kokogasugoi-oc__ttl:after {
          width: 24px;
          height: 24px;
          left: -12px;
          top: -12px; } }
    .kokogasugoi-oc__ttl:after {
      left: auto;
      right: -20px; }
      @media screen and (max-width: 767px) {
        .kokogasugoi-oc__ttl:after {
          right: -12px; } }
    .kokogasugoi-oc__ttl-inner {
      display: flex;
      flex-direction: column;
      align-items: center;
      position: relative;
      padding: 40px 0; }
      @media screen and (max-width: 767px) {
        .kokogasugoi-oc__ttl-inner {
          padding: 30px 0; } }
      .kokogasugoi-oc__ttl-inner:before, .kokogasugoi-oc__ttl-inner:after {
        content: "";
        display: block;
        background: #fff;
        width: 40px;
        height: 40px;
        border-radius: 50%;
        position: absolute;
        left: -20px;
        bottom: -20px; }
        @media screen and (max-width: 767px) {
          .kokogasugoi-oc__ttl-inner:before, .kokogasugoi-oc__ttl-inner:after {
            width: 24px;
            height: 24px;
            left: -12px;
            bottom: -12px; } }
      .kokogasugoi-oc__ttl-inner:after {
        left: auto;
        right: -20px; }
        @media screen and (max-width: 767px) {
          .kokogasugoi-oc__ttl-inner:after {
            right: -12px; } }
    .kokogasugoi-oc__ttl .line1 {
      font-size: 45px;
      position: relative; }
      @media screen and (max-width: 767px) {
        .kokogasugoi-oc__ttl .line1 {
          font-size: 27px; } }
    .kokogasugoi-oc__ttl .line2 {
      font-size: 68px; }
      @media screen and (max-width: 767px) {
        .kokogasugoi-oc__ttl .line2 {
          font-size: 42px; } }
      @media screen and (max-width: 767px) {
        .kokogasugoi-oc__ttl .line2 span {
          font-size: 33px;
          display: inline-block; } }
  .kokogasugoi-oc__list {
    display: flex;
    justify-content: center;
    gap: 60px;
    margin-bottom: 120px; }
    @media screen and (max-width: 767px) {
      .kokogasugoi-oc__list {
        flex-direction: column;
        margin-bottom: 40px;
        gap: 30px; } }
  @media screen and (max-width: 767px) {
    .kokogasugoi-oc__item {
      display: flex;
      align-items: center; } }
  .kokogasugoi-oc__item:not(:last-child) {
    position: relative; }
    .kokogasugoi-oc__item:not(:last-child):after {
      content: "";
      display: block;
      width: 1px;
      height: 100%;
      background: #a01e28;
      position: absolute;
      right: -30px;
      top: 50%;
      transform: translate(0, -50%); }
      @media screen and (max-width: 767px) {
        .kokogasugoi-oc__item:not(:last-child):after {
          width: 90%;
          height: 1px;
          right: auto;
          left: 50%;
          top: auto;
          bottom: -15px;
          transform: translate(-50%, 0); } }
  .kokogasugoi-oc__item .img {
    margin-bottom: 30px; }
    @media screen and (max-width: 767px) {
      .kokogasugoi-oc__item .img {
        flex: 0 0 30.5vw;
        margin-left: -2.5vw;
        margin-bottom: 0; } }
    .kokogasugoi-oc__item .img img {
      width: 196px; }
      @media screen and (max-width: 767px) {
        .kokogasugoi-oc__item .img img {
          width: 100%; } }
  @media screen and (max-width: 767px) {
    .kokogasugoi-oc__item .txt {
      padding-left: 5px; } }
  .kokogasugoi-oc__item .txt .ttl-img {
    height: 74px;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 15px; }
    @media screen and (max-width: 767px) {
      .kokogasugoi-oc__item .txt .ttl-img {
        margin-bottom: 10px;
        text-align: left;
        display: block;
        height: auto; } }
    .kokogasugoi-oc__item .txt .ttl-img img.w-267 {
      width: 267px; }
    .kokogasugoi-oc__item .txt .ttl-img img.w-311 {
      width: 311px; }
    .kokogasugoi-oc__item .txt .ttl-img img.w-247 {
      width: 247px; }
    @media screen and (max-width: 767px) {
      .kokogasugoi-oc__item .txt .ttl-img img.w2-250 {
        width: 62.5vw; } }
    @media screen and (max-width: 767px) {
      .kokogasugoi-oc__item .txt .ttl-img img.w2-292 {
        width: 73vw; } }
    @media screen and (max-width: 767px) {
      .kokogasugoi-oc__item .txt .ttl-img img.w2-232 {
        width: 58vw; } }
  .kokogasugoi-oc__item .txt .ttl {
    color: #a01e28;
    font-size: 32px;
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
    line-height: 1.28;
    margin-bottom: 15px; }
    @media screen and (max-width: 767px) {
      .kokogasugoi-oc__item .txt .ttl {
        font-size: 6vw;
        margin-bottom: 10px;
        text-align: left; } }
  .kokogasugoi-oc__item .txt .body {
    line-height: 1.5; }
    @media screen and (max-width: 767px) {
      .kokogasugoi-oc__item .txt .body {
        font-size: 3.25vw;
        text-align: left; } }
    .kokogasugoi-oc__item .txt .body span {
      font-size: 12px; }

.taiken-oc {
  text-align: center;
  margin-bottom: 120px; }
  .taiken-oc__list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 30px 60px;
    margin-bottom: 40px; }
    @media screen and (max-width: 767px) {
      .taiken-oc__list {
        flex-direction: column;
        margin-bottom: 60px;
        padding: 0 20px;
        gap: 10px;
        margin-bottom: 20px; } }
  @media screen and (max-width: 767px) {
    .taiken-oc__item {
      width: 100%;
      display: flex; } }
  .taiken-oc__item .icon {
    margin-bottom: 20px; }
    @media screen and (max-width: 767px) {
      .taiken-oc__item .icon {
        flex: 0 0 86px;
        margin: 0 0 0; } }
    .taiken-oc__item .icon img {
      width: 148px; }
  @media screen and (max-width: 767px) {
    .taiken-oc__item .txt {
      text-align: left;
      padding-left: 10px; } }
  .taiken-oc__item .ttl {
    font-size: 32px;
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
    margin: 0; }
    @media screen and (max-width: 767px) {
      .taiken-oc__item .ttl {
        font-size: 25px;
        line-height: 1.5; } }
  .taiken-oc__item .body {
    font-weight: 400; }
    @media screen and (max-width: 767px) {
      .taiken-oc__item .body {
        font-size: 3.75vw;
        line-height: 1.4; } }
  .taiken-oc__item:nth-child(1) .ttl {
    color: #d4727a; }
  .taiken-oc__item:nth-child(2) .ttl {
    color: #88c23f; }
  .taiken-oc__item:nth-child(3) .ttl {
    color: #5387ca; }
  .taiken-oc__item:nth-child(4) .ttl {
    color: #56a6b9; }
  .taiken-oc__item:nth-child(5) .ttl {
    color: #f7ac3b; }
  .taiken-oc__note {
    font-size: 12px; }

.oc-gallery {
  background: #efefef;
  text-align: center;
  padding: 80px 25px 150px;
  position: relative;
  /*タブ実装*/ }
  @media screen and (max-width: 767px) {
    .oc-gallery {
      padding: 40px 0; } }
  .oc-gallery__icon {
    margin-bottom: 30px; }
    @media screen and (max-width: 767px) {
      .oc-gallery__icon {
        margin-bottom: 15px; } }
    .oc-gallery__icon img {
      width: 55px; }
      @media screen and (max-width: 767px) {
        .oc-gallery__icon img {
          width: 35px; } }
  .oc-gallery__ttl {
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
    color: #a01e28;
    font-size: 68px;
    font-weight: 400;
    position: relative;
    z-index: 1;
    line-height: 1.15; }
    @media screen and (max-width: 767px) {
      .oc-gallery__ttl {
        font-size: 26px; } }
  .oc-gallery .tab_box .btn_area {
    display: flex;
    gap: 12px;
    margin: 40px 0 0; }
    @media screen and (max-width: 767px) {
      .oc-gallery .tab_box .btn_area {
        gap: 5px; } }
    .oc-gallery .tab_box .btn_area .tab_btn {
      width: calc((100% - 24px) / 3);
      cursor: pointer;
      display: flex;
      justify-content: center;
      align-items: center;
      text-align: center;
      background: #fff;
      height: 90px;
      position: relative; }
      @media screen and (max-width: 767px) {
        .oc-gallery .tab_box .btn_area .tab_btn {
          width: calc((100% - 10px) / 3);
          height: 55px;
          font-size: 12px;
          line-height: 1.6; } }
      .oc-gallery .tab_box .btn_area .tab_btn .arrow {
        position: absolute;
        right: 20px;
        top: 50%;
        transform: translate(0, -50%);
        width: 12px;
        height: 20px;
        background-image: url(../images/gallery-arrow-orange.svg);
        background-repeat: no-repeat;
        background-position: center;
        background-size: 12px auto; }
        @media screen and (max-width: 767px) {
          .oc-gallery .tab_box .btn_area .tab_btn .arrow {
            right: 5px;
            width: 6px;
            height: 10px;
            background-size: 6px auto; } }
      .oc-gallery .tab_box .btn_area .tab_btn:nth-child(1) {
        color: #c65a21; }
        .oc-gallery .tab_box .btn_area .tab_btn:nth-child(1) .arrow {
          background-image: url(../images/gallery-arrow-orange.svg); }
        .oc-gallery .tab_box .btn_area .tab_btn:nth-child(1).active {
          background: #c65a21;
          color: #fff; }
          .oc-gallery .tab_box .btn_area .tab_btn:nth-child(1).active .arrow {
            background-image: url(../images/gallery-arrow-white.svg); }
      .oc-gallery .tab_box .btn_area .tab_btn:nth-child(2) {
        color: #a8325b; }
        .oc-gallery .tab_box .btn_area .tab_btn:nth-child(2) .arrow {
          background-image: url(../images/gallery-arrow-red.svg); }
        .oc-gallery .tab_box .btn_area .tab_btn:nth-child(2).active {
          background: #a8325b;
          color: #fff; }
          .oc-gallery .tab_box .btn_area .tab_btn:nth-child(2).active .arrow {
            background-image: url(../images/gallery-arrow-white.svg); }
      .oc-gallery .tab_box .btn_area .tab_btn:nth-child(3) {
        color: #366f80; }
        .oc-gallery .tab_box .btn_area .tab_btn:nth-child(3) .arrow {
          background-image: url(../images/gallery-arrow-green.svg); }
        .oc-gallery .tab_box .btn_area .tab_btn:nth-child(3).active {
          background: #366f80;
          color: #fff; }
          .oc-gallery .tab_box .btn_area .tab_btn:nth-child(3).active .arrow {
            background-image: url(../images/gallery-arrow-white.svg); }
  .oc-gallery .tab_box .panel_area .tab_panel {
    visibility: hidden;
    height: 0;
    opacity: 0; }
    .oc-gallery .tab_box .panel_area .tab_panel.active {
      visibility: visible;
      height: auto;
      opacity: 1; }
    .oc-gallery .tab_box .panel_area .tab_panel .img a {
      pointer-events: none; }

.oc-movie {
  padding: 90px;
  text-align: center;
  position: relative; }
  @media screen and (max-width: 767px) {
    .oc-movie {
      padding: 40px 20px; } }
  .oc-movie-inner {
    max-width: 990px;
    margin: 0 auto; }
  .oc-movie__ttl {
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
    color: #a01e28;
    display: flex;
    flex-direction: column;
    margin-bottom: 80px; }
    @media screen and (max-width: 767px) {
      .oc-movie__ttl {
        margin-bottom: 30px; } }
    .oc-movie__ttl .en {
      font-size: 26px; }
      @media screen and (max-width: 767px) {
        .oc-movie__ttl .en {
          font-size: 20px; } }
    .oc-movie__ttl .jp {
      font-size: 43px; }
      @media screen and (max-width: 767px) {
        .oc-movie__ttl .jp {
          font-size: 8vw; } }
  .oc-movie .swiper-slide {
    margin-bottom: 30px; }
    @media screen and (max-width: 767px) {
      .oc-movie .swiper-slide {
        margin-bottom: 20px; } }
    .oc-movie .swiper-slide .img {
      margin-bottom: 20px; }
    .oc-movie .swiper-slide .txt {
      font-size: 20px;
      line-height: 1.5;
      font-weight: bold; }
      @media screen and (max-width: 767px) {
        .oc-movie .swiper-slide .txt {
          font-size: 4.5vw;
          opacity: 0; } }
    @media screen and (max-width: 767px) {
      .oc-movie .swiper-slide.swiper-slide-active .txt {
        opacity: 1; } }

.oc-movie-3ji {
  padding: 90px;
  text-align: center;
  position: relative;
  background: #efefef; }
  @media screen and (max-width: 767px) {
    .oc-movie-3ji {
      padding: 40px 20px; } }
  .oc-movie-3ji-inner {
    max-width: 990px;
    margin: 0 auto; }
  .oc-movie-3ji__ttl {
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
    color: #a01e28;
    display: flex;
    flex-direction: column;
    margin-bottom: 80px; }
    @media screen and (max-width: 767px) {
      .oc-movie-3ji__ttl {
        margin-bottom: 30px; } }
    .oc-movie-3ji__ttl .en {
      font-size: 49px; }
      @media screen and (max-width: 767px) {
        .oc-movie-3ji__ttl .en {
          font-size: 20px; } }
  .oc-movie-3ji__movie .img {
    margin-bottom: 20px; }
    .oc-movie-3ji__movie .img img {
      max-width: 800px; }
      @media screen and (max-width: 767px) {
        .oc-movie-3ji__movie .img img {
          max-width: 100%; } }
  .oc-movie-3ji__movie .txt {
    font-size: 20px;
    font-weight: bold; }
    @media screen and (max-width: 767px) {
      .oc-movie-3ji__movie .txt {
        font-size: 4.5vw; } }

.oc-gallery .swiper,
.oc-movie .swiper {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  z-index: 1;
  display: block; }

.oc-gallery .swiper-vertical > .swiper-wrapper,
.oc-movie .swiper-vertical > .swiper-wrapper {
  flex-direction: column; }

.oc-gallery .swiper-wrapper,
.oc-movie .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; }

.oc-gallery .swiper-android .swiper-slide,
.oc-gallery .swiper-ios .swiper-slide,
.oc-gallery .swiper-wrapper,
.oc-movie .swiper-android .swiper-slide,
.oc-movie .swiper-ios .swiper-slide,
.oc-movie .swiper-wrapper {
  transform: translate(0); }

.oc-gallery .swiper-horizontal,
.oc-movie .swiper-horizontal {
  touch-action: pan-y; }

.oc-gallery .swiper-vertical,
.oc-movie .swiper-vertical {
  touch-action: pan-x; }

.oc-gallery .swiper-slide,
.oc-movie .swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
  display: block; }
  .oc-gallery .swiper-slide .img a,
  .oc-movie .swiper-slide .img a {
    display: block;
    aspect-ratio: 1000 / 667;
    overflow: hidden; }
    .oc-gallery .swiper-slide .img a img,
    .oc-movie .swiper-slide .img a img {
      object-fit: cover;
      width: 100%;
      height: 100%;
      transition: all 0.3s ease 0s; }
    .oc-gallery .swiper-slide .img a:hover,
    .oc-movie .swiper-slide .img a:hover {
      opacity: 1; }
      .oc-gallery .swiper-slide .img a:hover img,
      .oc-movie .swiper-slide .img a:hover img {
        transform: scale(1.1); }

.oc-gallery .swiper-slide-invisible-blank,
.oc-movie .swiper-slide-invisible-blank {
  visibility: hidden; }

.oc-gallery .swiper-autoheight,
.oc-gallery .swiper-autoheight .swiper-slide,
.oc-movie .swiper-autoheight,
.oc-movie .swiper-autoheight .swiper-slide {
  height: auto; }

.oc-gallery .swiper-autoheight .swiper-wrapper,
.oc-movie .swiper-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height; }

.oc-gallery .swiper-backface-hidden .swiper-slide,
.oc-movie .swiper-backface-hidden .swiper-slide {
  transform: translateZ(0);
  backface-visibility: hidden; }

.oc-gallery .swiper-3d.swiper-css-mode .swiper-wrapper,
.oc-movie .swiper-3d.swiper-css-mode .swiper-wrapper {
  perspective: 1200px; }

.oc-gallery .swiper-3d .swiper-wrapper,
.oc-movie .swiper-3d .swiper-wrapper {
  transform-style: preserve-3d; }

.oc-gallery .swiper-3d,
.oc-movie .swiper-3d {
  perspective: 1200px; }

.oc-gallery .swiper-3d .swiper-slide,
.oc-gallery .swiper-3d .swiper-cube-shadow,
.oc-movie .swiper-3d .swiper-slide,
.oc-movie .swiper-3d .swiper-cube-shadow {
  transform-style: preserve-3d; }

.oc-gallery .swiper-css-mode > .swiper-wrapper,
.oc-movie .swiper-css-mode > .swiper-wrapper {
  overflow: auto;
  scrollbar-width: none;
  -ms-overflow-style: none; }

.oc-gallery .swiper-css-mode > .swiper-wrapper::-webkit-scrollbar,
.oc-movie .swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none; }

.oc-gallery .swiper-css-mode > .swiper-wrapper > .swiper-slide,
.oc-movie .swiper-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start; }

.oc-gallery .swiper-css-mode.swiper-horizontal > .swiper-wrapper,
.oc-movie .swiper-css-mode.swiper-horizontal > .swiper-wrapper {
  scroll-snap-type: x mandatory; }

.oc-gallery .swiper-css-mode.swiper-vertical > .swiper-wrapper,
.oc-movie .swiper-css-mode.swiper-vertical > .swiper-wrapper {
  scroll-snap-type: y mandatory; }

.oc-gallery .swiper-css-mode.swiper-free-mode > .swiper-wrapper,
.oc-movie .swiper-css-mode.swiper-free-mode > .swiper-wrapper {
  scroll-snap-type: none; }

.oc-gallery .swiper-css-mode.swiper-free-mode > .swiper-wrapper > .swiper-slide,
.oc-movie .swiper-css-mode.swiper-free-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: none; }

.oc-gallery .swiper-css-mode.swiper-centered > .swiper-wrapper:before,
.oc-movie .swiper-css-mode.swiper-centered > .swiper-wrapper:before {
  content: "";
  flex-shrink: 0;
  order: 9999; }

.oc-gallery .swiper-css-mode.swiper-centered > .swiper-wrapper > .swiper-slide,
.oc-movie .swiper-css-mode.swiper-centered > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: center center;
  scroll-snap-stop: always; }

.oc-gallery .swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child,
.oc-movie .swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
  margin-inline-start: var(--swiper-centered-offset-before); }

.oc-gallery .swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper:before,
.oc-movie .swiper-css-mode.swiper-centered.swiper-horizontal > .swiper-wrapper:before {
  height: 100%;
  min-height: 1px;
  width: var(--swiper-centered-offset-after); }

.oc-gallery .swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child,
.oc-movie .swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
  margin-block-start: var(--swiper-centered-offset-before); }

.oc-gallery .swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper:before,
.oc-movie .swiper-css-mode.swiper-centered.swiper-vertical > .swiper-wrapper:before {
  width: 100%;
  min-width: 1px;
  height: var(--swiper-centered-offset-after); }

.oc-gallery .swiper-3d .swiper-slide-shadow,
.oc-gallery .swiper-3d .swiper-slide-shadow-left,
.oc-gallery .swiper-3d .swiper-slide-shadow-right,
.oc-gallery .swiper-3d .swiper-slide-shadow-top,
.oc-gallery .swiper-3d .swiper-slide-shadow-bottom,
.oc-gallery .swiper-3d .swiper-slide-shadow,
.oc-gallery .swiper-3d .swiper-slide-shadow-left,
.oc-gallery .swiper-3d .swiper-slide-shadow-right,
.oc-gallery .swiper-3d .swiper-slide-shadow-top,
.oc-gallery .swiper-3d .swiper-slide-shadow-bottom,
.oc-movie .swiper-3d .swiper-slide-shadow,
.oc-movie .swiper-3d .swiper-slide-shadow-left,
.oc-movie .swiper-3d .swiper-slide-shadow-right,
.oc-movie .swiper-3d .swiper-slide-shadow-top,
.oc-movie .swiper-3d .swiper-slide-shadow-bottom,
.oc-movie .swiper-3d .swiper-slide-shadow,
.oc-movie .swiper-3d .swiper-slide-shadow-left,
.oc-movie .swiper-3d .swiper-slide-shadow-right,
.oc-movie .swiper-3d .swiper-slide-shadow-top,
.oc-movie .swiper-3d .swiper-slide-shadow-bottom {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10; }

.oc-gallery .swiper-3d .swiper-slide-shadow,
.oc-movie .swiper-3d .swiper-slide-shadow {
  background: rgba(0, 0, 0, 0.15); }

.oc-gallery .swiper-3d .swiper-slide-shadow-left,
.oc-movie .swiper-3d .swiper-slide-shadow-left {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); }

.oc-gallery .swiper-3d .swiper-slide-shadow-right,
.oc-movie .swiper-3d .swiper-slide-shadow-right {
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); }

.oc-gallery .swiper-3d .swiper-slide-shadow-top,
.oc-movie .swiper-3d .swiper-slide-shadow-top {
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); }

.oc-gallery .swiper-3d .swiper-slide-shadow-bottom,
.oc-movie .swiper-3d .swiper-slide-shadow-bottom {
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); }

.oc-gallery .swiper-lazy-preloader,
.oc-movie .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; }

.oc-gallery .swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,
.oc-gallery .swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader,
.oc-movie .swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,
.oc-movie .swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader {
  animation: swiper-preloader-spin 1s infinite linear; }

.oc-gallery .swiper-lazy-preloader-white,
.oc-movie .swiper-lazy-preloader-white {
  --swiper-preloader-color: #fff; }

.oc-gallery .swiper-lazy-preloader-black,
.oc-movie .swiper-lazy-preloader-black {
  --swiper-preloader-color: #000; }

@keyframes swiper-preloader-spin {
  0% {
    transform: rotate(0); }
  to {
    transform: rotate(360deg); } }

.oc-gallery .swiper-pagination,
.oc-movie .swiper-pagination {
  position: absolute;
  text-align: center;
  transition: 0.3s opacity;
  transform: translate(0);
  z-index: 10;
  display: none; }

.oc-gallery .swiper-pagination.swiper-pagination-hidden,
.oc-movie .swiper-pagination.swiper-pagination-hidden {
  opacity: 0; }

.oc-gallery .swiper-pagination-disabled > .swiper-pagination,
.oc-gallery .swiper-pagination.swiper-pagination-disabled,
.oc-movie .swiper-pagination-disabled > .swiper-pagination,
.oc-movie .swiper-pagination.swiper-pagination-disabled {
  display: none !important; }

.oc-gallery .swiper-pagination-fraction,
.oc-gallery .swiper-pagination-custom,
.oc-gallery .swiper-horizontal > .swiper-pagination-bullets,
.oc-gallery .swiper-pagination-bullets.swiper-pagination-horizontal,
.oc-movie .swiper-pagination-fraction,
.oc-movie .swiper-pagination-custom,
.oc-movie .swiper-horizontal > .swiper-pagination-bullets,
.oc-movie .swiper-pagination-bullets.swiper-pagination-horizontal {
  bottom: 90px;
  top: auto;
  left: 0;
  width: 100%; }
  @media screen and (max-width: 767px) {
    .oc-gallery .swiper-pagination-fraction,
    .oc-gallery .swiper-pagination-custom,
    .oc-gallery .swiper-horizontal > .swiper-pagination-bullets,
    .oc-gallery .swiper-pagination-bullets.swiper-pagination-horizontal,
    .oc-movie .swiper-pagination-fraction,
    .oc-movie .swiper-pagination-custom,
    .oc-movie .swiper-horizontal > .swiper-pagination-bullets,
    .oc-movie .swiper-pagination-bullets.swiper-pagination-horizontal {
      bottom: 70px; } }

.oc-gallery .swiper-pagination-bullets-dynamic,
.oc-movie .swiper-pagination-bullets-dynamic {
  overflow: hidden;
  font-size: 0; }

.oc-gallery .swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.oc-movie .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transform: scale(0.33);
  position: relative; }

.oc-gallery .swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active,
.oc-movie .swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
  transform: scale(1); }

.oc-gallery .swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main,
.oc-movie .swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  transform: scale(1); }

.oc-gallery .swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev,
.oc-movie .swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  transform: scale(0.66); }

.oc-gallery .swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev,
.oc-movie .swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  transform: scale(0.33); }

.oc-gallery .swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next,
.oc-movie .swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  transform: scale(0.66); }

.oc-gallery .swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next,
.oc-movie .swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  transform: scale(0.33); }

.oc-gallery .swiper-pagination-bullet,
.oc-movie .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); }

.oc-gallery button.swiper-pagination-bullet,
.oc-movie button.swiper-pagination-bullet {
  border: none;
  margin: 0;
  padding: 0;
  box-shadow: none;
  appearance: none; }

.oc-gallery .swiper-pagination-clickable .swiper-pagination-bullet,
.oc-movie .swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer; }

.oc-gallery .swiper-pagination-bullet:only-child,
.oc-movie .swiper-pagination-bullet:only-child {
  display: none !important; }

.oc-gallery .swiper-pagination-bullet-active,
.oc-movie .swiper-pagination-bullet-active {
  opacity: var(--swiper-pagination-bullet-opacity, 1);
  background: #a01e28; }

.oc-gallery .swiper-vertical > .swiper-pagination-bullets,
.oc-gallery .swiper-pagination-vertical.swiper-pagination-bullets,
.oc-movie .swiper-vertical > .swiper-pagination-bullets,
.oc-movie .swiper-pagination-vertical.swiper-pagination-bullets {
  right: var(--swiper-pagination-right, 8px);
  left: var(--swiper-pagination-left, auto);
  top: 50%;
  transform: translateY(-50%); }

.oc-gallery .swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet,
.oc-gallery .swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet,
.oc-movie .swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet,
.oc-movie .swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
  display: block; }

.oc-gallery .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.oc-gallery .swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.oc-movie .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.oc-movie .swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  top: 50%;
  transform: translateY(-50%);
  width: 8px; }

.oc-gallery .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.oc-gallery .swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.oc-movie .swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.oc-movie .swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  display: inline-block;
  transition: 0.2s transform, 0.2s top; }

.oc-gallery .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.oc-gallery .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet,
.oc-movie .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.oc-movie .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px); }

.oc-gallery .swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.oc-gallery .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.oc-movie .swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.oc-movie .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  left: 50%;
  transform: translate(-50%);
  white-space: nowrap; }

.oc-gallery .swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.oc-gallery .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.oc-movie .swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.oc-movie .swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 0.2s transform, 0.2s left; }

.oc-gallery .swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.oc-movie .swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 0.2s transform, 0.2s right; }

.oc-gallery .swiper-pagination-fraction,
.oc-movie .swiper-pagination-fraction {
  color: var(--swiper-pagination-fraction-color, inherit); }

.oc-gallery .swiper-pagination-progressbar,
.oc-movie .swiper-pagination-progressbar {
  background: var(--swiper-pagination-progressbar-bg-color, rgba(0, 0, 0, 0.25));
  position: absolute; }

.oc-gallery .swiper-pagination-progressbar .swiper-pagination-progressbar-fill,
.oc-movie .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; }

.oc-gallery .swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill,
.oc-movie .swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  transform-origin: right top; }

.oc-gallery .swiper-horizontal > .swiper-pagination-progressbar,
.oc-gallery .swiper-pagination-progressbar.swiper-pagination-horizontal,
.oc-gallery .swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.oc-gallery .swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite,
.oc-movie .swiper-horizontal > .swiper-pagination-progressbar,
.oc-movie .swiper-pagination-progressbar.swiper-pagination-horizontal,
.oc-movie .swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.oc-movie .swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite {
  width: 100%;
  height: var(--swiper-pagination-progressbar-size, 4px);
  left: 0;
  top: 0; }

.oc-gallery .swiper-vertical > .swiper-pagination-progressbar,
.oc-gallery .swiper-pagination-progressbar.swiper-pagination-vertical,
.oc-gallery .swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.oc-gallery .swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite,
.oc-movie .swiper-vertical > .swiper-pagination-progressbar,
.oc-movie .swiper-pagination-progressbar.swiper-pagination-vertical,
.oc-movie .swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.oc-movie .swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite {
  width: var(--swiper-pagination-progressbar-size, 4px);
  height: 100%;
  left: 0;
  top: 0; }

.oc-gallery .swiper-pagination-lock,
.oc-movie .swiper-pagination-lock {
  display: none; }

.oc-gallery :root,
.oc-movie :root {
  --swiper-navigation-size: 44px; }

.oc-gallery .swiper-button-prev,
.oc-gallery .swiper-button-next,
.oc-movie .swiper-button-prev,
.oc-movie .swiper-button-next {
  position: absolute;
  bottom: 0;
  top: auto;
  width: calc(var(--swiper-navigation-size) / 44 * 27);
  height: var(--swiper-navigation-size);
  margin-top: calc(0px - var(--swiper-navigation-size) / 2);
  z-index: 11;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #a01e28; }

.oc-gallery .swiper-button-prev.swiper-button-disabled,
.oc-gallery .swiper-button-next.swiper-button-disabled,
.oc-movie .swiper-button-prev.swiper-button-disabled,
.oc-movie .swiper-button-next.swiper-button-disabled {
  opacity: 0.35;
  cursor: auto;
  pointer-events: none; }

.oc-gallery .swiper-button-prev.swiper-button-hidden,
.oc-gallery .swiper-button-next.swiper-button-hidden,
.oc-movie .swiper-button-prev.swiper-button-hidden,
.oc-movie .swiper-button-next.swiper-button-hidden {
  opacity: 0;
  cursor: auto;
  pointer-events: none; }

.oc-gallery .swiper-navigation-disabled .swiper-button-prev,
.oc-gallery .swiper-navigation-disabled .swiper-button-next,
.oc-movie .swiper-navigation-disabled .swiper-button-prev,
.oc-movie .swiper-navigation-disabled .swiper-button-next {
  display: none !important; }

.oc-gallery .swiper-button-prev svg,
.oc-gallery .swiper-button-next svg,
.oc-movie .swiper-button-prev svg,
.oc-movie .swiper-button-next svg {
  width: 100%;
  height: 100%;
  object-fit: contain;
  transform-origin: center; }

.oc-gallery .swiper-rtl .swiper-button-prev svg,
.oc-gallery .swiper-rtl .swiper-button-next svg,
.oc-movie .swiper-rtl .swiper-button-prev svg,
.oc-movie .swiper-rtl .swiper-button-next svg {
  transform: rotate(180deg); }

.oc-gallery .swiper-button-prev,
.oc-gallery .swiper-rtl .swiper-button-next,
.oc-movie .swiper-button-prev,
.oc-movie .swiper-rtl .swiper-button-next {
  left: calc(50% - 60px);
  right: auto; }

.oc-gallery .swiper-button-lock,
.oc-movie .swiper-button-lock {
  display: none; }

.oc-gallery .swiper-button-prev:after,
.oc-gallery .swiper-button-next:after,
.oc-movie .swiper-button-prev:after,
.oc-movie .swiper-button-next:after {
  font-family: swiper-icons;
  font-size: 33px;
  font-weight: 400;
  text-transform: none !important;
  letter-spacing: 0;
  font-variant: initial;
  line-height: 1; }

.oc-gallery .swiper-button-prev:after,
.oc-gallery .swiper-rtl .swiper-button-next:after,
.oc-movie .swiper-button-prev:after,
.oc-movie .swiper-rtl .swiper-button-next:after {
  content: "prev"; }

.oc-gallery .swiper-button-next,
.oc-gallery .swiper-rtl .swiper-button-prev,
.oc-movie .swiper-button-next,
.oc-movie .swiper-rtl .swiper-button-prev {
  right: calc(50% - 60px);
  left: auto; }

.oc-gallery .swiper-button-next:after,
.oc-gallery .swiper-rtl .swiper-button-prev:after,
.oc-movie .swiper-button-next:after,
.oc-movie .swiper-rtl .swiper-button-prev:after {
  content: "next"; }

.oc-gallery .swiper-virtual .swiper-slide,
.oc-movie .swiper-virtual .swiper-slide {
  -webkit-backface-visibility: hidden;
  transform: translateZ(0); }

.oc-gallery .swiper-virtual.swiper-css-mode .swiper-wrapper:after,
.oc-movie .swiper-virtual.swiper-css-mode .swiper-wrapper:after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none; }

.oc-gallery .swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper:after,
.oc-movie .swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper:after {
  height: 1px;
  width: var(--swiper-virtual-size); }

.oc-gallery .swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper:after,
.oc-movie .swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper:after {
  width: 1px;
  height: var(--swiper-virtual-size); }

.oc-gallery .swiper-carousel,
.oc-movie .swiper-carousel {
  position: relative;
  margin: 0 auto;
  max-width: 100%;
  overflow: hidden; }

.oc-gallery .swiper-carousel .swiper-slide,
.oc-gallery .swiper-carousel swiper-slide,
.oc-movie .swiper-carousel .swiper-slide,
.oc-movie .swiper-carousel swiper-slide {
  position: relative; }

.oc-gallery .swiper-carousel,
.oc-movie .swiper-carousel {
  padding-bottom: 63px;
  max-width: 1200px; }

.oc-gallery .swiper-carousel .swiper-slide,
.oc-movie .swiper-carousel .swiper-slide {
  width: 520px;
  height: auto;
  border-radius: 8px;
  max-width: calc(100% - 48px); }

.oc-gallery .swiper-carousel .swiper-carousel-animate-opacity,
.oc-movie .swiper-carousel .swiper-carousel-animate-opacity {
  height: 100%; }

.oc-gallery .swiper-carousel .swiper-pagination-bullets,
.oc-movie .swiper-carousel .swiper-pagination-bullets {
  bottom: 9px; }
  @media screen and (max-width: 767px) {
    .oc-gallery .swiper-carousel .swiper-pagination-bullets,
    .oc-movie .swiper-carousel .swiper-pagination-bullets {
      bottom: -5px; } }

.oc-gallery .swiper-carousel img,
.oc-movie .swiper-carousel img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover; }

.oc-gallery .swiper-carousel .slide-content,
.oc-movie .swiper-carousel .slide-content {
  position: absolute;
  left: 0;
  width: 100%;
  bottom: 0;
  padding: 88px 16px 24px;
  box-sizing: border-box;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.75));
  border-radius: 0 0 8px 8px; }

.oc-gallery .swiper-carousel .slide-content h2,
.oc-movie .swiper-carousel .slide-content h2 {
  margin: 0;
  font-weight: bold;
  font-size: 24px;
  line-height: 1.1; }

.oc-gallery .swiper-carousel .slide-content p,
.oc-movie .swiper-carousel .slide-content p {
  margin: 8px 0 0;
  opacity: 0.65;
  font-size: 14px;
  font-weight: 500;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden; }

.oc-movie .swiper .swiper-pagination {
  display: block; }

.oc-movie .swiper .swiper-button-prev {
  left: calc(50% - 120px);
  right: auto; }

.oc-movie .swiper .swiper-button-next {
  right: calc(50% - 120px);
  left: auto; }

.oc-movie .swiper .swiper-pagination-bullets {
  bottom: 9px; }
  @media screen and (max-width: 767px) {
    .oc-movie .swiper .swiper-pagination-bullets {
      bottom: 11px; } }

.dept-introduction {
  background: #a01e28;
  color: #fff;
  padding: 60px;
  text-align: center; }
  @media screen and (max-width: 767px) {
    .dept-introduction {
      padding: 40px 20px; } }
  .dept-introduction-inner {
    max-width: 1156px;
    margin: 0 auto; }
  .dept-introduction__ttl {
    margin-bottom: 40px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px; }
    @media screen and (max-width: 767px) {
      .dept-introduction__ttl {
        display: none; } }
    .dept-introduction__ttl .line-1 {
      font-size: 18px;
      font-weight: 400;
      background: url(../images/dept-introduction-orn.svg) no-repeat center bottom/204px auto;
      padding-bottom: 20px; }
      @media screen and (max-width: 767px) {
        .dept-introduction__ttl .line-1 {
          font-size: 16px; } }
    .dept-introduction__ttl .line-2 {
      font-size: 43px;
      font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif; }
      @media screen and (max-width: 767px) {
        .dept-introduction__ttl .line-2 {
          font-size: 27px; } }
  @media screen and (max-width: 767px) {
    .dept-introduction .ac .ac-label {
      cursor: pointer;
      position: relative;
      transition: all 0.3s ease;
      max-width: 722px;
      margin: 0 auto;
      background: #a01e28;
      color: #fff;
      text-align: center;
      font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
      border-radius: 10px; }
      .dept-introduction .ac .ac-label:hover {
        opacity: 0.7; }
      .dept-introduction .ac .ac-label .label {
        margin-bottom: 0; }
        .dept-introduction .ac .ac-label .label img {
          width: 175px; }
      .dept-introduction .ac .ac-label .arrow {
        position: absolute;
        left: 0px;
        top: 50%;
        transform: translate(0, -50%);
        transition: all 0.3s ease 0s; }
        .dept-introduction .ac .ac-label .arrow img {
          width: 30px; }
        .dept-introduction .ac .ac-label .arrow.open {
          transform: translate(0, -50%) rotate(-90deg); }
    .dept-introduction .ac .ac-content {
      display: none;
      padding-top: 40px; } }
  .dept-introduction__list {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 20px; }
    @media screen and (max-width: 767px) {
      .dept-introduction__list {
        margin: 0; } }
  .dept-introduction__item {
    width: calc((100% - 80px) / 5);
    text-align: left;
    font-size: 18px;
    font-weight: bold; }
    @media screen and (max-width: 767px) {
      .dept-introduction__item {
        width: calc((100% - 20px) / 2);
        font-size: 16px; } }
    .dept-introduction__item a {
      box-sizing: border-box;
      padding: 14px 20px;
      display: block;
      width: 100%;
      color: #000;
      position: relative;
      background-color: #fff;
      border-radius: 100vh; }
      @media screen and (max-width: 767px) {
        .dept-introduction__item a {
          padding: 9px 10px; } }
      .dept-introduction__item a span {
        margin-right: 4px;
        transition: all 0.3s ease 0s; }
      .dept-introduction__item a:hover {
        color: #fff;
        opacity: 1; }
        .dept-introduction__item a:hover span {
          color: #fff; }
    .dept-introduction__item.item-law span {
      color: #e60012; }
    .dept-introduction__item.item-law a:hover {
      background: #e60012; }
    .dept-introduction__item.item-business span {
      color: #ea5504; }
    .dept-introduction__item.item-business a:hover {
      background: #ea5504; }
    .dept-introduction__item.item-economics span {
      color: #f08300; }
    .dept-introduction__item.item-economics a:hover {
      background: #f08300; }
    .dept-introduction__item.item-foreign span {
      color: #f6ac19; }
    .dept-introduction__item.item-foreign a:hover {
      background: #f6ac19; }
    .dept-introduction__item.item-human span {
      color: #e95471; }
    .dept-introduction__item.item-human a:hover {
      background: #e95471; }
    .dept-introduction__item.item-urban span {
      color: #00a9a5; }
    .dept-introduction__item.item-urban a:hover {
      background: #00a9a5; }
    .dept-introduction__item.item-information span {
      color: #8c8c8c; }
    .dept-introduction__item.item-information a:hover {
      background: #8c8c8c; }
    .dept-introduction__item.item-sci_tech span {
      color: #005083; }
    .dept-introduction__item.item-sci_tech a:hover {
      background: #005083; }
    .dept-introduction__item.item-agrobiol span {
      color: #00a95f; }
    .dept-introduction__item.item-agrobiol a:hover {
      background: #00a95f; }
    .dept-introduction__item.item-pharmacy span {
      color: #6e60a8; }
    .dept-introduction__item.item-pharmacy a:hover {
      background: #6e60a8; }

.ten-colors {
  background: url(../images/welcome-bg.jpg) no-repeat center/cover;
  text-align: center;
  padding: 70px 0;
  /* モーダル本体 */ }
  .ten-colors-inner {
    position: relative; }
    @media screen and (max-width: 767px) {
      .ten-colors-inner:before, .ten-colors-inner:after {
        content: "";
        display: block;
        position: absolute;
        width: 87px;
        height: 87px;
        top: -55px; } }
    @media screen and (max-width: 767px) {
      .ten-colors-inner:before {
        background: url(../images/welcome-orn-left-top.svg) no-repeat center/contain;
        left: 10px; } }
    @media screen and (max-width: 767px) {
      .ten-colors-inner:after {
        background: url(../images/welcome-orn-right-top.svg) no-repeat center/contain;
        right: 10px; } }
  .ten-colors__ttl .ttl {
    margin-bottom: 20px; }
    @media screen and (max-width: 767px) {
      .ten-colors__ttl .ttl {
        margin-bottom: 0px; } }
    .ten-colors__ttl .ttl img {
      width: 720px; }
      @media screen and (max-width: 767px) {
        .ten-colors__ttl .ttl img {
          width: 316px; } }
  .ten-colors__ttl .lead {
    padding: 20px 0;
    color: #a01e28;
    font-weight: 400; }
    @media screen and (max-width: 767px) {
      .ten-colors__ttl .lead {
        padding: 20px 0 70px;
        line-height: 1.5;
        color: #000; } }
  .ten-colors__books {
    width: 744px;
    height: 572px;
    margin: 0 auto;
    position: relative; }
    @media screen and (max-width: 767px) {
      .ten-colors__books {
        width: 99.5vw;
        height: 69vw; } }
    .ten-colors__books__badge {
      position: absolute;
      right: -110px;
      top: -200px; }
      @media screen and (max-width: 767px) {
        .ten-colors__books__badge {
          right: auto;
          left: 50%;
          top: -55px;
          transform: translate(-50%, 0);
          margin-bottom: 20px; } }
      .ten-colors__books__badge img {
        width: 128px; }
        @media screen and (max-width: 767px) {
          .ten-colors__books__badge img {
            width: 156px; } }
    .ten-colors__books__more {
      display: flex;
      justify-content: flex-end;
      margin-top: -50px;
      padding-right: 3vw; }
      @media screen and (max-width: 767px) {
        .ten-colors__books__more {
          justify-content: center;
          padding: 0;
          text-align: center;
          margin-top: 20px; } }
      .ten-colors__books__more a {
        display: block; }
      .ten-colors__books__more img {
        width: 240px; }
        @media screen and (max-width: 767px) {
          .ten-colors__books__more img {
            width: 185px; } }
    .ten-colors__books__item {
      position: absolute;
      left: 0;
      transition: all 0.3s ease 0s; }
      @media screen and (max-width: 767px) {
        .ten-colors__books__item {
          width: 20%; } }
      .ten-colors__books__item.modal__trigger {
        cursor: pointer; }
      .ten-colors__books__item:hover {
        transform: translate(0, -20px); }
      @media screen and (max-width: 767px) {
        .ten-colors__books__item img {
          width: 100%; } }
      .ten-colors__books__item.item-law {
        left: 0; }
        @media screen and (max-width: 767px) {
          .ten-colors__books__item.item-law {
            left: calc(50% - 15% - 15%);
            transform: translateX(-50%); }
            .ten-colors__books__item.item-law:hover {
              transform: translate(-50%, -20px); } }
      .ten-colors__books__item.item-business {
        left: 130px; }
        @media screen and (max-width: 767px) {
          .ten-colors__books__item.item-business {
            left: calc(50% - 15%);
            transform: translateX(-50%); }
            .ten-colors__books__item.item-business:hover {
              transform: translate(-50%, -20px); } }
      .ten-colors__books__item.item-economics {
        left: 260px; }
        @media screen and (max-width: 767px) {
          .ten-colors__books__item.item-economics {
            left: 50%;
            transform: translateX(-50%); }
            .ten-colors__books__item.item-economics:hover {
              transform: translate(-50%, -20px); } }
      .ten-colors__books__item.item-foreign {
        left: 390px; }
        @media screen and (max-width: 767px) {
          .ten-colors__books__item.item-foreign {
            left: calc(50% + 15%);
            transform: translateX(-50%); }
            .ten-colors__books__item.item-foreign:hover {
              transform: translate(-50%, -20px); } }
      .ten-colors__books__item.item-human {
        left: 520px; }
        @media screen and (max-width: 767px) {
          .ten-colors__books__item.item-human {
            left: calc(50% + 15% + 15%);
            transform: translateX(-50%); }
            .ten-colors__books__item.item-human:hover {
              transform: translate(-50%, -20px); } }
      .ten-colors__books__item.item-urban {
        bottom: 0;
        left: 20px; }
        @media screen and (max-width: 767px) {
          .ten-colors__books__item.item-urban {
            left: calc(50% + 2.5% - 15% - 15%);
            transform: translateX(-50%); }
            .ten-colors__books__item.item-urban:hover {
              transform: translate(-50%, -20px); } }
      .ten-colors__books__item.item-information {
        bottom: 0;
        left: 150px; }
        @media screen and (max-width: 767px) {
          .ten-colors__books__item.item-information {
            left: calc(50% + 2.5% - 15%);
            transform: translateX(-50%); }
            .ten-colors__books__item.item-information:hover {
              transform: translate(-50%, -20px); } }
      .ten-colors__books__item.item-sci_tech {
        bottom: 0;
        left: 280px; }
        @media screen and (max-width: 767px) {
          .ten-colors__books__item.item-sci_tech {
            left: calc(50% + 2.5%);
            transform: translateX(-50%); }
            .ten-colors__books__item.item-sci_tech:hover {
              transform: translate(-50%, -20px); } }
      .ten-colors__books__item.item-agrobiol {
        bottom: 0;
        left: 410px; }
        @media screen and (max-width: 767px) {
          .ten-colors__books__item.item-agrobiol {
            left: calc(50% + 2.5% + 15%);
            transform: translateX(-50%); }
            .ten-colors__books__item.item-agrobiol:hover {
              transform: translate(-50%, -20px); } }
      .ten-colors__books__item.item-pharmacy {
        bottom: 0;
        left: 540px; }
        @media screen and (max-width: 767px) {
          .ten-colors__books__item.item-pharmacy {
            left: calc(50% + 2.5% + 15% + 15%);
            transform: translateX(-50%); }
            .ten-colors__books__item.item-pharmacy:hover {
              transform: translate(-50%, -20px); } }
  .ten-colors__detail {
    /*タブ実装*/ }
    .ten-colors__detail__item {
      margin-bottom: 25px; }
      @media screen and (max-width: 767px) {
        .ten-colors__detail__item {
          margin-bottom: 15px; } }
      .ten-colors__detail__item a {
        display: flex;
        align-items: center;
        background: #fff;
        line-height: 1.37;
        text-align: left;
        border-radius: 10px;
        padding: 18px 0 18px 20px; }
        @media screen and (max-width: 767px) {
          .ten-colors__detail__item a {
            flex-wrap: wrap;
            padding: 15px; } }
        .ten-colors__detail__item a:hover {
          opacity: 1;
          background: #eee; }
      .ten-colors__detail__item .ttl {
        border-left: 6px solid #000;
        padding-left: 6px;
        width: 174px; }
        .ten-colors__detail__item .ttl .line1 {
          font-size: 14px; }
          @media screen and (max-width: 767px) {
            .ten-colors__detail__item .ttl .line1 {
              font-size: 12px; } }
        .ten-colors__detail__item .ttl .line2 {
          font-size: 20px; }
          @media screen and (max-width: 767px) {
            .ten-colors__detail__item .ttl .line2 {
              font-size: 18px; } }
      .ten-colors__detail__item .question {
        width: 433px;
        display: flex;
        align-items: center;
        padding-right: 30px; }
        @media screen and (max-width: 767px) {
          .ten-colors__detail__item .question {
            padding: 10px 0;
            font-size: 15px;
            width: 100%; } }
        .ten-colors__detail__item .question .icon {
          font-family: "Noto Serif JP", serif;
          font-size: 31px;
          margin-right: 8px;
          line-height: 1;
          position: relative;
          top: -5px; }
          @media screen and (max-width: 767px) {
            .ten-colors__detail__item .question .icon {
              font-size: 22px;
              left: -3px;
              margin-right: 5px; } }
      .ten-colors__detail__item .teacher {
        display: flex;
        align-items: center;
        width: 204px; }
        .ten-colors__detail__item .teacher .img {
          width: 93px;
          position: relative;
          margin-right: 5px; }
          .ten-colors__detail__item .teacher .img img {
            position: absolute;
            top: 50%;
            left: 0;
            transform: translate(0, -50%);
            width: 93px; }
            @media screen and (max-width: 767px) {
              .ten-colors__detail__item .teacher .img img {
                position: static;
                transform: translate(0, 0); } }
        .ten-colors__detail__item .teacher .txt .line1 {
          font-size: 12px;
          border-bottom: 1px solid #aaa;
          padding-bottom: 2px;
          margin-bottom: 2px; }
        .ten-colors__detail__item .teacher .txt .line2 {
          font-size: 14px; }
      .ten-colors__detail__item .arrow img {
        width: 9px; }
      .ten-colors__detail__item.item-law .ttl {
        border-color: #c13d31;
        color: #c13d31; }
      .ten-colors__detail__item.item-business .ttl {
        border-color: #ea5504;
        color: #ea5504; }
      .ten-colors__detail__item.item-economics .ttl {
        border-color: #f08300;
        color: #f08300; }
      .ten-colors__detail__item.item-foreign .ttl {
        border-color: #f6ac19;
        color: #f6ac19; }
      .ten-colors__detail__item.item-human .ttl {
        border-color: #e95471;
        color: #e95471; }
      .ten-colors__detail__item.item-urban .ttl {
        border-color: #00a9a5;
        color: #00a9a5; }
      .ten-colors__detail__item.item-information .ttl {
        border-color: #8c8c8c;
        color: #8c8c8c; }
      .ten-colors__detail__item.item-sci_tech .ttl {
        border-color: #005083;
        color: #005083; }
      .ten-colors__detail__item.item-agrobiol .ttl {
        border-color: #00a95f;
        color: #00a95f; }
      .ten-colors__detail__item.item-pharmacy .ttl {
        border-color: #6e60a8;
        color: #6e60a8; }
    .ten-colors__detail__other {
      text-align: left;
      margin-bottom: 10px; }
      .ten-colors__detail__other img {
        width: 150px; }
    .ten-colors__detail .tab_box .btn_area .tab_btn {
      text-align: left;
      cursor: pointer;
      transition: all 0.2s ease 0s; }
      .ten-colors__detail .tab_box .btn_area .tab_btn img {
        width: 150px; }
      .ten-colors__detail .tab_box .btn_area .tab_btn.tab_btn-prev {
        position: absolute;
        bottom: 12px;
        left: 0; }
        @media screen and (max-width: 767px) {
          .ten-colors__detail .tab_box .btn_area .tab_btn.tab_btn-prev {
            position: fixed;
            bottom: 32px;
            left: 10px; } }
      .ten-colors__detail .tab_box .btn_area .tab_btn.tab_btn-next {
        position: absolute;
        bottom: 12px;
        right: 0; }
        @media screen and (max-width: 767px) {
          .ten-colors__detail .tab_box .btn_area .tab_btn.tab_btn-next {
            position: fixed;
            bottom: 32px;
            right: 10px; } }
      .ten-colors__detail .tab_box .btn_area .tab_btn.active {
        display: none; }
    .ten-colors__detail .tab_box .panel_area .tab_panel {
      display: none; }
      .ten-colors__detail .tab_box .panel_area .tab_panel.active {
        display: block; }
  .ten-colors .modal__wrapper {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 120;
    width: 100%;
    height: 100%; }
    .ten-colors .modal__wrapper .modal__layer {
      height: 100%;
      background: rgba(50, 50, 50, 0.5);
      cursor: pointer; }
    .ten-colors .modal__wrapper .modal__container {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      width: 1037px;
      height: 662px;
      padding: 40px 90px;
      background: url(../images/ten_colors_book.png) no-repeat center/cover;
      color: #000; }
      @media screen and (max-width: 767px) {
        .ten-colors .modal__wrapper .modal__container {
          width: 90%;
          height: 90%;
          padding: 30px 0 45px 20px; } }
      .ten-colors .modal__wrapper .modal__container .modal__inner {
        position: relative;
        height: 100%;
        /* モーダルを閉じるボタン */ }
        @media screen and (max-width: 767px) {
          .ten-colors .modal__wrapper .modal__container .modal__inner {
            overflow: auto;
            padding-right: 20px; } }
        .ten-colors .modal__wrapper .modal__container .modal__inner .modal__close {
          position: absolute;
          top: -90px;
          right: -140px;
          cursor: pointer;
          transition: opacity 0.6s; }
          @media screen and (max-width: 767px) {
            .ten-colors .modal__wrapper .modal__container .modal__inner .modal__close {
              display: none; } }
          .ten-colors .modal__wrapper .modal__container .modal__inner .modal__close:hover {
            opacity: 0.7; }
          .ten-colors .modal__wrapper .modal__container .modal__inner .modal__close img {
            width: 49px; }
      .ten-colors .modal__wrapper .modal__container .modal__close-sp {
        display: none; }
        @media screen and (max-width: 767px) {
          .ten-colors .modal__wrapper .modal__container .modal__close-sp {
            display: flex;
            justify-content: center;
            align-items: center;
            position: absolute;
            left: 50%;
            bottom: -20px;
            right: auto;
            top: auto;
            transform: translate(-50%, 0);
            background: rgba(0, 0, 0, 0.7);
            border: 1px solid #fff;
            border-radius: 5px;
            color: #fff;
            font-size: 14px;
            width: 198px;
            height: 34px; } }
    .ten-colors .modal__wrapper#modal_information .ten-colors__detail__item .ttl {
      width: 220px; }
    .ten-colors .modal__wrapper#modal_information .ten-colors__detail__item .question {
      width: 387px; }
    .ten-colors .modal__wrapper#modal_sci_tech .tab_panel-2 .ten-colors__detail__item .ttl {
      width: 250px; }
    .ten-colors .modal__wrapper#modal_sci_tech .tab_panel-2 .ten-colors__detail__item .question {
      width: 357px; }

.campus-map {
  padding: 90px;
  text-align: center;
  background: #f2f2f2;
  /*タブ実装*/
  /* モーダル本体 */ }
  @media screen and (max-width: 767px) {
    .campus-map {
      padding: 40px 10px; } }
  .campus-map__ttl {
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
    color: #a01e28;
    font-size: 43px;
    margin-bottom: 60px; }
    @media screen and (max-width: 767px) {
      .campus-map__ttl {
        font-size: 27px;
        margin-bottom: 20px; } }
  .campus-map .tab_box .btn_area {
    display: -webkit-box;
    display: flex;
    gap: 13px; }
    @media screen and (max-width: 767px) {
      .campus-map .tab_box .btn_area {
        gap: 5px; } }
    .campus-map .tab_box .btn_area .tab_btn2 {
      width: calc((100% - 26px) / 3);
      padding: 8px 0;
      color: #fff;
      background: #b3b3b3;
      font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
      font-weight: bold;
      font-size: 25px;
      text-align: center;
      cursor: pointer;
      transition: all 0.2s ease 0s;
      border-radius: 10px 10px 0 0; }
      @media screen and (max-width: 767px) {
        .campus-map .tab_box .btn_area .tab_btn2 {
          width: calc((100% - 10px) / 3);
          font-size: 15px;
          line-height: 1.3;
          padding: 8px 0; } }
      .campus-map .tab_box .btn_area .tab_btn2.active {
        background: #a01e28; }
  .campus-map .tab_box .panel_area {
    background: #fff;
    padding: 40px 60px 30px;
    border-radius: 10px; }
    @media screen and (max-width: 767px) {
      .campus-map .tab_box .panel_area {
        padding: 15px 0 0; } }
    .campus-map .tab_box .panel_area .lead {
      color: #a01e28;
      font-size: 18px;
      margin-bottom: 35px; }
      @media screen and (max-width: 767px) {
        .campus-map .tab_box .panel_area .lead {
          font-size: 12px;
          margin-bottom: 15px; } }
    .campus-map .tab_box .panel_area .tab_panel2 {
      display: none; }
      .campus-map .tab_box .panel_area .tab_panel2.active {
        display: block; }
      .campus-map .tab_box .panel_area .tab_panel2 .grid {
        display: grid;
        grid-template-columns: 67% auto;
        grid-template-rows: 1fr auto auto;
        grid-column-gap: 22px;
        grid-row-gap: 0px; }
        @media screen and (max-width: 767px) {
          .campus-map .tab_box .panel_area .tab_panel2 .grid {
            display: flex;
            flex-direction: column; } }
        @media screen and (max-width: 767px) {
          .campus-map .tab_box .panel_area .tab_panel2 .grid .map {
            order: 0;
            padding: 0 30px; } }
        .campus-map .tab_box .panel_area .tab_panel2 .grid .facility {
          background: #a01e28;
          color: #fff;
          text-align: left;
          padding: 25px; }
          @media screen and (max-width: 767px) {
            .campus-map .tab_box .panel_area .tab_panel2 .grid .facility {
              order: 2; } }
          .campus-map .tab_box .panel_area .tab_panel2 .grid .facility .ttl {
            text-align: center;
            margin-bottom: 20px;
            font-size: 18px; }
            @media screen and (max-width: 767px) {
              .campus-map .tab_box .panel_area .tab_panel2 .grid .facility .ttl {
                font-size: 12px; } }
          @media screen and (max-width: 767px) {
            .campus-map .tab_box .panel_area .tab_panel2 .grid .facility__list-wrap {
              display: flex; } }
          .campus-map .tab_box .panel_area .tab_panel2 .grid .facility__list {
            margin: 0; }
            @media screen and (max-width: 767px) {
              .campus-map .tab_box .panel_area .tab_panel2 .grid .facility__list {
                width: 50%; } }
            .campus-map .tab_box .panel_area .tab_panel2 .grid .facility__list > li {
              position: relative;
              padding-left: 28px;
              font-size: 15px;
              line-height: 1.5; }
              @media screen and (max-width: 767px) {
                .campus-map .tab_box .panel_area .tab_panel2 .grid .facility__list > li {
                  font-size: 12px;
                  margin-bottom: 8px;
                  padding-left: 25px; } }
              .campus-map .tab_box .panel_area .tab_panel2 .grid .facility__list > li .modal__trigger {
                color: #f8ee71;
                text-decoration: underline;
                cursor: pointer; }
              .campus-map .tab_box .panel_area .tab_panel2 .grid .facility__list > li .number {
                position: absolute;
                left: 0;
                top: 4px;
                background: #fff;
                color: #a01e28;
                display: flex;
                justify-content: center;
                align-items: center;
                font-size: 13px;
                line-height: 1;
                width: 18px;
                height: 18px;
                text-align: center;
                letter-spacing: 0em; }
                @media screen and (max-width: 767px) {
                  .campus-map .tab_box .panel_area .tab_panel2 .grid .facility__list > li .number {
                    font-size: 12px;
                    top: 0;
                    width: 17px;
                    height: 17px; } }
              .campus-map .tab_box .panel_area .tab_panel2 .grid .facility__list > li .fs-s {
                font-size: 80%; }
                @media screen and (max-width: 767px) {
                  .campus-map .tab_box .panel_area .tab_panel2 .grid .facility__list > li .fs-s {
                    font-size: 90%; } }
              .campus-map .tab_box .panel_area .tab_panel2 .grid .facility__list > li .child__list {
                margin: 0; }
                @media screen and (max-width: 767px) {
                  .campus-map .tab_box .panel_area .tab_panel2 .grid .facility__list > li .child__list {
                    padding-top: 8px; } }
              .campus-map .tab_box .panel_area .tab_panel2 .grid .facility__list > li.has-trigger .number {
                background: #f8ee71; }
        .campus-map .tab_box .panel_area .tab_panel2 .grid .faculty {
          grid-area: 2 / 1 / 3 / 3;
          padding-top: 40px; }
          @media screen and (max-width: 767px) {
            .campus-map .tab_box .panel_area .tab_panel2 .grid .faculty {
              order: 1;
              padding-top: 10px; } }
          .campus-map .tab_box .panel_area .tab_panel2 .grid .faculty__list {
            display: flex;
            justify-content: center;
            gap: 20px; }
            @media screen and (max-width: 767px) {
              .campus-map .tab_box .panel_area .tab_panel2 .grid .faculty__list {
                flex-wrap: wrap;
                gap: 0 10px;
                margin-bottom: 20px; } }
          .campus-map .tab_box .panel_area .tab_panel2 .grid .faculty__item {
            font-size: 18px; }
            @media screen and (max-width: 767px) {
              .campus-map .tab_box .panel_area .tab_panel2 .grid .faculty__item {
                font-size: 12px; } }
            .campus-map .tab_box .panel_area .tab_panel2 .grid .faculty__item.item-law span {
              color: #e60012; }
            .campus-map .tab_box .panel_area .tab_panel2 .grid .faculty__item.item-business span {
              color: #ea5504; }
            .campus-map .tab_box .panel_area .tab_panel2 .grid .faculty__item.item-economics span {
              color: #f08300; }
            .campus-map .tab_box .panel_area .tab_panel2 .grid .faculty__item.item-foreign span {
              color: #f6ac19; }
            .campus-map .tab_box .panel_area .tab_panel2 .grid .faculty__item.item-human span {
              color: #e95471; }
            .campus-map .tab_box .panel_area .tab_panel2 .grid .faculty__item.item-urban span {
              color: #00a9a5; }
            .campus-map .tab_box .panel_area .tab_panel2 .grid .faculty__item.item-information span {
              color: #8c8c8c; }
            .campus-map .tab_box .panel_area .tab_panel2 .grid .faculty__item.item-sci_tech span {
              color: #005083; }
            .campus-map .tab_box .panel_area .tab_panel2 .grid .faculty__item.item-agrobiol span {
              color: #00a95f; }
            .campus-map .tab_box .panel_area .tab_panel2 .grid .faculty__item.item-pharmacy span {
              color: #6e60a8; }
        .campus-map .tab_box .panel_area .tab_panel2 .grid .map360 {
          grid-area: 3 / 1 / 4 / 3;
          display: flex;
          justify-content: center;
          padding: 10px 0 20px; }
          @media screen and (max-width: 767px) {
            .campus-map .tab_box .panel_area .tab_panel2 .grid .map360 {
              order: 3;
              background: #a01e28;
              padding: 10px 0 30px; } }
          .campus-map .tab_box .panel_area .tab_panel2 .grid .map360 a {
            display: block;
            background: #a01e28;
            color: #fff;
            text-align: center;
            padding: 7px 40px;
            border-radius: 100vh; }
            @media screen and (max-width: 767px) {
              .campus-map .tab_box .panel_area .tab_panel2 .grid .map360 a {
                background: #fff;
                color: #a01e28; } }
  .campus-map .modal__wrapper {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 120;
    width: 100%;
    height: 100%; }
    .campus-map .modal__wrapper .modal__layer {
      height: 100%;
      background: rgba(50, 50, 50, 0.5);
      cursor: pointer; }
    .campus-map .modal__wrapper .modal__container {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      width: 634px; }
      @media screen and (max-width: 767px) {
        .campus-map .modal__wrapper .modal__container {
          width: 90%; } }
      .campus-map .modal__wrapper .modal__container .modal__inner {
        position: relative;
        height: 100%; }
        @media screen and (max-width: 767px) {
          .campus-map .modal__wrapper .modal__container .modal__inner {
            overflow: auto; } }
        .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail {
          background: #fff;
          text-align: left; }
          @media screen and (max-width: 767px) {
            .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail {
              font-size: 14px; } }
          .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail .header {
            background-color: #a01e28;
            color: #fff;
            position: relative;
            padding: 10px;
            padding-right: 30px;
            display: flex;
            gap: 10px; }
            @media screen and (max-width: 767px) {
              .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail .header {
                line-height: 1.3;
                padding: 8px;
                padding-right: 30px; } }
            .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail .header .number {
              background: #fff;
              color: #a01e28;
              display: flex;
              justify-content: center;
              align-items: center;
              aspect-ratio: 1 / 1;
              width: 30px;
              height: auto;
              text-align: center; }
              @media screen and (max-width: 767px) {
                .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail .header .number {
                  width: 18px;
                  height: 18px;
                  display: flex; } }
            .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail .header .modal__close {
              position: absolute;
              right: 10px;
              top: 50%;
              width: 30px;
              height: 30px;
              transform: translate(0, -50%);
              cursor: pointer;
              transition: opacity 0.6s; }
              @media screen and (max-width: 767px) {
                .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail .header .modal__close {
                  width: 22px;
                  height: 22px;
                  right: 6px; } }
              .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail .header .modal__close-inner {
                position: relative;
                width: 100%;
                height: 100%; }
                .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail .header .modal__close-inner .line-1,
                .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail .header .modal__close-inner .line-2 {
                  position: absolute;
                  left: 50%;
                  top: 50%;
                  width: 100%;
                  height: 1px;
                  background: #fff; }
                .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail .header .modal__close-inner .line-1 {
                  transform: translate(-50%, -50%) rotate(45deg); }
                .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail .header .modal__close-inner .line-2 {
                  transform: translate(-50%, -50%) rotate(-45deg); }
          .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail .cnt {
            padding: 30px; }
            @media screen and (max-width: 767px) {
              .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail .cnt {
                padding: 20px;
                max-height: calc(100vh - 60px);
                overflow: auto; } }
            .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail .cnt .img {
              margin-bottom: 10px;
              display: flex;
              gap: 15px; }
              @media screen and (max-width: 767px) {
                .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail .cnt .img {
                  flex-direction: column; } }
              .campus-map .modal__wrapper .modal__container .modal__inner .modal__content .facility__detail .cnt .img img {
                min-width: 0; }

.kokogasugoi-meijo {
  text-align: center;
  padding: 90px; }
  @media screen and (max-width: 767px) {
    .kokogasugoi-meijo {
      padding: 40px 20px; } }
  .kokogasugoi-meijo__ttl {
    display: flex;
    flex-direction: column;
    align-items: center;
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
    color: #a01e28;
    font-weight: 100;
    margin-bottom: 50px;
    line-height: 1.2;
    position: relative; }
    @media screen and (max-width: 767px) {
      .kokogasugoi-meijo__ttl {
        margin-bottom: 20px; } }
    .kokogasugoi-meijo__ttl .line1 {
      font-size: 60px;
      position: relative; }
      @media screen and (max-width: 767px) {
        .kokogasugoi-meijo__ttl .line1 {
          font-size: 30px; } }
    .kokogasugoi-meijo__ttl .line2 {
      font-size: 94px; }
      @media screen and (max-width: 767px) {
        .kokogasugoi-meijo__ttl .line2 {
          font-size: 49px; } }
  .kokogasugoi-meijo__list {
    display: flex;
    flex-wrap: wrap;
    gap: 30px; }
    @media screen and (max-width: 767px) {
      .kokogasugoi-meijo__list {
        gap: 6px; } }
  .kokogasugoi-meijo__item {
    width: calc((100% - 60px) / 3); }
    @media screen and (max-width: 767px) {
      .kokogasugoi-meijo__item {
        width: calc((100% - 6px) / 2); } }
  .kokogasugoi-meijo .note-list > li {
    text-align: left;
    font-size: 12px;
    line-height: 1.25;
    position: relative;
    padding-left: 28px;
    margin-bottom: 10px; }
    @media screen and (max-width: 767px) {
      .kokogasugoi-meijo .note-list > li {
        font-size: 10px; } }
    .kokogasugoi-meijo .note-list > li .kome {
      position: absolute;
      left: 0;
      top: 0; }

.campus-life {
  padding: 90px 0;
  text-align: center;
  background: #f2f2f2;
  position: relative; }
  @media screen and (max-width: 767px) {
    .campus-life {
      padding: 40px 0; } }
  .campus-life__ttl {
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
    color: #a01e28;
    font-size: 43px;
    margin-bottom: 60px; }
  .campus-life__list {
    display: flex;
    flex-wrap: wrap;
    gap: 30px; }
    @media screen and (max-width: 767px) {
      .campus-life__list {
        padding: 0 20px;
        gap: 12px; } }
    .campus-life__list > li {
      width: calc((100% - 60px) / 3); }
      @media screen and (max-width: 767px) {
        .campus-life__list > li {
          width: 100%; } }
      .campus-life__list > li a {
        display: block; }

.access-sec {
  padding: 90px; }
  @media screen and (max-width: 767px) {
    .access-sec {
      padding: 40px 20px; } }
  .access-sec .ac .ac-label {
    cursor: pointer;
    position: relative;
    transition: all 0.3s ease;
    max-width: 722px;
    margin: 0 auto;
    background: #a01e28;
    color: #fff;
    text-align: center;
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
    border-radius: 10px;
    padding: 20px;
    margin-bottom: 50px; }
    @media screen and (max-width: 767px) {
      .access-sec .ac .ac-label {
        padding: 15px; } }
    .access-sec .ac .ac-label:hover {
      opacity: 0.7; }
    .access-sec .ac .ac-label .label {
      font-size: 43px;
      margin: 0; }
      @media screen and (max-width: 767px) {
        .access-sec .ac .ac-label .label {
          font-size: 30px; } }
    .access-sec .ac .ac-label .arrow {
      position: absolute;
      left: 30px;
      top: 50%;
      transform: translate(0, -50%);
      transition: all 0.3s ease 0s; }
      .access-sec .ac .ac-label .arrow img {
        width: 30px; }
      .access-sec .ac .ac-label .arrow.open {
        transform: translate(0, -50%) rotate(-90deg); }
  .access-sec .ac .ac-content {
    display: none;
    padding-bottom: 100px; }
    @media screen and (max-width: 767px) {
      .access-sec .ac .ac-content {
        padding-bottom: 20px; } }
  .access-sec__map {
    text-align: center;
    padding-bottom: 70px; }
    .access-sec__map img {
      max-width: 1081px; }
      @media screen and (max-width: 767px) {
        .access-sec__map img {
          max-width: 100%; } }
  .access-sec__list {
    display: flex;
    gap: 30px; }
    @media screen and (max-width: 767px) {
      .access-sec__list {
        flex-direction: column; } }
  .access-sec__item {
    width: calc((100% - 60px) / 3);
    display: flex;
    flex-direction: column; }
    @media screen and (max-width: 767px) {
      .access-sec__item {
        width: 100%; } }
    .access-sec__item .head {
      background: #a01e28;
      color: #fff;
      text-align: center;
      border-radius: 10px 10px 0 0; }
      .access-sec__item .head h3 {
        margin: 0;
        font-size: 24px;
        padding: 20px; }
    .access-sec__item .body {
      background: #f2f2f2;
      padding: 25px 30px;
      border-radius: 0 0 10px 10px;
      flex: 1 0 auto;
      display: flex;
      flex-direction: column;
      justify-content: space-between; }
      .access-sec__item .body .unit-wrap {
        padding-bottom: 20px; }
      .access-sec__item .body .unit {
        border-top: 1px solid #000;
        padding: 15px 0; }
        .access-sec__item .body .unit:first-child {
          border-top: none;
          padding-top: 0; }
        .access-sec__item .body .unit ul {
          display: flex;
          flex-wrap: wrap;
          gap: 0 15px; }
      .access-sec__item .body .more a {
        color: #a01e28;
        font-size: 20px;
        font-weight: bold;
        text-align: center;
        display: block;
        background: #fff;
        padding: 10px;
        border-radius: 100vh;
        box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.5); }
  .access-sec .afar {
    text-align: center; }
    .access-sec .afar-head {
      background: #a01e28;
      color: #fff;
      border-radius: 10px 10px 0 0; }
      .access-sec .afar-head h3 {
        margin: 0;
        font-size: 30px;
        padding: 20px; }
        @media screen and (max-width: 767px) {
          .access-sec .afar-head h3 {
            font-size: 22px; } }
    .access-sec .afar-body {
      background: #f2f2f2;
      padding: 25px 30px 40px;
      border-radius: 0 0 10px 10px;
      flex: 1 0 auto;
      display: flex;
      flex-direction: column;
      justify-content: space-between; }
      @media screen and (max-width: 767px) {
        .access-sec .afar-body {
          padding: 20px 10px 30px;
          font-size: 15px; } }
    .access-sec .afar__txt {
      line-height: 2; }
      @media screen and (max-width: 767px) {
        .access-sec .afar__txt {
          line-height: 1.75; }
          .access-sec .afar__txt span {
            font-size: 14px;
            line-height: 1.64;
            display: inline-block;
            margin-top: 20px; } }
    .access-sec .afar__btn a {
      display: inline-block;
      font-size: 24px;
      font-weight: bold;
      text-align: center;
      background: #fff;
      padding: 10px 40px;
      border-radius: 100vh;
      box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.5); }
      @media screen and (max-width: 767px) {
        .access-sec .afar__btn a {
          font-size: 20px; } }

.doc-request {
  background: #a01e28;
  color: #fff;
  padding: 60px 60px 90px;
  text-align: center; }
  @media screen and (max-width: 767px) {
    .doc-request {
      padding: 30px 20px; } }
  @media screen and (max-width: 767px) {
    .doc-request__lead {
      font-size: 20px; } }
  .doc-request__btn {
    padding-top: 40px; }
    @media screen and (max-width: 767px) {
      .doc-request__btn {
        padding-top: 20px; } }
    .doc-request__btn a {
      display: inline-block;
      min-width: 328px;
      color: #a01e28;
      font-size: 24px;
      font-weight: bold;
      text-align: center;
      background: #fff;
      padding: 5px 40px;
      border-radius: 100vh;
      box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.5); }

.checkpoint {
  /* モーダル本体 */ }
  .checkpoint__badge {
    cursor: pointer;
    transition: all 0.3s ease 0s;
    position: fixed;
    z-index: 110;
    right: 0px;
    bottom: 100px; }
    @media screen and (max-width: 767px) {
      .checkpoint__badge {
        right: 10px;
        bottom: auto;
        top: 70px;
        width: 71px;
        z-index: 90; } }
    .checkpoint__badge:hover {
      opacity: 0.7; }
    .checkpoint__badge img {
      width: 277px; }
      @media screen and (max-width: 767px) {
        .checkpoint__badge img {
          width: 390px; } }
  .checkpoint__detail {
    background-color: #a01e28;
    text-align: center;
    padding: 70px; }
    @media screen and (max-width: 767px) {
      .checkpoint__detail {
        padding: 40px 20px; } }
    .checkpoint__detail__ttl-1 {
      display: inline-block;
      position: relative;
      margin-bottom: 50px;
      padding-left: 130px; }
      @media screen and (max-width: 767px) {
        .checkpoint__detail__ttl-1 {
          padding-left: 0;
          margin-bottom: 30px; } }
      .checkpoint__detail__ttl-1 img {
        width: 590px; }
        @media screen and (max-width: 767px) {
          .checkpoint__detail__ttl-1 img {
            width: 100%; } }
        .checkpoint__detail__ttl-1 img.check {
          width: 105px;
          position: absolute;
          right: -120px;
          top: 0; }
    .checkpoint__detail__ttl-2 {
      margin-bottom: 30px; }
      @media screen and (max-width: 767px) {
        .checkpoint__detail__ttl-2 {
          margin-bottom: 20px; } }
      .checkpoint__detail__ttl-2 img {
        width: 1030px; }
    .checkpoint__detail__osusume-plan {
      max-width: 900px;
      margin: 0 auto 88px;
      padding: 40px 60px;
      background: url(../images/welcome-bg.jpg) no-repeat center/cover; }
      @media screen and (max-width: 767px) {
        .checkpoint__detail__osusume-plan {
          margin-bottom: 40px;
          padding: 30px 0; } }
      .checkpoint__detail__osusume-plan .ttl {
        font-size: 30px;
        font-weight: bold;
        color: #a01e28;
        margin-bottom: 10px; }
        @media screen and (max-width: 767px) {
          .checkpoint__detail__osusume-plan .ttl {
            font-size: 24px;
            line-height: 1.04;
            margin-bottom: 15px; } }
      .checkpoint__detail__osusume-plan .lead {
        font-size: 17px;
        line-height: 2;
        margin-bottom: 30px; }
        @media screen and (max-width: 767px) {
          .checkpoint__detail__osusume-plan .lead {
            font-size: 3vw;
            line-height: 1.58; } }
      .checkpoint__detail__osusume-plan .plan {
        margin-bottom: 20px; }
        @media screen and (max-width: 767px) {
          .checkpoint__detail__osusume-plan .plan {
            padding: 0 25px; } }
        .checkpoint__detail__osusume-plan .plan img {
          width: 900px; }
      .checkpoint__detail__osusume-plan .note {
        color: #a01e28;
        font-size: 17px; }
        @media screen and (max-width: 767px) {
          .checkpoint__detail__osusume-plan .note {
            font-size: 3vw;
            line-height: 1.58; } }
    .checkpoint__detail__ttl-3 {
      margin-bottom: 30px; }
      .checkpoint__detail__ttl-3 img {
        width: 1030px; }
    .checkpoint__detail__osusume-time {
      max-width: 900px;
      margin: 0 auto;
      background: url(../images/welcome-bg.jpg) no-repeat center/cover;
      padding: 40px 60px 60px; }
      @media screen and (max-width: 767px) {
        .checkpoint__detail__osusume-time {
          padding: 20px 0; } }
      .checkpoint__detail__osusume-time .ttl {
        font-size: 30px;
        color: #a01e28;
        margin-bottom: 5px;
        font-weight: bold; }
        @media screen and (max-width: 767px) {
          .checkpoint__detail__osusume-time .ttl {
            font-size: 24px;
            line-height: 1.1;
            margin-bottom: 20px; } }
      .checkpoint__detail__osusume-time .ttl2 {
        font-size: 30px;
        color: #a01e28;
        margin-bottom: 5px;
        font-weight: bold; }
        @media screen and (max-width: 767px) {
          .checkpoint__detail__osusume-time .ttl2 {
            font-size: 20px;
            line-height: 1.1; } }
      .checkpoint__detail__osusume-time .body {
        font-size: 17px; }
        @media screen and (max-width: 767px) {
          .checkpoint__detail__osusume-time .body {
            font-size: 2.75vw; } }
        .checkpoint__detail__osusume-time .body span {
          font-size: 23px;
          color: #a01e28;
          font-weight: bold; }
          @media screen and (max-width: 767px) {
            .checkpoint__detail__osusume-time .body span {
              font-size: 18px; } }
        .checkpoint__detail__osusume-time .body span.fs-l {
          font-size: 23px;
          color: #000;
          font-weight: bold; }
          @media screen and (max-width: 767px) {
            .checkpoint__detail__osusume-time .body span.fs-l {
              font-size: 14px; } }
      .checkpoint__detail__osusume-time .img {
        background: #fff;
        padding: 30px 0;
        margin: 40px 0; }
        @media screen and (max-width: 767px) {
          .checkpoint__detail__osusume-time .img {
            padding: 20px;
            margin: 40px 20px; } }
        .checkpoint__detail__osusume-time .img img {
          width: 704px; }
      .checkpoint__detail__osusume-time .line {
        margin-top: 30px; }
        @media screen and (max-width: 767px) {
          .checkpoint__detail__osusume-time .line {
            padding: 0 20px; } }
        .checkpoint__detail__osusume-time .line a {
          display: flex;
          align-items: center;
          background: #00b737 url(../images/checkpoint_line-icon.svg) no-repeat right 20px center/105px auto;
          color: #fff;
          width: 662px;
          margin: 0 auto;
          border-radius: 10px;
          font-size: 26px;
          line-height: 1.38;
          height: 124px;
          padding-left: 27px; }
          @media screen and (max-width: 767px) {
            .checkpoint__detail__osusume-time .line a {
              background: #00b737 url(../images/checkpoint_line-icon.svg) no-repeat right 15px center/56px auto;
              font-size: 3.5vw;
              line-height: 1.36;
              width: 100%;
              height: 72px;
              border-radius: 6px;
              text-align: left;
              padding-left: 17px; } }
        .checkpoint__detail__osusume-time .line img {
          width: 662px; }
  .checkpoint .modal__wrapper {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 120;
    width: 100%;
    height: 100%; }
    .checkpoint .modal__wrapper .modal__layer {
      height: 100%;
      background: rgba(255, 255, 255, 0.7);
      cursor: pointer; }
    .checkpoint .modal__wrapper .modal__container {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      width: 95%;
      max-width: 1174px;
      background: #fff;
      color: #000;
      height: 95%;
      overflow: auto;
      box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3); }
      @media screen and (max-width: 767px) {
        .checkpoint .modal__wrapper .modal__container {
          width: 90%;
          height: 90%; } }
      .checkpoint .modal__wrapper .modal__container .modal__inner {
        position: relative;
        height: 100%;
        /* モーダルを閉じるボタン */ }
        .checkpoint .modal__wrapper .modal__container .modal__inner .modal__close {
          color: #fff;
          margin-top: 40px;
          cursor: pointer;
          transition: opacity 0.6s; }
          .checkpoint .modal__wrapper .modal__container .modal__inner .modal__close:hover {
            opacity: 0.7; }

/* ++++++++++++++++++++ 3次公開 ++++++++++++++++++++ */
.oc-thanks {
  border-radius: 10px;
  box-shadow: 7px 7px 5px rgba(0, 0, 0, 0.5);
  background: #fff;
  padding: 60px 30px;
  text-align: center;
  max-width: 900px;
  margin: 0 auto; }
  @media screen and (max-width: 767px) {
    .oc-thanks {
      padding: 40px 20px;
      margin: 32px 10px; } }
  .oc-thanks__ttl {
    color: #a01e28;
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
    margin-bottom: 30px;
    font-size: 35px; }
    @media screen and (max-width: 767px) {
      .oc-thanks__ttl {
        flex-direction: column;
        gap: 0;
        margin-bottom: 20px;
        font-size: 24px; } }
  @media screen and (max-width: 767px) {
    .oc-thanks__body {
      font-size: 14px; } }
  .oc-thanks__name {
    color: #a01e28;
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
    font-size: 20px;
    font-weight: bold; }
    @media screen and (max-width: 767px) {
      .oc-thanks__name {
        flex-direction: column;
        gap: 0;
        font-size: 20px; } }

.ex-movie {
  background: #ffffc3;
  padding: 90px 0; }
  @media screen and (max-width: 767px) {
    .ex-movie {
      padding: 40px 20px; } }
  .ex-movie-inner {
    max-width: 960px;
    margin: 0 auto; }
  .ex-movie__ttl {
    text-align: center;
    color: #a01e28;
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
    margin-bottom: 30px;
    font-size: 43px; }
    @media screen and (max-width: 767px) {
      .ex-movie__ttl {
        flex-direction: column;
        gap: 0;
        margin-bottom: 20px;
        font-size: 27px; } }
  .ex-movie__list {
    display: flex;
    gap: 40px; }
    @media screen and (max-width: 767px) {
      .ex-movie__list {
        flex-direction: column;
        gap: 30px; } }
  .ex-movie__item {
    width: calc((100% - 40px) / 2); }
    @media screen and (max-width: 767px) {
      .ex-movie__item {
        width: 100%; } }
    .ex-movie__item .img {
      margin-bottom: 20px; }
    .ex-movie__item .movie {
      margin-bottom: 20px; }
      .ex-movie__item .movie iframe {
        width: 100%;
        height: auto;
        aspect-ratio: 16/9; }
    .ex-movie__item .txt {
      font-size: 19px;
      line-height: 1.5;
      font-weight: bold;
      text-align: center; }
      @media screen and (max-width: 767px) {
        .ex-movie__item .txt {
          font-size: 14px; } }
  .ex-movie-guide {
    text-align: center;
    padding-top: 72px; }
    @media screen and (max-width: 767px) {
      .ex-movie-guide {
        padding-top: 32px; } }
    .ex-movie-guide .line-1 {
      font-size: 25px;
      margin-bottom: 24px;
      font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
      font-weight: 600; }
      @media screen and (max-width: 767px) {
        .ex-movie-guide .line-1 {
          font-size: 18px;
          margin-bottom: 16px; } }
    .ex-movie-guide .line-2 {
      font-size: 14px; }
    .ex-movie-guide .btn {
      margin-bottom: 24px; }
      @media screen and (max-width: 767px) {
        .ex-movie-guide .btn {
          margin-bottom: 16px; } }
      .ex-movie-guide .btn a {
        display: block; }
        .ex-movie-guide .btn a img {
          width: 772px; }

.sns-sec {
  padding: 90px 0; }
  @media screen and (max-width: 767px) {
    .sns-sec {
      padding: 40px 20px; } }
  .sns-sec-inner {
    max-width: 1023px;
    margin: 0 auto; }
  .sns-sec__ttl {
    text-align: center;
    color: #a01e28;
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
    margin-bottom: 30px;
    font-size: 43px; }
    @media screen and (max-width: 767px) {
      .sns-sec__ttl {
        flex-direction: column;
        gap: 0;
        margin-bottom: 20px;
        font-size: 27px; } }
  .sns-sec-cnt {
    border: 2px solid #902b2d;
    border-radius: 10px;
    text-align: center;
    padding: 55px; }
    @media screen and (max-width: 767px) {
      .sns-sec-cnt {
        padding: 32px 20px; } }
  .sns-sec__ttl-2 {
    font-size: 27px;
    margin-bottom: 32px; }
    @media screen and (max-width: 767px) {
      .sns-sec__ttl-2 {
        font-size: 20px; } }
  .sns-sec__list {
    display: flex;
    gap: 100px; }
    @media screen and (max-width: 767px) {
      .sns-sec__list {
        flex-direction: column;
        gap: 40px;
        margin: 0; } }
    .sns-sec__list > li {
      width: calc((100% - 100px) / 2); }
      @media screen and (max-width: 767px) {
        .sns-sec__list > li {
          width: 100%; } }
      .sns-sec__list > li .icon {
        margin-bottom: 40px; }
        @media screen and (max-width: 767px) {
          .sns-sec__list > li .icon {
            margin-bottom: 24px; } }
        .sns-sec__list > li .icon img {
          height: 160px;
          width: auto; }
          @media screen and (max-width: 767px) {
            .sns-sec__list > li .icon img {
              height: 98px; } }
      @media screen and (max-width: 767px) {
        .sns-sec__list > li .btn img {
          width: 232px; } }

.page-ttl.photo-gallery {
  background: #a01e28;
  color: #fff;
  text-align: center;
  padding: 70px 0; }
  @media screen and (max-width: 767px) {
    .page-ttl.photo-gallery {
      padding: 20px 0; } }
  .page-ttl.photo-gallery .icon {
    margin-bottom: 10px; }
    .page-ttl.photo-gallery .icon img {
      width: 58px; }
      @media screen and (max-width: 767px) {
        .page-ttl.photo-gallery .icon img {
          width: 36px; } }
  .page-ttl.photo-gallery .txt {
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Noto Serif JP", serif;
    font-size: 40px;
    font-weight: 400;
    position: relative;
    z-index: 1; }
    @media screen and (max-width: 767px) {
      .page-ttl.photo-gallery .txt {
        font-size: 26px;
        line-height: 1.15; } }

.pg-gallery-inner {
  max-width: 926px;
  margin: 80px auto 150px; }
  @media screen and (max-width: 767px) {
    .pg-gallery-inner {
      margin: 40px auto 80px; } }

.pg-gallery__ttl {
  font-size: 27px;
  color: #a01e28;
  text-align: center;
  margin-bottom: 80px; }
  @media screen and (max-width: 767px) {
    .pg-gallery__ttl {
      font-size: 16px;
      margin-bottom: 40px; } }

.pg-gallery__list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px; }
  @media screen and (max-width: 767px) {
    .pg-gallery__list {
      padding: 0 10px;
      gap: 4px; } }

.pg-gallery__item {
  width: calc((100% - 20px) / 3); }
  @media screen and (max-width: 767px) {
    .pg-gallery__item {
      width: calc((100% - 8px) / 3); } }
  .pg-gallery__item a {
    display: block;
    aspect-ratio: 1 / 1; }
    .pg-gallery__item a img {
      object-fit: cover;
      width: 100%;
      height: 100%; }

.pg-gallery__back {
  text-align: center;
  margin-top: 60px; }
  @media screen and (max-width: 767px) {
    .pg-gallery__back {
      margin-top: 40px; } }
  .pg-gallery__back a {
    display: inline-block;
    width: 160px;
    background-color: #a01e28;
    color: #fff;
    border-radius: 21px;
    padding: 5px 0; }

.pg-body .lightbox {
  top: 50% !important;
  transform: translate(0, -50%);
  position: fixed !important;
  display: flex;
  flex-direction: column-reverse; }
  .pg-body .lightbox .lb-outerContainer {
    border-radius: 0; }
    .pg-body .lightbox .lb-outerContainer .lb-container {
      position: relative; }
      .pg-body .lightbox .lb-outerContainer .lb-container .lb-image {
        border: none;
        border-radius: 0; }
      .pg-body .lightbox .lb-outerContainer .lb-container .lb-nav a.lb-prev {
        background: url(../images/photo-gallery/left.svg) no-repeat center/16px auto;
        width: 16px;
        height: 27px;
        position: absolute;
        left: calc(50% - 40px);
        top: auto;
        bottom: -50px;
        opacity: 1; }
      .pg-body .lightbox .lb-outerContainer .lb-container .lb-nav a.lb-next {
        background: url(../images/photo-gallery/right.svg) no-repeat center/16px auto;
        width: 16px;
        height: 27px;
        position: absolute;
        right: calc(50% - 40px);
        top: auto;
        bottom: -50px;
        opacity: 1; }
  .pg-body .lightbox .lb-dataContainer {
    position: relative; }
    .pg-body .lightbox .lb-dataContainer .lb-details {
      display: none; }
    .pg-body .lightbox .lb-dataContainer .lb-close {
      display: block;
      width: 22px;
      height: 22px;
      background: url(../images/photo-gallery/close.svg) no-repeat center/contain;
      position: absolute;
      right: 0;
      top: -30px;
      opacity: 1; }

@-moz-document url-prefix() {}/* -------------------
  OBJECT FIT FOR IE
--------------------*/
.cover {
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover;'; }

/*# sourceMappingURL=../maps/index.css.map */
