@import url("https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300..800;1,300..800&display=swap");
/* reset CSS */
*,
::after,
::before {
  box-sizing: border-box;
}

section,
header,
footer,
nav,
h1,
h2,
h3,
h4,
h5,
h6,
form,
fieldset,
pre,
blockquote,
th,
td {
  margin: 0;
  padding: 0;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
}

input,
textarea {
  font-size: 100%;
  vertical-align: middle;
}

body,
div,
p,
address,
dl,
dt,
dd,
ul,
ol,
li {
  margin: 0;
  padding: 0;
}

img {
  display: inline-block;
  border: none;
  max-width: 100%;
  vertical-align: top;
}

table {
  border-collapse: collapse;
  border: none;
  border-spacing: 0;
  word-break: break-all;
}

input {
  line-height: 100%;
}

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

label {
  cursor: pointer;
}

address {
  font-style: normal;
}

article,
aside,
header,
hgroup,
footer,
nav,
section,
dialog,
figure {
  display: block;
}

audio,
canvas,
embed,
iframe,
img,
object,
svg,
video {
  display: block;
  max-width: 100%;
}

canvas,
img,
svg,
video {
  height: auto;
}

audio {
  width: 100%;
}

svg {
  overflow: hidden;
}

[type=checkbox],
[type=radio] {
  box-sizing: border-box;
  padding: 0;
}

:root {
  --10px: 0.625rem;
  --11px: 0.6875rem;
  --12px: 0.75rem;
  --13px: 0.8125rem;
  --14px: 0.875rem;
  --15px: 0.9375rem;
  --16px: 1rem;
  --17px: 1.0625rem;
  --18px: 1.125rem;
  --19px: 1.1875rem;
  --20px: 1.25rem;
  --22px: 1.375rem;
  --24px: 1.5rem;
  --26px: 1.625rem;
  --28px: 1.75rem;
  --30px: 1.875rem;
  --32px: 2rem;
  --36px: 2.25rem;
  --40px: 2.5rem;
  --48px: 3rem;
  --50px: 3.125rem;
  --60px: 3.75rem;
  --70px: 4.375rem;
  --text-2xs: clamp(0.625rem, 0.568rem + 0.24vw, 0.75rem);
  --text-xs: clamp(0.75rem, 0.693rem + 0.24vw, 0.875rem);
  --text-sm: clamp(0.813rem, 0.756rem + 0.24vw, 0.938rem);
  --text-md: clamp(0.875rem, 0.818rem + 0.24vw, 1rem);
  --text-lg: clamp(1rem, 0.943rem + 0.24vw, 1.125rem);
  --text-xl: clamp(1.125rem, 0.955rem + 0.73vw, 1.5rem);
  --text-2xl: clamp(1.5rem, 1.386rem + 0.48vw, 1.75rem);
  --text-3xl: clamp(1.75rem, 1.636rem + 0.48vw, 2rem);
  --text-4xl: clamp(2.375rem, 2.091rem + 1.21vw, 3rem);
  --text-5xl: clamp(2.5rem, 1.648rem + 3.64vw, 4.375rem);
  --font-sans-serif: "Noto Sans JP", sans-serif;
  --font-en: "Poppins", sans-serif;
  --font-mix: "Poppins", "Noto Sans JP", sans-serif;
  --font-normal: 400;
  --font-medium: 500;
  --font-bold: 700;
  --line-height-xs: 1.4;
  --line-height-sm: 1.5;
  --line-height-md: 1.6;
  --line-height-lg: 1.8;
  --line-height-xl: 2.2;
  --color-blue: #00acd7;
  --color-red-10: #ffe9e9;
  --color-red-20: #f86c6c;
  --color-red-30: #ff2d2d;
  --color-red-40: #d52828;
  --color-green-10: #daffd2;
  --color-white: #fff;
  --color-black: #000;
  --color-gray: #ccc;
  --color-gray-20: #f8f8f8;
  --color-gray-30: #f2f2f2;
  --color-gray-40: #c5c5c5;
  --color-gray-50: #b1b1b1;
  --color-gray-60: #919191;
  --color-gray-70: #777;
  --color-gray-80: #5e5f66;
  --color-gray-90: #47484d;
  --color-gray-dark: #ddd;
  --color-border: #ddd;
  --color-border-light: var(--color-gray-30);
  --color-border-dark: var(--color-gray-70);
  --color-input-border: var(--color-gray-60);
  --color-input-border-hover: var(--color-gray-80);
  --color-type: var(--color-black);
  --color-link: var(--color-black);
  --color-main-10-rgb: 241, 241, 255;
  --color-main-20-rgb: 232, 232, 255;
  --color-main-30-rgb: 116, 213, 244;
  --color-main-40-rgb: 65, 115, 196;
  --color-main-50-rgb: 39, 39, 235;
  --color-main-60-rgb: 0, 64, 151;
  --color-main-70-rgb: 12, 12, 129;
  --color-main-80-rgb: 60, 16, 94;
  --color-main-90-rgb: 10, 10, 61;
  --color-main-rgb: var(--color-main-60-rgb);
  --color-red-10-rgb: 255, 233, 233;
  --color-red-20-rgb: 248, 108, 108;
  --color-red-30-rgb: 255, 45, 45;
  --color-red-40-rgb: 213, 40, 40;
  --color-green-10-rgb: 218, 255, 210;
  --color-white-rgb: 255, 255, 255;
  --color-black-rgb: 0, 0, 0;
  --color-gray-10-rgb: 248, 250, 252;
  --color-gray-20-rgb: 248, 248, 248;
  --color-gray-30-rgb: 242, 242, 242;
  --color-gray-40-rgb: 197, 197, 197;
  --color-gray-50-rgb: 177, 177, 177;
  --color-gray-60-rgb: 145, 145, 145;
  --color-gray-70-rgb: 119, 119, 119;
  --color-gray-80-rgb: 94, 95, 102;
  --color-gray-90-rgb: 71, 72, 77;
  --color-gray-rgb: var(--color-gray-50-rgb);
  --ease: cubic-bezier(0.215, 0.61, 0.355, 1);
  --opacity: 0.7;
  --scale: 1.03;
  --bdrs: 0.6rem;
  --easing: cubic-bezier(0.2, 1, 0.2, 1);
  --transition: 0.8s var(--easing);
}

:root {
  --container-margin: 1.875rem;
}

@media (min-width: 768px) {
  :root {
    --container-margin: 5vw;
  }
}
html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: 62.5%;
  line-break: normal;
  overflow-wrap: break-word;
  text-underline-offset: 0.125em;
  scroll-behavior: smooth;
}

body {
  background-color: #fff;
  font-family: "Open Sans", sans-serif;
  font-optical-sizing: auto;
  font-kerning: none;
  font-size: clamp(1.3rem, 1.073rem + 0.606vw, 1.8rem);
  font-weight: 400;
  letter-spacing: 0.02rem;
  line-height: 1.4166666667;
}
@media screen and (min-width: 768px) {
  body {
    line-height: 1.65;
  }
}

section figure,
header figure,
footer figure,
div figure {
  margin: 0;
}

.container,
.container-md {
  position: relative;
  margin-inline: auto;
  width: calc(100% - var(--container-margin) * 2);
}

.container {
  max-width: 120rem;
}

.container-md {
  max-width: 144rem;
}

.container-sm {
  max-width: 110rem;
}

.container-lg,
.container-sm {
  position: relative;
  margin-inline: auto;
  width: calc(100% - var(--container-margin) * 2);
}

