@charset "utf-8";



.a-billboard .site_frame {
    position: relative;
    height: auto;
    top: -50px !important;
}

@media screen and (max-width: 640px) {
.a-billboard .site_frame {
    position: relative;
    height: auto;
    top: -13px !important;
}
}

.-height100 {
    min-height:auto !important;
}

.maincol {
   max-width: 1100px;
    margin: 25px auto;
    width: 90%;
}


.breadcrumb {
    padding: 0 0 35px 0;
    width: 100%;
    margin: 0 auto;
    color:#000;
}


.breadcrumb a {
    /* color: #FFF; */
}


/*course*/
ul.course_list{
    border: none;
    padding: 0;
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
}

ul.course_list li {
        list-style: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 0 40px;
    background: #FFF;
    padding: 20px;
    color: #000;
    font-size: 16px;
}

ul.course_list li h3{
    width: 100%;
    margin: 0 0 15px 0;
    padding: 15px;
    line-height: 1.4;
    font-size: 18px;
    background: #EFEFEF;
    color: #000;
}

ul.course_list li .image{
    width: 30%;
}

ul.course_list li .image img {
    width: 100%;
    height: 160px;
    object-fit: cover;
}

ul.course_list li .disc{
    width: 67%;
}

ul.course_list li .disc dl {
    border-top: 1px solid #CCC;
    border-left: 1px solid #CCC;
    display: flex;
    flex-wrap: wrap;
    font-size: 14px;
}

ul.course_list li .disc dl dt{
    width: 30%;
    border-bottom: 1px solid #CCC;
    border-right: 1px solid #CCC;
    box-sizing: border-box;
    padding: 7px;
    background: #EFEFEF;
}

ul.course_list li .disc dl dd{
    width: 70%;
    border-bottom: 1px solid #CCC;
    border-right: 1px solid #CCC;
    box-sizing: border-box;
    padding: 7px;
}


ul.course_list li .disc dl dd label.open {
    border: 1px solid #666;
    padding: 7px;
    display: flex;
    width: max-content;
}

ul.course_list li p.btn_reserve_main{
    background: orange;
    border-radius: 8px;
     margin: 20px 0 0 auto;
    width: 300px;
        padding: 3px;
}


ul.course_list li p.btn_reserve_main a {
    color: #FFF;
    padding:10px 15px;
    display: flex;
    font-size: 18px;
    font-weight: bold;
    align-items: center;
    justify-content: center;
    text-shadow: 1px 1px 1px rgb(0 0 0 / 60%);
    border: 1px solid #FFF;
    border-radius: 8px;
}



@media screen and (max-width: 640px) {
ul.course_list li .image {
    width: 100%;
}
ul.course_list li .disc {
    width: 100%;
}
    ul.course_list li p.btn_reserve_main {
    margin: 20px auto 0 auto;
}
}


p.btn01 a {
background: #000;
    padding: 20px 25px 20px;
    width: max-content;
    box-sizing: border-box;
    text-align: center;
    margin: 50px auto;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    position: relative;
    font-size: 18px;
    border-radius: 0px;
    font-weight: bold;
    line-height: 1;
}

p.btn01 a span {
  color: #fff;
  line-height: 1;
  font-size: 16px;
  margin: -1px 0 0 0;
}


p.btn02 a {
background: #000;
    padding: 16px 25px 16px;
    width: max-content;
    box-sizing: border-box;
    text-align: center;
    margin: 10px auto;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    position: relative;
    font-size: 16px;
    border-radius: 0px;
    font-weight: bold;
    line-height: 1;
}

p.btn02 a span {
  color: #fff;
  line-height: 1;
  font-size: 16px;
  margin: 4px 0 0 0;
}

.att {
    width: 87%;
    margin: 0 auto;
    border: 1px solid #000;
    padding: 20px;
    font-size: 16px;
    box-sizing: border-box;
    max-width: 800px;
    color:#000;
}

/*top_menu*/


.top_menu {
      padding: 45px 0 40px 0;
    display: block;
    box-sizing: border-box;
}

