.calendar-container{margin:2.25rem 0}.calendar-header{display:flex;justify-content:center;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:600;margin-bottom:1rem}.month-nav-button{border:1px solid #333333;background:#ffffff;color:#333333;border-radius:.4rem;padding:.25rem .55rem;font-size:.8rem;cursor:pointer}.month-nav-button:hover{background:#f3f4f6}.calendar-status{text-align:center;font-size:.9rem;color:#4b5563;margin:.5rem 0 .85rem}.calendar-legend{display:flex;gap:1rem;justify-content:center;align-items:center;flex-wrap:wrap;margin-bottom:1rem}.legend-item{display:inline-flex;align-items:center;gap:.4rem;font-size:.875rem;color:#333333}.legend-color{width:14px;height:14px;border-radius:3px;border:1px solid rgba(0,0,0,.2)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:.5rem;text-align:center;font-size:.875rem;font-weight:700;color:#333333}.weekday{padding:.25rem 0}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.75rem}.calendar-day{position:relative;padding:1.25rem;border:1px solid #333333;border-radius:.5rem;text-align:center;cursor:pointer;transition:background-color .2s ease}.calendar-day.today:before{content:"";position:absolute;width:28px;height:28px;background-color:#ef4444;border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);z-index:0}.calendar-day.today span{position:relative;z-index:1;color:white;font-weight:600}.calendar-day:hover{background-color:#f3f4f6}.calendar-day.event-regular,.legend-color.event-regular{background-color:#fef08a}.calendar-day.event-regular:hover{background-color:#fde047}.calendar-day.event-potlock-picnic,.legend-color.event-potlock-picnic{background-color:#bbf7d0}.calendar-day.event-potlock-picnic:hover{background-color:#79f1a3}.calendar-day.event-weekly-meeting,.legend-color.event-weekly-meeting{background-color:#bfdbfe}.calendar-day.event-weekly-meeting:hover{background-color:#68abfd}.event-details{margin-top:1.5rem;padding:1rem;border:1px solid #333333;border-radius:.5rem;box-shadow:0 1px 3px rgba(0,0,0,.08)}.event-title{font-size:1.125rem;font-weight:600}.event-date{font-size:.875rem;color:#333333}.event-date,.event-description{margin-top:.5rem}.event-link{display:inline-block;margin-top:.75rem;color:#2563eb;text-decoration:underline}.event-link:hover{opacity:.8}.events-page{padding:0 1rem}.events-header{margin-bottom:2rem}.events-header,.section-title{text-align:center}.calendar-wrapper{margin:1.25rem auto;max-width:80rem;padding:0 1rem}