.site-ttl {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .site-ttl {
    width: calc(100% - 6rem);
    height: 6rem;
    background-color: #fff;
    border-bottom: 1px solid #cdcdcd;
  }
  .site-ttl .site-ttl-inner {
    width: calc(100% - var(--container-margin) * 2);
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
@media screen and (min-width: 768px) {
  .site-ttl {
    max-width: 120rem;
    width: calc(100% - var(--container-margin) * 2);
    margin-top: 9rem;
    margin-inline: auto;
    padding: 4rem 1.5rem;
    border: 1px solid #cdcdcd;
    border-radius: 0.8rem;
  }
}

.nav-open .site-ttl {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
}

a {
  color: #1f2022;
  text-decoration: none;
  word-wrap: break-word;
}

a[href*="tel:"] {
  pointer-events: none;
  cursor: default;
  opacity: 1;
}

body.sp a[href*="tel:"] {
  pointer-events: auto;
}

.scroll-up {
  transition: 0.8s cubic-bezier(0.26, 0.06, 0, 1);
  transform: translateY(30px);
  opacity: 0;
}

.scroll-up.on {
  transform: translateY(0);
  opacity: 1;
}

.scroll-left {
  -webkit-transition: 0.8s ease-in-out;
  -moz-transition: 0.8s ease-in-out;
  -o-transition: 0.8s ease-in-out;
  transition: 0.8s ease-in-out;
  transform: translateX(-30px);
  opacity: 0;
  filter: alpha(opacity=0);
  -moz-opacity: 0;
}

.scroll-left.on {
  opacity: 1;
  filter: alpha(opacity=100);
  -moz-opacity: 1;
  transform: translateX(0);
}

.scroll-right {
  -webkit-transition: 0.8s ease-in-out;
  -moz-transition: 0.8s ease-in-out;
  -o-transition: 0.8s ease-in-out;
  transition: 0.8s ease-in-out;
  transform: translateX(30px);
  opacity: 0;
  filter: alpha(opacity=0);
  -moz-opacity: 0;
}

.scroll-right.on {
  opacity: 1;
  filter: alpha(opacity=100);
  -moz-opacity: 1;
  transform: translateX(0);
}

.timing02 {
  transition-delay: 0.2s;
}

.timing03 {
  transition-delay: 0.4s;
}

.timing04 {
  transition-delay: 0.6s;
}

.timing05 {
  transition-delay: 0.8s;
}

.timing06 {
  transition-delay: 1.2s;
}

.timing07 {
  transition-delay: 1.4s;
}

.timing08 {
  transition-delay: 1.6s;
}

.timing09 {
  transition-delay: 1.8s;
}

.timing10 {
  transition-delay: 2s;
}

.timing11 {
  transition-delay: 2.2s;
}

.timing12 {
  transition-delay: 2.4s;
}

::-moz-selection {
  color: #fff;
  background: rgb(5, 158, 206);
}

::selection {
  color: #fff;
  background: rgb(5, 158, 206);
}

@media screen and (min-width: 1025px) {
  .lg-hide {
    display: none !important;
  }
  .lg-visible {
    display: inherit !important;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .md-hide {
    display: none !important;
  }
  .md-visible {
    display: inherit !important;
  }
}
@media screen and (max-width: 767px) {
  .sm-hide {
    display: none !important;
  }
  .sm-visible {
    display: inherit !important;
  }
}
/* base
------------------------------*/
.breadcrumb {
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
}
@media screen and (min-width: 768px) {
  .breadcrumb {
    margin-top: 2rem;
    margin-bottom: 3rem;
  }
}
.breadcrumb .breadcrumb-list {
  display: flex;
  align-items: center;
  white-space: nowrap;
  overflow: auto;
}
.breadcrumb .breadcrumb-list li {
  font-size: clamp(1rem, 0.93rem + 0.188vw, 1.2rem);
  line-height: 1;
}
.breadcrumb .breadcrumb-list li:last-child {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.breadcrumb .breadcrumb-list li:not(:last-child)::after {
  content: "/";
  margin: 0.1rem 0.6rem 0;
  color: #99a1ac;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 768px) {
  .breadcrumb .breadcrumb-list li:not(:last-child)::after {
    margin: 0.1rem 1.6rem 0;
  }
}
.breadcrumb .breadcrumb-list li a {
  color: var(--color-blue);
  line-height: 1.5;
  text-decoration: underline;
}
.breadcrumb .breadcrumb-list li a:hover {
  text-decoration: none;
}

.article-desc p {
  font-size: clamp(1.5rem, 1.273rem + 0.606vw, 2rem);
}

.article-map-btn {
  padding-top: 3rem;
}
@media screen and (min-width: 768px) {
  .article-map-btn {
    padding-top: 4rem;
  }
}

.article-tag {
  padding-top: 3rem;
}
@media screen and (min-width: 768px) {
  .article-tag {
    padding-top: 4rem;
  }
}
.article-tag .article-tag-list {
  display: flex;
  flex-wrap: wrap;
}
.article-tag .article-tag-list li {
  margin-right: 1rem;
}
.article-tag .article-tag-list li a {
  padding: 0.5rem 1rem;
  border: 1px solid var(--color-gray);
  border-radius: var(--bdrs);
  transition: color 0.3s;
}
.article-tag .article-tag-list li a:hover {
  background-color: var(--color-black);
  border-color: var(--color-black);
  color: var(--color-white);
}

.article-date {
  padding-top: 3rem;
}
@media screen and (min-width: 768px) {
  .article-date {
    padding-top: 4rem;
  }
}
.article-date span {
  font-weight: 700;
}

.article-category {
  display: flex;
  flex-wrap: wrap;
}
.article-category li {
  margin-bottom: 1rem;
  margin-right: 1rem;
  padding: 0.5rem 1rem;
  background-color: var(--color-blue);
  font-weight: 700;
  color: var(--color-white);
  border-radius: 0.5rem;
  line-height: 1;
}

.article-ttl {
  padding-top: 0.5rem;
  font-size: clamp(2rem, 1.437rem + 1.502vw, 3.6rem);
  font-weight: 700;
  line-height: 1.4;
}

.article-number {
  margin-top: 3rem;
  display: inline-flex;
  background-color: ddd;
  border: 1px solid var(--color-gray);
  font-size: clamp(1.1rem, 0.994rem + 0.282vw, 1.4rem);
  line-height: 1.4;
}
.article-number em {
  padding: 0.5rem;
  background-color: var(--color-black);
  font-style: normal;
  color: var(--color-white);
}
.article-number span {
  padding: 0.5rem;
}

.article-desc {
  margin-top: 3rem;
}
.article-desc a {
  color: rgb(5, 158, 206);
  text-decoration: underline;
}
.article-desc a:hover {
  text-decoration: none;
}

.article-content {
  margin-top: 3rem;
  margin-bottom: 3rem;
}
@media screen and (min-width: 768px) {
  .article-content {
    margin-top: 5rem;
    margin-bottom: 5rem;
  }
}
.article-content p {
  padding-bottom: 2.5rem;
}
.article-content img {
  width: 100%;
}
.article-content a {
  color: rgb(5, 158, 206);
  text-decoration: underline;
}

.fix-btn {
  position: absolute;
  top: -3.2rem;
  left: 0;
  margin: 0 auto;
  z-index: 9999;
}
.fix-btn a {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 1rem;
  padding-bottom: 1rem;
  background-color: #00acd7;
  border-radius: 0 0 5px 5px;
  font-size: 1.3rem;
  font-weight: 700;
  color: #fff;
  text-align: center;
  line-height: 1;
  text-decoration: none;
  transition: all 0.3s;
}
@media screen and (min-width: 768px) {
  .fix-btn a {
    padding: 1rem;
  }
}
.fix-btn a i {
  width: 1.4rem;
  height: auto;
  margin-right: 1rem;
}
@media screen and (min-width: 768px) {
  .fix-btn a:hover {
    padding: 1.5rem 1rem;
  }
}

.ta-l {
  text-align: left;
}

.ta-c {
  text-align: center;
}

.ta-r {
  text-align: right;
}

.ta-j {
  text-align: justify;
}

@media (max-width: 1024px) {
  .md-ta-l {
    text-align: left;
  }
  .md-ta-c {
    text-align: center;
  }
  .md-ta-r {
    text-align: right;
  }
  .md-ta-j {
    text-align: justify;
  }
}
@media (max-width: 767px) {
  .sm-ta-l {
    text-align: left;
  }
  .sm-ta-c {
    text-align: center;
  }
  .sm-ta-r {
    text-align: right;
  }
  .sm-ta-j {
    text-align: justify;
  }
}
.btn,
a.btn,
button.btn {
  position: relative;
  display: inline-block;
  padding: 0.6rem 7rem;
  user-select: none;
  font-size: clamp(1.5rem, 1.273rem + 0.606vw, 2rem);
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  cursor: pointer;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.07);
  border-radius: 0.5rem;
}

.btn::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 100%;
  transition: width 0.8s cubic-bezier(0.4, 0.16, 0, 0.95) 0s;
}
.btn::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 1.75rem;
  width: 0.7rem;
  height: 0.7rem;
  border-right-style: solid;
  border-bottom-style: solid;
  border-right-width: 0.15rem;
  border-bottom-width: 0.15rem;
  transform: translateY(-50%) rotate(-45deg);
  transition: border 0.8s cubic-bezier(0.4, 0.16, 0, 0.95) 0s;
}
.btn span {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  transition: color 0.3s;
}
.btn:hover::before {
  width: 100%;
}
.btn.btn-pdf::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 1.75rem;
  width: 1.6rem;
  height: 1.9rem;
  border: none;
  transform: translateY(-50%) rotate(0);
  transition: border 0.8s cubic-bezier(0.4, 0.16, 0, 0.95) 0s;
  background: url(../img/common/icon-pdf.svg) no-repeat 0 0/cover;
}
.btn.btn-pdf:hover::after {
  background: url(../img/common/icon-pdf-white.svg) no-repeat 0 0/cover;
}
.btn.btn-movie::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 1.75rem;
  width: 1.6rem;
  height: 1.9rem;
  border: none;
  transform: translateY(-50%) rotate(0);
  transition: border 0.8s cubic-bezier(0.4, 0.16, 0, 0.95) 0s;
  background: url(../img/common/icon-movie.svg) no-repeat 0 0/cover;
}
.btn.btn-movie:hover::after {
  background: url(../img/common/icon-movie-white.svg) no-repeat 0 0/cover;
}

