body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-container{align-items:center;background-color:#f8fafc;display:flex;justify-content:center;min-height:100vh}.login-card{background:#fff;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;max-width:400px;padding:2.5rem;width:100%}.login-header{margin-bottom:2rem;text-align:center}.login-icon{align-items:center;background-color:#e0f2fe;border-radius:50%;color:#0284c7;display:flex;height:48px;justify-content:center;margin:0 auto 1rem;width:48px}.login-title{color:#0f172a;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.login-subtitle{color:#64748b;font-size:.875rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{gap:.5rem}.form-label{color:#334155;font-size:.875rem;font-weight:500}.form-input{border:1px solid #cbd5e1;border-radius:.5rem;font-size:.875rem;outline:none;padding:.75rem;transition:border-color .2s}.form-input:focus{border-color:#0284c7;box-shadow:0 0 0 2px #0284c71a}.login-button{align-items:center;background-color:#0284c7;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem;transition:background-color .2s}.login-button:hover{background-color:#0ea5e9}.login-button:disabled{background-color:#94a3b8;cursor:not-allowed}.error-message{background-color:#fef2f2;border:1px solid #fee2e2;border-radius:.5rem;color:#ef4444;font-size:.875rem;padding:.75rem;text-align:center}.dashboard{background:linear-gradient(135deg,#f8fafc,#f1f5f9);margin:0 auto;max-width:1400px;min-height:calc(100vh - 80px);padding:2rem}.dashboard-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:3rem}.current-date{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a;color:#475569;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem}.stats-grid{grid-gap:1.5rem;align-items:stretch;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:3rem}.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;cursor:pointer;gap:1.5rem;min-height:160px;overflow:hidden;padding:2rem;position:relative;transition:all .3s ease}.stat-card,.stat-card>*{align-items:center;display:flex;height:100%}.stat-card:before{content:"";height:4px;left:0;position:absolute;right:0;top:0}.patient-card:before{background:linear-gradient(135deg,#667eea,#764ba2)}.vaccination-card:before{background:linear-gradient(135deg,#f093fb,#f5576c)}.pending-card:before{background:linear-gradient(135deg,#4facfe,#00f2fe)}.completion-card:before{background:linear-gradient(135deg,#43e97b,#38f9d7)}.stat-icon-wrapper{flex-shrink:0}.stat-icon,.stat-icon-wrapper{align-items:center;display:flex;position:relative}.stat-icon{border-radius:16px;color:#fff;height:70px;justify-content:center;width:70px;z-index:2}.stat-icon:before{background:inherit;border-radius:20px;bottom:-5px;content:"";left:-5px;opacity:.2;position:absolute;right:-5px;top:-5px;z-index:1}.stat-icon.patients{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-icon.vaccinations{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-icon.pending{background:linear-gradient(135deg,#4facfe,#00f2fe)}.stat-icon.completion{background:linear-gradient(135deg,#43e97b,#38f9d7)}.stat-content{display:flex;flex:1 1;flex-direction:column;height:100%;justify-content:center}.stat-content h3{font-size:2.5rem;font-weight:800;line-height:1}.stat-content h3,.stat-content p{color:#1e293b;margin-bottom:.25rem}.stat-content p{font-size:1.1rem;font-weight:700}.stat-subtitle{color:#64748b;font-size:.875rem;font-weight:500}.recent-activity{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr}.activity-section{display:flex;flex-direction:column}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.section-header h3{color:#1e293b;font-size:1.5rem;font-weight:700}.view-all-btn{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.5rem 1rem;transition:all .3s ease}.view-all-btn:hover{background:#3b82f6;border-color:#3b82f6;color:#fff}.activity-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;flex:1 1;min-height:300px;padding:1.5rem}.activity-card,.activity-list{display:flex;flex-direction:column}.activity-list{gap:.75rem}.activity-item{align-items:center;border:1px solid #0000;border-radius:12px;cursor:pointer;display:flex;gap:1rem;padding:1rem;transition:all .3s ease}.activity-item:hover{border-color:#e2e8f0}.patient-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:flex;flex-shrink:0;font-size:1rem;font-weight:700;height:48px;justify-content:center;width:48px}.patient-details{display:flex;flex:1 1;flex-direction:column;min-width:0}.patient-details strong{color:#1e293b;font-size:1rem;font-weight:600}.patient-details span{color:#64748b;font-size:.875rem}.vaccine-count{background:#f1f5f9;border-radius:20px;color:#475569;flex-shrink:0;font-size:.75rem;padding:.25rem .75rem}.vaccine-badge{align-items:center;border-radius:10px;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.vaccine-badge.completed{background:#d1fae5;color:#065f46}.vaccine-badge.pending{background:#fef3c7;color:#92400e}.vaccine-badge.scheduled{background:#dbeafe;color:#1e40af}.vaccine-details{display:flex;flex:1 1;flex-direction:column;min-width:0}.vaccine-details strong{color:#1e293b;font-size:1rem;font-weight:600}.vaccine-details span{color:#64748b;font-size:.875rem}.vaccine-date{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0;gap:.25rem}.status-indicator{border-radius:12px;font-size:.7rem;font-weight:600;padding:.25rem .75rem;text-transform:capitalize}.status-indicator.completed{background:#d1fae5;color:#065f46}.status-indicator.pending{background:#fef3c7;color:#92400e}.status-indicator.scheduled{background:#dbeafe;color:#1e40af}.empty-state{align-items:center;color:#94a3b8;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:3rem 2rem;text-align:center}.empty-state svg{margin-bottom:1rem;opacity:.5}.empty-state p{font-size:1.1rem;font-weight:500;margin:0 0 .5rem}.empty-subtitle{font-size:.9rem;opacity:.7}.quick-actions{margin-top:2rem}.action-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;padding:2rem;text-align:center}.action-card h3{color:#1e293b;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.action-card p{color:#64748b;margin-bottom:1.5rem}.action-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.action-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.action-btn.primary:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190)}@media (max-width:1024px){.recent-activity{grid-template-columns:1fr}}@media (max-width:768px){.dashboard{padding:1rem}.stats-grid{grid-template-columns:1fr}.dashboard-header{flex-direction:column}.header-content h1{font-size:2rem}.stat-card{min-height:140px;padding:1.5rem}.stat-icon{height:60px;width:60px}.stat-content h3{font-size:2rem}}@media (max-width:480px){.activity-item{flex-direction:column;gap:.75rem;text-align:left}.activity-item,.vaccine-date{align-items:flex-start}.stat-card{min-height:130px;padding:1.25rem}}.patient-list-container{margin:0 auto;max-width:1200px;padding:20px}.patient-list-header{margin-bottom:25px}.patient-list-title{color:#2c5282;font-size:28px;font-weight:700;margin-bottom:8px}.patient-list-subtitle{color:#718096;font-size:16px}.search-container{margin-bottom:20px;position:relative}.search-input{background-color:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;font-size:16px;padding:12px 20px 12px 45px;width:100%}.search-input:focus{background-color:#fff;border-color:#4299e1;outline:none}.search-icon{color:#a0aec0;left:15px;position:absolute;top:50%;transform:translateY(-50%)}.patient-count{color:#718096;font-size:14px;margin-bottom:20px}.patients-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr)}.patient-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 2px 8px #00000014;height:-webkit-fit-content;height:fit-content;padding:20px;transition:all .3s ease}.patient-card:hover{box-shadow:0 4px 15px #0000001f;transform:translateY(-2px)}.patient-name{color:#2d3748;font-size:18px;font-weight:600;margin-bottom:8px}.patient-condition{background:#fed7d7;border-radius:16px;color:#c53030;display:inline-block;font-size:12px;font-weight:600;margin-bottom:12px;padding:4px 12px}.patient-details{margin-bottom:15px}.patient-detail{align-items:center;color:#4a5568;display:flex;font-size:14px;gap:8px;margin-bottom:5px}.patient-detail i{color:#718096;width:16px}.vaccine-info{align-items:center;background:#f0fff4;border:1px solid #c6f6d5;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:15px;padding:12px}.vaccine-count{color:#2f855a;font-weight:600}.vaccine-status{color:#718096;font-size:13px}.view-details-btn{background:#4299e1;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:background .3s ease;width:auto}.view-details-btn:hover{background:#3182ce}@media (max-width:1024px){.patients-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.patients-grid{grid-template-columns:1fr}.patient-list-container{padding:15px}}.action-buttons{align-items:center;gap:10px;margin-top:15px}.icon-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s ease;width:36px}.edit-btn{background:#eef2ff;color:#4f46e5}.edit-btn:hover{background:#e0e7ff}.delete-btn{background:#fee2e2;color:#ef4444}.delete-btn:hover{background:#fecaca}.patient-details{margin:0 auto;max-width:1000px;padding:2rem}.details-header{align-items:center;display:flex;gap:1rem;margin-bottom:2rem}.back-btn{gap:.5rem;padding:.5rem 1rem}.details-header h1{color:#1e293b;font-size:2rem;font-weight:700}.profile-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;margin-bottom:2rem;padding:2rem}.profile-header{align-items:flex-start;display:flex;gap:1.5rem;margin-bottom:1.5rem}.profile-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:1.5rem;font-weight:600;height:80px;justify-content:center;width:80px}.profile-info h2{color:#1e293b;font-size:1.75rem;font-weight:700;margin-bottom:.25rem}.mrn{color:#64748b;font-size:1rem;margin-bottom:1rem}.profile-stats{display:flex;gap:2rem}.stat{text-align:center}.stat-value{display:block;font-size:1.5rem}.stat-label{color:#64748b;font-size:.875rem}.contact-info{grid-gap:1rem;border-top:1px solid #e2e8f0;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));padding-top:1.5rem}.contact-item{align-items:center;color:#64748b;display:flex;gap:.5rem}.tab-navigation{border-bottom:1px solid #e2e8f0;display:flex;gap:.5rem;margin-bottom:2rem}.tab-btn{background:#0000;border:none;border-bottom:2px solid #0000;color:#64748b;cursor:pointer;font-weight:500;padding:1rem 2rem;transition:all .3s ease}.tab-btn.active{border-bottom-color:#3b82f6;color:#3b82f6}.tab-btn:hover{color:#374151}.tab-content{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;margin-bottom:2rem;padding:2rem}.tab-content h3{color:#1e293b;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem}.vaccine-list{display:flex;flex-direction:column;gap:1rem}.vaccine-card{border-radius:8px;gap:1rem;transition:all .3s ease}.vaccine-card:hover{background:#f8fafc}.vaccine-icon{align-items:center;background:#f1f5f9;border-radius:8px;color:#64748b;display:flex;height:40px;justify-content:center;width:40px}.vaccine-info{flex:1 1}.vaccine-info h4{color:#1e293b;font-weight:600;margin-bottom:.25rem}.vaccine-info p{color:#64748b;font-size:.875rem;margin-bottom:.25rem}.vaccine-date{color:#94a3b8;font-size:.75rem}.vaccine-status{align-items:center;border-radius:20px;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem}.vaccine-status.completed{background:#d1fae5;color:#065f46}.vaccine-status.pending{background:#fef3c7;color:#92400e}.empty-vaccines{color:#64748b;padding:3rem;text-align:center}.info-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item label{color:#374151;display:block;font-weight:600;margin-bottom:.5rem}.info-item p{color:#64748b;margin:0}.action-buttons{display:flex;gap:1rem;justify-content:flex-end}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2)}.btn-secondary{background:#f8fafc;border:1px solid #e2e8f0;color:#374151}.btn-primary:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190)}.btn-secondary:hover{background:#f1f5f9}.error-state{color:#64748b;padding:4rem 2rem;text-align:center}.error-state h3{color:#475569;margin:1rem 0 .5rem}@media (max-width:768px){.patient-details{padding:1rem}.profile-header{flex-direction:column;text-align:center}.profile-stats{justify-content:center}.action-buttons,.tab-navigation{flex-direction:column}.contact-info{grid-template-columns:1fr}}.profile-actions-top{align-items:flex-start;display:flex;justify-content:space-between;width:100%}.header-actions{gap:10px}.action-btn-secondary{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-weight:500;gap:8px;padding:8px 16px;transition:all .2s ease}.action-btn-secondary.edit{background:#eef2ff;color:#4f46e5}.action-btn-secondary.delete{background:#fee2e2;color:#ef4444}.action-btn-secondary.edit:hover{background:#e0e7ff}.action-btn-secondary.delete:hover{background:#fecaca}.profile-actions-bottom{border-top:1px solid #e2e8f0;display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:15px}.add-note-section{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.note-textarea{background:#fff;border:1px solid #cbd5e1;border-radius:8px;font-family:inherit;font-size:1rem;min-height:120px;padding:1rem;resize:vertical;transition:border-color .3s ease,box-shadow .3s ease;width:100%}.note-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.notes-list{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}.note-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}.note-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-2px)}.note-header{border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.75rem}.note-date{color:#64748b;font-size:.875rem;font-weight:500}.note-author{background:#eff6ff;border-radius:4px;color:#3b82f6;font-size:.875rem;font-weight:600;padding:2px 8px}.note-content p{color:#334155;line-height:1.6;white-space:pre-wrap}.add-note-section .btn-primary{align-self:flex-end;min-width:120px}.reports{background:linear-gradient(135deg,#f8fafc,#f1f5f9);margin:0 auto;max-width:1400px;min-height:calc(100vh - 80px);padding:2rem}.reports-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.header-content h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#1e293b,#475569);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:800;margin-bottom:.5rem}.header-content p{color:#64748b;font-size:1.2rem;font-weight:500}.header-actions{display:flex;gap:1rem}.export-btn,.filter-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.export-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.export-btn:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190)}.filter-btn{background:#fff;border:1px solid #e2e8f0;color:#374151}.filter-btn:hover{background:#f8fafc}.metrics-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:3rem}.metric-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;gap:1rem;padding:1.5rem}.metric-card,.metric-icon{align-items:center;display:flex}.metric-icon{border-radius:12px;color:#fff;height:60px;justify-content:center;width:60px}.metric-icon.total{background:linear-gradient(135deg,#667eea,#764ba2)}.metric-icon.vaccinations{background:linear-gradient(135deg,#f093fb,#f5576c)}.metric-icon.completion{background:linear-gradient(135deg,#43e97b,#38f9d7)}.metric-icon.pending{background:linear-gradient(135deg,#4facfe,#00f2fe)}.metric-content h3{color:#1e293b;font-size:2rem;font-weight:800;line-height:1;margin-bottom:.25rem}.metric-content p{color:#1e293b;font-weight:600;margin-bottom:.25rem}.metric-trend{font-size:.875rem;font-weight:500}.metric-trend.positive{color:#10b981}.metric-trend.negative{color:#ef4444}.charts-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));margin-bottom:2rem}.chart-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;padding:1.5rem}.chart-header{margin-bottom:1.5rem}.chart-header h3{color:#1e293b;font-size:1.25rem;font-weight:700;margin-bottom:.25rem}.chart-header p{color:#64748b;font-size:.875rem}.chart-container{height:300px;width:100%}.summary-cards{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr}.summary-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;padding:1.5rem}.summary-card h4{color:#1e293b;font-size:1.25rem;font-weight:700;margin-bottom:1rem}.stats-list,.vaccine-list{display:flex;flex-direction:column;gap:1rem}.vaccine-item{background:#f8fafc;border-radius:8px;gap:1rem;padding:.75rem}.vaccine-item,.vaccine-rank{align-items:center;display:flex}.vaccine-rank{background:#1e293b;border-radius:50%;color:#fff;font-size:.875rem;font-weight:700;height:30px;justify-content:center;width:30px}.vaccine-name{color:#1e293b;flex:1 1;font-weight:600}.vaccine-count{color:#64748b;font-weight:500}.stat-item{align-items:center;background:#f8fafc;border-radius:8px;display:flex;justify-content:space-between;padding:.75rem}.stat-item span:first-child{color:#64748b}.stat-value{color:#1e293b;font-weight:700}@media (max-width:1200px){.charts-grid,.summary-cards{grid-template-columns:1fr}}@media (max-width:768px){.reports{padding:1rem}.reports-header{flex-direction:column}.header-actions{justify-content:stretch;width:100%}.export-btn,.filter-btn{flex:1 1;justify-content:center}.charts-grid,.metrics-grid{grid-template-columns:1fr}.chart-card{padding:1rem}}@media (max-width:480px){.header-content h1{font-size:2rem}.metric-card{flex-direction:column;text-align:center}}.nepali-date-picker{position:relative}.nepali-date-picker .calender{background:#fff none repeat scroll 0 0;border-radius:6px;box-shadow:0 2px 6px 0 #0000001a;box-sizing:border-box;color:#8c8c8c;display:block;font-family:NotoSans,sans-serif;font-size:14px;font-style:normal;font-weight:400;height:auto;left:0;letter-spacing:.2px;line-height:1.25em;padding:15px;position:absolute;text-align:right;-webkit-user-select:none;user-select:none;z-index:9999}.nepali-date-picker .calender .calendar-controller{align-items:center;display:flex;justify-content:space-between;position:relative}.nepali-date-picker .calender .calendar-controller .date-indicator{display:flex}.nepali-date-picker .calender .calendar-controller .control{cursor:pointer;position:relative;text-align:center}.nepali-date-picker .calender .calendar-controller .control.icon-today{position:absolute;right:20px}.nepali-date-picker .calender .calendar-controller .control.month,.nepali-date-picker .calender .calendar-controller .control.year{border:1px solid #eee;line-height:24px;width:70px}.nepali-date-picker .calender .calendar-controller .control.month .current-month,.nepali-date-picker .calender .calendar-controller .control.month .current-year,.nepali-date-picker .calender .calendar-controller .control.year .current-month,.nepali-date-picker .calender .calendar-controller .control.year .current-year{display:block;padding:4px}.nepali-date-picker .calender .calendar-controller .control.year{border-left:none}.nepali-date-picker .calender .calendar-controller .control .drop-down{background-color:#fff;box-shadow:0 2px 6px 0 #0000001a;left:0;max-height:200px;overflow-y:scroll;position:absolute;top:0;width:100%;z-index:100}.nepali-date-picker .calender .calendar-controller .control .drop-down ul{list-style:none;margin:0;padding:0}.nepali-date-picker .calender .calendar-controller .control .drop-down li{padding:4px 10px}.nepali-date-picker .calender .calendar-controller .control .drop-down li.active{background:#2096f5;color:#fff}.nepali-date-picker .calender td.month-day.current{opacity:1}.nepali-date-picker .calender td.month-day.disabled{color:#d8d8d8}.nepali-date-picker .calender td.month-day.today{color:#4a4a4a;position:relative}.nepali-date-picker .calender td.month-day.today:before{background-color:#2096f5;border-radius:50%;bottom:6px;content:"";height:4px;left:50%;margin:auto;position:absolute;transform:translateX(-50%);width:4px}.nepali-date-picker .calender td.month-day.selected{color:#fff;position:relative}.nepali-date-picker .calender td.month-day.selected:after{background:#2096f5;border-radius:50%;content:"";height:35px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:35px;z-index:-1}.nepali-date-picker .calender table{border:none;text-align:center;width:100%}.nepali-date-picker .calender table td{border:none;height:40px;width:40px}.nepali-date-picker .calender table tr{border:none;height:36px}:root{--primary:#2563eb;--primary-light:#2563eb1a;--success:#10b981;--bg:#fff;--bg-alt:#f8fafc;--text:#1e293b;--border:#e2e8f0;--radius:14px;--shadow:0 10px 40px #0000001a}.unified-modal{background:#fff;background:var(--bg);border-radius:14px;border-radius:var(--radius);box-shadow:0 10px 40px #0000001a;box-shadow:var(--shadow);max-height:94vh;max-width:920px;overflow-y:auto;padding:2rem;position:relative;width:95%}.modal-header{border-bottom:1px solid var(--border);margin-bottom:1.5rem;padding-bottom:1rem}.modal-header h2{color:var(--text);font-size:1.75rem;font-weight:700;gap:.5rem}.close-btn,.modal-header h2{align-items:center;display:flex}.close-btn{background:#fee2e2;border:none;border-radius:50%;color:#ef4444;height:40px;justify-content:center;transition:all .2s;width:40px}.close-btn:hover{background:#ef4444;color:#fff}.input-wrapper{margin-bottom:1.2rem;position:relative}.input-wrapper input{background:#fafafa;border:2px solid #e2e8f0;border:2px solid var(--border);border-radius:14px;border-radius:var(--radius);font-size:1rem;padding:1.1rem 1rem .6rem 3rem;transition:all .3s ease;width:100%}.input-wrapper input:focus{background:#fff;border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 4px #2563eb1a;outline:none}.input-wrapper label{color:#64748b;font-size:1rem;left:3rem;pointer-events:none;position:absolute;top:1.1rem;transition:all .2s ease}.input-wrapper input:focus~label,.input-wrapper input:not(:placeholder-shown)~label{background:#fff;color:#2563eb;color:var(--primary);font-size:.8rem;font-weight:600;left:1rem;padding:0 .4rem;top:.5rem}.input-icon{color:#94a3b8;left:1rem;position:absolute;top:1.1rem;transition:color .3s}.input-wrapper input:focus~.input-icon{color:#2563eb;color:var(--primary)}.input-wrapper.error input{border-color:#ef4444}.radio-group{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.5rem}.radio-pill{background:#f1f5f9;border:2px solid #0000;border-radius:14px;border-radius:var(--radius);cursor:pointer;flex:1 1;font-weight:500;min-width:100px;padding:.9rem;text-align:center;transition:all .3s}.radio-pill:hover{transform:translateY(-2px)}.radio-pill.selected,.radio-pill:hover{border-color:#2563eb;border-color:var(--primary)}.radio-pill.selected{background:#2563eb1a;background:var(--primary-light);color:#2563eb;color:var(--primary);font-weight:600}.radio-pill input{display:none}.vaccine-grid{grid-gap:1rem;background:#f8fafc;background:var(--bg-alt);border:1px dashed #cbd5e1;border-radius:14px;border-radius:var(--radius);display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));padding:1.5rem}.vaccine-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:14px;border-radius:var(--radius);box-shadow:0 2px 10px #0000000d;cursor:pointer;display:flex;gap:.75rem;padding:1rem;transition:all .2s}.vaccine-card:hover{box-shadow:0 10px 25px #0000001a;transform:translateY(-4px)}.vaccine-card.checked{background:#ecfdf5;border-color:#10b981;border-color:var(--success);color:#10b981;color:var(--success);font-weight:600}.vaccine-card input{accent-color:#10b981;accent-color:var(--success)}.form-actions{border-top:1px solid var(--border);margin-top:2rem;padding-top:2rem}.btn-cancel{background:#f1f5f9;color:#64748b;padding:.9rem 2rem}.btn-cancel,.btn-primary{border:none;border-radius:14px;border-radius:var(--radius);cursor:pointer;font-weight:600}.btn-primary{align-items:center;background:#2563eb;background:var(--primary);box-shadow:0 4px 15px #2563eb4d;color:#fff;display:flex;gap:.5rem;padding:.9rem 2.2rem}.btn-primary:hover{background:#1d4ed8;transform:translateY(-2px)}@media (max-width:768px){.unified-modal{border-radius:0;height:100vh;padding:1.5rem;width:100%}.form-grid{grid-template-columns:1fr}.radio-group{flex-direction:column}.vaccine-grid{grid-template-columns:repeat(2,1fr)}}.nepali-datepicker-container{position:relative}.nepali-datepicker-container input{background:#fafafa;border:1px solid #e2e8f0;border-radius:14px;font-size:1rem;padding:.8rem;width:100%}.nepali-datepicker-container input:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1a;outline:none}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.vaccine-modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1.5rem 2rem}.modal-header h2{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0}.close-btn{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;padding:.5rem;transition:all .3s ease}.close-btn:hover{background:#f1f5f9;color:#374151}.vaccine-form{padding:2rem}.form-group{display:flex;flex-direction:column;margin-bottom:1.5rem}.form-group label{align-items:center;color:#374151;display:flex;font-weight:500;gap:.5rem;margin-bottom:.5rem}.form-group input,.form-group select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:.75rem 1rem;transition:all .3s ease}.form-group input:focus,.form-group select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-actions{border-top:1px solid #e2e8f0;display:flex;gap:1rem;justify-content:flex-end;padding-top:1.5rem}.btn-cancel,.btn-submit{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.btn-cancel{background:#f8fafc;border:1px solid #e2e8f0;color:#374151}.btn-cancel:hover{background:#f1f5f9}.btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-submit:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190)}@media (max-width:768px){.vaccine-modal{margin:1rem}.vaccine-form{padding:1.5rem}.modal-header{padding:1rem 1.5rem}}.header{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.header-content{height:70px;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 2rem}.header-content,.header-left{align-items:center;display:flex}.header-left{gap:1rem}.back-btn{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .3s ease}.back-btn:hover{background:#f1f5f9;color:#374151}.logo{align-items:center;cursor:pointer;display:flex;gap:.75rem}.logo-text{display:flex;flex-direction:column;line-height:1}.logo-primary{color:#1e293b;font-size:1.25rem;font-weight:800}.logo-secondary{color:#3b82f6;font-size:1rem;font-weight:600}.logo-icon{color:#3b82f6}.navigation{background:#f8fafc;border-radius:12px;gap:.25rem;padding:.25rem}.nav-btn,.navigation{display:flex;position:relative}.nav-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#64748b;cursor:pointer;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.nav-btn:hover{color:#374151}.nav-btn.active{background:#fff;box-shadow:0 1px 3px 0 #0000001a;color:#3b82f6}.nav-indicator{background:#3b82f6;border-radius:2px;bottom:-2px;height:3px;left:50%;position:absolute;transform:translateX(-50%);width:20px}.header-right{gap:1rem}.add-patient-btn,.header-right{align-items:center;display:flex}.add-patient-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.add-patient-btn:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190)}.notification-btn{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#64748b;cursor:pointer;padding:.75rem;position:relative;transition:all .3s ease}.notification-btn:hover{background:#f1f5f9;color:#374151}.notification-badge{align-items:center;background:#ef4444;border-radius:50%;color:#fff;display:flex;font-size:.75rem;font-weight:700;height:18px;justify-content:center;position:absolute;right:-5px;top:-5px;width:18px}.user-menu-container{position:relative}.user-btn{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#374151;cursor:pointer;display:flex;gap:.75rem;padding:.5rem .75rem;transition:all .3s ease}.user-btn:hover{background:#f1f5f9}.user-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;height:32px;justify-content:center;width:32px}.user-name{font-weight:500}.user-dropdown{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a;margin-top:.5rem;min-width:200px;overflow:hidden;position:absolute;right:0;top:100%;z-index:1000}.dropdown-item{align-items:center;background:#fff;border:none;color:#374151;cursor:pointer;display:flex;gap:.75rem;padding:.75rem 1rem;text-align:left;transition:all .3s ease;width:100%}.dropdown-item:hover{background:#f8fafc}.progress-bar{background:linear-gradient(90deg,#3b82f6,#8b5cf6,#ec4899);bottom:0;height:3px;left:0;position:absolute;right:0;transform-origin:left}@media (max-width:1024px){.navigation span{display:none}.nav-btn{padding:.75rem}}@media (max-width:768px){.header-content{padding:0 1rem}.add-patient-btn span,.user-name{display:none}.add-patient-btn{padding:.75rem}.logo-text{display:none}}@media (max-width:480px){.header-right{gap:.5rem}.notification-btn{padding:.5rem}}.mobile-bottom-nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border-top:1px solid #e2e8f0;bottom:0;box-shadow:0 -4px 6px -1px #0000001a;display:flex;left:0;padding:.5rem;position:fixed;right:0;z-index:1000}.nav-item{align-items:center;background:none;border:none;color:#64748b;cursor:pointer;display:flex;flex:1 1;flex-direction:column;gap:.25rem;min-height:60px;padding:.5rem;position:relative}.nav-item.active{color:#3b82f6}.nav-icon{align-items:center;display:flex;height:40px;justify-content:center;position:relative;width:40px}.active-indicator{background:#3b82f6;border-radius:50%;height:8px;position:absolute;right:-2px;top:-2px;width:8px}.nav-label{font-size:.75rem;font-weight:500}.fab{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;box-shadow:0 4px 12px #667eea66;color:#fff;cursor:pointer;display:flex;height:56px;justify-content:center;left:50%;position:absolute;top:-20px;transform:translateX(-50%);width:56px;z-index:1001}@media (min-width:769px){.mobile-bottom-nav{display:none}}@supports (padding:max(0px)){.mobile-bottom-nav{padding-bottom:max(.5rem,env(safe-area-inset-bottom))}}.loading-screen{overflow:hidden;position:relative}.loading-container{position:relative;text-align:center;z-index:10}.loading-logo{margin-bottom:2rem}.loading-logo .logo-icon{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #fff3;border-radius:50%;box-shadow:0 8px 32px #0000001a,inset 0 1px 0 #fff3;display:flex;font-size:4rem;height:120px;justify-content:center;margin:0 auto;width:120px}.loading-text h2{-webkit-text-fill-color:#0000;background:linear-gradient(45deg,#fff,#e0e7ff);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:700;margin-bottom:1rem;text-shadow:0 2px 4px #0000001a}.loading-text p{font-size:1.1rem;margin-bottom:2rem;opacity:.9}.loading-progress-container{margin:0 auto 2rem;width:300px}.loading-progress-bar{background:#fff3;height:6px;overflow:hidden}.loading-progress-bar,.progress-fill{border-radius:3px;position:relative;width:100%}.progress-fill{background:linear-gradient(90deg,#ff6b6b,#ffd93d,#6bcf7f,#4d96ff);height:100%;transform-origin:left}.progress-fill:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#fff6,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@keyframes shimmer{0%{left:-100%}to{left:100%}}.loading-dots{font-size:2rem;letter-spacing:.5rem;margin-bottom:1rem}.loading-dots span{display:inline-block}.loading-particles{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.particle{background:#fff9;border-radius:50%;height:8px;left:50%;position:absolute;top:50%;width:8px}.loading-screen:before{animation:pulseGlow 3s ease-in-out infinite;background:radial-gradient(circle at center,#0000 0,#ffffff1a 100%);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes pulseGlow{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.02)}}@media (max-width:768px){.loading-text h2{font-size:2rem}.loading-logo .logo-icon{font-size:3rem;height:100px;width:100px}.loading-progress-container{width:250px}}@media (prefers-reduced-motion:reduce){.loading-dots span,.loading-logo,.loading-logo .logo-icon,.loading-screen:before,.particle,.progress-fill{animation:none!important}}@media (max-width:768px){.action-btn,.btn-primary,.btn-secondary,.nav-btn,.view-details-btn,button{min-height:44px!important;min-width:44px!important}.stats-grid{gap:1rem!important}.recent-activity,.stats-grid{grid-template-columns:1fr!important}.recent-activity{gap:1.5rem!important}.patients-grid{grid-template-columns:1fr!important}.dashboard,.patient-details,.patient-list,.reports{padding:1rem!important}.dashboard-header h1,.details-header h1,.patient-list-header h1,.reports-header h1{font-size:1.75rem!important}input,select,textarea{font-size:16px!important}}@media (min-width:769px) and (max-width:1024px){.patients-grid,.stats-grid{grid-template-columns:repeat(2,1fr)!important}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;color:#1e293b;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}.App{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1;padding-top:0}html{scroll-behavior:smooth}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}button:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@media (max-width:768px){.main-content{padding-bottom:80px}}@media (hover:none) and (pointer:coarse){.activity-item,.nav-btn,.patient-card,button{min-height:44px;min-width:44px}.stat-card{padding:1.5rem 1rem}.activity-item{padding:1rem .75rem}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast:high){.activity-card,.stat-card{border:2px solid #000}}.loading-screen{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;height:100vh;justify-content:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;margin-bottom:1rem;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-screen p{font-size:1.2rem;font-weight:600}
/*# sourceMappingURL=main.748b2437.css.map*/