﻿@charset "utf-8";

/*
  File Name   : style.css
  Description : CSS
*/


/* PC Layout ******************************************************************************************* */

/* Common
============================================================ */


/* Home
============================================================ */
/*add 20200803*/
body{
	margin: 0;
	font-family: 'Noto Serif JP';
}

.kv-slide-embedWrap {
    margin-top: 100px;
    position: relative;
    z-index: -1;
}

.kv-slide-ytWrap {
    position: relative;
    z-index: -1;
}
.inline-YTPlayer {
    margin-top: 100px;
    max-width: 100% !important;
    position: relative;
    z-index: -1;
}

#player {
    width: 100%;
    height: auto !important;
    aspect-ratio: 16 / 9;
    padding: 0 !important;
    position: relative;
}

.inline-YTPlayer iframe {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 16 / 9;
    margin: 0 !important;
}
.inlinePlayButton {
    display: none;
}

.kv-slide {
    position: relative;
    height: 750px;
    overflow: hidden;
    margin: 0 auto;
    z-index: 1;
    margin-top: 100px;
}

h1.main-title {
    font-size: 60px;
    color: #ffffff;
    z-index: 999;
    position: absolute;
    font-family: "baskerville-display-pt", serif;
    font-weight: 600;
    letter-spacing: 1px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.slide {
  position: relative;
  width: 100%;
  height: 400px;
  overflow: hidden;
}

.slide-image {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  animation: slider-1 24s linear infinite;
}

.slide-image::before {
	content: '';
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    background-color: rgb(0 0 0 / 50%);
    z-index: 999;
}

.slide-image:nth-child(1) {
  background-image: url("../images/top/main-kv1.png");
  animation-delay: -2s;
}

.slide-image:nth-child(2) {
  background-image: url("../images/top/main-kv2.png");
  animation-delay: 6s;
}

.slide-image:nth-child(3) {
  background-image: url("../images/top/main-kv3.png");
  animation-delay: 14s;
}


.slide-image:nth-child(4) {
  background-image: url("../images/top/main-kv4.png");
  animation-delay: 22s;
}


.slide-image:nth-child(5) {
  background-image: url("../images/top/main-kv5.png");
  animation-delay: 30s;
}

@keyframes slider-1 {
  0% {
    opacity: 0;
    transform: scale(1);
  }
  4.16% {
    opacity: 1;
  }
  33.33% {
    opacity: 1;
  }
  41.66% {
    opacity: 0;
    transform: scale(1.2);
  }
  100% {
    opacity: 0;
  }
}

.contents {
	box-sizing: border-box;
	margin: 60px auto;
	width: 1000px;
}

.contents ul {
    list-style: none;
    display: flex;
    justify-content: space-between;
}

.contents li {
	height: 500px;
    border-radius: 10px;
    position: relative;
    width: 30%;
}

.contents li:first-child {
    background: url("../images/top/bg01.png") no-repeat;
	background-size: cover;
}

.contents li:nth-child(2) {
    background: url("../images/top/bg02.png") no-repeat;
	background-size: cover;
}

.contents li:last-child {
    background: url("../images/top/bg03.png") no-repeat;
	background-size: cover;
}

.contents h2 {
	margin-bottom: 10px;
    font-size: 30px;
    color: #fff;
    font-family: "baskerville-display-pt", serif;
    font-weight: 600;
    white-space: nowrap;
    line-height: 35px;
}

.contents p {
	margin-bottom: 20px;
    font-size: 14px;
    color: #fff;
	line-height: 25px;
}

.contents-top {
	width: 100%;
	position: relative;
}

.box-inner {
    position: absolute;
    bottom: 0;
    padding: 20px;
    width: 100%;
}

.box-inner .ta_right {
	float: right;
}

.box-inner a.btn {
    font-size: 15px;
    padding: 7px 35px 7px 0;
    font-weight: 700;
    color: #fff;
    display: inline-block;
    transition: .5s;
    border-bottom: 1px solid #fff;
    border-radius: inherit;
}

.box-inner a.btn::before {
	border-top: solid 1px #fff;
    border-right: solid 1px #fff;
    top: auto;
    right: 23px;
    margin-top: 8px;
}

.box-inner a.btn:hover {
    opacity: 0.7;
}

.p-top-terminalBtn {
    width: fit-content;
    max-width: 90%;
    margin: 80px auto 120px;
    padding: 14px 80px 14px 40px;
    color: #fff;
    line-height: 1.65;
    font-size: 20px;
    font-weight: 700;
    background-color: #60ADB8;
    border-radius: 50px;
    display: block;
    position: relative;
    z-index: 0;
    transition: .3s;
}

.p-top-terminalBtn:hover {
    background-color: #0DAFC4;
}

.p-top-terminalBtn::after {
	content: '';
    width: 7px;
    height: 7px;
    border: 0;
    border-top: solid 1px #fff;
    border-right: solid 1px #fff;
    position: absolute;
    top: calc(50% - 4px);
    right: 30px;
    transform: rotate(45deg);
}

.news {
	box-sizing: border-box;
	margin: 0 auto;
	width: 1000px;
	margin-bottom: 60px;
}

.news-inner {
    display: flex;
    align-items: center;
    padding: 25px 0;
    position: relative;
}

.news-inner h3 {
	font-size: 22px;
    font-weight: 600;
    color: #0DAFC4;
}

.news-inner .date {
	margin-left: 40px;
}

.news-inner .news-text {
	margin-left: 30px;
    text-decoration: underline;
    width: 550px;
}

.news-inner a {
	color: #006C90;
}

.news-inner a.btn {
	background: #fff;
    padding: 7px 35px 7px 0;
    font-size: 15px;
    font-weight: 700;
    color: #303338;
    display: inline-block;
    position: absolute;
    right: 0;
    transition: .5s;
    border-bottom: 1px solid #1E1E1E;
}

.news-inner a.btn:hover {
	opacity: 0.7;
	transition: .5s;
}

.spot_textarea {
    position: absolute;
    width: 1000px;
    top: 40px;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    text-align: left;
	color: #006C90;
}

.spot_textarea h2 {
    font-size: 70px;
    font-weight: 600;
    font-family: "baskerville-display-pt", serif;
	letter-spacing: 3px;
}

.spot_textarea p {
    width: 700px;
    line-height: 25px;
}

.menu-btn {
	width: 1000px;
	margin: 70px auto 100px;
}

.menu-btn ul {
	display: flex;
	justify-content: space-evenly;
}

.menu-btn li {
	width: 125px;
}

.contents-bottom {
    width: 100%;
    position: relative;
}

.topics_textarea {
    width: 1000px;
    margin: auto;
    text-align: left;
}

.topics_textarea h2 {
    font-size: 54px;
    font-weight: 600;
    font-family: "baskerville-display-pt", serif;
    letter-spacing: 1px;
    color: #0DAFC4;
	text-align: center;
}

a.topics-btn {
	background: #fff;
    padding: 7px 10px;
    font-size: 18px;
    font-weight: 600;
    color: #303338;
    transition: .5s;
    border: 1px solid #1E1E1E;
    text-align: center;
    margin: 60px auto 0;
    display: block;
    width: 200px;
    border-radius: 30px;
    position: relative;
}

a.topics-btn:hover {
	opacity: 0.7;
	transition: .5s;
}

a.topics-btn::before {
	content: '';
    width: 6px;
    height: 6px;
    border: 0;
    border-top: solid 1px #303338;
    border-right: solid 1px #303338;
    position: absolute;
    top: 50%;
    right: 20px;
    margin-top: -4px;
    transform: rotate(45deg);
}

.weather {
	margin: 100px 0 0;
}

.weather-inner {
	width: 1000px;
	margin: 0 auto;
}

.weather-inner ul {
	display: flex;
	justify-content: space-between;
	margin: 30px 0;
}

.weather-inner ul li {
	width: 32%;
}

/* 検索ブロック
----------------------------------------------------------- */
.search-block {
    width: 1000px;
    margin: 60px auto 0;
	display: flex;
    align-items: center;
	justify-content: center;
}

select.aria,
select.theme,
select.day{
    width: 25%;
    font-size: 16px;
    color: #707070;
    text-align: center;
    padding: 10px;
	border: 1px solid #303338;
    border-radius: 10px;
	margin-right: 20px;
}

input.search-btn {
    background: #0DC493;
    color: #fff;
    padding: 10px 20px;
    font-size: 16px;
    border-radius: 10px;
    border: none;
}

.select-box_inner {
    width: 1000px;
    margin: 60px auto 0;
}

.select-box_inner ul {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
}

.select-box_inner ul li:first-child,
.select-box_inner ul li:nth-child(2n){
    width: 25%;
    margin-right: 20px;
}

.select-box_inner ul li:nth-child(3n) {
    width: 60%;
}

select.aria02,
select.cat{
    width: 100%;
    font-size: 16px;
    color: #707070;
    text-align: center;
    padding: 10px;
	border: 1px solid #303338;
    border-radius: 10px;
	margin-right: 20px;
}

input.keyword{
    width: 80%;
    font-size: 16px;
    color: #707070;
    text-align: center;
    padding: 10px;
	border: 1px solid #303338;
    border-radius: 10px;
	margin-right: 20px;
}

/* ピックアップコンテンツ　トップページ
----------------------------------------------------------- */
/* simplebar用 */
.simplebar-track {
    background: #E5E5E5;
    border-radius: 10px;
	width: 1000px;
	margin: 0 auto;
}

.simplebar-track .simplebar-scrollbar.simplebar-visible::before{
  opacity:1;
}

.simplebar-track .simplebar-scrollbar::before{
  background: #0DAFC4;
}

/* その他装飾 */
.scroll-area{
	height: auto;
    padding-bottom: 40px;
    letter-spacing: 0.06em;
    line-height: 1.8;
    display: block;
    margin: 40px auto 0;
    text-align: center;
}

.flex ul{
	display:flex;
}

.flex ul li{
	width:380px;
	height:auto;
	margin: 0 50px 0 0;
	text-align: left;
    letter-spacing: 0;
}

.flex ul li:first-child{
	margin-left: 100px;
}

.flex ul li:last-child{
	margin-right: 100px;
}

.flex ul li p{
	margin-top: 5px;
    font-weight: 700;
    font-size: 18px;
    color: #006C90;
}

.flex ul li img{
	border-radius: 5px;
}

.flex ul li a{
	color: #303338;
}

/* 島の紹介一覧ページ */
.island-box {
    display: flex;
	align-items: center;
	padding-top: 80px;
}

.island-box01 {
    width: 53%;
}

.island-box02 {
	width: 47%;
    background: linear-gradient(180deg, rgba(0,161,181,1) 0%, rgba(71,226,177,1) 100%);
    height: 330px;
    align-items: center;
    display: flex;
	border-top-right-radius: 30px;
	border-bottom-right-radius: 30px;
}

.island-box03 {
	width: 47%;
    background: linear-gradient(180deg, rgba(0,161,181,1) 0%, rgba(71,226,177,1) 100%);
    height: 330px;
    align-items: center;
    display: flex;
	border-top-left-radius: 30px;
	border-bottom-left-radius: 30px;
}

.island-box_inner {
    width: 80%;
    margin: 0 auto;
}

h2.island {
    color: #fff;
    font-size: 30px;
    letter-spacing: 1px;
	margin-bottom: 10px;
	font-weight: 600;
    font-family: "baskerville-display-pt", serif;
}

p.island-txt {
    color: #fff;
}

a.island-btn {
    margin-top: 30px;
    float: right;
    letter-spacing: 1px;
    font-size: 15px;
    padding: 7px 35px 7px 0;
    font-weight: 700;
    transition: .5s;
    border-bottom: 1px solid #fff;
    border-radius: inherit;
    color: #fff;
	position: relative;
}

a.island-btn::before {
    content: '';
    width: 6px;
    height: 6px;
    border: 0;
	position: absolute;
	border-top: solid 1px #fff;
    border-right: solid 1px #fff;
    top: auto;
    right: 4px;
    margin-top: 8px;
	transform: rotate(45deg);
}

a.island-btn:hover {
    opacity: 0.7;
}

/* 島の紹介詳細ページ */

.heading-img {
	height: 230px;
}

.wave {
    margin-top: 100px;
    margin-bottom: 15px;
    background: url("../images/common/page-bg.png")no-repeat;
    background-size: cover;
}

.mukaishima-bnr,
.hakatajima-bnr,
.yumeshima-bnr,
.ikuchijima-bnr,
.oshima-bnr,
.onomichi-bnr,
.omishima-bnr,
.innoshima-bnr,
.imabari-bnr{
    margin-top: 100px;
    margin-bottom: 15px;
}

.wave h1.title {
    font-size: 40px;
    letter-spacing: 2px;
    color: #fff;
    text-align: center;
    padding-top: 90px;
	font-family: "baskerville-display-pt", serif;
    font-weight: 600;
}

.contents-box {
    margin-top: 30px!important;
}

.island-img {
    width: 60%;
    margin: 0 auto 20px;
}

p.island-text {
    line-height: 25px;
    font-weight: 400;
	margin-bottom: 60px;
}

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

.flex-2box li{
	width: 48%;
    text-align: center;
}

.flex-2box li.vertical img {
    width: 320px;
}

.spot-contents {
	background: url("../images/island/island-bg.png");
}

.spot-contents-inner {
	
}

h3.spot-name {
	padding-top: 80px;
    font-size: 40px;
    text-align: center;
    font-weight: 600;
}

h3.spot-name::after {
    content: '';
    border-bottom: solid 3px #0DAFC4;
    width: 100px;
    text-align: center;
    display: block;
    margin: 15px auto;
}

.spot-box {
	padding: 80px 0 50px;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.spot-box li {
	width: 48%;
	text-align: center;
	padding-bottom: 60px;
}

.spot-box li h3.title {
	background-image: url("../images/island/circle.svg");
    background-repeat: no-repeat;
    background-size: 40px;
    height: 40px;
    display: table;
    margin: 0 0 10px;
    background-position: left;
	padding-left: 15px;
}

.spot-box li h3.title span {
    font-size: 18px;
    font-weight: 600;
    color: #3E3A39;
    letter-spacing: 2px;
    display: table-cell;
    vertical-align: middle;
	text-align: left;
}

.spot-box li h3.title span .small {
    font-size: 12px;
}

.spot-box li img {
    margin-bottom: 15px;
}

.spot-box li .vertical{
    width: 320px;
}

.spot-box li p {
    padding-bottom: 60px;
	line-height: 25px;
	text-align: left;
}

.spot-box li p span {
    color: #2672B7;
    text-decoration: underline;
	font-weight: 600;
}

.island-btn.inner1000 {
    margin-top: 80px;
}

.flex-box {
    display: flex;
    justify-content: center;
	flex-wrap: wrap;
}

.flex-box .island-name {
	text-align: center;
	width: 185px;
	border-radius:40px;
	background: #F8F8F8;
	border: 1px solid #0DAFC4;
	color: #0DAFC4;
	letter-spacing:1px;
	cursor: pointer;
	transition: all 0.25s ease;
	margin-bottom: 20px;
	padding: 10px;
	margin-right: 18px;
}
.flex-box .island-name:nth-child(5) {
	text-align: center;
	width: 185px;
	border-radius:40px;
	background: #F8F8F8;
	border: 1px solid #0DAFC4;
	color: #0DAFC4;
	letter-spacing:1px;
	cursor: pointer;
	transition: all 0.25s ease;
	margin-bottom: 20px;
	padding: 10px;
	margin-right: 0;
}

.flex-box .island-name p {
	font-size: 18px;
	font-weight: 600;
}

.flex-box .island-name:hover {
    color:white;
    background: #0DAFC4;
}

.flex-box .island-name:active {
    letter-spacing: 2px;
}

.flex-box .island-name2 {
	text-align: center;
	width: 220px;
	border-radius:40px;
	background: #F8F8F8;
	border: 1px solid #0DAFC4;
	color: #0DAFC4;
	letter-spacing:1px;
	cursor: pointer;
	transition: all 0.25s ease;
	margin-bottom: 20px;
	padding: 10px;
}

.flex-box .island-name2 p {
	font-size: 18px;
	font-weight: 600;
}

.flex-box .island-name2:hover {
    color:white;
    background: #0DAFC4;
}

.flex-box .island-name2:active {
    letter-spacing: 2px;
}

.inner-btn {
    display: flex;
    justify-content: space-around;
}

a.map-btn {
    font-size: 17px;
    color: #EA7016;
    background: #fff;
    border: 1px solid #EA7016;
    padding: 8px 0;
    width: 200px;
    display: block;
    border-radius: 30px;
	cursor:pointer;
}

a.map-btn:hover {
    color: #fff;
    background: #EA7016;
	transition: .5s;
}

a.detail-btn {
    font-size: 17px;
    color: #0DC493;
    background: #fff;
    border: 1px solid #0DC493;
    padding: 8px 0;
    width: 200px;
    display: block;
    border-radius: 30px;
	cursor:pointer;
}

a.detail-btn:hover {
    color: #fff;
    background: #0DC493;
	transition: .5s;
}

.island-btn h2.title {
	text-align: center;
    font-size: 35px;
    font-weight: 700;
    letter-spacing: 1px;
    padding: 30px 0 0;
    background-position: center;
    margin-bottom: 30px;
}

.island-btn .onpage {
	background: #0DAFC4!important;
    color: #fff!important;
}

h3.islandinfo-title {
    font-size: 20px;
    text-align: center;
    color: #006C90;
    font-weight: 700;
    letter-spacing: 1px;
    margin-bottom: 15px;
}

.island-info{
	width: 600px;
    border-spacing: 0;
    margin: 0 auto 60px;
	border-collapse: collapse;
	color: #444444;
}

.island-info tr{
	border-top: solid 1px #9A9A9A;
	border-bottom: solid 1px #9A9A9A;
	font-size: 15px;
}

.island-info th{
	padding: 20px 0 20px 50px;
    text-align: left;
    width: 200px;
	font-weight: 600;
}

.island-info td{
	padding: 20px 40px;
	text-align: left;
}

.island-info td a{
	color: #006C90;
	text-decoration: underline;
}

h4.island-subtitle {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 10px;
}

h5.island-subname {
    font-size: 17px;
    font-weight: 600;
    margin: 35px 0 5px;
}

h3.table-title {
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 1px;
	margin: 60px 0 15px;
}

.table-list{
	width: 500px;
    border-spacing: 0;
	border-collapse: collapse;
	color: #444444;
}

.table-list tr{
	border-top: solid 1px #9A9A9A;
	font-size: 15px;
	display: table;
    width: 100%;
}

.table-list tr:last-child{
	border-top: solid 1px #9A9A9A;
	border-bottom: solid 1px #9A9A9A;
	font-size: 15px;
	display: table;
    width: 100%;
}

.table-list th{
	padding: 20px 0 20px 30px;
    text-align: left;
    width: 30%;
    font-weight: 600;
    display: table-cell;
    vertical-align: middle;
    white-space: nowrap;
}

.table-list td{
	padding: 20px 30px;
	text-align: left;
}

.table-list td a{
	color: #006C90;
	text-decoration: underline;
}

/* スポット一覧ページ */

.mymap {
    display: flex;
}

.mymap iframe {
    width: 1000px;
	margin: 0 auto;
}

.spot-block {
    padding: 90px 0;
}

.spot-block-inner {
    width: 1000px;
    margin: 0 auto;
}

.spot-block-inner ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.spot-block-inner ul li {
    width: 30%;
	margin-bottom: 50px;
	position: relative;
}

.spot-namebox {
	margin-top: 10px;
	text-align: center;
}

.spot-namebox h4.name {
	font-size: 18px;
	position: relative;
	font-weight: 700;
}

.selectbox-3 {
    display: inline-flex;
    align-items: center;
    position: relative;
}

.selectbox-3::after {
    position: absolute;
    right: 15px;
    width: 10px;
    height: 7px;
    background-color: #535353;
    clip-path: polygon(0 0, 100% 0, 50% 100%);
    content: '';
    pointer-events: none;
}

.selectbox-3 select {
    appearance: none;
    min-width: 230px;
    height: 2.8em;
    padding: .4em calc(.8em + 30px) .4em .8em;
    border: 1px solid #d0d0d0;
    border-radius: 3px;
    background-color: #fff;
    color: #333333;
    font-size: 1em;
    cursor: pointer;
}

/* スポット詳細ページ */

.block-box {
	margin: 0 auto;
}

h1.spot-title {
    font-size: 40px;
    font-weight: 600;
    color: #0DAFC4;
    width: 1000px;
	margin: 60px auto 30px;
}

/* スライダー共通のスタイル */
.slider_container * {
  box-sizing: border-box;
}
.slider_container img {
  max-width: 100%;
}

/* メインスライダーのスタイル */
#slider {
  margin-bottom: 50px; 
}
#slider .slick-slide {
	margin: 0 30px;
	width: 700px;
}