.btn-brand {
  background-color: rgb(5, 158, 206);
  border: 1px solid rgb(5, 158, 206);
  color: #fff;
}
.btn-brand::before {
  background-color: #fff;
}
.btn-brand::after {
  border-right-color: #fff;
  border-bottom-color: #fff;
}
.btn-brand:hover {
  color: rgb(5, 158, 206);
}
.btn-brand:hover::after {
  border-right-color: rgb(5, 158, 206);
  border-bottom-color: rgb(5, 158, 206);
}

.btn-black {
  background-color: #000;
  border: 1px solid #000;
  color: #fff;
}
.btn-black::before {
  background-color: #fff;
}
.btn-black::after {
  border-right-color: #fff;
  border-bottom-color: #fff;
}
.btn-black:hover {
  color: #000;
}
.btn-black:hover::after {
  border-right-color: #000;
  border-bottom-color: #000;
}

.btn-bland-line {
  background-color: #fff;
  color: rgb(5, 158, 206);
  border: 1px solid rgb(5, 158, 206);
}
.btn-bland-line::before {
  background-color: rgb(5, 158, 206);
}
.btn-bland-line:hover {
  color: #fff;
}
.btn-bland-line:hover::after {
  border-right-color: #fff;
  border-bottom-color: #fff;
}

.btn-black-line {
  background-color: #fff;
  color: #000;
  border: 1px solid #000;
}
.btn-black-line::before {
  background-color: #000;
}
.btn-black-line:hover {
  color: #fff;
}
.btn-black-line:hover::after {
  border-right-color: #fff;
  border-bottom-color: #fff;
}

.btn.btn-blank::after {
  display: none;
}

.btn-more .btn::after {
  transform: translateY(-50%) rotate(45deg);
}

.search-btn {
  margin-top: 3rem;
}
@media screen and (min-width: 768px) {
  .search-btn a {
    padding-right: 16rem;
    padding-left: 16rem;
  }
}

.search-btn i {
  margin-right: 0.6rem;
  width: 1.6rem;
  height: 1.6rem;
  background: url(../img/common/icon-search-white.svg) no-repeat 0 0/cover;
}

.search-btn a:hover i {
  background: url(../img/common/icon-search-black.svg) no-repeat 0 0/cover;
}

.blank-icon {
  position: absolute;
  top: 50%;
  right: 2rem;
  transform: translateY(-50%);
  width: 1rem;
  height: 0.8rem;
}

.blank-icon::before,
.blank-icon::after {
  content: "";
  box-sizing: border-box;
  position: absolute;
  width: 100%;
  height: 100%;
  border-style: solid;
  border-color: #000;
}

.blank-icon::before {
  top: 0;
  left: 0;
  border-width: 1px;
}

.blank-icon::after {
  top: 0.3rem;
  left: 0.3rem;
  border-width: 0 1px 1px 0;
}

.btn.btn-blank:hover .blank-icon::before,
.btn.btn-blank:hover .blank-icon::after {
  border-color: #fff;
}

@keyframes animationZoom1 {
  100% {
    transform: scale(1);
  }
}
.lower main {
  padding-bottom: 4rem;
}
@media screen and (min-width: 768px) {
  .lower main {
    padding-bottom: 8rem;
  }
}

.lower .sld {
  align-items: flex-end;
}
@media screen and (min-width: 768px) {
  .lower .sld {
    top: 0;
    bottom: 0;
    right: 2.25%;
    transform: translateY(0);
  }
}
@media screen and (max-width: 767px) {
  .lower .sld {
    right: 7px;
    bottom: 0;
  }
}

.gmap {
  position: relative;
  padding-bottom: 50.25%;
  height: 0;
  overflow: hidden;
}
.gmap iframe {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
}

.l-circle {
  margin-left: 1rem;
}

.l-circle li {
  position: relative;
  margin-bottom: 0.5rem;
  padding-left: 1rem;
  list-style: none;
}

.l-circle li::before {
  content: "";
  position: absolute;
  top: 1rem;
  left: -0.5rem;
  bottom: auto;
  right: auto;
  margin: auto;
  width: 0.5rem;
  height: 0.5rem;
  background-color: #222;
  border-radius: 50%;
}

.l-number {
  counter-reset: l-counter;
}

.l-number li {
  position: relative;
  margin-top: 3px;
  padding-left: 25px;
}

.l-number li::before {
  content: counter(l-counter) ".";
  counter-increment: l-counter;
  display: block;
  float: left;
  margin-left: -20px;
  text-align: left;
}

.pager {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 8rem;
  text-align: center;
}

.pager > * {
  margin: 0 0.5rem;
  padding: 0.8rem 1.6rem;
  text-align: center;
}

.pager a {
  background-color: #fff;
  border: 1px solid #ccc;
}

.pager a:hover,
.pager span {
  background-color: #222;
  color: #fff !important;
}

.pager span {
  display: flex;
  align-items: center;
}

.pager span.pn,
.pager span.previous,
.pager > span.next {
  padding: 0 2px;
  background: transparent !important;
  border: none;
  color: #333 !important;
}

.pager span.previous a:hover,
.pager span.next a:hover {
  opacity: 0.7;
}

.pager span.pn a,
.pager span.previous a,
.pager span.next a {
  position: static;
  display: inline-block;
  padding: 5px 0;
  color: #333 !important;
  background: transparent !important;
  border: none;
}

@media screen and (max-width: 767px) {
  .pager {
    margin-top: 4rem;
  }
  .pager > * {
    margin: 0 2px 0;
    padding: 4px 10px;
  }
  .pager a,
  .pager span {
    font-size: 1.2rem;
  }
  .pager span.pn a,
  .pager span.previous a,
  .pager span.next a {
    display: inline-block;
    padding: 10px 0;
    position: static;
    border: none;
    background: transparent !important;
  }
}
.container1,
.container2 {
  position: relative;
  max-width: 90%;
  margin: 0 auto;
}

.container1 {
  width: 126rem;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .container1 {
    width: 90%;
  }
}

.container2 {
  width: 98rem;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .container2 {
    width: 90%;
  }
}

.headline {
  font-size: clamp(2.7rem, 2.427rem + 0.727vw, 3.3rem);
  font-weight: bold;
  text-align: center;
}

.lower .headline {
  padding-bottom: 3rem;
}

.headline-comment {
  padding-bottom: 2.5rem;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .headline-comment {
    padding-bottom: 4.5rem;
  }
}

@media screen and (min-width: 768px) {
  .body {
    display: flex;
    justify-content: space-between;
  }
  .body .article-body {
    width: 64%;
  }
  .body aside {
    width: 31.0833333333%;
  }
}
@media screen and (max-width: 767px) {
  .body aside {
    margin-top: 4rem;
  }
}
.body aside h4 {
  padding: 0.4rem 0.4rem 0;
  background-color: var(--color-black);
  border-radius: 4px;
  font-size: clamp(1.5rem, 1.273rem + 0.606vw, 2rem);
  font-weight: 700;
  color: var(--color-white);
  text-align: center;
}
@media screen and (min-width: 768px) {
  .body aside h4 {
    padding: 0.2rem 0.2rem 0;
  }
}
.body aside .archive-list li {
  margin-top: 2rem;
}
.body aside .archive-list li a {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.body aside .archive-list li a figure {
  position: relative;
  width: 32.1715817694%;
  position: relative;
  overflow: hidden;
}
.body aside .archive-list li a figure::before {
  float: left;
  content: "";
  padding-top: 66.25%;
}
.body aside .archive-list li a figure::after {
  display: block;
  content: "";
  clear: both;
}
.body aside .archive-list li a figure > img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s cubic-bezier(0.09, 0.43, 0.1, 0.79);
}
.body aside .archive-list li a p {
  width: 64.8793565684%;
  font-size: clamp(1.3rem, 1.118rem + 0.485vw, 1.7rem);
  line-height: 1.4;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.body aside .archive-list li a:hover figure img {
  transform: scale(1.05);
}
.body aside .archive-list li a:hover p {
  opacity: 0.7;
}

.search {
  margin-bottom: 4rem;
}
@media screen and (min-width: 768px) {
  .search {
    margin-top: 2rem;
    margin-bottom: 8rem;
  }
}

.search input {
  margin: 0;
  width: 0;
}

.search .search-checkbox input:checked + span {
  background: var(--color-blue);
  border: 1px solid var(--color-blue);
  transition: all 0.45s ease-in-out;
}

.search .search-checkbox input:checked + span::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("../img/common/icon-check-white.svg") no-repeat 0 0/contain;
}

.search .search-checkbox span {
  position: relative;
  top: 0;
  left: 0;
  display: block;
  width: 1.8rem;
  height: 1.8rem;
  border: solid 1px var(--color-gray);
  background: #fff;
  border-radius: 4px;
}

.search .search-checkbox em {
  margin-left: 0.6rem;
  display: block;
  font-style: normal;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0;
}

.search .search-checkbox input:checked + span + em {
  color: var(--color-blue);
}

.search input[type=text] {
  width: 100%;
  padding: 10px;
  border: solid 1px var(--color-gray);
  background: #fff;
  border-radius: 4px;
}

.search-checkbox label {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
}

