.cal-page{display:flex;flex-direction:column;height:calc(100vh - 52px - 34px)}.cal-toolbar{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.cal-nav-group{display:flex;align-items:center;gap:6px}.cal-nav-btn{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--text2);cursor:pointer;transition:all .12s}.cal-nav-btn:hover{background:var(--bg3);color:var(--text)}.cal-period{font-size:14px;font-weight:500;min-width:120px;text-align:center}.view-tabs{display:flex;background:var(--bg3);border-radius:8px;padding:2px}.view-tab{padding:5px 14px;border-radius:6px;font-size:12px;cursor:pointer;color:var(--text3);transition:all .12s}.view-tab.active{background:var(--card-bg);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.15)}.cal-body{flex:1;overflow:auto}.month-grid{display:grid;grid-template-columns:repeat(7,1fr);border-left:1px solid var(--border);border-top:1px solid var(--border)}.month-dow{text-align:center;font-size:11px;color:var(--text3);padding:8px 0;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}.month-cell{min-height:96px;padding:4px 6px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s;vertical-align:top}.month-cell:hover{background:color-mix(in srgb,var(--accent) 4%,transparent)}.month-cell.other-month .day-num{color:var(--text3)}.month-cell.today{background:color-mix(in srgb,var(--accent) 6%,transparent)}.day-num{font-size:12px;color:var(--text2);line-height:1;display:flex;align-items:center;gap:4px}.day-num.today-num{width:22px;height:22px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:11px}.lunar-day{font-size:9px;color:var(--text3)}.day-events{margin-top:4px;display:flex;flex-direction:column;gap:2px}.day-event{font-size:10px;padding:1px 5px;border-radius:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}.more-events{font-size:10px;color:var(--text3);padding:1px 4px}.week-grid{display:grid;grid-template-columns:48px repeat(7,1fr)}.week-time-col{border-right:1px solid var(--border)}.week-header{display:contents}.week-day-header{text-align:center;padding:8px 4px;border-bottom:1px solid var(--border);border-right:1px solid var(--border)}.week-day-name{font-size:11px;color:var(--text3)}.week-day-num{font-size:15px;font-weight:500;margin-top:2px}.week-day-num.today{width:26px;height:26px;background:var(--accent);color:#fff;border-radius:50%;margin:2px auto 0;display:flex;align-items:center;justify-content:center;font-size:12px}.week-body{display:contents}.time-slot{height:48px;display:flex;align-items:flex-start;padding-top:4px;justify-content:flex-end;padding-right:8px;border-bottom:1px solid var(--border)}.time-label{font-size:10px;color:var(--text3);font-family:'JetBrains Mono',monospace}.week-cell{height:48px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);position:relative;cursor:pointer;transition:background .1s}.week-cell:hover{background:color-mix(in srgb,var(--accent) 4%,transparent)}.week-event{position:absolute;left:2px;right:2px;border-radius:3px;font-size:10px;padding:1px 4px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;cursor:pointer}.ec-blue{background:color-mix(in srgb,var(--accent3) 18%,transparent);color:var(--accent3)}.ec-red{background:color-mix(in srgb,var(--danger) 18%,transparent);color:var(--danger)}.ec-green{background:color-mix(in srgb,var(--accent2) 18%,transparent);color:var(--accent2)}.ec-yellow{background:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent)}.ec-purple{background:rgba(168,85,247,.18);color:#a855f7}.ev-modal{max-width:460px}.ev-form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.ev-color-row{display:flex;gap:8px;margin:4px 0}.ev-color-dot{width:20px;height:20px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .1s}.ev-color-dot:hover{transform:scale(1.15)}.ev-color-dot.sel{border-color:var(--text)}