.top_menu ul{
display: flex;
    justify-content: space-between;
    width: 90%;
    max-width: 1100px;
    margin: 0 auto;
}

.top_menu ul li{
    width: 47%;
    height: 250px;
    position: relative;
    background: #CCC;
    padding: 0;
    margin: 0;
}

.top_menu ul li a{
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    color: #FFF;
    justify-content: center;
    align-items: center;
    position: absolute;
    background: rgba(0,0,0,0.2);
    letter-spacing: 5px;
}

.top_menu ul li a:hover {
    opacity: 1;
    background: rgba(0,0,0,0);
}

.top_menu ul li a p{
    font-family: 'Encode Sans SC', sans-serif;
    font-size: 16px;
    font-weight: 300;
    margin: 7px 0;
}

.top_menu ul li a h3{
        font-size: 16px;
    letter-spacing: 1px;
    background: red;
    padding: 10px 13px;
    line-height: 1;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-weight: bold;
}

.top_menu ul li a span {
    transform: rotate(-90deg);

        margin: 0 0 0 14px;
}

.top_menu ul li img{
    width: 100%;
    height: 250px;
    object-fit: cover;
}



@media screen and (max-width: 768px) {
.top_menu ul {
  display: block;
  justify-content: space-around;
  width: 90%;
  margin: 0 auto;
}

    .top_menu ul li {
  width: 100%;
  height: 150px;
  position: relative;
  margin: 0 0 30px;
}

    .top_menu ul li img {
  height: 150px;
}

}




.monthly-calendar {
    background: #FFF;
    color: #000;
}

.monthly-calendar h3 {
    color: #000;
    background: #CCC;
    padding: 15px 20px;
    font-size: 18px;
}

.calendar-caption {
    font-size: 1.4rem;
    text-align: center;
    padding: 10px;
}


.monthly-next a {
    display: block;
    padding: 5px 20px;
    border: 1px solid #CCC;
    margin: 20px 0;
}

.monthly-next .no-link {
    display: block;
    padding: 5px 20px;
    border: 1px solid #CCC;
    margin: 20px 0;
    color: #CCC;
}


.monthly-prev a {
    display: block;
    padding: 5px 20px;
    border: 1px solid #CCC;
    margin: 20px 0 20px 20px;
}

.monthly-prev .no-link {
    display: block;
    padding: 5px 20px;
    border: 1px solid #CCC;
    margin: 20px 0 20px 20px;
    color: #CCC;
}



td.day-box {
    border: 1px solid #CCC;
}

.monthly-calendar table {
    margin: 0 auto !important;
    width: 94% !important;
}



.content-form th, .content-form td {
    border: none;
    font-size: 16px;
    padding: 0px 0 10px 20px;
    color:#000;
}

tr.booking-form-people-number-row {
    display:none !important;
}

.content-form select {
    font-size: 1rem;
    padding: 7px;
}

.content-form input, .content-form textarea {
    padding: 8px;
    margin-bottom: 3px;
    font-size: 16px;
}

.content-form textarea {
    height: 200px;
        width: 100% !important;
    box-sizing: border-box;
}

textarea#booking-option-work_other {
    height: 80px;
}

table.mtssb-timetable-link {
    width: 60% !important;
    padding: 20px 0;
}

.mtssb-timetable-name {
    font-size: 20px;
    font-weight: bold;
    padding: 35px 0 0 0;
    line-height: 1.4;
}

.mtssb-timetable-date {
    font-size: 16px;
    font-weight: bold;
}

.mtssb-daily-action button {
    margin: 0 0 30px 30px;
    width: 150px;
    padding: 7px;
}


th.day-left {
    border: 1px solid #CCC;
    background: cornsilk;
}


th.day-right{
     border: 1px solid #CCC;
}


table.mtssb-timetable-link tr:first-child th.day-left {
    background:#EFEFEF;
}

table.mtssb-timetable-link tr:first-child th.day-right {
    background:#EFEFEF;
}

