*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:#121212;color:#e0e0e0}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px;text-align:center;background-color:#121212}.login-container h1{font-size:2.5rem;margin-bottom:1rem;color:#8ab4f8}.login-container p{color:#9aa0a6;margin-bottom:2rem;max-width:300px}.login-button{background-color:#8ab4f8;color:#121212;border:none;padding:12px 24px;font-size:1rem;border-radius:4px;cursor:pointer;transition:background-color .2s;font-weight:500}.login-button:hover{background-color:#aecbfa}.login-button:disabled{background-color:#3c4043;color:#5f6368;cursor:not-allowed}.calendar-container{height:100vh;display:flex;flex-direction:column;background-color:#121212}.calendar-header{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background-color:#1e1e1e;border-bottom:1px solid #333;flex-shrink:0}.calendar-header h1{font-size:1.5rem;color:#8ab4f8}.logout-button{background:none;border:1px solid #5f6368;padding:8px 16px;border-radius:4px;cursor:pointer;color:#e0e0e0;font-size:.875rem;transition:background-color .2s}.logout-button:hover{background-color:#2d2d2d}.weekday-header{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));background-color:#1e1e1e;border-bottom:1px solid #333;position:sticky;top:0;z-index:50}.weekday{padding:10px 8px;text-align:center;font-size:.75rem;font-weight:600;color:#9aa0a6;text-transform:uppercase;letter-spacing:.5px}.infinite-scroll-container{flex:1;overflow-y:auto;overflow-x:hidden;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.continuous-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr))}.month-section,.month-grid{display:contents}.calendar-day.first-of-month:before{content:attr(data-month);position:absolute;top:calc(var(--num-rows, 5) * 200px / 2 - 9vw);left:0;right:0;margin-left:calc(-100% * (var(--col, 1) - 1));width:700%;text-align:center;font-size:18vw;font-weight:800;color:#ffffff08;text-transform:uppercase;letter-spacing:-.02em;pointer-events:none;white-space:nowrap;-webkit-user-select:none;user-select:none;line-height:1;z-index:0}.days-grid{display:contents}.calendar-day{position:relative;min-height:200px;border:1px solid #2d2d2d;margin-top:-1px;margin-left:-1px;padding:8px;cursor:pointer;transition:background-color .15s;background-color:transparent}.calendar-day:not(.first-of-month){overflow:hidden}.calendar-day:hover{background-color:#ffffff0d}.calendar-day.other-month{background-color:transparent}.calendar-day.other-month .day-number{color:#5f6368}.calendar-day.today .day-number{background-color:#8ab4f8;color:#121212;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-weight:600}.day-number{font-size:.9rem;font-weight:500;margin-bottom:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:#e0e0e0}.day-events{display:flex;flex-direction:column;gap:4px;max-height:140px;overflow:hidden}.event-item{font-size:.75rem;padding:4px 6px;border-radius:4px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:4px;cursor:pointer;transition:opacity .15s}.event-item:hover{opacity:.85}.event-item.all-day{background-color:#8ab4f8;color:#121212}.event-time{font-weight:500;flex-shrink:0}.event-title{overflow:hidden;text-overflow:ellipsis}.more-events{font-size:.75rem;color:#8ab4f8;padding:4px 6px;font-weight:500}.loading-overlay{position:absolute;inset:0;background-color:#121212cc;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:10}.loading-spinner{width:32px;height:32px;border:3px solid #3c4043;border-top-color:#8ab4f8;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background-color:#2d2d2d;border-radius:8px;padding:24px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000080}.modal-content h2{margin-bottom:20px;font-size:1.25rem;color:#e0e0e0}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:4px;font-size:.875rem;font-weight:500;color:#9aa0a6}.form-group input,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #5f6368;border-radius:4px;font-size:1rem;transition:border-color .2s;background-color:#1e1e1e;color:#e0e0e0}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#8ab4f8}.form-group textarea{resize:vertical;font-family:inherit}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-error{color:#f28b82;font-size:.875rem;margin-bottom:16px;padding:8px 12px;background-color:#f28b821a;border-radius:4px}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.form-actions button{padding:10px 20px;border-radius:4px;font-size:.875rem;cursor:pointer;transition:background-color .2s}.form-actions button:not(.primary){background:none;border:1px solid #5f6368;color:#e0e0e0}.form-actions button:not(.primary):hover{background-color:#3c4043}.form-actions button.primary{background-color:#8ab4f8;border:none;color:#121212;font-weight:500}.form-actions button.primary:hover{background-color:#aecbfa}.form-actions button:disabled{opacity:.6;cursor:not-allowed}.form-actions button.danger{background-color:#d93025;border:none;color:#fff;margin-right:auto}.form-actions button.danger:hover{background-color:#c5221f}.error-message{color:#f28b82;padding:20px;text-align:center}@media(max-width:768px){.calendar-header{padding:8px 12px}.calendar-header h1{font-size:1.2rem}.weekday{padding:6px 2px;font-size:.6rem;letter-spacing:0}.calendar-day{min-height:80px;padding:4px}.day-number{font-size:.7rem;width:20px;height:20px;margin-bottom:4px}.calendar-day.today .day-number{width:20px;height:20px}.day-events{gap:2px;max-height:50px}.event-item{font-size:.5rem;padding:2px 3px;border-radius:2px}.event-time{display:none}.more-events{font-size:.5rem;padding:2px 3px}.form-row{grid-template-columns:1fr}.calendar-day.first-of-month:before{font-size:14vw;top:calc(var(--num-rows, 5) * 80px / 2 - 7vw)}.modal-content{padding:16px}.logout-button{padding:6px 12px;font-size:.75rem}}
