@import "https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=DM+Mono:wght@400;500&display=swap";
*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#111;background:#f7f8fc;min-height:100vh;font-family:DM Sans,sans-serif}.app{max-width:1100px;margin:0 auto;padding:0 16px 40px}.header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:28px 0 20px;display:flex}.header-left{align-items:center;gap:20px;display:flex}.title{letter-spacing:-.01em;color:#111;font-size:1.05rem;font-weight:600}.subtitle{color:#888;margin-top:2px;font-size:.78rem;font-weight:400}.nav{align-items:center;gap:8px;display:flex}.nav-btn{cursor:pointer;color:#444;background:#fff;border:1.5px solid #e0e0e0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;transition:all .15s;display:flex}.nav-btn:hover{background:#f0f0f0;border-color:#ccc}.today-btn{cursor:pointer;color:#444;background:#fff;border:1.5px solid #e0e0e0;border-radius:8px;height:32px;padding:0 14px;font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;transition:all .15s}.today-btn:hover{background:#f0f0f0;border-color:#ccc}.week-label{color:#333;min-width:240px;font-size:.9rem;font-weight:500}.legend{flex-wrap:wrap;gap:16px;padding:0 0 16px;display:flex}.legend-item{color:#555;align-items:center;gap:7px;font-size:.78rem;font-weight:500;display:flex}.legend-dot{border-radius:50%;width:10px;height:10px}.calendar-wrap{background:#fff;border:1.5px solid #e8e8e8;border-radius:16px;overflow:hidden;box-shadow:0 2px 12px #0000000d}.day-headers{border-bottom:1.5px solid #ececec;grid-template-columns:52px repeat(7,1fr);display:grid}.day-header-spacer{background:#fff}.day-header{text-align:center;border-left:1px solid #ececec;padding:14px 8px 12px}.day-header-name{letter-spacing:.06em;text-transform:uppercase;color:#aaa;font-size:.7rem;font-weight:600}.day-header-num{color:#333;margin-top:2px;font-family:DM Mono,monospace;font-size:1.3rem;font-weight:300}.day-header.today .day-header-name{color:#4285f4}.day-header.today .day-header-num{color:#fff;background:#4285f4;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;margin:4px auto 0;font-size:1rem;font-weight:500;display:flex}.allday-row{border-bottom:1.5px solid #ececec;grid-template-columns:52px repeat(7,1fr);min-height:28px;display:grid}.allday-label{color:#bbb;letter-spacing:.04em;text-transform:uppercase;justify-content:center;align-items:center;font-size:.65rem;font-weight:500;display:flex}.allday-cell{border-left:1px solid #ececec;flex-direction:column;gap:2px;padding:3px 4px;display:flex}.allday-event{border-radius:4px;padding:2px 6px;font-size:.68rem;font-weight:500}.time-grid{grid-template-columns:52px repeat(7,1fr);display:grid;position:relative}.time-col{position:relative}.time-slot{justify-content:flex-end;align-items:flex-start;height:48px;padding:0 8px 0 0;display:flex}.time-label{color:#bbb;font-family:DM Mono,monospace;font-size:.65rem;font-weight:400;transform:translateY(-7px)}.day-col{border-left:1px solid #ececec;position:relative}.hour-line{background:#f0f0f0;height:1px;position:absolute;left:0;right:0}.half-line{background:#f7f7f7;border-top:1px dashed #efefef;height:1px;position:absolute;left:0;right:0}.now-line{z-index:10;background:#ea4335;height:2px;position:absolute;left:-1px;right:0}.now-dot{background:#ea4335;border-radius:50%;width:8px;height:8px;position:absolute;top:-4px;left:-4px}.event-block{cursor:default;z-index:5;border-left:3px solid;border-radius:6px;padding:3px 6px;font-size:.7rem;font-weight:500;transition:filter .1s;position:absolute;left:3px;right:3px;overflow:hidden}.event-block:hover{filter:brightness(.95)}.event-label{white-space:nowrap;text-overflow:ellipsis;line-height:1.3;overflow:hidden}.event-time{opacity:.7;margin-top:1px;font-family:DM Mono,monospace;font-size:.62rem}.status{color:#aaa;justify-content:center;align-items:center;gap:10px;height:200px;font-size:.85rem;display:flex}.spinner{border:2px solid #e0e0e0;border-top-color:#4285f4;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.footer{text-align:center;color:#ccc;margin-top:20px;font-size:.72rem}.day-header-num{cursor:pointer;text-align:center;border-radius:50%;width:34px;height:34px;margin:2px auto 0;line-height:34px;transition:background .15s;display:inline-block}.day-header-num:hover{background:#f0f0f0}.day-header-num.today-num{color:#fff;background:#4285f4;font-size:1rem;font-weight:500}.day-header-num.today-num:hover{background:#3367d6}.popup-overlay{z-index:100;background:#00000040;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.popup{background:#fff;border-radius:16px;width:100%;max-width:340px;overflow:hidden;box-shadow:0 8px 40px #00000026}.popup-header{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:flex-start;padding:20px 20px 16px;display:flex}.popup-title{color:#111;font-size:1rem;font-weight:600}.popup-subtitle{color:#aaa;margin-top:2px;font-size:.75rem}.popup-close{color:#aaa;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:2px 6px;font-size:.85rem;transition:background .1s}.popup-close:hover{color:#555;background:#f0f0f0}.popup-body{flex-direction:column;gap:8px;padding:12px 20px 20px;display:flex}.popup-empty{color:#aaa;text-align:center;padding:16px 0;font-size:.85rem}.popup-slot{background:#f7f8fc;border-left:3px solid #34a853;border-radius:10px;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.popup-slot-time{color:#222;font-family:DM Mono,monospace;font-size:.88rem;font-weight:500}.popup-slot-dur{color:#aaa;font-size:.75rem;font-weight:400}