div#action-button {
    display: flex;
    justify-content: space-around;
}




div#action-button button {
    background: rgb(204,204,204);
background: linear-gradient(0deg, rgba(204,204,204,1) 0%, rgba(255,255,255,1) 100%);
    color: #000;
    border: none;
    appearance: none;
    padding: 10px 20px;
    font-size: 18px;
}
div#action-button button.reserve {
    background: rgb(185,0,0);
background: linear-gradient(0deg, rgba(185,0,0,1) 0%, rgba(255,49,49,1) 100%);
    color: #FFF;
}

.subscription-search input {
    background: rgb(204,204,204);
background: linear-gradient(0deg, rgba(204,204,204,1) 0%, rgba(255,255,255,1) 100%);
    color: #000;
    border: none;
    appearance: none;
    padding: 10px 20px;
    font-size: 18px;
}


.mtssb-daily-action button {
    background: rgb(204,204,204);
background: linear-gradient(0deg, rgba(204,204,204,1) 0%, rgba(255,255,255,1) 100%);
    color: #000;
    border: none;
    appearance: none;
    padding: 10px 20px;
    font-size: 18px;
    border: 1px solid #999;
}


td.option-confirm-header {
   font-weight: bold;
    border-top: 1px solid #CCC;
    padding: 10px 0 0 0;
}

tr#confirmation-booking-message-title td {
    font-weight: bold;
    border-top: 1px solid #CCC;
    padding: 10px 0 0 0;
}


th.subscription-header form {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.subscription-cancel{
     float: none;
}

.subscription-cancel span {
    font-size: 15px;
    line-height: 1.4;
    border: 1px solid #CCC;
    padding: 7px;
    margin: 15px 0;
    display: block;
}


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

#booking-option-table tr {
    display: flex;
    flex-wrap: wrap;
}

#booking-option-table tr th {
    width: 100%;
    text-align: left;
    padding: 10px 0 0px 0;
    line-height: 1;
        font-weight: bold;
}

#booking-option-table tr td {
    width: 100%;
    text-align: left;
    padding:7px 0 13px 0;
    line-height: 1;
}

table.mtssb-timetable-link {
    width: 84% !important;
    padding: 20px 0;
}



fieldset#booking_client-fieldset tr {
    display: flex;
    flex-wrap: wrap;
}

    fieldset#booking_client-fieldset tr th{
        width: 100%;
    text-align: left;
    padding: 10px 0 0px 0;
    line-height: 1;
            font-weight: bold;
    }

    fieldset#booking_client-fieldset tr td{
        width: 100%;
    text-align: left;
    padding:7px 0 13px 0;
    line-height: 1;
    }

    #booking-confirm-fieldset table tr{
        display: flex;
        flex-wrap: wrap;
    }

    #booking-confirm-fieldset table tr th, #booking-confirm-fieldset table tr td {
    width: 100%;
    text-align: left;
}
    #booking-confirm-fieldset table tr th{
            font-weight: bold;
    line-height: 1;
    padding:7px 0 0 0;
    }

    th.subscription-header form {
    display: block;
    justify-content: space-between;
    align-items: center;
}

    table.form_subscription tr {
    display: flex;
    flex-wrap: wrap;
}

    table.form_subscription tr th {
    width: 100%;
    text-align: left;
    font-weight: bold;
    line-height: 1;
    padding: 10px 0 0 20px;
}

    table.form_subscription tr td {
    width: 100%;
    line-height: 1;
    padding: 5px 0 8px 20px;
}

    td.option-confirm-header {
    padding: 18px 0 2px 0 !important;
}

}
#booking-option-fieldset{
 color:#000;
}
.content-form legend{
 color:#000;
}
.content-form fieldset{
  color: #000;
}
.info-message.booking-completed{
  color:#000;
}
.inner_page{
  color:#000;
}

.cssskin-billboard-top {
    height: 4rem!important;
}
.cssskin-contents-ttl .c-title{
  padding: 1rem 0;
}
