body, html {
    font-family: Arial, sans-serif;
	height: 100%;
	margin: 0;
}

#wrapper {
	display: flex;
	flex-direction: column;
	 min-height: 100vh;
}

#container {
	width: 100%;
	flex: 1;
	max-width: 1200px;
}


@font-face {
    font-family: "number";
    src: url("https://chamber-opera.jp/wp-content/themes/cherubino/fonts/number.eot?")  format('eot'),
         url("https://chamber-opera.jp/members/wp-content/themes/cherubino/fonts/number.woff2") format('woff2'),
         url("https://chamber-opera.jp/wp-content/themes/cherubino/fonts/number.woff")  format('woff');
  }
  
#calendar-view-switch {
	width: 100%;
	text-align: right;
	padding-right: 20px;
}
  
#switch-to-normal, #switch-to-vertical {
    display: inline-block;
	padding: 5px 15px;
	background: #0080c0;
	color: white;
	border-radius: 5px;
	cursor: pointer;
	margin: 5px;
	border: solid 1px #fff;
}


button#prev-month, button#next-month{
    display: inline-block;
	padding: 3px 15px;
	background: #008080;
	color: white;
	border-radius: 5px;
	cursor: pointer;
	margin: 5px;
	border: solid 1px #fff;
}

.forword {
	display: flex;
	justify-content: space-between;
}

#current-year {
    font-size: 24px;
    font-family: "number";
}

#current-month {
    font-family: "number";
    font-size: 42px;
}

@media screen and (max-width: 400px) {
    button#prev-month, button#next-month{
        font-size: 11px;
    } 
    #current-year {
        font-size: 20px;
    }
    
    #current-month {
        font-size: 36px;
    }
}

#calendar-container {
    width: 100%;
    display: flex;
    flex-direction: column;
}

#calendar {
    width: 100%;
    border-collapse: collapse;
	margin-top: 15px;
}

#calendar th,
#calendar td {
    border: 1px solid #999;
    text-align: center;
    padding: 0.5rem;
	width: 14%;
	font-size: 13px;
}

.sunday {
	background: #ffc8c8;}
}

.saturday {
	background: #c8fffb;
}

#calendar td a{
	text-decoration: none;
	color: #0051a2;
}

#calendar th {
    background-color: #f3f3f3;
    font-weight: bold;
}

#calendar .sunday {
    background-color: #ffe0e0;
}

#calendar .saturday {
    background-color: #e0f0ff;
}

#calendar .holiday {
    background-color: #ffd700;
}

#calendar .empty {
    background-color: #f3f3f3;
}

#calendar .date {
    font-size: 1.2rem;
    margin-bottom: 0.5rem;
}

#calendar .holiday-name {
    font-size: 0.9rem;
    color: #555;
    margin-bottom: 0.5rem;
}

#calendar .events {
    font-size: 0.8rem;
}

.other-month {
	color: #acacac;
	}

.vertical #calendar th {
    display: none;
}

.vertical #calendar-body tr, .vertical #calendar, .vertical #calendar-body td {
	width: 100%;
}

.vertical tr td {
    display: flex;
    flex-direction: column;
    flex-direction: row;
	width: 100%;
	padding: 0;
}

.vertical tr td div.date,
.vertical tr td div.d-o-w {
    order: -1;
}



.vertical tr td .date,
.vertical tr td .d-o-w {
    order: -1;
    min-width: 40px;
    display: inline-block;
    text-align: right;
    padding-right: 5px;
	height: 100%;
    text-align: center;
}

.vertical tr td .event-wrap {
    flex-grow: 1;
}
.event-wrap {
    width: calc((90% - 100px) / 2);
    margin-right: 5%;
  }
  .event-wrap-horizontal {
    width: 100%;
    margin-left: 0;
  }
  

.vertical .date,
.vertical .d-o-w,
.vertical .event_1,
.vertical .event_2,
.vertical .event_3 {
    display: inline-block;
}
.event_1 {
	font-size: 11px;
}



.vertical .event-wrap {
    display: flex;
    flex-direction: row;
}

.vertical-view {
    position: relative;
}

.calendar .date.vertical-view::after,
.calendar .d-o-w.vertical-view::after {
    content: "";
    position: absolute;
    top: 0;
    right: -1px;
    bottom: 0;
    width: 1px;
    background-color: #000;
}

.calendar .d-o-w.vertical-view::after {
    bottom: auto; 
}