*{margin:0;padding:0;box-sizing:border-box}:root{--nav-height: 52px;--gutter-width: 48px;--hour-height: 60px;--discord-top: 0px}.cal-app{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;color:#e0e0e0;background:#2b2d31;height:100vh;display:flex;flex-direction:column;overflow:hidden;padding-top:var(--discord-top)}.cal-navbar{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;background:#1e1f22;border-top:1px solid #3a3c41;flex-shrink:0;min-height:var(--nav-height);gap:6px;z-index:20}.cal-navbar-left,.cal-navbar-right{display:flex;align-items:center;gap:4px}.cal-week-label{font-size:13px;font-weight:500;color:#f2f3f5;white-space:nowrap;text-align:center}.cal-btn{border:none;cursor:pointer;border-radius:6px;font-size:13px;transition:background .15s;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.cal-btn-today{padding:6px 10px;background:#4752c4;color:#fff;font-size:12px;font-weight:500}.cal-btn-today:hover,.cal-btn-today:active{background:#5865f2}.cal-btn-nav{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#3a3c41;color:#e0e0e0;font-size:14px;flex-shrink:0;touch-action:manipulation}.cal-btn-nav:hover,.cal-btn-nav:active{background:#4e5058}.cal-btn-add{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#248046;color:#fff;font-weight:700;font-size:18px;flex-shrink:0}.cal-btn-add:hover,.cal-btn-add:active{background:#2d9154}.cal-btn-submit{width:100%;padding:12px;background:#4752c4;color:#fff;font-weight:500;font-size:14px;margin-top:8px}.cal-btn-submit:hover{background:#5865f2}.cal-btn-submit:disabled{opacity:.6;cursor:not-allowed}.cal-grid-container{flex:1;overflow:auto;position:relative;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.cal-grid-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000004d;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;z-index:10}.cal-grid{display:flex;flex-direction:column;min-height:100%}.cal-grid-header{display:grid;grid-template-columns:var(--gutter-width) repeat(7,1fr);border-bottom:1px solid #3a3c41;position:sticky;top:0;background:#1e1f22;z-index:5}.cal-time-gutter{width:var(--gutter-width);flex-shrink:0}.cal-day-header{display:flex;flex-direction:column;align-items:center;padding:6px 0;font-size:12px;min-width:0}.cal-day-name{text-transform:uppercase;color:#999;font-size:10px;letter-spacing:.3px}.cal-day-number{font-size:16px;font-weight:500;color:#e0e0e0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%}.cal-today .cal-day-name{color:#5865f2}.cal-today-badge{background:#5865f2!important;color:#fff!important}.cal-grid-body{display:grid;grid-template-columns:var(--gutter-width) repeat(7,1fr);flex:1}.cal-grid-body>.cal-time-gutter{border-right:1px solid #3a3c41}.cal-time-slot{height:var(--hour-height);display:flex;align-items:flex-start;justify-content:flex-end;padding:0 4px}.cal-time-label{font-size:9px;color:#777;transform:translateY(-5px);white-space:nowrap}.cal-day-column{position:relative;border-right:1px solid rgba(47,49,54,.6);min-width:0}.cal-hour-line{height:var(--hour-height);border-bottom:1px solid rgba(47,49,54,.6)}.cal-event{position:absolute;left:1px;right:1px;border-radius:3px;padding:2px 4px;overflow:hidden;cursor:pointer;font-size:10px;line-height:1.2;z-index:2;transition:filter .15s}.cal-event:hover{filter:brightness(1.15)}.cal-event-allday{position:relative;margin:1px;top:auto;height:auto}.cal-event-time{display:block;font-weight:600;font-size:9px;opacity:.9}.cal-event-title{display:block;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-event-desc{display:block;font-size:9px;opacity:.8;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:normal;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;line-height:1.3}.cal-detail{background:#2b2d31;border:1px solid #3a3c41;border-radius:12px 12px 0 0;width:100%;max-width:480px;box-shadow:0 -4px 32px #0006;animation:slideUp .2s ease-out}.cal-detail-header{display:flex;align-items:flex-start;gap:12px;padding:16px}.cal-detail-color{width:6px;min-height:40px;border-radius:3px;flex-shrink:0;margin-top:2px}.cal-detail-info{flex:1;min-width:0}.cal-detail-title{font-size:18px;font-weight:600;color:#f2f3f5;margin-bottom:4px;word-break:break-word}.cal-detail-date{font-size:13px;color:#b5bac1;text-transform:capitalize}.cal-detail-time{font-size:13px;color:#999;margin-top:2px}.cal-detail-close{flex-shrink:0}.cal-detail-body{padding:12px 16px 16px;border-top:1px solid #3a3c41}.cal-detail-desc{font-size:14px;color:#b5bac1;line-height:1.5;white-space:pre-wrap;word-break:break-word}.cal-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:flex-end;justify-content:center;z-index:100}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.cal-modal{background:#2b2d31;border:1px solid #3a3c41;border-radius:12px 12px 0 0;width:100%;max-width:480px;max-height:85vh;overflow-y:auto;box-shadow:0 -4px 32px #0006;animation:slideUp .25s ease-out}.cal-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;border-bottom:1px solid #3a3c41;position:sticky;top:0;background:#2b2d31;z-index:1}.cal-modal-header h3{font-size:16px;font-weight:600;color:#f2f3f5}.cal-modal-error{margin:10px 16px 0;padding:8px 10px;background:#ed424526;border:1px solid rgba(237,66,69,.3);border-radius:4px;color:#ed4245;font-size:13px}.cal-modal-success{margin:10px 16px 0;padding:8px 10px;background:#24804626;border:1px solid rgba(36,128,70,.3);border-radius:4px;color:#2d9154;font-size:13px}.cal-modal-body{padding:16px;display:flex;flex-direction:column;gap:12px}.cal-field{display:flex;flex-direction:column;gap:4px}.cal-field span{font-size:11px;font-weight:600;text-transform:uppercase;color:#999}.cal-field input,.cal-field textarea{background:#1e1f22;border:1px solid #3a3c41;border-radius:6px;padding:10px 12px;color:#e0e0e0;font-size:16px;font-family:inherit;outline:none;transition:border-color .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.cal-field input:focus,.cal-field textarea:focus{border-color:#5865f2}.cal-field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.cal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px;color:#999}.cal-spinner{width:32px;height:32px;border:3px solid #3a3c41;border-top-color:#5865f2;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.cal-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:8px;color:#ed4245;padding:20px;text-align:center}.cal-error-detail{color:#999;font-size:13px}@media(max-width:600px){:root{--gutter-width: 36px;--hour-height: 50px;--nav-height: 56px;--discord-top: 50px}.cal-navbar{padding:8px 10px;min-height:56px}.cal-week-label{font-size:13px}.cal-btn-today{padding:8px 14px;font-size:13px}.cal-btn-nav{width:40px;height:40px;font-size:16px}.cal-btn-add{width:40px;height:40px;font-size:20px}.cal-day-name{font-size:9px}.cal-day-number{font-size:13px;width:24px;height:24px}.cal-time-label{font-size:8px}.cal-event{font-size:8px;padding:1px 2px;border-radius:2px}.cal-event-time{display:none}.cal-event-title{font-size:8px}.cal-event-desc{font-size:7px;-webkit-line-clamp:2}.cal-detail-title{font-size:16px}}@media(max-width:400px){:root{--gutter-width: 28px;--hour-height: 44px;--discord-top: 50px}.cal-btn-today{font-size:9px;padding:3px 6px}.cal-btn-nav{width:28px;height:28px;font-size:11px}.cal-btn-add{width:28px;height:28px;font-size:14px}.cal-day-name{font-size:8px}.cal-day-number{font-size:11px;width:20px;height:20px}}@media(min-width:800px){:root{--gutter-width: 60px;--hour-height: 60px;--discord-top: 0px}.cal-week-label{font-size:15px}.cal-day-name{font-size:11px}.cal-day-number{font-size:20px;width:36px;height:36px}.cal-time-label{font-size:10px}.cal-event{font-size:11px;padding:4px 6px}.cal-event-time{font-size:10px}.cal-modal-overlay{align-items:center}.cal-modal,.cal-detail{border-radius:12px;max-width:420px}}.cal-detail-actions{display:flex;gap:8px;padding:12px 16px 16px}.cal-btn-delete{flex:1;padding:10px;background:#3a3c41;color:#ed4245;font-size:13px;font-weight:500;border:1px solid transparent}.cal-btn-delete:hover,.cal-btn-delete:active{background:#ed424526;border-color:#ed42454d}.cal-btn-delete-confirm{background:#ed4245;color:#fff}.cal-btn-delete-confirm:hover,.cal-btn-delete-confirm:active{background:#d63638;border-color:transparent}.cal-btn-delete:disabled{opacity:.6;cursor:not-allowed}.cal-btn-cancel{padding:10px 16px;background:#3a3c41;color:#e0e0e0;font-size:13px}.cal-btn-cancel:hover,.cal-btn-cancel:active{background:#4e5058}
