@charset "utf-8";
.xo-event-meta {
padding: 3.8461% 0;
}
.xo-event-meta span {
display: block;
} html[lang="ja"] .xo-event-calendar .dashicons {
font-family: dashicons !important;
}
 .xo-event-calendar {
font-family: 'Noto Serif JP', serif;
color: #2f2f2f;
margin: 70px 0 80px;
}
.xo-event-calendar table {
width: 100%;
border-collapse: collapse;
table-layout: fixed;
} .xo-event-calendar table.xo-month {
border-top: 1px solid #d8d6cf;
border-bottom: 1px solid #d8d6cf;
border-left: none;
border-right: none;
} .xo-event-calendar table.xo-month caption .month-header span {
display: block;
text-align: center;
font-family: "Crimson Text", serif;
font-size: 16px;
letter-spacing: 0.16em;
color: #444;
margin: 16px 0 5px;
} .xo-month thead th {
font-size: 0;
padding: 25px 0;
position: relative;
}
.xo-month thead th:before {
font-family: "Crimson Text", serif;
font-size: 11px;
letter-spacing: 0.15em;
color: #777;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
.xo-month th.sunday:before { content: "S"; }
.xo-month th.monday:before { content: "M"; }
.xo-month th.tuesday:before { content: "T"; }
.xo-month th.wednesday:before { content: "W"; }
.xo-month th.thursday:before { content: "T"; }
.xo-month th.friday:before { content: "F"; }
.xo-month th.saturday:before { content: "S"; }  .xo-month .month-dayname td {
text-align: center;
vertical-align: middle;
}
.xo-month .month-dayname td div {
display: flex;
align-items: center;
justify-content: center;
margin: 8px auto;
width: 45px;
height: 45px;
border-radius: 50%;
font-size: 16px;
font-family: "Crimson Text", serif;
transition: all 0.25s ease;
} .xo-month .month-dayname td div.other-month {
opacity: 0.3;
}  .holiday-openfss {
background-color: #fffefd !important;
} .holiday-appomonthu {
background-color: #dee6e5 !important;
} .xo-event-calendar .holiday-titles {
padding: 20px 0 0 0;
}
.xo-event-calendar p.holiday-title {
font-size: 12px;
letter-spacing: 0.1em;
color: #444;
margin: 0 0 3px 0;
padding-left: 23px;
position: relative;
}
.xo-event-calendar p.holiday-title span {
position: absolute;
display: inline-block;
margin: 5px auto;
width: 15px;
height: 15px;
border-radius: 50%;
transition: all 0.25s ease;
top: -1px;
left: 0;
} @media (max-width: 1020px) and (min-width: 768px){
.xo-month .month-dayname td div {
width: 38px;
height: 38px;
font-size: 16px;
margin: 8px auto;
}
}
@media screen and (max-width: 767px) {
.xo-event-calendar table.xo-month caption .month-header span {
margin: 14px 0 5px;
font-size: 16px;
}
.xo-month thead th {
padding: 20px 0;
}
.xo-month .month-dayname td div {
width: 35px;
height: 35px;
font-size: 16px;
margin: 2px auto;
}
.xo-event-calendar p.holiday-title {
font-size: 11px;
margin: 0 0 2px 0;
}
}