/* サムネイルスライダーのスタイル */
#thumbs {
	width: 1000px;
	margin:0 auto;
}

#thumbs .slick-slide {
	margin: 0 5px;
	width: 32%!important;
}

.spot_detail {
    width: 1000px;
    margin: 80px auto;
}

h3.spot_detail-title {
    font-size: 25px;
    color: #0DAFC4;
    font-weight: 700;
	margin-bottom: 25px;
}

h3.spot_detail-title::after {
	content: '';
    border-bottom: solid 3px;
    width: 100px;
    text-align: center;
    display: block;
    padding-bottom: 10px;
}

p.spot_detail-text {
    letter-spacing: 1px;
    line-height: 28px;
}

h3.info-title {
    font-size: 30px;
    text-align: center;
    color: #0DAFC4;
    font-weight: 700;
    letter-spacing: 1px;
	margin-bottom: 25px;
}

.informaition{
	width: 1000px;
    border-spacing: 0;
    margin: 0 auto;
	border-collapse: collapse;
	color: #444444;
}

.informaition tr{
	border-top: solid 1px #9A9A9A;
	border-bottom: solid 1px #9A9A9A;
	font-size: 15px;
}

.informaition th{
	padding: 20px 0 20px 40px;
    text-align: left;
    width: 250px;
	font-weight: 600;
}

