.calendar-viewer{display:flex;flex-direction:column;gap:1rem}.viewer-header{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;padding:1rem;background:var(--bg-secondary, #f5f5f5);border-radius:8px}.file-info{display:flex;align-items:center;gap:1rem}.file-name{font-weight:600;color:var(--text-primary, #333)}.event-count{color:var(--text-secondary, #666);font-size:.875rem}.viewer-actions{display:flex;gap:.75rem;align-items:center}.filter-select{padding:.5rem .75rem;border:1px solid var(--border-color, #ddd);border-radius:6px;background:#fff;font-size:.875rem}.events-list{display:flex;flex-direction:column;gap:.75rem}.no-events{text-align:center;padding:2rem;color:var(--text-secondary, #666)}.event-card{background:var(--bg-secondary, #f5f5f5);border-radius:8px;overflow:hidden;transition:box-shadow .2s}.event-card:hover,.event-card.expanded{box-shadow:0 2px 8px #0000001a}.event-header{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;align-items:flex-start;padding:1rem;cursor:pointer}.event-main{flex:1;min-width:200px}.event-title{margin:0 0 .25rem;font-size:1rem;color:var(--text-primary, #333)}.event-time{font-size:.875rem;color:var(--text-secondary, #666)}.event-badges{display:flex;flex-wrap:wrap;gap:.5rem}.badge{padding:.25rem .5rem;background:var(--primary, #4361ee);color:#fff;border-radius:4px;font-size:.75rem;font-weight:500}.badge.recurring{background:var(--warning, #f59e0b)}.badge.status{background:var(--success, #22c55e)}.event-details{padding:.75rem 1rem 1rem;display:flex;flex-direction:column;gap:.5rem;border-top:1px solid var(--border-color, #e0e0e0);margin-top:.5rem}.detail-row{display:flex;gap:.5rem;font-size:.875rem}.detail-label{color:var(--text-secondary, #666);white-space:nowrap}.detail-value{color:var(--text-primary, #333);word-break:break-word}.error-message{text-align:center;padding:1rem;background:#ef44441a;color:var(--error, #ef4444);border-radius:8px;margin-top:1rem}.info-box{background:var(--bg-secondary, #f5f5f5);border-radius:8px;padding:1rem;margin-top:1.5rem}.info-box h4{margin:0 0 .75rem;font-size:1rem}.info-box ul{margin:0;padding-left:1.25rem}.info-box li{margin:.25rem 0;color:var(--text-secondary, #666);font-size:.875rem}.privacy-note{text-align:center;padding:.75rem;background:#4caf501a;color:var(--success, #4caf50);border-radius:8px;font-size:.875rem;margin-top:1rem}@media(max-width:640px){.viewer-header{flex-direction:column;align-items:stretch}.viewer-actions{justify-content:space-between}.event-header{flex-direction:column}.event-badges{margin-top:.5rem}}