.related {
  margin-top: 5rem;
}
@media screen and (min-width: 768px) {
  .related {
    margin-top: 8rem;
  }
}
.related h4 {
  margin-bottom: 2rem;
  padding: 0.2rem 0.2rem 0;
  background-color: var(--color-black);
  border-radius: 4px;
  font-size: clamp(2rem, 1.636rem + 0.97vw, 2.8rem);
  font-weight: 700;
  color: var(--color-white);
  text-align: center;
}
@media screen and (min-width: 768px) {
  .related h4 {
    margin-bottom: 4rem;
  }
}
.related .related-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  row-gap: 2rem;
}
@media screen and (min-width: 768px) {
  .related .related-list {
    grid-template-columns: 1fr 1fr 1fr 1fr;
    row-gap: 4rem;
  }
}
.related .related-list li {
  opacity: 1;
}
.related .related-list li.is-hidden {
  padding-bottom: 0;
}
.related .related-list li a figure {
  border-radius: 0.6rem;
  position: relative;
  overflow: hidden;
}
.related .related-list li a figure::before {
  float: left;
  content: "";
  padding-top: 65%;
}
.related .related-list li a figure::after {
  display: block;
  content: "";
  clear: both;
}
.related .related-list li a figure > img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s cubic-bezier(0.09, 0.43, 0.1, 0.79);
}
.related .related-list li a p {
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  margin-top: 1.5rem;
  font-weight: 700;
  font-size: clamp(1.4rem, 1.264rem + 0.364vw, 1.7rem);
  line-height: 1.2;
}
.related .related-list li a:hover figure img {
  transform: scale(1.05);
}
.related .related-list li a:hover p {
  opacity: 0.7;
}

.related-list li.is-hidden {
  opacity: 0;
  height: 0;
  margin: 0;
  pointer-events: none;
}

.related-list-btn.is-btn-hidden {
  display: none;
}

.search-result {
  margin-bottom: 2rem;
}
@media screen and (min-width: 768px) {
  .search-result {
    margin-bottom: 4rem;
  }
}
.search-result .search-result-inner {
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  text-align: center;
}
.search-result .search-result-inner strong {
  padding-right: 1rem;
  font-size: clamp(2.4rem, 1.855rem + 1.455vw, 3.6rem);
}

.home-feature .headline,
.home-reviews .headline {
  padding-bottom: 4rem;
}

.header {
  position: relative;
  width: 100%;
  z-index: 100;
}
@media screen and (min-width: 768px) {
  .header {
    position: absolute;
    top: 0;
    left: 0;
    height: inherit;
    margin-bottom: 0;
    padding-top: 3.2rem;
    padding-bottom: 3.2rem;
    transition: padding 0.6s cubic-bezier(0.19, 1, 0.22, 1);
    will-change: padding;
  }
  .header.scrolled {
    padding-top: 2rem;
    padding-bottom: 2rem;
    background-color: #fff;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
  }
}
.header .header-inner {
  display: flex;
}
.header .logo {
  position: absolute;
  top: 1.65rem;
  left: 2rem;
  width: 17rem;
  height: 2.7rem;
}
@media screen and (min-width: 1025px) {
  .header .logo {
    position: static;
    top: inherit;
    left: inherit;
  }
}
.header .logo img {
  max-width: inherit;
}
.header .nav {
  position: fixed;
  right: 0;
  left: 0;
  top: 0;
  width: 100%;
  height: 100vh;
  padding: 6rem 2rem;
  background-color: #fff;
  transition: visibility 0.3s, opacity 0.3s;
  visibility: hidden;
  opacity: 0;
  display: block;
}
@media screen and (max-width: 767px) {
  .header .nav {
    overflow-y: scroll;
  }
}
.header .nav.active {
  visibility: visible;
  opacity: 1;
}
@media screen and (min-width: 768px) {
  .header .nav {
    position: static;
    transform: initial;
    background-color: inherit;
    height: inherit;
    display: flex;
    justify-content: end;
    visibility: visible;
    opacity: 1;
    display: flex;
    align-items: center;
    margin-left: auto;
    padding: 0;
  }
}
@media screen and (min-width: 768px) {
  .header .nav .main-nav {
    align-items: center;
    background-color: transparent;
    display: flex;
  }
}
.header .nav .main-nav {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .header .nav .main-nav {
    width: auto;
  }
}
.header .nav .main-nav li {
  border-bottom: 1px solid #ccc;
}
@media screen and (min-width: 768px) {
  .header .nav .main-nav li {
    border-bottom: none;
  }
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .header .nav .main-nav li {
    padding-right: 2rem;
  }
}
@media screen and (min-width: 1025px) {
  .header .nav .main-nav li {
    padding-right: 2.5rem;
  }
}
@media screen and (min-width: 768px) {
  .header .nav .main-nav li.nav-privacy {
    display: none;
  }
  .header .nav .main-nav li.nav-contact {
    display: none;
  }
}
.header .nav .main-nav li a {
  position: relative;
  display: block;
  width: 100%;
  padding-top: 2rem;
  padding-bottom: 2rem;
  font-weight: 700;
  letter-spacing: 0.1rem;
}
@media screen and (max-width: 767px) {
  .header .nav .main-nav li a {
    font-size: 2rem;
  }
}
@media screen and (min-width: 768px) {
  .header .nav .main-nav li a {
    padding-top: 0;
    padding-bottom: 0;
    color: #fff;
  }
  .header .nav .main-nav li a::after {
    content: "";
    position: absolute;
    left: 0;
    width: 100%;
    height: 0.2rem;
    background-color: #fff;
    bottom: -1rem;
    opacity: 0;
    visibility: hidden;
    transition: 0.8s cubic-bezier(0.09, 0.43, 0.1, 0.79);
  }
  .header .nav .main-nav li a:hover {
    opacity: 1;
  }
  .header .nav .main-nav li a:hover::after {
    visibility: visible;
    bottom: 0;
    opacity: 1;
  }
}

.lower .header .nav .main-nav li a {
  color: currentColor;
}
.lower .header .nav .main-nav li a::after {
  content: "";
  background-color: currentColor;
}

body.nav-open .header .inner .logo {
  position: fixed;
  z-index: 10000;
}

.hamburger {
  position: fixed;
  top: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 6rem;
  height: 6rem;
  margin: 0;
  padding: 0;
  background-color: #00acd7;
  border: none;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .hamburger {
    display: none;
  }
}
.hamburger .hamburger-icon {
  width: 3rem;
  position: relative;
  transition: transform 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}
.hamburger .hamburger-icon span {
  height: 0.2rem;
  background-color: #fff;
  position: relative;
  transition: ease 0.4s;
  display: block;
}
.hamburger .hamburger-icon span:nth-child(1) {
  transform: translate3d(0, 0, 0) rotate(0deg);
}
.hamburger .hamburger-icon span:nth-child(2) {
  margin: 0.8rem 0;
  transition: transform 0.2s 0.3s, opacity 0.2s 0.3s;
}
.hamburger .hamburger-icon span:nth-child(3) {
  transform: translate3d(0, 0, 0) rotate(0deg);
}
.hamburger.active .hamburger-icon span:nth-child(1) {
  transform: translate3d(0, 1rem, 0) rotate(45deg);
}
.hamburger.active .hamburger-icon span:nth-child(2) {
  transition: transform 0.2s, opacity 0.2s;
  transform: scaleX(0);
}
.hamburger.active .hamburger-icon span:nth-child(3) {
  transform: translate3d(0, -1rem, 0) rotate(-45deg);
}

.btn-lang {
  position: relative;
  margin-top: 3rem;
}
@media screen and (min-width: 768px) {
  .btn-lang {
    margin-top: 0;
    width: 10rem;
  }
}
.btn-lang .btn-lang-ttl {
  position: relative;
  cursor: pointer;
  display: flex;
  align-items: center;
  height: 5rem;
  padding: 0.5rem 3rem 0.5rem 1rem;
  background-color: #555;
  font-size: 1.3rem;
  font-weight: 700;
  color: #fff;
  text-align: center;
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-duration: 0.5s;
  transition-duration: 0.5s;
  line-height: 1;
  letter-spacing: 0;
}
@media screen and (min-width: 768px) {
  .btn-lang .btn-lang-ttl {
    height: 3rem;
  }
}
.btn-lang .btn-lang-ttl::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 0.9em;
  width: 0.5rem;
  height: 0.5rem;
  border-bottom: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: translateY(-50%) rotate(45deg);
}
.btn-lang .btn-lang-ttl:hover {
  opacity: 0.8;
}

.btn-lang .btn-lang-inner {
  position: absolute;
  top: 30px;
  left: 0;
  width: 100%;
  background-color: #fff;
}

.btn-lang .open:before {
  transform: rotate(225deg);
}

.btn-lang .btn-lang-inner {
  position: absolute;
  top: 5rem;
  display: none;
}

@media screen and (min-width: 768px) {
  .btn-lang .btn-lang-inner {
    position: absolute;
    top: 3rem;
    left: 0;
    width: 100%;
    background: #fff;
  }
}
.btn-lang .btn-lang-inner .btn-lang-list li {
  border-bottom: 1px solid #555;
  border-left: 1px solid #555;
  border-right: 1px solid #555;
}

