@charset "utf-8";

#schedule h1 {
        font-family: 'Kiwi Maru', serif;
        position: absolute;
        top: 3.5vw;
        left: 10%;
        z-index: 1;
        color: #ffffff;
	font-size: 7vw;
	font-weight: normal;
}

.schedule-header {
        max-width: 1200px;
	width: 94%;
        margin: 3% auto;
        padding-bottom: 5px;   
}

.schedule-header .header-inner {
        height: 23vw;
	position: relative;
        background-color: #20aee5;
        border-radius: 5px;
}

.schedule-header .schedule-img {
        position: absolute;
        bottom: 0;
        right: 10%;
        width: 25%;
        height: auto;
        object-fit: cover;
}

/* main */
.mb20 {
        margin-bottom: 20px;
}

.schedule-main strong {
        color: red;
}

.schedule-main .main-inner{
        max-width: 1200px;
	width: 94%;
        margin: 20px auto;
}

.schedule-main .main-inner .graph-box {
	width: 94%;
	height: auto;
	margin: 1rem auto;
}

.schedule-main .main-inner .graph-box img {
	width: 100%;
	height: auto;
}

.schedule-main .top-title {
        margin-bottom: 20px;
}

.schedule-main h2 {
        font-family: 'Kiwi Maru', serif;
        padding: 0.5rem;
        margin: 1rem auto;
        border-top: solid 1px #20aee5;
        border-bottom: solid 1px #20aee5;
        color: #20aee5;
        text-align: center;
}

.schedule-main .main-contents {
        margin-top: 20px;
}

.schedule-main .top-title {
        position: relative;
        height: auto;
        padding: 1rem;
        border-bottom: 1px solid #fff;
        background-color: #20aee5;
        text-align: center;
        cursor: pointer;
        font-weight: bold;
        font-size: 1.8rem;
        color: #fff;
}

.schedule-main .top-title::after {
        position: absolute;
        right: 20px;
        font-family: "Font Awesome 5 Free";
        content: '\f0ab';
        font-weight: 900;
        display: inline-block;
        transition: .3s;
}

.schedule-main .top-title.open::after {
	transform: rotate(180deg);
}

.schedule-main .schedule-wrap {
	display: none;
}

.schedule-main .month {
        font-family: 'Kiwi Maru', serif;
        font-size: 18.5px;
        font-weight: bold;
        padding-left: 5px;
        margin: 15px auto;
        border-bottom: 1px dotted #20aee5;
}

.schedule-main h3 {
        font-family: 'Kiwi Maru', serif;
        font-size: 18px;
        font-weight: bold;
}

.schedule-main .schedule-wrap {
        width: 100%;
        padding-bottom: 20px;
        margin: 20px auto;
        background: url(../images/schedule_line00.png) left 6vw top repeat-y;
        background-size: 3rem auto;
}

.schedule-main .schedule-flex {
        display: flex;
        justify-content: space-around;
        align-items: flex-start;
}

.schedule-main .schedule-box {
        flex-basis: 10%;
}

.schedule-main .schedule-day {
        width: 6rem;
        height: 6rem;
        margin-left: 1rem !important;
        border-radius: 50%;
        color: #ffffff;
        font-size: 1.1rem;
        text-align: center;
        line-height: 6rem;
}

.schedule-main .schedule-special-day {
        width: 8rem;
        height: 8rem;
        border-radius: 50%;
        font-size: 1.6rem;
        color: #ffffff;
        text-align: center;
        line-height: 8rem;
}

.schedule-main .schedule-day01 {
        border: 1px solid #78cbee;
        background-color: #78cbee;
}

.schedule-main .schedule-day02 {
        border: 1px solid #95d300;
        background-color: #95d300;
}

.schedule-main .schedule-day03 {
        border: 1px solid #036eb8;
        background-color: #036eb8;
}

.schedule-main .schedule-day04 {
        border: 1px solid #e85298;
        background-color: #e85298;
}

