.calendar{display:flex;flex-direction:column;height:calc(100vh - var(--topbar-height) - var(--space-16));min-height:600px}.cal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) 0;margin-bottom:var(--space-4);flex-wrap:wrap;gap:var(--space-3)}.cal-header__nav{display:flex;align-items:center;gap:var(--space-2)}.cal-header__title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--weight-bold);letter-spacing:var(--tracking-tight);min-width:220px;text-align:center}.cal-header__btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-md);background:var(--bg-surface);border:1px solid var(--border-default);color:var(--text-secondary);transition:all var(--duration-fast) var(--ease-out)}.cal-header__btn:hover{background:var(--bg-surface-hover);color:var(--text-primary);border-color:var(--border-strong)}.cal-header__today{padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--weight-medium);background:var(--accent-subtle);color:var(--accent);transition:all var(--duration-fast) var(--ease-out)}.cal-header__today:hover{background:var(--accent);color:var(--accent-text)}.cal-header__views{display:flex;background:var(--bg-muted);border-radius:var(--radius-md);padding:3px;gap:2px}.cal-header__view-btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-tertiary);transition:all var(--duration-fast) var(--ease-out)}.cal-header__view-btn:hover{color:var(--text-primary)}.cal-header__view-btn--active{background:var(--bg-surface);color:var(--text-primary);box-shadow:var(--shadow-sm)}.cal-grid{flex:1;display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border-subtle);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden}.cal-grid__weekday{padding:var(--space-3) var(--space-2);font-size:var(--text-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--text-tertiary);text-align:center;background:var(--bg-surface)}.cal-grid__day{background:var(--bg-surface);padding:var(--space-2);min-height:100px;cursor:pointer;transition:background-color var(--duration-fast) var(--ease-out);display:flex;flex-direction:column;gap:var(--space-1);position:relative}.cal-grid__day:hover{background:var(--bg-surface-hover)}.cal-grid__day--today{background:var(--cal-today)}.cal-grid__day--today:after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--cal-today-border)}.cal-grid__day--other-month{opacity:.3}.cal-grid__day--unavailable{background:var(--cal-unavailable);cursor:not-allowed;pointer-events:none}.cal-grid__day--unavailable .cal-grid__day-num{color:var(--cal-unavailable-text);text-decoration:line-through}.cal-grid__day-num{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-secondary);width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full)}.cal-grid__day--today .cal-grid__day-num{background:var(--accent);color:var(--accent-text);font-weight:var(--weight-bold)}.cal-event{padding:2px var(--space-2);border-radius:var(--radius-sm);font-size:.6875rem;font-weight:var(--weight-medium);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.cal-event:hover{transform:scale(1.02);box-shadow:var(--shadow-sm)}.cal-event--meeting{background:var(--cal-meeting-bg);color:var(--cal-meeting);border-left:2px solid var(--cal-meeting)}.cal-event--appointment{background:var(--cal-appointment-bg);color:var(--cal-appointment);border-left:2px solid var(--cal-appointment)}.cal-event__more{font-size:.625rem;color:var(--text-tertiary);padding:1px var(--space-2);font-weight:var(--weight-medium)}.cal-week{flex:1;display:grid;grid-template-columns:60px repeat(7,1fr);gap:1px;background:var(--border-subtle);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden}.cal-week__time-label{background:var(--bg-surface);padding:var(--space-2);font-size:var(--text-xs);color:var(--text-tertiary);text-align:right;border-right:1px solid var(--border-subtle)}.cal-week__slot{background:var(--bg-surface);padding:var(--space-1);min-height:48px;border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background-color var(--duration-fast) var(--ease-out);position:relative}.cal-week__slot:hover{background:var(--bg-surface-hover)}.cal-week__slot--unavailable{background:var(--cal-unavailable);cursor:not-allowed;pointer-events:none}.cal-day{flex:1;display:flex;flex-direction:column;gap:1px;background:var(--border-subtle);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;overflow-y:auto}.cal-day__slot{display:grid;grid-template-columns:80px 1fr;min-height:60px;background:var(--bg-surface)}.cal-day__slot-time{padding:var(--space-3);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-tertiary);border-right:1px solid var(--border-subtle);display:flex;align-items:flex-start}.cal-day__slot-content{padding:var(--space-2) var(--space-3);cursor:pointer;transition:background-color var(--duration-fast) var(--ease-out)}.cal-day__slot-content:hover{background:var(--bg-surface-hover)}.cal-day__slot--unavailable .cal-day__slot-content{background:var(--cal-unavailable);cursor:not-allowed;pointer-events:none}.cal-day__slot--unavailable .cal-day__slot-time{color:var(--cal-unavailable-text)}.time-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--space-2);padding:var(--space-4) 0}.time-slot{padding:var(--space-3) var(--space-2);text-align:center;border:1px solid var(--border-default);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-secondary);transition:all var(--duration-fast) var(--ease-out);cursor:pointer}.time-slot:hover:not(.time-slot--disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-subtle)}.time-slot--selected{background:var(--accent);color:var(--accent-text);border-color:var(--accent);font-weight:var(--weight-semibold)}.time-slot--disabled{background:var(--cal-unavailable);color:var(--cal-unavailable-text);cursor:not-allowed;border-color:transparent;text-decoration:line-through}.cal-legend{display:flex;gap:var(--space-6);padding:var(--space-4) 0;font-size:var(--text-sm)}.cal-legend__item{display:flex;align-items:center;gap:var(--space-2);color:var(--text-secondary)}.cal-legend__dot{width:10px;height:10px;border-radius:var(--radius-full)}.cal-legend__dot--meeting{background:var(--cal-meeting)}.cal-legend__dot--appointment{background:var(--cal-appointment)}.cal-legend__dot--unavailable{background:var(--cal-unavailable-text)}