.informaition td{
	padding: 20px 30px;
	text-align: left;
}

.informaition td a{
	color: #006C90;
	text-decoration: underline;
}

.spot-map {
    margin: 80px auto 100px;
    display: block;
    width: 1000px;
}

.near-spotbox {
    width: 1000px;
    margin: 0 auto;
}

.near-spotbox .title01 {
    font-size: 25px;
    color: #0DAFC4;
    font-weight: 700;
    letter-spacing: 1px;
    margin-bottom: 30px;
}

.near-spotbox ul {
    display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.near-spotbox ul li {
    width: 22%;
}

/* レンタサイクルページ */
h2.title {
    margin: 0 auto;
    text-align: center;
    font-size: 30px;
    color: #01A6AD;
    font-weight: 600;
}

.main-rental {
    margin: 50px auto 0px;
    width: 1000px;
    text-align: center;
}

section.rentalbike {
    width: 1000px;
    margin: 0 auto;
}

.bike-list {
	margin: 40px 0 0;
}

.bike-list ul {
    display: flex;
    justify-content: space-between;
	flex-wrap: wrap;
}

.bike-list ul li {
	width: 47%;
	margin: 0 0 60px;
}

.bike-list ul li img {
    box-shadow: 0 0 4px 0 rgba(0, 0, 0, .2);
}

.bike-title {
    background: #0DAFC4;
    text-align: center;
    color: #fff;
    font-size: 18px;
    padding: 5px;
    margin-bottom: 10px;
    border-radius: 5px;
	font-weight: 700;
}

p.bike-text {
    line-height: 25px;
    font-size: 14px;
    margin: 15px 0 0;
}

.bike-list ul li tr {
    border-top: solid 1px #D4D4D4;
	vertical-align: middle;
}

.bike-list ul li th {
	background: #FFFBDE;
	font-size: 13px;
	text-align: center;
	padding: 8px 0;
	width: 35%;
	vertical-align: middle;
}

.bike-list ul li td {
	font-size: 13px;
	padding: 8px 20px;
	border-left: solid 1px #D4D4D4;
	vertical-align: middle;
}

.bike-list ul li tr:last-child {
    border-top: solid 1px #D4D4D4;
	border-bottom: solid 1px #D4D4D4; 
}

.bike-list ul li table {
    border-collapse:  collapse;
	width: 100%;
	margin-top: 15px;
}

.bike-subbox {
    width: 100%;
	margin: -35px 0 20px;
}

.bike-subbox tr {
    border-top: solid 1px #D4D4D4;
	vertical-align: middle;
}

.bike-subbox th {
    border-right: solid 1px #D4D4D4;
	background: #FFFBDE;
	font-size: 13px;
	text-align: center;
	padding: 8px 0;
	width: 50%;
}

.bike-subbox td {
	font-size: 13px;
	padding: 8px 20px;
}

.bike-subbox tr:last-child {
    border-top: solid 1px #D4D4D4;
	border-bottom: solid 1px #D4D4D4; 
}

.bike-subbox table {
    border-collapse:  collapse;
	width: 100%;
	margin-top: 15px;
}

p.bike_sub-title {
    font-size: 14px;
    margin: 15px 0 5px;
}

p.sub-text {
    font-size: 13px;
	margin-top: 5px;
}

h2.m-title {
    color: #2F85A2;
    font-size: 25px;
    font-weight: 700;
    letter-spacing: 1px;
}

.main-rental p {
	line-height: 25px;
	margin-top: 10px;
}

.sec_qa{
	padding: 40px 0 80px;
}
.wrap_qa{
	width: 1000px;
    margin: 0 auto;
}
.wrap_qa .wrap_title{
	margin-bottom: 70px;
	text-align: center;
}
.wrap_qa .wrap_title p{
	margin-top: 0.5em;
    font-weight: 400;
    font-size: 18px;
    color: #3B0C05;
}
.list_qa {
    margin-bottom: 20px;
}
.list_qa input{
	display: none;
}
.list_qa .box_q{
	background: #FFE98D;
}
.list_qa .box_q label{
	position: relative;
    display: block;
    padding: 20px 50px 20px 70px;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 1.5;
    cursor: pointer;
}
.list_qa .box_q label::before{
	content: "Q";
	position: absolute;
    top: 11px;
    left: 25px;
    font-size: 25px;
}
.list_qa .box_q label::after{
	content: "";
	position: absolute;
	right: 25px;
    top: 25px;
    display: block;
    width: 17px;
    height: 17px;
	background:  url(https://image.dive-hiroshima.com/wp-content/uploads/2022/04/icon_arrow.svg) center center / 100% auto no-repeat;
	transform-origin: center center;
	transition: transform .4s;
}
.list_qa input:checked ~ .box_q label::after{
	-webkit-transform: rotate(180deg);
	transform: rotate(180deg);
}
.list_qa .box_a{
	height: 0;
	padding: 0 60px;
	overflow: hidden;
	background: transparent;
	transition: padding .4s, background .4s;
	position: relative;
}

.list_qa .box_a p{
	font-size: 16px;
}
.list_qa .box_a > *:first-child::before{
	content: "A";
    line-height: 1;
    position: absolute;
    top: 18px;
    left: 25px;
    font-size: 25px;
	color: #EA7016;
}
.list_qa .box_a *{
	opacity: 0;
	transition: .4s 0s;
}
.list_qa input:checked ~ .box_a{
	height: auto;
	padding: 20px 50px 20px 70px;
	background: #fff;
	margin: 0;
}
.list_qa input:checked ~ .box_a *{
	opacity: 1;
	transition: .4s .4s;
}

.img-box {
    width: 1000px;
    margin: 30px auto;
}

.Reserve-btn {
    position: relative;
    text-align: center;
	padding: 80px;
}

.Reserve-btn a.btn {
    letter-spacing: 1px;
    font-size: 18px;
    padding: 20px 45px;
    font-weight: 700;
    transition: .5s;
    border-bottom: 1px solid #fff;
    color: #fff;
    background: #ED5C7D;
    position: relative;
    margin: 0 auto;
    border-radius: 10px;
	display: table;
    vertical-align: middle;
}

.Reserve-btn a.btn::before {
    content: '';
    width: 6px;
    height: 6px;
    border: 0;
	position: absolute;
	border-top: solid 1px #fff;
    border-right: solid 1px #fff;
    top: auto;
    right: 15px;
    margin-top: 11px;
	transform: rotate(45deg);
}

.Reserve-btn  a.btn:hover {
    opacity: 0.7;
}

p.pay-text {
    width: 1000px;
    margin: 0 auto;
    font-size: 12px;
    line-height: 23px;
}

.googlemap {
    width: 1000px;
    margin: 40px auto;
}

h4.chapter_title {
    font-size: 18px;
    margin-bottom: 10px;
}

.terminal_table_wrapper{
	padding-bottom:2.5em;
	width: 1000px;
    margin: 0 auto;
}
.table_wrapper {
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
	margin-bottom: 30px;
}
.table_wrapper th {
	padding: 10px;
	background: #FFFBDE;
	text-align: center;
	border: solid 1px #D4D4D4;
	font-size: 15px;
	vertical-align: middle;
}
.table_wrapper td {
	padding: 10px;
	border: solid 1px #D4D4D4;
	font-size: 15px;
	vertical-align: middle;
}

.table_wrapper td.area-name {
	padding: 10px;
	border: solid 1px #D4D4D4;
	font-size: 15px;
	vertical-align: middle;
	text-align: center;
	width: 15%;
}

.table_wrapper td.name {
	padding: 10px;
	font-size: 15px;
	vertical-align: middle;
	display: flex;
    align-items: center;
}

.table_wrapper td .flex-td {
	padding: 10px;
	font-size: 15px;
	vertical-align: middle;
	display: flex;
    align-items: center;
}

.table_wrapper td span {
	border: 1px solid #303338;
	font-size: 15px;
	padding: 5px;
	border-radius: 10px;
	margin-right: 15px;
}

.table_wrapper td.map {
	text-align: center;
	width: 13%;
}

.table_wrapper td.map img {
	width: 50px;
}

section.notice {
    width: 1000px;
    margin: 30px auto;
}

.notice-important {
    font-size: 22px;
    margin: 40px 0 10px;
}

.notice-important span {
    color: #ED5C7D;
}

.notice-text {
    line-height: 30px;
}

.notice-text span {
    color: #ED5C7D;
}

section.youtube {
    width: 1000px;
    margin: 100px auto 0;
}

.youtube-box ul {
	display: flex;
	justify-content: space-between;
	margin: 40px 0 0;
}

.youtube-box ul li {
	width: 30%;
}

.youtube-box ul li iframe {
	width: 323px;
    height: 200px;
}

/* ニュースページ */
.news-box {
	margin: 70px auto;
}

.news-box_inner {
	width: 1000px;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    position: relative;
}

li.item {
    display: flex;
    align-items: center;
    border-bottom: 1px solid #D4D4D4;
    padding: 20px 0;
    width: 1000px;
	position: relative;
}

li.item p.date {
    border: 1px solid #0DAFC4;
    color: #0DAFC4;
    width: 120px;
    text-align: center;
    padding: 5px 22px;
}

li.item p.title {
    margin-left: 25px;
    font-size: 18px;
    color: #303338;
    letter-spacing: 1.5px;
    padding-right: 130px;
}

li.item p.title a {
	color: #303338;
}

li.item a.btn {
    padding: 7px 35px 7px 0;
    font-size: 15px;
    font-weight: 500;
    color: #303338;
    display: inline-block;
    position: absolute;
    right: 0;
    transition: .5s;
    border-bottom: 1px solid;
}

li.item a.btn:hover {
    opacity: 0.7;
}

.news-detail_inner {
	width: 1000px;
    margin: 0 auto;
}

.news-detail_inner p.date {
    font-size: 20px;
    color: #0DAFC4;
    margin-bottom: 15px;
}

.news-detail_inner h3.news-title {
    font-size: 24px;
    color: #303338;
    letter-spacing: 1px;
    font-weight: 500;
    border-bottom: 2px solid #D4D4D4;
    padding-bottom: 15px;
}

.news-detail_inner .news-text {
    font-size: 17px;
    color: #303338;
    line-height: 30px;
    padding-top: 30px;
}

.news-detail_inner .news-text a {
    color: #2F85A2;
	text-decoration: underline;
}

.news-btn_box {
    margin: 0 auto;
    text-align: center;
}

.news-btn_box a.btn {
	text-align: center;
    padding: 7px 35px;
    font-size: 15px;
    font-weight: 500;
    color: #303338;
    display: inline-block;
    transition: .5s;
    border: 1px solid;
	border-radius: 25px;
	position: relative;
	width: 180px;
}

.news-btn_box a.btn::before {
    margin-right: 10px;
}

.news-btn_box a.btn:hover {
    opacity: 0.7;
}

/* ピックアップコンテンツページ */
.recommend-box {
    background: #008BAC;
}

.recommend-box_inner {
    width: 1000px;
    margin: 0 auto;
}

h3.recommend-title {
    font-size: 40px;
    color: #fff;
    font-weight: 700;
    text-align: center;
    font-family: "baskerville-display-pt", serif;
    background: url(../images/pickup/bg-02.png);
    padding: 80px 0 60px;
    background-repeat: no-repeat;
    background-size: 57%;
    background-position: center;
}

.recommend-box_inner ul {
    display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	padding-bottom: 80px;
}

.recommend-box_inner ul li {
    width: 47%;
	color: #fff;
}

.recommend-box_inner ul li img,
.contents-box_inner ul li img{
    border-radius: 5px;
}

.recommend-box_inner ul li h4 {
    font-size: 25px;
    line-height: 40px;
    margin: 15px 0;
	font-weight: 700;
}

.recommend-box_inner ul li p {
    line-height: 25px;
}

a.recommend-btn {
    margin-top: 30px;
    float: right;
    letter-spacing: 1px;
    font-size: 18px;
    padding: 7px 35px 7px 0;
    font-weight: 700;
    transition: .5s;
    border-bottom: 1px solid #fff;
    border-radius: inherit;
    color: #fff;
	position: relative;
}

a.recommend-btn::before {
    content: '';
    width: 6px;
    height: 6px;
    border: 0;
	position: absolute;
	border-top: solid 1px #fff;
    border-right: solid 1px #fff;
    top: auto;
    right: 4px;
    margin-top: 8px;
	transform: rotate(45deg);
}

a.recommend-btn:hover {
    opacity: 0.7;
}

.pickup-box_inner {
    width: 1000px;
    margin: 80px auto 0;
}

.contents-box_inner ul {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.contents-box_inner ul li {
	width: 45%;
	padding-bottom: 80px;
	position: relative;
}

.contents-box_inner ul li h4 {
	font-size: 20px;
    color: #006C90;
    font-weight: 600;
    margin-top: 10px;
    line-height: 35px;
}

.contents-box_inner ul li .caption {
	font-size: 20px;
	text-align: center;
	padding: 135px 0;
	color: #fff;
}
.contents-box_inner ul li .mask {
	width: 100%;
	height:	auto;
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	background-color: rgba(0,0,0,0.4);
	transition:	all 0.2s ease;
	border-radius: 5px;
}

.contents-box_inner ul li:hover .mask {
	opacity: 1;
}

/* コンテンツ詳細ページ */
.feature-contents_box-inner {
    width: 1000px;
    margin: 50px auto;
}

.feature-contents_box-inner h2 {
    color: #2F85A2;
    font-size: 30px;
    font-weight: 700;
    border-bottom: 1px solid;
    padding-bottom: 10px;
}

.FC_block {
    margin: 30px auto 60px;
}

/*.FC_block .FCimg-box {
	width: 60%;
	margin: 0 auto;
}*/

.FC_block .FC1column-box {
    width: 100%;
    margin: 0 auto 20px;
}

.FC_block .FC2column-box {
    width: 100%;
    margin: 0 auto 20px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-evenly;
}

.FC_block .FC2column-box img {
    width: 47%;
}

.FC_block .FC-title {
    font-size: 25px;
    color: #2F85A2;
    font-weight: 800;
    padding-bottom: 10px;
}

.FC_block h4 {
    font-size: 18px;
    margin-bottom: 10px;
}

.FC_block .FC-text {
    line-height: 25px;
}


/* モデルコース */
.modelcourse-box_inner {
    width: 1000px;
    margin: 80px auto 0;
}

.mc-box_inner ul {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.mc-box_inner ul li {
	width: 45%;
	padding-bottom: 80px;
	position: relative;
}

.mc-box_inner ul li h4 {
	font-size: 20px;
    color: #006C90;
    font-weight: 600;
    margin-top: 10px;
    line-height: 35px;
}

.mc-box_inner ul li .caption {
	font-size: 20px;
	text-align: center;
	padding: 135px 0;
	color: #fff;
}
.mc-box_inner ul li .mask {
	width: 100%;
	height:	auto;
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	background-color: rgba(0,0,0,0.4);
	transition:	all 0.2s ease;
	border-radius: 5px;
}

.mc-box_inner ul li:hover .mask {
	opacity: 1;
}

.mc-box_inner ul li a.btn {
	background: #fff;
    padding: 7px 35px 7px 0;
    font-size: 15px;
    font-weight: 700;
    color: #303338;
    display: inline-block;
    position: absolute;
    right: 0;
    transition: .5s;
    border-bottom: 1px solid #1E1E1E;
}

.mc-box_inner ul li a.btn:hover {
	opacity: 0.7;
	transition: .5s;
}

.category-box {
    display: flex;
    margin: 15px 0;
}

.area {
    background: #1A709D;
    color: #fff;
    padding: 5px 10px;
    font-size: 14px;
    border-radius: 3px;
}

.category {
    background: #01A6AD;
    color: #fff;
    padding: 5px 10px;
    font-size: 14px;
    border-radius: 3px;
    margin-left: 15px;
}

.days {
    background: #F18D5F;
    color: #fff;
    padding: 5px 10px;
    font-size: 14px;
    border-radius: 3px;
    margin-left: 15px;
}

/* モデルコース詳細ページ */
.SI-inner {
    width: 1000px;
    margin: 0 auto;
}

.SI-mainblock {
    margin: 0 auto 50px;
}

.SI-mainblock h2 {
    font-size: 35px;
	color: #01A6AD;
	font-weight: bold;
	margin: 20px auto 15px;
}

.SI-mainblock p{
    line-height: 25px;
}

.course-box_inner h2 {
    margin: 0 auto 45px;
	width: auto;
    display: flex;
    justify-content: center;
}

.course-box_inner .course-text {
    text-align: center;
	font-size: 20px;
	font-weight: 600;
	margin: 0 auto 70px;
}

.course-root {
    width: 100%;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
}

.course-root_inner {
    width: 90%;
	margin: 0 auto;
}

.course-root_inner ul {
    padding: 0;
	position: relative;
	padding-top: 30px;
}

.course-root_inner li {
    display: flex;
    border: 1px solid #D4D4D4;
    position: relative;
    align-items: center;
    text-align: left;
	margin-bottom: 80px;
}

.course-root_inner ul .arrow {
	display: flex;
    justify-content: center;
    margin: 18px 0;
	position: absolute;
    right: 0;
    bottom: -75px;
    left: 0;
}

.course-root_inner ul .arrow img {
	width: 35px;
}

.course-root_inner ul .arrow p {
	font-size: 18px;
    color: #01A6AD;
    font-weight: bold;
    position: absolute;
    padding-top: 5px;
    margin: 0;
	text-align: left;
    margin-left: 270px;
    width: 200px;
}

.course-root_inner li .left {
	width: 40%;
}

.course-root_inner li .right h4 {
    font-size: 20px;
	font-weight: bold;
	color: #0DAFC4;
}

.course-root_inner li .right {
    padding: 0 30px;
    width: 60%;
}

.accordion-001 {
    width: 1000px;
    background-color: #fff;
	border: 1px solid #0DAFC4;
    margin-bottom: 30px;
}

/*.accordion-001:not([open]) {
    margin-bottom: 7px;
}*/

.accordion-001 summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    padding: 15px 2em;
    background-color: #3FC3C9;
    color: #fff;
    font-weight: 600;
    cursor: pointer;
    font-size: 25px;
}

.accordion-001 summary::-webkit-details-marker {
    display: none;
}

.accordion-001 summary::after {
    transform: translateY(-25%) rotate(45deg);
    width: 7px;
    height: 7px;
    margin-left: 10px;
    border-bottom: 3px solid #fff;
    border-right: 3px solid #fff;
    content: '';
    transition: transform .3s;
}

.accordion-001[open] summary::after {
    transform: rotate(225deg);
}

.accordion-001 p {
    transform: translateY(-10px);
    opacity: 0;
    margin: 0;
    color: #333333;
    transition: transform .5s, opacity .5s;
	line-height: 23px;
    font-size: 14px;
	margin-top: 10px;
}

.accordion-001[open] p {
    transform: none;
    opacity: 1;
}

.si-notice {
    width: 90%;
    margin: 40px auto;
    background: #EDFEFF;
    border: 1px solid #01A6AD;
    padding: 30px;
}

.si-notice h5 {
    font-size: 20px
}

.si-notice div {
    font-size: 15px;
	line-height: 25px;
}

.accordion-001 .mymap {
    width: 90%;
    margin: 0 auto;
}

.si-btn  {
	width: 30%;
    margin: 40px auto 45px;
    text-align: center;
}

.si-btn a{
	border: 1px solid #0DAFC4;
    border-radius: 35px;
    display: block;
    color: #0DAFC4;
    padding: 15px 35px;
    font-size: 17px;
    letter-spacing: 1px;
    font-weight: 600;
	position: relative;
}

.si-btn a::before {
    content: '';
    width: 6px;
    height: 6px;
    border: 0;
    border-top: solid 1px #0DAFC4;
    border-right: solid 1px #0DAFC4;
    position: absolute;
	top: 50%;
    right: 25px;
    margin-top: -4px;
    transform: rotate(45deg);
}

.si-btn a:hover {
	border: 1px solid #0DAFC4;
	background: #0DAFC4;
	color: #fff;
	transition: .5s;
}

.si-btn a:hover::before {
	border-top: solid 1px #fff;
    border-right: solid 1px #fff;
}

.si_back-btn  {
	width: 25%;
    margin: 40px auto 0;
}

.si_back-btn a{
	border: 1px solid #0DAFC4;
    border-radius: 35px;
    display: block;
    color: #fff;
    padding: 15px 35px;
    font-size: 17px;
    letter-spacing: 1px;
    font-weight: 600;
	position: relative;
	background: #0DAFC4;
}

.si_back-btn a::before {
    content: '';
    width: 6px;
    height: 6px;
    border: 0;
    border-top: solid 1px #fff;
    border-right: solid 1px #fff;
    position: absolute;
	top: 50%;
    right: 25px;
    margin-top: -4px;
    transform: rotate(45deg);
}

.si_back-btn a:hover {
	border: 1px solid #0DAFC4;
	background: #fff;
	color: #0DAFC4;
	transition: .5s;
}

.si_back-btn a:hover::before {
	border-top: solid 1px #0DAFC4;
    border-right: solid 1px #0DAFC4;
}


/* 検索結果ページ */
.favorite-inner {
    width: 1000px;
    margin: 80px auto 40px;
}

.favorite-inner ul {
    display: flex;
	flex-wrap: wrap;
}

.favorite-inner ul li {
    width: 30%;
	margin-right: 50px;
	margin-bottom: 70px;
}

.favorite-inner ul li:nth-child(3n) {
    width: 30%;
	margin-bottom: 70px;
	margin-right: 0;
}

.favorite-inner ul li .category {
    border-radius: 25px;
    background: #006C90;
    width: 150px;
    text-align: center;
    color: #fff;
    font-size: 12px;
    padding: 5px;
	margin: 15px 0;
}

.favorite-inner ul li p.title {
    font-size: 18px;
	margin-bottom: 10px;
}

.favorite-inner ul li a {
    color: #303338;
}

/* 検索結果ページ */
.result-inner {
    width: 1000px;
    margin: 0 auto 80px;
}

.result-text {
    text-align: center;
    font-size: 18px;
    margin: 60px 0 40px;
}

.result-inner ul li {
    display: flex;
	justify-content: space-between;
	align-items: center;
	border-top: 1px solid #D4D4D4;
    padding: 30px 50px;
}

.result-inner ul li:last-child {
    display: flex;
	justify-content: space-between;
	align-items: center;
	border-top: 1px solid #D4D4D4;
	border-bottom: 1px solid #D4D4D4;
    padding: 30px 50px;
}

.result-inner ul li .left {
    width: 30%;
	margin-right: 30px;
}

.result-inner ul li .right {
    width: 70%;
}

.result-inner ul li .right .category {
    border-radius: 25px;
    background: #006C90;
    width: 160px;
    text-align: center;
    color: #fff;
    font-size: 13px;
    padding: 5px;
	margin-bottom: 15px;
}

.result-inner ul li .right p.title {
    font-size: 18px;
	text-decoration: underline;
	margin-bottom: 10px;
}

.result-inner ul li .right p.title a {
    color: #303338;
}

p.text2 {
    line-height: 30px;
    margin-bottom: 50px;
}

/* アクセスページ */
.access-box_inner {
    width: 1000px;
    margin: 0 auto;
}

h2.main-title {
    font-size: 40px;
    color: #006C90;
    font-weight: 700;
    border-bottom: 1px solid;
    padding-bottom: 5px;
    letter-spacing: 1px;
	margin-bottom: 30px;
	margin-top: 80px;
}

h4.sub-title {
    font-size: 22px;
    color: #3E3E3E;
    letter-spacing: 1px;
    margin-bottom: 15px;
    font-weight: 700;
}

p.text {
    line-height: 30px;
	margin-bottom: 50px;
}

p.text a {
    text-decoration: underline;
	color: #006C90;
	font-weight: 700;	
}

h3.ac-title {
    background: #006C90;
    color: #fff;
    font-size: 25px;
    font-weight: 600;
    letter-spacing: 0.5px;
    padding: 12px 30px;
	margin-bottom: 30px;
}

.access-block {
    display: flex;
    justify-content: space-between;
	margin-bottom: 40px;
}

.img-block {
    width: 30%;
}

.img-block .caption {
	font-size: 14px;
	padding-top: 5px;
}

.text-block {
	width: 70%;
	padding-left: 40px;
}

.text-block2 {
	width: 100%;
}

h5.title01 {
    padding-left: 90px;
    line-height: 70px;
    background: url(../images/access/train.svg) no-repeat;
    font-size: 25px;
    font-weight: 600;
    background-size: 70px;
    letter-spacing: 1px;
	margin-bottom: 15px;
}

.text-block p {
    line-height: 28px;
	margin-bottom: 30px;
}

.text-block2 p {
    line-height: 28px;
	margin-bottom: 50px;
}

.text-block2 p a {
    color: #006C90;
	font-weight: 700;
}

.text-block p span {
    font-size: 14px;
	line-height: 28px;
}

h5.title02 {
    padding-left: 90px;
    line-height: 70px;
    background: url(../images/access/bus.svg) no-repeat;
    font-size: 25px;
    font-weight: 600;
    background-size: 70px;
    letter-spacing: 1px;
	margin-bottom: 15px;
}

h5.title03 {
    padding-left: 90px;
    line-height: 70px;
    background: url("../images/access/airport.svg") no-repeat;
    font-size: 25px;
    font-weight: 600;
    background-size: 70px;
    letter-spacing: 1px;
	margin-bottom: 15px;
}

h5.title04 {
    padding-left: 90px;
    line-height: 70px;
    background: url("../images/access/ferry.svg") no-repeat;
    font-size: 25px;
    font-weight: 600;
    background-size: 70px;
    letter-spacing: 1px;
	margin-bottom: 15px;
}

h5.title05 {
    padding-left: 180px;
    line-height: 70px;
    background: url("../images/access/shinkansen.svg"),url("../images/access/ferry.svg");
	background-repeat: no-repeat, no-repeat;
	background-position: left, left 15% bottom;
    font-size: 25px;
    font-weight: 600;
    background-size: 70px;
    letter-spacing: 1px;
	margin-bottom: 15px;
}

/* プライバシーポリシーページ */

.text-areabox {
    width: 1000px;
    margin: 0 auto;
}

.text-areabox h3.heading {
	font-size: 18px;
    color: #0DAFC4;
    margin-bottom: 15px;
}

.text-areabox p {
	line-height: 30px;
    letter-spacing: 1px;
	margin-bottom: 80px;
}

.text-areabox p a {
	text-decoration: underline;
	color: #333;
}


/* サイトマップ */
section.sitemap-block {
    margin: 0 auto;
    width: 800px;
    padding: 20px 0;
}

.btn-inner li {
	margin-bottom: 25px;
}

.btn-inner li a.link-btn{
	border: 1px solid #0DAFC4;
    border-radius: 5px;
    width: 800px;
    display: block;
    color: #0DAFC4;
    padding: 15px 35px;
    font-size: 17px;
    letter-spacing: 1px;
    font-weight: 600;
	position: relative;
}

.btn-inner li a.link-btn::before {
    content: '';
    width: 6px;
    height: 6px;
    border: 0;
    border-top: solid 1px #0DAFC4;
    border-right: solid 1px #0DAFC4;
    position: absolute;
	top: 50%;
    right: 35px;
    margin-top: -4px;
    transform: rotate(45deg);
}

.btn-inner li a.link-btn:hover {
	border: 1px solid #0DAFC4;
	background: #0DAFC4;
	color: #fff;
	transition: .5s;
}

.btn-inner li a.link-btn:hover::before{
	border-top: solid 1px #fff;
    border-right: solid 1px #fff;
}

.btn-inner li a.link-btn {
	border: 1px solid #0DAFC4;
    border-radius: 5px;
    width: 800px;
    display: block;
    color: #0DAFC4;
    padding: 15px 35px;
    font-size: 17px;
    letter-spacing: 1px;
    font-weight: 600;
	position: relative;
}

.btn2-inner {
    margin-bottom: 40px;
}

.btn2-inner ul {
	margin-top: 40px;
}

.btn2-inner ul.half-box {
	margin-top: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.btn2-inner ul.half-box li {
	margin-top: 20px;
	width: 47%;
}

.btn2-inner li a.link-btn {
	border: 1px solid #0DAFC4;
    border-radius: 5px;
    display: block;
    color: #0DAFC4;
    padding: 15px 35px;
    font-size: 17px;
    letter-spacing: 1px;
    font-weight: 600;
	position: relative;
}

.btn2-inner li a.link-btn::before {
    content: '';
    width: 6px;
    height: 6px;
    border: 0;
    border-top: solid 1px #0DAFC4;
    border-right: solid 1px #0DAFC4;
    position: absolute;
	top: 50%;
    right: 35px;
    margin-top: -4px;
    transform: rotate(45deg);
}

.btn2-inner li a.link-btn:hover {
	border: 1px solid #0DAFC4;
	background: #0DAFC4;
	color: #fff;
	transition: .5s;
}

.btn2-inner li a.link-btn:hover::before{
	border-top: solid 1px #fff;
    border-right: solid 1px #fff;
}

.cc-animate.cc-revoke.cc-bottom {
    -webkit-transform: translateY(4em) !important;
    transform: translateY(4em) !important;
}


/* Souvenirs
============================================================ */
/*add 20241209*/

.p-souvenirs .inner1000 {
    width: 96%;
}

.p-souvenirs__kv {
    margin-bottom: 80px;
}

.p-souvenirs__pagettl {
    margin: 0 0 60px;
    font-size: 38px;
    color: #0DAFC4;
    font-weight: 400;
    font-family: "baskerville-display-pt", serif;
    text-align: center;
}

.p-souvenirs__summary {
    margin: 0 auto 40px;
    font-size: 22px;
    text-align: center;
    color: #000;
}

.p-souvenirs__summary:last-of-type {
    margin-bottom: 100px;
    text-align: center;
}

.p-souvenirs__sort {
    width: 96%;
    max-width: 1000px;
    margin: 0 auto 60px;
    display: flex;
    justify-content: space-between;
}

.p-souvenirs__sort-btn {
    width: calc(100% / 5);
    padding: 20px 15px 20px;
    border: none;
    text-align: center;
    line-height: 1.4;
    font-size: 18px;
    font-family: 'Noto Serif JP', sans-serif;
    color: #fff;
    background-color: #4AB9C1;
    border-right: solid 1px #fff;
    transition: .3s;
    cursor: pointer;
}

.p-souvenirs__sort-btn:last-of-type {
    border-right: none;
}

.p-souvenirs__sort-btn.is-active,
.p-souvenirs__sort-btn:hover {
    background-color: #FB7997;
}

.p-souvenirs__wrap {
    width: 100%;
    margin: 0 0 180px;
    display: flex;
    flex-wrap: wrap;
    gap: 45px 30px;
}

.p-souvenirs__item {
    width: calc( (100% / 3) - (60px / 3));
    padding: 25px 10px 25px;
    color: initial;
    border: solid 2px #000;
    border-radius: 20px;
    overflow: hidden;
    position: relative;
    cursor: pointer;
    transition: .3s;
    display: flex;
    flex-direction: column;
}
.p-souvenirs__item.is-hide {
    display: none;
}

@media screen and (min-width: 768px) {
    .p-souvenirs__item:hover .p-souvenirs__overlay {
        opacity: 1;
    }
}

.p-souvenirs__icon {
    width: 60px;
    height: auto;
    aspect-ratio: 1 / 1;
    color: #fff;
    text-align: center;
    line-height: 1.3;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 1;
}

.p-souvenirs__icon.--new {
    font-size: 18px;
    text-transform: capitalize;
    background-color: #F5A101;
}

.p-souvenirs__icon.--soldout {
    font-size: 14px;
    text-transform: uppercase;
    background-color: #070707;
}

.p-souvenirs__item .thumb {
    width: 96%;
    margin: 0 auto 10px;
}

.p-souvenirs__item:hover img {
    opacity: 1;
}

.p-souvenirs__item-body {
    margin-top: auto;
    padding: 0 15px;
}
.p-souvenirs__item .name {
    margin: 0 0 10px;
    font-size: 17px;
    line-height: 1.5;
    color: #005DFF;
}
.p-souvenirs__item .name .small {
    margin: 0 0 4px;
    font-size: 15px;
    line-height: 1.2;
    color: initial;
    display: block;
}
.p-souvenirs__item .name .small.--blue {
    color: #005DFF;
}
.p-souvenirs__item .name .sub {
    margin: 0 0 0 10px;
    font-size: 18px;
}
.p-souvenirs__item .info {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 15px 12px;
}
.p-souvenirs__item .price {
    color: #000;
    font-size: 28px;
    line-height: 1.2;
    font-weight: 400;
    flex-shrink: 0;

}
.p-souvenirs__item .size {
    font-size: 16px;
    line-height: 1.4;
    display: flex;
    flex-wrap: wrap;
    gap: 0 8px;
}
.p-souvenirs__item .size.smaller {
    font-size: 15px;
    line-height: 1.45;
}
.p-souvenirs__item .size.small {
    font-size: 14px;
}
.p-souvenirs__item .size.sp-only {
    display: none;
}
.p-souvenirs__item .size dt {
    flex-shrink: 0;
}
.p-souvenirs__item .size dt.none {
    display: none;
}
.p-souvenirs__item .size dd {
}

.p-souvenirs__overlay {
    width: 100%;
    height: 100%;
    padding: 10px 20px;
    background-color: rgba(255,255,255,0.935);
    position: absolute;
    top: 0;
    left: 0;
    z-index: 5;
}

@media screen and (min-width: 768px) {
    .p-souvenirs__overlay {
        transition: .3s;
        opacity: 0;
    }
}
@media screen and (max-width: 767px) {
    .p-souvenirs__overlay {
        display: none;
    }
}

.p-souvenirs__block {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.p-souvenirs__over-inner {
    font-size: 14px;
    line-height: 1.7;

}
.p-souvenirs__over-inner p {
    margin-bottom: 15px;
    font-size: 14px;
    font-weight: 300;
}
.p-souvenirs__over-inner p.bold {
    margin-bottom: 5px;
    font-size: 13px;
    font-weight: bold;
    line-height: 1.6;
}
.p-souvenirs__over-inner p.smaller {
    font-size: 13px;
    
}
.p-souvenirs__over-inner p:last-of-type {
    margin-bottom: 0;
}
.p-souvenirs__over-inner .size {
    margin-top: 14px;
}
.p-souvenirs__over-inner .close-btn {
    padding: 0 0.2em 0 2.5em;
    line-height: 1.2;
    border-bottom: solid 1px #000;
    position: absolute;
    right: 12px;
    bottom: 12px;
}
.p-souvenirs__over-inner .close-btn::before {
    content: "＜";
    position: absolute;
    left: 0;
    top: 0;
}

.p-souvenirs__ttl {
    margin: 0 0 40px;
    padding: 0 15px 15px;
    color: #005DFF;
    font-size: 28px;
    border-bottom: solid 2px #245BA6;
    display: flex;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: 5px 20px;
}

.p-souvenirs__ttl .note {
    color: initial;
    font-size: 22px;
    display: inline-block;
}
.p-souvenirs__table  {
    margin: 0 0 100px;
    border: 1px solid #707070;
}
.p-souvenirs__table table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
}
.p-souvenirs__table th {
    padding: 20px 10px 20px;
    color: #fff;
    font-size: 18px;
    text-align: center;
    line-height: 1.4;
    vertical-align: middle;
    background-color: #245BA6;
    border: 2px solid #707070;
}
.p-souvenirs__table th:nth-of-type(1) {
    
}
.p-souvenirs__table th:nth-of-type(2) {
    width: 160px;
}
.p-souvenirs__table th:nth-of-type(3) {
    width: 150px;
}
.p-souvenirs__table th:nth-of-type(4) {
    width: 150px;
}
.p-souvenirs__table td {
    padding: 16px 10px 16px;
    font-size: 18px;
    text-align: center;
    line-height: 1.4;
    vertical-align: middle;
    border: 2px solid #707070;
}
.p-souvenirs__table td:nth-of-type(1) {
    padding-left: 20px;
    padding-right: 10px;
    color: #005DFF;
    text-align: left;
}
.p-souvenirs__table td:nth-of-type(1) small {
    margin: 0 0 0 10px;
    color: initial;
    font-size: 18px;
    display: inline-block;
}
.p-souvenirs__table td:nth-of-type(3) img {
    width: 70px;
}
.p-souvenirs__table td:nth-of-type(4) img {
    width: 60px;
}



/* tablet Layout ******************************************************************************************* */
@media screen and (min-width: 768px) and (max-width: 1250px) {

}



@media screen and (max-width: 1000px) {

    .p-souvenirs__wrap {
        gap: 34px 34px;

    }
    .p-souvenirs__item {
        width: calc( (100% / 2) - (17px));
        border-radius: 20px;
    }
    .p-souvenirs__over-inner {
        line-height: 1.8;
    }

    .p-souvenirs__table th,
    .p-souvenirs__table td {
        font-size: 16px;
    }
    .p-souvenirs__table th:nth-of-type(2) {
        width: 140px;
    }
    .p-souvenirs__table th:nth-of-type(3) {
        width: 130px;
    }
    .p-souvenirs__table th:nth-of-type(4) {
        width: 130px;
    }


    .p-souvenirs__table td {
        padding: 15px 10px 15px;
    }
    .p-souvenirs__table td:nth-of-type(1) small {
        font-size: 16px;
    }
    .p-souvenirs__table td:nth-of-type(3) img {
        width: 60px;
    }
    .p-souvenirs__table td:nth-of-type(4) img {
        width: 50px;
    }
}

@media screen and (max-width: 900px) {
    .p-souvenirs__kv {
        margin-bottom: 50px;
    }
    .p-souvenirs__pagettl {
        margin-bottom: 50px;
    }
    .p-souvenirs__summary:last-of-type {
        margin-bottom: 80px;
    }
    .p-souvenirs__sort {
        width: 100%;
    }
    .p-souvenirs__wrap {
        margin-bottom: 150px;
        gap: 30px 30px;

    }
    .p-souvenirs__item {
        width: 100%;
    }
    .p-souvenirs__over-inner {
        line-height: 1.8;
    }

    .p-souvenirs__table {
        margin: 0;
        border: none;
    }
    
    .p-souvenirs__table thead {
        display: none;
    }
    .p-souvenirs__table tr {
        margin: 0 0 40px;
        display: flex;
        flex-wrap: wrap;
    }
    .p-souvenirs__table tr:last-of-type {
        margin-bottom: 0;
    }
    .p-souvenirs__table th {
        border-right: none;
    }
    .p-souvenirs__table th,
    .p-souvenirs__table td {
        padding-top: 15px;
        padding-bottom: 15px;
        font-size: 13px;
        border-width: 1px;
    }
    .p-souvenirs__table td:nth-of-type(1) small {
        margin: 3px 0 0 0;
        font-size: 12px;
    }
    .p-souvenirs__table th:nth-of-type(1),
    .p-souvenirs__table th:nth-of-type(2),
    .p-souvenirs__table th:nth-of-type(3),
    .p-souvenirs__table td:nth-of-type(2),
    .p-souvenirs__table td:nth-of-type(3),
    .p-souvenirs__table td:nth-of-type(4) {
        border-top: none;
    }
    .p-souvenirs__table th:nth-of-type(1),
    .p-souvenirs__table th:nth-of-type(2) {
        border-bottom-color: #fff;
    }
    .p-souvenirs__table th:nth-of-type(4) {
        border-left: none;
    }

    .p-souvenirs__table .sp-only,
    .p-souvenirs__table th:nth-of-type(2),
    .p-souvenirs__table th:nth-of-type(3),
    .p-souvenirs__table th:nth-of-type(4) {
        width: 100px;
        display: block;
        flex-shrink: 0;
    }
    .p-souvenirs__table th.sp-only {
        border-width: 1px;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .p-souvenirs__table td:not(.sp-only) {
        width: calc(100% - 100px);
        border-width: 1px;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
    .p-souvenirs__table td:nth-of-type(1),
    .p-souvenirs__table td:nth-of-type(2) {
        padding-left: 20px;
        padding-right: 20px;
        text-align: left;
    }
    .p-souvenirs__table td:nth-of-type(3),
    .p-souvenirs__table td:nth-of-type(4) {
        width: calc(50% - 100px);
    }

    .p-souvenirs__table td:nth-of-type(3) img {
        width: 50px;
    }
    .p-souvenirs__table td:nth-of-type(4) img {
        width: 40px;
    }
    
}

@media screen and (max-width: 767px) {
    .p-souvenirs .inner1000 {
        width: 85%;
    }
    
    .p-souvenirs__kv {
        margin-bottom: 40px;
    }
    .p-souvenirs__pagettl {
        margin-bottom: 35px;
        font-size: 22px;
    }
    .p-souvenirs__summary {
        margin-bottom: 30px;
        font-size: 17px;
    }
    .p-souvenirs__summary:last-of-type {
        margin-bottom: 50px;
    }
    .p-souvenirs__sort {
        margin-bottom: 50px;
    }
    .p-souvenirs__sort-btn {
        padding: 15px 5px;
        font-size: 12px;
    }
    .p-souvenirs__wrap {
        margin-bottom: 100px;
        gap: 20px 20px;
    }
    .p-souvenirs__item {
        padding: 20px 12px 20px;
        border-width: 1px;
        border-radius: 12px;
    }
    .p-souvenirs__item-body {
        padding: 0 5px;
    }
    .p-souvenirs__item .price {
        font-size: 25px;
    }
    .p-souvenirs__icon {
        width: 60px;
    }
    .p-souvenirs__icon.--new {
        font-size: 17px
    }
    .p-souvenirs__icon.--soldout {
        font-size: 14px
    }
    .p-souvenirs__item .name {
        margin-bottom: 8px;
        font-size: 14px;
    }
    .p-souvenirs__item .name .small {
        font-size: 14px;
    }
    .p-souvenirs__item .name .sub {
        font-size: 14px;
    }
    .p-souvenirs__item .size.pc-only {
        display: none;
    }
    
    .p-souvenirs__item .open-btn {
        padding: 0 2.5em 0 0;
        line-height: 1.2;
        font-size: 14px;
        border-bottom: solid 1px #000;
        position: absolute;
        right: 20px;
        bottom: 18px;
    }
    .p-souvenirs__item .open-btn::before {
        content: "＞";
        position: absolute;
        right: 0;
        top: 0;
    }
    .p-souvenirs__overlay {
        padding: 20px 20px;
    }
    .p-souvenirs__over-inner,
    .p-souvenirs__item .size.sp-only {
        font-size: 14px;
        line-height: 1.7;
    }
    .p-souvenirs__over-inner p {
        margin-bottom: 15px;
    }
    .p-souvenirs__over-inner p.bold {
        margin-bottom: 3px;
        font-size: 13px;
    }
    .p-souvenirs__item .size.sp-only {
        font-weight: 300;
        display: flex;
    }
    .p-souvenirs__item .size.sp-only dt,
    .p-souvenirs__item .size.sp-only dd {
        font-weight: inherit;
    }

    .p-souvenirs__ttl {
        margin-bottom: 20px;
        padding: 0 5px 15px;
        font-size: 20px;
        border-bottom-width: 1px;
    }
    .p-souvenirs__ttl .note {
        font-size: 15px;
    }
}


@media screen and (max-width: 450px) {
    .p-souvenirs__sort {
        margin-bottom: 35px;
    }
    .p-souvenirs__sort-btn {
        font-size: 11px;
    }
    .p-souvenirs__icon {
        width: 14vw;
        font-size: 5vw;
        top: 2.5vw;
        right: 2.5vw;
    }
    .p-souvenirs__icon.--new {
        font-size: 4.5vw;
    }
    .p-souvenirs__icon.--soldout {
        font-size: 3.2vw;
    }
    .p-souvenirs__item .size.sp-only,
    .p-souvenirs__over-inner p.bold,
    .p-souvenirs__over-inner p,
    .p-souvenirs__over-inner p.smaller,
    .p-souvenirs__over-inner .close-btn {
        font-size: 3.1vw;
    }
    .p-souvenirs__over-inner p.bold {
        margin-bottom: 0;
    }
    .p-souvenirs__over-inner p {
        margin-bottom: 2.5vw;
    }
    
    .p-souvenirs__table th,
    .p-souvenirs__table td {
        font-size: 12px;
    }
    .p-souvenirs__table .sp-only,
    .p-souvenirs__table th:nth-of-type(2),
    .p-souvenirs__table th:nth-of-type(3),
    .p-souvenirs__table th:nth-of-type(4) {
        width: 76px;
    }
    .p-souvenirs__table td:nth-of-type(1),
    .p-souvenirs__table td:nth-of-type(2) {
        padding-left: 15px;
        padding-right: 15px;
    }
    .p-souvenirs__table td:not(.sp-only) {
        width: calc(100% - 76px);
    }
    .p-souvenirs__table td:nth-of-type(3),
    .p-souvenirs__table td:nth-of-type(4){
        width: calc(50% - 76px);
    }
    .p-souvenirs__table td:nth-of-type(3) img {
        width: 40px;
    }
    .p-souvenirs__table td:nth-of-type(4) img {
        width: 34px;
    }
}

/* New terminal
============================================================ */
/*add 20251008*/

.p-terminal {
    color: #000;
}

.p-terminal .inner1000 {
    width: 96%;
    max-width: 1200px;
}

.p-terminal-intro {
    padding: 30px 0 80px;
}

.p-terminal-intro__pagettl {
    margin: 0 0 30px;
    font-size: 38px;
    font-weight: 700;
    text-align: center;
    color: #60ADB8;
}

.p-terminal-intro__summary {
    max-width: 680px;
    margin: 0 auto;
    text-align: center;
    font-size: 22px;
    line-height: 1.8;
}

.p-terminal-map__box {
    padding: 54px 30px 60px;
    color: #fff;
    background-color: #387D9F;
    border-radius: 20px;
}

.p-terminal-map__mds {
    margin-bottom: 28px;
    text-align: center;
    font-size: 31px;
    font-weight: 700;
    line-height: 1.65;
}

.p-terminal-map__mds .pc-none {
    display: none;
}

.p-terminal-map__txt {
    margin: 0 0 48px;
    font-size: 22px;
    text-align: center;
    line-height: 1.8;
}

.p-terminal-map__flex {
    max-width: 1000px;
    margin: 0 auto;
    display: flex;
    align-items: flex-start;
    gap: 3%;
}

.p-terminal-map__flex .img_l {
    width: calc(57% - 1.5%);
}

.p-terminal-map__flex .img_r {
    width: calc(43% - 1.5%);
}

.p-terminal-service {
    padding: 100px 0 170px;
    overflow: hidden;
}

.p-terminal-service__mds {
    margin: 0 0 60px;
    font-size: 38px;
    font-weight: 700;
    text-align: center;
    line-height: 1.7;
    color: #60ADB8;
}

.p-terminal-service__lists {
    display: flex;
    flex-direction: column;
    gap: 40px;
}

.p-terminal-service__lists li {
    width: 100%;
    min-height: 90px;
    padding: 15px 20px 15px 0;
    color: #fff;
    font-weight: 600;
    font-size: 28px;
    line-height: 1.4;
    background-color: #387D9F;
    border-radius: 10px;
    display: flex;
    align-items: center;
    position: relative;
}

.p-terminal-service__lists li:nth-of-type(2) {
    padding-right: 350px;
}
.p-terminal-service__lists li:nth-of-type(4),
.p-terminal-service__lists li:nth-of-type(5) {
    padding-right: 400px;
}

.p-terminal-service__lists li .icon {
    width: 115px;
    line-height: 1;
    text-align: center;
    flex-shrink: 0;
}

.p-terminal-service__lists li .icon img {
    width: auto;
}

.p-terminal-service__lists li:nth-of-type(2) .icon img {
    transform: rotate(20deg);
}

.p-terminal-service__deco {
    max-width: 329px;
    border-radius: 11px;
    position: absolute;
    z-index: 1;
}
.p-terminal-service__deco.img1 {
    top: -10px;
    right: -32px;
}
.p-terminal-service__deco.img2 {
    top: -14px;
    right: 50px;
}
.p-terminal-service__deco.img3,
.p-terminal-service__deco.img4 {
    display: none;
}

.p-terminal-howto {
    padding: 115px 0 130px;
    color: #2C2C2C;
    position: relative;
    z-index: 0;
}

.p-terminal-howto::before {
    content: "";
    width: 100%;
    height: 100%;
    background: linear-gradient(#4297a9 0%, #6ad7aa 100%);
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    opacity: 0.1;
}

.p-terminal-howto__mds {
    margin: 0 0 35px;
    font-size: 38px;
    font-weight: 700;
    text-align: center;
    color: #60ADB8;
    line-height: 1.7;
}

.p-terminal-howto__txt {
    margin: 0 0 40px;
    font-size: 22px;
    text-align: center;
    line-height: 1.85;
}

.p-terminal-howto__info {
    width: 90%;
    max-width: 895px;
    margin: 0 auto 68px;
    padding: 30px 15px 30px 55px;
    font-family: 'Noto Sans JP', "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN",
    "Hiragino Sans", Meiryo, sans-serif;
    border-radius: 22px;
    background-color: #fff;
}

.p-terminal-howto__lists {
    margin-bottom: 15px;
    font-size: 19px;
    font-weight: 400;
}

.p-terminal-howto__lists li {
    margin-bottom: 8px;
    padding-left: 1em;
    text-indent: -1em;
}

.p-terminal-howto__lists li:last-of-type {
    margin-bottom: 0;
}

.p-terminal-howto__note {
    padding-left: 1.2em;
    font-size: 16px;
    font-weight: 300;
    text-indent: -1.2em;
}

.p-terminal-howto__yt {
    width: 90%;
    max-width: 895px;
    height: auto;
    aspect-ratio: 16/9;
    margin: 0 auto;
    background-color: #707070;
    position: relative;
    z-index: 0;
    align-content: center;
}

.p-terminal-howto__soon {
    color: #fff;
    font-size: 48px;
    font-weight: 700;
    text-align: center;
}

.p-terminal-howto__yt iframe {
    width: 100%;
    height: 100%;
}

@media screen and (max-width: 1000px) {

    .p-terminal-service__lists li {
        font-size: 22px;
    }

    .p-terminal-service__lists li:nth-of-type(2) {
        padding-right: 270px;
    }

    .p-terminal-service__lists li:nth-of-type(4),
    .p-terminal-service__lists li:nth-of-type(5) {
        padding-right: 315px;
    }

    .p-terminal-service__deco {
        width: 280px;
    }
    .p-terminal-service__deco.img1 {
        right: -10px;
    }
    .p-terminal-service__deco.img2 {
        right: 15px;
    }

    .p-terminal-howto__info {
        padding: 30px 20px 30px 20px;
    }

}   

@media screen and (max-width: 767px) {

    .p-terminal-intro {
        padding: 10px 0 35px;
    }
    .p-terminal-intro__pagettl {
        margin-bottom: 20px;
        font-size: 20px;
    }
    .p-terminal-intro__summary {
        font-size: 15px;
    }

    .p-terminal-map__box {
        padding: 30px 25px 40px;
    }

    .p-terminal-map__mds {
        margin-bottom: 25px;
        font-size: 18px;
    }
    .p-terminal-map__mds .pc-none {
        display: block;
    }
    .p-terminal-map__txt {
        margin-bottom: 25px;
        font-size: 15px;
    }
    
    .p-terminal-map__flex {
        flex-direction: column;
        gap: 5vw;
    }
    .p-terminal-map__flex .img_l,
    .p-terminal-map__flex .img_r {
        width: 100%;
    }

    .p-terminal-service {
        padding: 45px 0 60px;
    }

    .p-terminal-service__mds {
        margin-bottom: 30px;
        font-size: 20px;
    }
    .p-terminal-service__lists {
        gap: 20px;
    }
    .p-terminal-service__lists li {
        min-height: 60px;
        padding-top: 12px;
        padding-bottom: 12px;
        font-size: 15px;
    }
    .p-terminal-service__lists li:nth-of-type(2) {
        padding-right: 20px;
    }
    .p-terminal-service__lists li:nth-of-type(4),
    .p-terminal-service__lists li:nth-of-type(5) {
        padding-right: 155px;
    }
    .p-terminal-service__lists li .icon {
        width: 70px;
    }
    .p-terminal-service__lists li:nth-of-type(1) .icon img {
        width: 44px;
    }
    .p-terminal-service__lists li:nth-of-type(2) .icon img {
        width: 28px;
    }
    .p-terminal-service__lists li:nth-of-type(3) .icon img {
        width: 28px;
    }
    .p-terminal-service__lists li:nth-of-type(4) .icon img {
        width: 38px;
    }
    .p-terminal-service__lists li:nth-of-type(5) .icon img {
        width: 40px;
    }
    .p-terminal-service__lists li:nth-of-type(6) .icon img {
        width: 35px;
    }
    .p-terminal-service__lists li:nth-of-type(7) .icon img {
        width: 35px;
    }
    .p-terminal-service__deco {
        width: 140px;
    }
    .p-terminal-service__deco.img1,
    .p-terminal-service__deco.img2 {
        display: none;
    }
    .p-terminal-service__deco.img3,
    .p-terminal-service__deco.img4 {
        display: block;
    }
    .p-terminal-service__deco.img3 {
        top: -10px;
        right: -8px;
    }
    .p-terminal-service__deco.img4 {
        top: 10px;
        right: 0;
    }
    .p-terminal-howto {
        padding: 50px 0 60px;
    }
    .p-terminal-howto__mds {
        margin-bottom: 25px;
        font-size: 20px;
    }
    .p-terminal-howto__txt {
        margin-bottom: 30px;
        font-size: 15px;
    }
    .p-terminal-howto__info {
        margin-bottom: 40px;
        padding: 20px;
        border-radius: 15px;
    }
    .p-terminal-howto__lists {
        font-size: 14px;
    }
    .p-terminal-howto__note {
        font-size: 14px;
    }
    .p-terminal-howto__soon {
        font-size: 6vw;
    }
} 
@media screen and (max-width: 450px) {
    .p-terminal-howto__mds {
        font-size: 18px;
    }
    .p-terminal-service__deco {
        width: 100px;
    }
    .p-terminal-service__lists li:nth-of-type(4), .p-terminal-service__lists li:nth-of-type(5) {
        padding-right: 120px;
    }
}