.schedule-main .schedule-day05 {
        border: 1px solid #859ccf;
        background-color: #859ccf;
}

.schedule-main .first {
        margin: 85px auto;
}

.schedule-main .all {
        margin: 40px auto; 
}

.schedule-main .last {
        margin: -20px auto;
}

.schedule-main .schedule-item {
        flex-basis: 80%;
}

.schedule-main .title-style {
        padding-left: 10px;
}

.schedule-main .title-style01 {
        color: #78cbee;
}

.schedule-main .title-style02 {
        color: #95d300;
}

.schedule-main .title-style03 {
        color: #036eb8;
}

.schedule-main .title-style04 {
        color: #e85298;
}

.schedule-main .title-style05 {
        color: #859ccf;
}

.schedule-main .text-style {
        font-size: 1.6rem;
}

.schedule-main .schedule-day .text-style {
        font-size: 1.3rem;
}


.schedule-main .schedule-text {
        text-align: justify;
        padding-right: 10px;
}

.schedule-main .schedule-img01 {
        width: 45%;
        margin: 10px auto;
        margin-left: 50%;
}

.schedule-main .schedule-img02 {
        width: 35%;
        margin: 10px auto;
}

.schedule-main .point-box {
        position: relative;
        margin: 2em 0;
        padding: 0.5em 1em;
        border: solid 3px #e85298;
        border-radius: 8px;
}

.schedule-main .point-box .box-title {
        position: absolute;
        display: inline-block;
        top: -13px;
        left: 10px;
        padding: 0 9px;
        line-height: 1;
        font-size: 19px;
        background-color: #ffffff;
        color: #e85298;
        font-weight: bold;
}

.schedule-main .point-box p {
        margin: 0; 
        padding: 0;
}

/* 後期 */
.schedule-main .second-term .first {
        margin: 75px auto;
}

.schedule-main .all02 {
        margin: -25px auto;
}

.schedule-main .schedule-img03 {
        width: 40%;
        margin: 10px auto;
        margin-left: 25%;
}

/* 推薦Ⅰ・Ⅱ・総合 */

.schedule-main .recommendation01 .first {
        margin: 170px auto;
}

.schedule-main .schedule-img04 {
        width: 40%;
        margin: 10px auto;
}

.schedule-main .schedule-img05 {
        width: 25%;
        margin: 10px auto;
        margin-left: 65%;
}

.schedule-main .schedule-img06 {
        width: 30%;
        margin-left: 60%;
}

.schedule-main .schedule-img07 {
        width: 20%;
        margin-left: 40%;
}

@media screen and (min-width:768px) {

#schedule h1 {
	position: absolute;
	left: 27%;
	top: 12rem;
        z-index: 1;
        color: #036eb8;
        font-family: 'Kiwi Maru', serif;
	font-weight: bold;
        font-size: 1.3rem;
}

#schedule .schedule-header .header-inner {
        margin-top: 8rem;
        height: 7rem;
        background-color: #bae3f9;
	background-image:
	radial-gradient(#d3edfb 20%, transparent 20%),
        radial-gradient(#d3edfb 20%, transparent 20%);
	background-size: 40px 40px;
	background-position: 0 0, 20px 20px;
}

#schedule .pc-schedule-title {
        position: absolute;
        left: 10%;
        bottom: 0;
        color: #036eb8;
        font-family: 'Kiwi Maru', serif;
	font-size: 4rem;
}

#schedule .schedule-header .schedule-img {
        position: absolute;
        bottom: 0;
        right: 10%;
        width: auto;
        height: 150%;
}

#schedule .schedule-main .main-inner .graph-box {
	width: 90%;
	height: auto;
	margin: 0;
}

#schedule .main-contents {
        width: 50%;
        float: left;
}

#schedule .schedule-contents {
        margin: 50px auto;
}

#schedule .schedule-main .schedule-wrap {
        background: url(../images/schedule_line00.png) left 2vw top repeat-y;
        background-size: 3rem auto;
}

}