@charset "UTF-8";
.top-first {
margin-bottom: 40px;
}
h3 {
margin-top: 50px;
}
#toc {
margin: 20px 0;
background: #fff;
padding: 20px clamp(1.25rem, 0.795rem + 2.27vw, 2.5rem);
}
#toc > div {
font-weight: bold;
text-align: center;
margin-bottom: 20px;
}
#toc > div >span:first-child {
display: block;
font-size: clamp(1.25rem, 1.159rem + 0.45vw, 1.5rem);
line-height: 1;
}
#toc > ol > li:not(:last-child) {
margin-bottom: 10px;
}
#toc > ol > li > a{
padding-left: 6px;
}
.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 > 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%;
}
.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;
}
.top .basicWrap figure img {
width: 100%;
}
.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: 24px;
}
.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;
display: flex;
}
.termarea dl dd {
display: flex;
}
.termarea dl dd p {
margin: 0 0 15px;
}
.termarea dl dt::before {
content:"Q.";
font-size: 20px;
color: var(--main-color);
padding-right: 6px;
line-height: 1.2;
}
.termarea dl dd::before {
content:"A.";
font-size: 20px;
font-weight: bold;
padding-right: 6px;
color: var(--accent-color);
line-height: 1.4;
}
@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;
background: #fff;
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;
}
.timeTable tr:first-child th:first-child::before {
background: var(--main-color);
}
}