:root{--color-bg: #f8fafc;--color-surface: #ffffff;--color-text: #0f172a;--color-text-muted: #64748b;--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-border: #e2e8f0;--color-weekend: #f1f5f9;--color-holiday: #fee2e2;--color-holiday-text: #ef4444;--font-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased}button{cursor:pointer;font-family:inherit}.calendar-year-view{display:flex;flex-direction:column;gap:0;padding:var(--spacing-md);max-width:100%}.calendar-month{display:flex;background:var(--color-surface);border-left:1px solid var(--color-border);border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);padding:0}.calendar-month:first-child{border-top:1px solid var(--color-border);border-top-left-radius:8px;border-top-right-radius:8px}.calendar-month:last-child{border-bottom-left-radius:8px;border-bottom-right-radius:8px}.month-sidebar{width:40px;background-color:#f8fafc;border-right:1px solid var(--color-border);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:var(--spacing-sm) 0;flex-shrink:0}.month-label{writing-mode:vertical-lr;transform:rotate(180deg);font-weight:700;font-size:1rem;color:var(--color-primary);text-transform:uppercase;letter-spacing:1px}.year-label{writing-mode:vertical-lr;transform:rotate(180deg);font-size:.75rem;color:var(--color-text-muted);margin-top:var(--spacing-xs)}.month-content{flex:1;display:flex;flex-direction:column}.month-header{display:none}.week-days-header{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;font-size:.875rem;color:var(--color-text-muted);padding:var(--spacing-xs) 0;background-color:#f8fafc;border-bottom:1px solid var(--color-border)}.month-grid-weeks{display:flex;flex-direction:column;gap:1px;background-color:var(--color-border);border:none}.week-row{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}.week-row.elapsed-week .day-cell{background-color:#f1f5f9;color:#94a3b8;opacity:.8}.day-cell{background-color:var(--color-surface);min-height:60px;padding:var(--spacing-xs);font-size:.875rem;position:relative;display:flex;flex-direction:column;cursor:pointer;transition:background-color .2s}.day-cell:hover{background-color:#f8fafc}.day-cell.weekend{background-color:var(--color-weekend)}.day-cell.other-month{background-color:#f8fafc;color:#cbd5e1}.day-cell.today{background-color:#eff6ff}.day-cell.droppable-over{background-color:#f0fdf4;outline:2px dashed #22c55e;z-index:2}.day-number{font-weight:500;margin-bottom:var(--spacing-xs)}.day-name-mobile{display:none}.day-cell.today .day-number{color:var(--color-primary);font-weight:700}.day-events{display:flex;flex-direction:column;gap:2px;flex:1}.event-label{font-size:.7rem;padding:2px 4px;border-radius:4px;white-space:normal;word-break:break-word;cursor:pointer;display:flex;align-items:center;gap:4px;transition:transform .1s}.event-label:hover{transform:scale(1.02);z-index:1}.event-icon{font-size:.8rem}@media(max-width:768px){.calendar-year-view{padding:var(--spacing-sm)}.calendar-month{flex-direction:column}.month-sidebar{width:100%;flex-direction:row;height:auto;padding:var(--spacing-xs);gap:var(--spacing-sm);border-right:none;border-bottom:1px solid var(--color-border)}.month-label,.year-label{writing-mode:horizontal-tb;transform:none;margin:0}.week-days-header{display:none}.week-row{display:flex;flex-direction:column;gap:1px}.day-cell.other-month{display:none}.day-cell{min-height:auto;padding:var(--spacing-sm);flex-direction:row;align-items:flex-start;gap:var(--spacing-md)}.day-number{margin-bottom:0;min-width:60px;font-size:.9rem}.day-name-mobile{display:inline;margin-right:4px;color:var(--color-text-muted)}.day-events{flex-direction:column;gap:4px}.event-label{font-size:.8rem;padding:4px 8px;white-space:normal}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-card{background:#fff;border-radius:12px;padding:40px;box-shadow:0 20px 60px #0000004d;max-width:420px;width:100%}.auth-title{text-align:center;font-size:32px;font-weight:700;margin-bottom:8px;color:#1a202c}.auth-subtitle{text-align:center;font-size:18px;font-weight:400;color:#718096;margin-bottom:32px}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:500;font-size:14px;color:#2d3748}.form-group input{padding:12px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:16px;transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f7fafc;cursor:not-allowed}.error-message{padding:12px;background-color:#fed7d7;color:#c53030;border-radius:8px;font-size:14px;text-align:center}.auth-button{padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:8px}.auth-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.auth-button:active:not(:disabled){transform:translateY(0)}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-toggle{text-align:center;margin-top:24px;font-size:14px;color:#718096}.toggle-button{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;text-decoration:underline;padding:0;font-size:14px}.toggle-button:hover:not(:disabled){color:#764ba2}.toggle-button:disabled{opacity:.6;cursor:not-allowed}
