.calendar-page{flex:1;padding:1rem}body .nav-top{padding:0.3rem 0}.calendar-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.year-nav-btn{display:inline-flex;align-items:center;gap:1rem;background-color:var(--bg-secondary);border:2px solid var(--border);border-radius:8px;padding:1rem 1.5rem;color:var(--link);text-decoration:none;font-size:1.2rem;font-weight:600;transition:all 0.3s ease;box-shadow:0 2px 4px var(--shadow)}.year-nav-btn:hover{background-color:var(--bg-tertiary);border-color:var(--link);transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow)}.year-nav-btn img{max-width:80px;height:auto;display:block}.year-nav-btn span{color:var(--text-primary);font-size:1.5rem}.prev-year-link{text-align:center;margin-top:1rem;margin-bottom:2rem}.next-year-link{text-align:center;margin-top:3rem;margin-bottom:2rem}.shift-legend{display:flex;justify-content:center;flex-wrap:wrap;gap:0.75rem;margin-bottom:0;padding:0.75rem;background-color:var(--bg-secondary);border-radius:4px}.legend-item{display:flex;align-items:center;gap:0.5rem;font-size:0.95rem}.legend-color{width:20px;height:20px;border-radius:50%;border:1px solid var(--border)}.calendar-container{max-width:1200px;margin:0 auto}.month{margin-bottom:2rem}.month-title{font-size:1.25rem;font-weight:600;color:var(--accent);margin-bottom:0.75rem;text-align:center}.calendar-grid{display:grid;grid-template-columns:auto repeat(7,1fr);gap:2px;background-color:#111;border:1px solid #111}.week-label{background-color:#111;padding:0.5rem;text-align:center;font-weight:600;font-size:0.75rem;color:var(--text-muted);display:flex;align-items:center;justify-content:center}.day-header{background-color:var(--bg-secondary);padding:0.5rem;text-align:center;font-weight:600;font-size:0.8rem;color:var(--text-secondary)}.day-cell{background-color:var(--calendar-cell);min-height:60px;padding:0.5rem;position:relative;cursor:pointer;transition:all 0.2s ease;display:flex;flex-direction:column}.day-cell:hover{transform:scale(1.02);z-index:10}.day-cell:focus{outline:2px solid var(--link);outline-offset:2px;z-index:11}.day-cell.empty{background-color:#111;cursor:default}.day-cell.empty:hover{transform:none}.day-cell.today{border:2px solid var(--accent);box-shadow:0 0 8px rgba(74,158,255,0.3);border-radius:4px 4px 4px 16px}.day-number{font-weight:700;font-size:1.5rem;margin-bottom:0.25rem;color:#111}.note-indicator{position:absolute;bottom:0.25rem;right:0.25rem;font-size:0.8rem;color:#111}.shift-night{background-color:var(--shift-night)}.shift-afternoon{background-color:var(--shift-afternoon)}.shift-morning{background-color:var(--shift-morning)}.shift-free{background-color:var(--shift-free)}.shift-holiday{background-color:var(--shift-holiday)}.modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,0.7);z-index:1000;align-items:center;justify-content:center;padding:1rem}.modal.show{display:flex}.modal-content{background-color:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:1.5rem;max-width:400px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{margin-bottom:1rem}.modal-header h2{color:var(--accent);margin-bottom:0;font-size:1.1rem}.modal-body{margin-bottom:1rem}.form-group{margin-bottom:1rem}.form-label{display:block;margin-bottom:0.5rem;font-weight:600;color:var(--text-primary)}.color-picker{display:grid;grid-template-columns:repeat(4,1fr);gap:0.5rem}.color-option{aspect-ratio:1;border:2px solid var(--border);border-radius:4px;cursor:pointer;transition:all 0.2s ease;min-width:36px;min-height:36px}.color-option:hover{transform:scale(1.1);border-color:var(--link)}.color-option.selected{border-color:var(--link);border-width:3px;box-shadow:0 0 8px var(--link)}.note-textarea{width:100%;min-height:70px;padding:0.5rem;background-color:var(--bg-tertiary);border:1px solid var(--border);border-radius:4px;color:var(--text-primary);font-family:inherit;font-size:0.9rem;resize:vertical}.note-textarea:focus{outline:none;border-color:var(--link)}.char-count{text-align:right;font-size:0.8rem;color:var(--text-muted);margin-top:0.25rem}.modal-footer{display:flex;gap:0.5rem;justify-content:flex-end;flex-wrap:wrap}.btn-primary{background-color:var(--link);color:#111;border:none}.btn-primary:hover{background-color:var(--link-hover)}.btn-secondary{background-color:var(--bg-tertiary)}@media (max-width:767px){body .nav-top{padding:0.3rem 0}.shift-legend{justify-content:center;gap:0.4rem;padding:0.5rem;margin-bottom:0}.legend-item{font-size:0.85rem}.legend-color{width:16px;height:16px}.calendar-grid{gap:1px}.day-cell{min-height:50px;padding:0.25rem}.day-number{font-size:1rem}.week-label{font-size:0.65rem;padding:0.25rem}.year-nav-btn{gap:0.75rem;padding:0.75rem 1rem;font-size:1rem}.year-nav-btn img{max-width:60px}.year-nav-btn span{font-size:1.2rem}.color-picker{grid-template-columns:repeat(4,1fr);gap:0.4rem}.color-option{min-width:32px;min-height:32px}.modal-content{padding:1rem;max-width:90%}.note-indicator{font-size:0.6rem}}@media (min-width:768px){.day-cell{min-height:80px}.calendar-grid{gap:3px}}