.dashboard-container{padding:30px;max-width:1400px;margin:0 auto;min-height:calc(100vh - 100px)}.dashboard-header{margin-bottom:40px}.dashboard-header h1{font-size:32px;font-weight:700;color:#1e293b;margin:0 0 8px}.dashboard-header p{font-size:16px;color:#64748b;margin:0}.dashboard-loading{text-align:center;padding:60px 20px;color:#64748b;font-size:18px}.dashboard-content{display:flex;flex-direction:column;gap:30px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}.stat-card{background:#fff;border-radius:16px;padding:24px;display:flex;align-items:flex-start;gap:20px;cursor:pointer;transition:all .3s ease;box-shadow:0 1px 3px #0000001a;border:1px solid #f1f5f9;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);opacity:0;transition:opacity .3s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #00000026}.stat-card:hover:before{opacity:1}.stat-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff;flex-shrink:0;box-shadow:0 4px 12px #00000026}.stat-card-clients .stat-icon{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-card-caregivers .stat-icon{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-card-careplans .stat-icon{background:linear-gradient(135deg,#4facfe,#00f2fe)}.stat-card-visits .stat-icon{background:linear-gradient(135deg,#43e97b,#38f9d7)}.stat-card-family .stat-icon{background:linear-gradient(135deg,#fa709a,#fee140)}.stat-content{flex:1}.stat-label{font-size:14px;font-weight:500;color:#64748b;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:36px;font-weight:700;color:#1e293b;line-height:1;margin-bottom:12px}.stat-detail{display:flex;align-items:center;gap:8px}.stat-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:600;background:#f1f5f9;color:#64748b}.stat-badge.active{background:#d1fae5;color:#065f46}.visit-stats-section{background:#fff;border-radius:16px;padding:30px;box-shadow:0 1px 3px #0000001a;border:1px solid #f1f5f9}.visit-stats-section h2{font-size:24px;font-weight:700;color:#1e293b;margin:0 0 24px}.visit-stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.visit-stat-card{background:linear-gradient(135deg,#f6f8fb,#fff);border-radius:12px;padding:24px;border:2px solid #e2e8f0;transition:all .3s ease}.visit-stat-card:hover{border-color:#cbd5e1;transform:translateY(-2px)}.visit-stat-label{font-size:14px;font-weight:500;color:#64748b;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.visit-stat-value{font-size:32px;font-weight:700;color:#3b82f6}.visit-stat-value.completed{color:#10b981}@media (max-width: 768px){.dashboard-container{padding:20px}.dashboard-header h1{font-size:24px}.dashboard-header p{font-size:14px}.stats-grid{grid-template-columns:1fr;gap:16px}.stat-card{padding:20px}.stat-value{font-size:28px}.visit-stats-cards{grid-template-columns:1fr}}.client-form-page{padding:30px;max-width:1000px;margin:0 auto}.client-form{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:30px}.client-form-page.read-only .client-form{box-shadow:none;border:1px solid #e1e4e8}.client-form-page.read-only .form-group input,.client-form-page.read-only .form-group select,.client-form-page.read-only .form-group textarea{background-color:#f9fafb;border-color:transparent;pointer-events:none;box-shadow:none}.client-form-page.read-only .form-group input:focus,.client-form-page.read-only .form-group select:focus,.client-form-page.read-only .form-group textarea:focus{border-color:transparent;box-shadow:none}.client-form-page.read-only .photo-preview{width:96px;height:96px;font-size:13px}.caregiver-list{padding:30px;max-width:1400px;margin:0 auto}.page-header h1{margin:0 0 5px;color:#2c3e50;font-size:32px}.page-header p{margin:0;color:#7f8c8d;font-size:14px}.btn-primary{background:#10b981;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .3s;text-transform:uppercase}.btn-primary:hover{background:#059669}.filters{display:flex;gap:15px;margin-bottom:25px;flex-wrap:wrap}.search-form{display:flex;gap:10px;flex:1;min-width:300px}.search-input{flex:1;padding:10px 15px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;height:42px;transition:all .3s ease}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.btn-search{background:#10b981;color:#fff;border:none;width:42px;height:42px;border-radius:8px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;font-size:16px}.btn-search:hover{background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.filter-select{padding:10px 15px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;height:42px;background:#fff;cursor:pointer;transition:all .3s ease}.filter-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.caregiver-table{width:100%;border-collapse:collapse}.caregiver-table thead{background:#f8f9fa}.caregiver-table th{padding:15px;text-align:left;font-weight:600;color:#2c3e50;font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e9ecef}.caregiver-table td{padding:15px;border-bottom:1px solid #f1f3f5;font-size:14px;color:#495057}.caregiver-table tbody tr:hover{background:#f8f9fa}.caregiver-name strong{display:block;color:#2c3e50;margin-bottom:3px}.caregiver-name small{color:#7f8c8d;font-size:12px}.contact-info div{font-size:13px;line-height:1.5}.skills-list{display:flex;flex-wrap:wrap;gap:5px}.skill-badge{display:inline-block;padding:3px 10px;background:#e7f3ff;color:#06c;border-radius:10px;font-size:11px;font-weight:600}.no-skills{color:#adb5bd;font-size:13px;font-style:italic}.rating-stars{display:flex;gap:2px}.star-filled{color:#ffc107;font-size:16px}.star-empty{color:#dee2e6;font-size:16px}.no-rating{color:#adb5bd;font-size:13px;font-style:italic}.status-active{background:#d4edda;color:#155724}.status-inactive{background:#f8d7da;color:#721c24}.status-leave{background:#fff3cd;color:#856404}.status-terminated{background:#d6d8db;color:#383d41}.visit-stats{font-weight:600;color:#495057}.action-buttons button{width:36px;height:36px;padding:0;border:none;border-radius:8px;font-size:14px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center}.btn-view{background:linear-gradient(135deg,#e7f3ff,#cce5ff);color:#06c;border:1px solid #b3d9ff}.btn-view:hover{background:linear-gradient(135deg,#06c,#0052a3);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #0066cc4d}.btn-delete{background:linear-gradient(135deg,#f8d7da,#f5c6cb);color:#721c24;border:1px solid #f1aeb5}.btn-delete:hover{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #dc35454d}.loading,.no-data{text-align:center;padding:40px;color:#7f8c8d;font-size:16px}.pagination{display:flex;justify-content:center;align-items:center;gap:20px;margin-top:20px}.btn-page{padding:8px 16px;border:1px solid #ddd;background:#fff;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s}.btn-page:hover:not(:disabled){background:#f8f9fa;border-color:#667eea}.page-info{color:#495057;font-size:14px}.caregiver-form-page{padding:30px;max-width:1000px;margin:0 auto}.form-header h1{margin:0;color:#2c3e50;font-size:32px}.btn-back{background:#ecf0f1;color:#2c3e50;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.btn-back:hover{background:#d5dbdb}.error-message{background:#f8d7da;color:#721c24;padding:15px;border-radius:8px;margin-bottom:20px;border:1px solid #f5c6cb}.error-message strong{display:block;margin-bottom:5px;font-size:16px}.error-message ul{margin:0;list-style:none;padding-left:0}.error-message ul li{padding:5px 0;font-size:14px}.error-message ul li strong{display:inline;color:#d63031;text-transform:capitalize;margin-right:5px}.form-group.has-error input,.form-group.has-error select,.form-group.has-error textarea{border-color:#dc3545;background-color:#fff5f5}.form-group.has-error label{color:#dc3545}.field-error{color:#dc3545;font-size:12px;margin-top:4px;display:block}.caregiver-form{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:30px}.form-section{margin-bottom:35px;padding-bottom:35px;border-bottom:1px solid #e9ecef}.form-section h2{margin:0 0 20px;color:#495057;font-size:20px;font-weight:600}.form-group label{margin-bottom:8px;color:#495057;font-size:14px;font-weight:600}.form-group input,.form-group select,.form-group textarea{padding:10px 15px;border:1px solid #ced4da;border-radius:8px;font-size:14px;font-family:inherit;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;min-height:80px}.checkbox-group{justify-content:center}.checkbox-group label{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:400}.form-actions{display:flex;justify-content:flex-end;gap:15px;margin-top:30px;padding-top:25px;border-top:1px solid #e9ecef}.btn-cancel{background:#f8f9fa;color:#495057;border:1px solid #ced4da;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:#e9ecef}.btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 32px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.loading{text-align:center;padding:60px;color:#7f8c8d;font-size:18px}.photo-row{display:flex;align-items:center;gap:16px}.photo-preview{width:72px;height:72px;border-radius:50%;overflow:hidden;background:#ecf0f1;display:flex;align-items:center;justify-content:center;font-size:12px;color:#7f8c8d}.photo-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.photo-crop-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1300}.photo-crop-modal{background:#fff;border-radius:12px;padding:20px;width:90%;max-width:520px;box-shadow:0 10px 30px #00000040;display:flex;flex-direction:column;gap:16px}.photo-crop-modal h3{margin:0;font-size:18px;color:#2c3e50}.photo-crop-area{position:relative;width:100%;height:320px;background:#000;border-radius:10px;overflow:hidden}.photo-crop-controls{display:flex;align-items:center;justify-content:flex-end;gap:12px}.photo-crop-zoom{flex:1}.header-buttons{display:flex;gap:10px;align-items:center}.btn-edit{background:#667eea;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.btn-edit:hover{background:#5568d3}.caregiver-form-page.read-only .caregiver-form{box-shadow:none;border:1px solid #e1e4e8}.caregiver-form-page.read-only .form-group input,.caregiver-form-page.read-only .form-group select,.caregiver-form-page.read-only .form-group textarea{background-color:#f9fafb;border-color:transparent;pointer-events:none;box-shadow:none}.caregiver-form-page.read-only .form-group input:focus,.caregiver-form-page.read-only .form-group select:focus,.caregiver-form-page.read-only .form-group textarea:focus{border-color:transparent;box-shadow:none}.caregiver-form-page.read-only .photo-preview{width:96px;height:96px;font-size:13px}.care-plan-list{padding:30px;max-width:1400px;margin:0 auto}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.header h1{margin:0 0 5px;color:#2c3e50;font-size:32px}.header p{margin:0;color:#7f8c8d;font-size:14px}.filters{margin-bottom:25px}.filter-row{display:flex;gap:15px;flex-wrap:wrap;align-items:flex-end}.search-form{display:flex;gap:10px;flex:1;min-width:300px;max-width:500px}.search-input{flex:1;padding:10px 15px;border:1px solid #ddd;border-radius:8px;font-size:14px;height:42px}.btn-search{background:#10b981;color:#fff;border:none;padding:10px 15px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background .3s;height:42px;width:42px;display:flex;align-items:center;justify-content:center}.btn-search:hover{background:#059669}.filter-group{display:flex;flex-direction:column;gap:5px;min-width:180px}.filter-group label{font-size:13px;font-weight:500;color:#555}.filter-select{padding:10px 15px;border:1px solid #ddd;border-radius:8px;height:42px;font-size:14px;background:#fff;cursor:pointer;min-width:180px}.table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;margin-bottom:20px}.care-plan-table{width:100%;border-collapse:collapse}.care-plan-table thead{background:#f8f9fa}.care-plan-table th{padding:15px;text-align:left;font-weight:600;color:#2c3e50;font-size:14px;border-bottom:2px solid #e9ecef}.care-plan-table td{padding:15px;border-bottom:1px solid #e9ecef;font-size:14px;color:#495057}.care-plan-table tbody tr:hover{background:#f8f9fa}.no-data{text-align:center;color:#7f8c8d;padding:40px!important}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.status-draft{background:#e3f2fd;color:#1976d2;border:1px solid #90caf9}.status-active{background:#e8f5e9;color:#2e7d32;border:1px solid #66bb6a}.status-completed{background:#f3e5f5;color:#7b1fa2;border:1px solid #ba68c8}.status-cancelled{background:#ffebee;color:#c62828;border:1px solid #ef5350}.btn-action{padding:6px 12px;border:1px solid #ddd;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;background:#fff}.btn-view{color:#667eea;border-color:#667eea}.btn-view:hover{background:#667eea;color:#fff}.btn-edit{background:linear-gradient(135deg,#ede9fe,#ddd6fe);color:#6d28d9;border:1px solid #c4b5fd}.btn-edit:hover{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.btn-delete{color:#ef5350;border-color:#ef5350}.btn-delete:hover{background:#ef5350;color:#fff}.pagination-container{display:flex;justify-content:center;align-items:center;gap:20px;padding:20px;flex-direction:column}.pagination-info{color:#7f8c8d;font-size:14px;margin:0}.care-plan-form{padding:30px;max-width:1200px;margin:0 auto}.form-header h1{margin:0 0 5px;color:#2c3e50;font-size:32px}.form-header p{margin:0;color:#7f8c8d;font-size:14px}.btn-back{background:#95a5a6;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.btn-back:hover{background:#7f8c8d}.error-message{background:#fee;color:#c33;padding:15px;border-radius:8px;margin-bottom:20px;border:1px solid #fcc}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#7f8c8d}.spinner{border:3px solid #f3f3f3;border-top:3px solid #667eea;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin-bottom:15px}.form-section{background:#fff;padding:25px;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:25px}.form-section h2{margin:0 0 20px;color:#2c3e50;font-size:20px;border-bottom:2px solid #e9ecef;padding-bottom:10px}.form-section h3{margin:20px 0 10px;color:#34495e;font-size:16px}.form-group label{font-size:14px;font-weight:600;color:#2c3e50;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{padding:10px 15px;border:1px solid #ddd;border-radius:8px;font-size:14px;font-family:inherit;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:#f8f9fa;cursor:not-allowed}.array-input{display:flex;gap:10px;margin-bottom:15px}.array-input input{flex:1;padding:10px 15px;border:1px solid #ddd;border-radius:8px;font-size:14px}.btn-add-item{background:#3498db;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.btn-add-item:hover{background:#2980b9}.array-items{display:flex;flex-direction:column;gap:8px}.array-item{display:flex;justify-content:space-between;align-items:center;padding:10px 15px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.array-item span{flex:1;font-size:14px;color:#495057}.btn-remove{background:#ef5350;color:#fff;border:none;width:24px;height:24px;border-radius:50%;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.btn-remove:hover{background:#c62828}.no-items{color:#7f8c8d;font-size:14px;font-style:italic;margin:10px 0}.form-actions{display:flex;justify-content:flex-end;gap:15px;padding:20px 0}.btn-cancel{background:#95a5a6;color:#fff;border:none;padding:12px 30px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.btn-cancel:hover{background:#7f8c8d}.btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 30px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}@media (max-width: 768px){.form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:1}}.family-user-list-page{max-width:1400px;margin:0 auto}.page-header h1{font-size:32px;margin-bottom:8px}.page-header p{color:#666;font-size:14px}.filters-section{background:#fff;padding:20px;border-radius:12px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.search-form{display:flex;gap:12px;margin-bottom:16px}.search-input{flex:1;padding:10px 16px;border:1px solid #ddd;border-radius:8px;font-size:14px}.btn-search{padding:10px 24px;background:#059669;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500}.btn-search:hover{background:#047857}.filter-controls{display:flex;gap:12px;flex-wrap:wrap}.filter-select{padding:8px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;background:#fff;cursor:pointer}.btn-clear-filters{padding:8px 16px;background:#ef4444;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px}.btn-clear-filters:hover{background:#dc2626}.family-users-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.family-users-table{width:100%;border-collapse:collapse}.family-users-table th{background:#f9fafb;padding:12px 16px;text-align:left;font-weight:600;font-size:13px;color:#374151;border-bottom:1px solid #e5e7eb}.family-users-table td{padding:16px;border-bottom:1px solid #f3f4f6;font-size:14px}.family-users-table tbody tr:hover{background:#f9fafb}.family-user-name strong{color:#111827}.relationship-badge{display:inline-block;padding:4px 12px;background:#dbeafe;color:#1e40af;border-radius:12px;font-size:13px;font-weight:500}.contact-info{font-size:13px;color:#6b7280}.contact-info div{margin-bottom:2px}.emergency-badge{display:inline-block;padding:4px 12px;background:#fee2e2;color:#991b1b;border-radius:12px;font-size:13px;font-weight:500}.text-muted{color:#9ca3af}.permissions{display:flex;gap:8px;font-size:16px}.permissions span{cursor:help}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;text-transform:capitalize}.status-active{background:#d1fae5;color:#065f46}.status-active svg{color:#10b981}.status-inactive{background:#fee2e2;color:#991b1b}.status-inactive svg{color:#ef4444}.btn-icon{padding:6px 10px;background:#f3f4f6;border:none;border-radius:6px;cursor:pointer;font-size:16px;transition:background .2s}.btn-icon:hover{background:#e5e7eb}.btn-delete:hover{background:#fee2e2}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px;padding:16px}.btn-page{padding:8px 16px;background:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;font-size:14px}.btn-page:hover:not(:disabled){background:#f9fafb}.btn-page:disabled{opacity:.5;cursor:not-allowed}.page-info{font-size:14px;color:#6b7280}.loading,.no-data{text-align:center;padding:40px;color:#6b7280}.btn-primary{padding:10px 24px;background:#059669;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500}.btn-primary:hover{background:#047857}.family-user-form-page{max-width:1000px;margin:0 auto}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.form-header h1{font-size:32px;margin-bottom:8px}.form-header p{color:#666;font-size:14px}.btn-back{padding:10px 20px;background:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;font-size:14px}.btn-back:hover{background:#f9fafb}.family-user-form{background:#fff;border-radius:12px;padding:32px;box-shadow:0 1px 3px #0000001a}.form-section{margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid #e5e7eb}.form-section h2{font-size:20px;margin-bottom:20px;color:#111827}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.form-group.full-width{grid-column:1 / -1}.form-group label{font-size:14px;font-weight:500;margin-bottom:6px;color:#374151}.required{color:#ef4444}.form-group input,.form-group select,.form-group textarea{padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#059669}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:#f9fafb;color:#6b7280;cursor:not-allowed}.form-group input.error,.form-group select.error{border-color:#ef4444}.error-text{color:#ef4444;font-size:12px;margin-top:4px}.error-banner{background:#fee2e2;color:#991b1b;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.error-summary{background:#fee2e2;border:1px solid #fca5a5;border-radius:12px;padding:20px;margin-bottom:24px}.error-summary h3{color:#991b1b;font-size:16px;margin-bottom:12px}.error-summary ul{list-style:disc;padding-left:24px;margin:0}.error-summary li{color:#991b1b;font-size:14px;margin-bottom:6px}.checkbox-group{flex-direction:row;align-items:center}.checkbox-group label{display:flex;align-items:center;cursor:pointer;margin-bottom:0}.checkbox-group input[type=checkbox]{width:18px;height:18px;margin-right:8px;cursor:pointer}.checkbox-label{font-size:14px;font-weight:500;color:#374151}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid #e5e7eb}.btn-cancel{padding:10px 24px;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500}.btn-cancel:hover{background:#f9fafb}.btn-submit{padding:10px 24px;background:#059669;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500}.btn-submit:hover:not(:disabled){background:#047857}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.loading{text-align:center;padding:40px;color:#6b7280}@media (max-width: 768px){.form-grid{grid-template-columns:1fr}.form-header{flex-direction:column;align-items:flex-start;gap:16px}.family-user-form{padding:20px}}.visit-calendar-page{padding:20px;background:#f5f7fa;min-height:calc(100vh - 60px)}.calendar-toolbar{background:#fff;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px}.toolbar-left{display:flex;gap:12px;align-items:center}.selected-date-label{font-size:13px;color:#4b5563}.toolbar-left h1{margin:0;font-size:24px;color:#2d3748}.btn-add{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-add:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.toolbar-center{display:flex;align-items:center;gap:10px}.btn-nav,.btn-today{background:#fff;border:1px solid #ddd;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.btn-nav:hover,.btn-today:hover{background:#f8f9fa;border-color:#bbb}.current-period{font-weight:600;color:#2d3748;min-width:200px;text-align:center}.toolbar-right{display:flex;gap:5px}.btn-view{background:#fff;border:1px solid #ddd;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.btn-view:hover{background:#f8f9fa;border-color:#bbb}.btn-view.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent}.btn-view.active{background:#059669;color:#fff;border-color:#059669}.calendar-week{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.calendar-header{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:2px solid #e2e8f0;background:#f7fafc}.calendar-day-header{padding:15px;text-align:center;border-right:1px solid #e2e8f0}.calendar-day-header:last-child{border-right:none}.day-name{font-weight:600;color:#4a5568;font-size:12px;text-transform:uppercase;margin-bottom:5px}.day-number{font-size:18px;color:#2d3748;font-weight:700}.calendar-body{display:grid;grid-template-columns:repeat(7,1fr);min-height:500px}.calendar-day-column{border-right:1px solid #e2e8f0;padding:10px;overflow-y:auto}.calendar-day-column:last-child{border-right:none}.visit-card{background:#ecfdf5;border-left:3px solid #059669;padding:8px;margin-bottom:8px;border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s}.visit-card:hover{transform:translate(3px);box-shadow:0 2px 8px #0000001a}.visit-card.status-scheduled{background:#e6f2ff;border-left-color:#3182ce}.visit-card.status-in_progress{background:#fff5e6;border-left-color:#f59e0b}.visit-card.status-completed{background:#e6ffe6;border-left-color:#10b981}.visit-card.status-cancelled{background:#ffe6e6;border-left-color:#ef4444}.visit-card.status-pending{background:#f3f4f6;border-left-color:#9ca3af}.visit-time{font-weight:600;color:#1a202c;margin-bottom:4px}.visit-client{color:#4a5568;margin-bottom:2px}.visit-caregiver{color:#718096;font-size:11px}.visit-unassigned{color:#e53e3e;font-size:11px;font-weight:600}.calendar-day-view{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.time-slots{max-height:calc(100vh - 200px);overflow-y:auto}.time-slot{display:grid;grid-template-columns:80px 1fr;border-bottom:1px solid #e2e8f0;min-height:60px}.time-label{padding:10px;text-align:right;color:#718096;font-size:12px;font-weight:600;background:#f7fafc;border-right:2px solid #e2e8f0}.time-slot-content{padding:5px;position:relative}.visit-block{background:#f0f4ff;border-left:4px solid #667eea;padding:10px;margin-bottom:5px;border-radius:4px;cursor:pointer;transition:all .2s}.visit-block:hover{box-shadow:0 4px 12px #00000026}.visit-block.status-scheduled{background:#e6f2ff;border-left-color:#3182ce}.visit-block.status-in_progress{background:#fff5e6;border-left-color:#f59e0b}.visit-block.status-completed{background:#e6ffe6;border-left-color:#10b981}.visit-block.status-cancelled{background:#ffe6e6;border-left-color:#ef4444}.visit-info{margin-top:5px;font-size:13px;color:#4a5568}.unassigned-label{color:#e53e3e;font-weight:600;font-size:12px}.loading{text-align:center;padding:50px;color:#718096;font-size:16px}.month-view-notice{background:#fff;border-radius:8px;padding:50px;text-align:center;color:#718096;font-size:16px}@media (max-width: 768px){.calendar-toolbar{flex-direction:column;align-items:stretch}.toolbar-left,.toolbar-center,.toolbar-right{justify-content:center}.calendar-body{grid-template-columns:1fr}.calendar-header{display:none}.calendar-day-column{border-bottom:2px solid #e2e8f0;border-right:none}}.visit-list-page{padding:30px;max-width:1400px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.page-header h1{margin:0;color:#2c3e50;font-size:32px}.btn-add{background:#10b981;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .3s;text-transform:uppercase}.btn-add:hover{background:#059669}.filters-section{background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;display:flex;flex-direction:column;gap:15px}.filter-row{display:flex;gap:15px;flex-wrap:wrap}.filter-group{flex:1;min-width:200px}.filter-input,.filter-select{width:100%;padding:10px 15px;border:1px solid #dfe6e9;border-radius:8px;font-size:14px;transition:border-color .2s}.filter-input:focus,.filter-select:focus{outline:none;border-color:#3498db}.visits-table{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.visits-table table{width:100%;border-collapse:collapse}.visits-table thead{background:#f8f9fa}.visits-table th{padding:15px;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #ecf0f1;font-size:14px}.visits-table td{padding:15px;border-bottom:1px solid #ecf0f1;font-size:14px;color:#34495e}.visits-table tbody tr:hover{background:#f8f9fa}.client-info{display:flex;flex-direction:column;gap:4px}.client-info strong{color:#2c3e50}.client-address{font-size:12px;color:#7f8c8d}.text-muted{color:#95a5a6}.unassigned{color:#e74c3c;font-style:italic}.visit-type{text-transform:capitalize;color:#34495e}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:capitalize}.status-scheduled{background:#e3f2fd;color:#1976d2}.status-in-progress{background:#fff3e0;color:#f57c00}.status-completed{background:#e8f5e9;color:#388e3c}.status-cancelled{background:#ffebee;color:#d32f2f}.status-no-show{background:#f3e5f5;color:#7b1fa2}.status-default{background:#ecf0f1;color:#7f8c8d}.action-buttons{display:flex;gap:8px}.btn-view{background:#ecf0f1;color:#2c3e50;border:none;padding:6px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s}.btn-view:hover{background:#d5dbdb}.no-data{text-align:center;padding:40px!important;color:#95a5a6;font-style:italic}.pagination{display:flex;justify-content:center;align-items:center;gap:20px;margin-top:20px;padding:20px}.btn-page{background:#3498db;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.btn-page:hover:not(:disabled){background:#2980b9}.btn-page:disabled{background:#bdc3c7;cursor:not-allowed}.page-info{color:#2c3e50;font-size:14px;font-weight:500}.loading{text-align:center;padding:60px 20px;color:#7f8c8d;font-size:16px}.visit-form-page{padding:20px;background:#f5f7fa;min-height:calc(100vh - 60px)}.form-header{margin-bottom:20px}.form-header h1{color:#2d3748;font-size:24px;margin:0}.visit-form{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:30px}.form-section{margin-bottom:30px;padding-bottom:30px;border-bottom:1px solid #e2e8f0}.form-section:last-of-type{border-bottom:none}.form-section h3{color:#2d3748;font-size:18px;margin:0 0 20px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:600;margin-bottom:8px;color:#4a5568;font-size:14px}.form-group input,.form-group select,.form-group textarea{padding:10px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:14px;transition:all .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#059669;box-shadow:0 0 0 3px #0596691f}.client-info,.caregiver-info{margin-top:5px;color:#718096;font-size:12px}.recommendation-section{margin-bottom:20px}.btn-recommendations{background:linear-gradient(135deg,#059669,#10b981);color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:transform .2s,box-shadow .2s}.btn-recommendations:hover{transform:translateY(-2px);box-shadow:0 10px 15px #05966940}.btn-recommendations:disabled{opacity:.6;cursor:not-allowed;transform:none}.recommendations-list{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:20px;margin-bottom:20px}.recommendations-list h4{margin:0 0 15px;color:#2d3748;font-size:16px}.recommendation-card{background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:15px;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center;transition:all .2s}.recommendation-card:hover{box-shadow:0 4px 12px #0000001a}.rec-info{flex:1}.rec-info strong{color:#2d3748;font-size:14px;display:block;margin-bottom:5px}.rec-score{margin:5px 0;font-size:13px;color:#4a5568}.score-value{font-weight:700;color:#059669;font-size:16px}.rec-breakdown{font-size:12px;color:#718096;margin-top:5px}.btn-select{background:#48bb78;color:#fff;border:none;padding:8px 20px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s}.btn-select:hover{background:#38a169}.checkbox-group{margin-top:15px}.checkbox-group label{display:flex;align-items:center;gap:8px;cursor:pointer;color:#4a5568;font-size:14px}.checkbox-group input[type=checkbox]{width:18px;height:18px;cursor:pointer}.form-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:30px}.btn-cancel{background:#fff;color:#4a5568;border:1px solid #e2e8f0;padding:12px 30px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.btn-cancel:hover{background:#f7fafc;border-color:#cbd5e0}.btn-submit{background:linear-gradient(135deg,#059669,#10b981);color:#fff;border:none;padding:12px 30px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:transform .2s,box-shadow .2s}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 10px 15px #05966940}.btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-delete{background:#f56565;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s,transform .2s,box-shadow .2s}.btn-delete:hover{background:#e53e3e;box-shadow:0 8px 12px #e53e3e4d}.error-message{background:#fed7d7;color:#c53030;padding:15px;border-radius:6px;margin-bottom:20px;border-left:4px solid #f56565}@media (max-width: 768px){.visit-form{padding:20px}.form-grid{grid-template-columns:1fr}.recommendation-card{flex-direction:column;align-items:flex-start;gap:15px}.btn-select{width:100%}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}}.notifications-page{min-height:100vh;background-color:#f5f5f5;display:flex;flex-direction:column}.notifications-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;box-shadow:0 2px 10px #0000001a}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.header-content h1{font-size:2rem;margin:0}.header-status{display:flex;align-items:center;gap:1rem}.connection-status{display:flex;align-items:center;gap:.5rem;font-size:.875rem;background:#fff3;padding:.5rem 1rem;border-radius:20px}.status-dot{width:8px;height:8px;background:#22c55e;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.header-actions{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.filter-tabs{display:flex;gap:.5rem}.filter-tabs button{background:#fff3;border:none;color:#fff;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.filter-tabs button:hover{background:#ffffff4d}.filter-tabs button.active{background:#fff;color:#667eea}.mark-all-btn{background:#fff3;border:none;color:#fff;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.mark-all-btn:hover{background:#ffffff4d}.notifications-content{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:2rem}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:#666}.empty-state{text-align:center;padding:4rem 2rem;color:#666}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state h2{color:#333;margin-bottom:.5rem}.notifications-list{display:flex;flex-direction:column;gap:1rem}.notification-card{background:#fff;border-radius:12px;padding:1.5rem;display:flex;align-items:flex-start;gap:1rem;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:all .2s;border-left:4px solid transparent}.notification-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.notification-card.unread{background:#eff6ff;border-left-color:#3b82f6}.notification-card.priority-urgent{border-left-color:#ef4444}.notification-card.priority-high{border-left-color:#f97316}.notification-card.priority-medium{border-left-color:#3b82f6}.notification-card.priority-low{border-left-color:#9ca3af}.notification-icon{font-size:2rem;flex-shrink:0}.notification-body{flex:1;min-width:0}.notification-header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.5rem}.notification-title{font-size:1.125rem;font-weight:600;color:#111;margin:0}.notification-time{font-size:.875rem;color:#666;white-space:nowrap}.notification-message{color:#444;line-height:1.5;margin:0 0 .75rem}.notification-meta{display:flex;gap:.5rem;flex-wrap:wrap}.meta-tag{background:#f3f4f6;color:#666;font-size:.75rem;padding:.25rem .5rem;border-radius:4px}.notification-delete{background:none;border:none;font-size:1.5rem;color:#999;cursor:pointer;padding:0;width:32px;height:32px;border-radius:6px;transition:all .2s;flex-shrink:0}.notification-delete:hover{background:#fee2e2;color:#ef4444}.notifications-footer{max-width:1200px;width:100%;margin:0 auto;padding:2rem}.back-btn{background:#fff;border:1px solid #e5e7eb;color:#667eea;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.back-btn:hover{background:#f9fafb;border-color:#667eea}@media (max-width: 768px){.header-content{flex-direction:column;align-items:flex-start;gap:1rem}.header-actions{flex-direction:column;align-items:stretch;gap:1rem}.filter-tabs{width:100%}.filter-tabs button{flex:1}.notification-header-row{flex-direction:column;align-items:flex-start}.notification-time{font-size:.75rem}}.reports-page{min-height:100vh;background-color:#f5f5f5}.reports-header{background:linear-gradient(135deg,#059669,#10b981);color:#fff;padding:2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a}.reports-header h1{margin:0;font-size:2rem}.header-actions{display:flex;gap:1rem}.export-btn,.back-btn{padding:.75rem 1.5rem;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.export-btn{background:#fff;color:#059669}.export-btn:hover{background:#f0f0f0;transform:translateY(-2px)}.back-btn{background:#fff3;color:#fff}.back-btn:hover{background:#ffffff4d}.reports-controls{background:#fff;padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e5e7eb}.date-range-picker{display:flex;gap:1rem}.date-range-picker label{display:flex;flex-direction:column;gap:.5rem;font-weight:500;color:#374151}.date-range-picker input{padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem}.preset-buttons{display:flex;gap:.5rem}.preset-buttons button{padding:.5rem 1rem;border:1px solid #d1d5db;background:#fff;border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .2s}.preset-buttons button:hover{background:#f9fafb;border-color:#059669}.reports-tabs{background:#fff;padding:0 2rem;display:flex;gap:0;border-bottom:2px solid #e5e7eb}.reports-tabs button{padding:1rem 1.5rem;border:none;background:none;cursor:pointer;font-weight:500;color:#6b7280;border-bottom:3px solid transparent;transition:all .2s}.reports-tabs button:hover{color:#059669;background:#f9fafb}.reports-tabs button.active{color:#059669;border-bottom-color:#059669}.reports-content{max-width:1400px;margin:0 auto;padding:2rem}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:#666}.spinner{width:48px;height:48px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-bottom:2rem}.card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;gap:1rem;transition:all .2s}.card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.card-icon{font-size:2.5rem}.card-content h3{margin:0;font-size:2rem;color:#111827}.card-content p{margin:.25rem 0 0;color:#6b7280;font-size:.875rem}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem;margin-bottom:2rem}.chart-container,.chart-container-full{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.chart-container-full{margin-bottom:2rem}.chart-container h3,.chart-container-full h3{margin:0 0 1rem;color:#111827;font-size:1.125rem}.performance-metrics{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.performance-metrics h3{margin:0 0 1rem;color:#111827}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.metric{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f9fafb;border-radius:8px}.metric-label{font-weight:500;color:#6b7280}.metric-value{font-size:1.5rem;font-weight:700;color:#059669}.caregiver-table,.billing-table,.client-table{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;overflow-x:auto}.caregiver-table h3,.billing-table h3,.client-table h3{margin:0 0 1rem;color:#111827}table{width:100%;border-collapse:collapse}thead{background:#f9fafb}thead tr{border-bottom:2px solid #e5e7eb}th{padding:.75rem 1rem;text-align:left;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s}tbody tr:hover{background:#f9fafb}td{padding:1rem;color:#1f2937;font-size:.875rem}td:first-child{font-weight:500}@media (max-width: 1024px){.charts-grid{grid-template-columns:1fr}.summary-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.reports-header{flex-direction:column;gap:1rem;align-items:flex-start}.header-actions{width:100%;justify-content:space-between}.reports-controls{flex-direction:column;gap:1rem;align-items:stretch}.date-range-picker{flex-direction:column}.preset-buttons{display:grid;grid-template-columns:repeat(2,1fr)}.reports-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.reports-tabs button{flex-shrink:0}.summary-cards{grid-template-columns:1fr}table{font-size:.75rem}th,td{padding:.5rem}}.recharts-wrapper{margin:0 auto}.recharts-surface{overflow:visible}.notification-bell-container{position:relative;display:inline-block}.notification-bell{position:relative;background:#fff;border:1px solid #e2e8f0;width:42px;height:42px;cursor:pointer;padding:0;border-radius:12px;display:flex;align-items:center;justify-content:center;transition:all .25s cubic-bezier(.4,0,.2,1);color:#475569}.notification-bell:hover{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px #667eea4d}.notification-badge{position:absolute;top:-4px;right:-4px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-radius:12px;padding:2px 7px;font-size:10px;font-weight:700;min-width:20px;text-align:center;border:2px solid white;box-shadow:0 2px 8px #ef44444d}.connection-indicator{position:absolute;bottom:-2px;right:-2px;width:10px;height:10px;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:50%;border:2px solid white;box-shadow:0 0 0 2px #22c55e33;animation:pulse-green 2s infinite}@keyframes pulse-green{0%,to{box-shadow:0 0 0 2px #22c55e33}50%{box-shadow:0 0 0 4px #22c55e1a}}.notification-dropdown{position:absolute;top:calc(100% + 12px);right:0;width:400px;max-height:600px;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001f,0 4px 8px #00000014;border:1px solid #e2e8f0;z-index:1000;display:flex;flex-direction:column;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #f1f5f9;background:linear-gradient(135deg,#f8fafc,#fff);border-radius:16px 16px 0 0}.notification-header h3{margin:0;font-size:18px;font-weight:700;color:#0f172a;letter-spacing:-.3px}.mark-all-read-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;font-size:13px;font-weight:600;cursor:pointer;padding:8px 16px;border-radius:8px;transition:all .2s ease}.mark-all-read-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.notification-list{flex:1;overflow-y:auto;max-height:480px}.no-notifications{padding:40px 20px;text-align:center;color:#9ca3af}.notification-item{display:flex;align-items:flex-start;padding:12px 20px;border-bottom:1px solid #f3f4f6;cursor:pointer;transition:background-color .2s;position:relative}.notification-item:hover{background-color:#f9fafb}.notification-item.unread{background-color:#eff6ff}.notification-item.unread:hover{background-color:#dbeafe}.notification-item.priority-urgent{border-left:4px solid #ef4444}.notification-item.priority-high{border-left:4px solid #f97316}.notification-item.priority-medium{border-left:4px solid #3b82f6}.notification-item.priority-low{border-left:4px solid #9ca3af}.notification-icon{font-size:24px;margin-right:12px;flex-shrink:0}.notification-content{flex:1;min-width:0}.notification-title{font-weight:600;font-size:14px;color:#111827;margin-bottom:4px}.notification-message{font-size:13px;color:#6b7280;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.notification-time{font-size:12px;color:#9ca3af}.notification-delete{background:none;border:none;font-size:24px;color:#9ca3af;cursor:pointer;padding:0;width:24px;height:24px;line-height:24px;border-radius:4px;transition:all .2s;flex-shrink:0;margin-left:8px}.notification-delete:hover{background-color:#fee2e2;color:#ef4444}.notification-footer{padding:12px 20px;border-top:1px solid #e5e7eb;text-align:center}.notification-footer button{background:none;border:none;color:#3b82f6;font-size:14px;font-weight:500;cursor:pointer;padding:8px 16px;border-radius:4px;transition:background-color .2s}.notification-footer button:hover{background-color:#eff6ff}.notification-list::-webkit-scrollbar{width:6px}.notification-list::-webkit-scrollbar-track{background:#f3f4f6}.notification-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.notification-list::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media (max-width: 640px){.notification-dropdown{width:320px;right:-50%}}.app-layout{display:flex;min-height:100vh}.app-sidebar{width:260px;background:#fff;color:#1e293b;display:flex;flex-direction:column;box-shadow:2px 0 12px #00000014;position:fixed;left:0;top:0;bottom:0;z-index:1000;border-right:1px solid #f1f5f9}.sidebar-logo{padding:24px 20px;border-bottom:1px solid #f1f5f9}.sidebar-logo h1{font-size:24px;font-weight:700;margin:0 0 4px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-logo p{font-size:12px;color:#64748b;margin:0;text-transform:uppercase;letter-spacing:1px}.sidebar-nav{flex:1;overflow-y:auto;padding:12px 0}.sidebar-nav-item{display:flex;align-items:center;padding:12px 20px;color:#64748b;text-decoration:none;transition:all .3s ease;position:relative;cursor:pointer;border-left:3px solid transparent;margin:2px 8px;border-radius:8px}.sidebar-nav-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(135deg,#667eea,#764ba2);transform:scaleY(0);transition:transform .3s ease;border-radius:0 3px 3px 0}.sidebar-nav-item:hover{background:#f8fafc;color:#1e293b}.sidebar-nav-item.active{background:linear-gradient(135deg,#667eea1a,#764ba21a);color:#667eea;border-left-color:#667eea;font-weight:600}.sidebar-nav-item.active:before{transform:scaleY(1)}.sidebar-nav-item.disabled{opacity:.5;cursor:not-allowed}.sidebar-nav-item.disabled:hover{background:transparent;color:#64748b}.sidebar-nav-icon{width:20px;height:20px;margin-right:12px;display:flex;align-items:center;justify-content:center;font-size:18px}.sidebar-nav-label{flex:1;font-size:14px;font-weight:500}.sidebar-nav-badge{background:#fbbf2426;color:#d97706;padding:2px 8px;border-radius:12px;font-size:10px;font-weight:600;text-transform:uppercase;border:1px solid rgba(251,191,36,.3)}.sidebar-footer{padding:16px 20px;border-top:1px solid #f1f5f9}.sidebar-user{display:flex;align-items:center;gap:12px;padding:12px;background:#f8fafc;border-radius:8px;margin-bottom:12px;border:1px solid #f1f5f9}.sidebar-user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff}.sidebar-user-info{flex:1}.sidebar-user-name{font-size:13px;font-weight:600;color:#1e293b;margin:0 0 2px}.sidebar-user-role{font-size:11px;color:#64748b;margin:0}.sidebar-logout{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;background:#ef444414;color:#ef4444;border:1px solid rgba(239,68,68,.15);border-radius:8px;cursor:pointer;transition:all .3s ease;font-size:14px;font-weight:500}.sidebar-logout:hover{background:#ef444426;border-color:#ef44444d}.app-main{flex:1;margin-left:260px;background:#f8fafc;min-height:100vh}.app-header{background:#fff;padding:14px 30px;box-shadow:0 1px 4px #0000000f;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:999;border-bottom:1px solid #e2e8f0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffffa}.app-header-title{font-size:22px;font-weight:700;color:#0f172a;margin:0;letter-spacing:-.3px}.app-header-actions{display:flex;align-items:center;gap:12px}.notification-icon{position:relative;width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);color:#475569}.notification-icon:hover{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px #667eea4d}.notification-badge{position:absolute;top:-2px;right:-2px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;border:2px solid white}.app-content{padding:30px}@media (max-width: 768px){.app-sidebar{transform:translate(-100%);transition:transform .3s ease}.app-sidebar.mobile-open{transform:translate(0)}.app-main{margin-left:0}.mobile-menu-btn{display:block;position:fixed;top:16px;left:16px;z-index:1001;background:#fff;width:40px;height:40px;border-radius:50%;box-shadow:0 2px 8px #00000026;display:flex;align-items:center;justify-content:center;cursor:pointer}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:999;opacity:0;pointer-events:none;transition:opacity .3s ease}.sidebar-overlay.active{opacity:1;pointer-events:all}}@media (min-width: 769px){.mobile-menu-btn,.sidebar-overlay{display:none}}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:#f8fafc}.sidebar-nav::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#94a3b8}/*! tailwindcss v4.1.18 | MIT License | https://tailwindcss.com */@layer properties{@supports ((-webkit-hyphens:none) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::-moz-placeholder{opacity:1}::placeholder{opacity:1}@supports (not (-webkit-appearance:-apple-pay-button)) or (contain-intrinsic-size:1px){::-moz-placeholder{color:currentColor}::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::-moz-placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.flex{display:flex}.hidden{display:none}.inline-flex{display:inline-flex}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.rounded{border-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.overline{text-decoration-line:overline}.underline{text-decoration-line:underline}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}html{scroll-behavior:smooth}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app{min-height:100vh}button{cursor:pointer;border:none;outline:none}input,textarea{font-family:inherit}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
