/* calendar styles for activities  menu */
.calendar-block { margin: 20px 0 ; padding: 18px; background-color: #d4dbf7; border: 1px solid #d4dbf7;     -moz-border-radius: 10px;  -webkit-border-radius: 10px;  border-radius: 10px; border-left: 38px solid #c4cef5; }
.calendar-title { font-size: 18px; line-height: 1.3; color: #07077c; margin: 0 0 12px; }
.calendar-container { display: flex; flex-direction: column; gap: 12px; }
.calendar-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; background-color:#fff; border-top: 1px solid #89aad9; border-bottom: 1px solid #89aad9; border-radius: 7px; -moz-border-radius: 7px; -webkit-border-radius: 7px;}
.calendar-month { font-weight: 600; color: #333333; }
.calendar-header >  button { border: 1px solid #a5b4f1!important; background-color:#a5b4f1!important;}

.calendar-nav { border: 1px solid #ed6712; background-color: #ed6712; color: #fff; padding: 4px 10px; border-radius: 4px; cursor: pointer; font-size: 16px; line-height: 1; }
.calendar_explain { margin: 5px 0 0 ; color:#000a7d;}
ul.calendar-manual { padding: 5px 0 15px; }
.calendar-manual li { list-style-type: none; padding: 2px 0 0 ;}
.calendar-apply.small, .calendar-nav.small { font-size: 13px; padding: 2px 3px;letter-spacing: -1px; cursor: auto;}
.calendar-reset {  color: #07077c; cursor: pointer;  border: 1px solid #07077c; background-color: #fff;  padding: 4px 10px; border-radius: 4px; font-size: 16px; line-height: 1; }
.calendar-nav[disabled] { opacity: 0.35; cursor: not-allowed; pointer-events: none; }
.calendar-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
.calendar-cell { text-align: center; font-size: 13px; }
.calendar-label { font-weight: 600; text-transform: uppercase; color: #666666; padding: 4px 0; }
.calendar-day { padding: 10px 0; border: 1px solid #dcdcdc; border-radius: 4px; background-color: #fbfbfb; cursor: pointer; transition: background-color 0.2s, color 0.2s; }
.calendar-day:hover { background-color: #07077c; color: #ffffff; }
.calendar-day--has-event { border-color: #fb882d; position: relative; }
.calendar-day--has-event::after { content: ''; position: absolute; bottom: 6px; left: 50%; width: 6px; height: 6px; margin-left: -3px; border-radius: 50%; background-color: #fb882d; }
.calendar-day--active { background-color: #07077c; color: #ffffff; }
.calendar-empty { color: #07077c; font-size: 15px; font-weight: bold; text-align: left; padding:  0; width: 100%; }
.calendar-events { border-top: 1px solid #e3e3e3; padding: 12px 0 0; display: flex; flex-direction: column; align-items: stretch; gap: 10px; }
.calendar-event-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; width: 100%; }
.calendar-event-list li { display: flex; flex-direction: column; gap: 4px; text-align: left; }
.calendar-event-list a { color: #07077c; font-weight: 600; }
.calendar-event-list a:hover { text-decoration: underline; }
.calendar-data { display: none; }
.calendar-feedback { display:none!important;
    font-size: 14px;
    color: #fd0707;
    margin-top: 4px;
    min-height: 18px;
    padding: 5px;
    border: 1px solid #fd0707;
    background-color: #fff;
}

.calendar-reset:hover { text-decoration: none; }
.calendar-reset:focus { outline: 1px dotted #07077c; outline-offset: 2px; }
.calendar-filter-hidden { display: none !important; }
.calendar-container.is-empty .calendar-grid { opacity: 0.6; }
.calendar-container.is-empty .calendar-nav { opacity: 0.35; pointer-events: none; }
.calendar-container.is-empty .calendar-feedback { color: #666666; }
/* Range UI */
.calendar-range-controls { display:flex; gap:8px; align-items:center; flex-wrap:wrap; margin-top:4px; margin-bottom: 10px; }
.calendar-day--in-range { outline: 2px solid #fb882d; outline-offset: -2px; }
.calendar-day--range-start,
.calendar-day--range-end { box-shadow: inset 0 0 0 2px #07077c; }
.calendar-feedback--active { font-weight: 500; }
.calendar-actions { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.calendar-apply {  cursor:pointer; border:1px solid #07077c; background-color:#07077c; color:#fff; padding:6px 12px; border-radius:4px; font-size:15px; line-height:1; }
.calendar-apply:hover { background-color:#0a0a9c; border-color:#0a0a9c; }
.calendar-reset { padding:6px 12px; }
@media screen and (max-width: 768px) {
    .calendar-block { padding: 16px; }
    .calendar-day { padding: 8px 0; }
}

.calendar-actions-footer{ display:flex; gap:10px; flex-wrap:wrap; align-items:center; }

