:root{--bg-gradient-from:#ebd6ff;--bg-gradient-to:#cab0e8;--accent:#4b335e;--accent-soft:#f3ecf8;--accent-strong:#5a4070;--accent-text:#4b335e}.calendar{max-width:1025px;max-height:calc(100vh - 4rem);margin:2rem auto;padding:2rem;background:white;border-radius:16px;box-shadow:0 4px 24px rgba(75,51,94,.12);overflow-x:hidden;overflow-y:auto;display:flex;flex-direction:column}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.calendar-title{font-family:Lexend Exa,sans-serif;font-size:1.8rem;text-transform:lowercase}.calendar-nav-btn,.calendar-title{font-weight:700;color:var(--accent)}.calendar-nav-btn{width:40px;height:40px;border-radius:50%;border:none;background:var(--accent-soft);font-size:1.4rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.calendar-nav-btn:hover{background:var(--accent);color:white}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-gap:4px;gap:4px}.calendar-weekday{font-family:Lexend Exa,sans-serif;font-size:.75rem;font-weight:600;color:var(--bg-gradient-to);text-transform:uppercase;letter-spacing:.5px;padding:.5rem 0;text-align:center}.calendar-day{min-height:110px;padding:6px 8px;border-radius:10px;background:var(--accent-soft);border:1.5px solid transparent;text-align:left;transition:all .15s ease;display:flex;flex-direction:column;overflow:hidden;min-width:0}.calendar-day:hover{background:var(--accent-soft);border-color:var(--bg-gradient-from)}.calendar-day.empty{border:none;min-height:0}.calendar-day.empty,.calendar-day.empty:hover{background:transparent}.calendar-day.today{border-color:var(--accent);background:var(--accent-soft)}.calendar-day.today .day-number{background:var(--accent);color:white}.day-number{font-family:Lexend Exa,sans-serif;font-size:.8rem;font-weight:600;color:var(--accent);width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;margin-bottom:4px;flex-shrink:0}.day-assignments{display:flex;flex-direction:column;gap:2px;overflow:hidden;flex:1 1}.calAssignment{color:white;font-family:Fredoka,sans-serif;font-size:.65rem;font-weight:500;padding:3px 6px;border-radius:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;min-width:0;cursor:pointer;transition:opacity .15s ease,transform .15s ease}.calAssignment:hover{opacity:.85}@media (max-width:600px){.calendar{padding:1rem;margin:1rem}.calendar-title{font-size:1.3rem}.calendar-day{min-height:60px;padding:4px}.day-number{font-size:.7rem;width:22px;height:22px}.calAssignment{font-size:.55rem;padding:2px 3px}}