.btn-lang .btn-lang-inner .btn-lang-list li a {
  display: block;
  padding: 0.5rem 0.5rem 0.5rem 1rem;
  font-size: 1.1rem;
  color: #555;
  background-color: #fff;
  text-align: left;
}

@media screen and (max-width: 767px) {
  .btn-lang .btn-lang-inner .btn-lang-list li a {
    padding: 1.5rem 0.5rem 1.5rem 1rem;
  }
}
.btn-lang .btn-lang-inner .btn-lang-list li a:hover {
  background-color: #f2f2f2;
}

.banner {
  margin: 0 auto;
  padding-top: 5rem;
  padding-bottom: 2rem;
}
.banner-disc {
  text-align: center;
  font-weight: 700;
}
.banner-disc span {
  position: relative;
}
.banner-disc span::before, .banner-disc span::after {
  content: "";
  position: absolute;
  width: 0.1rem;
  height: 1.5rem;
  bottom: 0;
  background-color: var(--color-black);
}
@media screen and (min-width: 768px) {
  .banner-disc span::before, .banner-disc span::after {
    height: 2rem;
  }
}
.banner-disc span::before {
  left: -1.5rem;
  transform: rotate(-20deg);
}
.banner-disc span::after {
  right: -1.5rem;
  transform: rotate(20deg);
}
.banner-disc2 {
  padding-top: 5rem;
  padding-bottom: 3rem;
  text-align: center;
  font-weight: 700;
}
@media screen and (min-width: 768px) {
  .banner-disc2 {
    padding-top: 5rem;
    padding-bottom: 3rem;
  }
}
.banner .container {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.banner .trip-site {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 2.5rem;
  margin-bottom: 2.5rem;
}
@media screen and (min-width: 768px) {
  .banner .trip-site {
    margin-top: 3rem;
    margin-bottom: 5rem;
  }
}
.banner .trip-site-booking {
  width: 28rem;
}
.banner .trip-site-agoda {
  width: 15rem;
}
.banner .trip-site a {
  margin-right: 2.5rem;
  margin-left: 2.5rem;
  transition: all 0.3s;
}
.banner .trip-site a:hover {
  opacity: var(--opacity);
}
.banner ul {
  display: grid;
  justify-items: center;
  gap: 2rem;
}
@media screen and (min-width: 768px) {
  .banner ul {
    gap: 2rem;
  }
}
.banner ul li a {
  transition: all 0.3s;
}
.banner ul li a:hover {
  opacity: var(--opacity);
}

.banner-type2 {
  margin: 0 auto;
  padding-bottom: 5rem;
}
@media screen and (min-width: 768px) {
  .banner-type2 {
    padding-bottom: 5rem;
  }
}
.banner-type2 ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2rem;
}
@media screen and (min-width: 768px) {
  .banner-type2 ul {
    gap: 2rem;
  }
}
.banner-type2 ul li a {
  transition: all 0.3s;
}
.banner-type2 ul li a:hover {
  opacity: var(--opacity);
}

.lower .banner {
  border-top: 1px solid #ccc;
}

footer {
  padding-top: 3rem;
  padding-bottom: 3rem;
  position: relative;
  background-color: #000;
}
footer .footer-inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
footer .footer-logo {
  padding-top: 6rem;
  padding-bottom: 6rem;
}
@media screen and (min-width: 768px) {
  footer .footer-logo {
    padding-top: 12rem;
    padding-bottom: 12rem;
  }
}
footer .footer-logo img {
  margin: 0 auto;
}
footer .footer-sns ul {
  display: flex;
  justify-content: center;
}
footer .footer-sns ul li a {
  transition: all 0.3s;
}
footer .footer-sns ul li a:hover {
  opacity: var(--opacity);
}
footer .footer-sns ul li:nth-child(n+2) {
  margin-left: 1.5rem;
}
footer .footer-bureau {
  padding-top: 2rem;
  padding-bottom: 1rem;
}
footer .footer-bureau img {
  margin: 0 auto;
}
footer .footer-link {
  text-align: center;
}
footer .footer-link ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  footer .footer-link ul li {
    width: 50%;
  }
  footer .footer-link ul li:first-child {
    width: 100%;
  }
  footer .footer-link ul li:nth-child(n+2) {
    margin-top: 1rem;
  }
}
@media screen and (min-width: 768px) {
  footer .footer-link ul li {
    margin-right: 1.5rem;
    margin-left: 1.5rem;
  }
}
footer .footer-link ul li a {
  position: relative;
  font-weight: 700;
  color: #fff;
}
footer .footer-link ul li a::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 0.2rem;
  background-color: #fff;
  bottom: -1rem;
  opacity: 0;
  visibility: hidden;
  transition: 0.8s cubic-bezier(0.09, 0.43, 0.1, 0.79);
}
footer .footer-link ul li a:hover {
  opacity: 1;
}
footer .footer-link ul li a:hover::after {
  visibility: visible;
  bottom: -0.5rem;
  opacity: 1;
}
footer .footer-copyright {
  font-size: 1rem;
  color: #fff;
  text-align: center;
}

.textlink {
  background: linear-gradient(0, #0f1821, #0f1821) 100% 100%/0 1px no-repeat;
  transition: background-size 0.4s cubic-bezier(0.83, 0, 0.17, 1);
}

@media (hover: hover) {
  .textlink:hover {
    background-position: 0 100%;
    background-size: 100% 0.1rem;
  }
  a:hover .textlink {
    background-position: 0 100%;
    background-size: 100% 0.1rem;
  }
}
.pagetop {
  position: absolute;
  right: 0;
  top: -1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 4rem;
  height: 4rem;
  border-radius: 50%;
  background-color: var(--color-blue);
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .pagetop {
    top: 0;
    width: 5rem;
    height: 5rem;
  }
}
.pagetop::after {
  content: "";
  width: 1rem;
  height: 1rem;
  border: 1px solid #fff;
  border-width: 1px 1px 0 0;
  transform: translateY(15%) rotate(-45deg);
}
@media screen and (min-width: 768px) {
  .pagetop::after {
    width: 1.2rem;
    height: 1.2rem;
  }
}
.pagetop:hover {
  opacity: 0.7;
}

#scroolltop {
  position: fixed;
  right: 10px;
  bottom: 10px;
  border-radius: 50%;
  background-color: #00acd7;
  color: #fff;
  font-size: 110%;
  text-align: center;
  text-decoration: none;
  z-index: 1000;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  transition: all 0.3s;
  transform: scale(0);
}

#scroolltop:hover {
  opacity: 0.8;
  text-decoration: none;
}

#scroolltop.show {
  transform: scale(1);
  -webkit-transform: translateZ(1);
}

a#scroolltop {
  display: block;
}

#scroolltop:before,
#scroolltop:after {
  position: absolute;
  left: 50%;
  content: "";
  width: 0;
  height: 0;
}

#scroolltop:before {
  top: 50%;
}

#scroolltop:after {
  top: 50%;
  z-index: -1;
}

@media screen and (min-width: 768px) {
  #scroolltop {
    width: 45px;
    height: 45px;
  }
  #scroolltop:before,
  #scroolltop:after {
    margin-left: -6px;
    border: 5px solid transparent;
  }
  #scroolltop:before {
    margin-top: -8px;
    border-bottom: 5px solid #00acd7;
  }
  #scroolltop:after {
    margin-top: -9px;
    border-bottom: 5px solid #fff;
  }
}
@media screen and (max-width: 767px) {
  #scroolltop {
    width: 30px;
    height: 30px;
  }
  #scroolltop:before,
  #scroolltop:after {
    margin-left: -5px;
    border: 5px solid transparent;
  }
  #scroolltop:before {
    margin-top: -6px;
    border-bottom: 5px solid #00acd7;
  }
  #scroolltop:after {
    margin-top: -8px;
    border-bottom: 5px solid #fff;
  }
}
@media screen and (min-width: 768px) {
  .page-home .site-ttl {
    display: none;
  }
}
[class*=swiper]:focus {
  outline: none;
}

.slide-cover {
  position: relative;
  overflow: hidden;
}

.slide-cover img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.swiper-button-prev,
.swiper-button-next {
  display: grid;
  place-content: center;
  width: 4rem;
  height: 4rem;
  cursor: pointer;
  -webkit-transition: var(--transition);
  transition: var(--transition);
}
@media screen and (min-width: 768px) {
  .swiper-button-prev,
  .swiper-button-next {
    width: 6rem;
    height: 6rem;
  }
}

.swiper-button-prev::before,
.swiper-button-next::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  border-radius: 50%;
}

.swiper-button-prev::after,
.swiper-button-next::after {
  content: "";
  width: 1.2rem;
  height: 1.2rem;
  border: solid var(--color-black);
  border-width: 1px 1px 0 0;
}

.swiper-button-prev::after {
  margin-left: 0.4rem;
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
}

