*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#fff;color:#333}.calendar{padding:20px;min-width:1200px;margin:0 auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow-x:auto}.calendar-grid{display:grid;grid-template-columns:repeat(6,minmax(180px,1fr));gap:0;border-top:1px solid #000;border-left:1px solid #000}.month-column{border-right:1px solid #000;border-bottom:1px solid #000}.month-header{font-weight:400;font-size:13px;padding:6px 8px;background:#fff;text-align:center;border-bottom:1px solid #000}.month-days{display:flex;flex-direction:column}.day-row{display:flex;align-items:flex-start;padding:2px 6px;min-height:18px;font-size:12px;position:relative;background:#fff;cursor:pointer;overflow:hidden}.day-row:hover{background-color:#f5f5f5}.day-row.odd-week:hover{background-color:#ddd}.day-row.odd-week{background-color:#e8e8e8}.day-row.today{background-color:#fff3cd;border-left:3px solid #ffc107}.day-row.today.odd-week{background-color:#fff3cd}.day-row.today:hover{background-color:#ffecb3}.day-weekday{width:12px;flex-shrink:0;color:#000;font-size:11px}.day-number{width:18px;flex-shrink:0;text-align:right;margin-right:6px;color:#000}.day-events{flex:1;min-width:0;display:flex;flex-direction:column;align-items:stretch;gap:1px;font-size:11px}.week-number{position:absolute;right:4px;font-size:10px;color:#000;font-weight:400}.event-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.event-dot.lecture{background-color:var(--course-color, #4CAF50)}.event-dot.deliverable{background-color:transparent;border:2px solid var(--course-color, #d32f2f)}.event-dot.exam{background-color:var(--course-color, #1976d2)}.event-dot.presentation{background-color:transparent;border:2px solid var(--course-color, #4CAF50)}.event-item{display:flex;align-items:center;gap:3px;cursor:pointer;padding:1px 3px;border-radius:2px;min-width:0}.event-item:hover{background:#00000014}.event-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.event-item:hover .event-label{overflow:visible;position:absolute;left:14px;z-index:10;background:#fff;padding:1px 4px;box-shadow:2px 2px 4px #0000001a;border-radius:2px}.event-item{position:relative}.event-item.has-notes .event-label{text-decoration:underline;text-decoration-style:dotted}.course-filter{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid #ccc;font-size:13px}.filter-label{font-weight:500;color:#666}.filter-items{display:flex;flex-wrap:wrap;gap:16px}.filter-item{display:flex;align-items:center;gap:6px;cursor:grab;-webkit-user-select:none;user-select:none}.filter-item.dragging{opacity:.5}.drag-handle{color:#999;font-size:10px;cursor:grab;letter-spacing:-2px}.drag-handle:active{cursor:grabbing}.filter-item input[type=checkbox]{cursor:pointer}.color-dot{width:10px;height:10px;border-radius:50%}.course-name{color:#333;cursor:pointer}.course-name:hover{text-decoration:underline}.add-course-btn{background:none;border:1px dashed #999;padding:4px 10px;border-radius:4px;font-size:12px;cursor:pointer;color:#666}.add-course-btn:hover{border-color:#666;color:#333}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:24px;border-radius:8px;width:100%;max-width:400px;box-shadow:0 4px 20px #00000026}.modal-content h3{margin:0 0 20px;font-size:18px;font-weight:500}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:13px;color:#666}.form-group input,.form-group select,.form-group textarea{width:100%;padding:8px 12px;border:1px solid #ccc;border-radius:4px;font-size:14px;font-family:inherit;box-sizing:border-box}.form-group textarea{resize:vertical;min-height:60px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#666}.modal-actions{display:flex;justify-content:space-between;align-items:center;margin-top:24px;gap:12px}.right-actions{display:flex;gap:8px;margin-left:auto}.modal-actions button{padding:8px 16px;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer;font-size:13px;font-family:inherit}.modal-actions button:hover{background:#f5f5f5}.modal-actions .save-btn{background:#333;color:#fff;border-color:#333}.modal-actions .save-btn:hover{background:#444}.modal-actions .delete-btn{color:#d32f2f;border-color:#d32f2f}.modal-actions .delete-btn:hover{background:#fef2f2}.color-picker{display:flex;gap:8px;flex-wrap:wrap}.color-option{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:#333}
