@charset "UTF-8";
.top-first {
margin-bottom: 40px;
}
.top-first img {
width: 100%;
}
h2 {
font-size: clamp(1.125rem, 1.068rem + 0.24vw, 1.25rem);
font-weight: 600;
color: #000;
margin: 58px 0 20px;
position: relative;
padding: 8px 0;
outline: none;
}
h2::before {
content:none;
}
h2::after {
content:none;
}
h3 {
font-size: clamp(1rem, 0.943rem + 0.24vw, 1.125rem);
font-weight: 600;
margin: 20px 0;
position: relative;
border-left: 6px solid var(--main-color);
padding-left: 10px;
}
h3::after {
content:none;
}
h4 {
font-size: clamp(1.125rem, 1.068rem + 0.24vw, 1.25rem);
font-weight: 600;
color: #000;
margin: 28px 0 20px;
position: relative;
padding: 8px 16px;
outline: 1px solid var(--main-color);
}
h4::before {
content: "";
position: absolute;
top: 6px;
left: 6px;
width: calc(100% - 12px);
height: calc(100% - 12px);
background: var(--main-color);
opacity: 0.1;
}
h4::after {
content: "";
position: absolute;
bottom:-6px;
right: -6px;
border-right: solid 1px var(--main-color);
border-bottom: solid 1px var(--main-color);
width: 98%;
height: 98%;
}
.visual img {
width: 100%;
object-fit: contain;
}
.visual ul.visual-button {
display: flex;
justify-content: flex-end;
gap: 8px;
margin-bottom: 8px;
}
.visual ul.visual-button > li a {
padding: 4px 16px;
color: #fff;
font-weight: bold;
display: block;
text-align: center;
font-size: 14px;
}
.visual ul.visual-button > li.review a {
background: var(--main-color);}
.visual ul.visual-button > li.official a {
background: var(--accent-color);
}
.recommendWrap {
padding: 20px;
border-radius: 10px;
border: 1px solid #d5d5d5;
margin-bottom: 40px;
position: relative;
}
.recommendWrap.premiumbox {
background: #fff;
padding: 20px;
border:none;
box-shadow: 0 0 8px rgba(67, 67, 67, 0.15);
overflow: hidden;
}
.recommendWrap.premiumbox h3 {
font-size: clamp(1.25rem, 1.13rem + 0.49vw, 1.5rem);
    color: var(--main-color);
    padding: 0 20px;
    margin: 10px 0 20px;
    border: none;
}
.recommendWrap.premiumbox h3 {
    padding: 0 20px;
    margin: 10px 0 20px;
}
.recommendWrap.premiumbox::before {
content: "おすすめ";
    position: absolute;
    top: 58px;
    left: -18px;
    background-color: #01afec;
    color: #fff;
    font-size: 12px;
    font-weight: bold;
    padding: 4px 30px;
    transform: rotate(-45deg);
    transform-origin: top left;
    z-index: 10;
    pointer-events: none;
}
.premium-section {
display: flex;
align-items: flex-start;
gap: 16px;
}
.premium-section.right {
flex-direction: row-reverse;
}
.premium-section figure {
max-width: 100%;
width: 38%;
display: flex;
flex-direction: column;
}
.premium-section figure img {
max-width: 100%;
width: 100%;
    height: auto;
    object-fit: contain;
}
.premium-section figure figcaption {
justify-content: center;
margin: 5px 0 0;
}
.premium-section > div {
width: 62%;
}
.recommendWrap > div:not(.visual) ul > li,
.recommendWrap > div:not(.visual) ol > li {
margin-left: clamp(1.875rem, 1.591rem + 1.21vw, 2.5rem);
margin-bottom: 10px;
}
.recommendWrap > div:not(.visual) ul > li {
list-style-type: disc;
}
.recommendWrap > div:not(.visual) ol > li {
list-style-type: decimal;
}
.recommendWrap > div:not(.visual) ul > li:has(ul),.recommendWrap > div:not(.visual) ul > li:has(ol) {
font-weight: bold;
margin-left: 0;
margin-bottom: 15px;
list-style-type: none;
}
.recommendWrap > div:not(.visual) ol > li:has(ul),.recommendWrap > div:not(.visual) ol > li:has(ol) {
font-weight: bold;
margin-left: 20px;
margin-bottom: 15px;
}
.recommendWrap > div:not(.visual) ul > li::marker,
.recommendWrap > div:not(.visual) ol > li::marker {
color: var(--main-color);
font-weight: bold;
}
/* サブリスト内のリストアイテム */
.recommendWrap > div:not(.visual) ul > li > ul,.recommendWrap > div:not(.visual) ul > li > ol,
.recommendWrap > div:not(.visual) ol > li > ul,.recommendWrap > div:not(.visual) ol > li > ol {
margin-top: 5px;
}
.recommendWrap > div:not(.visual) ul > li > ul > li,.recommendWrap > div:not(.visual) ul > li > ol > li,
.recommendWrap > div:not(.visual) ol > li > ul > li,.recommendWrap > div:not(.visual) ol > li > ol > li {
margin-left: clamp(1.875rem, 1.591rem + 1.21vw, 2.5rem);
margin-bottom: 5px;
font-weight: normal;
}
.officialLink a,.detailLink a {
text-align: center;
margin: 40px auto;
border-radius: 5px;
font-weight: bold;
padding: 12px;
display: block;
transition: .3s;
}
.officialLink a {
background: var(--accent-color);
border: var(--accent-color) 1px solid;
}
.detailLink a {
background: var(--main-color);
border: var(--main-color) 1px solid;
}
.officialLink a,.detailLink a {
color: #fff;
}
.officialLink a:hover,.detailLink a:hover {
opacity: 1;
background: #fff;
}
.officialLink a:hover {
color: var(--accent-color);
}
.detailLink a:hover {
color: var(--main-color);
}
.basicHead {
text-align: center;
font-weight: bold;
font-size: clamp(1rem, 0.943rem + 0.24vw, 1.125rem);
border-bottom: 1px solid var(--main-color);
padding-bottom: 10px;
margin: 30px 0 0px;
}
.top .basicInfo {
    width: 100%;
    margin: 30px 0 30px;
}
.top .basicInfo > li {
display: grid;
padding: 10px;
width: 100%;
grid-template-columns: 140px 1fr;
margin: 0;
}
.top .basicInfo > li:not(:last-child) {
border-bottom: 1px solid var(--main-color);
}
.top .basicInfo > li > span:first-child {
text-align: center;
font-weight: bold;
}
.top .basicInfo .map div {
margin-top: 20px;
}
.top .basicInfo .map iframe {
width: 100%;
height: 250px;
}
.timeTable tr > * {
padding: 6px 16px;
border: 2px solid var(--main-color);
background: #fff;
}
.timeTable tr:first-child th {
background: var(--main-color);
font-weight: bold;
color: #fff;
}
.timeremarks {
font-size: 14px;
margin-top: 10px;
}
.timeremarks p {
margin: 5px 0;
}
.termarea {
margin-top: 80px;
}
.termarea dl {
background: #fff;
padding: 18px;
}
.termarea dl dt {
font-weight: bold;
font-size: 18px;
border-bottom: solid 2px var(--main-color);
padding-bottom: 6px;
margin-bottom: 12px;
}	
@media screen and (max-width: 768px) {
.visual {
display: flex;
flex-direction: column-reverse;	
}
.visual ul.visual-button {
margin-bottom: 15px;
}
.visual ul.visual-button > li {
flex: 1;
}
.visual ul.visual-button > li a {
padding: 4px 16px;
color: #fff;
font-weight: bold;
display: block;
text-align: center;
}
.top .basicInfo > li {
grid-template-columns: 1fr;
}
.top .basicInfo > li > span:first-child {
text-align: left;
margin-bottom: 8px;
padding-left: 5px;
border-left: 5px solid var(--main-color);
}
.top .basicInfo .map div {
margin-top: 10px;
}
.timeZone {
overflow: hidden;
}
.timeTableWrap {
overflow: auto;
-webkit-overflow-scrolling: touch;
}
.timeTable {
white-space: nowrap;
}
.timeTable th:first-child {
position: sticky;
top: 0;
left: 0;
background: none;
border-left: none;
border-right: none;
}
.timeTable th:first-child::before {
content: "";
position: absolute;
top: 0;
left: 0;
width: calc(100% + 2px);
height: 100%;
border-left: 2px solid var(--main-color);
border-right: 2px solid var(--main-color);
z-index: -1;
background: #fff;
}
.timeTable tr:first-child th:first-child::before {
background: var(--main-color);
}
}
@media screen and (max-width: 680px) {
.premium-section {
flex-direction: column;
flex-wrap: wrap;
}
.premium-section figure {
width: 100%;
}
.premium-section figure img {
margin: auto;
width: auto;
}
.premium-section > div {
width: 100%;
}
}