.swiper-button-next::after {
  margin-right: 0.4rem;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.swiper-button-disabled {
  pointer-events: none;
  opacity: 0;
}

.fv {
  position: relative;
}
.fv .fv-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  width: 80%;
}
@media screen and (max-width: 767px) {
  .fv .fv-logo {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .fv .fv-logo {
    width: 90%;
  }
}
.fv .fv-logo img {
  margin: 0 auto;
}
.fv .swiper-pagination {
  position: absolute;
  bottom: 1rem;
  left: 0;
  width: 100%;
  text-align: center;
  z-index: 10;
}
@media screen and (min-width: 768px) {
  .fv .swiper-pagination {
    bottom: 2rem;
  }
}
.fv .swiper-pagination-bullet {
  margin: 0 0.5rem !important;
  background-color: #fff;
  opacity: 1;
}
.fv .swiper-pagination-bullet-active {
  background-color: #00acd7;
}
.fv .slide-cover {
  height: 80vh;
}
@media screen and (min-width: 1025px) {
  .fv .slide-cover {
    height: 80rem;
  }
}
.fv .slide-cover img {
  -webkit-transition: 7s 1s ease-out;
  transition: 7s 1s ease-out;
}
.fv .fv-ttl {
  position: absolute;
  left: 0;
  bottom: 4rem;
  width: 100%;
  padding: 1rem 3rem;
  background-color: rgba(255, 255, 255, 0.55);
  font-size: clamp(1.4rem, 0.945rem + 1.212vw, 2.4rem);
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .fv .fv-ttl {
    bottom: 7rem;
  }
}
.fv .swiper-slide[class*=-active] .img-cover img {
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
  -webkit-transform: scale(1.05);
  transform: scale(1.05);
}
.fv .swiper-slide[class*=-active] .fv-ttl {
  -webkit-animation: fv-fadeIn 2s 0.5s var(--easing) both;
  animation: fv-fadeIn 2s 0.5s var(--easing) both;
}

@-webkit-keyframes fv-fadeIn {
  0% {
    -webkit-transform: scale(0.5);
    transform: scale(0.5);
    opacity: 0;
    -webkit-filter: blur(300px);
    filter: blur(300px);
  }
  100% {
    -webkit-transform: scale(1);
    transform: scale(1);
    opacity: 1;
    -webkit-filter: blur(0);
    filter: blur(0);
  }
}
@keyframes fv-fadeIn {
  0% {
    -webkit-transform: scale(0.5);
    transform: scale(0.5);
    opacity: 0;
    -webkit-filter: blur(300px);
    filter: blur(300px);
  }
  100% {
    -webkit-transform: scale(1);
    transform: scale(1);
    opacity: 1;
    -webkit-filter: blur(0);
    filter: blur(0);
  }
}
.home-feature,
.home-feature2 {
  padding-top: 5rem;
  padding-bottom: 5rem;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .home-feature,
  .home-feature2 {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }
}
.home-feature .home-feature-inner,
.home-feature .home-feature-inner2,
.home-feature2 .home-feature-inner,
.home-feature2 .home-feature-inner2 {
  position: relative;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  max-width: 120rem;
  margin: 0 auto;
  padding: 0 10rem;
}
.home-feature .home-feature-inner .swiper,
.home-feature .home-feature-inner2 .swiper,
.home-feature2 .home-feature-inner .swiper,
.home-feature2 .home-feature-inner2 .swiper {
  overflow: visible;
}

.home-feature .swiper-button-prev::before,
.home-feature .swiper-button-next::before {
  background-color: #fff;
  -webkit-box-shadow: var(--box-shadow-dark);
  box-shadow: var(--box-shadow-dark);
}

.home-feature .swiper-button-prev::after,
.home-feature .swiper-button-next::after {
  border-color: var(--color-black);
}

.home-feature .swiper-button-prev,
.home-feature .swiper-button-next {
  left: inherit;
  right: inherit;
}

.home-feature .swiper-button-prev {
  right: calc(100% - 1.6rem);
}

.home-feature .swiper-button-next {
  left: calc(100% - 1.6rem);
}

.home-feature .slide {
  overflow: hidden;
  -webkit-transition: var(--transition), opacity 1s;
  transition: var(--transition), opacity 1s;
}

.home-feature a figure {
  position: relative;
  overflow: hidden;
  border-radius: var(--bdrs);
}
.home-feature a figure::before {
  float: left;
  content: "";
  padding-top: 113%;
}
.home-feature a figure::after {
  display: block;
  content: "";
  clear: both;
}
.home-feature a figure > img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s cubic-bezier(0.09, 0.43, 0.1, 0.79);
}
.home-feature a:hover img {
  transform: scale(1.05);
}
.home-feature a p {
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  margin-top: 1.5rem;
  font-weight: 700;
  font-size: clamp(1.5rem, 1.273rem + 0.606vw, 2rem);
  line-height: 1.2;
}
.home-feature a:hover p {
  opacity: var(--opacity);
}
.home-feature .t-feature-btn {
  margin-top: 4rem;
}
@media screen and (min-width: 768px) {
  .home-feature .t-feature-btn {
    margin-top: 5rem;
  }
}

.home-feature2 .t-feature-btn {
  margin-top: 4rem;
}
@media screen and (min-width: 768px) {
  .home-feature2 .t-feature-btn {
    margin-top: 5rem;
  }
}

.home-reviews {
  padding-top: 5rem;
  padding-bottom: 5rem;
}
@media screen and (min-width: 768px) {
  .home-reviews {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }
}

@media screen and (min-width: 768px) {
  .reviews .reviews-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 3rem;
    row-gap: 6rem;
  }
}
@media screen and (max-width: 767px) {
  .reviews .reviews-list li:nth-child(n+2) {
    margin-top: 4rem;
  }
}
.reviews .reviews-list li a {
  display: block;
}
.reviews .reviews-list li a .reviews-fv {
  position: relative;
  overflow: hidden;
  border-radius: var(--bdrs);
}
.reviews .reviews-list li a .reviews-fv::before {
  float: left;
  content: "";
  padding-top: 65%;
}
.reviews .reviews-list li a .reviews-fv::after {
  display: block;
  content: "";
  clear: both;
}
.reviews .reviews-list li a .reviews-fv > img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s cubic-bezier(0.09, 0.43, 0.1, 0.79);
}
.reviews .reviews-list li a:hover .reviews-fv img {
  transform: scale(1.05);
  opacity: 0.8;
}
.reviews .reviews-list li a dl {
  display: flex;
  align-items: center;
  margin-top: 1.5rem;
}
.reviews .reviews-list li a dl dt {
  width: 6rem;
}
.reviews .reviews-list li a dl dt figure {
  border-radius: 0;
  position: relative;
  overflow: hidden;
}
.reviews .reviews-list li a dl dt figure::before {
  float: left;
  content: "";
  padding-top: 100%;
}
.reviews .reviews-list li a dl dt figure::after {
  display: block;
  content: "";
  clear: both;
}
.reviews .reviews-list li a dl dt figure > img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s cubic-bezier(0.09, 0.43, 0.1, 0.79);
}
.reviews .reviews-list li a dl dd {
  flex: 1 0 0;
  padding-left: 1.5rem;
}
.reviews .reviews-list li a dl dd p:last-child span {
  padding-right: 0.5rem;
}
.reviews .reviews-list li a:hover dl {
  opacity: var(--opacity);
}
.reviews .reviews-list li a h3 {
  padding-top: 1.5rem;
  font-size: clamp(1.5rem, 1.273rem + 0.606vw, 2rem);
  font-weight: 700;
  line-height: 1.2;
}
.reviews .reviews-list li a:hover h3 {
  opacity: var(--opacity);
}
.reviews .t-reveiws-btn {
  margin-top: 4rem;
}
@media screen and (min-width: 768px) {
  .reviews .t-reveiws-btn {
    margin-top: 5rem;
  }
}

.instagram {
  padding-top: 5rem;
  padding-bottom: 5rem;
  background-color: #eee;
}
@media screen and (min-width: 768px) {
  .instagram {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }
}
.instagram .instagram-logo-txt img {
  margin: 0 auto;
}
.instagram .instagram-disc {
  padding-top: 1rem;
  padding-bottom: 2.5rem;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .instagram .instagram-disc {
    padding-bottom: 4rem;
  }
}
.instagram .instagram-disc span {
  color: #b20000;
}
.instagram .instagram-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 0.5rem;
  row-gap: 0.5rem;
}
@media screen and (min-width: 768px) {
  .instagram .instagram-list {
    grid-template-columns: repeat(5, 1fr);
  }
}
.instagram .instagram-list li a figure {
  position: relative;
  overflow: hidden;
}
.instagram .instagram-list li a figure::before {
  float: left;
  content: "";
  padding-top: 100%;
}
.instagram .instagram-list li a figure::after {
  display: block;
  content: "";
  clear: both;
}
.instagram .instagram-list li a figure > img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s cubic-bezier(0.09, 0.43, 0.1, 0.79);
}
.instagram .instagram-list li a:hover figure img {
  transform: scale(1.05);
  opacity: 0.8;
}

.dmap {
  aspect-ratio: 4/5;
}
@media screen and (min-width: 768px) {
  .dmap {
    aspect-ratio: 4/2;
  }
}

.dmap iframe {
  width: 100%;
  height: 100%;
}

.search .search-feature-list input {
  opacity: 0;
}

@media screen and (min-width: 768px) {
  .search-feature dl {
    display: flex;
    flex-wrap: wrap;
  }
}
.search-feature dl dt {
  padding-top: 1rem;
  padding-right: 1rem;
  font-weight: 700;
}
.search-feature dl dd {
  flex: 1 0 0;
}
.search-feature dl:nth-child(n+2) {
  margin-top: 2rem;
}
.search-feature dl:nth-child(n+2) dt {
  padding-bottom: 1rem;
}

.search-feature-list {
  display: flex;
  flex-wrap: wrap;
}
.search-feature-list li {
  padding-top: 1rem;
  padding-right: 2rem;
}

.feature .feature-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}
@media screen and (min-width: 768px) {
  .feature .feature-list {
    grid-template-columns: 1fr 1fr 1fr;
    gap: 3rem;
    row-gap: 5rem;
  }
}
.feature .feature-list li a figure {
  position: relative;
  overflow: hidden;
  border-radius: var(--bdrs);
}
.feature .feature-list li a figure::before {
  float: left;
  content: "";
  padding-top: 113%;
}
.feature .feature-list li a figure::after {
  display: block;
  content: "";
  clear: both;
}
.feature .feature-list li a figure > img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s cubic-bezier(0.09, 0.43, 0.1, 0.79);
}
.feature .feature-list li a:hover figure img {
  transform: scale(1.05);
}
.feature .feature-list li a p {
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  padding-top: 1.5rem;
  font-weight: 700;
  font-size: clamp(1.5rem, 1.273rem + 0.606vw, 2rem);
  line-height: 1.2;
}
.feature .feature-list li a:hover p {
  opacity: var(--opacity);
}

.article-body-feature .article-fv {
  margin-bottom: 3rem;
}

.reviews-contributor {
  margin-top: 4rem;
  margin-bottom: 4rem;
  padding: 2rem;
  background-color: #f4f4f4;
  border: 1px solid var(--color-gray);
  border-radius: var(--bdrs);
}
@media screen and (min-width: 768px) {
  .reviews-contributor {
    display: flex;
    justify-content: space-between;
    margin-top: 5rem;
    margin-bottom: 5rem;
    padding: 4rem;
  }
}
.reviews-contributor figure {
  width: 70%;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .reviews-contributor figure {
    width: 30%;
  }
}
@media screen and (max-width: 767px) {
  .reviews-contributor .contributor-desc {
    margin-top: 2rem;
  }
}
@media screen and (min-width: 768px) {
  .reviews-contributor .contributor-desc {
    flex: 1 0 0;
    padding-left: 2rem;
  }
}
.reviews-contributor .contributor-desc .contributor-profile {
  margin-bottom: 1.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px dashed var(--color-gray);
}
.reviews-contributor .contributor-desc .contributor-profile span {
  font-size: clamp(1.5rem, 1.227rem + 0.727vw, 2.1rem);
  font-weight: 700;
}
.reviews-contributor .contributor-desc .contributor-profile p:last-child {
  letter-spacing: 0.08rem;
}

.article-body-reviews .article-fv {
  margin-top: 2rem;
}

.travel-cs {
  padding: 10rem 2rem;
  background-color: var(--color-blue);
  border-radius: var(--bdrs);
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .travel-cs {
    padding: 15rem 5rem;
  }
}
.travel-cs p {
  font-size: clamp(5rem, 0.455rem + 12.121vw, 15rem);
  text-align: center;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.3);
  white-space: nowrap;
  line-height: 1.2;
  text-transform: uppercase;
  animation-name: scrolltext;
  animation-duration: 30s;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
  transition: bottom 1s cubic-bezier(0.43, 0.05, 0.17, 1);
  transition-delay: 0s;
  transition-delay: 0.7s;
}
.travel-cs span {
  display: block;
  font-size: clamp(1.3rem, 0.527rem + 2.061vw, 3rem);
  font-weight: 700;
  color: var(--color-white);
  text-align: center;
}

@keyframes scrolltext {
  0% {
    transform: translate(0%, 0%);
  }
  100% {
    transform: translate(-50%, 0%);
  }
}
.login-block {
  display: flex;
  align-items: center;
  flex-direction: column;
}

.login-block .login-msg {
  padding-bottom: 4rem;
}

.login-block .form-block {
  margin: 0 auto 20px;
  display: flex;
  align-items: center;
}

@media screen and (max-width: 768px) {
  .login-block {
    padding: 80px 20px 0;
  }
  .login-block .login-msg {
    padding: 20px 0;
    font-size: 0.875rem;
  }
}
.callout.callout-danger {
  color: #d90606;
  font-weight: bold;
  margin-bottom: 40px;
}

.login-block .form-block label {
  width: 10rem;
  margin-right: 1.5rem;
  display: block;
}

.form-main {
  flex: 1 0 0;
}

@media only screen and (max-width: 768px) {
  .login-block .form-block {
    display: block;
  }
  .login-block .form-block label {
    margin-right: 0;
    margin-bottom: 0.5rem;
    font-size: 0.875rem;
  }
  .login-block .form-button {
    margin-top: 20px !important;
  }
  .callout.callout-danger {
    margin-bottom: 20px;
    font-size: 0.875rem;
  }
}
.login-block .forget-msg {
  text-align: center;
  margin-top: 40px;
}

.login-block .forget-msg a:link {
  text-decoration: underline;
  color: #1946a5;
}

.login-block .forget-msg a:hover {
  opacity: 0.8;
}

.login-block .input {
  box-shadow: none inset;
  outline: none;
  appearance: none;
  box-sizing: border-box;
  border-radius: 0;
  background: #fff;
  border: 1px solid var(--color-gray);
  border-radius: var(--bdrs);
  padding: 1.5rem;
  width: 100%;
  font-weight: 400;
}

.login-block .form-button {
  display: flex;
  justify-content: center;
  margin-top: 40px;
}

.login-block .form-button button {
  overflow: hidden;
  appearance: none;
  outline: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  background: var(--color-blue);
  font-size: 2.6rem;
  color: #fff;
  width: 100%;
  padding-bottom: 4px;
  letter-spacing: 0.2rem;
  border: 1px solid var(--color-blue);
  border-radius: var(--bdrs);
}

@media only screen and (min-width: 769px) {
  .login-block .form-button button {
    width: 400px;
    height: 72px;
    padding-bottom: 6px;
  }
  .login-block .form-button button:hover {
    background: var(--color-white);
    color: var(--color-blue);
    transition: all 0.3s;
  }
}
@media only screen and (max-width: 768px) {
  .login-block .input {
    font-size: 0.875rem;
  }
  .login-block .form-button button {
    height: 50px;
    font-size: 1rem;
  }
  .login-block .forget-msg {
    text-align: left;
    margin-top: 2rem;
    font-size: 0.875rem;
  }
}
.travel .travel-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}
@media screen and (min-width: 768px) {
  .travel .travel-list {
    grid-template-columns: 1fr 1fr 1fr;
    gap: 3rem;
    row-gap: 5rem;
  }
}
.travel .travel-list li a figure {
  position: relative;
  overflow: hidden;
  border-radius: var(--bdrs);
}
.travel .travel-list li a figure::before {
  float: left;
  content: "";
  padding-top: 65%;
}
.travel .travel-list li a figure::after {
  display: block;
  content: "";
  clear: both;
}
.travel .travel-list li a figure > img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s cubic-bezier(0.09, 0.43, 0.1, 0.79);
}
.travel .travel-list li a:hover figure img {
  transform: scale(1.05);
}
.travel .travel-list li a p {
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  padding-top: 1.5rem;
  font-weight: 700;
  font-size: clamp(1.5rem, 1.273rem + 0.606vw, 2rem);
  line-height: 1.2;
}
.travel .travel-list li a:hover p {
  opacity: var(--opacity);
}

.article-body-travel .article-fv {
  margin-bottom: 3rem;
}

.article-table {
  padding-top: 4rem;
}
.article-table dl {
  border-radius: var(--bdrs);
  overflow: hidden;
  border-bottom: 1px solid var(--color-gray);
}
@media screen and (min-width: 1025px) {
  .article-table dl {
    display: flex;
    flex-wrap: wrap;
  }
}
.article-table dl dt {
  padding: 2rem 0;
  border-top: 1px solid var(--color-gray);
}
@media screen and (min-width: 1025px) {
  .article-table dl dt {
    width: 18rem;
    padding: 2rem 0 2rem 2rem;
    background-color: var(--color-black);
    color: var(--color-white);
  }
}
.article-table dl dd {
  padding: 0 0 2rem;
}
@media screen and (min-width: 1025px) {
  .article-table dl dd {
    width: calc(100% - 18rem);
    padding: 2rem 0 2rem 2rem;
    border-top: 1px solid var(--color-gray);
  }
  .article-table dl dd a {
    text-decoration: underline;
  }
  .article-table dl dd a:hover {
    text-decoration: none;
  }
}

.btn-tariff {
  margin-top: 2rem;
}

.tariff-list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1.5rem;
  margin-top: 5rem;
}
.tariff-list .btn {
  display: flex;
  align-items: center;
  width: 100%;
  text-align: left;
  font-size: clamp(1.5rem, 1.5rem + 0vw, 1.5rem);
  padding: 1rem 3rem 1rem 1rem;
}
.tariff-list .btn.btn-pdf::after {
  right: 1rem;
}
.tariff-list .btn.btn-movie::after {
  right: 1rem;
}

.tariff-list + .tariff-list {
  margin-top: 2rem;
}

.foods .foods-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}
@media screen and (min-width: 768px) {
  .foods .foods-list {
    grid-template-columns: 1fr 1fr 1fr;
    gap: 3rem;
    row-gap: 5rem;
  }
}
.foods .foods-list li a figure {
  position: relative;
  overflow: hidden;
}
.foods .foods-list li a figure::before {
  float: left;
  content: "";
  padding-top: 65%;
}
.foods .foods-list li a figure::after {
  display: block;
  content: "";
  clear: both;
}
.foods .foods-list li a figure > img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s cubic-bezier(0.09, 0.43, 0.1, 0.79);
}
.foods .foods-list li a:hover figure img {
  transform: scale(1.05);
}
.foods .foods-list li a p {
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  padding-top: 1.5rem;
  font-weight: 700;
  font-size: clamp(1.5rem, 1.273rem + 0.606vw, 2rem);
  line-height: 1.2;
}
.foods .foods-list li a:hover p {
  opacity: var(--opacity);
}

.article-body-foods .article-fv {
  margin-bottom: 3rem;
}

.article-table {
  padding-top: 4rem;
}
.article-table dl {
  border-radius: var(--bdrs);
  overflow: hidden;
  border-bottom: 1px solid var(--color-gray);
}
@media screen and (min-width: 1025px) {
  .article-table dl {
    display: flex;
    flex-wrap: wrap;
  }
}
.article-table dl dt {
  padding: 2rem 0;
  border-top: 1px solid var(--color-gray);
}
@media screen and (min-width: 1025px) {
  .article-table dl dt {
    width: 18rem;
    padding: 2rem 0 2rem 2rem;
    background-color: var(--color-black);
    color: var(--color-white);
  }
}
.article-table dl dd {
  padding: 0 0 2rem;
}
@media screen and (min-width: 1025px) {
  .article-table dl dd {
    width: calc(100% - 18rem);
    padding: 2rem 0 2rem 2rem;
    border-top: 1px solid var(--color-gray);
  }
  .article-table dl dd a {
    text-decoration: underline;
  }
  .article-table dl dd a:hover {
    text-decoration: none;
  }
}

.article-body-note {
  margin-right: auto;
  margin-left: auto;
}
.article-body-note .article-fv {
  margin-top: 2rem;
  margin-bottom: 2rem;
}

.access {
  overflow-x: hidden;
}
.access .access-hyogo {
  background-color: #f4f4f4;
}
.access .access-anchor {
  display: flex;
  justify-content: center;
  padding-top: 6rem;
  padding-bottom: 6rem;
}
.access .access-anchor .access-anchor-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
.access .access-anchor .access-anchor-inner p {
  padding-right: 1rem;
  font-size: clamp(1.3rem, 1.164rem + 0.364vw, 1.6rem);
  font-weight: 600;
}
.access .access-anchor .access-anchor-inner ul {
  display: flex;
  flex-wrap: wrap;
}
.access .access-anchor .access-anchor-inner ul li a {
  font-size: clamp(1.3rem, 1.164rem + 0.364vw, 1.6rem);
  font-weight: 600;
  color: var(--color-blue);
  text-decoration: underline;
}
.access .access-anchor .access-anchor-inner ul li a:hover {
  text-decoration: none;
}
@media screen and (max-width: 767px) {
  .access .access-anchor .access-anchor-inner ul li {
    width: 50%;
    margin-top: 1rem;
  }
  .access .access-anchor .access-anchor-inner ul li:nth-child(even)::before {
    padding-right: 1.5rem;
    content: "/";
  }
}
@media screen and (min-width: 768px) {
  .access .access-anchor .access-anchor-inner ul li:nth-child(n+2)::before {
    padding-right: 1.5rem;
    padding-left: 1.5rem;
    content: "/";
  }
}
.access .access-ttl {
  position: relative;
  margin-top: 6rem;
  background-color: var(--color-blue);
  font-size: clamp(1.6rem, 1.236rem + 0.97vw, 2.4rem);
  font-weight: 700;
  color: var(--color-white);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .access .access-ttl {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
  }
}
@media screen and (min-width: 768px) {
  .access .access-ttl {
    margin-top: 11rem;
  }
}
.access .access-ttl:first-of-type {
  margin-top: 0;
}
.access .access-ttl::before {
  content: "";
  position: absolute;
  top: 0;
  width: 50%;
  height: 100%;
  background-color: var(--color-blue);
}
.access .access-ttl.access-ttl-bdl {
  border-radius: 0 0.6rem 0.6rem 0;
}
.access .access-ttl.access-ttl-bdl::before {
  left: -50%;
}
.access .access-ttl.access-ttl-bdr {
  border-radius: 0.6rem 0 0 0.6rem;
}
.access .access-ttl.access-ttl-bdr::before {
  right: -50%;
}
.access .access-map {
  padding-top: 3rem;
  padding-bottom: 3rem;
  border-bottom: 2px dashed #ccc;
}
.access .access-map.access-map-no-bdr {
  border-bottom: none;
}
.access .access-map .access-map-inner {
  width: 100%;
  overflow-y: hidden;
  overflow-x: auto;
}
.access .access-map .access-map-inner img {
  min-width: 700px;
}
@media screen and (min-width: 768px) {
  .access .access-map {
    padding-top: 5rem;
    padding-bottom: 5rem;
  }
}
.access .access-btn {
  margin-top: 5rem;
}

.scroll-txt {
  padding-bottom: 1.5rem;
}
.scroll-txt::before {
  content: "";
  display: inline-block;
  margin-right: 0.5rem;
  vertical-align: middle;
  line-height: 1;
  width: 0;
  height: 0;
  border-style: solid;
  border-color: transparent;
  border-width: 0.64952em 0.375em;
  border-top-color: var(--color-blue);
  border-bottom: 0;
}

.videos .videos-anker {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 3rem;
}
@media screen and (min-width: 768px) {
  .videos .videos-anker {
    margin-bottom: 5rem;
  }
}
.videos .videos-anker li {
  margin-right: 2rem;
  margin-left: 2rem;
}
.videos .videos-anker li a {
  display: block;
  position: relative;
  padding-top: 1rem;
  padding-bottom: 1rem;
  padding-left: 1.5rem;
  border-bottom: 1px solid #ccc;
  font-weight: 500;
  line-height: 1;
}
.videos .videos-anker li a::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 0.5rem;
  height: 0.5rem;
  border-bottom: 1px solid var(--color-blue);
  border-right: 1px solid var(--color-blue);
  transform: translateY(-50%) rotate(45deg);
}
.videos .videos-anker li a:hover {
  border-bottom-color: var(--color-blue);
}
.videos .videos-ttl {
  position: relative;
  margin-bottom: 2rem;
  font-weight: 700;
  font-size: clamp(2.2rem, 1.927rem + 0.727vw, 2.8rem);
  line-height: 1.2;
}
@media screen and (min-width: 768px) {
  .videos .videos-ttl {
    margin-bottom: 5rem;
  }
}
.videos .videos-ttl::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #ccc;
}
.videos .videos-ttl span {
  position: relative;
  display: inline-flex;
  padding-bottom: 1.5rem;
}
@media screen and (min-width: 768px) {
  .videos .videos-ttl span {
    padding-bottom: 2.5rem;
  }
}
.videos .videos-ttl span::after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 100%;
  height: 3px;
  background-color: var(--color-blue);
}
.videos .videos-ttl:not(:first-of-type) {
  margin-top: 5rem;
}
@media screen and (min-width: 768px) {
  .videos .videos-ttl:not(:first-of-type) {
    margin-top: 10rem;
  }
}
@media screen and (min-width: 768px) {
  .videos .videos-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 3rem;
    row-gap: 5rem;
  }
}
@media screen and (min-width: 1025px) {
  .videos .videos-list {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .videos .videos-list li:nth-child(n+2) {
    margin-top: 3rem;
  }
}
.videos .videos-list li .yt-modal {
  position: relative;
  transition: 0.8s cubic-bezier(0.09, 0.43, 0.1, 0.79);
}
.videos .videos-list li .yt-modal iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
}
.videos .videos-list li .yt-modal p {
  padding-top: 0.5rem;
  font-weight: 600;
  font-size: clamp(1.4rem, 1.309rem + 0.242vw, 1.6rem);
  line-height: 1.5;
}
@media screen and (min-width: 768px) {
  .videos .videos-list li .yt-modal p {
    padding-top: 1rem;
  }
}
.videos .videos-list li .yt-modal a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.videos .videos-list li .yt-modal:hover {
  opacity: var(--opacity);
}/*# sourceMappingURL=style.css.map */